123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300930193029303930493059306930793089309931093119312931393149315931693179318931993209321932293239324932593269327932893299330933193329333933493359336933793389339934093419342934393449345934693479348934993509351935293539354935593569357935893599360936193629363936493659366936793689369937093719372937393749375937693779378937993809381938293839384938593869387938893899390939193929393939493959396939793989399940094019402940394049405940694079408940994109411941294139414941594169417941894199420942194229423942494259426942794289429943094319432943394349435943694379438943994409441944294439444944594469447944894499450945194529453945494559456945794589459946094619462946394649465946694679468946994709471947294739474947594769477947894799480948194829483948494859486948794889489949094919492949394949495949694979498949995009501950295039504950595069507950895099510951195129513951495159516951795189519952095219522952395249525952695279528952995309531953295339534953595369537953895399540954195429543954495459546954795489549955095519552955395549555955695579558955995609561956295639564956595669567956895699570957195729573957495759576957795789579958095819582958395849585958695879588958995909591959295939594959595969597959895999600960196029603960496059606960796089609961096119612961396149615961696179618961996209621962296239624962596269627962896299630963196329633963496359636963796389639964096419642964396449645964696479648964996509651965296539654965596569657965896599660966196629663966496659666966796689669967096719672967396749675967696779678967996809681968296839684968596869687968896899690969196929693969496959696969796989699970097019702970397049705970697079708970997109711971297139714971597169717971897199720972197229723972497259726972797289729973097319732973397349735973697379738973997409741974297439744974597469747974897499750975197529753975497559756975797589759976097619762976397649765976697679768976997709771977297739774977597769777977897799780978197829783978497859786978797889789979097919792979397949795979697979798979998009801980298039804980598069807980898099810981198129813981498159816981798189819982098219822982398249825982698279828982998309831983298339834983598369837983898399840984198429843984498459846984798489849985098519852985398549855985698579858985998609861986298639864986598669867986898699870987198729873987498759876987798789879988098819882988398849885988698879888988998909891989298939894989598969897989898999900990199029903990499059906990799089909991099119912991399149915991699179918991999209921992299239924992599269927992899299930993199329933993499359936993799389939994099419942994399449945994699479948994999509951995299539954995599569957995899599960996199629963996499659966996799689969997099719972997399749975997699779978997999809981998299839984998599869987998899899990999199929993999499959996999799989999100001000110002100031000410005100061000710008100091001010011100121001310014100151001610017100181001910020100211002210023100241002510026100271002810029100301003110032100331003410035100361003710038100391004010041100421004310044100451004610047100481004910050100511005210053100541005510056100571005810059100601006110062100631006410065100661006710068100691007010071100721007310074100751007610077100781007910080100811008210083100841008510086100871008810089100901009110092100931009410095100961009710098100991010010101101021010310104101051010610107101081010910110101111011210113101141011510116101171011810119101201012110122101231012410125101261012710128101291013010131101321013310134101351013610137101381013910140101411014210143101441014510146101471014810149101501015110152101531015410155101561015710158101591016010161101621016310164101651016610167101681016910170101711017210173101741017510176101771017810179101801018110182101831018410185101861018710188101891019010191101921019310194101951019610197101981019910200102011020210203102041020510206102071020810209102101021110212102131021410215102161021710218102191022010221102221022310224102251022610227102281022910230102311023210233102341023510236102371023810239102401024110242102431024410245102461024710248102491025010251102521025310254102551025610257102581025910260102611026210263102641026510266102671026810269102701027110272102731027410275102761027710278102791028010281102821028310284102851028610287102881028910290102911029210293102941029510296102971029810299103001030110302103031030410305103061030710308103091031010311103121031310314103151031610317103181031910320103211032210323103241032510326103271032810329103301033110332103331033410335103361033710338103391034010341103421034310344103451034610347103481034910350103511035210353103541035510356103571035810359103601036110362103631036410365103661036710368103691037010371103721037310374103751037610377103781037910380103811038210383103841038510386103871038810389103901039110392103931039410395103961039710398103991040010401104021040310404104051040610407104081040910410104111041210413104141041510416104171041810419104201042110422104231042410425104261042710428104291043010431104321043310434104351043610437104381043910440104411044210443104441044510446104471044810449104501045110452104531045410455104561045710458104591046010461104621046310464104651046610467104681046910470104711047210473104741047510476104771047810479104801048110482104831048410485104861048710488104891049010491104921049310494104951049610497104981049910500105011050210503105041050510506105071050810509105101051110512105131051410515105161051710518105191052010521105221052310524105251052610527105281052910530105311053210533105341053510536105371053810539105401054110542105431054410545105461054710548105491055010551105521055310554105551055610557105581055910560105611056210563105641056510566105671056810569105701057110572105731057410575105761057710578105791058010581105821058310584105851058610587105881058910590105911059210593105941059510596105971059810599106001060110602106031060410605106061060710608106091061010611106121061310614106151061610617106181061910620106211062210623106241062510626106271062810629106301063110632106331063410635106361063710638106391064010641106421064310644106451064610647106481064910650106511065210653106541065510656106571065810659106601066110662106631066410665106661066710668106691067010671106721067310674106751067610677106781067910680106811068210683106841068510686106871068810689106901069110692106931069410695106961069710698106991070010701107021070310704107051070610707107081070910710107111071210713107141071510716107171071810719107201072110722107231072410725107261072710728107291073010731107321073310734107351073610737107381073910740107411074210743107441074510746107471074810749107501075110752107531075410755107561075710758107591076010761107621076310764107651076610767107681076910770107711077210773107741077510776107771077810779107801078110782107831078410785107861078710788107891079010791107921079310794107951079610797107981079910800108011080210803108041080510806108071080810809108101081110812108131081410815108161081710818108191082010821108221082310824108251082610827108281082910830108311083210833108341083510836108371083810839108401084110842108431084410845108461084710848108491085010851108521085310854108551085610857108581085910860108611086210863108641086510866108671086810869108701087110872108731087410875108761087710878108791088010881108821088310884108851088610887108881088910890108911089210893108941089510896108971089810899109001090110902109031090410905109061090710908109091091010911109121091310914109151091610917109181091910920109211092210923109241092510926109271092810929109301093110932109331093410935109361093710938109391094010941109421094310944109451094610947109481094910950109511095210953109541095510956109571095810959109601096110962109631096410965109661096710968109691097010971109721097310974109751097610977109781097910980109811098210983109841098510986109871098810989109901099110992109931099410995109961099710998109991100011001110021100311004110051100611007110081100911010110111101211013110141101511016110171101811019110201102111022110231102411025110261102711028110291103011031110321103311034110351103611037110381103911040110411104211043110441104511046110471104811049110501105111052110531105411055110561105711058110591106011061110621106311064110651106611067110681106911070110711107211073110741107511076110771107811079110801108111082110831108411085110861108711088110891109011091110921109311094110951109611097110981109911100111011110211103111041110511106111071110811109111101111111112111131111411115111161111711118111191112011121111221112311124111251112611127111281112911130111311113211133111341113511136111371113811139111401114111142111431114411145111461114711148111491115011151111521115311154111551115611157111581115911160111611116211163111641116511166111671116811169111701117111172111731117411175111761117711178111791118011181111821118311184111851118611187111881118911190111911119211193111941119511196111971119811199112001120111202112031120411205112061120711208112091121011211112121121311214112151121611217112181121911220112211122211223112241122511226112271122811229112301123111232112331123411235112361123711238112391124011241112421124311244112451124611247112481124911250112511125211253112541125511256112571125811259112601126111262112631126411265112661126711268112691127011271112721127311274112751127611277112781127911280112811128211283112841128511286112871128811289112901129111292112931129411295112961129711298112991130011301113021130311304113051130611307113081130911310113111131211313113141131511316113171131811319113201132111322113231132411325113261132711328113291133011331113321133311334113351133611337113381133911340113411134211343113441134511346113471134811349113501135111352113531135411355113561135711358113591136011361113621136311364113651136611367113681136911370113711137211373113741137511376113771137811379113801138111382113831138411385113861138711388113891139011391113921139311394113951139611397113981139911400114011140211403114041140511406114071140811409114101141111412114131141411415114161141711418114191142011421114221142311424114251142611427114281142911430114311143211433114341143511436114371143811439114401144111442114431144411445114461144711448114491145011451114521145311454114551145611457114581145911460114611146211463114641146511466114671146811469114701147111472114731147411475114761147711478114791148011481114821148311484114851148611487114881148911490114911149211493114941149511496114971149811499115001150111502115031150411505115061150711508115091151011511115121151311514115151151611517115181151911520115211152211523115241152511526115271152811529115301153111532115331153411535115361153711538115391154011541115421154311544115451154611547115481154911550115511155211553115541155511556115571155811559115601156111562115631156411565115661156711568115691157011571115721157311574115751157611577115781157911580115811158211583115841158511586115871158811589115901159111592115931159411595115961159711598115991160011601116021160311604116051160611607116081160911610116111161211613116141161511616116171161811619116201162111622116231162411625116261162711628116291163011631116321163311634116351163611637116381163911640116411164211643116441164511646116471164811649116501165111652116531165411655116561165711658116591166011661116621166311664116651166611667116681166911670116711167211673116741167511676116771167811679116801168111682116831168411685116861168711688116891169011691116921169311694116951169611697116981169911700117011170211703117041170511706117071170811709117101171111712117131171411715117161171711718117191172011721117221172311724117251172611727117281172911730117311173211733117341173511736117371173811739117401174111742117431174411745117461174711748117491175011751117521175311754117551175611757117581175911760117611176211763117641176511766117671176811769117701177111772117731177411775117761177711778117791178011781117821178311784117851178611787117881178911790117911179211793117941179511796117971179811799118001180111802118031180411805118061180711808118091181011811118121181311814118151181611817118181181911820118211182211823118241182511826118271182811829118301183111832118331183411835118361183711838118391184011841118421184311844118451184611847118481184911850118511185211853118541185511856118571185811859118601186111862118631186411865118661186711868118691187011871118721187311874118751187611877118781187911880118811188211883118841188511886118871188811889118901189111892118931189411895118961189711898118991190011901119021190311904119051190611907119081190911910119111191211913119141191511916119171191811919119201192111922119231192411925119261192711928119291193011931119321193311934119351193611937119381193911940119411194211943119441194511946119471194811949119501195111952119531195411955119561195711958119591196011961119621196311964119651196611967119681196911970119711197211973119741197511976119771197811979119801198111982119831198411985119861198711988119891199011991119921199311994119951199611997119981199912000120011200212003120041200512006120071200812009120101201112012120131201412015120161201712018120191202012021120221202312024120251202612027120281202912030120311203212033120341203512036120371203812039120401204112042120431204412045120461204712048120491205012051120521205312054120551205612057120581205912060120611206212063120641206512066120671206812069120701207112072120731207412075120761207712078120791208012081120821208312084120851208612087120881208912090120911209212093120941209512096120971209812099121001210112102121031210412105121061210712108121091211012111121121211312114121151211612117121181211912120121211212212123121241212512126121271212812129121301213112132121331213412135121361213712138121391214012141121421214312144121451214612147121481214912150121511215212153121541215512156121571215812159121601216112162121631216412165121661216712168121691217012171121721217312174121751217612177121781217912180121811218212183121841218512186121871218812189121901219112192121931219412195121961219712198121991220012201122021220312204122051220612207122081220912210122111221212213122141221512216122171221812219122201222112222122231222412225122261222712228122291223012231122321223312234122351223612237122381223912240122411224212243122441224512246122471224812249122501225112252122531225412255122561225712258122591226012261122621226312264122651226612267122681226912270122711227212273122741227512276122771227812279122801228112282122831228412285122861228712288122891229012291122921229312294122951229612297122981229912300123011230212303123041230512306123071230812309123101231112312123131231412315123161231712318123191232012321123221232312324123251232612327123281232912330123311233212333123341233512336123371233812339123401234112342123431234412345123461234712348123491235012351123521235312354123551235612357123581235912360123611236212363123641236512366123671236812369123701237112372123731237412375123761237712378123791238012381123821238312384123851238612387123881238912390123911239212393123941239512396123971239812399124001240112402124031240412405124061240712408124091241012411124121241312414124151241612417124181241912420124211242212423124241242512426124271242812429124301243112432124331243412435124361243712438124391244012441124421244312444124451244612447124481244912450124511245212453124541245512456124571245812459124601246112462124631246412465124661246712468124691247012471124721247312474124751247612477124781247912480124811248212483124841248512486124871248812489124901249112492124931249412495124961249712498124991250012501125021250312504125051250612507125081250912510125111251212513125141251512516125171251812519125201252112522125231252412525125261252712528125291253012531125321253312534125351253612537125381253912540125411254212543125441254512546125471254812549125501255112552125531255412555125561255712558125591256012561125621256312564125651256612567125681256912570125711257212573125741257512576125771257812579125801258112582125831258412585125861258712588125891259012591125921259312594125951259612597125981259912600126011260212603126041260512606126071260812609126101261112612126131261412615126161261712618126191262012621126221262312624126251262612627126281262912630126311263212633126341263512636126371263812639126401264112642126431264412645126461264712648126491265012651126521265312654126551265612657126581265912660126611266212663126641266512666126671266812669126701267112672126731267412675126761267712678126791268012681126821268312684126851268612687126881268912690126911269212693126941269512696126971269812699127001270112702127031270412705127061270712708127091271012711127121271312714127151271612717127181271912720127211272212723127241272512726127271272812729127301273112732127331273412735127361273712738127391274012741127421274312744127451274612747127481274912750127511275212753127541275512756127571275812759127601276112762127631276412765127661276712768127691277012771127721277312774127751277612777127781277912780127811278212783127841278512786127871278812789127901279112792127931279412795127961279712798127991280012801128021280312804128051280612807128081280912810128111281212813128141281512816128171281812819128201282112822128231282412825128261282712828128291283012831128321283312834128351283612837128381283912840128411284212843128441284512846128471284812849128501285112852128531285412855128561285712858128591286012861128621286312864128651286612867128681286912870128711287212873128741287512876128771287812879128801288112882128831288412885128861288712888128891289012891128921289312894128951289612897128981289912900129011290212903129041290512906129071290812909129101291112912129131291412915129161291712918129191292012921129221292312924129251292612927129281292912930129311293212933129341293512936129371293812939129401294112942129431294412945129461294712948129491295012951129521295312954129551295612957129581295912960129611296212963129641296512966129671296812969129701297112972129731297412975129761297712978129791298012981129821298312984129851298612987129881298912990129911299212993129941299512996129971299812999130001300113002130031300413005130061300713008130091301013011130121301313014130151301613017130181301913020130211302213023130241302513026130271302813029130301303113032130331303413035130361303713038130391304013041130421304313044130451304613047130481304913050130511305213053130541305513056130571305813059130601306113062130631306413065130661306713068130691307013071130721307313074130751307613077130781307913080130811308213083130841308513086130871308813089130901309113092130931309413095130961309713098130991310013101131021310313104131051310613107131081310913110131111311213113131141311513116131171311813119131201312113122131231312413125131261312713128131291313013131131321313313134131351313613137131381313913140131411314213143131441314513146131471314813149131501315113152131531315413155131561315713158131591316013161131621316313164131651316613167131681316913170131711317213173131741317513176131771317813179131801318113182131831318413185131861318713188131891319013191131921319313194131951319613197131981319913200132011320213203132041320513206132071320813209132101321113212132131321413215132161321713218132191322013221132221322313224132251322613227132281322913230132311323213233132341323513236132371323813239132401324113242132431324413245132461324713248132491325013251132521325313254132551325613257132581325913260132611326213263132641326513266132671326813269132701327113272132731327413275132761327713278132791328013281132821328313284132851328613287132881328913290132911329213293132941329513296132971329813299133001330113302133031330413305133061330713308133091331013311133121331313314133151331613317133181331913320133211332213323133241332513326133271332813329133301333113332133331333413335133361333713338133391334013341133421334313344133451334613347133481334913350133511335213353133541335513356133571335813359133601336113362133631336413365133661336713368133691337013371133721337313374133751337613377133781337913380133811338213383133841338513386133871338813389133901339113392133931339413395133961339713398133991340013401134021340313404134051340613407134081340913410134111341213413134141341513416134171341813419134201342113422134231342413425134261342713428134291343013431134321343313434134351343613437134381343913440134411344213443134441344513446134471344813449134501345113452134531345413455134561345713458134591346013461134621346313464134651346613467134681346913470134711347213473134741347513476134771347813479134801348113482134831348413485134861348713488134891349013491134921349313494134951349613497134981349913500135011350213503135041350513506135071350813509135101351113512135131351413515135161351713518135191352013521135221352313524135251352613527135281352913530135311353213533135341353513536135371353813539135401354113542135431354413545135461354713548135491355013551135521355313554135551355613557135581355913560135611356213563135641356513566135671356813569135701357113572135731357413575135761357713578135791358013581135821358313584135851358613587135881358913590135911359213593135941359513596135971359813599136001360113602136031360413605136061360713608136091361013611136121361313614136151361613617136181361913620136211362213623136241362513626136271362813629136301363113632136331363413635136361363713638136391364013641136421364313644136451364613647136481364913650136511365213653136541365513656136571365813659136601366113662136631366413665136661366713668136691367013671136721367313674136751367613677136781367913680136811368213683136841368513686136871368813689136901369113692136931369413695136961369713698136991370013701137021370313704137051370613707137081370913710137111371213713137141371513716137171371813719137201372113722137231372413725137261372713728137291373013731137321373313734137351373613737137381373913740137411374213743137441374513746137471374813749137501375113752137531375413755137561375713758137591376013761137621376313764137651376613767137681376913770137711377213773137741377513776137771377813779137801378113782137831378413785137861378713788137891379013791137921379313794137951379613797137981379913800138011380213803138041380513806138071380813809138101381113812138131381413815138161381713818138191382013821138221382313824138251382613827138281382913830138311383213833138341383513836138371383813839138401384113842138431384413845138461384713848138491385013851138521385313854138551385613857138581385913860138611386213863138641386513866138671386813869138701387113872138731387413875138761387713878138791388013881138821388313884138851388613887138881388913890138911389213893138941389513896138971389813899139001390113902139031390413905139061390713908139091391013911139121391313914139151391613917139181391913920139211392213923139241392513926139271392813929139301393113932139331393413935139361393713938139391394013941139421394313944139451394613947139481394913950139511395213953139541395513956139571395813959139601396113962139631396413965139661396713968139691397013971139721397313974139751397613977139781397913980139811398213983139841398513986139871398813989139901399113992139931399413995139961399713998139991400014001140021400314004140051400614007140081400914010140111401214013140141401514016140171401814019140201402114022140231402414025140261402714028140291403014031140321403314034140351403614037140381403914040140411404214043140441404514046140471404814049140501405114052140531405414055140561405714058140591406014061140621406314064140651406614067140681406914070140711407214073140741407514076140771407814079140801408114082140831408414085140861408714088140891409014091140921409314094140951409614097140981409914100141011410214103141041410514106141071410814109141101411114112141131411414115141161411714118141191412014121141221412314124141251412614127141281412914130141311413214133141341413514136141371413814139141401414114142141431414414145141461414714148141491415014151141521415314154141551415614157141581415914160141611416214163141641416514166141671416814169141701417114172141731417414175141761417714178141791418014181141821418314184141851418614187141881418914190141911419214193141941419514196141971419814199142001420114202142031420414205142061420714208142091421014211142121421314214142151421614217142181421914220142211422214223142241422514226142271422814229142301423114232142331423414235142361423714238142391424014241142421424314244142451424614247142481424914250142511425214253142541425514256142571425814259142601426114262142631426414265142661426714268142691427014271142721427314274142751427614277142781427914280142811428214283142841428514286142871428814289142901429114292142931429414295142961429714298142991430014301143021430314304143051430614307143081430914310143111431214313143141431514316143171431814319143201432114322143231432414325143261432714328143291433014331143321433314334143351433614337143381433914340143411434214343143441434514346143471434814349143501435114352143531435414355143561435714358143591436014361143621436314364143651436614367143681436914370143711437214373143741437514376143771437814379143801438114382143831438414385143861438714388143891439014391143921439314394143951439614397143981439914400144011440214403144041440514406144071440814409144101441114412144131441414415144161441714418144191442014421144221442314424144251442614427144281442914430144311443214433144341443514436144371443814439144401444114442144431444414445144461444714448144491445014451144521445314454144551445614457144581445914460144611446214463144641446514466144671446814469144701447114472144731447414475144761447714478144791448014481144821448314484144851448614487144881448914490144911449214493144941449514496144971449814499145001450114502145031450414505145061450714508145091451014511145121451314514145151451614517145181451914520145211452214523145241452514526145271452814529145301453114532145331453414535145361453714538145391454014541145421454314544145451454614547145481454914550145511455214553145541455514556145571455814559145601456114562145631456414565145661456714568145691457014571145721457314574145751457614577145781457914580145811458214583145841458514586145871458814589145901459114592145931459414595145961459714598145991460014601146021460314604146051460614607146081460914610146111461214613146141461514616146171461814619146201462114622146231462414625146261462714628146291463014631146321463314634146351463614637146381463914640146411464214643146441464514646146471464814649146501465114652146531465414655146561465714658146591466014661146621466314664146651466614667146681466914670146711467214673146741467514676146771467814679146801468114682146831468414685146861468714688146891469014691146921469314694146951469614697146981469914700147011470214703147041470514706147071470814709147101471114712147131471414715147161471714718147191472014721147221472314724147251472614727147281472914730147311473214733147341473514736147371473814739147401474114742147431474414745147461474714748147491475014751147521475314754147551475614757147581475914760147611476214763147641476514766147671476814769147701477114772147731477414775147761477714778147791478014781147821478314784147851478614787147881478914790147911479214793147941479514796147971479814799148001480114802148031480414805148061480714808148091481014811148121481314814148151481614817148181481914820148211482214823148241482514826148271482814829148301483114832148331483414835148361483714838148391484014841148421484314844148451484614847148481484914850148511485214853148541485514856148571485814859148601486114862148631486414865148661486714868148691487014871148721487314874148751487614877148781487914880148811488214883148841488514886148871488814889148901489114892148931489414895148961489714898148991490014901149021490314904149051490614907149081490914910149111491214913149141491514916149171491814919149201492114922149231492414925149261492714928149291493014931149321493314934149351493614937149381493914940149411494214943149441494514946149471494814949149501495114952149531495414955149561495714958149591496014961149621496314964149651496614967149681496914970149711497214973149741497514976149771497814979149801498114982149831498414985149861498714988149891499014991149921499314994149951499614997149981499915000150011500215003150041500515006150071500815009150101501115012150131501415015150161501715018150191502015021150221502315024150251502615027150281502915030150311503215033150341503515036150371503815039150401504115042150431504415045150461504715048150491505015051150521505315054150551505615057150581505915060150611506215063150641506515066150671506815069150701507115072150731507415075150761507715078150791508015081150821508315084150851508615087150881508915090150911509215093150941509515096150971509815099151001510115102151031510415105151061510715108151091511015111151121511315114151151511615117151181511915120151211512215123151241512515126151271512815129151301513115132151331513415135151361513715138151391514015141151421514315144151451514615147151481514915150151511515215153151541515515156151571515815159151601516115162151631516415165151661516715168151691517015171151721517315174151751517615177151781517915180151811518215183151841518515186151871518815189151901519115192151931519415195151961519715198151991520015201152021520315204152051520615207152081520915210152111521215213152141521515216152171521815219152201522115222152231522415225152261522715228152291523015231152321523315234152351523615237152381523915240152411524215243152441524515246152471524815249152501525115252152531525415255152561525715258152591526015261152621526315264152651526615267152681526915270152711527215273152741527515276152771527815279152801528115282152831528415285152861528715288152891529015291152921529315294152951529615297152981529915300153011530215303153041530515306153071530815309153101531115312153131531415315153161531715318153191532015321153221532315324153251532615327153281532915330153311533215333153341533515336153371533815339153401534115342153431534415345153461534715348153491535015351153521535315354153551535615357153581535915360153611536215363153641536515366153671536815369153701537115372153731537415375153761537715378153791538015381153821538315384153851538615387153881538915390153911539215393153941539515396153971539815399154001540115402154031540415405154061540715408154091541015411154121541315414154151541615417154181541915420154211542215423154241542515426154271542815429154301543115432154331543415435154361543715438154391544015441154421544315444154451544615447154481544915450154511545215453154541545515456154571545815459154601546115462154631546415465154661546715468154691547015471154721547315474154751547615477154781547915480154811548215483154841548515486154871548815489154901549115492154931549415495154961549715498154991550015501155021550315504155051550615507155081550915510155111551215513155141551515516155171551815519155201552115522155231552415525155261552715528155291553015531155321553315534155351553615537155381553915540155411554215543155441554515546155471554815549155501555115552155531555415555155561555715558155591556015561155621556315564155651556615567155681556915570155711557215573155741557515576155771557815579155801558115582155831558415585155861558715588155891559015591155921559315594155951559615597155981559915600156011560215603156041560515606156071560815609156101561115612156131561415615156161561715618156191562015621156221562315624156251562615627156281562915630156311563215633156341563515636156371563815639156401564115642156431564415645156461564715648156491565015651156521565315654156551565615657156581565915660156611566215663156641566515666156671566815669156701567115672156731567415675156761567715678156791568015681156821568315684156851568615687156881568915690156911569215693156941569515696156971569815699157001570115702157031570415705157061570715708157091571015711157121571315714157151571615717157181571915720157211572215723157241572515726157271572815729157301573115732157331573415735157361573715738157391574015741157421574315744157451574615747157481574915750157511575215753157541575515756157571575815759157601576115762157631576415765157661576715768157691577015771157721577315774157751577615777157781577915780157811578215783157841578515786157871578815789157901579115792157931579415795157961579715798157991580015801158021580315804158051580615807158081580915810158111581215813158141581515816158171581815819158201582115822158231582415825158261582715828158291583015831158321583315834158351583615837158381583915840158411584215843158441584515846158471584815849158501585115852158531585415855158561585715858158591586015861158621586315864158651586615867158681586915870158711587215873158741587515876158771587815879158801588115882158831588415885158861588715888158891589015891158921589315894158951589615897158981589915900159011590215903159041590515906159071590815909159101591115912159131591415915159161591715918159191592015921159221592315924159251592615927159281592915930159311593215933159341593515936159371593815939159401594115942159431594415945159461594715948159491595015951159521595315954159551595615957159581595915960159611596215963159641596515966159671596815969159701597115972159731597415975159761597715978159791598015981159821598315984159851598615987159881598915990159911599215993159941599515996159971599815999160001600116002160031600416005160061600716008160091601016011160121601316014160151601616017160181601916020160211602216023160241602516026160271602816029160301603116032160331603416035160361603716038160391604016041160421604316044160451604616047160481604916050160511605216053160541605516056160571605816059160601606116062160631606416065160661606716068160691607016071160721607316074160751607616077160781607916080160811608216083160841608516086160871608816089160901609116092160931609416095160961609716098160991610016101161021610316104161051610616107161081610916110161111611216113161141611516116161171611816119161201612116122161231612416125161261612716128161291613016131161321613316134161351613616137161381613916140161411614216143161441614516146161471614816149161501615116152161531615416155161561615716158161591616016161161621616316164161651616616167161681616916170161711617216173161741617516176161771617816179161801618116182161831618416185161861618716188161891619016191161921619316194161951619616197161981619916200162011620216203162041620516206162071620816209162101621116212162131621416215162161621716218162191622016221162221622316224162251622616227162281622916230162311623216233162341623516236162371623816239162401624116242162431624416245162461624716248162491625016251162521625316254162551625616257162581625916260162611626216263162641626516266162671626816269162701627116272162731627416275162761627716278162791628016281162821628316284162851628616287162881628916290162911629216293162941629516296162971629816299163001630116302163031630416305163061630716308163091631016311163121631316314163151631616317163181631916320163211632216323163241632516326163271632816329163301633116332163331633416335163361633716338163391634016341163421634316344163451634616347163481634916350163511635216353163541635516356163571635816359163601636116362163631636416365163661636716368163691637016371163721637316374163751637616377163781637916380163811638216383163841638516386163871638816389163901639116392163931639416395163961639716398163991640016401164021640316404164051640616407164081640916410164111641216413164141641516416164171641816419164201642116422164231642416425164261642716428164291643016431164321643316434164351643616437164381643916440164411644216443164441644516446164471644816449164501645116452164531645416455164561645716458164591646016461164621646316464164651646616467164681646916470164711647216473164741647516476164771647816479164801648116482164831648416485164861648716488164891649016491164921649316494164951649616497164981649916500165011650216503165041650516506165071650816509165101651116512165131651416515165161651716518165191652016521165221652316524165251652616527165281652916530165311653216533165341653516536165371653816539165401654116542165431654416545165461654716548165491655016551165521655316554165551655616557165581655916560165611656216563165641656516566165671656816569165701657116572165731657416575165761657716578165791658016581165821658316584165851658616587165881658916590165911659216593165941659516596165971659816599166001660116602166031660416605166061660716608166091661016611166121661316614166151661616617166181661916620166211662216623166241662516626166271662816629166301663116632166331663416635166361663716638166391664016641166421664316644166451664616647166481664916650166511665216653166541665516656166571665816659166601666116662166631666416665166661666716668166691667016671166721667316674166751667616677166781667916680166811668216683166841668516686166871668816689166901669116692166931669416695166961669716698166991670016701167021670316704167051670616707167081670916710167111671216713167141671516716167171671816719167201672116722167231672416725167261672716728167291673016731167321673316734167351673616737167381673916740167411674216743167441674516746167471674816749167501675116752167531675416755167561675716758167591676016761167621676316764167651676616767167681676916770167711677216773167741677516776167771677816779167801678116782167831678416785167861678716788167891679016791167921679316794167951679616797167981679916800168011680216803168041680516806168071680816809168101681116812168131681416815168161681716818168191682016821168221682316824168251682616827168281682916830168311683216833168341683516836168371683816839168401684116842168431684416845168461684716848168491685016851168521685316854168551685616857168581685916860168611686216863168641686516866168671686816869168701687116872168731687416875168761687716878168791688016881168821688316884168851688616887168881688916890168911689216893168941689516896168971689816899169001690116902169031690416905169061690716908169091691016911169121691316914169151691616917169181691916920169211692216923169241692516926169271692816929169301693116932169331693416935169361693716938169391694016941169421694316944169451694616947169481694916950169511695216953169541695516956169571695816959169601696116962169631696416965169661696716968169691697016971169721697316974169751697616977169781697916980169811698216983169841698516986169871698816989169901699116992169931699416995169961699716998169991700017001170021700317004170051700617007170081700917010170111701217013170141701517016170171701817019170201702117022170231702417025170261702717028170291703017031170321703317034170351703617037170381703917040170411704217043170441704517046170471704817049170501705117052170531705417055170561705717058170591706017061170621706317064170651706617067170681706917070170711707217073170741707517076170771707817079170801708117082170831708417085170861708717088170891709017091170921709317094170951709617097170981709917100171011710217103171041710517106171071710817109171101711117112171131711417115171161711717118171191712017121171221712317124171251712617127171281712917130171311713217133171341713517136171371713817139171401714117142171431714417145171461714717148171491715017151171521715317154171551715617157171581715917160171611716217163171641716517166171671716817169171701717117172171731717417175171761717717178171791718017181171821718317184171851718617187171881718917190171911719217193171941719517196171971719817199172001720117202172031720417205172061720717208172091721017211172121721317214172151721617217172181721917220172211722217223172241722517226172271722817229172301723117232172331723417235172361723717238172391724017241172421724317244172451724617247172481724917250172511725217253172541725517256172571725817259172601726117262172631726417265172661726717268172691727017271172721727317274172751727617277172781727917280172811728217283172841728517286172871728817289172901729117292172931729417295172961729717298172991730017301173021730317304173051730617307173081730917310173111731217313173141731517316173171731817319173201732117322173231732417325173261732717328173291733017331173321733317334173351733617337173381733917340173411734217343173441734517346173471734817349173501735117352173531735417355173561735717358173591736017361173621736317364173651736617367173681736917370173711737217373173741737517376173771737817379173801738117382173831738417385173861738717388173891739017391173921739317394173951739617397173981739917400174011740217403174041740517406174071740817409174101741117412174131741417415174161741717418174191742017421174221742317424174251742617427174281742917430174311743217433174341743517436174371743817439174401744117442174431744417445174461744717448174491745017451174521745317454174551745617457174581745917460174611746217463174641746517466174671746817469174701747117472174731747417475174761747717478174791748017481174821748317484174851748617487174881748917490174911749217493174941749517496174971749817499175001750117502175031750417505175061750717508175091751017511175121751317514175151751617517175181751917520175211752217523175241752517526175271752817529175301753117532175331753417535175361753717538175391754017541175421754317544175451754617547175481754917550175511755217553175541755517556175571755817559175601756117562175631756417565175661756717568175691757017571175721757317574175751757617577175781757917580175811758217583175841758517586175871758817589175901759117592175931759417595175961759717598175991760017601176021760317604176051760617607176081760917610176111761217613176141761517616176171761817619176201762117622176231762417625176261762717628176291763017631176321763317634176351763617637176381763917640176411764217643176441764517646176471764817649176501765117652176531765417655176561765717658176591766017661176621766317664176651766617667176681766917670176711767217673176741767517676176771767817679176801768117682176831768417685176861768717688176891769017691176921769317694176951769617697176981769917700177011770217703177041770517706177071770817709177101771117712177131771417715177161771717718177191772017721177221772317724177251772617727177281772917730177311773217733177341773517736177371773817739177401774117742177431774417745177461774717748177491775017751177521775317754177551775617757177581775917760177611776217763177641776517766177671776817769177701777117772177731777417775177761777717778177791778017781177821778317784177851778617787177881778917790177911779217793177941779517796177971779817799178001780117802178031780417805178061780717808178091781017811178121781317814178151781617817178181781917820178211782217823178241782517826178271782817829178301783117832178331783417835178361783717838178391784017841178421784317844178451784617847178481784917850178511785217853178541785517856178571785817859178601786117862178631786417865178661786717868178691787017871178721787317874178751787617877178781787917880178811788217883178841788517886178871788817889178901789117892178931789417895178961789717898178991790017901179021790317904179051790617907179081790917910179111791217913179141791517916179171791817919179201792117922179231792417925179261792717928179291793017931179321793317934179351793617937179381793917940179411794217943179441794517946179471794817949179501795117952179531795417955179561795717958179591796017961179621796317964179651796617967179681796917970179711797217973179741797517976179771797817979179801798117982179831798417985179861798717988179891799017991179921799317994179951799617997179981799918000180011800218003180041800518006180071800818009180101801118012180131801418015180161801718018180191802018021180221802318024180251802618027180281802918030180311803218033180341803518036180371803818039180401804118042180431804418045180461804718048180491805018051180521805318054180551805618057180581805918060180611806218063180641806518066180671806818069180701807118072180731807418075180761807718078180791808018081180821808318084180851808618087180881808918090180911809218093180941809518096180971809818099181001810118102181031810418105181061810718108181091811018111181121811318114181151811618117181181811918120181211812218123181241812518126181271812818129181301813118132181331813418135181361813718138181391814018141181421814318144181451814618147181481814918150181511815218153181541815518156181571815818159181601816118162181631816418165181661816718168181691817018171181721817318174181751817618177181781817918180181811818218183181841818518186181871818818189181901819118192181931819418195181961819718198181991820018201182021820318204182051820618207182081820918210182111821218213182141821518216182171821818219182201822118222182231822418225182261822718228182291823018231182321823318234182351823618237182381823918240182411824218243182441824518246182471824818249182501825118252182531825418255182561825718258182591826018261182621826318264182651826618267182681826918270182711827218273182741827518276182771827818279182801828118282182831828418285182861828718288182891829018291182921829318294182951829618297182981829918300183011830218303183041830518306183071830818309183101831118312183131831418315183161831718318183191832018321183221832318324183251832618327183281832918330183311833218333183341833518336183371833818339183401834118342183431834418345183461834718348183491835018351183521835318354183551835618357183581835918360183611836218363183641836518366183671836818369183701837118372183731837418375183761837718378183791838018381183821838318384183851838618387183881838918390183911839218393183941839518396183971839818399184001840118402184031840418405184061840718408184091841018411184121841318414184151841618417184181841918420184211842218423184241842518426184271842818429184301843118432184331843418435184361843718438184391844018441184421844318444184451844618447184481844918450184511845218453184541845518456184571845818459184601846118462184631846418465184661846718468184691847018471184721847318474184751847618477184781847918480184811848218483184841848518486184871848818489184901849118492184931849418495184961849718498184991850018501185021850318504185051850618507185081850918510185111851218513185141851518516185171851818519185201852118522185231852418525185261852718528185291853018531185321853318534185351853618537185381853918540185411854218543185441854518546185471854818549185501855118552185531855418555185561855718558185591856018561185621856318564185651856618567185681856918570185711857218573185741857518576185771857818579185801858118582185831858418585185861858718588185891859018591185921859318594185951859618597185981859918600186011860218603186041860518606186071860818609186101861118612186131861418615186161861718618186191862018621186221862318624186251862618627186281862918630186311863218633186341863518636186371863818639186401864118642186431864418645186461864718648186491865018651186521865318654186551865618657186581865918660186611866218663186641866518666186671866818669186701867118672186731867418675186761867718678186791868018681186821868318684186851868618687186881868918690186911869218693186941869518696186971869818699187001870118702187031870418705187061870718708187091871018711187121871318714187151871618717187181871918720187211872218723187241872518726187271872818729187301873118732187331873418735187361873718738187391874018741187421874318744187451874618747187481874918750187511875218753187541875518756187571875818759187601876118762187631876418765187661876718768187691877018771187721877318774187751877618777187781877918780187811878218783187841878518786187871878818789187901879118792187931879418795187961879718798187991880018801188021880318804188051880618807188081880918810188111881218813188141881518816188171881818819188201882118822188231882418825188261882718828188291883018831188321883318834188351883618837188381883918840188411884218843188441884518846188471884818849188501885118852188531885418855188561885718858188591886018861188621886318864188651886618867188681886918870188711887218873188741887518876188771887818879188801888118882188831888418885188861888718888188891889018891188921889318894188951889618897188981889918900189011890218903189041890518906189071890818909189101891118912189131891418915189161891718918189191892018921189221892318924189251892618927189281892918930189311893218933189341893518936189371893818939189401894118942189431894418945189461894718948189491895018951189521895318954189551895618957189581895918960189611896218963189641896518966189671896818969189701897118972189731897418975189761897718978189791898018981189821898318984189851898618987189881898918990189911899218993189941899518996189971899818999190001900119002190031900419005190061900719008190091901019011190121901319014190151901619017190181901919020190211902219023190241902519026190271902819029190301903119032190331903419035190361903719038190391904019041190421904319044190451904619047190481904919050190511905219053190541905519056190571905819059190601906119062190631906419065190661906719068190691907019071190721907319074190751907619077190781907919080190811908219083190841908519086190871908819089190901909119092190931909419095190961909719098190991910019101191021910319104191051910619107191081910919110191111911219113191141911519116191171911819119191201912119122191231912419125191261912719128191291913019131191321913319134191351913619137191381913919140191411914219143191441914519146191471914819149191501915119152191531915419155191561915719158191591916019161191621916319164191651916619167191681916919170191711917219173191741917519176191771917819179191801918119182191831918419185191861918719188191891919019191191921919319194191951919619197191981919919200192011920219203192041920519206192071920819209192101921119212192131921419215192161921719218192191922019221192221922319224192251922619227192281922919230192311923219233192341923519236192371923819239192401924119242192431924419245192461924719248192491925019251192521925319254192551925619257192581925919260192611926219263192641926519266192671926819269192701927119272192731927419275192761927719278192791928019281192821928319284192851928619287192881928919290192911929219293192941929519296192971929819299193001930119302193031930419305193061930719308193091931019311193121931319314193151931619317193181931919320193211932219323193241932519326193271932819329193301933119332193331933419335193361933719338193391934019341193421934319344193451934619347193481934919350193511935219353193541935519356193571935819359193601936119362193631936419365193661936719368193691937019371193721937319374193751937619377193781937919380193811938219383193841938519386193871938819389193901939119392193931939419395193961939719398193991940019401194021940319404194051940619407194081940919410194111941219413194141941519416194171941819419194201942119422194231942419425194261942719428194291943019431194321943319434194351943619437194381943919440194411944219443194441944519446194471944819449194501945119452194531945419455194561945719458194591946019461194621946319464194651946619467194681946919470194711947219473194741947519476194771947819479194801948119482194831948419485194861948719488194891949019491194921949319494194951949619497194981949919500195011950219503195041950519506195071950819509195101951119512195131951419515195161951719518195191952019521195221952319524195251952619527195281952919530195311953219533195341953519536195371953819539195401954119542195431954419545195461954719548195491955019551195521955319554195551955619557195581955919560195611956219563195641956519566195671956819569195701957119572195731957419575195761957719578195791958019581195821958319584195851958619587195881958919590195911959219593195941959519596195971959819599196001960119602196031960419605196061960719608196091961019611196121961319614196151961619617196181961919620196211962219623196241962519626196271962819629196301963119632196331963419635196361963719638196391964019641196421964319644196451964619647196481964919650196511965219653196541965519656196571965819659196601966119662196631966419665196661966719668196691967019671196721967319674196751967619677196781967919680196811968219683196841968519686196871968819689196901969119692196931969419695196961969719698196991970019701197021970319704197051970619707197081970919710197111971219713197141971519716197171971819719197201972119722197231972419725197261972719728197291973019731197321973319734197351973619737197381973919740197411974219743197441974519746197471974819749197501975119752197531975419755197561975719758197591976019761197621976319764197651976619767197681976919770197711977219773197741977519776197771977819779197801978119782197831978419785197861978719788197891979019791197921979319794197951979619797197981979919800198011980219803198041980519806198071980819809198101981119812198131981419815198161981719818198191982019821198221982319824198251982619827198281982919830198311983219833198341983519836198371983819839198401984119842198431984419845198461984719848198491985019851198521985319854198551985619857198581985919860198611986219863198641986519866198671986819869198701987119872198731987419875198761987719878198791988019881198821988319884198851988619887198881988919890198911989219893198941989519896198971989819899199001990119902199031990419905199061990719908199091991019911199121991319914199151991619917199181991919920199211992219923199241992519926199271992819929199301993119932199331993419935199361993719938199391994019941199421994319944199451994619947199481994919950199511995219953199541995519956199571995819959199601996119962199631996419965199661996719968199691997019971199721997319974199751997619977199781997919980199811998219983199841998519986199871998819989199901999119992199931999419995199961999719998199992000020001200022000320004200052000620007200082000920010200112001220013200142001520016200172001820019200202002120022200232002420025200262002720028200292003020031200322003320034200352003620037200382003920040200412004220043200442004520046200472004820049200502005120052200532005420055200562005720058200592006020061200622006320064200652006620067200682006920070200712007220073200742007520076200772007820079200802008120082200832008420085200862008720088200892009020091200922009320094200952009620097200982009920100201012010220103201042010520106201072010820109201102011120112201132011420115201162011720118201192012020121201222012320124201252012620127201282012920130201312013220133201342013520136201372013820139201402014120142201432014420145201462014720148201492015020151201522015320154201552015620157201582015920160201612016220163201642016520166201672016820169201702017120172201732017420175201762017720178201792018020181201822018320184201852018620187201882018920190201912019220193201942019520196201972019820199202002020120202202032020420205202062020720208202092021020211202122021320214202152021620217202182021920220202212022220223202242022520226202272022820229202302023120232202332023420235202362023720238202392024020241202422024320244202452024620247202482024920250202512025220253202542025520256202572025820259202602026120262202632026420265202662026720268202692027020271202722027320274202752027620277202782027920280202812028220283202842028520286202872028820289202902029120292202932029420295202962029720298202992030020301203022030320304203052030620307203082030920310203112031220313203142031520316203172031820319203202032120322203232032420325203262032720328203292033020331203322033320334203352033620337203382033920340203412034220343203442034520346203472034820349203502035120352203532035420355203562035720358203592036020361203622036320364203652036620367203682036920370203712037220373203742037520376203772037820379203802038120382203832038420385203862038720388203892039020391203922039320394203952039620397203982039920400204012040220403204042040520406204072040820409204102041120412204132041420415204162041720418204192042020421204222042320424204252042620427204282042920430204312043220433204342043520436204372043820439204402044120442204432044420445204462044720448204492045020451204522045320454204552045620457204582045920460204612046220463204642046520466204672046820469204702047120472204732047420475204762047720478204792048020481204822048320484204852048620487204882048920490204912049220493204942049520496204972049820499205002050120502205032050420505205062050720508205092051020511205122051320514205152051620517205182051920520205212052220523205242052520526205272052820529205302053120532205332053420535205362053720538205392054020541205422054320544205452054620547205482054920550205512055220553205542055520556205572055820559205602056120562205632056420565205662056720568205692057020571205722057320574205752057620577205782057920580205812058220583205842058520586205872058820589205902059120592205932059420595205962059720598205992060020601206022060320604206052060620607206082060920610206112061220613206142061520616206172061820619206202062120622206232062420625206262062720628206292063020631206322063320634206352063620637206382063920640206412064220643206442064520646206472064820649206502065120652206532065420655206562065720658206592066020661206622066320664206652066620667206682066920670206712067220673206742067520676206772067820679206802068120682206832068420685206862068720688206892069020691206922069320694206952069620697206982069920700207012070220703207042070520706207072070820709207102071120712207132071420715207162071720718207192072020721207222072320724207252072620727207282072920730207312073220733207342073520736207372073820739207402074120742207432074420745207462074720748207492075020751207522075320754207552075620757207582075920760207612076220763207642076520766207672076820769207702077120772207732077420775207762077720778207792078020781207822078320784207852078620787207882078920790207912079220793207942079520796207972079820799208002080120802208032080420805208062080720808208092081020811208122081320814208152081620817208182081920820208212082220823208242082520826208272082820829208302083120832208332083420835208362083720838208392084020841208422084320844208452084620847208482084920850208512085220853208542085520856208572085820859208602086120862208632086420865208662086720868208692087020871208722087320874208752087620877208782087920880208812088220883208842088520886208872088820889208902089120892208932089420895208962089720898208992090020901209022090320904209052090620907209082090920910209112091220913209142091520916209172091820919209202092120922209232092420925209262092720928209292093020931209322093320934209352093620937209382093920940209412094220943209442094520946209472094820949209502095120952209532095420955209562095720958209592096020961209622096320964209652096620967209682096920970209712097220973209742097520976209772097820979209802098120982209832098420985209862098720988209892099020991209922099320994209952099620997209982099921000210012100221003210042100521006210072100821009210102101121012210132101421015210162101721018210192102021021210222102321024210252102621027210282102921030210312103221033210342103521036210372103821039210402104121042210432104421045210462104721048210492105021051210522105321054210552105621057210582105921060210612106221063210642106521066210672106821069210702107121072210732107421075210762107721078210792108021081210822108321084210852108621087210882108921090210912109221093210942109521096210972109821099211002110121102211032110421105211062110721108211092111021111211122111321114211152111621117211182111921120211212112221123211242112521126211272112821129211302113121132211332113421135211362113721138211392114021141211422114321144211452114621147211482114921150211512115221153211542115521156211572115821159211602116121162211632116421165211662116721168211692117021171211722117321174211752117621177211782117921180211812118221183211842118521186211872118821189211902119121192211932119421195211962119721198211992120021201212022120321204212052120621207212082120921210212112121221213212142121521216212172121821219212202122121222212232122421225212262122721228212292123021231212322123321234212352123621237212382123921240212412124221243212442124521246212472124821249212502125121252212532125421255212562125721258212592126021261212622126321264212652126621267212682126921270212712127221273212742127521276212772127821279212802128121282212832128421285212862128721288212892129021291212922129321294212952129621297212982129921300213012130221303213042130521306213072130821309213102131121312213132131421315213162131721318213192132021321213222132321324213252132621327213282132921330213312133221333213342133521336213372133821339213402134121342213432134421345213462134721348213492135021351213522135321354213552135621357213582135921360213612136221363213642136521366213672136821369213702137121372213732137421375213762137721378213792138021381213822138321384213852138621387213882138921390213912139221393213942139521396213972139821399214002140121402214032140421405214062140721408214092141021411214122141321414214152141621417214182141921420214212142221423214242142521426214272142821429214302143121432214332143421435214362143721438214392144021441214422144321444214452144621447214482144921450214512145221453214542145521456214572145821459214602146121462214632146421465214662146721468214692147021471214722147321474214752147621477214782147921480214812148221483214842148521486214872148821489214902149121492214932149421495214962149721498214992150021501215022150321504215052150621507215082150921510215112151221513215142151521516215172151821519215202152121522215232152421525215262152721528215292153021531215322153321534215352153621537215382153921540215412154221543215442154521546215472154821549215502155121552215532155421555215562155721558215592156021561215622156321564215652156621567215682156921570215712157221573215742157521576215772157821579215802158121582215832158421585215862158721588215892159021591215922159321594215952159621597215982159921600216012160221603216042160521606216072160821609216102161121612216132161421615216162161721618216192162021621216222162321624216252162621627216282162921630216312163221633216342163521636216372163821639216402164121642216432164421645216462164721648216492165021651216522165321654216552165621657216582165921660216612166221663216642166521666216672166821669216702167121672216732167421675216762167721678216792168021681216822168321684216852168621687216882168921690216912169221693216942169521696216972169821699217002170121702217032170421705217062170721708217092171021711217122171321714217152171621717217182171921720217212172221723217242172521726217272172821729217302173121732217332173421735217362173721738217392174021741217422174321744217452174621747217482174921750217512175221753217542175521756217572175821759217602176121762217632176421765217662176721768217692177021771217722177321774217752177621777217782177921780217812178221783217842178521786217872178821789217902179121792217932179421795217962179721798217992180021801218022180321804218052180621807218082180921810218112181221813218142181521816218172181821819218202182121822218232182421825218262182721828218292183021831218322183321834218352183621837218382183921840218412184221843218442184521846218472184821849218502185121852218532185421855218562185721858218592186021861218622186321864218652186621867218682186921870218712187221873218742187521876218772187821879218802188121882218832188421885218862188721888218892189021891218922189321894218952189621897218982189921900219012190221903219042190521906219072190821909219102191121912219132191421915219162191721918219192192021921219222192321924219252192621927219282192921930219312193221933219342193521936219372193821939219402194121942219432194421945219462194721948219492195021951219522195321954219552195621957219582195921960219612196221963219642196521966219672196821969219702197121972219732197421975219762197721978219792198021981219822198321984219852198621987219882198921990219912199221993219942199521996219972199821999220002200122002220032200422005220062200722008220092201022011220122201322014220152201622017220182201922020220212202222023220242202522026220272202822029220302203122032220332203422035220362203722038220392204022041220422204322044220452204622047220482204922050220512205222053220542205522056220572205822059220602206122062220632206422065220662206722068220692207022071220722207322074220752207622077220782207922080220812208222083220842208522086220872208822089220902209122092220932209422095220962209722098220992210022101221022210322104221052210622107221082210922110221112211222113221142211522116221172211822119221202212122122221232212422125221262212722128221292213022131221322213322134221352213622137221382213922140221412214222143221442214522146221472214822149221502215122152221532215422155221562215722158221592216022161221622216322164221652216622167221682216922170221712217222173221742217522176221772217822179221802218122182221832218422185221862218722188221892219022191221922219322194221952219622197221982219922200222012220222203222042220522206222072220822209222102221122212222132221422215222162221722218222192222022221222222222322224222252222622227222282222922230222312223222233222342223522236222372223822239222402224122242222432224422245222462224722248222492225022251222522225322254222552225622257222582225922260222612226222263222642226522266222672226822269222702227122272222732227422275222762227722278222792228022281222822228322284222852228622287222882228922290222912229222293222942229522296222972229822299223002230122302223032230422305223062230722308223092231022311223122231322314223152231622317223182231922320223212232222323223242232522326223272232822329223302233122332223332233422335223362233722338223392234022341223422234322344223452234622347223482234922350223512235222353223542235522356223572235822359223602236122362223632236422365223662236722368223692237022371223722237322374223752237622377223782237922380223812238222383223842238522386223872238822389223902239122392223932239422395223962239722398223992240022401224022240322404224052240622407224082240922410224112241222413224142241522416224172241822419224202242122422224232242422425224262242722428224292243022431224322243322434224352243622437224382243922440224412244222443224442244522446224472244822449224502245122452224532245422455224562245722458224592246022461224622246322464224652246622467224682246922470224712247222473224742247522476224772247822479224802248122482224832248422485224862248722488224892249022491224922249322494224952249622497224982249922500225012250222503225042250522506225072250822509225102251122512225132251422515225162251722518225192252022521225222252322524225252252622527225282252922530225312253222533225342253522536225372253822539225402254122542225432254422545225462254722548225492255022551225522255322554225552255622557225582255922560225612256222563225642256522566225672256822569225702257122572225732257422575225762257722578225792258022581225822258322584225852258622587225882258922590225912259222593225942259522596225972259822599226002260122602226032260422605226062260722608226092261022611226122261322614226152261622617226182261922620226212262222623226242262522626226272262822629226302263122632226332263422635226362263722638226392264022641226422264322644226452264622647226482264922650226512265222653226542265522656226572265822659226602266122662226632266422665226662266722668226692267022671226722267322674226752267622677226782267922680226812268222683226842268522686226872268822689226902269122692226932269422695226962269722698226992270022701227022270322704227052270622707227082270922710227112271222713227142271522716227172271822719227202272122722227232272422725227262272722728227292273022731227322273322734227352273622737227382273922740227412274222743227442274522746227472274822749227502275122752227532275422755227562275722758227592276022761227622276322764227652276622767227682276922770227712277222773227742277522776227772277822779227802278122782227832278422785227862278722788227892279022791227922279322794227952279622797227982279922800228012280222803228042280522806228072280822809228102281122812228132281422815228162281722818228192282022821228222282322824228252282622827228282282922830228312283222833228342283522836228372283822839228402284122842228432284422845228462284722848228492285022851228522285322854228552285622857228582285922860228612286222863228642286522866228672286822869228702287122872228732287422875228762287722878228792288022881228822288322884228852288622887228882288922890228912289222893228942289522896228972289822899229002290122902229032290422905229062290722908229092291022911229122291322914229152291622917229182291922920229212292222923229242292522926229272292822929229302293122932229332293422935229362293722938229392294022941229422294322944229452294622947229482294922950229512295222953229542295522956229572295822959229602296122962229632296422965229662296722968229692297022971229722297322974229752297622977229782297922980229812298222983229842298522986229872298822989229902299122992229932299422995229962299722998229992300023001230022300323004230052300623007230082300923010230112301223013230142301523016230172301823019230202302123022230232302423025230262302723028230292303023031230322303323034230352303623037230382303923040230412304223043230442304523046230472304823049230502305123052230532305423055230562305723058230592306023061230622306323064230652306623067230682306923070230712307223073230742307523076230772307823079230802308123082230832308423085230862308723088230892309023091230922309323094230952309623097230982309923100231012310223103231042310523106231072310823109231102311123112231132311423115231162311723118231192312023121231222312323124231252312623127231282312923130231312313223133231342313523136231372313823139231402314123142231432314423145231462314723148231492315023151231522315323154231552315623157231582315923160231612316223163231642316523166231672316823169231702317123172231732317423175231762317723178231792318023181231822318323184231852318623187231882318923190231912319223193231942319523196231972319823199232002320123202232032320423205232062320723208232092321023211232122321323214232152321623217232182321923220232212322223223232242322523226232272322823229232302323123232232332323423235232362323723238232392324023241232422324323244232452324623247232482324923250232512325223253232542325523256232572325823259232602326123262232632326423265232662326723268232692327023271232722327323274232752327623277232782327923280232812328223283232842328523286232872328823289232902329123292232932329423295232962329723298232992330023301233022330323304233052330623307233082330923310233112331223313233142331523316233172331823319233202332123322233232332423325233262332723328233292333023331233322333323334233352333623337233382333923340233412334223343233442334523346233472334823349233502335123352233532335423355233562335723358233592336023361233622336323364233652336623367233682336923370233712337223373233742337523376233772337823379233802338123382233832338423385233862338723388233892339023391233922339323394233952339623397233982339923400234012340223403234042340523406234072340823409234102341123412234132341423415234162341723418234192342023421234222342323424234252342623427234282342923430234312343223433234342343523436234372343823439234402344123442234432344423445234462344723448234492345023451234522345323454234552345623457234582345923460234612346223463234642346523466234672346823469234702347123472234732347423475234762347723478234792348023481234822348323484234852348623487234882348923490234912349223493234942349523496234972349823499235002350123502235032350423505235062350723508235092351023511235122351323514235152351623517235182351923520235212352223523235242352523526235272352823529235302353123532235332353423535235362353723538235392354023541235422354323544235452354623547235482354923550235512355223553235542355523556235572355823559235602356123562235632356423565235662356723568235692357023571235722357323574235752357623577235782357923580235812358223583235842358523586235872358823589235902359123592235932359423595235962359723598235992360023601236022360323604236052360623607236082360923610236112361223613236142361523616236172361823619236202362123622236232362423625236262362723628236292363023631236322363323634236352363623637236382363923640236412364223643236442364523646236472364823649236502365123652236532365423655236562365723658236592366023661236622366323664236652366623667236682366923670236712367223673236742367523676236772367823679236802368123682236832368423685236862368723688236892369023691236922369323694236952369623697236982369923700237012370223703237042370523706237072370823709237102371123712237132371423715237162371723718237192372023721237222372323724237252372623727237282372923730237312373223733237342373523736237372373823739237402374123742237432374423745237462374723748237492375023751237522375323754237552375623757237582375923760237612376223763237642376523766237672376823769237702377123772237732377423775237762377723778237792378023781237822378323784237852378623787237882378923790237912379223793237942379523796237972379823799238002380123802238032380423805238062380723808238092381023811238122381323814238152381623817238182381923820238212382223823238242382523826238272382823829238302383123832238332383423835238362383723838238392384023841238422384323844238452384623847238482384923850238512385223853238542385523856238572385823859238602386123862238632386423865238662386723868238692387023871238722387323874238752387623877238782387923880238812388223883238842388523886238872388823889238902389123892238932389423895238962389723898238992390023901239022390323904239052390623907239082390923910239112391223913239142391523916239172391823919239202392123922239232392423925239262392723928239292393023931239322393323934239352393623937239382393923940239412394223943239442394523946239472394823949239502395123952239532395423955239562395723958239592396023961239622396323964239652396623967239682396923970239712397223973239742397523976239772397823979239802398123982239832398423985239862398723988239892399023991239922399323994239952399623997239982399924000240012400224003240042400524006240072400824009240102401124012240132401424015240162401724018240192402024021240222402324024240252402624027240282402924030240312403224033240342403524036240372403824039240402404124042240432404424045240462404724048240492405024051240522405324054240552405624057240582405924060240612406224063240642406524066240672406824069240702407124072240732407424075240762407724078240792408024081240822408324084240852408624087240882408924090240912409224093240942409524096240972409824099241002410124102241032410424105241062410724108241092411024111241122411324114241152411624117241182411924120241212412224123241242412524126241272412824129241302413124132241332413424135241362413724138241392414024141241422414324144241452414624147241482414924150241512415224153241542415524156241572415824159241602416124162241632416424165241662416724168241692417024171241722417324174241752417624177241782417924180241812418224183241842418524186241872418824189241902419124192241932419424195241962419724198241992420024201242022420324204242052420624207242082420924210242112421224213242142421524216242172421824219242202422124222242232422424225242262422724228242292423024231242322423324234242352423624237242382423924240242412424224243242442424524246242472424824249242502425124252242532425424255242562425724258242592426024261242622426324264242652426624267242682426924270242712427224273242742427524276242772427824279242802428124282242832428424285242862428724288242892429024291242922429324294242952429624297242982429924300243012430224303243042430524306243072430824309243102431124312243132431424315243162431724318243192432024321243222432324324243252432624327243282432924330243312433224333243342433524336243372433824339243402434124342243432434424345243462434724348243492435024351243522435324354243552435624357243582435924360243612436224363243642436524366243672436824369243702437124372243732437424375243762437724378243792438024381243822438324384243852438624387243882438924390243912439224393243942439524396243972439824399244002440124402244032440424405244062440724408244092441024411244122441324414244152441624417244182441924420244212442224423244242442524426244272442824429244302443124432244332443424435244362443724438244392444024441244422444324444244452444624447244482444924450244512445224453244542445524456244572445824459244602446124462244632446424465244662446724468244692447024471244722447324474244752447624477244782447924480244812448224483244842448524486244872448824489244902449124492244932449424495244962449724498244992450024501245022450324504245052450624507245082450924510245112451224513245142451524516245172451824519245202452124522245232452424525245262452724528245292453024531245322453324534245352453624537245382453924540245412454224543245442454524546245472454824549245502455124552245532455424555245562455724558245592456024561245622456324564245652456624567245682456924570245712457224573245742457524576245772457824579245802458124582245832458424585245862458724588245892459024591245922459324594245952459624597245982459924600246012460224603246042460524606246072460824609246102461124612246132461424615246162461724618246192462024621246222462324624246252462624627246282462924630246312463224633246342463524636246372463824639246402464124642246432464424645246462464724648246492465024651246522465324654246552465624657246582465924660246612466224663246642466524666246672466824669246702467124672246732467424675246762467724678246792468024681246822468324684246852468624687246882468924690246912469224693246942469524696246972469824699247002470124702247032470424705247062470724708247092471024711247122471324714247152471624717247182471924720247212472224723247242472524726247272472824729247302473124732247332473424735247362473724738247392474024741247422474324744247452474624747247482474924750247512475224753247542475524756247572475824759247602476124762247632476424765247662476724768247692477024771247722477324774247752477624777247782477924780247812478224783247842478524786247872478824789247902479124792247932479424795247962479724798247992480024801248022480324804248052480624807248082480924810248112481224813248142481524816248172481824819248202482124822248232482424825248262482724828248292483024831248322483324834248352483624837248382483924840248412484224843248442484524846248472484824849248502485124852248532485424855248562485724858248592486024861248622486324864248652486624867248682486924870248712487224873248742487524876248772487824879248802488124882248832488424885248862488724888248892489024891248922489324894248952489624897248982489924900249012490224903249042490524906249072490824909249102491124912249132491424915249162491724918249192492024921249222492324924249252492624927249282492924930249312493224933249342493524936249372493824939249402494124942249432494424945249462494724948249492495024951249522495324954249552495624957249582495924960249612496224963249642496524966249672496824969249702497124972249732497424975249762497724978249792498024981249822498324984249852498624987249882498924990249912499224993249942499524996249972499824999250002500125002250032500425005250062500725008250092501025011250122501325014250152501625017250182501925020250212502225023250242502525026250272502825029250302503125032250332503425035250362503725038250392504025041250422504325044250452504625047250482504925050250512505225053250542505525056250572505825059250602506125062250632506425065250662506725068250692507025071250722507325074250752507625077250782507925080250812508225083250842508525086250872508825089250902509125092250932509425095250962509725098250992510025101251022510325104251052510625107251082510925110251112511225113251142511525116251172511825119251202512125122251232512425125251262512725128251292513025131251322513325134251352513625137251382513925140251412514225143251442514525146251472514825149251502515125152251532515425155251562515725158251592516025161251622516325164251652516625167251682516925170251712517225173251742517525176251772517825179251802518125182251832518425185251862518725188251892519025191251922519325194251952519625197251982519925200252012520225203252042520525206252072520825209252102521125212252132521425215252162521725218252192522025221252222522325224252252522625227252282522925230252312523225233252342523525236252372523825239252402524125242252432524425245252462524725248252492525025251252522525325254252552525625257252582525925260252612526225263252642526525266252672526825269252702527125272252732527425275252762527725278252792528025281252822528325284252852528625287252882528925290252912529225293252942529525296252972529825299253002530125302253032530425305253062530725308253092531025311253122531325314253152531625317253182531925320253212532225323253242532525326253272532825329253302533125332253332533425335253362533725338253392534025341253422534325344253452534625347253482534925350253512535225353253542535525356253572535825359253602536125362253632536425365253662536725368253692537025371253722537325374253752537625377253782537925380253812538225383253842538525386253872538825389253902539125392253932539425395253962539725398253992540025401254022540325404254052540625407254082540925410254112541225413254142541525416254172541825419254202542125422254232542425425254262542725428254292543025431254322543325434254352543625437254382543925440254412544225443254442544525446254472544825449254502545125452254532545425455254562545725458254592546025461254622546325464254652546625467254682546925470254712547225473254742547525476254772547825479254802548125482254832548425485254862548725488254892549025491254922549325494254952549625497254982549925500255012550225503255042550525506255072550825509255102551125512255132551425515255162551725518255192552025521255222552325524255252552625527255282552925530255312553225533255342553525536255372553825539255402554125542255432554425545255462554725548255492555025551255522555325554255552555625557255582555925560255612556225563255642556525566255672556825569255702557125572255732557425575255762557725578255792558025581255822558325584255852558625587255882558925590255912559225593255942559525596255972559825599256002560125602256032560425605256062560725608256092561025611256122561325614256152561625617256182561925620256212562225623256242562525626256272562825629256302563125632256332563425635256362563725638256392564025641256422564325644256452564625647256482564925650256512565225653256542565525656256572565825659256602566125662256632566425665256662566725668256692567025671256722567325674256752567625677256782567925680256812568225683256842568525686256872568825689256902569125692256932569425695256962569725698256992570025701257022570325704257052570625707257082570925710257112571225713257142571525716257172571825719257202572125722257232572425725257262572725728257292573025731257322573325734257352573625737257382573925740257412574225743257442574525746257472574825749257502575125752257532575425755257562575725758257592576025761257622576325764257652576625767257682576925770257712577225773257742577525776257772577825779257802578125782257832578425785257862578725788257892579025791257922579325794257952579625797257982579925800258012580225803258042580525806258072580825809258102581125812258132581425815258162581725818258192582025821258222582325824258252582625827258282582925830258312583225833258342583525836258372583825839258402584125842258432584425845258462584725848258492585025851258522585325854258552585625857258582585925860258612586225863258642586525866258672586825869258702587125872258732587425875258762587725878258792588025881258822588325884258852588625887258882588925890258912589225893258942589525896258972589825899259002590125902259032590425905259062590725908259092591025911259122591325914259152591625917259182591925920259212592225923259242592525926259272592825929259302593125932259332593425935259362593725938259392594025941259422594325944259452594625947259482594925950259512595225953259542595525956259572595825959259602596125962259632596425965259662596725968259692597025971259722597325974259752597625977259782597925980259812598225983259842598525986259872598825989259902599125992259932599425995259962599725998259992600026001260022600326004260052600626007260082600926010260112601226013260142601526016260172601826019260202602126022260232602426025260262602726028260292603026031260322603326034260352603626037260382603926040260412604226043260442604526046260472604826049260502605126052260532605426055260562605726058260592606026061260622606326064260652606626067260682606926070260712607226073260742607526076260772607826079260802608126082260832608426085260862608726088260892609026091260922609326094260952609626097260982609926100261012610226103261042610526106261072610826109261102611126112261132611426115261162611726118261192612026121261222612326124261252612626127261282612926130261312613226133261342613526136261372613826139261402614126142261432614426145261462614726148261492615026151261522615326154261552615626157261582615926160261612616226163261642616526166261672616826169261702617126172261732617426175261762617726178261792618026181261822618326184261852618626187261882618926190261912619226193261942619526196261972619826199262002620126202262032620426205262062620726208262092621026211262122621326214262152621626217262182621926220262212622226223262242622526226262272622826229262302623126232262332623426235262362623726238262392624026241262422624326244262452624626247262482624926250262512625226253262542625526256262572625826259262602626126262262632626426265262662626726268262692627026271262722627326274262752627626277262782627926280262812628226283262842628526286262872628826289262902629126292262932629426295262962629726298262992630026301263022630326304263052630626307263082630926310263112631226313263142631526316263172631826319263202632126322263232632426325263262632726328263292633026331263322633326334263352633626337263382633926340263412634226343263442634526346263472634826349263502635126352263532635426355263562635726358263592636026361263622636326364263652636626367263682636926370263712637226373263742637526376263772637826379263802638126382263832638426385263862638726388263892639026391263922639326394263952639626397263982639926400264012640226403264042640526406264072640826409264102641126412264132641426415264162641726418264192642026421264222642326424264252642626427264282642926430264312643226433264342643526436264372643826439264402644126442264432644426445264462644726448264492645026451264522645326454264552645626457264582645926460264612646226463264642646526466264672646826469264702647126472264732647426475264762647726478264792648026481264822648326484264852648626487264882648926490264912649226493264942649526496264972649826499265002650126502265032650426505265062650726508265092651026511265122651326514265152651626517265182651926520265212652226523265242652526526265272652826529265302653126532265332653426535265362653726538265392654026541265422654326544265452654626547265482654926550265512655226553265542655526556265572655826559265602656126562265632656426565265662656726568265692657026571265722657326574265752657626577265782657926580265812658226583265842658526586265872658826589265902659126592265932659426595265962659726598265992660026601266022660326604266052660626607266082660926610266112661226613266142661526616266172661826619266202662126622266232662426625266262662726628266292663026631266322663326634266352663626637266382663926640266412664226643266442664526646266472664826649266502665126652266532665426655266562665726658266592666026661266622666326664266652666626667266682666926670266712667226673266742667526676266772667826679266802668126682266832668426685266862668726688266892669026691266922669326694266952669626697266982669926700267012670226703267042670526706267072670826709267102671126712267132671426715267162671726718267192672026721267222672326724267252672626727267282672926730267312673226733267342673526736267372673826739267402674126742267432674426745267462674726748267492675026751267522675326754267552675626757267582675926760267612676226763267642676526766267672676826769267702677126772267732677426775267762677726778267792678026781267822678326784267852678626787267882678926790267912679226793267942679526796267972679826799268002680126802268032680426805268062680726808268092681026811268122681326814268152681626817268182681926820268212682226823268242682526826268272682826829268302683126832268332683426835268362683726838268392684026841268422684326844268452684626847268482684926850268512685226853268542685526856268572685826859268602686126862268632686426865268662686726868268692687026871268722687326874268752687626877268782687926880268812688226883268842688526886268872688826889268902689126892268932689426895268962689726898268992690026901269022690326904269052690626907269082690926910269112691226913269142691526916269172691826919269202692126922269232692426925269262692726928269292693026931269322693326934269352693626937269382693926940269412694226943269442694526946269472694826949269502695126952269532695426955269562695726958269592696026961269622696326964269652696626967269682696926970269712697226973269742697526976269772697826979269802698126982269832698426985269862698726988269892699026991269922699326994269952699626997269982699927000270012700227003270042700527006270072700827009270102701127012270132701427015270162701727018270192702027021270222702327024270252702627027270282702927030270312703227033270342703527036270372703827039270402704127042270432704427045270462704727048270492705027051270522705327054270552705627057270582705927060270612706227063270642706527066270672706827069270702707127072270732707427075270762707727078270792708027081270822708327084270852708627087270882708927090270912709227093270942709527096270972709827099271002710127102271032710427105271062710727108271092711027111271122711327114271152711627117271182711927120271212712227123271242712527126271272712827129271302713127132271332713427135271362713727138271392714027141271422714327144271452714627147271482714927150271512715227153271542715527156271572715827159271602716127162271632716427165271662716727168271692717027171271722717327174271752717627177271782717927180271812718227183271842718527186271872718827189271902719127192271932719427195271962719727198271992720027201272022720327204272052720627207272082720927210272112721227213272142721527216272172721827219272202722127222272232722427225272262722727228272292723027231272322723327234272352723627237272382723927240272412724227243272442724527246272472724827249272502725127252272532725427255272562725727258272592726027261272622726327264272652726627267272682726927270272712727227273272742727527276272772727827279272802728127282272832728427285272862728727288272892729027291272922729327294272952729627297272982729927300273012730227303273042730527306273072730827309273102731127312273132731427315273162731727318273192732027321273222732327324273252732627327273282732927330273312733227333273342733527336273372733827339273402734127342273432734427345273462734727348273492735027351273522735327354273552735627357273582735927360273612736227363273642736527366273672736827369273702737127372273732737427375273762737727378273792738027381273822738327384273852738627387273882738927390273912739227393273942739527396273972739827399274002740127402274032740427405274062740727408274092741027411274122741327414274152741627417274182741927420274212742227423274242742527426274272742827429274302743127432274332743427435274362743727438274392744027441274422744327444274452744627447274482744927450274512745227453274542745527456274572745827459274602746127462274632746427465274662746727468274692747027471274722747327474274752747627477274782747927480274812748227483274842748527486274872748827489274902749127492274932749427495274962749727498274992750027501275022750327504275052750627507275082750927510275112751227513275142751527516275172751827519275202752127522275232752427525275262752727528275292753027531275322753327534275352753627537275382753927540275412754227543275442754527546275472754827549275502755127552275532755427555275562755727558275592756027561275622756327564275652756627567275682756927570275712757227573275742757527576275772757827579275802758127582275832758427585275862758727588275892759027591275922759327594275952759627597275982759927600276012760227603276042760527606276072760827609276102761127612276132761427615276162761727618276192762027621276222762327624276252762627627276282762927630276312763227633276342763527636276372763827639276402764127642276432764427645276462764727648276492765027651276522765327654276552765627657276582765927660276612766227663276642766527666276672766827669276702767127672276732767427675276762767727678276792768027681276822768327684276852768627687276882768927690276912769227693276942769527696276972769827699277002770127702277032770427705277062770727708277092771027711277122771327714277152771627717277182771927720277212772227723277242772527726277272772827729277302773127732277332773427735277362773727738277392774027741277422774327744277452774627747277482774927750277512775227753277542775527756277572775827759277602776127762277632776427765277662776727768277692777027771277722777327774277752777627777277782777927780277812778227783277842778527786277872778827789277902779127792277932779427795277962779727798277992780027801278022780327804278052780627807278082780927810278112781227813278142781527816278172781827819278202782127822278232782427825278262782727828278292783027831278322783327834278352783627837278382783927840278412784227843278442784527846278472784827849278502785127852278532785427855278562785727858278592786027861278622786327864278652786627867278682786927870278712787227873278742787527876278772787827879278802788127882278832788427885278862788727888278892789027891278922789327894278952789627897278982789927900279012790227903279042790527906279072790827909279102791127912279132791427915279162791727918279192792027921279222792327924279252792627927279282792927930279312793227933279342793527936279372793827939279402794127942279432794427945279462794727948279492795027951279522795327954279552795627957279582795927960279612796227963279642796527966279672796827969279702797127972279732797427975279762797727978279792798027981279822798327984279852798627987279882798927990279912799227993279942799527996279972799827999280002800128002280032800428005280062800728008280092801028011280122801328014280152801628017280182801928020280212802228023280242802528026280272802828029280302803128032280332803428035280362803728038280392804028041280422804328044280452804628047280482804928050280512805228053280542805528056280572805828059280602806128062280632806428065280662806728068280692807028071280722807328074280752807628077280782807928080280812808228083280842808528086280872808828089280902809128092280932809428095280962809728098280992810028101281022810328104281052810628107281082810928110281112811228113281142811528116281172811828119281202812128122281232812428125281262812728128281292813028131281322813328134281352813628137281382813928140281412814228143281442814528146281472814828149281502815128152281532815428155281562815728158281592816028161281622816328164281652816628167281682816928170281712817228173281742817528176281772817828179281802818128182281832818428185281862818728188281892819028191281922819328194281952819628197281982819928200282012820228203282042820528206282072820828209282102821128212282132821428215282162821728218282192822028221282222822328224282252822628227282282822928230282312823228233282342823528236282372823828239282402824128242282432824428245282462824728248282492825028251282522825328254282552825628257282582825928260282612826228263282642826528266282672826828269282702827128272282732827428275282762827728278282792828028281282822828328284282852828628287282882828928290282912829228293282942829528296282972829828299283002830128302283032830428305283062830728308283092831028311283122831328314283152831628317283182831928320283212832228323283242832528326283272832828329283302833128332283332833428335283362833728338283392834028341283422834328344283452834628347283482834928350283512835228353283542835528356283572835828359283602836128362283632836428365283662836728368283692837028371283722837328374283752837628377283782837928380283812838228383283842838528386283872838828389283902839128392283932839428395283962839728398283992840028401284022840328404284052840628407284082840928410284112841228413284142841528416284172841828419284202842128422284232842428425284262842728428284292843028431284322843328434284352843628437284382843928440284412844228443284442844528446284472844828449284502845128452284532845428455284562845728458284592846028461284622846328464284652846628467284682846928470284712847228473284742847528476284772847828479284802848128482284832848428485284862848728488284892849028491284922849328494284952849628497284982849928500285012850228503285042850528506285072850828509285102851128512285132851428515285162851728518285192852028521285222852328524285252852628527285282852928530285312853228533285342853528536285372853828539285402854128542285432854428545285462854728548285492855028551285522855328554285552855628557285582855928560285612856228563285642856528566285672856828569285702857128572285732857428575285762857728578285792858028581285822858328584285852858628587285882858928590285912859228593285942859528596285972859828599286002860128602286032860428605286062860728608286092861028611286122861328614286152861628617286182861928620286212862228623286242862528626286272862828629286302863128632286332863428635286362863728638286392864028641286422864328644286452864628647286482864928650286512865228653286542865528656286572865828659286602866128662286632866428665286662866728668286692867028671286722867328674286752867628677286782867928680286812868228683286842868528686286872868828689286902869128692286932869428695286962869728698286992870028701287022870328704287052870628707287082870928710287112871228713287142871528716287172871828719287202872128722287232872428725287262872728728287292873028731287322873328734287352873628737287382873928740287412874228743287442874528746287472874828749287502875128752287532875428755287562875728758287592876028761287622876328764287652876628767287682876928770287712877228773287742877528776287772877828779287802878128782287832878428785287862878728788287892879028791287922879328794287952879628797287982879928800288012880228803288042880528806288072880828809288102881128812288132881428815288162881728818288192882028821288222882328824288252882628827288282882928830288312883228833288342883528836288372883828839288402884128842288432884428845288462884728848288492885028851288522885328854288552885628857288582885928860288612886228863288642886528866288672886828869288702887128872288732887428875288762887728878288792888028881288822888328884288852888628887288882888928890288912889228893288942889528896288972889828899289002890128902289032890428905289062890728908289092891028911289122891328914289152891628917289182891928920289212892228923289242892528926289272892828929289302893128932289332893428935289362893728938289392894028941289422894328944289452894628947289482894928950289512895228953289542895528956289572895828959289602896128962289632896428965289662896728968289692897028971289722897328974289752897628977289782897928980289812898228983289842898528986289872898828989289902899128992289932899428995289962899728998289992900029001290022900329004290052900629007290082900929010290112901229013290142901529016290172901829019290202902129022290232902429025290262902729028290292903029031290322903329034290352903629037290382903929040290412904229043290442904529046290472904829049290502905129052290532905429055290562905729058290592906029061290622906329064290652906629067290682906929070290712907229073290742907529076290772907829079290802908129082290832908429085290862908729088290892909029091290922909329094290952909629097290982909929100291012910229103291042910529106291072910829109291102911129112291132911429115291162911729118291192912029121291222912329124291252912629127291282912929130291312913229133291342913529136291372913829139291402914129142291432914429145291462914729148291492915029151291522915329154291552915629157291582915929160291612916229163291642916529166291672916829169291702917129172291732917429175291762917729178291792918029181291822918329184291852918629187291882918929190291912919229193291942919529196291972919829199292002920129202292032920429205292062920729208292092921029211292122921329214292152921629217292182921929220292212922229223292242922529226292272922829229292302923129232292332923429235292362923729238292392924029241292422924329244292452924629247292482924929250292512925229253292542925529256292572925829259292602926129262292632926429265292662926729268292692927029271292722927329274292752927629277292782927929280292812928229283292842928529286292872928829289292902929129292292932929429295292962929729298292992930029301293022930329304293052930629307293082930929310293112931229313293142931529316293172931829319293202932129322293232932429325293262932729328293292933029331293322933329334293352933629337293382933929340293412934229343293442934529346293472934829349293502935129352293532935429355293562935729358293592936029361293622936329364293652936629367293682936929370293712937229373293742937529376293772937829379293802938129382293832938429385293862938729388293892939029391293922939329394293952939629397293982939929400294012940229403294042940529406294072940829409294102941129412294132941429415294162941729418294192942029421294222942329424294252942629427294282942929430294312943229433294342943529436294372943829439294402944129442294432944429445294462944729448294492945029451294522945329454294552945629457294582945929460294612946229463294642946529466294672946829469294702947129472294732947429475294762947729478294792948029481294822948329484294852948629487294882948929490294912949229493294942949529496294972949829499295002950129502295032950429505295062950729508295092951029511295122951329514295152951629517295182951929520295212952229523295242952529526295272952829529295302953129532295332953429535295362953729538295392954029541295422954329544295452954629547295482954929550295512955229553295542955529556295572955829559295602956129562295632956429565295662956729568295692957029571295722957329574295752957629577295782957929580295812958229583295842958529586295872958829589295902959129592295932959429595295962959729598295992960029601296022960329604296052960629607296082960929610296112961229613296142961529616296172961829619296202962129622296232962429625296262962729628296292963029631296322963329634296352963629637296382963929640296412964229643296442964529646296472964829649296502965129652296532965429655296562965729658296592966029661296622966329664296652966629667296682966929670296712967229673296742967529676296772967829679296802968129682296832968429685296862968729688296892969029691296922969329694296952969629697296982969929700297012970229703297042970529706297072970829709297102971129712297132971429715297162971729718297192972029721297222972329724297252972629727297282972929730297312973229733297342973529736297372973829739297402974129742297432974429745297462974729748297492975029751297522975329754297552975629757297582975929760297612976229763297642976529766297672976829769297702977129772297732977429775297762977729778297792978029781297822978329784297852978629787297882978929790297912979229793297942979529796297972979829799298002980129802298032980429805298062980729808298092981029811298122981329814298152981629817298182981929820298212982229823298242982529826298272982829829298302983129832298332983429835298362983729838298392984029841298422984329844298452984629847298482984929850298512985229853298542985529856298572985829859298602986129862298632986429865298662986729868298692987029871298722987329874298752987629877298782987929880298812988229883298842988529886298872988829889298902989129892298932989429895298962989729898298992990029901299022990329904299052990629907299082990929910299112991229913299142991529916299172991829919299202992129922299232992429925299262992729928299292993029931299322993329934299352993629937299382993929940299412994229943299442994529946299472994829949299502995129952299532995429955299562995729958299592996029961299622996329964299652996629967299682996929970299712997229973299742997529976299772997829979299802998129982299832998429985299862998729988299892999029991299922999329994299952999629997299982999930000300013000230003300043000530006300073000830009300103001130012300133001430015300163001730018300193002030021300223002330024300253002630027300283002930030300313003230033300343003530036300373003830039300403004130042300433004430045300463004730048300493005030051300523005330054300553005630057300583005930060300613006230063300643006530066300673006830069300703007130072300733007430075300763007730078300793008030081300823008330084300853008630087300883008930090300913009230093300943009530096300973009830099301003010130102301033010430105301063010730108301093011030111301123011330114301153011630117301183011930120301213012230123301243012530126301273012830129301303013130132301333013430135301363013730138301393014030141301423014330144301453014630147301483014930150301513015230153301543015530156301573015830159301603016130162301633016430165301663016730168301693017030171301723017330174301753017630177301783017930180301813018230183301843018530186301873018830189301903019130192301933019430195301963019730198301993020030201302023020330204302053020630207302083020930210302113021230213302143021530216302173021830219302203022130222302233022430225302263022730228302293023030231302323023330234302353023630237302383023930240302413024230243302443024530246302473024830249302503025130252302533025430255302563025730258302593026030261302623026330264302653026630267302683026930270302713027230273302743027530276302773027830279302803028130282302833028430285302863028730288302893029030291302923029330294302953029630297302983029930300303013030230303303043030530306303073030830309303103031130312303133031430315303163031730318303193032030321303223032330324303253032630327303283032930330303313033230333303343033530336303373033830339303403034130342303433034430345303463034730348303493035030351303523035330354303553035630357303583035930360303613036230363303643036530366303673036830369303703037130372303733037430375303763037730378303793038030381303823038330384303853038630387303883038930390303913039230393303943039530396303973039830399304003040130402304033040430405304063040730408304093041030411304123041330414304153041630417304183041930420304213042230423304243042530426304273042830429304303043130432304333043430435304363043730438304393044030441304423044330444304453044630447304483044930450304513045230453304543045530456304573045830459304603046130462304633046430465304663046730468304693047030471304723047330474304753047630477304783047930480304813048230483304843048530486304873048830489304903049130492304933049430495304963049730498304993050030501305023050330504305053050630507305083050930510305113051230513305143051530516305173051830519305203052130522305233052430525305263052730528305293053030531305323053330534305353053630537305383053930540305413054230543305443054530546305473054830549305503055130552305533055430555305563055730558305593056030561305623056330564305653056630567305683056930570305713057230573305743057530576305773057830579305803058130582305833058430585305863058730588305893059030591305923059330594305953059630597305983059930600306013060230603306043060530606306073060830609306103061130612306133061430615306163061730618306193062030621306223062330624306253062630627306283062930630306313063230633306343063530636306373063830639306403064130642306433064430645306463064730648306493065030651306523065330654306553065630657306583065930660306613066230663306643066530666306673066830669306703067130672306733067430675306763067730678306793068030681306823068330684306853068630687306883068930690306913069230693306943069530696306973069830699307003070130702307033070430705307063070730708307093071030711307123071330714307153071630717307183071930720307213072230723307243072530726307273072830729307303073130732307333073430735307363073730738307393074030741307423074330744307453074630747307483074930750307513075230753307543075530756307573075830759307603076130762307633076430765307663076730768307693077030771307723077330774307753077630777307783077930780307813078230783307843078530786307873078830789307903079130792307933079430795307963079730798307993080030801308023080330804308053080630807308083080930810308113081230813308143081530816308173081830819308203082130822308233082430825308263082730828308293083030831308323083330834308353083630837308383083930840308413084230843308443084530846308473084830849308503085130852308533085430855308563085730858308593086030861308623086330864308653086630867308683086930870308713087230873308743087530876308773087830879308803088130882308833088430885308863088730888308893089030891308923089330894308953089630897308983089930900309013090230903309043090530906309073090830909309103091130912309133091430915309163091730918309193092030921309223092330924309253092630927309283092930930309313093230933309343093530936309373093830939309403094130942309433094430945309463094730948309493095030951309523095330954309553095630957309583095930960309613096230963309643096530966309673096830969309703097130972309733097430975309763097730978309793098030981309823098330984309853098630987309883098930990309913099230993309943099530996309973099830999310003100131002310033100431005310063100731008310093101031011310123101331014310153101631017310183101931020310213102231023310243102531026310273102831029310303103131032310333103431035310363103731038310393104031041310423104331044310453104631047310483104931050310513105231053310543105531056310573105831059310603106131062310633106431065310663106731068310693107031071310723107331074310753107631077310783107931080310813108231083310843108531086310873108831089310903109131092310933109431095310963109731098310993110031101311023110331104311053110631107311083110931110311113111231113311143111531116311173111831119311203112131122311233112431125311263112731128311293113031131311323113331134311353113631137311383113931140311413114231143311443114531146311473114831149311503115131152311533115431155311563115731158311593116031161311623116331164311653116631167311683116931170311713117231173311743117531176311773117831179311803118131182311833118431185311863118731188311893119031191311923119331194311953119631197311983119931200312013120231203312043120531206312073120831209312103121131212312133121431215312163121731218312193122031221312223122331224312253122631227312283122931230312313123231233312343123531236312373123831239312403124131242312433124431245312463124731248312493125031251312523125331254312553125631257312583125931260312613126231263312643126531266312673126831269312703127131272312733127431275312763127731278312793128031281312823128331284312853128631287312883128931290312913129231293312943129531296312973129831299313003130131302313033130431305313063130731308313093131031311313123131331314313153131631317313183131931320313213132231323313243132531326313273132831329313303133131332313333133431335313363133731338313393134031341313423134331344313453134631347313483134931350313513135231353313543135531356313573135831359313603136131362313633136431365313663136731368313693137031371313723137331374313753137631377313783137931380313813138231383313843138531386313873138831389313903139131392313933139431395313963139731398313993140031401314023140331404314053140631407314083140931410314113141231413314143141531416314173141831419314203142131422314233142431425314263142731428314293143031431314323143331434314353143631437314383143931440314413144231443314443144531446314473144831449314503145131452314533145431455314563145731458314593146031461314623146331464314653146631467314683146931470314713147231473314743147531476314773147831479314803148131482314833148431485314863148731488314893149031491314923149331494314953149631497314983149931500315013150231503315043150531506315073150831509315103151131512315133151431515315163151731518315193152031521315223152331524315253152631527315283152931530315313153231533315343153531536315373153831539315403154131542315433154431545315463154731548315493155031551315523155331554315553155631557315583155931560315613156231563315643156531566315673156831569315703157131572315733157431575315763157731578315793158031581315823158331584315853158631587315883158931590315913159231593315943159531596315973159831599316003160131602316033160431605316063160731608316093161031611316123161331614316153161631617316183161931620316213162231623316243162531626316273162831629316303163131632316333163431635316363163731638316393164031641316423164331644316453164631647316483164931650316513165231653316543165531656316573165831659316603166131662316633166431665316663166731668316693167031671316723167331674316753167631677316783167931680316813168231683316843168531686316873168831689316903169131692316933169431695316963169731698316993170031701317023170331704317053170631707317083170931710317113171231713317143171531716317173171831719317203172131722317233172431725317263172731728317293173031731317323173331734317353173631737317383173931740317413174231743317443174531746317473174831749317503175131752317533175431755317563175731758317593176031761317623176331764317653176631767317683176931770317713177231773317743177531776317773177831779317803178131782317833178431785317863178731788317893179031791317923179331794317953179631797317983179931800318013180231803318043180531806318073180831809318103181131812318133181431815318163181731818318193182031821318223182331824318253182631827318283182931830318313183231833318343183531836318373183831839318403184131842318433184431845318463184731848318493185031851318523185331854318553185631857318583185931860318613186231863318643186531866318673186831869318703187131872318733187431875318763187731878318793188031881318823188331884318853188631887318883188931890318913189231893318943189531896318973189831899319003190131902319033190431905319063190731908319093191031911319123191331914319153191631917319183191931920319213192231923319243192531926319273192831929319303193131932319333193431935319363193731938319393194031941319423194331944319453194631947319483194931950319513195231953319543195531956319573195831959319603196131962319633196431965319663196731968319693197031971319723197331974319753197631977319783197931980319813198231983319843198531986319873198831989319903199131992319933199431995319963199731998319993200032001320023200332004320053200632007320083200932010320113201232013320143201532016320173201832019320203202132022320233202432025320263202732028320293203032031320323203332034320353203632037320383203932040320413204232043320443204532046320473204832049320503205132052320533205432055320563205732058320593206032061320623206332064320653206632067320683206932070320713207232073320743207532076320773207832079320803208132082320833208432085320863208732088320893209032091320923209332094320953209632097320983209932100321013210232103321043210532106321073210832109321103211132112321133211432115321163211732118321193212032121321223212332124321253212632127321283212932130321313213232133321343213532136321373213832139321403214132142321433214432145321463214732148321493215032151321523215332154321553215632157321583215932160321613216232163321643216532166321673216832169321703217132172321733217432175321763217732178321793218032181321823218332184321853218632187321883218932190321913219232193321943219532196321973219832199322003220132202322033220432205322063220732208322093221032211322123221332214322153221632217322183221932220322213222232223322243222532226322273222832229322303223132232322333223432235322363223732238322393224032241322423224332244322453224632247322483224932250322513225232253322543225532256322573225832259322603226132262322633226432265322663226732268322693227032271322723227332274322753227632277322783227932280322813228232283322843228532286322873228832289322903229132292322933229432295322963229732298322993230032301323023230332304323053230632307323083230932310323113231232313323143231532316323173231832319323203232132322323233232432325323263232732328323293233032331323323233332334323353233632337323383233932340323413234232343323443234532346323473234832349323503235132352323533235432355323563235732358323593236032361323623236332364323653236632367323683236932370323713237232373323743237532376323773237832379323803238132382323833238432385323863238732388323893239032391323923239332394323953239632397323983239932400324013240232403324043240532406324073240832409324103241132412324133241432415324163241732418324193242032421324223242332424324253242632427324283242932430324313243232433324343243532436324373243832439324403244132442324433244432445324463244732448324493245032451324523245332454324553245632457324583245932460324613246232463324643246532466324673246832469324703247132472324733247432475324763247732478324793248032481324823248332484324853248632487324883248932490324913249232493324943249532496324973249832499325003250132502325033250432505325063250732508325093251032511325123251332514325153251632517325183251932520325213252232523325243252532526325273252832529325303253132532325333253432535325363253732538325393254032541325423254332544325453254632547325483254932550325513255232553325543255532556325573255832559325603256132562325633256432565325663256732568325693257032571325723257332574325753257632577325783257932580325813258232583325843258532586325873258832589325903259132592325933259432595325963259732598325993260032601326023260332604326053260632607326083260932610326113261232613326143261532616326173261832619326203262132622326233262432625326263262732628326293263032631326323263332634326353263632637326383263932640326413264232643326443264532646326473264832649326503265132652326533265432655326563265732658326593266032661326623266332664326653266632667326683266932670326713267232673326743267532676326773267832679326803268132682326833268432685326863268732688326893269032691326923269332694326953269632697326983269932700327013270232703327043270532706327073270832709327103271132712327133271432715327163271732718327193272032721327223272332724327253272632727327283272932730327313273232733327343273532736327373273832739327403274132742327433274432745327463274732748327493275032751327523275332754327553275632757327583275932760327613276232763327643276532766327673276832769327703277132772327733277432775327763277732778327793278032781327823278332784327853278632787327883278932790327913279232793327943279532796327973279832799328003280132802328033280432805328063280732808328093281032811328123281332814328153281632817328183281932820328213282232823328243282532826328273282832829328303283132832328333283432835328363283732838328393284032841328423284332844328453284632847328483284932850328513285232853328543285532856328573285832859328603286132862328633286432865328663286732868328693287032871328723287332874328753287632877328783287932880328813288232883328843288532886328873288832889328903289132892328933289432895328963289732898328993290032901329023290332904329053290632907329083290932910329113291232913329143291532916329173291832919329203292132922329233292432925329263292732928329293293032931329323293332934329353293632937329383293932940329413294232943329443294532946329473294832949329503295132952329533295432955329563295732958329593296032961329623296332964329653296632967329683296932970329713297232973329743297532976329773297832979329803298132982329833298432985329863298732988329893299032991329923299332994329953299632997329983299933000330013300233003330043300533006330073300833009330103301133012330133301433015330163301733018330193302033021330223302333024330253302633027330283302933030330313303233033330343303533036330373303833039330403304133042330433304433045330463304733048330493305033051330523305333054330553305633057330583305933060330613306233063330643306533066330673306833069330703307133072330733307433075330763307733078330793308033081330823308333084330853308633087330883308933090330913309233093330943309533096330973309833099331003310133102331033310433105331063310733108331093311033111331123311333114331153311633117331183311933120331213312233123331243312533126331273312833129331303313133132331333313433135331363313733138331393314033141331423314333144331453314633147331483314933150331513315233153331543315533156331573315833159331603316133162331633316433165331663316733168331693317033171331723317333174331753317633177331783317933180331813318233183331843318533186331873318833189331903319133192331933319433195331963319733198331993320033201332023320333204332053320633207332083320933210332113321233213332143321533216332173321833219332203322133222332233322433225332263322733228332293323033231332323323333234332353323633237332383323933240332413324233243332443324533246332473324833249332503325133252332533325433255332563325733258332593326033261332623326333264332653326633267332683326933270332713327233273332743327533276332773327833279332803328133282332833328433285332863328733288332893329033291332923329333294332953329633297332983329933300333013330233303333043330533306333073330833309333103331133312333133331433315333163331733318333193332033321333223332333324333253332633327333283332933330333313333233333333343333533336333373333833339333403334133342333433334433345333463334733348333493335033351333523335333354333553335633357333583335933360333613336233363333643336533366333673336833369333703337133372333733337433375333763337733378333793338033381333823338333384333853338633387333883338933390333913339233393333943339533396333973339833399334003340133402334033340433405334063340733408334093341033411334123341333414334153341633417334183341933420334213342233423334243342533426334273342833429334303343133432334333343433435334363343733438334393344033441334423344333444334453344633447334483344933450334513345233453334543345533456334573345833459334603346133462334633346433465334663346733468334693347033471334723347333474334753347633477334783347933480334813348233483334843348533486334873348833489334903349133492334933349433495334963349733498334993350033501335023350333504335053350633507335083350933510335113351233513335143351533516335173351833519335203352133522335233352433525335263352733528335293353033531335323353333534335353353633537335383353933540335413354233543335443354533546335473354833549335503355133552335533355433555335563355733558335593356033561335623356333564335653356633567335683356933570335713357233573335743357533576335773357833579335803358133582335833358433585335863358733588335893359033591335923359333594335953359633597335983359933600336013360233603336043360533606336073360833609336103361133612336133361433615336163361733618336193362033621336223362333624336253362633627336283362933630336313363233633336343363533636336373363833639336403364133642336433364433645336463364733648336493365033651336523365333654336553365633657336583365933660336613366233663336643366533666336673366833669336703367133672336733367433675336763367733678336793368033681336823368333684336853368633687336883368933690336913369233693336943369533696336973369833699337003370133702337033370433705337063370733708337093371033711337123371333714337153371633717337183371933720337213372233723337243372533726337273372833729337303373133732337333373433735337363373733738337393374033741337423374333744337453374633747337483374933750337513375233753337543375533756337573375833759337603376133762337633376433765337663376733768337693377033771337723377333774337753377633777337783377933780337813378233783337843378533786337873378833789337903379133792337933379433795337963379733798337993380033801338023380333804338053380633807338083380933810338113381233813338143381533816338173381833819338203382133822338233382433825338263382733828338293383033831338323383333834338353383633837338383383933840338413384233843338443384533846338473384833849338503385133852338533385433855338563385733858338593386033861338623386333864338653386633867338683386933870338713387233873338743387533876338773387833879338803388133882338833388433885338863388733888338893389033891338923389333894338953389633897338983389933900339013390233903339043390533906339073390833909339103391133912339133391433915339163391733918339193392033921339223392333924339253392633927339283392933930339313393233933339343393533936339373393833939339403394133942339433394433945339463394733948339493395033951339523395333954339553395633957339583395933960339613396233963339643396533966339673396833969339703397133972339733397433975339763397733978339793398033981339823398333984339853398633987339883398933990339913399233993339943399533996339973399833999340003400134002340033400434005340063400734008340093401034011340123401334014340153401634017340183401934020340213402234023340243402534026340273402834029340303403134032340333403434035340363403734038340393404034041340423404334044340453404634047340483404934050340513405234053340543405534056340573405834059340603406134062340633406434065340663406734068340693407034071340723407334074340753407634077340783407934080340813408234083340843408534086340873408834089340903409134092340933409434095340963409734098340993410034101341023410334104341053410634107341083410934110341113411234113341143411534116341173411834119341203412134122341233412434125341263412734128341293413034131341323413334134341353413634137341383413934140341413414234143341443414534146341473414834149341503415134152341533415434155341563415734158341593416034161341623416334164341653416634167341683416934170341713417234173341743417534176341773417834179341803418134182341833418434185341863418734188341893419034191341923419334194341953419634197341983419934200342013420234203342043420534206342073420834209342103421134212342133421434215342163421734218342193422034221342223422334224342253422634227342283422934230342313423234233342343423534236342373423834239342403424134242342433424434245342463424734248342493425034251342523425334254342553425634257342583425934260342613426234263342643426534266342673426834269342703427134272342733427434275342763427734278342793428034281342823428334284342853428634287342883428934290342913429234293342943429534296342973429834299343003430134302343033430434305343063430734308343093431034311343123431334314343153431634317343183431934320343213432234323343243432534326343273432834329343303433134332343333433434335343363433734338343393434034341343423434334344343453434634347343483434934350343513435234353343543435534356343573435834359343603436134362343633436434365343663436734368343693437034371343723437334374343753437634377343783437934380343813438234383343843438534386343873438834389343903439134392343933439434395343963439734398343993440034401344023440334404344053440634407344083440934410344113441234413344143441534416344173441834419344203442134422344233442434425344263442734428344293443034431344323443334434344353443634437344383443934440344413444234443344443444534446344473444834449344503445134452344533445434455344563445734458344593446034461344623446334464344653446634467344683446934470344713447234473344743447534476344773447834479344803448134482344833448434485344863448734488344893449034491344923449334494344953449634497344983449934500345013450234503345043450534506345073450834509345103451134512345133451434515345163451734518345193452034521345223452334524345253452634527345283452934530345313453234533345343453534536345373453834539345403454134542345433454434545345463454734548345493455034551345523455334554345553455634557345583455934560345613456234563345643456534566345673456834569345703457134572345733457434575345763457734578345793458034581345823458334584345853458634587345883458934590345913459234593345943459534596345973459834599346003460134602346033460434605346063460734608346093461034611346123461334614346153461634617346183461934620346213462234623346243462534626346273462834629346303463134632346333463434635346363463734638346393464034641346423464334644346453464634647346483464934650346513465234653346543465534656346573465834659346603466134662346633466434665346663466734668346693467034671346723467334674346753467634677346783467934680346813468234683346843468534686346873468834689346903469134692346933469434695346963469734698346993470034701347023470334704347053470634707347083470934710347113471234713347143471534716347173471834719347203472134722347233472434725347263472734728347293473034731347323473334734347353473634737347383473934740347413474234743347443474534746347473474834749347503475134752347533475434755347563475734758347593476034761347623476334764347653476634767347683476934770347713477234773347743477534776347773477834779347803478134782347833478434785347863478734788347893479034791347923479334794347953479634797347983479934800348013480234803348043480534806348073480834809348103481134812348133481434815348163481734818348193482034821348223482334824348253482634827348283482934830348313483234833348343483534836348373483834839348403484134842348433484434845348463484734848348493485034851348523485334854348553485634857348583485934860348613486234863348643486534866348673486834869348703487134872348733487434875348763487734878348793488034881348823488334884348853488634887348883488934890348913489234893348943489534896348973489834899349003490134902349033490434905349063490734908349093491034911349123491334914349153491634917349183491934920349213492234923349243492534926349273492834929349303493134932349333493434935349363493734938349393494034941349423494334944349453494634947349483494934950349513495234953349543495534956349573495834959349603496134962349633496434965349663496734968349693497034971349723497334974349753497634977349783497934980349813498234983349843498534986349873498834989349903499134992349933499434995349963499734998349993500035001350023500335004350053500635007350083500935010350113501235013350143501535016350173501835019350203502135022350233502435025350263502735028350293503035031350323503335034350353503635037350383503935040350413504235043350443504535046350473504835049350503505135052350533505435055350563505735058350593506035061350623506335064350653506635067350683506935070350713507235073350743507535076350773507835079350803508135082350833508435085350863508735088350893509035091350923509335094350953509635097350983509935100351013510235103351043510535106351073510835109351103511135112351133511435115351163511735118351193512035121351223512335124351253512635127351283512935130351313513235133351343513535136351373513835139351403514135142351433514435145351463514735148351493515035151351523515335154351553515635157351583515935160351613516235163351643516535166351673516835169351703517135172351733517435175351763517735178351793518035181351823518335184351853518635187351883518935190351913519235193351943519535196351973519835199352003520135202352033520435205352063520735208352093521035211352123521335214352153521635217352183521935220352213522235223352243522535226352273522835229352303523135232352333523435235352363523735238352393524035241352423524335244352453524635247352483524935250352513525235253352543525535256352573525835259352603526135262352633526435265352663526735268352693527035271352723527335274352753527635277352783527935280352813528235283352843528535286352873528835289352903529135292352933529435295352963529735298352993530035301353023530335304353053530635307353083530935310353113531235313353143531535316353173531835319353203532135322353233532435325353263532735328353293533035331353323533335334353353533635337353383533935340353413534235343353443534535346353473534835349353503535135352353533535435355353563535735358353593536035361353623536335364353653536635367353683536935370353713537235373353743537535376353773537835379353803538135382353833538435385353863538735388353893539035391353923539335394353953539635397353983539935400354013540235403354043540535406354073540835409354103541135412354133541435415354163541735418354193542035421354223542335424354253542635427354283542935430354313543235433354343543535436354373543835439354403544135442354433544435445354463544735448354493545035451354523545335454354553545635457354583545935460354613546235463354643546535466354673546835469354703547135472354733547435475354763547735478354793548035481354823548335484354853548635487354883548935490354913549235493354943549535496354973549835499355003550135502355033550435505355063550735508355093551035511355123551335514355153551635517355183551935520355213552235523355243552535526355273552835529355303553135532355333553435535355363553735538355393554035541355423554335544355453554635547355483554935550355513555235553355543555535556355573555835559355603556135562355633556435565355663556735568355693557035571355723557335574355753557635577355783557935580355813558235583355843558535586355873558835589355903559135592355933559435595355963559735598355993560035601356023560335604356053560635607356083560935610356113561235613356143561535616356173561835619356203562135622356233562435625356263562735628356293563035631356323563335634356353563635637356383563935640356413564235643356443564535646356473564835649356503565135652356533565435655356563565735658356593566035661356623566335664356653566635667356683566935670356713567235673356743567535676356773567835679356803568135682356833568435685356863568735688356893569035691356923569335694356953569635697356983569935700357013570235703357043570535706357073570835709357103571135712357133571435715357163571735718357193572035721357223572335724357253572635727357283572935730357313573235733357343573535736357373573835739357403574135742357433574435745357463574735748357493575035751357523575335754357553575635757357583575935760357613576235763357643576535766357673576835769357703577135772357733577435775357763577735778357793578035781357823578335784357853578635787357883578935790357913579235793357943579535796357973579835799358003580135802358033580435805358063580735808358093581035811358123581335814358153581635817358183581935820358213582235823358243582535826358273582835829358303583135832358333583435835358363583735838358393584035841358423584335844358453584635847358483584935850358513585235853358543585535856358573585835859358603586135862358633586435865358663586735868358693587035871358723587335874358753587635877358783587935880358813588235883358843588535886358873588835889358903589135892358933589435895358963589735898358993590035901359023590335904359053590635907359083590935910359113591235913359143591535916359173591835919359203592135922359233592435925359263592735928359293593035931359323593335934359353593635937359383593935940359413594235943359443594535946359473594835949359503595135952359533595435955359563595735958359593596035961359623596335964359653596635967359683596935970359713597235973359743597535976359773597835979359803598135982359833598435985359863598735988359893599035991359923599335994359953599635997359983599936000360013600236003360043600536006360073600836009360103601136012360133601436015360163601736018360193602036021360223602336024360253602636027360283602936030360313603236033360343603536036360373603836039360403604136042360433604436045360463604736048360493605036051360523605336054360553605636057360583605936060360613606236063360643606536066360673606836069360703607136072360733607436075360763607736078360793608036081360823608336084360853608636087360883608936090360913609236093360943609536096360973609836099361003610136102361033610436105361063610736108361093611036111361123611336114361153611636117361183611936120361213612236123361243612536126361273612836129361303613136132361333613436135361363613736138361393614036141361423614336144361453614636147361483614936150361513615236153361543615536156361573615836159361603616136162361633616436165361663616736168361693617036171361723617336174361753617636177361783617936180361813618236183361843618536186361873618836189361903619136192361933619436195361963619736198361993620036201362023620336204362053620636207362083620936210362113621236213362143621536216362173621836219362203622136222362233622436225362263622736228362293623036231362323623336234362353623636237362383623936240362413624236243362443624536246362473624836249362503625136252362533625436255362563625736258362593626036261362623626336264362653626636267362683626936270362713627236273362743627536276362773627836279362803628136282362833628436285362863628736288362893629036291362923629336294362953629636297362983629936300363013630236303363043630536306363073630836309363103631136312363133631436315363163631736318363193632036321363223632336324363253632636327363283632936330363313633236333363343633536336363373633836339363403634136342363433634436345363463634736348363493635036351363523635336354363553635636357363583635936360363613636236363363643636536366363673636836369363703637136372363733637436375363763637736378363793638036381363823638336384363853638636387363883638936390363913639236393363943639536396363973639836399364003640136402364033640436405364063640736408364093641036411364123641336414364153641636417364183641936420364213642236423364243642536426364273642836429364303643136432364333643436435364363643736438364393644036441364423644336444364453644636447364483644936450364513645236453364543645536456364573645836459364603646136462364633646436465364663646736468364693647036471364723647336474364753647636477364783647936480364813648236483364843648536486364873648836489364903649136492364933649436495364963649736498364993650036501365023650336504365053650636507365083650936510365113651236513365143651536516365173651836519365203652136522365233652436525365263652736528365293653036531365323653336534365353653636537365383653936540365413654236543365443654536546365473654836549365503655136552365533655436555365563655736558365593656036561365623656336564365653656636567365683656936570365713657236573365743657536576365773657836579365803658136582365833658436585365863658736588365893659036591365923659336594365953659636597365983659936600366013660236603366043660536606366073660836609366103661136612366133661436615366163661736618366193662036621366223662336624366253662636627366283662936630366313663236633366343663536636366373663836639366403664136642366433664436645366463664736648366493665036651366523665336654366553665636657366583665936660366613666236663366643666536666366673666836669366703667136672366733667436675366763667736678366793668036681366823668336684366853668636687366883668936690366913669236693366943669536696366973669836699367003670136702367033670436705367063670736708367093671036711367123671336714367153671636717367183671936720367213672236723367243672536726367273672836729367303673136732367333673436735367363673736738367393674036741367423674336744367453674636747367483674936750367513675236753367543675536756367573675836759367603676136762367633676436765367663676736768367693677036771367723677336774367753677636777367783677936780367813678236783367843678536786367873678836789367903679136792367933679436795367963679736798367993680036801368023680336804368053680636807368083680936810368113681236813368143681536816368173681836819368203682136822368233682436825368263682736828368293683036831368323683336834368353683636837368383683936840368413684236843368443684536846368473684836849368503685136852368533685436855368563685736858368593686036861368623686336864368653686636867368683686936870368713687236873368743687536876368773687836879368803688136882368833688436885368863688736888368893689036891368923689336894368953689636897368983689936900369013690236903369043690536906369073690836909369103691136912369133691436915369163691736918369193692036921369223692336924369253692636927369283692936930369313693236933369343693536936369373693836939369403694136942369433694436945369463694736948369493695036951369523695336954369553695636957369583695936960369613696236963369643696536966369673696836969369703697136972369733697436975369763697736978369793698036981369823698336984369853698636987369883698936990369913699236993369943699536996369973699836999370003700137002370033700437005370063700737008370093701037011370123701337014370153701637017370183701937020370213702237023370243702537026370273702837029370303703137032370333703437035370363703737038370393704037041370423704337044370453704637047370483704937050370513705237053370543705537056370573705837059370603706137062370633706437065370663706737068370693707037071370723707337074370753707637077370783707937080370813708237083370843708537086370873708837089370903709137092370933709437095370963709737098370993710037101371023710337104371053710637107371083710937110371113711237113371143711537116371173711837119371203712137122371233712437125371263712737128371293713037131371323713337134371353713637137371383713937140371413714237143371443714537146371473714837149371503715137152371533715437155371563715737158371593716037161371623716337164371653716637167371683716937170371713717237173371743717537176371773717837179371803718137182371833718437185371863718737188371893719037191371923719337194371953719637197371983719937200372013720237203372043720537206372073720837209372103721137212372133721437215372163721737218372193722037221372223722337224372253722637227372283722937230372313723237233372343723537236372373723837239372403724137242372433724437245372463724737248372493725037251372523725337254372553725637257372583725937260372613726237263372643726537266372673726837269372703727137272372733727437275372763727737278372793728037281372823728337284372853728637287372883728937290372913729237293372943729537296372973729837299373003730137302373033730437305373063730737308373093731037311373123731337314373153731637317373183731937320373213732237323373243732537326373273732837329373303733137332373333733437335373363733737338373393734037341373423734337344373453734637347373483734937350373513735237353373543735537356373573735837359373603736137362373633736437365373663736737368373693737037371373723737337374373753737637377373783737937380373813738237383373843738537386373873738837389373903739137392373933739437395373963739737398373993740037401374023740337404374053740637407374083740937410374113741237413374143741537416374173741837419374203742137422374233742437425374263742737428374293743037431374323743337434374353743637437374383743937440374413744237443374443744537446374473744837449374503745137452374533745437455374563745737458374593746037461374623746337464374653746637467374683746937470374713747237473374743747537476374773747837479374803748137482374833748437485374863748737488374893749037491374923749337494374953749637497374983749937500375013750237503375043750537506375073750837509375103751137512375133751437515375163751737518375193752037521375223752337524375253752637527375283752937530375313753237533375343753537536375373753837539375403754137542375433754437545375463754737548375493755037551375523755337554375553755637557375583755937560375613756237563375643756537566375673756837569375703757137572375733757437575375763757737578375793758037581375823758337584375853758637587375883758937590375913759237593375943759537596375973759837599376003760137602376033760437605376063760737608376093761037611376123761337614376153761637617376183761937620376213762237623376243762537626376273762837629376303763137632376333763437635376363763737638376393764037641376423764337644376453764637647376483764937650376513765237653376543765537656376573765837659376603766137662376633766437665376663766737668376693767037671376723767337674376753767637677376783767937680376813768237683376843768537686376873768837689376903769137692376933769437695376963769737698376993770037701377023770337704377053770637707377083770937710377113771237713377143771537716377173771837719377203772137722377233772437725377263772737728377293773037731377323773337734377353773637737377383773937740377413774237743377443774537746377473774837749377503775137752377533775437755377563775737758377593776037761377623776337764377653776637767377683776937770377713777237773377743777537776377773777837779377803778137782377833778437785377863778737788377893779037791377923779337794377953779637797377983779937800378013780237803378043780537806378073780837809378103781137812378133781437815378163781737818378193782037821378223782337824378253782637827378283782937830378313783237833378343783537836378373783837839378403784137842378433784437845378463784737848378493785037851378523785337854378553785637857378583785937860378613786237863378643786537866378673786837869378703787137872378733787437875378763787737878378793788037881378823788337884378853788637887378883788937890378913789237893378943789537896378973789837899379003790137902379033790437905379063790737908379093791037911379123791337914379153791637917379183791937920379213792237923379243792537926379273792837929379303793137932379333793437935379363793737938379393794037941379423794337944379453794637947379483794937950379513795237953379543795537956379573795837959379603796137962379633796437965379663796737968379693797037971379723797337974379753797637977379783797937980379813798237983379843798537986379873798837989379903799137992379933799437995379963799737998379993800038001380023800338004380053800638007380083800938010380113801238013380143801538016380173801838019380203802138022380233802438025380263802738028380293803038031380323803338034380353803638037380383803938040380413804238043380443804538046380473804838049380503805138052380533805438055380563805738058380593806038061380623806338064380653806638067380683806938070380713807238073380743807538076380773807838079380803808138082380833808438085380863808738088380893809038091380923809338094380953809638097380983809938100381013810238103381043810538106381073810838109381103811138112381133811438115381163811738118381193812038121381223812338124381253812638127381283812938130381313813238133381343813538136381373813838139381403814138142381433814438145381463814738148381493815038151381523815338154381553815638157381583815938160381613816238163381643816538166381673816838169381703817138172381733817438175381763817738178381793818038181381823818338184381853818638187381883818938190381913819238193381943819538196381973819838199382003820138202382033820438205382063820738208382093821038211382123821338214382153821638217382183821938220382213822238223382243822538226382273822838229382303823138232382333823438235382363823738238382393824038241382423824338244382453824638247382483824938250382513825238253382543825538256382573825838259382603826138262382633826438265382663826738268382693827038271382723827338274382753827638277382783827938280382813828238283382843828538286382873828838289382903829138292382933829438295382963829738298382993830038301383023830338304383053830638307383083830938310383113831238313383143831538316383173831838319383203832138322383233832438325383263832738328383293833038331383323833338334383353833638337383383833938340383413834238343383443834538346383473834838349383503835138352383533835438355383563835738358383593836038361383623836338364383653836638367383683836938370383713837238373383743837538376383773837838379383803838138382383833838438385383863838738388383893839038391383923839338394383953839638397383983839938400384013840238403384043840538406384073840838409384103841138412384133841438415384163841738418384193842038421384223842338424384253842638427384283842938430384313843238433384343843538436384373843838439384403844138442384433844438445384463844738448384493845038451384523845338454384553845638457384583845938460384613846238463384643846538466384673846838469384703847138472384733847438475384763847738478384793848038481384823848338484384853848638487384883848938490384913849238493384943849538496384973849838499385003850138502385033850438505385063850738508385093851038511385123851338514385153851638517385183851938520385213852238523385243852538526385273852838529385303853138532385333853438535385363853738538385393854038541385423854338544385453854638547385483854938550385513855238553385543855538556385573855838559385603856138562385633856438565385663856738568385693857038571385723857338574385753857638577385783857938580385813858238583385843858538586385873858838589385903859138592385933859438595385963859738598385993860038601386023860338604386053860638607386083860938610386113861238613386143861538616386173861838619386203862138622386233862438625386263862738628386293863038631386323863338634386353863638637386383863938640386413864238643386443864538646386473864838649386503865138652386533865438655386563865738658386593866038661386623866338664386653866638667386683866938670386713867238673386743867538676386773867838679386803868138682386833868438685386863868738688386893869038691386923869338694386953869638697386983869938700387013870238703387043870538706387073870838709387103871138712387133871438715387163871738718387193872038721387223872338724387253872638727387283872938730387313873238733387343873538736387373873838739387403874138742387433874438745387463874738748387493875038751387523875338754387553875638757387583875938760387613876238763387643876538766387673876838769387703877138772387733877438775387763877738778387793878038781387823878338784387853878638787387883878938790387913879238793387943879538796387973879838799388003880138802388033880438805388063880738808388093881038811388123881338814388153881638817388183881938820388213882238823388243882538826388273882838829388303883138832388333883438835388363883738838388393884038841388423884338844388453884638847388483884938850388513885238853388543885538856388573885838859388603886138862388633886438865388663886738868388693887038871388723887338874388753887638877388783887938880388813888238883388843888538886388873888838889388903889138892388933889438895388963889738898388993890038901389023890338904389053890638907389083890938910389113891238913389143891538916389173891838919389203892138922389233892438925389263892738928389293893038931389323893338934389353893638937389383893938940389413894238943389443894538946389473894838949389503895138952389533895438955389563895738958389593896038961389623896338964389653896638967389683896938970389713897238973389743897538976389773897838979389803898138982389833898438985389863898738988389893899038991389923899338994389953899638997389983899939000390013900239003390043900539006390073900839009390103901139012390133901439015390163901739018390193902039021390223902339024390253902639027390283902939030390313903239033390343903539036390373903839039390403904139042390433904439045390463904739048390493905039051390523905339054390553905639057390583905939060390613906239063390643906539066390673906839069390703907139072390733907439075390763907739078390793908039081390823908339084390853908639087390883908939090390913909239093390943909539096390973909839099391003910139102391033910439105391063910739108391093911039111391123911339114391153911639117391183911939120391213912239123391243912539126391273912839129391303913139132391333913439135391363913739138391393914039141391423914339144391453914639147391483914939150391513915239153391543915539156391573915839159391603916139162391633916439165391663916739168391693917039171391723917339174391753917639177391783917939180391813918239183391843918539186391873918839189391903919139192391933919439195391963919739198391993920039201392023920339204392053920639207392083920939210392113921239213392143921539216392173921839219392203922139222392233922439225392263922739228392293923039231392323923339234392353923639237392383923939240392413924239243392443924539246392473924839249392503925139252392533925439255392563925739258392593926039261392623926339264392653926639267392683926939270392713927239273392743927539276392773927839279392803928139282392833928439285392863928739288392893929039291392923929339294392953929639297392983929939300393013930239303393043930539306393073930839309393103931139312393133931439315393163931739318393193932039321393223932339324393253932639327393283932939330393313933239333393343933539336393373933839339393403934139342393433934439345393463934739348393493935039351393523935339354393553935639357393583935939360393613936239363393643936539366393673936839369393703937139372393733937439375393763937739378393793938039381393823938339384393853938639387393883938939390393913939239393393943939539396393973939839399394003940139402394033940439405394063940739408394093941039411394123941339414394153941639417394183941939420394213942239423394243942539426394273942839429394303943139432394333943439435394363943739438394393944039441394423944339444394453944639447394483944939450394513945239453394543945539456394573945839459394603946139462394633946439465394663946739468394693947039471394723947339474394753947639477394783947939480394813948239483394843948539486394873948839489394903949139492394933949439495394963949739498394993950039501395023950339504395053950639507395083950939510395113951239513395143951539516395173951839519395203952139522395233952439525395263952739528395293953039531395323953339534395353953639537395383953939540395413954239543395443954539546395473954839549395503955139552395533955439555395563955739558395593956039561395623956339564395653956639567395683956939570395713957239573395743957539576395773957839579395803958139582395833958439585395863958739588395893959039591395923959339594395953959639597395983959939600396013960239603396043960539606396073960839609396103961139612396133961439615396163961739618396193962039621396223962339624396253962639627396283962939630396313963239633396343963539636396373963839639396403964139642396433964439645396463964739648396493965039651396523965339654396553965639657396583965939660396613966239663396643966539666396673966839669396703967139672396733967439675396763967739678396793968039681396823968339684396853968639687396883968939690396913969239693396943969539696396973969839699397003970139702397033970439705397063970739708397093971039711397123971339714397153971639717397183971939720397213972239723397243972539726397273972839729397303973139732397333973439735397363973739738397393974039741397423974339744397453974639747397483974939750397513975239753397543975539756397573975839759397603976139762397633976439765397663976739768397693977039771397723977339774397753977639777397783977939780397813978239783397843978539786397873978839789397903979139792397933979439795397963979739798397993980039801398023980339804398053980639807398083980939810398113981239813398143981539816398173981839819398203982139822398233982439825398263982739828398293983039831398323983339834398353983639837398383983939840398413984239843398443984539846398473984839849398503985139852398533985439855398563985739858398593986039861398623986339864398653986639867398683986939870398713987239873398743987539876398773987839879398803988139882398833988439885398863988739888398893989039891398923989339894398953989639897398983989939900399013990239903399043990539906399073990839909399103991139912399133991439915399163991739918399193992039921399223992339924399253992639927399283992939930399313993239933399343993539936399373993839939399403994139942399433994439945399463994739948399493995039951399523995339954399553995639957399583995939960399613996239963399643996539966399673996839969399703997139972399733997439975399763997739978399793998039981399823998339984399853998639987399883998939990399913999239993399943999539996399973999839999400004000140002400034000440005400064000740008400094001040011400124001340014400154001640017400184001940020400214002240023400244002540026400274002840029400304003140032400334003440035400364003740038400394004040041400424004340044400454004640047400484004940050400514005240053400544005540056400574005840059400604006140062400634006440065400664006740068400694007040071400724007340074400754007640077400784007940080400814008240083400844008540086400874008840089400904009140092400934009440095400964009740098400994010040101401024010340104401054010640107401084010940110401114011240113401144011540116401174011840119401204012140122401234012440125401264012740128401294013040131401324013340134401354013640137401384013940140401414014240143401444014540146401474014840149401504015140152401534015440155401564015740158401594016040161401624016340164401654016640167401684016940170401714017240173401744017540176401774017840179401804018140182401834018440185401864018740188401894019040191401924019340194401954019640197401984019940200402014020240203402044020540206402074020840209402104021140212402134021440215402164021740218402194022040221402224022340224402254022640227402284022940230402314023240233402344023540236402374023840239402404024140242402434024440245402464024740248402494025040251402524025340254402554025640257402584025940260402614026240263402644026540266402674026840269402704027140272402734027440275402764027740278402794028040281402824028340284402854028640287402884028940290402914029240293402944029540296402974029840299403004030140302403034030440305403064030740308403094031040311403124031340314403154031640317403184031940320403214032240323403244032540326403274032840329403304033140332403334033440335403364033740338403394034040341403424034340344403454034640347403484034940350403514035240353403544035540356403574035840359403604036140362403634036440365403664036740368403694037040371403724037340374403754037640377403784037940380403814038240383403844038540386403874038840389403904039140392403934039440395403964039740398403994040040401404024040340404404054040640407404084040940410404114041240413404144041540416404174041840419404204042140422404234042440425404264042740428404294043040431404324043340434404354043640437404384043940440404414044240443404444044540446404474044840449404504045140452404534045440455404564045740458404594046040461404624046340464404654046640467404684046940470404714047240473404744047540476404774047840479404804048140482404834048440485404864048740488404894049040491404924049340494404954049640497404984049940500405014050240503405044050540506405074050840509405104051140512405134051440515405164051740518405194052040521405224052340524405254052640527405284052940530405314053240533405344053540536405374053840539405404054140542405434054440545405464054740548405494055040551405524055340554405554055640557405584055940560405614056240563405644056540566405674056840569405704057140572405734057440575405764057740578405794058040581405824058340584405854058640587405884058940590405914059240593405944059540596405974059840599406004060140602406034060440605406064060740608406094061040611406124061340614406154061640617406184061940620406214062240623406244062540626406274062840629406304063140632406334063440635406364063740638406394064040641406424064340644406454064640647406484064940650406514065240653406544065540656406574065840659406604066140662406634066440665406664066740668406694067040671406724067340674406754067640677406784067940680406814068240683406844068540686406874068840689406904069140692406934069440695406964069740698406994070040701407024070340704407054070640707407084070940710407114071240713407144071540716407174071840719407204072140722407234072440725407264072740728407294073040731407324073340734407354073640737407384073940740407414074240743407444074540746407474074840749407504075140752407534075440755407564075740758407594076040761407624076340764407654076640767407684076940770407714077240773407744077540776407774077840779407804078140782407834078440785407864078740788407894079040791407924079340794407954079640797407984079940800408014080240803408044080540806408074080840809408104081140812408134081440815408164081740818408194082040821408224082340824408254082640827408284082940830408314083240833408344083540836408374083840839408404084140842408434084440845408464084740848408494085040851408524085340854408554085640857408584085940860408614086240863408644086540866408674086840869408704087140872408734087440875408764087740878408794088040881408824088340884408854088640887408884088940890408914089240893408944089540896408974089840899409004090140902409034090440905409064090740908409094091040911409124091340914409154091640917409184091940920409214092240923409244092540926409274092840929409304093140932409334093440935409364093740938409394094040941409424094340944409454094640947409484094940950409514095240953409544095540956409574095840959409604096140962409634096440965409664096740968409694097040971409724097340974409754097640977409784097940980409814098240983409844098540986409874098840989409904099140992409934099440995409964099740998409994100041001410024100341004410054100641007410084100941010410114101241013410144101541016410174101841019410204102141022410234102441025410264102741028410294103041031410324103341034410354103641037410384103941040410414104241043410444104541046410474104841049410504105141052410534105441055410564105741058410594106041061410624106341064410654106641067410684106941070410714107241073410744107541076410774107841079410804108141082410834108441085410864108741088410894109041091410924109341094410954109641097410984109941100411014110241103411044110541106411074110841109411104111141112411134111441115411164111741118411194112041121411224112341124411254112641127411284112941130411314113241133411344113541136411374113841139411404114141142411434114441145411464114741148411494115041151411524115341154411554115641157411584115941160411614116241163411644116541166411674116841169411704117141172411734117441175411764117741178411794118041181411824118341184411854118641187411884118941190411914119241193411944119541196411974119841199412004120141202412034120441205412064120741208412094121041211412124121341214412154121641217412184121941220412214122241223412244122541226412274122841229412304123141232412334123441235412364123741238412394124041241412424124341244412454124641247412484124941250412514125241253412544125541256412574125841259412604126141262412634126441265412664126741268412694127041271412724127341274412754127641277412784127941280412814128241283412844128541286412874128841289412904129141292412934129441295412964129741298412994130041301413024130341304413054130641307413084130941310413114131241313413144131541316413174131841319413204132141322413234132441325413264132741328413294133041331413324133341334413354133641337413384133941340413414134241343413444134541346413474134841349413504135141352413534135441355413564135741358413594136041361413624136341364413654136641367413684136941370413714137241373413744137541376413774137841379413804138141382413834138441385413864138741388413894139041391413924139341394413954139641397413984139941400414014140241403414044140541406414074140841409414104141141412414134141441415414164141741418414194142041421414224142341424414254142641427414284142941430414314143241433414344143541436414374143841439414404144141442414434144441445414464144741448414494145041451414524145341454414554145641457414584145941460414614146241463414644146541466414674146841469414704147141472414734147441475414764147741478414794148041481414824148341484414854148641487414884148941490414914149241493414944149541496414974149841499415004150141502415034150441505415064150741508415094151041511415124151341514415154151641517415184151941520415214152241523415244152541526415274152841529415304153141532415334153441535415364153741538415394154041541415424154341544415454154641547415484154941550415514155241553415544155541556415574155841559415604156141562415634156441565415664156741568415694157041571415724157341574415754157641577415784157941580415814158241583415844158541586415874158841589415904159141592415934159441595415964159741598415994160041601416024160341604416054160641607416084160941610416114161241613416144161541616416174161841619416204162141622416234162441625416264162741628416294163041631416324163341634416354163641637416384163941640416414164241643416444164541646416474164841649416504165141652416534165441655416564165741658416594166041661416624166341664416654166641667416684166941670416714167241673416744167541676416774167841679416804168141682416834168441685416864168741688416894169041691416924169341694416954169641697416984169941700417014170241703417044170541706417074170841709417104171141712417134171441715417164171741718417194172041721417224172341724417254172641727417284172941730417314173241733417344173541736417374173841739417404174141742417434174441745417464174741748417494175041751417524175341754417554175641757417584175941760417614176241763417644176541766417674176841769417704177141772417734177441775417764177741778417794178041781417824178341784417854178641787417884178941790417914179241793417944179541796417974179841799418004180141802418034180441805418064180741808418094181041811418124181341814418154181641817418184181941820418214182241823418244182541826418274182841829418304183141832418334183441835418364183741838418394184041841418424184341844418454184641847418484184941850418514185241853418544185541856418574185841859418604186141862418634186441865418664186741868418694187041871418724187341874418754187641877418784187941880418814188241883418844188541886418874188841889418904189141892418934189441895418964189741898418994190041901419024190341904419054190641907419084190941910419114191241913419144191541916419174191841919419204192141922419234192441925419264192741928419294193041931419324193341934419354193641937419384193941940419414194241943419444194541946419474194841949419504195141952419534195441955419564195741958419594196041961419624196341964419654196641967419684196941970419714197241973419744197541976419774197841979419804198141982419834198441985419864198741988419894199041991419924199341994419954199641997419984199942000420014200242003420044200542006420074200842009420104201142012420134201442015420164201742018420194202042021420224202342024420254202642027420284202942030420314203242033420344203542036420374203842039420404204142042420434204442045420464204742048420494205042051420524205342054420554205642057420584205942060420614206242063420644206542066420674206842069420704207142072420734207442075420764207742078420794208042081420824208342084420854208642087420884208942090420914209242093420944209542096420974209842099421004210142102421034210442105421064210742108421094211042111421124211342114421154211642117421184211942120421214212242123421244212542126421274212842129421304213142132421334213442135421364213742138421394214042141421424214342144421454214642147421484214942150421514215242153421544215542156421574215842159421604216142162421634216442165421664216742168421694217042171421724217342174421754217642177421784217942180421814218242183421844218542186421874218842189421904219142192421934219442195421964219742198421994220042201422024220342204422054220642207422084220942210422114221242213422144221542216422174221842219422204222142222422234222442225422264222742228422294223042231422324223342234422354223642237422384223942240422414224242243422444224542246422474224842249422504225142252422534225442255422564225742258422594226042261422624226342264422654226642267422684226942270422714227242273422744227542276422774227842279422804228142282422834228442285422864228742288422894229042291422924229342294422954229642297422984229942300423014230242303423044230542306423074230842309423104231142312423134231442315423164231742318423194232042321423224232342324423254232642327423284232942330423314233242333423344233542336423374233842339423404234142342423434234442345423464234742348423494235042351423524235342354423554235642357423584235942360423614236242363423644236542366423674236842369423704237142372423734237442375423764237742378423794238042381423824238342384423854238642387423884238942390423914239242393423944239542396423974239842399424004240142402424034240442405424064240742408424094241042411424124241342414424154241642417424184241942420424214242242423424244242542426424274242842429424304243142432424334243442435424364243742438424394244042441424424244342444424454244642447424484244942450424514245242453424544245542456424574245842459424604246142462424634246442465424664246742468424694247042471424724247342474424754247642477424784247942480424814248242483424844248542486424874248842489424904249142492424934249442495424964249742498424994250042501425024250342504425054250642507425084250942510425114251242513425144251542516425174251842519425204252142522425234252442525425264252742528425294253042531425324253342534425354253642537425384253942540425414254242543425444254542546425474254842549425504255142552425534255442555425564255742558425594256042561425624256342564425654256642567425684256942570425714257242573425744257542576425774257842579425804258142582425834258442585425864258742588425894259042591425924259342594425954259642597425984259942600426014260242603426044260542606426074260842609426104261142612426134261442615426164261742618426194262042621426224262342624426254262642627426284262942630426314263242633426344263542636426374263842639426404264142642426434264442645426464264742648426494265042651426524265342654426554265642657426584265942660426614266242663426644266542666426674266842669426704267142672426734267442675426764267742678426794268042681426824268342684426854268642687426884268942690426914269242693426944269542696426974269842699427004270142702427034270442705427064270742708427094271042711427124271342714427154271642717427184271942720427214272242723427244272542726427274272842729427304273142732427334273442735427364273742738427394274042741427424274342744427454274642747427484274942750427514275242753427544275542756427574275842759427604276142762427634276442765427664276742768427694277042771427724277342774427754277642777427784277942780427814278242783427844278542786427874278842789427904279142792427934279442795427964279742798427994280042801428024280342804428054280642807428084280942810428114281242813428144281542816428174281842819428204282142822428234282442825428264282742828428294283042831428324283342834428354283642837428384283942840428414284242843428444284542846428474284842849428504285142852428534285442855428564285742858428594286042861428624286342864428654286642867428684286942870428714287242873428744287542876428774287842879428804288142882428834288442885428864288742888428894289042891428924289342894428954289642897428984289942900429014290242903429044290542906429074290842909429104291142912429134291442915429164291742918429194292042921429224292342924429254292642927429284292942930429314293242933429344293542936429374293842939429404294142942429434294442945429464294742948429494295042951429524295342954429554295642957429584295942960429614296242963429644296542966429674296842969429704297142972429734297442975429764297742978429794298042981429824298342984429854298642987429884298942990429914299242993429944299542996429974299842999430004300143002430034300443005430064300743008430094301043011430124301343014430154301643017430184301943020430214302243023430244302543026430274302843029430304303143032430334303443035430364303743038430394304043041430424304343044430454304643047430484304943050430514305243053430544305543056430574305843059430604306143062430634306443065430664306743068430694307043071430724307343074430754307643077430784307943080430814308243083430844308543086430874308843089430904309143092430934309443095430964309743098430994310043101431024310343104431054310643107431084310943110431114311243113431144311543116431174311843119431204312143122431234312443125431264312743128431294313043131431324313343134431354313643137431384313943140431414314243143431444314543146431474314843149431504315143152431534315443155431564315743158431594316043161431624316343164431654316643167431684316943170431714317243173431744317543176431774317843179431804318143182431834318443185431864318743188431894319043191431924319343194431954319643197431984319943200432014320243203432044320543206432074320843209432104321143212432134321443215432164321743218432194322043221432224322343224432254322643227432284322943230432314323243233432344323543236432374323843239432404324143242432434324443245432464324743248432494325043251432524325343254432554325643257432584325943260432614326243263432644326543266432674326843269432704327143272432734327443275432764327743278432794328043281432824328343284432854328643287432884328943290432914329243293432944329543296432974329843299433004330143302433034330443305433064330743308433094331043311433124331343314433154331643317433184331943320433214332243323433244332543326433274332843329433304333143332433334333443335433364333743338433394334043341433424334343344433454334643347433484334943350433514335243353433544335543356433574335843359433604336143362433634336443365433664336743368433694337043371433724337343374433754337643377433784337943380433814338243383433844338543386433874338843389433904339143392433934339443395433964339743398433994340043401434024340343404434054340643407434084340943410434114341243413434144341543416434174341843419434204342143422434234342443425434264342743428434294343043431434324343343434434354343643437434384343943440434414344243443434444344543446434474344843449434504345143452434534345443455434564345743458434594346043461434624346343464434654346643467434684346943470434714347243473434744347543476434774347843479434804348143482434834348443485434864348743488434894349043491434924349343494434954349643497434984349943500435014350243503435044350543506435074350843509435104351143512435134351443515435164351743518435194352043521435224352343524435254352643527435284352943530435314353243533435344353543536435374353843539435404354143542435434354443545435464354743548435494355043551435524355343554435554355643557435584355943560435614356243563435644356543566435674356843569435704357143572435734357443575435764357743578435794358043581435824358343584435854358643587435884358943590435914359243593435944359543596435974359843599436004360143602436034360443605436064360743608436094361043611436124361343614436154361643617436184361943620436214362243623436244362543626436274362843629436304363143632436334363443635436364363743638436394364043641436424364343644436454364643647436484364943650436514365243653436544365543656436574365843659436604366143662436634366443665436664366743668436694367043671436724367343674436754367643677436784367943680436814368243683436844368543686436874368843689436904369143692436934369443695436964369743698436994370043701437024370343704437054370643707437084370943710437114371243713437144371543716437174371843719437204372143722437234372443725437264372743728437294373043731437324373343734437354373643737437384373943740437414374243743437444374543746437474374843749437504375143752437534375443755437564375743758437594376043761437624376343764437654376643767437684376943770437714377243773437744377543776437774377843779437804378143782437834378443785437864378743788437894379043791437924379343794437954379643797437984379943800438014380243803438044380543806438074380843809438104381143812438134381443815438164381743818438194382043821438224382343824438254382643827438284382943830438314383243833438344383543836438374383843839438404384143842438434384443845438464384743848438494385043851438524385343854438554385643857438584385943860438614386243863438644386543866438674386843869438704387143872438734387443875438764387743878438794388043881438824388343884438854388643887438884388943890438914389243893438944389543896438974389843899439004390143902439034390443905439064390743908439094391043911439124391343914439154391643917439184391943920439214392243923439244392543926439274392843929439304393143932439334393443935439364393743938439394394043941439424394343944439454394643947439484394943950439514395243953439544395543956439574395843959439604396143962439634396443965439664396743968439694397043971439724397343974439754397643977439784397943980439814398243983439844398543986439874398843989439904399143992439934399443995439964399743998439994400044001440024400344004440054400644007440084400944010440114401244013440144401544016440174401844019440204402144022440234402444025440264402744028440294403044031440324403344034440354403644037440384403944040440414404244043440444404544046440474404844049440504405144052440534405444055440564405744058440594406044061440624406344064440654406644067440684406944070440714407244073440744407544076440774407844079440804408144082440834408444085440864408744088440894409044091440924409344094440954409644097440984409944100441014410244103441044410544106441074410844109441104411144112441134411444115441164411744118441194412044121441224412344124441254412644127441284412944130441314413244133441344413544136441374413844139441404414144142441434414444145441464414744148441494415044151441524415344154441554415644157441584415944160441614416244163441644416544166441674416844169441704417144172441734417444175441764417744178441794418044181441824418344184441854418644187441884418944190441914419244193441944419544196441974419844199442004420144202442034420444205442064420744208442094421044211442124421344214442154421644217442184421944220442214422244223442244422544226442274422844229442304423144232442334423444235442364423744238442394424044241442424424344244442454424644247442484424944250442514425244253442544425544256442574425844259442604426144262442634426444265442664426744268442694427044271442724427344274442754427644277442784427944280442814428244283442844428544286442874428844289442904429144292442934429444295442964429744298442994430044301443024430344304443054430644307443084430944310443114431244313443144431544316443174431844319443204432144322443234432444325443264432744328443294433044331443324433344334443354433644337443384433944340443414434244343443444434544346443474434844349443504435144352443534435444355443564435744358443594436044361443624436344364443654436644367443684436944370443714437244373443744437544376443774437844379443804438144382443834438444385443864438744388443894439044391443924439344394443954439644397443984439944400444014440244403444044440544406444074440844409444104441144412444134441444415444164441744418444194442044421444224442344424444254442644427444284442944430444314443244433444344443544436444374443844439444404444144442444434444444445444464444744448444494445044451444524445344454444554445644457444584445944460444614446244463444644446544466444674446844469444704447144472444734447444475444764447744478444794448044481444824448344484444854448644487444884448944490444914449244493444944449544496444974449844499445004450144502445034450444505445064450744508445094451044511445124451344514445154451644517445184451944520445214452244523445244452544526445274452844529445304453144532445334453444535445364453744538445394454044541445424454344544445454454644547445484454944550445514455244553445544455544556445574455844559445604456144562445634456444565445664456744568445694457044571445724457344574445754457644577445784457944580445814458244583445844458544586445874458844589445904459144592445934459444595445964459744598445994460044601446024460344604446054460644607446084460944610446114461244613446144461544616446174461844619446204462144622446234462444625446264462744628446294463044631446324463344634446354463644637446384463944640446414464244643446444464544646446474464844649446504465144652446534465444655446564465744658446594466044661446624466344664446654466644667446684466944670446714467244673446744467544676446774467844679446804468144682446834468444685446864468744688446894469044691446924469344694446954469644697446984469944700447014470244703447044470544706447074470844709447104471144712447134471444715447164471744718447194472044721447224472344724447254472644727447284472944730447314473244733447344473544736447374473844739447404474144742447434474444745447464474744748447494475044751447524475344754447554475644757447584475944760447614476244763447644476544766447674476844769447704477144772447734477444775447764477744778447794478044781447824478344784447854478644787447884478944790447914479244793447944479544796447974479844799448004480144802448034480444805448064480744808448094481044811448124481344814448154481644817448184481944820448214482244823448244482544826448274482844829448304483144832448334483444835448364483744838448394484044841448424484344844448454484644847448484484944850448514485244853448544485544856448574485844859448604486144862448634486444865448664486744868448694487044871448724487344874448754487644877448784487944880448814488244883448844488544886448874488844889448904489144892448934489444895448964489744898448994490044901449024490344904449054490644907449084490944910449114491244913449144491544916449174491844919449204492144922449234492444925449264492744928449294493044931449324493344934449354493644937449384493944940449414494244943449444494544946449474494844949449504495144952449534495444955449564495744958449594496044961449624496344964449654496644967449684496944970449714497244973449744497544976449774497844979449804498144982449834498444985449864498744988449894499044991449924499344994449954499644997449984499945000450014500245003450044500545006450074500845009450104501145012450134501445015450164501745018450194502045021450224502345024450254502645027450284502945030450314503245033450344503545036450374503845039450404504145042450434504445045450464504745048450494505045051450524505345054450554505645057450584505945060450614506245063450644506545066450674506845069450704507145072450734507445075450764507745078450794508045081450824508345084450854508645087450884508945090450914509245093450944509545096450974509845099451004510145102451034510445105451064510745108451094511045111451124511345114451154511645117451184511945120451214512245123451244512545126451274512845129451304513145132451334513445135451364513745138451394514045141451424514345144451454514645147451484514945150451514515245153451544515545156451574515845159451604516145162451634516445165451664516745168451694517045171451724517345174451754517645177451784517945180451814518245183451844518545186451874518845189451904519145192451934519445195451964519745198451994520045201452024520345204452054520645207452084520945210452114521245213452144521545216452174521845219452204522145222452234522445225452264522745228452294523045231452324523345234452354523645237452384523945240452414524245243452444524545246452474524845249452504525145252452534525445255452564525745258452594526045261452624526345264452654526645267452684526945270452714527245273452744527545276452774527845279452804528145282452834528445285452864528745288452894529045291452924529345294452954529645297452984529945300453014530245303453044530545306453074530845309453104531145312453134531445315453164531745318453194532045321453224532345324453254532645327453284532945330453314533245333453344533545336453374533845339453404534145342453434534445345453464534745348453494535045351453524535345354453554535645357453584535945360453614536245363453644536545366453674536845369453704537145372453734537445375453764537745378453794538045381453824538345384453854538645387453884538945390453914539245393453944539545396453974539845399454004540145402454034540445405454064540745408454094541045411454124541345414454154541645417454184541945420454214542245423454244542545426454274542845429454304543145432454334543445435454364543745438454394544045441454424544345444454454544645447454484544945450454514545245453454544545545456454574545845459454604546145462454634546445465454664546745468454694547045471454724547345474454754547645477454784547945480454814548245483454844548545486454874548845489454904549145492454934549445495454964549745498454994550045501455024550345504455054550645507455084550945510455114551245513455144551545516455174551845519455204552145522455234552445525455264552745528455294553045531455324553345534455354553645537455384553945540455414554245543455444554545546455474554845549455504555145552455534555445555455564555745558455594556045561455624556345564455654556645567455684556945570455714557245573455744557545576455774557845579455804558145582455834558445585455864558745588455894559045591455924559345594455954559645597455984559945600456014560245603456044560545606456074560845609456104561145612456134561445615456164561745618456194562045621456224562345624456254562645627456284562945630456314563245633456344563545636456374563845639456404564145642456434564445645456464564745648456494565045651456524565345654456554565645657456584565945660456614566245663456644566545666456674566845669456704567145672456734567445675456764567745678456794568045681456824568345684456854568645687456884568945690456914569245693456944569545696456974569845699457004570145702457034570445705457064570745708457094571045711457124571345714457154571645717457184571945720457214572245723457244572545726457274572845729457304573145732457334573445735457364573745738457394574045741457424574345744457454574645747457484574945750457514575245753457544575545756457574575845759457604576145762457634576445765457664576745768457694577045771457724577345774457754577645777457784577945780457814578245783457844578545786457874578845789457904579145792457934579445795457964579745798457994580045801458024580345804458054580645807458084580945810458114581245813458144581545816458174581845819458204582145822458234582445825458264582745828458294583045831458324583345834458354583645837458384583945840458414584245843458444584545846458474584845849458504585145852458534585445855458564585745858458594586045861458624586345864458654586645867458684586945870458714587245873458744587545876458774587845879458804588145882458834588445885458864588745888458894589045891458924589345894458954589645897458984589945900459014590245903459044590545906459074590845909459104591145912459134591445915459164591745918459194592045921459224592345924459254592645927459284592945930459314593245933459344593545936459374593845939459404594145942459434594445945459464594745948459494595045951459524595345954459554595645957459584595945960459614596245963459644596545966459674596845969459704597145972459734597445975459764597745978459794598045981459824598345984459854598645987459884598945990459914599245993459944599545996459974599845999460004600146002460034600446005460064600746008460094601046011460124601346014460154601646017460184601946020460214602246023460244602546026460274602846029460304603146032460334603446035460364603746038460394604046041460424604346044460454604646047460484604946050460514605246053460544605546056460574605846059460604606146062460634606446065460664606746068460694607046071460724607346074460754607646077460784607946080460814608246083460844608546086460874608846089460904609146092460934609446095460964609746098460994610046101461024610346104461054610646107461084610946110461114611246113461144611546116461174611846119461204612146122461234612446125461264612746128461294613046131461324613346134461354613646137461384613946140461414614246143461444614546146461474614846149461504615146152461534615446155461564615746158461594616046161461624616346164461654616646167461684616946170461714617246173461744617546176461774617846179461804618146182461834618446185461864618746188461894619046191461924619346194461954619646197461984619946200462014620246203462044620546206462074620846209462104621146212462134621446215462164621746218462194622046221462224622346224462254622646227462284622946230462314623246233462344623546236462374623846239462404624146242462434624446245462464624746248462494625046251462524625346254462554625646257462584625946260462614626246263462644626546266462674626846269462704627146272462734627446275462764627746278462794628046281462824628346284462854628646287462884628946290462914629246293462944629546296462974629846299463004630146302463034630446305463064630746308463094631046311463124631346314463154631646317463184631946320463214632246323463244632546326463274632846329463304633146332463334633446335463364633746338463394634046341463424634346344463454634646347463484634946350463514635246353463544635546356463574635846359463604636146362463634636446365463664636746368463694637046371463724637346374463754637646377463784637946380463814638246383463844638546386463874638846389463904639146392463934639446395463964639746398463994640046401464024640346404464054640646407464084640946410464114641246413464144641546416464174641846419464204642146422464234642446425464264642746428464294643046431464324643346434464354643646437464384643946440464414644246443464444644546446464474644846449464504645146452464534645446455464564645746458464594646046461464624646346464464654646646467464684646946470464714647246473464744647546476464774647846479464804648146482464834648446485464864648746488464894649046491464924649346494464954649646497464984649946500465014650246503465044650546506465074650846509465104651146512465134651446515465164651746518465194652046521465224652346524465254652646527465284652946530465314653246533465344653546536465374653846539465404654146542465434654446545465464654746548465494655046551465524655346554465554655646557465584655946560465614656246563465644656546566465674656846569465704657146572465734657446575465764657746578465794658046581465824658346584465854658646587465884658946590465914659246593465944659546596465974659846599466004660146602466034660446605466064660746608466094661046611466124661346614466154661646617466184661946620466214662246623466244662546626466274662846629466304663146632466334663446635466364663746638466394664046641466424664346644466454664646647466484664946650466514665246653466544665546656466574665846659466604666146662466634666446665466664666746668466694667046671466724667346674466754667646677466784667946680466814668246683466844668546686466874668846689466904669146692466934669446695466964669746698466994670046701467024670346704467054670646707467084670946710467114671246713467144671546716467174671846719467204672146722467234672446725467264672746728467294673046731467324673346734467354673646737467384673946740467414674246743467444674546746467474674846749467504675146752467534675446755467564675746758467594676046761467624676346764467654676646767467684676946770467714677246773467744677546776467774677846779467804678146782467834678446785467864678746788467894679046791467924679346794467954679646797467984679946800468014680246803468044680546806468074680846809468104681146812468134681446815468164681746818468194682046821468224682346824468254682646827468284682946830468314683246833468344683546836468374683846839468404684146842468434684446845468464684746848468494685046851468524685346854468554685646857468584685946860468614686246863468644686546866468674686846869468704687146872468734687446875468764687746878468794688046881468824688346884468854688646887468884688946890468914689246893468944689546896468974689846899469004690146902469034690446905469064690746908469094691046911469124691346914469154691646917469184691946920469214692246923469244692546926469274692846929469304693146932469334693446935469364693746938469394694046941469424694346944469454694646947469484694946950469514695246953469544695546956469574695846959469604696146962469634696446965469664696746968469694697046971469724697346974469754697646977469784697946980469814698246983469844698546986469874698846989469904699146992469934699446995469964699746998469994700047001470024700347004470054700647007470084700947010470114701247013470144701547016470174701847019470204702147022470234702447025470264702747028470294703047031470324703347034470354703647037470384703947040470414704247043470444704547046470474704847049470504705147052470534705447055470564705747058470594706047061470624706347064470654706647067470684706947070470714707247073470744707547076470774707847079470804708147082470834708447085470864708747088470894709047091470924709347094470954709647097470984709947100471014710247103471044710547106471074710847109471104711147112471134711447115471164711747118471194712047121471224712347124471254712647127471284712947130471314713247133471344713547136471374713847139471404714147142471434714447145471464714747148471494715047151471524715347154471554715647157471584715947160471614716247163471644716547166471674716847169471704717147172471734717447175471764717747178471794718047181471824718347184471854718647187471884718947190471914719247193471944719547196471974719847199472004720147202472034720447205472064720747208472094721047211472124721347214472154721647217472184721947220472214722247223472244722547226472274722847229472304723147232472334723447235472364723747238472394724047241472424724347244472454724647247472484724947250472514725247253472544725547256472574725847259472604726147262472634726447265472664726747268472694727047271472724727347274472754727647277472784727947280472814728247283472844728547286472874728847289472904729147292472934729447295472964729747298472994730047301473024730347304473054730647307473084730947310473114731247313473144731547316473174731847319473204732147322473234732447325473264732747328473294733047331473324733347334473354733647337473384733947340473414734247343473444734547346473474734847349473504735147352473534735447355473564735747358473594736047361473624736347364473654736647367473684736947370473714737247373473744737547376473774737847379473804738147382473834738447385473864738747388473894739047391473924739347394473954739647397473984739947400474014740247403474044740547406474074740847409474104741147412474134741447415474164741747418474194742047421474224742347424474254742647427474284742947430474314743247433474344743547436474374743847439474404744147442474434744447445474464744747448474494745047451474524745347454474554745647457474584745947460474614746247463474644746547466474674746847469474704747147472474734747447475474764747747478474794748047481474824748347484474854748647487474884748947490474914749247493474944749547496474974749847499475004750147502475034750447505475064750747508475094751047511475124751347514475154751647517475184751947520475214752247523475244752547526475274752847529475304753147532475334753447535475364753747538475394754047541475424754347544475454754647547475484754947550475514755247553475544755547556475574755847559475604756147562475634756447565475664756747568475694757047571475724757347574475754757647577475784757947580475814758247583475844758547586475874758847589475904759147592475934759447595475964759747598475994760047601476024760347604476054760647607476084760947610476114761247613476144761547616476174761847619476204762147622476234762447625476264762747628476294763047631476324763347634476354763647637476384763947640476414764247643476444764547646476474764847649476504765147652476534765447655476564765747658476594766047661476624766347664476654766647667476684766947670476714767247673476744767547676476774767847679476804768147682476834768447685476864768747688476894769047691476924769347694476954769647697476984769947700477014770247703477044770547706477074770847709477104771147712477134771447715477164771747718477194772047721477224772347724477254772647727477284772947730477314773247733477344773547736477374773847739477404774147742477434774447745477464774747748477494775047751477524775347754477554775647757477584775947760477614776247763477644776547766477674776847769477704777147772477734777447775477764777747778477794778047781477824778347784477854778647787477884778947790477914779247793477944779547796477974779847799478004780147802478034780447805478064780747808478094781047811478124781347814478154781647817478184781947820478214782247823478244782547826478274782847829478304783147832478334783447835478364783747838478394784047841478424784347844478454784647847478484784947850478514785247853478544785547856478574785847859478604786147862478634786447865478664786747868478694787047871478724787347874478754787647877478784787947880478814788247883478844788547886478874788847889478904789147892478934789447895478964789747898478994790047901479024790347904479054790647907479084790947910479114791247913479144791547916479174791847919479204792147922479234792447925479264792747928479294793047931479324793347934479354793647937479384793947940479414794247943479444794547946479474794847949479504795147952479534795447955479564795747958479594796047961479624796347964479654796647967479684796947970479714797247973479744797547976479774797847979479804798147982479834798447985479864798747988479894799047991479924799347994479954799647997479984799948000480014800248003480044800548006480074800848009480104801148012480134801448015480164801748018480194802048021480224802348024480254802648027480284802948030480314803248033480344803548036480374803848039480404804148042480434804448045480464804748048480494805048051480524805348054480554805648057480584805948060480614806248063480644806548066480674806848069480704807148072480734807448075480764807748078480794808048081480824808348084480854808648087480884808948090480914809248093480944809548096480974809848099481004810148102481034810448105481064810748108481094811048111481124811348114481154811648117481184811948120481214812248123481244812548126481274812848129481304813148132481334813448135481364813748138481394814048141481424814348144481454814648147481484814948150481514815248153481544815548156481574815848159481604816148162481634816448165481664816748168481694817048171481724817348174481754817648177481784817948180481814818248183481844818548186481874818848189481904819148192481934819448195481964819748198481994820048201482024820348204482054820648207482084820948210482114821248213482144821548216482174821848219482204822148222482234822448225482264822748228482294823048231482324823348234482354823648237482384823948240482414824248243482444824548246482474824848249482504825148252482534825448255482564825748258482594826048261482624826348264482654826648267482684826948270482714827248273482744827548276482774827848279482804828148282482834828448285482864828748288482894829048291482924829348294482954829648297482984829948300483014830248303483044830548306483074830848309483104831148312483134831448315483164831748318483194832048321483224832348324483254832648327483284832948330483314833248333483344833548336483374833848339483404834148342483434834448345483464834748348483494835048351483524835348354483554835648357483584835948360483614836248363483644836548366483674836848369483704837148372483734837448375483764837748378483794838048381483824838348384483854838648387483884838948390483914839248393483944839548396483974839848399484004840148402484034840448405484064840748408484094841048411484124841348414484154841648417484184841948420484214842248423484244842548426484274842848429484304843148432484334843448435484364843748438484394844048441484424844348444484454844648447484484844948450484514845248453484544845548456484574845848459484604846148462484634846448465484664846748468484694847048471484724847348474484754847648477484784847948480484814848248483484844848548486484874848848489484904849148492484934849448495484964849748498484994850048501485024850348504485054850648507485084850948510485114851248513485144851548516485174851848519485204852148522485234852448525485264852748528485294853048531485324853348534485354853648537485384853948540485414854248543485444854548546485474854848549485504855148552485534855448555485564855748558485594856048561485624856348564485654856648567485684856948570485714857248573485744857548576485774857848579485804858148582485834858448585485864858748588485894859048591485924859348594485954859648597485984859948600486014860248603486044860548606486074860848609486104861148612486134861448615486164861748618486194862048621486224862348624486254862648627486284862948630486314863248633486344863548636486374863848639486404864148642486434864448645486464864748648486494865048651486524865348654486554865648657486584865948660486614866248663486644866548666486674866848669486704867148672486734867448675486764867748678486794868048681486824868348684486854868648687486884868948690486914869248693486944869548696486974869848699487004870148702487034870448705487064870748708487094871048711487124871348714487154871648717487184871948720487214872248723487244872548726487274872848729487304873148732487334873448735487364873748738487394874048741487424874348744487454874648747487484874948750487514875248753487544875548756487574875848759487604876148762487634876448765487664876748768487694877048771487724877348774487754877648777487784877948780487814878248783487844878548786487874878848789487904879148792487934879448795487964879748798487994880048801488024880348804488054880648807488084880948810488114881248813488144881548816488174881848819488204882148822488234882448825488264882748828488294883048831488324883348834488354883648837488384883948840488414884248843488444884548846488474884848849488504885148852488534885448855488564885748858488594886048861488624886348864488654886648867488684886948870488714887248873488744887548876488774887848879488804888148882488834888448885488864888748888488894889048891488924889348894488954889648897488984889948900489014890248903489044890548906489074890848909489104891148912489134891448915489164891748918489194892048921489224892348924489254892648927489284892948930489314893248933489344893548936489374893848939489404894148942489434894448945489464894748948489494895048951489524895348954489554895648957489584895948960489614896248963489644896548966489674896848969489704897148972489734897448975489764897748978489794898048981489824898348984489854898648987489884898948990489914899248993489944899548996489974899848999490004900149002490034900449005490064900749008490094901049011490124901349014490154901649017490184901949020490214902249023490244902549026490274902849029490304903149032490334903449035490364903749038490394904049041490424904349044490454904649047490484904949050490514905249053490544905549056490574905849059490604906149062490634906449065490664906749068490694907049071490724907349074490754907649077490784907949080490814908249083490844908549086490874908849089490904909149092490934909449095490964909749098490994910049101491024910349104491054910649107491084910949110491114911249113491144911549116491174911849119491204912149122491234912449125491264912749128491294913049131491324913349134491354913649137491384913949140491414914249143491444914549146491474914849149491504915149152491534915449155491564915749158491594916049161491624916349164491654916649167491684916949170491714917249173491744917549176491774917849179491804918149182491834918449185491864918749188491894919049191491924919349194491954919649197491984919949200492014920249203492044920549206492074920849209492104921149212492134921449215492164921749218492194922049221492224922349224492254922649227492284922949230492314923249233492344923549236492374923849239492404924149242492434924449245492464924749248492494925049251492524925349254492554925649257492584925949260492614926249263492644926549266492674926849269492704927149272492734927449275492764927749278492794928049281492824928349284492854928649287492884928949290492914929249293492944929549296492974929849299493004930149302493034930449305493064930749308493094931049311493124931349314493154931649317493184931949320493214932249323493244932549326493274932849329493304933149332493334933449335493364933749338493394934049341493424934349344493454934649347493484934949350493514935249353493544935549356493574935849359493604936149362493634936449365493664936749368493694937049371493724937349374493754937649377493784937949380493814938249383493844938549386493874938849389493904939149392493934939449395493964939749398493994940049401494024940349404494054940649407494084940949410494114941249413494144941549416494174941849419494204942149422494234942449425494264942749428494294943049431494324943349434494354943649437494384943949440494414944249443494444944549446494474944849449494504945149452494534945449455494564945749458494594946049461494624946349464494654946649467494684946949470494714947249473494744947549476494774947849479494804948149482494834948449485494864948749488494894949049491494924949349494494954949649497494984949949500495014950249503495044950549506495074950849509495104951149512495134951449515495164951749518495194952049521495224952349524495254952649527495284952949530495314953249533495344953549536495374953849539495404954149542495434954449545495464954749548495494955049551495524955349554495554955649557495584955949560495614956249563495644956549566495674956849569495704957149572495734957449575495764957749578495794958049581495824958349584495854958649587495884958949590495914959249593495944959549596495974959849599496004960149602496034960449605496064960749608496094961049611496124961349614496154961649617496184961949620496214962249623496244962549626496274962849629496304963149632496334963449635496364963749638496394964049641496424964349644496454964649647496484964949650496514965249653496544965549656496574965849659496604966149662496634966449665496664966749668496694967049671496724967349674496754967649677496784967949680496814968249683496844968549686496874968849689496904969149692496934969449695496964969749698496994970049701497024970349704497054970649707497084970949710497114971249713497144971549716497174971849719497204972149722497234972449725497264972749728497294973049731497324973349734497354973649737497384973949740497414974249743497444974549746497474974849749497504975149752497534975449755497564975749758497594976049761497624976349764497654976649767497684976949770497714977249773497744977549776497774977849779497804978149782497834978449785497864978749788497894979049791497924979349794497954979649797497984979949800498014980249803498044980549806498074980849809498104981149812498134981449815498164981749818498194982049821498224982349824498254982649827498284982949830498314983249833498344983549836498374983849839498404984149842498434984449845498464984749848498494985049851498524985349854498554985649857498584985949860498614986249863498644986549866498674986849869498704987149872498734987449875498764987749878498794988049881498824988349884498854988649887498884988949890498914989249893498944989549896498974989849899499004990149902499034990449905499064990749908499094991049911499124991349914499154991649917499184991949920499214992249923499244992549926499274992849929499304993149932499334993449935499364993749938499394994049941499424994349944499454994649947499484994949950499514995249953499544995549956499574995849959499604996149962499634996449965499664996749968499694997049971499724997349974499754997649977499784997949980499814998249983499844998549986499874998849989499904999149992499934999449995499964999749998499995000050001500025000350004500055000650007500085000950010500115001250013500145001550016500175001850019500205002150022500235002450025500265002750028500295003050031500325003350034500355003650037500385003950040500415004250043500445004550046500475004850049500505005150052500535005450055500565005750058500595006050061500625006350064500655006650067500685006950070500715007250073500745007550076500775007850079500805008150082500835008450085500865008750088500895009050091500925009350094500955009650097500985009950100501015010250103501045010550106501075010850109501105011150112501135011450115501165011750118501195012050121501225012350124501255012650127501285012950130501315013250133501345013550136501375013850139501405014150142501435014450145501465014750148501495015050151501525015350154501555015650157501585015950160501615016250163501645016550166501675016850169501705017150172501735017450175501765017750178501795018050181501825018350184501855018650187501885018950190501915019250193501945019550196501975019850199502005020150202502035020450205502065020750208502095021050211502125021350214502155021650217502185021950220502215022250223502245022550226502275022850229502305023150232502335023450235502365023750238502395024050241502425024350244502455024650247502485024950250502515025250253502545025550256502575025850259502605026150262502635026450265502665026750268502695027050271502725027350274502755027650277502785027950280502815028250283502845028550286502875028850289502905029150292502935029450295502965029750298502995030050301503025030350304503055030650307503085030950310503115031250313503145031550316503175031850319503205032150322503235032450325503265032750328503295033050331503325033350334503355033650337503385033950340503415034250343503445034550346503475034850349503505035150352503535035450355503565035750358503595036050361503625036350364503655036650367503685036950370503715037250373503745037550376503775037850379503805038150382503835038450385503865038750388503895039050391503925039350394503955039650397503985039950400504015040250403504045040550406504075040850409504105041150412504135041450415504165041750418504195042050421504225042350424504255042650427504285042950430504315043250433504345043550436504375043850439504405044150442504435044450445504465044750448504495045050451504525045350454504555045650457504585045950460504615046250463504645046550466504675046850469504705047150472504735047450475504765047750478504795048050481504825048350484504855048650487504885048950490504915049250493504945049550496504975049850499505005050150502505035050450505505065050750508505095051050511505125051350514505155051650517505185051950520505215052250523505245052550526505275052850529505305053150532505335053450535505365053750538505395054050541505425054350544505455054650547505485054950550505515055250553505545055550556505575055850559505605056150562505635056450565505665056750568505695057050571505725057350574505755057650577505785057950580505815058250583505845058550586505875058850589505905059150592505935059450595505965059750598505995060050601506025060350604506055060650607506085060950610506115061250613506145061550616506175061850619506205062150622506235062450625506265062750628506295063050631506325063350634506355063650637506385063950640506415064250643506445064550646506475064850649506505065150652506535065450655506565065750658506595066050661506625066350664506655066650667506685066950670506715067250673506745067550676506775067850679506805068150682506835068450685506865068750688506895069050691506925069350694506955069650697506985069950700507015070250703507045070550706507075070850709507105071150712507135071450715507165071750718507195072050721507225072350724507255072650727507285072950730507315073250733507345073550736507375073850739507405074150742507435074450745507465074750748507495075050751507525075350754507555075650757507585075950760507615076250763507645076550766507675076850769507705077150772507735077450775507765077750778507795078050781507825078350784507855078650787507885078950790507915079250793507945079550796507975079850799508005080150802508035080450805508065080750808508095081050811508125081350814508155081650817508185081950820508215082250823508245082550826508275082850829508305083150832508335083450835508365083750838508395084050841508425084350844508455084650847508485084950850508515085250853508545085550856508575085850859508605086150862508635086450865508665086750868508695087050871508725087350874508755087650877508785087950880508815088250883508845088550886508875088850889508905089150892508935089450895508965089750898508995090050901509025090350904509055090650907509085090950910509115091250913509145091550916509175091850919509205092150922509235092450925509265092750928509295093050931509325093350934509355093650937509385093950940509415094250943509445094550946509475094850949509505095150952509535095450955509565095750958509595096050961509625096350964509655096650967509685096950970509715097250973509745097550976509775097850979509805098150982509835098450985509865098750988509895099050991509925099350994509955099650997509985099951000510015100251003510045100551006510075100851009510105101151012510135101451015510165101751018510195102051021510225102351024510255102651027510285102951030510315103251033510345103551036510375103851039510405104151042510435104451045510465104751048510495105051051510525105351054510555105651057510585105951060510615106251063510645106551066510675106851069510705107151072510735107451075510765107751078510795108051081510825108351084510855108651087510885108951090510915109251093510945109551096510975109851099511005110151102511035110451105511065110751108511095111051111511125111351114511155111651117511185111951120511215112251123511245112551126511275112851129511305113151132511335113451135511365113751138511395114051141511425114351144511455114651147511485114951150511515115251153511545115551156511575115851159511605116151162511635116451165511665116751168511695117051171511725117351174511755117651177511785117951180511815118251183511845118551186511875118851189511905119151192511935119451195511965119751198511995120051201512025120351204512055120651207512085120951210512115121251213512145121551216512175121851219512205122151222512235122451225512265122751228512295123051231512325123351234512355123651237512385123951240512415124251243512445124551246512475124851249512505125151252512535125451255512565125751258512595126051261512625126351264512655126651267512685126951270512715127251273512745127551276512775127851279512805128151282512835128451285512865128751288512895129051291512925129351294512955129651297512985129951300513015130251303513045130551306513075130851309513105131151312513135131451315513165131751318513195132051321513225132351324513255132651327513285132951330513315133251333513345133551336513375133851339513405134151342513435134451345513465134751348513495135051351513525135351354513555135651357513585135951360513615136251363513645136551366513675136851369513705137151372513735137451375513765137751378513795138051381513825138351384513855138651387513885138951390513915139251393513945139551396513975139851399514005140151402514035140451405514065140751408514095141051411514125141351414514155141651417514185141951420514215142251423514245142551426514275142851429514305143151432514335143451435514365143751438514395144051441514425144351444514455144651447514485144951450514515145251453514545145551456514575145851459514605146151462514635146451465514665146751468514695147051471514725147351474514755147651477514785147951480514815148251483514845148551486514875148851489514905149151492514935149451495514965149751498514995150051501515025150351504515055150651507515085150951510515115151251513515145151551516515175151851519515205152151522515235152451525515265152751528515295153051531515325153351534515355153651537515385153951540515415154251543515445154551546515475154851549515505155151552515535155451555515565155751558515595156051561515625156351564515655156651567515685156951570515715157251573515745157551576515775157851579515805158151582515835158451585515865158751588515895159051591515925159351594515955159651597515985159951600516015160251603516045160551606516075160851609516105161151612516135161451615516165161751618516195162051621516225162351624516255162651627516285162951630516315163251633516345163551636516375163851639516405164151642516435164451645516465164751648516495165051651516525165351654516555165651657516585165951660516615166251663516645166551666516675166851669516705167151672516735167451675516765167751678516795168051681516825168351684516855168651687516885168951690516915169251693516945169551696516975169851699517005170151702517035170451705517065170751708517095171051711517125171351714517155171651717517185171951720517215172251723517245172551726517275172851729517305173151732517335173451735517365173751738517395174051741517425174351744517455174651747517485174951750517515175251753517545175551756517575175851759517605176151762517635176451765517665176751768517695177051771517725177351774517755177651777517785177951780517815178251783517845178551786517875178851789517905179151792517935179451795517965179751798517995180051801518025180351804518055180651807518085180951810518115181251813518145181551816518175181851819518205182151822518235182451825518265182751828518295183051831518325183351834518355183651837518385183951840518415184251843518445184551846518475184851849518505185151852518535185451855518565185751858518595186051861518625186351864518655186651867518685186951870518715187251873518745187551876518775187851879518805188151882518835188451885518865188751888518895189051891518925189351894518955189651897518985189951900519015190251903519045190551906519075190851909519105191151912519135191451915519165191751918519195192051921519225192351924519255192651927519285192951930519315193251933519345193551936519375193851939519405194151942519435194451945519465194751948519495195051951519525195351954519555195651957519585195951960519615196251963519645196551966519675196851969519705197151972519735197451975519765197751978519795198051981519825198351984519855198651987519885198951990519915199251993519945199551996519975199851999520005200152002520035200452005520065200752008520095201052011520125201352014520155201652017520185201952020520215202252023520245202552026520275202852029520305203152032520335203452035520365203752038520395204052041520425204352044520455204652047520485204952050520515205252053520545205552056520575205852059520605206152062520635206452065520665206752068520695207052071520725207352074520755207652077520785207952080520815208252083520845208552086520875208852089520905209152092520935209452095520965209752098520995210052101521025210352104521055210652107521085210952110521115211252113521145211552116521175211852119521205212152122521235212452125521265212752128521295213052131521325213352134521355213652137521385213952140521415214252143521445214552146521475214852149521505215152152521535215452155521565215752158521595216052161521625216352164521655216652167521685216952170521715217252173521745217552176521775217852179521805218152182521835218452185521865218752188521895219052191521925219352194521955219652197521985219952200522015220252203522045220552206522075220852209522105221152212522135221452215522165221752218522195222052221522225222352224522255222652227522285222952230522315223252233522345223552236522375223852239522405224152242522435224452245522465224752248522495225052251522525225352254522555225652257522585225952260522615226252263522645226552266522675226852269522705227152272522735227452275522765227752278522795228052281522825228352284522855228652287522885228952290522915229252293522945229552296522975229852299523005230152302523035230452305523065230752308523095231052311523125231352314523155231652317523185231952320523215232252323523245232552326523275232852329523305233152332523335233452335523365233752338523395234052341523425234352344523455234652347523485234952350523515235252353523545235552356523575235852359523605236152362523635236452365523665236752368523695237052371523725237352374523755237652377523785237952380523815238252383523845238552386523875238852389523905239152392523935239452395523965239752398523995240052401524025240352404524055240652407524085240952410524115241252413524145241552416524175241852419524205242152422524235242452425524265242752428524295243052431524325243352434524355243652437524385243952440524415244252443524445244552446524475244852449524505245152452524535245452455524565245752458524595246052461524625246352464524655246652467524685246952470524715247252473524745247552476524775247852479524805248152482524835248452485524865248752488524895249052491524925249352494524955249652497524985249952500525015250252503525045250552506525075250852509525105251152512525135251452515525165251752518525195252052521525225252352524525255252652527525285252952530525315253252533525345253552536525375253852539525405254152542525435254452545525465254752548525495255052551525525255352554525555255652557525585255952560525615256252563525645256552566525675256852569525705257152572525735257452575525765257752578525795258052581525825258352584525855258652587525885258952590525915259252593525945259552596525975259852599526005260152602526035260452605526065260752608526095261052611526125261352614526155261652617526185261952620526215262252623526245262552626526275262852629526305263152632526335263452635526365263752638526395264052641526425264352644526455264652647526485264952650526515265252653526545265552656526575265852659526605266152662526635266452665526665266752668526695267052671526725267352674526755267652677526785267952680526815268252683526845268552686526875268852689526905269152692526935269452695526965269752698526995270052701527025270352704527055270652707527085270952710527115271252713527145271552716527175271852719527205272152722527235272452725527265272752728527295273052731527325273352734527355273652737527385273952740527415274252743527445274552746527475274852749527505275152752527535275452755527565275752758527595276052761527625276352764527655276652767527685276952770527715277252773527745277552776527775277852779527805278152782527835278452785527865278752788527895279052791527925279352794527955279652797527985279952800528015280252803528045280552806528075280852809528105281152812528135281452815528165281752818528195282052821528225282352824528255282652827528285282952830528315283252833528345283552836528375283852839528405284152842528435284452845528465284752848528495285052851528525285352854528555285652857528585285952860528615286252863528645286552866528675286852869528705287152872528735287452875528765287752878528795288052881528825288352884528855288652887528885288952890528915289252893528945289552896528975289852899529005290152902529035290452905529065290752908529095291052911529125291352914529155291652917529185291952920529215292252923529245292552926529275292852929529305293152932529335293452935529365293752938529395294052941529425294352944529455294652947529485294952950529515295252953529545295552956529575295852959529605296152962529635296452965529665296752968529695297052971529725297352974529755297652977529785297952980529815298252983529845298552986529875298852989529905299152992529935299452995529965299752998529995300053001530025300353004530055300653007530085300953010530115301253013530145301553016530175301853019530205302153022530235302453025530265302753028530295303053031530325303353034530355303653037530385303953040530415304253043530445304553046530475304853049530505305153052530535305453055530565305753058530595306053061530625306353064530655306653067530685306953070530715307253073530745307553076530775307853079530805308153082530835308453085530865308753088530895309053091530925309353094530955309653097530985309953100531015310253103531045310553106531075310853109531105311153112531135311453115531165311753118531195312053121531225312353124531255312653127531285312953130531315313253133531345313553136531375313853139531405314153142531435314453145531465314753148531495315053151531525315353154531555315653157531585315953160531615316253163531645316553166531675316853169531705317153172531735317453175531765317753178531795318053181531825318353184531855318653187531885318953190531915319253193531945319553196531975319853199532005320153202532035320453205532065320753208532095321053211532125321353214532155321653217532185321953220532215322253223532245322553226532275322853229532305323153232532335323453235532365323753238532395324053241532425324353244532455324653247532485324953250532515325253253532545325553256532575325853259532605326153262532635326453265532665326753268532695327053271532725327353274532755327653277532785327953280532815328253283532845328553286532875328853289532905329153292532935329453295532965329753298532995330053301533025330353304533055330653307533085330953310533115331253313533145331553316533175331853319533205332153322533235332453325533265332753328533295333053331533325333353334533355333653337533385333953340533415334253343533445334553346533475334853349533505335153352533535335453355533565335753358533595336053361533625336353364533655336653367533685336953370533715337253373533745337553376533775337853379533805338153382533835338453385533865338753388533895339053391533925339353394533955339653397533985339953400534015340253403534045340553406534075340853409534105341153412534135341453415534165341753418534195342053421534225342353424534255342653427534285342953430534315343253433534345343553436534375343853439534405344153442534435344453445534465344753448534495345053451534525345353454534555345653457534585345953460534615346253463534645346553466534675346853469534705347153472534735347453475534765347753478534795348053481534825348353484534855348653487534885348953490534915349253493534945349553496534975349853499535005350153502535035350453505535065350753508535095351053511535125351353514535155351653517535185351953520535215352253523535245352553526535275352853529535305353153532535335353453535535365353753538535395354053541535425354353544535455354653547535485354953550535515355253553535545355553556535575355853559535605356153562535635356453565535665356753568535695357053571535725357353574535755357653577535785357953580535815358253583535845358553586535875358853589535905359153592535935359453595535965359753598535995360053601536025360353604536055360653607536085360953610536115361253613536145361553616536175361853619536205362153622536235362453625536265362753628536295363053631536325363353634536355363653637536385363953640536415364253643536445364553646536475364853649536505365153652536535365453655536565365753658536595366053661536625366353664536655366653667536685366953670536715367253673536745367553676536775367853679536805368153682536835368453685536865368753688536895369053691536925369353694536955369653697536985369953700537015370253703537045370553706537075370853709537105371153712537135371453715537165371753718537195372053721537225372353724537255372653727537285372953730537315373253733537345373553736537375373853739537405374153742537435374453745537465374753748537495375053751537525375353754537555375653757537585375953760537615376253763537645376553766537675376853769537705377153772537735377453775537765377753778537795378053781537825378353784537855378653787537885378953790537915379253793537945379553796537975379853799538005380153802538035380453805538065380753808538095381053811538125381353814538155381653817538185381953820538215382253823538245382553826538275382853829538305383153832538335383453835538365383753838538395384053841538425384353844538455384653847538485384953850538515385253853538545385553856538575385853859538605386153862538635386453865538665386753868538695387053871538725387353874538755387653877538785387953880538815388253883538845388553886538875388853889538905389153892538935389453895538965389753898538995390053901539025390353904539055390653907539085390953910539115391253913539145391553916539175391853919539205392153922539235392453925539265392753928539295393053931539325393353934539355393653937539385393953940539415394253943539445394553946539475394853949539505395153952539535395453955539565395753958539595396053961539625396353964539655396653967539685396953970539715397253973539745397553976539775397853979539805398153982539835398453985539865398753988539895399053991539925399353994539955399653997539985399954000540015400254003540045400554006540075400854009540105401154012540135401454015540165401754018540195402054021540225402354024540255402654027540285402954030540315403254033540345403554036540375403854039540405404154042540435404454045540465404754048540495405054051540525405354054540555405654057540585405954060540615406254063540645406554066540675406854069540705407154072540735407454075540765407754078540795408054081540825408354084540855408654087540885408954090540915409254093540945409554096540975409854099541005410154102541035410454105541065410754108541095411054111541125411354114541155411654117541185411954120541215412254123541245412554126541275412854129541305413154132541335413454135541365413754138541395414054141541425414354144541455414654147541485414954150541515415254153541545415554156541575415854159541605416154162541635416454165541665416754168541695417054171541725417354174541755417654177541785417954180541815418254183541845418554186541875418854189541905419154192541935419454195541965419754198541995420054201542025420354204542055420654207542085420954210542115421254213542145421554216542175421854219542205422154222542235422454225542265422754228542295423054231542325423354234542355423654237542385423954240542415424254243542445424554246542475424854249542505425154252542535425454255542565425754258542595426054261542625426354264542655426654267542685426954270542715427254273542745427554276542775427854279542805428154282542835428454285542865428754288542895429054291542925429354294542955429654297542985429954300543015430254303543045430554306543075430854309543105431154312543135431454315543165431754318543195432054321543225432354324543255432654327543285432954330543315433254333543345433554336543375433854339543405434154342543435434454345543465434754348543495435054351543525435354354543555435654357543585435954360543615436254363543645436554366543675436854369543705437154372543735437454375543765437754378543795438054381543825438354384543855438654387543885438954390543915439254393543945439554396543975439854399544005440154402544035440454405544065440754408544095441054411544125441354414544155441654417544185441954420544215442254423544245442554426544275442854429544305443154432544335443454435544365443754438544395444054441544425444354444544455444654447544485444954450544515445254453544545445554456544575445854459544605446154462544635446454465544665446754468544695447054471544725447354474544755447654477544785447954480544815448254483544845448554486544875448854489544905449154492544935449454495544965449754498544995450054501545025450354504545055450654507545085450954510545115451254513545145451554516545175451854519545205452154522545235452454525545265452754528545295453054531545325453354534545355453654537545385453954540545415454254543545445454554546545475454854549545505455154552545535455454555545565455754558545595456054561545625456354564545655456654567545685456954570545715457254573545745457554576545775457854579545805458154582545835458454585545865458754588545895459054591545925459354594545955459654597545985459954600546015460254603546045460554606546075460854609546105461154612546135461454615546165461754618546195462054621546225462354624546255462654627546285462954630546315463254633546345463554636546375463854639546405464154642546435464454645546465464754648546495465054651546525465354654546555465654657546585465954660546615466254663546645466554666546675466854669546705467154672546735467454675546765467754678546795468054681546825468354684546855468654687546885468954690546915469254693546945469554696546975469854699547005470154702547035470454705547065470754708547095471054711547125471354714547155471654717547185471954720547215472254723547245472554726547275472854729547305473154732547335473454735547365473754738547395474054741547425474354744547455474654747547485474954750547515475254753547545475554756547575475854759547605476154762547635476454765547665476754768547695477054771547725477354774547755477654777547785477954780547815478254783547845478554786547875478854789547905479154792547935479454795547965479754798547995480054801548025480354804548055480654807548085480954810548115481254813548145481554816548175481854819548205482154822548235482454825548265482754828548295483054831548325483354834548355483654837548385483954840548415484254843548445484554846548475484854849548505485154852548535485454855548565485754858548595486054861548625486354864548655486654867548685486954870548715487254873548745487554876548775487854879548805488154882548835488454885548865488754888548895489054891548925489354894548955489654897548985489954900549015490254903549045490554906549075490854909549105491154912549135491454915549165491754918549195492054921549225492354924549255492654927549285492954930549315493254933549345493554936549375493854939549405494154942549435494454945549465494754948549495495054951549525495354954549555495654957549585495954960549615496254963549645496554966549675496854969549705497154972549735497454975549765497754978549795498054981549825498354984549855498654987549885498954990549915499254993549945499554996549975499854999550005500155002550035500455005550065500755008550095501055011550125501355014550155501655017550185501955020550215502255023550245502555026550275502855029550305503155032550335503455035550365503755038550395504055041550425504355044550455504655047550485504955050550515505255053550545505555056550575505855059550605506155062550635506455065550665506755068550695507055071550725507355074550755507655077550785507955080550815508255083550845508555086550875508855089550905509155092550935509455095550965509755098550995510055101551025510355104551055510655107551085510955110551115511255113551145511555116551175511855119551205512155122551235512455125551265512755128551295513055131551325513355134551355513655137551385513955140551415514255143551445514555146551475514855149551505515155152551535515455155551565515755158551595516055161551625516355164551655516655167551685516955170551715517255173551745517555176551775517855179551805518155182551835518455185551865518755188551895519055191551925519355194551955519655197551985519955200552015520255203552045520555206552075520855209552105521155212552135521455215552165521755218552195522055221552225522355224552255522655227552285522955230552315523255233552345523555236552375523855239552405524155242552435524455245552465524755248552495525055251552525525355254552555525655257552585525955260552615526255263552645526555266552675526855269552705527155272552735527455275552765527755278552795528055281552825528355284552855528655287552885528955290552915529255293552945529555296552975529855299553005530155302553035530455305553065530755308553095531055311553125531355314553155531655317553185531955320553215532255323553245532555326553275532855329553305533155332553335533455335553365533755338553395534055341553425534355344553455534655347553485534955350553515535255353553545535555356553575535855359553605536155362553635536455365553665536755368553695537055371553725537355374553755537655377553785537955380553815538255383553845538555386553875538855389553905539155392553935539455395553965539755398553995540055401554025540355404554055540655407554085540955410554115541255413554145541555416554175541855419554205542155422554235542455425554265542755428554295543055431554325543355434554355543655437554385543955440554415544255443554445544555446554475544855449554505545155452554535545455455554565545755458554595546055461554625546355464554655546655467554685546955470554715547255473554745547555476554775547855479554805548155482554835548455485554865548755488554895549055491554925549355494554955549655497554985549955500555015550255503555045550555506555075550855509555105551155512555135551455515555165551755518555195552055521555225552355524555255552655527555285552955530555315553255533555345553555536555375553855539555405554155542555435554455545555465554755548555495555055551555525555355554555555555655557555585555955560555615556255563555645556555566555675556855569555705557155572555735557455575555765557755578555795558055581555825558355584555855558655587555885558955590555915559255593555945559555596555975559855599556005560155602556035560455605556065560755608556095561055611556125561355614556155561655617556185561955620556215562255623556245562555626556275562855629556305563155632556335563455635556365563755638556395564055641556425564355644556455564655647556485564955650556515565255653556545565555656556575565855659556605566155662556635566455665556665566755668556695567055671556725567355674556755567655677556785567955680556815568255683556845568555686556875568855689556905569155692556935569455695556965569755698556995570055701557025570355704557055570655707557085570955710557115571255713557145571555716557175571855719557205572155722557235572455725557265572755728557295573055731557325573355734557355573655737557385573955740557415574255743557445574555746557475574855749557505575155752557535575455755557565575755758557595576055761557625576355764557655576655767557685576955770557715577255773557745577555776557775577855779557805578155782557835578455785557865578755788557895579055791557925579355794557955579655797557985579955800558015580255803558045580555806558075580855809558105581155812558135581455815558165581755818558195582055821558225582355824558255582655827558285582955830558315583255833558345583555836558375583855839558405584155842558435584455845558465584755848558495585055851558525585355854558555585655857558585585955860558615586255863558645586555866558675586855869558705587155872558735587455875558765587755878558795588055881558825588355884558855588655887558885588955890558915589255893558945589555896558975589855899559005590155902559035590455905559065590755908559095591055911559125591355914559155591655917559185591955920559215592255923559245592555926559275592855929559305593155932559335593455935559365593755938559395594055941559425594355944559455594655947559485594955950559515595255953559545595555956559575595855959559605596155962559635596455965559665596755968559695597055971559725597355974559755597655977559785597955980559815598255983559845598555986559875598855989559905599155992559935599455995559965599755998559995600056001560025600356004560055600656007560085600956010560115601256013560145601556016560175601856019560205602156022560235602456025560265602756028560295603056031560325603356034560355603656037560385603956040560415604256043560445604556046560475604856049560505605156052560535605456055560565605756058560595606056061560625606356064560655606656067560685606956070560715607256073560745607556076560775607856079560805608156082560835608456085560865608756088560895609056091560925609356094560955609656097560985609956100561015610256103561045610556106561075610856109561105611156112561135611456115561165611756118561195612056121561225612356124561255612656127561285612956130561315613256133561345613556136561375613856139561405614156142561435614456145561465614756148561495615056151561525615356154561555615656157561585615956160561615616256163561645616556166561675616856169561705617156172561735617456175561765617756178561795618056181561825618356184561855618656187561885618956190561915619256193561945619556196561975619856199562005620156202562035620456205562065620756208562095621056211562125621356214562155621656217562185621956220562215622256223562245622556226562275622856229562305623156232562335623456235562365623756238562395624056241562425624356244562455624656247562485624956250562515625256253562545625556256562575625856259562605626156262562635626456265562665626756268562695627056271562725627356274562755627656277562785627956280562815628256283562845628556286562875628856289562905629156292562935629456295562965629756298562995630056301563025630356304563055630656307563085630956310563115631256313563145631556316563175631856319563205632156322563235632456325563265632756328563295633056331563325633356334563355633656337563385633956340563415634256343563445634556346563475634856349563505635156352563535635456355563565635756358563595636056361563625636356364563655636656367563685636956370563715637256373563745637556376563775637856379563805638156382563835638456385563865638756388563895639056391563925639356394563955639656397563985639956400564015640256403564045640556406564075640856409564105641156412564135641456415564165641756418564195642056421564225642356424564255642656427564285642956430564315643256433564345643556436564375643856439564405644156442564435644456445564465644756448564495645056451564525645356454564555645656457564585645956460564615646256463564645646556466564675646856469564705647156472564735647456475564765647756478564795648056481564825648356484564855648656487564885648956490564915649256493564945649556496564975649856499565005650156502565035650456505565065650756508565095651056511565125651356514565155651656517565185651956520565215652256523565245652556526565275652856529565305653156532565335653456535565365653756538565395654056541565425654356544565455654656547565485654956550565515655256553565545655556556565575655856559565605656156562565635656456565565665656756568565695657056571565725657356574565755657656577565785657956580565815658256583565845658556586565875658856589565905659156592565935659456595565965659756598565995660056601566025660356604566055660656607566085660956610566115661256613566145661556616566175661856619566205662156622566235662456625566265662756628566295663056631566325663356634566355663656637566385663956640566415664256643566445664556646566475664856649566505665156652566535665456655566565665756658566595666056661566625666356664566655666656667566685666956670566715667256673566745667556676566775667856679566805668156682566835668456685566865668756688566895669056691566925669356694566955669656697566985669956700567015670256703567045670556706567075670856709567105671156712567135671456715567165671756718567195672056721567225672356724567255672656727567285672956730567315673256733567345673556736567375673856739567405674156742567435674456745567465674756748567495675056751567525675356754567555675656757567585675956760567615676256763567645676556766567675676856769567705677156772567735677456775567765677756778567795678056781567825678356784567855678656787567885678956790567915679256793567945679556796567975679856799568005680156802568035680456805568065680756808568095681056811568125681356814568155681656817568185681956820568215682256823568245682556826568275682856829568305683156832568335683456835568365683756838568395684056841568425684356844568455684656847568485684956850568515685256853568545685556856568575685856859568605686156862568635686456865568665686756868568695687056871568725687356874568755687656877568785687956880568815688256883568845688556886568875688856889568905689156892568935689456895568965689756898568995690056901569025690356904569055690656907569085690956910569115691256913569145691556916569175691856919569205692156922569235692456925569265692756928569295693056931569325693356934569355693656937569385693956940569415694256943569445694556946569475694856949569505695156952569535695456955569565695756958569595696056961569625696356964569655696656967569685696956970569715697256973569745697556976569775697856979569805698156982569835698456985569865698756988569895699056991569925699356994569955699656997569985699957000570015700257003570045700557006570075700857009570105701157012570135701457015570165701757018570195702057021570225702357024570255702657027570285702957030570315703257033570345703557036570375703857039570405704157042570435704457045570465704757048570495705057051570525705357054570555705657057570585705957060570615706257063570645706557066570675706857069570705707157072570735707457075570765707757078570795708057081570825708357084570855708657087570885708957090570915709257093570945709557096570975709857099571005710157102571035710457105571065710757108571095711057111571125711357114571155711657117571185711957120571215712257123571245712557126571275712857129571305713157132571335713457135571365713757138571395714057141571425714357144571455714657147571485714957150571515715257153571545715557156571575715857159571605716157162571635716457165571665716757168571695717057171571725717357174571755717657177571785717957180571815718257183571845718557186571875718857189571905719157192571935719457195571965719757198571995720057201572025720357204572055720657207572085720957210572115721257213572145721557216572175721857219572205722157222572235722457225572265722757228572295723057231572325723357234572355723657237572385723957240572415724257243572445724557246572475724857249572505725157252572535725457255572565725757258572595726057261572625726357264572655726657267572685726957270572715727257273572745727557276572775727857279572805728157282572835728457285572865728757288572895729057291572925729357294572955729657297572985729957300573015730257303573045730557306573075730857309573105731157312573135731457315573165731757318573195732057321573225732357324573255732657327573285732957330573315733257333573345733557336573375733857339573405734157342573435734457345573465734757348573495735057351573525735357354573555735657357573585735957360573615736257363573645736557366573675736857369573705737157372573735737457375573765737757378573795738057381573825738357384573855738657387573885738957390573915739257393573945739557396573975739857399574005740157402574035740457405574065740757408574095741057411574125741357414574155741657417574185741957420574215742257423574245742557426574275742857429574305743157432574335743457435574365743757438574395744057441574425744357444574455744657447574485744957450574515745257453574545745557456574575745857459574605746157462574635746457465574665746757468574695747057471574725747357474574755747657477574785747957480574815748257483574845748557486574875748857489574905749157492574935749457495574965749757498574995750057501575025750357504575055750657507575085750957510575115751257513575145751557516575175751857519575205752157522575235752457525575265752757528575295753057531575325753357534575355753657537575385753957540575415754257543575445754557546575475754857549575505755157552575535755457555575565755757558575595756057561575625756357564575655756657567575685756957570575715757257573575745757557576575775757857579575805758157582575835758457585575865758757588575895759057591575925759357594575955759657597575985759957600576015760257603576045760557606576075760857609576105761157612576135761457615576165761757618576195762057621576225762357624576255762657627576285762957630576315763257633576345763557636576375763857639576405764157642576435764457645576465764757648576495765057651576525765357654576555765657657576585765957660576615766257663576645766557666576675766857669576705767157672576735767457675576765767757678576795768057681576825768357684576855768657687576885768957690576915769257693576945769557696576975769857699577005770157702577035770457705577065770757708577095771057711577125771357714577155771657717577185771957720577215772257723577245772557726577275772857729577305773157732577335773457735577365773757738577395774057741577425774357744577455774657747577485774957750577515775257753577545775557756577575775857759577605776157762577635776457765577665776757768577695777057771577725777357774577755777657777577785777957780577815778257783577845778557786577875778857789577905779157792577935779457795577965779757798577995780057801578025780357804578055780657807578085780957810578115781257813578145781557816578175781857819578205782157822578235782457825578265782757828578295783057831578325783357834578355783657837578385783957840578415784257843578445784557846578475784857849578505785157852578535785457855578565785757858578595786057861578625786357864578655786657867578685786957870578715787257873578745787557876578775787857879578805788157882578835788457885578865788757888578895789057891578925789357894578955789657897578985789957900579015790257903579045790557906579075790857909579105791157912579135791457915579165791757918579195792057921579225792357924579255792657927579285792957930579315793257933579345793557936579375793857939579405794157942579435794457945579465794757948579495795057951579525795357954579555795657957579585795957960579615796257963579645796557966579675796857969579705797157972579735797457975579765797757978579795798057981579825798357984579855798657987579885798957990579915799257993579945799557996579975799857999580005800158002580035800458005580065800758008580095801058011580125801358014580155801658017580185801958020580215802258023580245802558026580275802858029580305803158032580335803458035580365803758038580395804058041580425804358044580455804658047580485804958050580515805258053580545805558056580575805858059580605806158062580635806458065580665806758068580695807058071580725807358074580755807658077580785807958080580815808258083580845808558086580875808858089580905809158092580935809458095580965809758098580995810058101581025810358104581055810658107581085810958110581115811258113581145811558116581175811858119581205812158122581235812458125581265812758128581295813058131581325813358134581355813658137581385813958140581415814258143581445814558146581475814858149581505815158152581535815458155581565815758158581595816058161581625816358164581655816658167581685816958170581715817258173581745817558176581775817858179581805818158182581835818458185581865818758188581895819058191581925819358194581955819658197581985819958200582015820258203582045820558206582075820858209582105821158212582135821458215582165821758218582195822058221582225822358224582255822658227582285822958230582315823258233582345823558236582375823858239582405824158242582435824458245582465824758248582495825058251582525825358254582555825658257582585825958260582615826258263582645826558266582675826858269582705827158272582735827458275582765827758278582795828058281582825828358284582855828658287582885828958290582915829258293582945829558296582975829858299583005830158302583035830458305583065830758308583095831058311583125831358314583155831658317583185831958320583215832258323583245832558326583275832858329583305833158332583335833458335583365833758338583395834058341583425834358344583455834658347583485834958350583515835258353583545835558356583575835858359583605836158362583635836458365583665836758368583695837058371583725837358374583755837658377583785837958380583815838258383583845838558386583875838858389583905839158392583935839458395583965839758398583995840058401584025840358404584055840658407584085840958410584115841258413584145841558416584175841858419584205842158422584235842458425584265842758428584295843058431584325843358434584355843658437584385843958440584415844258443584445844558446584475844858449584505845158452584535845458455584565845758458584595846058461584625846358464584655846658467584685846958470584715847258473584745847558476584775847858479584805848158482584835848458485584865848758488584895849058491584925849358494584955849658497584985849958500585015850258503585045850558506585075850858509585105851158512585135851458515585165851758518585195852058521585225852358524585255852658527585285852958530585315853258533585345853558536585375853858539585405854158542585435854458545585465854758548585495855058551585525855358554585555855658557585585855958560585615856258563585645856558566585675856858569585705857158572585735857458575585765857758578585795858058581585825858358584585855858658587585885858958590585915859258593585945859558596585975859858599586005860158602586035860458605586065860758608586095861058611586125861358614586155861658617586185861958620586215862258623586245862558626586275862858629586305863158632586335863458635586365863758638586395864058641586425864358644586455864658647586485864958650586515865258653586545865558656586575865858659586605866158662586635866458665586665866758668586695867058671586725867358674586755867658677586785867958680586815868258683586845868558686586875868858689586905869158692586935869458695586965869758698586995870058701587025870358704587055870658707587085870958710587115871258713587145871558716587175871858719587205872158722587235872458725587265872758728587295873058731587325873358734587355873658737587385873958740587415874258743587445874558746587475874858749587505875158752587535875458755587565875758758587595876058761587625876358764587655876658767587685876958770587715877258773587745877558776587775877858779587805878158782587835878458785587865878758788587895879058791587925879358794587955879658797587985879958800588015880258803588045880558806588075880858809588105881158812588135881458815588165881758818588195882058821588225882358824588255882658827588285882958830588315883258833588345883558836588375883858839588405884158842588435884458845588465884758848588495885058851588525885358854588555885658857588585885958860588615886258863588645886558866588675886858869588705887158872588735887458875588765887758878588795888058881588825888358884588855888658887588885888958890588915889258893588945889558896588975889858899589005890158902589035890458905589065890758908589095891058911589125891358914589155891658917589185891958920589215892258923589245892558926589275892858929589305893158932589335893458935589365893758938589395894058941589425894358944589455894658947589485894958950589515895258953589545895558956589575895858959589605896158962589635896458965589665896758968589695897058971589725897358974589755897658977589785897958980589815898258983589845898558986589875898858989589905899158992589935899458995589965899758998589995900059001590025900359004590055900659007590085900959010590115901259013590145901559016590175901859019590205902159022590235902459025590265902759028590295903059031590325903359034590355903659037590385903959040590415904259043590445904559046590475904859049590505905159052590535905459055590565905759058590595906059061590625906359064590655906659067590685906959070590715907259073590745907559076590775907859079590805908159082590835908459085590865908759088590895909059091590925909359094590955909659097590985909959100591015910259103591045910559106591075910859109591105911159112591135911459115591165911759118591195912059121591225912359124591255912659127591285912959130591315913259133591345913559136591375913859139591405914159142591435914459145591465914759148591495915059151591525915359154591555915659157591585915959160591615916259163591645916559166591675916859169591705917159172591735917459175591765917759178591795918059181591825918359184591855918659187591885918959190591915919259193591945919559196591975919859199592005920159202592035920459205592065920759208592095921059211592125921359214592155921659217592185921959220592215922259223592245922559226592275922859229592305923159232592335923459235592365923759238592395924059241592425924359244592455924659247592485924959250592515925259253592545925559256592575925859259592605926159262592635926459265592665926759268592695927059271592725927359274592755927659277592785927959280592815928259283592845928559286592875928859289592905929159292592935929459295592965929759298592995930059301593025930359304593055930659307593085930959310593115931259313593145931559316593175931859319593205932159322593235932459325593265932759328593295933059331593325933359334593355933659337593385933959340593415934259343593445934559346593475934859349593505935159352593535935459355593565935759358593595936059361593625936359364593655936659367593685936959370593715937259373593745937559376593775937859379593805938159382593835938459385593865938759388593895939059391593925939359394593955939659397593985939959400594015940259403594045940559406594075940859409594105941159412594135941459415594165941759418594195942059421594225942359424594255942659427594285942959430594315943259433594345943559436594375943859439594405944159442594435944459445594465944759448594495945059451594525945359454594555945659457594585945959460594615946259463594645946559466594675946859469594705947159472594735947459475594765947759478594795948059481594825948359484594855948659487594885948959490594915949259493594945949559496594975949859499595005950159502595035950459505595065950759508595095951059511595125951359514595155951659517595185951959520595215952259523595245952559526595275952859529595305953159532595335953459535595365953759538595395954059541595425954359544595455954659547595485954959550595515955259553595545955559556595575955859559595605956159562595635956459565595665956759568595695957059571595725957359574595755957659577595785957959580595815958259583595845958559586595875958859589595905959159592595935959459595595965959759598595995960059601596025960359604596055960659607596085960959610596115961259613596145961559616596175961859619596205962159622596235962459625596265962759628596295963059631596325963359634596355963659637596385963959640596415964259643596445964559646596475964859649596505965159652596535965459655596565965759658596595966059661596625966359664596655966659667596685966959670596715967259673596745967559676596775967859679596805968159682596835968459685596865968759688596895969059691596925969359694596955969659697596985969959700597015970259703597045970559706597075970859709597105971159712597135971459715597165971759718597195972059721597225972359724597255972659727597285972959730597315973259733597345973559736597375973859739597405974159742597435974459745597465974759748597495975059751597525975359754597555975659757597585975959760597615976259763597645976559766597675976859769597705977159772597735977459775597765977759778597795978059781597825978359784597855978659787597885978959790597915979259793597945979559796597975979859799598005980159802598035980459805598065980759808598095981059811598125981359814598155981659817598185981959820598215982259823598245982559826598275982859829598305983159832598335983459835598365983759838598395984059841598425984359844598455984659847598485984959850598515985259853598545985559856598575985859859598605986159862598635986459865598665986759868598695987059871598725987359874598755987659877598785987959880598815988259883598845988559886598875988859889598905989159892598935989459895598965989759898598995990059901599025990359904599055990659907599085990959910599115991259913599145991559916599175991859919599205992159922599235992459925599265992759928599295993059931599325993359934599355993659937599385993959940599415994259943599445994559946599475994859949599505995159952599535995459955599565995759958599595996059961599625996359964599655996659967599685996959970599715997259973599745997559976599775997859979599805998159982599835998459985599865998759988599895999059991599925999359994599955999659997599985999960000600016000260003600046000560006600076000860009600106001160012600136001460015600166001760018600196002060021600226002360024600256002660027600286002960030600316003260033600346003560036600376003860039600406004160042600436004460045600466004760048600496005060051600526005360054600556005660057600586005960060600616006260063600646006560066600676006860069600706007160072600736007460075600766007760078600796008060081600826008360084600856008660087600886008960090600916009260093600946009560096600976009860099601006010160102601036010460105601066010760108601096011060111601126011360114601156011660117601186011960120601216012260123601246012560126601276012860129601306013160132601336013460135601366013760138601396014060141601426014360144601456014660147601486014960150601516015260153601546015560156601576015860159601606016160162601636016460165601666016760168601696017060171601726017360174601756017660177601786017960180601816018260183601846018560186601876018860189601906019160192601936019460195601966019760198601996020060201602026020360204602056020660207602086020960210602116021260213602146021560216602176021860219602206022160222602236022460225602266022760228602296023060231602326023360234602356023660237602386023960240602416024260243602446024560246602476024860249602506025160252602536025460255602566025760258602596026060261602626026360264602656026660267602686026960270602716027260273602746027560276602776027860279602806028160282602836028460285602866028760288602896029060291602926029360294602956029660297602986029960300603016030260303603046030560306603076030860309603106031160312603136031460315603166031760318603196032060321603226032360324603256032660327603286032960330603316033260333603346033560336603376033860339603406034160342603436034460345603466034760348603496035060351603526035360354603556035660357603586035960360603616036260363603646036560366603676036860369603706037160372603736037460375603766037760378603796038060381603826038360384603856038660387603886038960390603916039260393603946039560396603976039860399604006040160402604036040460405604066040760408604096041060411604126041360414604156041660417604186041960420604216042260423604246042560426604276042860429604306043160432604336043460435604366043760438604396044060441604426044360444604456044660447604486044960450604516045260453604546045560456604576045860459604606046160462604636046460465604666046760468604696047060471604726047360474604756047660477604786047960480604816048260483604846048560486604876048860489604906049160492604936049460495604966049760498604996050060501605026050360504605056050660507605086050960510605116051260513605146051560516605176051860519605206052160522605236052460525605266052760528605296053060531605326053360534605356053660537605386053960540605416054260543605446054560546605476054860549605506055160552605536055460555605566055760558605596056060561605626056360564605656056660567605686056960570605716057260573605746057560576605776057860579605806058160582605836058460585605866058760588605896059060591605926059360594605956059660597605986059960600606016060260603606046060560606606076060860609606106061160612606136061460615606166061760618606196062060621606226062360624606256062660627606286062960630606316063260633606346063560636606376063860639606406064160642606436064460645606466064760648606496065060651606526065360654606556065660657606586065960660606616066260663606646066560666606676066860669606706067160672606736067460675606766067760678606796068060681606826068360684606856068660687606886068960690606916069260693606946069560696606976069860699607006070160702607036070460705607066070760708607096071060711607126071360714607156071660717607186071960720607216072260723607246072560726607276072860729607306073160732607336073460735607366073760738607396074060741607426074360744607456074660747607486074960750607516075260753607546075560756607576075860759607606076160762607636076460765607666076760768607696077060771607726077360774607756077660777607786077960780607816078260783607846078560786607876078860789607906079160792607936079460795607966079760798607996080060801608026080360804608056080660807608086080960810608116081260813608146081560816608176081860819608206082160822608236082460825608266082760828608296083060831608326083360834608356083660837608386083960840608416084260843608446084560846608476084860849608506085160852608536085460855608566085760858608596086060861608626086360864608656086660867608686086960870608716087260873608746087560876608776087860879608806088160882608836088460885608866088760888608896089060891608926089360894608956089660897608986089960900609016090260903609046090560906609076090860909609106091160912609136091460915609166091760918609196092060921609226092360924609256092660927609286092960930609316093260933609346093560936609376093860939609406094160942609436094460945609466094760948609496095060951609526095360954609556095660957609586095960960609616096260963609646096560966609676096860969609706097160972609736097460975609766097760978609796098060981609826098360984609856098660987609886098960990609916099260993609946099560996609976099860999610006100161002610036100461005610066100761008610096101061011610126101361014610156101661017610186101961020610216102261023610246102561026610276102861029610306103161032610336103461035610366103761038610396104061041610426104361044610456104661047610486104961050610516105261053610546105561056610576105861059610606106161062610636106461065610666106761068610696107061071610726107361074610756107661077610786107961080610816108261083610846108561086610876108861089610906109161092610936109461095610966109761098610996110061101611026110361104611056110661107611086110961110611116111261113611146111561116611176111861119611206112161122611236112461125611266112761128611296113061131611326113361134611356113661137611386113961140611416114261143611446114561146611476114861149611506115161152611536115461155611566115761158611596116061161611626116361164611656116661167611686116961170611716117261173611746117561176611776117861179611806118161182611836118461185611866118761188611896119061191611926119361194611956119661197611986119961200612016120261203612046120561206612076120861209612106121161212612136121461215612166121761218612196122061221612226122361224612256122661227612286122961230612316123261233612346123561236612376123861239612406124161242612436124461245612466124761248612496125061251612526125361254612556125661257612586125961260612616126261263612646126561266612676126861269612706127161272612736127461275612766127761278612796128061281612826128361284612856128661287612886128961290612916129261293612946129561296612976129861299613006130161302613036130461305613066130761308613096131061311613126131361314613156131661317613186131961320613216132261323613246132561326613276132861329613306133161332613336133461335613366133761338613396134061341613426134361344613456134661347613486134961350613516135261353613546135561356613576135861359613606136161362613636136461365613666136761368613696137061371613726137361374613756137661377613786137961380613816138261383613846138561386613876138861389613906139161392613936139461395613966139761398613996140061401614026140361404614056140661407614086140961410614116141261413614146141561416614176141861419614206142161422614236142461425614266142761428614296143061431614326143361434614356143661437614386143961440614416144261443614446144561446614476144861449614506145161452614536145461455614566145761458614596146061461614626146361464614656146661467614686146961470614716147261473614746147561476614776147861479614806148161482614836148461485614866148761488614896149061491614926149361494614956149661497614986149961500615016150261503615046150561506615076150861509615106151161512615136151461515615166151761518615196152061521615226152361524615256152661527615286152961530615316153261533615346153561536615376153861539615406154161542615436154461545615466154761548615496155061551615526155361554615556155661557615586155961560615616156261563615646156561566615676156861569615706157161572615736157461575615766157761578615796158061581615826158361584615856158661587615886158961590615916159261593615946159561596615976159861599616006160161602616036160461605616066160761608616096161061611616126161361614616156161661617616186161961620616216162261623616246162561626616276162861629616306163161632616336163461635616366163761638616396164061641616426164361644616456164661647616486164961650616516165261653616546165561656616576165861659616606166161662616636166461665616666166761668616696167061671616726167361674616756167661677616786167961680616816168261683616846168561686616876168861689616906169161692616936169461695616966169761698616996170061701617026170361704617056170661707617086170961710617116171261713617146171561716617176171861719617206172161722617236172461725617266172761728617296173061731617326173361734617356173661737617386173961740617416174261743617446174561746617476174861749617506175161752617536175461755617566175761758617596176061761617626176361764617656176661767617686176961770617716177261773617746177561776617776177861779617806178161782617836178461785617866178761788617896179061791617926179361794617956179661797617986179961800618016180261803618046180561806618076180861809618106181161812618136181461815618166181761818618196182061821618226182361824618256182661827618286182961830618316183261833618346183561836618376183861839618406184161842618436184461845618466184761848618496185061851618526185361854618556185661857618586185961860618616186261863618646186561866618676186861869618706187161872618736187461875618766187761878618796188061881618826188361884618856188661887618886188961890618916189261893618946189561896618976189861899619006190161902619036190461905619066190761908619096191061911619126191361914619156191661917619186191961920619216192261923619246192561926619276192861929619306193161932619336193461935619366193761938619396194061941619426194361944619456194661947619486194961950619516195261953619546195561956619576195861959619606196161962619636196461965619666196761968619696197061971619726197361974619756197661977619786197961980619816198261983619846198561986619876198861989619906199161992619936199461995619966199761998619996200062001620026200362004620056200662007620086200962010620116201262013620146201562016620176201862019620206202162022620236202462025620266202762028620296203062031620326203362034620356203662037620386203962040620416204262043620446204562046620476204862049620506205162052620536205462055620566205762058620596206062061620626206362064620656206662067620686206962070620716207262073620746207562076620776207862079620806208162082620836208462085620866208762088620896209062091620926209362094620956209662097620986209962100621016210262103621046210562106621076210862109621106211162112621136211462115621166211762118621196212062121621226212362124621256212662127621286212962130621316213262133621346213562136621376213862139621406214162142621436214462145621466214762148621496215062151621526215362154621556215662157621586215962160621616216262163621646216562166621676216862169621706217162172621736217462175621766217762178621796218062181621826218362184621856218662187621886218962190621916219262193621946219562196621976219862199622006220162202622036220462205622066220762208622096221062211622126221362214622156221662217622186221962220622216222262223622246222562226622276222862229622306223162232622336223462235622366223762238622396224062241622426224362244622456224662247622486224962250622516225262253622546225562256622576225862259622606226162262622636226462265622666226762268622696227062271622726227362274622756227662277622786227962280622816228262283622846228562286622876228862289622906229162292622936229462295622966229762298622996230062301623026230362304623056230662307623086230962310623116231262313623146231562316623176231862319623206232162322623236232462325623266232762328623296233062331623326233362334623356233662337623386233962340623416234262343623446234562346623476234862349623506235162352623536235462355623566235762358623596236062361623626236362364623656236662367623686236962370623716237262373623746237562376623776237862379623806238162382623836238462385623866238762388623896239062391623926239362394623956239662397623986239962400624016240262403624046240562406624076240862409624106241162412624136241462415624166241762418624196242062421624226242362424624256242662427624286242962430624316243262433624346243562436624376243862439624406244162442624436244462445624466244762448624496245062451624526245362454624556245662457624586245962460624616246262463624646246562466624676246862469624706247162472624736247462475624766247762478624796248062481624826248362484624856248662487624886248962490624916249262493624946249562496624976249862499625006250162502625036250462505625066250762508625096251062511625126251362514625156251662517625186251962520625216252262523625246252562526625276252862529625306253162532625336253462535625366253762538625396254062541625426254362544625456254662547625486254962550625516255262553625546255562556625576255862559625606256162562625636256462565625666256762568625696257062571625726257362574625756257662577625786257962580625816258262583625846258562586625876258862589625906259162592625936259462595625966259762598625996260062601626026260362604626056260662607626086260962610626116261262613626146261562616626176261862619626206262162622626236262462625626266262762628626296263062631626326263362634626356263662637626386263962640626416264262643626446264562646626476264862649626506265162652626536265462655626566265762658626596266062661626626266362664626656266662667626686266962670626716267262673626746267562676626776267862679626806268162682626836268462685626866268762688626896269062691626926269362694626956269662697626986269962700627016270262703627046270562706627076270862709627106271162712627136271462715627166271762718627196272062721627226272362724627256272662727627286272962730627316273262733627346273562736627376273862739627406274162742627436274462745627466274762748627496275062751627526275362754627556275662757627586275962760627616276262763627646276562766627676276862769627706277162772627736277462775627766277762778627796278062781627826278362784627856278662787627886278962790627916279262793627946279562796627976279862799628006280162802628036280462805628066280762808628096281062811628126281362814628156281662817628186281962820628216282262823628246282562826628276282862829628306283162832628336283462835628366283762838628396284062841628426284362844628456284662847628486284962850628516285262853628546285562856628576285862859628606286162862628636286462865628666286762868628696287062871628726287362874628756287662877628786287962880628816288262883628846288562886628876288862889628906289162892628936289462895628966289762898628996290062901629026290362904629056290662907629086290962910629116291262913629146291562916629176291862919629206292162922629236292462925629266292762928629296293062931629326293362934629356293662937629386293962940629416294262943629446294562946629476294862949629506295162952629536295462955629566295762958629596296062961629626296362964629656296662967629686296962970629716297262973629746297562976629776297862979629806298162982629836298462985629866298762988629896299062991629926299362994629956299662997629986299963000630016300263003630046300563006630076300863009630106301163012630136301463015630166301763018630196302063021630226302363024630256302663027630286302963030630316303263033630346303563036630376303863039630406304163042630436304463045630466304763048630496305063051630526305363054630556305663057630586305963060630616306263063630646306563066630676306863069630706307163072630736307463075630766307763078630796308063081630826308363084630856308663087630886308963090630916309263093630946309563096630976309863099631006310163102631036310463105631066310763108631096311063111631126311363114631156311663117631186311963120631216312263123631246312563126631276312863129631306313163132631336313463135631366313763138631396314063141631426314363144631456314663147631486314963150631516315263153631546315563156631576315863159631606316163162631636316463165631666316763168631696317063171631726317363174631756317663177631786317963180631816318263183631846318563186631876318863189631906319163192631936319463195631966319763198631996320063201632026320363204632056320663207632086320963210632116321263213632146321563216632176321863219632206322163222632236322463225632266322763228632296323063231632326323363234632356323663237632386323963240632416324263243632446324563246632476324863249632506325163252632536325463255632566325763258632596326063261632626326363264632656326663267632686326963270632716327263273632746327563276632776327863279632806328163282632836328463285632866328763288632896329063291632926329363294632956329663297632986329963300633016330263303633046330563306633076330863309633106331163312633136331463315633166331763318633196332063321633226332363324633256332663327633286332963330633316333263333633346333563336633376333863339633406334163342633436334463345633466334763348633496335063351633526335363354633556335663357633586335963360633616336263363633646336563366633676336863369633706337163372633736337463375633766337763378633796338063381633826338363384633856338663387633886338963390633916339263393633946339563396633976339863399634006340163402634036340463405634066340763408634096341063411634126341363414634156341663417634186341963420634216342263423634246342563426634276342863429634306343163432634336343463435634366343763438634396344063441634426344363444634456344663447634486344963450634516345263453634546345563456634576345863459634606346163462634636346463465634666346763468634696347063471634726347363474634756347663477634786347963480634816348263483634846348563486634876348863489634906349163492634936349463495634966349763498634996350063501635026350363504635056350663507635086350963510635116351263513635146351563516635176351863519635206352163522635236352463525635266352763528635296353063531635326353363534635356353663537635386353963540635416354263543635446354563546635476354863549635506355163552635536355463555635566355763558635596356063561635626356363564635656356663567635686356963570635716357263573635746357563576635776357863579635806358163582635836358463585635866358763588635896359063591635926359363594635956359663597635986359963600636016360263603636046360563606636076360863609636106361163612636136361463615636166361763618636196362063621636226362363624636256362663627636286362963630636316363263633636346363563636636376363863639636406364163642636436364463645636466364763648636496365063651636526365363654636556365663657636586365963660636616366263663636646366563666636676366863669636706367163672636736367463675636766367763678636796368063681636826368363684636856368663687636886368963690636916369263693636946369563696636976369863699637006370163702637036370463705637066370763708637096371063711637126371363714637156371663717637186371963720637216372263723637246372563726637276372863729637306373163732637336373463735637366373763738637396374063741637426374363744637456374663747637486374963750637516375263753637546375563756637576375863759637606376163762637636376463765637666376763768637696377063771637726377363774637756377663777637786377963780637816378263783637846378563786637876378863789637906379163792637936379463795637966379763798637996380063801638026380363804638056380663807638086380963810638116381263813638146381563816638176381863819638206382163822638236382463825638266382763828638296383063831638326383363834638356383663837638386383963840638416384263843638446384563846638476384863849638506385163852638536385463855638566385763858638596386063861638626386363864638656386663867638686386963870638716387263873638746387563876638776387863879638806388163882638836388463885638866388763888638896389063891638926389363894638956389663897638986389963900639016390263903639046390563906639076390863909639106391163912639136391463915639166391763918639196392063921639226392363924639256392663927639286392963930639316393263933639346393563936639376393863939639406394163942639436394463945639466394763948639496395063951639526395363954639556395663957639586395963960639616396263963639646396563966639676396863969639706397163972639736397463975639766397763978639796398063981639826398363984639856398663987639886398963990639916399263993639946399563996639976399863999640006400164002640036400464005640066400764008640096401064011640126401364014640156401664017640186401964020640216402264023640246402564026640276402864029640306403164032640336403464035640366403764038640396404064041640426404364044640456404664047640486404964050640516405264053640546405564056640576405864059640606406164062640636406464065640666406764068640696407064071640726407364074640756407664077640786407964080640816408264083640846408564086640876408864089640906409164092640936409464095640966409764098640996410064101641026410364104641056410664107641086410964110641116411264113641146411564116641176411864119641206412164122641236412464125641266412764128641296413064131641326413364134641356413664137641386413964140641416414264143641446414564146641476414864149641506415164152641536415464155641566415764158641596416064161641626416364164641656416664167641686416964170641716417264173641746417564176641776417864179641806418164182641836418464185641866418764188641896419064191641926419364194641956419664197641986419964200642016420264203642046420564206642076420864209642106421164212642136421464215642166421764218642196422064221642226422364224642256422664227642286422964230642316423264233642346423564236642376423864239642406424164242642436424464245642466424764248642496425064251642526425364254642556425664257642586425964260642616426264263642646426564266642676426864269642706427164272642736427464275642766427764278642796428064281642826428364284642856428664287642886428964290642916429264293642946429564296642976429864299643006430164302643036430464305643066430764308643096431064311643126431364314643156431664317643186431964320643216432264323643246432564326643276432864329643306433164332643336433464335643366433764338643396434064341643426434364344643456434664347643486434964350643516435264353643546435564356643576435864359643606436164362643636436464365643666436764368643696437064371643726437364374643756437664377643786437964380643816438264383643846438564386643876438864389643906439164392643936439464395643966439764398643996440064401644026440364404644056440664407644086440964410644116441264413644146441564416644176441864419644206442164422644236442464425644266442764428644296443064431644326443364434644356443664437644386443964440644416444264443644446444564446644476444864449644506445164452644536445464455644566445764458644596446064461644626446364464644656446664467644686446964470644716447264473644746447564476644776447864479644806448164482644836448464485644866448764488644896449064491644926449364494644956449664497644986449964500645016450264503645046450564506645076450864509645106451164512645136451464515645166451764518645196452064521645226452364524645256452664527645286452964530645316453264533645346453564536645376453864539645406454164542645436454464545645466454764548645496455064551645526455364554645556455664557645586455964560645616456264563645646456564566645676456864569645706457164572645736457464575645766457764578645796458064581645826458364584645856458664587645886458964590645916459264593645946459564596645976459864599646006460164602646036460464605646066460764608646096461064611646126461364614646156461664617646186461964620646216462264623646246462564626646276462864629646306463164632646336463464635646366463764638646396464064641646426464364644646456464664647646486464964650646516465264653646546465564656646576465864659646606466164662646636466464665646666466764668646696467064671646726467364674646756467664677646786467964680646816468264683646846468564686646876468864689646906469164692646936469464695646966469764698646996470064701647026470364704647056470664707647086470964710647116471264713647146471564716647176471864719647206472164722647236472464725647266472764728647296473064731647326473364734647356473664737647386473964740647416474264743647446474564746647476474864749647506475164752647536475464755647566475764758647596476064761647626476364764647656476664767647686476964770647716477264773647746477564776647776477864779647806478164782647836478464785647866478764788647896479064791647926479364794647956479664797647986479964800648016480264803648046480564806648076480864809648106481164812648136481464815648166481764818648196482064821648226482364824648256482664827648286482964830648316483264833648346483564836648376483864839648406484164842648436484464845648466484764848648496485064851648526485364854648556485664857648586485964860648616486264863648646486564866648676486864869648706487164872648736487464875648766487764878648796488064881648826488364884648856488664887648886488964890648916489264893648946489564896648976489864899649006490164902649036490464905649066490764908649096491064911649126491364914649156491664917649186491964920649216492264923649246492564926649276492864929649306493164932649336493464935649366493764938649396494064941649426494364944649456494664947649486494964950649516495264953649546495564956649576495864959649606496164962649636496464965649666496764968649696497064971649726497364974649756497664977649786497964980649816498264983649846498564986649876498864989649906499164992649936499464995649966499764998649996500065001650026500365004650056500665007650086500965010650116501265013650146501565016650176501865019650206502165022650236502465025650266502765028650296503065031650326503365034650356503665037650386503965040650416504265043650446504565046650476504865049650506505165052650536505465055650566505765058650596506065061650626506365064650656506665067650686506965070650716507265073650746507565076650776507865079650806508165082650836508465085650866508765088650896509065091650926509365094650956509665097650986509965100651016510265103651046510565106651076510865109651106511165112651136511465115651166511765118651196512065121651226512365124651256512665127651286512965130651316513265133651346513565136651376513865139651406514165142651436514465145651466514765148651496515065151651526515365154651556515665157651586515965160651616516265163651646516565166651676516865169651706517165172651736517465175651766517765178651796518065181651826518365184651856518665187651886518965190651916519265193651946519565196651976519865199652006520165202652036520465205652066520765208652096521065211652126521365214652156521665217652186521965220652216522265223652246522565226652276522865229652306523165232652336523465235652366523765238652396524065241652426524365244652456524665247652486524965250652516525265253652546525565256652576525865259652606526165262652636526465265652666526765268652696527065271652726527365274652756527665277652786527965280652816528265283652846528565286652876528865289652906529165292652936529465295652966529765298652996530065301653026530365304653056530665307653086530965310653116531265313653146531565316653176531865319653206532165322653236532465325653266532765328653296533065331653326533365334653356533665337653386533965340653416534265343653446534565346653476534865349653506535165352653536535465355653566535765358653596536065361653626536365364653656536665367653686536965370653716537265373653746537565376653776537865379653806538165382653836538465385653866538765388653896539065391653926539365394653956539665397653986539965400654016540265403654046540565406654076540865409654106541165412654136541465415654166541765418654196542065421654226542365424654256542665427654286542965430654316543265433654346543565436654376543865439654406544165442654436544465445654466544765448654496545065451654526545365454654556545665457654586545965460654616546265463654646546565466654676546865469654706547165472654736547465475654766547765478654796548065481654826548365484654856548665487654886548965490654916549265493654946549565496654976549865499655006550165502655036550465505655066550765508655096551065511655126551365514655156551665517655186551965520655216552265523655246552565526655276552865529655306553165532655336553465535655366553765538655396554065541655426554365544655456554665547655486554965550655516555265553655546555565556655576555865559655606556165562655636556465565655666556765568655696557065571655726557365574655756557665577655786557965580655816558265583655846558565586655876558865589655906559165592655936559465595655966559765598655996560065601656026560365604656056560665607656086560965610656116561265613656146561565616656176561865619656206562165622656236562465625656266562765628656296563065631656326563365634656356563665637656386563965640656416564265643656446564565646656476564865649656506565165652656536565465655656566565765658656596566065661656626566365664656656566665667656686566965670656716567265673656746567565676656776567865679656806568165682656836568465685656866568765688656896569065691656926569365694656956569665697656986569965700657016570265703657046570565706657076570865709657106571165712657136571465715657166571765718657196572065721657226572365724657256572665727657286572965730657316573265733657346573565736657376573865739657406574165742657436574465745657466574765748657496575065751657526575365754657556575665757657586575965760657616576265763657646576565766657676576865769657706577165772657736577465775657766577765778657796578065781657826578365784657856578665787657886578965790657916579265793657946579565796657976579865799658006580165802658036580465805658066580765808658096581065811658126581365814658156581665817658186581965820658216582265823658246582565826658276582865829658306583165832658336583465835658366583765838658396584065841658426584365844658456584665847658486584965850658516585265853658546585565856658576585865859658606586165862658636586465865658666586765868658696587065871658726587365874658756587665877658786587965880658816588265883658846588565886658876588865889658906589165892658936589465895658966589765898658996590065901659026590365904659056590665907659086590965910659116591265913659146591565916659176591865919659206592165922659236592465925659266592765928659296593065931659326593365934659356593665937659386593965940659416594265943659446594565946659476594865949659506595165952659536595465955659566595765958659596596065961659626596365964659656596665967659686596965970659716597265973659746597565976659776597865979659806598165982659836598465985659866598765988659896599065991659926599365994659956599665997659986599966000660016600266003660046600566006660076600866009660106601166012660136601466015660166601766018660196602066021660226602366024660256602666027660286602966030660316603266033660346603566036660376603866039660406604166042660436604466045660466604766048660496605066051660526605366054660556605666057660586605966060660616606266063660646606566066660676606866069660706607166072660736607466075660766607766078660796608066081660826608366084660856608666087660886608966090660916609266093660946609566096660976609866099661006610166102661036610466105661066610766108661096611066111661126611366114661156611666117661186611966120661216612266123661246612566126661276612866129661306613166132661336613466135661366613766138661396614066141661426614366144661456614666147661486614966150661516615266153661546615566156661576615866159661606616166162661636616466165661666616766168661696617066171661726617366174661756617666177661786617966180661816618266183661846618566186661876618866189661906619166192661936619466195661966619766198661996620066201662026620366204662056620666207662086620966210662116621266213662146621566216662176621866219662206622166222662236622466225662266622766228662296623066231662326623366234662356623666237662386623966240662416624266243662446624566246662476624866249662506625166252662536625466255662566625766258662596626066261662626626366264662656626666267662686626966270662716627266273662746627566276662776627866279662806628166282662836628466285662866628766288662896629066291662926629366294662956629666297662986629966300663016630266303663046630566306663076630866309663106631166312663136631466315663166631766318663196632066321663226632366324663256632666327663286632966330663316633266333663346633566336663376633866339663406634166342663436634466345663466634766348663496635066351663526635366354663556635666357663586635966360663616636266363663646636566366663676636866369663706637166372663736637466375663766637766378663796638066381663826638366384663856638666387663886638966390663916639266393663946639566396663976639866399664006640166402664036640466405664066640766408664096641066411664126641366414664156641666417664186641966420664216642266423664246642566426664276642866429664306643166432664336643466435664366643766438664396644066441664426644366444664456644666447664486644966450664516645266453664546645566456664576645866459664606646166462664636646466465664666646766468664696647066471664726647366474664756647666477664786647966480664816648266483664846648566486664876648866489664906649166492664936649466495664966649766498664996650066501665026650366504665056650666507665086650966510665116651266513665146651566516665176651866519665206652166522665236652466525665266652766528665296653066531665326653366534665356653666537665386653966540665416654266543665446654566546665476654866549665506655166552665536655466555665566655766558665596656066561665626656366564665656656666567665686656966570665716657266573665746657566576665776657866579665806658166582665836658466585665866658766588665896659066591665926659366594665956659666597665986659966600666016660266603666046660566606666076660866609666106661166612666136661466615666166661766618666196662066621666226662366624666256662666627666286662966630666316663266633666346663566636666376663866639666406664166642666436664466645666466664766648666496665066651666526665366654666556665666657666586665966660666616666266663666646666566666666676666866669666706667166672666736667466675666766667766678666796668066681666826668366684666856668666687666886668966690666916669266693666946669566696666976669866699667006670166702667036670466705667066670766708667096671066711667126671366714667156671666717667186671966720667216672266723667246672566726667276672866729667306673166732667336673466735667366673766738667396674066741667426674366744667456674666747667486674966750667516675266753667546675566756667576675866759667606676166762667636676466765667666676766768667696677066771667726677366774667756677666777667786677966780667816678266783667846678566786667876678866789667906679166792667936679466795667966679766798667996680066801668026680366804668056680666807668086680966810668116681266813668146681566816668176681866819668206682166822668236682466825668266682766828668296683066831668326683366834668356683666837668386683966840668416684266843668446684566846668476684866849668506685166852668536685466855668566685766858668596686066861668626686366864668656686666867668686686966870668716687266873668746687566876668776687866879668806688166882668836688466885668866688766888668896689066891668926689366894668956689666897668986689966900669016690266903669046690566906669076690866909669106691166912669136691466915669166691766918669196692066921669226692366924669256692666927669286692966930669316693266933669346693566936669376693866939669406694166942669436694466945669466694766948669496695066951669526695366954669556695666957669586695966960669616696266963669646696566966669676696866969669706697166972669736697466975669766697766978669796698066981669826698366984669856698666987669886698966990669916699266993669946699566996669976699866999670006700167002670036700467005670066700767008670096701067011670126701367014670156701667017670186701967020670216702267023670246702567026670276702867029670306703167032670336703467035670366703767038670396704067041670426704367044670456704667047670486704967050670516705267053670546705567056670576705867059670606706167062670636706467065670666706767068670696707067071670726707367074670756707667077670786707967080670816708267083670846708567086670876708867089670906709167092670936709467095670966709767098670996710067101671026710367104671056710667107671086710967110671116711267113671146711567116671176711867119671206712167122671236712467125671266712767128671296713067131671326713367134671356713667137671386713967140671416714267143671446714567146671476714867149671506715167152671536715467155671566715767158671596716067161671626716367164671656716667167671686716967170671716717267173671746717567176671776717867179671806718167182671836718467185671866718767188671896719067191671926719367194671956719667197671986719967200672016720267203672046720567206672076720867209672106721167212672136721467215672166721767218672196722067221672226722367224672256722667227672286722967230672316723267233672346723567236672376723867239672406724167242672436724467245672466724767248672496725067251672526725367254672556725667257672586725967260672616726267263672646726567266672676726867269672706727167272672736727467275672766727767278672796728067281672826728367284672856728667287672886728967290672916729267293672946729567296672976729867299673006730167302673036730467305673066730767308673096731067311673126731367314673156731667317673186731967320673216732267323673246732567326673276732867329673306733167332673336733467335673366733767338673396734067341673426734367344673456734667347673486734967350673516735267353673546735567356673576735867359673606736167362673636736467365673666736767368673696737067371673726737367374673756737667377673786737967380673816738267383673846738567386673876738867389673906739167392673936739467395673966739767398673996740067401674026740367404674056740667407674086740967410674116741267413674146741567416674176741867419674206742167422674236742467425674266742767428674296743067431674326743367434674356743667437674386743967440674416744267443674446744567446674476744867449674506745167452674536745467455674566745767458674596746067461674626746367464674656746667467674686746967470674716747267473674746747567476674776747867479674806748167482674836748467485674866748767488674896749067491674926749367494674956749667497674986749967500675016750267503675046750567506675076750867509675106751167512675136751467515675166751767518675196752067521675226752367524675256752667527675286752967530675316753267533675346753567536675376753867539675406754167542675436754467545675466754767548675496755067551675526755367554675556755667557675586755967560675616756267563675646756567566675676756867569675706757167572675736757467575675766757767578675796758067581675826758367584675856758667587675886758967590675916759267593675946759567596675976759867599676006760167602676036760467605676066760767608676096761067611676126761367614676156761667617676186761967620676216762267623676246762567626676276762867629676306763167632676336763467635676366763767638676396764067641676426764367644676456764667647676486764967650676516765267653676546765567656676576765867659676606766167662676636766467665676666766767668676696767067671676726767367674676756767667677676786767967680676816768267683676846768567686676876768867689676906769167692676936769467695676966769767698676996770067701677026770367704677056770667707677086770967710677116771267713677146771567716677176771867719677206772167722677236772467725677266772767728677296773067731677326773367734677356773667737677386773967740677416774267743677446774567746677476774867749677506775167752677536775467755677566775767758677596776067761677626776367764677656776667767677686776967770677716777267773677746777567776677776777867779677806778167782677836778467785677866778767788677896779067791677926779367794677956779667797677986779967800678016780267803678046780567806678076780867809678106781167812678136781467815678166781767818678196782067821678226782367824678256782667827678286782967830678316783267833678346783567836678376783867839678406784167842678436784467845678466784767848678496785067851678526785367854678556785667857678586785967860678616786267863678646786567866678676786867869678706787167872678736787467875678766787767878678796788067881678826788367884678856788667887678886788967890678916789267893678946789567896678976789867899679006790167902679036790467905679066790767908679096791067911679126791367914679156791667917679186791967920679216792267923679246792567926679276792867929679306793167932679336793467935679366793767938679396794067941679426794367944679456794667947679486794967950679516795267953679546795567956679576795867959679606796167962679636796467965679666796767968679696797067971679726797367974679756797667977679786797967980679816798267983679846798567986679876798867989679906799167992679936799467995679966799767998679996800068001680026800368004680056800668007680086800968010680116801268013680146801568016680176801868019680206802168022680236802468025680266802768028680296803068031680326803368034680356803668037680386803968040680416804268043680446804568046680476804868049680506805168052680536805468055680566805768058680596806068061680626806368064680656806668067680686806968070680716807268073680746807568076680776807868079680806808168082680836808468085680866808768088680896809068091680926809368094680956809668097680986809968100681016810268103681046810568106681076810868109681106811168112681136811468115681166811768118681196812068121681226812368124681256812668127681286812968130681316813268133681346813568136681376813868139681406814168142681436814468145681466814768148681496815068151681526815368154681556815668157681586815968160681616816268163681646816568166681676816868169681706817168172681736817468175681766817768178681796818068181681826818368184681856818668187681886818968190681916819268193681946819568196681976819868199682006820168202682036820468205682066820768208682096821068211682126821368214682156821668217682186821968220682216822268223682246822568226682276822868229682306823168232682336823468235682366823768238682396824068241682426824368244682456824668247682486824968250682516825268253682546825568256682576825868259682606826168262682636826468265682666826768268682696827068271682726827368274682756827668277682786827968280682816828268283682846828568286682876828868289682906829168292682936829468295682966829768298682996830068301683026830368304683056830668307683086830968310683116831268313683146831568316683176831868319683206832168322683236832468325683266832768328683296833068331683326833368334683356833668337683386833968340683416834268343683446834568346683476834868349683506835168352683536835468355683566835768358683596836068361683626836368364683656836668367683686836968370683716837268373683746837568376683776837868379683806838168382683836838468385683866838768388683896839068391683926839368394683956839668397683986839968400684016840268403684046840568406684076840868409684106841168412684136841468415684166841768418684196842068421684226842368424684256842668427684286842968430684316843268433684346843568436684376843868439684406844168442684436844468445684466844768448684496845068451684526845368454684556845668457684586845968460684616846268463684646846568466684676846868469684706847168472684736847468475684766847768478684796848068481684826848368484684856848668487684886848968490684916849268493684946849568496684976849868499685006850168502685036850468505685066850768508685096851068511685126851368514685156851668517685186851968520685216852268523685246852568526685276852868529685306853168532685336853468535685366853768538685396854068541685426854368544685456854668547685486854968550685516855268553685546855568556685576855868559685606856168562685636856468565685666856768568685696857068571685726857368574685756857668577685786857968580685816858268583685846858568586685876858868589685906859168592685936859468595685966859768598685996860068601686026860368604686056860668607686086860968610686116861268613686146861568616686176861868619686206862168622686236862468625686266862768628686296863068631686326863368634686356863668637686386863968640686416864268643686446864568646686476864868649686506865168652686536865468655686566865768658686596866068661686626866368664686656866668667686686866968670686716867268673686746867568676686776867868679686806868168682686836868468685686866868768688686896869068691686926869368694686956869668697686986869968700687016870268703687046870568706687076870868709687106871168712687136871468715687166871768718687196872068721687226872368724687256872668727687286872968730687316873268733687346873568736687376873868739687406874168742687436874468745687466874768748687496875068751687526875368754687556875668757687586875968760687616876268763687646876568766687676876868769687706877168772687736877468775687766877768778687796878068781687826878368784687856878668787687886878968790687916879268793687946879568796687976879868799688006880168802688036880468805688066880768808688096881068811688126881368814688156881668817688186881968820688216882268823688246882568826688276882868829688306883168832688336883468835688366883768838688396884068841688426884368844688456884668847688486884968850688516885268853688546885568856688576885868859688606886168862688636886468865688666886768868688696887068871688726887368874688756887668877688786887968880688816888268883688846888568886688876888868889688906889168892688936889468895688966889768898688996890068901689026890368904689056890668907689086890968910689116891268913689146891568916689176891868919689206892168922689236892468925689266892768928689296893068931689326893368934689356893668937689386893968940689416894268943689446894568946689476894868949689506895168952689536895468955689566895768958689596896068961689626896368964689656896668967689686896968970689716897268973689746897568976689776897868979689806898168982689836898468985689866898768988689896899068991689926899368994689956899668997689986899969000690016900269003690046900569006690076900869009690106901169012690136901469015690166901769018690196902069021690226902369024690256902669027690286902969030690316903269033690346903569036690376903869039690406904169042690436904469045690466904769048690496905069051690526905369054690556905669057690586905969060690616906269063690646906569066690676906869069690706907169072690736907469075690766907769078690796908069081690826908369084690856908669087690886908969090690916909269093690946909569096690976909869099691006910169102691036910469105691066910769108691096911069111691126911369114691156911669117691186911969120691216912269123691246912569126691276912869129691306913169132691336913469135691366913769138691396914069141691426914369144691456914669147691486914969150691516915269153691546915569156691576915869159691606916169162691636916469165691666916769168691696917069171691726917369174691756917669177691786917969180691816918269183691846918569186691876918869189691906919169192691936919469195691966919769198691996920069201692026920369204692056920669207692086920969210692116921269213692146921569216692176921869219692206922169222692236922469225692266922769228692296923069231692326923369234692356923669237692386923969240692416924269243692446924569246692476924869249692506925169252692536925469255692566925769258692596926069261692626926369264692656926669267692686926969270692716927269273692746927569276692776927869279692806928169282692836928469285692866928769288692896929069291692926929369294692956929669297692986929969300693016930269303693046930569306693076930869309693106931169312693136931469315693166931769318693196932069321693226932369324693256932669327693286932969330693316933269333693346933569336693376933869339693406934169342693436934469345693466934769348693496935069351693526935369354693556935669357693586935969360693616936269363693646936569366693676936869369693706937169372693736937469375693766937769378693796938069381693826938369384693856938669387693886938969390693916939269393693946939569396693976939869399694006940169402694036940469405694066940769408694096941069411694126941369414694156941669417694186941969420694216942269423694246942569426694276942869429694306943169432694336943469435694366943769438694396944069441694426944369444694456944669447694486944969450694516945269453694546945569456694576945869459694606946169462694636946469465694666946769468694696947069471694726947369474694756947669477694786947969480694816948269483694846948569486694876948869489694906949169492694936949469495694966949769498694996950069501695026950369504695056950669507695086950969510695116951269513695146951569516695176951869519695206952169522695236952469525695266952769528695296953069531695326953369534695356953669537695386953969540695416954269543695446954569546695476954869549695506955169552695536955469555695566955769558695596956069561695626956369564695656956669567695686956969570695716957269573695746957569576695776957869579695806958169582695836958469585695866958769588695896959069591695926959369594695956959669597695986959969600696016960269603696046960569606696076960869609696106961169612696136961469615696166961769618696196962069621696226962369624696256962669627696286962969630696316963269633696346963569636696376963869639696406964169642696436964469645696466964769648696496965069651696526965369654696556965669657696586965969660696616966269663696646966569666696676966869669696706967169672696736967469675696766967769678696796968069681696826968369684696856968669687696886968969690696916969269693696946969569696696976969869699697006970169702697036970469705697066970769708697096971069711697126971369714697156971669717697186971969720697216972269723697246972569726697276972869729697306973169732697336973469735697366973769738697396974069741697426974369744697456974669747697486974969750697516975269753697546975569756697576975869759697606976169762697636976469765697666976769768697696977069771697726977369774697756977669777697786977969780697816978269783697846978569786697876978869789697906979169792697936979469795697966979769798697996980069801698026980369804698056980669807698086980969810698116981269813698146981569816698176981869819698206982169822698236982469825698266982769828698296983069831698326983369834698356983669837698386983969840698416984269843698446984569846698476984869849698506985169852698536985469855698566985769858698596986069861698626986369864698656986669867698686986969870698716987269873698746987569876698776987869879698806988169882698836988469885698866988769888698896989069891698926989369894698956989669897698986989969900699016990269903699046990569906699076990869909699106991169912699136991469915699166991769918699196992069921699226992369924699256992669927699286992969930699316993269933699346993569936699376993869939699406994169942699436994469945699466994769948699496995069951699526995369954699556995669957699586995969960699616996269963699646996569966699676996869969699706997169972699736997469975699766997769978699796998069981699826998369984699856998669987699886998969990699916999269993699946999569996699976999869999700007000170002700037000470005700067000770008700097001070011700127001370014700157001670017700187001970020700217002270023700247002570026700277002870029700307003170032700337003470035700367003770038700397004070041700427004370044700457004670047700487004970050700517005270053700547005570056700577005870059700607006170062700637006470065700667006770068700697007070071700727007370074700757007670077700787007970080700817008270083700847008570086700877008870089700907009170092700937009470095700967009770098700997010070101701027010370104701057010670107701087010970110701117011270113701147011570116701177011870119701207012170122701237012470125701267012770128701297013070131701327013370134701357013670137701387013970140701417014270143701447014570146701477014870149701507015170152701537015470155701567015770158701597016070161701627016370164701657016670167701687016970170701717017270173701747017570176701777017870179701807018170182701837018470185701867018770188701897019070191701927019370194701957019670197701987019970200702017020270203702047020570206702077020870209702107021170212702137021470215702167021770218702197022070221702227022370224702257022670227702287022970230702317023270233702347023570236702377023870239702407024170242702437024470245702467024770248702497025070251702527025370254702557025670257702587025970260702617026270263702647026570266702677026870269702707027170272702737027470275702767027770278702797028070281702827028370284702857028670287702887028970290702917029270293702947029570296702977029870299703007030170302703037030470305703067030770308703097031070311703127031370314703157031670317703187031970320703217032270323703247032570326703277032870329703307033170332703337033470335703367033770338703397034070341703427034370344703457034670347703487034970350703517035270353703547035570356703577035870359703607036170362703637036470365703667036770368703697037070371703727037370374703757037670377703787037970380703817038270383703847038570386703877038870389703907039170392703937039470395703967039770398703997040070401704027040370404704057040670407704087040970410704117041270413704147041570416704177041870419704207042170422704237042470425704267042770428704297043070431704327043370434704357043670437704387043970440704417044270443704447044570446704477044870449704507045170452704537045470455704567045770458704597046070461704627046370464704657046670467704687046970470704717047270473704747047570476704777047870479704807048170482704837048470485704867048770488704897049070491704927049370494704957049670497704987049970500705017050270503705047050570506705077050870509705107051170512705137051470515705167051770518705197052070521705227052370524705257052670527705287052970530705317053270533705347053570536705377053870539705407054170542705437054470545705467054770548705497055070551705527055370554705557055670557705587055970560705617056270563705647056570566705677056870569705707057170572705737057470575705767057770578705797058070581705827058370584705857058670587705887058970590705917059270593705947059570596705977059870599706007060170602706037060470605706067060770608706097061070611706127061370614706157061670617706187061970620706217062270623706247062570626706277062870629706307063170632706337063470635706367063770638706397064070641706427064370644706457064670647706487064970650706517065270653706547065570656706577065870659706607066170662706637066470665706667066770668706697067070671706727067370674706757067670677706787067970680706817068270683706847068570686706877068870689706907069170692706937069470695706967069770698706997070070701707027070370704707057070670707707087070970710707117071270713707147071570716707177071870719707207072170722707237072470725707267072770728707297073070731707327073370734707357073670737707387073970740707417074270743707447074570746707477074870749707507075170752707537075470755707567075770758707597076070761707627076370764707657076670767707687076970770707717077270773707747077570776707777077870779707807078170782707837078470785707867078770788707897079070791707927079370794707957079670797707987079970800708017080270803708047080570806708077080870809708107081170812708137081470815708167081770818708197082070821708227082370824708257082670827708287082970830708317083270833708347083570836708377083870839708407084170842708437084470845708467084770848708497085070851708527085370854708557085670857708587085970860708617086270863708647086570866708677086870869708707087170872708737087470875708767087770878708797088070881708827088370884708857088670887708887088970890708917089270893708947089570896708977089870899709007090170902709037090470905709067090770908709097091070911709127091370914709157091670917709187091970920709217092270923709247092570926709277092870929709307093170932709337093470935709367093770938709397094070941709427094370944709457094670947709487094970950709517095270953709547095570956709577095870959709607096170962709637096470965709667096770968709697097070971709727097370974709757097670977709787097970980709817098270983709847098570986709877098870989709907099170992709937099470995709967099770998709997100071001710027100371004710057100671007710087100971010710117101271013710147101571016710177101871019710207102171022710237102471025710267102771028710297103071031710327103371034710357103671037710387103971040710417104271043710447104571046710477104871049710507105171052710537105471055710567105771058710597106071061710627106371064710657106671067710687106971070710717107271073710747107571076710777107871079710807108171082710837108471085710867108771088710897109071091710927109371094710957109671097710987109971100711017110271103711047110571106711077110871109711107111171112711137111471115711167111771118711197112071121711227112371124711257112671127711287112971130711317113271133711347113571136711377113871139711407114171142711437114471145711467114771148711497115071151711527115371154711557115671157711587115971160711617116271163711647116571166711677116871169711707117171172711737117471175711767117771178711797118071181711827118371184711857118671187711887118971190711917119271193711947119571196711977119871199712007120171202712037120471205712067120771208712097121071211712127121371214712157121671217712187121971220712217122271223712247122571226712277122871229712307123171232712337123471235712367123771238712397124071241712427124371244712457124671247712487124971250712517125271253712547125571256712577125871259712607126171262712637126471265712667126771268712697127071271712727127371274712757127671277712787127971280712817128271283712847128571286712877128871289712907129171292712937129471295712967129771298712997130071301713027130371304713057130671307713087130971310713117131271313713147131571316713177131871319713207132171322713237132471325713267132771328713297133071331713327133371334713357133671337713387133971340713417134271343713447134571346713477134871349713507135171352713537135471355713567135771358713597136071361713627136371364713657136671367713687136971370713717137271373713747137571376713777137871379713807138171382713837138471385713867138771388713897139071391713927139371394713957139671397713987139971400714017140271403714047140571406714077140871409714107141171412714137141471415714167141771418714197142071421714227142371424714257142671427714287142971430714317143271433714347143571436714377143871439714407144171442714437144471445714467144771448714497145071451714527145371454714557145671457714587145971460714617146271463714647146571466714677146871469714707147171472714737147471475714767147771478714797148071481714827148371484714857148671487714887148971490714917149271493714947149571496714977149871499715007150171502715037150471505715067150771508715097151071511715127151371514715157151671517715187151971520715217152271523715247152571526715277152871529715307153171532715337153471535715367153771538715397154071541715427154371544715457154671547715487154971550715517155271553715547155571556715577155871559715607156171562715637156471565715667156771568715697157071571715727157371574715757157671577715787157971580715817158271583715847158571586715877158871589715907159171592715937159471595715967159771598715997160071601716027160371604716057160671607716087160971610716117161271613716147161571616716177161871619716207162171622716237162471625716267162771628716297163071631716327163371634716357163671637716387163971640716417164271643716447164571646716477164871649716507165171652716537165471655716567165771658716597166071661716627166371664716657166671667716687166971670716717167271673716747167571676716777167871679716807168171682716837168471685716867168771688716897169071691716927169371694716957169671697716987169971700717017170271703717047170571706717077170871709717107171171712717137171471715717167171771718717197172071721717227172371724717257172671727717287172971730717317173271733717347173571736717377173871739717407174171742717437174471745717467174771748717497175071751717527175371754717557175671757717587175971760717617176271763717647176571766717677176871769717707177171772717737177471775717767177771778717797178071781717827178371784717857178671787717887178971790717917179271793717947179571796717977179871799718007180171802718037180471805718067180771808718097181071811718127181371814718157181671817718187181971820718217182271823718247182571826718277182871829718307183171832718337183471835718367183771838718397184071841718427184371844718457184671847718487184971850718517185271853718547185571856718577185871859718607186171862718637186471865718667186771868718697187071871718727187371874718757187671877718787187971880718817188271883718847188571886718877188871889718907189171892718937189471895718967189771898718997190071901719027190371904719057190671907719087190971910719117191271913719147191571916719177191871919719207192171922719237192471925719267192771928719297193071931719327193371934719357193671937719387193971940719417194271943719447194571946719477194871949719507195171952719537195471955719567195771958719597196071961719627196371964719657196671967719687196971970719717197271973719747197571976719777197871979719807198171982719837198471985719867198771988719897199071991719927199371994719957199671997719987199972000720017200272003720047200572006720077200872009720107201172012720137201472015720167201772018720197202072021720227202372024720257202672027720287202972030720317203272033720347203572036720377203872039720407204172042720437204472045720467204772048720497205072051720527205372054720557205672057720587205972060720617206272063720647206572066720677206872069720707207172072720737207472075720767207772078720797208072081720827208372084720857208672087720887208972090720917209272093720947209572096720977209872099721007210172102721037210472105721067210772108721097211072111721127211372114721157211672117721187211972120721217212272123721247212572126721277212872129721307213172132721337213472135721367213772138721397214072141721427214372144721457214672147721487214972150721517215272153721547215572156721577215872159721607216172162721637216472165721667216772168721697217072171721727217372174721757217672177721787217972180721817218272183721847218572186721877218872189721907219172192721937219472195721967219772198721997220072201722027220372204722057220672207722087220972210722117221272213722147221572216722177221872219722207222172222722237222472225722267222772228722297223072231722327223372234722357223672237722387223972240722417224272243722447224572246722477224872249722507225172252722537225472255722567225772258722597226072261722627226372264722657226672267722687226972270722717227272273722747227572276722777227872279722807228172282722837228472285722867228772288722897229072291722927229372294722957229672297722987229972300723017230272303723047230572306723077230872309723107231172312723137231472315723167231772318723197232072321723227232372324723257232672327723287232972330723317233272333723347233572336723377233872339723407234172342723437234472345723467234772348723497235072351723527235372354723557235672357723587235972360723617236272363723647236572366723677236872369723707237172372723737237472375723767237772378723797238072381723827238372384723857238672387723887238972390723917239272393723947239572396723977239872399724007240172402724037240472405724067240772408724097241072411724127241372414724157241672417724187241972420724217242272423724247242572426724277242872429724307243172432724337243472435724367243772438724397244072441724427244372444724457244672447724487244972450724517245272453724547245572456724577245872459724607246172462724637246472465724667246772468724697247072471724727247372474724757247672477724787247972480724817248272483724847248572486724877248872489724907249172492724937249472495724967249772498724997250072501725027250372504725057250672507725087250972510725117251272513725147251572516725177251872519725207252172522725237252472525725267252772528725297253072531725327253372534725357253672537725387253972540725417254272543725447254572546725477254872549725507255172552725537255472555725567255772558725597256072561725627256372564725657256672567725687256972570725717257272573725747257572576725777257872579725807258172582725837258472585725867258772588725897259072591725927259372594725957259672597725987259972600726017260272603726047260572606726077260872609726107261172612726137261472615726167261772618726197262072621726227262372624726257262672627726287262972630726317263272633726347263572636726377263872639726407264172642726437264472645726467264772648726497265072651726527265372654726557265672657726587265972660726617266272663726647266572666726677266872669726707267172672726737267472675726767267772678726797268072681726827268372684726857268672687726887268972690726917269272693726947269572696726977269872699727007270172702727037270472705727067270772708727097271072711727127271372714727157271672717727187271972720727217272272723727247272572726727277272872729727307273172732727337273472735727367273772738727397274072741727427274372744727457274672747727487274972750727517275272753727547275572756727577275872759727607276172762727637276472765727667276772768727697277072771727727277372774727757277672777727787277972780727817278272783727847278572786727877278872789727907279172792727937279472795727967279772798727997280072801728027280372804728057280672807728087280972810728117281272813728147281572816728177281872819728207282172822728237282472825728267282772828728297283072831728327283372834728357283672837728387283972840728417284272843728447284572846728477284872849728507285172852728537285472855728567285772858728597286072861728627286372864728657286672867728687286972870728717287272873728747287572876728777287872879728807288172882728837288472885728867288772888728897289072891728927289372894728957289672897728987289972900729017290272903729047290572906729077290872909729107291172912729137291472915729167291772918729197292072921729227292372924729257292672927729287292972930729317293272933729347293572936729377293872939729407294172942729437294472945729467294772948729497295072951729527295372954729557295672957729587295972960729617296272963729647296572966729677296872969729707297172972729737297472975729767297772978729797298072981729827298372984729857298672987729887298972990729917299272993729947299572996729977299872999730007300173002730037300473005730067300773008730097301073011730127301373014730157301673017730187301973020730217302273023730247302573026730277302873029730307303173032730337303473035730367303773038730397304073041730427304373044730457304673047730487304973050730517305273053730547305573056730577305873059730607306173062730637306473065730667306773068730697307073071730727307373074730757307673077730787307973080730817308273083730847308573086730877308873089730907309173092730937309473095730967309773098730997310073101731027310373104731057310673107731087310973110731117311273113731147311573116731177311873119731207312173122731237312473125731267312773128731297313073131731327313373134731357313673137731387313973140731417314273143731447314573146731477314873149731507315173152731537315473155731567315773158731597316073161731627316373164731657316673167731687316973170731717317273173731747317573176731777317873179731807318173182731837318473185731867318773188731897319073191731927319373194731957319673197731987319973200732017320273203732047320573206732077320873209732107321173212732137321473215732167321773218732197322073221732227322373224732257322673227732287322973230732317323273233732347323573236732377323873239732407324173242732437324473245732467324773248732497325073251732527325373254732557325673257732587325973260732617326273263732647326573266732677326873269732707327173272732737327473275732767327773278732797328073281732827328373284732857328673287732887328973290732917329273293732947329573296732977329873299733007330173302733037330473305733067330773308733097331073311733127331373314733157331673317733187331973320733217332273323733247332573326733277332873329733307333173332733337333473335733367333773338733397334073341733427334373344733457334673347733487334973350733517335273353733547335573356733577335873359733607336173362733637336473365733667336773368733697337073371733727337373374733757337673377733787337973380733817338273383733847338573386733877338873389733907339173392733937339473395733967339773398733997340073401734027340373404734057340673407734087340973410734117341273413734147341573416734177341873419734207342173422734237342473425734267342773428734297343073431734327343373434734357343673437734387343973440734417344273443734447344573446734477344873449734507345173452734537345473455734567345773458734597346073461734627346373464734657346673467734687346973470734717347273473734747347573476734777347873479734807348173482734837348473485734867348773488734897349073491734927349373494734957349673497734987349973500735017350273503735047350573506735077350873509735107351173512735137351473515735167351773518735197352073521735227352373524735257352673527735287352973530735317353273533735347353573536735377353873539735407354173542735437354473545735467354773548735497355073551735527355373554735557355673557735587355973560735617356273563735647356573566735677356873569735707357173572735737357473575735767357773578735797358073581735827358373584735857358673587735887358973590735917359273593735947359573596735977359873599736007360173602736037360473605736067360773608736097361073611736127361373614736157361673617736187361973620736217362273623736247362573626736277362873629736307363173632736337363473635736367363773638736397364073641736427364373644736457364673647736487364973650736517365273653736547365573656736577365873659736607366173662736637366473665736667366773668736697367073671736727367373674736757367673677736787367973680736817368273683736847368573686736877368873689736907369173692736937369473695736967369773698736997370073701737027370373704737057370673707737087370973710737117371273713737147371573716737177371873719737207372173722737237372473725737267372773728737297373073731737327373373734737357373673737737387373973740737417374273743737447374573746737477374873749737507375173752737537375473755737567375773758737597376073761737627376373764737657376673767737687376973770737717377273773737747377573776737777377873779737807378173782737837378473785737867378773788737897379073791737927379373794737957379673797737987379973800738017380273803738047380573806738077380873809738107381173812738137381473815738167381773818738197382073821738227382373824738257382673827738287382973830738317383273833738347383573836738377383873839738407384173842738437384473845738467384773848738497385073851738527385373854738557385673857738587385973860738617386273863738647386573866738677386873869738707387173872738737387473875738767387773878738797388073881738827388373884738857388673887738887388973890738917389273893738947389573896738977389873899739007390173902739037390473905739067390773908739097391073911739127391373914739157391673917739187391973920739217392273923739247392573926739277392873929739307393173932739337393473935739367393773938739397394073941739427394373944739457394673947739487394973950739517395273953739547395573956739577395873959739607396173962739637396473965739667396773968739697397073971739727397373974739757397673977739787397973980739817398273983739847398573986739877398873989739907399173992739937399473995739967399773998739997400074001740027400374004740057400674007740087400974010740117401274013740147401574016740177401874019740207402174022740237402474025740267402774028740297403074031740327403374034740357403674037740387403974040740417404274043740447404574046740477404874049740507405174052740537405474055740567405774058740597406074061740627406374064740657406674067740687406974070740717407274073740747407574076740777407874079740807408174082740837408474085740867408774088740897409074091740927409374094740957409674097740987409974100741017410274103741047410574106741077410874109741107411174112741137411474115741167411774118741197412074121741227412374124741257412674127741287412974130741317413274133741347413574136741377413874139741407414174142741437414474145741467414774148741497415074151741527415374154741557415674157741587415974160741617416274163741647416574166741677416874169741707417174172741737417474175741767417774178741797418074181741827418374184741857418674187741887418974190741917419274193741947419574196741977419874199742007420174202742037420474205742067420774208742097421074211742127421374214742157421674217742187421974220742217422274223742247422574226742277422874229742307423174232742337423474235742367423774238742397424074241742427424374244742457424674247742487424974250742517425274253742547425574256742577425874259742607426174262742637426474265742667426774268742697427074271742727427374274742757427674277742787427974280742817428274283742847428574286742877428874289742907429174292742937429474295742967429774298742997430074301743027430374304743057430674307743087430974310743117431274313743147431574316743177431874319743207432174322743237432474325743267432774328743297433074331743327433374334743357433674337743387433974340743417434274343743447434574346743477434874349743507435174352743537435474355743567435774358743597436074361743627436374364743657436674367743687436974370743717437274373743747437574376743777437874379743807438174382743837438474385743867438774388743897439074391743927439374394743957439674397743987439974400744017440274403744047440574406744077440874409744107441174412744137441474415744167441774418744197442074421744227442374424744257442674427744287442974430744317443274433744347443574436744377443874439744407444174442744437444474445744467444774448744497445074451744527445374454744557445674457744587445974460744617446274463744647446574466744677446874469744707447174472744737447474475744767447774478744797448074481744827448374484744857448674487744887448974490744917449274493744947449574496744977449874499745007450174502745037450474505745067450774508745097451074511745127451374514745157451674517745187451974520745217452274523745247452574526745277452874529745307453174532745337453474535745367453774538745397454074541745427454374544745457454674547745487454974550745517455274553745547455574556745577455874559745607456174562745637456474565745667456774568745697457074571745727457374574745757457674577745787457974580745817458274583745847458574586745877458874589745907459174592745937459474595745967459774598745997460074601746027460374604746057460674607746087460974610746117461274613746147461574616746177461874619746207462174622746237462474625746267462774628746297463074631746327463374634746357463674637746387463974640746417464274643746447464574646746477464874649746507465174652746537465474655746567465774658746597466074661746627466374664746657466674667746687466974670746717467274673746747467574676746777467874679746807468174682746837468474685746867468774688746897469074691746927469374694746957469674697746987469974700747017470274703747047470574706747077470874709747107471174712747137471474715747167471774718747197472074721747227472374724747257472674727747287472974730747317473274733747347473574736747377473874739747407474174742747437474474745747467474774748747497475074751747527475374754747557475674757747587475974760747617476274763747647476574766747677476874769747707477174772747737477474775747767477774778747797478074781747827478374784747857478674787747887478974790747917479274793747947479574796747977479874799748007480174802748037480474805748067480774808748097481074811748127481374814748157481674817748187481974820748217482274823748247482574826748277482874829748307483174832748337483474835748367483774838748397484074841748427484374844748457484674847748487484974850748517485274853748547485574856748577485874859748607486174862748637486474865748667486774868748697487074871748727487374874748757487674877748787487974880748817488274883748847488574886748877488874889748907489174892748937489474895748967489774898748997490074901749027490374904749057490674907749087490974910749117491274913749147491574916749177491874919749207492174922749237492474925749267492774928749297493074931749327493374934749357493674937749387493974940749417494274943749447494574946749477494874949749507495174952749537495474955749567495774958749597496074961749627496374964749657496674967749687496974970749717497274973749747497574976749777497874979749807498174982749837498474985749867498774988749897499074991749927499374994749957499674997749987499975000750017500275003750047500575006750077500875009750107501175012750137501475015750167501775018750197502075021750227502375024750257502675027750287502975030750317503275033750347503575036750377503875039750407504175042750437504475045750467504775048750497505075051750527505375054750557505675057750587505975060750617506275063750647506575066750677506875069750707507175072750737507475075750767507775078750797508075081750827508375084750857508675087750887508975090750917509275093750947509575096750977509875099751007510175102751037510475105751067510775108751097511075111751127511375114751157511675117751187511975120751217512275123751247512575126751277512875129751307513175132751337513475135751367513775138751397514075141751427514375144751457514675147751487514975150751517515275153751547515575156751577515875159751607516175162751637516475165751667516775168751697517075171751727517375174751757517675177751787517975180751817518275183751847518575186751877518875189751907519175192751937519475195751967519775198751997520075201752027520375204752057520675207752087520975210752117521275213752147521575216752177521875219752207522175222752237522475225752267522775228752297523075231752327523375234752357523675237752387523975240752417524275243752447524575246752477524875249752507525175252752537525475255752567525775258752597526075261752627526375264752657526675267752687526975270752717527275273752747527575276752777527875279752807528175282752837528475285752867528775288752897529075291752927529375294752957529675297752987529975300753017530275303753047530575306753077530875309753107531175312753137531475315753167531775318753197532075321753227532375324753257532675327753287532975330753317533275333753347533575336753377533875339753407534175342753437534475345753467534775348753497535075351753527535375354753557535675357753587535975360753617536275363753647536575366753677536875369753707537175372753737537475375753767537775378753797538075381753827538375384753857538675387753887538975390753917539275393753947539575396753977539875399754007540175402754037540475405754067540775408754097541075411754127541375414754157541675417754187541975420754217542275423754247542575426754277542875429754307543175432754337543475435754367543775438754397544075441754427544375444754457544675447754487544975450754517545275453754547545575456754577545875459754607546175462754637546475465754667546775468754697547075471754727547375474754757547675477754787547975480754817548275483754847548575486754877548875489754907549175492754937549475495754967549775498754997550075501755027550375504755057550675507755087550975510755117551275513755147551575516755177551875519755207552175522755237552475525755267552775528755297553075531755327553375534755357553675537755387553975540755417554275543755447554575546755477554875549755507555175552755537555475555755567555775558755597556075561755627556375564755657556675567755687556975570755717557275573755747557575576755777557875579755807558175582755837558475585755867558775588755897559075591755927559375594755957559675597755987559975600756017560275603756047560575606756077560875609756107561175612756137561475615756167561775618756197562075621756227562375624756257562675627756287562975630756317563275633756347563575636756377563875639756407564175642756437564475645756467564775648756497565075651756527565375654756557565675657756587565975660756617566275663756647566575666756677566875669756707567175672756737567475675756767567775678756797568075681756827568375684756857568675687756887568975690756917569275693756947569575696756977569875699757007570175702757037570475705757067570775708757097571075711757127571375714757157571675717757187571975720757217572275723757247572575726757277572875729757307573175732757337573475735757367573775738757397574075741757427574375744757457574675747757487574975750757517575275753757547575575756757577575875759757607576175762757637576475765757667576775768757697577075771757727577375774757757577675777757787577975780757817578275783757847578575786757877578875789757907579175792757937579475795757967579775798757997580075801758027580375804758057580675807758087580975810758117581275813758147581575816758177581875819758207582175822758237582475825758267582775828758297583075831758327583375834758357583675837758387583975840758417584275843758447584575846758477584875849758507585175852758537585475855758567585775858758597586075861758627586375864758657586675867758687586975870758717587275873758747587575876758777587875879758807588175882758837588475885758867588775888758897589075891758927589375894758957589675897758987589975900759017590275903759047590575906759077590875909759107591175912759137591475915759167591775918759197592075921759227592375924759257592675927759287592975930759317593275933759347593575936759377593875939759407594175942759437594475945759467594775948759497595075951759527595375954759557595675957759587595975960759617596275963759647596575966759677596875969759707597175972759737597475975759767597775978759797598075981759827598375984759857598675987759887598975990759917599275993759947599575996759977599875999760007600176002760037600476005760067600776008760097601076011760127601376014760157601676017760187601976020760217602276023760247602576026760277602876029760307603176032760337603476035760367603776038760397604076041760427604376044760457604676047760487604976050760517605276053760547605576056760577605876059760607606176062760637606476065760667606776068760697607076071760727607376074760757607676077760787607976080760817608276083760847608576086760877608876089760907609176092760937609476095760967609776098760997610076101761027610376104761057610676107761087610976110761117611276113761147611576116761177611876119761207612176122761237612476125761267612776128761297613076131761327613376134761357613676137761387613976140761417614276143761447614576146761477614876149761507615176152761537615476155761567615776158761597616076161761627616376164761657616676167761687616976170761717617276173761747617576176761777617876179761807618176182761837618476185761867618776188761897619076191761927619376194761957619676197761987619976200762017620276203762047620576206762077620876209762107621176212762137621476215762167621776218762197622076221762227622376224762257622676227762287622976230762317623276233762347623576236762377623876239762407624176242762437624476245762467624776248762497625076251762527625376254762557625676257762587625976260762617626276263762647626576266762677626876269762707627176272762737627476275762767627776278762797628076281762827628376284762857628676287762887628976290762917629276293762947629576296762977629876299763007630176302763037630476305763067630776308763097631076311763127631376314763157631676317763187631976320763217632276323763247632576326763277632876329763307633176332763337633476335763367633776338763397634076341763427634376344763457634676347763487634976350763517635276353763547635576356763577635876359763607636176362763637636476365763667636776368763697637076371763727637376374763757637676377763787637976380763817638276383763847638576386763877638876389763907639176392763937639476395763967639776398763997640076401764027640376404764057640676407764087640976410764117641276413764147641576416764177641876419764207642176422764237642476425764267642776428764297643076431764327643376434764357643676437764387643976440764417644276443764447644576446764477644876449764507645176452764537645476455764567645776458764597646076461764627646376464764657646676467764687646976470764717647276473764747647576476764777647876479764807648176482764837648476485764867648776488764897649076491764927649376494764957649676497764987649976500765017650276503765047650576506765077650876509765107651176512765137651476515765167651776518765197652076521765227652376524765257652676527765287652976530765317653276533765347653576536765377653876539765407654176542765437654476545765467654776548765497655076551765527655376554765557655676557765587655976560765617656276563765647656576566765677656876569765707657176572765737657476575765767657776578765797658076581765827658376584765857658676587765887658976590765917659276593765947659576596765977659876599766007660176602766037660476605766067660776608766097661076611766127661376614766157661676617766187661976620766217662276623766247662576626766277662876629766307663176632766337663476635766367663776638766397664076641766427664376644766457664676647766487664976650766517665276653766547665576656766577665876659766607666176662766637666476665766667666776668766697667076671766727667376674766757667676677766787667976680766817668276683766847668576686766877668876689766907669176692766937669476695766967669776698766997670076701767027670376704767057670676707767087670976710767117671276713767147671576716767177671876719767207672176722767237672476725767267672776728767297673076731767327673376734767357673676737767387673976740767417674276743767447674576746767477674876749767507675176752767537675476755767567675776758767597676076761767627676376764767657676676767767687676976770767717677276773767747677576776767777677876779767807678176782767837678476785767867678776788767897679076791767927679376794767957679676797767987679976800768017680276803768047680576806768077680876809768107681176812768137681476815768167681776818768197682076821768227682376824768257682676827768287682976830768317683276833768347683576836768377683876839768407684176842768437684476845768467684776848768497685076851768527685376854768557685676857768587685976860768617686276863768647686576866768677686876869768707687176872768737687476875768767687776878768797688076881768827688376884768857688676887768887688976890768917689276893768947689576896768977689876899769007690176902769037690476905769067690776908769097691076911769127691376914769157691676917769187691976920769217692276923769247692576926769277692876929769307693176932769337693476935769367693776938769397694076941769427694376944769457694676947769487694976950769517695276953769547695576956769577695876959769607696176962769637696476965769667696776968769697697076971769727697376974769757697676977769787697976980769817698276983769847698576986769877698876989769907699176992769937699476995769967699776998769997700077001770027700377004770057700677007770087700977010770117701277013770147701577016770177701877019770207702177022770237702477025770267702777028770297703077031770327703377034770357703677037770387703977040770417704277043770447704577046770477704877049770507705177052770537705477055770567705777058770597706077061770627706377064770657706677067770687706977070770717707277073770747707577076770777707877079770807708177082770837708477085770867708777088770897709077091770927709377094770957709677097770987709977100771017710277103771047710577106771077710877109771107711177112771137711477115771167711777118771197712077121771227712377124771257712677127771287712977130771317713277133771347713577136771377713877139771407714177142771437714477145771467714777148771497715077151771527715377154771557715677157771587715977160771617716277163771647716577166771677716877169771707717177172771737717477175771767717777178771797718077181771827718377184771857718677187771887718977190771917719277193771947719577196771977719877199772007720177202772037720477205772067720777208772097721077211772127721377214772157721677217772187721977220772217722277223772247722577226772277722877229772307723177232772337723477235772367723777238772397724077241772427724377244772457724677247772487724977250772517725277253772547725577256772577725877259772607726177262772637726477265772667726777268772697727077271772727727377274772757727677277772787727977280772817728277283772847728577286772877728877289772907729177292772937729477295772967729777298772997730077301773027730377304773057730677307773087730977310773117731277313773147731577316773177731877319773207732177322773237732477325773267732777328773297733077331773327733377334773357733677337773387733977340773417734277343773447734577346773477734877349773507735177352773537735477355773567735777358773597736077361773627736377364773657736677367773687736977370773717737277373773747737577376773777737877379773807738177382773837738477385773867738777388773897739077391773927739377394773957739677397773987739977400774017740277403774047740577406774077740877409774107741177412774137741477415774167741777418774197742077421774227742377424774257742677427774287742977430774317743277433774347743577436774377743877439774407744177442774437744477445774467744777448774497745077451774527745377454774557745677457774587745977460774617746277463774647746577466774677746877469774707747177472774737747477475774767747777478774797748077481774827748377484774857748677487774887748977490774917749277493774947749577496774977749877499775007750177502775037750477505775067750777508775097751077511775127751377514775157751677517775187751977520775217752277523775247752577526775277752877529775307753177532775337753477535775367753777538775397754077541775427754377544775457754677547775487754977550775517755277553775547755577556775577755877559775607756177562775637756477565775667756777568775697757077571775727757377574775757757677577775787757977580775817758277583775847758577586775877758877589775907759177592775937759477595775967759777598775997760077601776027760377604776057760677607776087760977610776117761277613776147761577616776177761877619776207762177622776237762477625776267762777628776297763077631776327763377634776357763677637776387763977640776417764277643776447764577646776477764877649776507765177652776537765477655776567765777658776597766077661776627766377664776657766677667776687766977670776717767277673776747767577676776777767877679776807768177682776837768477685776867768777688776897769077691776927769377694776957769677697776987769977700777017770277703777047770577706777077770877709777107771177712777137771477715777167771777718777197772077721777227772377724777257772677727777287772977730777317773277733777347773577736777377773877739777407774177742777437774477745777467774777748777497775077751777527775377754777557775677757777587775977760777617776277763777647776577766777677776877769777707777177772777737777477775777767777777778777797778077781777827778377784777857778677787777887778977790777917779277793777947779577796777977779877799778007780177802778037780477805778067780777808778097781077811778127781377814778157781677817778187781977820778217782277823778247782577826778277782877829778307783177832778337783477835778367783777838778397784077841778427784377844778457784677847778487784977850778517785277853778547785577856778577785877859778607786177862778637786477865778667786777868778697787077871778727787377874778757787677877778787787977880778817788277883778847788577886778877788877889778907789177892778937789477895778967789777898778997790077901779027790377904779057790677907779087790977910779117791277913779147791577916779177791877919779207792177922779237792477925779267792777928779297793077931779327793377934779357793677937779387793977940779417794277943779447794577946779477794877949779507795177952779537795477955779567795777958779597796077961779627796377964779657796677967779687796977970779717797277973779747797577976779777797877979779807798177982779837798477985779867798777988779897799077991779927799377994779957799677997779987799978000780017800278003780047800578006780077800878009780107801178012780137801478015780167801778018780197802078021780227802378024780257802678027780287802978030780317803278033780347803578036780377803878039780407804178042780437804478045780467804778048780497805078051780527805378054780557805678057780587805978060780617806278063780647806578066780677806878069780707807178072780737807478075780767807778078780797808078081780827808378084780857808678087780887808978090780917809278093780947809578096780977809878099781007810178102781037810478105781067810778108781097811078111781127811378114781157811678117781187811978120781217812278123781247812578126781277812878129781307813178132781337813478135781367813778138781397814078141781427814378144781457814678147781487814978150781517815278153781547815578156781577815878159781607816178162781637816478165781667816778168781697817078171781727817378174781757817678177781787817978180781817818278183781847818578186781877818878189781907819178192781937819478195781967819778198781997820078201782027820378204782057820678207782087820978210782117821278213782147821578216782177821878219782207822178222782237822478225782267822778228782297823078231782327823378234782357823678237782387823978240782417824278243782447824578246782477824878249782507825178252782537825478255782567825778258782597826078261782627826378264782657826678267782687826978270782717827278273782747827578276782777827878279782807828178282782837828478285782867828778288782897829078291782927829378294782957829678297782987829978300783017830278303783047830578306783077830878309783107831178312783137831478315783167831778318783197832078321783227832378324783257832678327783287832978330783317833278333783347833578336783377833878339783407834178342783437834478345783467834778348783497835078351783527835378354783557835678357783587835978360783617836278363783647836578366783677836878369783707837178372783737837478375783767837778378783797838078381783827838378384783857838678387783887838978390783917839278393783947839578396783977839878399784007840178402784037840478405784067840778408784097841078411784127841378414784157841678417784187841978420784217842278423784247842578426784277842878429784307843178432784337843478435784367843778438784397844078441784427844378444784457844678447784487844978450784517845278453784547845578456784577845878459784607846178462784637846478465784667846778468784697847078471784727847378474784757847678477784787847978480784817848278483784847848578486784877848878489784907849178492784937849478495784967849778498784997850078501785027850378504785057850678507785087850978510785117851278513785147851578516785177851878519785207852178522785237852478525785267852778528785297853078531785327853378534785357853678537785387853978540785417854278543785447854578546785477854878549785507855178552785537855478555785567855778558785597856078561785627856378564785657856678567785687856978570785717857278573785747857578576785777857878579785807858178582785837858478585785867858778588785897859078591785927859378594785957859678597785987859978600786017860278603786047860578606786077860878609786107861178612786137861478615786167861778618786197862078621786227862378624786257862678627786287862978630786317863278633786347863578636786377863878639786407864178642786437864478645786467864778648786497865078651786527865378654786557865678657786587865978660786617866278663786647866578666786677866878669786707867178672786737867478675786767867778678786797868078681786827868378684786857868678687786887868978690786917869278693786947869578696786977869878699787007870178702787037870478705787067870778708787097871078711787127871378714787157871678717787187871978720787217872278723787247872578726787277872878729787307873178732787337873478735787367873778738787397874078741787427874378744787457874678747787487874978750787517875278753787547875578756787577875878759787607876178762787637876478765787667876778768787697877078771787727877378774787757877678777787787877978780787817878278783787847878578786787877878878789787907879178792787937879478795787967879778798787997880078801788027880378804788057880678807788087880978810788117881278813788147881578816788177881878819788207882178822788237882478825788267882778828788297883078831788327883378834788357883678837788387883978840788417884278843788447884578846788477884878849788507885178852788537885478855788567885778858788597886078861788627886378864788657886678867788687886978870788717887278873788747887578876788777887878879788807888178882788837888478885788867888778888788897889078891788927889378894788957889678897788987889978900789017890278903789047890578906789077890878909789107891178912789137891478915789167891778918789197892078921789227892378924789257892678927789287892978930789317893278933789347893578936789377893878939789407894178942789437894478945789467894778948789497895078951789527895378954789557895678957789587895978960789617896278963789647896578966789677896878969789707897178972789737897478975789767897778978789797898078981789827898378984789857898678987789887898978990789917899278993789947899578996789977899878999790007900179002790037900479005790067900779008790097901079011790127901379014790157901679017790187901979020790217902279023790247902579026790277902879029790307903179032790337903479035790367903779038790397904079041790427904379044790457904679047790487904979050790517905279053790547905579056790577905879059790607906179062790637906479065790667906779068790697907079071790727907379074790757907679077790787907979080790817908279083790847908579086790877908879089790907909179092790937909479095790967909779098790997910079101791027910379104791057910679107791087910979110791117911279113791147911579116791177911879119791207912179122791237912479125791267912779128791297913079131791327913379134791357913679137791387913979140791417914279143791447914579146791477914879149791507915179152791537915479155791567915779158791597916079161791627916379164791657916679167791687916979170791717917279173791747917579176791777917879179791807918179182791837918479185791867918779188791897919079191791927919379194791957919679197791987919979200792017920279203792047920579206792077920879209792107921179212792137921479215792167921779218792197922079221792227922379224792257922679227792287922979230792317923279233792347923579236792377923879239792407924179242792437924479245792467924779248792497925079251792527925379254792557925679257792587925979260792617926279263792647926579266792677926879269792707927179272792737927479275792767927779278792797928079281792827928379284792857928679287792887928979290792917929279293792947929579296792977929879299793007930179302793037930479305793067930779308793097931079311793127931379314793157931679317793187931979320793217932279323793247932579326793277932879329793307933179332793337933479335793367933779338793397934079341793427934379344793457934679347793487934979350793517935279353793547935579356793577935879359793607936179362793637936479365793667936779368793697937079371793727937379374793757937679377793787937979380793817938279383793847938579386793877938879389793907939179392793937939479395793967939779398793997940079401794027940379404794057940679407794087940979410794117941279413794147941579416794177941879419794207942179422794237942479425794267942779428794297943079431794327943379434794357943679437794387943979440794417944279443794447944579446794477944879449794507945179452794537945479455794567945779458794597946079461794627946379464794657946679467794687946979470794717947279473794747947579476794777947879479794807948179482794837948479485794867948779488794897949079491794927949379494794957949679497794987949979500795017950279503795047950579506795077950879509795107951179512795137951479515795167951779518795197952079521795227952379524795257952679527795287952979530795317953279533795347953579536795377953879539795407954179542795437954479545795467954779548795497955079551795527955379554795557955679557795587955979560795617956279563795647956579566795677956879569795707957179572795737957479575795767957779578795797958079581795827958379584795857958679587795887958979590795917959279593795947959579596795977959879599796007960179602796037960479605796067960779608796097961079611796127961379614796157961679617796187961979620796217962279623796247962579626796277962879629796307963179632796337963479635796367963779638796397964079641796427964379644796457964679647796487964979650796517965279653796547965579656796577965879659796607966179662796637966479665796667966779668796697967079671796727967379674796757967679677796787967979680796817968279683796847968579686796877968879689796907969179692796937969479695796967969779698796997970079701797027970379704797057970679707797087970979710797117971279713797147971579716797177971879719797207972179722797237972479725797267972779728797297973079731797327973379734797357973679737797387973979740797417974279743797447974579746797477974879749797507975179752797537975479755797567975779758797597976079761797627976379764797657976679767797687976979770797717977279773797747977579776797777977879779797807978179782797837978479785797867978779788797897979079791797927979379794797957979679797797987979979800798017980279803798047980579806798077980879809798107981179812798137981479815798167981779818798197982079821798227982379824798257982679827798287982979830798317983279833798347983579836798377983879839798407984179842798437984479845798467984779848798497985079851798527985379854798557985679857798587985979860798617986279863798647986579866798677986879869798707987179872798737987479875798767987779878798797988079881798827988379884798857988679887798887988979890798917989279893798947989579896798977989879899799007990179902799037990479905799067990779908799097991079911799127991379914799157991679917799187991979920799217992279923799247992579926799277992879929799307993179932799337993479935799367993779938799397994079941799427994379944799457994679947799487994979950799517995279953799547995579956799577995879959799607996179962799637996479965799667996779968799697997079971799727997379974799757997679977799787997979980799817998279983799847998579986799877998879989799907999179992799937999479995799967999779998799998000080001800028000380004800058000680007800088000980010800118001280013800148001580016800178001880019800208002180022800238002480025800268002780028800298003080031800328003380034800358003680037800388003980040800418004280043800448004580046800478004880049800508005180052800538005480055800568005780058800598006080061800628006380064800658006680067800688006980070800718007280073800748007580076800778007880079800808008180082800838008480085800868008780088800898009080091800928009380094800958009680097800988009980100801018010280103801048010580106801078010880109801108011180112801138011480115801168011780118801198012080121801228012380124801258012680127801288012980130801318013280133801348013580136801378013880139801408014180142801438014480145801468014780148801498015080151801528015380154801558015680157801588015980160801618016280163801648016580166801678016880169801708017180172801738017480175801768017780178801798018080181801828018380184801858018680187801888018980190801918019280193801948019580196801978019880199802008020180202802038020480205802068020780208802098021080211802128021380214802158021680217802188021980220802218022280223802248022580226802278022880229802308023180232802338023480235802368023780238802398024080241802428024380244802458024680247802488024980250802518025280253802548025580256802578025880259802608026180262802638026480265802668026780268802698027080271802728027380274802758027680277802788027980280802818028280283802848028580286802878028880289802908029180292802938029480295802968029780298802998030080301803028030380304803058030680307803088030980310803118031280313803148031580316803178031880319803208032180322803238032480325803268032780328803298033080331803328033380334803358033680337803388033980340803418034280343803448034580346803478034880349803508035180352803538035480355803568035780358803598036080361803628036380364803658036680367803688036980370803718037280373803748037580376803778037880379803808038180382803838038480385803868038780388803898039080391803928039380394803958039680397803988039980400804018040280403804048040580406804078040880409804108041180412804138041480415804168041780418804198042080421804228042380424804258042680427804288042980430804318043280433804348043580436804378043880439804408044180442804438044480445804468044780448804498045080451804528045380454804558045680457804588045980460804618046280463804648046580466804678046880469804708047180472804738047480475804768047780478804798048080481804828048380484804858048680487804888048980490804918049280493804948049580496804978049880499805008050180502805038050480505805068050780508805098051080511805128051380514805158051680517805188051980520805218052280523805248052580526805278052880529805308053180532805338053480535805368053780538805398054080541805428054380544805458054680547805488054980550805518055280553805548055580556805578055880559805608056180562805638056480565805668056780568805698057080571805728057380574805758057680577805788057980580805818058280583805848058580586805878058880589805908059180592805938059480595805968059780598805998060080601806028060380604806058060680607806088060980610806118061280613806148061580616806178061880619806208062180622806238062480625806268062780628806298063080631806328063380634806358063680637806388063980640806418064280643806448064580646806478064880649806508065180652806538065480655806568065780658806598066080661806628066380664806658066680667806688066980670806718067280673806748067580676806778067880679806808068180682806838068480685806868068780688806898069080691806928069380694806958069680697806988069980700807018070280703807048070580706807078070880709807108071180712807138071480715807168071780718807198072080721807228072380724807258072680727807288072980730807318073280733807348073580736807378073880739807408074180742807438074480745807468074780748807498075080751807528075380754807558075680757807588075980760807618076280763807648076580766807678076880769807708077180772807738077480775807768077780778807798078080781807828078380784807858078680787807888078980790807918079280793807948079580796807978079880799808008080180802808038080480805808068080780808808098081080811808128081380814808158081680817808188081980820808218082280823808248082580826808278082880829808308083180832808338083480835808368083780838808398084080841808428084380844808458084680847808488084980850808518085280853808548085580856808578085880859808608086180862808638086480865808668086780868808698087080871808728087380874808758087680877808788087980880808818088280883808848088580886808878088880889808908089180892808938089480895808968089780898808998090080901809028090380904809058090680907809088090980910809118091280913809148091580916809178091880919809208092180922809238092480925809268092780928809298093080931809328093380934809358093680937809388093980940809418094280943809448094580946809478094880949809508095180952809538095480955809568095780958809598096080961809628096380964809658096680967809688096980970809718097280973809748097580976809778097880979809808098180982809838098480985809868098780988809898099080991809928099380994809958099680997809988099981000810018100281003810048100581006810078100881009810108101181012810138101481015810168101781018810198102081021810228102381024810258102681027810288102981030810318103281033810348103581036810378103881039810408104181042810438104481045810468104781048810498105081051810528105381054810558105681057810588105981060810618106281063810648106581066810678106881069810708107181072810738107481075810768107781078810798108081081810828108381084810858108681087810888108981090810918109281093810948109581096810978109881099811008110181102811038110481105811068110781108811098111081111811128111381114811158111681117811188111981120811218112281123811248112581126811278112881129811308113181132811338113481135811368113781138811398114081141811428114381144811458114681147811488114981150811518115281153811548115581156811578115881159811608116181162811638116481165811668116781168811698117081171811728117381174811758117681177811788117981180811818118281183811848118581186811878118881189811908119181192811938119481195811968119781198811998120081201812028120381204812058120681207812088120981210812118121281213812148121581216812178121881219812208122181222812238122481225812268122781228812298123081231812328123381234812358123681237812388123981240812418124281243812448124581246812478124881249812508125181252812538125481255812568125781258812598126081261812628126381264812658126681267812688126981270812718127281273812748127581276812778127881279812808128181282812838128481285812868128781288812898129081291812928129381294812958129681297812988129981300813018130281303813048130581306813078130881309813108131181312813138131481315813168131781318813198132081321813228132381324813258132681327813288132981330813318133281333813348133581336813378133881339813408134181342813438134481345813468134781348813498135081351813528135381354813558135681357813588135981360813618136281363813648136581366813678136881369813708137181372813738137481375813768137781378813798138081381813828138381384813858138681387813888138981390813918139281393813948139581396813978139881399814008140181402814038140481405814068140781408814098141081411814128141381414814158141681417814188141981420814218142281423814248142581426814278142881429814308143181432814338143481435814368143781438814398144081441814428144381444814458144681447814488144981450814518145281453814548145581456814578145881459814608146181462814638146481465814668146781468814698147081471814728147381474814758147681477814788147981480814818148281483814848148581486814878148881489814908149181492814938149481495814968149781498814998150081501815028150381504815058150681507815088150981510815118151281513815148151581516815178151881519815208152181522815238152481525815268152781528815298153081531815328153381534815358153681537815388153981540815418154281543815448154581546815478154881549815508155181552815538155481555815568155781558815598156081561815628156381564815658156681567815688156981570815718157281573815748157581576815778157881579815808158181582815838158481585815868158781588815898159081591815928159381594815958159681597815988159981600816018160281603816048160581606816078160881609816108161181612816138161481615816168161781618816198162081621816228162381624816258162681627816288162981630816318163281633816348163581636816378163881639816408164181642816438164481645816468164781648816498165081651816528165381654816558165681657816588165981660816618166281663816648166581666816678166881669816708167181672816738167481675816768167781678816798168081681816828168381684816858168681687816888168981690816918169281693816948169581696816978169881699817008170181702817038170481705817068170781708817098171081711817128171381714817158171681717817188171981720817218172281723817248172581726817278172881729817308173181732817338173481735817368173781738817398174081741817428174381744817458174681747817488174981750817518175281753817548175581756817578175881759817608176181762817638176481765817668176781768817698177081771817728177381774817758177681777817788177981780817818178281783817848178581786817878178881789817908179181792817938179481795817968179781798817998180081801818028180381804818058180681807818088180981810818118181281813818148181581816818178181881819818208182181822818238182481825818268182781828818298183081831818328183381834818358183681837818388183981840818418184281843818448184581846818478184881849818508185181852818538185481855818568185781858818598186081861818628186381864818658186681867818688186981870818718187281873818748187581876818778187881879818808188181882818838188481885818868188781888818898189081891818928189381894818958189681897818988189981900819018190281903819048190581906819078190881909819108191181912819138191481915819168191781918819198192081921819228192381924819258192681927819288192981930819318193281933819348193581936819378193881939819408194181942819438194481945819468194781948819498195081951819528195381954819558195681957819588195981960819618196281963819648196581966819678196881969819708197181972819738197481975819768197781978819798198081981819828198381984819858198681987819888198981990819918199281993819948199581996819978199881999820008200182002820038200482005820068200782008820098201082011820128201382014820158201682017820188201982020820218202282023820248202582026820278202882029820308203182032820338203482035820368203782038820398204082041820428204382044820458204682047820488204982050820518205282053820548205582056820578205882059820608206182062820638206482065820668206782068820698207082071820728207382074820758207682077820788207982080820818208282083820848208582086820878208882089820908209182092820938209482095820968209782098820998210082101821028210382104821058210682107821088210982110821118211282113821148211582116821178211882119821208212182122821238212482125821268212782128821298213082131821328213382134821358213682137821388213982140821418214282143821448214582146821478214882149821508215182152821538215482155821568215782158821598216082161821628216382164821658216682167821688216982170821718217282173821748217582176821778217882179821808218182182821838218482185821868218782188821898219082191821928219382194821958219682197821988219982200822018220282203822048220582206822078220882209822108221182212822138221482215822168221782218822198222082221822228222382224822258222682227822288222982230822318223282233822348223582236822378223882239822408224182242822438224482245822468224782248822498225082251822528225382254822558225682257822588225982260822618226282263822648226582266822678226882269822708227182272822738227482275822768227782278822798228082281822828228382284822858228682287822888228982290822918229282293822948229582296822978229882299823008230182302823038230482305823068230782308823098231082311823128231382314823158231682317823188231982320823218232282323823248232582326823278232882329823308233182332823338233482335823368233782338823398234082341823428234382344823458234682347823488234982350823518235282353823548235582356823578235882359823608236182362823638236482365823668236782368823698237082371823728237382374823758237682377823788237982380823818238282383823848238582386823878238882389823908239182392823938239482395823968239782398823998240082401824028240382404824058240682407824088240982410824118241282413824148241582416824178241882419824208242182422824238242482425824268242782428824298243082431824328243382434824358243682437824388243982440824418244282443824448244582446824478244882449824508245182452824538245482455824568245782458824598246082461824628246382464824658246682467824688246982470824718247282473824748247582476824778247882479824808248182482824838248482485824868248782488824898249082491824928249382494824958249682497824988249982500825018250282503825048250582506825078250882509825108251182512825138251482515825168251782518825198252082521825228252382524825258252682527825288252982530825318253282533825348253582536825378253882539825408254182542825438254482545825468254782548825498255082551825528255382554825558255682557825588255982560825618256282563825648256582566825678256882569825708257182572825738257482575825768257782578825798258082581825828258382584825858258682587825888258982590825918259282593825948259582596825978259882599826008260182602826038260482605826068260782608826098261082611826128261382614826158261682617826188261982620826218262282623826248262582626826278262882629826308263182632826338263482635826368263782638826398264082641826428264382644826458264682647826488264982650826518265282653826548265582656826578265882659826608266182662826638266482665826668266782668826698267082671826728267382674826758267682677826788267982680826818268282683826848268582686826878268882689826908269182692826938269482695826968269782698826998270082701827028270382704827058270682707827088270982710827118271282713827148271582716827178271882719827208272182722827238272482725827268272782728827298273082731827328273382734827358273682737827388273982740827418274282743827448274582746827478274882749827508275182752827538275482755827568275782758827598276082761827628276382764827658276682767827688276982770827718277282773827748277582776827778277882779827808278182782827838278482785827868278782788827898279082791827928279382794827958279682797827988279982800828018280282803828048280582806828078280882809828108281182812828138281482815828168281782818828198282082821828228282382824828258282682827828288282982830828318283282833828348283582836828378283882839828408284182842828438284482845828468284782848828498285082851828528285382854828558285682857828588285982860828618286282863828648286582866828678286882869828708287182872828738287482875828768287782878828798288082881828828288382884828858288682887828888288982890828918289282893828948289582896828978289882899829008290182902829038290482905829068290782908829098291082911829128291382914829158291682917829188291982920829218292282923829248292582926829278292882929829308293182932829338293482935829368293782938829398294082941829428294382944829458294682947829488294982950829518295282953829548295582956829578295882959829608296182962829638296482965829668296782968829698297082971829728297382974829758297682977829788297982980829818298282983829848298582986829878298882989829908299182992829938299482995829968299782998829998300083001830028300383004830058300683007830088300983010830118301283013830148301583016830178301883019830208302183022830238302483025830268302783028830298303083031830328303383034830358303683037830388303983040830418304283043830448304583046830478304883049830508305183052830538305483055830568305783058830598306083061830628306383064830658306683067830688306983070830718307283073830748307583076830778307883079830808308183082830838308483085830868308783088830898309083091830928309383094830958309683097830988309983100831018310283103831048310583106831078310883109831108311183112831138311483115831168311783118831198312083121831228312383124831258312683127831288312983130831318313283133831348313583136831378313883139831408314183142831438314483145831468314783148831498315083151831528315383154831558315683157831588315983160831618316283163831648316583166831678316883169831708317183172831738317483175831768317783178831798318083181831828318383184831858318683187831888318983190831918319283193831948319583196831978319883199832008320183202832038320483205832068320783208832098321083211832128321383214832158321683217832188321983220832218322283223832248322583226832278322883229832308323183232832338323483235832368323783238832398324083241832428324383244832458324683247832488324983250832518325283253832548325583256832578325883259832608326183262832638326483265832668326783268832698327083271832728327383274832758327683277832788327983280832818328283283832848328583286832878328883289832908329183292832938329483295832968329783298832998330083301833028330383304833058330683307833088330983310833118331283313833148331583316833178331883319833208332183322833238332483325833268332783328833298333083331833328333383334833358333683337833388333983340833418334283343833448334583346833478334883349833508335183352833538335483355833568335783358833598336083361833628336383364833658336683367833688336983370833718337283373833748337583376833778337883379833808338183382833838338483385833868338783388833898339083391833928339383394833958339683397833988339983400834018340283403834048340583406834078340883409834108341183412834138341483415834168341783418834198342083421834228342383424834258342683427834288342983430834318343283433834348343583436834378343883439834408344183442834438344483445834468344783448834498345083451834528345383454834558345683457834588345983460834618346283463834648346583466834678346883469834708347183472834738347483475834768347783478834798348083481834828348383484834858348683487834888348983490834918349283493834948349583496834978349883499835008350183502835038350483505835068350783508835098351083511835128351383514835158351683517835188351983520835218352283523835248352583526835278352883529835308353183532835338353483535835368353783538835398354083541835428354383544835458354683547835488354983550835518355283553835548355583556835578355883559835608356183562835638356483565835668356783568835698357083571835728357383574835758357683577835788357983580835818358283583835848358583586835878358883589835908359183592835938359483595835968359783598835998360083601836028360383604836058360683607836088360983610836118361283613836148361583616836178361883619836208362183622836238362483625836268362783628836298363083631836328363383634836358363683637836388363983640836418364283643836448364583646836478364883649836508365183652836538365483655836568365783658836598366083661836628366383664836658366683667836688366983670836718367283673836748367583676836778367883679836808368183682836838368483685836868368783688836898369083691836928369383694836958369683697836988369983700837018370283703837048370583706837078370883709837108371183712837138371483715837168371783718837198372083721837228372383724837258372683727837288372983730837318373283733837348373583736837378373883739837408374183742837438374483745837468374783748837498375083751837528375383754837558375683757837588375983760837618376283763837648376583766837678376883769837708377183772837738377483775837768377783778837798378083781837828378383784837858378683787837888378983790837918379283793837948379583796837978379883799838008380183802838038380483805838068380783808838098381083811838128381383814838158381683817838188381983820838218382283823838248382583826838278382883829838308383183832838338383483835838368383783838838398384083841838428384383844838458384683847838488384983850838518385283853838548385583856838578385883859838608386183862838638386483865838668386783868838698387083871838728387383874838758387683877838788387983880838818388283883838848388583886838878388883889838908389183892838938389483895838968389783898838998390083901839028390383904839058390683907839088390983910839118391283913839148391583916839178391883919839208392183922839238392483925839268392783928839298393083931839328393383934839358393683937839388393983940839418394283943839448394583946839478394883949839508395183952839538395483955839568395783958839598396083961839628396383964839658396683967839688396983970839718397283973839748397583976839778397883979839808398183982839838398483985839868398783988839898399083991839928399383994839958399683997839988399984000840018400284003840048400584006840078400884009840108401184012840138401484015840168401784018840198402084021840228402384024840258402684027840288402984030840318403284033840348403584036840378403884039840408404184042840438404484045840468404784048840498405084051840528405384054840558405684057840588405984060840618406284063840648406584066840678406884069840708407184072840738407484075840768407784078840798408084081840828408384084840858408684087840888408984090840918409284093840948409584096840978409884099841008410184102841038410484105841068410784108841098411084111841128411384114841158411684117841188411984120841218412284123841248412584126841278412884129841308413184132841338413484135841368413784138841398414084141841428414384144841458414684147841488414984150841518415284153841548415584156841578415884159841608416184162841638416484165841668416784168841698417084171841728417384174841758417684177841788417984180841818418284183841848418584186841878418884189841908419184192841938419484195841968419784198841998420084201842028420384204842058420684207842088420984210842118421284213842148421584216842178421884219842208422184222842238422484225842268422784228842298423084231842328423384234842358423684237842388423984240842418424284243842448424584246842478424884249842508425184252842538425484255842568425784258842598426084261842628426384264842658426684267842688426984270842718427284273842748427584276842778427884279842808428184282842838428484285842868428784288842898429084291842928429384294842958429684297842988429984300843018430284303843048430584306843078430884309843108431184312843138431484315843168431784318843198432084321843228432384324843258432684327843288432984330843318433284333843348433584336843378433884339843408434184342843438434484345843468434784348843498435084351843528435384354843558435684357843588435984360843618436284363843648436584366843678436884369843708437184372843738437484375843768437784378843798438084381843828438384384843858438684387843888438984390843918439284393843948439584396843978439884399844008440184402844038440484405844068440784408844098441084411844128441384414844158441684417844188441984420844218442284423844248442584426844278442884429844308443184432844338443484435844368443784438844398444084441844428444384444844458444684447844488444984450844518445284453844548445584456844578445884459844608446184462844638446484465844668446784468844698447084471844728447384474844758447684477844788447984480844818448284483844848448584486844878448884489844908449184492844938449484495844968449784498844998450084501845028450384504845058450684507845088450984510845118451284513845148451584516845178451884519845208452184522845238452484525845268452784528845298453084531845328453384534845358453684537845388453984540845418454284543845448454584546845478454884549845508455184552845538455484555845568455784558845598456084561845628456384564845658456684567845688456984570845718457284573845748457584576845778457884579845808458184582845838458484585845868458784588845898459084591845928459384594845958459684597845988459984600846018460284603846048460584606846078460884609846108461184612846138461484615846168461784618846198462084621846228462384624846258462684627846288462984630846318463284633846348463584636846378463884639846408464184642846438464484645846468464784648846498465084651846528465384654846558465684657846588465984660846618466284663846648466584666846678466884669846708467184672846738467484675846768467784678846798468084681846828468384684846858468684687846888468984690846918469284693846948469584696846978469884699847008470184702847038470484705847068470784708847098471084711847128471384714847158471684717847188471984720847218472284723847248472584726847278472884729847308473184732847338473484735847368473784738847398474084741847428474384744847458474684747847488474984750847518475284753847548475584756847578475884759847608476184762847638476484765847668476784768847698477084771847728477384774847758477684777847788477984780847818478284783847848478584786847878478884789847908479184792847938479484795847968479784798847998480084801848028480384804848058480684807848088480984810848118481284813848148481584816848178481884819848208482184822848238482484825848268482784828848298483084831848328483384834848358483684837848388483984840848418484284843848448484584846848478484884849848508485184852848538485484855848568485784858848598486084861848628486384864848658486684867848688486984870848718487284873848748487584876848778487884879848808488184882848838488484885848868488784888848898489084891848928489384894848958489684897848988489984900849018490284903849048490584906849078490884909849108491184912849138491484915849168491784918849198492084921849228492384924849258492684927849288492984930849318493284933849348493584936849378493884939849408494184942849438494484945849468494784948849498495084951849528495384954849558495684957849588495984960849618496284963849648496584966849678496884969849708497184972849738497484975849768497784978849798498084981849828498384984849858498684987849888498984990849918499284993849948499584996849978499884999850008500185002850038500485005850068500785008850098501085011850128501385014850158501685017850188501985020850218502285023850248502585026850278502885029850308503185032850338503485035850368503785038850398504085041850428504385044850458504685047850488504985050850518505285053850548505585056850578505885059850608506185062850638506485065850668506785068850698507085071850728507385074850758507685077850788507985080850818508285083850848508585086850878508885089850908509185092850938509485095850968509785098850998510085101851028510385104851058510685107851088510985110851118511285113851148511585116851178511885119851208512185122851238512485125851268512785128851298513085131851328513385134851358513685137851388513985140851418514285143851448514585146851478514885149851508515185152851538515485155851568515785158851598516085161851628516385164851658516685167851688516985170851718517285173851748517585176851778517885179851808518185182851838518485185851868518785188851898519085191851928519385194851958519685197851988519985200852018520285203852048520585206852078520885209852108521185212852138521485215852168521785218852198522085221852228522385224852258522685227852288522985230852318523285233852348523585236852378523885239852408524185242852438524485245852468524785248852498525085251852528525385254852558525685257852588525985260852618526285263852648526585266852678526885269852708527185272852738527485275852768527785278852798528085281852828528385284852858528685287852888528985290852918529285293852948529585296852978529885299853008530185302853038530485305853068530785308853098531085311853128531385314853158531685317853188531985320853218532285323853248532585326853278532885329853308533185332853338533485335853368533785338853398534085341853428534385344853458534685347853488534985350853518535285353853548535585356853578535885359853608536185362853638536485365853668536785368853698537085371853728537385374853758537685377853788537985380853818538285383853848538585386853878538885389853908539185392853938539485395853968539785398853998540085401854028540385404854058540685407854088540985410854118541285413854148541585416854178541885419854208542185422854238542485425854268542785428854298543085431854328543385434854358543685437854388543985440854418544285443854448544585446854478544885449854508545185452854538545485455854568545785458854598546085461854628546385464854658546685467854688546985470854718547285473854748547585476854778547885479854808548185482854838548485485854868548785488854898549085491854928549385494854958549685497854988549985500855018550285503855048550585506855078550885509855108551185512855138551485515855168551785518855198552085521855228552385524855258552685527855288552985530855318553285533855348553585536855378553885539855408554185542855438554485545855468554785548855498555085551855528555385554855558555685557855588555985560855618556285563855648556585566855678556885569855708557185572855738557485575855768557785578855798558085581855828558385584855858558685587855888558985590855918559285593855948559585596855978559885599856008560185602856038560485605856068560785608856098561085611856128561385614856158561685617856188561985620856218562285623856248562585626856278562885629856308563185632856338563485635856368563785638856398564085641856428564385644856458564685647856488564985650856518565285653856548565585656856578565885659856608566185662856638566485665856668566785668856698567085671856728567385674856758567685677856788567985680856818568285683856848568585686856878568885689856908569185692856938569485695856968569785698856998570085701857028570385704857058570685707857088570985710857118571285713857148571585716857178571885719857208572185722857238572485725857268572785728857298573085731857328573385734857358573685737857388573985740857418574285743857448574585746857478574885749857508575185752857538575485755857568575785758857598576085761857628576385764857658576685767857688576985770857718577285773857748577585776857778577885779857808578185782857838578485785857868578785788857898579085791857928579385794857958579685797857988579985800858018580285803858048580585806858078580885809858108581185812858138581485815858168581785818858198582085821858228582385824858258582685827858288582985830858318583285833858348583585836858378583885839858408584185842858438584485845858468584785848858498585085851858528585385854858558585685857858588585985860858618586285863858648586585866858678586885869858708587185872858738587485875858768587785878858798588085881858828588385884858858588685887858888588985890858918589285893858948589585896858978589885899859008590185902859038590485905859068590785908859098591085911859128591385914859158591685917859188591985920859218592285923859248592585926859278592885929859308593185932859338593485935859368593785938859398594085941859428594385944859458594685947859488594985950859518595285953859548595585956859578595885959859608596185962859638596485965859668596785968859698597085971859728597385974859758597685977859788597985980859818598285983859848598585986859878598885989859908599185992859938599485995859968599785998859998600086001860028600386004860058600686007860088600986010860118601286013860148601586016860178601886019860208602186022860238602486025860268602786028860298603086031860328603386034860358603686037860388603986040860418604286043860448604586046860478604886049860508605186052860538605486055860568605786058860598606086061860628606386064860658606686067860688606986070860718607286073860748607586076860778607886079860808608186082860838608486085860868608786088860898609086091860928609386094860958609686097860988609986100861018610286103861048610586106861078610886109861108611186112861138611486115861168611786118861198612086121861228612386124861258612686127861288612986130861318613286133861348613586136861378613886139861408614186142861438614486145861468614786148861498615086151861528615386154861558615686157861588615986160861618616286163861648616586166861678616886169861708617186172861738617486175861768617786178861798618086181861828618386184861858618686187861888618986190861918619286193861948619586196861978619886199862008620186202862038620486205862068620786208862098621086211862128621386214862158621686217862188621986220862218622286223862248622586226862278622886229862308623186232862338623486235862368623786238862398624086241862428624386244862458624686247862488624986250862518625286253862548625586256862578625886259862608626186262862638626486265862668626786268862698627086271862728627386274862758627686277862788627986280862818628286283862848628586286862878628886289862908629186292862938629486295862968629786298862998630086301863028630386304863058630686307863088630986310863118631286313863148631586316863178631886319863208632186322863238632486325863268632786328863298633086331863328633386334863358633686337863388633986340863418634286343863448634586346863478634886349863508635186352863538635486355863568635786358863598636086361863628636386364863658636686367863688636986370863718637286373863748637586376863778637886379863808638186382863838638486385863868638786388863898639086391863928639386394863958639686397863988639986400864018640286403864048640586406864078640886409864108641186412864138641486415864168641786418864198642086421864228642386424864258642686427864288642986430864318643286433864348643586436864378643886439864408644186442864438644486445864468644786448864498645086451864528645386454864558645686457864588645986460864618646286463864648646586466864678646886469864708647186472864738647486475864768647786478864798648086481864828648386484864858648686487864888648986490864918649286493864948649586496864978649886499865008650186502865038650486505865068650786508865098651086511865128651386514865158651686517865188651986520865218652286523865248652586526865278652886529865308653186532865338653486535865368653786538865398654086541865428654386544865458654686547865488654986550865518655286553865548655586556865578655886559865608656186562865638656486565865668656786568865698657086571865728657386574865758657686577865788657986580865818658286583865848658586586865878658886589865908659186592865938659486595865968659786598865998660086601866028660386604866058660686607866088660986610866118661286613866148661586616866178661886619866208662186622866238662486625866268662786628866298663086631866328663386634866358663686637866388663986640866418664286643866448664586646866478664886649866508665186652866538665486655866568665786658866598666086661866628666386664866658666686667866688666986670866718667286673866748667586676866778667886679866808668186682866838668486685866868668786688866898669086691866928669386694866958669686697866988669986700867018670286703867048670586706867078670886709867108671186712867138671486715867168671786718867198672086721867228672386724867258672686727867288672986730867318673286733867348673586736867378673886739867408674186742867438674486745867468674786748867498675086751867528675386754867558675686757867588675986760867618676286763867648676586766867678676886769867708677186772867738677486775867768677786778867798678086781867828678386784867858678686787867888678986790867918679286793867948679586796867978679886799868008680186802868038680486805868068680786808868098681086811868128681386814868158681686817868188681986820868218682286823868248682586826868278682886829868308683186832868338683486835868368683786838868398684086841868428684386844868458684686847868488684986850868518685286853868548685586856868578685886859868608686186862868638686486865868668686786868868698687086871868728687386874868758687686877868788687986880868818688286883868848688586886868878688886889868908689186892868938689486895868968689786898868998690086901869028690386904869058690686907869088690986910869118691286913869148691586916869178691886919869208692186922869238692486925869268692786928869298693086931869328693386934869358693686937869388693986940869418694286943869448694586946869478694886949869508695186952869538695486955869568695786958869598696086961869628696386964869658696686967869688696986970869718697286973869748697586976869778697886979869808698186982869838698486985869868698786988869898699086991869928699386994869958699686997869988699987000870018700287003870048700587006870078700887009870108701187012870138701487015870168701787018870198702087021870228702387024870258702687027870288702987030870318703287033870348703587036870378703887039870408704187042870438704487045870468704787048870498705087051870528705387054870558705687057870588705987060870618706287063870648706587066870678706887069870708707187072870738707487075870768707787078870798708087081870828708387084870858708687087870888708987090870918709287093870948709587096870978709887099871008710187102871038710487105871068710787108871098711087111871128711387114871158711687117871188711987120871218712287123871248712587126871278712887129871308713187132871338713487135871368713787138871398714087141871428714387144871458714687147871488714987150871518715287153871548715587156871578715887159871608716187162871638716487165871668716787168871698717087171871728717387174871758717687177871788717987180871818718287183871848718587186871878718887189871908719187192871938719487195871968719787198871998720087201872028720387204872058720687207872088720987210872118721287213872148721587216872178721887219872208722187222872238722487225872268722787228872298723087231872328723387234872358723687237872388723987240872418724287243872448724587246872478724887249872508725187252872538725487255872568725787258872598726087261872628726387264872658726687267872688726987270872718727287273872748727587276872778727887279872808728187282872838728487285872868728787288872898729087291872928729387294872958729687297872988729987300873018730287303873048730587306873078730887309873108731187312873138731487315873168731787318873198732087321873228732387324873258732687327873288732987330873318733287333873348733587336873378733887339873408734187342873438734487345873468734787348873498735087351873528735387354873558735687357873588735987360873618736287363873648736587366873678736887369873708737187372873738737487375873768737787378873798738087381873828738387384873858738687387873888738987390873918739287393873948739587396873978739887399874008740187402874038740487405874068740787408874098741087411874128741387414874158741687417874188741987420874218742287423874248742587426874278742887429874308743187432874338743487435874368743787438874398744087441874428744387444874458744687447874488744987450874518745287453874548745587456874578745887459874608746187462874638746487465874668746787468874698747087471874728747387474874758747687477874788747987480874818748287483874848748587486874878748887489874908749187492874938749487495874968749787498874998750087501875028750387504875058750687507875088750987510875118751287513875148751587516875178751887519875208752187522875238752487525875268752787528875298753087531875328753387534875358753687537875388753987540875418754287543875448754587546875478754887549875508755187552875538755487555875568755787558875598756087561875628756387564875658756687567875688756987570875718757287573875748757587576875778757887579875808758187582875838758487585875868758787588875898759087591875928759387594875958759687597875988759987600876018760287603876048760587606876078760887609876108761187612876138761487615876168761787618876198762087621876228762387624876258762687627876288762987630876318763287633876348763587636876378763887639876408764187642876438764487645876468764787648876498765087651876528765387654876558765687657876588765987660876618766287663876648766587666876678766887669876708767187672876738767487675876768767787678876798768087681876828768387684876858768687687876888768987690876918769287693876948769587696876978769887699877008770187702877038770487705877068770787708877098771087711877128771387714877158771687717877188771987720877218772287723877248772587726877278772887729877308773187732877338773487735877368773787738877398774087741877428774387744877458774687747877488774987750877518775287753877548775587756877578775887759877608776187762877638776487765877668776787768877698777087771877728777387774877758777687777877788777987780877818778287783877848778587786877878778887789877908779187792877938779487795877968779787798877998780087801878028780387804878058780687807878088780987810878118781287813878148781587816878178781887819878208782187822878238782487825878268782787828878298783087831878328783387834878358783687837878388783987840878418784287843878448784587846878478784887849878508785187852878538785487855878568785787858878598786087861878628786387864878658786687867878688786987870878718787287873878748787587876878778787887879878808788187882878838788487885878868788787888878898789087891878928789387894878958789687897878988789987900879018790287903879048790587906879078790887909879108791187912879138791487915879168791787918879198792087921879228792387924879258792687927879288792987930879318793287933879348793587936879378793887939879408794187942879438794487945879468794787948879498795087951879528795387954879558795687957879588795987960879618796287963879648796587966879678796887969879708797187972879738797487975879768797787978879798798087981879828798387984879858798687987879888798987990879918799287993879948799587996879978799887999880008800188002880038800488005880068800788008880098801088011880128801388014880158801688017880188801988020880218802288023880248802588026880278802888029880308803188032880338803488035880368803788038880398804088041880428804388044880458804688047880488804988050880518805288053880548805588056880578805888059880608806188062880638806488065880668806788068880698807088071880728807388074880758807688077880788807988080880818808288083880848808588086880878808888089880908809188092880938809488095880968809788098880998810088101881028810388104881058810688107881088810988110881118811288113881148811588116881178811888119881208812188122881238812488125881268812788128881298813088131881328813388134881358813688137881388813988140881418814288143881448814588146881478814888149881508815188152881538815488155881568815788158881598816088161881628816388164881658816688167881688816988170881718817288173881748817588176881778817888179881808818188182881838818488185881868818788188881898819088191881928819388194881958819688197881988819988200882018820288203882048820588206882078820888209882108821188212882138821488215882168821788218882198822088221882228822388224882258822688227882288822988230882318823288233882348823588236882378823888239882408824188242882438824488245882468824788248882498825088251882528825388254882558825688257882588825988260882618826288263882648826588266882678826888269882708827188272882738827488275882768827788278882798828088281882828828388284882858828688287882888828988290882918829288293882948829588296882978829888299883008830188302883038830488305883068830788308883098831088311883128831388314883158831688317883188831988320883218832288323883248832588326883278832888329883308833188332883338833488335883368833788338883398834088341883428834388344883458834688347883488834988350883518835288353883548835588356883578835888359883608836188362883638836488365883668836788368883698837088371883728837388374883758837688377883788837988380883818838288383883848838588386883878838888389883908839188392883938839488395883968839788398883998840088401884028840388404884058840688407884088840988410884118841288413884148841588416884178841888419884208842188422884238842488425884268842788428884298843088431884328843388434884358843688437884388843988440884418844288443884448844588446884478844888449884508845188452884538845488455884568845788458884598846088461884628846388464884658846688467884688846988470884718847288473884748847588476884778847888479884808848188482884838848488485884868848788488884898849088491884928849388494884958849688497884988849988500885018850288503885048850588506885078850888509885108851188512885138851488515885168851788518885198852088521885228852388524885258852688527885288852988530885318853288533885348853588536885378853888539885408854188542885438854488545885468854788548885498855088551885528855388554885558855688557885588855988560885618856288563885648856588566885678856888569885708857188572885738857488575885768857788578885798858088581885828858388584885858858688587885888858988590885918859288593885948859588596885978859888599886008860188602886038860488605886068860788608886098861088611886128861388614886158861688617886188861988620886218862288623886248862588626886278862888629886308863188632886338863488635886368863788638886398864088641886428864388644886458864688647886488864988650886518865288653886548865588656886578865888659886608866188662886638866488665886668866788668886698867088671886728867388674886758867688677886788867988680886818868288683886848868588686886878868888689886908869188692886938869488695886968869788698886998870088701887028870388704887058870688707887088870988710887118871288713887148871588716887178871888719887208872188722887238872488725887268872788728887298873088731887328873388734887358873688737887388873988740887418874288743887448874588746887478874888749887508875188752887538875488755887568875788758887598876088761887628876388764887658876688767887688876988770887718877288773887748877588776887778877888779887808878188782887838878488785887868878788788887898879088791887928879388794887958879688797887988879988800888018880288803888048880588806888078880888809888108881188812888138881488815888168881788818888198882088821888228882388824888258882688827888288882988830888318883288833888348883588836888378883888839888408884188842888438884488845888468884788848888498885088851888528885388854888558885688857888588885988860888618886288863888648886588866888678886888869888708887188872888738887488875888768887788878888798888088881888828888388884888858888688887888888888988890888918889288893888948889588896888978889888899889008890188902889038890488905889068890788908889098891088911889128891388914889158891688917889188891988920889218892288923889248892588926889278892888929889308893188932889338893488935889368893788938889398894088941889428894388944889458894688947889488894988950889518895288953889548895588956889578895888959889608896188962889638896488965889668896788968889698897088971889728897388974889758897688977889788897988980889818898288983889848898588986889878898888989889908899188992889938899488995889968899788998889998900089001890028900389004890058900689007890088900989010890118901289013890148901589016890178901889019890208902189022890238902489025890268902789028890298903089031890328903389034890358903689037890388903989040890418904289043890448904589046890478904889049890508905189052890538905489055890568905789058890598906089061890628906389064890658906689067890688906989070890718907289073890748907589076890778907889079890808908189082890838908489085890868908789088890898909089091890928909389094890958909689097890988909989100891018910289103891048910589106891078910889109891108911189112891138911489115891168911789118891198912089121891228912389124891258912689127891288912989130891318913289133891348913589136891378913889139891408914189142891438914489145891468914789148891498915089151891528915389154891558915689157891588915989160891618916289163891648916589166891678916889169891708917189172891738917489175891768917789178891798918089181891828918389184891858918689187891888918989190891918919289193891948919589196891978919889199892008920189202892038920489205892068920789208892098921089211892128921389214892158921689217892188921989220892218922289223892248922589226892278922889229892308923189232892338923489235892368923789238892398924089241892428924389244892458924689247892488924989250892518925289253892548925589256892578925889259892608926189262892638926489265892668926789268892698927089271892728927389274892758927689277892788927989280892818928289283892848928589286892878928889289892908929189292892938929489295892968929789298892998930089301893028930389304893058930689307893088930989310893118931289313893148931589316893178931889319893208932189322893238932489325893268932789328893298933089331893328933389334893358933689337893388933989340893418934289343893448934589346893478934889349893508935189352893538935489355893568935789358893598936089361893628936389364893658936689367893688936989370893718937289373893748937589376893778937889379893808938189382893838938489385893868938789388893898939089391893928939389394893958939689397893988939989400894018940289403894048940589406894078940889409894108941189412894138941489415894168941789418894198942089421894228942389424894258942689427894288942989430894318943289433894348943589436894378943889439894408944189442894438944489445894468944789448894498945089451894528945389454894558945689457894588945989460894618946289463894648946589466894678946889469894708947189472894738947489475894768947789478894798948089481894828948389484894858948689487894888948989490894918949289493894948949589496894978949889499895008950189502895038950489505895068950789508895098951089511895128951389514895158951689517895188951989520895218952289523895248952589526895278952889529895308953189532895338953489535895368953789538895398954089541895428954389544895458954689547895488954989550895518955289553895548955589556895578955889559895608956189562895638956489565895668956789568895698957089571895728957389574895758957689577895788957989580895818958289583895848958589586895878958889589895908959189592895938959489595895968959789598895998960089601896028960389604896058960689607896088960989610896118961289613896148961589616896178961889619896208962189622896238962489625896268962789628896298963089631896328963389634896358963689637896388963989640896418964289643896448964589646896478964889649896508965189652896538965489655896568965789658896598966089661896628966389664896658966689667896688966989670896718967289673896748967589676896778967889679896808968189682896838968489685896868968789688896898969089691896928969389694896958969689697896988969989700897018970289703897048970589706897078970889709897108971189712897138971489715897168971789718897198972089721897228972389724897258972689727897288972989730897318973289733897348973589736897378973889739897408974189742897438974489745897468974789748897498975089751897528975389754897558975689757897588975989760897618976289763897648976589766897678976889769897708977189772897738977489775897768977789778897798978089781897828978389784897858978689787897888978989790897918979289793897948979589796897978979889799898008980189802898038980489805898068980789808898098981089811898128981389814898158981689817898188981989820898218982289823898248982589826898278982889829898308983189832898338983489835898368983789838898398984089841898428984389844898458984689847898488984989850898518985289853898548985589856898578985889859898608986189862898638986489865898668986789868898698987089871898728987389874898758987689877898788987989880898818988289883898848988589886898878988889889898908989189892898938989489895898968989789898898998990089901899028990389904899058990689907899088990989910899118991289913899148991589916899178991889919899208992189922899238992489925899268992789928899298993089931899328993389934899358993689937899388993989940899418994289943899448994589946899478994889949899508995189952899538995489955899568995789958899598996089961899628996389964899658996689967899688996989970899718997289973899748997589976899778997889979899808998189982899838998489985899868998789988899898999089991899928999389994899958999689997899988999990000900019000290003900049000590006900079000890009900109001190012900139001490015900169001790018900199002090021900229002390024900259002690027900289002990030900319003290033900349003590036900379003890039900409004190042900439004490045900469004790048900499005090051900529005390054900559005690057900589005990060900619006290063900649006590066900679006890069900709007190072900739007490075900769007790078900799008090081900829008390084900859008690087900889008990090900919009290093900949009590096900979009890099901009010190102901039010490105901069010790108901099011090111901129011390114901159011690117901189011990120901219012290123901249012590126901279012890129901309013190132901339013490135901369013790138901399014090141901429014390144901459014690147901489014990150901519015290153901549015590156901579015890159901609016190162901639016490165901669016790168901699017090171901729017390174901759017690177901789017990180901819018290183901849018590186901879018890189901909019190192901939019490195901969019790198901999020090201902029020390204902059020690207902089020990210902119021290213902149021590216902179021890219902209022190222902239022490225902269022790228902299023090231902329023390234902359023690237902389023990240902419024290243902449024590246902479024890249902509025190252902539025490255902569025790258902599026090261902629026390264902659026690267902689026990270902719027290273902749027590276902779027890279902809028190282902839028490285902869028790288902899029090291902929029390294902959029690297902989029990300903019030290303903049030590306903079030890309903109031190312903139031490315903169031790318903199032090321903229032390324903259032690327903289032990330903319033290333903349033590336903379033890339903409034190342903439034490345903469034790348903499035090351903529035390354903559035690357903589035990360903619036290363903649036590366903679036890369903709037190372903739037490375903769037790378903799038090381903829038390384903859038690387903889038990390903919039290393903949039590396903979039890399904009040190402904039040490405904069040790408904099041090411904129041390414904159041690417904189041990420904219042290423904249042590426904279042890429904309043190432904339043490435904369043790438904399044090441904429044390444904459044690447904489044990450904519045290453904549045590456904579045890459904609046190462904639046490465904669046790468904699047090471904729047390474904759047690477904789047990480904819048290483904849048590486904879048890489904909049190492904939049490495904969049790498904999050090501905029050390504905059050690507905089050990510905119051290513905149051590516905179051890519905209052190522905239052490525905269052790528905299053090531905329053390534905359053690537905389053990540905419054290543905449054590546905479054890549905509055190552905539055490555905569055790558905599056090561905629056390564905659056690567905689056990570905719057290573905749057590576905779057890579905809058190582905839058490585905869058790588905899059090591905929059390594905959059690597905989059990600906019060290603906049060590606906079060890609906109061190612906139061490615906169061790618906199062090621906229062390624906259062690627906289062990630906319063290633906349063590636906379063890639906409064190642906439064490645906469064790648906499065090651906529065390654906559065690657906589065990660906619066290663906649066590666906679066890669906709067190672906739067490675906769067790678906799068090681906829068390684906859068690687906889068990690906919069290693906949069590696906979069890699907009070190702907039070490705907069070790708907099071090711907129071390714907159071690717907189071990720907219072290723907249072590726907279072890729907309073190732907339073490735907369073790738907399074090741907429074390744907459074690747907489074990750907519075290753907549075590756907579075890759907609076190762907639076490765907669076790768907699077090771907729077390774907759077690777907789077990780907819078290783907849078590786907879078890789907909079190792907939079490795907969079790798907999080090801908029080390804908059080690807908089080990810908119081290813908149081590816908179081890819908209082190822908239082490825908269082790828908299083090831908329083390834908359083690837908389083990840908419084290843908449084590846908479084890849908509085190852908539085490855908569085790858908599086090861908629086390864908659086690867908689086990870908719087290873908749087590876908779087890879908809088190882908839088490885908869088790888908899089090891908929089390894908959089690897908989089990900909019090290903909049090590906909079090890909909109091190912909139091490915909169091790918909199092090921909229092390924909259092690927909289092990930909319093290933909349093590936909379093890939909409094190942909439094490945909469094790948909499095090951909529095390954909559095690957909589095990960909619096290963909649096590966909679096890969909709097190972909739097490975909769097790978909799098090981909829098390984909859098690987909889098990990909919099290993909949099590996909979099890999910009100191002910039100491005910069100791008910099101091011910129101391014910159101691017910189101991020910219102291023910249102591026910279102891029910309103191032910339103491035910369103791038910399104091041910429104391044910459104691047910489104991050910519105291053910549105591056910579105891059910609106191062910639106491065910669106791068910699107091071910729107391074910759107691077910789107991080910819108291083910849108591086910879108891089910909109191092910939109491095910969109791098910999110091101911029110391104911059110691107911089110991110911119111291113911149111591116911179111891119911209112191122911239112491125911269112791128911299113091131911329113391134911359113691137911389113991140911419114291143911449114591146911479114891149911509115191152911539115491155911569115791158911599116091161911629116391164911659116691167911689116991170911719117291173911749117591176911779117891179911809118191182911839118491185911869118791188911899119091191911929119391194911959119691197911989119991200912019120291203912049120591206912079120891209912109121191212912139121491215912169121791218912199122091221912229122391224912259122691227912289122991230912319123291233912349123591236912379123891239912409124191242912439124491245912469124791248912499125091251912529125391254912559125691257912589125991260912619126291263912649126591266912679126891269912709127191272912739127491275912769127791278912799128091281912829128391284912859128691287912889128991290912919129291293912949129591296912979129891299913009130191302913039130491305913069130791308913099131091311913129131391314913159131691317913189131991320913219132291323913249132591326913279132891329913309133191332913339133491335913369133791338913399134091341913429134391344913459134691347913489134991350913519135291353913549135591356913579135891359913609136191362913639136491365913669136791368913699137091371913729137391374913759137691377913789137991380913819138291383913849138591386913879138891389913909139191392913939139491395913969139791398913999140091401914029140391404914059140691407914089140991410914119141291413914149141591416914179141891419914209142191422914239142491425914269142791428914299143091431914329143391434914359143691437914389143991440914419144291443914449144591446914479144891449914509145191452914539145491455914569145791458914599146091461914629146391464914659146691467914689146991470914719147291473914749147591476914779147891479914809148191482914839148491485914869148791488914899149091491914929149391494914959149691497914989149991500915019150291503915049150591506915079150891509915109151191512915139151491515915169151791518915199152091521915229152391524915259152691527915289152991530915319153291533915349153591536915379153891539915409154191542915439154491545915469154791548915499155091551915529155391554915559155691557915589155991560915619156291563915649156591566915679156891569915709157191572915739157491575915769157791578915799158091581915829158391584915859158691587915889158991590915919159291593915949159591596915979159891599916009160191602916039160491605916069160791608916099161091611916129161391614916159161691617916189161991620916219162291623916249162591626916279162891629916309163191632916339163491635916369163791638916399164091641916429164391644916459164691647916489164991650916519165291653916549165591656916579165891659916609166191662916639166491665916669166791668916699167091671916729167391674916759167691677916789167991680916819168291683916849168591686916879168891689916909169191692916939169491695916969169791698916999170091701917029170391704917059170691707917089170991710917119171291713917149171591716917179171891719917209172191722917239172491725917269172791728917299173091731917329173391734917359173691737917389173991740917419174291743917449174591746917479174891749917509175191752917539175491755917569175791758917599176091761917629176391764917659176691767917689176991770917719177291773917749177591776917779177891779917809178191782917839178491785917869178791788917899179091791917929179391794917959179691797917989179991800918019180291803918049180591806918079180891809918109181191812918139181491815918169181791818918199182091821918229182391824918259182691827918289182991830918319183291833918349183591836918379183891839918409184191842918439184491845918469184791848918499185091851918529185391854918559185691857918589185991860918619186291863918649186591866918679186891869918709187191872918739187491875918769187791878918799188091881918829188391884918859188691887918889188991890918919189291893918949189591896918979189891899919009190191902919039190491905919069190791908919099191091911919129191391914919159191691917919189191991920919219192291923919249192591926919279192891929919309193191932919339193491935919369193791938919399194091941919429194391944919459194691947919489194991950919519195291953919549195591956919579195891959919609196191962919639196491965919669196791968919699197091971919729197391974919759197691977919789197991980919819198291983919849198591986919879198891989919909199191992919939199491995919969199791998919999200092001920029200392004920059200692007920089200992010920119201292013920149201592016920179201892019920209202192022920239202492025920269202792028920299203092031920329203392034920359203692037920389203992040920419204292043920449204592046920479204892049920509205192052920539205492055920569205792058920599206092061920629206392064920659206692067920689206992070920719207292073920749207592076920779207892079920809208192082920839208492085920869208792088920899209092091920929209392094920959209692097920989209992100921019210292103921049210592106921079210892109921109211192112921139211492115921169211792118921199212092121921229212392124921259212692127921289212992130921319213292133921349213592136921379213892139921409214192142921439214492145921469214792148921499215092151921529215392154921559215692157921589215992160921619216292163921649216592166921679216892169921709217192172921739217492175921769217792178921799218092181921829218392184921859218692187921889218992190921919219292193921949219592196921979219892199922009220192202922039220492205922069220792208922099221092211922129221392214922159221692217922189221992220922219222292223922249222592226922279222892229922309223192232922339223492235922369223792238922399224092241922429224392244922459224692247922489224992250922519225292253922549225592256922579225892259922609226192262922639226492265922669226792268922699227092271922729227392274922759227692277922789227992280922819228292283922849228592286922879228892289922909229192292922939229492295922969229792298922999230092301923029230392304923059230692307923089230992310923119231292313923149231592316923179231892319923209232192322923239232492325923269232792328923299233092331923329233392334923359233692337923389233992340923419234292343923449234592346923479234892349923509235192352923539235492355923569235792358923599236092361923629236392364923659236692367923689236992370923719237292373923749237592376923779237892379923809238192382923839238492385923869238792388923899239092391923929239392394923959239692397923989239992400924019240292403924049240592406924079240892409924109241192412924139241492415924169241792418924199242092421924229242392424924259242692427924289242992430924319243292433924349243592436924379243892439924409244192442924439244492445924469244792448924499245092451924529245392454924559245692457924589245992460924619246292463924649246592466924679246892469924709247192472924739247492475924769247792478924799248092481924829248392484924859248692487924889248992490924919249292493924949249592496924979249892499925009250192502925039250492505925069250792508925099251092511925129251392514925159251692517925189251992520925219252292523925249252592526925279252892529925309253192532925339253492535925369253792538925399254092541925429254392544925459254692547925489254992550925519255292553925549255592556925579255892559925609256192562925639256492565925669256792568925699257092571925729257392574925759257692577925789257992580925819258292583925849258592586925879258892589925909259192592925939259492595925969259792598925999260092601926029260392604926059260692607926089260992610926119261292613926149261592616926179261892619926209262192622926239262492625926269262792628926299263092631926329263392634926359263692637926389263992640926419264292643926449264592646926479264892649926509265192652926539265492655926569265792658926599266092661926629266392664926659266692667926689266992670926719267292673926749267592676926779267892679926809268192682926839268492685926869268792688926899269092691926929269392694926959269692697926989269992700927019270292703927049270592706927079270892709927109271192712927139271492715927169271792718927199272092721927229272392724927259272692727927289272992730927319273292733927349273592736927379273892739927409274192742927439274492745927469274792748927499275092751927529275392754927559275692757927589275992760927619276292763927649276592766927679276892769927709277192772927739277492775927769277792778927799278092781927829278392784927859278692787927889278992790927919279292793927949279592796927979279892799928009280192802928039280492805928069280792808928099281092811928129281392814928159281692817928189281992820928219282292823928249282592826928279282892829928309283192832928339283492835928369283792838928399284092841928429284392844928459284692847928489284992850928519285292853928549285592856928579285892859928609286192862928639286492865928669286792868928699287092871928729287392874928759287692877928789287992880928819288292883928849288592886928879288892889928909289192892928939289492895928969289792898928999290092901929029290392904929059290692907929089290992910929119291292913929149291592916929179291892919929209292192922929239292492925929269292792928929299293092931929329293392934929359293692937929389293992940929419294292943929449294592946929479294892949929509295192952929539295492955929569295792958929599296092961929629296392964929659296692967929689296992970929719297292973929749297592976929779297892979929809298192982929839298492985929869298792988929899299092991929929299392994929959299692997929989299993000930019300293003930049300593006930079300893009930109301193012930139301493015930169301793018930199302093021930229302393024930259302693027930289302993030930319303293033930349303593036930379303893039930409304193042930439304493045930469304793048930499305093051930529305393054930559305693057930589305993060930619306293063930649306593066930679306893069930709307193072930739307493075930769307793078930799308093081930829308393084930859308693087930889308993090930919309293093930949309593096930979309893099931009310193102931039310493105931069310793108931099311093111931129311393114931159311693117931189311993120931219312293123931249312593126931279312893129931309313193132931339313493135931369313793138931399314093141931429314393144931459314693147931489314993150931519315293153931549315593156931579315893159931609316193162931639316493165931669316793168931699317093171931729317393174931759317693177931789317993180931819318293183931849318593186931879318893189931909319193192931939319493195931969319793198931999320093201932029320393204932059320693207932089320993210932119321293213932149321593216932179321893219932209322193222932239322493225932269322793228932299323093231932329323393234932359323693237932389323993240932419324293243932449324593246932479324893249932509325193252932539325493255932569325793258932599326093261932629326393264932659326693267932689326993270932719327293273932749327593276932779327893279932809328193282932839328493285932869328793288932899329093291932929329393294932959329693297932989329993300933019330293303933049330593306933079330893309933109331193312933139331493315933169331793318933199332093321933229332393324933259332693327933289332993330933319333293333933349333593336933379333893339933409334193342933439334493345933469334793348933499335093351933529335393354933559335693357933589335993360933619336293363933649336593366933679336893369933709337193372933739337493375933769337793378933799338093381933829338393384933859338693387933889338993390933919339293393933949339593396933979339893399934009340193402934039340493405934069340793408934099341093411934129341393414934159341693417934189341993420934219342293423934249342593426934279342893429934309343193432934339343493435934369343793438934399344093441934429344393444934459344693447934489344993450934519345293453934549345593456934579345893459934609346193462934639346493465934669346793468934699347093471934729347393474934759347693477934789347993480934819348293483934849348593486934879348893489934909349193492934939349493495934969349793498934999350093501935029350393504935059350693507935089350993510935119351293513935149351593516935179351893519935209352193522935239352493525935269352793528935299353093531935329353393534935359353693537935389353993540935419354293543935449354593546935479354893549935509355193552935539355493555935569355793558935599356093561935629356393564935659356693567935689356993570935719357293573935749357593576935779357893579935809358193582935839358493585935869358793588935899359093591935929359393594935959359693597935989359993600936019360293603936049360593606936079360893609936109361193612936139361493615936169361793618936199362093621936229362393624936259362693627936289362993630936319363293633936349363593636936379363893639936409364193642936439364493645936469364793648936499365093651936529365393654936559365693657936589365993660936619366293663936649366593666936679366893669936709367193672936739367493675936769367793678936799368093681936829368393684936859368693687936889368993690936919369293693936949369593696936979369893699937009370193702937039370493705937069370793708937099371093711937129371393714937159371693717937189371993720937219372293723937249372593726937279372893729937309373193732937339373493735937369373793738937399374093741937429374393744937459374693747937489374993750937519375293753937549375593756937579375893759937609376193762937639376493765937669376793768937699377093771937729377393774937759377693777937789377993780937819378293783937849378593786937879378893789937909379193792937939379493795937969379793798937999380093801938029380393804938059380693807938089380993810938119381293813938149381593816938179381893819938209382193822938239382493825938269382793828938299383093831938329383393834938359383693837938389383993840938419384293843938449384593846938479384893849938509385193852938539385493855938569385793858938599386093861938629386393864938659386693867938689386993870938719387293873938749387593876938779387893879938809388193882938839388493885938869388793888938899389093891938929389393894938959389693897938989389993900939019390293903939049390593906939079390893909939109391193912939139391493915939169391793918939199392093921939229392393924939259392693927939289392993930939319393293933939349393593936939379393893939939409394193942939439394493945939469394793948939499395093951939529395393954939559395693957939589395993960939619396293963939649396593966939679396893969939709397193972939739397493975939769397793978939799398093981939829398393984939859398693987939889398993990939919399293993939949399593996939979399893999940009400194002940039400494005940069400794008940099401094011940129401394014940159401694017940189401994020940219402294023940249402594026940279402894029940309403194032940339403494035940369403794038940399404094041940429404394044940459404694047940489404994050940519405294053940549405594056940579405894059940609406194062940639406494065940669406794068940699407094071940729407394074940759407694077940789407994080940819408294083940849408594086940879408894089940909409194092940939409494095940969409794098940999410094101941029410394104941059410694107941089410994110941119411294113941149411594116941179411894119941209412194122941239412494125941269412794128941299413094131941329413394134941359413694137941389413994140941419414294143941449414594146941479414894149941509415194152941539415494155941569415794158941599416094161941629416394164941659416694167941689416994170941719417294173941749417594176941779417894179941809418194182941839418494185941869418794188941899419094191941929419394194941959419694197941989419994200942019420294203942049420594206942079420894209942109421194212942139421494215942169421794218942199422094221942229422394224942259422694227942289422994230942319423294233942349423594236942379423894239942409424194242942439424494245942469424794248942499425094251942529425394254942559425694257942589425994260942619426294263942649426594266942679426894269942709427194272942739427494275942769427794278942799428094281942829428394284942859428694287942889428994290942919429294293942949429594296942979429894299943009430194302943039430494305943069430794308943099431094311943129431394314943159431694317943189431994320943219432294323943249432594326943279432894329943309433194332943339433494335943369433794338943399434094341943429434394344943459434694347943489434994350943519435294353943549435594356943579435894359943609436194362943639436494365943669436794368943699437094371943729437394374943759437694377943789437994380943819438294383943849438594386943879438894389943909439194392943939439494395943969439794398943999440094401944029440394404944059440694407944089440994410944119441294413944149441594416944179441894419944209442194422944239442494425944269442794428944299443094431944329443394434944359443694437944389443994440944419444294443944449444594446944479444894449944509445194452944539445494455944569445794458944599446094461944629446394464944659446694467944689446994470944719447294473944749447594476944779447894479944809448194482944839448494485944869448794488944899449094491944929449394494944959449694497944989449994500945019450294503945049450594506945079450894509945109451194512945139451494515945169451794518945199452094521945229452394524945259452694527945289452994530945319453294533945349453594536945379453894539945409454194542945439454494545945469454794548945499455094551945529455394554945559455694557945589455994560945619456294563945649456594566945679456894569945709457194572945739457494575945769457794578945799458094581945829458394584945859458694587945889458994590945919459294593945949459594596945979459894599946009460194602946039460494605946069460794608946099461094611946129461394614946159461694617946189461994620946219462294623946249462594626946279462894629946309463194632946339463494635946369463794638946399464094641946429464394644946459464694647946489464994650946519465294653946549465594656946579465894659946609466194662946639466494665946669466794668946699467094671946729467394674946759467694677946789467994680946819468294683946849468594686946879468894689946909469194692946939469494695946969469794698946999470094701947029470394704947059470694707947089470994710947119471294713947149471594716947179471894719947209472194722947239472494725947269472794728947299473094731947329473394734947359473694737947389473994740947419474294743947449474594746947479474894749947509475194752947539475494755947569475794758947599476094761947629476394764947659476694767947689476994770947719477294773947749477594776947779477894779947809478194782947839478494785947869478794788947899479094791947929479394794947959479694797947989479994800948019480294803948049480594806948079480894809948109481194812948139481494815948169481794818948199482094821948229482394824948259482694827948289482994830948319483294833948349483594836948379483894839948409484194842948439484494845948469484794848948499485094851948529485394854948559485694857948589485994860948619486294863948649486594866948679486894869948709487194872948739487494875948769487794878948799488094881948829488394884948859488694887948889488994890948919489294893948949489594896948979489894899949009490194902949039490494905949069490794908949099491094911949129491394914949159491694917949189491994920949219492294923949249492594926949279492894929949309493194932949339493494935949369493794938949399494094941949429494394944949459494694947949489494994950949519495294953949549495594956949579495894959949609496194962949639496494965949669496794968949699497094971949729497394974949759497694977949789497994980949819498294983949849498594986949879498894989949909499194992949939499494995949969499794998949999500095001950029500395004950059500695007950089500995010950119501295013950149501595016950179501895019950209502195022950239502495025950269502795028950299503095031950329503395034950359503695037950389503995040950419504295043950449504595046950479504895049950509505195052950539505495055950569505795058950599506095061950629506395064950659506695067950689506995070950719507295073950749507595076950779507895079950809508195082950839508495085950869508795088950899509095091950929509395094950959509695097950989509995100951019510295103951049510595106951079510895109951109511195112951139511495115951169511795118951199512095121951229512395124951259512695127951289512995130951319513295133951349513595136951379513895139951409514195142951439514495145951469514795148951499515095151951529515395154951559515695157951589515995160951619516295163951649516595166951679516895169951709517195172951739517495175951769517795178951799518095181951829518395184951859518695187951889518995190951919519295193951949519595196951979519895199952009520195202952039520495205952069520795208952099521095211952129521395214952159521695217952189521995220952219522295223952249522595226952279522895229952309523195232952339523495235952369523795238952399524095241952429524395244952459524695247952489524995250952519525295253952549525595256952579525895259952609526195262952639526495265952669526795268952699527095271952729527395274952759527695277952789527995280952819528295283952849528595286952879528895289952909529195292952939529495295952969529795298952999530095301953029530395304953059530695307953089530995310953119531295313953149531595316953179531895319953209532195322953239532495325953269532795328953299533095331953329533395334953359533695337953389533995340953419534295343953449534595346953479534895349953509535195352953539535495355953569535795358953599536095361953629536395364953659536695367953689536995370953719537295373953749537595376953779537895379953809538195382953839538495385953869538795388953899539095391953929539395394953959539695397953989539995400954019540295403954049540595406954079540895409954109541195412954139541495415954169541795418954199542095421954229542395424954259542695427954289542995430954319543295433954349543595436954379543895439954409544195442954439544495445954469544795448954499545095451954529545395454954559545695457954589545995460954619546295463954649546595466954679546895469954709547195472954739547495475954769547795478954799548095481954829548395484954859548695487954889548995490954919549295493954949549595496954979549895499955009550195502955039550495505955069550795508955099551095511955129551395514955159551695517955189551995520955219552295523955249552595526955279552895529955309553195532955339553495535955369553795538955399554095541955429554395544955459554695547955489554995550955519555295553955549555595556955579555895559955609556195562955639556495565955669556795568955699557095571955729557395574955759557695577955789557995580955819558295583955849558595586955879558895589955909559195592955939559495595955969559795598955999560095601956029560395604956059560695607956089560995610956119561295613956149561595616956179561895619956209562195622956239562495625956269562795628956299563095631956329563395634956359563695637956389563995640956419564295643956449564595646956479564895649956509565195652956539565495655956569565795658956599566095661956629566395664956659566695667956689566995670956719567295673956749567595676956779567895679956809568195682956839568495685956869568795688956899569095691956929569395694956959569695697956989569995700957019570295703957049570595706957079570895709957109571195712957139571495715957169571795718957199572095721957229572395724957259572695727957289572995730957319573295733957349573595736957379573895739957409574195742957439574495745957469574795748957499575095751957529575395754957559575695757957589575995760957619576295763957649576595766957679576895769957709577195772957739577495775957769577795778957799578095781957829578395784957859578695787957889578995790957919579295793957949579595796957979579895799958009580195802958039580495805958069580795808958099581095811958129581395814958159581695817958189581995820958219582295823958249582595826958279582895829958309583195832958339583495835958369583795838958399584095841958429584395844958459584695847958489584995850958519585295853958549585595856958579585895859958609586195862958639586495865958669586795868958699587095871958729587395874958759587695877958789587995880958819588295883958849588595886958879588895889958909589195892958939589495895958969589795898958999590095901959029590395904959059590695907959089590995910959119591295913959149591595916959179591895919959209592195922959239592495925959269592795928959299593095931959329593395934959359593695937959389593995940959419594295943959449594595946959479594895949959509595195952959539595495955959569595795958959599596095961959629596395964959659596695967959689596995970959719597295973959749597595976959779597895979959809598195982959839598495985959869598795988959899599095991959929599395994959959599695997959989599996000960019600296003960049600596006960079600896009960109601196012960139601496015960169601796018960199602096021960229602396024960259602696027960289602996030960319603296033960349603596036960379603896039960409604196042960439604496045960469604796048960499605096051960529605396054960559605696057960589605996060960619606296063960649606596066960679606896069960709607196072960739607496075960769607796078960799608096081960829608396084960859608696087960889608996090960919609296093960949609596096960979609896099961009610196102961039610496105961069610796108961099611096111961129611396114961159611696117961189611996120961219612296123961249612596126961279612896129961309613196132961339613496135961369613796138961399614096141961429614396144961459614696147961489614996150961519615296153961549615596156961579615896159961609616196162961639616496165961669616796168961699617096171961729617396174961759617696177961789617996180961819618296183961849618596186961879618896189961909619196192961939619496195961969619796198961999620096201962029620396204962059620696207962089620996210962119621296213962149621596216962179621896219962209622196222962239622496225962269622796228962299623096231962329623396234962359623696237962389623996240962419624296243962449624596246962479624896249962509625196252962539625496255962569625796258962599626096261962629626396264962659626696267962689626996270962719627296273962749627596276962779627896279962809628196282962839628496285962869628796288962899629096291962929629396294962959629696297962989629996300963019630296303963049630596306963079630896309963109631196312963139631496315963169631796318963199632096321963229632396324963259632696327963289632996330963319633296333963349633596336963379633896339963409634196342963439634496345963469634796348963499635096351963529635396354963559635696357963589635996360963619636296363963649636596366963679636896369963709637196372963739637496375963769637796378963799638096381963829638396384963859638696387963889638996390963919639296393963949639596396963979639896399964009640196402964039640496405964069640796408964099641096411964129641396414964159641696417964189641996420964219642296423964249642596426964279642896429964309643196432964339643496435964369643796438964399644096441964429644396444964459644696447964489644996450964519645296453964549645596456964579645896459964609646196462964639646496465964669646796468964699647096471964729647396474964759647696477964789647996480964819648296483964849648596486964879648896489964909649196492964939649496495964969649796498964999650096501965029650396504965059650696507965089650996510965119651296513965149651596516965179651896519965209652196522965239652496525965269652796528965299653096531965329653396534965359653696537965389653996540965419654296543965449654596546965479654896549965509655196552965539655496555965569655796558965599656096561965629656396564965659656696567965689656996570965719657296573965749657596576965779657896579965809658196582965839658496585965869658796588965899659096591965929659396594965959659696597965989659996600966019660296603966049660596606966079660896609966109661196612966139661496615966169661796618966199662096621966229662396624966259662696627966289662996630966319663296633966349663596636966379663896639966409664196642966439664496645966469664796648966499665096651966529665396654966559665696657966589665996660966619666296663966649666596666966679666896669966709667196672966739667496675966769667796678966799668096681966829668396684966859668696687966889668996690966919669296693966949669596696966979669896699967009670196702967039670496705967069670796708967099671096711967129671396714967159671696717967189671996720967219672296723967249672596726967279672896729967309673196732967339673496735967369673796738967399674096741967429674396744967459674696747967489674996750967519675296753967549675596756967579675896759967609676196762967639676496765967669676796768967699677096771967729677396774967759677696777967789677996780967819678296783967849678596786967879678896789967909679196792967939679496795967969679796798967999680096801968029680396804968059680696807968089680996810968119681296813968149681596816968179681896819968209682196822968239682496825968269682796828968299683096831968329683396834968359683696837968389683996840968419684296843968449684596846968479684896849968509685196852968539685496855968569685796858968599686096861968629686396864968659686696867968689686996870968719687296873968749687596876968779687896879968809688196882968839688496885968869688796888968899689096891968929689396894968959689696897968989689996900969019690296903969049690596906969079690896909969109691196912969139691496915969169691796918969199692096921969229692396924969259692696927969289692996930969319693296933969349693596936969379693896939969409694196942969439694496945969469694796948969499695096951969529695396954969559695696957969589695996960969619696296963969649696596966969679696896969969709697196972969739697496975969769697796978969799698096981969829698396984969859698696987969889698996990969919699296993969949699596996969979699896999970009700197002970039700497005970069700797008970099701097011970129701397014970159701697017970189701997020970219702297023970249702597026970279702897029970309703197032970339703497035970369703797038970399704097041970429704397044970459704697047970489704997050970519705297053970549705597056970579705897059970609706197062970639706497065970669706797068970699707097071970729707397074970759707697077970789707997080970819708297083970849708597086970879708897089970909709197092970939709497095970969709797098970999710097101971029710397104971059710697107971089710997110971119711297113971149711597116971179711897119971209712197122971239712497125971269712797128971299713097131971329713397134971359713697137971389713997140971419714297143971449714597146971479714897149971509715197152971539715497155971569715797158971599716097161971629716397164971659716697167971689716997170971719717297173971749717597176971779717897179971809718197182971839718497185971869718797188971899719097191971929719397194971959719697197971989719997200972019720297203972049720597206972079720897209972109721197212972139721497215972169721797218972199722097221972229722397224972259722697227972289722997230972319723297233972349723597236972379723897239972409724197242972439724497245972469724797248972499725097251972529725397254972559725697257972589725997260972619726297263972649726597266972679726897269972709727197272972739727497275972769727797278972799728097281972829728397284972859728697287972889728997290972919729297293972949729597296972979729897299973009730197302973039730497305973069730797308973099731097311973129731397314973159731697317973189731997320973219732297323973249732597326973279732897329973309733197332973339733497335973369733797338973399734097341973429734397344973459734697347973489734997350973519735297353973549735597356973579735897359973609736197362973639736497365973669736797368973699737097371973729737397374973759737697377973789737997380973819738297383973849738597386973879738897389973909739197392973939739497395973969739797398973999740097401974029740397404974059740697407974089740997410974119741297413974149741597416974179741897419974209742197422974239742497425974269742797428974299743097431974329743397434974359743697437974389743997440974419744297443974449744597446974479744897449974509745197452974539745497455974569745797458974599746097461974629746397464974659746697467974689746997470974719747297473974749747597476974779747897479974809748197482974839748497485974869748797488974899749097491974929749397494974959749697497974989749997500975019750297503975049750597506975079750897509975109751197512975139751497515975169751797518975199752097521975229752397524975259752697527975289752997530975319753297533975349753597536975379753897539975409754197542975439754497545975469754797548975499755097551975529755397554975559755697557975589755997560975619756297563975649756597566975679756897569975709757197572975739757497575975769757797578975799758097581975829758397584975859758697587975889758997590975919759297593975949759597596975979759897599976009760197602976039760497605976069760797608976099761097611976129761397614976159761697617976189761997620976219762297623976249762597626976279762897629976309763197632976339763497635976369763797638976399764097641976429764397644976459764697647976489764997650976519765297653976549765597656976579765897659976609766197662976639766497665976669766797668976699767097671976729767397674976759767697677976789767997680976819768297683976849768597686976879768897689976909769197692976939769497695976969769797698976999770097701977029770397704977059770697707977089770997710977119771297713977149771597716977179771897719977209772197722977239772497725977269772797728977299773097731977329773397734977359773697737977389773997740977419774297743977449774597746977479774897749977509775197752977539775497755977569775797758977599776097761977629776397764977659776697767977689776997770977719777297773977749777597776977779777897779977809778197782977839778497785977869778797788977899779097791977929779397794977959779697797977989779997800978019780297803978049780597806978079780897809978109781197812978139781497815978169781797818978199782097821978229782397824978259782697827978289782997830978319783297833978349783597836978379783897839978409784197842978439784497845978469784797848978499785097851978529785397854978559785697857978589785997860978619786297863978649786597866978679786897869978709787197872978739787497875978769787797878978799788097881978829788397884978859788697887978889788997890978919789297893978949789597896978979789897899979009790197902979039790497905979069790797908979099791097911979129791397914979159791697917979189791997920979219792297923979249792597926979279792897929979309793197932979339793497935979369793797938979399794097941979429794397944979459794697947979489794997950979519795297953979549795597956979579795897959979609796197962979639796497965979669796797968979699797097971979729797397974979759797697977979789797997980979819798297983979849798597986979879798897989979909799197992979939799497995979969799797998979999800098001980029800398004980059800698007980089800998010980119801298013980149801598016980179801898019980209802198022980239802498025980269802798028980299803098031980329803398034980359803698037980389803998040980419804298043980449804598046980479804898049980509805198052980539805498055980569805798058980599806098061980629806398064980659806698067980689806998070980719807298073980749807598076980779807898079980809808198082980839808498085980869808798088980899809098091980929809398094980959809698097980989809998100981019810298103981049810598106981079810898109981109811198112981139811498115981169811798118981199812098121981229812398124981259812698127981289812998130981319813298133981349813598136981379813898139981409814198142981439814498145981469814798148981499815098151981529815398154981559815698157981589815998160981619816298163981649816598166981679816898169981709817198172981739817498175981769817798178981799818098181981829818398184981859818698187981889818998190981919819298193981949819598196981979819898199982009820198202982039820498205982069820798208982099821098211982129821398214982159821698217982189821998220982219822298223982249822598226982279822898229982309823198232982339823498235982369823798238982399824098241982429824398244982459824698247982489824998250982519825298253982549825598256982579825898259982609826198262982639826498265982669826798268982699827098271982729827398274982759827698277982789827998280982819828298283982849828598286982879828898289982909829198292982939829498295982969829798298982999830098301983029830398304983059830698307983089830998310983119831298313983149831598316983179831898319983209832198322983239832498325983269832798328983299833098331983329833398334983359833698337983389833998340983419834298343983449834598346983479834898349983509835198352983539835498355983569835798358983599836098361983629836398364983659836698367983689836998370983719837298373983749837598376983779837898379983809838198382983839838498385983869838798388983899839098391983929839398394983959839698397983989839998400984019840298403984049840598406984079840898409984109841198412984139841498415984169841798418984199842098421984229842398424984259842698427984289842998430984319843298433984349843598436984379843898439984409844198442984439844498445984469844798448984499845098451984529845398454984559845698457984589845998460984619846298463984649846598466984679846898469984709847198472984739847498475984769847798478984799848098481984829848398484984859848698487984889848998490984919849298493984949849598496984979849898499985009850198502985039850498505985069850798508985099851098511985129851398514985159851698517985189851998520985219852298523985249852598526985279852898529985309853198532985339853498535985369853798538985399854098541985429854398544985459854698547985489854998550985519855298553985549855598556985579855898559985609856198562985639856498565985669856798568985699857098571985729857398574985759857698577985789857998580985819858298583985849858598586985879858898589985909859198592985939859498595985969859798598985999860098601986029860398604986059860698607986089860998610986119861298613986149861598616986179861898619986209862198622986239862498625986269862798628986299863098631986329863398634986359863698637986389863998640986419864298643986449864598646986479864898649986509865198652986539865498655986569865798658986599866098661986629866398664986659866698667986689866998670986719867298673986749867598676986779867898679986809868198682986839868498685986869868798688986899869098691986929869398694986959869698697986989869998700987019870298703987049870598706987079870898709987109871198712987139871498715987169871798718987199872098721987229872398724987259872698727987289872998730987319873298733987349873598736987379873898739987409874198742987439874498745987469874798748987499875098751987529875398754987559875698757987589875998760987619876298763987649876598766987679876898769987709877198772987739877498775987769877798778987799878098781987829878398784987859878698787987889878998790987919879298793987949879598796987979879898799988009880198802988039880498805988069880798808988099881098811988129881398814988159881698817988189881998820988219882298823988249882598826988279882898829988309883198832988339883498835988369883798838988399884098841988429884398844988459884698847988489884998850988519885298853988549885598856988579885898859988609886198862988639886498865988669886798868988699887098871988729887398874988759887698877988789887998880988819888298883988849888598886988879888898889988909889198892988939889498895988969889798898988999890098901989029890398904989059890698907989089890998910989119891298913989149891598916989179891898919989209892198922989239892498925989269892798928989299893098931989329893398934989359893698937989389893998940989419894298943989449894598946989479894898949989509895198952989539895498955989569895798958989599896098961989629896398964989659896698967989689896998970989719897298973989749897598976989779897898979989809898198982989839898498985989869898798988989899899098991989929899398994989959899698997989989899999000990019900299003990049900599006990079900899009990109901199012990139901499015990169901799018990199902099021990229902399024990259902699027990289902999030990319903299033990349903599036990379903899039990409904199042990439904499045990469904799048990499905099051990529905399054990559905699057990589905999060990619906299063990649906599066990679906899069990709907199072990739907499075990769907799078990799908099081990829908399084990859908699087990889908999090990919909299093990949909599096990979909899099991009910199102991039910499105991069910799108991099911099111991129911399114991159911699117991189911999120991219912299123991249912599126991279912899129991309913199132991339913499135991369913799138991399914099141991429914399144991459914699147991489914999150991519915299153991549915599156991579915899159991609916199162991639916499165991669916799168991699917099171991729917399174991759917699177991789917999180991819918299183991849918599186991879918899189991909919199192991939919499195991969919799198991999920099201992029920399204992059920699207992089920999210992119921299213992149921599216992179921899219992209922199222992239922499225992269922799228992299923099231992329923399234992359923699237992389923999240992419924299243992449924599246992479924899249992509925199252992539925499255992569925799258992599926099261992629926399264992659926699267992689926999270992719927299273992749927599276992779927899279992809928199282992839928499285992869928799288992899929099291992929929399294992959929699297992989929999300993019930299303993049930599306993079930899309993109931199312993139931499315993169931799318993199932099321993229932399324993259932699327993289932999330993319933299333993349933599336993379933899339993409934199342993439934499345993469934799348993499935099351993529935399354993559935699357993589935999360993619936299363993649936599366993679936899369993709937199372993739937499375993769937799378993799938099381993829938399384993859938699387993889938999390993919939299393993949939599396993979939899399994009940199402994039940499405994069940799408994099941099411994129941399414994159941699417994189941999420994219942299423994249942599426994279942899429994309943199432994339943499435994369943799438994399944099441994429944399444994459944699447994489944999450994519945299453994549945599456994579945899459994609946199462994639946499465994669946799468994699947099471994729947399474994759947699477994789947999480994819948299483994849948599486994879948899489994909949199492994939949499495994969949799498994999950099501995029950399504995059950699507995089950999510995119951299513995149951599516995179951899519995209952199522995239952499525995269952799528995299953099531995329953399534995359953699537995389953999540995419954299543995449954599546995479954899549995509955199552995539955499555995569955799558995599956099561995629956399564995659956699567995689956999570995719957299573995749957599576995779957899579995809958199582995839958499585995869958799588995899959099591995929959399594995959959699597995989959999600996019960299603996049960599606996079960899609996109961199612996139961499615996169961799618996199962099621996229962399624996259962699627996289962999630996319963299633996349963599636996379963899639996409964199642996439964499645996469964799648996499965099651996529965399654996559965699657996589965999660996619966299663996649966599666996679966899669996709967199672996739967499675996769967799678996799968099681996829968399684996859968699687996889968999690996919969299693996949969599696996979969899699997009970199702997039970499705997069970799708997099971099711997129971399714997159971699717997189971999720997219972299723997249972599726997279972899729997309973199732997339973499735997369973799738997399974099741997429974399744997459974699747997489974999750997519975299753997549975599756997579975899759997609976199762997639976499765997669976799768997699977099771997729977399774997759977699777997789977999780997819978299783997849978599786997879978899789997909979199792997939979499795997969979799798997999980099801998029980399804998059980699807998089980999810998119981299813998149981599816998179981899819998209982199822998239982499825998269982799828998299983099831998329983399834998359983699837998389983999840998419984299843998449984599846998479984899849998509985199852998539985499855998569985799858998599986099861998629986399864998659986699867998689986999870998719987299873998749987599876998779987899879998809988199882998839988499885998869988799888998899989099891998929989399894998959989699897998989989999900999019990299903999049990599906999079990899909999109991199912999139991499915999169991799918999199992099921999229992399924999259992699927999289992999930999319993299933999349993599936999379993899939999409994199942999439994499945999469994799948999499995099951999529995399954999559995699957999589995999960999619996299963999649996599966999679996899969999709997199972999739997499975999769997799978999799998099981999829998399984999859998699987999889998999990999919999299993999949999599996999979999899999100000100001100002100003100004100005100006100007100008100009100010100011100012100013100014100015100016100017100018100019100020100021100022100023100024100025100026100027100028100029100030100031100032100033100034100035100036100037100038100039100040100041100042100043100044100045100046100047100048100049100050100051100052100053100054100055100056100057100058100059100060100061100062100063100064100065100066100067100068100069100070100071100072100073100074100075100076100077100078100079100080100081100082100083100084100085100086100087100088100089100090100091100092100093100094100095100096100097100098100099100100100101100102100103100104100105100106100107100108100109100110100111100112100113100114100115100116100117100118100119100120100121100122100123100124100125100126100127100128100129100130100131100132100133100134100135100136100137100138100139100140100141100142100143100144100145100146100147100148100149100150100151100152100153100154100155100156100157100158100159100160100161100162100163100164100165100166100167100168100169100170100171100172100173100174100175100176100177100178100179100180100181100182100183100184100185100186100187100188100189100190100191100192100193100194100195100196100197100198100199100200100201100202100203100204100205100206100207100208100209100210100211100212100213100214100215100216100217100218100219100220100221100222100223100224100225100226100227100228100229100230100231100232100233100234100235100236100237100238100239100240100241100242100243100244100245100246100247100248100249100250100251100252100253100254100255100256100257100258100259100260100261100262100263100264100265100266100267100268100269100270100271100272100273100274100275100276100277100278100279100280100281100282100283100284100285100286100287100288100289100290100291100292100293100294100295100296100297100298100299100300100301100302100303100304100305100306100307100308100309100310100311100312100313100314100315100316100317100318100319100320100321100322100323100324100325100326100327100328100329100330100331100332100333100334100335100336100337100338100339100340100341100342100343100344100345100346100347100348100349100350100351100352100353100354100355100356100357100358100359100360100361100362100363100364100365100366100367100368100369100370100371100372100373100374100375100376100377100378100379100380100381100382100383100384100385100386100387100388100389100390100391100392100393100394100395100396100397100398100399100400100401100402100403100404100405100406100407100408100409100410100411100412100413100414100415100416100417100418100419100420100421100422100423100424100425100426100427100428100429100430100431100432100433100434100435100436100437100438100439100440100441100442100443100444100445100446100447100448100449100450100451100452100453100454100455100456100457100458100459100460100461100462100463100464100465100466100467100468100469100470100471100472100473100474100475100476100477100478100479100480100481100482100483100484100485100486100487100488100489100490100491100492100493100494100495100496100497100498100499100500100501100502100503100504100505100506100507100508100509100510100511100512100513100514100515100516100517100518100519100520100521100522100523100524100525100526100527100528100529100530100531100532100533100534100535100536100537100538100539100540100541100542100543100544100545100546100547100548100549100550100551100552100553100554100555100556100557100558100559100560100561100562100563100564100565100566100567100568100569100570100571100572100573100574100575100576100577100578100579100580100581100582100583100584100585100586100587100588100589100590100591100592100593100594100595100596100597100598100599100600100601100602100603100604100605100606100607100608100609100610100611100612100613100614100615100616100617100618100619100620100621100622100623100624100625100626100627100628100629100630100631100632100633100634100635100636100637100638100639100640100641100642100643100644100645100646100647100648100649100650100651100652100653100654100655100656100657100658100659100660100661100662100663100664100665100666100667100668100669100670100671100672100673100674100675100676100677100678100679100680100681100682100683100684100685100686100687100688100689100690100691100692100693100694100695100696100697100698100699100700100701100702100703100704100705100706100707100708100709100710100711100712100713100714100715100716100717100718100719100720100721100722100723100724100725100726100727100728100729100730100731100732100733100734100735100736100737100738100739100740100741100742100743100744100745100746100747100748100749100750100751100752100753100754100755100756100757100758100759100760100761100762100763100764100765100766100767100768100769100770100771100772100773100774100775100776100777100778100779100780100781100782100783100784100785100786100787100788100789100790100791100792100793100794100795100796100797100798100799100800100801100802100803100804100805100806100807100808100809100810100811100812100813100814100815100816100817100818100819100820100821100822100823100824100825100826100827100828100829100830100831100832100833100834100835100836100837100838100839100840100841100842100843100844100845100846100847100848100849100850100851100852100853100854100855100856100857100858100859100860100861100862100863100864100865100866100867100868100869100870100871100872100873100874100875100876100877100878100879100880100881100882100883100884100885100886100887100888100889100890100891100892100893100894100895100896100897100898100899100900100901100902100903100904100905100906100907100908100909100910100911100912100913100914100915100916100917100918100919100920100921100922100923100924100925100926100927100928100929100930100931100932100933100934100935100936100937100938100939100940100941100942100943100944100945100946100947100948100949100950100951100952100953100954100955100956100957100958100959100960100961100962100963100964100965100966100967100968100969100970100971100972100973100974100975100976100977100978100979100980100981100982100983100984100985100986100987100988100989100990100991100992100993100994100995100996100997100998100999101000101001101002101003101004101005101006101007101008101009101010101011101012101013101014101015101016101017101018101019101020101021101022101023101024101025101026101027101028101029101030101031101032101033101034101035101036101037101038101039101040101041101042101043101044101045101046101047101048101049101050101051101052101053101054101055101056101057101058101059101060101061101062101063101064101065101066101067101068101069101070101071101072101073101074101075101076101077101078101079101080101081101082101083101084101085101086101087101088101089101090101091101092101093101094101095101096101097101098101099101100101101101102101103101104101105101106101107101108101109101110101111101112101113101114101115101116101117101118101119101120101121101122101123101124101125101126101127101128101129101130101131101132101133101134101135101136101137101138101139101140101141101142101143101144101145101146101147101148101149101150101151101152101153101154101155101156101157101158101159101160101161101162101163101164101165101166101167101168101169101170101171101172101173101174101175101176101177101178101179101180101181101182101183101184101185101186101187101188101189101190101191101192101193101194101195101196101197101198101199101200101201101202101203101204101205101206101207101208101209101210101211101212101213101214101215101216101217101218101219101220101221101222101223101224101225101226101227101228101229101230101231101232101233101234101235101236101237101238101239101240101241101242101243101244101245101246101247101248101249101250101251101252101253101254101255101256101257101258101259101260101261101262101263101264101265101266101267101268101269101270101271101272101273101274101275101276101277101278101279101280101281101282101283101284101285101286101287101288101289101290101291101292101293101294101295101296101297101298101299101300101301101302101303101304101305101306101307101308101309101310101311101312101313101314101315101316101317101318101319101320101321101322101323101324101325101326101327101328101329101330101331101332101333101334101335101336101337101338101339101340101341101342101343101344101345101346101347101348101349101350101351101352101353101354101355101356101357101358101359101360101361101362101363101364101365101366101367101368101369101370101371101372101373101374101375101376101377101378101379101380101381101382101383101384101385101386101387101388101389101390101391101392101393101394101395101396101397101398101399101400101401101402101403101404101405101406101407101408101409101410101411101412101413101414101415101416101417101418101419101420101421101422101423101424101425101426101427101428101429101430101431101432101433101434101435101436101437101438101439101440101441101442101443101444101445101446101447101448101449101450101451101452101453101454101455101456101457101458101459101460101461101462101463101464101465101466101467101468101469101470101471101472101473101474101475101476101477101478101479101480101481101482101483101484101485101486101487101488101489101490101491101492101493101494101495101496101497101498101499101500101501101502101503101504101505101506101507101508101509101510101511101512101513101514101515101516101517101518101519101520101521101522101523101524101525101526101527101528101529101530101531101532101533101534101535101536101537101538101539101540101541101542101543101544101545101546101547101548101549101550101551101552101553101554101555101556101557101558101559101560101561101562101563101564101565101566101567101568101569101570101571101572101573101574101575101576101577101578101579101580101581101582101583101584101585101586101587101588101589101590101591101592101593101594101595101596101597101598101599101600101601101602101603101604101605101606101607101608101609101610101611101612101613101614101615101616101617101618101619101620101621101622101623101624101625101626101627101628101629101630101631101632101633101634101635101636101637101638101639101640101641101642101643101644101645101646101647101648101649101650101651101652101653101654101655101656101657101658101659101660101661101662101663101664101665101666101667101668101669101670101671101672101673101674101675101676101677101678101679101680101681101682101683101684101685101686101687101688101689101690101691101692101693101694101695101696101697101698101699101700101701101702101703101704101705101706101707101708101709101710101711101712101713101714101715101716101717101718101719101720101721101722101723101724101725101726101727101728101729101730101731101732101733101734101735101736101737101738101739101740101741101742101743101744101745101746101747101748101749101750101751101752101753101754101755101756101757101758101759101760101761101762101763101764101765101766101767101768101769101770101771101772101773101774101775101776101777101778101779101780101781101782101783101784101785101786101787101788101789101790101791101792101793101794101795101796101797101798101799101800101801101802101803101804101805101806101807101808101809101810101811101812101813101814101815101816101817101818101819101820101821101822101823101824101825101826101827101828101829101830101831101832101833101834101835101836101837101838101839101840101841101842101843101844101845101846101847101848101849101850101851101852101853101854101855101856101857101858101859101860101861101862101863101864101865101866101867101868101869101870101871101872101873101874101875101876101877101878101879101880101881101882101883101884101885101886101887101888101889101890101891101892101893101894101895101896101897101898101899101900101901101902101903101904101905101906101907101908101909101910101911101912101913101914101915101916101917101918101919101920101921101922101923101924101925101926101927101928101929101930101931101932101933101934101935101936101937101938101939101940101941101942101943101944101945101946101947101948101949101950101951101952101953101954101955101956101957101958101959101960101961101962101963101964101965101966101967101968101969101970101971101972101973101974101975101976101977101978101979101980101981101982101983101984101985101986101987101988101989101990101991101992101993101994101995101996101997101998101999102000102001102002102003102004102005102006102007102008102009102010102011102012102013102014102015102016102017102018102019102020102021102022102023102024102025102026102027102028102029102030102031102032102033102034102035102036102037102038102039102040102041102042102043102044102045102046102047102048102049102050102051102052102053102054102055102056102057102058102059102060102061102062102063102064102065102066102067102068102069102070102071102072102073102074102075102076102077102078102079102080102081102082102083102084102085102086102087102088102089102090102091102092102093102094102095102096102097102098102099102100102101102102102103102104102105102106102107102108102109102110102111102112102113102114102115102116102117102118102119102120102121102122102123102124102125102126102127102128102129102130102131102132102133102134102135102136102137102138102139102140102141102142102143102144102145102146102147102148102149102150102151102152102153102154102155102156102157102158102159102160102161102162102163102164102165102166102167102168102169102170102171102172102173102174102175102176102177102178102179102180102181102182102183102184102185102186102187102188102189102190102191102192102193102194102195102196102197102198102199102200102201102202102203102204102205102206102207102208102209102210102211102212102213102214102215102216102217102218102219102220102221102222102223102224102225102226102227102228102229102230102231102232102233102234102235102236102237102238102239102240102241102242102243102244102245102246102247102248102249102250102251102252102253102254102255102256102257102258102259102260102261102262102263102264102265102266102267102268102269102270102271102272102273102274102275102276102277102278102279102280102281102282102283102284102285102286102287102288102289102290102291102292102293102294102295102296102297102298102299102300102301102302102303102304102305102306102307102308102309102310102311102312102313102314102315102316102317102318102319102320102321102322102323102324102325102326102327102328102329102330102331102332102333102334102335102336102337102338102339102340102341102342102343102344102345102346102347102348102349102350102351102352102353102354102355102356102357102358102359102360102361102362102363102364102365102366102367102368102369102370102371102372102373102374102375102376102377102378102379102380102381102382102383102384102385102386102387102388102389102390102391102392102393102394102395102396102397102398102399102400102401102402102403102404102405102406102407102408102409102410102411102412102413102414102415102416102417102418102419102420102421102422102423102424102425102426102427102428102429102430102431102432102433102434102435102436102437102438102439102440102441102442102443102444102445102446102447102448102449102450102451102452102453102454102455102456102457102458102459102460102461102462102463102464102465102466102467102468102469102470102471102472102473102474102475102476102477102478102479102480102481102482102483102484102485102486102487102488102489102490102491102492102493102494102495102496102497102498102499102500102501102502102503102504102505102506102507102508102509102510102511102512102513102514102515102516102517102518102519102520102521102522102523102524102525102526102527102528102529102530102531102532102533102534102535102536102537102538102539102540102541102542102543102544102545102546102547102548102549102550102551102552102553102554102555102556102557102558102559102560102561102562102563102564102565102566102567102568102569102570102571102572102573102574102575102576102577102578102579102580102581102582102583102584102585102586102587102588102589102590102591102592102593102594102595102596102597102598102599102600102601102602102603102604102605102606102607102608102609102610102611102612102613102614102615102616102617102618102619102620102621102622102623102624102625102626102627102628102629102630102631102632102633102634102635102636102637102638102639102640102641102642102643102644102645102646102647102648102649102650102651102652102653102654102655102656102657102658102659102660102661102662102663102664102665102666102667102668102669102670102671102672102673102674102675102676102677102678102679102680102681102682102683102684102685102686102687102688102689102690102691102692102693102694102695102696102697102698102699102700102701102702102703102704102705102706102707102708102709102710102711102712102713102714102715102716102717102718102719102720102721102722102723102724102725102726102727102728102729102730102731102732102733102734102735102736102737102738102739102740102741102742102743102744102745102746102747102748102749102750102751102752102753102754102755102756102757102758102759102760102761102762102763102764102765102766102767102768102769102770102771102772102773102774102775102776102777102778102779102780102781102782102783102784102785102786102787102788102789102790102791102792102793102794102795102796102797102798102799102800102801102802102803102804102805102806102807102808102809102810102811102812102813102814102815102816102817102818102819102820102821102822102823102824102825102826102827102828102829102830102831102832102833102834102835102836102837102838102839102840102841102842102843102844102845102846102847102848102849102850102851102852102853102854102855102856102857102858102859102860102861102862102863102864102865102866102867102868102869102870102871102872102873102874102875102876102877102878102879102880102881102882102883102884102885102886102887102888102889102890102891102892102893102894102895102896102897102898102899102900102901102902102903102904102905102906102907102908102909102910102911102912102913102914102915102916102917102918102919102920102921102922102923102924102925102926102927102928102929102930102931102932102933102934102935102936102937102938102939102940102941102942102943102944102945102946102947102948102949102950102951102952102953102954102955102956102957102958102959102960102961102962102963102964102965102966102967102968102969102970102971102972102973102974102975102976102977102978102979102980102981102982102983102984102985102986102987102988102989102990102991102992102993102994102995102996102997102998102999103000103001103002103003103004103005103006103007103008103009103010103011103012103013103014103015103016103017103018103019103020103021103022103023103024103025103026103027103028103029103030103031103032103033103034103035103036103037103038103039103040103041103042103043103044103045103046103047103048103049103050103051103052103053103054103055103056103057103058103059103060103061103062103063103064103065103066103067103068103069103070103071103072103073103074103075103076103077103078103079103080103081103082103083103084103085103086103087103088103089103090103091103092103093103094103095103096103097103098103099103100103101103102103103103104103105103106103107103108103109103110103111103112103113103114103115103116103117103118103119103120103121103122103123103124103125103126103127103128103129103130103131103132103133103134103135103136103137103138103139103140103141103142103143103144103145103146103147103148103149103150103151103152103153103154103155103156103157103158103159103160103161103162103163103164103165103166103167103168103169103170103171103172103173103174103175103176103177103178103179103180103181103182103183103184103185103186103187103188103189103190103191103192103193103194103195103196103197103198103199103200103201103202103203103204103205103206103207103208103209103210103211103212103213103214103215103216103217103218103219103220103221103222103223103224103225103226103227103228103229103230103231103232103233103234103235103236103237103238103239103240103241103242103243103244103245103246103247103248103249103250103251103252103253103254103255103256103257103258103259103260103261103262103263103264103265103266103267103268103269103270103271103272103273103274103275103276103277103278103279103280103281103282103283103284103285103286103287103288103289103290103291103292103293103294103295103296103297103298103299103300103301103302103303103304103305103306103307103308103309103310103311103312103313103314103315103316103317103318103319103320103321103322103323103324103325103326103327103328103329103330103331103332103333103334103335103336103337103338103339103340103341103342103343103344103345103346103347103348103349103350103351103352103353103354103355103356103357103358103359103360103361103362103363103364103365103366103367103368103369103370103371103372103373103374103375103376103377103378103379103380103381103382103383103384103385103386103387103388103389103390103391103392103393103394103395103396103397103398103399103400103401103402103403103404103405103406103407103408103409103410103411103412103413103414103415103416103417103418103419103420103421103422103423103424103425103426103427103428103429103430103431103432103433103434103435103436103437103438103439103440103441103442103443103444103445103446103447103448103449103450103451103452103453103454103455103456103457103458103459103460103461103462103463103464103465103466103467103468103469103470103471103472103473103474103475103476103477103478103479103480103481103482103483103484103485103486103487103488103489103490103491103492103493103494103495103496103497103498103499103500103501103502103503103504103505103506103507103508103509103510103511103512103513103514103515103516103517103518103519103520103521103522103523103524103525103526103527103528103529103530103531103532103533103534103535103536103537103538103539103540103541103542103543103544103545103546103547103548103549103550103551103552103553103554103555103556103557103558103559103560103561103562103563103564103565103566103567103568103569103570103571103572103573103574103575103576103577103578103579103580103581103582103583103584103585103586103587103588103589103590103591103592103593103594103595103596103597103598103599103600103601103602103603103604103605103606103607103608103609103610103611103612103613103614103615103616103617103618103619103620103621103622103623103624103625103626103627103628103629103630103631103632103633103634103635103636103637103638103639103640103641103642103643103644103645103646103647103648103649103650103651103652103653103654103655103656103657103658103659103660103661103662103663103664103665103666103667103668103669103670103671103672103673103674103675103676103677103678103679103680103681103682103683103684103685103686103687103688103689103690103691103692103693103694103695103696103697103698103699103700103701103702103703103704103705103706103707103708103709103710103711103712103713103714103715103716103717103718103719103720103721103722103723103724103725103726103727103728103729103730103731103732103733103734103735103736103737103738103739103740103741103742103743103744103745103746103747103748103749103750103751103752103753103754103755103756103757103758103759103760103761103762103763103764103765103766103767103768103769103770103771103772103773103774103775103776103777103778103779103780103781103782103783103784103785103786103787103788103789103790103791103792103793103794103795103796103797103798103799103800103801103802103803103804103805103806103807103808103809103810103811103812103813103814103815103816103817103818103819103820103821103822103823103824103825103826103827103828103829103830103831103832103833103834103835103836103837103838103839103840103841103842103843103844103845103846103847103848103849103850103851103852103853103854103855103856103857103858103859103860103861103862103863103864103865103866103867103868103869103870103871103872103873103874103875103876103877103878103879103880103881103882103883103884103885103886103887103888103889103890103891103892103893103894103895103896103897103898103899103900103901103902103903103904103905103906103907103908103909103910103911103912103913103914103915103916103917103918103919103920103921103922103923103924103925103926103927103928103929103930103931103932103933103934103935103936103937103938103939103940103941103942103943103944103945103946103947103948103949103950103951103952103953103954103955103956103957103958103959103960103961103962103963103964103965103966103967103968103969103970103971103972103973103974103975103976103977103978103979103980103981103982103983103984103985103986103987103988103989103990103991103992103993103994103995103996103997103998103999104000104001104002104003104004104005104006104007104008104009104010104011104012104013104014104015104016104017104018104019104020104021104022104023104024104025104026104027104028104029104030104031104032104033104034104035104036104037104038104039104040104041104042104043104044104045104046104047104048104049104050104051104052104053104054104055104056104057104058104059104060104061104062104063104064104065104066104067104068104069104070104071104072104073104074104075104076104077104078104079104080104081104082104083104084104085104086104087104088104089104090104091104092104093104094104095104096104097104098104099104100104101104102104103104104104105104106104107104108104109104110104111104112104113104114104115104116104117104118104119104120104121104122104123104124104125104126104127104128104129104130104131104132104133104134104135104136104137104138104139104140104141104142104143104144104145104146104147104148104149104150104151104152104153104154104155104156104157104158104159104160104161104162104163104164104165104166104167104168104169104170104171104172104173104174104175104176104177104178104179104180104181104182104183104184104185104186104187104188104189104190104191104192104193104194104195104196104197104198104199104200104201104202104203104204104205104206104207104208104209104210104211104212104213104214104215104216104217104218104219104220104221104222104223104224104225104226104227104228104229104230104231104232104233104234104235104236104237104238104239104240104241104242104243104244104245104246104247104248104249104250104251104252104253104254104255104256104257104258104259104260104261104262104263104264104265104266104267104268104269104270104271104272104273104274104275104276104277104278104279104280104281104282104283104284104285104286104287104288104289104290104291104292104293104294104295104296104297104298104299104300104301104302104303104304104305104306104307104308104309104310104311104312104313104314104315104316104317104318104319104320104321104322104323104324104325104326104327104328104329104330104331104332104333104334104335104336104337104338104339104340104341104342104343104344104345104346104347104348104349104350104351104352104353104354104355104356104357104358104359104360104361104362104363104364104365104366104367104368104369104370104371104372104373104374104375104376104377104378104379104380104381104382104383104384104385104386104387104388104389104390104391104392104393104394104395104396104397104398104399104400104401104402104403104404104405104406104407104408104409104410104411104412104413104414104415104416104417104418104419104420104421104422104423104424104425104426104427104428104429104430104431104432104433104434104435104436104437104438104439104440104441104442104443104444104445104446104447104448104449104450104451104452104453104454104455104456104457104458104459104460104461104462104463104464104465104466104467104468104469104470104471104472104473104474104475104476104477104478104479104480104481104482104483104484104485104486104487104488104489104490104491104492104493104494104495104496104497104498104499104500104501104502104503104504104505104506104507104508104509104510104511104512104513104514104515104516104517104518104519104520104521104522104523104524104525104526104527104528104529104530104531104532104533104534104535104536104537104538104539104540104541104542104543104544104545104546104547104548104549104550104551104552104553104554104555104556104557104558104559104560104561104562104563104564104565104566104567104568104569104570104571104572104573104574104575104576104577104578104579104580104581104582104583104584104585104586104587104588104589104590104591104592104593104594104595104596104597104598104599104600104601104602104603104604104605104606104607104608104609104610104611104612104613104614104615104616104617104618104619104620104621104622104623104624104625104626104627104628104629104630104631104632104633104634104635104636104637104638104639104640104641104642104643104644104645104646104647104648104649104650104651104652104653104654104655104656104657104658104659104660104661104662104663104664104665104666104667104668104669104670104671104672104673104674104675104676104677104678104679104680104681104682104683104684104685104686104687104688104689104690104691104692104693104694104695104696104697104698104699104700104701104702104703104704104705104706104707104708104709104710104711104712104713104714104715104716104717104718104719104720104721104722104723104724104725104726104727104728104729104730104731104732104733104734104735104736104737104738104739104740104741104742104743104744104745104746104747104748104749104750104751104752104753104754104755104756104757104758104759104760104761104762104763104764104765104766104767104768104769104770104771104772104773104774104775104776104777104778104779104780104781104782104783104784104785104786104787104788104789104790104791104792104793104794104795104796104797104798104799104800104801104802104803104804104805104806104807104808104809104810104811104812104813104814104815104816104817104818104819104820104821104822104823104824104825104826104827104828104829104830104831104832104833104834104835104836104837104838104839104840104841104842104843104844104845104846104847104848104849104850104851104852104853104854104855104856104857104858104859104860104861104862104863104864104865104866104867104868104869104870104871104872104873104874104875104876104877104878104879104880104881104882104883104884104885104886104887104888104889104890104891104892104893104894104895104896104897104898104899104900104901104902104903104904104905104906104907104908104909104910104911104912104913104914104915104916104917104918104919104920104921104922104923104924104925104926104927104928104929104930104931104932104933104934104935104936104937104938104939104940104941104942104943104944104945104946104947104948104949104950104951104952104953104954104955104956104957104958104959104960104961104962104963104964104965104966104967104968104969104970104971104972104973104974104975104976104977104978104979104980104981104982104983104984104985104986104987104988104989104990104991104992104993104994104995104996104997104998104999105000105001105002105003105004105005105006105007105008105009105010105011105012105013105014105015105016105017105018105019105020105021105022105023105024105025105026105027105028105029105030105031105032105033105034105035105036105037105038105039105040105041105042105043105044105045105046105047105048105049105050105051105052105053105054105055105056105057105058105059105060105061105062105063105064105065105066105067105068105069105070105071105072105073105074105075105076105077105078105079105080105081105082105083105084105085105086105087105088105089105090105091105092105093105094105095105096105097105098105099105100105101105102105103105104105105105106105107105108105109105110105111105112105113105114105115105116105117105118105119105120105121105122105123105124105125105126105127105128105129105130105131105132105133105134105135105136105137105138105139105140105141105142105143105144105145105146105147105148105149105150105151105152105153105154105155105156105157105158105159105160105161105162105163105164105165105166105167105168105169105170105171105172105173105174105175105176105177105178105179105180105181105182105183105184105185105186105187105188105189105190105191105192105193105194105195105196105197105198105199105200105201105202105203105204105205105206105207105208105209105210105211105212105213105214105215105216105217105218105219105220105221105222105223105224105225105226105227105228105229105230105231105232105233105234105235105236105237105238105239105240105241105242105243105244105245105246105247105248105249105250105251105252105253105254105255105256105257105258105259105260105261105262105263105264105265105266105267105268105269105270105271105272105273105274105275105276105277105278105279105280105281105282105283105284105285105286105287105288105289105290105291105292105293105294105295105296105297105298105299105300105301105302105303105304105305105306105307105308105309105310105311105312105313105314105315105316105317105318105319105320105321105322105323105324105325105326105327105328105329105330105331105332105333105334105335105336105337105338105339105340105341105342105343105344105345105346105347105348105349105350105351105352105353105354105355105356105357105358105359105360105361105362105363105364105365105366105367105368105369105370105371105372105373105374105375105376105377105378105379105380105381105382105383105384105385105386105387105388105389105390105391105392105393105394105395105396105397105398105399105400105401105402105403105404105405105406105407105408105409105410105411105412105413105414105415105416105417105418105419105420105421105422105423105424105425105426105427105428105429105430105431105432105433105434105435105436105437105438105439105440105441105442105443105444105445105446105447105448105449105450105451105452105453105454105455105456105457105458105459105460105461105462105463105464105465105466105467105468105469105470105471105472105473105474105475105476105477105478105479105480105481105482105483105484105485105486105487105488105489105490105491105492105493105494105495105496105497105498105499105500105501105502105503105504105505105506105507105508105509105510105511105512105513105514105515105516105517105518105519105520105521105522105523105524105525105526105527105528105529105530105531105532105533105534105535105536105537105538105539105540105541105542105543105544105545105546105547105548105549105550105551105552105553105554105555105556105557105558105559105560105561105562105563105564105565105566105567105568105569105570105571105572105573105574105575105576105577105578105579105580105581105582105583105584105585105586105587105588105589105590105591105592105593105594105595105596105597105598105599105600105601105602105603105604105605105606105607105608105609105610105611105612105613105614105615105616105617105618105619105620105621105622105623105624105625105626105627105628105629105630105631105632105633105634105635105636105637105638105639105640105641105642105643105644105645105646105647105648105649105650105651105652105653105654105655105656105657105658105659105660105661105662105663105664105665105666105667105668105669105670105671105672105673105674105675105676105677105678105679105680105681105682105683105684105685105686105687105688105689105690105691105692105693105694105695105696105697105698105699105700105701105702105703105704105705105706105707105708105709105710105711105712105713105714105715105716105717105718105719105720105721105722105723105724105725105726105727105728105729105730105731105732105733105734105735105736105737105738105739105740105741105742105743105744105745105746105747105748105749105750105751105752105753105754105755105756105757105758105759105760105761105762105763105764105765105766105767105768105769105770105771105772105773105774105775105776105777105778105779105780105781105782105783105784105785105786105787105788105789105790105791105792105793105794105795105796105797105798105799105800105801105802105803105804105805105806105807105808105809105810105811105812105813105814105815105816105817105818105819105820105821105822105823105824105825105826105827105828105829105830105831105832105833105834105835105836105837105838105839105840105841105842105843105844105845105846105847105848105849105850105851105852105853105854105855105856105857105858105859105860105861105862105863105864105865105866105867105868105869105870105871105872105873105874105875105876105877105878105879105880105881105882105883105884105885105886105887105888105889105890105891105892105893105894105895105896105897105898105899105900105901105902105903105904105905105906105907105908105909105910105911105912105913105914105915105916105917105918105919105920105921105922105923105924105925105926105927105928105929105930105931105932105933105934105935105936105937105938105939105940105941105942105943105944105945105946105947105948105949105950105951105952105953105954105955105956105957105958105959105960105961105962105963105964105965105966105967105968105969105970105971105972105973105974105975105976105977105978105979105980105981105982105983105984105985105986105987105988105989105990105991105992105993105994105995105996105997105998105999106000106001106002106003106004106005106006106007106008106009106010106011106012106013106014106015106016106017106018106019106020106021106022106023106024106025106026106027106028106029106030106031106032106033106034106035106036106037106038106039106040106041106042106043106044106045106046106047106048106049106050106051106052106053106054106055106056106057106058106059106060106061106062106063106064106065106066106067106068106069106070106071106072106073106074106075106076106077106078106079106080106081106082106083106084106085106086106087106088106089106090106091106092106093106094106095106096106097106098106099106100106101106102106103106104106105106106106107106108106109106110106111106112106113106114106115106116106117106118106119106120106121106122106123106124106125106126106127106128106129106130106131106132106133106134106135106136106137106138106139106140106141106142106143106144106145106146106147106148106149106150106151106152106153106154106155106156106157106158106159106160106161106162106163106164106165106166106167106168106169106170106171106172106173106174106175106176106177106178106179106180106181106182106183106184106185106186106187106188106189106190106191106192106193106194106195106196106197106198106199106200106201106202106203106204106205106206106207106208106209106210106211106212106213106214106215106216106217106218106219106220106221106222106223106224106225106226106227106228106229106230106231106232106233106234106235106236106237106238106239106240106241106242106243106244106245106246106247106248106249106250106251106252106253106254106255106256106257106258106259106260106261106262106263106264106265106266106267106268106269106270106271106272106273106274106275106276106277106278106279106280106281106282106283106284106285106286106287106288106289106290106291106292106293106294106295106296106297106298106299106300106301106302106303106304106305106306106307106308106309106310106311106312106313106314106315106316106317106318106319106320106321106322106323106324106325106326106327106328106329106330106331106332106333106334106335106336106337106338106339106340106341106342106343106344106345106346106347106348106349106350106351106352106353106354106355106356106357106358106359106360106361106362106363106364106365106366106367106368106369106370106371106372106373106374106375106376106377106378106379106380106381106382106383106384106385106386106387106388106389106390106391106392106393106394106395106396106397106398106399106400106401106402106403106404106405106406106407106408106409106410106411106412106413106414106415106416106417106418106419106420106421106422106423106424106425106426106427106428106429106430106431106432106433106434106435106436106437106438106439106440106441106442106443106444106445106446106447106448106449106450106451106452106453106454106455106456106457106458106459106460106461106462106463106464106465106466106467106468106469106470106471106472106473106474106475106476106477106478106479106480106481106482106483106484106485106486106487106488106489106490106491106492106493106494106495106496106497106498106499106500106501106502106503106504106505106506106507106508106509106510106511106512106513106514106515106516106517106518106519106520106521106522106523106524106525106526106527106528106529106530106531106532106533106534106535106536106537106538106539106540106541106542106543106544106545106546106547106548106549106550106551106552106553106554106555106556106557106558106559106560106561106562106563106564106565106566106567106568106569106570106571106572106573106574106575106576106577106578106579106580106581106582106583106584106585106586106587106588106589106590106591106592106593106594106595106596106597106598106599106600106601106602106603106604106605106606106607106608106609106610106611106612106613106614106615106616106617106618106619106620106621106622106623106624106625106626106627106628106629106630106631106632106633106634106635106636106637106638106639106640106641106642106643106644106645106646106647106648106649106650106651106652106653106654106655106656106657106658106659106660106661106662106663106664106665106666106667106668106669106670106671106672106673106674106675106676106677106678106679106680106681106682106683106684106685106686106687106688106689106690106691106692106693106694106695106696106697106698106699106700106701106702106703106704106705106706106707106708106709106710106711106712106713106714106715106716106717106718106719106720106721106722106723106724106725106726106727106728106729106730106731106732106733106734106735106736106737106738106739106740106741106742106743106744106745106746106747106748106749106750106751106752106753106754106755106756106757106758106759106760106761106762106763106764106765106766106767106768106769106770106771106772106773106774106775106776106777106778106779106780106781106782106783106784106785106786106787106788106789106790106791106792106793106794106795106796106797106798106799106800106801106802106803106804106805106806106807106808106809106810106811106812106813106814106815106816106817106818106819106820106821106822106823106824106825106826106827106828106829106830106831106832106833106834106835106836106837106838106839106840106841106842106843106844106845106846106847106848106849106850106851106852106853106854106855106856106857106858106859106860106861106862106863106864106865106866106867106868106869106870106871106872106873106874106875106876106877106878106879106880106881106882106883106884106885106886106887106888106889106890106891106892106893106894106895106896106897106898106899106900106901106902106903106904106905106906106907106908106909106910106911106912106913106914106915106916106917106918106919106920106921106922106923106924106925106926106927106928106929106930106931106932106933106934106935106936106937106938106939106940106941106942106943106944106945106946106947106948106949106950106951106952106953106954106955106956106957106958106959106960106961106962106963106964106965106966106967106968106969106970106971106972106973106974106975106976106977106978106979106980106981106982106983106984106985106986106987106988106989106990106991106992106993106994106995106996106997106998106999107000107001107002107003107004107005107006107007107008107009107010107011107012107013107014107015107016107017107018107019107020107021107022107023107024107025107026107027107028107029107030107031107032107033107034107035107036107037107038107039107040107041107042107043107044107045107046107047107048107049107050107051107052107053107054107055107056107057107058107059107060107061107062107063107064107065107066107067107068107069107070107071107072107073107074107075107076107077107078107079107080107081107082107083107084107085107086107087107088107089107090107091107092107093107094107095107096107097107098107099107100107101107102107103107104107105107106107107107108107109107110107111107112107113107114107115107116107117107118107119107120107121107122107123107124107125107126107127107128107129107130107131107132107133107134107135107136107137107138107139107140107141107142107143107144107145107146107147107148107149107150107151107152107153107154107155107156107157107158107159107160107161107162107163107164107165107166107167107168107169107170107171107172107173107174107175107176107177107178107179107180107181107182107183107184107185107186107187107188107189107190107191107192107193107194107195107196107197107198107199107200107201107202107203107204107205107206107207107208107209107210107211107212107213107214107215107216107217107218107219107220107221107222107223107224107225107226107227107228107229107230107231107232107233107234107235107236107237107238107239107240107241107242107243107244107245107246107247107248107249107250107251107252107253107254107255107256107257107258107259107260107261107262107263107264107265107266107267107268107269107270107271107272107273107274107275107276107277107278107279107280107281107282107283107284107285107286107287107288107289107290107291107292107293107294107295107296107297107298107299107300107301107302107303107304107305107306107307107308107309107310107311107312107313107314107315107316107317107318107319107320107321107322107323107324107325107326107327107328107329107330107331107332107333107334107335107336107337107338107339107340107341107342107343107344107345107346107347107348107349107350107351107352107353107354107355107356107357107358107359107360107361107362107363107364107365107366107367107368107369107370107371107372107373107374107375107376107377107378107379107380107381107382107383107384107385107386107387107388107389107390107391107392107393107394107395107396107397107398107399107400107401107402107403107404107405107406107407107408107409107410107411107412107413107414107415107416107417107418107419107420107421107422107423107424107425107426107427107428107429107430107431107432107433107434107435107436107437107438107439107440107441107442107443107444107445107446107447107448107449107450107451107452107453107454107455107456107457107458107459107460107461107462107463107464107465107466107467107468107469107470107471107472107473107474107475107476107477107478107479107480107481107482107483107484107485107486107487107488107489107490107491107492107493107494107495107496107497107498107499107500107501107502107503107504107505107506107507107508107509107510107511107512107513107514107515107516107517107518107519107520107521107522107523107524107525107526107527107528107529107530107531107532107533107534107535107536107537107538107539107540107541107542107543107544107545107546107547107548107549107550107551107552107553107554107555107556107557107558107559107560107561107562107563107564107565107566107567107568107569107570107571107572107573107574107575107576107577107578107579107580107581107582107583107584107585107586107587107588107589107590107591107592107593107594107595107596107597107598107599107600107601107602107603107604107605107606107607107608107609107610107611107612107613107614107615107616107617107618107619107620107621107622107623107624107625107626107627107628107629107630107631107632107633107634107635107636107637107638107639107640107641107642107643107644107645107646107647107648107649107650107651107652107653107654107655107656107657107658107659107660107661107662107663107664107665107666107667107668107669107670107671107672107673107674107675107676107677107678107679107680107681107682107683107684107685107686107687107688107689107690107691107692107693107694107695107696107697107698107699107700107701107702107703107704107705107706107707107708107709107710107711107712107713107714107715107716107717107718107719107720107721107722107723107724107725107726107727107728107729107730107731107732107733107734107735107736107737107738107739107740107741107742107743107744107745107746107747107748107749107750107751107752107753107754107755107756107757107758107759107760107761107762107763107764107765107766107767107768107769107770107771107772107773107774107775107776107777107778107779107780107781107782107783107784107785107786107787107788107789107790107791107792107793107794107795107796107797107798107799107800107801107802107803107804107805107806107807107808107809107810107811107812107813107814107815107816107817107818107819107820107821107822107823107824107825107826107827107828107829107830107831107832107833107834107835107836107837107838107839107840107841107842107843107844107845107846107847107848107849107850107851107852107853107854107855107856107857107858107859107860107861107862107863107864107865107866107867107868107869107870107871107872107873107874107875107876107877107878107879107880107881107882107883107884107885107886107887107888107889107890107891107892107893107894107895107896107897107898107899107900107901107902107903107904107905107906107907107908107909107910107911107912107913107914107915107916107917107918107919107920107921107922107923107924107925107926107927107928107929107930107931107932107933107934107935107936107937107938107939107940107941107942107943107944107945107946107947107948107949107950107951107952107953107954107955107956107957107958107959107960107961107962107963107964107965107966107967107968107969107970107971107972107973107974107975107976107977107978107979107980107981107982107983107984107985107986107987107988107989107990107991107992107993107994107995107996107997107998107999108000108001108002108003108004108005108006108007108008108009108010108011108012108013108014108015108016108017108018108019108020108021108022108023108024108025108026108027108028108029108030108031108032108033108034108035108036108037108038108039108040108041108042108043108044108045108046108047108048108049108050108051108052108053108054108055108056108057108058108059108060108061108062108063108064108065108066108067108068108069108070108071108072108073108074108075108076108077108078108079108080108081108082108083108084108085108086108087108088108089108090108091108092108093108094108095108096108097108098108099108100108101108102108103108104108105108106108107108108108109108110108111108112108113108114108115108116108117108118108119108120108121108122108123108124108125108126108127108128108129108130108131108132108133108134108135108136108137108138108139108140108141108142108143108144108145108146108147108148108149108150108151108152108153108154108155108156108157108158108159108160108161108162108163108164108165108166108167108168108169108170108171108172108173108174108175108176108177108178108179108180108181108182108183108184108185108186108187108188108189108190108191108192108193108194108195108196108197108198108199108200108201108202108203108204108205108206108207108208108209108210108211108212108213108214108215108216108217108218108219108220108221108222108223108224108225108226108227108228108229108230108231108232108233108234108235108236108237108238108239108240108241108242108243108244108245108246108247108248108249108250108251108252108253108254108255108256108257108258108259108260108261108262108263108264108265108266108267108268108269108270108271108272108273108274108275108276108277108278108279108280108281108282108283108284108285108286108287108288108289108290108291108292108293108294108295108296108297108298108299108300108301108302108303108304108305108306108307108308108309108310108311108312108313108314108315108316108317108318108319108320108321108322108323108324108325108326108327108328108329108330108331108332108333108334108335108336108337108338108339108340108341108342108343108344108345108346108347108348108349108350108351108352108353108354108355108356108357108358108359108360108361108362108363108364108365108366108367108368108369108370108371108372108373108374108375108376108377108378108379108380108381108382108383108384108385108386108387108388108389108390108391108392108393108394108395108396108397108398108399108400108401108402108403108404108405108406108407108408108409108410108411108412108413108414108415108416108417108418108419108420108421108422108423108424108425108426108427108428108429108430108431108432108433108434108435108436108437108438108439108440108441108442108443108444108445108446108447108448108449108450108451108452108453108454108455108456108457108458108459108460108461108462108463108464108465108466108467108468108469108470108471108472108473108474108475108476108477108478108479108480108481108482108483108484108485108486108487108488108489108490108491108492108493108494108495108496108497108498108499108500108501108502108503108504108505108506108507108508108509108510108511108512108513108514108515108516108517108518108519108520108521108522108523108524108525108526108527108528108529108530108531108532108533108534108535108536108537108538108539108540108541108542108543108544108545108546108547108548108549108550108551108552108553108554108555108556108557108558108559108560108561108562108563108564108565108566108567108568108569108570108571108572108573108574108575108576108577108578108579108580108581108582108583108584108585108586108587108588108589108590108591108592108593108594108595108596108597108598108599108600108601108602108603108604108605108606108607108608108609108610108611108612108613108614108615108616108617108618108619108620108621108622108623108624108625108626108627108628108629108630108631108632108633108634108635108636108637108638108639108640108641108642108643108644108645108646108647108648108649108650108651108652108653108654108655108656108657108658108659108660108661108662108663108664108665108666108667108668108669108670108671108672108673108674108675108676108677108678108679108680108681108682108683108684108685108686108687108688108689108690108691108692108693108694108695108696108697108698108699108700108701108702108703108704108705108706108707108708108709108710108711108712108713108714108715108716108717108718108719108720108721108722108723108724108725108726108727108728108729108730108731108732108733108734108735108736108737108738108739108740108741108742108743108744108745108746108747108748108749108750108751108752108753108754108755108756108757108758108759108760108761108762108763108764108765108766108767108768108769108770108771108772108773108774108775108776108777108778108779108780108781108782108783108784108785108786108787108788108789108790108791108792108793108794108795108796108797108798108799108800108801108802108803108804108805108806108807108808108809108810108811108812108813108814108815108816108817108818108819108820108821108822108823108824108825108826108827108828108829108830108831108832108833108834108835108836108837108838108839108840108841108842108843108844108845108846108847108848108849108850108851108852108853108854108855108856108857108858108859108860108861108862108863108864108865108866108867108868108869108870108871108872108873108874108875108876108877108878108879108880108881108882108883108884108885108886108887108888108889108890108891108892108893108894108895108896108897108898108899108900108901108902108903108904108905108906108907108908108909108910108911108912108913108914108915108916108917108918108919108920108921108922108923108924108925108926108927108928108929108930108931108932108933108934108935108936108937108938108939108940108941108942108943108944108945108946108947108948108949108950108951108952108953108954108955108956108957108958108959108960108961108962108963108964108965108966108967108968108969108970108971108972108973108974108975108976108977108978108979108980108981108982108983108984108985108986108987108988108989108990108991108992108993108994108995108996108997108998108999109000109001109002109003109004109005109006109007109008109009109010109011109012109013109014109015109016109017109018109019109020109021109022109023109024109025109026109027109028109029109030109031109032109033109034109035109036109037109038109039109040109041109042109043109044109045109046109047109048109049109050109051109052109053109054109055109056109057109058109059109060109061109062109063109064109065109066109067109068109069109070109071109072109073109074109075109076109077109078109079109080109081109082109083109084109085109086109087109088109089109090109091109092109093109094109095109096109097109098109099109100109101109102109103109104109105109106109107109108109109109110109111109112109113109114109115109116109117109118109119109120109121109122109123109124109125109126109127109128109129109130109131109132109133109134109135109136109137109138109139109140109141109142109143109144109145109146109147109148109149109150109151109152109153109154109155109156109157109158109159109160109161109162109163109164109165109166109167109168109169109170109171109172109173109174109175109176109177109178109179109180109181109182109183109184109185109186109187109188109189109190109191109192109193109194109195109196109197109198109199109200109201109202109203109204109205109206109207109208109209109210109211109212109213109214109215109216109217109218109219109220109221109222109223109224109225109226109227109228109229109230109231109232109233109234109235109236109237109238109239109240109241109242109243109244109245109246109247109248109249109250109251109252109253109254109255109256109257109258109259109260109261109262109263109264109265109266109267109268109269109270109271109272109273109274109275109276109277109278109279109280109281109282109283109284109285109286109287109288109289109290109291109292109293109294109295109296109297109298109299109300109301109302109303109304109305109306109307109308109309109310109311109312109313109314109315109316109317109318109319109320109321109322109323109324109325109326109327109328109329109330109331109332109333109334109335109336109337109338109339109340109341109342109343109344109345109346109347109348109349109350109351109352109353109354109355109356109357109358109359109360109361109362109363109364109365109366109367109368109369109370109371109372109373109374109375109376109377109378109379109380109381109382109383109384109385109386109387109388109389109390109391109392109393109394109395109396109397109398109399109400109401109402109403109404109405109406109407109408109409109410109411109412109413109414109415109416109417109418109419109420109421109422109423109424109425109426109427109428109429109430109431109432109433109434109435109436109437109438109439109440109441109442109443109444109445109446109447109448109449109450109451109452109453109454109455109456109457109458109459109460109461109462109463109464109465109466109467109468109469109470109471109472109473109474109475109476109477109478109479109480109481109482109483109484109485109486109487109488109489109490109491109492109493109494109495109496109497109498109499109500109501109502109503109504109505109506109507109508109509109510109511109512109513109514109515109516109517109518109519109520109521109522109523109524109525109526109527109528109529109530109531109532109533109534109535109536109537109538109539109540109541109542109543109544109545109546109547109548109549109550109551109552109553109554109555109556109557109558109559109560109561109562109563109564109565109566109567109568109569109570109571109572109573109574109575109576109577109578109579109580109581109582109583109584109585109586109587109588109589109590109591109592109593109594109595109596109597109598109599109600109601109602109603109604109605109606109607109608109609109610109611109612109613109614109615109616109617109618109619109620109621109622109623109624109625109626109627109628109629109630109631109632109633109634109635109636109637109638109639109640109641109642109643109644109645109646109647109648109649109650109651109652109653109654109655109656109657109658109659109660109661109662109663109664109665109666109667109668109669109670109671109672109673109674109675109676109677109678109679109680109681109682109683109684109685109686109687109688109689109690109691109692109693109694109695109696109697109698109699109700109701109702109703109704109705109706109707109708109709109710109711109712109713109714109715109716109717109718109719109720109721109722109723109724109725109726109727109728109729109730109731109732109733109734109735109736109737109738109739109740109741109742109743109744109745109746109747109748109749109750109751109752109753109754109755109756109757109758109759109760109761109762109763109764109765109766109767109768109769109770109771109772109773109774109775109776109777109778109779109780109781109782109783109784109785109786109787109788109789109790109791109792109793109794109795109796109797109798109799109800109801109802109803109804109805109806109807109808109809109810109811109812109813109814109815109816109817109818109819109820109821109822109823109824109825109826109827109828109829109830109831109832109833109834109835109836109837109838109839109840109841109842109843109844109845109846109847109848109849109850109851109852109853109854109855109856109857109858109859109860109861109862109863109864109865109866109867109868109869109870109871109872109873109874109875109876109877109878109879109880109881109882109883109884109885109886109887109888109889109890109891109892109893109894109895109896109897109898109899109900109901109902109903109904109905109906109907109908109909109910109911109912109913109914109915109916109917109918109919109920109921109922109923109924109925109926109927109928109929109930109931109932109933109934109935109936109937109938109939109940109941109942109943109944109945109946109947109948109949109950109951109952109953109954109955109956109957109958109959109960109961109962109963109964109965109966109967109968109969109970109971109972109973109974109975109976109977109978109979109980109981109982109983109984109985109986109987109988109989109990109991109992109993109994109995109996109997109998109999110000110001110002110003110004110005110006110007110008110009110010110011110012110013110014110015110016110017110018110019110020110021110022110023110024110025110026110027110028110029110030110031110032110033110034110035110036110037110038110039110040110041110042110043110044110045110046110047110048110049110050110051110052110053110054110055110056110057110058110059110060110061110062110063110064110065110066110067110068110069110070110071110072110073110074110075110076110077110078110079110080110081110082110083110084110085110086110087110088110089110090110091110092110093110094110095110096110097110098110099110100110101110102110103110104110105110106110107110108110109110110110111110112110113110114110115110116110117110118110119110120110121110122110123110124110125110126110127110128110129110130110131110132110133110134110135110136110137110138110139110140110141110142110143110144110145110146110147110148110149110150110151110152110153110154110155110156110157110158110159110160110161110162110163110164110165110166110167110168110169110170110171110172110173110174110175110176110177110178110179110180110181110182110183110184110185110186110187110188110189110190110191110192110193110194110195110196110197110198110199110200110201110202110203110204110205110206110207110208110209110210110211110212110213110214110215110216110217110218110219110220110221110222110223110224110225110226110227110228110229110230110231110232110233110234110235110236110237110238110239110240110241110242110243110244110245110246110247110248110249110250110251110252110253110254110255110256110257110258110259110260110261110262110263110264110265110266110267110268110269110270110271110272110273110274110275110276110277110278110279110280110281110282110283110284110285110286110287110288110289110290110291110292110293110294110295110296110297110298110299110300110301110302110303110304110305110306110307110308110309110310110311110312110313110314110315110316110317110318110319110320110321110322110323110324110325110326110327110328110329110330110331110332110333110334110335110336110337110338110339110340110341110342110343110344110345110346110347110348110349110350110351110352110353110354110355110356110357110358110359110360110361110362110363110364110365110366110367110368110369110370110371110372110373110374110375110376110377110378110379110380110381110382110383110384110385110386110387110388110389110390110391110392110393110394110395110396110397110398110399110400110401110402110403110404110405110406110407110408110409110410110411110412110413110414110415110416110417110418110419110420110421110422110423110424110425110426110427110428110429110430110431110432110433110434110435110436110437110438110439110440110441110442110443110444110445110446110447110448110449110450110451110452110453110454110455110456110457110458110459110460110461110462110463110464110465110466110467110468110469110470110471110472110473110474110475110476110477110478110479110480110481110482110483110484110485110486110487110488110489110490110491110492110493110494110495110496110497110498110499110500110501110502110503110504110505110506110507110508110509110510110511110512110513110514110515110516110517110518110519110520110521110522110523110524110525110526110527110528110529110530110531110532110533110534110535110536110537110538110539110540110541110542110543110544110545110546110547110548110549110550110551110552110553110554110555110556110557110558110559110560110561110562110563110564110565110566110567110568110569110570110571110572110573110574110575110576110577110578110579110580110581110582110583110584110585110586110587110588110589110590110591110592110593110594110595110596110597110598110599110600110601110602110603110604110605110606110607110608110609110610110611110612110613110614110615110616110617110618110619110620110621110622110623110624110625110626110627110628110629110630110631110632110633110634110635110636110637110638110639110640110641110642110643110644110645110646110647110648110649110650110651110652110653110654110655110656110657110658110659110660110661110662110663110664110665110666110667110668110669110670110671110672110673110674110675110676110677110678110679110680110681110682110683110684110685110686110687110688110689110690110691110692110693110694110695110696110697110698110699110700110701110702110703110704110705110706110707110708110709110710110711110712110713110714110715110716110717110718110719110720110721110722110723110724110725110726110727110728110729110730110731110732110733110734110735110736110737110738110739110740110741110742110743110744110745110746110747110748110749110750110751110752110753110754110755110756110757110758110759110760110761110762110763110764110765110766110767110768110769110770110771110772110773110774110775110776110777110778110779110780110781110782110783110784110785110786110787110788110789110790110791110792110793110794110795110796110797110798110799110800110801110802110803110804110805110806110807110808110809110810110811110812110813110814110815110816110817110818110819110820110821110822110823110824110825110826110827110828110829110830110831110832110833110834110835110836110837110838110839110840110841110842110843110844110845110846110847110848110849110850110851110852110853110854110855110856110857110858110859110860110861110862110863110864110865110866110867110868110869110870110871110872110873110874110875110876110877110878110879110880110881110882110883110884110885110886110887110888110889110890110891110892110893110894110895110896110897110898110899110900110901110902110903110904110905110906110907110908110909110910110911110912110913110914110915110916110917110918110919110920110921110922110923110924110925110926110927110928110929110930110931110932110933110934110935110936110937110938110939110940110941110942110943110944110945110946110947110948110949110950110951110952110953110954110955110956110957110958110959110960110961110962110963110964110965110966110967110968110969110970110971110972110973110974110975110976110977110978110979110980110981110982110983110984110985110986110987110988110989110990110991110992110993110994110995110996110997110998110999111000111001111002111003111004111005111006111007111008111009111010111011111012111013111014111015111016111017111018111019111020111021111022111023111024111025111026111027111028111029111030111031111032111033111034111035111036111037111038111039111040111041111042111043111044111045111046111047111048111049111050111051111052111053111054111055111056111057111058111059111060111061111062111063111064111065111066111067111068111069111070111071111072111073111074111075111076111077111078111079111080111081111082111083111084111085111086111087111088111089111090111091111092111093111094111095111096111097111098111099111100111101111102111103111104111105111106111107111108111109111110111111111112111113111114111115111116111117111118111119111120111121111122111123111124111125111126111127111128111129111130111131111132111133111134111135111136111137111138111139111140111141111142111143111144111145111146111147111148111149111150111151111152111153111154111155111156111157111158111159111160111161111162111163111164111165111166111167111168111169111170111171111172111173111174111175111176111177111178111179111180111181111182111183111184111185111186111187111188111189111190111191111192111193111194111195111196111197111198111199111200111201111202111203111204111205111206111207111208111209111210111211111212111213111214111215111216111217111218111219111220111221111222111223111224111225111226111227111228111229111230111231111232111233111234111235111236111237111238111239111240111241111242111243111244111245111246111247111248111249111250111251111252111253111254111255111256111257111258111259111260111261111262111263111264111265111266111267111268111269111270111271111272111273111274111275111276111277111278111279111280111281111282111283111284111285111286111287111288111289111290111291111292111293111294111295111296111297111298111299111300111301111302111303111304111305111306111307111308111309111310111311111312111313111314111315111316111317111318111319111320111321111322111323111324111325111326111327111328111329111330111331111332111333111334111335111336111337111338111339111340111341111342111343111344111345111346111347111348111349111350111351111352111353111354111355111356111357111358111359111360111361111362111363111364111365111366111367111368111369111370111371111372111373111374111375111376111377111378111379111380111381111382111383111384111385111386111387111388111389111390111391111392111393111394111395111396111397111398111399111400111401111402111403111404111405111406111407111408111409111410111411111412111413111414111415111416111417111418111419111420111421111422111423111424111425111426111427111428111429111430111431111432111433111434111435111436111437111438111439111440111441111442111443111444111445111446111447111448111449111450111451111452111453111454111455111456111457111458111459111460111461111462111463111464111465111466111467111468111469111470111471111472111473111474111475111476111477111478111479111480111481111482111483111484111485111486111487111488111489111490111491111492111493111494111495111496111497111498111499111500111501111502111503111504111505111506111507111508111509111510111511111512111513111514111515111516111517111518111519111520111521111522111523111524111525111526111527111528111529111530111531111532111533111534111535111536111537111538111539111540111541111542111543111544111545111546111547111548111549111550111551111552111553111554111555111556111557111558111559111560111561111562111563111564111565111566111567111568111569111570111571111572111573111574111575111576111577111578111579111580111581111582111583111584111585111586111587111588111589111590111591111592111593111594111595111596111597111598111599111600111601111602111603111604111605111606111607111608111609111610111611111612111613111614111615111616111617111618111619111620111621111622111623111624111625111626111627111628111629111630111631111632111633111634111635111636111637111638111639111640111641111642111643111644111645111646111647111648111649111650111651111652111653111654111655111656111657111658111659111660111661111662111663111664111665111666111667111668111669111670111671111672111673111674111675111676111677111678111679111680111681111682111683111684111685111686111687111688111689111690111691111692111693111694111695111696111697111698111699111700111701111702111703111704111705111706111707111708111709111710111711111712111713111714111715111716111717111718111719111720111721111722111723111724111725111726111727111728111729111730111731111732111733111734111735111736111737111738111739111740111741111742111743111744111745111746111747111748111749111750111751111752111753111754111755111756111757111758111759111760111761111762111763111764111765111766111767111768111769111770111771111772111773111774111775111776111777111778111779111780111781111782111783111784111785111786111787111788111789111790111791111792111793111794111795111796111797111798111799111800111801111802111803111804111805111806111807111808111809111810111811111812111813111814111815111816111817111818111819111820111821111822111823111824111825111826111827111828111829111830111831111832111833111834111835111836111837111838111839111840111841111842111843111844111845111846111847111848111849111850111851111852111853111854111855111856111857111858111859111860111861111862111863111864111865111866111867111868111869111870111871111872111873111874111875111876111877111878111879111880111881111882111883111884111885111886111887111888111889111890111891111892111893111894111895111896111897111898111899111900111901111902111903111904111905111906111907111908111909111910111911111912111913111914111915111916111917111918111919111920111921111922111923111924111925111926111927111928111929111930111931111932111933111934111935111936111937111938111939111940111941111942111943111944111945111946111947111948111949111950111951111952111953111954111955111956111957111958111959111960111961111962111963111964111965111966111967111968111969111970111971111972111973111974111975111976111977111978111979111980111981111982111983111984111985111986111987111988111989111990111991111992111993111994111995111996111997111998111999112000112001112002112003112004112005112006112007112008112009112010112011112012112013112014112015112016112017112018112019112020112021112022112023112024112025112026112027112028112029112030112031112032112033112034112035112036112037112038112039112040112041112042112043112044112045112046112047112048112049112050112051112052112053112054112055112056112057112058112059112060112061112062112063112064112065112066112067112068112069112070112071112072112073112074112075112076112077112078112079112080112081112082112083112084112085112086112087112088112089112090112091112092112093112094112095112096112097112098112099112100112101112102112103112104112105112106112107112108112109112110112111112112112113112114112115112116112117112118112119112120112121112122112123112124112125112126112127112128112129112130112131112132112133112134112135112136112137112138112139112140112141112142112143112144112145112146112147112148112149112150112151112152112153112154112155112156112157112158112159112160112161112162112163112164112165112166112167112168112169112170112171112172112173112174112175112176112177112178112179112180112181112182112183112184112185112186112187112188112189112190112191112192112193112194112195112196112197112198112199112200112201112202112203112204112205112206112207112208112209112210112211112212112213112214112215112216112217112218112219112220112221112222112223112224112225112226112227112228112229112230112231112232112233112234112235112236112237112238112239112240112241112242112243112244112245112246112247112248112249112250112251112252112253112254112255112256112257112258112259112260112261112262112263112264112265112266112267112268112269112270112271112272112273112274112275112276112277112278112279112280112281112282112283112284112285112286112287112288112289112290112291112292112293112294112295112296112297112298112299112300112301112302112303112304112305112306112307112308112309112310112311112312112313112314112315112316112317112318112319112320112321112322112323112324112325112326112327112328112329112330112331112332112333112334112335112336112337112338112339112340112341112342112343112344112345112346112347112348112349112350112351112352112353112354112355112356112357112358112359112360112361112362112363112364112365112366112367112368112369112370112371112372112373112374112375112376112377112378112379112380112381112382112383112384112385112386112387112388112389112390112391112392112393112394112395112396112397112398112399112400112401112402112403112404112405112406112407112408112409112410112411112412112413112414112415112416112417112418112419112420112421112422112423112424112425112426112427112428112429112430112431112432112433112434112435112436112437112438112439112440112441112442112443112444112445112446112447112448112449112450112451112452112453112454112455112456112457112458112459112460112461112462112463112464112465112466112467112468112469112470112471112472112473112474112475112476112477112478112479112480112481112482112483112484112485112486112487112488112489112490112491112492112493112494112495112496112497112498112499112500112501112502112503112504112505112506112507112508112509112510112511112512112513112514112515112516112517112518112519112520112521112522112523112524112525112526112527112528112529112530112531112532112533112534112535112536112537112538112539112540112541112542112543112544112545112546112547112548112549112550112551112552112553112554112555112556112557112558112559112560112561112562112563112564112565112566112567112568112569112570112571112572112573112574112575112576112577112578112579112580112581112582112583112584112585112586112587112588112589112590112591112592112593112594112595112596112597112598112599112600112601112602112603112604112605112606112607112608112609112610112611112612112613112614112615112616112617112618112619112620112621112622112623112624112625112626112627112628112629112630112631112632112633112634112635112636112637112638112639112640112641112642112643112644112645112646112647112648112649112650112651112652112653112654112655112656112657112658112659112660112661112662112663112664112665112666112667112668112669112670112671112672112673112674112675112676112677112678112679112680112681112682112683112684112685112686112687112688112689112690112691112692112693112694112695112696112697112698112699112700112701112702112703112704112705112706112707112708112709112710112711112712112713112714112715112716112717112718112719112720112721112722112723112724112725112726112727112728112729112730112731112732112733112734112735112736112737112738112739112740112741112742112743112744112745112746112747112748112749112750112751112752112753112754112755112756112757112758112759112760112761112762112763112764112765112766112767112768112769112770112771112772112773112774112775112776112777112778112779112780112781112782112783112784112785112786112787112788112789112790112791112792112793112794112795112796112797112798112799112800112801112802112803112804112805112806112807112808112809112810112811112812112813112814112815112816112817112818112819112820112821112822112823112824112825112826112827112828112829112830112831112832112833112834112835112836112837112838112839112840112841112842112843112844112845112846112847112848112849112850112851112852112853112854112855112856112857112858112859112860112861112862112863112864112865112866112867112868112869112870112871112872112873112874112875112876112877112878112879112880112881112882112883112884112885112886112887112888112889112890112891112892112893112894112895112896112897112898112899112900112901112902112903112904112905112906112907112908112909112910112911112912112913112914112915112916112917112918112919112920112921112922112923112924112925112926112927112928112929112930112931112932112933112934112935112936112937112938112939112940112941112942112943112944112945112946112947112948112949112950112951112952112953112954112955112956112957112958112959112960112961112962112963112964112965112966112967112968112969112970112971112972112973112974112975112976112977112978112979112980112981112982112983112984112985112986112987112988112989112990112991112992112993112994112995112996112997112998112999113000113001113002113003113004113005113006113007113008113009113010113011113012113013113014113015113016113017113018113019113020113021113022113023113024113025113026113027113028113029113030113031113032113033113034113035113036113037113038113039113040113041113042113043113044113045113046113047113048113049113050113051113052113053113054113055113056113057113058113059113060113061113062113063113064113065113066113067113068113069113070113071113072113073113074113075113076113077113078113079113080113081113082113083113084113085113086113087113088113089113090113091113092113093113094113095113096113097113098113099113100113101113102113103113104113105113106113107113108113109113110113111113112113113113114113115113116113117113118113119113120113121113122113123113124113125113126113127113128113129113130113131113132113133113134113135113136113137113138113139113140113141113142113143113144113145113146113147113148113149113150113151113152113153113154113155113156113157113158113159113160113161113162113163113164113165113166113167113168113169113170113171113172113173113174113175113176113177113178113179113180113181113182113183113184113185113186113187113188113189113190113191113192113193113194113195113196113197113198113199113200113201113202113203113204113205113206113207113208113209113210113211113212113213113214113215113216113217113218113219113220113221113222113223113224113225113226113227113228113229113230113231113232113233113234113235113236113237113238113239113240113241113242113243113244113245113246113247113248113249113250113251113252113253113254113255113256113257113258113259113260113261113262113263113264113265113266113267113268113269113270113271113272113273113274113275113276113277113278113279113280113281113282113283113284113285113286113287113288113289113290113291113292113293113294113295113296113297113298113299113300113301113302113303113304113305113306113307113308113309113310113311113312113313113314113315113316113317113318113319113320113321113322113323113324113325113326113327113328113329113330113331113332113333113334113335113336113337113338113339113340113341113342113343113344113345113346113347113348113349113350113351113352113353113354113355113356113357113358113359113360113361113362113363113364113365113366113367113368113369113370113371113372113373113374113375113376113377113378113379113380113381113382113383113384113385113386113387113388113389113390113391113392113393113394113395113396113397113398113399113400113401113402113403113404113405113406113407113408113409113410113411113412113413113414113415113416113417113418113419113420113421113422113423113424113425113426113427113428113429113430113431113432113433113434113435113436113437113438113439113440113441113442113443113444113445113446113447113448113449113450113451113452113453113454113455113456113457113458113459113460113461113462113463113464113465113466113467113468113469113470113471113472113473113474113475113476113477113478113479113480113481113482113483113484113485113486113487113488113489113490113491113492113493113494113495113496113497113498113499113500113501113502113503113504113505113506113507113508113509113510113511113512113513113514113515113516113517113518113519113520113521113522113523113524113525113526113527113528113529113530113531113532113533113534113535113536113537113538113539113540113541113542113543113544113545113546113547113548113549113550113551113552113553113554113555113556113557113558113559113560113561113562113563113564113565113566113567113568113569113570113571113572113573113574113575113576113577113578113579113580113581113582113583113584113585113586113587113588113589113590113591113592113593113594113595113596113597113598113599113600113601113602113603113604113605113606113607113608113609113610113611113612113613113614113615113616113617113618113619113620113621113622113623113624113625113626113627113628113629113630113631113632113633113634113635113636113637113638113639113640113641113642113643113644113645113646113647113648113649113650113651113652113653113654113655113656113657113658113659113660113661113662113663113664113665113666113667113668113669113670113671113672113673113674113675113676113677113678113679113680113681113682113683113684113685113686113687113688113689113690113691113692113693113694113695113696113697113698113699113700113701113702113703113704113705113706113707113708113709113710113711113712113713113714113715113716113717113718113719113720113721113722113723113724113725113726113727113728113729113730113731113732113733113734113735113736113737113738113739113740113741113742113743113744113745113746113747113748113749113750113751113752113753113754113755113756113757113758113759113760113761113762113763113764113765113766113767113768113769113770113771113772113773113774113775113776113777113778113779113780113781113782113783113784113785113786113787113788113789113790113791113792113793113794113795113796113797113798113799113800113801113802113803113804113805113806113807113808113809113810113811113812113813113814113815113816113817113818113819113820113821113822113823113824113825113826113827113828113829113830113831113832113833113834113835113836113837113838113839113840113841113842113843113844113845113846113847113848113849113850113851113852113853113854113855113856113857113858113859113860113861113862113863113864113865113866113867113868113869113870113871113872113873113874113875113876113877113878113879113880113881113882113883113884113885113886113887113888113889113890113891113892113893113894113895113896113897113898113899113900113901113902113903113904113905113906113907113908113909113910113911113912113913113914113915113916113917113918113919113920113921113922113923113924113925113926113927113928113929113930113931113932113933113934113935113936113937113938113939113940113941113942113943113944113945113946113947113948113949113950113951113952113953113954113955113956113957113958113959113960113961113962113963113964113965113966113967113968113969113970113971113972113973113974113975113976113977113978113979113980113981113982113983113984113985113986113987113988113989113990113991113992113993113994113995113996113997113998113999114000114001114002114003114004114005114006114007114008114009114010114011114012114013114014114015114016114017114018114019114020114021114022114023114024114025114026114027114028114029114030114031114032114033114034114035114036114037114038114039114040114041114042114043114044114045114046114047114048114049114050114051114052114053114054114055114056114057114058114059114060114061114062114063114064114065114066114067114068114069114070114071114072114073114074114075114076114077114078114079114080114081114082114083114084114085114086114087114088114089114090114091114092114093114094114095114096114097114098114099114100114101114102114103114104114105114106114107114108114109114110114111114112114113114114114115114116114117114118114119114120114121114122114123114124114125114126114127114128114129114130114131114132114133114134114135114136114137114138114139114140114141114142114143114144114145114146114147114148114149114150114151114152114153114154114155114156114157114158114159114160114161114162114163114164114165114166114167114168114169114170114171114172114173114174114175114176114177114178114179114180114181114182114183114184114185114186114187114188114189114190114191114192114193114194114195114196114197114198114199114200114201114202114203114204114205114206114207114208114209114210114211114212114213114214114215114216114217114218114219114220114221114222114223114224114225114226114227114228114229114230114231114232114233114234114235114236114237114238114239114240114241114242114243114244114245114246114247114248114249114250114251114252114253114254114255114256114257114258114259114260114261114262114263114264114265114266114267114268114269114270114271114272114273114274114275114276114277114278114279114280114281114282114283114284114285114286114287114288114289114290114291114292114293114294114295114296114297114298114299114300114301114302114303114304114305114306114307114308114309114310114311114312114313114314114315114316114317114318114319114320114321114322114323114324114325114326114327114328114329114330114331114332114333114334114335114336114337114338114339114340114341114342114343114344114345114346114347114348114349114350114351114352114353114354114355114356114357114358114359114360114361114362114363114364114365114366114367114368114369114370114371114372114373114374114375114376114377114378114379114380114381114382114383114384114385114386114387114388114389114390114391114392114393114394114395114396114397114398114399114400114401114402114403114404114405114406114407114408114409114410114411114412114413114414114415114416114417114418114419114420114421114422114423114424114425114426114427114428114429114430114431114432114433114434114435114436114437114438114439114440114441114442114443114444114445114446114447114448114449114450114451114452114453114454114455114456114457114458114459114460114461114462114463114464114465114466114467114468114469114470114471114472114473114474114475114476114477114478114479114480114481114482114483114484114485114486114487114488114489114490114491114492114493114494114495114496114497114498114499114500114501114502114503114504114505114506114507114508114509114510114511114512114513114514114515114516114517114518114519114520114521114522114523114524114525114526114527114528114529114530114531114532114533114534114535114536114537114538114539114540114541114542114543114544114545114546114547114548114549114550114551114552114553114554114555114556114557114558114559114560114561114562114563114564114565114566114567114568114569114570114571114572114573114574114575114576114577114578114579114580114581114582114583114584114585114586114587114588114589114590114591114592114593114594114595114596114597114598114599114600114601114602114603114604114605114606114607114608114609114610114611114612114613114614114615114616114617114618114619114620114621114622114623114624114625114626114627114628114629114630114631114632114633114634114635114636114637114638114639114640114641114642114643114644114645114646114647114648114649114650114651114652114653114654114655114656114657114658114659114660114661114662114663114664114665114666114667114668114669114670114671114672114673114674114675114676114677114678114679114680114681114682114683114684114685114686114687114688114689114690114691114692114693114694114695114696114697114698114699114700114701114702114703114704114705114706114707114708114709114710114711114712114713114714114715114716114717114718114719114720114721114722114723114724114725114726114727114728114729114730114731114732114733114734114735114736114737114738114739114740114741114742114743114744114745114746114747114748114749114750114751114752114753114754114755114756114757114758114759114760114761114762114763114764114765114766114767114768114769114770114771114772114773114774114775114776114777114778114779114780114781114782114783114784114785114786114787114788114789114790114791114792114793114794114795114796114797114798114799114800114801114802114803114804114805114806114807114808114809114810114811114812114813114814114815114816114817114818114819114820114821114822114823114824114825114826114827114828114829114830114831114832114833114834114835114836114837114838114839114840114841114842114843114844114845114846114847114848114849114850114851114852114853114854114855114856114857114858114859114860114861114862114863114864114865114866114867114868114869114870114871114872114873114874114875114876114877114878114879114880114881114882114883114884114885114886114887114888114889114890114891114892114893114894114895114896114897114898114899114900114901114902114903114904114905114906114907114908114909114910114911114912114913114914114915114916114917114918114919114920114921114922114923114924114925114926114927114928114929114930114931114932114933114934114935114936114937114938114939114940114941114942114943114944114945114946114947114948114949114950114951114952114953114954114955114956114957114958114959114960114961114962114963114964114965114966114967114968114969114970114971114972114973114974114975114976114977114978114979114980114981114982114983114984114985114986114987114988114989114990114991114992114993114994114995114996114997114998114999115000115001115002115003115004115005115006115007115008115009115010115011115012115013115014115015115016115017115018115019115020115021115022115023115024115025115026115027115028115029115030115031115032115033115034115035115036115037115038115039115040115041115042115043115044115045115046115047115048115049115050115051115052115053115054115055115056115057115058115059115060115061115062115063115064115065115066115067115068115069115070115071115072115073115074115075115076115077115078115079115080115081115082115083115084115085115086115087115088115089115090115091115092115093115094115095115096115097115098115099115100115101115102115103115104115105115106115107115108115109115110115111115112115113115114115115115116115117115118115119115120115121115122115123115124115125115126115127115128115129115130115131115132115133115134115135115136115137115138115139115140115141115142115143115144115145115146115147115148115149115150115151115152115153115154115155115156115157115158115159115160115161115162115163115164115165115166115167115168115169115170115171115172115173115174115175115176115177115178115179115180115181115182115183115184115185115186115187115188115189115190115191115192115193115194115195115196115197115198115199115200115201115202115203115204115205115206115207115208115209115210115211115212115213115214115215115216115217115218115219115220115221115222115223115224115225115226115227115228115229115230115231115232115233115234115235115236115237115238115239115240115241115242115243115244115245115246115247115248115249115250115251115252115253115254115255115256115257115258115259115260115261115262115263115264115265115266115267115268115269115270115271115272115273115274115275115276115277115278115279115280115281115282115283115284115285115286115287115288115289115290115291115292115293115294115295115296115297115298115299115300115301115302115303115304115305115306115307115308115309115310115311115312115313115314115315115316115317115318115319115320115321115322115323115324115325115326115327115328115329115330115331115332115333115334115335115336115337115338115339115340115341115342115343115344115345115346115347115348115349115350115351115352115353115354115355115356115357115358115359115360115361115362115363115364115365115366115367115368115369115370115371115372115373115374115375115376115377115378115379115380115381115382115383115384115385115386115387115388115389115390115391115392115393115394115395115396115397115398115399115400115401115402115403115404115405115406115407115408115409115410115411115412115413115414115415115416115417115418115419115420115421115422115423115424115425115426115427115428115429115430115431115432115433115434115435115436115437115438115439115440115441115442115443115444115445115446115447115448115449115450115451115452115453115454115455115456115457115458115459115460115461115462115463115464115465115466115467115468115469115470115471115472115473115474115475115476115477115478115479115480115481115482115483115484115485115486115487115488115489115490115491115492115493115494115495115496115497115498115499115500115501115502115503115504115505115506115507115508115509115510115511115512115513115514115515115516115517115518115519115520115521115522115523115524115525115526115527115528115529115530115531115532115533115534115535115536115537115538115539115540115541115542115543115544115545115546115547115548115549115550115551115552115553115554115555115556115557115558115559115560115561115562115563115564115565115566115567115568115569115570115571115572115573115574115575115576115577115578115579115580115581115582115583115584115585115586115587115588115589115590115591115592115593115594115595115596115597115598115599115600115601115602115603115604115605115606115607115608115609115610115611115612115613115614115615115616115617115618115619115620115621115622115623115624115625115626115627115628115629115630115631115632115633115634115635115636115637115638115639115640115641115642115643115644115645115646115647115648115649115650115651115652115653115654115655115656115657115658115659115660115661115662115663115664115665115666115667115668115669115670115671115672115673115674115675115676115677115678115679115680115681115682115683115684115685115686115687115688115689115690115691115692115693115694115695115696115697115698115699115700115701115702115703115704115705115706115707115708115709115710115711115712115713115714115715115716115717115718115719115720115721115722115723115724115725115726115727115728115729115730115731115732115733115734115735115736115737115738115739115740115741115742115743115744115745115746115747115748115749115750115751115752115753115754115755115756115757115758115759115760115761115762115763115764115765115766115767115768115769115770115771115772115773115774115775115776115777115778115779115780115781115782115783115784115785115786115787115788115789115790115791115792115793115794115795115796115797115798115799115800115801115802115803115804115805115806115807115808115809115810115811115812115813115814115815115816115817115818115819115820115821115822115823115824115825115826115827115828115829115830115831115832115833115834115835115836115837115838115839115840115841115842115843115844115845115846115847115848115849115850115851115852115853115854115855115856115857115858115859115860115861115862115863115864115865115866115867115868115869115870115871115872115873115874115875115876115877115878115879115880115881115882115883115884115885115886115887115888115889115890115891115892115893115894115895115896115897115898115899115900115901115902115903115904115905115906115907115908115909115910115911115912115913115914115915115916115917115918115919115920115921115922115923115924115925115926115927115928115929115930115931115932115933115934115935115936115937115938115939115940115941115942115943115944115945115946115947115948115949115950115951115952115953115954115955115956115957115958115959115960115961115962115963115964115965115966115967115968115969115970115971115972115973115974115975115976115977115978115979115980115981115982115983115984115985115986115987115988115989115990115991115992115993115994115995115996115997115998115999116000116001116002116003116004116005116006116007116008116009116010116011116012116013116014116015116016116017116018116019116020116021116022116023116024116025116026116027116028116029116030116031116032116033116034116035116036116037116038116039116040116041116042116043116044116045116046116047116048116049116050116051116052116053116054116055116056116057116058116059116060116061116062116063116064116065116066116067116068116069116070116071116072116073116074116075116076116077116078116079116080116081116082116083116084116085116086116087116088116089116090116091116092116093116094116095116096116097116098116099116100116101116102116103116104116105116106116107116108116109116110116111116112116113116114116115116116116117116118116119116120116121116122116123116124116125116126116127116128116129116130116131116132116133116134116135116136116137116138116139116140116141116142116143116144116145116146116147116148116149116150116151116152116153116154116155116156116157116158116159116160116161116162116163116164116165116166116167116168116169116170116171116172116173116174116175116176116177116178116179116180116181116182116183116184116185116186116187116188116189116190116191116192116193116194116195116196116197116198116199116200116201116202116203116204116205116206116207116208116209116210116211116212116213116214116215116216116217116218116219116220116221116222116223116224116225116226 |
- var __defProp = Object.defineProperty;
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __publicField = (obj, key, value) => {
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
- return value;
- };
- import { getCurrentScope, onScopeDispose, unref, getCurrentInstance, onMounted, nextTick, ref, readonly, watch, openBlock, createElementBlock, createElementVNode, warn, computed as computed$1, watchEffect, onBeforeUnmount, inject, isRef, shallowRef, onBeforeMount, provide, defineComponent, renderSlot, mergeProps, toRef, onUnmounted, useAttrs as useAttrs$1, useSlots, withDirectives, createCommentVNode, Fragment, normalizeClass, createBlock, withCtx, resolveDynamicComponent, withModifiers, createVNode, toDisplayString, normalizeStyle, vShow, Transition, reactive, onUpdated, cloneVNode, Text as Text$1, Comment as Comment$1, Teleport, onDeactivated, vModelRadio, createTextVNode, toRefs, toHandlers, withKeys, renderList, h, createSlots, toRaw as toRaw$1, triggerRef, resolveComponent, resolveDirective, vModelText, defineCustomElement } from "vue";
- const CHARS = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split("");
- class Util {
- static uuid(prefix = "D") {
- let uuid = [];
- uuid[8] = uuid[13] = uuid[18] = uuid[23] = "-";
- uuid[14] = "4";
- let r2;
- for (let i2 = 0; i2 < 36; i2++) {
- if (!uuid[i2]) {
- r2 = 0 | Math.random() * 16;
- uuid[i2] = CHARS[i2 == 19 ? r2 & 3 | 8 : r2];
- }
- }
- return prefix + "-" + uuid.join("");
- }
- static merge(dest, ...sources) {
- let i2, j, len, src;
- for (j = 0, len = sources.length; j < len; j++) {
- src = sources[j];
- for (i2 in src) {
- dest[i2] = src[i2];
- }
- }
- return dest;
- }
- static trim(str) {
- return str.trim ? str.trim() : str.replace(/^\s+|\s+$/g, "");
- }
- static splitWords(str) {
- return this.trim(str).split(/\s+/);
- }
- static setOptions(obj, options2) {
- if (!obj.hasOwnProperty("options")) {
- obj.options = obj.options ? create(obj.options) : {};
- }
- for (var i2 in options2) {
- obj.options[i2] = options2[i2];
- }
- return obj.options;
- }
- static checkPosition(position2) {
- return position2 && position2.hasOwnProperty("_lng") && position2.hasOwnProperty("_lat") && position2.hasOwnProperty("_alt");
- }
- static checkPositions(positions) {
- return positions && (typeof positions === "string" || Array.isArray(positions));
- }
- static checkViewer(viewer2) {
- return viewer2 && viewer2.delegate && viewer2.canvas;
- }
- }
- class DomUtil {
- static get(id) {
- return typeof id === "string" ? document.getElementById(id) : id;
- }
- static getStyle(el, style) {
- var value = el.style[style] || el.currentStyle && el.currentStyle[style];
- if ((!value || value === "auto") && document.defaultView) {
- var css = document.defaultView.getComputedStyle(el, null);
- value = css ? css[style] : null;
- }
- return value === "auto" ? null : value;
- }
- static create(tagName, className, container) {
- var el = document.createElement(tagName);
- el.className = className || "";
- if (container) {
- container.appendChild(el);
- }
- return el;
- }
- static remove(el) {
- var parent = el.parentNode;
- if (parent) {
- parent.removeChild(el);
- }
- }
- static empty(el) {
- while (el.firstChild) {
- el.removeChild(el.firstChild);
- }
- }
- hasClass(el, name) {
- if (el.classList !== void 0) {
- return el.classList.contains(name);
- }
- var className = getClass(el);
- return className.length > 0 && new RegExp("(^|\\s)" + name + "(\\s|$)").test(className);
- }
- static addClass(el, name) {
- if (el.classList !== void 0) {
- let classes = Util.splitWords(name);
- for (let i2 = 0, len = classes.length; i2 < len; i2++) {
- el.classList.add(classes[i2]);
- }
- } else if (!this.hasClass(el, name)) {
- let className = this.getClass(el);
- this.setClass(el, (className ? className + " " : "") + name);
- }
- }
- static removeClass(el, name) {
- if (el.classList !== void 0) {
- el.classList.remove(name);
- } else {
- this.setClass(
- el,
- Util.trim(
- (" " + this.getClass(el) + " ").replace(" " + name + " ", " ")
- )
- );
- }
- }
- static setClass(el, name) {
- if (el.className.baseVal === void 0) {
- el.className = name;
- } else {
- el.className.baseVal = name;
- }
- }
- static getClass(el) {
- if (el.correspondingElement) {
- el = el.correspondingElement;
- }
- return el.className.baseVal === void 0 ? el.className : el.className.baseVal;
- }
- static createSvg(width2, height2, path, container) {
- let svg = document.createElementNS("http://www.w3.org/2000/svg", "svg:svg");
- svg.setAttribute("class", "svg-path");
- svg.setAttribute("width", width2);
- svg.setAttribute("height", height2);
- svg.setAttribute("viewBox", `0 0 ${width2} ${height2}`);
- let pathEl = document.createElementNS("http://www.w3.org/2000/svg", "path");
- pathEl.setAttribute("d", path);
- svg.appendChild(pathEl);
- if (container) {
- container.appendChild(svg);
- }
- return svg;
- }
- }
- var StatusBar$1 = "";
- class StatusBar {
- constructor(viewer2) {
- if (!viewer2)
- throw new Error("viewer is required!");
- this._viewer = viewer2;
- this._show = false;
- this._handler;
- this._posX;
- this._posY;
- this._posZ;
- this._cameraHeight;
- this._pitch;
- this._heading;
- this._scale;
- this.initListener();
- }
- get params() {
- return {
- posX: this._posX,
- posY: this._posY,
- posZ: this._posZ,
- cameraHeight: this._cameraHeight,
- pitch: this._pitch,
- heading: this._heading,
- scale: this._scale
- };
- }
- get statusDom() {
- let innerHtml = `
- <span class="status-scale">
- \u6BD4\u4F8B\u5C3A\uFF1A
- <span class="scale-border">
- ${this._scale}
- </span>
- </span>
- <span class="status-position">
- <span id="status_spaceInfo">\u7A7A\u95F4\u4FE1\u606F</span>
- \u5237\u5E27\u7387\uFF1A<span id="status_ms"></span>|<span id="status_fps"></span>
- </span>
- `;
- return innerHtml;
- }
- get show() {
- return this._show;
- }
- set show(bool) {
- bool ? this.createStatusBar() : this.removeStatusBar();
- this._show = bool;
- }
- initListener() {
- const $this = this;
- const scene = this._viewer.scene;
- this._scaleListener = function() {
- let width2 = scene.canvas.clientWidth;
- let height2 = scene.canvas.clientHeight;
- let left = scene.camera.getPickRay(
- new Cesium.Cartesian2(width2 / 2 | 0, height2 - 1)
- );
- let right = scene.camera.getPickRay(
- new Cesium.Cartesian2(1 + width2 / 2 | 0, height2 - 1)
- );
- let globe = scene.globe;
- let leftPosition = globe.pick(left, scene);
- let rightPosition = globe.pick(right, scene);
- if (leftPosition && rightPosition) {
- let geodesic = new Cesium.EllipsoidGeodesic();
- let leftCartographic = globe.ellipsoid.cartesianToCartographic(leftPosition);
- let rightCartographic = globe.ellipsoid.cartesianToCartographic(rightPosition);
- geodesic.setEndPoints(leftCartographic, rightCartographic);
- let distance2 = geodesic.surfaceDistance;
- let curScaleNum = $this.closest(distance2 / 10);
- if (curScaleNum < 1) {
- $this._scale = curScaleNum * 1e3 + "m";
- } else {
- $this._scale = curScaleNum + "km";
- }
- }
- document.getElementsByClassName("scale-border")[0].innerText = $this._scale;
- if (document.getElementsByClassName("cesium-performanceDisplay-ms").length > 0) {
- document.getElementById("status_ms").innerText = document.getElementsByClassName("cesium-performanceDisplay-ms")[0].innerText;
- }
- if (document.getElementsByClassName("cesium-performanceDisplay-fps").length > 0) {
- document.getElementById("status_fps").innerText = document.getElementsByClassName("cesium-performanceDisplay-fps")[0].innerText;
- }
- };
- }
- createStatusBar() {
- const _delegate = this._viewer;
- this.initHandler(_delegate);
- this.initScale(_delegate, true);
- this._domContainer = DomUtil.create(
- "div",
- "lk-status-bar",
- document.getElementById(this._viewer._container.id)
- );
- this._domContainer.innerHTML = this.statusDom;
- }
- removeStatusBar() {
- this.initScale(this._viewer, false);
- if (this._handler) {
- this._handler.destroy();
- }
- if (this._domContainer) {
- DomUtil.remove(this._domContainer);
- }
- }
- initHandler(viewer2) {
- const $this = this;
- this._handler = new Cesium.ScreenSpaceEventHandler(viewer2.scene.canvas);
- const mouseOverHandler = function(movement) {
- let loc2 = $this._getScreenClickPositionAndHeight(movement.endPosition);
- if (!Cesium.defined(loc2))
- return;
- if (!loc2.lng)
- return;
- $this._posX = loc2.lng.toFixed(8);
- $this._posY = loc2.lat.toFixed(8);
- $this._posZ = loc2.height.toFixed(2);
- document.getElementById("status_spaceInfo").innerHTML = `
- <span>\u7ECF\u5EA6\uFF1A${$this._posX}</span>
- <span>\u7EAC\u5EA6\uFF1A${$this._posY}</span>
- <span>\u9AD8\u5EA6\uFF1A${$this._posZ}</span>
- `;
- };
- this._handler.setInputAction(
- mouseOverHandler,
- Cesium.ScreenSpaceEventType.MOUSE_MOVE
- );
- }
- initScale(viewer2, bool) {
- const scene = viewer2.scene;
- bool ? scene.postRender.addEventListener(this._scaleListener) : scene.postRender.removeEventListener(this._scaleListener);
- }
- closest(num) {
- const scaleList = [
- 1e-3,
- 2e-3,
- 3e-3,
- 5e-3,
- 0.01,
- 0.015,
- 0.02,
- 0.025,
- 0.03,
- 0.035,
- 0.04,
- 0.045,
- 0.05,
- 0.06,
- 0.07,
- 0.08,
- 0.09,
- 0.1,
- 0.12,
- 0.15,
- 0.2,
- 0.25,
- 0.3,
- 0.5,
- 1,
- 2,
- 3,
- 5,
- 10,
- 15,
- 20,
- 25,
- 30,
- 35,
- 40,
- 45,
- 50,
- 60,
- 70,
- 80,
- 90,
- 100,
- 120,
- 150,
- 200,
- 250,
- 300,
- 500,
- 1e3,
- 2e3,
- 5e3,
- 1e4,
- 1e5,
- 5e5,
- 1e6
- ];
- let ret = scaleList[0];
- let distance2 = Math.abs(ret - num);
- for (let i2 = 1; i2 < scaleList.length; i2++) {
- let newDistance = Math.abs(scaleList[i2] - num);
- if (newDistance < distance2) {
- distance2 = newDistance;
- ret = scaleList[i2];
- }
- }
- return ret;
- }
- _getScreenClickPositionAndHeight(screenPoint) {
- var lng = void 0, lat = void 0, height2 = void 0;
- var ray = this._viewer.scene.camera.getPickRay(screenPoint);
- var position2 = this._viewer.scene.globe.pick(ray, this._viewer.scene);
- if (position2) {
- var cartographic = Cesium.Ellipsoid.WGS84.cartesianToCartographic(position2);
- cartographic = Cesium.Cartographic.fromCartesian(position2);
- var feature2 = this._viewer.scene.pick(screenPoint);
- if (feature2 === void 0 && Cesium.defined(cartographic)) {
- lng = this._arcToDegree(cartographic.longitude);
- lat = this._arcToDegree(cartographic.latitude);
- height2 = cartographic.height;
- } else {
- var cartesian = this._viewer.scene.pickPosition(screenPoint);
- if (Cesium.defined(cartesian)) {
- var cartographic = Cesium.Cartographic.fromCartesian(cartesian);
- if (Cesium.defined(cartographic)) {
- lng = this._arcToDegree(cartographic.longitude);
- lat = this._arcToDegree(cartographic.latitude);
- height2 = cartographic.height;
- }
- }
- }
- }
- return {
- lng,
- lat,
- height: height2
- };
- }
- _arcToDegree(arc) {
- return arc / Math.PI * 180;
- }
- }
- var base = "";
- class jtMap3d {
- constructor(options2) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.container)) {
- throw new Cesium.DeveloperError("options.container is required.");
- }
- Cesium.Ion.defaultAccessToken = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiIxNzM5YjQ3MC03YmMxLTRmMjAtOTk4Yi0yNDMyMDZlOTQzYTYiLCJpZCI6NTU5MjAsImlhdCI6MTYyNDI0NTM5NX0.diydVWFzw5C5rQlHaFYkdDJoSorcdex81KpWcntyICo";
- this._viewer = this._initMap(options2);
- this._imageryLayers = this._viewer.imageryLayers;
- this._primitives = this._viewer.scene.primitives;
- this._entities = this._viewer.entities;
- this._dataSources = this._viewer.dataSources;
- this._defaultSkyBox = this._viewer.scene.skyBox;
- this.statusBar = new StatusBar(this._viewer);
- }
- _initMap(options2) {
- let viewer2 = new Cesium.Viewer(options2.container, {
- animation: true,
- timeline: true,
- shadows: false,
- shouldAnimate: true,
- baseLayerPicker: false,
- navigationHelpButton: false,
- homeButton: false,
- fullscreenButton: false,
- sceneModePicker: false,
- scene3DOnly: true,
- infoBox: false,
- clampToGround: true,
- geocoder: false,
- imageryProvider: new Cesium.SingleTileImageryProvider({
- url: "jt3dSDK/imgs/earth_2.jpg"
- }),
- selectionIndicator: false,
- contextOptions: {
- webgl: {
- alpha: true,
- depth: true,
- stencil: true,
- antialias: true,
- premultipliedAlpha: true,
- preserveDrawingBuffer: true,
- failIfMajorPerformanceCaveat: true
- }
- }
- });
- viewer2._cesiumWidget._creditContainer.style.display = "none";
- viewer2.scene.globe.show = true;
- viewer2.scene.globe.depthTestAgainstTerrain = true;
- viewer2.scene.globe.enableLighting = false;
- viewer2.scene.requestRenderMode = false;
- viewer2.scene.debugShowFramesPerSecond = true;
- viewer2.scene.skyAtmosphere.show = false;
- viewer2.scene.skyBox.show = true;
- viewer2.scene.sun.show = true;
- viewer2.scene.moon.show = false;
- viewer2.cesiumWidget.screenSpaceEventHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
- viewer2.animation.viewModel.dateFormatter = localeDateTimeFormatter;
- viewer2.animation.viewModel.timeFormatter = localeTimeFormatter;
- viewer2.timeline.makeLabel = localeDateTimeFormatter;
- function localeDateTimeFormatter(datetime, viewModel, ignoredate) {
- var julianDT = new Cesium.JulianDate();
- Cesium.JulianDate.addHours(datetime, 8, julianDT);
- var gregorianDT = Cesium.JulianDate.toGregorianDate(julianDT);
- var objDT;
- if (ignoredate) {
- objDT = "";
- } else {
- objDT = new Date(gregorianDT.year, gregorianDT.month - 1, gregorianDT.day);
- objDT = gregorianDT.year + "-" + objDT.toLocaleString("zh-cn", {
- month: "short"
- }).split("\u6708").join("-") + gregorianDT.day + " ";
- if (viewModel || gregorianDT.hour + gregorianDT.minute === 0) {
- return objDT;
- }
- }
- let hour, minute, second;
- if (gregorianDT.hour < 10) {
- hour = `0${gregorianDT.hour}`;
- } else {
- hour = gregorianDT.hour;
- }
- if (gregorianDT.minute < 10) {
- minute = `0${gregorianDT.minute}`;
- } else {
- minute = gregorianDT.minute;
- }
- if (gregorianDT.second < 10) {
- second = `0${gregorianDT.second}`;
- } else {
- second = gregorianDT.second;
- }
- return objDT + hour + ":" + minute + ":" + second;
- }
- function localeTimeFormatter(time, viewModel) {
- return localeDateTimeFormatter(time, viewModel, true);
- }
- return viewer2;
- }
- _setView(options2) {
- if (!Cesium.defined(options2.longitude) && !Cesium.defined(options2.latitude)) {
- throw new Cesium.DeveloperError("longitude and latitude are required.");
- }
- Cesium.Check.typeOf.number("longitude", options2.longitude);
- Cesium.Check.typeOf.number("latitude", options2.latitude);
- this._viewer.camera.setView({
- destination: Cesium.Cartesian3.fromDegrees(
- options2.longitude,
- options2.latitude,
- options2.height
- ),
- orientation: {
- heading: Cesium.Math.toRadians(Cesium.defaultValue(options2.heading, 0)),
- pitch: Cesium.Math.toRadians(Cesium.defaultValue(options2.pitch, -90)),
- roll: options2.roll
- }
- });
- }
- _getChinaPostion() {
- return Cesium.Cartesian3.fromDegrees(116.435314, 40.960521, 1e7);
- }
- }
- Object.assign(jtMap3d.prototype, {
- flytoChina() {
- this._viewer.camera.flyTo({
- destination: this._getChinaPostion(),
- duration: 3
- });
- },
- setViewChina: function() {
- this._setView({
- longitude: 103.84,
- latitude: 31.15,
- height: 24e6,
- heading: 0,
- pitch: -90,
- roll: 0
- });
- },
- fullMap: function(options2) {
- return new Promise((resolve2, reject2) => {
- let _self = this;
- this._entities.removeById("fullMapRectangle");
- options2.isRemove = Cesium.defaultValue(options2.isRemove, true);
- options2.duration = Cesium.defaultValue(options2.duration, 3);
- options2.heading = Cesium.defaultValue(options2.heading, 0);
- options2.pitch = Cesium.defaultValue(options2.pitch, -90);
- options2.range = Cesium.defaultValue(options2.range, 0);
- var rectangle = Cesium.Rectangle.fromDegrees(
- options2.west,
- options2.south,
- options2.east,
- options2.north
- );
- var fullMapEntity = this._entities.add({
- id: "fullMapRectangle",
- name: "fullMapRectangle",
- rectangle: {
- coordinates: rectangle,
- material: Cesium.Color.GREEN.withAlpha(0),
- height: 10,
- outline: false
- }
- });
- var flyPromise = this._viewer.flyTo(fullMapEntity, {
- duration: options2.duration,
- offset: {
- heading: Cesium.Math.toRadians(options2.heading),
- pitch: Cesium.Math.toRadians(options2.pitch),
- range: options2.range
- }
- });
- flyPromise.then(function(flyPromise2) {
- if (flyPromise2) {
- if (options2.isRemove) {
- fullMapEntity && (_self._entities.remove(fullMapEntity), fullMapEntity = null);
- }
- resolve2(true);
- }
- }).catch(function(error) {
- console.log(error);
- });
- });
- },
- setMapNorth() {
- let viewer2 = this._viewer;
- let pitch = Cesium.Math.toDegrees(viewer2.camera.pitch).toFixed(0);
- var center2 = viewer2.camera.pickEllipsoid(new Cesium.Cartesian2(viewer2.canvas.clientWidth / 2, viewer2.canvas.clientHeight / 2));
- var curPosition = Cesium.Ellipsoid.WGS84.cartesianToCartographic(center2);
- let centerX = curPosition.longitude * 180 / Math.PI;
- let centerY = curPosition.latitude * 180 / Math.PI;
- let cameraPointX = viewer2.camera.positionCartographic.longitude * 180 / Math.PI;
- let cameraPointY = viewer2.camera.positionCartographic.latitude * 180 / Math.PI;
- let cameraPointZ = viewer2.camera.positionCartographic.height.toFixed(0);
- var satrt = Cesium.Cartographic.fromDegrees(cameraPointX, cameraPointY, cameraPointZ);
- var end = Cesium.Cartographic.fromDegrees(centerX, centerY, 0);
- var geodesic = new Cesium.EllipsoidGeodesic();
- geodesic.setEndPoints(satrt, end);
- var distance2 = geodesic.surfaceDistance;
- let range3 = Math.sqrt(Math.pow(distance2, 2) + Math.pow(cameraPointZ - 0, 2));
- if (this.centerEntity) {
- viewer2.entities.remove(this.centerEntity);
- }
- this.centerEntity = viewer2.entities.add({
- position: Cesium.Cartesian3.fromDegrees(centerX, centerY, 0),
- point: {
- color: Cesium.Color.RED,
- pixelSize: 1
- }
- });
- let offset = new Cesium.HeadingPitchRange(Cesium.Math.toRadians(0), Cesium.Math.toRadians(pitch), range3);
- viewer2.zoomTo(this.centerEntity, offset);
- },
- setMapSpinByPoint(points2, options2) {
- let viewer2 = this._viewer;
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- options2 = options2 || {};
- options2.speed = Cesium.defaultValue(options2.speed, 30);
- var position2 = points2;
- if (points2 instanceof Cesium.Cartesian3) {
- position2 = points2;
- } else {
- position2 = Cesium.Cartesian3.fromDegrees(points2[0], points2[1], points2[2] || 0);
- }
- var entity = viewer2.entities.add(
- new Cesium.Entity({
- point: new Cesium.PointGraphics({
- color: new Cesium.Color(1, 1, 0),
- pixelSize: 6,
- outlineColor: new Cesium.Color(0, 1, 1)
- }),
- position: position2
- })
- );
- var angle = 360 / options2.speed;
- var initialHeading = viewer2.camera.heading;
- var pitch = viewer2.camera.pitch;
- if (options2.pitch) {
- pitch = Cesium.Math.toRadians(options2.pitch);
- }
- var distance2 = viewer2.camera.positionCartographic.height;
- if (options2.height) {
- distance2 = options2.height;
- }
- var startTime = Cesium.JulianDate.fromDate(new Date());
- viewer2.clock.startTime = startTime.clone();
- viewer2.clock.currentTime = startTime.clone();
- viewer2.clock.clockRange = Cesium.ClockRange.CLAMPED;
- viewer2.clock.clockStep = Cesium.ClockStep.SYSTEM_CLOCK;
- var Exection = function TimeExecution() {
- var delTime = Cesium.JulianDate.secondsDifference(viewer2.clock.currentTime, viewer2.clock.startTime);
- var heading = Cesium.Math.toRadians(delTime * angle) + initialHeading;
- viewer2.scene.camera.setView({
- destination: position2,
- orientation: {
- heading,
- pitch
- }
- });
- viewer2.scene.camera.moveBackward(distance2);
- if (Cesium.JulianDate.compare(viewer2.clock.currentTime, viewer2.clock.stopTime) >= 0) {
- viewer2.clock.onTick.removeEventListener(Exection);
- }
- var handler = new Cesium.ScreenSpaceEventHandler(viewer2.scene.canvas);
- handler.setInputAction(function(click) {
- viewer2.clock.onTick.removeEventListener(Exection);
- viewer2.entities.remove(entity);
- }, Cesium.ScreenSpaceEventType.LEFT_DOWN);
- };
- viewer2.clock.onTick.addEventListener(Exection);
- }
- });
- const BD_FACTOR = 3.141592653589793 * 3e3 / 180;
- const PI = 3.141592653589793;
- const RADIUS = 6378245;
- const EE = 0.006693421622965943;
- class CoordTransform {
- static BD09ToGCJ02(lng, lat) {
- let x = +lng - 65e-4;
- let y = +lat - 6e-3;
- let z = Math.sqrt(x * x + y * y) - 2e-5 * Math.sin(y * BD_FACTOR);
- let theta = Math.atan2(y, x) - 3e-6 * Math.cos(x * BD_FACTOR);
- let gg_lng = z * Math.cos(theta);
- let gg_lat = z * Math.sin(theta);
- return [gg_lng, gg_lat];
- }
- static GCJ02ToBD09(lng, lat) {
- lat = +lat;
- lng = +lng;
- let z = Math.sqrt(lng * lng + lat * lat) + 2e-5 * Math.sin(lat * BD_FACTOR);
- let theta = Math.atan2(lat, lng) + 3e-6 * Math.cos(lng * BD_FACTOR);
- let bd_lng = z * Math.cos(theta) + 65e-4;
- let bd_lat = z * Math.sin(theta) + 6e-3;
- return [bd_lng, bd_lat];
- }
- static WGS84ToGCJ02(lng, lat) {
- lat = +lat;
- lng = +lng;
- if (this.out_of_china(lng, lat)) {
- return [lng, lat];
- } else {
- let d2 = this.delta(lng, lat);
- return [lng + d2[0], lat + d2[1]];
- }
- }
- static GCJ02ToWGS84(lng, lat) {
- lat = +lat;
- lng = +lng;
- if (this.out_of_china(lng, lat)) {
- return [lng, lat];
- } else {
- let d2 = this.delta(lng, lat);
- let mgLng = lng + d2[0];
- let mgLat = lat + d2[1];
- return [lng * 2 - mgLng, lat * 2 - mgLat];
- }
- }
- static delta(lng, lat) {
- let dLng = this.transformLng(lng - 105, lat - 35);
- let dLat = this.transformLat(lng - 105, lat - 35);
- const radLat = lat / 180 * PI;
- let magic = Math.sin(radLat);
- magic = 1 - EE * magic * magic;
- const sqrtMagic = Math.sqrt(magic);
- dLng = dLng * 180 / (RADIUS / sqrtMagic * Math.cos(radLat) * PI);
- dLat = dLat * 180 / (RADIUS * (1 - EE) / (magic * sqrtMagic) * PI);
- return [dLng, dLat];
- }
- static transformLng(lng, lat) {
- lat = +lat;
- lng = +lng;
- let ret = 300 + lng + 2 * lat + 0.1 * lng * lng + 0.1 * lng * lat + 0.1 * Math.sqrt(Math.abs(lng));
- ret += (20 * Math.sin(6 * lng * PI) + 20 * Math.sin(2 * lng * PI)) * 2 / 3;
- ret += (20 * Math.sin(lng * PI) + 40 * Math.sin(lng / 3 * PI)) * 2 / 3;
- ret += (150 * Math.sin(lng / 12 * PI) + 300 * Math.sin(lng / 30 * PI)) * 2 / 3;
- return ret;
- }
- static transformLat(lng, lat) {
- lat = +lat;
- lng = +lng;
- let ret = -100 + 2 * lng + 3 * lat + 0.2 * lat * lat + 0.1 * lng * lat + 0.2 * Math.sqrt(Math.abs(lng));
- ret += (20 * Math.sin(6 * lng * PI) + 20 * Math.sin(2 * lng * PI)) * 2 / 3;
- ret += (20 * Math.sin(lat * PI) + 40 * Math.sin(lat / 3 * PI)) * 2 / 3;
- ret += (160 * Math.sin(lat / 12 * PI) + 320 * Math.sin(lat * PI / 30)) * 2 / 3;
- return ret;
- }
- static out_of_china(lng, lat) {
- lat = +lat;
- lng = +lng;
- return !(lng > 73.66 && lng < 135.05 && lat > 3.86 && lat < 53.55);
- }
- static getCatesian3FromPX(viewer2, px) {
- let picks = viewer2.scene.drillPick(px);
- let cartesian = null;
- let isOn3dtiles = false, isOnTerrain = false;
- for (let i2 in picks) {
- let pick = picks[i2];
- if (pick && pick.primitive instanceof Cesium.Cesium3DTileFeature || pick && pick.primitive instanceof Cesium.Cesium3DTileset || pick && pick.primitive instanceof Cesium.Model) {
- isOn3dtiles = true;
- }
- if (isOn3dtiles) {
- viewer2.scene.pick(px);
- cartesian = viewer2.scene.pickPosition(px);
- if (cartesian) {
- let cartographic = Cesium.Cartographic.fromCartesian(cartesian);
- if (cartographic.height < 0)
- cartographic.height = 0;
- let lon = Cesium.Math.toDegrees(cartographic.longitude), lat = Cesium.Math.toDegrees(cartographic.latitude), height2 = cartographic.height;
- cartesian = this.transformWGS84ToCartesian({
- lng: lon,
- lat,
- alt: height2
- });
- }
- }
- }
- let boolTerrain = viewer2.terrainProvider instanceof Cesium.EllipsoidTerrainProvider;
- if (!isOn3dtiles && !boolTerrain) {
- let ray = viewer2.scene.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = viewer2.scene.globe.pick(ray, viewer2.scene);
- isOnTerrain = true;
- }
- if (!isOn3dtiles && !isOnTerrain && boolTerrain) {
- cartesian = viewer2.scene.camera.pickEllipsoid(
- px,
- viewer2.scene.globe.ellipsoid
- );
- }
- if (cartesian) {
- let position2 = this.transformCartesianToWGS84(cartesian);
- if (position2.alt < 0) {
- cartesian = this.transformWGS84ToCartesian(position2, 0.1);
- }
- return cartesian;
- }
- return false;
- }
- static transformWGS84ToCartesian(position2, alt) {
- return position2 ? Cesium.Cartesian3.fromDegrees(
- position2.lng || position2.lon,
- position2.lat,
- position2.alt = alt || position2.alt,
- Cesium.Ellipsoid.WGS84
- ) : Cesium.Cartesian3.ZERO;
- }
- static transformCartesianToWGS84(cartesian) {
- let ellipsoid = Cesium.Ellipsoid.WGS84;
- let cartographic = ellipsoid.cartesianToCartographic(cartesian);
- return {
- lng: Cesium.Math.toDegrees(cartographic.longitude),
- lat: Cesium.Math.toDegrees(cartographic.latitude),
- alt: cartographic.height
- };
- }
- static Cartesian3ListToWGS84(cartesianList) {
- let ellipsoid = Cesium.Ellipsoid.WGS84;
- let result = [];
- for (let index2 = 0; index2 < cartesianList.length; index2++) {
- const cartesian = cartesianList[index2];
- let cartographic = ellipsoid.cartesianToCartographic(cartesian);
- result.push({
- lng: Cesium.Math.toDegrees(cartographic.longitude),
- lat: Cesium.Math.toDegrees(cartographic.latitude),
- alt: cartographic.height
- });
- }
- return result;
- }
- static Degrees2DMS(value) {
- let degrees = Math.floor(value);
- let rem = (value - degrees) * 60;
- let minutes = Math.floor(rem);
- let _second = (rem - minutes) * 60;
- let seconds = Math.round(_second);
- Cesium.Math.toRadians(value);
- Cesium.Math.toDegrees(value);
- let DMS = {
- degrees,
- minutes,
- seconds
- };
- return DMS;
- }
- static DMS2Degrees(DMS) {
- let _double = parseFloat(DMS.degrees) + parseFloat(DMS.minutes) / 60 + parseFloat(DMS.seconds) / 3600;
- return parseFloat(_double).toFixed(6);
- }
- static _cartesian3ToGeo(position2) {
- let g = Cesium.Ellipsoid.WGS84.cartesianToCartographic(position2);
- return {
- longitude: Cesium.Math.toDegrees(g.longitude),
- latitude: Cesium.Math.toDegrees(g.latitude),
- height: g.height
- };
- }
- static _arcToDegree(arc) {
- return arc / Math.PI * 180;
- }
- static _getScreenClickPositionAndHeight(viewer2, screenPoint) {
- this._viewer = viewer2;
- var lng = void 0, lat = void 0, height2 = void 0;
- var ray = this._viewer.scene.camera.getPickRay(screenPoint);
- var position2 = this._viewer.scene.globe.pick(ray, this._viewer.scene);
- var cartographic = Cesium.Ellipsoid.WGS84.cartesianToCartographic(position2);
- var feature2 = this._viewer.scene.pick(screenPoint);
- if (feature2 == void 0) {
- lng = this._arcToDegree(cartographic.longitude);
- lat = this._arcToDegree(cartographic.latitude);
- height2 = cartographic.height;
- } else {
- var cartesian = this._viewer.scene.pickPosition(screenPoint);
- if (Cesium.defined(cartesian)) {
- var cartographic = Cesium.Cartographic.fromCartesian(cartesian);
- lng = this._arcToDegree(cartographic.longitude);
- lat = this._arcToDegree(cartographic.latitude);
- height2 = cartographic.height;
- }
- }
- return {
- lng,
- lat,
- height: height2
- };
- }
- static _transfromFromScreenPoint(viewer2, screenPosition) {
- let location = this._getScreenClickPositionAndHeight(viewer2, screenPosition);
- var cartesian = Cesium.Cartesian3.fromDegrees(location.lng, location.lat, location.height);
- return {
- gLocation: location,
- sLocation: cartesian
- };
- }
- }
- class PolylineDirectionMaterialProperty {
- constructor(options2) {
- this.defaultColor = new Cesium.Color(255 / 255, 0, 0, 0);
- options2 = options2 || {};
- options2.isImageAlpha = Cesium.defaultValue(options2.isImageAlpha, true);
- options2.imgUrl = Cesium.defaultValue(options2.imgUrl, "jt3dSDK/imgs/polylinematerial/spriteline1.png");
- options2.duration = Cesium.defaultValue(options2.duration, 3e3);
- options2.count = Cesium.defaultValue(options2.count, 1);
- options2.direction = Cesium.defaultValue(options2.direction, "horizontal");
- options2.order = Cesium.defaultValue(options2.order, "-");
- if (options2.isImageAlpha) {
- options2.color = this.defaultColor;
- } else {
- if (options2.color instanceof Array) {
- options2.color = new Cesium.Color(options2.color[0] / 255, options2.color[1] / 255, options2.color[2] / 255, options2.color[3]);
- } else if (typeof options2.color === "string") {
- options2.color = new Cesium.Color.fromCssColorString(options2.color);
- } else {
- options2.color = this.defaultColor;
- }
- }
- this._definitionChanged = new Cesium.Event();
- this._color = void 0;
- this._image = void 0;
- this.color = options2.color;
- this.image = options2.imgUrl;
- this._isImageAlpha = options2.isImageAlpha;
- this._duration = options2.duration;
- this._count = options2.count;
- this._direction = options2.direction;
- this._order = options2.order;
- this._time = performance.now();
- this.addMaterial();
- }
- addMaterial() {
- Cesium.Material.PolylineTrailType = "PolylineTrail";
- Cesium.Material.Polylineimage = "images/colors.png";
- if (this._direction === "vertical") {
- if (this._isImageAlpha) {
- Cesium.Material.PolylineTrailSource = "czm_material czm_getMaterial(czm_materialInput materialInput)\n {\n czm_material material = czm_getDefaultMaterial(materialInput);\n vec2 st = repeat * materialInput.st;\n vec4 colorImage = texture2D(image, vec2(fract(st.t " + this._order + " time), st.s));\n material.alpha = colorImage.a;\n material.diffuse = colorImage.rgb* 1.5 ;\n return material;\n }";
- } else {
- Cesium.Material.PolylineTrailSource = "czm_material czm_getMaterial(czm_materialInput materialInput)\n {\n czm_material material = czm_getDefaultMaterial(materialInput);\n vec2 st = repeat * materialInput.st;\n vec4 colorImage = texture2D(image, vec2(fract(st.t " + this._order + " time), st.s));\n material.alpha = colorImage.a * color.a;\n material.diffuse = max(color.rgb * material.alpha * 3.0, color.rgb);\n return material;\n }";
- }
- } else if (this._direction === "horizontal") {
- if (this._isImageAlpha) {
- Cesium.Material.PolylineTrailSource = "czm_material czm_getMaterial(czm_materialInput materialInput)\n {\n czm_material material = czm_getDefaultMaterial(materialInput);\n vec2 st = repeat * materialInput.st;\n vec4 colorImage = texture2D(image, vec2(fract(st.s " + this._order + " time), st.t));\n material.alpha = colorImage.a;\n material.diffuse = colorImage.rgb * 1.5 ;\n return material;\n }";
- } else {
- Cesium.Material.PolylineTrailSource = "czm_material czm_getMaterial(czm_materialInput materialInput)\n {\n czm_material material = czm_getDefaultMaterial(materialInput);\n vec2 st = repeat * materialInput.st;\n vec4 colorImage = texture2D(image, vec2(fract(st.s " + this._order + " time), st.t));\n material.alpha = colorImage.a * color.a;\n material.diffuse = max(color.rgb * material.alpha * 3.0, color.rgb);\n return material;\n }";
- }
- }
- Cesium.Material._materialCache.addMaterial(Cesium.Material.PolylineTrailType, {
- fabric: {
- type: Cesium.Material.PolylineTrailType,
- uniforms: {
- color: new Cesium.Color(1, 0, 0, 0.5),
- image: Cesium.Material.Polylineimage,
- time: 0,
- repeat: new Cesium.Cartesian2(5, 1),
- order: "-"
- },
- source: Cesium.Material.PolylineTrailSource
- },
- translucent: function(material) {
- return true;
- }
- });
- }
- }
- PolylineDirectionMaterialProperty.prototype.getType = function(time) {
- return "PolylineTrail";
- };
- PolylineDirectionMaterialProperty.prototype.getValue = function(time, result) {
- if (!Cesium.defined(result)) {
- result = {};
- }
- result.color = Cesium.Property.getValueOrClonedDefault(this._color, time, this.defaultColor, result.color);
- result.image = Cesium.Property.getValueOrUndefined(this._image, time);
- result.time = (performance.now() - this._time) % this._duration / this._duration;
- result.repeat = new Cesium.Cartesian2(this._count, 1);
- result.order = this._order;
- return result;
- };
- PolylineDirectionMaterialProperty.prototype.equals = function(other) {
- return this === other || other instanceof PolylineDirectionMaterialProperty && Cesium.Property.equals(this._color, other._color);
- };
- Object.defineProperties(PolylineDirectionMaterialProperty.prototype, {
- isConstant: {
- get: function() {
- return false;
- }
- },
- definitionChanged: {
- get: function() {
- return this._definitionChanged;
- }
- },
- color: Cesium.createPropertyDescriptor("color"),
- image: Cesium.createPropertyDescriptor("image")
- });
- class WallMaterialProperty$1 {
- constructor(viewer2, options2) {
- this._viewer = viewer2;
- options2 = options2 || {};
- this._definitionChanged = new Cesium.Event();
- this._color = void 0;
- this.color = options2.color || Cesium.Color.BLUE;
- this.duration = options2.duration || 1e3;
- this.count = options2.duration || 1;
- this.direction = options2.duration || "vertical";
- this.order = options2.duration || "-";
- this.trailImage = Cesium.defaultValue(options2.trailImage, "jt3dSDK/imgs/wallmaterial/wl.png");
- this._time = new Date().getTime();
- this._materialTypeName = "WallMaterial" + this._guid();
- this._param = {
- color: this.color._value.toCssColorString(),
- image: this.trailImage,
- duration: this.duration,
- count: this.count,
- direction: this.direction,
- order: this.order
- };
- Cesium.Material._materialCache.addMaterial(this._materialTypeName, {
- fabric: {
- type: this._materialTypeName,
- uniforms: {
- time: -20,
- color: new Cesium.Color(1, 0, 0, 0.5),
- image: options2.trailImage
- },
- source: this._getDirectionWallShader(options2.param)
- },
- translucent: function(material) {
- return true;
- }
- });
- }
- _guid() {
- function S4() {
- return ((1 + Math.random()) * 65536 | 0).toString(16).substring(1);
- }
- return S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4();
- }
- getType(time) {
- return this._materialTypeName;
- }
- getValue(time, result) {
- if (!Cesium.defined(result)) {
- result = {};
- }
- result.color = Cesium.Property.getValueOrClonedDefault(this._color, time, Cesium.Color.BLUE, result.color);
- result.image = this.trailImage;
- if (this.duration) {
- result.time = (new Date().getTime() - this._time) % this.duration / this.duration;
- }
- this._viewer.scene.requestRender();
- return result;
- }
- equals(other) {
- return this === other || other instanceof WallMaterialProperty$1 && Cesium.Property.equals(this._color, other._color) && other._param.order === this._param.order && other._param.count === this._param.count && other._param.direction === this._param.direction && other.duration === this.duration;
- }
- _getDirectionWallShader(options2) {
- let op = Cesium.defaultValue(options2, {});
- let count = op.count !== void 0 && typeof op.count === "number" && op.count > 0 ? op.count : 1;
- let direction = op.direction === "horizontal" ? "horizontal" : "vertical";
- let order = op.order === "+" ? "+" : "-";
- this._param.count = count;
- this._param.direction = direction;
- this._param.order = order;
- let materail = "";
- materail += "czm_material czm_getMaterial(czm_materialInput materialInput){\n czm_material material = czm_getDefaultMaterial(materialInput);\n vec2 st = materialInput.st;\n";
- if (direction === "vertical") {
- materail += " vec4 colorImage = texture2D(image,vec2(st.s,fract(float(" + count + ")*st.t " + order + " time)));\n";
- } else if (direction === "horizontal") {
- materail += " vec4 colorImage = texture2D(image, vec2(fract(float(" + count + ")*st.s " + order + " time), st.t));\n";
- }
- materail += " vec4 fragColor;\n fragColor.rgb = color.rgb / 1.0;\n fragColor = czm_gammaCorrect(fragColor);\n material.alpha = colorImage.a * color.a;\n material.diffuse = color.rgb;\n material.emission = fragColor.rgb;\n return material;\n}";
- return materail;
- }
- }
- Object.defineProperties(WallMaterialProperty$1.prototype, {
- isConstant: {
- get: function() {
- return false;
- }
- },
- definitionChanged: {
- get: function() {
- return this._definitionChanged;
- }
- },
- color: Cesium.createPropertyDescriptor("color")
- });
- var tooltip = "";
- function setSessionid$1(num) {
- let len = num || 32;
- let chars = "ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678";
- let maxPos = chars.length;
- let pwd = "";
- for (let i2 = 0; i2 < len; i2++) {
- pwd += chars.charAt(Math.floor(Math.random() * maxPos));
- }
- return pwd;
- }
- function guid() {
- function S4() {
- return ((1 + Math.random()) * 65536 | 0).toString(16).substring(1);
- }
- return S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4();
- }
- function getGuid(removeMinus) {
- let d2 = new Date().getTime();
- let uuid = "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function(c) {
- const r2 = (d2 + Math.random() * 16) % 16 | 0;
- d2 = Math.floor(d2 / 16);
- return (c === "x" ? r2 : r2 & 3 | 8).toString(16);
- });
- if (removeMinus) {
- uuid = uuid.replace(/-/g, "");
- }
- return uuid;
- }
- function getHeigthByLngLat(viewer2, options2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!Cesium.defined(options2.longitude) && !Cesium.defined(options2.latitude)) {
- throw new Cesium.DeveloperError("longitude and latitude are required.");
- }
- options2.level = Cesium.defaultValue(options2.level, 11);
- let positions = Cesium.Cartographic.fromDegrees(options2.longitude, options2.latitude);
- let terrainProvider = viewer2.terrainProvider;
- return new Promise((resolve2, reject2) => {
- new Cesium.sampleTerrain(terrainProvider, options2.level, [positions]).then(function(updatedPositions) {
- if (updatedPositions) {
- resolve2(updatedPositions[0].height);
- }
- });
- });
- }
- function getHeigthByPoints(viewer2, options2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!Cesium.defined(options2)) {
- throw new Cesium.DeveloperError("options is required.");
- }
- options2.level = Cesium.defaultValue(options2.level, 11);
- let positions = [];
- let points2 = options2.points;
- for (let i2 = 0; i2 < points2.length; i2++) {
- let pointX = points2[i2][0];
- let pointY = points2[i2][1];
- positions.push(
- Cesium.Cartographic.fromDegrees(pointX, pointY)
- );
- }
- let terrainProvider = viewer2.terrainProvider;
- return new Promise((resolve2, reject2) => {
- new Cesium.sampleTerrain(terrainProvider, options2.level, positions).then(function(updatedPositions) {
- if (updatedPositions) {
- resolve2(updatedPositions);
- }
- });
- });
- }
- function getHeigthByPointsMostDetailed(viewer2, points2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- let positions = [];
- for (let i2 = 0; i2 < points2.length; i2++) {
- let pointX = points2[i2][0];
- let pointY = points2[i2][1];
- positions.push(Cesium.Cartographic.fromDegrees(pointX, pointY));
- }
- let terrainProvider = viewer2.terrainProvider;
- return new Promise((resolve2, reject2) => {
- let promise = new Cesium.sampleTerrainMostDetailed(terrainProvider, positions);
- promise.then(function(updatedPositions) {
- resolve2(updatedPositions);
- });
- });
- }
- function getHeigthByPointMostDetailed(viewer2, points2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- let positions = Cesium.Cartographic.fromDegrees(points2[0], points2[1]);
- let terrainProvider = viewer2.terrainProvider;
- return new Promise((resolve2, reject2) => {
- let promise = new Cesium.sampleTerrainMostDetailed(terrainProvider, positions);
- promise.then(function(updatedPositions) {
- resolve2(updatedPositions);
- });
- });
- }
- function createTooltip(frameDiv) {
- var tooltip2 = function(frameDiv2) {
- var div = document.createElement("DIV");
- div.className = "twipsy right";
- var arrow = document.createElement("DIV");
- arrow.className = "twipsy-arrow";
- div.appendChild(arrow);
- var title = document.createElement("DIV");
- title.className = "twipsy-inner";
- div.appendChild(title);
- this._div = div;
- this._title = title;
- frameDiv2.appendChild(div);
- };
- tooltip2.prototype.setVisible = function(visible) {
- this._div.style.display = visible ? "block" : "none";
- };
- tooltip2.prototype.showAt = function(position2, message) {
- if (position2 && message) {
- this.setVisible(true);
- this._title.innerHTML = message;
- this._div.style.left = position2.x + 10 + "px";
- this._div.style.top = position2.y - this._div.clientHeight / 2 + "px";
- }
- };
- return new tooltip2(frameDiv);
- }
- var common = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
- __proto__: null,
- setSessionid: setSessionid$1,
- guid,
- getGuid,
- getHeigthByLngLat,
- getHeigthByPoints,
- getHeigthByPointsMostDetailed,
- getHeigthByPointMostDetailed,
- createTooltip
- }, Symbol.toStringTag, { value: "Module" }));
- class PointObject {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- }
- }
- Object.assign(PointObject.prototype, {
- addLabel(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- let position2;
- if (points2 instanceof Cesium.Cartesian3) {
- position2 = points2;
- } else {
- position2 = Cesium.Cartesian3.fromDegrees(points2[0], points2[1], points2[2] || 0);
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- let label2 = options2.label || {};
- label2.text = Cesium.defaultValue(label2.text, "\u91D1\u7530CIM\u4E09\u7EF4\u57FA\u7840\u5E73\u53F0");
- label2.font = Cesium.defaultValue(label2.font, "24px Helvetica");
- if (label2.fillColor instanceof Cesium.Color) {
- label2.fillColor = label2.fillColor;
- } else if (label2.fillColor instanceof Array) {
- label2.fillColor = new Cesium.Color(label2.fillColor[0] / 255, label2.fillColor[1] / 255, label2.fillColor[2] / 255, label2.fillColor[3]);
- } else if (typeof label2.fillColor === "string") {
- label2.fillColor = new Cesium.Color.fromCssColorString(label2.fillColor);
- } else {
- label2.fillColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- if (label2.outlineColor instanceof Cesium.Color) {
- label2.outlineColor = label2.outlineColor;
- } else if (label2.outlineColor instanceof Array) {
- label2.outlineColor = new Cesium.Color(label2.outlineColor[0] / 255, label2.outlineColor[1] / 255, label2.outlineColor[2] / 255, label2.outlineColor[3]);
- } else if (typeof label2.outlineColor === "string") {
- label2.outlineColor = new Cesium.Color.fromCssColorString(label2.outlineColor);
- } else {
- label2.outlineColor = new Cesium.Color.fromCssColorString("#FFF");
- }
- label2.outlineWidth = Cesium.defaultValue(label2.outlineWidth, 1);
- label2.showBackground = Cesium.defaultValue(label2.showBackground, false);
- if (label2.backgroundColor instanceof Cesium.Color) {
- label2.backgroundColor = label2.backgroundColor;
- } else if (label2.backgroundColor instanceof Array) {
- label2.backgroundColor = new Cesium.Color(label2.backgroundColor[0] / 255, label2.backgroundColor[1] / 255, label2.backgroundColor[2] / 255, label2.backgroundColor[3]);
- } else if (typeof label2.backgroundColor === "string") {
- label2.backgroundColor = new Cesium.Color.fromCssColorString(label2.backgroundColor);
- } else {
- label2.backgroundColor = new Cesium.Color.fromCssColorString("#FFF");
- }
- if (label2.backgroundPadding) {
- label2.backgroundPadding = new Cesium.Cartesian2(label2.backgroundPadding, label2.backgroundPadding);
- }
- let entity = new Cesium.Entity({
- position: position2,
- label: {
- text: label2.text,
- font: label2.font,
- fillColor: label2.fillColor,
- outlineColor: label2.outlineColor,
- outlineWidth: label2.outlineWidth,
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- showBackground: label2.showBackground,
- backgroundColor: label2.backgroundColor,
- backgroundPadding: label2.backgroundPadding
- }
- });
- if (label2.pixelOffset) {
- label2.pixelOffset.x = Cesium.defaultValue(label2.pixelOffset.x, 0);
- label2.pixelOffset.y = Cesium.defaultValue(label2.pixelOffset.y, 0);
- entity.label.pixelOffset = new Cesium.Cartesian2(label2.pixelOffset.x, label2.pixelOffset.y);
- }
- if (label2.eyeOffset) {
- label2.eyeOffset.x = Cesium.defaultValue(label2.eyeOffset.x, 0);
- label2.eyeOffset.y = Cesium.defaultValue(label2.eyeOffset.y, 0);
- label2.eyeOffset.z = Cesium.defaultValue(label2.eyeOffset.z, 0);
- entity.label.eyeOffset = new Cesium.Cartesian3(label2.eyeOffset.x, label2.eyeOffset.y, label2.eyeOffset.z);
- }
- if (label2.scaleByDistance) {
- label2.scaleByDistance.near = Cesium.defaultValue(label2.scaleByDistance.near, 0);
- label2.scaleByDistance.nearValue = Cesium.defaultValue(label2.scaleByDistance.nearValue, 0);
- label2.scaleByDistance.far = Cesium.defaultValue(label2.scaleByDistance.far, 1);
- label2.scaleByDistance.farValue = Cesium.defaultValue(label2.scaleByDistance.farValue, 0);
- entity.label.scaleByDistance = new Cesium.NearFarScalar(label2.scaleByDistance.near, label2.scaleByDistance.nearValue, label2.scaleByDistance.far, label2.scaleByDistance.farValue);
- }
- if (label2.distanceDisplayCondition) {
- label2.distanceDisplayCondition.near = Cesium.defaultValue(label2.distanceDisplayCondition.near, 0);
- label2.distanceDisplayCondition.far = Cesium.defaultValue(label2.distanceDisplayCondition.far, Number.MAX_VALUE);
- entity.label.distanceDisplayCondition = new Cesium.DistanceDisplayCondition(label2.distanceDisplayCondition.near, label2.distanceDisplayCondition.far);
- }
- if (label2.disableDepthTestDistance) {
- label2.disableDepthTestDistance = Cesium.defaultValue(label2.disableDepthTestDistance, 999);
- entity.label.disableDepthTestDistance = label2.disableDepthTestDistance;
- }
- resolve2(entity);
- });
- },
- addPoint(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- let position2;
- if (points2 instanceof Cesium.Cartesian3) {
- position2 = points2;
- } else {
- position2 = Cesium.Cartesian3.fromDegrees(points2[0], points2[1], points2[2] || 0);
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- let point2 = options2.point || {};
- point2.pixelSize = Cesium.defaultValue(point2.pixelSize, 10);
- if (point2.color instanceof Cesium.Color) {
- point2.color = point2.color;
- } else if (point2.color instanceof Array) {
- point2.color = new Cesium.Color(point2.color[0] / 255, point2.color[1] / 255, point2.color[2] / 255, point2.color[3]);
- } else if (typeof point2.color === "string") {
- point2.color = new Cesium.Color.fromCssColorString(point2.color);
- } else {
- point2.color = new Cesium.Color.fromCssColorString("#FFF");
- }
- if (point2.outlineColor instanceof Cesium.Color) {
- point2.outlineColor = point2.outlineColor;
- } else if (point2.outlineColor instanceof Array) {
- point2.outlineColor = new Cesium.Color(point2.outlineColor[0] / 255, point2.outlineColor[1] / 255, point2.outlineColor[2] / 255, point2.outlineColor[3]);
- } else if (typeof point2.outlineColor === "string") {
- point2.outlineColor = new Cesium.Color.fromCssColorString(point2.outlineColor);
- } else {
- point2.outlineColor = new Cesium.Color.fromCssColorString("#FFF");
- }
- point2.outlineWidth = Cesium.defaultValue(point2.outlineWidth, 1);
- let entity = new Cesium.Entity({
- position: position2,
- point: {
- pixelSize: point2.pixelSize,
- color: point2.color,
- outlineColor: point2.outlineColor,
- outlineWidth: point2.outlineWidth,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND,
- disableDepthTestDistance: Number.POSITIVE_INFINITY,
- clampToGround: true
- }
- });
- if (options2.label) {
- let label2 = options2.label || {};
- label2.text = Cesium.defaultValue(label2.text, "");
- label2.font = Cesium.defaultValue(label2.font, "24px Helvetica");
- if (label2.fillColor instanceof Cesium.Color) {
- label2.fillColor = label2.outlineColor;
- } else if (label2.fillColor instanceof Array) {
- label2.fillColor = new Cesium.Color(label2.fillColor[0] / 255, label2.fillColor[1] / 255, label2.fillColor[2] / 255, label2.fillColor[3]);
- } else if (typeof label2.fillColor === "string") {
- label2.fillColor = new Cesium.Color.fromCssColorString(label2.fillColor);
- } else {
- label2.fillColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- if (label2.outlineColor instanceof Cesium.Color) {
- label2.outlineColor = label2.outlineColor;
- } else if (label2.outlineColor instanceof Array) {
- label2.outlineColor = new Cesium.Color(label2.outlineColor[0] / 255, label2.outlineColor[1] / 255, label2.outlineColor[2] / 255, label2.outlineColor[3]);
- } else if (typeof label2.outlineColor === "string") {
- label2.outlineColor = new Cesium.Color.fromCssColorString(label2.outlineColor);
- } else {
- label2.outlineColor = new Cesium.Color.fromCssColorString("#FFF");
- }
- label2.outlineWidth = Cesium.defaultValue(label2.outlineWidth, 1);
- label2.showBackground = Cesium.defaultValue(label2.showBackground, false);
- if (label2.backgroundColor instanceof Cesium.Color) {
- label2.backgroundColor = label2.backgroundColor;
- } else if (label2.backgroundColor instanceof Array) {
- label2.backgroundColor = new Cesium.Color(label2.backgroundColor[0] / 255, label2.backgroundColor[1] / 255, label2.backgroundColor[2] / 255, label2.backgroundColor[3]);
- } else if (typeof label2.backgroundColor === "string") {
- label2.backgroundColor = new Cesium.Color.fromCssColorString(label2.backgroundColor);
- } else {
- label2.backgroundColor = new Cesium.Color.fromCssColorString("#FFF");
- }
- if (label2.backgroundPadding) {
- label2.backgroundPadding = new Cesium.Cartesian2(label2.backgroundPadding, label2.backgroundPadding);
- }
- entity.label = {
- text: label2.text,
- font: label2.font,
- fillColor: label2.fillColor,
- outlineColor: label2.outlineColor,
- outlineWidth: label2.outlineWidth,
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- showBackground: label2.showBackground,
- backgroundColor: label2.backgroundColor,
- backgroundPadding: new Cesium.Cartesian2(6, 6),
- disableDepthTestDistance: Number.POSITIVE_INFINITY,
- eyeOffset: new Cesium.Cartesian3(0, 0, 1e4),
- clampToGround: true
- };
- if (label2.pixelOffset) {
- label2.pixelOffset.x = Cesium.defaultValue(label2.pixelOffset.x, 0);
- label2.pixelOffset.y = Cesium.defaultValue(label2.pixelOffset.y, 0);
- entity.label.pixelOffset = new Cesium.Cartesian2(label2.pixelOffset.x, label2.pixelOffset.y);
- }
- if (label2.scaleByDistance) {
- label2.scaleByDistance.near = Cesium.defaultValue(label2.scaleByDistance.near, 0);
- label2.scaleByDistance.nearValue = Cesium.defaultValue(label2.scaleByDistance.nearValue, 0);
- label2.scaleByDistance.far = Cesium.defaultValue(label2.scaleByDistance.far, 1);
- label2.scaleByDistance.farValue = Cesium.defaultValue(label2.scaleByDistance.farValue, 0);
- entity.label.scaleByDistance = new Cesium.NearFarScalar(label2.scaleByDistance.near, label2.scaleByDistance.nearValue, label2.scaleByDistance.far, label2.scaleByDistance.farValue);
- entity.label.distanceDisplayCondition = new Cesium.DistanceDisplayCondition(label2.scaleByDistance.near, label2.scaleByDistance.far);
- }
- if (label2.distanceDisplayCondition) {
- label2.distanceDisplayCondition.near = Cesium.defaultValue(label2.distanceDisplayCondition.near, 0);
- label2.distanceDisplayCondition.far = Cesium.defaultValue(label2.distanceDisplayCondition.far, Number.MAX_VALUE);
- entity.label.distanceDisplayCondition = new Cesium.DistanceDisplayCondition(label2.distanceDisplayCondition.near, label2.distanceDisplayCondition.far);
- }
- if (label2.disableDepthTestDistance) {
- label2.disableDepthTestDistance = Cesium.defaultValue(label2.disableDepthTestDistance, 999);
- entity.label.disableDepthTestDistance = label2.disableDepthTestDistance;
- }
- }
- resolve2(entity);
- });
- },
- addBillboard(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- let position2;
- if (points2 instanceof Cesium.Cartesian3) {
- position2 = points2;
- } else {
- position2 = Cesium.Cartesian3.fromDegrees(points2[0], points2[1], points2[2] || 0);
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- let billboard = options2.billboard || {};
- billboard.image = billboard.imgUrl || "jt3dSDK/imgs/point/point3.png";
- billboard.scale = Cesium.defaultValue(billboard.scale, 1);
- let entity = new Cesium.Entity({
- name: "add billboard",
- position: position2,
- billboard: {
- image: billboard.image,
- horizontalOrigin: Cesium.HorizontalOrigin.CENTER,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- scale: billboard.scale
- }
- });
- if (options2.properties) {
- entity.properties = options2.properties;
- }
- if (billboard.pixelOffset) {
- billboard.pixelOffset.x = Cesium.defaultValue(billboard.pixelOffset.x, 0);
- billboard.pixelOffset.y = Cesium.defaultValue(billboard.pixelOffset.y, 0);
- entity.billboard.pixelOffset = new Cesium.Cartesian2(billboard.pixelOffset.x, billboard.pixelOffset.y);
- }
- if (billboard.scaleByDistance) {
- billboard.scaleByDistance.near = Cesium.defaultValue(billboard.scaleByDistance.near, 0);
- billboard.scaleByDistance.nearValue = Cesium.defaultValue(billboard.scaleByDistance.nearValue, 0);
- billboard.scaleByDistance.far = Cesium.defaultValue(billboard.scaleByDistance.far, 1);
- billboard.scaleByDistance.farValue = Cesium.defaultValue(billboard.scaleByDistance.farValue, 0);
- entity.billboard.scaleByDistance = new Cesium.NearFarScalar(billboard.scaleByDistance.near, billboard.scaleByDistance.nearValue, billboard.scaleByDistance.far, billboard.scaleByDistance.farValue);
- entity.billboard.distanceDisplayCondition = new Cesium.DistanceDisplayCondition(billboard.scaleByDistance.near, billboard.scaleByDistance.far);
- }
- if (billboard.distanceDisplayCondition) {
- billboard.distanceDisplayCondition.near = Cesium.defaultValue(billboard.distanceDisplayCondition.near, 0);
- billboard.distanceDisplayCondition.far = Cesium.defaultValue(billboard.distanceDisplayCondition.far, Number.MAX_VALUE);
- entity.billboard.distanceDisplayCondition = new Cesium.DistanceDisplayCondition(billboard.distanceDisplayCondition.near, billboard.distanceDisplayCondition.far);
- }
- if (billboard.disableDepthTestDistance) {
- billboard.disableDepthTestDistance = Cesium.defaultValue(billboard.disableDepthTestDistance, 999);
- entity.billboard.disableDepthTestDistance = billboard.disableDepthTestDistance;
- }
- if (options2.label) {
- let label2 = options2.label || {};
- label2.text = Cesium.defaultValue(label2.text, "");
- label2.font = Cesium.defaultValue(label2.font, "24px Helvetica");
- if (label2.fillColor instanceof Cesium.Color) {
- label2.fillColor = label2.fillColor;
- } else if (label2.fillColor instanceof Array) {
- label2.fillColor = new Cesium.Color(label2.fillColor[0] / 255, label2.fillColor[1] / 255, label2.fillColor[2] / 255, label2.fillColor[3]);
- } else if (typeof label2.fillColor === "string") {
- label2.fillColor = new Cesium.Color.fromCssColorString(label2.fillColor);
- } else {
- label2.fillColor = new Cesium.Color.fromCssColorString("#ff0000");
- }
- if (label2.outlineColor instanceof Cesium.Color) {
- label2.outlineColor = label2.outlineColor;
- } else if (label2.outlineColor instanceof Array) {
- label2.outlineColor = new Cesium.Color(label2.outlineColor[0] / 255, label2.outlineColor[1] / 255, label2.outlineColor[2] / 255, label2.outlineColor[3]);
- } else if (typeof label2.outlineColor === "string") {
- label2.outlineColor = new Cesium.Color.fromCssColorString(label2.outlineColor);
- } else {
- label2.outlineColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- label2.outlineWidth = Cesium.defaultValue(label2.outlineWidth, 1);
- label2.showBackground = Cesium.defaultValue(label2.showBackground, false);
- if (label2.backgroundColor instanceof Cesium.Color) {
- label2.backgroundColor = label2.backgroundColor;
- } else if (label2.backgroundColor instanceof Array) {
- label2.backgroundColor = new Cesium.Color(label2.backgroundColor[0] / 255, label2.backgroundColor[1] / 255, label2.backgroundColor[2] / 255, label2.backgroundColor[3]);
- } else if (typeof label2.backgroundColor === "string") {
- label2.backgroundColor = new Cesium.Color.fromCssColorString(label2.backgroundColor);
- } else {
- label2.backgroundColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- if (label2.backgroundPadding) {
- label2.backgroundPadding = new Cesium.Cartesian2(label2.backgroundPadding, label2.backgroundPadding);
- }
- entity.label = {
- text: label2.text,
- font: label2.font,
- fillColor: label2.fillColor,
- outlineColor: label2.outlineColor,
- outlineWidth: label2.outlineWidth,
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- showBackground: label2.showBackground,
- backgroundColor: label2.backgroundColor,
- backgroundPadding: label2.backgroundPadding,
- clampToGround: true,
- eyeOffset: new Cesium.Cartesian3(0, 0, 1e4)
- };
- if (label2.pixelOffset) {
- label2.pixelOffset.x = Cesium.defaultValue(label2.pixelOffset.x, 0);
- label2.pixelOffset.y = Cesium.defaultValue(label2.pixelOffset.y, 0);
- entity.label.pixelOffset = new Cesium.Cartesian2(label2.pixelOffset.x, label2.pixelOffset.y);
- }
- if (label2.scaleByDistance) {
- label2.scaleByDistance.near = Cesium.defaultValue(label2.scaleByDistance.near, 0);
- label2.scaleByDistance.nearValue = Cesium.defaultValue(label2.scaleByDistance.nearValue, 0);
- label2.scaleByDistance.far = Cesium.defaultValue(label2.scaleByDistance.far, 1);
- label2.scaleByDistance.farValue = Cesium.defaultValue(label2.scaleByDistance.farValue, 0);
- entity.label.scaleByDistance = new Cesium.NearFarScalar(label2.scaleByDistance.near, label2.scaleByDistance.nearValue, label2.scaleByDistance.far, label2.scaleByDistance.farValue);
- entity.label.distanceDisplayCondition = new Cesium.DistanceDisplayCondition(label2.scaleByDistance.near, label2.scaleByDistance.far);
- }
- if (label2.distanceDisplayCondition) {
- label2.distanceDisplayCondition.near = Cesium.defaultValue(label2.distanceDisplayCondition.near, 0);
- label2.distanceDisplayCondition.far = Cesium.defaultValue(label2.distanceDisplayCondition.far, Number.MAX_VALUE);
- entity.label.distanceDisplayCondition = new Cesium.DistanceDisplayCondition(label2.distanceDisplayCondition.near, label2.distanceDisplayCondition.far);
- }
- if (label2.disableDepthTestDistance) {
- label2.disableDepthTestDistance = Cesium.defaultValue(label2.disableDepthTestDistance, 999);
- entity.label.disableDepthTestDistance = label2.disableDepthTestDistance;
- }
- }
- resolve2(entity);
- });
- },
- addModel: function(points2, options2) {
- this._viewer;
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- let position2;
- if (points2 instanceof Cesium.Cartesian3) {
- position2 = points2;
- } else {
- position2 = Cesium.Cartesian3.fromDegrees(points2[0], points2[1], points2[2] || 0);
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- let model = options2.model || {};
- model.alpha = Cesium.defaultValue(model.alpha, 1);
- model.heading = Cesium.defaultValue(model.heading, 0);
- model.pitch = Cesium.defaultValue(model.pitch, 0);
- model.roll = Cesium.defaultValue(model.roll, 0);
- var heading = Cesium.Math.toRadians(model.heading);
- var pitch = model.pitch;
- var roll = model.roll;
- new Cesium.HeadingPitchRoll(heading, pitch, roll);
- let entity = new Cesium.Entity({
- position: position2,
- model: {
- uri: model.url,
- incrementallyLoadTextures: true,
- colorBlendMode: Cesium.ColorBlendMode["HIGHLIGHT"],
- colorBlendAmount: 0.1,
- color: Cesium.Color.WHITE.withAlpha(model.alpha),
- imageBasedLightingFactor: new Cesium.Cartesian2(12, 13),
- runAnimations: true,
- show: true,
- debugWireframe: false,
- debugShowBoundingVolume: false,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND,
- disableDepthTestDistance: Number.POSITIVE_INFINITY,
- clampToGround: true
- }
- });
- if (model.minimumPixelSize) {
- entity.model.minimumPixelSize = model.minimumPixelSize;
- }
- if (model.maximumScale) {
- entity.model.maximumScale = model.maximumScale;
- }
- if (options2.silhouetteColor) {
- if (model.silhouetteColor instanceof Cesium.Color) {
- model.silhouetteColor = model.silhouetteColor;
- } else if (model.silhouetteColor instanceof Array) {
- model.silhouetteColor = new Cesium.Color(model.silhouetteColor[0] / 255, model.silhouetteColor[1] / 255, model.silhouetteColor[2] / 255, model.silhouetteColor[3]);
- } else if (typeof model.silhouetteColor === "string") {
- model.silhouetteColor = new Cesium.Color.fromCssColorString(model.silhouetteColor);
- } else {
- model.silhouetteColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- model.silhouetteSize = Cesium.defaultValue(model.silhouetteSize, 1);
- resolve2(entity);
- });
- },
- generatePoint(points2, options2) {
- return new Promise((resolve2, reject2) => {
- let _self = this;
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- let point2 = options2.point || {};
- point2.pixelSize = Cesium.defaultValue(point2.pixelSize, 10);
- if (point2.color instanceof Cesium.Color) {
- point2.color = point2.color;
- } else if (point2.color instanceof Array) {
- point2.color = new Cesium.Color(point2.color[0] / 255, point2.color[1] / 255, point2.color[2] / 255, point2.color[3]);
- } else if (typeof point2.color === "string") {
- point2.color = new Cesium.Color.fromCssColorString(point2.color);
- } else {
- point2.color = new Cesium.Color.fromCssColorString("#FFF");
- }
- if (point2.outlineColor instanceof Cesium.Color) {
- point2.outlineColor = point2.outlineColor;
- } else if (point2.outlineColor instanceof Array) {
- point2.outlineColor = new Cesium.Color(point2.outlineColor[0] / 255, point2.outlineColor[1] / 255, point2.outlineColor[2] / 255, point2.outlineColor[3]);
- } else if (typeof point2.outlineColor === "string") {
- point2.outlineColor = new Cesium.Color.fromCssColorString(point2.outlineColor);
- } else {
- point2.outlineColor = new Cesium.Color.fromCssColorString("#FFF");
- }
- point2.outlineWidth = Cesium.defaultValue(point2.outlineWidth, 1);
- let terrainAltitude = getHeigthByPointsMostDetailed(_self._viewer, [points2]);
- terrainAltitude.then(function(updatedPositions) {
- let position2 = Cesium.Cartesian3.fromDegrees(points2[0], points2[1], updatedPositions[0].height);
- let entity = new Cesium.Entity({
- id: options2.id,
- position: position2,
- point: {
- pixelSize: point2.pixelSize,
- color: point2.color,
- outlineColor: point2.outlineColor,
- outlineWidth: point2.outlineWidth,
- heightReference: Cesium.HeightReference.NONE,
- disableDepthTestDistance: updatedPositions[0].height,
- clampToGround: true
- }
- });
- if (options2.label) {
- let label2 = options2.label || {};
- label2.text = Cesium.defaultValue(label2.text, "");
- label2.font = Cesium.defaultValue(label2.font, "24px Helvetica");
- if (label2.fillColor instanceof Cesium.Color) {
- label2.fillColor = label2.fillColor;
- } else if (label2.fillColor instanceof Array) {
- label2.fillColor = new Cesium.Color(label2.fillColor[0] / 255, label2.fillColor[1] / 255, label2.fillColor[2] / 255, label2.fillColor[3]);
- } else if (typeof label2.fillColor === "string") {
- label2.fillColor = new Cesium.Color.fromCssColorString(label2.fillColor);
- } else {
- label2.fillColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- if (label2.outlineColor instanceof Cesium.Color) {
- label2.outlineColor = label2.outlineColor;
- } else if (label2.outlineColor instanceof Array) {
- label2.outlineColor = new Cesium.Color(label2.outlineColor[0] / 255, label2.outlineColor[1] / 255, label2.outlineColor[2] / 255, label2.outlineColor[3]);
- } else if (typeof label2.outlineColor === "string") {
- label2.outlineColor = new Cesium.Color.fromCssColorString(label2.outlineColor);
- } else {
- label2.outlineColor = new Cesium.Color.fromCssColorString("#FFF");
- }
- label2.outlineWidth = Cesium.defaultValue(label2.outlineWidth, 1);
- label2.showBackground = Cesium.defaultValue(label2.showBackground, false);
- if (label2.backgroundColor instanceof Cesium.Color) {
- label2.backgroundColor = label2.backgroundColor;
- } else if (label2.backgroundColor instanceof Array) {
- label2.backgroundColor = new Cesium.Color(label2.backgroundColor[0] / 255, label2.backgroundColor[1] / 255, label2.backgroundColor[2] / 255, label2.backgroundColor[3]);
- } else if (typeof label2.backgroundColor === "string") {
- label2.backgroundColor = new Cesium.Color.fromCssColorString(label2.backgroundColor);
- } else {
- label2.backgroundColor = new Cesium.Color.fromCssColorString("#FFF");
- }
- label2.scale = Cesium.defaultValue(label2.scale, 1);
- entity.label = {
- text: label2.text,
- font: label2.font,
- fillColor: label2.fillColor,
- outlineColor: label2.outlineColor,
- outlineWidth: label2.outlineWidth,
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- showBackground: label2.showBackground,
- backgroundColor: label2.backgroundColor,
- backgroundPadding: new Cesium.Cartesian2(6, 6),
- disableDepthTestDistance: Number.POSITIVE_INFINITY,
- scale: label2.scale,
- clampToGround: true
- };
- if (label2.pixelOffset) {
- label2.pixelOffset.x = Cesium.defaultValue(label2.pixelOffset.x, 0);
- label2.pixelOffset.y = Cesium.defaultValue(label2.pixelOffset.y, 0);
- entity.label.pixelOffset = new Cesium.Cartesian2(label2.pixelOffset.x, label2.pixelOffset.y);
- }
- if (label2.scaleByDistance) {
- label2.scaleByDistance.near = Cesium.defaultValue(label2.scaleByDistance.near, 0);
- label2.scaleByDistance.nearValue = Cesium.defaultValue(label2.scaleByDistance.nearValue, 0);
- label2.scaleByDistance.far = Cesium.defaultValue(label2.scaleByDistance.far, 1);
- label2.scaleByDistance.farValue = Cesium.defaultValue(label2.scaleByDistance.farValue, 0);
- entity.label.scaleByDistance = new Cesium.NearFarScalar(label2.scaleByDistance.near, label2.scaleByDistance.nearValue, label2.scaleByDistance.far, label2.scaleByDistance.farValue);
- }
- if (label2.distanceDisplayCondition) {
- label2.distanceDisplayCondition.near = Cesium.defaultValue(label2.distanceDisplayCondition.near, 0);
- label2.distanceDisplayCondition.far = Cesium.defaultValue(label2.distanceDisplayCondition.far, Number.MAX_VALUE);
- entity.label.distanceDisplayCondition = new Cesium.DistanceDisplayCondition(label2.distanceDisplayCondition.near, label2.distanceDisplayCondition.far);
- }
- if (label2.disableDepthTestDistance) {
- label2.disableDepthTestDistance = Cesium.defaultValue(label2.disableDepthTestDistance, 999);
- entity.label.disableDepthTestDistance = label2.disableDepthTestDistance;
- }
- }
- resolve2(entity);
- });
- });
- },
- addBillboardByGeoJson: function(geoJsonUrl, options2) {
- return new Promise((resolve2, reject2) => {
- let viewer2 = this._viewer;
- if (!Cesium.defined(geoJsonUrl)) {
- throw new Cesium.DeveloperError("geoJsonUrl is required.");
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- let billboard = options2.billboard || {};
- billboard.imgUrl = Cesium.defaultValue(billboard.imgUrl, "jt3dSDK/imgs/point/point3.png");
- billboard.scale = Cesium.defaultValue(billboard.scale, 1);
- let label2 = options2.label || {};
- label2.text = Cesium.defaultValue(label2.text, "");
- label2.textField = Cesium.defaultValue(label2.textField, "");
- label2.font = Cesium.defaultValue(label2.font, "24px Helvetica");
- if (label2.fillColor instanceof Cesium.Color) {
- label2.fillColor = label2.fillColor;
- } else if (label2.fillColor instanceof Array) {
- label2.fillColor = new Cesium.Color(label2.fillColor[0] / 255, label2.fillColor[1] / 255, label2.fillColor[2] / 255, label2.fillColor[3]);
- } else if (typeof label2.fillColor === "string") {
- label2.fillColor = new Cesium.Color.fromCssColorString(label2.fillColor);
- } else {
- label2.fillColor = new Cesium.Color.fromCssColorString("#ff0000");
- }
- if (label2.outlineColor instanceof Cesium.Color) {
- label2.outlineColor = label2.outlineColor;
- } else if (label2.outlineColor instanceof Array) {
- label2.outlineColor = new Cesium.Color(label2.outlineColor[0] / 255, label2.outlineColor[1] / 255, label2.outlineColor[2] / 255, label2.outlineColor[3]);
- } else if (typeof label2.outlineColor === "string") {
- label2.outlineColor = new Cesium.Color.fromCssColorString(label2.outlineColor);
- } else {
- label2.outlineColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- label2.outlineWidth = Cesium.defaultValue(label2.outlineWidth, 1);
- label2.showBackground = Cesium.defaultValue(label2.showBackground, false);
- if (label2.backgroundColor instanceof Cesium.Color) {
- label2.backgroundColor = label2.backgroundColor;
- } else if (label2.backgroundColor instanceof Array) {
- label2.backgroundColor = new Cesium.Color(label2.backgroundColor[0] / 255, label2.backgroundColor[1] / 255, label2.backgroundColor[2] / 255, label2.backgroundColor[3]);
- } else if (typeof label2.backgroundColor === "string") {
- label2.backgroundColor = new Cesium.Color.fromCssColorString(label2.backgroundColor);
- } else {
- label2.backgroundColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- label2.scale = Cesium.defaultValue(label2.scale, 1);
- const dataSource = new Cesium.GeoJsonDataSource(options2.id);
- dataSource.load(geoJsonUrl, {
- clampToGround: true
- }).then(function(data) {
- viewer2.dataSources.add(data);
- const entities2 = data.entities.values;
- entities2.forEach((entity) => {
- entity.billboard = {
- image: billboard.imgUrl,
- horizontalOrigin: Cesium.HorizontalOrigin.CENTER,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- scale: billboard.scale,
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- };
- let labelText = label2.text;
- if (entity.properties[label2.textField]) {
- labelText = entity.properties[label2.textField]._value;
- }
- if (labelText === "") {
- labelText = (i + 1).toString();
- }
- entity.label = {
- text: labelText.toString(),
- font: label2.font,
- fillColor: label2.fillColor,
- outlineColor: label2.outlineColor,
- outlineWidth: label2.outlineWidth,
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- showBackground: label2.showBackground,
- backgroundColor: label2.backgroundColor,
- backgroundPadding: new Cesium.Cartesian2(6, 6),
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND,
- scale: label2.scale
- };
- if (label2.scaleByDistance) {
- label2.scaleByDistance.near = Cesium.defaultValue(label2.scaleByDistance.near, 0);
- label2.scaleByDistance.nearValue = Cesium.defaultValue(label2.scaleByDistance.nearValue, 0);
- label2.scaleByDistance.far = Cesium.defaultValue(label2.scaleByDistance.far, 1);
- label2.scaleByDistance.farValue = Cesium.defaultValue(label2.scaleByDistance.farValue, 0);
- entity.label.scaleByDistance = new Cesium.NearFarScalar(label2.scaleByDistance.near, label2.scaleByDistance.nearValue, label2.scaleByDistance.far, label2.scaleByDistance.farValue);
- }
- if (label2.distanceDisplayCondition) {
- label2.distanceDisplayCondition.near = Cesium.defaultValue(label2.distanceDisplayCondition.near, 0);
- label2.distanceDisplayCondition.far = Cesium.defaultValue(label2.distanceDisplayCondition.far, Number.MAX_VALUE);
- entity.label.distanceDisplayCondition = new Cesium.DistanceDisplayCondition(label2.distanceDisplayCondition.near, label2.distanceDisplayCondition.far);
- }
- if (label2.disableDepthTestDistance) {
- label2.disableDepthTestDistance = Cesium.defaultValue(label2.disableDepthTestDistance, 999);
- entity.label.disableDepthTestDistance = label2.disableDepthTestDistance;
- }
- });
- });
- });
- },
- addGltf: function(options2) {
- let viewer2 = this._viewer;
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(options2.points)) {
- resolve2("options.points is required.");
- throw new Cesium.DeveloperError("options.points is required.");
- }
- if (!Cesium.defined(options2.url)) {
- resolve2("options.url is required.");
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2.id = options2.id || setSessionid$1();
- options2.heading = Cesium.defaultValue(options2.heading, 0);
- options2.pitch = Cesium.defaultValue(options2.pitch, 0);
- options2.roll = Cesium.defaultValue(options2.roll, 0);
- options2.alpha = Cesium.defaultValue(options2.alpha, 1);
- let position2 = void 0;
- if (options2.points instanceof Cesium.Cartesian3) {
- position2 = options2.points;
- } else {
- position2 = Cesium.Cartesian3.fromDegrees(options2.points[0], options2.points[1], options2.points[2] || 0);
- }
- var heading = Cesium.Math.toRadians(options2.heading);
- var pitch = options2.pitch;
- var roll = options2.roll;
- var hpr = new Cesium.HeadingPitchRoll(heading, pitch, roll);
- var modelGltf = viewer2.entities.add({
- id: options2.id,
- position: position2,
- orientation: Cesium.Transforms.headingPitchRollQuaternion(position2, hpr),
- model: {
- uri: options2.url,
- incrementallyLoadTextures: true,
- colorBlendMode: Cesium.ColorBlendMode["HIGHLIGHT"],
- colorBlendAmount: 0.1,
- color: Cesium.Color.WHITE.withAlpha(options2.alpha),
- imageBasedLightingFactor: new Cesium.Cartesian2(12, 13),
- runAnimations: true,
- show: true,
- debugWireframe: false,
- debugShowBoundingVolume: false
- }
- });
- if (options2.minimumPixelSize) {
- modelGltf.model.minimumPixelSize = options2.minimumPixelSize;
- }
- if (options2.maximumScale) {
- modelGltf.model.maximumScale = options2.maximumScale;
- }
- if (options2.silhouetteColor) {
- if (options2.silhouetteColor instanceof Cesium.Color) {
- options2.silhouetteColor = label.silhouetteColor;
- } else if (options2.silhouetteColor instanceof Array) {
- options2.silhouetteColor = new Cesium.Color(options2.silhouetteColor[0] / 255, options2.silhouetteColor[1] / 255, options2.silhouetteColor[2] / 255, options2.silhouetteColor[3]);
- } else if (typeof options2.silhouetteColor === "string") {
- options2.silhouetteColor = new Cesium.Color.fromCssColorString(options2.silhouetteColor);
- } else {
- options2.silhouetteColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- window[options2.id] = modelGltf;
- resolve2(options2.id);
- });
- },
- addModelFromGltf(points2, options2) {
- let viewer2 = this._viewer;
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(options2.points)) {
- resolve2("options.points is required.");
- throw new Cesium.DeveloperError("options.points is required.");
- }
- if (!Cesium.defined(options2.url)) {
- resolve2("options.url is required.");
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2.id = options2.id || setSessionid$1();
- options2.scale = Cesium.defaultValue(options2.scale, 1);
- let position2 = void 0;
- if (options2.points instanceof Cesium.Cartesian3) {
- position2 = options2.points;
- } else {
- position2 = Cesium.Cartesian3.fromDegrees(options2.points[0], options2.points[1], options2.points[2] || 0);
- }
- const modelMatrix = Cesium.Transforms.eastNorthUpToFixedFrame(position2);
- let model = viewer2.scene.primitives.add(
- Cesium.Model.fromGltf({
- show: true,
- url: options2.url,
- modelMatrix,
- lightColor: new Cesium.Cartesian3(10, 10, 10),
- debugWireframe: false,
- debugShowBoundingVolume: false
- })
- );
- model.readyPromise.then(function() {
- var rotationX = Cesium.Matrix4.fromRotationTranslation(Cesium.Matrix3.fromRotationZ(Cesium.Math.toRadians(0)));
- Cesium.Matrix4.multiply(model.modelMatrix, rotationX, model.modelMatrix);
- });
- window[options2.id] = model;
- resolve2(options2.id);
- });
- }
- });
- class PolylineObject {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- }
- }
- Object.assign(PolylineObject.prototype, {
- addPolyline: function(points2, options2) {
- this._viewer;
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- if (points2.length < 2) {
- reject2("\u7EBF\u5BF9\u8C61\uFF0C\u70B9\u6570\u81F3\u5C112\u4E2A");
- }
- let positions;
- if (points2[0] instanceof Cesium.Cartesian3) {
- positions = points2;
- } else {
- positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- }
- options2 = options2 || {};
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- options2.clampToGround = Cesium.defaultValue(options2.clampToGround, true);
- options2.width = Cesium.defaultValue(options2.width, 3);
- options2.minHeigh = Cesium.defaultValue(options2.minHeigh, 0);
- options2.maxHeigh = Cesium.defaultValue(options2.maxHeigh, 2e8);
- let distanceDisplayCondition = new Cesium.DistanceDisplayCondition(options2.minHeigh, options2.maxHeigh);
- let material = new PolylineDirectionMaterialProperty(options2);
- let entity = new Cesium.Entity({
- name: "line",
- polyline: {
- positions,
- width: options2.width,
- material,
- distanceDisplayCondition
- }
- });
- if (options2.clampToGround) {
- entity.polyline.clampToGround = true;
- }
- resolve2(entity);
- });
- },
- drawPolylineByGeoJson: function(geoJsonUrl, options2) {
- return new Promise((resolve2, reject2) => {
- let viewer2 = this._viewer;
- if (!Cesium.defined(geoJsonUrl)) {
- throw new Cesium.DeveloperError("geoJsonUrl is required.");
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- options2.clampToGround = Cesium.defaultValue(options2.clampToGround, true);
- options2.width = Cesium.defaultValue(options2.width, 3);
- options2.minHeigh = Cesium.defaultValue(options2.minHeigh, 0);
- options2.maxHeigh = Cesium.defaultValue(options2.maxHeigh, 2e8);
- let promise = Cesium.GeoJsonDataSource.load(geoJsonUrl, {
- clampToGround: options2.clampToGround
- });
- promise.then((dataSource) => {
- viewer2.dataSources.add(dataSource);
- dataSource.name = options2.id;
- let entities2 = dataSource.entities.values;
- let distanceDisplayCondition = new Cesium.DistanceDisplayCondition(options2.minHeigh, options2.maxHeigh);
- let material = new PolylineDirectionMaterialProperty(options2);
- for (var i2 = 0; i2 < entities2.length; i2++) {
- var entity = entities2[i2];
- entity.polyline.distanceDisplayCondition = distanceDisplayCondition;
- entity.polyline.material = material;
- entity.polyline.width = options2.width;
- if (options2.clampToGround) {
- entity.polyline.clampToGround = true;
- }
- }
- resolve2(entities2);
- });
- });
- },
- PolylineLinkPulseMaterialProperty: function(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- if (points2.length < 2) {
- reject2("\u7EBF\u5BF9\u8C61\uFF0C\u70B9\u6570\u81F3\u5C112\u4E2A");
- }
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- options2.width = options2.width || 5;
- let material = new PolylineDirectionMaterialProperty(options2);
- let entity = this._viewer.entities.add({
- id: options2.id,
- name: "Pulse line",
- polyline: {
- positions,
- width: options2.width,
- material,
- clampToGround: true
- }
- });
- resolve2(entity);
- });
- },
- PolylineArrowMaterialProperty: function(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- if (points2.length < 2) {
- reject2("\u7EBF\u5BF9\u8C61\uFF0C\u70B9\u6570\u81F3\u5C112\u4E2A");
- }
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- options2.width = options2.width || 5;
- let material = new PolylineDirectionMaterialProperty(options2);
- let entity = this._viewer.entities.add({
- id: options2.id,
- name: "Pulse line",
- polyline: {
- positions,
- width: options2.width,
- material,
- clampToGround: true
- }
- });
- resolve2(entity);
- });
- },
- drawGlowingLine(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- if (points2.length < 2) {
- reject2("\u7EBF\u5BF9\u8C61\uFF0C\u70B9\u6570\u81F3\u5C112\u4E2A");
- }
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- if (options2.color) {
- if (options2.color instanceof Array) {
- options2.color = new Cesium.Color(options2.color[0] / 255, options2.color[1] / 255, options2.color[2] / 255, options2.color[3]);
- } else if (typeof options2.color === "string") {
- options2.color = new Cesium.Color.fromCssColorString(options2.color);
- } else {
- options2.color = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- options2.width = options2.width || 5;
- options2.glowPower = options2.glowPower || 0.25;
- options2.taperPower = options2.taperPower || 1;
- let entity = this._viewer.entities.add({
- id: options2.id,
- name: "Glowing blue line on the surface",
- polyline: {
- clampToGround: true,
- positions,
- width: options2.width,
- followSurface: true,
- material: new Cesium.PolylineGlowMaterialProperty({
- color: options2.color,
- glowPower: options2.glowPower,
- taperPower: options2.taperPower
- })
- }
- });
- resolve2(entity);
- });
- },
- drawSpecifyColorLine(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- reject2("points is required.");
- }
- if (points2.length < 2) {
- reject2("\u7EBF\u5BF9\u8C61\uFF0C\u70B9\u6570\u81F3\u5C112\u4E2A");
- }
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- if (options2.color) {
- if (options2.color instanceof Array) {
- options2.color = new Cesium.Color(options2.color[0] / 255, options2.color[1] / 255, options2.color[2] / 255, options2.color[3]);
- } else if (typeof options2.color === "string") {
- options2.color = new Cesium.Color.fromCssColorString(options2.color);
- } else {
- options2.color = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- options2.width = options2.width || 5;
- let entity = this._viewer.entities.add({
- id: options2.id,
- name: "Red line on the surface",
- polyline: {
- clampToGround: true,
- positions,
- width: options2.width,
- material: options2.color
- }
- });
- resolve2(entity);
- });
- },
- drawSpecifyColorAndOutlineColorLine(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- if (points2.length < 2) {
- reject2("\u7EBF\u5BF9\u8C61\uFF0C\u70B9\u6570\u81F3\u5C112\u4E2A");
- }
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- if (options2.color) {
- if (options2.color instanceof Array) {
- options2.color = new Cesium.Color(options2.color[0] / 255, options2.color[1] / 255, options2.color[2] / 255, options2.color[3]);
- } else if (typeof options2.color === "string") {
- options2.color = new Cesium.Color.fromCssColorString(options2.color);
- } else {
- options2.color = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- options2.width = options2.width || 5;
- if (options2.outlineColor) {
- if (options2.outlineColor instanceof Array) {
- options2.outlineColor = new Cesium.Color(options2.outlineColor[0] / 255, options2.outlineColor[1] / 255, options2.outlineColor[2] / 255, options2.outlineColor[3]);
- } else if (typeof options2.outlineColor === "string") {
- options2.outlineColor = new Cesium.Color.fromCssColorString(options2.outlineColor);
- } else {
- options2.outlineColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- options2.outlineWidth = Cesium.defaultValue(options2.outlineWidth, 1);
- let entity = this._viewer.entities.add({
- id: options2.id,
- name: "Orange line with black outline at height and following the surface",
- polyline: {
- clampToGround: true,
- positions,
- width: options2.width,
- material: new Cesium.PolylineOutlineMaterialProperty({
- color: options2.color,
- outlineWidth: options2.outlineWidth,
- outlineColor: options2.outlineColor
- })
- }
- });
- resolve2(entity);
- });
- },
- drawSpecifyColorArrowStaticStateLine(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- if (points2.length < 2) {
- reject2("\u7EBF\u5BF9\u8C61\uFF0C\u70B9\u6570\u81F3\u5C112\u4E2A");
- }
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- if (options2.color) {
- if (options2.color instanceof Array) {
- options2.color = new Cesium.Color(options2.color[0] / 255, options2.color[1] / 255, options2.color[2] / 255, options2.color[3]);
- } else if (typeof options2.color === "string") {
- options2.color = new Cesium.Color.fromCssColorString(options2.color);
- } else {
- options2.color = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- options2.width = options2.width || 5;
- let entity = this._viewer.entities.add({
- id: options2.id,
- name: "Purple straight arrow at height",
- polyline: {
- clampToGround: true,
- positions,
- width: options2.width,
- followSurface: false,
- material: new Cesium.PolylineArrowMaterialProperty(options2.color)
- }
- });
- resolve2(entity);
- });
- },
- drawDashedLine(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- if (points2.length < 2) {
- reject2("\u7EBF\u5BF9\u8C61\uFF0C\u70B9\u6570\u81F3\u5C112\u4E2A");
- }
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- if (options2.color) {
- if (options2.color instanceof Array) {
- options2.color = new Cesium.Color(options2.color[0] / 255, options2.color[1] / 255, options2.color[2] / 255, options2.color[3]);
- } else if (typeof options2.color === "string") {
- options2.color = new Cesium.Color.fromCssColorString(options2.color);
- } else {
- options2.color = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- options2.width = options2.width || 5;
- if (options2.gapColor) {
- if (options2.gapColor instanceof Array) {
- options2.gapColor = new Cesium.Color(options2.gapColor[0] / 255, options2.gapColor[1] / 255, options2.gapColor[2] / 255, options2.gapColor[3]);
- } else if (typeof options2.gapColor === "string") {
- options2.gapColor = new Cesium.Color.fromCssColorString(options2.gapColor);
- } else {
- options2.gapColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- options2.dashLength = options2.dashLength || 16;
- options2.dashPattern = options2.dashPattern || 255;
- let entity = this._viewer.entities.add({
- id: options2.id,
- name: "CYAN dashed line",
- polyline: {
- clampToGround: true,
- positions,
- width: options2.width,
- material: new Cesium.PolylineDashMaterialProperty({
- color: options2.color,
- gapColor: options2.gapColor,
- dashLength: options2.dashLength,
- dashPattern: options2.dashPattern
- })
- }
- });
- resolve2(entity);
- });
- }
- });
- function DynamicWallMaterialProperty(options2) {
- this._definitionChanged = new Cesium.Event();
- this._color = void 0;
- this._colorSubscription = void 0;
- this.color = options2.color || Color.BLUE;
- this.duration = options2.duration || 1e3;
- this.trailImage = options2.trailImage;
- this._time = new Date().getTime();
- }
- function _getDirectionWallShader(options2) {
- if (options2 && options2.get) {
- var materail = "czm_material czm_getMaterial(czm_materialInput materialInput)\n {\n czm_material material = czm_getDefaultMaterial(materialInput);\n vec2 st = materialInput.st;";
- if (options2.direction == "vertical") {
- materail += "vec4 colorImage = texture2D(image, vec2(fract(st.s), fract(float(" + options2.count + ")*st.t" + options2.order + " time)));\n ";
- } else {
- materail += "vec4 colorImage = texture2D(image, vec2(fract(float(" + options2.count + ")*st.s " + options2.order + " time), fract(st.t)));\n ";
- }
- materail += "vec4 fragColor;\n fragColor.rgb = (colorImage.rgb+color.rgb) / 1.0;\n fragColor = czm_gammaCorrect(fragColor);\n material.diffuse = colorImage.rgb;\n material.alpha = colorImage.a;\n material.emission = fragColor.rgb;\n return material;\n }";
- return materail;
- }
- }
- Object.defineProperties(DynamicWallMaterialProperty.prototype, {
- isConstant: {
- get: function() {
- return false;
- }
- },
- definitionChanged: {
- get: function() {
- return this._definitionChanged;
- }
- },
- color: Cesium.createPropertyDescriptor("color")
- });
- var MaterialType = "wallType" + parseInt(Math.random() * 1e3);
- DynamicWallMaterialProperty.prototype.getType = function(time) {
- return MaterialType;
- };
- DynamicWallMaterialProperty.prototype.getValue = function(time, result) {
- if (!Cesium.defined(result)) {
- result = {};
- }
- result.color = Cesium.Property.getValueOrClonedDefault(this._color, time, Cesium.Color.WHITE, result.color);
- result.image = this.trailImage;
- if (this.duration) {
- result.time = (new Date().getTime() - this._time) % this.duration / this.duration;
- }
- viewer.scene.requestRender();
- return result;
- };
- DynamicWallMaterialProperty.prototype.equals = function(other) {
- return this === other || other instanceof DynamicWallMaterialProperty && Cesium.Property.equals(this._color, other._color);
- };
- Cesium.Material._materialCache.addMaterial(MaterialType, {
- fabric: {
- type: MaterialType,
- uniforms: {
- color: new Cesium.Color(1, 0, 0, 0.5),
- image: Cesium.Material.DefaultImageId,
- time: -20
- },
- source: _getDirectionWallShader({
- get: true,
- count: 3,
- direction: "vertical",
- order: "-"
- })
- },
- translucent: function(material) {
- return true;
- }
- });
- Cesium.DynamicWallMaterialProperty = DynamicWallMaterialProperty;
- class WallDiffuseMaterialProperty {
- constructor(options2) {
- this._definitionChanged = new Cesium.Event();
- this._color = void 0;
- this.color = options2.color;
- }
- get isConstant() {
- return false;
- }
- get definitionChanged() {
- return this._definitionChanged;
- }
- getType(time) {
- return Cesium.Material.WallDiffuseMaterialType;
- }
- getValue(time, result) {
- if (!Cesium.defined(result)) {
- result = {};
- }
- result.color = Cesium.Property.getValueOrDefault(this._color, time, Cesium.Color.RED, result.color);
- return result;
- }
- equals(other) {
- return this === other || other instanceof WallDiffuseMaterialProperty && Cesium.Property.equals(this._color, other._color);
- }
- }
- Object.defineProperties(WallDiffuseMaterialProperty.prototype, {
- color: Cesium.createPropertyDescriptor("color")
- });
- Cesium.WallDiffuseMaterialProperty = WallDiffuseMaterialProperty;
- Cesium.Material.WallDiffuseMaterialProperty = "WallDiffuseMaterialProperty";
- Cesium.Material.WallDiffuseMaterialType = "WallDiffuseMaterialType";
- Cesium.Material.WallDiffuseMaterialSource = `
- uniform vec4 color;
- czm_material czm_getMaterial(czm_materialInput materialInput){
- czm_material material = czm_getDefaultMaterial(materialInput);
- vec2 st = materialInput.st;
- material.diffuse = color.rgb * 2.0;
- material.alpha = color.a * (1.0 - fract(st.t)) * 0.8;
- return material;
- }
-
- `;
- Cesium.Material._materialCache.addMaterial(Cesium.Material.WallDiffuseMaterialType, {
- fabric: {
- type: Cesium.Material.WallDiffuseMaterialType,
- uniforms: {
- color: new Cesium.Color(1, 0, 0, 1)
- },
- source: Cesium.Material.WallDiffuseMaterialSource
- },
- translucent: function(material) {
- return true;
- }
- });
- class WallObject {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- }
- }
- Object.assign(WallObject.prototype, {
- drawWallByGeoJson: function(geoJsonUrl, options2) {
- return new Promise((resolve2, reject2) => {
- let _self = this;
- let viewer2 = this._viewer;
- if (!Cesium.defined(geoJsonUrl)) {
- throw new Cesium.DeveloperError("geoJsonUrl is required.");
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- fetch(geoJsonUrl).then((res) => {
- return res.json();
- }).then((res) => {
- let wall = new Cesium.CustomDataSource(options2.id);
- viewer2.dataSources.add(wall);
- for (var i2 = 0; i2 < res.features.length; i2++) {
- if (res.features[i2].geometry) {
- if (res.features[i2].geometry.type === "MultiLineString") {
- let coordinatesList = res.features[i2].geometry.coordinates;
- for (var j = 0; j < coordinatesList.length; j++) {
- let coordinates = coordinatesList[j];
- let positions = coordinates.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- _self.addWall(positions, options2).then((entity) => {
- wall.entities.add(entity);
- });
- }
- } else {
- let coordinates = res.features[i2].geometry.coordinates;
- let positions = coordinates.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- _self.addWall(positions, options2).then((entity) => {
- wall.entities.add(entity);
- });
- }
- }
- }
- resolve2(options2.id);
- });
- });
- },
- addWall(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- if (points2.length < 2) {
- reject2("\u5899\u4F53\u5BF9\u8C61\uFF0C\u70B9\u6570\u81F3\u5C112\u4E2A");
- }
- let positions;
- if (points2[0] instanceof Cesium.Cartesian3) {
- positions = points2;
- } else {
- positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- options2.clampToGround = Cesium.defaultValue(options2.clampToGround, true);
- options2.minimunHeights = options2.minimunHeights !== void 0 && typeof options2.minimunHeights === "number" ? options2.minimunHeights : 0;
- options2.maximumHeights = options2.maximumHeights !== void 0 && typeof options2.maximumHeights === "number" ? options2.maximumHeights : 1e3;
- if (options2.color) {
- if (options2.color instanceof Cesium.Color) {
- options2.color = options2.color;
- } else if (options2.color instanceof Array) {
- options2.color = new Cesium.Color(options2.color[0] / 255, options2.color[1] / 255, options2.color[2] / 255, options2.color[3]);
- } else if (typeof options2.color === "string") {
- options2.color = new Cesium.Color.fromCssColorString(options2.color);
- } else {
- options2.color = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- options2.trailImage = Cesium.defaultValue(options2.trailImage, "jt3dSDK/imgs/wallmaterial/wl.png");
- options2.duration = Cesium.defaultValue(options2.duration, 3e3);
- options2.count = Cesium.defaultValue(options2.count, 1);
- options2.direction = Cesium.defaultValue(options2.direction, "vertical");
- options2.order = Cesium.defaultValue(options2.order, "-");
- let entity = new Cesium.Entity({
- name: "\u7ACB\u4F53\u5899\u6548\u679C",
- wall: {
- positions,
- maximumHeights: new Array(positions.length).fill(options2.maximumHeights),
- minimunHeights: new Array(positions.length).fill(options2.minimunHeights),
- material: new WallMaterialProperty$1(viewer, {
- trailImage: options2.trailImage,
- color: options2.color,
- duration: options2.duration,
- param: {
- count: options2.count,
- direction: options2.direction,
- order: options2.order
- }
- })
- }
- });
- resolve2(entity);
- });
- }
- });
- class LoadMapData {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this._pointObject = new PointObject(viewer2);
- this._polylineObject = new PolylineObject(viewer2);
- this._wallObject = new WallObject(viewer2);
- }
- _addImageryProvider(id, provider) {
- window[id] = this._viewer.imageryLayers.addImageryProvider(provider);
- }
- _removeImageryProvider(serviceId) {
- this._viewer.imageryLayers.remove(window[serviceId]);
- window[serviceId] = null;
- }
- _addTerrainProvider(provider) {
- this._viewer.terrainProvider = provider;
- }
- _setEllipsoidTerrain() {
- this._viewer.terrainProvider = new Cesium.EllipsoidTerrainProvider({});
- }
- _addScenePrimitives(scenePrimitives) {
- this._viewer.scene.primitives.add(scenePrimitives);
- }
- _removeScenePrimitives(serviceId) {
- this._viewer.scene.primitives.remove(window[serviceId]);
- window[serviceId] = null;
- }
- _guid() {
- function S4() {
- return ((1 + Math.random()) * 65536 | 0).toString(16).substring(1);
- }
- return S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4();
- }
- _transformProjection(provider) {
- let webMercatorTilingScheme = provider.tilingScheme;
- let projection = webMercatorTilingScheme._projection;
- projection.x_project = projection.project;
- projection.project = function(cartographic) {
- let point2;
- return point2 = CoordTransform.WGS84ToGCJ02(
- Cesium.Math.toDegrees(cartographic.longitude),
- Cesium.Math.toDegrees(cartographic.latitude)
- ), projection.x_project(
- new Cesium.Cartographic(
- Cesium.Math.toRadians(point2[0]),
- Cesium.Math.toRadians(point2[1])
- )
- );
- };
- projection.x_unproject = projection.unproject;
- projection.unproject = function(cartesian) {
- let point2, cartographic = projection.x_unproject(cartesian);
- return point2 = CoordTransform.GCJ02ToWGS84(
- Cesium.Math.toDegrees(cartographic.longitude),
- Cesium.Math.toDegrees(cartographic.latitude)
- ), new Cesium.Cartographic(
- Cesium.Math.toRadians(point2[0]),
- Cesium.Math.toRadians(point2[1])
- );
- };
- return provider;
- }
- }
- Object.assign(LoadMapData.prototype, {
- addTerrain(options2) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.url)) {
- throw new Cesium.DeveloperError("options.url is required.");
- }
- let _ConstructorOptions = {
- url: options2.url
- };
- if (options2.requestVertexNormals) {
- _ConstructorOptions.requestVertexNormals = options2.requestVertexNormals;
- } else {
- _ConstructorOptions.requestVertexNormals = false;
- }
- if (options2.requestWaterMask) {
- _ConstructorOptions.requestWaterMask = options2.requestWaterMask;
- } else {
- _ConstructorOptions.requestWaterMask = false;
- }
- var terrainProvider = new Cesium.CesiumTerrainProvider(_ConstructorOptions);
- this._addTerrainProvider(terrainProvider);
- this.setTerrainExaggeration(options2);
- },
- addMapboxLayer(options2, callSuccess) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.styleId)) {
- throw new Cesium.DeveloperError("options.styleId is required.");
- }
- if (!Cesium.defined(options2.accessToken)) {
- throw new Cesium.DeveloperError("options.accessToken is required.");
- }
- options2.id = options2.id || this._guid();
- var imageryProvider = new Cesium.MapboxStyleImageryProvider({
- url: options2.url,
- username: options2.username,
- styleId: options2.styleId,
- accessToken: options2.accessToken,
- scaleFactor: options2.scaleFactor
- });
- this._addImageryProvider(options2.id, imageryProvider);
- this.setLayersStyle({
- serviceId: options2.id,
- alpha: options2.alpha
- });
- if (callSuccess)
- callSuccess(options2.id);
- },
- addUrlTemplateImagery: function(options2, callSuccess) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.url)) {
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2.id = options2.id || this._guid();
- options2.CRS = options2.CRS || "";
- let _ConstructorOptions = {
- url: options2.url
- };
- if (options2.minimumLevel) {
- _ConstructorOptions.minimumLevel = options2.minimumLevel;
- }
- if (options2.maximumLevel) {
- _ConstructorOptions.maximumLevel = options2.maximumLevel;
- } else {
- _ConstructorOptions.maximumLevel = 18;
- }
- var imageryProvider = new Cesium.UrlTemplateImageryProvider(_ConstructorOptions);
- if (options2.CRS.toUpperCase() === "WGS84") {
- imageryProvider.readyPromise.then(() => {
- this._transformProjection(imageryProvider);
- });
- }
- this._addImageryProvider(options2.id, imageryProvider);
- this.setLayersStyle({
- serviceId: options2.id,
- alpha: options2.alpha
- });
- if (callSuccess)
- callSuccess(options2.id);
- },
- addTileMapServiceImagery: function(options2, callSuccess) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.url)) {
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2.id = options2.id || this._guid();
- let _ConstructorOptions = {
- url: options2.url
- };
- if (options2.minimumLevel) {
- _ConstructorOptions.minimumLevel = options2.minimumLevel;
- }
- if (options2.maximumLevel) {
- _ConstructorOptions.maximumLevel = options2.maximumLevel;
- } else {
- _ConstructorOptions.maximumLevel = 18;
- }
- var imageryProvider = new Cesium.TileMapServiceImageryProvider(_ConstructorOptions);
- this._addImageryProvider(options2.id, imageryProvider);
- this.setLayersStyle({
- serviceId: options2.id,
- alpha: options2.alpha
- });
- if (callSuccess)
- callSuccess(options2.id);
- },
- addWebMapTileService: function(options2, callSuccess) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.url)) {
- throw new Cesium.DeveloperError("options.url is required.");
- }
- if (!Cesium.defined(options2.layers)) {
- throw new Cesium.DeveloperError("options.layers is required.");
- }
- if (!Cesium.defined(options2.style)) {
- throw new Cesium.DeveloperError("options.style is required.");
- }
- if (!Cesium.defined(options2.tileMatrixSetID)) {
- throw new Cesium.DeveloperError("options.tileMatrixSetID is required.");
- }
- options2.id = options2.id || this._guid();
- let _ConstructorOptions = {
- url: options2.url,
- layer: options2.layers,
- style: options2.style,
- tileMatrixSetID: options2.tileMatrixSetID,
- format: Cesium.defaultValue(options2.format, "image/png")
- };
- if (options2.tileMatrixLabels) {
- _ConstructorOptions.tileMatrixLabels = options2.tileMatrixLabels;
- }
- if (options2.minimumLevel) {
- _ConstructorOptions.minimumLevel = options2.minimumLevel;
- }
- if (options2.maximumLevel) {
- _ConstructorOptions.maximumLevel = options2.maximumLevel;
- } else {
- _ConstructorOptions.maximumLevel = 18;
- }
- let imageryProvider = new Cesium.WebMapTileServiceImageryProvider(_ConstructorOptions);
- this._addImageryProvider(options2.id, imageryProvider);
- this.setLayersStyle({
- serviceId: options2.id,
- alpha: options2.alpha
- });
- if (callSuccess)
- callSuccess(options2.id);
- },
- addWebMapService: function(options2, callSuccess) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.url)) {
- throw new Cesium.DeveloperError("options.url is required.");
- }
- if (!Cesium.defined(options2.layers)) {
- throw new Cesium.DeveloperError("options.layers is required.");
- }
- options2.id = options2.id || this._guid();
- let _ConstructorOptions = {
- url: options2.url,
- layers: options2.layers
- };
- if (options2.parameters) {
- _ConstructorOptions.parameters = options2.parameters;
- }
- if (options2.minimumLevel) {
- _ConstructorOptions.minimumLevel = options2.minimumLevel;
- }
- if (options2.maximumLevel) {
- _ConstructorOptions.maximumLevel = options2.maximumLevel;
- } else {
- _ConstructorOptions.maximumLevel = 18;
- }
- let imageryProvider = new Cesium.WebMapServiceImageryProvider(_ConstructorOptions);
- this._addImageryProvider(options2.id, imageryProvider);
- this.setLayersStyle({
- serviceId: options2.id,
- alpha: options2.alpha
- });
- if (callSuccess)
- callSuccess(options2.id);
- },
- addArcGisMapServer: function(options2, callSuccess) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.url)) {
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2.id = options2.id || this._guid();
- let _ConstructorOptions = {
- url: options2.url
- };
- if (options2.layers) {
- _ConstructorOptions.layers = options2.layers;
- }
- let imageryProvider = new Cesium.ArcGisMapServerImageryProvider(_ConstructorOptions);
- this._addImageryProvider(options2.id, imageryProvider);
- this.setLayersStyle({
- serviceId: options2.id,
- alpha: options2.alpha
- });
- if (callSuccess)
- callSuccess(options2.id);
- },
- addCesium3DTileset: function(options2, callSuccess) {
- let _self = this;
- if (!Cesium.defined(options2) || !Cesium.defined(options2.url)) {
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2.id = options2.id || this._guid();
- let _ConstructorOptions = {
- url: options2.url,
- skipLevelOfDetail: true
- };
- let tileSetModel = new Cesium.Cesium3DTileset(_ConstructorOptions);
- tileSetModel.readyPromise.then((tileset) => {
- window[options2.id] = tileset;
- _self._addScenePrimitives(tileset);
- _self.set3DTilePosition({
- serviceId: options2.id,
- height: options2.height
- });
- _self.set3DTileStyle({
- serviceId: options2.id,
- alpha: options2.alpha
- });
- if (callSuccess)
- callSuccess(options2.id);
- }).catch(function(error) {
- console.log(error);
- });
- },
- addCesium3DTilesetBm: function(options2, callSuccess) {
- let _self = this;
- if (!Cesium.defined(options2) || !Cesium.defined(options2.url)) {
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2.id = options2.id || this._guid();
- let _ConstructorOptions = {
- url: options2.url,
- skipLevelOfDetail: true
- };
- let tileSetModel = new Cesium.Cesium3DTileset(_ConstructorOptions);
- tileSetModel.readyPromise.then((tileset) => {
- window[options2.id] = tileset;
- _self._addScenePrimitives(tileset);
- _self.set3DTileBMStyle({
- serviceId: options2.id,
- color: options2.color
- });
- if (callSuccess)
- callSuccess(options2.id);
- }).catch(function(error) {
- console.log(error);
- });
- },
- addPolygonImageMaterial: function(options2, callSuccess) {
- if (!Cesium.defined(options2.points)) {
- throw new Cesium.DeveloperError("options.points is required.");
- }
- if (options2.points.length < 3) {
- reject("\u9762\u5BF9\u8C61\uFF0C\u70B9\u6570\u81F3\u5C113\u4E2A");
- }
- let positions = [];
- if (options2.points instanceof Cesium.Cartesian3) {
- positions = options2.points;
- } else {
- positions = options2.points.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- }
- options2.id = options2.id || this._guid();
- options2.alpha = options2.alpha || 1;
- this.classificationType = Cesium.ClassificationType.BOTH;
- if (options2.classificationType === "Terrain") {
- this.classificationType = Cesium.ClassificationType.TERRAIN;
- } else if (options2.classificationType === "3DTiles") {
- this.classificationType = Cesium.ClassificationType.CESIUM_3D_TILE;
- }
- if (options2.url) {
- if (!Cesium.Entity.supportsMaterialsforEntitiesOnTerrain(this._viewer.scene)) {
- window.alert("Terrain Entity materials are not supported on this platform");
- }
- this.material = new Cesium.ImageMaterialProperty({
- image: options2.url,
- repeat: Cesium.Cartesian2(1, 1),
- transparent: true,
- color: Cesium.Color.WHITE.withAlpha(options2.alpha)
- });
- } else {
- this.material = Cesium.Color.RED.withAlpha(options2.alpha);
- }
- window[options2.id] = this._viewer.entities.add({
- id: options2.id,
- polygon: {
- hierarchy: positions,
- material: this.material,
- classificationType: this.classificationType
- }
- });
- if (callSuccess)
- callSuccess(options2.id);
- },
- addEntitiesGltf: function(options2, callSuccess) {
- let viewer2 = this._viewer;
- if (!Cesium.defined(options2.points)) {
- resolve("options.points is required.");
- throw new Cesium.DeveloperError("options.points is required.");
- }
- if (!Cesium.defined(options2.url)) {
- resolve("options.url is required.");
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2.id = options2.id || this._guid();
- options2.heading = Cesium.defaultValue(options2.heading, 0);
- options2.pitch = Cesium.defaultValue(options2.pitch, 0);
- options2.roll = Cesium.defaultValue(options2.roll, 0);
- options2.alpha = Cesium.defaultValue(options2.alpha, 1);
- let position2 = void 0;
- if (options2.points instanceof Cesium.Cartesian3) {
- position2 = options2.points;
- } else {
- position2 = Cesium.Cartesian3.fromDegrees(options2.points[0], options2.points[1], options2.points[2] || 0);
- }
- var heading = Cesium.Math.toRadians(options2.heading);
- var pitch = options2.pitch;
- var roll = options2.roll;
- var hpr = new Cesium.HeadingPitchRoll(heading, pitch, roll);
- var modelGltf = viewer2.entities.add({
- id: options2.id,
- position: position2,
- orientation: Cesium.Transforms.headingPitchRollQuaternion(position2, hpr),
- model: {
- uri: options2.url,
- incrementallyLoadTextures: true,
- colorBlendMode: Cesium.ColorBlendMode["HIGHLIGHT"],
- colorBlendAmount: 0.1,
- color: Cesium.Color.WHITE.withAlpha(options2.alpha),
- imageBasedLightingFactor: new Cesium.Cartesian2(12, 13),
- runAnimations: true,
- show: true,
- debugWireframe: false,
- debugShowBoundingVolume: false
- }
- });
- if (options2.minimumPixelSize) {
- modelGltf.model.minimumPixelSize = options2.minimumPixelSize;
- }
- if (options2.maximumScale) {
- modelGltf.model.maximumScale = options2.maximumScale;
- }
- if (options2.silhouetteColor) {
- modelGltf.model.silhouetteColor = new Cesium.Color(options2.silhouetteColor[0] / 255, options2.silhouetteColor[1] / 255, options2.silhouetteColor[2] / 255, options2.silhouetteColor[3]);
- }
- window[options2.id] = modelGltf;
- if (callSuccess)
- callSuccess(options2.id);
- },
- addScenePrimitivesGltf(options2, callSuccess) {
- let viewer2 = this._viewer;
- if (!Cesium.defined(options2.points)) {
- resolve("options.points is required.");
- throw new Cesium.DeveloperError("options.points is required.");
- }
- if (!Cesium.defined(options2.url)) {
- resolve("options.url is required.");
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2.id = options2.id || this._guid();
- options2.scale = Cesium.defaultValue(options2.scale, 1);
- let position2 = void 0;
- if (options2.points instanceof Cesium.Cartesian3) {
- position2 = options2.points;
- } else {
- position2 = Cesium.Cartesian3.fromDegrees(options2.points[0], options2.points[1], options2.points[2] || 0);
- }
- const modelMatrix = Cesium.Transforms.eastNorthUpToFixedFrame(position2);
- let model = viewer2.scene.primitives.add(
- Cesium.Model.fromGltf({
- show: true,
- url: options2.url,
- modelMatrix,
- lightColor: new Cesium.Cartesian3(10, 10, 10),
- scale: options2.scale,
- debugWireframe: false,
- debugShowBoundingVolume: false
- })
- );
- model.readyPromise.then(function() {
- var rotationX = Cesium.Matrix4.fromRotationTranslation(Cesium.Matrix3.fromRotationZ(Cesium.Math.toRadians(0)));
- Cesium.Matrix4.multiply(model.modelMatrix, rotationX, model.modelMatrix);
- });
- window[options2.id] = model;
- if (callSuccess)
- callSuccess(options2.id);
- },
- addPolylineByGeoJson(options2, callSuccess) {
- let _self = this;
- this._viewer;
- if (!Cesium.defined(options2.url)) {
- resolve("options.url is required.");
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2 = options2 || {};
- options2.id = options2.id || this._guid();
- let promise = Cesium.GeoJsonDataSource.load(options2.url, {
- clampToGround: options2.clampToGround
- });
- promise.then((dataSource) => {
- _self._viewer.dataSources.add(dataSource);
- dataSource.name = options2.id;
- let entities2 = dataSource.entities.values;
- let material = new PolylineDirectionMaterialProperty(options2);
- for (var i2 = 0; i2 < entities2.length; i2++) {
- var entity = entities2[i2];
- entity.polyline.material = material;
- entity.polyline.width = options2.width;
- if (options2.clampToGround) {
- entity.polyline.clampToGround = true;
- }
- }
- if (callSuccess)
- callSuccess(options2.id);
- });
- },
- addPolylineByJson(options2, callSuccess) {
- let _self = this;
- let viewer2 = this._viewer;
- if (!Cesium.defined(options2.url)) {
- resolve("options.url is required.");
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2 = options2 || {};
- options2.id = options2.id || this._guid();
- fetch(options2.url).then((res) => {
- return res.json();
- }).then((res) => {
- let dataSource = new Cesium.CustomDataSource(options2.id);
- viewer2.dataSources.add(dataSource);
- for (var i2 = 0; i2 < res.features.length; i2++) {
- if (res.features[i2].geometry) {
- if (res.features[i2].geometry.type === "MultiLineString") {
- let coordinatesList = res.features[i2].geometry.coordinates;
- for (var j = 0; j < coordinatesList.length; j++) {
- let coordinates = coordinatesList[j];
- let positions = coordinates.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- _self._polylineObject.addPolyline(positions, options2).then((entity) => {
- dataSource.entities.add(entity);
- });
- }
- } else {
- let coordinates = res.features[i2].geometry.coordinates;
- let positions = coordinates.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- _self._polylineObject.addPolyline(positions, options2).then((entity) => {
- dataSource.entities.add(entity);
- });
- }
- }
- }
- if (callSuccess)
- callSuccess(options2.id);
- });
- },
- addBillboardByGeoJson(options2, callSuccess) {
- let viewer2 = this._viewer;
- if (!Cesium.defined(options2.url)) {
- resolve("options.url is required.");
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2 = options2 || {};
- options2.id = options2.id || this._guid();
- let billboard = options2.billboard || {};
- billboard.imgUrl = Cesium.defaultValue(billboard.imgUrl, "jt3dSDK/imgs/point/point3.png");
- billboard.scale = Cesium.defaultValue(billboard.scale, 1);
- billboard.pixelOffset = Cesium.defaultValue(billboard.pixelOffset, 0);
- const dataSource = new Cesium.GeoJsonDataSource(options2.id);
- dataSource.load(options2.url, {
- clampToGround: true
- }).then(function(data) {
- viewer2.dataSources.add(data);
- const entities2 = data.entities.values;
- entities2.forEach((entity) => {
- entity.billboard = {
- image: billboard.imgUrl,
- horizontalOrigin: Cesium.HorizontalOrigin.CENTER,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- scale: billboard.scale,
- pixelOffset: new Cesium.Cartesian2(0, billboard.pixelOffset),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- };
- if (billboard.scaleByDistance) {
- billboard.scaleByDistance.near = Cesium.defaultValue(billboard.scaleByDistance.near, 0);
- billboard.scaleByDistance.nearValue = Cesium.defaultValue(billboard.scaleByDistance.nearValue, 0);
- billboard.scaleByDistance.far = Cesium.defaultValue(billboard.scaleByDistance.far, 1);
- billboard.scaleByDistance.farValue = Cesium.defaultValue(billboard.scaleByDistance.farValue, 0);
- entity.billboard.scaleByDistance = new Cesium.NearFarScalar(billboard.scaleByDistance.near, billboard.scaleByDistance.nearValue, billboard.scaleByDistance.far, billboard.scaleByDistance.farValue);
- }
- if (options2.label) {
- let label2 = options2.label || {};
- label2.text = Cesium.defaultValue(label2.text, "");
- label2.textField = Cesium.defaultValue(label2.textField, "");
- label2.font = Cesium.defaultValue(label2.font, "24px Helvetica");
- if (label2.fillColor instanceof Array) {
- label2.fillColor = new Cesium.Color(label2.fillColor[0] / 255, label2.fillColor[1] / 255, label2.fillColor[2] / 255, label2.fillColor[3]);
- } else if (typeof options2.color === "string") {
- label2.fillColor = new Cesium.Color.fromCssColorString(label2.fillColor);
- } else {
- label2.fillColor = new Cesium.Color.fromCssColorString("#ff0000");
- }
- if (label2.outlineColor instanceof Array) {
- label2.outlineColor = new Cesium.Color(label2.outlineColor[0] / 255, label2.outlineColor[1] / 255, label2.outlineColor[2] / 255, label2.outlineColor[3]);
- } else if (label2.outlineColor instanceof String) {
- label2.outlineColor = new Cesium.Color.fromCssColorString(label2.outlineColor);
- } else {
- label2.outlineColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- label2.outlineWidth = Cesium.defaultValue(label2.outlineWidth, 1);
- label2.showBackground = Cesium.defaultValue(label2.showBackground, false);
- if (label2.backgroundColor instanceof Array) {
- label2.backgroundColor = new Cesium.Color(label2.backgroundColor[0] / 255, label2.backgroundColor[1] / 255, label2.backgroundColor[2] / 255, label2.backgroundColor[3]);
- } else if (label2.backgroundColor instanceof String) {
- label2.backgroundColor = new Cesium.Color.fromCssColorString(label2.backgroundColor);
- } else {
- label2.backgroundColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- label2.pixelOffset = Cesium.defaultValue(label2.pixelOffset, 0);
- label2.scale = Cesium.defaultValue(label2.scale, 1);
- label2.near = Cesium.defaultValue(label2.near, 150);
- label2.nearValue = Cesium.defaultValue(label2.nearValue, 1);
- label2.far = Cesium.defaultValue(label2.far, 2400);
- label2.farValue = Cesium.defaultValue(label2.farValue, 0);
- let labelText = label2.text;
- if (entity.properties[label2.textField]) {
- labelText = entity.properties[label2.textField]._value;
- }
- if (labelText === "") {
- labelText = (i + 1).toString();
- }
- entity.label = {
- text: labelText.toString(),
- font: label2.font,
- fillColor: label2.fillColor,
- outlineColor: label2.outlineColor,
- outlineWidth: label2.outlineWidth,
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- showBackground: label2.showBackground,
- backgroundColor: label2.backgroundColor,
- backgroundPadding: new Cesium.Cartesian2(6, 6),
- disableDepthTestDistance: Number.POSITIVE_INFINITY,
- pixelOffset: new Cesium.Cartesian2(0, label2.pixelOffset),
- scale: label2.scale
- };
- if (label2.scaleByDistance) {
- label2.scaleByDistance.near = Cesium.defaultValue(label2.scaleByDistance.near, 0);
- label2.scaleByDistance.nearValue = Cesium.defaultValue(label2.scaleByDistance.nearValue, 0);
- label2.scaleByDistance.far = Cesium.defaultValue(label2.scaleByDistance.far, 1);
- label2.scaleByDistance.farValue = Cesium.defaultValue(label2.scaleByDistance.farValue, 0);
- entity.label.scaleByDistance = new Cesium.NearFarScalar(label2.scaleByDistance.near, label2.scaleByDistance.nearValue, label2.scaleByDistance.far, label2.scaleByDistance.farValue);
- }
- }
- });
- if (callSuccess)
- callSuccess(options2.id);
- });
- },
- addBillboardByJson(options2, callSuccess) {
- let _self = this;
- let viewer2 = this._viewer;
- if (!Cesium.defined(options2.url)) {
- resolve("options.url is required.");
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2 = options2 || {};
- let id = options2.id || this._guid();
- let height2 = Cesium.defaultValue(options2.height, 0);
- viewer2.terrainProvider;
- fetch(options2.url).then((res) => {
- return res.json();
- }).then((res) => {
- let dataSource = new Cesium.CustomDataSource(options2.id);
- viewer2.dataSources.add(dataSource);
- let promiseList = [];
- for (var i2 = 0; i2 < res.features.length; i2++) {
- let geometry2 = res.features[i2].geometry;
- let properties = res.features[i2].properties;
- if (geometry2) {
- if (properties) {
- options2.properties = properties;
- if (options2.label) {
- let label2 = options2.label || {};
- if (properties[label2.textField]) {
- options2.label.text = properties[label2.textField];
- }
- }
- }
- if (geometry2.type === "MultiPoint") {
- let coordinatesList = geometry2.coordinates;
- for (var j = 0; j < coordinatesList.length; j++) {
- let coordinates = coordinatesList[j];
- let position2 = Cesium.Cartesian3.fromDegrees(coordinates[0], coordinates[1], coordinates[2] || height2);
- if (options2.billboard) {
- _self._pointObject.addBillboard(position2, options2).then((entity) => {
- dataSource.entities.add(entity);
- });
- } else {
- _self._pointObject.addLabel(position2, options2).then((entity) => {
- dataSource.entities.add(entity);
- });
- }
- }
- } else {
- let coordinates = geometry2.coordinates;
- let position2 = Cesium.Cartesian3.fromDegrees(coordinates[0], coordinates[1], coordinates[2] || height2);
- if (options2.billboard) {
- let result = _self._pointObject.addBillboard(position2, options2);
- promiseList.push(result);
- } else {
- let result = _self._pointObject.addLabel(position2, options2);
- promiseList.push(result);
- }
- }
- }
- }
- Promise.all(promiseList).then((itemList) => {
- itemList.forEach((item, index2) => {
- dataSource.entities.add(item);
- });
- if (callSuccess)
- callSuccess(id);
- });
- });
- },
- addWallByJson(options2, callSuccess) {
- let _self = this;
- let viewer2 = this._viewer;
- if (!Cesium.defined(options2.url)) {
- resolve("options.url is required.");
- throw new Cesium.DeveloperError("options.url is required.");
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid();
- fetch(options2.url).then((res) => {
- return res.json();
- }).then((res) => {
- let dataSource = new Cesium.CustomDataSource(options2.id);
- viewer2.dataSources.add(dataSource);
- for (var i2 = 0; i2 < res.features.length; i2++) {
- if (res.features[i2].geometry) {
- if (res.features[i2].geometry.type === "MultiLineString") {
- let coordinatesList = res.features[i2].geometry.coordinates;
- for (var j = 0; j < coordinatesList.length; j++) {
- let coordinates = coordinatesList[j];
- let positions = coordinates.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- _self._wallObject.addWall(positions, options2).then((entity) => {
- dataSource.entities.add(entity);
- });
- }
- } else {
- let coordinates = res.features[i2].geometry.coordinates;
- let positions = coordinates.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- _self._wallObject.addWall(positions, options2).then((entity) => {
- dataSource.entities.add(entity);
- });
- }
- }
- }
- if (callSuccess)
- callSuccess(options2.id);
- });
- }
- });
- Object.assign(LoadMapData.prototype, {
- set3DTileStyle(options2) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.serviceId)) {
- throw new Cesium.DeveloperError("options.serviceId is required.");
- }
- if (Cesium.defined(options2.alpha)) {
- Cesium.Check.typeOf.number("alpha", options2.alpha);
- }
- options2.alpha = Cesium.defaultValue(options2.alpha, 1);
- let tileset = window[options2.serviceId];
- tileset.style = new Cesium.Cesium3DTileStyle({
- color: "color('rgba(255,255,255," + options2.alpha + ")')"
- });
- },
- set3DTileBMStyle: function(options2) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.serviceId)) {
- throw new Cesium.DeveloperError("options.serviceId is required.");
- }
- options2.color = options2.color ? "vec4(" + options2.color[0] + "/255, " + options2.color[1] + "/255, " + options2.color[2] + "/255, " + options2.color[3] + ")" : "vec4(0.0, 0.58, 0.86, 1.0)";
- let tileset = window[options2.serviceId];
- tileset.readyPromise.then((tileset2) => {
- tileset2.boundingSphere.radius;
- if (tileset2.boundingSphere.radius > 1e4) {
- tileset2.boundingSphere.radius / 10;
- }
- tileset2.style = new Cesium.Cesium3DTileStyle({
- color: options2.color
- });
- tileset2.tileVisible.addEventListener((tile) => {
- let content = tile.content;
- let featuresLength = content.featuresLength;
- for (let i2 = 0; i2 < featuresLength; i2 += 2) {
- const feature2 = content.getFeature(i2);
- const model = feature2.content._model;
- if (model && model._sourcePrograms && model._rendererResources) {
- Object.keys(model._sourcePrograms).forEach((key) => {
- const program = model._sourcePrograms[key];
- const fragmentShader = model._rendererResources.sourceShaders[program.fragmentShader];
- let vPosition = "";
- if (fragmentShader.indexOf(" v_positionEC;") !== -1) {
- vPosition = "v_positionEC";
- } else if (fragmentShader.indexOf(" v_pos;") !== -1) {
- vPosition = "v_pos";
- }
- const color2 = `vec4(${feature2.color.toString()})`;
- model._rendererResources.sourceShaders[program.fragmentShader] = `
- varying vec3 ${vPosition};
- void main(void){
- vec4 v_helsing_position = czm_inverseModelView * vec4(${vPosition},1);
-
- float _baseHeight = -30.0;
- float vtxf_height = v_helsing_position.z - _baseHeight;
- float stc_pl = fract(czm_frameNumber / 120.0) * 3.14159265 * 2.0;
- float stc_sd = vtxf_height / 30.0 + sin(stc_pl) * 0.1;
- gl_FragColor = ${color2};
- gl_FragColor *= vec4(stc_sd, stc_sd, stc_sd, 1.0);
- /* \u626B\u63CF\u7EBF */
- float glowRange = 80.0;
- float stc_a13 = fract(czm_frameNumber / 460.0);
- float stc_h = clamp(v_helsing_position.z / glowRange, 0.0, 1.0);
- stc_a13 = abs(stc_a13 - 0.5) * 1.0;
- float stc_diff = step(0.003, abs(stc_h - stc_a13));
- gl_FragColor.rgb += gl_FragColor.rgb * (1.0 - stc_diff);
- }
- `;
- });
- model._shouldRegenerateShaders = true;
- }
- }
- });
- });
- this._viewer.scene.requestRender();
- },
- set3DTilePosition: function(options2) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.serviceId)) {
- throw new Cesium.DeveloperError("options.serviceId is required.");
- }
- options2.height = Cesium.defaultValue(options2.height, 0);
- let boundingSphere = window[options2.serviceId].boundingSphere;
- let cartographic = Cesium.Cartographic.fromCartesian(boundingSphere.center);
- let left = Cesium.Cartesian3.fromRadians(cartographic.longitude, cartographic.latitude, options2.height);
- let right = Cesium.Cartesian3.fromRadians(cartographic.longitude, cartographic.latitude, 0);
- let translation = Cesium.Cartesian3.subtract(left, right, new Cesium.Cartesian3());
- window[options2.serviceId].modelMatrix = Cesium.Matrix4.fromTranslation(translation);
- this._viewer.scene.requestRender();
- },
- setLayersStyle(options2) {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.serviceId)) {
- throw new Cesium.DeveloperError("options.serviceId is required.");
- }
- let layer = window[options2.serviceId];
- if (Cesium.defined(options2.alpha)) {
- Cesium.Check.typeOf.number("alpha", options2.alpha);
- }
- options2.alpha = Cesium.defaultValue(options2.alpha, 1);
- layer.alpha = options2.alpha;
- if (Cesium.defined(options2.brightness)) {
- Cesium.Check.typeOf.number("brightness", options2.brightness);
- }
- options2.brightness = Cesium.defaultValue(options2.brightness, 1);
- layer.brightness = options2.brightness;
- if (Cesium.defined(options2.contrast)) {
- Cesium.Check.typeOf.number("contrast", options2.contrast);
- }
- options2.contrast = Cesium.defaultValue(options2.contrast, 1);
- layer.contrast = options2.contrast;
- if (Cesium.defined(options2.gamma)) {
- Cesium.Check.typeOf.number("gamma", options2.gamma);
- }
- options2.gamma = Cesium.defaultValue(options2.gamma, 1);
- layer.gamma = options2.gamma;
- if (Cesium.defined(options2.hue)) {
- Cesium.Check.typeOf.number("hue", options2.hue);
- }
- options2.hue = Cesium.defaultValue(options2.hue, 0);
- layer.hue = options2.hue;
- if (Cesium.defined(options2.saturation)) {
- Cesium.Check.typeOf.number("saturation", options2.saturation);
- }
- options2.saturation = Cesium.defaultValue(options2.saturation, 1);
- layer.saturation = options2.saturation;
- },
- setPolygonImageMaterial(options2) {
- if (Cesium.defined(options2.alpha)) {
- Cesium.Check.typeOf.number("alpha", options2.alpha);
- }
- options2.alpha = Cesium.defaultValue(options2.alpha, 1);
- let entity = window[options2.serviceId];
- entity.polygon.material.color._value.alpha = options2.alpha;
- },
- setModelStyle(options2) {
- if (Cesium.defined(options2.alpha)) {
- Cesium.Check.typeOf.number("alpha", options2.alpha);
- }
- options2.alpha = Cesium.defaultValue(options2.alpha, 1);
- let entity = window[options2.serviceId];
- if (entity.model) {
- entity.model.color._value.alpha = options2.alpha;
- } else {
- entity.color._value.alpha = options2.alpha;
- }
- },
- setTerrainExaggeration(options2) {
- if (Cesium.defined(options2.terrainExaggeration)) {
- Cesium.Check.typeOf.number("terrainExaggeration", options2.terrainExaggeration);
- }
- options2.terrainExaggeration = Cesium.defaultValue(options2.terrainExaggeration, 1);
- this._viewer.scene.globe.terrainExaggeration = options2.terrainExaggeration;
- }
- });
- Object.assign(LoadMapData.prototype, {
- removeImageryProvider(options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.serviceId)) {
- throw new Cesium.DeveloperError("options.serviceId is required.");
- }
- this._removeImageryProvider(options2.serviceId);
- resolve2(true);
- });
- },
- removeTerrain() {
- return new Promise((resolve2, reject2) => {
- this._setEllipsoidTerrain();
- resolve2(true);
- });
- },
- removeScenePrimitives(options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.serviceId)) {
- throw new Cesium.DeveloperError("options.serviceId is required.");
- }
- this._removeScenePrimitives(options2.serviceId);
- resolve2(true);
- });
- },
- removeEntity(options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.serviceId)) {
- throw new Cesium.DeveloperError("options.serviceId is required.");
- }
- this._viewer.entities.remove(window[options2.serviceId]);
- window[options2.serviceId] = null;
- resolve2(true);
- });
- },
- removeDataSources(options2) {
- let viewer2 = this._viewer;
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.serviceId)) {
- throw new Cesium.DeveloperError("options.serviceId is required.");
- }
- let list = viewer2.dataSources.getByName(options2.serviceId);
- list.forEach((res, index2) => {
- viewer2.dataSources.remove(res);
- if (index2 === list.length - 1) {
- resolve2(true);
- }
- });
- });
- }
- });
- Date.prototype.Format = function(fmt) {
- var o = {
- "M+": this.getMonth() + 1,
- "d+": this.getDate(),
- "h+": this.getHours(),
- "m+": this.getMinutes(),
- "s+": this.getSeconds(),
- "q+": Math.floor((this.getMonth() + 3) / 3),
- "S": this.getMilliseconds()
- };
- if (/(y+)/.test(fmt))
- fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
- for (var k in o)
- if (new RegExp("(" + k + ")").test(fmt))
- fmt = fmt.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length));
- return fmt;
- };
- class CrImageServerLayer {
- constructor({
- viewer: viewer2,
- url,
- opacity = 0.75,
- show = true
- } = {}) {
- this._viewer = viewer2;
- this._url = url;
- this._opacity = opacity;
- this._renderName = this._guid();
- let dataSource = new Cesium.CustomDataSource(this._renderName);
- this._viewer.dataSources.add(dataSource);
- this._entities = dataSource.entities;
- this._renderEntities = /* @__PURE__ */ new Map();
- this._isUpdateTile = show;
- this._isDebug = false;
- this._init();
- }
- _init() {
- let _self = this;
- this._provider = new Cesium.ArcGisMapServerImageryProvider({
- url: _self._url
- });
- this._provider.readyPromise.then(function(result) {
- _self._rectangle = _self._provider.rectangle;
- if (_self._isDebug)
- _self._printDebug();
- _self._viewer.scene.postRender.addEventListener(() => {
- if (_self._isUpdateTile) {
- _self._isUpdateTile = false;
- _self._renderTiles();
- }
- });
- });
- }
- _guid() {
- function S4() {
- return ((1 + Math.random()) * 65536 | 0).toString(16).substring(1);
- }
- return S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4();
- }
- _printDebug() {
- this._provider.tilingScheme;
- let tiling84 = new Cesium.GeographicTilingScheme();
- this._drawDebugRectangle(this._rectangle, Cesium.Color.GREEN);
- tiling84.tileXYToRectangle(1696, 312, 10);
- }
- _drawDebugRectangle(rectangle, color2) {
- let positions = this._calculateRectangleOutlineCoordinates(rectangle);
- let rectEntity = new Cesium.Entity({
- name: this._renderName,
- polyline: {
- positions,
- material: color2,
- width: 10,
- clampToGround: true
- }
- });
- this._entities.add(rectEntity);
- }
- _console(...rest) {
- if (this._isDebug)
- console.log("===" + new Date().Format("yyyy-MM-dd HH:mm:ss") + ">>>", rest);
- }
- _renderTiles() {
- let _self = this;
- let tilesToRender = this._viewer.scene.globe._surface._tilesToRender;
- if (tilesToRender === void 0 || tilesToRender.length === 0) {
- this._isUpdateTile = true;
- return;
- } else {
- new Promise((resolve2, reject2) => {
- tilesToRender.sort(function(obj1, obj2) {
- let level1 = parseInt(obj1.level);
- let level2 = parseInt(obj2.level);
- return level1 - level2;
- });
- resolve2(tilesToRender);
- }).then((tiles) => {
- _self._asyncProjectionTiles(tiles);
- });
- }
- }
- _createKey(x, y, level) {
- let key = `${this._renderName}_${x}_${y}_${level}`;
- return key;
- }
- _asyncProjectionTiles(tiles) {
- let renderTiles = [];
- for (let tile of tiles) {
- let proTiles = this._projectionTile(tile);
- for (let proTile of proTiles) {
- let key = this._createKey(proTile.x, proTile.y, proTile.level);
- let subTile = renderTiles.find((obj) => {
- return obj.x === proTile.x && obj.y === proTile.y;
- });
- if (subTile === void 0) {
- let isExists = false;
- for (let eTile of renderTiles) {
- if (Cesium.Rectangle.intersection(eTile.rectangle, proTile.rectangle)) {
- eTile.childTiles.push(key);
- isExists = true;
- break;
- }
- }
- if (!isExists) {
- renderTiles.push({
- key,
- x: proTile.x,
- y: proTile.y,
- level: proTile.level,
- rectangle: proTile.rectangle,
- childTiles: []
- });
- }
- }
- }
- }
- let i2 = renderTiles.length;
- let appendTiles = [];
- while (i2--) {
- let findTile = renderTiles[i2];
- if (findTile.childTiles.length >= 1) {
- let tiles2 = this._createFourTiles(findTile);
- for (let tile of tiles2) {
- appendTiles.push(tile);
- }
- renderTiles.splice(i2, 1);
- }
- }
- for (let appendTile of appendTiles) {
- renderTiles.push(appendTile);
- }
- renderTiles.sort(function(obj1, obj2) {
- let level1 = parseInt(obj1.level);
- let level2 = parseInt(obj2.level);
- return level1 - level2;
- });
- this._renderTilesToViewer(renderTiles);
- }
- _createTileByRectangleAndLevel(rectangle, level) {
- let center2 = Cesium.Rectangle.center(rectangle);
- let nLevel = parseInt(level) + 1;
- let query = this._provider.tilingScheme.positionToTileXY(center2, nLevel);
- if (query === void 0)
- return void 0;
- return {
- key: this._createKey(query.x, query.y, nLevel),
- x: query.x,
- y: query.y,
- level: nLevel,
- rectangle,
- childTiles: []
- };
- }
- _createFourTiles(tile) {
- let rects = [];
- let results = [];
- let rectangle = tile.rectangle;
- rects.push(Cesium.Rectangle.subsection(rectangle, 0, 0, 0.5, 0.5));
- rects.push(Cesium.Rectangle.subsection(rectangle, 0.5, 0, 1, 0.5));
- rects.push(Cesium.Rectangle.subsection(rectangle, 0, 0.5, 0.5, 1));
- rects.push(Cesium.Rectangle.subsection(rectangle, 0.5, 0.5, 1, 1));
- for (let rect of rects) {
- if (Cesium.Rectangle.intersection(rect, this._rectangle)) {
- let newTile = this._createTileByRectangleAndLevel(rect, tile.level);
- if (newTile !== void 0)
- results.push(newTile);
- }
- }
- return results;
- }
- _renderTilesToViewer(tiles) {
- let _self = this;
- let deleteKeys = [];
- for (let [key, tile] of this._renderEntities) {
- let findTile = tiles.find((obj) => {
- return obj.key === key;
- });
- if (findTile === void 0) {
- deleteKeys.push(key);
- }
- }
- for (let key of deleteKeys) {
- this._renderEntities.delete(key);
- this._entities.removeById(key);
- }
- for (let tile of tiles) {
- if (!this._renderEntities.has(tile.key)) {
- let entity = this._renderSimpleTileToViewer(tile);
- this._renderEntities.set(tile.key, entity);
- let workBlob = new Blob([`(${downloadWorker.toString()})()`]);
- let worker = new Worker(URL.createObjectURL(workBlob));
- worker.postMessage({
- key: tile.key,
- url: this._url,
- x: tile.x,
- y: tile.y,
- level: tile.level
- });
- worker.onmessage = function(event2) {
- _self._console(`render x:${event2.data.x} y:${event2.data.y} level:${event2.data.level}`);
- let renderEntity = _self._entities.getById(event2.data.key);
- if (renderEntity !== void 0) {
- event2.data.key;
- const canvas = _self._createCanvas(event2.data, event2.data.image, _self._isDebug);
- renderEntity.rectangle.material = canvas;
- }
- worker.terminate();
- };
- }
- }
- this._isUpdateTile = true;
- }
- _renderSimpleTileToViewer(tile) {
- const canvas = this._createCanvas(tile, void 0, this._isDebug);
- let bjPositions = this._calculateRectangleOutlineCoordinates(tile.rectangle);
- let tileEntity = new Cesium.Entity({
- name: this._renderName,
- id: tile.key,
- rectangle: {
- coordinates: tile.rectangle,
- material: canvas
- },
- polyline: {
- positions: bjPositions,
- material: Cesium.Color.YELLOW.withAlpha(this._isDebug ? 1 : 0),
- width: 1,
- clampToGround: true
- }
- });
- return this._entities.add(tileEntity);
- }
- _createCanvas(tile, image, islabel) {
- let provider = this._provider;
- const canvas = document.createElement("canvas");
- canvas.width = provider.tileWidth;
- canvas.height = provider.tileHeight;
- const context = canvas.getContext("2d");
- if (image !== void 0) {
- context.globalAlpha = this._opacity;
- context.drawImage(event.data.image, 0, 0, canvas.width, canvas.height);
- }
- if (islabel !== void 0 && islabel === true) {
- context.globalAlpha = 1;
- context.font = "20px Arial";
- context.textAlign = "center";
- context.fillStyle = "rgba(255,255,0)";
- context.strokeStyle = "rgba(255,255,255,1)";
- context.lineWidth = 2;
- context.strokeText(`L: ${tile.level}`, 126, 86);
- context.fillText(`L: ${tile.level}`, 126, 86);
- context.strokeText(`X: ${tile.x}`, 126, 136);
- context.fillText(`X: ${tile.x}`, 126, 136);
- context.strokeText(`Y: ${tile.y}`, 126, 186);
- context.fillText(`Y: ${tile.y}`, 126, 186);
- }
- return canvas;
- }
- _projectionTile(tile) {
- let rectangle = tile._rectangle;
- let imageryLevel = parseInt(tile.level);
- let mercatorTilingScheme = this._provider.tilingScheme;
- let res = [];
- let interRectangle = Cesium.Rectangle.intersection(rectangle, this._rectangle);
- if (interRectangle === void 0)
- return res;
- let northwestTileCoordinates = mercatorTilingScheme.positionToTileXY(
- Cesium.Rectangle.northwest(rectangle),
- imageryLevel
- );
- let southeastTileCoordinates = mercatorTilingScheme.positionToTileXY(
- Cesium.Rectangle.southeast(rectangle),
- imageryLevel
- );
- if (northwestTileCoordinates !== void 0 && southeastTileCoordinates !== void 0) {
- for (let i2 = northwestTileCoordinates.x; i2 <= southeastTileCoordinates.x; i2++) {
- for (let j = northwestTileCoordinates.y; j <= southeastTileCoordinates.y; j++) {
- let _webRectangle = mercatorTilingScheme.tileXYToRectangle(i2, j, imageryLevel);
- if (Cesium.Rectangle.intersection(_webRectangle, this._rectangle)) {
- res.push({
- x: i2,
- y: j,
- level: imageryLevel,
- rectangle: _webRectangle
- });
- }
- }
- }
- } else if (northwestTileCoordinates !== void 0) {
- let _webRectangle = mercatorTilingScheme.tileXYToRectangle(
- northwestTileCoordinates.x,
- northwestTileCoordinates.y,
- imageryLevel
- );
- if (Cesium.Rectangle.intersection(_webRectangle, this._rectangle)) {
- res.push({
- x: northwestTileCoordinates.x,
- y: northwestTileCoordinates.y,
- level: imageryLevel,
- rectangle: _webRectangle
- });
- }
- } else if (southeastTileCoordinates !== void 0) {
- let _webRectangle = mercatorTilingScheme.tileXYToRectangle(
- southeastTileCoordinates.x,
- southeastTileCoordinates.y,
- imageryLevel
- );
- if (Cesium.Rectangle.intersection(_webRectangle, this._rectangle)) {
- res.push({
- x: southeastTileCoordinates.x,
- y: southeastTileCoordinates.y,
- level: imageryLevel,
- rectangle: _webRectangle
- });
- }
- }
- return res;
- }
- _calculateRectangleOutlineCoordinates(rectangle) {
- let south_east = Cesium.Rectangle.southeast(rectangle);
- let se2 = Cesium.Cartographic.toCartesian(south_east);
- let south_west = Cesium.Rectangle.southwest(rectangle);
- let sw = Cesium.Cartographic.toCartesian(south_west);
- let north_east = Cesium.Rectangle.northeast(rectangle);
- let ne2 = Cesium.Cartographic.toCartesian(north_east);
- let north_west = Cesium.Rectangle.northwest(rectangle);
- let nw = Cesium.Cartographic.toCartesian(north_west);
- return [sw, se2, ne2, nw, sw];
- }
- _removeEntityByName(entityName) {
- var entities2 = this._entities;
- if (!entities2 || !entities2.values)
- return;
- var delEntitys = [];
- for (var i2 = 0; i2 < entities2.values.length; i2++) {
- if (entities2.values[i2].name == entityName) {
- delEntitys.push(entities2.values[i2]);
- }
- }
- for (var i2 = 0; i2 < delEntitys.length; i2++) {
- entities2.remove(delEntitys[i2]);
- }
- }
- }
- Object.assign(CrImageServerLayer.prototype, {
- hide: function() {
- this._console("\u9690\u85CF");
- this._isUpdateTile = false;
- this._removeEntityByName(this._renderName);
- this._renderEntities.clear();
- },
- show: function() {
- this._console("\u663E\u793A");
- this._isUpdateTile = true;
- },
- setOpacity: function(opacity) {
- if (opacity === void 0 || typeof opacity !== "number")
- return;
- if (opacity >= 1)
- this._opacity = 1;
- if (opacity <= 0)
- this._opacity = 0;
- this._opacity = parseFloat(opacity);
- }
- });
- function downloadWorker() {
- onmessage = function(event2) {
- let data = event2.data;
- let url = data.url + "/tile/" + data.level + "/" + data.y + "/" + data.x;
- let xhr = new XMLHttpRequest();
- xhr.open("get", url, true);
- xhr.responseType = "blob";
- xhr.onload = function() {
- if (this.status === 200) {
- var blob = this.response;
- var bmpPromise = createImageBitmap(blob, {
- imageOrientation: "none",
- premultiplyAlpha: "none",
- colorSpaceConversion: "default"
- });
- bmpPromise.then(function(image) {
- let outObj = {
- key: data.key,
- x: data.x,
- y: data.y,
- level: data.level,
- image
- };
- postMessage(outObj);
- });
- } else {
- console.log("===>>>", url + " Not found");
- }
- };
- xhr.send();
- };
- }
- class LocateUtil {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this._locationEntity = null;
- }
- }
- Object.assign(LocateUtil.prototype, {
- flyToPoint: function(options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(options2) || !Cesium.defined(options2.longitude) || !Cesium.defined(options2.latitude)) {
- throw new Cesium.DeveloperError("options.longitude and options.latitude are required.");
- }
- options2.height = Cesium.defaultValue(options2.height, 0);
- options2.heading = Cesium.defaultValue(options2.heading, 0);
- options2.pitch = Cesium.defaultValue(options2.pitch, -90);
- options2.range = Cesium.defaultValue(options2.range, 0);
- options2.duration = Cesium.defaultValue(options2.duration, 3);
- var boundingSphere = new Cesium.BoundingSphere(Cesium.Cartesian3.fromDegrees(options2.longitude, options2.latitude, options2.height), 0);
- this._viewer.camera.flyToBoundingSphere(boundingSphere, {
- duration: options2.duration,
- complete: function() {
- resolve2(true);
- },
- offset: {
- heading: Cesium.Math.toRadians(options2.heading),
- pitch: Cesium.Math.toRadians(options2.pitch),
- range: options2.range
- }
- });
- });
- },
- flyToEntityByPoints: function(points2, type2, options2) {
- return new Promise((resolve2, reject2) => {
- let _self = this;
- options2 = options2 || {};
- if (points2 === void 0 || points2.length === void 0) {
- reject2("\u8F93\u5165\u7684\u5750\u6807\u96C6\u5408\u5F02\u5E38\uFF01");
- return;
- }
- let pointsArray = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- switch (type2) {
- case "point":
- _self._locationEntity = _self._viewer.entities.add({
- position: pointsArray[0],
- point: {
- pixelSize: 1
- }
- });
- break;
- case "polyline":
- if (pointsArray.length < 2) {
- reject2("\u7EBF\u5BF9\u8C61\u5B9A\u4F4D\uFF0C\u70B9\u6570\u81F3\u5C112\u4E2A");
- } else {
- _self._locationEntity = _self._viewer.entities.add({
- polyline: {
- positions: pointsArray,
- clampToGround: true,
- material: new Cesium.Color(255, 0, 0, 0.5),
- width: 1
- }
- });
- }
- break;
- case "polygon":
- if (pointsArray.length < 3) {
- reject2("\u9762\u5BF9\u8C61\u5B9A\u4F4D\uFF0C\u70B9\u6570\u81F3\u5C113\u4E2A");
- } else {
- _self._locationEntity = _self._viewer.entities.add({
- polygon: {
- hierarchy: {
- positions: pointsArray
- },
- material: new Cesium.Color(255, 0, 0, 0.5),
- outline: true
- }
- });
- }
- break;
- default:
- reject2("\u5750\u6807\u5F02\u5E38\uFF01");
- break;
- }
- options2.duration = Cesium.defaultValue(options2.duration, 3);
- options2.heading = Cesium.defaultValue(options2.heading, 0);
- options2.pitch = Cesium.defaultValue(options2.pitch, -90);
- options2.range = Cesium.defaultValue(options2.range, 0);
- let flyPromise = _self._viewer.flyTo(_self._locationEntity, {
- duration: options2.duration,
- offset: {
- heading: Cesium.Math.toRadians(options2.heading),
- pitch: Cesium.Math.toRadians(options2.pitch),
- range: options2.range
- }
- });
- flyPromise.then(function(flag) {
- resolve2(flag);
- });
- });
- },
- flyToEntity: function(entity, options2) {
- return new Promise((resolve2, reject2) => {
- let _self = this;
- options2 = options2 || {};
- options2.duration = Cesium.defaultValue(options2.duration, 3);
- options2.heading = Cesium.defaultValue(options2.heading, 0);
- options2.pitch = Cesium.defaultValue(options2.pitch, -90);
- options2.range = Cesium.defaultValue(options2.range, 0);
- let flyPromise = _self._viewer.flyTo(entity, {
- duration: options2.duration,
- offset: {
- heading: Cesium.Math.toRadians(options2.heading),
- pitch: Cesium.Math.toRadians(options2.pitch),
- range: options2.range
- }
- });
- flyPromise.then(function(flag) {
- resolve2(flag);
- });
- });
- },
- zoomToTilesets(tileset, options2) {
- return new Promise((resolve2, reject2) => {
- let _self = this;
- if (!Cesium.defined(tileset)) {
- throw new Cesium.DeveloperError("tileset is required.");
- }
- options2 = options2 || {};
- options2.heading = Cesium.defaultValue(options2.heading, 120);
- options2.pitch = Cesium.defaultValue(options2.pitch, -10);
- options2.range = Cesium.defaultValue(options2.range, 450);
- options2.duration = Cesium.defaultValue(options2.duration, 3);
- let boundingSphere = tileset.boundingSphere;
- _self._viewer.camera.flyToBoundingSphere(boundingSphere, {
- duration: options2.duration,
- complete: function() {
- resolve2(true);
- },
- offset: {
- heading: Cesium.Math.toRadians(options2.heading),
- pitch: Cesium.Math.toRadians(options2.pitch),
- range: options2.range
- }
- });
- });
- },
- flyToTileset(tileset, options2) {
- return new Promise((resolve2, reject2) => {
- let _self = this;
- if (!Cesium.defined(tileset)) {
- throw new Cesium.DeveloperError("tileset is required.");
- }
- options2 = options2 || {};
- options2.heading = Cesium.defaultValue(options2.heading, 120);
- options2.pitch = Cesium.defaultValue(options2.pitch, -10);
- options2.range = Cesium.defaultValue(options2.range, 450);
- options2.duration = Cesium.defaultValue(options2.duration, 3);
- let flyPromise = _self._viewer.flyTo(tileset, {
- duration: options2.duration,
- offset: {
- heading: Cesium.Math.toRadians(options2.heading),
- pitch: Cesium.Math.toRadians(options2.pitch),
- range: options2.range
- }
- });
- flyPromise.then(function(flag) {
- resolve2(flag);
- });
- });
- }
- });
- const CreateRemindertip = function(arr, position2, show) {
- let tooltip2 = document.getElementById("toolTip");
- let style, _x, _y, _color;
- if (arr && typeof arr === "object") {
- style = arr;
- }
- if (style && style.origin) {
- style.origin === "center" && (_x = 15, _y = -12);
- style.origin === "top" && (_x = 15, _y = -44);
- style.origin === "bottom" && (_x = 15, _y = 20);
- } else {
- _x = 15, _y = 20;
- }
- if (style && style.color) {
- style.color === "white" && (_color = "background: rgba(255, 255, 255, 0.8);color: black;");
- style.color === "black" && (_color = "background: rgba(0, 0, 0, 0.65);color: white;");
- style.color === "yellow" && (_color = "color: black;background-color: #ffcc33;border: 1px solid white;");
- } else {
- _color = "background: rgba(0, 0, 0, 0.65);color: white;";
- }
- if (!tooltip2) {
- const viewerDom = document.getElementsByClassName("cesium-viewer")[0];
- let elementbottom = document.createElement("div");
- viewerDom.append(elementbottom);
- let html = '<div id="toolTip" style="display: none;pointer-events: none;position: absolute;z-index: 1000;opacity: 0.8;border-radius: 4px;padding: 4px 8px;white-space: nowrap;font-family:\u9ED1\u4F53;color:white;font-weight: bolder;font-size: 14px;' + _color + '"></div>';
- viewerDom.insertAdjacentHTML("beforeend", html);
- tooltip2 = document.getElementById("toolTip");
- }
- if (show) {
- tooltip2.innerHTML = arr;
- tooltip2.style.left = position2.x + _x + "px";
- tooltip2.style.top = position2.y + _y + "px";
- tooltip2.style.display = "block";
- } else {
- tooltip2.style.display = "none";
- }
- return {
- tooltip: tooltip2,
- style,
- showAt: function(position3, text) {
- this.tooltip.innerHTML = text;
- if (this.style && this.style.origin) {
- this.style.origin === "center" && (_x = 15, _y = -this.tooltip.offsetHeight / 2);
- this.style.origin === "top" && (_x = 15, _y = -this.tooltip.offsetHeight - 20);
- this.style.origin === "bottom" && (_x = 15, _y = 20);
- } else {
- _x = 15, _y = -this.tooltip.offsetHeight / 2;
- }
- this.tooltip.style.left = position3.x + _x + "px";
- this.tooltip.style.top = position3.y + _y + "px";
- this.tooltip.style.display = "block";
- },
- show: function(show2) {
- if (show2) {
- this.tooltip.style.display = "block";
- } else {
- this.tooltip.style.display = "none";
- }
- }
- };
- };
- class SightLine {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this._resultObject = {
- viewPoint: void 0,
- targetPoints: [],
- targetPoint: void 0,
- objectExclude: [],
- entities: []
- };
- }
- _distance(point1, point2) {
- let point1cartographic = Cesium.Cartographic.fromCartesian(point1);
- let point2cartographic = Cesium.Cartographic.fromCartesian(point2);
- let geodesic = new Cesium.EllipsoidGeodesic();
- geodesic.setEndPoints(point1cartographic, point2cartographic);
- let s = geodesic.surfaceDistance;
- s = Math.sqrt(
- Math.pow(s, 2) + Math.pow(point2cartographic.height - point1cartographic.height, 2)
- );
- return s;
- }
- _checkAppOrWeb() {
- if (window.navigator.userAgent.match(
- /(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i
- )) {
- return SightLine.RuntimeEnvironment.App;
- } else {
- return SightLine.RuntimeEnvironment.Web;
- }
- }
- _isRuntimeApp() {
- if (this._checkAppOrWeb() === SightLine.RuntimeEnvironment.App) {
- return true;
- }
- return false;
- }
- _isRuntimeWeb() {
- if (this._checkAppOrWeb() === SightLine.RuntimeEnvironment.Web) {
- return true;
- }
- return false;
- }
- _createOperationMainDom() {
- let buttonDiv = document.createElement("div");
- buttonDiv.id = "drawButtonDiv";
- buttonDiv.style.width = "80px";
- buttonDiv.style.backgroundColor = "rgba(5, 45, 155, 0.7)";
- buttonDiv.style.borderRadius = "5px";
- buttonDiv.style.display = "flex";
- buttonDiv.style.flexDirection = "column";
- buttonDiv.style.padding = "8px";
- buttonDiv.style.justifyContent = "center";
- buttonDiv.style.position = "absolute";
- buttonDiv.style.bottom = "150px";
- buttonDiv.style.right = "10px";
- let btnCompletion = document.createElement("button");
- btnCompletion.id = "btnDrawComplete";
- btnCompletion.style.height = "30px";
- btnCompletion.style.backgroundColor = "rgba(88, 185, 45, 1.0)";
- btnCompletion.style.color = "rgb(255, 255, 255)";
- btnCompletion.style.border = "0px solid red";
- btnCompletion.style.borderRadius = "5px";
- btnCompletion.innerHTML = "\u5B8C\u6210";
- btnCompletion.style.fontSize = "13px";
- btnCompletion.style.cursor = "pointer";
- buttonDiv.appendChild(btnCompletion);
- document.body.appendChild(buttonDiv);
- }
- _showTooltipMessage(message) {
- let msgMainDom = document.getElementById("messageMainDom");
- if (msgMainDom !== null && msgMainDom !== void 0) {
- document.body.removeChild(msgMainDom);
- }
- msgMainDom = document.createElement("div");
- msgMainDom.style.width = "30%";
- msgMainDom.style.backgroundColor = "rgba(237, 248, 230, 1.0)";
- msgMainDom.style.height = "45px";
- msgMainDom.style.border = "solid 2px rgb(219, 241, 208)";
- msgMainDom.style.borderRadius = "8px";
- msgMainDom.style.display = "flex";
- msgMainDom.style.alignItems = "center";
- msgMainDom.style.paddingLeft = "10px";
- msgMainDom.style.color = "rgb(91, 188, 48)";
- msgMainDom.style.fontSize = "14px";
- msgMainDom.style.fontWeight = "600";
- msgMainDom.style.position = "absolute";
- msgMainDom.style.left = "35%";
- msgMainDom.style.transition = "transform 1s";
- msgMainDom.style.transform = "translateY(-90px)";
- msgMainDom.style.top = "0px";
- msgMainDom.style.zIndex = 1e3;
- document.body.appendChild(msgMainDom);
- let strHtml = "";
- strHtml += "<div style='";
- strHtml += "background-color: rgb(88, 185, 45);";
- strHtml += "color: rgb(255, 255, 255);";
- strHtml += "height: 24px;";
- strHtml += "width: 24px;";
- strHtml += "border-radius: 20px;";
- strHtml += "display: flex;";
- strHtml += "justify-content: center;";
- strHtml += "align-items: center;";
- strHtml += "font-size: 14px;";
- strHtml += "margin-right: 18px;";
- strHtml += "'>✓</div>";
- strHtml += "<div>" + message + "</div>";
- msgMainDom.innerHTML = strHtml;
- msgMainDom.addEventListener("transitionend", function() {
- setTimeout(function() {
- document.body.removeChild(msgMainDom);
- }, 1e3);
- }, false);
- setTimeout(function() {
- msgMainDom.style.transform = "translateY(50px)";
- }, 100);
- }
- }
- Object.assign(SightLine.prototype, {
- startSightLine() {
- let _self = this;
- _self.clearAll();
- let toolTip = "\u5DE6\u952E\u5355\u51FB\u521B\u5EFA\u89C6\u89D2\u8D77\u70B9";
- if (this._isRuntimeApp()) {
- toolTip = "\u5355\u51FB\u521B\u5EFA\u89C6\u89D2\u8D77\u70B9";
- _self._showTooltipMessage(toolTip);
- }
- _self.handler = new Cesium.ScreenSpaceEventHandler(_self._viewer.canvas);
- _self.handler.setInputAction((event2) => {
- let loc2 = CoordTransform._transfromFromScreenPoint(_self._viewer, event2.position);
- toolTip = "\u5DE6\u952E\u521B\u5EFA\u89C6\u89D2\u7EC8\u70B9\uFF0C\u53F3\u952E\u7ED3\u675F\u901A\u89C6\u5206\u6790";
- if (this._isRuntimeApp()) {
- toolTip = "\u518D\u6B21\u5355\u51FB\u521B\u5EFA\u89C6\u89D2\u7EC8\u70B9";
- _self._showTooltipMessage(toolTip);
- }
- if (!Cesium.defined(loc2.sLocation))
- return;
- let cartesian = loc2.sLocation;
- if (!_self._resultObject.viewPoint) {
- _self._resultObject.viewPoint = cartesian;
- let pointEntity = _self._viewer.entities.add({
- position: cartesian,
- point: {
- color: Cesium.Color.YELLOW,
- pixelSize: 5
- },
- label: {
- text: "\u89C2\u5BDF\u4F4D\u7F6E",
- font: "12px sans-serif",
- fillColor: new Cesium.Color(255 / 255, 255 / 255, 255 / 255, 1),
- outlineColor: new Cesium.Color(0, 154 / 255, 94 / 255, 1),
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- outlineWidth: 1,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- pixelOffset: new Cesium.Cartesian2(0, -28),
- showBackground: true,
- backgroundColor: new Cesium.Color(0, 0, 0, 0.6),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- }
- });
- _self._resultObject.objectExclude.push(pointEntity);
- _self._resultObject.entities.push(pointEntity);
- } else {
- _self._resultObject.targetPoint = cartesian;
- let pointEntity = _self._viewer.entities.add({
- position: cartesian,
- point: {
- color: Cesium.Color.YELLOW,
- pixelSize: 5
- },
- label: {
- text: "\u76EE\u6807\u4F4D\u7F6E",
- font: "12px sans-serif",
- fillColor: new Cesium.Color(255 / 255, 255 / 255, 255 / 255, 1),
- outlineColor: new Cesium.Color(0, 154 / 255, 94 / 255, 1),
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- outlineWidth: 1,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- pixelOffset: new Cesium.Cartesian2(0, -28),
- showBackground: true,
- backgroundColor: new Cesium.Color(0, 0, 0, 0.6),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- }
- });
- _self._resultObject.objectExclude.push(pointEntity);
- _self._resultObject.entities.push(pointEntity);
- let direction = Cesium.Cartesian3.normalize(
- Cesium.Cartesian3.subtract(
- _self._resultObject.targetPoint,
- _self._resultObject.viewPoint,
- new Cesium.Cartesian3()
- ),
- new Cesium.Cartesian3()
- );
- let ray = new Cesium.Ray(_self._resultObject.viewPoint, direction);
- let result = _self._viewer.scene.pickFromRay(ray, _self._resultObject.objectExclude);
- if (result) {
- let dis0 = _self._distance(
- _self._resultObject.viewPoint,
- _self._resultObject.targetPoint
- );
- let dis1 = _self._distance(
- _self._resultObject.viewPoint,
- result.position
- );
- let dis2 = _self._distance(
- result.position,
- _self._resultObject.targetPoint
- );
- if (dis0 > dis1) {
- let _poly0 = _self._viewer.entities.add({
- polyline: {
- positions: [_self._resultObject.viewPoint, result.position],
- material: Cesium.Color.GREEN,
- width: 3
- }
- });
- _self._resultObject.entities.push(_poly0);
- let _poly1 = _self._viewer.entities.add({
- polyline: {
- positions: [result.position, _self._resultObject.targetPoint],
- material: Cesium.Color.RED,
- width: 3
- }
- });
- _self._resultObject.entities.push(_poly1);
- _self._resultObject.targetPoints.push({
- targetPoint: cartesian,
- visual: false,
- distance: [dis0, dis1, dis2]
- });
- } else {
- let _poly2 = _self._viewer.entities.add({
- polyline: {
- positions: [
- _self._resultObject.viewPoint,
- _self._resultObject.targetPoint
- ],
- material: Cesium.Color.GREEN,
- width: 3
- }
- });
- _self._resultObject.entities.push(_poly2);
- _self._resultObject.targetPoints.push({
- targetPoint: cartesian,
- visual: true,
- distance: [dis0, dis1, dis2]
- });
- }
- }
- }
- if (_self._resultObject.objectExclude.length === 2) {
- if (this._isRuntimeApp()) {
- _self._createOperationMainDom();
- document.getElementById("btnDrawComplete").onclick = () => {
- CreateRemindertip(toolTip, event2.endPosition, false);
- _self.handler.destroy();
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv) {
- document.body.removeChild(buttonDiv);
- }
- };
- }
- }
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- _self.handler.setInputAction(function(move) {
- if (_self._isRuntimeApp())
- return;
- CreateRemindertip(toolTip, move.endPosition, true);
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- _self.handler.setInputAction((event2) => {
- CreateRemindertip(toolTip, event2.endPosition, false);
- _self.handler.destroy();
- }, Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- },
- clearAll() {
- this._resultObject.entities.forEach((element) => {
- this._viewer.entities.remove(element);
- });
- this._resultObject = {
- viewPoint: void 0,
- targetPoints: [],
- targetPoint: void 0,
- objectExclude: [],
- entities: []
- };
- if (this.handler) {
- this.handler.destroy();
- }
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv) {
- document.body.removeChild(buttonDiv);
- }
- }
- });
- SightLine.RuntimeEnvironment = Object.freeze({
- App: "app",
- Web: "web"
- });
- /*!
- * author: [object Object]
- * @sakitam-gis/kriging v0.1.0
- * build-time: 2019-7-6 20:41
- * LICENSE: MIT
- * (c) 2019-2019 https://github.com/sakitam-gis/kriging.js
- */
- function max(source) {
- return Math.max.apply(null, source);
- }
- function min(source) {
- return Math.min.apply(null, source);
- }
- function rep(source, n) {
- var array = [];
- for (var i2 = 0; i2 < n; i2++) {
- array.push(source);
- }
- return array;
- }
- function pip(source, x, y) {
- var i2 = 0;
- var j = source.length - 1;
- var c = false;
- var length = source.length;
- for (; i2 < length; j = i2++) {
- if (source[i2][1] > y !== source[j][1] > y && x < (source[j][0] - source[i2][0]) * (y - source[i2][1]) / (source[j][1] - source[i2][1]) + source[i2][0]) {
- c = !c;
- }
- }
- return c;
- }
- function matrixDiag(c, n) {
- var i2 = 0;
- var Z2 = rep(0, n * n);
- for (; i2 < n; i2++) {
- Z2[i2 * n + i2] = c;
- }
- return Z2;
- }
- function matrixTranspose(X2, n, m) {
- var i2 = 0;
- var j;
- var Z2 = Array(m * n);
- for (; i2 < n; i2++) {
- j = 0;
- for (; j < m; j++) {
- Z2[j * n + i2] = X2[i2 * m + j];
- }
- }
- return Z2;
- }
- function matrixAdd(X2, Y, n, m) {
- var i2 = 0;
- var j;
- var Z2 = Array(n * m);
- for (; i2 < n; i2++) {
- j = 0;
- for (; j < m; j++) {
- Z2[i2 * m + j] = X2[i2 * m + j] + Y[i2 * m + j];
- }
- }
- return Z2;
- }
- function matrixMultiply(X2, Y, n, m, p) {
- var i2 = 0;
- var j;
- var k;
- var Z2 = Array(n * p);
- for (; i2 < n; i2++) {
- j = 0;
- for (; j < p; j++) {
- Z2[i2 * p + j] = 0;
- k = 0;
- for (; k < m; k++) {
- Z2[i2 * p + j] += X2[i2 * m + k] * Y[k * p + j];
- }
- }
- }
- return Z2;
- }
- function matrixChol(X2, n) {
- var i2;
- var j;
- var k;
- var p = Array(n);
- for (i2 = 0; i2 < n; i2++)
- p[i2] = X2[i2 * n + i2];
- for (i2 = 0; i2 < n; i2++) {
- for (j = 0; j < i2; j++)
- p[i2] -= X2[i2 * n + j] * X2[i2 * n + j];
- if (p[i2] <= 0)
- return false;
- p[i2] = Math.sqrt(p[i2]);
- for (j = i2 + 1; j < n; j++) {
- for (k = 0; k < i2; k++)
- X2[j * n + i2] -= X2[j * n + k] * X2[i2 * n + k];
- X2[j * n + i2] /= p[i2];
- }
- }
- for (i2 = 0; i2 < n; i2++)
- X2[i2 * n + i2] = p[i2];
- return true;
- }
- function matrixChol2inv(X2, n) {
- var i2;
- var j;
- var k;
- var sum;
- for (i2 = 0; i2 < n; i2++) {
- X2[i2 * n + i2] = 1 / X2[i2 * n + i2];
- for (j = i2 + 1; j < n; j++) {
- sum = 0;
- for (k = i2; k < j; k++)
- sum -= X2[j * n + k] * X2[k * n + i2];
- X2[j * n + i2] = sum / X2[j * n + j];
- }
- }
- for (i2 = 0; i2 < n; i2++)
- for (j = i2 + 1; j < n; j++)
- X2[i2 * n + j] = 0;
- for (i2 = 0; i2 < n; i2++) {
- X2[i2 * n + i2] *= X2[i2 * n + i2];
- for (k = i2 + 1; k < n; k++)
- X2[i2 * n + i2] += X2[k * n + i2] * X2[k * n + i2];
- for (j = i2 + 1; j < n; j++)
- for (k = j; k < n; k++)
- X2[i2 * n + j] += X2[k * n + i2] * X2[k * n + j];
- }
- for (i2 = 0; i2 < n; i2++)
- for (j = 0; j < i2; j++)
- X2[i2 * n + j] = X2[j * n + i2];
- }
- function matrixSolve(X2, n) {
- var m = n;
- var b = Array(n * n);
- var indxc = Array(n);
- var indxr = Array(n);
- var ipiv = Array(n);
- var i2;
- var icol = 0;
- var irow = 0;
- var j;
- var k;
- var l;
- var ll;
- var big;
- var dum;
- var pivinv;
- var temp;
- for (i2 = 0; i2 < n; i2++) {
- for (j = 0; j < n; j++) {
- if (i2 === j)
- b[i2 * n + j] = 1;
- else
- b[i2 * n + j] = 0;
- }
- }
- for (j = 0; j < n; j++)
- ipiv[j] = 0;
- for (i2 = 0; i2 < n; i2++) {
- big = 0;
- for (j = 0; j < n; j++) {
- if (ipiv[j] !== 1) {
- for (k = 0; k < n; k++) {
- if (ipiv[k] === 0) {
- if (Math.abs(X2[j * n + k]) >= big) {
- big = Math.abs(X2[j * n + k]);
- irow = j;
- icol = k;
- }
- }
- }
- }
- }
- ++ipiv[icol];
- if (irow !== icol) {
- for (l = 0; l < n; l++) {
- temp = X2[irow * n + l];
- X2[irow * n + l] = X2[icol * n + l];
- X2[icol * n + l] = temp;
- }
- for (l = 0; l < m; l++) {
- temp = b[irow * n + l];
- b[irow * n + l] = b[icol * n + l];
- b[icol * n + l] = temp;
- }
- }
- indxr[i2] = irow;
- indxc[i2] = icol;
- if (X2[icol * n + icol] === 0)
- return false;
- pivinv = 1 / X2[icol * n + icol];
- X2[icol * n + icol] = 1;
- for (l = 0; l < n; l++)
- X2[icol * n + l] *= pivinv;
- for (l = 0; l < m; l++)
- b[icol * n + l] *= pivinv;
- for (ll = 0; ll < n; ll++) {
- if (ll !== icol) {
- dum = X2[ll * n + icol];
- X2[ll * n + icol] = 0;
- for (l = 0; l < n; l++)
- X2[ll * n + l] -= X2[icol * n + l] * dum;
- for (l = 0; l < m; l++)
- b[ll * n + l] -= b[icol * n + l] * dum;
- }
- }
- }
- for (l = n - 1; l >= 0; l--) {
- if (indxr[l] !== indxc[l]) {
- for (k = 0; k < n; k++) {
- temp = X2[k * n + indxr[l]];
- X2[k * n + indxr[l]] = X2[k * n + indxc[l]];
- X2[k * n + indxc[l]] = temp;
- }
- }
- }
- return true;
- }
- function variogramGaussian(h2, nugget, range3, sill, A) {
- return nugget + (sill - nugget) / range3 * (1 - Math.exp(-(1 / A) * Math.pow(h2 / range3, 2)));
- }
- function variogramExponential(h2, nugget, range3, sill, A) {
- return nugget + (sill - nugget) / range3 * (1 - Math.exp(-(1 / A) * (h2 / range3)));
- }
- function variogramSpherical(h2, nugget, range3, sill) {
- if (h2 > range3)
- return nugget + (sill - nugget) / range3;
- return nugget + (sill - nugget) / range3 * (1.5 * (h2 / range3) - 0.5 * Math.pow(h2 / range3, 3));
- }
- function train(t2, x, y, model, sigma2, alpha) {
- var variogram = {
- t: t2,
- x,
- y,
- nugget: 0,
- range: 0,
- sill: 0,
- A: 1 / 3,
- n: 0,
- model: variogramExponential,
- K: [],
- M: []
- };
- switch (model) {
- case "gaussian":
- variogram.model = variogramGaussian;
- break;
- case "exponential":
- variogram.model = variogramExponential;
- break;
- case "spherical":
- variogram.model = variogramSpherical;
- break;
- default:
- variogram.model = variogramExponential;
- }
- var i2;
- var j;
- var k;
- var l;
- var n = t2.length;
- var distance2 = Array((n * n - n) / 2);
- for (i2 = 0, k = 0; i2 < n; i2++) {
- for (j = 0; j < i2; j++, k++) {
- distance2[k] = Array(2);
- distance2[k][0] = Math.pow(Math.pow(x[i2] - x[j], 2) + Math.pow(y[i2] - y[j], 2), 0.5);
- distance2[k][1] = Math.abs(t2[i2] - t2[j]);
- }
- }
- distance2.sort(function(a, b) {
- return a[0] - b[0];
- });
- variogram.range = distance2[(n * n - n) / 2 - 1][0];
- var lags = (n * n - n) / 2 > 30 ? 30 : (n * n - n) / 2;
- var tolerance = variogram.range / lags;
- var lag = rep(0, lags);
- var semi = rep(0, lags);
- if (lags < 30) {
- for (l = 0; l < lags; l++) {
- lag[l] = distance2[l][0];
- semi[l] = distance2[l][1];
- }
- } else {
- for (i2 = 0, j = 0, k = 0, l = 0; i2 < lags && j < (n * n - n) / 2; i2++, k = 0) {
- while (distance2[j][0] <= (i2 + 1) * tolerance) {
- lag[l] += distance2[j][0];
- semi[l] += distance2[j][1];
- j++;
- k++;
- if (j >= (n * n - n) / 2)
- break;
- }
- if (k > 0) {
- lag[l] /= k;
- semi[l] /= k;
- l++;
- }
- }
- if (l < 2)
- return variogram;
- }
- n = l;
- variogram.range = lag[n - 1] - lag[0];
- var X2 = rep(1, 2 * n);
- var Y = Array(n);
- var A = variogram.A;
- for (i2 = 0; i2 < n; i2++) {
- switch (model) {
- case "gaussian":
- X2[i2 * 2 + 1] = 1 - Math.exp(-(1 / A) * Math.pow(lag[i2] / variogram.range, 2));
- break;
- case "exponential":
- X2[i2 * 2 + 1] = 1 - Math.exp(-(1 / A) * lag[i2] / variogram.range);
- break;
- case "spherical":
- X2[i2 * 2 + 1] = 1.5 * (lag[i2] / variogram.range) - 0.5 * Math.pow(lag[i2] / variogram.range, 3);
- break;
- }
- Y[i2] = semi[i2];
- }
- var Xt2 = matrixTranspose(X2, n, 2);
- var Z2 = matrixMultiply(Xt2, X2, 2, n, 2);
- Z2 = matrixAdd(Z2, matrixDiag(1 / alpha, 2), 2, 2);
- var cloneZ = Z2.slice(0);
- if (matrixChol(Z2, 2)) {
- matrixChol2inv(Z2, 2);
- } else {
- matrixSolve(cloneZ, 2);
- Z2 = cloneZ;
- }
- var W2 = matrixMultiply(matrixMultiply(Z2, Xt2, 2, 2, n), Y, 2, n, 1);
- variogram.nugget = W2[0];
- variogram.sill = W2[1] * variogram.range + variogram.nugget;
- variogram.n = x.length;
- n = x.length;
- var K2 = Array(n * n);
- for (i2 = 0; i2 < n; i2++) {
- for (j = 0; j < i2; j++) {
- K2[i2 * n + j] = variogram.model(Math.pow(Math.pow(x[i2] - x[j], 2) + Math.pow(y[i2] - y[j], 2), 0.5), variogram.nugget, variogram.range, variogram.sill, variogram.A);
- K2[j * n + i2] = K2[i2 * n + j];
- }
- K2[i2 * n + i2] = variogram.model(0, variogram.nugget, variogram.range, variogram.sill, variogram.A);
- }
- var C2 = matrixAdd(K2, matrixDiag(sigma2, n), n, n);
- var cloneC = C2.slice(0);
- if (matrixChol(C2, n)) {
- matrixChol2inv(C2, n);
- } else {
- matrixSolve(cloneC, n);
- C2 = cloneC;
- }
- var K1 = C2.slice(0);
- var M = matrixMultiply(C2, t2, n, n, 1);
- variogram.K = K1;
- variogram.M = M;
- return variogram;
- }
- function predict(x, y, variogram) {
- var i2;
- var k = Array(variogram.n);
- for (i2 = 0; i2 < variogram.n; i2++) {
- k[i2] = variogram.model(Math.pow(Math.pow(x - variogram.x[i2], 2) + Math.pow(y - variogram.y[i2], 2), 0.5), variogram.nugget, variogram.range, variogram.sill, variogram.A);
- }
- return matrixMultiply(k, variogram.M, 1, variogram.n, 1)[0];
- }
- function variance(x, y, variogram) {
- var i2;
- var k = Array(variogram.n);
- for (i2 = 0; i2 < variogram.n; i2++) {
- k[i2] = variogram.model(Math.pow(Math.pow(x - variogram.x[i2], 2) + Math.pow(y - variogram.y[i2], 2), 0.5), variogram.nugget, variogram.range, variogram.sill, variogram.A);
- }
- var val = matrixMultiply(matrixMultiply(k, variogram.K, 1, variogram.n, variogram.n), k, 1, variogram.n, 1)[0];
- return variogram.model(0, variogram.nugget, variogram.range, variogram.sill, variogram.A) + val;
- }
- function grid(polygons2, variogram, width2) {
- var i2;
- var j;
- var k;
- var n = polygons2.length;
- if (n === 0)
- return;
- var xlim = [polygons2[0][0][0], polygons2[0][0][0]];
- var ylim = [polygons2[0][0][1], polygons2[0][0][1]];
- for (i2 = 0; i2 < n; i2++) {
- for (j = 0; j < polygons2[i2].length; j++) {
- if (polygons2[i2][j][0] < xlim[0])
- xlim[0] = polygons2[i2][j][0];
- if (polygons2[i2][j][0] > xlim[1])
- xlim[1] = polygons2[i2][j][0];
- if (polygons2[i2][j][1] < ylim[0])
- ylim[0] = polygons2[i2][j][1];
- if (polygons2[i2][j][1] > ylim[1])
- ylim[1] = polygons2[i2][j][1];
- }
- }
- var xtarget;
- var ytarget;
- var a = Array(2);
- var b = Array(2);
- var lxlim = Array(2);
- var lylim = Array(2);
- var x = Math.ceil((xlim[1] - xlim[0]) / width2);
- var y = Math.ceil((ylim[1] - ylim[0]) / width2);
- var A = Array(x + 1);
- for (i2 = 0; i2 <= x; i2++)
- A[i2] = Array(y + 1);
- for (i2 = 0; i2 < n; i2++) {
- lxlim[0] = polygons2[i2][0][0];
- lxlim[1] = lxlim[0];
- lylim[0] = polygons2[i2][0][1];
- lylim[1] = lylim[0];
- for (j = 1; j < polygons2[i2].length; j++) {
- if (polygons2[i2][j][0] < lxlim[0])
- lxlim[0] = polygons2[i2][j][0];
- if (polygons2[i2][j][0] > lxlim[1])
- lxlim[1] = polygons2[i2][j][0];
- if (polygons2[i2][j][1] < lylim[0])
- lylim[0] = polygons2[i2][j][1];
- if (polygons2[i2][j][1] > lylim[1])
- lylim[1] = polygons2[i2][j][1];
- }
- a[0] = Math.floor((lxlim[0] - (lxlim[0] - xlim[0]) % width2 - xlim[0]) / width2);
- a[1] = Math.ceil((lxlim[1] - (lxlim[1] - xlim[1]) % width2 - xlim[0]) / width2);
- b[0] = Math.floor((lylim[0] - (lylim[0] - ylim[0]) % width2 - ylim[0]) / width2);
- b[1] = Math.ceil((lylim[1] - (lylim[1] - ylim[1]) % width2 - ylim[0]) / width2);
- for (j = a[0]; j <= a[1]; j++) {
- for (k = b[0]; k <= b[1]; k++) {
- xtarget = xlim[0] + j * width2;
- ytarget = ylim[0] + k * width2;
- if (pip(polygons2[i2], xtarget, ytarget)) {
- A[j][k] = predict(xtarget, ytarget, variogram);
- }
- }
- }
- }
- return {
- xlim,
- ylim,
- width: width2,
- data: A,
- zlim: [min(variogram.t), max(variogram.t)]
- };
- }
- function plot(canvas, grid2, xlim, ylim, colors) {
- var ctx = canvas.getContext("2d");
- var data = grid2.data, zlim = grid2.zlim, width2 = grid2.width;
- if (ctx) {
- ctx.clearRect(0, 0, canvas.width, canvas.height);
- var range3 = [xlim[1] - xlim[0], ylim[1] - ylim[0], zlim[1] - zlim[0]];
- var i2 = void 0;
- var j = void 0;
- var x = void 0;
- var y = void 0;
- var z = void 0;
- var n = data.length;
- var m = data[0].length;
- var wx = Math.ceil(width2 * canvas.width / (xlim[1] - xlim[0]));
- var wy = Math.ceil(width2 * canvas.height / (ylim[1] - ylim[0]));
- for (i2 = 0; i2 < n; i2++) {
- for (j = 0; j < m; j++) {
- if (data[i2][j] === void 0)
- continue;
- x = canvas.width * (i2 * width2 + grid2.xlim[0] - xlim[0]) / range3[0];
- y = canvas.height * (1 - (j * width2 + grid2.ylim[0] - ylim[0]) / range3[1]);
- z = (data[i2][j] - zlim[0]) / range3[2];
- if (z < 0)
- z = 0;
- if (z > 1)
- z = 1;
- ctx.fillStyle = colors[Math.floor((colors.length - 1) * z)];
- ctx.fillRect(Math.round(x - wx / 2), Math.round(y - wy / 2), wx, wy);
- }
- }
- }
- }
- var index = {
- train,
- predict,
- variance,
- grid,
- plot,
- max,
- min,
- pip,
- rep,
- matrixDiag,
- matrixTranspose,
- matrixAdd,
- matrixMultiply,
- matrixChol,
- matrixChol2inv,
- matrixSolve,
- variogramGaussian,
- variogramExponential,
- variogramSpherical
- };
- var earthRadius = 63710088e-1;
- var factors = {
- centimeters: earthRadius * 100,
- centimetres: earthRadius * 100,
- degrees: earthRadius / 111325,
- feet: earthRadius * 3.28084,
- inches: earthRadius * 39.37,
- kilometers: earthRadius / 1e3,
- kilometres: earthRadius / 1e3,
- meters: earthRadius,
- metres: earthRadius,
- miles: earthRadius / 1609.344,
- millimeters: earthRadius * 1e3,
- millimetres: earthRadius * 1e3,
- nauticalmiles: earthRadius / 1852,
- radians: 1,
- yards: earthRadius * 1.0936
- };
- var unitsFactors = {
- centimeters: 100,
- centimetres: 100,
- degrees: 1 / 111325,
- feet: 3.28084,
- inches: 39.37,
- kilometers: 1 / 1e3,
- kilometres: 1 / 1e3,
- meters: 1,
- metres: 1,
- miles: 1 / 1609.344,
- millimeters: 1e3,
- millimetres: 1e3,
- nauticalmiles: 1 / 1852,
- radians: 1 / earthRadius,
- yards: 1.0936133
- };
- var areaFactors = {
- acres: 247105e-9,
- centimeters: 1e4,
- centimetres: 1e4,
- feet: 10.763910417,
- hectares: 1e-4,
- inches: 1550.003100006,
- kilometers: 1e-6,
- kilometres: 1e-6,
- meters: 1,
- metres: 1,
- miles: 386e-9,
- millimeters: 1e6,
- millimetres: 1e6,
- yards: 1.195990046
- };
- function feature(geom, properties, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var feat = { type: "Feature" };
- if (options2.id === 0 || options2.id) {
- feat.id = options2.id;
- }
- if (options2.bbox) {
- feat.bbox = options2.bbox;
- }
- feat.properties = properties || {};
- feat.geometry = geom;
- return feat;
- }
- function geometry(type2, coordinates, _options) {
- switch (type2) {
- case "Point":
- return point(coordinates).geometry;
- case "LineString":
- return lineString(coordinates).geometry;
- case "Polygon":
- return polygon(coordinates).geometry;
- case "MultiPoint":
- return multiPoint(coordinates).geometry;
- case "MultiLineString":
- return multiLineString(coordinates).geometry;
- case "MultiPolygon":
- return multiPolygon(coordinates).geometry;
- default:
- throw new Error(type2 + " is invalid");
- }
- }
- function point(coordinates, properties, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- if (!coordinates) {
- throw new Error("coordinates is required");
- }
- if (!Array.isArray(coordinates)) {
- throw new Error("coordinates must be an Array");
- }
- if (coordinates.length < 2) {
- throw new Error("coordinates must be at least 2 numbers long");
- }
- if (!isNumber$1(coordinates[0]) || !isNumber$1(coordinates[1])) {
- throw new Error("coordinates must contain numbers");
- }
- var geom = {
- type: "Point",
- coordinates
- };
- return feature(geom, properties, options2);
- }
- function points(coordinates, properties, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- return featureCollection$1(coordinates.map(function(coords) {
- return point(coords, properties);
- }), options2);
- }
- function polygon(coordinates, properties, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- for (var _i = 0, coordinates_1 = coordinates; _i < coordinates_1.length; _i++) {
- var ring = coordinates_1[_i];
- if (ring.length < 4) {
- throw new Error("Each LinearRing of a Polygon must have 4 or more Positions.");
- }
- for (var j = 0; j < ring[ring.length - 1].length; j++) {
- if (ring[ring.length - 1][j] !== ring[0][j]) {
- throw new Error("First and last Position are not equivalent.");
- }
- }
- }
- var geom = {
- type: "Polygon",
- coordinates
- };
- return feature(geom, properties, options2);
- }
- function polygons(coordinates, properties, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- return featureCollection$1(coordinates.map(function(coords) {
- return polygon(coords, properties);
- }), options2);
- }
- function lineString(coordinates, properties, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- if (coordinates.length < 2) {
- throw new Error("coordinates must be an array of two or more positions");
- }
- var geom = {
- type: "LineString",
- coordinates
- };
- return feature(geom, properties, options2);
- }
- function lineStrings(coordinates, properties, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- return featureCollection$1(coordinates.map(function(coords) {
- return lineString(coords, properties);
- }), options2);
- }
- function featureCollection$1(features, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var fc = { type: "FeatureCollection" };
- if (options2.id) {
- fc.id = options2.id;
- }
- if (options2.bbox) {
- fc.bbox = options2.bbox;
- }
- fc.features = features;
- return fc;
- }
- function multiLineString(coordinates, properties, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var geom = {
- type: "MultiLineString",
- coordinates
- };
- return feature(geom, properties, options2);
- }
- function multiPoint(coordinates, properties, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var geom = {
- type: "MultiPoint",
- coordinates
- };
- return feature(geom, properties, options2);
- }
- function multiPolygon(coordinates, properties, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var geom = {
- type: "MultiPolygon",
- coordinates
- };
- return feature(geom, properties, options2);
- }
- function geometryCollection(geometries, properties, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var geom = {
- type: "GeometryCollection",
- geometries
- };
- return feature(geom, properties, options2);
- }
- function round(num, precision) {
- if (precision === void 0) {
- precision = 0;
- }
- if (precision && !(precision >= 0)) {
- throw new Error("precision must be a positive number");
- }
- var multiplier = Math.pow(10, precision || 0);
- return Math.round(num * multiplier) / multiplier;
- }
- function radiansToLength(radians, units) {
- if (units === void 0) {
- units = "kilometers";
- }
- var factor = factors[units];
- if (!factor) {
- throw new Error(units + " units is invalid");
- }
- return radians * factor;
- }
- function lengthToRadians(distance2, units) {
- if (units === void 0) {
- units = "kilometers";
- }
- var factor = factors[units];
- if (!factor) {
- throw new Error(units + " units is invalid");
- }
- return distance2 / factor;
- }
- function lengthToDegrees(distance2, units) {
- return radiansToDegrees(lengthToRadians(distance2, units));
- }
- function bearingToAzimuth(bearing2) {
- var angle = bearing2 % 360;
- if (angle < 0) {
- angle += 360;
- }
- return angle;
- }
- function radiansToDegrees(radians) {
- var degrees = radians % (2 * Math.PI);
- return degrees * 180 / Math.PI;
- }
- function degreesToRadians(degrees) {
- var radians = degrees % 360;
- return radians * Math.PI / 180;
- }
- function convertLength(length, originalUnit, finalUnit) {
- if (originalUnit === void 0) {
- originalUnit = "kilometers";
- }
- if (finalUnit === void 0) {
- finalUnit = "kilometers";
- }
- if (!(length >= 0)) {
- throw new Error("length must be a positive number");
- }
- return radiansToLength(lengthToRadians(length, originalUnit), finalUnit);
- }
- function convertArea(area, originalUnit, finalUnit) {
- if (originalUnit === void 0) {
- originalUnit = "meters";
- }
- if (finalUnit === void 0) {
- finalUnit = "kilometers";
- }
- if (!(area >= 0)) {
- throw new Error("area must be a positive number");
- }
- var startFactor = areaFactors[originalUnit];
- if (!startFactor) {
- throw new Error("invalid original units");
- }
- var finalFactor = areaFactors[finalUnit];
- if (!finalFactor) {
- throw new Error("invalid final units");
- }
- return area / startFactor * finalFactor;
- }
- function isNumber$1(num) {
- return !isNaN(num) && num !== null && !Array.isArray(num);
- }
- function isObject$6(input) {
- return !!input && input.constructor === Object;
- }
- function validateBBox(bbox2) {
- if (!bbox2) {
- throw new Error("bbox is required");
- }
- if (!Array.isArray(bbox2)) {
- throw new Error("bbox must be an Array");
- }
- if (bbox2.length !== 4 && bbox2.length !== 6) {
- throw new Error("bbox must be an Array of 4 or 6 numbers");
- }
- bbox2.forEach(function(num) {
- if (!isNumber$1(num)) {
- throw new Error("bbox must only contain numbers");
- }
- });
- }
- function validateId(id) {
- if (!id) {
- throw new Error("id is required");
- }
- if (["string", "number"].indexOf(typeof id) === -1) {
- throw new Error("id must be a number or a string");
- }
- }
- var es$2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
- __proto__: null,
- earthRadius,
- factors,
- unitsFactors,
- areaFactors,
- feature,
- geometry,
- point,
- points,
- polygon,
- polygons,
- lineString,
- lineStrings,
- featureCollection: featureCollection$1,
- multiLineString,
- multiPoint,
- multiPolygon,
- geometryCollection,
- round,
- radiansToLength,
- lengthToRadians,
- lengthToDegrees,
- bearingToAzimuth,
- radiansToDegrees,
- degreesToRadians,
- convertLength,
- convertArea,
- isNumber: isNumber$1,
- isObject: isObject$6,
- validateBBox,
- validateId
- }, Symbol.toStringTag, { value: "Module" }));
- function coordEach(geojson, callback2, excludeWrapCoord) {
- if (geojson === null)
- return;
- var j, k, l, geometry2, stopG, coords, geometryMaybeCollection, wrapShrink = 0, coordIndex = 0, isGeometryCollection, type2 = geojson.type, isFeatureCollection = type2 === "FeatureCollection", isFeature = type2 === "Feature", stop = isFeatureCollection ? geojson.features.length : 1;
- for (var featureIndex = 0; featureIndex < stop; featureIndex++) {
- geometryMaybeCollection = isFeatureCollection ? geojson.features[featureIndex].geometry : isFeature ? geojson.geometry : geojson;
- isGeometryCollection = geometryMaybeCollection ? geometryMaybeCollection.type === "GeometryCollection" : false;
- stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;
- for (var geomIndex = 0; geomIndex < stopG; geomIndex++) {
- var multiFeatureIndex = 0;
- var geometryIndex = 0;
- geometry2 = isGeometryCollection ? geometryMaybeCollection.geometries[geomIndex] : geometryMaybeCollection;
- if (geometry2 === null)
- continue;
- coords = geometry2.coordinates;
- var geomType = geometry2.type;
- wrapShrink = excludeWrapCoord && (geomType === "Polygon" || geomType === "MultiPolygon") ? 1 : 0;
- switch (geomType) {
- case null:
- break;
- case "Point":
- if (callback2(
- coords,
- coordIndex,
- featureIndex,
- multiFeatureIndex,
- geometryIndex
- ) === false)
- return false;
- coordIndex++;
- multiFeatureIndex++;
- break;
- case "LineString":
- case "MultiPoint":
- for (j = 0; j < coords.length; j++) {
- if (callback2(
- coords[j],
- coordIndex,
- featureIndex,
- multiFeatureIndex,
- geometryIndex
- ) === false)
- return false;
- coordIndex++;
- if (geomType === "MultiPoint")
- multiFeatureIndex++;
- }
- if (geomType === "LineString")
- multiFeatureIndex++;
- break;
- case "Polygon":
- case "MultiLineString":
- for (j = 0; j < coords.length; j++) {
- for (k = 0; k < coords[j].length - wrapShrink; k++) {
- if (callback2(
- coords[j][k],
- coordIndex,
- featureIndex,
- multiFeatureIndex,
- geometryIndex
- ) === false)
- return false;
- coordIndex++;
- }
- if (geomType === "MultiLineString")
- multiFeatureIndex++;
- if (geomType === "Polygon")
- geometryIndex++;
- }
- if (geomType === "Polygon")
- multiFeatureIndex++;
- break;
- case "MultiPolygon":
- for (j = 0; j < coords.length; j++) {
- geometryIndex = 0;
- for (k = 0; k < coords[j].length; k++) {
- for (l = 0; l < coords[j][k].length - wrapShrink; l++) {
- if (callback2(
- coords[j][k][l],
- coordIndex,
- featureIndex,
- multiFeatureIndex,
- geometryIndex
- ) === false)
- return false;
- coordIndex++;
- }
- geometryIndex++;
- }
- multiFeatureIndex++;
- }
- break;
- case "GeometryCollection":
- for (j = 0; j < geometry2.geometries.length; j++)
- if (coordEach(geometry2.geometries[j], callback2, excludeWrapCoord) === false)
- return false;
- break;
- default:
- throw new Error("Unknown Geometry Type");
- }
- }
- }
- }
- function coordReduce(geojson, callback2, initialValue, excludeWrapCoord) {
- var previousValue = initialValue;
- coordEach(
- geojson,
- function(currentCoord, coordIndex, featureIndex, multiFeatureIndex, geometryIndex) {
- if (coordIndex === 0 && initialValue === void 0)
- previousValue = currentCoord;
- else
- previousValue = callback2(
- previousValue,
- currentCoord,
- coordIndex,
- featureIndex,
- multiFeatureIndex,
- geometryIndex
- );
- },
- excludeWrapCoord
- );
- return previousValue;
- }
- function propEach(geojson, callback2) {
- var i2;
- switch (geojson.type) {
- case "FeatureCollection":
- for (i2 = 0; i2 < geojson.features.length; i2++) {
- if (callback2(geojson.features[i2].properties, i2) === false)
- break;
- }
- break;
- case "Feature":
- callback2(geojson.properties, 0);
- break;
- }
- }
- function propReduce(geojson, callback2, initialValue) {
- var previousValue = initialValue;
- propEach(geojson, function(currentProperties, featureIndex) {
- if (featureIndex === 0 && initialValue === void 0)
- previousValue = currentProperties;
- else
- previousValue = callback2(previousValue, currentProperties, featureIndex);
- });
- return previousValue;
- }
- function featureEach$1(geojson, callback2) {
- if (geojson.type === "Feature") {
- callback2(geojson, 0);
- } else if (geojson.type === "FeatureCollection") {
- for (var i2 = 0; i2 < geojson.features.length; i2++) {
- if (callback2(geojson.features[i2], i2) === false)
- break;
- }
- }
- }
- function featureReduce(geojson, callback2, initialValue) {
- var previousValue = initialValue;
- featureEach$1(geojson, function(currentFeature, featureIndex) {
- if (featureIndex === 0 && initialValue === void 0)
- previousValue = currentFeature;
- else
- previousValue = callback2(previousValue, currentFeature, featureIndex);
- });
- return previousValue;
- }
- function coordAll(geojson) {
- var coords = [];
- coordEach(geojson, function(coord) {
- coords.push(coord);
- });
- return coords;
- }
- function geomEach(geojson, callback2) {
- var i2, j, g, geometry2, stopG, geometryMaybeCollection, isGeometryCollection, featureProperties, featureBBox, featureId, featureIndex = 0, isFeatureCollection = geojson.type === "FeatureCollection", isFeature = geojson.type === "Feature", stop = isFeatureCollection ? geojson.features.length : 1;
- for (i2 = 0; i2 < stop; i2++) {
- geometryMaybeCollection = isFeatureCollection ? geojson.features[i2].geometry : isFeature ? geojson.geometry : geojson;
- featureProperties = isFeatureCollection ? geojson.features[i2].properties : isFeature ? geojson.properties : {};
- featureBBox = isFeatureCollection ? geojson.features[i2].bbox : isFeature ? geojson.bbox : void 0;
- featureId = isFeatureCollection ? geojson.features[i2].id : isFeature ? geojson.id : void 0;
- isGeometryCollection = geometryMaybeCollection ? geometryMaybeCollection.type === "GeometryCollection" : false;
- stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;
- for (g = 0; g < stopG; g++) {
- geometry2 = isGeometryCollection ? geometryMaybeCollection.geometries[g] : geometryMaybeCollection;
- if (geometry2 === null) {
- if (callback2(
- null,
- featureIndex,
- featureProperties,
- featureBBox,
- featureId
- ) === false)
- return false;
- continue;
- }
- switch (geometry2.type) {
- case "Point":
- case "LineString":
- case "MultiPoint":
- case "Polygon":
- case "MultiLineString":
- case "MultiPolygon": {
- if (callback2(
- geometry2,
- featureIndex,
- featureProperties,
- featureBBox,
- featureId
- ) === false)
- return false;
- break;
- }
- case "GeometryCollection": {
- for (j = 0; j < geometry2.geometries.length; j++) {
- if (callback2(
- geometry2.geometries[j],
- featureIndex,
- featureProperties,
- featureBBox,
- featureId
- ) === false)
- return false;
- }
- break;
- }
- default:
- throw new Error("Unknown Geometry Type");
- }
- }
- featureIndex++;
- }
- }
- function geomReduce(geojson, callback2, initialValue) {
- var previousValue = initialValue;
- geomEach(
- geojson,
- function(currentGeometry, featureIndex, featureProperties, featureBBox, featureId) {
- if (featureIndex === 0 && initialValue === void 0)
- previousValue = currentGeometry;
- else
- previousValue = callback2(
- previousValue,
- currentGeometry,
- featureIndex,
- featureProperties,
- featureBBox,
- featureId
- );
- }
- );
- return previousValue;
- }
- function flattenEach(geojson, callback2) {
- geomEach(geojson, function(geometry2, featureIndex, properties, bbox2, id) {
- var type2 = geometry2 === null ? null : geometry2.type;
- switch (type2) {
- case null:
- case "Point":
- case "LineString":
- case "Polygon":
- if (callback2(
- feature(geometry2, properties, { bbox: bbox2, id }),
- featureIndex,
- 0
- ) === false)
- return false;
- return;
- }
- var geomType;
- switch (type2) {
- case "MultiPoint":
- geomType = "Point";
- break;
- case "MultiLineString":
- geomType = "LineString";
- break;
- case "MultiPolygon":
- geomType = "Polygon";
- break;
- }
- for (var multiFeatureIndex = 0; multiFeatureIndex < geometry2.coordinates.length; multiFeatureIndex++) {
- var coordinate = geometry2.coordinates[multiFeatureIndex];
- var geom = {
- type: geomType,
- coordinates: coordinate
- };
- if (callback2(feature(geom, properties), featureIndex, multiFeatureIndex) === false)
- return false;
- }
- });
- }
- function flattenReduce(geojson, callback2, initialValue) {
- var previousValue = initialValue;
- flattenEach(
- geojson,
- function(currentFeature, featureIndex, multiFeatureIndex) {
- if (featureIndex === 0 && multiFeatureIndex === 0 && initialValue === void 0)
- previousValue = currentFeature;
- else
- previousValue = callback2(
- previousValue,
- currentFeature,
- featureIndex,
- multiFeatureIndex
- );
- }
- );
- return previousValue;
- }
- function segmentEach(geojson, callback2) {
- flattenEach(geojson, function(feature2, featureIndex, multiFeatureIndex) {
- var segmentIndex = 0;
- if (!feature2.geometry)
- return;
- var type2 = feature2.geometry.type;
- if (type2 === "Point" || type2 === "MultiPoint")
- return;
- var previousCoords;
- var previousFeatureIndex = 0;
- var previousMultiIndex = 0;
- var prevGeomIndex = 0;
- if (coordEach(
- feature2,
- function(currentCoord, coordIndex, featureIndexCoord, multiPartIndexCoord, geometryIndex) {
- if (previousCoords === void 0 || featureIndex > previousFeatureIndex || multiPartIndexCoord > previousMultiIndex || geometryIndex > prevGeomIndex) {
- previousCoords = currentCoord;
- previousFeatureIndex = featureIndex;
- previousMultiIndex = multiPartIndexCoord;
- prevGeomIndex = geometryIndex;
- segmentIndex = 0;
- return;
- }
- var currentSegment = lineString(
- [previousCoords, currentCoord],
- feature2.properties
- );
- if (callback2(
- currentSegment,
- featureIndex,
- multiFeatureIndex,
- geometryIndex,
- segmentIndex
- ) === false)
- return false;
- segmentIndex++;
- previousCoords = currentCoord;
- }
- ) === false)
- return false;
- });
- }
- function segmentReduce(geojson, callback2, initialValue) {
- var previousValue = initialValue;
- var started = false;
- segmentEach(
- geojson,
- function(currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) {
- if (started === false && initialValue === void 0)
- previousValue = currentSegment;
- else
- previousValue = callback2(
- previousValue,
- currentSegment,
- featureIndex,
- multiFeatureIndex,
- geometryIndex,
- segmentIndex
- );
- started = true;
- }
- );
- return previousValue;
- }
- function lineEach(geojson, callback2) {
- if (!geojson)
- throw new Error("geojson is required");
- flattenEach(geojson, function(feature2, featureIndex, multiFeatureIndex) {
- if (feature2.geometry === null)
- return;
- var type2 = feature2.geometry.type;
- var coords = feature2.geometry.coordinates;
- switch (type2) {
- case "LineString":
- if (callback2(feature2, featureIndex, multiFeatureIndex, 0, 0) === false)
- return false;
- break;
- case "Polygon":
- for (var geometryIndex = 0; geometryIndex < coords.length; geometryIndex++) {
- if (callback2(
- lineString(coords[geometryIndex], feature2.properties),
- featureIndex,
- multiFeatureIndex,
- geometryIndex
- ) === false)
- return false;
- }
- break;
- }
- });
- }
- function lineReduce(geojson, callback2, initialValue) {
- var previousValue = initialValue;
- lineEach(
- geojson,
- function(currentLine, featureIndex, multiFeatureIndex, geometryIndex) {
- if (featureIndex === 0 && initialValue === void 0)
- previousValue = currentLine;
- else
- previousValue = callback2(
- previousValue,
- currentLine,
- featureIndex,
- multiFeatureIndex,
- geometryIndex
- );
- }
- );
- return previousValue;
- }
- function findSegment(geojson, options2) {
- options2 = options2 || {};
- if (!isObject$6(options2))
- throw new Error("options is invalid");
- var featureIndex = options2.featureIndex || 0;
- var multiFeatureIndex = options2.multiFeatureIndex || 0;
- var geometryIndex = options2.geometryIndex || 0;
- var segmentIndex = options2.segmentIndex || 0;
- var properties = options2.properties;
- var geometry2;
- switch (geojson.type) {
- case "FeatureCollection":
- if (featureIndex < 0)
- featureIndex = geojson.features.length + featureIndex;
- properties = properties || geojson.features[featureIndex].properties;
- geometry2 = geojson.features[featureIndex].geometry;
- break;
- case "Feature":
- properties = properties || geojson.properties;
- geometry2 = geojson.geometry;
- break;
- case "Point":
- case "MultiPoint":
- return null;
- case "LineString":
- case "Polygon":
- case "MultiLineString":
- case "MultiPolygon":
- geometry2 = geojson;
- break;
- default:
- throw new Error("geojson is invalid");
- }
- if (geometry2 === null)
- return null;
- var coords = geometry2.coordinates;
- switch (geometry2.type) {
- case "Point":
- case "MultiPoint":
- return null;
- case "LineString":
- if (segmentIndex < 0)
- segmentIndex = coords.length + segmentIndex - 1;
- return lineString(
- [coords[segmentIndex], coords[segmentIndex + 1]],
- properties,
- options2
- );
- case "Polygon":
- if (geometryIndex < 0)
- geometryIndex = coords.length + geometryIndex;
- if (segmentIndex < 0)
- segmentIndex = coords[geometryIndex].length + segmentIndex - 1;
- return lineString(
- [
- coords[geometryIndex][segmentIndex],
- coords[geometryIndex][segmentIndex + 1]
- ],
- properties,
- options2
- );
- case "MultiLineString":
- if (multiFeatureIndex < 0)
- multiFeatureIndex = coords.length + multiFeatureIndex;
- if (segmentIndex < 0)
- segmentIndex = coords[multiFeatureIndex].length + segmentIndex - 1;
- return lineString(
- [
- coords[multiFeatureIndex][segmentIndex],
- coords[multiFeatureIndex][segmentIndex + 1]
- ],
- properties,
- options2
- );
- case "MultiPolygon":
- if (multiFeatureIndex < 0)
- multiFeatureIndex = coords.length + multiFeatureIndex;
- if (geometryIndex < 0)
- geometryIndex = coords[multiFeatureIndex].length + geometryIndex;
- if (segmentIndex < 0)
- segmentIndex = coords[multiFeatureIndex][geometryIndex].length - segmentIndex - 1;
- return lineString(
- [
- coords[multiFeatureIndex][geometryIndex][segmentIndex],
- coords[multiFeatureIndex][geometryIndex][segmentIndex + 1]
- ],
- properties,
- options2
- );
- }
- throw new Error("geojson is invalid");
- }
- function findPoint(geojson, options2) {
- options2 = options2 || {};
- if (!isObject$6(options2))
- throw new Error("options is invalid");
- var featureIndex = options2.featureIndex || 0;
- var multiFeatureIndex = options2.multiFeatureIndex || 0;
- var geometryIndex = options2.geometryIndex || 0;
- var coordIndex = options2.coordIndex || 0;
- var properties = options2.properties;
- var geometry2;
- switch (geojson.type) {
- case "FeatureCollection":
- if (featureIndex < 0)
- featureIndex = geojson.features.length + featureIndex;
- properties = properties || geojson.features[featureIndex].properties;
- geometry2 = geojson.features[featureIndex].geometry;
- break;
- case "Feature":
- properties = properties || geojson.properties;
- geometry2 = geojson.geometry;
- break;
- case "Point":
- case "MultiPoint":
- return null;
- case "LineString":
- case "Polygon":
- case "MultiLineString":
- case "MultiPolygon":
- geometry2 = geojson;
- break;
- default:
- throw new Error("geojson is invalid");
- }
- if (geometry2 === null)
- return null;
- var coords = geometry2.coordinates;
- switch (geometry2.type) {
- case "Point":
- return point(coords, properties, options2);
- case "MultiPoint":
- if (multiFeatureIndex < 0)
- multiFeatureIndex = coords.length + multiFeatureIndex;
- return point(coords[multiFeatureIndex], properties, options2);
- case "LineString":
- if (coordIndex < 0)
- coordIndex = coords.length + coordIndex;
- return point(coords[coordIndex], properties, options2);
- case "Polygon":
- if (geometryIndex < 0)
- geometryIndex = coords.length + geometryIndex;
- if (coordIndex < 0)
- coordIndex = coords[geometryIndex].length + coordIndex;
- return point(coords[geometryIndex][coordIndex], properties, options2);
- case "MultiLineString":
- if (multiFeatureIndex < 0)
- multiFeatureIndex = coords.length + multiFeatureIndex;
- if (coordIndex < 0)
- coordIndex = coords[multiFeatureIndex].length + coordIndex;
- return point(coords[multiFeatureIndex][coordIndex], properties, options2);
- case "MultiPolygon":
- if (multiFeatureIndex < 0)
- multiFeatureIndex = coords.length + multiFeatureIndex;
- if (geometryIndex < 0)
- geometryIndex = coords[multiFeatureIndex].length + geometryIndex;
- if (coordIndex < 0)
- coordIndex = coords[multiFeatureIndex][geometryIndex].length - coordIndex;
- return point(
- coords[multiFeatureIndex][geometryIndex][coordIndex],
- properties,
- options2
- );
- }
- throw new Error("geojson is invalid");
- }
- var es$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
- __proto__: null,
- coordAll,
- coordEach,
- coordReduce,
- featureEach: featureEach$1,
- featureReduce,
- findPoint,
- findSegment,
- flattenEach,
- flattenReduce,
- geomEach,
- geomReduce,
- lineEach,
- lineReduce,
- propEach,
- propReduce,
- segmentEach,
- segmentReduce
- }, Symbol.toStringTag, { value: "Module" }));
- function bbox$1(geojson) {
- var result = [Infinity, Infinity, -Infinity, -Infinity];
- coordEach(geojson, function(coord) {
- if (result[0] > coord[0]) {
- result[0] = coord[0];
- }
- if (result[1] > coord[1]) {
- result[1] = coord[1];
- }
- if (result[2] < coord[0]) {
- result[2] = coord[0];
- }
- if (result[3] < coord[1]) {
- result[3] = coord[1];
- }
- });
- return result;
- }
- bbox$1["default"] = bbox$1;
- var es = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
- __proto__: null,
- "default": bbox$1
- }, Symbol.toStringTag, { value: "Module" }));
- function getCoord(coord) {
- if (!coord) {
- throw new Error("coord is required");
- }
- if (!Array.isArray(coord)) {
- if (coord.type === "Feature" && coord.geometry !== null && coord.geometry.type === "Point") {
- return coord.geometry.coordinates;
- }
- if (coord.type === "Point") {
- return coord.coordinates;
- }
- }
- if (Array.isArray(coord) && coord.length >= 2 && !Array.isArray(coord[0]) && !Array.isArray(coord[1])) {
- return coord;
- }
- throw new Error("coord must be GeoJSON Point or an Array of numbers");
- }
- function getCoords(coords) {
- if (Array.isArray(coords)) {
- return coords;
- }
- if (coords.type === "Feature") {
- if (coords.geometry !== null) {
- return coords.geometry.coordinates;
- }
- } else {
- if (coords.coordinates) {
- return coords.coordinates;
- }
- }
- throw new Error("coords must be GeoJSON Feature, Geometry Object or an Array");
- }
- function getGeom(geojson) {
- if (geojson.type === "Feature") {
- return geojson.geometry;
- }
- return geojson;
- }
- function getType(geojson, _name) {
- if (geojson.type === "FeatureCollection") {
- return "FeatureCollection";
- }
- if (geojson.type === "GeometryCollection") {
- return "GeometryCollection";
- }
- if (geojson.type === "Feature" && geojson.geometry !== null) {
- return geojson.geometry.type;
- }
- return geojson.type;
- }
- var commonjsGlobal = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
- function getDefaultExportFromCjs(x) {
- return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, "default") ? x["default"] : x;
- }
- function getAugmentedNamespace(n) {
- if (n.__esModule)
- return n;
- var a = Object.defineProperty({}, "__esModule", { value: true });
- Object.keys(n).forEach(function(k) {
- var d2 = Object.getOwnPropertyDescriptor(n, k);
- Object.defineProperty(a, k, d2.get ? d2 : {
- enumerable: true,
- get: function() {
- return n[k];
- }
- });
- });
- return a;
- }
- var concaveman$2 = { exports: {} };
- var rbush_min$1 = { exports: {} };
- (function(module2, exports2) {
- !function(t2, i2) {
- module2.exports = i2();
- }(commonjsGlobal, function() {
- function t2(t3, r3, e2, a2, h3) {
- !function t4(n2, r4, e3, a3, h4) {
- for (; a3 > e3; ) {
- if (a3 - e3 > 600) {
- var o2 = a3 - e3 + 1, s2 = r4 - e3 + 1, l2 = Math.log(o2), f2 = 0.5 * Math.exp(2 * l2 / 3), u2 = 0.5 * Math.sqrt(l2 * f2 * (o2 - f2) / o2) * (s2 - o2 / 2 < 0 ? -1 : 1), m2 = Math.max(e3, Math.floor(r4 - s2 * f2 / o2 + u2)), c2 = Math.min(a3, Math.floor(r4 + (o2 - s2) * f2 / o2 + u2));
- t4(n2, r4, m2, c2, h4);
- }
- var p2 = n2[r4], d3 = e3, x = a3;
- for (i2(n2, e3, r4), h4(n2[a3], p2) > 0 && i2(n2, e3, a3); d3 < x; ) {
- for (i2(n2, d3, x), d3++, x--; h4(n2[d3], p2) < 0; )
- d3++;
- for (; h4(n2[x], p2) > 0; )
- x--;
- }
- 0 === h4(n2[e3], p2) ? i2(n2, e3, x) : i2(n2, ++x, a3), x <= r4 && (e3 = x + 1), r4 <= x && (a3 = x - 1);
- }
- }(t3, r3, e2 || 0, a2 || t3.length - 1, h3 || n);
- }
- function i2(t3, i3, n2) {
- var r3 = t3[i3];
- t3[i3] = t3[n2], t3[n2] = r3;
- }
- function n(t3, i3) {
- return t3 < i3 ? -1 : t3 > i3 ? 1 : 0;
- }
- var r2 = function(t3) {
- void 0 === t3 && (t3 = 9), this._maxEntries = Math.max(4, t3), this._minEntries = Math.max(2, Math.ceil(0.4 * this._maxEntries)), this.clear();
- };
- function e(t3, i3, n2) {
- if (!n2)
- return i3.indexOf(t3);
- for (var r3 = 0; r3 < i3.length; r3++)
- if (n2(t3, i3[r3]))
- return r3;
- return -1;
- }
- function a(t3, i3) {
- h2(t3, 0, t3.children.length, i3, t3);
- }
- function h2(t3, i3, n2, r3, e2) {
- e2 || (e2 = p(null)), e2.minX = 1 / 0, e2.minY = 1 / 0, e2.maxX = -1 / 0, e2.maxY = -1 / 0;
- for (var a2 = i3; a2 < n2; a2++) {
- var h3 = t3.children[a2];
- o(e2, t3.leaf ? r3(h3) : h3);
- }
- return e2;
- }
- function o(t3, i3) {
- return t3.minX = Math.min(t3.minX, i3.minX), t3.minY = Math.min(t3.minY, i3.minY), t3.maxX = Math.max(t3.maxX, i3.maxX), t3.maxY = Math.max(t3.maxY, i3.maxY), t3;
- }
- function s(t3, i3) {
- return t3.minX - i3.minX;
- }
- function l(t3, i3) {
- return t3.minY - i3.minY;
- }
- function f(t3) {
- return (t3.maxX - t3.minX) * (t3.maxY - t3.minY);
- }
- function u(t3) {
- return t3.maxX - t3.minX + (t3.maxY - t3.minY);
- }
- function m(t3, i3) {
- return t3.minX <= i3.minX && t3.minY <= i3.minY && i3.maxX <= t3.maxX && i3.maxY <= t3.maxY;
- }
- function c(t3, i3) {
- return i3.minX <= t3.maxX && i3.minY <= t3.maxY && i3.maxX >= t3.minX && i3.maxY >= t3.minY;
- }
- function p(t3) {
- return { children: t3, height: 1, leaf: true, minX: 1 / 0, minY: 1 / 0, maxX: -1 / 0, maxY: -1 / 0 };
- }
- function d2(i3, n2, r3, e2, a2) {
- for (var h3 = [n2, r3]; h3.length; )
- if (!((r3 = h3.pop()) - (n2 = h3.pop()) <= e2)) {
- var o2 = n2 + Math.ceil((r3 - n2) / e2 / 2) * e2;
- t2(i3, o2, n2, r3, a2), h3.push(n2, o2, o2, r3);
- }
- }
- return r2.prototype.all = function() {
- return this._all(this.data, []);
- }, r2.prototype.search = function(t3) {
- var i3 = this.data, n2 = [];
- if (!c(t3, i3))
- return n2;
- for (var r3 = this.toBBox, e2 = []; i3; ) {
- for (var a2 = 0; a2 < i3.children.length; a2++) {
- var h3 = i3.children[a2], o2 = i3.leaf ? r3(h3) : h3;
- c(t3, o2) && (i3.leaf ? n2.push(h3) : m(t3, o2) ? this._all(h3, n2) : e2.push(h3));
- }
- i3 = e2.pop();
- }
- return n2;
- }, r2.prototype.collides = function(t3) {
- var i3 = this.data;
- if (!c(t3, i3))
- return false;
- for (var n2 = []; i3; ) {
- for (var r3 = 0; r3 < i3.children.length; r3++) {
- var e2 = i3.children[r3], a2 = i3.leaf ? this.toBBox(e2) : e2;
- if (c(t3, a2)) {
- if (i3.leaf || m(t3, a2))
- return true;
- n2.push(e2);
- }
- }
- i3 = n2.pop();
- }
- return false;
- }, r2.prototype.load = function(t3) {
- if (!t3 || !t3.length)
- return this;
- if (t3.length < this._minEntries) {
- for (var i3 = 0; i3 < t3.length; i3++)
- this.insert(t3[i3]);
- return this;
- }
- var n2 = this._build(t3.slice(), 0, t3.length - 1, 0);
- if (this.data.children.length)
- if (this.data.height === n2.height)
- this._splitRoot(this.data, n2);
- else {
- if (this.data.height < n2.height) {
- var r3 = this.data;
- this.data = n2, n2 = r3;
- }
- this._insert(n2, this.data.height - n2.height - 1, true);
- }
- else
- this.data = n2;
- return this;
- }, r2.prototype.insert = function(t3) {
- return t3 && this._insert(t3, this.data.height - 1), this;
- }, r2.prototype.clear = function() {
- return this.data = p([]), this;
- }, r2.prototype.remove = function(t3, i3) {
- if (!t3)
- return this;
- for (var n2, r3, a2, h3 = this.data, o2 = this.toBBox(t3), s2 = [], l2 = []; h3 || s2.length; ) {
- if (h3 || (h3 = s2.pop(), r3 = s2[s2.length - 1], n2 = l2.pop(), a2 = true), h3.leaf) {
- var f2 = e(t3, h3.children, i3);
- if (-1 !== f2)
- return h3.children.splice(f2, 1), s2.push(h3), this._condense(s2), this;
- }
- a2 || h3.leaf || !m(h3, o2) ? r3 ? (n2++, h3 = r3.children[n2], a2 = false) : h3 = null : (s2.push(h3), l2.push(n2), n2 = 0, r3 = h3, h3 = h3.children[0]);
- }
- return this;
- }, r2.prototype.toBBox = function(t3) {
- return t3;
- }, r2.prototype.compareMinX = function(t3, i3) {
- return t3.minX - i3.minX;
- }, r2.prototype.compareMinY = function(t3, i3) {
- return t3.minY - i3.minY;
- }, r2.prototype.toJSON = function() {
- return this.data;
- }, r2.prototype.fromJSON = function(t3) {
- return this.data = t3, this;
- }, r2.prototype._all = function(t3, i3) {
- for (var n2 = []; t3; )
- t3.leaf ? i3.push.apply(i3, t3.children) : n2.push.apply(n2, t3.children), t3 = n2.pop();
- return i3;
- }, r2.prototype._build = function(t3, i3, n2, r3) {
- var e2, h3 = n2 - i3 + 1, o2 = this._maxEntries;
- if (h3 <= o2)
- return a(e2 = p(t3.slice(i3, n2 + 1)), this.toBBox), e2;
- r3 || (r3 = Math.ceil(Math.log(h3) / Math.log(o2)), o2 = Math.ceil(h3 / Math.pow(o2, r3 - 1))), (e2 = p([])).leaf = false, e2.height = r3;
- var s2 = Math.ceil(h3 / o2), l2 = s2 * Math.ceil(Math.sqrt(o2));
- d2(t3, i3, n2, l2, this.compareMinX);
- for (var f2 = i3; f2 <= n2; f2 += l2) {
- var u2 = Math.min(f2 + l2 - 1, n2);
- d2(t3, f2, u2, s2, this.compareMinY);
- for (var m2 = f2; m2 <= u2; m2 += s2) {
- var c2 = Math.min(m2 + s2 - 1, u2);
- e2.children.push(this._build(t3, m2, c2, r3 - 1));
- }
- }
- return a(e2, this.toBBox), e2;
- }, r2.prototype._chooseSubtree = function(t3, i3, n2, r3) {
- for (; r3.push(i3), !i3.leaf && r3.length - 1 !== n2; ) {
- for (var e2 = 1 / 0, a2 = 1 / 0, h3 = void 0, o2 = 0; o2 < i3.children.length; o2++) {
- var s2 = i3.children[o2], l2 = f(s2), u2 = (m2 = t3, c2 = s2, (Math.max(c2.maxX, m2.maxX) - Math.min(c2.minX, m2.minX)) * (Math.max(c2.maxY, m2.maxY) - Math.min(c2.minY, m2.minY)) - l2);
- u2 < a2 ? (a2 = u2, e2 = l2 < e2 ? l2 : e2, h3 = s2) : u2 === a2 && l2 < e2 && (e2 = l2, h3 = s2);
- }
- i3 = h3 || i3.children[0];
- }
- var m2, c2;
- return i3;
- }, r2.prototype._insert = function(t3, i3, n2) {
- var r3 = n2 ? t3 : this.toBBox(t3), e2 = [], a2 = this._chooseSubtree(r3, this.data, i3, e2);
- for (a2.children.push(t3), o(a2, r3); i3 >= 0 && e2[i3].children.length > this._maxEntries; )
- this._split(e2, i3), i3--;
- this._adjustParentBBoxes(r3, e2, i3);
- }, r2.prototype._split = function(t3, i3) {
- var n2 = t3[i3], r3 = n2.children.length, e2 = this._minEntries;
- this._chooseSplitAxis(n2, e2, r3);
- var h3 = this._chooseSplitIndex(n2, e2, r3), o2 = p(n2.children.splice(h3, n2.children.length - h3));
- o2.height = n2.height, o2.leaf = n2.leaf, a(n2, this.toBBox), a(o2, this.toBBox), i3 ? t3[i3 - 1].children.push(o2) : this._splitRoot(n2, o2);
- }, r2.prototype._splitRoot = function(t3, i3) {
- this.data = p([t3, i3]), this.data.height = t3.height + 1, this.data.leaf = false, a(this.data, this.toBBox);
- }, r2.prototype._chooseSplitIndex = function(t3, i3, n2) {
- for (var r3, e2, a2, o2, s2, l2, u2, m2 = 1 / 0, c2 = 1 / 0, p2 = i3; p2 <= n2 - i3; p2++) {
- var d3 = h2(t3, 0, p2, this.toBBox), x = h2(t3, p2, n2, this.toBBox), v = (e2 = d3, a2 = x, o2 = void 0, s2 = void 0, l2 = void 0, u2 = void 0, o2 = Math.max(e2.minX, a2.minX), s2 = Math.max(e2.minY, a2.minY), l2 = Math.min(e2.maxX, a2.maxX), u2 = Math.min(e2.maxY, a2.maxY), Math.max(0, l2 - o2) * Math.max(0, u2 - s2)), M = f(d3) + f(x);
- v < m2 ? (m2 = v, r3 = p2, c2 = M < c2 ? M : c2) : v === m2 && M < c2 && (c2 = M, r3 = p2);
- }
- return r3 || n2 - i3;
- }, r2.prototype._chooseSplitAxis = function(t3, i3, n2) {
- var r3 = t3.leaf ? this.compareMinX : s, e2 = t3.leaf ? this.compareMinY : l;
- this._allDistMargin(t3, i3, n2, r3) < this._allDistMargin(t3, i3, n2, e2) && t3.children.sort(r3);
- }, r2.prototype._allDistMargin = function(t3, i3, n2, r3) {
- t3.children.sort(r3);
- for (var e2 = this.toBBox, a2 = h2(t3, 0, i3, e2), s2 = h2(t3, n2 - i3, n2, e2), l2 = u(a2) + u(s2), f2 = i3; f2 < n2 - i3; f2++) {
- var m2 = t3.children[f2];
- o(a2, t3.leaf ? e2(m2) : m2), l2 += u(a2);
- }
- for (var c2 = n2 - i3 - 1; c2 >= i3; c2--) {
- var p2 = t3.children[c2];
- o(s2, t3.leaf ? e2(p2) : p2), l2 += u(s2);
- }
- return l2;
- }, r2.prototype._adjustParentBBoxes = function(t3, i3, n2) {
- for (var r3 = n2; r3 >= 0; r3--)
- o(i3[r3], t3);
- }, r2.prototype._condense = function(t3) {
- for (var i3 = t3.length - 1, n2 = void 0; i3 >= 0; i3--)
- 0 === t3[i3].children.length ? i3 > 0 ? (n2 = t3[i3 - 1].children).splice(n2.indexOf(t3[i3]), 1) : this.clear() : a(t3[i3], this.toBBox);
- }, r2;
- });
- })(rbush_min$1);
- class TinyQueue {
- constructor(data = [], compare = defaultCompare) {
- this.data = data;
- this.length = this.data.length;
- this.compare = compare;
- if (this.length > 0) {
- for (let i2 = (this.length >> 1) - 1; i2 >= 0; i2--)
- this._down(i2);
- }
- }
- push(item) {
- this.data.push(item);
- this.length++;
- this._up(this.length - 1);
- }
- pop() {
- if (this.length === 0)
- return void 0;
- const top = this.data[0];
- const bottom = this.data.pop();
- this.length--;
- if (this.length > 0) {
- this.data[0] = bottom;
- this._down(0);
- }
- return top;
- }
- peek() {
- return this.data[0];
- }
- _up(pos) {
- const { data, compare } = this;
- const item = data[pos];
- while (pos > 0) {
- const parent = pos - 1 >> 1;
- const current = data[parent];
- if (compare(item, current) >= 0)
- break;
- data[pos] = current;
- pos = parent;
- }
- data[pos] = item;
- }
- _down(pos) {
- const { data, compare } = this;
- const halfLength = this.length >> 1;
- const item = data[pos];
- while (pos < halfLength) {
- let left = (pos << 1) + 1;
- let best = data[left];
- const right = left + 1;
- if (right < this.length && compare(data[right], best) < 0) {
- left = right;
- best = data[right];
- }
- if (compare(best, item) >= 0)
- break;
- data[pos] = best;
- pos = left;
- }
- data[pos] = item;
- }
- }
- function defaultCompare(a, b) {
- return a < b ? -1 : a > b ? 1 : 0;
- }
- var tinyqueue = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
- __proto__: null,
- "default": TinyQueue
- }, Symbol.toStringTag, { value: "Module" }));
- var require$$1$2 = /* @__PURE__ */ getAugmentedNamespace(tinyqueue);
- var pointInPolygon$1 = { exports: {} };
- var flat = function pointInPolygonFlat(point2, vs, start2, end) {
- var x = point2[0], y = point2[1];
- var inside2 = false;
- if (start2 === void 0)
- start2 = 0;
- if (end === void 0)
- end = vs.length;
- var len = (end - start2) / 2;
- for (var i2 = 0, j = len - 1; i2 < len; j = i2++) {
- var xi = vs[start2 + i2 * 2 + 0], yi = vs[start2 + i2 * 2 + 1];
- var xj = vs[start2 + j * 2 + 0], yj = vs[start2 + j * 2 + 1];
- var intersect = yi > y !== yj > y && x < (xj - xi) * (y - yi) / (yj - yi) + xi;
- if (intersect)
- inside2 = !inside2;
- }
- return inside2;
- };
- var nested = function pointInPolygonNested(point2, vs, start2, end) {
- var x = point2[0], y = point2[1];
- var inside2 = false;
- if (start2 === void 0)
- start2 = 0;
- if (end === void 0)
- end = vs.length;
- var len = end - start2;
- for (var i2 = 0, j = len - 1; i2 < len; j = i2++) {
- var xi = vs[i2 + start2][0], yi = vs[i2 + start2][1];
- var xj = vs[j + start2][0], yj = vs[j + start2][1];
- var intersect = yi > y !== yj > y && x < (xj - xi) * (y - yi) / (yj - yi) + xi;
- if (intersect)
- inside2 = !inside2;
- }
- return inside2;
- };
- var pointInPolygonFlat2 = flat;
- var pointInPolygonNested2 = nested;
- pointInPolygon$1.exports = function pointInPolygon(point2, vs, start2, end) {
- if (vs.length > 0 && Array.isArray(vs[0])) {
- return pointInPolygonNested2(point2, vs, start2, end);
- } else {
- return pointInPolygonFlat2(point2, vs, start2, end);
- }
- };
- pointInPolygon$1.exports.nested = pointInPolygonNested2;
- pointInPolygon$1.exports.flat = pointInPolygonFlat2;
- var orient2d_min = { exports: {} };
- (function(module2, exports2) {
- !function(t2, e) {
- e(exports2);
- }(commonjsGlobal, function(t2) {
- const e = 134217729, n = 33306690738754706e-32;
- function r2(t3, e2, n2, r3, o2) {
- let f2, i3, u2, c2, s2 = e2[0], a2 = r3[0], d3 = 0, l2 = 0;
- a2 > s2 == a2 > -s2 ? (f2 = s2, s2 = e2[++d3]) : (f2 = a2, a2 = r3[++l2]);
- let p = 0;
- if (d3 < t3 && l2 < n2)
- for (a2 > s2 == a2 > -s2 ? (u2 = f2 - ((i3 = s2 + f2) - s2), s2 = e2[++d3]) : (u2 = f2 - ((i3 = a2 + f2) - a2), a2 = r3[++l2]), f2 = i3, 0 !== u2 && (o2[p++] = u2); d3 < t3 && l2 < n2; )
- a2 > s2 == a2 > -s2 ? (u2 = f2 - ((i3 = f2 + s2) - (c2 = i3 - f2)) + (s2 - c2), s2 = e2[++d3]) : (u2 = f2 - ((i3 = f2 + a2) - (c2 = i3 - f2)) + (a2 - c2), a2 = r3[++l2]), f2 = i3, 0 !== u2 && (o2[p++] = u2);
- for (; d3 < t3; )
- u2 = f2 - ((i3 = f2 + s2) - (c2 = i3 - f2)) + (s2 - c2), s2 = e2[++d3], f2 = i3, 0 !== u2 && (o2[p++] = u2);
- for (; l2 < n2; )
- u2 = f2 - ((i3 = f2 + a2) - (c2 = i3 - f2)) + (a2 - c2), a2 = r3[++l2], f2 = i3, 0 !== u2 && (o2[p++] = u2);
- return 0 === f2 && 0 !== p || (o2[p++] = f2), p;
- }
- function o(t3) {
- return new Float64Array(t3);
- }
- const f = 33306690738754716e-32, i2 = 22204460492503146e-32, u = 11093356479670487e-47, c = o(4), s = o(8), a = o(12), d2 = o(16), l = o(4);
- t2.orient2d = function(t3, o2, p, b, y, h2) {
- const M = (o2 - h2) * (p - y), x = (t3 - y) * (b - h2), j = M - x;
- if (0 === M || 0 === x || M > 0 != x > 0)
- return j;
- const m = Math.abs(M + x);
- return Math.abs(j) >= f * m ? j : -function(t4, o3, f2, p2, b2, y2, h3) {
- let M2, x2, j2, m2, _, v, w, A, F, O, P2, g, k, q2, z, B2, C2, D;
- const E2 = t4 - b2, G2 = f2 - b2, H2 = o3 - y2, I2 = p2 - y2;
- _ = (z = (A = E2 - (w = (v = e * E2) - (v - E2))) * (O = I2 - (F = (v = e * I2) - (v - I2))) - ((q2 = E2 * I2) - w * F - A * F - w * O)) - (P2 = z - (C2 = (A = H2 - (w = (v = e * H2) - (v - H2))) * (O = G2 - (F = (v = e * G2) - (v - G2))) - ((B2 = H2 * G2) - w * F - A * F - w * O))), c[0] = z - (P2 + _) + (_ - C2), _ = (k = q2 - ((g = q2 + P2) - (_ = g - q2)) + (P2 - _)) - (P2 = k - B2), c[1] = k - (P2 + _) + (_ - B2), _ = (D = g + P2) - g, c[2] = g - (D - _) + (P2 - _), c[3] = D;
- let J2 = function(t5, e2) {
- let n2 = e2[0];
- for (let r3 = 1; r3 < t5; r3++)
- n2 += e2[r3];
- return n2;
- }(4, c), K2 = i2 * h3;
- if (J2 >= K2 || -J2 >= K2)
- return J2;
- if (M2 = t4 - (E2 + (_ = t4 - E2)) + (_ - b2), j2 = f2 - (G2 + (_ = f2 - G2)) + (_ - b2), x2 = o3 - (H2 + (_ = o3 - H2)) + (_ - y2), m2 = p2 - (I2 + (_ = p2 - I2)) + (_ - y2), 0 === M2 && 0 === x2 && 0 === j2 && 0 === m2)
- return J2;
- if (K2 = u * h3 + n * Math.abs(J2), (J2 += E2 * m2 + I2 * M2 - (H2 * j2 + G2 * x2)) >= K2 || -J2 >= K2)
- return J2;
- _ = (z = (A = M2 - (w = (v = e * M2) - (v - M2))) * (O = I2 - (F = (v = e * I2) - (v - I2))) - ((q2 = M2 * I2) - w * F - A * F - w * O)) - (P2 = z - (C2 = (A = x2 - (w = (v = e * x2) - (v - x2))) * (O = G2 - (F = (v = e * G2) - (v - G2))) - ((B2 = x2 * G2) - w * F - A * F - w * O))), l[0] = z - (P2 + _) + (_ - C2), _ = (k = q2 - ((g = q2 + P2) - (_ = g - q2)) + (P2 - _)) - (P2 = k - B2), l[1] = k - (P2 + _) + (_ - B2), _ = (D = g + P2) - g, l[2] = g - (D - _) + (P2 - _), l[3] = D;
- const L = r2(4, c, 4, l, s);
- _ = (z = (A = E2 - (w = (v = e * E2) - (v - E2))) * (O = m2 - (F = (v = e * m2) - (v - m2))) - ((q2 = E2 * m2) - w * F - A * F - w * O)) - (P2 = z - (C2 = (A = H2 - (w = (v = e * H2) - (v - H2))) * (O = j2 - (F = (v = e * j2) - (v - j2))) - ((B2 = H2 * j2) - w * F - A * F - w * O))), l[0] = z - (P2 + _) + (_ - C2), _ = (k = q2 - ((g = q2 + P2) - (_ = g - q2)) + (P2 - _)) - (P2 = k - B2), l[1] = k - (P2 + _) + (_ - B2), _ = (D = g + P2) - g, l[2] = g - (D - _) + (P2 - _), l[3] = D;
- const N2 = r2(L, s, 4, l, a);
- _ = (z = (A = M2 - (w = (v = e * M2) - (v - M2))) * (O = m2 - (F = (v = e * m2) - (v - m2))) - ((q2 = M2 * m2) - w * F - A * F - w * O)) - (P2 = z - (C2 = (A = x2 - (w = (v = e * x2) - (v - x2))) * (O = j2 - (F = (v = e * j2) - (v - j2))) - ((B2 = x2 * j2) - w * F - A * F - w * O))), l[0] = z - (P2 + _) + (_ - C2), _ = (k = q2 - ((g = q2 + P2) - (_ = g - q2)) + (P2 - _)) - (P2 = k - B2), l[1] = k - (P2 + _) + (_ - B2), _ = (D = g + P2) - g, l[2] = g - (D - _) + (P2 - _), l[3] = D;
- const Q2 = r2(N2, a, 4, l, d2);
- return d2[Q2 - 1];
- }(t3, o2, p, b, y, h2, m);
- }, t2.orient2dfast = function(t3, e2, n2, r3, o2, f2) {
- return (e2 - f2) * (n2 - o2) - (t3 - o2) * (r3 - f2);
- }, Object.defineProperty(t2, "__esModule", { value: true });
- });
- })(orient2d_min, orient2d_min.exports);
- var RBush = rbush_min$1.exports;
- var Queue = require$$1$2;
- var pointInPolygon2 = pointInPolygon$1.exports;
- var orient = orient2d_min.exports.orient2d;
- if (Queue.default) {
- Queue = Queue.default;
- }
- concaveman$2.exports = concaveman;
- concaveman$2.exports.default = concaveman;
- function concaveman(points2, concavity, lengthThreshold) {
- concavity = Math.max(0, concavity === void 0 ? 2 : concavity);
- lengthThreshold = lengthThreshold || 0;
- var hull = fastConvexHull(points2);
- var tree = new RBush(16);
- tree.toBBox = function(a2) {
- return {
- minX: a2[0],
- minY: a2[1],
- maxX: a2[0],
- maxY: a2[1]
- };
- };
- tree.compareMinX = function(a2, b2) {
- return a2[0] - b2[0];
- };
- tree.compareMinY = function(a2, b2) {
- return a2[1] - b2[1];
- };
- tree.load(points2);
- var queue = [];
- for (var i2 = 0, last; i2 < hull.length; i2++) {
- var p = hull[i2];
- tree.remove(p);
- last = insertNode(p, last);
- queue.push(last);
- }
- var segTree = new RBush(16);
- for (i2 = 0; i2 < queue.length; i2++)
- segTree.insert(updateBBox(queue[i2]));
- var sqConcavity = concavity * concavity;
- var sqLenThreshold = lengthThreshold * lengthThreshold;
- while (queue.length) {
- var node = queue.shift();
- var a = node.p;
- var b = node.next.p;
- var sqLen = getSqDist(a, b);
- if (sqLen < sqLenThreshold)
- continue;
- var maxSqLen = sqLen / sqConcavity;
- p = findCandidate(tree, node.prev.p, a, b, node.next.next.p, maxSqLen, segTree);
- if (p && Math.min(getSqDist(p, a), getSqDist(p, b)) <= maxSqLen) {
- queue.push(node);
- queue.push(insertNode(p, node));
- tree.remove(p);
- segTree.remove(node);
- segTree.insert(updateBBox(node));
- segTree.insert(updateBBox(node.next));
- }
- }
- node = last;
- var concave = [];
- do {
- concave.push(node.p);
- node = node.next;
- } while (node !== last);
- concave.push(node.p);
- return concave;
- }
- function findCandidate(tree, a, b, c, d2, maxDist, segTree) {
- var queue = new Queue([], compareDist);
- var node = tree.data;
- while (node) {
- for (var i2 = 0; i2 < node.children.length; i2++) {
- var child = node.children[i2];
- var dist = node.leaf ? sqSegDist(child, b, c) : sqSegBoxDist(b, c, child);
- if (dist > maxDist)
- continue;
- queue.push({
- node: child,
- dist
- });
- }
- while (queue.length && !queue.peek().node.children) {
- var item = queue.pop();
- var p = item.node;
- var d0 = sqSegDist(p, a, b);
- var d1 = sqSegDist(p, c, d2);
- if (item.dist < d0 && item.dist < d1 && noIntersections(b, p, segTree) && noIntersections(c, p, segTree))
- return p;
- }
- node = queue.pop();
- if (node)
- node = node.node;
- }
- return null;
- }
- function compareDist(a, b) {
- return a.dist - b.dist;
- }
- function sqSegBoxDist(a, b, bbox2) {
- if (inside(a, bbox2) || inside(b, bbox2))
- return 0;
- var d1 = sqSegSegDist(a[0], a[1], b[0], b[1], bbox2.minX, bbox2.minY, bbox2.maxX, bbox2.minY);
- if (d1 === 0)
- return 0;
- var d2 = sqSegSegDist(a[0], a[1], b[0], b[1], bbox2.minX, bbox2.minY, bbox2.minX, bbox2.maxY);
- if (d2 === 0)
- return 0;
- var d3 = sqSegSegDist(a[0], a[1], b[0], b[1], bbox2.maxX, bbox2.minY, bbox2.maxX, bbox2.maxY);
- if (d3 === 0)
- return 0;
- var d4 = sqSegSegDist(a[0], a[1], b[0], b[1], bbox2.minX, bbox2.maxY, bbox2.maxX, bbox2.maxY);
- if (d4 === 0)
- return 0;
- return Math.min(d1, d2, d3, d4);
- }
- function inside(a, bbox2) {
- return a[0] >= bbox2.minX && a[0] <= bbox2.maxX && a[1] >= bbox2.minY && a[1] <= bbox2.maxY;
- }
- function noIntersections(a, b, segTree) {
- var minX = Math.min(a[0], b[0]);
- var minY = Math.min(a[1], b[1]);
- var maxX = Math.max(a[0], b[0]);
- var maxY = Math.max(a[1], b[1]);
- var edges = segTree.search({ minX, minY, maxX, maxY });
- for (var i2 = 0; i2 < edges.length; i2++) {
- if (intersects$1(edges[i2].p, edges[i2].next.p, a, b))
- return false;
- }
- return true;
- }
- function cross(p1, p2, p3) {
- return orient(p1[0], p1[1], p2[0], p2[1], p3[0], p3[1]);
- }
- function intersects$1(p1, q1, p2, q2) {
- return p1 !== q2 && q1 !== p2 && cross(p1, q1, p2) > 0 !== cross(p1, q1, q2) > 0 && cross(p2, q2, p1) > 0 !== cross(p2, q2, q1) > 0;
- }
- function updateBBox(node) {
- var p1 = node.p;
- var p2 = node.next.p;
- node.minX = Math.min(p1[0], p2[0]);
- node.minY = Math.min(p1[1], p2[1]);
- node.maxX = Math.max(p1[0], p2[0]);
- node.maxY = Math.max(p1[1], p2[1]);
- return node;
- }
- function fastConvexHull(points2) {
- var left = points2[0];
- var top = points2[0];
- var right = points2[0];
- var bottom = points2[0];
- for (var i2 = 0; i2 < points2.length; i2++) {
- var p = points2[i2];
- if (p[0] < left[0])
- left = p;
- if (p[0] > right[0])
- right = p;
- if (p[1] < top[1])
- top = p;
- if (p[1] > bottom[1])
- bottom = p;
- }
- var cull = [left, top, right, bottom];
- var filtered = cull.slice();
- for (i2 = 0; i2 < points2.length; i2++) {
- if (!pointInPolygon2(points2[i2], cull))
- filtered.push(points2[i2]);
- }
- return convexHull(filtered);
- }
- function insertNode(p, prev) {
- var node = {
- p,
- prev: null,
- next: null,
- minX: 0,
- minY: 0,
- maxX: 0,
- maxY: 0
- };
- if (!prev) {
- node.prev = node;
- node.next = node;
- } else {
- node.next = prev.next;
- node.prev = prev;
- prev.next.prev = node;
- prev.next = node;
- }
- return node;
- }
- function getSqDist(p1, p2) {
- var dx = p1[0] - p2[0], dy = p1[1] - p2[1];
- return dx * dx + dy * dy;
- }
- function sqSegDist(p, p1, p2) {
- var x = p1[0], y = p1[1], dx = p2[0] - x, dy = p2[1] - y;
- if (dx !== 0 || dy !== 0) {
- var t2 = ((p[0] - x) * dx + (p[1] - y) * dy) / (dx * dx + dy * dy);
- if (t2 > 1) {
- x = p2[0];
- y = p2[1];
- } else if (t2 > 0) {
- x += dx * t2;
- y += dy * t2;
- }
- }
- dx = p[0] - x;
- dy = p[1] - y;
- return dx * dx + dy * dy;
- }
- function sqSegSegDist(x0, y0, x1, y1, x2, y2, x3, y3) {
- var ux = x1 - x0;
- var uy = y1 - y0;
- var vx = x3 - x2;
- var vy = y3 - y2;
- var wx = x0 - x2;
- var wy = y0 - y2;
- var a = ux * ux + uy * uy;
- var b = ux * vx + uy * vy;
- var c = vx * vx + vy * vy;
- var d2 = ux * wx + uy * wy;
- var e = vx * wx + vy * wy;
- var D = a * c - b * b;
- var sc, sN, tc, tN;
- var sD = D;
- var tD = D;
- if (D === 0) {
- sN = 0;
- sD = 1;
- tN = e;
- tD = c;
- } else {
- sN = b * e - c * d2;
- tN = a * e - b * d2;
- if (sN < 0) {
- sN = 0;
- tN = e;
- tD = c;
- } else if (sN > sD) {
- sN = sD;
- tN = e + b;
- tD = c;
- }
- }
- if (tN < 0) {
- tN = 0;
- if (-d2 < 0)
- sN = 0;
- else if (-d2 > a)
- sN = sD;
- else {
- sN = -d2;
- sD = a;
- }
- } else if (tN > tD) {
- tN = tD;
- if (-d2 + b < 0)
- sN = 0;
- else if (-d2 + b > a)
- sN = sD;
- else {
- sN = -d2 + b;
- sD = a;
- }
- }
- sc = sN === 0 ? 0 : sN / sD;
- tc = tN === 0 ? 0 : tN / tD;
- var cx = (1 - sc) * x0 + sc * x1;
- var cy = (1 - sc) * y0 + sc * y1;
- var cx2 = (1 - tc) * x2 + tc * x3;
- var cy2 = (1 - tc) * y2 + tc * y3;
- var dx = cx2 - cx;
- var dy = cy2 - cy;
- return dx * dx + dy * dy;
- }
- function compareByX(a, b) {
- return a[0] === b[0] ? a[1] - b[1] : a[0] - b[0];
- }
- function convexHull(points2) {
- points2.sort(compareByX);
- var lower = [];
- for (var i2 = 0; i2 < points2.length; i2++) {
- while (lower.length >= 2 && cross(lower[lower.length - 2], lower[lower.length - 1], points2[i2]) <= 0) {
- lower.pop();
- }
- lower.push(points2[i2]);
- }
- var upper = [];
- for (var ii = points2.length - 1; ii >= 0; ii--) {
- while (upper.length >= 2 && cross(upper[upper.length - 2], upper[upper.length - 1], points2[ii]) <= 0) {
- upper.pop();
- }
- upper.push(points2[ii]);
- }
- upper.pop();
- lower.pop();
- return lower.concat(upper);
- }
- var concaveman$1 = concaveman$2.exports;
- function convex(geojson, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- options2.concavity = options2.concavity || Infinity;
- var points2 = [];
- coordEach(geojson, function(coord) {
- points2.push([coord[0], coord[1]]);
- });
- if (!points2.length) {
- return null;
- }
- var convexHull2 = concaveman$1(points2, options2.concavity);
- if (convexHull2.length > 3) {
- return polygon([convexHull2]);
- }
- return null;
- }
- function booleanPointInPolygon(point2, polygon2, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- if (!point2) {
- throw new Error("point is required");
- }
- if (!polygon2) {
- throw new Error("polygon is required");
- }
- var pt2 = getCoord(point2);
- var geom = getGeom(polygon2);
- var type2 = geom.type;
- var bbox2 = polygon2.bbox;
- var polys = geom.coordinates;
- if (bbox2 && inBBox(pt2, bbox2) === false) {
- return false;
- }
- if (type2 === "Polygon") {
- polys = [polys];
- }
- var insidePoly = false;
- for (var i2 = 0; i2 < polys.length && !insidePoly; i2++) {
- if (inRing(pt2, polys[i2][0], options2.ignoreBoundary)) {
- var inHole = false;
- var k = 1;
- while (k < polys[i2].length && !inHole) {
- if (inRing(pt2, polys[i2][k], !options2.ignoreBoundary)) {
- inHole = true;
- }
- k++;
- }
- if (!inHole) {
- insidePoly = true;
- }
- }
- }
- return insidePoly;
- }
- function inRing(pt2, ring, ignoreBoundary) {
- var isInside = false;
- if (ring[0][0] === ring[ring.length - 1][0] && ring[0][1] === ring[ring.length - 1][1]) {
- ring = ring.slice(0, ring.length - 1);
- }
- for (var i2 = 0, j = ring.length - 1; i2 < ring.length; j = i2++) {
- var xi = ring[i2][0];
- var yi = ring[i2][1];
- var xj = ring[j][0];
- var yj = ring[j][1];
- var onBoundary = pt2[1] * (xi - xj) + yi * (xj - pt2[0]) + yj * (pt2[0] - xi) === 0 && (xi - pt2[0]) * (xj - pt2[0]) <= 0 && (yi - pt2[1]) * (yj - pt2[1]) <= 0;
- if (onBoundary) {
- return !ignoreBoundary;
- }
- var intersect = yi > pt2[1] !== yj > pt2[1] && pt2[0] < (xj - xi) * (pt2[1] - yi) / (yj - yi) + xi;
- if (intersect) {
- isInside = !isInside;
- }
- }
- return isInside;
- }
- function inBBox(pt2, bbox2) {
- return bbox2[0] <= pt2[0] && bbox2[1] <= pt2[1] && bbox2[2] >= pt2[0] && bbox2[3] >= pt2[1];
- }
- function distance(from3, to, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var coordinates1 = getCoord(from3);
- var coordinates2 = getCoord(to);
- var dLat = degreesToRadians(coordinates2[1] - coordinates1[1]);
- var dLon = degreesToRadians(coordinates2[0] - coordinates1[0]);
- var lat1 = degreesToRadians(coordinates1[1]);
- var lat2 = degreesToRadians(coordinates2[1]);
- var a = Math.pow(Math.sin(dLat / 2), 2) + Math.pow(Math.sin(dLon / 2), 2) * Math.cos(lat1) * Math.cos(lat2);
- return radiansToLength(2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)), options2.units);
- }
- function bboxPolygon(bbox2, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var west = Number(bbox2[0]);
- var south = Number(bbox2[1]);
- var east = Number(bbox2[2]);
- var north = Number(bbox2[3]);
- if (bbox2.length === 6) {
- throw new Error("@turf/bbox-polygon does not support BBox with 6 positions");
- }
- var lowLeft = [west, south];
- var topLeft = [west, north];
- var topRight = [east, north];
- var lowRight = [east, south];
- return polygon([[lowLeft, lowRight, topRight, topLeft, lowLeft]], options2.properties, { bbox: bbox2, id: options2.id });
- }
- function destination(origin, distance2, bearing2, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var coordinates1 = getCoord(origin);
- var longitude1 = degreesToRadians(coordinates1[0]);
- var latitude1 = degreesToRadians(coordinates1[1]);
- var bearingRad = degreesToRadians(bearing2);
- var radians = lengthToRadians(distance2, options2.units);
- var latitude2 = Math.asin(Math.sin(latitude1) * Math.cos(radians) + Math.cos(latitude1) * Math.sin(radians) * Math.cos(bearingRad));
- var longitude2 = longitude1 + Math.atan2(Math.sin(bearingRad) * Math.sin(radians) * Math.cos(latitude1), Math.cos(radians) - Math.sin(latitude1) * Math.sin(latitude2));
- var lng = radiansToDegrees(longitude2);
- var lat = radiansToDegrees(latitude2);
- return point([lng, lat], options2.properties);
- }
- function bearing(start2, end, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- if (options2.final === true) {
- return calculateFinalBearing(start2, end);
- }
- var coordinates1 = getCoord(start2);
- var coordinates2 = getCoord(end);
- var lon1 = degreesToRadians(coordinates1[0]);
- var lon2 = degreesToRadians(coordinates2[0]);
- var lat1 = degreesToRadians(coordinates1[1]);
- var lat2 = degreesToRadians(coordinates2[1]);
- var a = Math.sin(lon2 - lon1) * Math.cos(lat2);
- var b = Math.cos(lat1) * Math.sin(lat2) - Math.sin(lat1) * Math.cos(lat2) * Math.cos(lon2 - lon1);
- return radiansToDegrees(Math.atan2(a, b));
- }
- function calculateFinalBearing(start2, end) {
- var bear = bearing(end, start2);
- bear = (bear + 180) % 360;
- return bear;
- }
- function midpoint(point1, point2) {
- var dist = distance(point1, point2);
- var heading = bearing(point1, point2);
- var midpoint2 = destination(point1, dist / 2, heading);
- return midpoint2;
- }
- function center(geojson, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var ext = bbox$1(geojson);
- var x = (ext[0] + ext[2]) / 2;
- var y = (ext[1] + ext[3]) / 2;
- return point([x, y], options2.properties, options2);
- }
- function centroid(geojson, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var xSum = 0;
- var ySum = 0;
- var len = 0;
- coordEach(geojson, function(coord) {
- xSum += coord[0];
- ySum += coord[1];
- len++;
- }, true);
- return point([xSum / len, ySum / len], options2.properties);
- }
- function centerOfMass(geojson, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- switch (getType(geojson)) {
- case "Point":
- return point(getCoord(geojson), options2.properties);
- case "Polygon":
- var coords = [];
- coordEach(geojson, function(coord) {
- coords.push(coord);
- });
- var centre = centroid(geojson, { properties: options2.properties });
- var translation = centre.geometry.coordinates;
- var sx = 0;
- var sy = 0;
- var sArea = 0;
- var i2, pi, pj, xi, xj, yi, yj, a;
- var neutralizedPoints = coords.map(function(point2) {
- return [point2[0] - translation[0], point2[1] - translation[1]];
- });
- for (i2 = 0; i2 < coords.length - 1; i2++) {
- pi = neutralizedPoints[i2];
- xi = pi[0];
- yi = pi[1];
- pj = neutralizedPoints[i2 + 1];
- xj = pj[0];
- yj = pj[1];
- a = xi * yj - xj * yi;
- sArea += a;
- sx += (xi + xj) * a;
- sy += (yi + yj) * a;
- }
- if (sArea === 0) {
- return centre;
- } else {
- var area = sArea * 0.5;
- var areaFactor = 1 / (6 * area);
- return point([translation[0] + areaFactor * sx, translation[1] + areaFactor * sy], options2.properties);
- }
- default:
- var hull = convex(geojson);
- if (hull)
- return centerOfMass(hull, { properties: options2.properties });
- else
- return centroid(geojson, { properties: options2.properties });
- }
- }
- function lineSegment(geojson) {
- if (!geojson) {
- throw new Error("geojson is required");
- }
- var results = [];
- flattenEach(geojson, function(feature2) {
- lineSegmentFeature(feature2, results);
- });
- return featureCollection$1(results);
- }
- function lineSegmentFeature(geojson, results) {
- var coords = [];
- var geometry2 = geojson.geometry;
- if (geometry2 !== null) {
- switch (geometry2.type) {
- case "Polygon":
- coords = getCoords(geometry2);
- break;
- case "LineString":
- coords = [getCoords(geometry2)];
- }
- coords.forEach(function(coord) {
- var segments = createSegments(coord, geojson.properties);
- segments.forEach(function(segment) {
- segment.id = results.length;
- results.push(segment);
- });
- });
- }
- }
- function createSegments(coords, properties) {
- var segments = [];
- coords.reduce(function(previousCoords, currentCoords) {
- var segment = lineString([previousCoords, currentCoords], properties);
- segment.bbox = bbox(previousCoords, currentCoords);
- segments.push(segment);
- return currentCoords;
- });
- return segments;
- }
- function bbox(coords1, coords2) {
- var x1 = coords1[0];
- var y1 = coords1[1];
- var x2 = coords2[0];
- var y2 = coords2[1];
- var west = x1 < x2 ? x1 : x2;
- var south = y1 < y2 ? y1 : y2;
- var east = x1 > x2 ? x1 : x2;
- var north = y1 > y2 ? y1 : y2;
- return [west, south, east, north];
- }
- var geojsonRbush$1 = { exports: {} };
- var rbush_min = { exports: {} };
- (function(module2, exports2) {
- !function(t2, i2) {
- module2.exports = i2();
- }(commonjsGlobal, function() {
- function t2(t3, r3, e2, a2, h3) {
- !function t4(n2, r4, e3, a3, h4) {
- for (; a3 > e3; ) {
- if (a3 - e3 > 600) {
- var o2 = a3 - e3 + 1, s2 = r4 - e3 + 1, l2 = Math.log(o2), f2 = 0.5 * Math.exp(2 * l2 / 3), u2 = 0.5 * Math.sqrt(l2 * f2 * (o2 - f2) / o2) * (s2 - o2 / 2 < 0 ? -1 : 1), m2 = Math.max(e3, Math.floor(r4 - s2 * f2 / o2 + u2)), c2 = Math.min(a3, Math.floor(r4 + (o2 - s2) * f2 / o2 + u2));
- t4(n2, r4, m2, c2, h4);
- }
- var p2 = n2[r4], d3 = e3, x = a3;
- for (i2(n2, e3, r4), h4(n2[a3], p2) > 0 && i2(n2, e3, a3); d3 < x; ) {
- for (i2(n2, d3, x), d3++, x--; h4(n2[d3], p2) < 0; )
- d3++;
- for (; h4(n2[x], p2) > 0; )
- x--;
- }
- 0 === h4(n2[e3], p2) ? i2(n2, e3, x) : i2(n2, ++x, a3), x <= r4 && (e3 = x + 1), r4 <= x && (a3 = x - 1);
- }
- }(t3, r3, e2 || 0, a2 || t3.length - 1, h3 || n);
- }
- function i2(t3, i3, n2) {
- var r3 = t3[i3];
- t3[i3] = t3[n2], t3[n2] = r3;
- }
- function n(t3, i3) {
- return t3 < i3 ? -1 : t3 > i3 ? 1 : 0;
- }
- var r2 = function(t3) {
- void 0 === t3 && (t3 = 9), this._maxEntries = Math.max(4, t3), this._minEntries = Math.max(2, Math.ceil(0.4 * this._maxEntries)), this.clear();
- };
- function e(t3, i3, n2) {
- if (!n2)
- return i3.indexOf(t3);
- for (var r3 = 0; r3 < i3.length; r3++)
- if (n2(t3, i3[r3]))
- return r3;
- return -1;
- }
- function a(t3, i3) {
- h2(t3, 0, t3.children.length, i3, t3);
- }
- function h2(t3, i3, n2, r3, e2) {
- e2 || (e2 = p(null)), e2.minX = 1 / 0, e2.minY = 1 / 0, e2.maxX = -1 / 0, e2.maxY = -1 / 0;
- for (var a2 = i3; a2 < n2; a2++) {
- var h3 = t3.children[a2];
- o(e2, t3.leaf ? r3(h3) : h3);
- }
- return e2;
- }
- function o(t3, i3) {
- return t3.minX = Math.min(t3.minX, i3.minX), t3.minY = Math.min(t3.minY, i3.minY), t3.maxX = Math.max(t3.maxX, i3.maxX), t3.maxY = Math.max(t3.maxY, i3.maxY), t3;
- }
- function s(t3, i3) {
- return t3.minX - i3.minX;
- }
- function l(t3, i3) {
- return t3.minY - i3.minY;
- }
- function f(t3) {
- return (t3.maxX - t3.minX) * (t3.maxY - t3.minY);
- }
- function u(t3) {
- return t3.maxX - t3.minX + (t3.maxY - t3.minY);
- }
- function m(t3, i3) {
- return t3.minX <= i3.minX && t3.minY <= i3.minY && i3.maxX <= t3.maxX && i3.maxY <= t3.maxY;
- }
- function c(t3, i3) {
- return i3.minX <= t3.maxX && i3.minY <= t3.maxY && i3.maxX >= t3.minX && i3.maxY >= t3.minY;
- }
- function p(t3) {
- return { children: t3, height: 1, leaf: true, minX: 1 / 0, minY: 1 / 0, maxX: -1 / 0, maxY: -1 / 0 };
- }
- function d2(i3, n2, r3, e2, a2) {
- for (var h3 = [n2, r3]; h3.length; )
- if (!((r3 = h3.pop()) - (n2 = h3.pop()) <= e2)) {
- var o2 = n2 + Math.ceil((r3 - n2) / e2 / 2) * e2;
- t2(i3, o2, n2, r3, a2), h3.push(n2, o2, o2, r3);
- }
- }
- return r2.prototype.all = function() {
- return this._all(this.data, []);
- }, r2.prototype.search = function(t3) {
- var i3 = this.data, n2 = [];
- if (!c(t3, i3))
- return n2;
- for (var r3 = this.toBBox, e2 = []; i3; ) {
- for (var a2 = 0; a2 < i3.children.length; a2++) {
- var h3 = i3.children[a2], o2 = i3.leaf ? r3(h3) : h3;
- c(t3, o2) && (i3.leaf ? n2.push(h3) : m(t3, o2) ? this._all(h3, n2) : e2.push(h3));
- }
- i3 = e2.pop();
- }
- return n2;
- }, r2.prototype.collides = function(t3) {
- var i3 = this.data;
- if (!c(t3, i3))
- return false;
- for (var n2 = []; i3; ) {
- for (var r3 = 0; r3 < i3.children.length; r3++) {
- var e2 = i3.children[r3], a2 = i3.leaf ? this.toBBox(e2) : e2;
- if (c(t3, a2)) {
- if (i3.leaf || m(t3, a2))
- return true;
- n2.push(e2);
- }
- }
- i3 = n2.pop();
- }
- return false;
- }, r2.prototype.load = function(t3) {
- if (!t3 || !t3.length)
- return this;
- if (t3.length < this._minEntries) {
- for (var i3 = 0; i3 < t3.length; i3++)
- this.insert(t3[i3]);
- return this;
- }
- var n2 = this._build(t3.slice(), 0, t3.length - 1, 0);
- if (this.data.children.length)
- if (this.data.height === n2.height)
- this._splitRoot(this.data, n2);
- else {
- if (this.data.height < n2.height) {
- var r3 = this.data;
- this.data = n2, n2 = r3;
- }
- this._insert(n2, this.data.height - n2.height - 1, true);
- }
- else
- this.data = n2;
- return this;
- }, r2.prototype.insert = function(t3) {
- return t3 && this._insert(t3, this.data.height - 1), this;
- }, r2.prototype.clear = function() {
- return this.data = p([]), this;
- }, r2.prototype.remove = function(t3, i3) {
- if (!t3)
- return this;
- for (var n2, r3, a2, h3 = this.data, o2 = this.toBBox(t3), s2 = [], l2 = []; h3 || s2.length; ) {
- if (h3 || (h3 = s2.pop(), r3 = s2[s2.length - 1], n2 = l2.pop(), a2 = true), h3.leaf) {
- var f2 = e(t3, h3.children, i3);
- if (-1 !== f2)
- return h3.children.splice(f2, 1), s2.push(h3), this._condense(s2), this;
- }
- a2 || h3.leaf || !m(h3, o2) ? r3 ? (n2++, h3 = r3.children[n2], a2 = false) : h3 = null : (s2.push(h3), l2.push(n2), n2 = 0, r3 = h3, h3 = h3.children[0]);
- }
- return this;
- }, r2.prototype.toBBox = function(t3) {
- return t3;
- }, r2.prototype.compareMinX = function(t3, i3) {
- return t3.minX - i3.minX;
- }, r2.prototype.compareMinY = function(t3, i3) {
- return t3.minY - i3.minY;
- }, r2.prototype.toJSON = function() {
- return this.data;
- }, r2.prototype.fromJSON = function(t3) {
- return this.data = t3, this;
- }, r2.prototype._all = function(t3, i3) {
- for (var n2 = []; t3; )
- t3.leaf ? i3.push.apply(i3, t3.children) : n2.push.apply(n2, t3.children), t3 = n2.pop();
- return i3;
- }, r2.prototype._build = function(t3, i3, n2, r3) {
- var e2, h3 = n2 - i3 + 1, o2 = this._maxEntries;
- if (h3 <= o2)
- return a(e2 = p(t3.slice(i3, n2 + 1)), this.toBBox), e2;
- r3 || (r3 = Math.ceil(Math.log(h3) / Math.log(o2)), o2 = Math.ceil(h3 / Math.pow(o2, r3 - 1))), (e2 = p([])).leaf = false, e2.height = r3;
- var s2 = Math.ceil(h3 / o2), l2 = s2 * Math.ceil(Math.sqrt(o2));
- d2(t3, i3, n2, l2, this.compareMinX);
- for (var f2 = i3; f2 <= n2; f2 += l2) {
- var u2 = Math.min(f2 + l2 - 1, n2);
- d2(t3, f2, u2, s2, this.compareMinY);
- for (var m2 = f2; m2 <= u2; m2 += s2) {
- var c2 = Math.min(m2 + s2 - 1, u2);
- e2.children.push(this._build(t3, m2, c2, r3 - 1));
- }
- }
- return a(e2, this.toBBox), e2;
- }, r2.prototype._chooseSubtree = function(t3, i3, n2, r3) {
- for (; r3.push(i3), !i3.leaf && r3.length - 1 !== n2; ) {
- for (var e2 = 1 / 0, a2 = 1 / 0, h3 = void 0, o2 = 0; o2 < i3.children.length; o2++) {
- var s2 = i3.children[o2], l2 = f(s2), u2 = (m2 = t3, c2 = s2, (Math.max(c2.maxX, m2.maxX) - Math.min(c2.minX, m2.minX)) * (Math.max(c2.maxY, m2.maxY) - Math.min(c2.minY, m2.minY)) - l2);
- u2 < a2 ? (a2 = u2, e2 = l2 < e2 ? l2 : e2, h3 = s2) : u2 === a2 && l2 < e2 && (e2 = l2, h3 = s2);
- }
- i3 = h3 || i3.children[0];
- }
- var m2, c2;
- return i3;
- }, r2.prototype._insert = function(t3, i3, n2) {
- var r3 = n2 ? t3 : this.toBBox(t3), e2 = [], a2 = this._chooseSubtree(r3, this.data, i3, e2);
- for (a2.children.push(t3), o(a2, r3); i3 >= 0 && e2[i3].children.length > this._maxEntries; )
- this._split(e2, i3), i3--;
- this._adjustParentBBoxes(r3, e2, i3);
- }, r2.prototype._split = function(t3, i3) {
- var n2 = t3[i3], r3 = n2.children.length, e2 = this._minEntries;
- this._chooseSplitAxis(n2, e2, r3);
- var h3 = this._chooseSplitIndex(n2, e2, r3), o2 = p(n2.children.splice(h3, n2.children.length - h3));
- o2.height = n2.height, o2.leaf = n2.leaf, a(n2, this.toBBox), a(o2, this.toBBox), i3 ? t3[i3 - 1].children.push(o2) : this._splitRoot(n2, o2);
- }, r2.prototype._splitRoot = function(t3, i3) {
- this.data = p([t3, i3]), this.data.height = t3.height + 1, this.data.leaf = false, a(this.data, this.toBBox);
- }, r2.prototype._chooseSplitIndex = function(t3, i3, n2) {
- for (var r3, e2, a2, o2, s2, l2, u2, m2 = 1 / 0, c2 = 1 / 0, p2 = i3; p2 <= n2 - i3; p2++) {
- var d3 = h2(t3, 0, p2, this.toBBox), x = h2(t3, p2, n2, this.toBBox), v = (e2 = d3, a2 = x, o2 = void 0, s2 = void 0, l2 = void 0, u2 = void 0, o2 = Math.max(e2.minX, a2.minX), s2 = Math.max(e2.minY, a2.minY), l2 = Math.min(e2.maxX, a2.maxX), u2 = Math.min(e2.maxY, a2.maxY), Math.max(0, l2 - o2) * Math.max(0, u2 - s2)), M = f(d3) + f(x);
- v < m2 ? (m2 = v, r3 = p2, c2 = M < c2 ? M : c2) : v === m2 && M < c2 && (c2 = M, r3 = p2);
- }
- return r3 || n2 - i3;
- }, r2.prototype._chooseSplitAxis = function(t3, i3, n2) {
- var r3 = t3.leaf ? this.compareMinX : s, e2 = t3.leaf ? this.compareMinY : l;
- this._allDistMargin(t3, i3, n2, r3) < this._allDistMargin(t3, i3, n2, e2) && t3.children.sort(r3);
- }, r2.prototype._allDistMargin = function(t3, i3, n2, r3) {
- t3.children.sort(r3);
- for (var e2 = this.toBBox, a2 = h2(t3, 0, i3, e2), s2 = h2(t3, n2 - i3, n2, e2), l2 = u(a2) + u(s2), f2 = i3; f2 < n2 - i3; f2++) {
- var m2 = t3.children[f2];
- o(a2, t3.leaf ? e2(m2) : m2), l2 += u(a2);
- }
- for (var c2 = n2 - i3 - 1; c2 >= i3; c2--) {
- var p2 = t3.children[c2];
- o(s2, t3.leaf ? e2(p2) : p2), l2 += u(s2);
- }
- return l2;
- }, r2.prototype._adjustParentBBoxes = function(t3, i3, n2) {
- for (var r3 = n2; r3 >= 0; r3--)
- o(i3[r3], t3);
- }, r2.prototype._condense = function(t3) {
- for (var i3 = t3.length - 1, n2 = void 0; i3 >= 0; i3--)
- 0 === t3[i3].children.length ? i3 > 0 ? (n2 = t3[i3 - 1].children).splice(n2.indexOf(t3[i3]), 1) : this.clear() : a(t3[i3], this.toBBox);
- }, r2;
- });
- })(rbush_min);
- var require$$1$1 = /* @__PURE__ */ getAugmentedNamespace(es$2);
- var require$$2 = /* @__PURE__ */ getAugmentedNamespace(es$1);
- var require$$3 = /* @__PURE__ */ getAugmentedNamespace(es);
- var rbush = rbush_min.exports;
- var helpers = require$$1$1;
- var meta = require$$2;
- var turfBBox = require$$3.default;
- var featureEach = meta.featureEach;
- meta.coordEach;
- helpers.polygon;
- var featureCollection = helpers.featureCollection;
- function geojsonRbush(maxEntries) {
- var tree = new rbush(maxEntries);
- tree.insert = function(feature2) {
- if (feature2.type !== "Feature")
- throw new Error("invalid feature");
- feature2.bbox = feature2.bbox ? feature2.bbox : turfBBox(feature2);
- return rbush.prototype.insert.call(this, feature2);
- };
- tree.load = function(features) {
- var load = [];
- if (Array.isArray(features)) {
- features.forEach(function(feature2) {
- if (feature2.type !== "Feature")
- throw new Error("invalid features");
- feature2.bbox = feature2.bbox ? feature2.bbox : turfBBox(feature2);
- load.push(feature2);
- });
- } else {
- featureEach(features, function(feature2) {
- if (feature2.type !== "Feature")
- throw new Error("invalid features");
- feature2.bbox = feature2.bbox ? feature2.bbox : turfBBox(feature2);
- load.push(feature2);
- });
- }
- return rbush.prototype.load.call(this, load);
- };
- tree.remove = function(feature2, equals) {
- if (feature2.type !== "Feature")
- throw new Error("invalid feature");
- feature2.bbox = feature2.bbox ? feature2.bbox : turfBBox(feature2);
- return rbush.prototype.remove.call(this, feature2, equals);
- };
- tree.clear = function() {
- return rbush.prototype.clear.call(this);
- };
- tree.search = function(geojson) {
- var features = rbush.prototype.search.call(this, this.toBBox(geojson));
- return featureCollection(features);
- };
- tree.collides = function(geojson) {
- return rbush.prototype.collides.call(this, this.toBBox(geojson));
- };
- tree.all = function() {
- var features = rbush.prototype.all.call(this);
- return featureCollection(features);
- };
- tree.toJSON = function() {
- return rbush.prototype.toJSON.call(this);
- };
- tree.fromJSON = function(json) {
- return rbush.prototype.fromJSON.call(this, json);
- };
- tree.toBBox = function(geojson) {
- var bbox2;
- if (geojson.bbox)
- bbox2 = geojson.bbox;
- else if (Array.isArray(geojson) && geojson.length === 4)
- bbox2 = geojson;
- else if (Array.isArray(geojson) && geojson.length === 6)
- bbox2 = [geojson[0], geojson[1], geojson[3], geojson[4]];
- else if (geojson.type === "Feature")
- bbox2 = turfBBox(geojson);
- else if (geojson.type === "FeatureCollection")
- bbox2 = turfBBox(geojson);
- else
- throw new Error("invalid geojson");
- return {
- minX: bbox2[0],
- minY: bbox2[1],
- maxX: bbox2[2],
- maxY: bbox2[3]
- };
- };
- return tree;
- }
- geojsonRbush$1.exports = geojsonRbush;
- geojsonRbush$1.exports.default = geojsonRbush;
- var rbush$1 = geojsonRbush$1.exports;
- function lineIntersect(line1, line2) {
- var unique = {};
- var results = [];
- if (line1.type === "LineString") {
- line1 = feature(line1);
- }
- if (line2.type === "LineString") {
- line2 = feature(line2);
- }
- if (line1.type === "Feature" && line2.type === "Feature" && line1.geometry !== null && line2.geometry !== null && line1.geometry.type === "LineString" && line2.geometry.type === "LineString" && line1.geometry.coordinates.length === 2 && line2.geometry.coordinates.length === 2) {
- var intersect = intersects(line1, line2);
- if (intersect) {
- results.push(intersect);
- }
- return featureCollection$1(results);
- }
- var tree = rbush$1();
- tree.load(lineSegment(line2));
- featureEach$1(lineSegment(line1), function(segment) {
- featureEach$1(tree.search(segment), function(match) {
- var intersect2 = intersects(segment, match);
- if (intersect2) {
- var key = getCoords(intersect2).join(",");
- if (!unique[key]) {
- unique[key] = true;
- results.push(intersect2);
- }
- }
- });
- });
- return featureCollection$1(results);
- }
- function intersects(line1, line2) {
- var coords1 = getCoords(line1);
- var coords2 = getCoords(line2);
- if (coords1.length !== 2) {
- throw new Error("<intersects> line1 must only contain 2 coordinates");
- }
- if (coords2.length !== 2) {
- throw new Error("<intersects> line2 must only contain 2 coordinates");
- }
- var x1 = coords1[0][0];
- var y1 = coords1[0][1];
- var x2 = coords1[1][0];
- var y2 = coords1[1][1];
- var x3 = coords2[0][0];
- var y3 = coords2[0][1];
- var x4 = coords2[1][0];
- var y4 = coords2[1][1];
- var denom = (y4 - y3) * (x2 - x1) - (x4 - x3) * (y2 - y1);
- var numeA = (x4 - x3) * (y1 - y3) - (y4 - y3) * (x1 - x3);
- var numeB = (x2 - x1) * (y1 - y3) - (y2 - y1) * (x1 - x3);
- if (denom === 0) {
- if (numeA === 0 && numeB === 0) {
- return null;
- }
- return null;
- }
- var uA = numeA / denom;
- var uB = numeB / denom;
- if (uA >= 0 && uA <= 1 && uB >= 0 && uB <= 1) {
- var x = x1 + uA * (x2 - x1);
- var y = y1 + uA * (y2 - y1);
- return point([x, y]);
- }
- return null;
- }
- function booleanPointOnLine(pt2, line, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var ptCoords = getCoord(pt2);
- var lineCoords = getCoords(line);
- for (var i2 = 0; i2 < lineCoords.length - 1; i2++) {
- var ignoreBoundary = false;
- if (options2.ignoreEndVertices) {
- if (i2 === 0) {
- ignoreBoundary = "start";
- }
- if (i2 === lineCoords.length - 2) {
- ignoreBoundary = "end";
- }
- if (i2 === 0 && i2 + 1 === lineCoords.length - 1) {
- ignoreBoundary = "both";
- }
- }
- if (isPointOnLineSegment$1(lineCoords[i2], lineCoords[i2 + 1], ptCoords, ignoreBoundary, typeof options2.epsilon === "undefined" ? null : options2.epsilon)) {
- return true;
- }
- }
- return false;
- }
- function isPointOnLineSegment$1(lineSegmentStart, lineSegmentEnd, pt2, excludeBoundary, epsilon) {
- var x = pt2[0];
- var y = pt2[1];
- var x1 = lineSegmentStart[0];
- var y1 = lineSegmentStart[1];
- var x2 = lineSegmentEnd[0];
- var y2 = lineSegmentEnd[1];
- var dxc = pt2[0] - x1;
- var dyc = pt2[1] - y1;
- var dxl = x2 - x1;
- var dyl = y2 - y1;
- var cross2 = dxc * dyl - dyc * dxl;
- if (epsilon !== null) {
- if (Math.abs(cross2) > epsilon) {
- return false;
- }
- } else if (cross2 !== 0) {
- return false;
- }
- if (!excludeBoundary) {
- if (Math.abs(dxl) >= Math.abs(dyl)) {
- return dxl > 0 ? x1 <= x && x <= x2 : x2 <= x && x <= x1;
- }
- return dyl > 0 ? y1 <= y && y <= y2 : y2 <= y && y <= y1;
- } else if (excludeBoundary === "start") {
- if (Math.abs(dxl) >= Math.abs(dyl)) {
- return dxl > 0 ? x1 < x && x <= x2 : x2 <= x && x < x1;
- }
- return dyl > 0 ? y1 < y && y <= y2 : y2 <= y && y < y1;
- } else if (excludeBoundary === "end") {
- if (Math.abs(dxl) >= Math.abs(dyl)) {
- return dxl > 0 ? x1 <= x && x < x2 : x2 < x && x <= x1;
- }
- return dyl > 0 ? y1 <= y && y < y2 : y2 < y && y <= y1;
- } else if (excludeBoundary === "both") {
- if (Math.abs(dxl) >= Math.abs(dyl)) {
- return dxl > 0 ? x1 < x && x < x2 : x2 < x && x < x1;
- }
- return dyl > 0 ? y1 < y && y < y2 : y2 < y && y < y1;
- }
- return false;
- }
- function booleanWithin(feature1, feature2) {
- var geom1 = getGeom(feature1);
- var geom2 = getGeom(feature2);
- var type1 = geom1.type;
- var type2 = geom2.type;
- switch (type1) {
- case "Point":
- switch (type2) {
- case "MultiPoint":
- return isPointInMultiPoint(geom1, geom2);
- case "LineString":
- return booleanPointOnLine(geom1, geom2, { ignoreEndVertices: true });
- case "Polygon":
- case "MultiPolygon":
- return booleanPointInPolygon(geom1, geom2, { ignoreBoundary: true });
- default:
- throw new Error("feature2 " + type2 + " geometry not supported");
- }
- case "MultiPoint":
- switch (type2) {
- case "MultiPoint":
- return isMultiPointInMultiPoint(geom1, geom2);
- case "LineString":
- return isMultiPointOnLine(geom1, geom2);
- case "Polygon":
- case "MultiPolygon":
- return isMultiPointInPoly(geom1, geom2);
- default:
- throw new Error("feature2 " + type2 + " geometry not supported");
- }
- case "LineString":
- switch (type2) {
- case "LineString":
- return isLineOnLine$1(geom1, geom2);
- case "Polygon":
- case "MultiPolygon":
- return isLineInPoly$1(geom1, geom2);
- default:
- throw new Error("feature2 " + type2 + " geometry not supported");
- }
- case "Polygon":
- switch (type2) {
- case "Polygon":
- case "MultiPolygon":
- return isPolyInPoly$1(geom1, geom2);
- default:
- throw new Error("feature2 " + type2 + " geometry not supported");
- }
- default:
- throw new Error("feature1 " + type1 + " geometry not supported");
- }
- }
- function isPointInMultiPoint(point2, multiPoint2) {
- var i2;
- var output = false;
- for (i2 = 0; i2 < multiPoint2.coordinates.length; i2++) {
- if (compareCoords$1(multiPoint2.coordinates[i2], point2.coordinates)) {
- output = true;
- break;
- }
- }
- return output;
- }
- function isMultiPointInMultiPoint(multiPoint1, multiPoint2) {
- for (var i2 = 0; i2 < multiPoint1.coordinates.length; i2++) {
- var anyMatch = false;
- for (var i22 = 0; i22 < multiPoint2.coordinates.length; i22++) {
- if (compareCoords$1(multiPoint1.coordinates[i2], multiPoint2.coordinates[i22])) {
- anyMatch = true;
- }
- }
- if (!anyMatch) {
- return false;
- }
- }
- return true;
- }
- function isMultiPointOnLine(multiPoint2, lineString2) {
- var foundInsidePoint = false;
- for (var i2 = 0; i2 < multiPoint2.coordinates.length; i2++) {
- if (!booleanPointOnLine(multiPoint2.coordinates[i2], lineString2)) {
- return false;
- }
- if (!foundInsidePoint) {
- foundInsidePoint = booleanPointOnLine(multiPoint2.coordinates[i2], lineString2, { ignoreEndVertices: true });
- }
- }
- return foundInsidePoint;
- }
- function isMultiPointInPoly(multiPoint2, polygon2) {
- var output = true;
- var isInside = false;
- for (var i2 = 0; i2 < multiPoint2.coordinates.length; i2++) {
- isInside = booleanPointInPolygon(multiPoint2.coordinates[1], polygon2);
- if (!isInside) {
- output = false;
- break;
- }
- {
- isInside = booleanPointInPolygon(multiPoint2.coordinates[1], polygon2, {
- ignoreBoundary: true
- });
- }
- }
- return output && isInside;
- }
- function isLineOnLine$1(lineString1, lineString2) {
- for (var i2 = 0; i2 < lineString1.coordinates.length; i2++) {
- if (!booleanPointOnLine(lineString1.coordinates[i2], lineString2)) {
- return false;
- }
- }
- return true;
- }
- function isLineInPoly$1(linestring, polygon2) {
- var polyBbox = bbox$1(polygon2);
- var lineBbox = bbox$1(linestring);
- if (!doBBoxOverlap(polyBbox, lineBbox)) {
- return false;
- }
- var foundInsidePoint = false;
- for (var i2 = 0; i2 < linestring.coordinates.length - 1; i2++) {
- if (!booleanPointInPolygon(linestring.coordinates[i2], polygon2)) {
- return false;
- }
- if (!foundInsidePoint) {
- foundInsidePoint = booleanPointInPolygon(linestring.coordinates[i2], polygon2, { ignoreBoundary: true });
- }
- if (!foundInsidePoint) {
- var midpoint2 = getMidpoint(linestring.coordinates[i2], linestring.coordinates[i2 + 1]);
- foundInsidePoint = booleanPointInPolygon(midpoint2, polygon2, {
- ignoreBoundary: true
- });
- }
- }
- return foundInsidePoint;
- }
- function isPolyInPoly$1(geometry1, geometry2) {
- var poly1Bbox = bbox$1(geometry1);
- var poly2Bbox = bbox$1(geometry2);
- if (!doBBoxOverlap(poly2Bbox, poly1Bbox)) {
- return false;
- }
- for (var i2 = 0; i2 < geometry1.coordinates[0].length; i2++) {
- if (!booleanPointInPolygon(geometry1.coordinates[0][i2], geometry2)) {
- return false;
- }
- }
- return true;
- }
- function doBBoxOverlap(bbox1, bbox2) {
- if (bbox1[0] > bbox2[0])
- return false;
- if (bbox1[2] < bbox2[2])
- return false;
- if (bbox1[1] > bbox2[1])
- return false;
- if (bbox1[3] < bbox2[3])
- return false;
- return true;
- }
- function compareCoords$1(pair1, pair2) {
- return pair1[0] === pair2[0] && pair1[1] === pair2[1];
- }
- function getMidpoint(pair1, pair2) {
- return [(pair1[0] + pair2[0]) / 2, (pair1[1] + pair2[1]) / 2];
- }
- function pointGrid(bbox2, cellSide, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- if (options2.mask && !options2.units)
- options2.units = "kilometers";
- var results = [];
- var west = bbox2[0];
- var south = bbox2[1];
- var east = bbox2[2];
- var north = bbox2[3];
- var xFraction = cellSide / distance([west, south], [east, south], options2);
- var cellWidth = xFraction * (east - west);
- var yFraction = cellSide / distance([west, south], [west, north], options2);
- var cellHeight = yFraction * (north - south);
- var bboxWidth = east - west;
- var bboxHeight = north - south;
- var columns = Math.floor(bboxWidth / cellWidth);
- var rows = Math.floor(bboxHeight / cellHeight);
- var deltaX = (bboxWidth - columns * cellWidth) / 2;
- var deltaY = (bboxHeight - rows * cellHeight) / 2;
- var currentX = west + deltaX;
- while (currentX <= east) {
- var currentY = south + deltaY;
- while (currentY <= north) {
- var cellPt = point([currentX, currentY], options2.properties);
- if (options2.mask) {
- if (booleanWithin(cellPt, options2.mask))
- results.push(cellPt);
- } else {
- results.push(cellPt);
- }
- currentY += cellHeight;
- }
- currentX += cellWidth;
- }
- return featureCollection$1(results);
- }
- function polygonToLine(poly, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var geom = getGeom(poly);
- if (!options2.properties && poly.type === "Feature") {
- options2.properties = poly.properties;
- }
- switch (geom.type) {
- case "Polygon":
- return polygonToLine$1(geom, options2);
- case "MultiPolygon":
- return multiPolygonToLine(geom, options2);
- default:
- throw new Error("invalid poly");
- }
- }
- function polygonToLine$1(poly, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var geom = getGeom(poly);
- var coords = geom.coordinates;
- var properties = options2.properties ? options2.properties : poly.type === "Feature" ? poly.properties : {};
- return coordsToLine(coords, properties);
- }
- function multiPolygonToLine(multiPoly, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var geom = getGeom(multiPoly);
- var coords = geom.coordinates;
- var properties = options2.properties ? options2.properties : multiPoly.type === "Feature" ? multiPoly.properties : {};
- var lines = [];
- coords.forEach(function(coord) {
- lines.push(coordsToLine(coord, properties));
- });
- return featureCollection$1(lines);
- }
- function coordsToLine(coords, properties) {
- if (coords.length > 1) {
- return multiLineString(coords, properties);
- }
- return lineString(coords[0], properties);
- }
- function booleanClockwise(line) {
- var ring = getCoords(line);
- var sum = 0;
- var i2 = 1;
- var prev;
- var cur;
- while (i2 < ring.length) {
- prev = cur || ring[0];
- cur = ring[i2];
- sum += (cur[0] - prev[0]) * (cur[1] + prev[1]);
- i2++;
- }
- return sum > 0;
- }
- function booleanDisjoint(feature1, feature2) {
- var bool = true;
- flattenEach(feature1, function(flatten1) {
- flattenEach(feature2, function(flatten22) {
- if (bool === false) {
- return false;
- }
- bool = disjoint(flatten1.geometry, flatten22.geometry);
- });
- });
- return bool;
- }
- function disjoint(geom1, geom2) {
- switch (geom1.type) {
- case "Point":
- switch (geom2.type) {
- case "Point":
- return !compareCoords(geom1.coordinates, geom2.coordinates);
- case "LineString":
- return !isPointOnLine(geom2, geom1);
- case "Polygon":
- return !booleanPointInPolygon(geom1, geom2);
- }
- break;
- case "LineString":
- switch (geom2.type) {
- case "Point":
- return !isPointOnLine(geom1, geom2);
- case "LineString":
- return !isLineOnLine(geom1, geom2);
- case "Polygon":
- return !isLineInPoly(geom2, geom1);
- }
- break;
- case "Polygon":
- switch (geom2.type) {
- case "Point":
- return !booleanPointInPolygon(geom2, geom1);
- case "LineString":
- return !isLineInPoly(geom1, geom2);
- case "Polygon":
- return !isPolyInPoly(geom2, geom1);
- }
- }
- return false;
- }
- function isPointOnLine(lineString2, pt2) {
- for (var i2 = 0; i2 < lineString2.coordinates.length - 1; i2++) {
- if (isPointOnLineSegment(lineString2.coordinates[i2], lineString2.coordinates[i2 + 1], pt2.coordinates)) {
- return true;
- }
- }
- return false;
- }
- function isLineOnLine(lineString1, lineString2) {
- var doLinesIntersect = lineIntersect(lineString1, lineString2);
- if (doLinesIntersect.features.length > 0) {
- return true;
- }
- return false;
- }
- function isLineInPoly(polygon2, lineString2) {
- for (var _i = 0, _a2 = lineString2.coordinates; _i < _a2.length; _i++) {
- var coord = _a2[_i];
- if (booleanPointInPolygon(coord, polygon2)) {
- return true;
- }
- }
- var doLinesIntersect = lineIntersect(lineString2, polygonToLine(polygon2));
- if (doLinesIntersect.features.length > 0) {
- return true;
- }
- return false;
- }
- function isPolyInPoly(feature1, feature2) {
- for (var _i = 0, _a2 = feature1.coordinates[0]; _i < _a2.length; _i++) {
- var coord1 = _a2[_i];
- if (booleanPointInPolygon(coord1, feature2)) {
- return true;
- }
- }
- for (var _b = 0, _c = feature2.coordinates[0]; _b < _c.length; _b++) {
- var coord2 = _c[_b];
- if (booleanPointInPolygon(coord2, feature1)) {
- return true;
- }
- }
- var doLinesIntersect = lineIntersect(polygonToLine(feature1), polygonToLine(feature2));
- if (doLinesIntersect.features.length > 0) {
- return true;
- }
- return false;
- }
- function isPointOnLineSegment(lineSegmentStart, lineSegmentEnd, pt2) {
- var dxc = pt2[0] - lineSegmentStart[0];
- var dyc = pt2[1] - lineSegmentStart[1];
- var dxl = lineSegmentEnd[0] - lineSegmentStart[0];
- var dyl = lineSegmentEnd[1] - lineSegmentStart[1];
- var cross2 = dxc * dyl - dyc * dxl;
- if (cross2 !== 0) {
- return false;
- }
- if (Math.abs(dxl) >= Math.abs(dyl)) {
- if (dxl > 0) {
- return lineSegmentStart[0] <= pt2[0] && pt2[0] <= lineSegmentEnd[0];
- } else {
- return lineSegmentEnd[0] <= pt2[0] && pt2[0] <= lineSegmentStart[0];
- }
- } else if (dyl > 0) {
- return lineSegmentStart[1] <= pt2[1] && pt2[1] <= lineSegmentEnd[1];
- } else {
- return lineSegmentEnd[1] <= pt2[1] && pt2[1] <= lineSegmentStart[1];
- }
- }
- function compareCoords(pair1, pair2) {
- return pair1[0] === pair2[0] && pair1[1] === pair2[1];
- }
- function booleanIntersects(feature1, feature2) {
- var bool = false;
- flattenEach(feature1, function(flatten1) {
- flattenEach(feature2, function(flatten22) {
- if (bool === true) {
- return true;
- }
- bool = !booleanDisjoint(flatten1.geometry, flatten22.geometry);
- });
- });
- return bool;
- }
- function rectangleGrid(bbox2, cellWidth, cellHeight, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var results = [];
- var west = bbox2[0];
- var south = bbox2[1];
- var east = bbox2[2];
- var north = bbox2[3];
- var xFraction = cellWidth / distance([west, south], [east, south], options2);
- var cellWidthDeg = xFraction * (east - west);
- var yFraction = cellHeight / distance([west, south], [west, north], options2);
- var cellHeightDeg = yFraction * (north - south);
- var bboxWidth = east - west;
- var bboxHeight = north - south;
- var columns = Math.floor(bboxWidth / cellWidthDeg);
- var rows = Math.floor(bboxHeight / cellHeightDeg);
- var deltaX = (bboxWidth - columns * cellWidthDeg) / 2;
- var deltaY = (bboxHeight - rows * cellHeightDeg) / 2;
- var currentX = west + deltaX;
- for (var column = 0; column < columns; column++) {
- var currentY = south + deltaY;
- for (var row = 0; row < rows; row++) {
- var cellPoly = polygon([
- [
- [currentX, currentY],
- [currentX, currentY + cellHeightDeg],
- [currentX + cellWidthDeg, currentY + cellHeightDeg],
- [currentX + cellWidthDeg, currentY],
- [currentX, currentY]
- ]
- ], options2.properties);
- if (options2.mask) {
- if (booleanIntersects(options2.mask, cellPoly)) {
- results.push(cellPoly);
- }
- } else {
- results.push(cellPoly);
- }
- currentY += cellHeightDeg;
- }
- currentX += cellWidthDeg;
- }
- return featureCollection$1(results);
- }
- function squareGrid(bbox2, cellSide, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- return rectangleGrid(bbox2, cellSide, cellSide, options2);
- }
- class ViewShed {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this.viewer = viewer2;
- this.handler = void 0;
- this.lightCamera;
- this.pyramid;
- this.frustumPrimitive;
- this.viewershedPolygon;
- }
- initHandler() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = void 0;
- }
- let canvas = document.getElementById("canvasMap");
- if (canvas == null) {
- canvas = document.createElement("canvas");
- canvas.id = "canvasMap";
- canvas.style.display = "none";
- canvas.style.top = "0px";
- canvas.style.position = "absolute";
- document.body.append(canvas);
- }
- this.canvasEle = canvas;
- }
- ReturnDistance(pos0, pos1) {
- let point1cartographic = Cesium.Cartographic.fromCartesian(pos0);
- let point2cartographic = Cesium.Cartographic.fromCartesian(pos1);
- let geodesic = new Cesium.EllipsoidGeodesic();
- geodesic.setEndPoints(point1cartographic, point2cartographic);
- let s = geodesic.surfaceDistance;
- return s;
- }
- getHeight(x, y, objectsToExclude) {
- let endCartographic = Cesium.Cartographic.fromDegrees(x, y);
- let endHeight = this.viewer.scene.sampleHeight(
- endCartographic,
- objectsToExclude
- );
- return endHeight;
- }
- cartesian3ToDegree(Cartesian32) {
- let _ellipsoid = this.viewer.scene.globe.ellipsoid;
- let _cartographic = _ellipsoid.cartesianToCartographic(Cartesian32);
- let _lat = Cesium.Math.toDegrees(_cartographic.latitude);
- let _lng = Cesium.Math.toDegrees(_cartographic.longitude);
- let _alt = _cartographic.height;
- return [_lng, _lat, _alt];
- }
- getAngle(lng1, lat1, lng2, lat2) {
- let dRotateAngle = Math.atan2(Math.abs(lng1 - lng2), Math.abs(lat1 - lat2));
- if (lng2 >= lng1) {
- dRotateAngle = lat2 < lat1 ? Math.PI - dRotateAngle : dRotateAngle;
- } else {
- dRotateAngle = lat2 >= lat1 ? 2 * Math.PI - dRotateAngle : Math.PI + dRotateAngle;
- }
- dRotateAngle = dRotateAngle * 180 / Math.PI;
- return dRotateAngle;
- }
- getPitch(pointA, pointB) {
- let transfrom = Cesium.Transforms.eastNorthUpToFixedFrame(pointA);
- const vector = Cesium.Cartesian3.subtract(
- pointB,
- pointA,
- new Cesium.Cartesian3()
- );
- let direction = Cesium.Matrix4.multiplyByPointAsVector(
- Cesium.Matrix4.inverse(transfrom, transfrom),
- vector,
- vector
- );
- Cesium.Cartesian3.normalize(direction, direction);
- return Cesium.Math.PI_OVER_TWO - Cesium.Math.acosClamped(direction.z);
- }
- updateViewShed() {
- this.clear();
- this.setLightCamera();
- this.addVisualPyramid();
- this.createFrustum();
- }
- clear() {
- if (this.pyramid) {
- this.viewer.entities.removeById(this.pyramid.id);
- this.pyramid = void 0;
- }
- if (this.frustumPrimitive) {
- this.viewer.scene.primitives.remove(this.frustumPrimitive);
- this.frustumPrimitive = void 0;
- }
- if (this.debugModelMatrixPrimitive) {
- this.viewer.scene.primitives.remove(this.debugModelMatrixPrimitive);
- this.debugModelMatrixPrimitive = void 0;
- }
- }
- addVisualPyramid() {
- let options2 = this.ViewShedOptions;
- let position2 = options2.viewPosition;
- let visualRange = Number(options2.visualRange);
- let transform3 = Cesium.Transforms.eastNorthUpToFixedFrame(position2);
- this.debugModelMatrixPrimitive = this.viewer.scene.primitives.add(
- new Cesium.DebugModelMatrixPrimitive({
- modelMatrix: transform3,
- length: 5
- })
- );
- const halfClock = options2.horizontalViewAngle / 2;
- const halfCone = options2.verticalViewAngle / 2;
- const pitch = Cesium.Math.toDegrees(options2.pitch);
- const ellipsoid = new Cesium.EllipsoidGraphics({
- radii: new Cesium.Cartesian3(visualRange, visualRange, visualRange),
- minimumClock: Cesium.Math.toRadians(90 - options2.direction - halfClock),
- maximumClock: Cesium.Math.toRadians(90 - options2.direction + halfClock),
- minimumCone: Cesium.Math.toRadians(90 - pitch - halfCone),
- maximumCone: Cesium.Math.toRadians(90 - pitch + halfCone),
- fill: false,
- outline: true,
- subdivisions: 256,
- stackPartitions: 64,
- slicePartitions: 64,
- outlineColor: Cesium.Color.YELLOWGREEN.withAlpha(0.5)
- });
- const pyramidEntity = new Cesium.Entity({
- position: position2,
- ellipsoid
- });
- this.pyramid = this.viewer.entities.add(pyramidEntity);
- }
- setLightCamera() {
- if (!this.lightCamera) {
- this.lightCamera = new Cesium.Camera(this.viewer.scene);
- }
- let options2 = this.ViewShedOptions;
- let visualRange = Number(options2.visualRange);
- this.lightCamera.position = options2.viewPosition;
- this.lightCamera.frustum.near = 0.1;
- this.lightCamera.frustum.far = visualRange;
- const hr = Cesium.Math.toRadians(options2.horizontalViewAngle);
- const vr = Cesium.Math.toRadians(options2.verticalViewAngle);
- this.lightCamera.frustum.aspectRatio = visualRange * Math.tan(hr / 2) * 2 / (visualRange * Math.tan(vr / 2) * 2);
- this.lightCamera.frustum.fov = hr > vr ? hr : vr;
- this.lightCamera.setView({
- destination: options2.viewPosition,
- orientation: {
- heading: Cesium.Math.toRadians(options2.direction || 0),
- pitch: options2.pitch || 0,
- roll: 0
- }
- });
- }
- createFrustum() {
- const scratchRight = new Cesium.Cartesian3();
- const scratchRotation = new Cesium.Matrix3();
- const scratchOrientation = new Cesium.Quaternion();
- const direction = this.lightCamera.directionWC;
- const up = this.lightCamera.upWC;
- let right = this.lightCamera.rightWC;
- right = Cesium.Cartesian3.negate(right, scratchRight);
- let rotation = scratchRotation;
- Cesium.Matrix3.setColumn(rotation, 0, right, rotation);
- Cesium.Matrix3.setColumn(rotation, 1, up, rotation);
- Cesium.Matrix3.setColumn(rotation, 2, direction, rotation);
- let orientation = Cesium.Quaternion.fromRotationMatrix(
- rotation,
- scratchOrientation
- );
- let instanceOutline = new Cesium.GeometryInstance({
- geometry: new Cesium.FrustumOutlineGeometry({
- frustum: this.lightCamera.frustum,
- origin: this.ViewShedOptions.viewPosition,
- orientation
- }),
- id: "\u89C6\u690E\u4F53\u8F6E\u5ED3\u7EBF" + Math.random().toString(36).substr(2),
- attributes: {
- color: Cesium.ColorGeometryInstanceAttribute.fromColor(
- new Cesium.Color(0, 1, 0, 1)
- ),
- show: new Cesium.ShowGeometryInstanceAttribute(true)
- }
- });
- this.frustumPrimitive = this.viewer.scene.primitives.add(
- new Cesium.Primitive({
- geometryInstances: instanceOutline,
- appearance: new Cesium.PerInstanceColorAppearance({
- flat: true,
- translucent: false,
- closed: true
- })
- })
- );
- }
- addViewershedPolygon(positionArr) {
- let polygon2 = new Cesium.PolygonGeometry({
- polygonHierarchy: new Cesium.PolygonHierarchy(
- Cesium.Cartesian3.fromDegreesArray(positionArr)
- ),
- height: 0,
- extrudedHeight: 0,
- vertexFormat: Cesium.PerInstanceColorAppearance.VERTEX_FORMAT,
- stRotation: 0,
- ellipsoid: Cesium.Ellipsoid.WGS84,
- granularity: Cesium.Math.RADIANS_PER_DEGREE,
- perPositionHeight: false,
- closeTop: true,
- closeBottom: true,
- arcType: Cesium.ArcType.GEODESIC
- });
- let polygonInstance = new Cesium.GeometryInstance({
- geometry: polygon2,
- name: "ViewershedPolygon",
- attributes: {
- color: Cesium.ColorGeometryInstanceAttribute.fromColor(
- Cesium.Color.BLUE.withAlpha(0.6)
- ),
- show: new Cesium.ShowGeometryInstanceAttribute(true)
- }
- });
- this.viewershedPolygon = this.viewer.scene.primitives.add(
- new Cesium.GroundPrimitive({
- geometryInstances: polygonInstance,
- appearance: new Cesium.EllipsoidSurfaceAppearance({
- aboveGround: true,
- material: new Cesium.Material({
- fabric: {
- type: "Image",
- uniforms: {
- image: this.returnImgae()
- }
- }
- })
- })
- })
- );
- }
- drawViewershed(precision) {
- const pos = this.cartesian3ToDegree(this.ViewShedOptions.viewPosition);
- const radius = this.ViewShedOptions.visualRange;
- const direction = this.ViewShedOptions.direction;
- let boundary = this.computeBoundaryOptions(pos, radius, direction);
- const bbox2 = boundary.bbox;
- let mask = polygon([boundary.boundaryPoints]);
- const dis = this.ViewShedOptions.visualRange / (precision * 1e3);
- let gridPoints = pointGrid(bbox2, dis, {
- mask
- });
- let pointsResult = this.createTargetPoints(gridPoints, dis, pos);
- let variogram = index.train(
- pointsResult.values,
- pointsResult.lngs,
- pointsResult.lats,
- "exponential",
- 0,
- 100
- );
- let grid2 = index.grid([boundary.boundaryPoints], variogram, dis / 1e3);
- const colors = [
- "#ff000080",
- "#ff000080",
- "#ff000080",
- "#ff000080",
- "#ff000080",
- "#ff000080",
- "#00ff0080",
- "#00ff0080",
- "#00ff0080",
- "#00ff0080",
- "#00ff0080",
- "#00ff0080"
- ];
- this.canvasEle.width = 3840;
- this.canvasEle.height = 2160;
- index.plot(
- this.canvasEle,
- grid2,
- [bbox2[0], bbox2[2]],
- [bbox2[1], bbox2[3]],
- colors
- );
- this.addViewershedPolygon(boundary.positionArr);
- }
- computeBoundaryOptions(pos, radius, angle) {
- let Ea = 6378137;
- let Eb = 6356725;
- const lng = pos[0], lat = pos[1];
- const bbox2 = [lng, lat, lng, lat];
- let positionArr = [];
- let boundaryPoints = [];
- positionArr.push(lng, lat);
- boundaryPoints.push([lng, lat]);
- let start2 = angle + 45 > 360 ? angle - 45 - 360 : angle - 45;
- let end = start2 + 90;
- for (let i2 = start2; i2 <= end; i2++) {
- let dx = radius * Math.sin(i2 * Math.PI / 180);
- let dy = radius * Math.cos(i2 * Math.PI / 180);
- let ec = Eb + (Ea - Eb) * (90 - lat) / 90;
- let ed = ec * Math.cos(lat * Math.PI / 180);
- let BJD = lng + dx / ed * 180 / Math.PI;
- let BWD = lat + dy / ec * 180 / Math.PI;
- positionArr.push(BJD, BWD);
- boundaryPoints.push([BJD, BWD]);
- this.refreshBBox(bbox2, BJD, BWD);
- }
- boundaryPoints.push([lng, lat]);
- return {
- positionArr,
- boundaryPoints,
- bbox: bbox2
- };
- }
- refreshBBox(result, x, y) {
- result[0] = x < result[0] ? x : result[0];
- result[1] = y < result[1] ? y : result[1];
- result[2] = x > result[2] ? x : result[2];
- result[3] = y > result[3] ? y : result[3];
- }
- createTargetPoints(gridPoints, step, sourcePos) {
- let positionArr = [];
- let objectsToExclude = [
- this.frustumPrimitive,
- this.pyramid,
- this.debugModelMatrixPrimitive
- ];
- let values3 = [], lngs = [], lats = [];
- let height2 = this.getHeight(sourcePos[0], sourcePos[1], objectsToExclude);
- positionArr.push({
- x: sourcePos[0],
- y: sourcePos[1],
- z: height2
- });
- let viewPoint = this.ViewShedOptions.viewPosition;
- for (let index2 = 0; index2 < gridPoints.features.length; index2++) {
- const feature2 = gridPoints.features[index2];
- const coords = feature2.geometry.coordinates;
- const x = coords[0], y = coords[1];
- let h2 = this.getHeight(x, y, objectsToExclude);
- let endPoint = Cesium.Cartesian3.fromDegrees(x, y, h2);
- let direction = Cesium.Cartesian3.normalize(
- Cesium.Cartesian3.subtract(
- endPoint,
- viewPoint,
- new Cesium.Cartesian3()
- ),
- new Cesium.Cartesian3()
- );
- let ray = new Cesium.Ray(viewPoint, direction);
- let result = this.viewer.scene.pickFromRay(ray, objectsToExclude);
- if (result) {
- let buffer = this.ReturnDistance(endPoint, result.position);
- if (buffer > step) {
- values3.push(0);
- } else {
- values3.push(1);
- }
- lngs.push(x);
- lats.push(y);
- }
- }
- return {
- values: values3,
- lngs,
- lats
- };
- }
- returnImgae() {
- return this.canvasEle.toDataURL("image/png");
- }
- }
- Object.assign(ViewShed.prototype, {
- createViewshed: function(precision) {
- let _self = this;
- let scene = _self.viewer.scene;
- _self.initHandler();
- _self.clearAll();
- let count = 0;
- let toolTip = "\u5DE6\u952E\u70B9\u51FB\u521B\u5EFA\u8D77\u70B9";
- _self.handler = new Cesium.ScreenSpaceEventHandler(_self.viewer.canvas);
- _self.handler.setInputAction((event2) => {
- count++;
- if (count === 1) {
- toolTip = "\u5DE6\u952E\u70B9\u51FB\u521B\u5EFA\u7EC8\u70B9";
- let earthPosition = scene.pickPosition(event2.position);
- let pos = _self.cartesian3ToDegree(earthPosition);
- _self.handler.setInputAction(function(move) {
- CreateRemindertip(toolTip, move.endPosition, true);
- let newPosition = scene.pickPosition(move.endPosition);
- if (Cesium.defined(newPosition)) {
- let pos1 = _self.cartesian3ToDegree(newPosition);
- let distance2 = Cesium.Cartesian3.distance(newPosition, earthPosition);
- let angle = _self.getAngle(pos[0], pos[1], pos1[0], pos1[1]);
- let pitch = _self.getPitch(earthPosition, newPosition);
- _self.ViewShedOptions = {
- viewPosition: earthPosition,
- endPosition: newPosition,
- direction: angle,
- pitch,
- horizontalViewAngle: 90,
- verticalViewAngle: 60,
- visibleAreaColor: Cesium.Color.GREEN,
- invisibleAreaColor: Cesium.Color.RED,
- visualRange: distance2
- };
- _self.updateViewShed();
- }
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- }
- if (count === 2) {
- _self.initHandler();
- _self.drawViewershed(precision);
- CreateRemindertip(toolTip, event2.endPosition, false);
- }
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- _self.handler.setInputAction(function(move) {
- CreateRemindertip(toolTip, move.endPosition, true);
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- },
- clearAll: function() {
- this.clear();
- if (this.viewershedPolygon) {
- this.viewer.scene.primitives.remove(this.viewershedPolygon);
- this.viewershedPolygon = void 0;
- }
- }
- });
- class SunshineShadow {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this._stopTime = null;
- }
- }
- Object.assign(SunshineShadow.prototype, {
- startSunShine(options2) {
- options2 = options2 || {};
- if (!Cesium.defined(options2.startTime)) {
- options2.startTime = new Date().getTime();
- }
- if (!Cesium.defined(options2.stopTime)) {
- options2.stopTime = new Date().getTime() + 1e3;
- }
- if (!Cesium.defined(options2.speed)) {
- options2.speed = 1600;
- }
- if (this._stopTime) {
- this._viewer.clock.shouldAnimate = true;
- this._viewer.clock.currentTime = this._stopTime;
- } else {
- this._viewer.scene.globe.enableLighting = true;
- this._viewer.shadows = true;
- this._viewer.clock.startTime = Cesium.JulianDate.fromDate(new Date(options2.startTime));
- this._viewer.clock.currentTime = Cesium.JulianDate.fromDate(new Date(options2.startTime));
- this._viewer.clock.stopTime = Cesium.JulianDate.fromDate(new Date(options2.stopTime));
- this._viewer.clock.clockRange = Cesium.ClockRange.LOOP_STOP;
- this._viewer.clock.clockStep = Cesium.ClockStep.SYSTEM_CLOCK_MULTIPLIER;
- this._viewer.clock.multiplier = options2.speed;
- this._viewer.clock.canAnimate = true;
- this._viewer.clock.shouldAnimate = true;
- }
- },
- stopSunShine() {
- this._stopTime = this._viewer.clock.currentTime;
- this._viewer.clock.shouldAnimate = false;
- },
- removeSunShine() {
- if (this._stopTime) {
- this._viewer.clock.shouldAnimate = true;
- this._viewer.clock.currentTime = this._stopTime;
- }
- this._viewer.scene.globe.enableLighting = false;
- this._viewer.shadows = false;
- this._stopTime = null;
- }
- });
- Object.assign(SunshineShadow.prototype, {
- start(options2) {
- if (document.getElementsByClassName("cesium-viewer-animationContainer").length > 0) {
- document.getElementsByClassName("cesium-viewer-animationContainer")[0].style.display = "block";
- }
- if (document.getElementsByClassName("cesium-viewer-timelineContainer").length > 0) {
- document.getElementsByClassName("cesium-viewer-timelineContainer")[0].style.display = "block";
- }
- this._viewer.shadows = true;
- options2 = options2 || {};
- if (!Cesium.defined(options2.startTime)) {
- options2.startTime = new Date(new Date().toLocaleDateString()).getTime();
- }
- if (!Cesium.defined(options2.stopTime)) {
- options2.stopTime = new Date(new Date().toLocaleDateString()).getTime() + 24 * 60 * 60 * 1e3 - 1;
- }
- if (!Cesium.defined(options2.speed)) {
- options2.speed = 1600;
- }
- let start2 = Cesium.JulianDate.fromDate(new Date(options2.startTime));
- let stop = Cesium.JulianDate.fromDate(new Date(options2.stopTime));
- viewer.timeline.zoomTo(start2, stop);
- let clock2 = viewer.clock;
- clock2.shouldAnimate = false;
- clock2.startTime = start2;
- clock2.stopTime = stop;
- clock2.currentTime = start2;
- clock2.clockRange = Cesium.ClockRange.UNBOUNDED;
- clock2.multiplier = options2.speed;
- },
- remove() {
- if (document.getElementsByClassName("cesium-viewer-animationContainer").length > 0) {
- document.getElementsByClassName("cesium-viewer-animationContainer")[0].style.display = "none";
- }
- if (document.getElementsByClassName("cesium-viewer-timelineContainer").length > 0) {
- document.getElementsByClassName("cesium-viewer-timelineContainer")[0].style.display = "none";
- }
- this._viewer.shadows = false;
- this._viewer.clock.currentTime = Cesium.JulianDate.fromDate(new Date(new Date().getTime()));
- this._viewer.clock.shouldAnimate = false;
- }
- });
- class Profile {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this._profileEntities = [];
- }
- _interPoints(positions, objectsToExclude) {
- let positionsCartographic = [];
- let terrainSamplePositions = [];
- for (let index2 = 0; index2 < positions.length; index2++) {
- const element = positions[index2];
- let ellipsoid = this._viewer.scene.globe.ellipsoid;
- let cartographic = ellipsoid.cartesianToCartographic(element);
- positionsCartographic.push(cartographic);
- }
- for (let i2 = 0; i2 < positionsCartographic.length; i2++) {
- const m_Cartographic0 = positionsCartographic[i2];
- const m_Cartographic1 = positionsCartographic[i2 + 1];
- if (m_Cartographic1) {
- let a = Math.abs(m_Cartographic0.longitude - m_Cartographic1.longitude) * 1e7;
- let b = Math.abs(m_Cartographic0.latitude - m_Cartographic1.latitude) * 1e7;
- if (a > b)
- b = a;
- let length = parseInt(b / 2);
- if (length > 1e3)
- length = 1e3;
- if (length < 2)
- length = 2;
- for (let j = 0; j < length; j++) {
- terrainSamplePositions.push(
- new Cesium.Cartographic(
- Cesium.Math.lerp(
- m_Cartographic0.longitude,
- m_Cartographic1.longitude,
- j / (length - 1)
- ),
- Cesium.Math.lerp(
- m_Cartographic0.latitude,
- m_Cartographic1.latitude,
- j / (length - 1)
- )
- )
- );
- }
- terrainSamplePositions.pop();
- } else {
- terrainSamplePositions.push(m_Cartographic0);
- }
- }
- let positions_Inter = [];
- let distance2 = 0;
- for (let n = 0; n < terrainSamplePositions.length; n++) {
- let curCartographic = terrainSamplePositions[n];
- let height2 = this._viewer.scene.sampleHeight(curCartographic, objectsToExclude);
- const lon = curCartographic.longitude / Math.PI * 180;
- const lat = curCartographic.latitude / Math.PI * 180;
- let point2 = Cesium.Cartesian3.fromDegrees(lon, lat, height2);
- let preCartographic = terrainSamplePositions[n - 1];
- if (preCartographic) {
- const lon1 = preCartographic.longitude / Math.PI * 180;
- const lat1 = preCartographic.latitude / Math.PI * 180;
- let point1 = Cesium.Cartesian3.fromDegrees(lon1, lat1, height2);
- let curDis = Cesium.Cartesian3.distance(point1, point2);
- distance2 += curDis;
- }
- positions_Inter.push({
- position: {
- lon,
- lat,
- height: height2
- },
- distance: distance2
- });
- }
- return positions_Inter;
- }
- }
- Object.assign(Profile.prototype, {
- startProfileAnalysis(points2, entity) {
- return new Promise((resolve2, reject2) => {
- let _self = this;
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- _self.removeProfileAnalysis();
- entity.clampToGround = true;
- let pointsList = _self._interPoints(positions, [entity]);
- resolve2(pointsList);
- });
- },
- removeProfileAnalysis() {
- let _self = this;
- if (_self._profileEntities && _self._profileEntities.length > 0) {
- _self._profileEntities.forEach((element) => {
- _self._viewer.entities.remove(element);
- });
- }
- _self._profileEntities = [];
- }
- });
- class CutFill {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this.delEntitys = [];
- this.maxHeigh = -1e6;
- }
- _VolumeAnalysis(options2) {
- let _self = this;
- let cutArea = 0, cutVolume = 0, fillArea = 0, fillVolume = 0;
- const indices = options2.geom.indices;
- const positions = options2.geom.attributes.position.values;
- for (let index2 = 0; index2 < indices.length; index2 += 3) {
- const pos0 = _self._returnPosition(positions, indices[index2]);
- const pos1 = _self._returnPosition(positions, indices[index2 + 1]);
- const pos2 = _self._returnPosition(positions, indices[index2 + 2]);
- let _entities = _self._viewer.entities.add({
- name: "\u4E09\u89D2\u9762",
- polygon: {
- hierarchy: [pos0.heightPos, pos1.heightPos, pos2.heightPos],
- perPositionHeight: true,
- material: Cesium.Color.fromRandom(),
- extrudedHeight: options2.height,
- outline: true,
- outlineColor: Cesium.Color.BLACK
- }
- });
- _self.delEntitys.push(_entities);
- const area = _self._computeArea4Triangle(
- pos0.noHeightPos,
- pos1.noHeightPos,
- pos2.noHeightPos
- );
- const height2 = (pos0.height + pos1.height + pos2.height) / 3;
- if (height2 < options2.height) {
- fillArea += area;
- const volume = area * (options2.height - height2);
- fillVolume += volume;
- } else {
- cutArea += area;
- const volume = area * (height2 - options2.height);
- cutVolume += volume;
- }
- }
- let allArea = cutArea + fillArea;
- allArea = allArea.toFixed(2);
- cutArea = cutArea.toFixed(2);
- cutVolume = cutVolume.toFixed(2);
- fillArea = fillArea.toFixed(2);
- fillVolume = fillVolume.toFixed(2);
- let result = {
- allArea,
- cutArea,
- cutVolume,
- fillArea,
- fillVolume
- };
- return result;
- }
- _computeArea4Triangle(pos1, pos2, pos3) {
- let a = Cesium.Cartesian3.distance(pos1, pos2);
- let b = Cesium.Cartesian3.distance(pos2, pos3);
- let c = Cesium.Cartesian3.distance(pos3, pos1);
- let S = (a + b + c) / 2;
- return Math.sqrt(S * (S - a) * (S - b) * (S - c));
- }
- _returnPosition(positions, index2) {
- let cartesian = new Cesium.Cartesian3(
- positions[index2 * 3],
- positions[index2 * 3 + 1],
- positions[index2 * 3 + 2]
- );
- let cartographic = Cesium.Cartographic.fromCartesian(cartesian);
- let height2 = this._viewer.scene.sampleHeightSupported ? this._viewer.scene.sampleHeight(cartographic) : this._viewer.scene.globe.getHeight(cartographic);
- if (height2 > this.maxHeigh) {
- this.maxHeigh = height2;
- }
- return {
- heightPos: Cesium.Cartesian3.fromRadians(cartographic.longitude, cartographic.latitude, height2),
- noHeightPos: Cesium.Cartesian3.fromRadians(cartographic.longitude, cartographic.latitude, 0),
- height: height2
- };
- }
- }
- Object.assign(CutFill.prototype, {
- createPolygonGeo(points2, options2) {
- return new Promise((resolve2, reject2) => {
- let _self = this;
- options2 = options2 || {};
- options2.precision = Cesium.defaultValue(options2.precision, 256);
- options2.height = Cesium.defaultValue(options2.height, 10);
- _self.remove();
- let positions = [];
- for (let i2 = 0; i2 < points2.length; i2++) {
- if (points2[i2] instanceof Cesium.Cartesian3) {
- positions.push(points2[i2]);
- } else {
- positions.push(Cesium.Cartesian3.fromDegrees(points2[i2][0], points2[i2][1], points2[i2][1] || 0));
- }
- }
- let granularity = Math.PI / Math.pow(2, 11);
- granularity = granularity / options2.precision;
- let polygonGeometry = new Cesium.PolygonGeometry.fromPositions({
- positions,
- vertexFormat: Cesium.PerInstanceColorAppearance.FLAT_VERTEX_FORMAT,
- granularity
- });
- options2.geom = new Cesium.PolygonGeometry.createGeometry(polygonGeometry);
- let result = _self._VolumeAnalysis(options2);
- _self._viewer.scene.globe.baseColor = new Cesium.Color(1, 1, 1, 0.9);
- _self._viewer.scene.screenSpaceCameraController.enableCollisionDetection = false;
- _self._viewer.scene.globe.translucency.enabled = true;
- resolve2(result);
- });
- },
- remove() {
- for (var i2 = 0; i2 < this.delEntitys.length; i2++) {
- this._viewer.entities.remove(this.delEntitys[i2]);
- }
- this._viewer.scene.screenSpaceCameraController.enableCollisionDetection = true;
- this._viewer.scene.globe.translucency.enabled = false;
- }
- });
- class HeightLimit {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this.targetY = 0;
- }
- _setPolygon(options2) {
- let _self = this;
- _self.HiePolygon = _self._viewer.entities.add({
- polygon: {
- hierarchy: new Cesium.PolygonHierarchy(_self.data),
- material: _self._handleColor("#FFF8DC", options2.alpha),
- height: new Cesium.CallbackProperty(_self._createPolygonUpdateFunction(), false),
- perPositionHeight: false,
- outline: true,
- outlineColor: _self._handleColor("red", options2.alpha),
- outlineWidth: 1
- }
- });
- }
- _createPolygonUpdateFunction() {
- let _self = this;
- return function() {
- return _self.targetY;
- };
- }
- _handleColor(color2, alpha) {
- return Cesium.Color.fromCssColorString(color2).withAlpha(alpha || 1);
- }
- _getMinHeight(points2) {
- let height2 = 0;
- points2.map((point2) => {
- let _height = point2[2] || 0;
- height2 = _height;
- if (_height < height2) {
- height2 = _height;
- }
- });
- return height2;
- }
- }
- Object.assign(HeightLimit.prototype, {
- addPrimitive(points2, options2) {
- this.removePrimitive();
- options2 = options2 || {};
- options2.height = Cesium.defaultValue(options2.height, 50);
- options2.baseHeight = Cesium.defaultValue(options2.baseHeight, 50);
- options2.color = Cesium.defaultValue(options2.color, "red");
- options2.alpha = Cesium.defaultValue(options2.alpha, 0.6);
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- let _self = this;
- _self.data = positions;
- _self.baseHeight = options2.baseHeight;
- _self.targetY = options2.baseHeight + options2.height;
- let polygonInstance = new Cesium.GeometryInstance({
- geometry: new Cesium.PolygonGeometry({
- polygonHierarchy: new Cesium.PolygonHierarchy(_self.data),
- height: _self.baseHeight,
- extrudedHeight: _self.baseHeight + 3e3
- }),
- attributes: {
- color: Cesium.ColorGeometryInstanceAttribute.fromColor(
- Cesium.Color.fromCssColorString(options2.color).withAlpha(options2.alpha)
- ),
- show: new Cesium.ShowGeometryInstanceAttribute(true)
- }
- });
- _self.limitHeightPrimitive = _self._viewer.scene.primitives.add(
- new Cesium.ClassificationPrimitive({
- geometryInstances: polygonInstance,
- releaseGeometryInstances: false,
- classificationType: Cesium.ClassificationType.CESIUM_3D_TILE
- })
- );
- _self._setPolygon(options2);
- },
- removePrimitive() {
- if (this.HiePolygon) {
- this._viewer.entities.remove(this.HiePolygon);
- }
- if (this.limitHeightPrimitive) {
- this._viewer.scene.primitives.remove(this.limitHeightPrimitive);
- }
- },
- changeHeight(height2) {
- if (!this.limitHeightPrimitive)
- return;
- this.targetY = this.baseHeight + height2;
- let cartographic = Cesium.Cartographic.fromCartesian(this.limitHeightPrimitive._primitive._boundingSpheres[0].center);
- let surface = Cesium.Cartesian3.fromRadians(cartographic.longitude, cartographic.latitude, this.baseHeight);
- let offset = Cesium.Cartesian3.fromRadians(cartographic.longitude, cartographic.latitude, this.baseHeight + height2);
- let translation = Cesium.Cartesian3.subtract(offset, surface, new Cesium.Cartesian3());
- this.limitHeightPrimitive._primitive.modelMatrix = Cesium.Matrix4.fromTranslation(translation);
- }
- });
- class Cutting {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this._camera = this._viewer.camera;
- this._scene = this._viewer.scene;
- this.targetY = 0;
- this._mouseHandler();
- }
- _mouseHandler() {
- let _self = this;
- let viewer2 = _self._viewer;
- let scene = _self._scene;
- let selectedPlane;
- let downHandler = new Cesium.ScreenSpaceEventHandler(viewer2.scene.canvas);
- downHandler.setInputAction(function(movement) {
- let pickedObject = scene.pick(movement.position);
- if (Cesium.defined(pickedObject) && Cesium.defined(pickedObject.id) && Cesium.defined(pickedObject.id.plane)) {
- selectedPlane = pickedObject.id.plane;
- selectedPlane.material = Cesium.Color.RED.withAlpha(0.05);
- selectedPlane.outlineColor = Cesium.Color.RED;
- scene.screenSpaceCameraController.enableInputs = false;
- }
- }, Cesium.ScreenSpaceEventType.LEFT_DOWN);
- let upHandler = new Cesium.ScreenSpaceEventHandler(viewer2.scene.canvas);
- upHandler.setInputAction(function() {
- if (Cesium.defined(selectedPlane)) {
- selectedPlane.material = Cesium.Color.RED.withAlpha(0.1);
- selectedPlane.outlineColor = Cesium.Color.RED;
- selectedPlane = void 0;
- }
- scene.screenSpaceCameraController.enableInputs = true;
- }, Cesium.ScreenSpaceEventType.LEFT_UP);
- let moveHandler = new Cesium.ScreenSpaceEventHandler(viewer2.scene.canvas);
- moveHandler.setInputAction(function(movement) {
- if (Cesium.defined(selectedPlane)) {
- let deltaY = movement.startPosition.y - movement.endPosition.y;
- _self.targetY += deltaY;
- }
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- }
- _createPlaneUpdateFunction(plane) {
- let _self = this;
- return function() {
- plane.distance = _self.targetY;
- return plane;
- };
- }
- _createPlane(p1, p2, inverseTransform) {
- let _self = this;
- let p1C3 = _self._getOriginCoordinateSystemPoint(p1, inverseTransform);
- let p2C3 = _self._getOriginCoordinateSystemPoint(p2, inverseTransform);
- let up = new Cesium.Cartesian3(0, 0, 10);
- let right = Cesium.Cartesian3.subtract(p2C3, p1C3, new Cesium.Cartesian3());
- let normal = Cesium.Cartesian3.cross(right, up, new Cesium.Cartesian3());
- normal = Cesium.Cartesian3.normalize(normal, normal);
- let planeTmp = Cesium.Plane.fromPointNormal(p1C3, normal);
- return Cesium.ClippingPlane.fromPlane(planeTmp);
- }
- _getOriginCoordinateSystemPoint(point2, inverseTransform) {
- let val = Cesium.Cartesian3.fromDegrees(point2[0], point2[1]);
- return Cesium.Matrix4.multiplyByPoint(
- inverseTransform,
- val,
- new Cesium.Cartesian3(0, 0, 0)
- );
- }
- _getInverseTransform(tileSet) {
- let transform3;
- const tmp = tileSet.root.transform;
- if (tmp && tmp.equals(Cesium.Matrix4.IDENTITY) || !tmp) {
- transform3 = Cesium.Transforms.eastNorthUpToFixedFrame(tileSet.boundingSphere.center);
- } else {
- transform3 = Cesium.Matrix4.fromArray(tileSet.root.transform);
- }
- return Cesium.Matrix4.inverseTransformation(transform3, new Cesium.Matrix4());
- }
- _isDirRes(polygon2, isClockwise) {
- var lineStringList = [];
- polygon2.forEach((p) => {
- lineStringList.push([p.lng, p.lat]);
- });
- var clockwiseRing = lineString(lineStringList);
- let isR = booleanClockwise(clockwiseRing);
- var points2 = [];
- if (isClockwise) {
- if (!isR) {
- points2 = polygon2;
- } else {
- var count = 0;
- for (var ii = polygon2.length - 1; ii >= 0; ii--) {
- points2[count] = polygon2[ii];
- count++;
- }
- }
- } else {
- if (isR) {
- points2 = polygon2;
- } else {
- var count = 0;
- for (var ii = polygon2.length - 1; ii >= 0; ii--) {
- points2[count] = polygon2[ii];
- count++;
- }
- }
- }
- return points2;
- }
- }
- Object.assign(Cutting.prototype, {
- activate(tileset) {
- let _self = this;
- let viewer2 = _self._viewer;
- let inverseTransform = _self._getInverseTransform(tileset);
- const clippingPlanes1 = [];
- clippingPlanes1.push(_self._createPlane([121.55814450142213, 37.39658788787028], [121.65814450142213, 37.49658788787028], inverseTransform));
- let clippingPlanes = new Cesium.ClippingPlaneCollection({
- planes: [
- new Cesium.ClippingPlane(
- new Cesium.Cartesian3(0, 1, 0),
- -10
- )
- ],
- edgeWidth: 1
- });
- _self.tileset = tileset;
- tileset.clippingPlanes = clippingPlanes;
- tileset.debugShowBoundingVolume = false;
- return tileset.readyPromise.then(function() {
- let boundingSphere = tileset.boundingSphere;
- let radius = boundingSphere.radius;
- viewer2.zoomTo(
- tileset,
- new Cesium.HeadingPitchRange(0.5, -0.2, radius / 5)
- );
- if (!Cesium.Matrix4.equals(
- tileset.root.transform,
- Cesium.Matrix4.IDENTITY
- )) {
- const transformCenter = Cesium.Matrix4.getTranslation(tileset.root.transform, new Cesium.Cartesian3());
- const transformCartographic = Cesium.Cartographic.fromCartesian(transformCenter);
- const boundingSphereCartographic = Cesium.Cartographic.fromCartesian(tileset.boundingSphere.center);
- const height2 = boundingSphereCartographic.height - transformCartographic.height;
- clippingPlanes.modelMatrix = Cesium.Matrix4.fromTranslation(new Cesium.Cartesian3(0, 0, height2));
- }
- for (let i2 = 0; i2 < clippingPlanes.length; ++i2) {
- const plane = clippingPlanes.get(i2);
- viewer2.entities.add({
- position: boundingSphere.center,
- plane: {
- dimensions: new Cesium.Cartesian2(
- radius / 10,
- radius / 10
- ),
- material: Cesium.Color.WHITE.withAlpha(0.1),
- plane: new Cesium.CallbackProperty(
- _self._createPlaneUpdateFunction(plane),
- false
- ),
- outline: true,
- outlineColor: Cesium.Color.WHITE
- }
- });
- }
- return tileset;
- });
- },
- addTiles(my3dtiles, pointsArray) {
- let _self = this;
- let viewer2 = _self._viewer;
- let tileset = my3dtiles;
- _self.polygon = pointsArray;
- _self.tileset = tileset;
- return tileset.readyPromise.then(function() {
- let inverseTransform = _self._getInverseTransform(tileset);
- _self.polygon = _self._isDirRes(_self.polygon, false);
- const clippingPlanes1 = [];
- for (let i2 = 0; i2 < _self.polygon.length; i2++) {
- if (i2 === _self.polygon.length - 1) {
- clippingPlanes1.push(_self._createPlane(_self.polygon[i2], _self.polygon[0], inverseTransform));
- } else {
- clippingPlanes1.push(_self._createPlane(_self.polygon[i2], _self.polygon[i2 + 1], inverseTransform));
- }
- }
- let clippingPlanes = new Cesium.ClippingPlaneCollection({
- planes: clippingPlanes1,
- edgeWidth: 1,
- edgeColor: Cesium.Color.RED,
- unionClippingRegions: false
- });
- _self.clippingPlanes = clippingPlanes;
- tileset.clippingPlanes = clippingPlanes;
- tileset.debugShowBoundingVolume = false;
- let boundingSphere = tileset.boundingSphere;
- let radius = boundingSphere.radius;
- for (let i2 = 0; i2 < clippingPlanes.length; ++i2) {
- let plane = clippingPlanes.get(i2);
- viewer2.entities.add({
- position: boundingSphere.center,
- plane: {
- dimensions: new Cesium.Cartesian2(
- radius / 10,
- radius / 10
- ),
- material: Cesium.Color.RED.withAlpha(0.1),
- plane: new Cesium.CallbackProperty(
- _self._createPlaneUpdateFunction(plane),
- false
- ),
- outline: true,
- outlineColor: Cesium.Color.RED
- }
- });
- }
- return tileset;
- });
- },
- addTiles2(my3dtiles, pointsArray) {
- let _self = this;
- _self._viewer;
- let tileset = my3dtiles;
- _self.polygon = pointsArray;
- _self.tileset = tileset;
- Cesium.Matrix4.fromArray(
- [
- 1,
- 5551115123125783e-31,
- 5898416033378595e-24,
- 0,
- -6106226635438361e-31,
- 1,
- -11355608731111744e-24,
- 0,
- -5898416061134171e-24,
- 11355608731111744e-24,
- 0.9999999999999999,
- 0,
- 9.912469893228263,
- -19.08345020748675,
- -14.613607150502503,
- 1
- ]
- );
- let transform3 = Cesium.Matrix4.fromArray(
- [
- -0.8874246461620654,
- -0.46095281470464317,
- 0,
- 0,
- 0.2602796082288922,
- -0.5010893346724129,
- 0.8253266045740758,
- 0,
- -0.3804366214290463,
- 0.7324151700322881,
- 0.5646556435405804,
- 0,
- -2429070591483741e-9,
- 467643767731705e-8,
- 3581165448379543e-9,
- 1
- ]
- );
- let inverseTransform = Cesium.Matrix4.inverseTransformation(transform3, new Cesium.Matrix4());
- let clippingPlanes1 = [];
- for (let i2 = 0; i2 < _self.polygon.length - 1; i2++) {
- let plane = _self.createPlane(_self.polygon[i2], _self.polygon[i2 + 1], inverseTransform);
- clippingPlanes1.push(plane);
- }
- let clippingPlanes = new Cesium.ClippingPlaneCollection({
- planes: clippingPlanes1,
- edgeWidth: 1,
- edgeColor: Cesium.Color.RED,
- unionClippingRegions: false
- });
- _self.clippingPlanes = clippingPlanes;
- return tileset.readyPromise.then(function() {
- tileset.clippingPlanes = clippingPlanes;
- tileset.debugShowBoundingVolume = false;
- let boundingSphere = tileset.boundingSphere;
- boundingSphere.radius;
- return tileset;
- });
- },
- toggleClipping() {
- let _self = this;
- _self.tileset = null;
- }
- });
- class GeologyClipPlan {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this._camera = this._viewer.camera;
- this._scene = this._viewer.scene;
- this.tileset = void 0;
- this.targetY = 0;
- this.planeEntities = [];
- this._mouseHandler();
- }
- _mouseHandler() {
- let _self = this;
- let viewer2 = _self._viewer;
- let scene = _self._scene;
- let selectedPlane;
- let downHandler = new Cesium.ScreenSpaceEventHandler(viewer2.scene.canvas);
- downHandler.setInputAction(function(movement) {
- let pickedObject = scene.pick(movement.position);
- if (Cesium.defined(pickedObject) && Cesium.defined(pickedObject.id) && Cesium.defined(pickedObject.id.plane)) {
- selectedPlane = pickedObject.id.plane;
- selectedPlane.material = Cesium.Color.RED.withAlpha(0.05);
- selectedPlane.outlineColor = Cesium.Color.RED;
- scene.screenSpaceCameraController.enableInputs = false;
- }
- }, Cesium.ScreenSpaceEventType.LEFT_DOWN);
- let upHandler = new Cesium.ScreenSpaceEventHandler(viewer2.scene.canvas);
- upHandler.setInputAction(function() {
- if (Cesium.defined(selectedPlane)) {
- selectedPlane.material = Cesium.Color.RED.withAlpha(0.1);
- selectedPlane.outlineColor = Cesium.Color.RED;
- selectedPlane = void 0;
- }
- scene.screenSpaceCameraController.enableInputs = true;
- }, Cesium.ScreenSpaceEventType.LEFT_UP);
- let moveHandler = new Cesium.ScreenSpaceEventHandler(viewer2.scene.canvas);
- moveHandler.setInputAction(function(movement) {
- if (Cesium.defined(selectedPlane)) {
- let deltaY = movement.startPosition.y - movement.endPosition.y;
- _self.targetY += deltaY;
- }
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- }
- _createPlaneUpdateFunction(plane) {
- let _self = this;
- return function() {
- plane.distance = _self.targetY;
- return plane;
- };
- }
- }
- Object.assign(GeologyClipPlan.prototype, {
- activate(tileset, options2) {
- let _self = this;
- let viewer2 = _self._viewer;
- let distance2 = 1e5;
- let clippingPlanes = new Cesium.ClippingPlaneCollection({
- planes: [
- new Cesium.ClippingPlane(
- new Cesium.Cartesian3(0, 0, -1),
- distance2
- )
- ],
- edgeWidth: 1
- });
- _self.tileset = tileset;
- tileset.clippingPlanes = clippingPlanes;
- tileset.debugShowBoundingVolume = false;
- return tileset.readyPromise.then(function() {
- let boundingSphere = tileset.boundingSphere;
- let radius = boundingSphere.radius;
- if (!Cesium.Matrix4.equals(
- tileset.root.transform,
- Cesium.Matrix4.IDENTITY
- )) {
- const transformCenter = Cesium.Matrix4.getTranslation(
- tileset.root.transform,
- new Cesium.Cartesian3()
- );
- const transformCartographic = Cesium.Cartographic.fromCartesian(
- transformCenter
- );
- const boundingSphereCartographic = Cesium.Cartographic.fromCartesian(
- tileset.boundingSphere.center
- );
- const height2 = boundingSphereCartographic.height - transformCartographic.height;
- clippingPlanes.modelMatrix = Cesium.Matrix4.fromTranslation(new Cesium.Cartesian3(0, 0, height2));
- }
- viewer2.zoomTo(
- tileset,
- new Cesium.HeadingPitchRange(0.5, -0.2, radius / 10)
- );
- let cartographic = Cesium.Cartographic.fromCartesian(boundingSphere.center);
- let lng = Cesium.Math.toDegrees(cartographic.longitude);
- let lat = Cesium.Math.toDegrees(cartographic.latitude);
- cartographic.height;
- var Cartesian33 = Cesium.Cartesian3.fromDegrees(lng, lat, 105);
- for (let i2 = 0; i2 < clippingPlanes.length; ++i2) {
- let plane = clippingPlanes.get(i2);
- let planeEntity = viewer2.entities.add({
- position: Cartesian33,
- plane: {
- dimensions: new Cesium.Cartesian2(
- radius / 10,
- radius / 20
- ),
- material: Cesium.Color.RED.withAlpha(0.1),
- plane: new Cesium.CallbackProperty(
- _self._createPlaneUpdateFunction(plane),
- false
- ),
- outline: true,
- outlineColor: Cesium.Color.RED
- }
- });
- _self.planeEntities.push(planeEntity);
- }
- return tileset;
- });
- },
- toggleClipping() {
- let _self = this;
- for (let i2 = 0; i2 < _self.planeEntities.length; i2++) {
- _self._viewer.entities.remove(_self.planeEntities[i2]);
- }
- _self.planeEntities = [];
- _self.targetY = 0;
- let boundingSphere = _self.tileset.boundingSphere;
- _self._camera.viewBoundingSphere(boundingSphere, new Cesium.HeadingPitchRange(Cesium.Math.toRadians(120), Cesium.Math.toRadians(-10), boundingSphere.radius * 2.5));
- _self._camera.lookAtTransform(Cesium.Matrix4.IDENTITY);
- },
- reset() {
- this.planeEntities = [];
- this.targetY = 0;
- }
- });
- let SpatialAnalysis = {
- SightLine,
- ViewShed,
- SunshineShadow,
- Profile,
- CutFill,
- HeightLimit,
- Cutting,
- GeologyClipPlan
- };
- class TerrainExcavation {
- constructor(viewer2) {
- if (!viewer2)
- throw new Error("no viewer object!");
- this.viewer = viewer2;
- }
- prepareWell(activePoints) {
- let pointLength = activePoints.length;
- let heightDiff = this.excavateMinHeight - this.height;
- let no_height_top = [], bottom_pos = [], lerp_pos = [];
- for (let l = 0; l < pointLength; l++) {
- let u = l == pointLength - 1 ? 0 : l + 1;
- let point0 = [
- Cesium.Cartographic.fromCartesian(activePoints[l]).longitude,
- Cesium.Cartographic.fromCartesian(activePoints[l]).latitude
- ];
- let point1 = [
- Cesium.Cartographic.fromCartesian(activePoints[u]).longitude,
- Cesium.Cartographic.fromCartesian(activePoints[u]).latitude
- ];
- if (0 == l) {
- lerp_pos.push(new Cesium.Cartographic(point0[0], point0[1]));
- bottom_pos.push(
- Cesium.Cartesian3.fromRadians(point0[0], point0[1], heightDiff)
- );
- no_height_top.push(
- Cesium.Cartesian3.fromRadians(point0[0], point0[1], 0)
- );
- }
- for (let p = 1; p <= this.splitNum; p++) {
- let m = Cesium.Math.lerp(point0[0], point1[0], p / this.splitNum);
- let g = Cesium.Math.lerp(point0[1], point1[1], p / this.splitNum);
- l == pointLength - 1 && p == this.splitNum || (lerp_pos.push(new Cesium.Cartographic(m, g)), bottom_pos.push(Cesium.Cartesian3.fromRadians(m, g, heightDiff)), no_height_top.push(Cesium.Cartesian3.fromRadians(m, g, 0)));
- }
- }
- this.wellData = {
- lerp_pos,
- bottom_pos,
- no_height_top
- };
- }
- createWell(wallData) {
- let $this = this;
- if (this.viewer.terrainProvider._layers) {
- this.createBottomSurface(wallData.bottom_pos);
- let positions = Cesium.sampleTerrainMostDetailed(
- this.viewer.terrainProvider,
- wallData.lerp_pos
- );
- positions.then(function(pos) {
- let positionList = [];
- for (let index2 = 0; index2 < pos.length; index2++) {
- const element = pos[index2];
- let curPos = Cesium.Cartesian3.fromRadians(
- element.longitude,
- element.latitude,
- element.height
- );
- positionList.push(curPos);
- }
- $this.createWellWall(wallData.bottom_pos, positionList);
- });
- } else {
- this.createBottomSurface(wallData.bottom_pos);
- this.createWellWall(wallData.bottom_pos, wallData.no_height_top);
- }
- }
- ellipsoidToDegree(pos) {
- let cartesian3 = new Cesium.Cartesian3(pos.x, pos.y, pos.z);
- let cartographic = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian3);
- return {
- longitude: Cesium.Math.toDegrees(cartographic.longitude),
- latitude: Cesium.Math.toDegrees(cartographic.latitude),
- altitude: cartographic.height
- };
- }
- createBottomSurface(points2) {
- if (points2.length) {
- let minHeight = this.getMinHeight(points2);
- let positions = [];
- for (let i2 = 0; i2 < points2.length; i2++) {
- let curPoint = this.ellipsoidToDegree(points2[i2]);
- positions.push(curPoint.longitude, curPoint.latitude, minHeight);
- }
- let polygon2 = new Cesium.PolygonGeometry({
- polygonHierarchy: new Cesium.PolygonHierarchy(
- Cesium.Cartesian3.fromDegreesArrayHeights(positions)
- ),
- perPositionHeight: true
- });
- let material = new Cesium.Material({
- fabric: {
- type: "Image",
- uniforms: {
- image: this.bottomImg
- }
- }
- });
- let appearance = new Cesium.MaterialAppearance({
- translucent: false,
- flat: true,
- material
- });
- this.bottomSurface = new Cesium.Primitive({
- geometryInstances: new Cesium.GeometryInstance({
- geometry: Cesium.PolygonGeometry.createGeometry(polygon2)
- }),
- appearance,
- asynchronous: false
- });
- this.viewer.scene.primitives.add(this.bottomSurface);
- }
- }
- createWellWall(bottomPos, positionList) {
- let minHeight = this.getMinHeight(bottomPos);
- let maxHeights = [], minHeights = [];
- for (let i2 = 0; i2 < positionList.length; i2++) {
- maxHeights.push(this.ellipsoidToDegree(positionList[i2]).altitude);
- minHeights.push(minHeight);
- }
- let wall = new Cesium.WallGeometry({
- positions: positionList,
- maximumHeights: maxHeights,
- minimumHeights: minHeights
- });
- let geometry2 = Cesium.WallGeometry.createGeometry(wall);
- let material = new Cesium.Material({
- fabric: {
- type: "Image",
- uniforms: {
- image: this.wallImg
- }
- }
- });
- let appearance = new Cesium.MaterialAppearance({
- translucent: false,
- flat: true,
- material
- });
- this.wellWall = new Cesium.Primitive({
- geometryInstances: new Cesium.GeometryInstance({
- geometry: geometry2,
- attributes: {
- color: Cesium.ColorGeometryInstanceAttribute.fromColor(
- Cesium.Color.GREY
- )
- },
- id: "PitWall"
- }),
- appearance,
- asynchronous: false
- });
- this.viewer.scene.primitives.add(this.wellWall);
- }
- getMinHeight(points2) {
- let minHeight = 5e6;
- let minPoint = null;
- for (let i2 = 0; i2 < points2.length; i2++) {
- let height2 = points2[i2]["z"];
- if (height2 < minHeight) {
- minHeight = height2;
- minPoint = this.ellipsoidToDegree(points2[i2]);
- }
- }
- return minPoint.altitude;
- }
- switchExcavate(show) {
- if (show) {
- this.viewer.scene.globe.material = null;
- this.wellWall.show = true;
- this.bottomSurface.show = true;
- } else {
- this.viewer.scene.globe.material = null;
- this.wellWall.show = false;
- this.bottomSurface.show = false;
- }
- }
- updateExcavateDepth(height2) {
- this.viewer.scene.primitives.remove(this.bottomSurface);
- this.viewer.scene.primitives.remove(this.wellWall);
- let lerp_pos = this.wellData.lerp_pos;
- let posList = [];
- for (let n = 0; n < lerp_pos.length; n++) {
- posList.push(
- Cesium.Cartesian3.fromRadians(
- lerp_pos[n].longitude,
- lerp_pos[n].latitude,
- this.excavateMinHeight - height2
- )
- );
- }
- this.wellData.bottom_pos = posList;
- this.createWell(this.wellData);
- }
- }
- Object.defineProperties(TerrainExcavation.prototype, {
- show: {
- get: function() {
- return this._show;
- },
- set: function(e) {
- this._show = e;
- this.switchExcavate(e);
- }
- },
- height: {
- get: function() {
- return this._height;
- },
- set: function(e) {
- this._height = e;
- this.updateExcavateDepth(e);
- }
- }
- });
- Object.assign(TerrainExcavation.prototype, {
- add(activePoints, options2) {
- options2 = options2 || {};
- this._height = options2.excavateDepth || 10;
- this.bottomImg = options2.bottomImg || "jt3dSDK/imgs/polygon/ground.png";
- this.wallImg = options2.wallImg || "jt3dSDK/imgs/polygon/ground.png";
- this.splitNum = Cesium.defaultValue(options2.splitNum, 50);
- activePoints = activePoints.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- let viewer2 = this.viewer;
- this.clear();
- let clippingPlanesList = [];
- let car3Difference = Cesium.Cartesian3.subtract(
- activePoints[0],
- activePoints[1],
- new Cesium.Cartesian3()
- );
- let boolDiff = car3Difference.x > 0;
- this.excavateMinHeight = 999999999;
- for (let index2 = 0; index2 < activePoints.length; ++index2) {
- let s = (index2 + 1) % activePoints.length;
- let curMidPoint = Cesium.Cartesian3.midpoint(
- activePoints[index2],
- activePoints[s],
- new Cesium.Cartesian3()
- );
- let cartographic = Cesium.Cartographic.fromCartesian(activePoints[index2]);
- let curHeight = viewer2.scene.globe.getHeight(cartographic) || cartographic.height;
- if (curHeight < this.excavateMinHeight) {
- this.excavateMinHeight = curHeight;
- }
- let curMidPointNormal = Cesium.Cartesian3.normalize(
- curMidPoint,
- new Cesium.Cartesian3()
- );
- let curMidPointDifference = boolDiff ? Cesium.Cartesian3.subtract(
- activePoints[index2],
- curMidPoint,
- new Cesium.Cartesian3()
- ) : Cesium.Cartesian3.subtract(
- activePoints[s],
- curMidPoint,
- new Cesium.Cartesian3()
- );
- curMidPointDifference = Cesium.Cartesian3.normalize(
- curMidPointDifference,
- curMidPointDifference
- );
- let curMidPointCross = Cesium.Cartesian3.cross(
- curMidPointDifference,
- curMidPointNormal,
- new Cesium.Cartesian3()
- );
- curMidPointCross = Cesium.Cartesian3.normalize(
- curMidPointCross,
- curMidPointCross
- );
- let plane = new Cesium.Plane(curMidPointCross, 0);
- let distance2 = Cesium.Plane.getPointDistance(plane, curMidPoint);
- clippingPlanesList.push(
- new Cesium.ClippingPlane(curMidPointCross, distance2)
- );
- }
- this.viewer.scene.globe.clippingPlanes = new Cesium.ClippingPlaneCollection({
- planes: clippingPlanesList,
- edgeWidth: 1,
- edgeColor: Cesium.Color.WHITE,
- enabled: true
- });
- this.prepareWell(activePoints);
- this.createWell(this.wellData);
- },
- clear() {
- if (this.viewer.scene.globe.clippingPlanes) {
- this.viewer.scene.globe.clippingPlanes.removeAll();
- this.viewer.scene.primitives.remove(this.bottomSurface);
- this.viewer.scene.primitives.remove(this.wellWall);
- this.viewer.scene.render();
- }
- }
- });
- class SlopeAspect {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this.result = [];
- this.handler = void 0;
- this.toolTip = "";
- }
- _openTip() {
- let _self = this;
- this.handler = new Cesium.ScreenSpaceEventHandler(_self._viewer.canvas);
- this.handler.setInputAction(function(movement) {
- let endPos = movement.endPosition;
- var pick = _self._viewer.scene.pick(endPos);
- if (pick && pick.id && pick.id.type === "SlopeAspect") {
- _self.toolTip = pick.id.value.toFixed(2);
- CreateRemindertip(_self.toolTip, endPos, true);
- } else {
- _self.toolTip = "";
- CreateRemindertip(_self.toolTip, endPos, false);
- }
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- }
- _createEllipse(gridSquare) {
- let _self = this;
- let boxResults = [];
- for (let index2 = 0; index2 < gridSquare.features.length; index2++) {
- const feature2 = gridSquare.features[index2];
- const coordinates = feature2.geometry.coordinates[0];
- const centerdegree = [
- (coordinates[0][0] + coordinates[2][0]) / 2,
- (coordinates[0][1] + coordinates[2][1]) / 2
- ];
- let centerCartographic = Cesium.Cartographic.fromDegrees(
- centerdegree[0],
- centerdegree[1]
- );
- boxResults.push(centerCartographic);
- for (let i2 = 0; i2 < coordinates.length; i2++) {
- const coord = coordinates[i2];
- let cartographic = Cesium.Cartographic.fromDegrees(coord[0], coord[1]);
- boxResults.push(cartographic);
- const coord1 = coordinates[i2 + 1];
- if (coord1) {
- let newCoord = [(coord[0] + coord1[0]) / 2, (coord[1] + coord1[1]) / 2];
- let newCartographic = Cesium.Cartographic.fromDegrees(newCoord[0], newCoord[1]);
- boxResults.push(newCartographic);
- }
- }
- }
- Cesium.sampleTerrainMostDetailed(
- _self._viewer.scene.terrainProvider,
- boxResults
- ).then((updatePositions) => {
- let arrr = [];
- let ellipseResults = updatePositions.reduce(function(pre, item, index2, updatePositions2) {
- var begin = index2 * 10;
- var end = begin + 10;
- var res = updatePositions2.slice(begin, end);
- if (res.length != 0) {
- arrr[index2] = res;
- }
- return arrr;
- }, []);
- _self._calculateSlope(ellipseResults);
- _self._openTip();
- });
- }
- _createPolygonInsrance(points2, color2) {
- let positions = [];
- for (let index2 = 1; index2 < points2.length - 1; index2++) {
- const element = points2[index2];
- positions.push(Cesium.Cartographic.toCartesian(element));
- }
- let polygon2 = new Cesium.PolygonGeometry({
- polygonHierarchy: new Cesium.PolygonHierarchy(positions)
- });
- let polygonInstance = new Cesium.GeometryInstance({
- geometry: polygon2,
- attributes: {
- color: Cesium.ColorGeometryInstanceAttribute.fromColor(
- Cesium.Color.fromCssColorString(color2)
- ),
- show: new Cesium.ShowGeometryInstanceAttribute(true)
- }
- });
- return polygonInstance;
- }
- _createArrowInstance(targetPoint, center2, diagonalPoint, heightDifference, curSlope) {
- let cartographic_0 = new Cesium.Cartographic(
- (targetPoint.longitude + center2.longitude) / 2,
- (targetPoint.latitude + center2.latitude) / 2,
- (targetPoint.height + center2.height) / 2
- );
- let cartographic_1 = new Cesium.Cartographic(
- (diagonalPoint.longitude + center2.longitude) / 2,
- (diagonalPoint.latitude + center2.latitude) / 2,
- (diagonalPoint.height + center2.height) / 2
- );
- let positions1 = heightDifference > 0 ? [
- Cesium.Cartographic.toCartesian(cartographic_0),
- Cesium.Cartographic.toCartesian(cartographic_1)
- ] : [
- Cesium.Cartographic.toCartesian(cartographic_1),
- Cesium.Cartographic.toCartesian(cartographic_0)
- ];
- const instance = new Cesium.GeometryInstance({
- id: {
- type: "SlopeAspect",
- value: curSlope
- },
- geometry: new Cesium.GroundPolylineGeometry({
- positions: positions1,
- width: this.arrowWidth
- }),
- attributes: {
- color: Cesium.ColorGeometryInstanceAttribute.fromColor(
- Cesium.Color.BLUE.withAlpha(0.6)
- ),
- show: new Cesium.ShowGeometryInstanceAttribute(true)
- }
- });
- return instance;
- }
- _calculateSlope(ellipseResults) {
- let _self = this;
- let instances = [];
- let polygonInstance = [];
- for (let index2 = 0; index2 < ellipseResults.length; index2++) {
- const ellipse = ellipseResults[index2];
- const center2 = ellipse[0];
- let heightDifference = 0;
- let maxIndex = 0;
- for (let i2 = 1; i2 < ellipse.length - 1; i2++) {
- const point2 = ellipse[i2];
- let curHD = point2.height - center2.height;
- if (Math.abs(curHD) > heightDifference) {
- heightDifference = curHD;
- maxIndex = i2;
- }
- }
- let pos0 = new Cesium.Cartographic(center2.longitude, center2.latitude, 0);
- let pos1 = new Cesium.Cartographic(
- ellipse[maxIndex].longitude,
- ellipse[maxIndex].latitude,
- 0
- );
- let distance2 = Cesium.Cartesian3.distance(
- Cesium.Cartographic.toCartesian(pos0),
- Cesium.Cartographic.toCartesian(pos1)
- );
- let curSlope = Math.abs(heightDifference / distance2);
- let curColor = _self._calculateSlopeColor(curSlope, 0.4);
- const curPolygonInstance = _self._createPolygonInsrance(ellipse, curColor);
- polygonInstance.push(curPolygonInstance);
- let diagonalPoint = maxIndex > 4 ? ellipse[maxIndex - 4] : ellipse[maxIndex + 4];
- let targetPoint = ellipse[maxIndex];
- const arrowInstance = _self._createArrowInstance(targetPoint, center2, diagonalPoint, heightDifference, curSlope);
- instances.push(arrowInstance);
- }
- const mapPrimitive = _self._viewer.scene.primitives.add(
- new Cesium.GroundPrimitive({
- geometryInstances: polygonInstance,
- appearance: new Cesium.PerInstanceColorAppearance({
- translucent: true,
- closed: false
- })
- })
- );
- const arrowPrimitive = _self._viewer.scene.primitives.add(
- new Cesium.GroundPolylinePrimitive({
- geometryInstances: instances,
- appearance: new Cesium.PolylineMaterialAppearance({
- material: new Cesium.Material({
- fabric: {
- type: "PolylineArrow",
- uniforms: {
- color: new Cesium.Color(1, 1, 0, 0.8)
- }
- }
- })
- })
- })
- );
- _self.result.push(arrowPrimitive, mapPrimitive);
- }
- _calculateSlopeColor(value, alpha) {
- if (value < 0.00872686779075879) {
- return "rgba(85,182,43," + alpha + ")";
- } else if (value < 0.03492076949174773) {
- return "rgba(135,211,43," + alpha + ")";
- } else if (value < 0.08748866352592401) {
- return "rgba(204,244,44," + alpha + ")";
- } else if (value < 0.2679491924311227) {
- return "rgba(245,233,44," + alpha + ")";
- } else if (value < 0.7002075382097097) {
- return "rgba(255,138,43," + alpha + ")";
- } else if (value < 1.4281480067421144) {
- return "rgba(255,84,43," + alpha + ")";
- } else {
- return "rgba(255,32,43," + alpha + ")";
- }
- }
- }
- Object.assign(SlopeAspect.prototype, {
- createNew4Distance(points2, options2) {
- let _self = this;
- options2 = options2 || {};
- options2.distance = options2.distance || 0.1;
- let width2 = options2.distance * 200 > 35 ? 35 : options2.distance * 200;
- _self.arrowWidth = width2 < 15 ? 15 : width2;
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- _self.clearAll();
- let degrees = CoordTransform.Cartesian3ListToWGS84(positions);
- let boundary = [];
- let minX = 1e4, minY = 1e4, maxX = -1e4, maxY = -1e3;
- for (let index2 = 0; index2 < degrees.length; index2++) {
- const element = degrees[index2];
- const x = element.lng;
- const y = element.lat;
- boundary.push([x, y]);
- minX = x < minX ? x : minX;
- minY = y < minY ? y : minY;
- maxX = x > maxX ? x : maxX;
- maxY = y > maxY ? y : maxY;
- }
- boundary.push(boundary[0]);
- let bbox2 = [minX, minY, maxX, maxY];
- let mask = polygon([boundary]);
- let gridSquare = squareGrid(bbox2, options2.distance, {
- mask
- });
- _self._createEllipse(gridSquare);
- },
- createNew4Num(points2, options2) {
- let _self = this;
- options2 = options2 || {};
- options2.num = Cesium.defaultValue(options2.num, 10);
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- _self.clearAll();
- let degrees = CoordTransform.Cartesian3ListToWGS84(positions);
- let boundary = [];
- let minX = 1e4, minY = 1e4, maxX = -1e4, maxY = -1e3;
- for (let index2 = 0; index2 < degrees.length; index2++) {
- const element = degrees[index2];
- const x = element.lng;
- const y = element.lat;
- boundary.push([x, y]);
- minX = x < minX ? x : minX;
- minY = y < minY ? y : minY;
- maxX = x > maxX ? x : maxX;
- maxY = y > maxY ? y : maxY;
- }
- boundary.push(boundary[0]);
- let bbox2 = [minX, minY, maxX, maxY];
- let a = maxX - minX;
- let b = maxY - minY;
- b = b > a ? b : a;
- const step = b / options2.num;
- let width2 = step * 2e3 > 35 ? 35 : step * 2e3;
- _self.arrowWidth = width2 < 15 ? 15 : width2;
- polygon([boundary]);
- let gridSquare = squareGrid(bbox2, step, {
- units: "degrees"
- });
- _self._createEllipse(gridSquare);
- },
- clearAll() {
- this.result.forEach((element) => {
- this._viewer.scene.primitives.remove(element);
- });
- this.result = [];
- if (this.handler) {
- this.handler.destroy();
- this.handler = void 0;
- }
- }
- });
- let TerrainAnalysis = {
- TerrainExcavation,
- SlopeAspect
- };
- class Weather {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- }
- _initRain() {
- this.rainStage = new Cesium.PostProcessStage({
- name: "jt_rain",
- fragmentShader: this._rain(),
- uniforms: {
- tiltAngle: () => {
- return this.tiltAngle;
- },
- rainSize: () => {
- return this.rainSize;
- },
- rainSpeed: () => {
- return this.rainSpeed;
- }
- }
- });
- this._viewer.scene.postProcessStages.add(this.rainStage);
- }
- _initSnow() {
- this.snowStage = new Cesium.PostProcessStage({
- name: "jt_snow",
- fragmentShader: this._snow(),
- uniforms: {
- snowSize: () => {
- return this.snowSize;
- },
- snowSpeed: () => {
- return this.snowSpeed;
- }
- }
- });
- this._viewer.scene.postProcessStages.add(this.snowStage);
- }
- _initFog() {
- this.fogStage = new Cesium.PostProcessStage({
- name: "jt_fog",
- fragmentShader: this._fog(),
- uniforms: {
- visibility: () => {
- return this.visibility;
- },
- fogColor: () => {
- return this.color;
- }
- }
- });
- this._viewer.scene.postProcessStages.add(this.fogStage);
- }
- _rain() {
- return "uniform sampler2D colorTexture;\n varying vec2 v_textureCoordinates;\n uniform float tiltAngle;\n uniform float rainSize;\n uniform float rainSpeed;\n float hash(float x) {\n return fract(sin(x * 133.3) * 13.13);\n }\n void main(void) {\n float time = czm_frameNumber / rainSpeed;\n vec2 resolution = czm_viewport.zw;\n vec2 uv = (gl_FragCoord.xy * 2. - resolution.xy) / min(resolution.x, resolution.y);\n vec3 c = vec3(.6, .7, .8);\n float a = tiltAngle;\n float si = sin(a), co = cos(a);\n uv *= mat2(co, -si, si, co);\n uv *= length(uv + vec2(0, 4.9)) * rainSize + 1.;\n float v = 1. - sin(hash(floor(uv.x * 100.)) * 2.);\n float b = clamp(abs(sin(20. * time * v + uv.y * (5. / (2. + v)))) - .95, 0., 1.) * 20.;\n c *= v * b;\n gl_FragColor = mix(texture2D(colorTexture, v_textureCoordinates), vec4(c, 1), .5);\n }\n ";
- }
- _snow() {
- return "uniform sampler2D colorTexture;\n varying vec2 v_textureCoordinates;\n uniform float snowSpeed;\n uniform float snowSize;\n float snow(vec2 uv,float scale)\n {\n float time=czm_frameNumber/snowSpeed;\n float w=smoothstep(1.,0.,-uv.y*(scale/10.));if(w<.1)return 0.;\n uv+=time/scale;uv.y+=time*2./scale;uv.x+=sin(uv.y+time*.5)/scale;\n uv*=scale;vec2 s=floor(uv),f=fract(uv),p;float k=3.,d;\n p=.5+.35*sin(11.*fract(sin((s+p+scale)*mat2(7,3,6,5))*5.))-f;d=length(p);k=min(d,k);\n k=smoothstep(0.,k,sin(f.x+f.y)*snowSize);\n return k*w;\n }\n void main(void){\n vec2 resolution=czm_viewport.zw;\n vec2 uv=(gl_FragCoord.xy*2.-resolution.xy)/min(resolution.x,resolution.y);\n vec3 finalColor=vec3(0);\n //float c=smoothstep(1.,0.3,clamp(uv.y*.3+.8,0.,.75));\n float c=0.;\n c+=snow(uv,30.)*.0;\n c+=snow(uv,20.)*.0;\n c+=snow(uv,15.)*.0;\n c+=snow(uv,10.);\n c+=snow(uv,8.);\n c+=snow(uv,6.);\n c+=snow(uv,5.);\n finalColor=(vec3(c));\n gl_FragColor=mix(texture2D(colorTexture,v_textureCoordinates),vec4(finalColor,1),.5);\n }\n ";
- }
- _fog() {
- return "uniform sampler2D colorTexture;\n uniform sampler2D depthTexture;\n uniform float visibility;\n uniform vec4 fogColor;\n varying vec2 v_textureCoordinates; \n void main(void) \n { \n vec4 origcolor = texture2D(colorTexture, v_textureCoordinates); \n float depth = czm_readDepth(depthTexture, v_textureCoordinates); \n vec4 depthcolor = texture2D(depthTexture, v_textureCoordinates); \n float f = visibility * (depthcolor.r - 0.3) / 0.2; \n if (f < 0.0) f = 0.0; \n else if (f > 1.0) f = 1.0; \n gl_FragColor = mix(origcolor, fogColor, f); \n }\n";
- }
- _removeSnow() {
- if (!this._viewer || !this.snowStage)
- return;
- this._viewer.scene.postProcessStages.remove(this.snowStage);
- delete this.snowSize;
- delete this.snowSpeed;
- }
- _removeRain() {
- if (!this._viewer || !this.rainStage)
- return;
- this._viewer.scene.postProcessStages.remove(this.rainStage);
- delete this.tiltAngle;
- delete this.rainSize;
- delete this.rainSpeed;
- }
- _removeFog() {
- if (!this._viewer || !this.fogStage)
- return;
- this._viewer.scene.postProcessStages.remove(this.fogStage);
- delete this.visibility;
- delete this.color;
- }
- }
- Object.assign(Weather.prototype, {
- addRainEffect(options2) {
- options2 = options2 || {};
- this.tiltAngle = Cesium.defaultValue(options2.tiltAngle, -0.6);
- this.rainSize = Cesium.defaultValue(options2.rainSize, 0.3);
- this.rainSpeed = Cesium.defaultValue(options2.rainSpeed, 60);
- this._initRain();
- },
- addSnowEffect(options2) {
- options2 = options2 || {};
- this.snowSize = Cesium.defaultValue(options2.snowSize, 0.02);
- this.snowSpeed = Cesium.defaultValue(options2.snowSpeed, 60);
- this._initSnow();
- },
- addFogEffect(options2) {
- options2 = options2 || {};
- this.visibility = Cesium.defaultValue(options2.visibility, 0.1);
- this.color = Cesium.defaultValue(options2.color, new Cesium.Color(0.8, 0.8, 0.8, 0.5));
- this._show = Cesium.defaultValue(options2.show, true);
- this._initFog();
- },
- removeEffect() {
- if (this.snowStage) {
- this._removeSnow();
- }
- if (this.rainStage) {
- this._removeRain();
- }
- if (this.fogStage) {
- this._removeFog();
- }
- }
- });
- const BoxGeometry = Cesium.BoxGeometry;
- const Cartesian3 = Cesium.Cartesian3;
- const defaultValue = Cesium.defaultValue;
- const defined = Cesium.defined;
- const destroyObject = Cesium.destroyObject;
- const DeveloperError$1 = Cesium.DeveloperError;
- const GeometryPipeline = Cesium.GeometryPipeline;
- const Matrix3 = Cesium.Matrix3;
- const Matrix4 = Cesium.Matrix4;
- const Transforms = Cesium.Transforms;
- const VertexFormat = Cesium.VertexFormat;
- const BufferUsage = Cesium.BufferUsage;
- const CubeMap = Cesium.CubeMap;
- const DrawCommand = Cesium.DrawCommand;
- const loadCubeMap = Cesium.loadCubeMap;
- const RenderState = Cesium.RenderState;
- const VertexArray = Cesium.VertexArray;
- const BlendingState = Cesium.BlendingState;
- const SceneMode = Cesium.SceneMode;
- const ShaderProgram = Cesium.ShaderProgram;
- const ShaderSource = Cesium.ShaderSource;
- const SkyBoxFS = "uniform samplerCube u_cubeMap;\n varying vec3 v_texCoord;\n void main()\n {\n vec4 color = textureCube(u_cubeMap, normalize(v_texCoord));\n gl_FragColor = vec4(czm_gammaCorrect(color).rgb, czm_morphTime);\n }\n ";
- const SkyBoxVS = "attribute vec3 position;\n varying vec3 v_texCoord;\n uniform mat3 u_rotateMatrix;\n void main()\n {\n vec3 p = czm_viewRotation * u_rotateMatrix * (czm_temeToPseudoFixed * (czm_entireFrustum.y * position));\n gl_Position = czm_projection * vec4(p, 1.0);\n v_texCoord = position.xyz;\n }\n ";
- if (!Cesium.defined(Cesium.Matrix4.getRotation)) {
- Cesium.Matrix4.getRotation = Cesium.Matrix4.getMatrix3;
- }
- class SkyBoxOnGround {
- constructor(options2) {
- this.sources = options2.sources;
- this._sources = void 0;
- this.show = defaultValue(options2.show, true);
- this._command = new DrawCommand({
- modelMatrix: Matrix4.clone(Matrix4.IDENTITY),
- owner: this
- });
- this._cubeMap = void 0;
- this._attributeLocations = void 0;
- this._useHdr = void 0;
- }
- }
- const skyboxMatrix3 = new Matrix3();
- SkyBoxOnGround.prototype.update = function(frameState, useHdr) {
- const that = this;
- if (!this.show) {
- return void 0;
- }
- if (frameState.mode !== SceneMode.SCENE3D && frameState.mode !== SceneMode.MORPHING) {
- return void 0;
- }
- if (!frameState.passes.render) {
- return void 0;
- }
- const context = frameState.context;
- if (this._sources !== this.sources) {
- this._sources = this.sources;
- const sources = this.sources;
- if (!defined(sources.positiveX) || !defined(sources.negativeX) || !defined(sources.positiveY) || !defined(sources.negativeY) || !defined(sources.positiveZ) || !defined(sources.negativeZ)) {
- throw new DeveloperError$1(
- "this.sources is required and must have positiveX, negativeX, positiveY, negativeY, positiveZ, and negativeZ properties."
- );
- }
- if (typeof sources.positiveX !== typeof sources.negativeX || typeof sources.positiveX !== typeof sources.positiveY || typeof sources.positiveX !== typeof sources.negativeY || typeof sources.positiveX !== typeof sources.positiveZ || typeof sources.positiveX !== typeof sources.negativeZ) {
- throw new DeveloperError$1(
- "this.sources properties must all be the same type."
- );
- }
- if (typeof sources.positiveX === "string") {
- loadCubeMap(context, this._sources).then(function(cubeMap) {
- that._cubeMap = that._cubeMap && that._cubeMap.destroy();
- that._cubeMap = cubeMap;
- });
- } else {
- this._cubeMap = this._cubeMap && this._cubeMap.destroy();
- this._cubeMap = new CubeMap({
- context,
- source: sources
- });
- }
- }
- const command = this._command;
- command.modelMatrix = Transforms.eastNorthUpToFixedFrame(
- frameState.camera._positionWC
- );
- if (!defined(command.vertexArray)) {
- command.uniformMap = {
- u_cubeMap: function() {
- return that._cubeMap;
- },
- u_rotateMatrix: function() {
- return Matrix4.getRotation(command.modelMatrix, skyboxMatrix3);
- }
- };
- const geometry2 = BoxGeometry.createGeometry(
- BoxGeometry.fromDimensions({
- dimensions: new Cartesian3(2, 2, 2),
- vertexFormat: VertexFormat.POSITION_ONLY
- })
- );
- const attributeLocations = this._attributeLocations = GeometryPipeline.createAttributeLocations(
- geometry2
- );
- command.vertexArray = VertexArray.fromGeometry({
- context,
- geometry: geometry2,
- attributeLocations,
- bufferUsage: BufferUsage._DRAW
- });
- command.renderState = RenderState.fromCache({
- blending: BlendingState.ALPHA_BLEND
- });
- }
- if (!defined(command.shaderProgram) || this._useHdr !== useHdr) {
- const fs = new ShaderSource({
- defines: [useHdr ? "HDR" : ""],
- sources: [SkyBoxFS]
- });
- command.shaderProgram = ShaderProgram.fromCache({
- context,
- vertexShaderSource: SkyBoxVS,
- fragmentShaderSource: fs,
- attributeLocations: this._attributeLocations
- });
- this._useHdr = useHdr;
- }
- if (!defined(this._cubeMap)) {
- return void 0;
- }
- return command;
- };
- SkyBoxOnGround.prototype.isDestroyed = function() {
- return false;
- };
- SkyBoxOnGround.prototype.destroy = function() {
- const command = this._command;
- command.vertexArray = command.vertexArray && command.vertexArray.destroy();
- command.shaderProgram = command.shaderProgram && command.shaderProgram.destroy();
- this._cubeMap = this._cubeMap && this._cubeMap.destroy();
- return destroyObject(this);
- };
- class SkyBox {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this._farSkyBox = viewer2.scene.skyBox;
- }
- }
- Object.assign(SkyBox.prototype, {
- setGroundSkyBox(options2) {
- options2 = options2 || {};
- options2.height = options2.height || 2e5;
- options2.type = options2.type || "\u84DD\u5929";
- if (!options2.sources) {
- switch (options2.type) {
- case "\u665A\u971E":
- options2.sources = {
- positiveX: "jt3dSDK/imgs/skybox/01/px.png",
- negativeX: "jt3dSDK/imgs/skybox/01/nx.png",
- positiveY: "jt3dSDK/imgs/skybox/01/py.png",
- negativeY: "jt3dSDK/imgs/skybox/01/ny.png",
- positiveZ: "jt3dSDK/imgs/skybox/01/pz.png",
- negativeZ: "jt3dSDK/imgs/skybox/01/nz.png"
- };
- break;
- case "\u9634\u5929":
- options2.sources = {
- positiveX: "jt3dSDK/imgs/skybox/02/px.jpg",
- negativeX: "jt3dSDK/imgs/skybox/02/nx.jpg",
- positiveY: "jt3dSDK/imgs/skybox/02/py.jpg",
- negativeY: "jt3dSDK/imgs/skybox/02/ny.jpg",
- positiveZ: "jt3dSDK/imgs/skybox/02/pz.jpg",
- negativeZ: "jt3dSDK/imgs/skybox/02/nz.jpg"
- };
- break;
- case "\u84DD\u5929":
- options2.sources = {
- positiveX: "jt3dSDK/imgs/skybox/03/px.jpg",
- negativeX: "jt3dSDK/imgs/skybox/03/nx.jpg",
- positiveY: "jt3dSDK/imgs/skybox/03/py.jpg",
- negativeY: "jt3dSDK/imgs/skybox/03/ny.jpg",
- positiveZ: "jt3dSDK/imgs/skybox/03/pz.jpg",
- negativeZ: "jt3dSDK/imgs/skybox/03/nz.jpg"
- };
- break;
- case "\u7D2B\u8272\u661F\u7A7A":
- options2.sources = {
- positiveX: "jt3dSDK/imgs/skybox/04/px.jpg",
- negativeX: "jt3dSDK/imgs/skybox/04/nx.jpg",
- positiveY: "jt3dSDK/imgs/skybox/04/py.jpg",
- negativeY: "jt3dSDK/imgs/skybox/04/ny.jpg",
- positiveZ: "jt3dSDK/imgs/skybox/04/pz.jpg",
- negativeZ: "jt3dSDK/imgs/skybox/04/nz.jpg"
- };
- break;
- case "\u84DD\u8272\u661F\u7A7A":
- options2.sources = {
- positiveX: "jt3dSDK/imgs/skybox/05/px.jpg",
- negativeX: "jt3dSDK/imgs/skybox/05/nx.jpg",
- positiveY: "jt3dSDK/imgs/skybox/05/py.jpg",
- negativeY: "jt3dSDK/imgs/skybox/05/ny.jpg",
- positiveZ: "jt3dSDK/imgs/skybox/05/pz.jpg",
- negativeZ: "jt3dSDK/imgs/skybox/05/nz.jpg"
- };
- break;
- }
- } else if (!Cesium.defined(options2.sources.positiveX) || !Cesium.defined(options2.sources.negativeX) || !Cesium.defined(options2.sources.positiveY) || !Cesium.defined(options2.sources.negativeY) || !Cesium.defined(options2.sources.positiveZ) || !Cesium.defined(options2.sources.negativeZ)) {
- throw new Cesium.DeveloperError(
- "options.sources is required and must have positiveX, negativeX, positiveY, negativeY, positiveZ, and negativeZ properties."
- );
- }
- let _self = this;
- let groundSkyBox = new SkyBoxOnGround({
- sources: options2.sources,
- show: true
- });
- _self._viewer.scene.postRender.addEventListener(() => {
- var e = _self._viewer.camera.position;
- if (Cesium.Cartographic.fromCartesian(e).height < options2.height) {
- _self._viewer.scene.skyBox = groundSkyBox;
- } else {
- _self._viewer.scene.skyBox = _self._defaultSkyBox;
- }
- });
- }
- });
- class ParticleSystem {
- constructor(viewer2) {
- if (!viewer2)
- throw new DeveloperError("no viewer object!");
- this.viewer = viewer2;
- }
- }
- Object.assign(ParticleSystem.prototype, {
- createParticleFire: function(coordinates) {
- this.viewer.clock.shouldAnimate = true;
- var position2 = Cesium.Cartesian3.fromDegrees(coordinates[0], coordinates[1], coordinates[2] || 0);
- var entity = this.viewer.entities.add({
- position: position2
- });
- function computeModelMatrix(entity2, time) {
- var position3 = Cesium.Property.getValueOrUndefined(entity2.position);
- var modelMatrix = Cesium.Transforms.eastNorthUpToFixedFrame(position3);
- return modelMatrix;
- }
- var viewModel = {
- startScale: 3,
- endScale: 1.5,
- minimumParticleLife: 1.5,
- maximumParticleLife: 1.8,
- minimumSpeed: 7,
- maximumSpeed: 9,
- particleSize: 2,
- emissionRate: 200
- };
- var primitive = this.viewer.scene.primitives.add(
- new Cesium.ParticleSystem({
- image: "jt3dSDK/imgs/particlesystem/fire.png",
- imageSize: new Cesium.Cartesian2(viewModel.particleSize, viewModel.particleSize),
- startColor: new Cesium.Color(1, 1, 1, 1),
- endColor: new Cesium.Color(0.5, 0, 0, 0),
- startScale: viewModel.startScale,
- endScale: viewModel.endScale,
- minimumParticleLife: viewModel.minimumParticleLife,
- maximumParticleLife: viewModel.maximumParticleLife,
- minimumSpeed: viewModel.minimumSpeed,
- maximumSpeed: viewModel.maximumSpeed,
- emissionRate: viewModel.emissionRate,
- lifetime: 16,
- loop: true,
- sizeInMeters: true,
- emitter: new Cesium.ConeEmitter(Cesium.Math.toRadians(45)),
- modelMatrix: computeModelMatrix(entity, Cesium.JulianDate.now())
- })
- );
- entity.remove = function() {
- viewer.entities.remove(entity);
- viewer.scene.primitives.remove(primitive);
- };
- return entity;
- },
- createParticleWater: function(coordinates) {
- let viewer2 = this.viewer;
- this.viewer.clock.shouldAnimate = true;
- var position2 = Cesium.Cartesian3.fromDegrees(coordinates[0], coordinates[1], coordinates[2] || 0);
- var entity = this.viewer.entities.add({
- position: position2
- });
- function computeModelMatrix(entity2, time) {
- return entity2.computeModelMatrix(time, new Cesium.Matrix4());
- }
- function computeEmitterModelMatrix() {
- let hpr = Cesium.HeadingPitchRoll.fromDegrees(viewModel.heading, viewModel.pitch, viewModel.roll);
- let trs = new Cesium.TranslationRotationScale();
- trs.translation = Cesium.Cartesian3.fromElements(0, 0, 1);
- trs.rotation = Cesium.Quaternion.fromHeadingPitchRoll(hpr);
- let Matrix42 = Cesium.Matrix4.fromTranslationRotationScale(trs);
- return Matrix42;
- }
- function updateCallback(p, dt2) {
- var gravityScratch = new Cesium.Cartesian3();
- var position3 = p.position;
- Cesium.Cartesian3.normalize(position3, gravityScratch);
- Cesium.Cartesian3.multiplyByScalar(gravityScratch, viewModel.gravity * dt2, gravityScratch);
- p.velocity = Cesium.Cartesian3.add(p.velocity, gravityScratch, p.velocity);
- }
- function update(scene, time) {
- waterParticleSystem.modelMatrix = computeModelMatrix(entity, time);
- waterParticleSystem.emitterModelMatrix = computeEmitterModelMatrix();
- }
- viewer2.scene.preUpdate.addEventListener(update);
- var viewModel = {
- startScale: 1,
- endScale: 7,
- minimumParticleLife: 6,
- maximumParticleLife: 7,
- minimumSpeed: 9,
- maximumSpeed: 9.5,
- particleSize: 1,
- emissionRate: 60,
- gravity: -4,
- heading: 110,
- pitch: 30,
- roll: 0
- };
- var waterParticleSystem = new Cesium.ParticleSystem({
- image: "jt3dSDK/imgs/particlesystem/water.png",
- imageSize: new Cesium.Cartesian2(viewModel.particleSize, viewModel.particleSize),
- startColor: new Cesium.Color(1, 1, 1, 0.6),
- endColor: new Cesium.Color(0.8, 0.86, 1, 0.4),
- startScale: viewModel.startScale,
- endScale: viewModel.endScale,
- minimumParticleLife: viewModel.minimumParticleLife,
- maximumParticleLife: viewModel.maximumParticleLife,
- minimumSpeed: viewModel.minimumSpeed,
- maximumSpeed: viewModel.maximumSpeed,
- emissionRate: viewModel.emissionRate,
- sizeInMeters: true,
- emitter: new Cesium.CircleEmitter(0.2),
- modelMatrix: computeModelMatrix(entity),
- emitterModelMatrix: computeEmitterModelMatrix(),
- updateCallback
- });
- viewer2.scene.primitives.add(waterParticleSystem);
- entity.remove = function() {
- viewer2.entities.remove(entity);
- viewer2.scene.primitives.remove(waterParticleSystem);
- };
- return entity;
- }
- });
- function Intensity(options2) {
- options2 = options2 || {};
- this.gradient = options2.gradient || {
- 0.25: "rgba(0, 0, 255, 1)",
- 0.55: "rgba(0, 255, 0, 1)",
- 0.85: "rgba(255, 255, 0, 1)",
- 1: "rgba(255, 0, 0, 1)"
- };
- this.maxSize = options2.maxSize || 35;
- this.minSize = options2.minSize || 0;
- this.max = options2.max || 100;
- this.min = options2.min || 0;
- this.initPalette();
- }
- Intensity.prototype.setMax = function(value) {
- this.max = value || 100;
- };
- Intensity.prototype.setMin = function(value) {
- this.min = value || 0;
- };
- Intensity.prototype.setMaxSize = function(maxSize) {
- this.maxSize = maxSize || 35;
- };
- Intensity.prototype.setMinSize = function(minSize) {
- this.minSize = minSize || 0;
- };
- Intensity.prototype.initPalette = function() {
- let gradient = this.gradient;
- let canvas = new Canvas(256, 1);
- let paletteCtx = this.paletteCtx = canvas.getContext("2d");
- let lineGradient = paletteCtx.createLinearGradient(0, 0, 256, 1);
- for (let key in gradient) {
- lineGradient.addColorStop(parseFloat(key), gradient[key]);
- }
- paletteCtx.fillStyle = lineGradient;
- paletteCtx.fillRect(0, 0, 256, 1);
- };
- Intensity.prototype.getColor = function(value) {
- let imageData = this.getImageData(value);
- return "rgba(" + imageData[0] + ", " + imageData[1] + ", " + imageData[2] + ", " + imageData[3] / 256 + ")";
- };
- Intensity.prototype.getImageData = function(value) {
- let imageData = this.paletteCtx.getImageData(0, 0, 256, 1).data;
- if (value === void 0) {
- return imageData;
- }
- let max2 = this.max;
- let min2 = this.min;
- if (value > max2) {
- value = max2;
- }
- if (value < min2) {
- value = min2;
- }
- let index2 = Math.floor((value - min2) / (max2 - min2) * (256 - 1)) * 4;
- return [
- imageData[index2],
- imageData[index2 + 1],
- imageData[index2 + 2],
- imageData[index2 + 3]
- ];
- };
- Intensity.prototype.getSize = function(value) {
- let size = 0;
- let max2 = this.max;
- let min2 = this.min;
- let maxSize = this.maxSize;
- let minSize = this.minSize;
- if (value > max2) {
- value = max2;
- }
- if (value < min2) {
- value = min2;
- }
- size = minSize + (value - min2) / (max2 - min2) * (maxSize - minSize);
- return size;
- };
- Intensity.prototype.getLegend = function(options2) {
- let gradient = this.gradient;
- let width2 = options2.width || 20;
- let height2 = options2.height || 180;
- let canvas = new Canvas(width2, height2);
- let paletteCtx = canvas.getContext("2d");
- let lineGradient = paletteCtx.createLinearGradient(0, height2, 0, 0);
- for (let key in gradient) {
- lineGradient.addColorStop(parseFloat(key), gradient[key]);
- }
- paletteCtx.fillStyle = lineGradient;
- paletteCtx.fillRect(0, 0, width2, height2);
- return canvas;
- };
- function Canvas(width2, height2) {
- let canvas = document.createElement("canvas");
- canvas.width = width2;
- canvas.height = height2;
- return canvas;
- }
- const Cesium$1 = window.Cesium;
- class HeatmapIntensity {
- constructor(viewer2, option = {}) {
- if (!viewer2)
- throw new Error("no viewer object!");
- this._viewer = viewer2;
- this._min = option.min || 0;
- this._max = option.max || 100;
- this._size = option.size || 20;
- this._result = void 0;
- this._canvas = void 0;
- }
- get min() {
- return this._min;
- }
- set min(val) {
- this._min = val;
- this.updateHeatmap(this._result.canvasData);
- }
- get max() {
- return this._max;
- }
- set max(val) {
- this._max = val;
- this.updateHeatmap(this._result.canvasData);
- }
- get size() {
- return this._size;
- }
- set size(val) {
- this._size = val;
- this.updateHeatmap(this._result.canvasData);
- }
- get result() {
- return this._result;
- }
- createHeatmap(box, data) {
- const mercator_WestSouth = this.WGS84ToWebMercator(box.west, box.south, 0);
- const mercator_EastNorth = this.WGS84ToWebMercator(box.east, box.north, 0);
- const diffDegrees_X = mercator_EastNorth.x - mercator_WestSouth.x;
- const diffDegrees_Y = mercator_EastNorth.y - mercator_WestSouth.y;
- const diffMax = Math.max(diffDegrees_X, diffDegrees_Y);
- let multiple = diffMax / 300;
- const width2 = Math.ceil(diffDegrees_X / multiple);
- const height2 = Math.ceil(diffDegrees_Y / multiple);
- this.mercator_WestSouth = mercator_WestSouth;
- this.mercator_EastNorth = mercator_EastNorth;
- this.diffDegrees_X = diffDegrees_X;
- this.diffDegrees_Y = diffDegrees_Y;
- let canvasData = [];
- data.forEach((element) => {
- const curMercator = this.WGS84ToWebMercator(
- Number(element.x),
- Number(element.y),
- 0
- );
- const per_X = (curMercator.x - mercator_WestSouth.x) / diffDegrees_X;
- const currentPix_X = Math.ceil(per_X * width2);
- const per_Y = (curMercator.y - mercator_WestSouth.y) / diffDegrees_Y;
- const currentPix_Y = Math.ceil(per_Y * height2);
- const currentValue = Number(element.value);
- canvasData.push({
- x: currentPix_X,
- y: height2 - currentPix_Y - 1,
- value: currentValue
- });
- });
- let canvas = new Canvas(width2, height2);
- let context = canvas.getContext("2d");
- context.clearRect(0, 0, canvas.width, canvas.height);
- let circle = this.createCircle(this._size);
- let circleHalfWidth = circle.width / 2;
- let circleHalfHeight = circle.height / 2;
- let dataOrderByAlpha = {};
- canvasData.forEach((item) => {
- let alpha = item.value < this._min ? 0 : Math.min(1, item.value / this._max).toFixed(2);
- dataOrderByAlpha[alpha] = dataOrderByAlpha[alpha] || [];
- dataOrderByAlpha[alpha].push(item);
- });
- for (let i2 in dataOrderByAlpha) {
- if (isNaN(i2))
- continue;
- let _data = dataOrderByAlpha[i2];
- context.beginPath();
- context.globalAlpha = i2;
- _data.forEach((item) => {
- context.drawImage(
- circle,
- item.x - circleHalfWidth,
- item.y - circleHalfHeight
- );
- });
- }
- let intensity = new Intensity();
- let colored = context.getImageData(
- 0,
- 0,
- context.canvas.width,
- context.canvas.height
- );
- const options2 = { min: 0, max: this._max, size: this._size };
- this.colorize(options2, colored.data, intensity.getImageData());
- context.clearRect(0, 0, context.canvas.width, context.canvas.height);
- context.putImageData(colored, 0, 0);
- let entity = this._viewer.entities.add({
- name: "rectangle",
- rectangle: {
- coordinates: Cesium$1.Rectangle.fromDegrees(
- box.west,
- box.south,
- box.east,
- box.north
- ),
- material: new Cesium$1.ImageMaterialProperty({
- image: canvas,
- transparent: true
- })
- }
- });
- this._canvas = canvas;
- this._result = { box, data, canvasData, entity };
- return this._result;
- }
- setData(data) {
- if (!this._result) {
- return;
- }
- let canvasData = [];
- const height2 = this._canvas.height;
- const width2 = this._canvas.width;
- data.forEach((element) => {
- const curMercator = this.WGS84ToWebMercator(
- Number(element.x),
- Number(element.y),
- 0
- );
- const per_X = (curMercator.x - this.mercator_WestSouth.x) / this.diffDegrees_X;
- const currentPix_X = Math.ceil(per_X * width2);
- const per_Y = (curMercator.y - this.mercator_WestSouth.y) / this.diffDegrees_Y;
- const currentPix_Y = Math.ceil(per_Y * height2);
- const currentValue = Number(element.value);
- canvasData.push({
- x: currentPix_X,
- y: height2 - currentPix_Y - 1,
- value: currentValue
- });
- });
- this._result.data = data;
- this._result.canvasData = canvasData;
- this.updateHeatmap(canvasData);
- }
- updateHeatmap(data) {
- let canvas = this._canvas;
- let context = canvas.getContext("2d");
- context.clearRect(0, 0, canvas.width, canvas.height);
- let circle = this.createCircle(this._size);
- let circleHalfWidth = circle.width / 2;
- let circleHalfHeight = circle.height / 2;
- let dataOrderByAlpha = {};
- data.forEach((item) => {
- let alpha = item.value < this._min ? 0 : Math.min(1, item.value / this._max).toFixed(2);
- dataOrderByAlpha[alpha] = dataOrderByAlpha[alpha] || [];
- dataOrderByAlpha[alpha].push(item);
- });
- for (let i2 in dataOrderByAlpha) {
- if (isNaN(i2))
- continue;
- let _data = dataOrderByAlpha[i2];
- context.beginPath();
- context.globalAlpha = i2;
- _data.forEach((item) => {
- context.drawImage(
- circle,
- item.x - circleHalfWidth,
- item.y - circleHalfHeight
- );
- });
- }
- let intensity = new Intensity();
- let colored = context.getImageData(
- 0,
- 0,
- context.canvas.width,
- context.canvas.height
- );
- const options2 = { min: 0, max: this._max, size: this._size };
- this.colorize(options2, colored.data, intensity.getImageData());
- context.clearRect(0, 0, context.canvas.width, context.canvas.height);
- context.putImageData(colored, 0, 0);
- this._result.entity.rectangle.material = new Cesium$1.ImageMaterialProperty({
- image: canvas,
- transparent: true
- });
- return this._result;
- }
- createCircle(size) {
- let shadowBlur = size / 2;
- let r2 = size + shadowBlur;
- let offsetDistance = 1e4;
- let circle = new Canvas(r2 * 2, r2 * 2);
- let context = circle.getContext("2d");
- context.shadowBlur = shadowBlur;
- context.shadowColor = "black";
- context.shadowOffsetX = context.shadowOffsetY = offsetDistance;
- context.beginPath();
- context.arc(
- r2 - offsetDistance,
- r2 - offsetDistance,
- size,
- 0,
- Math.PI * 2,
- true
- );
- context.closePath();
- context.fill();
- return circle;
- }
- colorize(options2, pixels, gradient) {
- let max2 = options2.max;
- let min2 = options2.min;
- let diff = max2 - min2;
- let range3 = options2.range || null;
- let jMin = 0;
- let jMax = 1024;
- if (range3 && range3.length === 2) {
- jMin = (range3[0] - min2) / diff * 1024;
- }
- if (range3 && range3.length === 2) {
- jMax = (range3[1] - min2) / diff * 1024;
- }
- let maxOpacity = options2.maxOpacity || 0.8;
- for (let i2 = 3, len = pixels.length, j; i2 < len; i2 += 4) {
- j = pixels[i2] * 4;
- if (pixels[i2] / 256 > maxOpacity) {
- pixels[i2] = 256 * maxOpacity;
- }
- if (j && j >= jMin && j <= jMax) {
- pixels[i2 - 3] = gradient[j];
- pixels[i2 - 2] = gradient[j + 1];
- pixels[i2 - 1] = gradient[j + 2];
- } else {
- pixels[i2] = 0;
- }
- }
- }
- WGS84ToWebMercator(lng, lat, height2) {
- let mercator = {};
- let x = lng * 2003750834e-2 / 180;
- let y = Math.log(Math.tan((90 + lat) * Math.PI / 360)) / (Math.PI / 180);
- y = y * 2003750834e-2 / 180;
- mercator.x = x;
- mercator.y = y;
- mercator.z = height2;
- return mercator;
- }
- clearAll() {
- this._result && this._viewer.entities.remove(this._result.entity);
- this._result = void 0;
- }
- }
- let SceneEffects = {
- Weather,
- SkyBox,
- ParticleSystem,
- HeatmapIntensity
- };
- class ImageLayerSplit {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- }
- }
- Object.assign(ImageLayerSplit.prototype, {
- initSplit() {
- let _self = this;
- this.viewer = this._viewer;
- let sliderDiv = document.getElementById("image_slider");
- if (sliderDiv == null) {
- sliderDiv = document.createElement("div");
- sliderDiv.id = "image_slider";
- sliderDiv.style.position = "absolute";
- sliderDiv.style.left = "50%";
- sliderDiv.style.top = "0px";
- sliderDiv.style.backgroundColor = "#d3d3d3";
- sliderDiv.style.width = "5px";
- sliderDiv.style.height = "100%";
- sliderDiv.style.zIndex = "9999";
- sliderDiv.onmouseover = function() {
- this.style.cursor = "ew-resize";
- };
- document.body.appendChild(sliderDiv);
- }
- this.slider = sliderDiv;
- viewer.scene.splitPosition = this.slider.offsetLeft / this.slider.parentElement.offsetWidth;
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- this.handler = new Cesium.ScreenSpaceEventHandler(this.slider);
- var moveActive = false;
- function move(movement) {
- if (!moveActive) {
- return;
- }
- var relativeOffset = movement.endPosition.x;
- var splitPosition = (_self.slider.offsetLeft + relativeOffset) / _self.slider.parentElement.offsetWidth;
- _self.slider.style.left = `${100 * splitPosition}%`;
- viewer.scene.splitPosition = splitPosition;
- }
- this.handler.setInputAction(function() {
- moveActive = true;
- }, Cesium.ScreenSpaceEventType.LEFT_DOWN);
- this.handler.setInputAction(function() {
- moveActive = true;
- }, Cesium.ScreenSpaceEventType.PINCH_START);
- this.handler.setInputAction(move, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(move, Cesium.ScreenSpaceEventType.PINCH_MOVE);
- this.handler.setInputAction(function() {
- moveActive = false;
- }, Cesium.ScreenSpaceEventType.LEFT_UP);
- this.handler.setInputAction(function() {
- moveActive = false;
- }, Cesium.ScreenSpaceEventType.PINCH_END);
- },
- addSplitLayer(earthAtLeft, earthAtRight) {
- if (this.earthAtLeft) {
- this._viewer.imageryLayers.remove(this.earthAtLeft);
- }
- if (this.earthAtRight) {
- this._viewer.imageryLayers.remove(this.earthAtRight);
- }
- this.earthAtLeft = earthAtLeft;
- this.earthAtRight = earthAtRight;
- this.earthAtLeft.splitDirection = Cesium.SplitDirection.LEFT;
- this.earthAtRight.splitDirection = Cesium.SplitDirection.RIGHT;
- },
- removeSplitLayer() {
- document.body.removeChild(this.slider);
- if (this.earthAtLeft) {
- this._viewer.imageryLayers.remove(this.earthAtLeft);
- }
- if (this.earthAtRight) {
- this._viewer.imageryLayers.remove(this.earthAtRight);
- }
- }
- });
- class ViewerSplitScreen {
- constructor() {
- }
- }
- Object.assign(ViewerSplitScreen.prototype, {
- initHandler(viewer1, viewer2) {
- var _self = this;
- if (_self.handler1 && _self.handler1.getInputAction(Cesium.ScreenSpaceEventType.MOUSE_MOVE)) {
- return;
- }
- _self.handler1 = new Cesium.ScreenSpaceEventHandler(viewer1.scene.canvas);
- _self.handler2 = new Cesium.ScreenSpaceEventHandler(viewer2.scene.canvas);
- _self.handler1.setInputAction(function(movement) {
- var _camerca = viewer1.camera;
- viewer2.camera.setView({
- destination: _camerca.position,
- orientation: {
- direction: _camerca._direction,
- up: _camerca.up,
- heading: _camerca.heading,
- pitch: _camerca.pitch,
- roll: _camerca.roll
- }
- });
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- _self.handler1.setInputAction(function(movement) {
- var _camerca = viewer1.camera;
- viewer2.camera.setView({
- destination: _camerca.position,
- orientation: {
- direction: _camerca._direction,
- up: _camerca.up,
- heading: _camerca.heading,
- pitch: _camerca.pitch,
- roll: _camerca.roll
- }
- });
- }, Cesium.ScreenSpaceEventType.WHEEL);
- _self.handler2.setInputAction(function(movement) {
- var _camerca = viewer2.camera;
- viewer1.camera.setView({
- destination: _camerca.position,
- orientation: {
- direction: _camerca._direction,
- up: _camerca.up,
- heading: _camerca.heading,
- pitch: _camerca.pitch,
- roll: _camerca.roll
- }
- });
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- _self.handler2.setInputAction(function(movement) {
- var _camerca = viewer2.camera;
- viewer1.camera.setView({
- destination: _camerca.position,
- orientation: {
- direction: _camerca._direction,
- up: _camerca.up,
- heading: _camerca.heading,
- pitch: _camerca.pitch,
- roll: _camerca.roll
- }
- });
- }, Cesium.ScreenSpaceEventType.WHEEL);
- },
- clearHandler() {
- var _self = this;
- if (_self.handler1) {
- _self.handler1.removeInputAction(Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- _self.handler1.removeInputAction(Cesium.ScreenSpaceEventType.WHEEL);
- }
- if (_self.handler2) {
- _self.handler2.removeInputAction(Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- _self.handler2.removeInputAction(Cesium.ScreenSpaceEventType.WHEEL);
- }
- }
- });
- let SceneControl = {
- ImageLayerSplit,
- ViewerSplitScreen
- };
- class TrackRoam {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this._draw3DObj = null;
- }
- _startFly(pathsData, options2) {
- var _self = this;
- options2 = options2 || {};
- options2.time = Cesium.defaultValue(options2.time, 360);
- options2.isPathShow = Cesium.defaultValue(options2.isPathShow, true);
- options2.height = Cesium.defaultValue(options2.height, 5);
- options2.role = Cesium.defaultValue(options2.role, 1);
- this.url = options2.modelUrl;
- this.time = options2.time;
- this.isPathShow = options2.isPathShow;
- this.height = options2.height;
- this.role = options2.role;
- _self.clearFlyPaths();
- _self._viewer.camera.setView({
- destination: pathsData.position,
- orientation: pathsData.orientation
- });
- setTimeout(function() {
- executeFly3D();
- }, 200);
- function executeFly3D() {
- if (pathsData && pathsData.geometry) {
- var positionA = pathsData.geometry.coordinates;
- let positions = positionA.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2.lng, point2.lat, point2.height);
- });
- let distance2 = [];
- for (let i2 = 0; i2 < positions.length - 1; i2++) {
- let dis = Cesium.Cartesian3.distance(positions[i2], positions[i2 + 1]);
- distance2.push(dis);
- }
- let times = [Cesium.JulianDate.fromDate(new Date())];
- times.push(Cesium.JulianDate.addSeconds(times[0], _self.time, new Cesium.JulianDate()));
- for (let i2 = 1; i2 < positions.length - 1; i2++) {
- let s = Cesium.JulianDate.addSeconds(times[i2], _self.time * (distance2[i2] / distance2[0]), new Cesium.JulianDate());
- times.push(s);
- }
- let oriSamples = new Cesium.SampledProperty(Cesium.Cartesian3);
- oriSamples.addSamples(times, positions);
- let startTime = times[0];
- let stopTime = times[times.length - 1];
- _self._viewer.clock.startTime = startTime.clone();
- _self._viewer.clock.stopTime = stopTime.clone();
- _self._viewer.clock.currentTime = startTime.clone();
- _self._viewer.clock.clockRange = Cesium.ClockRange.LOOP_STOP;
- _self._viewer.clock.multiplier = 10;
- let timeOfResolution = 6;
- let samplesNum = Math.floor(
- Cesium.JulianDate.secondsDifference(stopTime, startTime) / timeOfResolution
- );
- let sampledPositions = [];
- let sampledTimes = [];
- for (let i2 = 0; i2 < samplesNum + 1; i2++) {
- let sampleTime = Cesium.JulianDate.addSeconds(
- startTime,
- i2 * timeOfResolution,
- new Cesium.JulianDate()
- );
- let tmpPos = oriSamples.getValue(sampleTime);
- sampledPositions.push(Cesium.Cartographic.fromCartesian(tmpPos));
- sampledTimes.push(sampleTime);
- }
- Cesium.sampleTerrainMostDetailed(
- _self._viewer.terrainProvider,
- sampledPositions
- ).then(() => {
- let carPositionProperty = new Cesium.SampledPositionProperty();
- for (let i2 = 0; i2 < sampledPositions.length; i2++) {
- sampledPositions[i2].height = sampledPositions[i2].height + _self.height;
- }
- for (let i2 = 0; i2 < samplesNum + 1; i2++) {
- carPositionProperty.addSample(
- sampledTimes[i2],
- Cesium.Ellipsoid.WGS84.cartographicToCartesian(sampledPositions[i2])
- );
- }
- var position2 = carPositionProperty;
- _self.entityFly = _self._viewer.entities.add({
- availability: new Cesium.TimeIntervalCollection([
- new Cesium.TimeInterval({
- start: startTime,
- stop: stopTime
- })
- ]),
- position: position2,
- orientation: new Cesium.VelocityOrientationProperty(position2),
- point: {
- color: Cesium.Color.RED,
- outlineColor: Cesium.Color.WHITE,
- outlineWidth: 2,
- pixelSize: 10
- },
- path: {
- show: _self.isPathShow,
- resolution: 1,
- material: new Cesium.PolylineGlowMaterialProperty({
- glowPower: 0.1,
- color: Cesium.Color.YELLOW
- }),
- width: 10
- }
- });
- if (_self.role == 0)
- ;
- else if (_self.role == 1) {
- _self._viewer.trackedEntity = _self.entityFly;
- } else if (_self.role == 2) {
- _self._viewer.trackedEntity = _self.entityFly;
- let exection = function TimeExecution() {
- if (_self._viewer.clock.shouldAnimate === true) {
- let center2 = _self.entity.position.getValue(
- _self._viewer.clock.currentTime
- );
- let orientation = _self.entity.orientation.getValue(
- _self._viewer.clock.currentTime
- );
- let transform3 = Cesium.Transforms.eastNorthUpToFixedFrame(center2);
- transform3 = Cesium.Matrix4.fromRotationTranslation(Cesium.Matrix3.fromQuaternion(orientation), center2);
- _self._viewer.camera.lookAtTransform(transform3, new Cesium.Cartesian3(-50, 0, 250));
- }
- };
- _self._viewer.clock.onTick.addEventListener(exection);
- } else if (_self.role == 3) {
- _self._viewer.trackedEntity = _self.entityFly;
- let exection = function TimeExecution() {
- if (_self._viewer.clock.shouldAnimate === true) {
- let center2 = _self.entity.position.getValue(
- _self._viewer.clock.currentTime
- );
- _self._viewer.camera.lookAt(center2, new Cesium.Cartesian3(0, 0, 1e3));
- }
- };
- _self._viewer.clock.onTick.addEventListener(exection);
- }
- });
- } else {
- return;
- }
- }
- }
- }
- Object.assign(TrackRoam.prototype, {
- drawFlyPaths(coordinates, options2) {
- return new Promise((resolve2, reject2) => {
- let _self = this;
- _self.clearFlyPaths();
- let position2 = _self._viewer.camera.position;
- let heading = _self._viewer.camera.heading;
- let pitch = _self._viewer.camera.pitch;
- let roll = _self._viewer.camera.roll;
- var pathsData = {
- "orientation": {
- "heading": heading,
- "pitch": pitch,
- "roll": roll
- },
- "position": position2,
- "clampToGround": true,
- "geometry": {
- "type": "LineString",
- "coordinates": coordinates
- }
- };
- _self._draw3DObj = pathsData;
- resolve2(true);
- });
- },
- clearFlyPaths() {
- this._draw3DObj = null;
- this._viewer.trackedEntity = void 0;
- this._viewer.entities.remove(this.entityFly);
- },
- startFly(options2, callError) {
- if (this._draw3DObj) {
- this._startFly(this._draw3DObj, options2);
- } else {
- if (callError)
- callError("\u6F2B\u6E38\u8DEF\u7EBF\u4E0D\u5B58\u5728");
- }
- },
- pauseFly() {
- var clockViewModel = this._viewer.clockViewModel;
- if (clockViewModel.shouldAnimate) {
- clockViewModel.shouldAnimate = false;
- } else if (this._viewer.clockViewModel.canAnimate) {
- clockViewModel.shouldAnimate = true;
- }
- },
- forwardFly() {
- var clockViewModel = this._viewer.clockViewModel;
- var multiplier = clockViewModel.multiplier;
- if (multiplier < 0) {
- clockViewModel.multiplier = -multiplier;
- }
- clockViewModel.shouldAnimate = true;
- },
- backwardsFly() {
- var clockViewModel = this._viewer.clockViewModel;
- var multiplier = clockViewModel.multiplier;
- if (multiplier > 0) {
- clockViewModel.multiplier = -multiplier;
- }
- clockViewModel.shouldAnimate = true;
- },
- outFly() {
- var start2 = Cesium.JulianDate.fromDate(new Date());
- this._viewer.clock.startTime = start2.clone();
- var stop = Cesium.JulianDate.addSeconds(start2, 3e8, new Cesium.JulianDate());
- this._viewer.clock.stopTime = stop.clone();
- this.clearFlyPaths();
- }
- });
- class Roaming {
- constructor(viewer2, positions, options2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!positions)
- throw new Cesium.DeveloperError("no positions Array!");
- this.viewer = viewer2;
- this.entity = void 0;
- options2 = options2 || {};
- options2.time = Cesium.defaultValue(options2.time, 360);
- options2.speed = Cesium.defaultValue(options2.speed, 10);
- options2.isPathShow = Cesium.defaultValue(options2.isPathShow, true);
- options2.height = Cesium.defaultValue(options2.height, 5);
- options2.role = Cesium.defaultValue(options2.role, 1);
- options2.followedX = Cesium.defaultValue(options2.followedX, 50);
- options2.followedZ = Cesium.defaultValue(options2.followedZ, 10);
- this.time = options2.time;
- this.speed = options2.speed;
- this.isPathShow = options2.isPathShow;
- this.height = options2.height;
- this.role = options2.role;
- this.followedX = options2.followedX;
- this.followedZ = options2.followedZ;
- this.model = options2.model;
- this.billboard = options2.billboard;
- this.point = options2.point;
- this.label = options2.label;
- this.property = this.ComputeRoamingLineProperty(positions, this.time);
- }
- ComputeRoamingLineProperty(Lines, time) {
- let positions = [];
- if (Lines[0] instanceof Cesium.Cartesian3) {
- positions = Lines;
- } else {
- positions = Lines.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- }
- let distance2 = [];
- for (let i2 = 0; i2 < positions.length - 1; i2++) {
- let dis = Cesium.Cartesian3.distance(positions[i2], positions[i2 + 1]);
- distance2.push(dis);
- }
- let times = [Cesium.JulianDate.fromDate(new Date())];
- times.push(Cesium.JulianDate.addSeconds(times[0], time, new Cesium.JulianDate()));
- for (let i2 = 1; i2 < positions.length - 1; i2++) {
- let s = Cesium.JulianDate.addSeconds(times[i2], time * (distance2[i2] / distance2[0]), new Cesium.JulianDate());
- times.push(s);
- }
- let oriSamples = new Cesium.SampledProperty(Cesium.Cartesian3);
- oriSamples.addSamples(times, positions);
- let startTime = times[0];
- let stopTime = times[times.length - 1];
- this.viewer.clock.startTime = startTime.clone();
- this.viewer.clock.stopTime = stopTime.clone();
- this.viewer.clock.currentTime = startTime.clone();
- this.viewer.clock.clockRange = Cesium.ClockRange.LOOP_STOP;
- this.viewer.clock.multiplier = this.speed;
- let timeOfResolution = 6;
- let samplesNum = Math.floor(
- Cesium.JulianDate.secondsDifference(stopTime, startTime) / timeOfResolution
- );
- let sampledPositions = [];
- let sampledTimes = [];
- for (let i2 = 0; i2 < samplesNum + 1; i2++) {
- let sampleTime = Cesium.JulianDate.addSeconds(
- startTime,
- i2 * timeOfResolution,
- new Cesium.JulianDate()
- );
- let tmpPos = oriSamples.getValue(sampleTime);
- sampledPositions.push(Cesium.Cartographic.fromCartesian(tmpPos));
- sampledTimes.push(sampleTime);
- }
- Cesium.sampleTerrainMostDetailed(
- this.viewer.terrainProvider,
- sampledPositions
- ).then((updatedPositions) => {
- let carPositionProperty = new Cesium.SampledPositionProperty();
- for (let i2 = 0; i2 < sampledPositions.length; i2++) {
- sampledPositions[i2].height = sampledPositions[i2].height + this.height;
- }
- for (let i2 = 0; i2 < samplesNum + 1; i2++) {
- carPositionProperty.addSample(
- sampledTimes[i2],
- Cesium.Ellipsoid.WGS84.cartographicToCartesian(sampledPositions[i2])
- );
- }
- var position2 = carPositionProperty;
- this.InitRoaming(position2, startTime, stopTime, this.isPathShow);
- });
- }
- InitRoaming(position2, start2, stop, isPathShow) {
- this.entity = this.viewer.entities.add({
- availability: new Cesium.TimeIntervalCollection([new Cesium.TimeInterval({
- start: start2,
- stop
- })]),
- position: position2,
- orientation: new Cesium.VelocityOrientationProperty(position2),
- path: {
- resolution: 1,
- material: new Cesium.PolylineGlowMaterialProperty({
- glowPower: 0.1,
- color: Cesium.Color.YELLOW
- }),
- width: 10,
- show: isPathShow
- }
- });
- if (this.model) {
- let model = this.model;
- this.entity.model = {
- uri: model.url,
- minimumPixelSize: 64,
- maximumSize: 128,
- maximumScale: 200,
- show: true,
- silhouetteColor: Cesium.Color.WHITE,
- debugWireframe: false,
- debugShowBoundingVolume: false,
- scale: 20,
- runAnimations: true
- };
- } else if (this.billboard) {
- let billboard = this.billboard;
- billboard.imgUrl = Cesium.defaultValue(billboard.imgUrl, "jt3dSDK/imgs/point/point3.png");
- this.entity.billboard = {
- image: billboard.imgUrl,
- show: true,
- width: 30,
- scale: 1,
- height: 30,
- pixelOffset: new Cesium.Cartesian2(0, -14)
- };
- } else {
- let point2 = {};
- if (this.point) {
- point2 = this.point;
- }
- point2.pixelSize = Cesium.defaultValue(point2.pixelSize, 10);
- if (point2.color) {
- if (point2.color instanceof Array) {
- point2.color = new Cesium.Color(point2.color[0] / 255, point2.color[1] / 255, point2.color[2] / 255, point2.color[3]);
- } else if (typeof point2.color === "string") {
- point2.color = new Cesium.Color.fromCssColorString(point2.color);
- } else {
- point2.color = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- if (point2.outlineColor) {
- if (point2.outlineColor instanceof Array) {
- point2.outlineColor = new Cesium.Color(point2.outlineColor[0] / 255, point2.outlineColor[1] / 255, point2.outlineColor[2] / 255, point2.outlineColor[3]);
- } else if (typeof point2.outlineColor === "string") {
- point2.outlineColor = new Cesium.Color.fromCssColorString(point2.outlineColor);
- } else {
- point2.outlineColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- point2.outlineWidth = Cesium.defaultValue(point2.outlineWidth, 2);
- this.entity.point = point2;
- }
- if (this.label) {
- let label2 = this.label;
- label2.text = Cesium.defaultValue(label2.text, "");
- label2.font = Cesium.defaultValue(label2.font, "24px Helvetica");
- if (label2.fillColor) {
- if (label2.fillColor instanceof Array) {
- label2.fillColor = new Cesium.Color(label2.fillColor[0] / 255, label2.fillColor[1] / 255, label2.fillColor[2] / 255, label2.fillColor[3]);
- } else if (typeof label2.fillColor === "string") {
- label2.fillColor = new Cesium.Color.fromCssColorString(label2.fillColor);
- } else {
- label2.fillColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- if (label2.outlineColor) {
- if (label2.outlineColor instanceof Array) {
- label2.outlineColor = new Cesium.Color(label2.outlineColor[0] / 255, label2.outlineColor[1] / 255, label2.outlineColor[2] / 255, label2.outlineColor[3]);
- } else if (typeof label2.outlineColor === "string") {
- label2.outlineColor = new Cesium.Color.fromCssColorString(label2.outlineColor);
- } else {
- label2.outlineColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- label2.outlineWidth = Cesium.defaultValue(label2.outlineWidth, 1);
- label2.showBackground = Cesium.defaultValue(label2.showBackground, false);
- if (label2.backgroundColor) {
- if (label2.backgroundColor instanceof Array) {
- label2.backgroundColor = new Cesium.Color(label2.backgroundColor[0] / 255, label2.backgroundColor[1] / 255, label2.backgroundColor[2] / 255, label2.backgroundColor[3]);
- } else if (typeof label2.backgroundColor === "string") {
- label2.backgroundColor = new Cesium.Color.fromCssColorString(label2.backgroundColor);
- } else {
- label2.backgroundColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- label2.pixelOffset = Cesium.defaultValue(label2.pixelOffset, 0);
- label2.scale = Cesium.defaultValue(label2.scale, 1);
- label2.near = Cesium.defaultValue(label2.near, 150);
- label2.nearValue = Cesium.defaultValue(label2.nearValue, 1);
- label2.far = Cesium.defaultValue(label2.far, 2400);
- label2.farValue = Cesium.defaultValue(label2.farValue, 0);
- this.entity.label = {
- text: label2.text,
- font: label2.font,
- fillColor: label2.fillColor,
- outlineColor: label2.outlineColor,
- outlineWidth: label2.outlineWidth,
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- showBackground: label2.showBackground,
- backgroundColor: label2.backgroundColor,
- backgroundPadding: new Cesium.Cartesian2(6, 6),
- disableDepthTestDistance: Number.POSITIVE_INFINITY,
- pixelOffset: new Cesium.Cartesian2(0, label2.pixelOffset),
- scale: label2.scale
- };
- }
- this.entity.position.setInterpolationOptions({
- interpolationDegree: 5,
- interpolationAlgorithm: Cesium.LagrangePolynomialApproximation
- });
- this.initRole(this.role);
- }
- initRole(role) {
- let _self = this;
- if (role == 0) {
- this.viewer.trackedEntity = void 0;
- let len = _self.viewer.clock.onTick.numberOfListeners;
- for (let i2 = 0; i2 < len; i2++) {
- _self.viewer.clock.onTick.removeEventListener(_self.viewer.clock.onTick._listeners[i2]);
- }
- } else if (role == 1) {
- this.viewer.trackedEntity = this.entity;
- let len = _self.viewer.clock.onTick.numberOfListeners;
- for (let i2 = 0; i2 < len; i2++) {
- _self.viewer.clock.onTick.removeEventListener(_self.viewer.clock.onTick._listeners[i2]);
- }
- } else if (role == 2) {
- this.viewer.trackedEntity = this.entity;
- let exection = function TimeExecution() {
- if (_self.viewer.clock.shouldAnimate === true) {
- let center2 = _self.entity.position.getValue(
- _self.viewer.clock.currentTime
- );
- let orientation = _self.entity.orientation.getValue(
- _self.viewer.clock.currentTime
- );
- let transform3 = Cesium.Transforms.eastNorthUpToFixedFrame(center2);
- transform3 = Cesium.Matrix4.fromRotationTranslation(Cesium.Matrix3.fromQuaternion(orientation), center2);
- var transformX = _self.followedX || 50;
- var transformZ = _self.followedZ || 10;
- _self.viewer.camera.lookAtTransform(transform3, new Cesium.Cartesian3(transformX, 0, transformZ));
- }
- };
- this.viewer.clock.onTick.addEventListener(exection);
- } else if (role == 3) {
- this.viewer.trackedEntity = this.entity;
- let exection = function TimeExecution() {
- if (_self.viewer.clock.shouldAnimate === true) {
- let center2 = _self.entity.position.getValue(
- _self.viewer.clock.currentTime
- );
- _self.viewer.camera.lookAt(center2, new Cesium.Cartesian3(0, 0, 1e3));
- }
- };
- this.viewer.clock.onTick.addEventListener(exection);
- }
- }
- PauseOrContinue(state) {
- this.viewer.clock.shouldAnimate = state;
- }
- forwardFly() {
- var multiplier = this.viewer.clock.multiplier;
- if (multiplier < 0) {
- this.viewer.clock.multiplier = -multiplier;
- }
- this.viewer.clock.shouldAnimate = true;
- }
- backwardsFly() {
- var multiplier = this.viewer.clock.multiplier;
- if (multiplier > 0) {
- this.viewer.clock.multiplier = -multiplier;
- }
- this.viewer.clock.shouldAnimate = true;
- }
- ChangeRoamingSpeed(value) {
- this.viewer.clock.multiplier = value;
- }
- EndRoaming() {
- if (this.entity !== void 0) {
- this.viewer.entities.remove(this.entity);
- }
- this.viewer.trackedEntity = void 0;
- this.viewer.clock.shouldAnimate = false;
- let len = this.viewer.clock.onTick.numberOfListeners;
- for (let i2 = 0; i2 < len; i2++) {
- this.viewer.clock.onTick.removeEventListener(this.viewer.clock.onTick._listeners[i2]);
- }
- }
- }
- class PolygonObject {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this._drawEntities = [];
- this._polygonEntity = null;
- }
- }
- Object.assign(PolygonObject.prototype, {
- drawPolygonByGeoJson(geoJsonUrl, options2) {
- return new Promise((resolve2, reject2) => {
- let _self = this;
- if (!Cesium.defined(geoJsonUrl)) {
- throw new Cesium.DeveloperError("geoJsonUrl is required.");
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- options2.clampToGround = Cesium.defaultValue(options2.clampToGround, true);
- options2.color = Cesium.defaultValue(options2.color, "#FF0000");
- options2.outlineColor = Cesium.defaultValue(options2.outlineColor, "#FFFF00");
- options2.outlineWidth = Cesium.defaultValue(options2.outlineWidth, 1);
- options2.extrudedHeight = Cesium.defaultValue(options2.extrudedHeight, 0);
- let promise = Cesium.GeoJsonDataSource.load(geoJsonUrl, {
- clampToGround: true,
- stroke: Cesium.Color.WHITE,
- strokeWidth: 3,
- fill: Cesium.Color.RED.withAlpha(0.5)
- });
- promise.then((dataSource) => {
- _self._viewer.dataSources.add(dataSource);
- dataSource.name = options2.id;
- let entities2 = dataSource.entities.values;
- for (let index2 = 0; index2 < entities2.length; index2++) {
- let entity = entities2[index2];
- entity.polygon.material = new Cesium.Color.fromCssColorString(color).withAlpha(0.1);
- entity.polygon.extrudedHeight = options2.extrudedHeight;
- entity.polygon.fill = false;
- entity.polygon.outline = false;
- entity.polygon.outlineWidth = options2.outlineWidth;
- entity.polygon.outlineColor = options2.outlineColor;
- entity.polyline = {
- positions: entity.polygon.hierarchy._value.positions,
- width: entity.polygon.outlineWidth,
- material: new Cesium.Color.fromCssColorString(color).withAlpha(0.1)
- };
- if (options2.clampToGround) {
- entity.polyline.clampToGround = true;
- }
- }
- resolve2(entities2);
- });
- });
- },
- generatePolygonByPoints(points2, options2) {
- return new Promise((resolve2, reject2) => {
- if (!Cesium.defined(points2)) {
- throw new Cesium.DeveloperError("points is required.");
- }
- if (points2.length < 3) {
- reject2("\u9762\u5BF9\u8C61\uFF0C\u70B9\u6570\u81F3\u5C113\u4E2A");
- }
- let positions = points2.map((point2) => {
- return Cesium.Cartesian3.fromDegrees(point2[0], point2[1], point2[2] || 0);
- });
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- options2.fill = options2.fill || true;
- if (options2.color) {
- options2.color = new Cesium.Color(options2.color[0] / 255, options2.color[1] / 255, options2.color[2] / 255, options2.color[3]);
- } else {
- options2.color = new Cesium.Color.fromCssColorString("#ff0000");
- }
- options2.outline = options2.outline || false;
- if (options2.outlineColor) {
- options2.outlineColor = new Cesium.Color(options2.outlineColor[0] / 255, options2.outlineColor[1] / 255, options2.outlineColor[2] / 255, options2.outlineColor[3]);
- } else {
- options2.outlineColor = new Cesium.Color.fromCssColorString("#000");
- }
- options2.outlineWidth = Cesium.defaultValue(options2.outlineWidth, 1);
- let entity = new Cesium.Entity({
- id: options2.id,
- name: "Generate surfaces based on coordinate points",
- polygon: {
- hierarchy: positions,
- material: options2.color,
- fill: options2.fill,
- outline: options2.outline,
- outlineWidth: options2.outlineWidth,
- outlineColor: options2.outlineColor
- }
- });
- if (options2.outline) {
- entity.polyline = {
- positions: entity.polygon.hierarchy._value.positions,
- width: options2.outlineWidth,
- material: options2.outlineColor,
- clampToGround: true
- };
- }
- resolve2(entity);
- });
- }
- });
- class CircleMaterialProperty$1 {
- constructor(options2) {
- this._viewer = options2.viewer;
- this._definitionChanged = new Cesium.Event();
- this._color = void 0;
- this.color = options2.color || Cesium.Color.BLUE;
- this.count = options2.count || 1;
- this.duration = options2.duration || 1e3;
- this._time = new Date().getTime();
- this._materialTypeName = "jtCircleMaterial";
- this._param = {
- color: this.color._value.toCssColorString(),
- duration: this.duration,
- count: this.count
- };
- Cesium.Material._materialCache.addMaterial(this._materialTypeName, {
- fabric: {
- type: this._materialTypeName,
- uniforms: {
- time: 0,
- color: new Cesium.Color(1, 0, 0, 0.5),
- count: 1
- },
- source: this._getCircleMaterial()
- },
- translucent: function(material) {
- return true;
- }
- });
- }
- _getCircleMaterial() {
- let circleMaterial = "czm_material czm_getMaterial(czm_materialInput materialInput)\n{\n czm_material material = czm_getDefaultMaterial(materialInput);\n material.diffuse = 1.5 * color.rgb;\n vec2 st = materialInput.st;\n vec3 str = materialInput.str;\n float dis = distance(st, vec2(0.5, 0.5));\n float per = fract(time);\n if (abs(str.z) > 0.001)\n {\n //\u7740\u8272\u5668\u6E32\u67D3\u505C\u6B62\uFF0C\u4E0D\u5728\u7ED8\u5236\u5185\u5BB9 \n discard;\n }\n if (dis > 0.5)\n {\n //\u8D85\u51FA\u534A\u5F84\u8303\u56F4\u65F6\uFF0C\u7740\u8272\u5668\u6E32\u67D3\u505C\u6B62 \n discard;\n } else {\n //\u628A\u534A\u5F84\u5206\u6210count\u4EFD\uFF0C\u6BCF\u4E24\u4EFD\u4E4B\u95F4\u7684\u95F4\u9694\u8DDD\u79BB \n float perDis = 0.5 / count;\n float disNum;\n float bl = 0.0;\n //\u5FAA\u73AF\uFF0C\u6700\u591A999\u4E2A\u73AF \n for (int i = 0; i <= 999; i++)\n {\n //\u5224\u65AD\u662F\u5426\u5C5E\u4E8E\u6570\u91CF\u5185\u7684\u73AF \n if (float(i) <= count)\n {\n disNum = perDis * float(i) - dis + per / count;\n if (disNum > 0.0)\n {\n if (disNum < perDis)\n {\n bl = 1.0 - disNum / perDis;\n } else if (disNum - perDis < perDis) {\n bl = 1.0 - abs(1.0 - disNum / perDis);\n }\n material.alpha = color.a * pow(bl, 3.0);\n }\n }\n }\n }\n return material;\n}\n";
- return circleMaterial;
- }
- }
- Object.assign(CircleMaterialProperty$1.prototype, {
- getType: function(time) {
- return this._materialTypeName;
- },
- getValue: function(time, result) {
- if (!Cesium.defined(result)) {
- result = {};
- }
- result.color = Cesium.Property.getValueOrClonedDefault(this._color, time, Cesium.Color.BLUE, result.color);
- result.count = this.count;
- if (this.duration) {
- result.time = (new Date().getTime() - this._time) % this.duration / this.duration;
- }
- this._viewer.scene.requestRender();
- return result;
- },
- equals: function(other) {
- return this === other || other instanceof CircleMaterialProperty$1 && Cesium.Property.equals(this._color, other._color);
- }
- });
- Object.defineProperties(CircleMaterialProperty$1.prototype, {
- isConstant: {
- get: function() {
- return false;
- }
- },
- definitionChanged: {
- get: function() {
- return this._definitionChanged;
- }
- },
- color: Cesium.createPropertyDescriptor("color")
- });
- class CircleRippleMaterialProperty {
- constructor(options2) {
- this._definitionChanged = new Cesium.Event();
- this._color = void 0;
- this._speed = void 0;
- this.color = options2.color;
- this.speed = options2.speed;
- this.count = options2.count;
- this.gradient = options2.gradient;
- }
- get isConstant() {
- return false;
- }
- get definitionChanged() {
- return this._definitionChanged;
- }
- getType(time) {
- return Cesium.Material.CircleRippleMaterialType;
- }
- getValue(time, result) {
- if (!Cesium.defined(result)) {
- result = {};
- }
- result.color = Cesium.Property.getValueOrDefault(this._color, time, Cesium.Color.RED, result.color);
- result.speed = Cesium.Property.getValueOrDefault(this._speed, time, 10, result.speed);
- result.count = this.count;
- result.gradient = this.gradient;
- return result;
- }
- equals(other) {
- return this === other || other instanceof CircleRippleMaterialProperty && Cesium.Property.equals(this._color, other._color) && Cesium.Property.equals(this._speed, other._speed) && Cesium.Property.equals(this.count, other.count) && Cesium.Property.equals(this.gradient, other.gradient);
- }
- }
- Object.defineProperties(CircleRippleMaterialProperty.prototype, {
- color: Cesium.createPropertyDescriptor("color"),
- speed: Cesium.createPropertyDescriptor("speed"),
- count: Cesium.createPropertyDescriptor("count"),
- gradient: Cesium.createPropertyDescriptor("gradient")
- });
- Cesium.CircleRippleMaterialProperty = CircleRippleMaterialProperty;
- Cesium.Material.CircleRippleMaterialProperty = "CircleRippleMaterialProperty";
- Cesium.Material.CircleRippleMaterialType = "CircleRippleMaterialType";
- Cesium.Material.CircleRippleMaterialSource = `
- uniform vec4 color;
- uniform float speed;
- uniform float count;
- uniform float gradient;
- czm_material czm_getMaterial(czm_materialInput materialInput)
- {
- czm_material material = czm_getDefaultMaterial(materialInput);
- material.diffuse = 1.5 * color.rgb;
- vec2 st = materialInput.st;
- float dis = distance(st, vec2(0.5, 0.5));
- float per = fract(czm_frameNumber * speed / 1000.0);
- if(count == 1.0){
- if(dis > per * 0.5){
- discard;
- }else {
- material.alpha = color.a * dis / per / 2.0;
- }
- } else {
- vec3 str = materialInput.str;
- if(abs(str.z) > 0.001){
- discard;
- }
- if(dis > 0.5){
- discard;
- } else {
- float perDis = 0.5 / count;
- float disNum;
- float bl = 0.0;
- for(int i = 0; i <= 999; i++){
- if(float(i) <= count){
- disNum = perDis * float(i) - dis + per / count;
- if(disNum > 0.0){
- if(disNum < perDis){
- bl = 1.0 - disNum / perDis;
- }
- else if(disNum - perDis < perDis){
- bl = 1.0 - abs(1.0 - disNum / perDis);
- }
- material.alpha = pow(bl,(1.0 + 10.0 * (1.0 - gradient)));
- }
- }
- }
- }
- }
- return material;
- }
- `;
- Cesium.Material._materialCache.addMaterial(Cesium.Material.CircleRippleMaterialType, {
- fabric: {
- type: Cesium.Material.CircleRippleMaterialType,
- uniforms: {
- color: new Cesium.Color(1, 0, 0, 1),
- speed: 3,
- count: 4,
- gradient: 0.2
- },
- source: Cesium.Material.CircleRippleMaterialSource
- },
- translucent: function(material) {
- return true;
- }
- });
- class CircleObject {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- }
- }
- Object.assign(CircleObject.prototype, {
- drawCircle: function(centerPoint, radius, options2) {
- return new Promise((resolve2, reject2) => {
- this._viewer;
- if (!Cesium.defined(centerPoint)) {
- throw new Cesium.DeveloperError("centerPoint is required.");
- }
- if (!Cesium.defined(radius)) {
- throw new Cesium.DeveloperError("radius is required.");
- }
- let position2;
- if (centerPoint instanceof Cesium.Cartesian3) {
- position2 = centerPoint;
- } else {
- position2 = Cesium.Cartesian3.fromDegrees(centerPoint[0], centerPoint[1], centerPoint[2] || 0);
- }
- if (typeof radius === "number" && radius > 0) {
- radius = radius;
- } else {
- radius = 100;
- }
- options2 = options2 || {};
- options2.id = options2.id || setSessionid$1();
- options2.clampToGround = Cesium.defaultValue(options2.clampToGround, true);
- options2.CircleType = Cesium.defaultValue(options2.CircleType, "ColorCircle");
- options2.duration = Cesium.defaultValue(options2.duration, 3e3);
- options2.count = Cesium.defaultValue(options2.count, 1);
- if (options2.color) {
- if (options2.color instanceof Array) {
- options2.color = new Cesium.Color(options2.color[0] / 255, options2.color[1] / 255, options2.color[2] / 255, options2.color[3]);
- } else if (typeof options2.color === "string") {
- options2.color = new Cesium.Color.fromCssColorString(options2.color);
- } else {
- options2.color = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- if (options2.outlineColor) {
- if (options2.outlineColor instanceof Array) {
- options2.outlineColor = new Cesium.Color(options2.outlineColor[0] / 255, options2.outlineColor[1] / 255, options2.outlineColor[2] / 255, options2.outlineColor[3]);
- } else if (typeof options2.outlineColor === "string") {
- options2.outlineColor = new Cesium.Color.fromCssColorString(options2.outlineColor);
- } else {
- options2.outlineColor = new Cesium.Color.fromCssColorString("#FFFF00");
- }
- }
- options2.outlineWidth = Cesium.defaultValue(options2.outlineWidth, 0);
- let polygonMaterial = options2.color;
- options2.outlineColor;
- if (options2.CircleType === "DynamicCircle") {
- polygonMaterial = new Cesium.CircleRippleMaterialProperty({
- color: options2.color,
- speed: options2.duration / 1e3,
- count: options2.count,
- gradient: 0.2
- });
- }
- let entity = new Cesium.Entity({
- id: options2.id,
- position: position2,
- ellipse: {
- semiMinorAxis: radius,
- semiMajorAxis: radius,
- material: polygonMaterial,
- outline: true,
- outlineColor: options2.outlineColor,
- outlineWidth: options2.outlineWidth
- }
- });
- resolve2(entity);
- });
- }
- });
- Cesium.Primitive.prototype.setUseGeometry = function(geometry2) {
- this._useGeometry = geometry2;
- };
- Cesium.Primitive.prototype.getUseGeometry = function() {
- return this._useGeometry;
- };
- class SketchViewModel {
- constructor(viewer2, options2) {
- this._viewer = viewer2;
- this._init(options2);
- }
- _init(options2) {
- this._viewer.scene.globe.depthTestAgainstTerrain = true;
- this._viewer.cesiumWidget.screenSpaceEventHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
- this._entities = this._viewer.entities;
- this._pointEntitys = [];
- this._sketchPointImage = void 0;
- this._iconNormal = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABwAAAAcEAYAAAAinQPXAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAB2FJREFUWMO9mHtQlNcZxn/nW65GxHtEqTEajUxVoLYRSIyipHG4qG0lajtxVIRFubgqXuOI28ZE7FAvCLKLSNKxg/FSIzdvqNE62kaRitqpYMxovBGigo4I4n6nfwjsCrsLrtjnn53vnPe87/Oc9/2+854VdBhCd6ZP6dMHlAXO/lOngrzMLz/8EEQ0ASNGANNY2aOHxYIdfHr3LuBCwPnzQIKcf/AgiJ8pQV99BfmvR4+orHxZVsLxpZFT0qd07gyP7zqrej3IInF47lwQkTLV3d1xv3KXWPT4MYhLzMzIgHpn10+Sk+Gw74w+jx79HwSGnzUYhg4FED4FBcBq/jtokOOC2oSb0FZUgHpKVoeHQ9GtGM/y8lcgMLxf5juDBwNDlOWnTgGvUdWz5wsQ7c179fUWzz9y0tX1BdZPILeqCpTtil9QEOT9c876K1faWqS07XeMzJFuboCXkpaX1w5hqxl14QJIKYRWCzLV5OXtDQXbon3c3c2/TeMoYvncucAgPrl40Y7fA0zv1QtMydKwb58FL7toRwbDYo3/0utB3OD8qlX2hIkLqalwO0b9+fLlUHJOG9vQ0P4EjfyFIdPZGfqsURampIBIlxsWLLBtL/NltF4PhUIrVq92QGDIeEOmpye4pYju164Bq6n29LTiopy8tDTIL48pSExsDq/Oj9is/eAD4CRbli1DMEFUBAYCewnUaJD8jr2lpQjpJ7M2bBBi0+L47Tt2mP2G5xhNaWnAHrLj461tKF1rasA0rW5b//6w/0rigQcPWhrZKVFXP8TkybaFyb3kXbkCbiO6fpyU1Dwq58vNG3U6BJvEiYMHEcwQW8aNA3pT7O4OaPmTiwuCnlwcNQrEDRGYmytloilj5vr1Zv+mNXVhSUnmOFYEVnt6gtM9t+8mTbKlwo5AoWdySIjteWUcIwwG2LX7o6lPnkiZULTlj/7+wEThm5oKbCBeCOANUisqkNRxLCEBSSzrYmOB3jw6c8Yi3kL5K51OyvkZGXUTJz7LSH09CIPwMBpt85CHhMf48Q4IJFPofHzsbMAAJfjIEQtXC9TZWi0wkEuKAmjEyspKpNN2pyVBQULZaIjbvXmzUDb6xF0zGJCqv+no6NGAK5fLyiz8JssVcXEWgQLUsZZxWmGbrLTN057Agfh7eNiefhpRb7h922LgOzFp2DDzxnJXrsvLE0rqOW3sTz+12h4lLfRZhuQybuXmWmQkgPzhwy0o1jlV37ljh+e3/L1LF0cEXqX04UPb0075rlovLwtBHuqZ5845T5Z37UqbEAPkzOfsUvlHXZ35saFnQ4++fe04eIfftv64tEfgdvkXeweprFIvBQaaebJH+f3x4xbPvsRPnixlQlHGtDFjWq2Wuqj0yz4+QKk4FxNjMVXD2998Y0FRKEsCAuzwzBKv2eZpR6DspxQcPWpnvrNYoNNBZOTOnRoN0ilJMzYjA3ibsKoqoIxezs6gLJbpxcVSTbyePurwYSkT76VPKSgAWQslJcAmenTrBszgP7W1wBlRmZICY2SydHIC8ZCvdTo7Ak+ri44dcySDNDTs2mVufluhThoGD4bHp6or4uOb3zWJnoqwMGAVLnfuACHscHJCiFRmhISA0BMcFob52PDC/8EDkLfkR5GRQmycN8/t8mXw8O73WVwctnvdJ3SqrQXNSJeY3bttaWhHJxMxzDh97VqQAwheutR2IC6pm/z8oOBm7LcVFVJNKNo0oUsXhBKmGR0VBfI0vkFBINzExxoNEKP+ePYsktefFmVnC2Vjvm5SZSVEpGUNefNNUH8ti8rKQCziaOfOVuL2563PP4eCjJhxK1a8hMCJJ7NTPDxAXWIaefEi0J2r/ftbMfyryDhxAkZ2u1EaHAx6oReq2rb/JiTLZKkoUHLf2//YMWCGnPf++1YM7zHw+nVQ1mlKhg2DvPeiltr+GLaj2W524Kd6zZ4NhGOQ0ophI6GSkr4Gq61VGyjx7vdZQoIdYY1xVZ06RKttS1gTHLkPLjVmGo3AJZToaCsGjSWrPFBKfH3bvta0uyR3ySlGIxS4a7trte1l244MtoRpT93XSUk0l0oruFDbqROYUtQ9X3xhLr2WaBpX4+WnOTl2hHkw9eZN0Li5dLP6Dehogc1dexslK/7MynffhbNDvZXnWq9GNJWyiKC69TlphvobtWbOHNgnZonq6hdl+xL/yTQhbKUxeOtWEP9melSUFYMWJSv/IAtNprZLUu4Rf9u6FQpdo49bfRXaBQcy2BL1p+XURYtAZrLwhx+sGDSWrDpc3ZeVBbJMPt22zY6wRj/1oep08zXMUXRABpsQFmqcHhICYiLlhw4BBWiFA/5FOXmhoc8u0Pv3vyyrDshgEwqLYnKLi4FO5OfkvPh66UdudnZHCXsFAptQ96XMW7jQTsm2xAF23roFlD6NXLy4o9m8AoHFR7SxNTWgjGOsVovtxqBxXAzEbc4cKCycN+/+/Y7n88oRvjarcNYsCDtprP/+ewjvZ1xz9SpERBp3zpz5qqP/D5zQE33tptaiAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDIyLTA0LTA5VDE2OjQyOjI5KzA4OjAwjRBbGwAAACV0RVh0ZGF0ZTptb2RpZnkAMjAyMi0wNC0wOVQxNjo0MjoyOSswODowMPxN46cAAABKdEVYdHN2ZzpiYXNlLXVyaQBmaWxlOi8vL2hvbWUvYWRtaW4vaWNvbi1mb250L3RtcC9pY29uXzJhcHo1b3VpcnV4L2Rpbmd3ZWkuc3ZncY9vkgAAAABJRU5ErkJggg==";
- this._iconBlue = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDozNjZmZDYyMy02NmE4LWYzNDUtODc4MC00YmMwY2IzZWM4OTMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MkEyMUE1MDg3NTAyMTFFREI0RUY4MjBCRjRGRDc0QUIiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MkEyMUE1MDc3NTAyMTFFREI0RUY4MjBCRjRGRDc0QUIiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6OWFmM2ZiODktNzQ4OS1kMDRkLTkyNzUtZDM5MWNhYzYwMGE1IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjM2NmZkNjIzLTY2YTgtZjM0NS04NzgwLTRiYzBjYjNlYzg5MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pv/grmkAAAhxSURBVHjazFoLUFVFGN49597LBdFUEpEQI0IpyxIfqU1ZkY/pNZg1RZlWY2lW4yMncxq18oHZ0+lhOaWZUo0zPjIr8W1NiubI+AxBIkRQQsQE7us8tv3P7qGL7gXOPRdzZ3bmcnf3+7/v/Lv/+f/lYkIIMpur2yBktQVO5yM7LRybIvsOFKFGCeHyQz/dFO2Ousflcg6UJSlVlqVEjHEMjNMH5tE0vVLT9ZJAQNnn9fm3d+9z3xEYioR9bNcjW9Z8Gtv35l7PUAFjnU5HLytrFUU9TgV9XXD4+PJhoyfV2/GIFO4TGD8my1lVuGXSHYNuPdyhfbv5VkVAgzWwFjAACzAvp0fwoV++uz6lxzXLolzOW1AEmz+gHCwtq3i2z52Pn2jtlgvXI1LpgQ0jeqYm74y0CGiACdjUxkir3KxMlsoKNj6WmNAlV5Kk9qiNGmBTG6vAlhV+rd1aUuGeNSNSeiSuolGo2X1cdDogbThQ79h21CMfP6NKtR4dw/edYiTSK8GhZ/aO0R7KiFV7dnPpzeFQXkppWeWY9MGj8+ifektbqzVC8KbVH6UNHdJvOw2nHUIB7vrDI89df861p0SRsUSjuiSzB4qxyYzx0TVEdBUNTnVqs7I6B4beEKOFwqThuu7X/IJ7hj/yYlGoM9NqIakpSVH7t67c3C4muq8IyKcQ9EpuddSK3xqcSHJR7g7WsSkCm8+YiSEgRuU9gMbd3k5578kufrcTC8U0eLwF/e99anhJ6Sm/HSHSid/Xv5CclJAjAjlXr+GHP6x07z9JZCSDCBfzBJapBomJabJfdKqFCiGa4RkQgrQA6p+MtbVTEn2dY2XhUz956szM6wdkLRFtsVZFrReeeaRTQte46aIxT4DgrA9ABJKRw42QTLsjimqATgUZwpxNO/0OGz3KmMvWuBFgABZgimwBB+ASbtSSp0zIHutyOuNEg9NW/e06UE49YRBi5LFB2NxaMoQg5iGJfza+Y+MwlwlmogALMIXpD+UAXIBTOEKi4rt0zg51sFft8TjN7YQbnzrbVpeeD8Q+w3fYFCQba9ha5kHABGyRTcrlCeBkVQjO/Wxeb3rA00WDb62rcbHzAARML0hBAloK+lyQ4TEHx2B4BragUS69vl06/6aLnk6LQuQ+vdMyRQMHT/ql/D9VGfEQi00PGFDYwqsP8/AsMQyJbTvABhuiFb3TU+8Otb1CCXFd1SF2gGhg/f56Bw4+B9iCJ0J5Bv93fgAbbIimd7yq/UDgZklITLQ7RTSwp9grs7MgBYXYMEQ0OTtBWBR7d5FX+NQ5J0tCHG63K0GYglSpkrklGkXY1GGKMbdo8d+qkBfn5LB0RpwOeDlc2mo9NNYHbyOMIuCRptvNsCGqXxgnS2dEoslhxMrgSDXOSbL0HlFVzSv6vlMMJigorWGpnJ2ymzRdTrENGxY4NSeE+PwBYQ3ds6tDN1IewvvFRMLQwTBMPB2lxTuEaTvnRKwI0S/U1ZeLBganRWtGwteYAOoR8EgQFsUe3DNamNpzTroVIWp1TW2xaCCrf6xKzDScaP89SRKGGBLkCSMjVo1aZRS1IZrOOalWhCgHjxTvEw3ckhylD7rOobF6ghZJphhk1TO80DK8Yab1KgJssCHMKhgnxYqQQM7i5bv9AaVONDh7VFzAqCWMekLhRZIFzzQWWLzIMjAY3qwsii2+YakDTsDNkkdoRVZbXHLyN9EglKdjh8QoUBSBcaIDEYU91cbtRi7yUFCF2OgBha9lBRZg3nWjuPQFLsDJqkfAtfWfr1jzDSHiR/zuk/GBjO5YQyqtQDU/5WYKCjo/Oicd/JmPw1xYA2sBA7AAM8RFBAEuwMnqYTei3Q95vx47U1VzTJj3uDBZNzXRl9EdUTE+SshnECJcFPOWwraNxj0GYo3OyLM1PgQYgAWYIlvAAbgAp3AKK6XyTPXZ56bOm0f3p/BFFEdr7LwZSd5xQ9wKUukUo/u4h8SdecCHzPmwdtOMJF9ciHodbE+cvmA+cAm1rVoSAsD1m3fmH127cfvSUJOiXRh98nS8/8dpXb0DknWNKB5qzsOIKlwYdIULpWMwB+ZunNrVC2tDeQIa2P552+4jfFsROxd0sbRfm5/31dyMPumZLQWkwsqA9EOTCzqCzdTGvKB7MCNWTU9s/oIOWsHh41tvGz5uNv34Fxdi64IOvNaxQ/t2aXvzVixKTUnqezkSRBqhCm4bMW7GhboGuJw7H+qQW7nEBoALFPCvOx8cP+toYUl+W4v4o6h0L9iiNkvBdnNXplYvsSEtOFddc75owLCxc6jLd7aVCMDulzlmDtgCm6FSEju38RAxztJUumTkoy+9faqyqjDSIgDzgezJi6gN+P9Is1HKjpBGz9T+U1cy+ulXZ9XU/lMRKRGABZjUEyeseCJcIY1i6BY4NmHagjlen/+CXREUow6wADMcEeEKQTxxq96wadfvCz9cvpBuBSVcEbCWYuQAFmCGSgrbSojx0qW9KmfxV5u/zP1+MTEqI6vlCNFhLWAAFsdEl1sIvIAgdTn98muL1mzZtXe1VYCtv+xbDWsBg2OR/0OIKaaB9ooHsqcsoXt8h4Uwu+P+xyfD/zwqOIatHw7YFQJvVthSUICVDxs9Kae0rOJwS2vKyk8fgbmwhq/V7fKwLYSLgWLoPLz9s59//c3mwjKMPTZ+5hswl6ceWiQ4REQIF2OE5QOHCo9NfCVndoPHW3vxHPgOxmAOzOVr0BUlhIuB0Hn2+5937p/77hcLgsMyfF7wwbKFMAZz+Fx0RQoJDsvvL8ndYYZlM8y+8/HKbXbDbKgW8ftd+qQJLQcglFZCaE3qFn81wogEh1mYE/F74bb64RnFAm/DDwy6mPdrkJLzKGfLpsj+vwIMACSZzfDJFmOPAAAAAElFTkSuQmCC";
- this._iconGreen = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDozNjZmZDYyMy02NmE4LWYzNDUtODc4MC00YmMwY2IzZWM4OTMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MjI1NDIwOUU3NTAyMTFFRDk0MTJGQzhGMTFCQkREODIiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MjI1NDIwOUQ3NTAyMTFFRDk0MTJGQzhGMTFCQkREODIiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6OWFmM2ZiODktNzQ4OS1kMDRkLTkyNzUtZDM5MWNhYzYwMGE1IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjM2NmZkNjIzLTY2YTgtZjM0NS04NzgwLTRiYzBjYjNlYzg5MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PgEE4igAAAgKSURBVHjazFoJbFRVFP3L/OlMoQXKImAFm0JbFtFKShEQI6UsggmkGKghIKTIIgZUohIDKEuLaFTQiIKyKKghqSyyF0pZbcHQsJVpoRkKbYFAW+iU2f78/313+qY+hvc78+dPkZfcMJ377rn3/Pve/fe9gVUUhfENY5eBjNbhvlnI6Bmh+KT5NzBhGigg9sb5vX3NpohhRqMwgOe4eJ7nurIsGwl69MDskiRXS7Jc7naLpx1OV/4z/V67CKpw+Gf1ZiQv9/vWyc8lTkMEpgiCIVGLrSh6ShGhX4ovlG5Mz5jToCcjXKhPIGvyOOG2JW/OywNfuBAd1WqFVhIwwAZsAQOwAPNxZoQ9f+yPHnHdn94QYRSeZ8I4XG7xnLWianq/oZOuBrvkQs0IZz27a2RCfLeCcJOAAZiAjXyM0hqblslcRfHuiV07d9zKcVwU00IDsJGPLeBLS3zBLi3O8nfuyLjuXbegKtTsOrY4Ldz22u2GPFue4bL7MlfrqWXh+xhDjNLL2EtOj0r3jI8Z70kyJcnN4aC4RGtF9eSklzIOoD/lQEsrGCLs/m3f9nxlUP98VE6j1QDz6/P5xZWLI06KJ3lGwIWdB2tfZEgkJB4oVwwzWBgsLY1d6hoWPUxSw0Tl2na8sHjYiAnvlKntmaD3SHxcrDG1f9/1aiScspOZYZ1hGm4dHnmSRyRglk+i/ITQwVywAVvAoA3kMyolufc6iEHv0uKuntkxu1ts5xyacY2nhh1TNsZcpBTxjBl2K4AQ2eD8MiITWXFDmULiYJhUNlXak7DH0d7QnvrUr1feWtgjZdxa2hILKiOzp01o1/mp9gtoOrtsZ0eXjjYXMYhEa/RFKyxmLCaCmBF/NhF633xkCxiABZg0XxADxBJq1eLnz8ycYhSE9jTl3Iq5EWeYM/wjwUPQvj1CEwHP8SMFWIBJbX9QDBALzrNmIhGdOsZkqm3sTfWbhKbgTcSSMhBLiiYcMc9I2CMswARsmk8Uy5s4r5qIsFt/WN6nVaQ5iaZcVLkoQjEpjbD++4IM+hFUQniCDMYBTMCm+USxJP6+bkVfFWRVIny/Pj3TaIpiezF3SjzFN619AaNwRLABSwzhnSOWGxLABh80sz5J8a+qLS81IsY20a1TaIrc2lzhoX3A+2Ui6FcxkRn+4f3j9UEZbdtEDcCUgycSaTbF0RQnGk7wTY79S2xIbSvGIDCPNxynPnUckyYiBpPJ2JmmKBVLuSYCXIA9EWxWWAIPYZeJZdS4cEwGTXtEMBhMNEWthHonVieB5gix2Aft/NIYk6Y9wqHmMGzH4HANHBOn6T3i8UgO2vcxfIzibTdI0Tv88Lw+NMTUHBHF6XJTz9CJQqLs7ZdkLHoIkbbyf71YgpBAbdtxTIoWInK9reEGTTGk9RCpqfGTCDJ6skE2kxL2QRk4JlkLEc+dmrorNEVGTIbo7VxFgowUQlYU4oxCnFMAe0LMBJFmgmPyaCEinrt45TRNkRyZLA8SBkleMj5CMvGclCBJMIQdJgAC2OCDZoZjErUQcees3njK5RZtNOWy2GUu1sk2nidcOAiPX2aUAHvC/1yCBDDh1Khyw2KDmLBF8Bkpt1bWXSm/fpKmhOPp9OjpIhyKGCcWHxkPpQj4b2oPQcJnj7AAMy06jbo/IBaISWtGwF3Dj5tzf1PIIyQx1nRf40phUiTmQWMQTaTI/ePx2wPEPvAF7xWEAViAqXIRoUAsEJPWze6tdn8dOF5y63ZNCbXv4SKVvYl7HSkKItPQGMwjpFx+4he8V5AtYAAWYNJ8QQwQC0bQfLASq2/duTvjveXL0fqkvog6GDooR3sdtWdFZomsjW18Xj5SdhXBwYOADdgW9CpwAJbK3nDMWpC9AmJRW1aBiABww8GCwkt/7s5fpzbJzJmZ9XHrnYfiDtkHSgMlph59CSXC9y8phA7m5sXl2cFWLRMwwPe+w6cuYvqKngs6uFp4tvDApmUv9ktKC1RZSxwl3I66HYaD9QcNFtHC+RpAaDuShCR5RPQIz7h24zy9zb3lQFjFF0oPpY6Yuhh9vIaJ6Lqgg6y1jY5q1bPowOZV8XGxyY+jQUQVqjh15NSP6m0P4HLuntom13KJDQD1CPDa0NezFl2ylBe2NInLZdYi8IV8WvGCDJi9YC+JoXDW3qm5V5aSPmUJSnlBS5EA7P5pk5eAL/Cp1pLouY2HinEXtdLlo96Y+3ll9W1LuEkA5tjMeauQD/h9pNkqpYdIU2bq7tvKM976cFFN3f2qcJEALMBEmbiqJROhEmkig5ZAycz3s5c4nK56vSQQhg2wADMUEqESYXCTcWfX/qNnVn6zcSVaCmKoJMAWYeQAFmCqNYUtRYTBTcftnNWbDv68dedqVMZlrQBgA7aAAVgYk3ncRBTcNd189+NVuXlHi7ZpBTh07PQ2sAUMjKX8H0R8ZKB7qhqbOX8tWuNHNJTZI2MmzYPfPKowhq5rDL1E4M0q4w7qRnrGnBxrRdWFQDYVN25ehLlgg21lvXHoJoLJwInjHrz9M9/+5LPmyjLoJmYt/BTm4tZDCkcMYSGCyXjL8tnzlpJZH+QsfmB31PnPge9AB3NgLrZhnigimAyUzrs79xX8s+zLn7LJsgyfs7/esBJ0MAfPZZ5IImRZ/mrt1iO+suwrs1989+thvWVWbYT9fhc9aQUdB6CUVkNpje3SqQPDMgpZZmFO2O+FW+o/niEsyDb8qt7Rd78GLTmucrp80vz/K8AAYAEv1AHM/GwAAAAASUVORK5CYII=";
- this._iconViolet = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDozNjZmZDYyMy02NmE4LWYzNDUtODc4MC00YmMwY2IzZWM4OTMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MzFDREU3Mjk3NTAyMTFFREE4MThDODBGNzMxNDBCQzEiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MzFDREU3Mjg3NTAyMTFFREE4MThDODBGNzMxNDBCQzEiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6OWFmM2ZiODktNzQ4OS1kMDRkLTkyNzUtZDM5MWNhYzYwMGE1IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjM2NmZkNjIzLTY2YTgtZjM0NS04NzgwLTRiYzBjYjNlYzg5MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Ppb+WxIAAAhcSURBVHjazFoLcFTVGb6vvdnNY0lEEJOIxhCSKTEFKSC1osIgjqIyA62mZfAxWJU+tC3TVh2lHSGhtNOKOqK0ii+0QwcfFB+IAsKIITpJhUBDHhMiSSBCTMgm2d377PnungubnXOT3L0b6rlzmM2e83/n+87/n/+ecxbeNE3OLvLFV3Fui3KiivNSkhmTNb7EpagQQvzxg++VBvxpc2XZN1MUhEJRFHJ5nk9HO5mwAV03OnTDaFYUtTocie66pOymOjSlYnzeq0d2bn02c9oVxXcTAct8PqnYja2qakeJoFdqDx3dNH/xij4vHhGSnYHlSxf5Out3rrjmqqmHglkZa9yKQIENbIEBLGCeT4/wB/f+c1LBpXkvpsm+73IpLFFF/bKltf2esjl3NI005JL1iNBSs23B5MKJe1ItAgWYwCZj3OiWm5vOQmvt9ttzJ4zbLAhCFjdKBdhkjNcwlht+Iw0tof6zrQsKLs19jWShIeM40hASure3S727O0WloV/QehTeSo/ZsilPzjCC11+k5yzM0/yTs4yhcAgvtaW1Y2nJ7MU7yJ/GcKE1EiH8B1ueLrr2+9N3kXQadAIM7f1abK84LEcOnBFFXuREMpk8TyrHx4jhMQ1OJ5x0U+f8s8boeY9MUbLmjNedMEm6Du2rqp17w5KfNTitmRGvkcKCfHnW9NK/O4kwIjp37JdfpDUv+jSgVw+IASHAofpRef/gSttQ0Rc2sAUGq5Axs2ZM+85GcPAaWkLT528/MDF/QiXLWPtG4Rt/tM+v1vSLMi9zPl4iniCVeASeEPjB82QQj8Az8IjOaZxqapxiKpzvygy9aMs1EekCmTnrX7WdfHjSjEUbWCE2Io88cPeSnAkXjV3J9ERY5xuX7PNrNQOin0/j0kiVUQUI8llVSnjs79FHpjawBQawgMkaCxzAJdmsJT50X/ky2ecby5yllTWy+p9+MY2PkYonb60RUuER1udBoixBMgcsYDK3P4QDuIBTMkLSxo+7oNxpYfe80eaLhZPMSSSkUAU8vPWvFVr2QrdimD7xfWw7nzUZMgdMYLPGJFx+DE5uhfCbn1s9JSM9UMJqbF9TJ5O5tNZEooh48o4Lk66fwWJIJZjAZtkQLsVvbFxTapm7ECKWTSmax2oYONgjRKp7RSluYbsRwRITS9cxQcDGGCybKSWF1zuFl5MQeUwwcwaroXtbmyTRWLdFkJekKxGDwo3nz4nB+iEVY7D6Z4/JmgluroSkB/wFrIa+z7rE2DyeWwfJiEhcO2fXD3n69p9mzjrl5EqI5PfLE5hv0qZ+gach4TacRhJmwFaaB5i8KCfJ1RrxSZKfuW3oUflE8l49kvg3xmCeX2KcXK0RMut8yo7BqSqUk+DqPaJpepjpqmyfaSbs30wPx24WFsZww2koIWYkqjDP0PKkDAO7WOuheyevBRgGxQS2XJjO3LZTTqYbIUZvqO84qyFz9lidyohtzenjRYT92LiZsy9kbocpJ8ONEO1UV3cjqyHn1nxNw+6V1tgsJicmdkaJCbDxgJ1zW77G6k85aW6EqF/WNVYzc3lZtuGfGdQ1sgXHVtwW4zbM4sPJ3tYDE9gYg2VDOaluhCiV6zftjypqiNWY92iponKKdZ7QaHUjJl6EbQ8sYOY+Uqo43LCEwAncXHmkuaWtu7H5q09ZjTieZv/kEhWHIpXURDHx6ydxLcT3OSdCsQ5YwAxeyz76ggs4ufUIXNv3/MtbXzfjj5BxZeK6aYpvaoYetUhECRnVqhoNNyvkTIP5WbNOh7H+sAUGsIDpcBFhggs4uV3sVrb79459R052dh1hGgZEs+hfP4hIU9P1iEUmapFSDGWQqPjnLHlDoQKiHGyBASxgssYCB3ABp2QOVmrHyVOn7/3V6tUkPpkvImlsmln83nXh4NJcNWKGuYgRIxcTpcQIx1fynd2OvrCBbfG710WA5bA2wvevrFgDLk5hNZwQAPd9uKfq8Jvbd210BPCL3GVPfS9a+PbVYWF6QA8bEBSrYYgzI1a1Ptvfk4q+l791dRi2Tp5Awdjvf7y/joaV6eWCLpPUy6p2vPTElWUl84bLSOH6XqHn3Xapd9fXotLUJ+jdmrUBFHMkU56UaQTnkkRxc54WKAkaw2HVHjr60awb7nycfDxGhXi6oIPXsoNZGUUHdry8rrAgf9r52CCSDFU7a8Gdv+sN9eNyrsdpkbu5xAZALwE8NueW5Y8drm+uGm0R/21oOYCxyJgtGHuoK1O3l9jYFnxzqqunYcb8ZauIy/eMlghgT5+3dBXGwphOWxIvt/HIGKfJVrr5xh/+/E9tHZ31qRYBzIXlD64jY+D3kSGzlBchZz3TfSbUvPiu3z7W1X2mPVUigAVM4okmN55IVshZMSQEjtz364pV4Ui016sIghECFjCTEZGsEI5u3E5t++CTz9c+uWktCQU1WRGwJRiVwAKm06ZwtIRYL11SOyvXv/ThC5vfWW/iaOf2PEJsYAsMYFFM7nwLwQsIW5cTv/j9uq07PzmwxS3AR3urt8AWGBTL/H8IscX04zp4YflDG0iM73aRZnfffMeD+M2jnWJ4Ovx7FYI3K0IKB7Dj8xevqGxpbT80nE3r8RN16Asbamt45eFZCBWDw1AP3v7lP330j0OlZbTdvvzhP6Av3XroqeCQEiFUjJWWaw7WH7n/N5WP9w+EuxP74Du0oQ/6UhvuWyWEikHqPP3O+3u+eOIv/6iIT8v4XPG3F9eiDX1oX+5bKSQ+Lf91w+bddlq20+yfn3n1Y69p1qmk/H6XzLRJjgNIpR1IrfkXj7+Q4zkzPs2iT8rvhUfrP54RLHgbv82Ps+/XsCWnWc7TmKzx/yfAAHo1CtU9myPWAAAAAElFTkSuQmCC";
- this._sketchEntityName = "sketchEntity";
- this._sketchTempPoints = [];
- this._sketchPoints = [];
- this._sketchOutputPoints = [];
- this._sketchTempPolyline = void 0;
- this._sketchPolyline = void 0;
- this._sketchTempPolygon = void 0;
- this._sketchPolygon = void 0;
- this._sketchTempAltituePolyline = void 0;
- this._sketchAltitudePolyline = void 0;
- this._sketchAltitudeInitHeight = 0;
- this._sketchTempSpatialPolyline = void 0;
- this._sketchSpatialPolyline = void 0;
- this._sketchTempCircle = void 0;
- this._sketchCircle = void 0;
- this._sketchTempRectangle = void 0;
- this._sketchRectangle = void 0;
- this._sketchTempTriangleAltitudePolyline = void 0;
- this._sketchTriangleAltituePolyline = void 0;
- this._sketchTempSpatialTriangle = void 0;
- this._sketchSpatialTriangle = void 0;
- this._lineLabel = void 0;
- this._polygonLabel = void 0;
- options2 = options2 || {};
- if (options2.isDrawPoint) {
- this._isDrawPoint = options2.isDrawPoint;
- } else {
- this._isDrawPoint = false;
- }
- if (options2.isRetainDrawPoint) {
- this._isRetainDrawPoint = options2.isRetainDrawPoint;
- } else {
- this._isRetainDrawPoint = false;
- }
- this._param = {
- moveLineWidth: 2,
- lineWidth: 2,
- moveAltitudeLineWidth: 2,
- altitudeLineWidth: 2,
- spatialLineWidth: 2,
- moveEllipseColor: [0, 255, 0, 0.5],
- moveEllipseOutline: true,
- moveEllipseOutlineColor: [255, 0, 0, 0.5],
- moveEllipseOutlineWidth: 1,
- spatialLineWidth: 2,
- ellipseColor: [0, 0, 255, 0.5],
- ellipseOutline: true,
- ellipseOutlineColor: [255, 0, 0, 0.5],
- ellipseOutlineWidth: 1
- };
- this._setMoveLineStyle(void 0);
- this._setLineStyle(void 0);
- this._setMovePolygonStyle(void 0);
- this._setPolygonStyle(void 0);
- this._setMoveAltitudeLineStyle(void 0);
- this._setAltitudeLineStyle(void 0);
- this._setMoveEllipseStyle(void 0);
- this._setEllipseStyle(void 0);
- this._setSpatialLineStyle(void 0);
- if (options2 && options2.iconType) {
- switch (options2.iconType) {
- case SketchViewModel.SketchIconType.Normal:
- this._sketchPointImage = this._iconNormal;
- break;
- case SketchViewModel.SketchIconType.Blue:
- this._sketchPointImage = this._iconBlue;
- break;
- case SketchViewModel.SketchIconType.Green:
- this._sketchPointImage = this._iconGreen;
- break;
- case SketchViewModel.SketchIconType.Violet:
- this._sketchPointImage = this._iconViolet;
- break;
- default:
- this._sketchPointImage = this._iconNormal;
- break;
- }
- } else {
- this._sketchPointImage = this._iconNormal;
- }
- }
- _arcToDegree(arc) {
- return arc / Math.PI * 180;
- }
- _toColor(red, green, blue, alpha) {
- let normalColor = new Cesium.Color(0, 0, 0, 1);
- if (typeof red != "number")
- return normalColor;
- if (typeof green != "number")
- return normalColor;
- if (typeof blue != "number")
- return normalColor;
- if (typeof alpha != "number")
- return normalColor;
- if (red < 0 || red > 255 || green < 0 || green > 255 || blue < 0 || blue > 255 || alpha < 0 || alpha > 1)
- return normalColor;
- return new Cesium.Color(red / 255, green / 255, blue / 255, alpha);
- }
- _toColorFromArray(array) {
- if (!array || array.length === void 0 || array.length === 0)
- return new Cesium.Color(255 / 255, 255 / 255, 255 / 255, 1);
- let r2 = 255, g = 255, b = 255, a = 1;
- if (array.length === 1) {
- r2 = parseInt(array[0]);
- } else if (array.length === 2) {
- r2 = parseInt(array[0]);
- g = parseInt(array[1]);
- } else if (array.length === 3) {
- r2 = parseInt(array[0]);
- g = parseInt(array[1]);
- b = parseInt(array[2]);
- } else if (array.length >= 4) {
- r2 = parseInt(array[0]);
- g = parseInt(array[1]);
- b = parseInt(array[2]);
- a = parseFloat(array[3]);
- }
- return new Cesium.Color(r2 / 255, g / 255, b / 255, a);
- }
- _updateScene() {
- this._viewer.scene.requestRender();
- }
- _getScreenClickPosition(screenPosition) {
- let resCartesian = void 0;
- let ray = this._viewer.scene.camera.getPickRay(screenPosition);
- let position2 = this._viewer.scene.globe.pick(ray, this._viewer.scene);
- Cesium.Ellipsoid.WGS84.cartesianToCartographic(position2);
- if (Cesium.defined(position2)) {
- resCartesian = {
- x: position2.x,
- y: position2.y,
- z: position2.z
- };
- }
- return resCartesian;
- }
- _getScreenClickPositionAndHeight(screenPoint) {
- var lng = void 0, lat = void 0, height2 = void 0;
- var ray = this._viewer.scene.camera.getPickRay(screenPoint);
- var position2 = this._viewer.scene.globe.pick(ray, this._viewer.scene);
- var cartographic = Cesium.Ellipsoid.WGS84.cartesianToCartographic(position2);
- var feature2 = this._viewer.scene.pick(screenPoint);
- if (feature2 == void 0) {
- lng = this._arcToDegree(cartographic.longitude);
- lat = this._arcToDegree(cartographic.latitude);
- height2 = cartographic.height;
- } else {
- var cartesian = this._viewer.scene.pickPosition(screenPoint);
- if (Cesium.defined(cartesian)) {
- var cartographic = Cesium.Cartographic.fromCartesian(cartesian);
- lng = this._arcToDegree(cartographic.longitude);
- lat = this._arcToDegree(cartographic.latitude);
- height2 = cartographic.height;
- }
- }
- return {
- lng,
- lat,
- height: height2
- };
- }
- _transfromFromScreenPoint(screenPosition) {
- let location = this._getScreenClickPositionAndHeight(screenPosition);
- var cartesian = Cesium.Cartesian3.fromDegrees(location.lng, location.lat, location.height);
- return {
- gLocation: location,
- sLocation: cartesian
- };
- }
- _removeEntityByName(entityName) {
- var entities2 = this._entities;
- if (!entities2 || !entities2.values)
- return;
- var delEntitys = [];
- for (var i2 = 0; i2 < entities2.values.length; i2++) {
- if (entities2.values[i2].name == entityName) {
- delEntitys.push(entities2.values[i2]);
- }
- }
- for (var i2 = 0; i2 < delEntitys.length; i2++) {
- entities2.remove(delEntitys[i2]);
- }
- this._updateScene();
- }
- _removeEntityByObject(objEntity) {
- if (!Cesium.defined(objEntity))
- return;
- this._entities.remove(objEntity);
- }
- _createPoint(coord, label2) {
- let _self = this;
- let entity = new Cesium.Entity({
- name: _self._sketchEntityName + "_Point",
- position: coord,
- billboard: {
- image: _self._sketchPointImage,
- horizontalOrigin: Cesium.HorizontalOrigin.center,
- verticalOrigin: Cesium.VerticalOrigin.bottom,
- scale: 0.5,
- pixelOffset: new Cesium.Cartesian2(0, -11),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- }
- });
- if (label2) {
- entity.label = {
- text: label2,
- font: "12px sans-serif",
- fillColor: this._toColor(255, 255, 255, 1),
- outlineColor: this._toColor(0, 154, 94, 1),
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- outlineWidth: 1,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- pixelOffset: new Cesium.Cartesian2(0, -28),
- showBackground: true,
- backgroundColor: this._toColor(0, 0, 0, 0.6),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- };
- }
- this._entities.add(entity);
- this._pointEntitys.push(entity);
- this._updateScene();
- }
- _removePointEntitys() {
- this._removeEntityByName(this._sketchEntityName + "_Point");
- this._pointEntitys = [];
- }
- _createTempPolyline() {
- let _self = this;
- if (!Cesium.defined(this._sketchTempPolyline)) {
- this._sketchTempPolyline = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(function() {
- return _self._sketchTempPoints;
- }, false),
- material: _self._tempLineMaterial,
- width: _self._param.moveLineWidth,
- clampToGround: true
- }
- });
- this._entities.add(this._sketchTempPolyline);
- this._updateScene();
- }
- }
- _createPolyline() {
- let _self = this;
- if (!Cesium.defined(this._sketchPolyline)) {
- this._sketchPolyline = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: _self._sketchPoints,
- material: _self._lineMaterial,
- width: _self._param.lineWidth,
- clampToGround: true
- }
- });
- this._entities.add(this._sketchPolyline);
- this._updateScene();
- }
- }
- _createTempSpatialPolyline() {
- let _self = this;
- if (!Cesium.defined(this._sketchTempSpatialPolyline)) {
- this._sketchTempSpatialPolyline = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(function() {
- return _self._sketchTempPoints;
- }, false),
- material: _self._tempLineMaterial,
- width: _self._param.moveLineWidth,
- clampToGround: false
- }
- });
- this._entities.add(this._sketchTempSpatialPolyline);
- this._updateScene();
- }
- }
- _createSpatialPolyline() {
- let _self = this;
- if (!Cesium.defined(this._sketchSpatialPolyline)) {
- this._sketchSpatialPolyline = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: _self._sketchPoints,
- material: _self._spatialLineMaterial,
- width: _self._param.spatialLineWidth,
- clampToGround: false
- }
- });
- this._entities.add(this._sketchSpatialPolyline);
- this._updateScene();
- }
- }
- _createTempPolygon() {
- let _self = this;
- if (!Cesium.defined(this._sketchTempPolygon)) {
- this._sketchTempPolygon = new Cesium.Entity({
- name: _self._sketchEntityName,
- polygon: {
- show: true,
- hierarchy: new Cesium.CallbackProperty(function() {
- return {
- positions: _self._sketchTempPoints
- };
- }, false),
- material: _self._tempPolygonMaterial,
- classificationType: Cesium.ClassificationType.BOTH
- }
- });
- this._entities.add(this._sketchTempPolygon);
- this._updateScene();
- }
- }
- _createPolygon() {
- let _self = this;
- if (!Cesium.defined(this._sketchPolygon)) {
- this._sketchPoints.push(this._sketchPoints[0]);
- this._sketchPolygon = new Cesium.Entity({
- name: _self._sketchEntityName,
- polygon: {
- show: true,
- hierarchy: {
- positions: _self._sketchPoints
- },
- material: _self._polygonMaterial,
- classificationType: Cesium.ClassificationType.BOTH
- },
- polyline: {
- show: true,
- positions: _self._sketchPoints,
- material: _self._lineMaterial,
- width: _self._param.lineWidth,
- clampToGround: true
- }
- });
- this._entities.add(this._sketchPolygon);
- this._updateScene();
- }
- }
- _createPolygonBody(options2) {
- let _self = this;
- let appendHeight = parseFloat(100);
- if (options2 && options2.height && typeof options2.height === "number")
- appendHeight = parseFloat(options2.height);
- let wallColor = [255, 255, 0, 1];
- let polygonColor = [0, 0, 255, 0.65];
- if (options2 && options2.color && this._checkColorAndAlpha(options2.color))
- polygonColor = this._checkColorAndAlpha(options2.color);
- if (!Cesium.defined(this._sketchPolygon)) {
- let shaderSource = "czm_material czm_getMaterial(czm_materialInput materialInput){\n czm_material material = czm_getDefaultMaterial(materialInput);\n vec2 st = materialInput.st;\n vec3 str = materialInput.str;\n material.diffuse = color.rgb;\n material.alpha = color.a;\n return material;\n}";
- let wallMaterial = new Cesium.Material({
- fabric: {
- type: "wallMaterial",
- uniforms: {
- color: _self._toColorFromArray(wallColor),
- speed: 100
- },
- source: shaderSource
- }
- });
- new Cesium.MaterialAppearance({
- material: wallMaterial
- });
- let polygonAppearance = new Cesium.MaterialAppearance({
- material: new Cesium.Material({
- fabric: {
- type: "Color",
- uniforms: {
- color: _self._toColorFromArray(polygonColor)
- }
- }
- })
- });
- let wallMinimumHeights = [];
- let wallMaximumHeights = [];
- for (let i2 = 0; i2 < _self._sketchOutputPoints.length; i2++) {
- let height3 = parseFloat(_self._sketchOutputPoints[i2].height);
- wallMinimumHeights.push(height3);
- wallMaximumHeights.push(height3 + appendHeight);
- }
- let height2 = parseFloat(_self._sketchOutputPoints[0].height);
- wallMinimumHeights.push(height2);
- wallMaximumHeights.push(height2 + appendHeight);
- let tempPoints = [];
- for (let i2 = 0; i2 < _self._sketchPoints.length; i2++) {
- tempPoints.push(_self._sketchPoints[i2]);
- }
- tempPoints.push(_self._sketchPoints[0]);
- new Cesium.WallGeometry({
- positions: tempPoints,
- maximumHeights: wallMaximumHeights,
- minimumHeights: wallMinimumHeights
- });
- let polygonGeometry = new Cesium.PolygonGeometry({
- polygonHierarchy: new Cesium.PolygonHierarchy(tempPoints),
- perPositionHeight: true,
- extrudedHeight: Math.max.apply(null, wallMaximumHeights)
- });
- let polygonPrimitive = new Cesium.Primitive({
- geometryInstances: new Cesium.GeometryInstance({
- geometry: polygonGeometry
- }),
- appearance: polygonAppearance,
- releaseGeometryInstances: false
- });
- polygonPrimitive.setUseGeometry({
- cPoints: _self._sketchPoints,
- gPoints: _self._sketchOutputPoints,
- height: appendHeight,
- color: polygonColor
- });
- this._viewer.scene.primitives.add(polygonPrimitive);
- }
- }
- _callUpdaeEllipseCenterPosition() {
- let _self = this;
- return function() {
- let point1cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[0]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- _self._sketchEllipseCenterPosition = Cesium.Cartesian3.fromDegrees(Cesium.Math.toDegrees(point1cartographic.longitude), Cesium.Math.toDegrees(point1cartographic.latitude), point2cartographic.height);
- return _self._sketchEllipseCenterPosition;
- };
- }
- _callUpdateAltitudePolylinePositions() {
- let _self = this;
- return function() {
- _self._sketchAltitudePolylinePostions = [];
- _self._sketchAltitudePolylinePostions.push(_self._sketchTempPoints[0]);
- let point1cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[0]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- let point_temp = Cesium.Cartesian3.fromDegrees(
- Cesium.Math.toDegrees(
- point1cartographic.longitude
- ),
- Cesium.Math.toDegrees(point1cartographic.latitude),
- point2cartographic.height
- );
- _self._sketchAltitudePolylinePostions.push(point_temp);
- return _self._sketchAltitudePolylinePostions;
- };
- }
- _callUpdateEllipseMinorAxis() {
- let _self = this;
- return function() {
- let point1cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[0]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- let geodesic = new Cesium.EllipsoidGeodesic();
- geodesic.setEndPoints(point1cartographic, point2cartographic);
- _self._sketchEllipseRadius = geodesic.surfaceDistance;
- if (_self._sketchEllipseRadius <= 0)
- _self._sketchEllipseRadius = 1;
- return _self._sketchEllipseRadius;
- };
- }
- _callUpdateEllipseHeight() {
- let _self = this;
- return function() {
- let cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[0]);
- let cartographic1 = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- let height_temp = cartographic1.height - cartographic.height;
- _self._sketchEllipseHeight = height_temp + _self._sketchAltitudeInitHeight;
- return _self._sketchEllipseHeight;
- };
- }
- _createTempAltitudePolyline() {
- let _self = this;
- if (!Cesium.defined(this._sketchTempAltituePolyline)) {
- this._sketchTempAltituePolyline = new Cesium.Entity({
- name: _self._sketchEntityName,
- position: new Cesium.CallbackProperty(
- _self._callUpdaeEllipseCenterPosition(),
- false
- ),
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(
- _self._callUpdateAltitudePolylinePositions(),
- false
- ),
- material: _self._tempAlititudeLineMaterial,
- width: _self._param.moveAltitudeLineWidth,
- clampToGround: false
- },
- ellipse: {
- show: true,
- semiMinorAxis: new Cesium.CallbackProperty(_self._callUpdateEllipseMinorAxis(), false),
- semiMajorAxis: new Cesium.CallbackProperty(_self._callUpdateEllipseMinorAxis(), false),
- height: new Cesium.CallbackProperty(_self._callUpdateEllipseHeight(), false),
- material: _self._toColorFromArray(_self._param.moveEllipseColor),
- outline: _self._param.moveEllipseOutline,
- outlineWidth: _self._param.moveEllipseOutlineWidth,
- outlineColor: _self._toColorFromArray(_self._param.moveEllipseOutlineColor)
- }
- });
- _self._entities.add(_self._sketchTempAltituePolyline);
- }
- }
- _createAltitudePolyline() {
- let _self = this;
- if (!Cesium.defined(this._sketchAltitudePolyline)) {
- this._sketchAltitudePolyline = new Cesium.Entity({
- name: _self._sketchEntityName,
- position: _self._sketchEllipseCenterPosition,
- polyline: {
- show: true,
- positions: _self._sketchAltitudePolylinePostions,
- material: _self._altitudeLineMaterial,
- width: _self._param.altitudeLineWidth,
- clampToGround: false
- },
- ellipse: {
- show: true,
- semiMinorAxis: _self._sketchEllipseRadius,
- semiMajorAxis: _self._sketchEllipseRadius,
- height: _self._sketchEllipseHeight,
- material: _self._toColorFromArray(_self._param.ellipseColor),
- outline: _self._param.ellipseOutline,
- outlineWidth: _self._param.ellipseOutlineWidth,
- outlineColor: _self._toColorFromArray(_self._param.ellipseOutlineColor)
- }
- });
- _self._entities.add(_self._sketchAltitudePolyline);
- }
- }
- _callEllipseOutlineCoordinate() {
- let _self = this;
- return function() {
- let positionCenter = _self._sketchEllipseCenterPosition;
- let positionRotate = _self._sketchTempPoints[1];
- _self._ellipseOutlineCoordinates = [];
- for (let angle = 5; angle < 360; ) {
- let newPosition = _self._rotatedPointByAngle(positionRotate, positionCenter, angle);
- _self._ellipseOutlineCoordinates.push(newPosition);
- angle = angle + 5;
- }
- _self._ellipseOutlineCoordinates.push(_self._ellipseOutlineCoordinates[0]);
- return _self._ellipseOutlineCoordinates;
- };
- }
- _createTempCircle(centerPosition) {
- let _self = this;
- if (!Cesium.defined(this._sketchTempCircle)) {
- _self._sketchEllipseCenterPosition = centerPosition.clone();
- this._sketchTempCircle = new Cesium.Entity({
- name: _self._sketchEntityName,
- position: centerPosition,
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(_self._callEllipseOutlineCoordinate(), false),
- material: _self._tempLineMaterial,
- width: _self._param.moveLineWidth,
- clampToGround: true
- },
- ellipse: {
- show: true,
- semiMinorAxis: new Cesium.CallbackProperty(_self._callUpdateEllipseMinorAxis(), false),
- semiMajorAxis: new Cesium.CallbackProperty(_self._callUpdateEllipseMinorAxis(), false),
- material: _self._tempPolygonMaterial,
- classificationType: Cesium.ClassificationType.BOTH
- }
- });
- _self._entities.add(_self._sketchTempCircle);
- }
- }
- _rotatedPointByAngle(position_A, position_B, angle) {
- var localToWorld_Matrix = Cesium.Transforms.eastNorthUpToFixedFrame(position_B);
- var worldToLocal_Matrix = Cesium.Matrix4.inverse(localToWorld_Matrix, new Cesium.Matrix4());
- Cesium.Matrix4.multiplyByPoint(worldToLocal_Matrix, position_B, new Cesium.Cartesian3());
- var localPosition_A = Cesium.Matrix4.multiplyByPoint(worldToLocal_Matrix, position_A, new Cesium.Cartesian3());
- var new_x = localPosition_A.x * Math.cos(Cesium.Math.toRadians(angle)) + localPosition_A.y * Math.sin(Cesium.Math.toRadians(angle));
- var new_y = localPosition_A.y * Math.cos(Cesium.Math.toRadians(angle)) - localPosition_A.x * Math.sin(Cesium.Math.toRadians(angle));
- var new_z = localPosition_A.z;
- return Cesium.Matrix4.multiplyByPoint(
- localToWorld_Matrix,
- new Cesium.Cartesian3(new_x, new_y, new_z),
- new Cesium.Cartesian3()
- );
- }
- _createCircle() {
- let _self = this;
- if (!Cesium.defined(this._sketchCircle)) {
- this._sketchCircle = new Cesium.Entity({
- name: _self._sketchEntityName,
- position: _self._sketchEllipseCenterPosition,
- polyline: {
- show: true,
- positions: _self._ellipseOutlineCoordinates,
- material: _self._lineMaterial,
- width: _self._param.lineWidth,
- clampToGround: true
- },
- ellipse: {
- show: true,
- semiMinorAxis: _self._sketchEllipseRadius,
- semiMajorAxis: _self._sketchEllipseRadius,
- material: _self._polygonMaterial,
- classificationType: Cesium.ClassificationType.BOTH
- }
- });
- _self._entities.add(_self._sketchCircle);
- }
- }
- _callUpdateRectangleCoordinates() {
- let _self = this;
- return function() {
- let lng0 = parseFloat(_self._sketchTempPoints[0].lng);
- let lat0 = parseFloat(_self._sketchTempPoints[0].lat);
- let lng1 = parseFloat(_self._sketchTempPoints[1].lng);
- let lat1 = parseFloat(_self._sketchTempPoints[1].lat);
- _self._rectangleCoordinates = [0, 0, 1, 1];
- if (lng0 < lng1) {
- _self._rectangleCoordinates[0] = lng0;
- _self._rectangleCoordinates[2] = lng1;
- } else {
- _self._rectangleCoordinates[0] = lng1;
- _self._rectangleCoordinates[2] = lng0;
- }
- if (lat0 < lat1) {
- _self._rectangleCoordinates[1] = lat0;
- _self._rectangleCoordinates[3] = lat1;
- } else {
- _self._rectangleCoordinates[1] = lat1;
- _self._rectangleCoordinates[3] = lat0;
- }
- let rectangle = Cesium.Rectangle.fromDegrees(
- _self._rectangleCoordinates[0],
- _self._rectangleCoordinates[1],
- _self._rectangleCoordinates[2],
- _self._rectangleCoordinates[3]
- );
- let res = _self._calculateRectangleOutlineCoordinates(rectangle);
- _self._rectangleOutlineCoordinates = res.cPoints;
- _self._sketchOutputPoints = res.gPoints;
- return rectangle;
- };
- }
- _calculateRectangleOutlineCoordinates(rectangle) {
- let south_east = Cesium.Rectangle.southeast(rectangle);
- let se2 = Cesium.Cartographic.toCartesian(south_east);
- let south_west = Cesium.Rectangle.southwest(rectangle);
- let sw = Cesium.Cartographic.toCartesian(south_west);
- let north_east = Cesium.Rectangle.northeast(rectangle);
- let ne2 = Cesium.Cartographic.toCartesian(north_east);
- let north_west = Cesium.Rectangle.northwest(rectangle);
- let nw = Cesium.Cartographic.toCartesian(north_west);
- let gPoints = [];
- gPoints.push({
- lng: Cesium.Math.toDegrees(south_west.longitude),
- lat: Cesium.Math.toDegrees(south_west.latitude),
- height: south_west.height
- });
- gPoints.push({
- lng: Cesium.Math.toDegrees(south_east.longitude),
- lat: Cesium.Math.toDegrees(south_east.latitude),
- height: south_east.height
- });
- gPoints.push({
- lng: Cesium.Math.toDegrees(north_east.longitude),
- lat: Cesium.Math.toDegrees(north_east.latitude),
- height: north_east.height
- });
- gPoints.push({
- lng: Cesium.Math.toDegrees(north_west.longitude),
- lat: Cesium.Math.toDegrees(north_west.latitude),
- height: north_west.height
- });
- gPoints.push({
- lng: Cesium.Math.toDegrees(south_west.longitude),
- lat: Cesium.Math.toDegrees(south_west.latitude),
- height: south_west.height
- });
- return {
- cPoints: [sw, se2, ne2, nw, sw],
- gPoints
- };
- }
- _callUpdateRectangleOutlineCoordinates() {
- let _self = this;
- return function() {
- return _self._rectangleOutlineCoordinates;
- };
- }
- _createTempRectangle() {
- let _self = this;
- if (!Cesium.defined(this._sketchTempRectangle)) {
- this._sketchTempRectangle = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(_self._callUpdateRectangleOutlineCoordinates(), false),
- material: _self._tempLineMaterial,
- width: _self._param.moveLineWidth,
- clampToGround: true
- },
- rectangle: {
- show: true,
- coordinates: new Cesium.CallbackProperty(_self._callUpdateRectangleCoordinates(), false),
- material: _self._tempPolygonMaterial,
- classificationType: Cesium.ClassificationType.BOTH
- }
- });
- _self._entities.add(_self._sketchTempRectangle);
- }
- }
- _createRectangle() {
- let _self = this;
- if (!Cesium.defined(this._sketchRectangle)) {
- this._sketchRectangle = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: _self._rectangleOutlineCoordinates,
- material: _self._lineMaterial,
- width: _self._param.lineWidth,
- clampToGround: true
- },
- rectangle: {
- show: true,
- coordinates: Cesium.Rectangle.fromDegrees(_self._rectangleCoordinates[0], _self._rectangleCoordinates[1], _self._rectangleCoordinates[2], _self._rectangleCoordinates[3]),
- material: _self._polygonMaterial,
- classificationType: Cesium.ClassificationType.BOTH
- }
- });
- _self._entities.add(_self._sketchRectangle);
- }
- }
- _callUpdaeTriangleEllipseCenterPosition() {
- let _self = this;
- return function() {
- let point1cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[2]);
- _self._sketchEllipseCenterPosition = Cesium.Cartesian3.fromDegrees(Cesium.Math.toDegrees(point1cartographic.longitude), Cesium.Math.toDegrees(point1cartographic.latitude), point2cartographic.height);
- return _self._sketchEllipseCenterPosition;
- };
- }
- _callUpdateTriangleAltitudePolylinePositions() {
- let _self = this;
- return function() {
- _self._sketchAltitudePolylinePostions = [];
- _self._sketchAltitudePolylinePostions.push(_self._sketchTempPoints[1]);
- let point1cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[2]);
- let point_temp = Cesium.Cartesian3.fromDegrees(
- Cesium.Math.toDegrees(
- point1cartographic.longitude
- ),
- Cesium.Math.toDegrees(point1cartographic.latitude),
- point2cartographic.height
- );
- _self._sketchAltitudePolylinePostions.push(point_temp);
- return _self._sketchAltitudePolylinePostions;
- };
- }
- _callUpdateTriangleEllipseMinorAxis() {
- let _self = this;
- return function() {
- let point1cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[2]);
- let geodesic = new Cesium.EllipsoidGeodesic();
- geodesic.setEndPoints(point1cartographic, point2cartographic);
- _self._sketchEllipseRadius = geodesic.surfaceDistance;
- if (_self._sketchEllipseRadius <= 0)
- _self._sketchEllipseRadius = 1;
- return _self._sketchEllipseRadius;
- };
- }
- _callUpdateTriangleEllipseHeight() {
- let _self = this;
- return function() {
- let cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- let cartographic1 = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[2]);
- let height_temp = cartographic1.height - cartographic.height;
- _self._sketchEllipseHeight = height_temp + _self._sketchAltitudeInitHeight;
- return _self._sketchEllipseHeight;
- };
- }
- _callUpdateTriangleSpatialPolylinePositions() {
- let _self = this;
- return function() {
- _self._sketchTriangleSpatialPolylinePositions = [];
- _self._sketchTriangleSpatialPolylinePositions.push(_self._sketchTempPoints[0]);
- _self._sketchTriangleSpatialPolylinePositions.push(_self._sketchEllipseCenterPosition);
- return _self._sketchTriangleSpatialPolylinePositions;
- };
- }
- _createTriangleSpatialPolyline() {
- let _self = this;
- this._sketchSpatialPolyline = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: _self._sketchTriangleSpatialPolylinePositions,
- material: _self._spatialLineMaterial,
- width: _self._param.spatialLineWidth,
- clampToGround: false
- }
- });
- this._entities.add(this._sketchSpatialPolyline);
- }
- _createTempTriangleAltitudePolylineAndSpatialPolyline() {
- let _self = this;
- if (!Cesium.defined(this._sketchTempTriangleAltitudePolyline) && !Cesium.defined(this._sketchTempSpatialPolyline)) {
- this._sketchTempTriangleAltitudePolyline = new Cesium.Entity({
- name: _self._sketchEntityName,
- position: new Cesium.CallbackProperty(
- _self._callUpdaeTriangleEllipseCenterPosition(),
- false
- ),
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(
- _self._callUpdateTriangleAltitudePolylinePositions(),
- false
- ),
- material: _self._tempAlititudeLineMaterial,
- width: _self._param.moveAltitudeLineWidth,
- clampToGround: false
- },
- ellipse: {
- show: true,
- semiMinorAxis: new Cesium.CallbackProperty(_self._callUpdateTriangleEllipseMinorAxis(), false),
- semiMajorAxis: new Cesium.CallbackProperty(_self._callUpdateTriangleEllipseMinorAxis(), false),
- height: new Cesium.CallbackProperty(_self._callUpdateTriangleEllipseHeight(), false),
- material: _self._toColorFromArray(_self._param.moveEllipseColor),
- outline: _self._param.moveEllipseOutline,
- outlineWidth: _self._param.moveEllipseOutlineWidth,
- outlineColor: _self._toColorFromArray(_self._param.moveEllipseOutlineColor)
- }
- });
- _self._entities.add(_self._sketchTempTriangleAltitudePolyline);
- _self._sketchTempSpatialPolyline = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(_self._callUpdateTriangleSpatialPolylinePositions(), false),
- material: _self._tempLineMaterial,
- width: _self._param.moveLineWidth,
- clampToGround: false
- }
- });
- _self._entities.add(_self._sketchTempSpatialPolyline);
- }
- }
- _createTempSpatialTriangle() {
- let _self = this;
- if (!Cesium.defined(this._sketchTempSpatialTriangle)) {
- this._sketchTempSpatialTriangle = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(function() {
- _self._sketchSpatialTrianglePositions = [];
- _self._sketchSpatialTrianglePositions.push(_self._sketchTempPoints[0].clone());
- _self._sketchSpatialTrianglePositions.push(_self._sketchTempPoints[1].clone());
- let point1cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[0]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- let point_temp = Cesium.Cartesian3.fromDegrees(Cesium.Math.toDegrees(point1cartographic.longitude), Cesium.Math.toDegrees(point1cartographic.latitude), point2cartographic.height);
- _self._sketchSpatialTrianglePositions.push(point_temp);
- _self._sketchSpatialTrianglePositions.push(_self._sketchTempPoints[0].clone());
- return _self._sketchSpatialTrianglePositions;
- }, false),
- material: _self._tempLineMaterial,
- width: _self._param.moveLineWidth,
- clampToGround: false
- }
- });
- this._entities.add(this._sketchTempSpatialTriangle);
- this._updateScene();
- }
- }
- _createSpatialTriangle() {
- let _self = this;
- if (!Cesium.defined(this._sketchSpatialTriangle)) {
- this._sketchSpatialTriangle = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: _self._sketchSpatialTrianglePositions,
- material: _self._lineMaterial,
- width: _self._param.lineWidth,
- clampToGround: false
- }
- });
- this._entities.add(this._sketchSpatialTriangle);
- this._updateScene();
- }
- }
- _setMoveLineStyle(options2) {
- let _self = this;
- let color2 = [255, 255, 255, 1];
- let lineWidth = 3;
- let isOutline = false;
- let power = 0.2;
- let outlineColor = [255, 0, 0, 1];
- let outlineWidth = 1;
- if (options2 && options2.color && options2.color.length === 4)
- color2 = options2.color;
- if (options2 && options2.outline && typeof options2.outline === "boolean")
- isOutline = options2.outline;
- if (options2 && options2.outlineColor && options2.outlineColor.length === 4)
- outlineColor = options2.outlineColor;
- if (options2 && options2.outlineWidth && typeof options2.outlineWidth === "number")
- outlineWidth = options2.outlineWidth;
- if (options2 && options2.lineWidth && typeof options2.lineWidth === "number")
- lineWidth = options2.lineWidth;
- if (options2 && options2.power)
- power = options2.power;
- if (isOutline) {
- this._tempLineMaterial = new Cesium.PolylineOutlineMaterialProperty({
- color: _self._toColorFromArray(color2),
- outlineColor: _self._toColorFromArray(outlineColor),
- outlineWidth
- });
- } else {
- if (power === void 0) {
- this._tempLineMaterial = new Cesium.PolylineDashMaterialProperty({
- color: _self._toColorFromArray(color2)
- });
- } else {
- this._tempLineMaterial = new Cesium.PolylineGlowMaterialProperty({
- color: _self._toColorFromArray(color2),
- glowPower: power
- });
- }
- }
- this._param.moveLineWidth = lineWidth;
- }
- _setLineStyle(options2) {
- let _self = this;
- let color2 = [255, 255, 255, 1];
- let lineWidth = 2;
- let outlineColor = [0, 255, 0, 0.6];
- let outlineWidth = 1;
- if (options2 && options2.color && options2.color.length === 4)
- color2 = options2.color;
- if (options2 && options2.outlineColor && options2.outlineColor.length === 4)
- outlineColor = options2.outlineColor;
- if (options2 && options2.outlineWidth && typeof options2.outlineWidth === "number")
- outlineWidth = options2.outlineWidth;
- if (options2 && options2.lineWidth && typeof options2.lineWidth === "number")
- lineWidth = options2.lineWidth;
- this._lineMaterial = new Cesium.PolylineOutlineMaterialProperty({
- color: _self._toColorFromArray(color2),
- outlineColor: _self._toColorFromArray(outlineColor),
- outlineWidth
- });
- this._param.lineWidth = lineWidth;
- }
- _setSpatialLineStyle(options2) {
- let _self = this;
- let color2 = [255, 255, 0, 1];
- let lineWidth = 2;
- let outlineColor = [255, 255, 255, 1];
- let outlineWidth = 1;
- if (options2 && options2.color && options2.color.length === 4)
- color2 = options2.color;
- if (options2 && options2.outlineColor && options2.outlineColor.length === 4)
- outlineColor = options2.outlineColor;
- if (options2 && options2.outlineWidth && typeof options2.outlineWidth === "number")
- outlineWidth = options2.outlineWidth;
- if (options2 && options2.lineWidth && typeof options2.lineWidth === "number")
- lineWidth = options2.lineWidth;
- this._spatialLineMaterial = new Cesium.PolylineOutlineMaterialProperty({
- color: _self._toColorFromArray(color2),
- outlineColor: _self._toColorFromArray(outlineColor),
- outlineWidth
- });
- this._param.spatialLineWidth = lineWidth;
- }
- _setMovePolygonStyle(options2) {
- let polygonColor = [255, 0, 0, 0.3];
- if (options2 && options2.color && options2.color.length === 4)
- polygonColor = options2.color;
- this._tempPolygonMaterial = new Cesium.ColorMaterialProperty(this._toColorFromArray(polygonColor));
- }
- _setPolygonStyle(options2) {
- let polygonColor = [0, 0, 255, 0.3];
- if (options2 && options2.color && options2.color.length === 4)
- polygonColor = options2.color;
- this._polygonMaterial = new Cesium.ColorMaterialProperty(this._toColorFromArray(polygonColor));
- }
- _setMoveAltitudeLineStyle(options2) {
- let _self = this;
- let color2 = [255, 255, 255, 1];
- let lineWidth = 2;
- let isOutline = true;
- let outlineColor = [255, 255, 0, 1];
- let outlineWidth = 1;
- if (options2 && options2.color && options2.color.length === 4)
- color2 = options2.color;
- if (options2 && options2.outline && typeof options2.outline === "boolean")
- isOutline = options2.outline;
- if (options2 && options2.outlineColor && options2.outlineColor.length === 4)
- outlineColor = options2.outlineColor;
- if (options2 && options2.outlineWidth && typeof options2.outlineWidth === "number")
- outlineWidth = options2.outlineWidth;
- if (options2 && options2.lineWidth && typeof options2.lineWidth === "number")
- lineWidth = options2.lineWidth;
- if (isOutline) {
- this._tempAlititudeLineMaterial = new Cesium.PolylineOutlineMaterialProperty({
- color: _self._toColorFromArray(color2),
- outlineColor: _self._toColorFromArray(outlineColor),
- outlineWidth
- });
- } else {
- this._tempAlititudeLineMaterial = new Cesium.PolylineDashMaterialProperty({
- color: _self._toColorFromArray(color2)
- });
- }
- this._param.moveAltitudeLineWidth = lineWidth;
- }
- _setAltitudeLineStyle(options2) {
- let _self = this;
- let color2 = [255, 255, 255, 1];
- let lineWidth = 2;
- let outlineColor = [0, 0, 255, 1];
- let outlineWidth = 1;
- if (options2 && options2.color && options2.color.length === 4)
- color2 = options2.color;
- if (options2 && options2.outlineColor && options2.outlineColor.length === 4)
- outlineColor = options2.outlineColor;
- if (options2 && options2.outlineWidth && typeof options2.outlineWidth === "number")
- outlineWidth = options2.outlineWidth;
- if (options2 && options2.lineWidth && typeof options2.lineWidth === "number")
- lineWidth = options2.lineWidth;
- this._altitudeLineMaterial = new Cesium.PolylineOutlineMaterialProperty({
- color: _self._toColorFromArray(color2),
- outlineColor: _self._toColorFromArray(outlineColor),
- outlineWidth
- });
- this._param.altitudeLineWidth = lineWidth;
- }
- _setMoveEllipseStyle(options2) {
- if (options2 && options2.color && options2.color.length === 4)
- this._param.moveEllipseColor = options2.color;
- if (options2 && options2.outlineWidth && typeof options2.outlineWidth === "number")
- this._param.moveEllipseOutlineWidth = options2.outlineWidth;
- if (options2 && options2.outline && typeof options2.outline === "boolean")
- this._param.moveEllipseOutline = options2.outline;
- if (options2 && options2.outlineColor && options2.outlineColor.length === 4)
- this._param.moveEllipseOutlineColor = options2.outlineColor;
- }
- _setEllipseStyle(options2) {
- if (options2 && options2.color && options2.color.length === 4)
- this._param.ellipseColor = options2.color;
- if (options2 && options2.outlineWidth && typeof options2.outlineWidth === "number")
- this._param.ellipseOutlineWidth = options2.outlineWidth;
- if (options2 && options2.outline && typeof options2.outline === "boolean")
- this._param.ellipseOutline = options2.outline;
- if (options2 && options2.outlineColor && options2.outlineColor.length === 4)
- this._param.ellipseOutlineColor = options2.outlineColor;
- }
- _clear(isAll) {
- if (isAll != void 0 && isAll === true) {
- this._removeEntityByName(this._sketchEntityName);
- this._removePointEntitys();
- }
- this._sketchTempPoints = [];
- this._sketchPoints = [];
- this._sketchOutputPoints = [];
- this._sketchTempPolyline = void 0;
- this._sketchPolyline = void 0;
- this._sketchTempPolygon = void 0;
- this._sketchPolygon = void 0;
- this._sketchTempAltituePolyline = void 0;
- this._sketchAltitudePolyline = void 0;
- this._sketchTempSpatialPolyline = void 0;
- this._sketchSpatialPolyline = void 0;
- this._sketchTempCircle = void 0;
- this._sketchCircle = void 0;
- this._sketchTempRectangle = void 0;
- this._sketchRectangle = void 0;
- this._sketchTempTriangleAltitudePolyline = void 0;
- this._sketchTriangleAltituePolyline = void 0;
- this._sketchTempSpatialTriangle = void 0;
- this._sketchSpatialTriangle = void 0;
- }
- _checkAppOrWeb() {
- if (window.navigator.userAgent.match(
- /(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i
- )) {
- return SketchViewModel.RuntimeEnvironment.App;
- } else {
- return SketchViewModel.RuntimeEnvironment.Web;
- }
- }
- _isRuntimeApp() {
- if (this._checkAppOrWeb() === SketchViewModel.RuntimeEnvironment.App) {
- return true;
- }
- return false;
- }
- }
- Object.assign(SketchViewModel.prototype, {
- setMoveLineStyle: function(options2) {
- this._setMoveLineStyle(options2);
- },
- setLineStyle: function(options2) {
- this._setLineStyle(options2);
- },
- setSpatialLineStyle: function() {
- this._setSpatialLineStyle(options);
- },
- setMovePolygonStyle: function(options2) {
- this._setMovePolygonStyle(options2);
- },
- setPolygonStyle: function(options2) {
- this._setPolygonStyle(options2);
- },
- setMoveAltitudeLineStyle: function(options2) {
- this._setMoveAltitudeLineStyle(options2);
- },
- setAltitudeLineStyle: function(options2) {
- this._setAltitudeLineStyle(options2);
- },
- setMoveEllipseStyle: function(options2) {
- this._setMoveEllipseStyle(options2);
- },
- setEllipseStyle: function(options2) {
- this._setEllipseStyle(options2);
- },
- setLabel: function(options2) {
- if (!options2) {
- options2 = {
- lineLabel: void 0,
- polygonLabel: void 0
- };
- }
- if (options2.lineLabel)
- this._lineLabel = options2.lineLabel;
- if (options2.polygonLabel)
- this._lineLabel = options2.polygonLabel;
- }
- });
- Object.assign(SketchViewModel.prototype, {
- _registerLeftClickEvent: function(handler, callChange) {
- let _self = this;
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- _self._lock = true;
- if (_self._timer != null)
- clearTimeout(_self._timer);
- _self._timer = setTimeout(function() {
- if (callChange)
- callChange(event2);
- _self._lock = false;
- }, 200);
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- },
- _registerLeftDoubleClickEvent: function(handler, callChange) {
- let _self = this;
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (_self._timer != null)
- clearTimeout(_self._timer);
- _self._lock = false;
- if (callChange)
- callChange(event2);
- }, Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
- },
- _registerMouseMoveEvent: function(handler, callChange) {
- let _self = this;
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (_self._lock === void 0 || _self._lock === false) {
- if (callChange)
- callChange(event2);
- }
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- },
- _registerRightClickEvent: function(handler, callChange) {
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (callChange)
- callChange(event2);
- }, Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- },
- _clearEvent: function(handler) {
- if (!handler)
- return;
- handler.destroy();
- handler = null;
- }
- });
- Object.assign(SketchViewModel.prototype, {
- _sketchDrawPoint(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(loc2.sLocation, loc2.gLocation);
- });
- },
- _sketchDrawMultiplePoint(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- _self._sketchPoints.push(loc2.sLocation);
- _self._sketchOutputPoints.push(loc2.gLocation);
- if (options2.onAdded)
- options2.onAdded(loc2.sLocation, loc2.gLocation);
- });
- this._registerRightClickEvent(handler, function(event2) {
- if (_self._sketchPoints.length > 0) {
- _self._sketchPoints.pop();
- _self._sketchOutputPoints.pop();
- if (options2.onUndo)
- options2.onUndo();
- }
- });
- this._registerLeftDoubleClickEvent(handler, function(event2) {
- _self._clearEvent();
- if (options2.onComplete)
- options2.onComplete(_self._sketchPoints, _self._sketchOutputPoints);
- });
- },
- _sketchDrawPolyline(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- if (_self._sketchTempPoints.length === 0) {
- _self._createTempPolyline();
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- }
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation.clone());
- _self._sketchOutputPoints.push(loc2.gLocation);
- if (options2.onAdded)
- options2.onAdded(_self._sketchPoints, _self._sketchOutputPoints);
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (Cesium.defined(_self._sketchTempPolyline)) {
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- if (options2.onMoving)
- options2.onMoving(loc2.sLocation);
- }
- });
- this._registerRightClickEvent(handler, function(event2) {
- if (_self._sketchTempPoints.length > 2) {
- _self._sketchPoints.pop();
- _self._sketchTempPoints.splice(_self._sketchTempPoints.length - 2, 1);
- if (_self._isDrawPoint) {
- let lastPointEntity = _self._pointEntitys[_self._pointEntitys.length - 1];
- _self._entities.remove(lastPointEntity);
- _self._pointEntitys.pop();
- }
- if (options2.onUndo)
- options2.onUndo();
- }
- });
- this._registerLeftDoubleClickEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- if (_self._sketchPoints.length < 2) {
- if (options2.onError)
- options2.onError("\u70B9\u6570\u5C11\u4E8E\u4E24\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._removeEntityByObject(_self._sketchTempPolyline);
- _self._createPolyline();
- if (!_self._isRetainDrawPoint)
- _self._removePointEntitys();
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchPoints, _self._sketchOutputPoints);
- });
- },
- _sketchDrawSpatialPolyline(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- if (_self._sketchTempPoints.length === 0) {
- _self._createTempSpatialPolyline();
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- }
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation.clone());
- _self._sketchOutputPoints.push(loc2.gLocation);
- if (options2.onAdded)
- options2.onAdded(_self._sketchPoints, _self._sketchOutputPoints);
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (Cesium.defined(_self._sketchTempSpatialPolyline)) {
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- if (options2.onMoving)
- options2.onMoving(loc2.sLocation);
- }
- });
- this._registerLeftDoubleClickEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- if (_self._sketchPoints.length < 2) {
- if (options2.onError)
- options2.onError("\u7ED8\u5236\u70B9\u5C11\u4E8E2\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._removeEntityByObject(_self._sketchTempSpatialPolyline);
- _self._createSpatialPolyline();
- _self._removePointEntitys();
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchPoints, _self._sketchOutputPoints);
- });
- this._registerRightClickEvent(handler, function(event2) {
- if (_self._sketchTempPoints.length > 2) {
- _self._sketchPoints.pop();
- _self._sketchTempPoints.splice(_self._sketchTempPoints.length - 2, 1);
- if (options2.onUndo)
- options2.onUndo();
- }
- });
- },
- _sketchDrawPolygon(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- if (_self._sketchTempPoints.length === 0) {
- _self._createTempPolygon();
- _self._createTempPolyline();
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- }
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation.clone());
- _self._sketchOutputPoints.push(loc2.gLocation);
- if (options2.onAdded)
- options2.onAdded(_self._sketchPoints, _self._sketchOutputPoints);
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (Cesium.defined(_self._sketchTempPolygon)) {
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- if (options2.onMoving)
- options2.onMoving(loc2.sLocation);
- }
- });
- this._registerRightClickEvent(handler, function(event2) {
- if (_self._sketchTempPoints.length > 2) {
- _self._sketchPoints.pop();
- _self._sketchTempPoints.splice(_self._sketchTempPoints.length - 2, 1);
- if (_self._isDrawPoint) {
- let lastPointEntity = _self._pointEntitys[_self._pointEntitys.length - 1];
- _self._entities.remove(lastPointEntity);
- _self._pointEntitys.pop();
- }
- if (options2.onUndo)
- options2.onUndo();
- }
- });
- this._registerLeftDoubleClickEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- if (_self._sketchPoints.length < 3) {
- if (options2.onError)
- options2.onError("\u70B9\u6570\u5C11\u4E8E3\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._removeEntityByObject(_self._sketchTempPolygon);
- _self._removeEntityByObject(_self._sketchTempPolyline);
- _self._createPolygon();
- if (!_self._isRetainDrawPoint)
- _self._removePointEntitys();
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchPoints, _self._sketchOutputPoints);
- });
- },
- _sketchDrawCircle: function(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchTempPoints.length === 0) {
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, "\u8D77\u70B9");
- }
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation.clone());
- _self._sketchOutputPoints.push(loc2.gLocation);
- _self._createTempCircle(loc2.sLocation);
- if (options2.onAdded)
- options2.onAdded(loc2.sLocation);
- } else {
- if (_self._isRuntimeApp()) {
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- let positionCenter = _self._sketchEllipseCenterPosition;
- let positionRotate = _self._sketchTempPoints[1];
- _self._ellipseOutlineCoordinates = [];
- for (let angle = 5; angle < 360; ) {
- let newPosition = _self._rotatedPointByAngle(positionRotate, positionCenter, angle);
- _self._ellipseOutlineCoordinates.push(newPosition);
- angle = angle + 5;
- }
- _self._ellipseOutlineCoordinates.push(_self._ellipseOutlineCoordinates[0]);
- let point1cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[0]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- let geodesic = new Cesium.EllipsoidGeodesic();
- geodesic.setEndPoints(point1cartographic, point2cartographic);
- _self._sketchEllipseRadius = geodesic.surfaceDistance;
- if (_self._sketchEllipseRadius <= 0)
- _self._sketchEllipseRadius = 1;
- }
- _self._removePointEntitys();
- _self._removeEntityByObject(_self._sketchTempCircle);
- _self._createCircle();
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchOutputPoints[0], _self._sketchEllipseRadius);
- }
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- if (!Cesium.defined(_self._sketchTempCircle))
- return;
- var cartesian = _self._viewer.scene.pickPosition(event2.endPosition);
- if (cartesian == void 0)
- return;
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(cartesian);
- });
- },
- _sketchDrawHeightPolyline: function(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchTempPoints.length === 0) {
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, "\u8D77\u70B9");
- }
- _self._sketchAltitudeInitHeight = loc2.gLocation.height;
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation.clone());
- if (options2.onAdded)
- options2.onAdded(loc2.sLocation);
- } else {
- if (_self._isRuntimeApp()) {
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- let point1cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[0]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- _self._sketchEllipseCenterPosition = Cesium.Cartesian3.fromDegrees(Cesium.Math.toDegrees(point1cartographic.longitude), Cesium.Math.toDegrees(point1cartographic.latitude), point2cartographic.height);
- _self._sketchAltitudePolylinePostions = [];
- _self._sketchAltitudePolylinePostions.push(_self._sketchTempPoints[0]);
- let point_temp = Cesium.Cartesian3.fromDegrees(Cesium.Math.toDegrees(point1cartographic.longitude), Cesium.Math.toDegrees(point1cartographic.latitude), point2cartographic.height);
- _self._sketchAltitudePolylinePostions.push(point_temp);
- let geodesic = new Cesium.EllipsoidGeodesic();
- geodesic.setEndPoints(point1cartographic, point2cartographic);
- _self._sketchEllipseRadius = geodesic.surfaceDistance;
- if (_self._sketchEllipseRadius <= 0)
- _self._sketchEllipseRadius = 1;
- let height_temp = point2cartographic.height - point1cartographic.height;
- _self._sketchEllipseHeight = height_temp + _self._sketchAltitudeInitHeight;
- }
- _self._removePointEntitys();
- _self._removeEntityByObject(_self._sketchTempAltituePolyline);
- _self._createAltitudePolyline();
- _self._clearEvent(handler);
- if (options2.onComplete) {
- options2.onComplete(_self._sketchAltitudePolylinePostions, _self._sketchEllipseCenterPosition);
- }
- }
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- if (_self._sketchTempPoints == void 0 || _self._sketchTempPoints.length == 0)
- return;
- var cartesian = _self._viewer.scene.pickPosition(event2.endPosition);
- if (cartesian == void 0)
- return;
- if (_self._sketchTempPoints.length >= 2) {
- if (!Cesium.defined(_self._sketchTempAltituePolyline)) {
- _self._createTempAltitudePolyline();
- } else {
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(cartesian);
- }
- if (options2.onMoving) {
- options2.onMoving(_self._sketchAltitudePolylinePostions, _self._sketchEllipseCenterPosition);
- }
- }
- });
- },
- _sketchDrawRectangle: function(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchTempPoints.length === 0) {
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, "\u8D77\u70B9");
- }
- _self._sketchTempPoints.push(loc2.gLocation);
- _self._sketchTempPoints.push(loc2.gLocation);
- _self._sketchPoints.push(loc2.gLocation);
- _self._createTempRectangle();
- if (options2.onAdded)
- options2.onAdded(loc2.sLocation);
- } else {
- if (_self._isRuntimeApp()) {
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.gLocation);
- let lng0 = parseFloat(_self._sketchTempPoints[0].lng);
- let lat0 = parseFloat(_self._sketchTempPoints[0].lat);
- let lng1 = parseFloat(_self._sketchTempPoints[1].lng);
- let lat1 = parseFloat(_self._sketchTempPoints[1].lat);
- _self._rectangleCoordinates = [0, 0, 1, 1];
- if (lng0 < lng1) {
- _self._rectangleCoordinates[0] = lng0;
- _self._rectangleCoordinates[2] = lng1;
- } else {
- _self._rectangleCoordinates[0] = lng1;
- _self._rectangleCoordinates[2] = lng0;
- }
- if (lat0 < lat1) {
- _self._rectangleCoordinates[1] = lat0;
- _self._rectangleCoordinates[3] = lat1;
- } else {
- _self._rectangleCoordinates[1] = lat1;
- _self._rectangleCoordinates[3] = lat0;
- }
- let rectangle = Cesium.Rectangle.fromDegrees(_self._rectangleCoordinates[0], _self._rectangleCoordinates[1], _self._rectangleCoordinates[2], _self._rectangleCoordinates[3]);
- let res = _self._calculateRectangleOutlineCoordinates(rectangle);
- _self._rectangleOutlineCoordinates = res.cPoints;
- _self._sketchOutputPoints = res.gPoints;
- }
- _self._removePointEntitys();
- _self._removeEntityByObject(_self._sketchTempRectangle);
- _self._createRectangle();
- handler.destroy();
- handler = null;
- if (options2.onComplete)
- options2.onComplete(_self._sketchOutputPoints);
- }
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- if (!Cesium.defined(_self._sketchTempRectangle))
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.gLocation);
- });
- },
- _sketchDrawTriangle: function(handler, options2) {
- let _self = this;
- handler.setInputAction(function(event2) {
- if (Cesium.defined(_self._sketchTempAltituePolyline))
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchPoints.length == 0) {
- _self._createPoint(loc2.sLocation, "\u8D77\u70B9");
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation);
- _self._createTempPolyline();
- } else if (_self._sketchPoints.length === 1) {
- _self._createPoint(loc2.sLocation, "\u9AD8\u5EA6\u8D77\u70B9");
- _self._entities.remove(_self._sketchTempPolyline);
- _self._sketchPoints.push(loc2.sLocation);
- _self._createPolyline();
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- _self._sketchPoints.push(loc2.sLocation);
- _self._sketchAltitudeInitHeight = loc2.gLocation.height;
- _self._createTempTriangleAltitudePolylineAndSpatialPolyline();
- }
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- handler.setInputAction(function(event2) {
- if (_self._sketchPoints === void 0 || _self._sketchPoints.length === 0)
- return;
- var cartesian = _self._viewer.scene.pickPosition(event2.endPosition);
- if (cartesian == void 0)
- return;
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(cartesian);
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- handler.setInputAction(function(event2) {
- if (_self._sketchPoints.length < 2) {
- if (options2.onError)
- options2.onError("\u7ED8\u5236\u56FE\u5F62\u4E0D\u5B8C\u6574\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._removePointEntitys();
- _self._removeEntityByObject(_self._sketchTempTriangleAltitudePolyline);
- _self._removeEntityByObject(_self._sketchTempSpatialPolyline);
- _self._createAltitudePolyline();
- _self._createTriangleSpatialPolyline();
- handler.destroy();
- handler = null;
- options2.onComplete(
- _self._sketchPoints,
- _self._sketchTriangleSpatialPolylinePositions,
- _self._sketchAltitudePolylinePostions,
- _self._sketchEllipseCenterPosition
- );
- }, Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- },
- _sketchDrawPolygonBody(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- if (_self._sketchTempPoints.length === 0) {
- _self._createTempPolygon();
- _self._createTempPolyline();
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- }
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation.clone());
- _self._sketchOutputPoints.push(loc2.gLocation);
- if (options2.onAdded)
- options2.onAdded(_self._sketchPoints, _self._sketchOutputPoints);
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (Cesium.defined(_self._sketchTempPolygon)) {
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- if (options2.onMoving)
- options2.onMoving(loc2.sLocation);
- }
- });
- this._registerRightClickEvent(handler, function(event2) {
- if (_self._sketchTempPoints.length > 2) {
- _self._sketchPoints.pop();
- _self._sketchOutputPoints.pop();
- _self._sketchTempPoints.splice(_self._sketchTempPoints.length - 2, 1);
- if (options2.onUndo)
- options2.onUndo(_self._sketchPoints);
- }
- });
- this._registerLeftDoubleClickEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- if (_self._sketchPoints.length < 3) {
- if (options2.onError)
- options2.onError("\u70B9\u6570\u5C11\u4E8E3\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._removeEntityByObject(_self._sketchTempPolygon);
- _self._removeEntityByObject(_self._sketchTempPolyline);
- _self._createPolygonBody({
- height: 30,
- color: [255, 255, 0, 0.9]
- });
- _self._removePointEntitys();
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchPoints, _self._sketchOutputPoints);
- });
- },
- _sketchDrawTriangleA: function(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- if (Cesium.defined(_self._sketchTempAltituePolyline))
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchPoints.length == 0) {
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, "\u8D77\u70B9");
- }
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation);
- _self._createTempSpatialTriangle();
- if (options2.onAdded)
- options2.onAdded(loc2.sLocation);
- } else if (_self._sketchPoints.length > 0) {
- if (_self._isRuntimeApp()) {
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchSpatialTrianglePositions = [];
- _self._sketchSpatialTrianglePositions.push(_self._sketchTempPoints[0].clone());
- _self._sketchSpatialTrianglePositions.push(_self._sketchTempPoints[1].clone());
- let point1cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[0]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- let point_temp = Cesium.Cartesian3.fromDegrees(Cesium.Math.toDegrees(point1cartographic.longitude), Cesium.Math.toDegrees(point1cartographic.latitude), point2cartographic.height);
- _self._sketchSpatialTrianglePositions.push(point_temp);
- _self._sketchSpatialTrianglePositions.push(_self._sketchTempPoints[0].clone());
- }
- _self._removePointEntitys();
- _self._removeEntityByObject(_self._sketchTempSpatialTriangle);
- _self._createSpatialTriangle();
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchSpatialTrianglePositions);
- }
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- if (_self._sketchPoints === void 0 || _self._sketchPoints.length === 0)
- return;
- var cartesian = _self._viewer.scene.pickPosition(event2.endPosition);
- if (cartesian == void 0)
- return;
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(cartesian);
- if (options2.onMoving)
- options2.onMoving(cartesian);
- });
- },
- sketchTools: function(toolsType, options2) {
- let _self = this;
- this._clear();
- _self._sketchEventHandler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- switch (toolsType) {
- case SketchViewModel.SketchType.Point:
- _self._sketchDrawPoint(_self._sketchEventHandler, options2);
- break;
- case SketchViewModel.SketchType.Line:
- _self._sketchDrawPolyline(_self._sketchEventHandler, options2);
- break;
- case SketchViewModel.SketchType.Polygon:
- _self._sketchDrawPolygon(_self._sketchEventHandler, options2);
- break;
- case SketchViewModel.SketchType.Height:
- _self._sketchDrawHeightPolyline(_self._sketchEventHandler, options2);
- break;
- case SketchViewModel.SketchType.Spatial:
- _self._sketchDrawSpatialPolyline(_self._sketchEventHandler, options2);
- break;
- case SketchViewModel.SketchType.Circle:
- _self._sketchDrawCircle(_self._sketchEventHandler, options2);
- break;
- case SketchViewModel.SketchType.Rectangle:
- _self._sketchDrawRectangle(_self._sketchEventHandler, options2);
- break;
- case SketchViewModel.SketchType.Triangle:
- _self._sketchDrawTriangleA(_self._sketchEventHandler, options2);
- break;
- case SketchViewModel.SketchType.PolygonBody:
- _self._sketchDrawPolygonBody(_self._sketchEventHandler, options2);
- break;
- case SketchViewModel.SketchType.MultiplePoint:
- _self._sketchDrawMultiplePoint(_self._sketchEventHandler, options2);
- break;
- }
- },
- sketchDrawFeacture: function(points2, type2, options2) {
- let _self = this;
- if (points2 === void 0 || points2.length === void 0 || points2.length < 2) {
- if (options2 && options2.onError)
- options2.onError("\u8F93\u5165\u7684\u5750\u6807\u96C6\u5408\u5F02\u5E38\uFF01");
- return;
- }
- this._sketchPoints = [];
- for (let i2 = 0; i2 < points2.length; ) {
- this._sketchPoints.push(Cesium.Cartesian3.fromDegrees(points2[i2], points2[i2 + 1], points2[i2 + 2]));
- i2 = i2 + 3;
- }
- switch (type2) {
- case SketchViewModel.SketchType.DrawPoint:
- _self._createPoint(_self._sketchPoints[0], _self._lineLabel);
- if (options2 && options2.onComplete)
- options2.onComplete(_self._pointEntitys);
- break;
- case SketchViewModel.SketchType.DrawMultiplePoint:
- for (let i2 = 0; i2 < _self._sketchPoints.length; i2++) {
- _self._createPoint(_self._sketchPoints[i2], _self._lineLabel);
- }
- if (options2 && options2.onComplete)
- options2.onComplete(_self._pointEntitys);
- break;
- case SketchViewModel.SketchType.DrawPolyline:
- if (_self._sketchPoints.length < 2) {
- if (options2 && options2.onError)
- options2.onError("\u70B9\u6570\u5C11\u4E8E2\u4E2A\uFF0C\u65E0\u6CD5\u7ED8\u5236\uFF01");
- } else {
- _self._createPolyline();
- if (options2 && options2.onComplete)
- options2.onComplete(_self._sketchPolyline);
- }
- break;
- case SketchViewModel.SketchType.DrawPolygon:
- if (_self._sketchPoints.length < 3) {
- if (options2 && options2.onError)
- options2.onError("\u70B9\u6570\u5C11\u4E8E3\u4E2A\uFF0C\u65E0\u6CD5\u7ED8\u5236\uFF01");
- } else {
- _self._createPolygon();
- if (options2 && options2.onComplete)
- options2.onComplete(_self._sketchPolygon);
- }
- break;
- default:
- if (options2 && options2.onError)
- options2.onError("\u7ED8\u5236\u7C7B\u578B\u5F02\u5E38\uFF01");
- break;
- }
- },
- sketchClear: function() {
- this._clear(true);
- this._clearEvent(this._sketchEventHandler);
- },
- sketchInit: function() {
- this._clear(false);
- }
- });
- Object.assign(SketchViewModel.prototype, {
- _checkColor: function(color2) {
- if (color2 === void 0 || color2 === null)
- return false;
- if (typeof color2 != "number")
- return false;
- let intColor = parseInt(color2);
- if (intColor < 0 || intColor > 255)
- return false;
- return true;
- },
- _checkAlpha: function(alpha) {
- if (alpha === void 0 || alpha === null)
- return false;
- if (typeof alpha != "number")
- return false;
- let floatAlpha = parseFloat(alpha);
- if (floatAlpha < 0 || floatAlpha > 1)
- return false;
- return true;
- },
- _checkColorAndAlpha: function(colorAndAlpah) {
- let setColor = void 0;
- if (!colorAndAlpah || colorAndAlpah.length === void 0 || colorAndAlpah.length === 0)
- return void 0;
- if (colorAndAlpah.length === 1 && this._checkColor(colorAndAlpah[0])) {
- setColor = [colorAndAlpah[0], 0, 0, 1];
- } else if (colorAndAlpah.length === 2 && this._checkColor(colorAndAlpah[0]) && this._checkColor(
- colorAndAlpah[1]
- )) {
- setColor = [colorAndAlpah[0], colorAndAlpah[1], 0, 1];
- } else if (colorAndAlpah.length === 3 && this._checkColor(colorAndAlpah[0]) && this._checkColor(
- colorAndAlpah[1]
- ) && this._checkColor(colorAndAlpah[2])) {
- setColor = [colorAndAlpah[0], colorAndAlpah[1], colorAndAlpah[2], 1];
- } else if (colorAndAlpah.length === 4 && this._checkColor(colorAndAlpah[0]) && this._checkColor(
- colorAndAlpah[1]
- ) && this._checkColor(colorAndAlpah[2]) && this._checkAlpha(
- colorAndAlpah[3]
- )) {
- setColor = [colorAndAlpah[0], colorAndAlpah[1], colorAndAlpah[2], colorAndAlpah[3]];
- }
- return setColor;
- },
- sketchEditPickPolygonBody: function(options2) {
- let _self = this;
- let primitive = _self._sketchPickPolygonBody;
- if (primitive === void 0) {
- if (options2.onComplete)
- options2.onComplete("\u672A\u62FE\u53D6\u5BF9\u8C61\u6216\u62FE\u53D6\u7684\u5BF9\u8C61\u4E0D\u7B26\u5408\u8981\u6C42\uFF01");
- return;
- }
- let color2 = primitive._useGeometry.color;
- let height2 = primitive._useGeometry.height;
- this._sketchPoints = primitive._useGeometry.cPoints;
- this._sketchOutputPoints = primitive._useGeometry.gPoints;
- if (options2 && options2.height && typeof options2.height === "number")
- height2 = parseInt(options2.height);
- if (options2 && options2.color && this._checkColorAndAlpha(options2.color))
- color2 = this._checkColorAndAlpha(options2.color);
- this._viewer.scene.primitives.remove(primitive);
- this._createPolygonBody({
- color: color2,
- height: height2
- });
- if (options2.onComplete)
- options2.onComplete(void 0);
- },
- sketchRemovePickPolygonBody: function(onComplete) {
- let _self = this;
- let primitive = _self._sketchPickPolygonBody;
- if (primitive === void 0) {
- if (onComplete)
- onComplete("\u672A\u62FE\u53D6\u5BF9\u8C61\u6216\u62FE\u53D6\u7684\u5BF9\u8C61\u4E0D\u7B26\u5408\u8981\u6C42\uFF01");
- return;
- }
- this._viewer.scene.primitives.remove(primitive);
- if (onComplete)
- onComplete(void 0);
- },
- sketchPick: function(onComplete) {
- let _self = this;
- let handler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- handler.setInputAction(function(event2) {
- let pickObj = _self._viewer.scene.pick(event2.position);
- if (pickObj && pickObj.primitive && pickObj.primitive._useGeometry != void 0) {
- _self._sketchPickPolygonBody = pickObj.primitive;
- if (onComplete)
- onComplete({
- color: pickObj.primitive._useGeometry.color,
- height: pickObj.primitive._useGeometry.height
- });
- } else {
- _self._sketchPickPolygonBody = void 0;
- if (onComplete)
- onComplete(void 0);
- }
- handler.destroy();
- handler = null;
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- }
- });
- SketchViewModel.SketchType = Object.freeze({
- Point: "point",
- MultiplePoint: "multiplePoint",
- Line: "line",
- Polygon: "polygon",
- Height: "height",
- Spatial: "spatial",
- Circle: "circle",
- Rectangle: "rectangle",
- Triangle: "triangle",
- PolygonBody: "polygonBody",
- DrawPoint: "drawPoint",
- DrawMultiplePoint: "drawMultiplePoint",
- DrawPolyline: "drawPolyline",
- DrawPolygon: "drawPolygon"
- });
- SketchViewModel.SketchIconType = Object.freeze({
- Normal: "normal",
- Blue: "blue",
- Green: "green",
- Violet: "violter"
- });
- SketchViewModel.RuntimeEnvironment = Object.freeze({
- App: "app",
- Web: "web"
- });
- class CommonTools {
- constructor(viewer2, options2) {
- this._viewer = viewer2;
- options2 = options2 || {};
- if (options2.isDrawPoint) {
- this._isDrawPoint = options2.isDrawPoint;
- } else {
- this._isDrawPoint = false;
- }
- if (options2.isRetainDrawPoint) {
- this._isRetainDrawPoint = options2.isRetainDrawPoint;
- } else {
- this._isRetainDrawPoint = false;
- }
- if (options2.isClear) {
- this._isClear = options2.isClear;
- } else {
- this._isClear = false;
- }
- this._sketchViewModel = new SketchViewModel(viewer2, {
- iconType: SketchViewModel.SketchIconType.Blue,
- isDrawPoint: this._isDrawPoint,
- isRetainDrawPoint: this._isRetainDrawPoint
- });
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv) {
- document.body.removeChild(buttonDiv);
- }
- this._init();
- }
- _init() {
- this._measureEntityName = "MeasureEntity";
- this._entities = this._viewer.entities;
- this._measurePointImage = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABwAAAAcEAYAAAAinQPXAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAB2FJREFUWMO9mHtQlNcZxn/nW65GxHtEqTEajUxVoLYRSIyipHG4qG0lajtxVIRFubgqXuOI28ZE7FAvCLKLSNKxg/FSIzdvqNE62kaRitqpYMxovBGigo4I4n6nfwjsCrsLrtjnn53vnPe87/Oc9/2+854VdBhCd6ZP6dMHlAXO/lOngrzMLz/8EEQ0ASNGANNY2aOHxYIdfHr3LuBCwPnzQIKcf/AgiJ8pQV99BfmvR4+orHxZVsLxpZFT0qd07gyP7zqrej3IInF47lwQkTLV3d1xv3KXWPT4MYhLzMzIgHpn10+Sk+Gw74w+jx79HwSGnzUYhg4FED4FBcBq/jtokOOC2oSb0FZUgHpKVoeHQ9GtGM/y8lcgMLxf5juDBwNDlOWnTgGvUdWz5wsQ7c179fUWzz9y0tX1BdZPILeqCpTtil9QEOT9c876K1faWqS07XeMzJFuboCXkpaX1w5hqxl14QJIKYRWCzLV5OXtDQXbon3c3c2/TeMoYvncucAgPrl40Y7fA0zv1QtMydKwb58FL7toRwbDYo3/0utB3OD8qlX2hIkLqalwO0b9+fLlUHJOG9vQ0P4EjfyFIdPZGfqsURampIBIlxsWLLBtL/NltF4PhUIrVq92QGDIeEOmpye4pYju164Bq6n29LTiopy8tDTIL48pSExsDq/Oj9is/eAD4CRbli1DMEFUBAYCewnUaJD8jr2lpQjpJ7M2bBBi0+L47Tt2mP2G5xhNaWnAHrLj461tKF1rasA0rW5b//6w/0rigQcPWhrZKVFXP8TkybaFyb3kXbkCbiO6fpyU1Dwq58vNG3U6BJvEiYMHEcwQW8aNA3pT7O4OaPmTiwuCnlwcNQrEDRGYmytloilj5vr1Zv+mNXVhSUnmOFYEVnt6gtM9t+8mTbKlwo5AoWdySIjteWUcIwwG2LX7o6lPnkiZULTlj/7+wEThm5oKbCBeCOANUisqkNRxLCEBSSzrYmOB3jw6c8Yi3kL5K51OyvkZGXUTJz7LSH09CIPwMBpt85CHhMf48Q4IJFPofHzsbMAAJfjIEQtXC9TZWi0wkEuKAmjEyspKpNN2pyVBQULZaIjbvXmzUDb6xF0zGJCqv+no6NGAK5fLyiz8JssVcXEWgQLUsZZxWmGbrLTN057Agfh7eNiefhpRb7h922LgOzFp2DDzxnJXrsvLE0rqOW3sTz+12h4lLfRZhuQybuXmWmQkgPzhwy0o1jlV37ljh+e3/L1LF0cEXqX04UPb0075rlovLwtBHuqZ5845T5Z37UqbEAPkzOfsUvlHXZ35saFnQ4++fe04eIfftv64tEfgdvkXeweprFIvBQaaebJH+f3x4xbPvsRPnixlQlHGtDFjWq2Wuqj0yz4+QKk4FxNjMVXD2998Y0FRKEsCAuzwzBKv2eZpR6DspxQcPWpnvrNYoNNBZOTOnRoN0ilJMzYjA3ibsKoqoIxezs6gLJbpxcVSTbyePurwYSkT76VPKSgAWQslJcAmenTrBszgP7W1wBlRmZICY2SydHIC8ZCvdTo7Ak+ri44dcySDNDTs2mVufluhThoGD4bHp6or4uOb3zWJnoqwMGAVLnfuACHscHJCiFRmhISA0BMcFob52PDC/8EDkLfkR5GRQmycN8/t8mXw8O73WVwctnvdJ3SqrQXNSJeY3bttaWhHJxMxzDh97VqQAwheutR2IC6pm/z8oOBm7LcVFVJNKNo0oUsXhBKmGR0VBfI0vkFBINzExxoNEKP+ePYsktefFmVnC2Vjvm5SZSVEpGUNefNNUH8ti8rKQCziaOfOVuL2563PP4eCjJhxK1a8hMCJJ7NTPDxAXWIaefEi0J2r/ftbMfyryDhxAkZ2u1EaHAx6oReq2rb/JiTLZKkoUHLf2//YMWCGnPf++1YM7zHw+nVQ1mlKhg2DvPeiltr+GLaj2W524Kd6zZ4NhGOQ0ophI6GSkr4Gq61VGyjx7vdZQoIdYY1xVZ06RKttS1gTHLkPLjVmGo3AJZToaCsGjSWrPFBKfH3bvta0uyR3ySlGIxS4a7trte1l244MtoRpT93XSUk0l0oruFDbqROYUtQ9X3xhLr2WaBpX4+WnOTl2hHkw9eZN0Li5dLP6Dehogc1dexslK/7MynffhbNDvZXnWq9GNJWyiKC69TlphvobtWbOHNgnZonq6hdl+xL/yTQhbKUxeOtWEP9melSUFYMWJSv/IAtNprZLUu4Rf9u6FQpdo49bfRXaBQcy2BL1p+XURYtAZrLwhx+sGDSWrDpc3ZeVBbJMPt22zY6wRj/1oep08zXMUXRABpsQFmqcHhICYiLlhw4BBWiFA/5FOXmhoc8u0Pv3vyyrDshgEwqLYnKLi4FO5OfkvPh66UdudnZHCXsFAptQ96XMW7jQTsm2xAF23roFlD6NXLy4o9m8AoHFR7SxNTWgjGOsVovtxqBxXAzEbc4cKCycN+/+/Y7n88oRvjarcNYsCDtprP/+ewjvZ1xz9SpERBp3zpz5qqP/D5zQE33tptaiAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDIyLTA0LTA5VDE2OjQyOjI5KzA4OjAwjRBbGwAAACV0RVh0ZGF0ZTptb2RpZnkAMjAyMi0wNC0wOVQxNjo0MjoyOSswODowMPxN46cAAABKdEVYdHN2ZzpiYXNlLXVyaQBmaWxlOi8vL2hvbWUvYWRtaW4vaWNvbi1mb250L3RtcC9pY29uXzJhcHo1b3VpcnV4L2Rpbmd3ZWkuc3ZncY9vkgAAAABJRU5ErkJggg==";
- this._iconBlue = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDozNjZmZDYyMy02NmE4LWYzNDUtODc4MC00YmMwY2IzZWM4OTMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MkEyMUE1MDg3NTAyMTFFREI0RUY4MjBCRjRGRDc0QUIiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MkEyMUE1MDc3NTAyMTFFREI0RUY4MjBCRjRGRDc0QUIiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6OWFmM2ZiODktNzQ4OS1kMDRkLTkyNzUtZDM5MWNhYzYwMGE1IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjM2NmZkNjIzLTY2YTgtZjM0NS04NzgwLTRiYzBjYjNlYzg5MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pv/grmkAAAhxSURBVHjazFoLUFVFGN49597LBdFUEpEQI0IpyxIfqU1ZkY/pNZg1RZlWY2lW4yMncxq18oHZ0+lhOaWZUo0zPjIr8W1NiubI+AxBIkRQQsQE7us8tv3P7qGL7gXOPRdzZ3bmcnf3+7/v/Lv/+f/lYkIIMpur2yBktQVO5yM7LRybIvsOFKFGCeHyQz/dFO2Ousflcg6UJSlVlqVEjHEMjNMH5tE0vVLT9ZJAQNnn9fm3d+9z3xEYioR9bNcjW9Z8Gtv35l7PUAFjnU5HLytrFUU9TgV9XXD4+PJhoyfV2/GIFO4TGD8my1lVuGXSHYNuPdyhfbv5VkVAgzWwFjAACzAvp0fwoV++uz6lxzXLolzOW1AEmz+gHCwtq3i2z52Pn2jtlgvXI1LpgQ0jeqYm74y0CGiACdjUxkir3KxMlsoKNj6WmNAlV5Kk9qiNGmBTG6vAlhV+rd1aUuGeNSNSeiSuolGo2X1cdDogbThQ79h21CMfP6NKtR4dw/edYiTSK8GhZ/aO0R7KiFV7dnPpzeFQXkppWeWY9MGj8+ifektbqzVC8KbVH6UNHdJvOw2nHUIB7vrDI89df861p0SRsUSjuiSzB4qxyYzx0TVEdBUNTnVqs7I6B4beEKOFwqThuu7X/IJ7hj/yYlGoM9NqIakpSVH7t67c3C4muq8IyKcQ9EpuddSK3xqcSHJR7g7WsSkCm8+YiSEgRuU9gMbd3k5578kufrcTC8U0eLwF/e99anhJ6Sm/HSHSid/Xv5CclJAjAjlXr+GHP6x07z9JZCSDCBfzBJapBomJabJfdKqFCiGa4RkQgrQA6p+MtbVTEn2dY2XhUz956szM6wdkLRFtsVZFrReeeaRTQte46aIxT4DgrA9ABJKRw42QTLsjimqATgUZwpxNO/0OGz3KmMvWuBFgABZgimwBB+ASbtSSp0zIHutyOuNEg9NW/e06UE49YRBi5LFB2NxaMoQg5iGJfza+Y+MwlwlmogALMIXpD+UAXIBTOEKi4rt0zg51sFft8TjN7YQbnzrbVpeeD8Q+w3fYFCQba9ha5kHABGyRTcrlCeBkVQjO/Wxeb3rA00WDb62rcbHzAARML0hBAloK+lyQ4TEHx2B4BragUS69vl06/6aLnk6LQuQ+vdMyRQMHT/ql/D9VGfEQi00PGFDYwqsP8/AsMQyJbTvABhuiFb3TU+8Otb1CCXFd1SF2gGhg/f56Bw4+B9iCJ0J5Bv93fgAbbIimd7yq/UDgZklITLQ7RTSwp9grs7MgBYXYMEQ0OTtBWBR7d5FX+NQ5J0tCHG63K0GYglSpkrklGkXY1GGKMbdo8d+qkBfn5LB0RpwOeDlc2mo9NNYHbyOMIuCRptvNsCGqXxgnS2dEoslhxMrgSDXOSbL0HlFVzSv6vlMMJigorWGpnJ2ymzRdTrENGxY4NSeE+PwBYQ3ds6tDN1IewvvFRMLQwTBMPB2lxTuEaTvnRKwI0S/U1ZeLBganRWtGwteYAOoR8EgQFsUe3DNamNpzTroVIWp1TW2xaCCrf6xKzDScaP89SRKGGBLkCSMjVo1aZRS1IZrOOalWhCgHjxTvEw3ckhylD7rOobF6ghZJphhk1TO80DK8Yab1KgJssCHMKhgnxYqQQM7i5bv9AaVONDh7VFzAqCWMekLhRZIFzzQWWLzIMjAY3qwsii2+YakDTsDNkkdoRVZbXHLyN9EglKdjh8QoUBSBcaIDEYU91cbtRi7yUFCF2OgBha9lBRZg3nWjuPQFLsDJqkfAtfWfr1jzDSHiR/zuk/GBjO5YQyqtQDU/5WYKCjo/Oicd/JmPw1xYA2sBA7AAM8RFBAEuwMnqYTei3Q95vx47U1VzTJj3uDBZNzXRl9EdUTE+SshnECJcFPOWwraNxj0GYo3OyLM1PgQYgAWYIlvAAbgAp3AKK6XyTPXZ56bOm0f3p/BFFEdr7LwZSd5xQ9wKUukUo/u4h8SdecCHzPmwdtOMJF9ciHodbE+cvmA+cAm1rVoSAsD1m3fmH127cfvSUJOiXRh98nS8/8dpXb0DknWNKB5qzsOIKlwYdIULpWMwB+ZunNrVC2tDeQIa2P552+4jfFsROxd0sbRfm5/31dyMPumZLQWkwsqA9EOTCzqCzdTGvKB7MCNWTU9s/oIOWsHh41tvGz5uNv34Fxdi64IOvNaxQ/t2aXvzVixKTUnqezkSRBqhCm4bMW7GhboGuJw7H+qQW7nEBoALFPCvOx8cP+toYUl+W4v4o6h0L9iiNkvBdnNXplYvsSEtOFddc75owLCxc6jLd7aVCMDulzlmDtgCm6FSEju38RAxztJUumTkoy+9faqyqjDSIgDzgezJi6gN+P9Is1HKjpBGz9T+U1cy+ulXZ9XU/lMRKRGABZjUEyeseCJcIY1i6BY4NmHagjlen/+CXREUow6wADMcEeEKQTxxq96wadfvCz9cvpBuBSVcEbCWYuQAFmCGSgrbSojx0qW9KmfxV5u/zP1+MTEqI6vlCNFhLWAAFsdEl1sIvIAgdTn98muL1mzZtXe1VYCtv+xbDWsBg2OR/0OIKaaB9ooHsqcsoXt8h4Uwu+P+xyfD/zwqOIatHw7YFQJvVthSUICVDxs9Kae0rOJwS2vKyk8fgbmwhq/V7fKwLYSLgWLoPLz9s59//c3mwjKMPTZ+5hswl6ceWiQ4REQIF2OE5QOHCo9NfCVndoPHW3vxHPgOxmAOzOVr0BUlhIuB0Hn2+5937p/77hcLgsMyfF7wwbKFMAZz+Fx0RQoJDsvvL8ndYYZlM8y+8/HKbXbDbKgW8ftd+qQJLQcglFZCaE3qFn81wogEh1mYE/F74bb64RnFAm/DDwy6mPdrkJLzKGfLpsj+vwIMACSZzfDJFmOPAAAAAElFTkSuQmCC";
- this._iconGreen = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDozNjZmZDYyMy02NmE4LWYzNDUtODc4MC00YmMwY2IzZWM4OTMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MjI1NDIwOUU3NTAyMTFFRDk0MTJGQzhGMTFCQkREODIiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MjI1NDIwOUQ3NTAyMTFFRDk0MTJGQzhGMTFCQkREODIiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6OWFmM2ZiODktNzQ4OS1kMDRkLTkyNzUtZDM5MWNhYzYwMGE1IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjM2NmZkNjIzLTY2YTgtZjM0NS04NzgwLTRiYzBjYjNlYzg5MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PgEE4igAAAgKSURBVHjazFoJbFRVFP3L/OlMoQXKImAFm0JbFtFKShEQI6UsggmkGKghIKTIIgZUohIDKEuLaFTQiIKyKKghqSyyF0pZbcHQsJVpoRkKbYFAW+iU2f78/313+qY+hvc78+dPkZfcMJ377rn3/Pve/fe9gVUUhfENY5eBjNbhvlnI6Bmh+KT5NzBhGigg9sb5vX3NpohhRqMwgOe4eJ7nurIsGwl69MDskiRXS7Jc7naLpx1OV/4z/V67CKpw+Gf1ZiQv9/vWyc8lTkMEpgiCIVGLrSh6ShGhX4ovlG5Mz5jToCcjXKhPIGvyOOG2JW/OywNfuBAd1WqFVhIwwAZsAQOwAPNxZoQ9f+yPHnHdn94QYRSeZ8I4XG7xnLWianq/oZOuBrvkQs0IZz27a2RCfLeCcJOAAZiAjXyM0hqblslcRfHuiV07d9zKcVwU00IDsJGPLeBLS3zBLi3O8nfuyLjuXbegKtTsOrY4Ldz22u2GPFue4bL7MlfrqWXh+xhDjNLL2EtOj0r3jI8Z70kyJcnN4aC4RGtF9eSklzIOoD/lQEsrGCLs/m3f9nxlUP98VE6j1QDz6/P5xZWLI06KJ3lGwIWdB2tfZEgkJB4oVwwzWBgsLY1d6hoWPUxSw0Tl2na8sHjYiAnvlKntmaD3SHxcrDG1f9/1aiScspOZYZ1hGm4dHnmSRyRglk+i/ITQwVywAVvAoA3kMyolufc6iEHv0uKuntkxu1ts5xyacY2nhh1TNsZcpBTxjBl2K4AQ2eD8MiITWXFDmULiYJhUNlXak7DH0d7QnvrUr1feWtgjZdxa2hILKiOzp01o1/mp9gtoOrtsZ0eXjjYXMYhEa/RFKyxmLCaCmBF/NhF633xkCxiABZg0XxADxBJq1eLnz8ycYhSE9jTl3Iq5EWeYM/wjwUPQvj1CEwHP8SMFWIBJbX9QDBALzrNmIhGdOsZkqm3sTfWbhKbgTcSSMhBLiiYcMc9I2CMswARsmk8Uy5s4r5qIsFt/WN6nVaQ5iaZcVLkoQjEpjbD++4IM+hFUQniCDMYBTMCm+USxJP6+bkVfFWRVIny/Pj3TaIpiezF3SjzFN619AaNwRLABSwzhnSOWGxLABh80sz5J8a+qLS81IsY20a1TaIrc2lzhoX3A+2Ui6FcxkRn+4f3j9UEZbdtEDcCUgycSaTbF0RQnGk7wTY79S2xIbSvGIDCPNxynPnUckyYiBpPJ2JmmKBVLuSYCXIA9EWxWWAIPYZeJZdS4cEwGTXtEMBhMNEWthHonVieB5gix2Aft/NIYk6Y9wqHmMGzH4HANHBOn6T3i8UgO2vcxfIzibTdI0Tv88Lw+NMTUHBHF6XJTz9CJQqLs7ZdkLHoIkbbyf71YgpBAbdtxTIoWInK9reEGTTGk9RCpqfGTCDJ6skE2kxL2QRk4JlkLEc+dmrorNEVGTIbo7VxFgowUQlYU4oxCnFMAe0LMBJFmgmPyaCEinrt45TRNkRyZLA8SBkleMj5CMvGclCBJMIQdJgAC2OCDZoZjErUQcees3njK5RZtNOWy2GUu1sk2nidcOAiPX2aUAHvC/1yCBDDh1Khyw2KDmLBF8Bkpt1bWXSm/fpKmhOPp9OjpIhyKGCcWHxkPpQj4b2oPQcJnj7AAMy06jbo/IBaISWtGwF3Dj5tzf1PIIyQx1nRf40phUiTmQWMQTaTI/ePx2wPEPvAF7xWEAViAqXIRoUAsEJPWze6tdn8dOF5y63ZNCbXv4SKVvYl7HSkKItPQGMwjpFx+4he8V5AtYAAWYNJ8QQwQC0bQfLASq2/duTvjveXL0fqkvog6GDooR3sdtWdFZomsjW18Xj5SdhXBwYOADdgW9CpwAJbK3nDMWpC9AmJRW1aBiABww8GCwkt/7s5fpzbJzJmZ9XHrnYfiDtkHSgMlph59CSXC9y8phA7m5sXl2cFWLRMwwPe+w6cuYvqKngs6uFp4tvDApmUv9ktKC1RZSxwl3I66HYaD9QcNFtHC+RpAaDuShCR5RPQIz7h24zy9zb3lQFjFF0oPpY6Yuhh9vIaJ6Lqgg6y1jY5q1bPowOZV8XGxyY+jQUQVqjh15NSP6m0P4HLuntom13KJDQD1CPDa0NezFl2ylBe2NInLZdYi8IV8WvGCDJi9YC+JoXDW3qm5V5aSPmUJSnlBS5EA7P5pk5eAL/Cp1pLouY2HinEXtdLlo96Y+3ll9W1LuEkA5tjMeauQD/h9pNkqpYdIU2bq7tvKM976cFFN3f2qcJEALMBEmbiqJROhEmkig5ZAycz3s5c4nK56vSQQhg2wADMUEqESYXCTcWfX/qNnVn6zcSVaCmKoJMAWYeQAFmCqNYUtRYTBTcftnNWbDv68dedqVMZlrQBgA7aAAVgYk3ncRBTcNd189+NVuXlHi7ZpBTh07PQ2sAUMjKX8H0R8ZKB7qhqbOX8tWuNHNJTZI2MmzYPfPKowhq5rDL1E4M0q4w7qRnrGnBxrRdWFQDYVN25ehLlgg21lvXHoJoLJwInjHrz9M9/+5LPmyjLoJmYt/BTm4tZDCkcMYSGCyXjL8tnzlpJZH+QsfmB31PnPge9AB3NgLrZhnigimAyUzrs79xX8s+zLn7LJsgyfs7/esBJ0MAfPZZ5IImRZ/mrt1iO+suwrs1989+thvWVWbYT9fhc9aQUdB6CUVkNpje3SqQPDMgpZZmFO2O+FW+o/niEsyDb8qt7Rd78GLTmucrp80vz/K8AAYAEv1AHM/GwAAAAASUVORK5CYII=";
- this._iconViolet = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDozNjZmZDYyMy02NmE4LWYzNDUtODc4MC00YmMwY2IzZWM4OTMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MzFDREU3Mjk3NTAyMTFFREE4MThDODBGNzMxNDBCQzEiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MzFDREU3Mjg3NTAyMTFFREE4MThDODBGNzMxNDBCQzEiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6OWFmM2ZiODktNzQ4OS1kMDRkLTkyNzUtZDM5MWNhYzYwMGE1IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjM2NmZkNjIzLTY2YTgtZjM0NS04NzgwLTRiYzBjYjNlYzg5MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Ppb+WxIAAAhcSURBVHjazFoLcFTVGb6vvdnNY0lEEJOIxhCSKTEFKSC1osIgjqIyA62mZfAxWJU+tC3TVh2lHSGhtNOKOqK0ii+0QwcfFB+IAsKIITpJhUBDHhMiSSBCTMgm2d377PnungubnXOT3L0b6rlzmM2e83/n+87/n/+ecxbeNE3OLvLFV3Fui3KiivNSkhmTNb7EpagQQvzxg++VBvxpc2XZN1MUhEJRFHJ5nk9HO5mwAV03OnTDaFYUtTocie66pOymOjSlYnzeq0d2bn02c9oVxXcTAct8PqnYja2qakeJoFdqDx3dNH/xij4vHhGSnYHlSxf5Out3rrjmqqmHglkZa9yKQIENbIEBLGCeT4/wB/f+c1LBpXkvpsm+73IpLFFF/bKltf2esjl3NI005JL1iNBSs23B5MKJe1ItAgWYwCZj3OiWm5vOQmvt9ttzJ4zbLAhCFjdKBdhkjNcwlht+Iw0tof6zrQsKLs19jWShIeM40hASure3S727O0WloV/QehTeSo/ZsilPzjCC11+k5yzM0/yTs4yhcAgvtaW1Y2nJ7MU7yJ/GcKE1EiH8B1ueLrr2+9N3kXQadAIM7f1abK84LEcOnBFFXuREMpk8TyrHx4jhMQ1OJ5x0U+f8s8boeY9MUbLmjNedMEm6Du2rqp17w5KfNTitmRGvkcKCfHnW9NK/O4kwIjp37JdfpDUv+jSgVw+IASHAofpRef/gSttQ0Rc2sAUGq5Axs2ZM+85GcPAaWkLT528/MDF/QiXLWPtG4Rt/tM+v1vSLMi9zPl4iniCVeASeEPjB82QQj8Az8IjOaZxqapxiKpzvygy9aMs1EekCmTnrX7WdfHjSjEUbWCE2Io88cPeSnAkXjV3J9ERY5xuX7PNrNQOin0/j0kiVUQUI8llVSnjs79FHpjawBQawgMkaCxzAJdmsJT50X/ky2ecby5yllTWy+p9+MY2PkYonb60RUuER1udBoixBMgcsYDK3P4QDuIBTMkLSxo+7oNxpYfe80eaLhZPMSSSkUAU8vPWvFVr2QrdimD7xfWw7nzUZMgdMYLPGJFx+DE5uhfCbn1s9JSM9UMJqbF9TJ5O5tNZEooh48o4Lk66fwWJIJZjAZtkQLsVvbFxTapm7ECKWTSmax2oYONgjRKp7RSluYbsRwRITS9cxQcDGGCybKSWF1zuFl5MQeUwwcwaroXtbmyTRWLdFkJekKxGDwo3nz4nB+iEVY7D6Z4/JmgluroSkB/wFrIa+z7rE2DyeWwfJiEhcO2fXD3n69p9mzjrl5EqI5PfLE5hv0qZ+gach4TacRhJmwFaaB5i8KCfJ1RrxSZKfuW3oUflE8l49kvg3xmCeX2KcXK0RMut8yo7BqSqUk+DqPaJpepjpqmyfaSbs30wPx24WFsZww2koIWYkqjDP0PKkDAO7WOuheyevBRgGxQS2XJjO3LZTTqYbIUZvqO84qyFz9lidyohtzenjRYT92LiZsy9kbocpJ8ONEO1UV3cjqyHn1nxNw+6V1tgsJicmdkaJCbDxgJ1zW77G6k85aW6EqF/WNVYzc3lZtuGfGdQ1sgXHVtwW4zbM4sPJ3tYDE9gYg2VDOaluhCiV6zftjypqiNWY92iponKKdZ7QaHUjJl6EbQ8sYOY+Uqo43LCEwAncXHmkuaWtu7H5q09ZjTieZv/kEhWHIpXURDHx6ydxLcT3OSdCsQ5YwAxeyz76ggs4ufUIXNv3/MtbXzfjj5BxZeK6aYpvaoYetUhECRnVqhoNNyvkTIP5WbNOh7H+sAUGsIDpcBFhggs4uV3sVrb79459R052dh1hGgZEs+hfP4hIU9P1iEUmapFSDGWQqPjnLHlDoQKiHGyBASxgssYCB3ABp2QOVmrHyVOn7/3V6tUkPpkvImlsmln83nXh4NJcNWKGuYgRIxcTpcQIx1fynd2OvrCBbfG710WA5bA2wvevrFgDLk5hNZwQAPd9uKfq8Jvbd210BPCL3GVPfS9a+PbVYWF6QA8bEBSrYYgzI1a1Ptvfk4q+l791dRi2Tp5Awdjvf7y/joaV6eWCLpPUy6p2vPTElWUl84bLSOH6XqHn3Xapd9fXotLUJ+jdmrUBFHMkU56UaQTnkkRxc54WKAkaw2HVHjr60awb7nycfDxGhXi6oIPXsoNZGUUHdry8rrAgf9r52CCSDFU7a8Gdv+sN9eNyrsdpkbu5xAZALwE8NueW5Y8drm+uGm0R/21oOYCxyJgtGHuoK1O3l9jYFnxzqqunYcb8ZauIy/eMlghgT5+3dBXGwphOWxIvt/HIGKfJVrr5xh/+/E9tHZ31qRYBzIXlD64jY+D3kSGzlBchZz3TfSbUvPiu3z7W1X2mPVUigAVM4okmN55IVshZMSQEjtz364pV4Ui016sIghECFjCTEZGsEI5u3E5t++CTz9c+uWktCQU1WRGwJRiVwAKm06ZwtIRYL11SOyvXv/ThC5vfWW/iaOf2PEJsYAsMYFFM7nwLwQsIW5cTv/j9uq07PzmwxS3AR3urt8AWGBTL/H8IscX04zp4YflDG0iM73aRZnfffMeD+M2jnWJ4Ovx7FYI3K0IKB7Dj8xevqGxpbT80nE3r8RN16Asbamt45eFZCBWDw1AP3v7lP330j0OlZbTdvvzhP6Av3XroqeCQEiFUjJWWaw7WH7n/N5WP9w+EuxP74Du0oQ/6UhvuWyWEikHqPP3O+3u+eOIv/6iIT8v4XPG3F9eiDX1oX+5bKSQ+Lf91w+bddlq20+yfn3n1Y69p1qmk/H6XzLRJjgNIpR1IrfkXj7+Q4zkzPs2iT8rvhUfrP54RLHgbv82Ps+/XsCWnWc7TmKzx/yfAAHo1CtU9myPWAAAAAElFTkSuQmCC";
- this._measureTempPoints = [];
- }
- _updateScene() {
- this._viewer.scene.requestRender();
- }
- _removeEntityByName(entityName) {
- let entities2 = this._entities;
- if (!entities2 || !entities2.values)
- return;
- let delEntitys = [];
- for (let i2 = 0; i2 < entities2.values.length; i2++) {
- if (entities2.values[i2].name == entityName) {
- delEntitys.push(entities2.values[i2]);
- }
- }
- for (let i2 = 0; i2 < delEntitys.length; i2++) {
- entities2.remove(delEntitys[i2]);
- }
- this._updateScene();
- }
- _clear(isAll) {
- if (isAll != void 0 && isAll === true) {
- this._removeEntityByName(this._measureEntityName);
- if (this._sketchViewModel != void 0) {
- this._sketchViewModel.sketchClear();
- }
- }
- this._measureTempPoints = [];
- this._altitudeDynamicLabel = void 0;
- this._tooltipRemove();
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv) {
- document.body.removeChild(buttonDiv);
- }
- }
- _toColor(red, green, blue, alpha) {
- return new Cesium.Color(red / 255, green / 255, blue / 255, alpha);
- }
- _cartesianToGeography(cartesian) {
- let ellipsoid = Cesium.Ellipsoid.WGS84;
- let cartographic = ellipsoid.cartesianToCartographic(cartesian);
- let latitude = Cesium.Math.toDegrees(cartographic.latitude);
- let longitude = Cesium.Math.toDegrees(cartographic.longitude);
- let altitude = cartographic.height;
- return {
- lon: longitude,
- lat: latitude,
- hei: altitude
- };
- }
- _createPoint(coord, label2) {
- let _self = this;
- let entity = new Cesium.Entity({
- name: _self._measureEntityName,
- position: coord,
- billboard: {
- image: _self._iconBlue,
- horizontalOrigin: Cesium.HorizontalOrigin.center,
- verticalOrigin: Cesium.VerticalOrigin.bottom,
- scale: 0.5,
- pixelOffset: new Cesium.Cartesian2(0, -11),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- }
- });
- if (label2) {
- entity.label = {
- text: label2,
- font: "30px SimHei",
- scale: 0.5,
- fillColor: this._toColor(255, 255, 255, 1),
- outlineColor: this._toColor(14, 30, 79, 1),
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- outlineWidth: 2,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- showBackground: true,
- backgroundColor: _self._toColor(0, 0, 0, 0.6),
- disableDepthTestDistance: Number.POSITIVE_INFINITY,
- pixelOffset: new Cesium.Cartesian2(0, -28)
- };
- }
- this._entities.add(entity);
- this._updateScene();
- return entity;
- }
- _createLabel(coord, label2) {
- let _self = this;
- let entity = new Cesium.Entity({
- name: _self._measureEntityName,
- position: coord,
- label: {
- text: label2,
- font: "30px SimHei",
- scale: 0.5,
- fillColor: this._toColor(255, 255, 255, 1),
- outlineColor: this._toColor(14, 30, 79, 1),
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- outlineWidth: 2,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- showBackground: true,
- backgroundColor: _self._toColor(0, 0, 0, 0.6),
- disableDepthTestDistance: Number.POSITIVE_INFINITY,
- pixelOffset: new Cesium.Cartesian2(0, -14)
- }
- });
- this._entities.add(entity);
- this._updateScene();
- }
- _createAltitudeDynamicLabel() {
- let _self = this;
- this._altitudeDynamicLabel = new Cesium.Entity({
- name: _self._measureEntityName,
- position: new Cesium.CallbackProperty(function() {
- return _self._altitudeLabelPosition;
- }, false),
- label: {
- text: new Cesium.CallbackProperty(function() {
- return _self._altitudeLabelText;
- }, false),
- font: "12px sans-serif",
- fillColor: this._toColor(255, 255, 255, 1),
- outlineColor: this._toColor(0, 154, 94, 1),
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- outlineWidth: 1,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- pixelOffset: new Cesium.Cartesian2(0, -28),
- showBackground: true,
- backgroundColor: this._toColor(0, 0, 0, 0.6),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- }
- });
- this._entities.add(this._altitudeDynamicLabel);
- this._updateScene();
- }
- _measureDistance(positions) {
- let distance2 = 0;
- for (let i2 = 0; i2 < positions.length - 1; i2++) {
- let point1cartographic = Cesium.Cartographic.fromCartesian(positions[i2]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(positions[i2 + 1]);
- let geodesic = new Cesium.EllipsoidGeodesic();
- geodesic.setEndPoints(point1cartographic, point2cartographic);
- let s = geodesic.surfaceDistance;
- s = Math.sqrt(Math.pow(s, 2) + Math.pow(
- point2cartographic.height - point1cartographic.height,
- 2
- ));
- distance2 = distance2 + s;
- }
- if (distance2 < 1e3)
- return distance2.toFixed(2) + "\u7C73";
- else
- return (distance2 / 1e3).toFixed(2) + "\u516C\u91CC";
- }
- _measureSpaceDistance(positions) {
- let distance2 = 0;
- for (let i2 = 0; i2 < positions.length - 1; i2++) {
- let point1 = positions[i2];
- let point2 = positions[i2 + 1];
- let sx = Math.abs(point1.x - point2.x);
- let sy = Math.abs(point1.y - point2.y);
- let sz = Math.abs(point1.z - point2.z);
- let s = Math.sqrt(Math.pow(sx, 2) + Math.pow(sy, 2) + Math.pow(sz, 2));
- distance2 = distance2 + s;
- }
- if (distance2 < 1e3)
- return distance2.toFixed(2) + "\u7C73";
- else
- return (distance2 / 1e3).toFixed(2) + "\u516C\u91CC";
- }
- _measureAreaBearing(from3, to) {
- let radiansPerDegree = Math.PI / 180;
- let degreesPerRadian = 180 / Math.PI;
- let lat1 = from3.lat * radiansPerDegree;
- let lon1 = from3.lon * radiansPerDegree;
- let lat2 = to.lat * radiansPerDegree;
- let lon2 = to.lon * radiansPerDegree;
- let angle = -Math.atan2(Math.sin(lon1 - lon2) * Math.cos(lat2), Math.cos(lat1) * Math.sin(
- lat2
- ) - Math.sin(lat1) * Math.cos(lat2) * Math.cos(lon1 - lon2));
- if (angle < 0) {
- angle += Math.PI * 2;
- }
- angle = angle * degreesPerRadian;
- return angle;
- }
- _calculateAreaAngle(p1, p2, p3) {
- let bearing21 = this._measureAreaBearing(p2, p1);
- let bearing23 = this._measureAreaBearing(p2, p3);
- let angle = bearing21 - bearing23;
- if (angle < 0) {
- angle += 360;
- }
- return angle;
- }
- _calculateDistance(point1, point2) {
- let point1cartographic = Cesium.Cartographic.fromCartesian(point1);
- let point2cartographic = Cesium.Cartographic.fromCartesian(point2);
- let geodesic = new Cesium.EllipsoidGeodesic();
- geodesic.setEndPoints(point1cartographic, point2cartographic);
- let s = geodesic.surfaceDistance;
- s = Math.sqrt(Math.pow(s, 2) + Math.pow(point2cartographic.height - point1cartographic.height, 2));
- return s;
- }
- _measureArea(points2, cartesianPoints) {
- let self2 = this;
- let res = 0;
- for (let i2 = 0; i2 < points2.length - 2; i2++) {
- let j = (i2 + 1) % points2.length;
- let k = (i2 + 2) % points2.length;
- let totalAngle = self2._calculateAreaAngle(points2[i2], points2[j], points2[k]);
- let dis_temp1 = self2._calculateDistance(cartesianPoints[i2], cartesianPoints[j]);
- let dis_temp2 = self2._calculateDistance(cartesianPoints[j], cartesianPoints[k]);
- res += dis_temp1 * dis_temp2 * Math.abs(Math.sin(totalAngle));
- }
- return res;
- }
- _calculatePolylineAltitudeHeight(points2) {
- if (points2 === void 0 || points2.length < 2)
- return -1;
- let cartographic = Cesium.Cartographic.fromCartesian(points2[0]);
- let cartographic1 = Cesium.Cartographic.fromCartesian(points2[1]);
- let height_temp = cartographic1.height - cartographic.height;
- return Math.abs(height_temp).toFixed(2) + "\u7C73";
- }
- _setMousePointerStyle() {
- document.querySelector("body").style.cursor = "crosshair";
- }
- _initMousePointerStyle() {
- document.querySelector("body").style.cursor = "default";
- }
- _checkAppOrWeb() {
- if (window.navigator.userAgent.match(
- /(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i
- )) {
- return CommonTools.RuntimeEnvironment.App;
- } else {
- return CommonTools.RuntimeEnvironment.Web;
- }
- }
- _isRuntimeApp() {
- if (this._checkAppOrWeb() === CommonTools.RuntimeEnvironment.App) {
- return true;
- }
- return false;
- }
- _isRuntimeWeb() {
- if (this._checkAppOrWeb() === CommonTools.RuntimeEnvironment.Web) {
- return true;
- }
- return false;
- }
- _createOperationMainDom() {
- let buttonDiv = document.createElement("div");
- buttonDiv.id = "drawButtonDiv";
- buttonDiv.style.width = "80px";
- buttonDiv.style.backgroundColor = "rgba(5, 45, 155, 0.7)";
- buttonDiv.style.borderRadius = "5px";
- buttonDiv.style.display = "flex";
- buttonDiv.style.flexDirection = "column";
- buttonDiv.style.padding = "8px";
- buttonDiv.style.justifyContent = "center";
- buttonDiv.style.position = "absolute";
- buttonDiv.style.bottom = "150px";
- buttonDiv.style.right = "10px";
- let btnUndo = document.createElement("button");
- btnUndo.id = "btnDrawBackout";
- btnUndo.style.height = "30px";
- btnUndo.style.marginBottom = "8px";
- btnUndo.style.backgroundColor = "rgba(52, 137, 255, 1.0)";
- btnUndo.style.color = "rgb(255, 255, 255)";
- btnUndo.style.border = "0px solid red";
- btnUndo.style.borderRadius = "5px";
- btnUndo.innerHTML = "\u56DE\u9000";
- btnUndo.style.fontSize = "13px";
- btnUndo.style.cursor = "pointer";
- buttonDiv.appendChild(btnUndo);
- let btnCompletion = document.createElement("button");
- btnCompletion.id = "btnDrawComplete";
- btnCompletion.style.height = "30px";
- btnCompletion.style.backgroundColor = "rgba(88, 185, 45, 1.0)";
- btnCompletion.style.color = "rgb(255, 255, 255)";
- btnCompletion.style.border = "0px solid red";
- btnCompletion.style.borderRadius = "5px";
- btnCompletion.innerHTML = "\u5B8C\u6210";
- btnCompletion.style.fontSize = "13px";
- btnCompletion.style.cursor = "pointer";
- buttonDiv.appendChild(btnCompletion);
- document.body.appendChild(buttonDiv);
- }
- _showTooltipMessage(message) {
- let msgMainDom = document.getElementById("messageMainDom");
- if (msgMainDom !== null && msgMainDom !== void 0) {
- document.body.removeChild(msgMainDom);
- }
- msgMainDom = document.createElement("div");
- msgMainDom.style.width = "30%";
- msgMainDom.style.backgroundColor = "rgba(237, 248, 230, 1.0)";
- msgMainDom.style.height = "45px";
- msgMainDom.style.border = "solid 2px rgb(219, 241, 208)";
- msgMainDom.style.borderRadius = "8px";
- msgMainDom.style.display = "flex";
- msgMainDom.style.alignItems = "center";
- msgMainDom.style.paddingLeft = "10px";
- msgMainDom.style.color = "rgb(91, 188, 48)";
- msgMainDom.style.fontSize = "14px";
- msgMainDom.style.fontWeight = "600";
- msgMainDom.style.position = "absolute";
- msgMainDom.style.left = "35%";
- msgMainDom.style.transition = "transform 1s";
- msgMainDom.style.transform = "translateY(-90px)";
- msgMainDom.style.top = "0px";
- msgMainDom.style.zIndex = 1e3;
- document.body.appendChild(msgMainDom);
- let strHtml = "";
- strHtml += "<div style='";
- strHtml += "background-color: rgb(88, 185, 45);";
- strHtml += "color: rgb(255, 255, 255);";
- strHtml += "height: 24px;";
- strHtml += "width: 24px;";
- strHtml += "border-radius: 20px;";
- strHtml += "display: flex;";
- strHtml += "justify-content: center;";
- strHtml += "align-items: center;";
- strHtml += "font-size: 14px;";
- strHtml += "margin-right: 18px;";
- strHtml += "'>✓</div>";
- strHtml += "<div>" + message + "</div>";
- msgMainDom.innerHTML = strHtml;
- msgMainDom.addEventListener("transitionend", function() {
- setTimeout(function() {
- document.body.removeChild(msgMainDom);
- }, 1e3);
- }, false);
- setTimeout(function() {
- msgMainDom.style.transform = "translateY(50px)";
- }, 100);
- }
- }
- Object.assign(CommonTools.prototype, {
- _tooltipInit: function(text) {
- this._tooltipId = "tooltipJt";
- let tooltipObj = document.getElementById(this._tooltipId);
- if (tooltipObj === null) {
- tooltipObj = document.createElement("div");
- tooltipObj.id = this._tooltipId;
- document.body.appendChild(tooltipObj);
- let divStyle = "";
- divStyle += "top: 30px;";
- divStyle += "left: 30px;";
- divStyle += "position: absolute;";
- divStyle += "display: flex;";
- divStyle += "align-items: center;";
- divStyle += "width: 12x0px;";
- divStyle += "height: auto;";
- divStyle += "background-color: rgba(0, 0, 0, 0.65);";
- divStyle += "border-radius: 5px;";
- divStyle += "color: rgb(255, 255, 255);";
- divStyle += "font-size: 12px;";
- divStyle += "font-family: 'Alimama_ShuHeiTi_Bold';";
- divStyle += "padding: 8px;";
- divStyle += "border:solid 1px rgb(255,0,0);";
- tooltipObj.setAttribute("style", divStyle);
- }
- if (text != void 0)
- tooltipObj.innerHTML = text;
- document.onmousemove = function(event2) {
- tooltipObj.style.left = event2.clientX + 10 + "px";
- tooltipObj.style.top = event2.clientY - tooltipObj.offsetHeight / 2 + "px";
- };
- },
- _tooltipRemove: function() {
- let tooltipObj = document.getElementById(this._tooltipId);
- if (tooltipObj != null) {
- document.body.removeChild(tooltipObj);
- }
- },
- _tooltipSetText: function(text) {
- let tooltipObj = document.getElementById(this._tooltipId);
- if (tooltipObj != null) {
- tooltipObj.innerHTML = text;
- }
- }
- });
- Object.assign(CommonTools.prototype, {
- clear: function() {
- this._clear(true);
- this._initMousePointerStyle();
- }
- });
- Object.assign(CommonTools.prototype, {
- measureLength: function(callError) {
- let _self = this;
- this._tempEntitys = [];
- this._clear(this._isClear);
- this._setMousePointerStyle();
- if (this._isRuntimeApp()) {
- this._showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u6D4B\u91CF");
- } else {
- this._tooltipInit("\u70B9\u51FB\u5F00\u59CB\u6D4B\u91CF");
- }
- if (this._isRuntimeWeb()) {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Line, {
- onAdded: function(cPoints, gPoints) {
- if (cPoints.length === 1) {
- _self._createPoint(cPoints[0], "\u8D77\u70B9");
- } else {
- let distince = _self._measureDistance(cPoints);
- let tempPoints = [cPoints[cPoints.length - 2], cPoints[cPoints.length - 1]];
- distince += " +" + _self._measureDistance(tempPoints);
- _self._tempEntitys.push(_self._createPoint(
- cPoints[cPoints.length - 1],
- distince
- ));
- }
- },
- onUndo: function() {
- _self._viewer.entities.remove(_self._tempEntitys[_self._tempEntitys.length - 1]);
- _self._tempEntitys.pop();
- },
- onMoving: function(cPoint, scPoint) {
- _self._tooltipSetText("\u53F3\u952E\u5355\u51FB\u56DE\u9000<br>\u5DE6\u952E\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236");
- },
- onError: function(error) {
- if (callError)
- callError(error);
- },
- onComplete: function(cPoints, gPoints) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- }
- });
- } else {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Line, {
- onAdded: function(cPoints, gPoints) {
- if (cPoints.length === 1) {
- _self._tooltipRemove();
- _self._createPoint(cPoints[0], "\u8D77\u70B9");
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv == null) {
- _self._createOperationMainDom();
- document.getElementById("btnDrawBackout").onclick = () => {
- if (_self._sketchViewModel._sketchTempPoints.length > 2) {
- _self._sketchViewModel._sketchPoints.pop();
- _self._sketchViewModel._sketchTempPoints.splice(_self._sketchViewModel._sketchTempPoints.length - 1, 1);
- if (_self._sketchViewModel._isDrawPoint) {
- let lastPointEntity = _self._sketchViewModel._pointEntitys[_self._sketchViewModel._pointEntitys.length - 1];
- _self._sketchViewModel._entities.remove(lastPointEntity);
- _self._sketchViewModel._pointEntitys.pop();
- }
- _self._viewer.entities.remove(_self._tempEntitys[_self._tempEntitys.length - 1]);
- _self._tempEntitys.pop();
- }
- };
- document.getElementById("btnDrawComplete").onclick = () => {
- if (_self._sketchViewModel._sketchPoints.length < 2) {
- if (callError)
- callError("\u70B9\u6570\u5C11\u4E8E\u4E24\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolyline);
- _self._sketchViewModel._createPolyline();
- if (!_self._sketchViewModel._isRetainDrawPoint)
- _self._sketchViewModel._removePointEntitys();
- _self._sketchViewModel._clearEvent(_self._sketchViewModel._sketchEventHandler);
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- let buttonDiv2 = document.getElementById("drawButtonDiv");
- if (buttonDiv2) {
- document.body.removeChild(buttonDiv2);
- }
- };
- }
- } else {
- let distince = _self._measureDistance(cPoints);
- let tempPoints = [cPoints[cPoints.length - 2], cPoints[cPoints.length - 1]];
- distince += " +" + _self._measureDistance(tempPoints);
- _self._tempEntitys.push(_self._createPoint(cPoints[cPoints.length - 1], distince));
- }
- }
- });
- }
- },
- measureSpatialLength: function(callError) {
- let _self = this;
- this._clear(this._isClear);
- this._setMousePointerStyle();
- if (this._isRuntimeApp()) {
- this._showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u6D4B\u91CF");
- } else {
- this._tooltipInit("\u70B9\u51FB\u5F00\u59CB\u6D4B\u91CF");
- }
- this._tempEntitys = [];
- if (this._isRuntimeWeb()) {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Spatial, {
- onAdded: function(cPoints, gPoints) {
- if (cPoints.length === 1) {
- _self._createPoint(cPoints[0], "\u8D77\u70B9");
- } else {
- let distince = _self._measureSpaceDistance(cPoints);
- _self._tempEntitys.push(_self._createPoint(
- cPoints[cPoints.length - 1],
- distince
- ));
- }
- },
- onUndo: function() {
- _self._viewer.entities.remove(_self._tempEntitys[_self._tempEntitys.length - 1]);
- _self._tempEntitys.pop();
- },
- onMoving: function(cPoint, scPoint) {
- _self._tooltipSetText("\u53F3\u952E\u5355\u51FB\u56DE\u9000<br>\u5DE6\u952E\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236");
- },
- onError: function(error) {
- if (callError)
- callError(error);
- },
- onComplete: function(cPoints, gPoints) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- }
- });
- } else {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Spatial, {
- onAdded: function(cPoints, gPoints) {
- if (cPoints.length === 1) {
- _self._tooltipRemove();
- _self._createPoint(cPoints[0], "\u8D77\u70B9");
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv == null) {
- _self._createOperationMainDom();
- document.getElementById("btnDrawBackout").onclick = () => {
- if (_self._sketchViewModel._sketchTempPoints.length > 2) {
- _self._sketchViewModel._sketchPoints.pop();
- _self._sketchViewModel._sketchTempPoints.splice(_self._sketchViewModel._sketchTempPoints.length - 1, 1);
- _self._viewer.entities.remove(_self._tempEntitys[_self._tempEntitys.length - 1]);
- _self._tempEntitys.pop();
- }
- };
- document.getElementById("btnDrawComplete").onclick = () => {
- if (_self._sketchViewModel._sketchPoints.length < 2) {
- if (callError)
- callError("\u70B9\u6570\u5C11\u4E8E\u4E24\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempSpatialPolyline);
- _self._sketchViewModel._createSpatialPolyline();
- _self._sketchViewModel._removePointEntitys();
- _self._sketchViewModel._clearEvent(_self._sketchViewModel._sketchEventHandler);
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- let buttonDiv2 = document.getElementById("drawButtonDiv");
- if (buttonDiv2) {
- document.body.removeChild(buttonDiv2);
- }
- };
- }
- } else {
- let distince = _self._measureSpaceDistance(cPoints);
- _self._tempEntitys.push(_self._createPoint(cPoints[cPoints.length - 1], distince));
- }
- }
- });
- }
- },
- measureArea: function(callError) {
- let _self = this;
- this._clear(this._isClear);
- this._setMousePointerStyle();
- if (this._isRuntimeApp()) {
- this._showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u6D4B\u91CF");
- } else {
- this._tooltipInit("\u70B9\u51FB\u5F00\u59CB\u6D4B\u91CF");
- }
- var _areaLabel = "";
- if (this._isRuntimeWeb()) {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Polygon, {
- onAdded: function(cPoints, gPoints) {
- _self._measureTempPoints.push(_self._cartesianToGeography(cPoints[cPoints.length - 1]));
- if (cPoints.length === 1) {
- _areaLabel = "\u8D77\u70B9";
- _self._createPoint(cPoints[0], new Cesium.CallbackProperty(function() {
- var lable = _areaLabel;
- return lable;
- }, false));
- } else if (cPoints.length >= 3) {
- let area = _self._measureArea(_self._measureTempPoints, cPoints);
- if (area > 1e5) {
- _areaLabel = (area / 1e5).toFixed(2) + "km\xB2";
- } else {
- _areaLabel = area.toFixed(2) + "m\xB2";
- }
- }
- },
- onUndo: function() {
- _self._measureTempPoints.pop();
- if (_self._measureTempPoints.length === 1)
- _self._areaLabel = "\u8D77\u70B9";
- },
- onMoving: function(cPoint, scPoint) {
- _self._tooltipSetText("\u53F3\u952E\u5355\u51FB\u56DE\u9000<br>\u5DE6\u952E\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236");
- },
- onError: function(error) {
- if (callError)
- callError(error);
- },
- onComplete: function(cPoints, gPoints) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- }
- });
- } else {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Polygon, {
- onAdded: function(cPoints, gPoints) {
- _self._measureTempPoints.push(_self._cartesianToGeography(cPoints[cPoints.length - 1]));
- if (cPoints.length === 1) {
- _self._tooltipRemove();
- _areaLabel = "\u8D77\u70B9";
- _self._createPoint(cPoints[0], new Cesium.CallbackProperty(function() {
- var lable = _areaLabel;
- return lable;
- }, false));
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv == null) {
- _self._createOperationMainDom();
- document.getElementById("btnDrawBackout").onclick = () => {
- if (_self._sketchViewModel._sketchTempPoints.length > 2) {
- _self._sketchViewModel._sketchPoints.pop();
- _self._sketchViewModel._sketchTempPoints.splice(_self._sketchViewModel._sketchTempPoints.length - 1, 1);
- if (_self._sketchViewModel._isDrawPoint) {
- let lastPointEntity = _self._sketchViewModel._pointEntitys[_self._sketchViewModel._pointEntitys.length - 1];
- _self._entities.remove(lastPointEntity);
- _self._sketchViewModel._pointEntitys.pop();
- }
- _self._measureTempPoints.pop();
- if (_self._measureTempPoints.length === 1)
- _self._areaLabel = "\u8D77\u70B9";
- }
- };
- document.getElementById("btnDrawComplete").onclick = () => {
- if (_self._sketchViewModel._sketchPoints.length < 3) {
- if (callError)
- callError("\u70B9\u6570\u5C11\u4E8E3\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolygon);
- _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolyline);
- _self._sketchViewModel._createPolygon();
- if (!_self._sketchViewModel._isRetainDrawPoint)
- _self._sketchViewModel._removePointEntitys();
- _self._sketchViewModel._clearEvent(_self._sketchViewModel._sketchEventHandler);
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- let buttonDiv2 = document.getElementById("drawButtonDiv");
- if (buttonDiv2) {
- document.body.removeChild(buttonDiv2);
- }
- };
- }
- } else if (cPoints.length >= 3) {
- let area = _self._measureArea(_self._measureTempPoints, cPoints);
- if (area > 1e5) {
- _areaLabel = (area / 1e5).toFixed(2) + "km\xB2";
- } else {
- _areaLabel = area.toFixed(2) + "m\xB2";
- }
- }
- }
- });
- }
- },
- measureHeight: function(callError) {
- let _self = this;
- this._clear(this._isClear);
- this._setMousePointerStyle();
- if (this._isRuntimeApp()) {
- this._showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236\u7EBF");
- } else {
- this._tooltipInit("\u5355\u51FB\u5F00\u59CB\u7ED8\u5236\u7EBF");
- }
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Height, {
- onAdded: function(cPoint) {
- if (_self._isRuntimeApp()) {
- _self._showTooltipMessage("\u518D\u6B21\u70B9\u51FB\u7ED3\u675F\u6D4B\u91CF");
- } else {
- _self._tooltipSetText("\u518D\u6B21\u5355\u51FB\u7ED3\u675F\u6D4B\u91CF");
- }
- },
- onMoving: function(cPoints, centerPoint) {
- let height2 = _self._calculatePolylineAltitudeHeight(cPoints);
- _self._altitudeLabelPosition = centerPoint;
- _self._altitudeLabelText = height2;
- if (_self._altitudeDynamicLabel === void 0) {
- _self._createAltitudeDynamicLabel();
- }
- },
- onError: function(error) {
- if (callError)
- callError(error);
- },
- onComplete: function(cPoints, centerPoint) {
- let height2 = _self._calculatePolylineAltitudeHeight(cPoints);
- _self._entities.remove(_self._altitudeDynamicLabel);
- _self._createLabel(centerPoint, height2);
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- }
- });
- },
- measureTriangle: function(callError) {
- let _self = this;
- this._clear(this._isClear);
- this._setMousePointerStyle();
- if (this._isRuntimeApp()) {
- this._showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236\u7EBF");
- } else {
- this._tooltipInit("\u5355\u51FB\u5F00\u59CB\u7ED8\u5236\u7EBF");
- }
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Triangle, {
- onAdded: function(cPoint) {
- if (_self._isRuntimeApp()) {
- _self._showTooltipMessage("\u518D\u6B21\u70B9\u51FB\u7ED3\u675F\u6D4B\u91CF");
- } else {
- _self._tooltipSetText("\u518D\u6B21\u5355\u51FB\u7ED3\u675F\u6D4B\u91CF");
- }
- },
- onMoving: function(cPoint) {
- _self._tooltipSetText("\u518D\u6B21\u5355\u51FB\u7ED3\u675F\u6D4B\u91CF");
- },
- onError: function(error) {
- if (callError)
- callError(error);
- },
- onComplete: function(positions) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- let sPoints = [positions[0], positions[1]];
- let sDistince = _self._measureSpaceDistance(sPoints);
- let hPoints = [positions[1], positions[2]];
- let hDistince = _self._measureSpaceDistance(hPoints);
- let hePoints = [positions[2], positions[0]];
- let height2 = _self._calculatePolylineAltitudeHeight(hePoints);
- _self._createLabel(positions[0], "\u659C\u8DDD:" + sDistince);
- _self._createLabel(positions[1], "\u5E73\u8DDD:" + hDistince);
- _self._createLabel(positions[2], "\u9AD8\u5EA6:" + height2);
- }
- });
- }
- });
- Object.assign(CommonTools.prototype, {
- queryByPoint: function(callComplete) {
- let _self = this;
- this._setMousePointerStyle();
- this._clear(this._isClear);
- if (this._isRuntimeApp()) {
- this._showTooltipMessage("\u70B9\u51FB\u4F4D\u7F6E\u8FDB\u884C\u67E5\u8BE2");
- } else {
- this._tooltipInit("\u5355\u51FB\u4F4D\u7F6E\u8FDB\u884C\u67E5\u8BE2");
- }
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Point, {
- onComplete: function(cPoint, gPoint) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- _self._createPoint(cPoint);
- let coordinates = gPoint.lng + "," + gPoint.lat;
- if (callComplete)
- callComplete(coordinates);
- }
- });
- },
- queryByMultiplePoint: function(callComplete) {
- let _self = this;
- this._setMousePointerStyle();
- this._clear(this._isClear);
- this._tooltipInit("\u70B9\u51FB\u4F4D\u7F6E\u7ED8\u5236<br>\u5DE6\u952E\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236");
- this._tempEntitys = [];
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.MultiplePoint, {
- onAdded: function(cPoint, gPoint) {
- let res = gPoint.lng.toFixed(6) + "," + gPoint.lat.toFixed(6);
- _self._tempEntitys.push(_self._createPoint(cPoint, res));
- },
- onUndo: function() {
- _self._viewer.entities.remove(_self._tempEntitys[_self._tempEntitys.length - 1]);
- _self._tempEntitys.pop();
- },
- onComplete: function(cPoints, gPoints) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- let res = [];
- for (let i2 = 0; i2 < gPoints.length; i2++) {
- res.push(gPoints[i2].lng);
- res.push(gPoints[i2].lat);
- }
- if (callComplete)
- callComplete(res);
- }
- });
- },
- queryByLine: function(callComplete, callError) {
- let _self = this;
- this._clear(this._isClear);
- this._setMousePointerStyle();
- if (this._isRuntimeApp()) {
- this._showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236\u7EBF");
- } else {
- this._tooltipInit("\u5355\u51FB\u5F00\u59CB\u7ED8\u5236\u7EBF");
- }
- if (this._isRuntimeWeb()) {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Line, {
- onAdded: function(cPoints, gPoints) {
- },
- onMoving: function(cPoint, scPoint) {
- _self._tooltipSetText("\u53F3\u952E\u5355\u51FB\u56DE\u9000<br>\u5DE6\u952E\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236\u5F00\u59CB\u67E5\u8BE2");
- },
- onError: function(error) {
- if (callError)
- callError(error);
- },
- onComplete: function(cPoints, gPoints) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- let coordinates = void 0;
- for (let i2 = 0; i2 < gPoints.length; i2++) {
- let point2 = gPoints[i2];
- if (coordinates === void 0)
- coordinates = point2.lng + "," + point2.lat;
- else
- coordinates += "," + point2.lng + "," + point2.lat;
- }
- if (callComplete)
- callComplete(coordinates);
- }
- });
- } else {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Line, {
- onAdded: function(cPoints, gPoints) {
- if (cPoints.length === 1) {
- _self._tooltipRemove();
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv == null) {
- _self._createOperationMainDom();
- document.getElementById("btnDrawBackout").onclick = () => {
- if (_self._sketchViewModel._sketchTempPoints.length > 2) {
- _self._sketchViewModel._sketchPoints.pop();
- _self._sketchViewModel._sketchTempPoints.splice(_self._sketchViewModel._sketchTempPoints.length - 1, 1);
- if (_self._sketchViewModel._isDrawPoint) {
- let lastPointEntity = _self._sketchViewModel._pointEntitys[_self._sketchViewModel._pointEntitys.length - 1];
- _self._sketchViewModel._entities.remove(lastPointEntity);
- _self._sketchViewModel._pointEntitys.pop();
- }
- }
- };
- document.getElementById("btnDrawComplete").onclick = () => {
- if (_self._sketchViewModel._sketchPoints.length < 2) {
- if (callError)
- callError("\u70B9\u6570\u5C11\u4E8E\u4E24\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolyline);
- _self._sketchViewModel._createPolyline();
- if (!_self._sketchViewModel._isRetainDrawPoint)
- _self._sketchViewModel._removePointEntitys();
- _self._sketchViewModel._clearEvent(_self._sketchViewModel._sketchEventHandler);
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- let coordinates = void 0;
- for (let i2 = 0; i2 < gPoints.length; i2++) {
- let point2 = gPoints[i2];
- if (coordinates === void 0)
- coordinates = point2.lng + "," + point2.lat;
- else
- coordinates += "," + point2.lng + "," + point2.lat;
- }
- let buttonDiv2 = document.getElementById("drawButtonDiv");
- if (buttonDiv2) {
- document.body.removeChild(buttonDiv2);
- }
- if (callComplete)
- callComplete(coordinates);
- };
- }
- }
- }
- });
- }
- },
- queryByPolygon: function(callComplete, callError) {
- let _self = this;
- this._clear(this._isClear);
- this._setMousePointerStyle();
- if (this._isRuntimeApp()) {
- this._showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236\u533A\u57DF");
- } else {
- this._tooltipInit("\u5355\u51FB\u5F00\u59CB\u7ED8\u5236\u533A\u57DF");
- }
- if (this._isRuntimeWeb()) {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Polygon, {
- onMoving: function(cPoint, scPoint) {
- _self._tooltipSetText("\u53F3\u952E\u5355\u51FB\u56DE\u9000<br>\u5DE6\u952E\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236\u5F00\u59CB\u67E5\u8BE2");
- },
- onError: function(error) {
- if (callError)
- callError(error);
- },
- onComplete: function(cPoints, gPoints) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- let coordinates = void 0;
- for (let i2 = 0; i2 < gPoints.length; i2++) {
- let point2 = gPoints[i2];
- if (coordinates === void 0)
- coordinates = point2.lng + "," + point2.lat;
- else
- coordinates += "," + point2.lng + "," + point2.lat;
- }
- coordinates += "," + gPoints[0].lng + "," + gPoints[0].lat;
- if (callComplete)
- callComplete(coordinates);
- }
- });
- } else {
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Polygon, {
- onAdded: function(cPoints, gPoints) {
- if (cPoints.length === 1) {
- _self._tooltipRemove();
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv == null) {
- _self._createOperationMainDom();
- document.getElementById("btnDrawBackout").onclick = () => {
- if (_self._sketchViewModel._sketchTempPoints.length > 2) {
- _self._sketchViewModel._sketchPoints.pop();
- _self._sketchViewModel._sketchTempPoints.splice(_self._sketchViewModel._sketchTempPoints.length - 1, 1);
- if (_self._sketchViewModel._isDrawPoint) {
- let lastPointEntity = _self._sketchViewModel._pointEntitys[_self._sketchViewModel._pointEntitys.length - 1];
- _self._entities.remove(lastPointEntity);
- _self._sketchViewModel._pointEntitys.pop();
- }
- }
- };
- document.getElementById("btnDrawComplete").onclick = () => {
- if (_self._sketchViewModel._sketchPoints.length < 3) {
- if (callError)
- callError("\u70B9\u6570\u5C11\u4E8E3\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolygon);
- _self._sketchViewModel._removeEntityByObject(_self._sketchViewModel._sketchTempPolyline);
- _self._sketchViewModel._createPolygon();
- if (!_self._sketchViewModel._isRetainDrawPoint)
- _self._sketchViewModel._removePointEntitys();
- _self._sketchViewModel._clearEvent(_self._sketchViewModel._sketchEventHandler);
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- let coordinates = void 0;
- for (let i2 = 0; i2 < gPoints.length; i2++) {
- let point2 = gPoints[i2];
- if (coordinates === void 0)
- coordinates = point2.lng + "," + point2.lat;
- else
- coordinates += "," + point2.lng + "," + point2.lat;
- }
- coordinates += "," + gPoints[0].lng + "," + gPoints[0].lat;
- let buttonDiv2 = document.getElementById("drawButtonDiv");
- if (buttonDiv2) {
- document.body.removeChild(buttonDiv2);
- }
- if (callComplete)
- callComplete(coordinates);
- };
- }
- }
- }
- });
- }
- },
- queryByCircle: function(callComplete) {
- let _self = this;
- this._clear(this._isClear);
- this._setMousePointerStyle();
- if (this._isRuntimeApp()) {
- this._showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236\u5706");
- } else {
- this._tooltipInit("\u5355\u51FB\u5F00\u59CB\u7ED8\u5236\u5706");
- }
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Circle, {
- onAdded: function(center2) {
- if (_self._isRuntimeApp()) {
- _self._showTooltipMessage("\u518D\u6B21\u70B9\u51FB\u7ED3\u675F\u7ED8\u5236");
- } else {
- _self._tooltipInit("\u518D\u6B21\u5355\u51FB\u7ED3\u675F\u7ED8\u5236");
- }
- },
- onComplete: function(center2, radius) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- if (callComplete)
- callComplete(center2.lng + "," + center2.lat, radius);
- }
- });
- },
- queryByRectangle: function(callComplete) {
- let _self = this;
- this._clear(this._isClear);
- this._setMousePointerStyle();
- if (this._isRuntimeApp()) {
- this._showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236\u77E9\u5F62");
- } else {
- this._tooltipInit("\u5355\u51FB\u5F00\u59CB\u7ED8\u5236\u77E9\u5F62");
- }
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.Rectangle, {
- onAdded: function(center2) {
- if (_self._isRuntimeApp()) {
- _self._showTooltipMessage("\u518D\u6B21\u70B9\u51FB\u7ED3\u675F\u7ED8\u5236");
- } else {
- _self._tooltipInit("\u518D\u6B21\u5355\u51FB\u7ED3\u675F\u7ED8\u5236");
- }
- },
- onComplete: function(gPoints) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- let coordinates = void 0;
- for (let i2 = 0; i2 < gPoints.length; i2++) {
- let point2 = gPoints[i2];
- if (coordinates === void 0)
- coordinates = point2.lng + "," + point2.lat;
- else
- coordinates += "," + point2.lng + "," + point2.lat;
- }
- if (callComplete)
- callComplete(coordinates);
- }
- });
- }
- });
- Object.assign(CommonTools.prototype, {
- drawPolygonBody: function(callComplete) {
- let _self = this;
- this._clear(this._isClear);
- this._setMousePointerStyle();
- this._tooltipInit("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- this._sketchViewModel.sketchTools(SketchViewModel.SketchType.PolygonBody, {
- onAdded: function(cPoints, gPoints) {
- if (cPoints.length === 0) {
- _self._tooltipInit("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- } else if (cPoints.length < 3) {
- _self._tooltipInit("\u53F3\u952E\u5355\u51FB\u56DE\u9000");
- } else {
- _self._tooltipInit("\u53F3\u952E\u5355\u51FB\u56DE\u9000<br>\u5DE6\u952E\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236");
- }
- },
- onUndo: function(cPoints) {
- if (cPoints.length === 0) {
- _self._tooltipInit("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- } else if (cPoints.length < 3) {
- _self._tooltipInit("\u53F3\u952E\u5355\u51FB\u56DE\u9000");
- } else {
- _self._tooltipInit("\u53F3\u952E\u5355\u51FB\u56DE\u9000<br>\u5DE6\u952E\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236");
- }
- },
- onComplete: function(cPoints, gPoints) {
- _self._initMousePointerStyle();
- _self._tooltipRemove();
- if (callComplete)
- callComplete();
- }
- });
- },
- drawPointFeacture: function(points2, options2) {
- this._sketchViewModel.sketchDrawFeacture(points2, SketchViewModel.SketchType.DrawPoint, options2);
- },
- drawMultiplePointFeacture: function(points2, options2) {
- this._sketchViewModel.sketchDrawFeacture(points2, SketchViewModel.SketchType.DrawMultiplePoint, options2);
- },
- drawPolylineFeacture: function(points2, options2) {
- this._sketchViewModel.sketchDrawFeacture(points2, SketchViewModel.SketchType.DrawPolyline, options2);
- },
- drawPolygonFeacture: function(points2, options2) {
- this._sketchViewModel.sketchDrawFeacture(points2, SketchViewModel.SketchType.DrawPolygon, options2);
- }
- });
- Object.assign(CommonTools.prototype, {
- tooltipInit: function(text) {
- this._tooltipInit(text);
- },
- tooltipRemove: function() {
- this._tooltipRemove();
- },
- tooltipSetText: function(text) {
- this._tooltipSetText(text);
- }
- });
- Object.assign(CommonTools.prototype, {
- pickPolygonBody: function(callComplete) {
- this._sketchViewModel.sketchPick(function(options2) {
- if (options2 === void 0) {
- if (callComplete)
- callComplete(void 0);
- } else {
- if (callComplete)
- callComplete({
- color: options2.color,
- height: options2.height
- });
- }
- });
- },
- setPolygonBody: function(options2) {
- this._sketchViewModel.sketchEditPickPolygonBody({
- color: options2.color,
- height: options2.height,
- onComplete: options2.onComplete
- });
- },
- removePolygonBody: function(onComplete) {
- this._sketchViewModel.sketchRemovePickPolygonBody(onComplete);
- }
- });
- CommonTools.RuntimeEnvironment = Object.freeze({
- App: "app",
- Web: "web"
- });
- const composeEventHandlers = (theirsHandler, oursHandler, { checkForDefaultPrevented = true } = {}) => {
- const handleEvent = (event2) => {
- const shouldPrevent = theirsHandler == null ? void 0 : theirsHandler(event2);
- if (checkForDefaultPrevented === false || !shouldPrevent) {
- return oursHandler == null ? void 0 : oursHandler(event2);
- }
- };
- return handleEvent;
- };
- var _a;
- const isClient = typeof window !== "undefined";
- const isString$1 = (val) => typeof val === "string";
- const noop$3 = () => {
- };
- const isIOS = isClient && ((_a = window == null ? void 0 : window.navigator) == null ? void 0 : _a.userAgent) && /iP(ad|hone|od)/.test(window.navigator.userAgent);
- function resolveUnref(r2) {
- return typeof r2 === "function" ? r2() : unref(r2);
- }
- function identity(arg) {
- return arg;
- }
- function tryOnScopeDispose(fn2) {
- if (getCurrentScope()) {
- onScopeDispose(fn2);
- return true;
- }
- return false;
- }
- function tryOnMounted(fn2, sync = true) {
- if (getCurrentInstance())
- onMounted(fn2);
- else if (sync)
- fn2();
- else
- nextTick(fn2);
- }
- function useTimeoutFn(cb, interval, options2 = {}) {
- const {
- immediate = true
- } = options2;
- const isPending = ref(false);
- let timer = null;
- function clear() {
- if (timer) {
- clearTimeout(timer);
- timer = null;
- }
- }
- function stop() {
- isPending.value = false;
- clear();
- }
- function start2(...args) {
- clear();
- isPending.value = true;
- timer = setTimeout(() => {
- isPending.value = false;
- timer = null;
- cb(...args);
- }, resolveUnref(interval));
- }
- if (immediate) {
- isPending.value = true;
- if (isClient)
- start2();
- }
- tryOnScopeDispose(stop);
- return {
- isPending: readonly(isPending),
- start: start2,
- stop
- };
- }
- function unrefElement(elRef) {
- var _a2;
- const plain = resolveUnref(elRef);
- return (_a2 = plain == null ? void 0 : plain.$el) != null ? _a2 : plain;
- }
- const defaultWindow = isClient ? window : void 0;
- function useEventListener(...args) {
- let target;
- let events;
- let listeners;
- let options2;
- if (isString$1(args[0]) || Array.isArray(args[0])) {
- [events, listeners, options2] = args;
- target = defaultWindow;
- } else {
- [target, events, listeners, options2] = args;
- }
- if (!target)
- return noop$3;
- if (!Array.isArray(events))
- events = [events];
- if (!Array.isArray(listeners))
- listeners = [listeners];
- const cleanups = [];
- const cleanup = () => {
- cleanups.forEach((fn2) => fn2());
- cleanups.length = 0;
- };
- const register = (el, event2, listener, options22) => {
- el.addEventListener(event2, listener, options22);
- return () => el.removeEventListener(event2, listener, options22);
- };
- const stopWatch = watch(() => [unrefElement(target), resolveUnref(options2)], ([el, options22]) => {
- cleanup();
- if (!el)
- return;
- cleanups.push(...events.flatMap((event2) => {
- return listeners.map((listener) => register(el, event2, listener, options22));
- }));
- }, { immediate: true, flush: "post" });
- const stop = () => {
- stopWatch();
- cleanup();
- };
- tryOnScopeDispose(stop);
- return stop;
- }
- let _iOSWorkaround = false;
- function onClickOutside(target, handler, options2 = {}) {
- const { window: window2 = defaultWindow, ignore = [], capture = true, detectIframe = false } = options2;
- if (!window2)
- return;
- if (isIOS && !_iOSWorkaround) {
- _iOSWorkaround = true;
- Array.from(window2.document.body.children).forEach((el) => el.addEventListener("click", noop$3));
- }
- let shouldListen = true;
- const shouldIgnore = (event2) => {
- return ignore.some((target2) => {
- if (typeof target2 === "string") {
- return Array.from(window2.document.querySelectorAll(target2)).some((el) => el === event2.target || event2.composedPath().includes(el));
- } else {
- const el = unrefElement(target2);
- return el && (event2.target === el || event2.composedPath().includes(el));
- }
- });
- };
- const listener = (event2) => {
- const el = unrefElement(target);
- if (!el || el === event2.target || event2.composedPath().includes(el))
- return;
- if (event2.detail === 0)
- shouldListen = !shouldIgnore(event2);
- if (!shouldListen) {
- shouldListen = true;
- return;
- }
- handler(event2);
- };
- const cleanup = [
- useEventListener(window2, "click", listener, { passive: true, capture }),
- useEventListener(window2, "pointerdown", (e) => {
- const el = unrefElement(target);
- if (el)
- shouldListen = !e.composedPath().includes(el) && !shouldIgnore(e);
- }, { passive: true }),
- detectIframe && useEventListener(window2, "blur", (event2) => {
- var _a2;
- const el = unrefElement(target);
- if (((_a2 = window2.document.activeElement) == null ? void 0 : _a2.tagName) === "IFRAME" && !(el == null ? void 0 : el.contains(window2.document.activeElement)))
- handler(event2);
- })
- ].filter(Boolean);
- const stop = () => cleanup.forEach((fn2) => fn2());
- return stop;
- }
- function useSupported(callback2, sync = false) {
- const isSupported = ref();
- const update = () => isSupported.value = Boolean(callback2());
- update();
- tryOnMounted(update, sync);
- return isSupported;
- }
- const _global = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
- const globalKey = "__vueuse_ssr_handlers__";
- _global[globalKey] = _global[globalKey] || {};
- _global[globalKey];
- var __getOwnPropSymbols$g = Object.getOwnPropertySymbols;
- var __hasOwnProp$g = Object.prototype.hasOwnProperty;
- var __propIsEnum$g = Object.prototype.propertyIsEnumerable;
- var __objRest$2 = (source, exclude) => {
- var target = {};
- for (var prop in source)
- if (__hasOwnProp$g.call(source, prop) && exclude.indexOf(prop) < 0)
- target[prop] = source[prop];
- if (source != null && __getOwnPropSymbols$g)
- for (var prop of __getOwnPropSymbols$g(source)) {
- if (exclude.indexOf(prop) < 0 && __propIsEnum$g.call(source, prop))
- target[prop] = source[prop];
- }
- return target;
- };
- function useResizeObserver(target, callback2, options2 = {}) {
- const _a2 = options2, { window: window2 = defaultWindow } = _a2, observerOptions = __objRest$2(_a2, ["window"]);
- let observer;
- const isSupported = useSupported(() => window2 && "ResizeObserver" in window2);
- const cleanup = () => {
- if (observer) {
- observer.disconnect();
- observer = void 0;
- }
- };
- const stopWatch = watch(() => unrefElement(target), (el) => {
- cleanup();
- if (isSupported.value && window2 && el) {
- observer = new ResizeObserver(callback2);
- observer.observe(el, observerOptions);
- }
- }, { immediate: true, flush: "post" });
- const stop = () => {
- cleanup();
- stopWatch();
- };
- tryOnScopeDispose(stop);
- return {
- isSupported,
- stop
- };
- }
- var SwipeDirection;
- (function(SwipeDirection2) {
- SwipeDirection2["UP"] = "UP";
- SwipeDirection2["RIGHT"] = "RIGHT";
- SwipeDirection2["DOWN"] = "DOWN";
- SwipeDirection2["LEFT"] = "LEFT";
- SwipeDirection2["NONE"] = "NONE";
- })(SwipeDirection || (SwipeDirection = {}));
- var __defProp2 = Object.defineProperty;
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
- var __hasOwnProp = Object.prototype.hasOwnProperty;
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
- var __defNormalProp2 = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __spreadValues = (a, b) => {
- for (var prop in b || (b = {}))
- if (__hasOwnProp.call(b, prop))
- __defNormalProp2(a, prop, b[prop]);
- if (__getOwnPropSymbols)
- for (var prop of __getOwnPropSymbols(b)) {
- if (__propIsEnum.call(b, prop))
- __defNormalProp2(a, prop, b[prop]);
- }
- return a;
- };
- const _TransitionPresets = {
- easeInSine: [0.12, 0, 0.39, 0],
- easeOutSine: [0.61, 1, 0.88, 1],
- easeInOutSine: [0.37, 0, 0.63, 1],
- easeInQuad: [0.11, 0, 0.5, 0],
- easeOutQuad: [0.5, 1, 0.89, 1],
- easeInOutQuad: [0.45, 0, 0.55, 1],
- easeInCubic: [0.32, 0, 0.67, 0],
- easeOutCubic: [0.33, 1, 0.68, 1],
- easeInOutCubic: [0.65, 0, 0.35, 1],
- easeInQuart: [0.5, 0, 0.75, 0],
- easeOutQuart: [0.25, 1, 0.5, 1],
- easeInOutQuart: [0.76, 0, 0.24, 1],
- easeInQuint: [0.64, 0, 0.78, 0],
- easeOutQuint: [0.22, 1, 0.36, 1],
- easeInOutQuint: [0.83, 0, 0.17, 1],
- easeInExpo: [0.7, 0, 0.84, 0],
- easeOutExpo: [0.16, 1, 0.3, 1],
- easeInOutExpo: [0.87, 0, 0.13, 1],
- easeInCirc: [0.55, 0, 1, 0.45],
- easeOutCirc: [0, 0.55, 0.45, 1],
- easeInOutCirc: [0.85, 0, 0.15, 1],
- easeInBack: [0.36, 0, 0.66, -0.56],
- easeOutBack: [0.34, 1.56, 0.64, 1],
- easeInOutBack: [0.68, -0.6, 0.32, 1.6]
- };
- __spreadValues({
- linear: identity
- }, _TransitionPresets);
- const isFirefox = () => isClient && /firefox/i.test(window.navigator.userAgent);
- const getClientXY = (event2) => {
- let clientX;
- let clientY;
- if (event2.type === "touchend") {
- clientY = event2.changedTouches[0].clientY;
- clientX = event2.changedTouches[0].clientX;
- } else if (event2.type.startsWith("touch")) {
- clientY = event2.touches[0].clientY;
- clientX = event2.touches[0].clientX;
- } else {
- clientY = event2.clientY;
- clientX = event2.clientX;
- }
- return {
- clientX,
- clientY
- };
- };
- const NOOP = () => {
- };
- const hasOwnProperty$9 = Object.prototype.hasOwnProperty;
- const hasOwn = (val, key) => hasOwnProperty$9.call(val, key);
- const isArray$2 = Array.isArray;
- const isFunction$3 = (val) => typeof val === "function";
- const isString = (val) => typeof val === "string";
- const isObject$5 = (val) => val !== null && typeof val === "object";
- const isPromise$2 = (val) => {
- return isObject$5(val) && isFunction$3(val.then) && isFunction$3(val.catch);
- };
- const objectToString$1 = Object.prototype.toString;
- const toTypeString = (value) => objectToString$1.call(value);
- const toRawType = (value) => {
- return toTypeString(value).slice(8, -1);
- };
- const cacheStringFunction = (fn2) => {
- const cache = /* @__PURE__ */ Object.create(null);
- return (str) => {
- const hit = cache[str];
- return hit || (cache[str] = fn2(str));
- };
- };
- const camelizeRE = /-(\w)/g;
- const camelize = cacheStringFunction((str) => {
- return str.replace(camelizeRE, (_, c) => c ? c.toUpperCase() : "");
- });
- var freeGlobal = typeof global == "object" && global && global.Object === Object && global;
- var freeGlobal$1 = freeGlobal;
- var freeSelf = typeof self == "object" && self && self.Object === Object && self;
- var root = freeGlobal$1 || freeSelf || Function("return this")();
- var root$1 = root;
- var Symbol$1 = root$1.Symbol;
- var Symbol$2 = Symbol$1;
- var objectProto$b = Object.prototype;
- var hasOwnProperty$8 = objectProto$b.hasOwnProperty;
- var nativeObjectToString$1 = objectProto$b.toString;
- var symToStringTag$1 = Symbol$2 ? Symbol$2.toStringTag : void 0;
- function getRawTag(value) {
- var isOwn = hasOwnProperty$8.call(value, symToStringTag$1), tag = value[symToStringTag$1];
- try {
- value[symToStringTag$1] = void 0;
- var unmasked = true;
- } catch (e) {
- }
- var result = nativeObjectToString$1.call(value);
- if (unmasked) {
- if (isOwn) {
- value[symToStringTag$1] = tag;
- } else {
- delete value[symToStringTag$1];
- }
- }
- return result;
- }
- var objectProto$a = Object.prototype;
- var nativeObjectToString = objectProto$a.toString;
- function objectToString(value) {
- return nativeObjectToString.call(value);
- }
- var nullTag = "[object Null]", undefinedTag = "[object Undefined]";
- var symToStringTag = Symbol$2 ? Symbol$2.toStringTag : void 0;
- function baseGetTag(value) {
- if (value == null) {
- return value === void 0 ? undefinedTag : nullTag;
- }
- return symToStringTag && symToStringTag in Object(value) ? getRawTag(value) : objectToString(value);
- }
- function isObjectLike(value) {
- return value != null && typeof value == "object";
- }
- var symbolTag$1 = "[object Symbol]";
- function isSymbol(value) {
- return typeof value == "symbol" || isObjectLike(value) && baseGetTag(value) == symbolTag$1;
- }
- function arrayMap(array, iteratee) {
- var index2 = -1, length = array == null ? 0 : array.length, result = Array(length);
- while (++index2 < length) {
- result[index2] = iteratee(array[index2], index2, array);
- }
- return result;
- }
- var isArray = Array.isArray;
- var isArray$1 = isArray;
- var INFINITY$1 = 1 / 0;
- var symbolProto$1 = Symbol$2 ? Symbol$2.prototype : void 0, symbolToString = symbolProto$1 ? symbolProto$1.toString : void 0;
- function baseToString(value) {
- if (typeof value == "string") {
- return value;
- }
- if (isArray$1(value)) {
- return arrayMap(value, baseToString) + "";
- }
- if (isSymbol(value)) {
- return symbolToString ? symbolToString.call(value) : "";
- }
- var result = value + "";
- return result == "0" && 1 / value == -INFINITY$1 ? "-0" : result;
- }
- var reWhitespace = /\s/;
- function trimmedEndIndex(string) {
- var index2 = string.length;
- while (index2-- && reWhitespace.test(string.charAt(index2))) {
- }
- return index2;
- }
- var reTrimStart = /^\s+/;
- function baseTrim(string) {
- return string ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, "") : string;
- }
- function isObject$4(value) {
- var type2 = typeof value;
- return value != null && (type2 == "object" || type2 == "function");
- }
- var NAN = 0 / 0;
- var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;
- var reIsBinary = /^0b[01]+$/i;
- var reIsOctal = /^0o[0-7]+$/i;
- var freeParseInt = parseInt;
- function toNumber(value) {
- if (typeof value == "number") {
- return value;
- }
- if (isSymbol(value)) {
- return NAN;
- }
- if (isObject$4(value)) {
- var other = typeof value.valueOf == "function" ? value.valueOf() : value;
- value = isObject$4(other) ? other + "" : other;
- }
- if (typeof value != "string") {
- return value === 0 ? value : +value;
- }
- value = baseTrim(value);
- var isBinary = reIsBinary.test(value);
- return isBinary || reIsOctal.test(value) ? freeParseInt(value.slice(2), isBinary ? 2 : 8) : reIsBadHex.test(value) ? NAN : +value;
- }
- var asyncTag = "[object AsyncFunction]", funcTag$1 = "[object Function]", genTag = "[object GeneratorFunction]", proxyTag = "[object Proxy]";
- function isFunction$2(value) {
- if (!isObject$4(value)) {
- return false;
- }
- var tag = baseGetTag(value);
- return tag == funcTag$1 || tag == genTag || tag == asyncTag || tag == proxyTag;
- }
- var coreJsData = root$1["__core-js_shared__"];
- var coreJsData$1 = coreJsData;
- var maskSrcKey = function() {
- var uid = /[^.]+$/.exec(coreJsData$1 && coreJsData$1.keys && coreJsData$1.keys.IE_PROTO || "");
- return uid ? "Symbol(src)_1." + uid : "";
- }();
- function isMasked(func) {
- return !!maskSrcKey && maskSrcKey in func;
- }
- var funcProto$1 = Function.prototype;
- var funcToString$1 = funcProto$1.toString;
- function toSource(func) {
- if (func != null) {
- try {
- return funcToString$1.call(func);
- } catch (e) {
- }
- try {
- return func + "";
- } catch (e) {
- }
- }
- return "";
- }
- var reRegExpChar = /[\\^$.*+?()[\]{}|]/g;
- var reIsHostCtor = /^\[object .+?Constructor\]$/;
- var funcProto = Function.prototype, objectProto$9 = Object.prototype;
- var funcToString = funcProto.toString;
- var hasOwnProperty$7 = objectProto$9.hasOwnProperty;
- var reIsNative = RegExp(
- "^" + funcToString.call(hasOwnProperty$7).replace(reRegExpChar, "\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, "$1.*?") + "$"
- );
- function baseIsNative(value) {
- if (!isObject$4(value) || isMasked(value)) {
- return false;
- }
- var pattern = isFunction$2(value) ? reIsNative : reIsHostCtor;
- return pattern.test(toSource(value));
- }
- function getValue(object, key) {
- return object == null ? void 0 : object[key];
- }
- function getNative(object, key) {
- var value = getValue(object, key);
- return baseIsNative(value) ? value : void 0;
- }
- var WeakMap$1 = getNative(root$1, "WeakMap");
- var WeakMap$2 = WeakMap$1;
- var MAX_SAFE_INTEGER$1 = 9007199254740991;
- var reIsUint = /^(?:0|[1-9]\d*)$/;
- function isIndex(value, length) {
- var type2 = typeof value;
- length = length == null ? MAX_SAFE_INTEGER$1 : length;
- return !!length && (type2 == "number" || type2 != "symbol" && reIsUint.test(value)) && (value > -1 && value % 1 == 0 && value < length);
- }
- function eq(value, other) {
- return value === other || value !== value && other !== other;
- }
- var MAX_SAFE_INTEGER = 9007199254740991;
- function isLength(value) {
- return typeof value == "number" && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;
- }
- function isArrayLike(value) {
- return value != null && isLength(value.length) && !isFunction$2(value);
- }
- var objectProto$8 = Object.prototype;
- function isPrototype(value) {
- var Ctor = value && value.constructor, proto = typeof Ctor == "function" && Ctor.prototype || objectProto$8;
- return value === proto;
- }
- function baseTimes(n, iteratee) {
- var index2 = -1, result = Array(n);
- while (++index2 < n) {
- result[index2] = iteratee(index2);
- }
- return result;
- }
- var argsTag$2 = "[object Arguments]";
- function baseIsArguments(value) {
- return isObjectLike(value) && baseGetTag(value) == argsTag$2;
- }
- var objectProto$7 = Object.prototype;
- var hasOwnProperty$6 = objectProto$7.hasOwnProperty;
- var propertyIsEnumerable$1 = objectProto$7.propertyIsEnumerable;
- var isArguments = baseIsArguments(function() {
- return arguments;
- }()) ? baseIsArguments : function(value) {
- return isObjectLike(value) && hasOwnProperty$6.call(value, "callee") && !propertyIsEnumerable$1.call(value, "callee");
- };
- var isArguments$1 = isArguments;
- function stubFalse() {
- return false;
- }
- var freeExports$1 = typeof exports == "object" && exports && !exports.nodeType && exports;
- var freeModule$1 = freeExports$1 && typeof module == "object" && module && !module.nodeType && module;
- var moduleExports$1 = freeModule$1 && freeModule$1.exports === freeExports$1;
- var Buffer$1 = moduleExports$1 ? root$1.Buffer : void 0;
- var nativeIsBuffer = Buffer$1 ? Buffer$1.isBuffer : void 0;
- var isBuffer = nativeIsBuffer || stubFalse;
- var isBuffer$1 = isBuffer;
- var argsTag$1 = "[object Arguments]", arrayTag$1 = "[object Array]", boolTag$1 = "[object Boolean]", dateTag$1 = "[object Date]", errorTag$1 = "[object Error]", funcTag = "[object Function]", mapTag$2 = "[object Map]", numberTag$1 = "[object Number]", objectTag$2 = "[object Object]", regexpTag$1 = "[object RegExp]", setTag$2 = "[object Set]", stringTag$1 = "[object String]", weakMapTag$1 = "[object WeakMap]";
- var arrayBufferTag$1 = "[object ArrayBuffer]", dataViewTag$2 = "[object DataView]", float32Tag = "[object Float32Array]", float64Tag = "[object Float64Array]", int8Tag = "[object Int8Array]", int16Tag = "[object Int16Array]", int32Tag = "[object Int32Array]", uint8Tag = "[object Uint8Array]", uint8ClampedTag = "[object Uint8ClampedArray]", uint16Tag = "[object Uint16Array]", uint32Tag = "[object Uint32Array]";
- var typedArrayTags = {};
- typedArrayTags[float32Tag] = typedArrayTags[float64Tag] = typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = typedArrayTags[uint32Tag] = true;
- typedArrayTags[argsTag$1] = typedArrayTags[arrayTag$1] = typedArrayTags[arrayBufferTag$1] = typedArrayTags[boolTag$1] = typedArrayTags[dataViewTag$2] = typedArrayTags[dateTag$1] = typedArrayTags[errorTag$1] = typedArrayTags[funcTag] = typedArrayTags[mapTag$2] = typedArrayTags[numberTag$1] = typedArrayTags[objectTag$2] = typedArrayTags[regexpTag$1] = typedArrayTags[setTag$2] = typedArrayTags[stringTag$1] = typedArrayTags[weakMapTag$1] = false;
- function baseIsTypedArray(value) {
- return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[baseGetTag(value)];
- }
- function baseUnary(func) {
- return function(value) {
- return func(value);
- };
- }
- var freeExports = typeof exports == "object" && exports && !exports.nodeType && exports;
- var freeModule = freeExports && typeof module == "object" && module && !module.nodeType && module;
- var moduleExports = freeModule && freeModule.exports === freeExports;
- var freeProcess = moduleExports && freeGlobal$1.process;
- var nodeUtil = function() {
- try {
- var types = freeModule && freeModule.require && freeModule.require("util").types;
- if (types) {
- return types;
- }
- return freeProcess && freeProcess.binding && freeProcess.binding("util");
- } catch (e) {
- }
- }();
- var nodeUtil$1 = nodeUtil;
- var nodeIsTypedArray = nodeUtil$1 && nodeUtil$1.isTypedArray;
- var isTypedArray$2 = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;
- var isTypedArray$3 = isTypedArray$2;
- var objectProto$6 = Object.prototype;
- var hasOwnProperty$5 = objectProto$6.hasOwnProperty;
- function arrayLikeKeys(value, inherited) {
- var isArr = isArray$1(value), isArg = !isArr && isArguments$1(value), isBuff = !isArr && !isArg && isBuffer$1(value), isType = !isArr && !isArg && !isBuff && isTypedArray$3(value), skipIndexes = isArr || isArg || isBuff || isType, result = skipIndexes ? baseTimes(value.length, String) : [], length = result.length;
- for (var key in value) {
- if ((inherited || hasOwnProperty$5.call(value, key)) && !(skipIndexes && (key == "length" || isBuff && (key == "offset" || key == "parent") || isType && (key == "buffer" || key == "byteLength" || key == "byteOffset") || isIndex(key, length)))) {
- result.push(key);
- }
- }
- return result;
- }
- function overArg(func, transform3) {
- return function(arg) {
- return func(transform3(arg));
- };
- }
- var nativeKeys = overArg(Object.keys, Object);
- var nativeKeys$1 = nativeKeys;
- var objectProto$5 = Object.prototype;
- var hasOwnProperty$4 = objectProto$5.hasOwnProperty;
- function baseKeys(object) {
- if (!isPrototype(object)) {
- return nativeKeys$1(object);
- }
- var result = [];
- for (var key in Object(object)) {
- if (hasOwnProperty$4.call(object, key) && key != "constructor") {
- result.push(key);
- }
- }
- return result;
- }
- function keys$2(object) {
- return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);
- }
- var reIsDeepProp = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, reIsPlainProp = /^\w*$/;
- function isKey(value, object) {
- if (isArray$1(value)) {
- return false;
- }
- var type2 = typeof value;
- if (type2 == "number" || type2 == "symbol" || type2 == "boolean" || value == null || isSymbol(value)) {
- return true;
- }
- return reIsPlainProp.test(value) || !reIsDeepProp.test(value) || object != null && value in Object(object);
- }
- var nativeCreate = getNative(Object, "create");
- var nativeCreate$1 = nativeCreate;
- function hashClear() {
- this.__data__ = nativeCreate$1 ? nativeCreate$1(null) : {};
- this.size = 0;
- }
- function hashDelete(key) {
- var result = this.has(key) && delete this.__data__[key];
- this.size -= result ? 1 : 0;
- return result;
- }
- var HASH_UNDEFINED$2 = "__lodash_hash_undefined__";
- var objectProto$4 = Object.prototype;
- var hasOwnProperty$3 = objectProto$4.hasOwnProperty;
- function hashGet(key) {
- var data = this.__data__;
- if (nativeCreate$1) {
- var result = data[key];
- return result === HASH_UNDEFINED$2 ? void 0 : result;
- }
- return hasOwnProperty$3.call(data, key) ? data[key] : void 0;
- }
- var objectProto$3 = Object.prototype;
- var hasOwnProperty$2 = objectProto$3.hasOwnProperty;
- function hashHas(key) {
- var data = this.__data__;
- return nativeCreate$1 ? data[key] !== void 0 : hasOwnProperty$2.call(data, key);
- }
- var HASH_UNDEFINED$1 = "__lodash_hash_undefined__";
- function hashSet(key, value) {
- var data = this.__data__;
- this.size += this.has(key) ? 0 : 1;
- data[key] = nativeCreate$1 && value === void 0 ? HASH_UNDEFINED$1 : value;
- return this;
- }
- function Hash(entries) {
- var index2 = -1, length = entries == null ? 0 : entries.length;
- this.clear();
- while (++index2 < length) {
- var entry = entries[index2];
- this.set(entry[0], entry[1]);
- }
- }
- Hash.prototype.clear = hashClear;
- Hash.prototype["delete"] = hashDelete;
- Hash.prototype.get = hashGet;
- Hash.prototype.has = hashHas;
- Hash.prototype.set = hashSet;
- function listCacheClear() {
- this.__data__ = [];
- this.size = 0;
- }
- function assocIndexOf(array, key) {
- var length = array.length;
- while (length--) {
- if (eq(array[length][0], key)) {
- return length;
- }
- }
- return -1;
- }
- var arrayProto = Array.prototype;
- var splice = arrayProto.splice;
- function listCacheDelete(key) {
- var data = this.__data__, index2 = assocIndexOf(data, key);
- if (index2 < 0) {
- return false;
- }
- var lastIndex = data.length - 1;
- if (index2 == lastIndex) {
- data.pop();
- } else {
- splice.call(data, index2, 1);
- }
- --this.size;
- return true;
- }
- function listCacheGet(key) {
- var data = this.__data__, index2 = assocIndexOf(data, key);
- return index2 < 0 ? void 0 : data[index2][1];
- }
- function listCacheHas(key) {
- return assocIndexOf(this.__data__, key) > -1;
- }
- function listCacheSet(key, value) {
- var data = this.__data__, index2 = assocIndexOf(data, key);
- if (index2 < 0) {
- ++this.size;
- data.push([key, value]);
- } else {
- data[index2][1] = value;
- }
- return this;
- }
- function ListCache(entries) {
- var index2 = -1, length = entries == null ? 0 : entries.length;
- this.clear();
- while (++index2 < length) {
- var entry = entries[index2];
- this.set(entry[0], entry[1]);
- }
- }
- ListCache.prototype.clear = listCacheClear;
- ListCache.prototype["delete"] = listCacheDelete;
- ListCache.prototype.get = listCacheGet;
- ListCache.prototype.has = listCacheHas;
- ListCache.prototype.set = listCacheSet;
- var Map$2 = getNative(root$1, "Map");
- var Map$3 = Map$2;
- function mapCacheClear() {
- this.size = 0;
- this.__data__ = {
- "hash": new Hash(),
- "map": new (Map$3 || ListCache)(),
- "string": new Hash()
- };
- }
- function isKeyable(value) {
- var type2 = typeof value;
- return type2 == "string" || type2 == "number" || type2 == "symbol" || type2 == "boolean" ? value !== "__proto__" : value === null;
- }
- function getMapData(map, key) {
- var data = map.__data__;
- return isKeyable(key) ? data[typeof key == "string" ? "string" : "hash"] : data.map;
- }
- function mapCacheDelete(key) {
- var result = getMapData(this, key)["delete"](key);
- this.size -= result ? 1 : 0;
- return result;
- }
- function mapCacheGet(key) {
- return getMapData(this, key).get(key);
- }
- function mapCacheHas(key) {
- return getMapData(this, key).has(key);
- }
- function mapCacheSet(key, value) {
- var data = getMapData(this, key), size = data.size;
- data.set(key, value);
- this.size += data.size == size ? 0 : 1;
- return this;
- }
- function MapCache(entries) {
- var index2 = -1, length = entries == null ? 0 : entries.length;
- this.clear();
- while (++index2 < length) {
- var entry = entries[index2];
- this.set(entry[0], entry[1]);
- }
- }
- MapCache.prototype.clear = mapCacheClear;
- MapCache.prototype["delete"] = mapCacheDelete;
- MapCache.prototype.get = mapCacheGet;
- MapCache.prototype.has = mapCacheHas;
- MapCache.prototype.set = mapCacheSet;
- var FUNC_ERROR_TEXT$1 = "Expected a function";
- function memoize(func, resolver) {
- if (typeof func != "function" || resolver != null && typeof resolver != "function") {
- throw new TypeError(FUNC_ERROR_TEXT$1);
- }
- var memoized = function() {
- var args = arguments, key = resolver ? resolver.apply(this, args) : args[0], cache = memoized.cache;
- if (cache.has(key)) {
- return cache.get(key);
- }
- var result = func.apply(this, args);
- memoized.cache = cache.set(key, result) || cache;
- return result;
- };
- memoized.cache = new (memoize.Cache || MapCache)();
- return memoized;
- }
- memoize.Cache = MapCache;
- var MAX_MEMOIZE_SIZE = 500;
- function memoizeCapped(func) {
- var result = memoize(func, function(key) {
- if (cache.size === MAX_MEMOIZE_SIZE) {
- cache.clear();
- }
- return key;
- });
- var cache = result.cache;
- return result;
- }
- var rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g;
- var reEscapeChar = /\\(\\)?/g;
- var stringToPath = memoizeCapped(function(string) {
- var result = [];
- if (string.charCodeAt(0) === 46) {
- result.push("");
- }
- string.replace(rePropName, function(match, number, quote, subString) {
- result.push(quote ? subString.replace(reEscapeChar, "$1") : number || match);
- });
- return result;
- });
- var stringToPath$1 = stringToPath;
- function toString$3(value) {
- return value == null ? "" : baseToString(value);
- }
- function castPath(value, object) {
- if (isArray$1(value)) {
- return value;
- }
- return isKey(value, object) ? [value] : stringToPath$1(toString$3(value));
- }
- var INFINITY = 1 / 0;
- function toKey(value) {
- if (typeof value == "string" || isSymbol(value)) {
- return value;
- }
- var result = value + "";
- return result == "0" && 1 / value == -INFINITY ? "-0" : result;
- }
- function baseGet(object, path) {
- path = castPath(path, object);
- var index2 = 0, length = path.length;
- while (object != null && index2 < length) {
- object = object[toKey(path[index2++])];
- }
- return index2 && index2 == length ? object : void 0;
- }
- function get$2(object, path, defaultValue2) {
- var result = object == null ? void 0 : baseGet(object, path);
- return result === void 0 ? defaultValue2 : result;
- }
- function arrayPush(array, values3) {
- var index2 = -1, length = values3.length, offset = array.length;
- while (++index2 < length) {
- array[offset + index2] = values3[index2];
- }
- return array;
- }
- function castArray() {
- if (!arguments.length) {
- return [];
- }
- var value = arguments[0];
- return isArray$1(value) ? value : [value];
- }
- function stackClear() {
- this.__data__ = new ListCache();
- this.size = 0;
- }
- function stackDelete(key) {
- var data = this.__data__, result = data["delete"](key);
- this.size = data.size;
- return result;
- }
- function stackGet(key) {
- return this.__data__.get(key);
- }
- function stackHas(key) {
- return this.__data__.has(key);
- }
- var LARGE_ARRAY_SIZE = 200;
- function stackSet(key, value) {
- var data = this.__data__;
- if (data instanceof ListCache) {
- var pairs = data.__data__;
- if (!Map$3 || pairs.length < LARGE_ARRAY_SIZE - 1) {
- pairs.push([key, value]);
- this.size = ++data.size;
- return this;
- }
- data = this.__data__ = new MapCache(pairs);
- }
- data.set(key, value);
- this.size = data.size;
- return this;
- }
- function Stack(entries) {
- var data = this.__data__ = new ListCache(entries);
- this.size = data.size;
- }
- Stack.prototype.clear = stackClear;
- Stack.prototype["delete"] = stackDelete;
- Stack.prototype.get = stackGet;
- Stack.prototype.has = stackHas;
- Stack.prototype.set = stackSet;
- function arrayFilter(array, predicate) {
- var index2 = -1, length = array == null ? 0 : array.length, resIndex = 0, result = [];
- while (++index2 < length) {
- var value = array[index2];
- if (predicate(value, index2, array)) {
- result[resIndex++] = value;
- }
- }
- return result;
- }
- function stubArray() {
- return [];
- }
- var objectProto$2 = Object.prototype;
- var propertyIsEnumerable = objectProto$2.propertyIsEnumerable;
- var nativeGetSymbols = Object.getOwnPropertySymbols;
- var getSymbols = !nativeGetSymbols ? stubArray : function(object) {
- if (object == null) {
- return [];
- }
- object = Object(object);
- return arrayFilter(nativeGetSymbols(object), function(symbol) {
- return propertyIsEnumerable.call(object, symbol);
- });
- };
- var getSymbols$1 = getSymbols;
- function baseGetAllKeys(object, keysFunc, symbolsFunc) {
- var result = keysFunc(object);
- return isArray$1(object) ? result : arrayPush(result, symbolsFunc(object));
- }
- function getAllKeys(object) {
- return baseGetAllKeys(object, keys$2, getSymbols$1);
- }
- var DataView$1 = getNative(root$1, "DataView");
- var DataView$2 = DataView$1;
- var Promise$1 = getNative(root$1, "Promise");
- var Promise$2 = Promise$1;
- var Set$2 = getNative(root$1, "Set");
- var Set$3 = Set$2;
- var mapTag$1 = "[object Map]", objectTag$1 = "[object Object]", promiseTag = "[object Promise]", setTag$1 = "[object Set]", weakMapTag = "[object WeakMap]";
- var dataViewTag$1 = "[object DataView]";
- var dataViewCtorString = toSource(DataView$2), mapCtorString = toSource(Map$3), promiseCtorString = toSource(Promise$2), setCtorString = toSource(Set$3), weakMapCtorString = toSource(WeakMap$2);
- var getTag = baseGetTag;
- if (DataView$2 && getTag(new DataView$2(new ArrayBuffer(1))) != dataViewTag$1 || Map$3 && getTag(new Map$3()) != mapTag$1 || Promise$2 && getTag(Promise$2.resolve()) != promiseTag || Set$3 && getTag(new Set$3()) != setTag$1 || WeakMap$2 && getTag(new WeakMap$2()) != weakMapTag) {
- getTag = function(value) {
- var result = baseGetTag(value), Ctor = result == objectTag$1 ? value.constructor : void 0, ctorString = Ctor ? toSource(Ctor) : "";
- if (ctorString) {
- switch (ctorString) {
- case dataViewCtorString:
- return dataViewTag$1;
- case mapCtorString:
- return mapTag$1;
- case promiseCtorString:
- return promiseTag;
- case setCtorString:
- return setTag$1;
- case weakMapCtorString:
- return weakMapTag;
- }
- }
- return result;
- };
- }
- var getTag$1 = getTag;
- var Uint8Array$1 = root$1.Uint8Array;
- var Uint8Array$2 = Uint8Array$1;
- var HASH_UNDEFINED = "__lodash_hash_undefined__";
- function setCacheAdd(value) {
- this.__data__.set(value, HASH_UNDEFINED);
- return this;
- }
- function setCacheHas(value) {
- return this.__data__.has(value);
- }
- function SetCache(values3) {
- var index2 = -1, length = values3 == null ? 0 : values3.length;
- this.__data__ = new MapCache();
- while (++index2 < length) {
- this.add(values3[index2]);
- }
- }
- SetCache.prototype.add = SetCache.prototype.push = setCacheAdd;
- SetCache.prototype.has = setCacheHas;
- function arraySome(array, predicate) {
- var index2 = -1, length = array == null ? 0 : array.length;
- while (++index2 < length) {
- if (predicate(array[index2], index2, array)) {
- return true;
- }
- }
- return false;
- }
- function cacheHas(cache, key) {
- return cache.has(key);
- }
- var COMPARE_PARTIAL_FLAG$3 = 1, COMPARE_UNORDERED_FLAG$1 = 2;
- function equalArrays(array, other, bitmask, customizer, equalFunc, stack) {
- var isPartial = bitmask & COMPARE_PARTIAL_FLAG$3, arrLength = array.length, othLength = other.length;
- if (arrLength != othLength && !(isPartial && othLength > arrLength)) {
- return false;
- }
- var arrStacked = stack.get(array);
- var othStacked = stack.get(other);
- if (arrStacked && othStacked) {
- return arrStacked == other && othStacked == array;
- }
- var index2 = -1, result = true, seen = bitmask & COMPARE_UNORDERED_FLAG$1 ? new SetCache() : void 0;
- stack.set(array, other);
- stack.set(other, array);
- while (++index2 < arrLength) {
- var arrValue = array[index2], othValue = other[index2];
- if (customizer) {
- var compared = isPartial ? customizer(othValue, arrValue, index2, other, array, stack) : customizer(arrValue, othValue, index2, array, other, stack);
- }
- if (compared !== void 0) {
- if (compared) {
- continue;
- }
- result = false;
- break;
- }
- if (seen) {
- if (!arraySome(other, function(othValue2, othIndex) {
- if (!cacheHas(seen, othIndex) && (arrValue === othValue2 || equalFunc(arrValue, othValue2, bitmask, customizer, stack))) {
- return seen.push(othIndex);
- }
- })) {
- result = false;
- break;
- }
- } else if (!(arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {
- result = false;
- break;
- }
- }
- stack["delete"](array);
- stack["delete"](other);
- return result;
- }
- function mapToArray(map) {
- var index2 = -1, result = Array(map.size);
- map.forEach(function(value, key) {
- result[++index2] = [key, value];
- });
- return result;
- }
- function setToArray(set4) {
- var index2 = -1, result = Array(set4.size);
- set4.forEach(function(value) {
- result[++index2] = value;
- });
- return result;
- }
- var COMPARE_PARTIAL_FLAG$2 = 1, COMPARE_UNORDERED_FLAG = 2;
- var boolTag = "[object Boolean]", dateTag = "[object Date]", errorTag = "[object Error]", mapTag = "[object Map]", numberTag = "[object Number]", regexpTag = "[object RegExp]", setTag = "[object Set]", stringTag = "[object String]", symbolTag = "[object Symbol]";
- var arrayBufferTag = "[object ArrayBuffer]", dataViewTag = "[object DataView]";
- var symbolProto = Symbol$2 ? Symbol$2.prototype : void 0, symbolValueOf = symbolProto ? symbolProto.valueOf : void 0;
- function equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {
- switch (tag) {
- case dataViewTag:
- if (object.byteLength != other.byteLength || object.byteOffset != other.byteOffset) {
- return false;
- }
- object = object.buffer;
- other = other.buffer;
- case arrayBufferTag:
- if (object.byteLength != other.byteLength || !equalFunc(new Uint8Array$2(object), new Uint8Array$2(other))) {
- return false;
- }
- return true;
- case boolTag:
- case dateTag:
- case numberTag:
- return eq(+object, +other);
- case errorTag:
- return object.name == other.name && object.message == other.message;
- case regexpTag:
- case stringTag:
- return object == other + "";
- case mapTag:
- var convert = mapToArray;
- case setTag:
- var isPartial = bitmask & COMPARE_PARTIAL_FLAG$2;
- convert || (convert = setToArray);
- if (object.size != other.size && !isPartial) {
- return false;
- }
- var stacked = stack.get(object);
- if (stacked) {
- return stacked == other;
- }
- bitmask |= COMPARE_UNORDERED_FLAG;
- stack.set(object, other);
- var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);
- stack["delete"](object);
- return result;
- case symbolTag:
- if (symbolValueOf) {
- return symbolValueOf.call(object) == symbolValueOf.call(other);
- }
- }
- return false;
- }
- var COMPARE_PARTIAL_FLAG$1 = 1;
- var objectProto$1 = Object.prototype;
- var hasOwnProperty$1 = objectProto$1.hasOwnProperty;
- function equalObjects(object, other, bitmask, customizer, equalFunc, stack) {
- var isPartial = bitmask & COMPARE_PARTIAL_FLAG$1, objProps = getAllKeys(object), objLength = objProps.length, othProps = getAllKeys(other), othLength = othProps.length;
- if (objLength != othLength && !isPartial) {
- return false;
- }
- var index2 = objLength;
- while (index2--) {
- var key = objProps[index2];
- if (!(isPartial ? key in other : hasOwnProperty$1.call(other, key))) {
- return false;
- }
- }
- var objStacked = stack.get(object);
- var othStacked = stack.get(other);
- if (objStacked && othStacked) {
- return objStacked == other && othStacked == object;
- }
- var result = true;
- stack.set(object, other);
- stack.set(other, object);
- var skipCtor = isPartial;
- while (++index2 < objLength) {
- key = objProps[index2];
- var objValue = object[key], othValue = other[key];
- if (customizer) {
- var compared = isPartial ? customizer(othValue, objValue, key, other, object, stack) : customizer(objValue, othValue, key, object, other, stack);
- }
- if (!(compared === void 0 ? objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack) : compared)) {
- result = false;
- break;
- }
- skipCtor || (skipCtor = key == "constructor");
- }
- if (result && !skipCtor) {
- var objCtor = object.constructor, othCtor = other.constructor;
- if (objCtor != othCtor && ("constructor" in object && "constructor" in other) && !(typeof objCtor == "function" && objCtor instanceof objCtor && typeof othCtor == "function" && othCtor instanceof othCtor)) {
- result = false;
- }
- }
- stack["delete"](object);
- stack["delete"](other);
- return result;
- }
- var COMPARE_PARTIAL_FLAG = 1;
- var argsTag = "[object Arguments]", arrayTag = "[object Array]", objectTag = "[object Object]";
- var objectProto = Object.prototype;
- var hasOwnProperty = objectProto.hasOwnProperty;
- function baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {
- var objIsArr = isArray$1(object), othIsArr = isArray$1(other), objTag = objIsArr ? arrayTag : getTag$1(object), othTag = othIsArr ? arrayTag : getTag$1(other);
- objTag = objTag == argsTag ? objectTag : objTag;
- othTag = othTag == argsTag ? objectTag : othTag;
- var objIsObj = objTag == objectTag, othIsObj = othTag == objectTag, isSameTag = objTag == othTag;
- if (isSameTag && isBuffer$1(object)) {
- if (!isBuffer$1(other)) {
- return false;
- }
- objIsArr = true;
- objIsObj = false;
- }
- if (isSameTag && !objIsObj) {
- stack || (stack = new Stack());
- return objIsArr || isTypedArray$3(object) ? equalArrays(object, other, bitmask, customizer, equalFunc, stack) : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);
- }
- if (!(bitmask & COMPARE_PARTIAL_FLAG)) {
- var objIsWrapped = objIsObj && hasOwnProperty.call(object, "__wrapped__"), othIsWrapped = othIsObj && hasOwnProperty.call(other, "__wrapped__");
- if (objIsWrapped || othIsWrapped) {
- var objUnwrapped = objIsWrapped ? object.value() : object, othUnwrapped = othIsWrapped ? other.value() : other;
- stack || (stack = new Stack());
- return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);
- }
- }
- if (!isSameTag) {
- return false;
- }
- stack || (stack = new Stack());
- return equalObjects(object, other, bitmask, customizer, equalFunc, stack);
- }
- function baseIsEqual(value, other, bitmask, customizer, stack) {
- if (value === other) {
- return true;
- }
- if (value == null || other == null || !isObjectLike(value) && !isObjectLike(other)) {
- return value !== value && other !== other;
- }
- return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);
- }
- var now = function() {
- return root$1.Date.now();
- };
- var now$1 = now;
- var FUNC_ERROR_TEXT = "Expected a function";
- var nativeMax = Math.max, nativeMin = Math.min;
- function debounce$2(func, wait, options2) {
- var lastArgs, lastThis, maxWait, result, timerId, lastCallTime, lastInvokeTime = 0, leading = false, maxing = false, trailing = true;
- if (typeof func != "function") {
- throw new TypeError(FUNC_ERROR_TEXT);
- }
- wait = toNumber(wait) || 0;
- if (isObject$4(options2)) {
- leading = !!options2.leading;
- maxing = "maxWait" in options2;
- maxWait = maxing ? nativeMax(toNumber(options2.maxWait) || 0, wait) : maxWait;
- trailing = "trailing" in options2 ? !!options2.trailing : trailing;
- }
- function invokeFunc(time) {
- var args = lastArgs, thisArg = lastThis;
- lastArgs = lastThis = void 0;
- lastInvokeTime = time;
- result = func.apply(thisArg, args);
- return result;
- }
- function leadingEdge(time) {
- lastInvokeTime = time;
- timerId = setTimeout(timerExpired, wait);
- return leading ? invokeFunc(time) : result;
- }
- function remainingWait(time) {
- var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime, timeWaiting = wait - timeSinceLastCall;
- return maxing ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke) : timeWaiting;
- }
- function shouldInvoke(time) {
- var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime;
- return lastCallTime === void 0 || timeSinceLastCall >= wait || timeSinceLastCall < 0 || maxing && timeSinceLastInvoke >= maxWait;
- }
- function timerExpired() {
- var time = now$1();
- if (shouldInvoke(time)) {
- return trailingEdge(time);
- }
- timerId = setTimeout(timerExpired, remainingWait(time));
- }
- function trailingEdge(time) {
- timerId = void 0;
- if (trailing && lastArgs) {
- return invokeFunc(time);
- }
- lastArgs = lastThis = void 0;
- return result;
- }
- function cancel() {
- if (timerId !== void 0) {
- clearTimeout(timerId);
- }
- lastInvokeTime = 0;
- lastArgs = lastCallTime = lastThis = timerId = void 0;
- }
- function flush() {
- return timerId === void 0 ? result : trailingEdge(now$1());
- }
- function debounced() {
- var time = now$1(), isInvoking = shouldInvoke(time);
- lastArgs = arguments;
- lastThis = this;
- lastCallTime = time;
- if (isInvoking) {
- if (timerId === void 0) {
- return leadingEdge(lastCallTime);
- }
- if (maxing) {
- clearTimeout(timerId);
- timerId = setTimeout(timerExpired, wait);
- return invokeFunc(lastCallTime);
- }
- }
- if (timerId === void 0) {
- timerId = setTimeout(timerExpired, wait);
- }
- return result;
- }
- debounced.cancel = cancel;
- debounced.flush = flush;
- return debounced;
- }
- function fromPairs(pairs) {
- var index2 = -1, length = pairs == null ? 0 : pairs.length, result = {};
- while (++index2 < length) {
- var pair = pairs[index2];
- result[pair[0]] = pair[1];
- }
- return result;
- }
- function isEqual(value, other) {
- return baseIsEqual(value, other);
- }
- function isNil(value) {
- return value == null;
- }
- function isUndefined$1(value) {
- return value === void 0;
- }
- const isUndefined = (val) => val === void 0;
- const isBoolean = (val) => typeof val === "boolean";
- const isNumber = (val) => typeof val === "number";
- const isElement = (e) => {
- if (typeof Element === "undefined")
- return false;
- return e instanceof Element;
- };
- const isStringNumber = (val) => {
- if (!isString(val)) {
- return false;
- }
- return !Number.isNaN(Number(val));
- };
- const escapeStringRegexp = (string = "") => string.replace(/[|\\{}()[\]^$+*?.]/g, "\\$&").replace(/-/g, "\\x2d");
- const keysOf = (arr) => Object.keys(arr);
- class ElementPlusError extends Error {
- constructor(m) {
- super(m);
- this.name = "ElementPlusError";
- }
- }
- function throwError(scope, m) {
- throw new ElementPlusError(`[${scope}] ${m}`);
- }
- function debugWarn(scope, message) {
- }
- const classNameToArray = (cls = "") => cls.split(" ").filter((item) => !!item.trim());
- const hasClass$2 = (el, cls) => {
- if (!el || !cls)
- return false;
- if (cls.includes(" "))
- throw new Error("className should not contain space.");
- return el.classList.contains(cls);
- };
- const addClass$2 = (el, cls) => {
- if (!el || !cls.trim())
- return;
- el.classList.add(...classNameToArray(cls));
- };
- const removeClass$2 = (el, cls) => {
- if (!el || !cls.trim())
- return;
- el.classList.remove(...classNameToArray(cls));
- };
- const getStyle = (element, styleName) => {
- var _a2;
- if (!isClient || !element || !styleName)
- return "";
- let key = camelize(styleName);
- if (key === "float")
- key = "cssFloat";
- try {
- const style = element.style[key];
- if (style)
- return style;
- const computed2 = (_a2 = document.defaultView) == null ? void 0 : _a2.getComputedStyle(element, "");
- return computed2 ? computed2[key] : "";
- } catch (e) {
- return element.style[key];
- }
- };
- function addUnit(value, defaultUnit = "px") {
- if (!value)
- return "";
- if (isNumber(value) || isStringNumber(value)) {
- return `${value}${defaultUnit}`;
- } else if (isString(value)) {
- return value;
- }
- }
- let scrollBarWidth;
- const getScrollBarWidth = (namespace) => {
- var _a2;
- if (!isClient)
- return 0;
- if (scrollBarWidth !== void 0)
- return scrollBarWidth;
- const outer = document.createElement("div");
- outer.className = `${namespace}-scrollbar__wrap`;
- outer.style.visibility = "hidden";
- outer.style.width = "100px";
- outer.style.position = "absolute";
- outer.style.top = "-9999px";
- document.body.appendChild(outer);
- const widthNoScroll = outer.offsetWidth;
- outer.style.overflow = "scroll";
- const inner = document.createElement("div");
- inner.style.width = "100%";
- outer.appendChild(inner);
- const widthWithScroll = inner.offsetWidth;
- (_a2 = outer.parentNode) == null ? void 0 : _a2.removeChild(outer);
- scrollBarWidth = widthNoScroll - widthWithScroll;
- return scrollBarWidth;
- };
- function scrollIntoView(container, selected) {
- if (!isClient)
- return;
- if (!selected) {
- container.scrollTop = 0;
- return;
- }
- const offsetParents = [];
- let pointer = selected.offsetParent;
- while (pointer !== null && container !== pointer && container.contains(pointer)) {
- offsetParents.push(pointer);
- pointer = pointer.offsetParent;
- }
- const top = selected.offsetTop + offsetParents.reduce((prev, curr) => prev + curr.offsetTop, 0);
- const bottom = top + selected.offsetHeight;
- const viewRectTop = container.scrollTop;
- const viewRectBottom = viewRectTop + container.clientHeight;
- if (top < viewRectTop) {
- container.scrollTop = top;
- } else if (bottom > viewRectBottom) {
- container.scrollTop = bottom - container.clientHeight;
- }
- }
- /*! Element Plus Icons Vue v2.1.0 */
- var export_helper_default = (sfc, props) => {
- let target = sfc.__vccOpts || sfc;
- for (let [key, val] of props)
- target[key] = val;
- return target;
- };
- var arrow_down_vue_vue_type_script_lang_default = {
- name: "ArrowDown"
- };
- var _hoisted_16$2 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_26$2 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M831.872 340.864 512 652.672 192.128 340.864a30.592 30.592 0 0 0-42.752 0 29.12 29.12 0 0 0 0 41.6L489.664 714.24a32 32 0 0 0 44.672 0l340.288-331.712a29.12 29.12 0 0 0 0-41.728 30.592 30.592 0 0 0-42.752 0z"
- },
- null,
- -1
- ), _hoisted_36$2 = [
- _hoisted_26$2
- ];
- function _sfc_render6(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_16$2, _hoisted_36$2);
- }
- var arrow_down_default = /* @__PURE__ */ export_helper_default(arrow_down_vue_vue_type_script_lang_default, [["render", _sfc_render6], ["__file", "arrow-down.vue"]]);
- var arrow_right_vue_vue_type_script_lang_default = {
- name: "ArrowRight"
- };
- var _hoisted_110 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_210 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M340.864 149.312a30.592 30.592 0 0 0 0 42.752L652.736 512 340.864 831.872a30.592 30.592 0 0 0 0 42.752 29.12 29.12 0 0 0 41.728 0L714.24 534.336a32 32 0 0 0 0-44.672L382.592 149.376a29.12 29.12 0 0 0-41.728 0z"
- },
- null,
- -1
- ), _hoisted_310 = [
- _hoisted_210
- ];
- function _sfc_render10(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_110, _hoisted_310);
- }
- var arrow_right_default = /* @__PURE__ */ export_helper_default(arrow_right_vue_vue_type_script_lang_default, [["render", _sfc_render10], ["__file", "arrow-right.vue"]]);
- var arrow_up_vue_vue_type_script_lang_default = {
- name: "ArrowUp"
- };
- var _hoisted_112 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_212 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "m488.832 344.32-339.84 356.672a32 32 0 0 0 0 44.16l.384.384a29.44 29.44 0 0 0 42.688 0l320-335.872 319.872 335.872a29.44 29.44 0 0 0 42.688 0l.384-.384a32 32 0 0 0 0-44.16L535.168 344.32a32 32 0 0 0-46.336 0z"
- },
- null,
- -1
- ), _hoisted_312 = [
- _hoisted_212
- ];
- function _sfc_render12(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_112, _hoisted_312);
- }
- var arrow_up_default = /* @__PURE__ */ export_helper_default(arrow_up_vue_vue_type_script_lang_default, [["render", _sfc_render12], ["__file", "arrow-up.vue"]]);
- var circle_check_vue_vue_type_script_lang_default = {
- name: "CircleCheck"
- };
- var _hoisted_149 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_249 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M512 896a384 384 0 1 0 0-768 384 384 0 0 0 0 768zm0 64a448 448 0 1 1 0-896 448 448 0 0 1 0 896z"
- },
- null,
- -1
- ), _hoisted_348 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M745.344 361.344a32 32 0 0 1 45.312 45.312l-288 288a32 32 0 0 1-45.312 0l-160-160a32 32 0 1 1 45.312-45.312L480 626.752l265.344-265.408z"
- },
- null,
- -1
- ), _hoisted_415 = [
- _hoisted_249,
- _hoisted_348
- ];
- function _sfc_render49(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_149, _hoisted_415);
- }
- var circle_check_default = /* @__PURE__ */ export_helper_default(circle_check_vue_vue_type_script_lang_default, [["render", _sfc_render49], ["__file", "circle-check.vue"]]);
- var circle_close_vue_vue_type_script_lang_default = {
- name: "CircleClose"
- };
- var _hoisted_151 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_251 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "m466.752 512-90.496-90.496a32 32 0 0 1 45.248-45.248L512 466.752l90.496-90.496a32 32 0 1 1 45.248 45.248L557.248 512l90.496 90.496a32 32 0 1 1-45.248 45.248L512 557.248l-90.496 90.496a32 32 0 0 1-45.248-45.248L466.752 512z"
- },
- null,
- -1
- ), _hoisted_350 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M512 896a384 384 0 1 0 0-768 384 384 0 0 0 0 768zm0 64a448 448 0 1 1 0-896 448 448 0 0 1 0 896z"
- },
- null,
- -1
- ), _hoisted_416 = [
- _hoisted_251,
- _hoisted_350
- ];
- function _sfc_render51(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_151, _hoisted_416);
- }
- var circle_close_default = /* @__PURE__ */ export_helper_default(circle_close_vue_vue_type_script_lang_default, [["render", _sfc_render51], ["__file", "circle-close.vue"]]);
- var close_vue_vue_type_script_lang_default = {
- name: "Close"
- };
- var _hoisted_156 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_256 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M764.288 214.592 512 466.88 259.712 214.592a31.936 31.936 0 0 0-45.12 45.12L466.752 512 214.528 764.224a31.936 31.936 0 1 0 45.12 45.184L512 557.184l252.288 252.288a31.936 31.936 0 0 0 45.12-45.12L557.12 512.064l252.288-252.352a31.936 31.936 0 1 0-45.12-45.184z"
- },
- null,
- -1
- ), _hoisted_355 = [
- _hoisted_256
- ];
- function _sfc_render56(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_156, _hoisted_355);
- }
- var close_default = /* @__PURE__ */ export_helper_default(close_vue_vue_type_script_lang_default, [["render", _sfc_render56], ["__file", "close.vue"]]);
- var delete_vue_vue_type_script_lang_default = {
- name: "Delete"
- };
- var _hoisted_180 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_280 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M160 256H96a32 32 0 0 1 0-64h256V95.936a32 32 0 0 1 32-32h256a32 32 0 0 1 32 32V192h256a32 32 0 1 1 0 64h-64v672a32 32 0 0 1-32 32H192a32 32 0 0 1-32-32V256zm448-64v-64H416v64h192zM224 896h576V256H224v640zm192-128a32 32 0 0 1-32-32V416a32 32 0 0 1 64 0v320a32 32 0 0 1-32 32zm192 0a32 32 0 0 1-32-32V416a32 32 0 0 1 64 0v320a32 32 0 0 1-32 32z"
- },
- null,
- -1
- ), _hoisted_379 = [
- _hoisted_280
- ];
- function _sfc_render80(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_180, _hoisted_379);
- }
- var delete_default = /* @__PURE__ */ export_helper_default(delete_vue_vue_type_script_lang_default, [["render", _sfc_render80], ["__file", "delete.vue"]]);
- var edit_vue_vue_type_script_lang_default = {
- name: "Edit"
- };
- var _hoisted_194 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_294 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M832 512a32 32 0 1 1 64 0v352a32 32 0 0 1-32 32H160a32 32 0 0 1-32-32V160a32 32 0 0 1 32-32h352a32 32 0 0 1 0 64H192v640h640V512z"
- },
- null,
- -1
- ), _hoisted_393 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "m469.952 554.24 52.8-7.552L847.104 222.4a32 32 0 1 0-45.248-45.248L477.44 501.44l-7.552 52.8zm422.4-422.4a96 96 0 0 1 0 135.808l-331.84 331.84a32 32 0 0 1-18.112 9.088L436.8 623.68a32 32 0 0 1-36.224-36.224l15.104-105.6a32 32 0 0 1 9.024-18.112l331.904-331.84a96 96 0 0 1 135.744 0z"
- },
- null,
- -1
- ), _hoisted_431 = [
- _hoisted_294,
- _hoisted_393
- ];
- function _sfc_render94(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_194, _hoisted_431);
- }
- var edit_default = /* @__PURE__ */ export_helper_default(edit_vue_vue_type_script_lang_default, [["render", _sfc_render94], ["__file", "edit.vue"]]);
- var hide_vue_vue_type_script_lang_default = {
- name: "Hide"
- };
- var _hoisted_1133 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_2133 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M876.8 156.8c0-9.6-3.2-16-9.6-22.4-6.4-6.4-12.8-9.6-22.4-9.6-9.6 0-16 3.2-22.4 9.6L736 220.8c-64-32-137.6-51.2-224-60.8-160 16-288 73.6-377.6 176C44.8 438.4 0 496 0 512s48 73.6 134.4 176c22.4 25.6 44.8 48 73.6 67.2l-86.4 89.6c-6.4 6.4-9.6 12.8-9.6 22.4 0 9.6 3.2 16 9.6 22.4 6.4 6.4 12.8 9.6 22.4 9.6 9.6 0 16-3.2 22.4-9.6l704-710.4c3.2-6.4 6.4-12.8 6.4-22.4Zm-646.4 528c-76.8-70.4-128-128-153.6-172.8 28.8-48 80-105.6 153.6-172.8C304 272 400 230.4 512 224c64 3.2 124.8 19.2 176 44.8l-54.4 54.4C598.4 300.8 560 288 512 288c-64 0-115.2 22.4-160 64s-64 96-64 160c0 48 12.8 89.6 35.2 124.8L256 707.2c-9.6-6.4-19.2-16-25.6-22.4Zm140.8-96c-12.8-22.4-19.2-48-19.2-76.8 0-44.8 16-83.2 48-112 32-28.8 67.2-48 112-48 28.8 0 54.4 6.4 73.6 19.2L371.2 588.8ZM889.599 336c-12.8-16-28.8-28.8-41.6-41.6l-48 48c73.6 67.2 124.8 124.8 150.4 169.6-28.8 48-80 105.6-153.6 172.8-73.6 67.2-172.8 108.8-284.8 115.2-51.2-3.2-99.2-12.8-140.8-28.8l-48 48c57.6 22.4 118.4 38.4 188.8 44.8 160-16 288-73.6 377.6-176C979.199 585.6 1024 528 1024 512s-48.001-73.6-134.401-176Z"
- },
- null,
- -1
- ), _hoisted_3132 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M511.998 672c-12.8 0-25.6-3.2-38.4-6.4l-51.2 51.2c28.8 12.8 57.6 19.2 89.6 19.2 64 0 115.2-22.4 160-64 41.6-41.6 64-96 64-160 0-32-6.4-64-19.2-89.6l-51.2 51.2c3.2 12.8 6.4 25.6 6.4 38.4 0 44.8-16 83.2-48 112-32 28.8-67.2 48-112 48Z"
- },
- null,
- -1
- ), _hoisted_438 = [
- _hoisted_2133,
- _hoisted_3132
- ];
- function _sfc_render133(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_1133, _hoisted_438);
- }
- var hide_default = /* @__PURE__ */ export_helper_default(hide_vue_vue_type_script_lang_default, [["render", _sfc_render133], ["__file", "hide.vue"]]);
- var loading_vue_vue_type_script_lang_default = {
- name: "Loading"
- };
- var _hoisted_1150 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_2150 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M512 64a32 32 0 0 1 32 32v192a32 32 0 0 1-64 0V96a32 32 0 0 1 32-32zm0 640a32 32 0 0 1 32 32v192a32 32 0 1 1-64 0V736a32 32 0 0 1 32-32zm448-192a32 32 0 0 1-32 32H736a32 32 0 1 1 0-64h192a32 32 0 0 1 32 32zm-640 0a32 32 0 0 1-32 32H96a32 32 0 0 1 0-64h192a32 32 0 0 1 32 32zM195.2 195.2a32 32 0 0 1 45.248 0L376.32 331.008a32 32 0 0 1-45.248 45.248L195.2 240.448a32 32 0 0 1 0-45.248zm452.544 452.544a32 32 0 0 1 45.248 0L828.8 783.552a32 32 0 0 1-45.248 45.248L647.744 692.992a32 32 0 0 1 0-45.248zM828.8 195.264a32 32 0 0 1 0 45.184L692.992 376.32a32 32 0 0 1-45.248-45.248l135.808-135.808a32 32 0 0 1 45.248 0zm-452.544 452.48a32 32 0 0 1 0 45.248L240.448 828.8a32 32 0 0 1-45.248-45.248l135.808-135.808a32 32 0 0 1 45.248 0z"
- },
- null,
- -1
- ), _hoisted_3149 = [
- _hoisted_2150
- ];
- function _sfc_render150(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_1150, _hoisted_3149);
- }
- var loading_default = /* @__PURE__ */ export_helper_default(loading_vue_vue_type_script_lang_default, [["render", _sfc_render150], ["__file", "loading.vue"]]);
- var minus_vue_vue_type_script_lang_default = {
- name: "Minus"
- };
- var _hoisted_1169 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_2169 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M128 544h768a32 32 0 1 0 0-64H128a32 32 0 0 0 0 64z"
- },
- null,
- -1
- ), _hoisted_3168 = [
- _hoisted_2169
- ];
- function _sfc_render169(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_1169, _hoisted_3168);
- }
- var minus_default = /* @__PURE__ */ export_helper_default(minus_vue_vue_type_script_lang_default, [["render", _sfc_render169], ["__file", "minus.vue"]]);
- var plus_vue_vue_type_script_lang_default = {
- name: "Plus"
- };
- var _hoisted_1201 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_2201 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M480 480V128a32 32 0 0 1 64 0v352h352a32 32 0 1 1 0 64H544v352a32 32 0 1 1-64 0V544H128a32 32 0 0 1 0-64h352z"
- },
- null,
- -1
- ), _hoisted_3200 = [
- _hoisted_2201
- ];
- function _sfc_render201(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_1201, _hoisted_3200);
- }
- var plus_default = /* @__PURE__ */ export_helper_default(plus_vue_vue_type_script_lang_default, [["render", _sfc_render201], ["__file", "plus.vue"]]);
- var setting_vue_vue_type_script_lang_default = {
- name: "Setting"
- };
- var _hoisted_1231 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_2231 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M600.704 64a32 32 0 0 1 30.464 22.208l35.2 109.376c14.784 7.232 28.928 15.36 42.432 24.512l112.384-24.192a32 32 0 0 1 34.432 15.36L944.32 364.8a32 32 0 0 1-4.032 37.504l-77.12 85.12a357.12 357.12 0 0 1 0 49.024l77.12 85.248a32 32 0 0 1 4.032 37.504l-88.704 153.6a32 32 0 0 1-34.432 15.296L708.8 803.904c-13.44 9.088-27.648 17.28-42.368 24.512l-35.264 109.376A32 32 0 0 1 600.704 960H423.296a32 32 0 0 1-30.464-22.208L357.696 828.48a351.616 351.616 0 0 1-42.56-24.64l-112.32 24.256a32 32 0 0 1-34.432-15.36L79.68 659.2a32 32 0 0 1 4.032-37.504l77.12-85.248a357.12 357.12 0 0 1 0-48.896l-77.12-85.248A32 32 0 0 1 79.68 364.8l88.704-153.6a32 32 0 0 1 34.432-15.296l112.32 24.256c13.568-9.152 27.776-17.408 42.56-24.64l35.2-109.312A32 32 0 0 1 423.232 64H600.64zm-23.424 64H446.72l-36.352 113.088-24.512 11.968a294.113 294.113 0 0 0-34.816 20.096l-22.656 15.36-116.224-25.088-65.28 113.152 79.68 88.192-1.92 27.136a293.12 293.12 0 0 0 0 40.192l1.92 27.136-79.808 88.192 65.344 113.152 116.224-25.024 22.656 15.296a294.113 294.113 0 0 0 34.816 20.096l24.512 11.968L446.72 896h130.688l36.48-113.152 24.448-11.904a288.282 288.282 0 0 0 34.752-20.096l22.592-15.296 116.288 25.024 65.28-113.152-79.744-88.192 1.92-27.136a293.12 293.12 0 0 0 0-40.256l-1.92-27.136 79.808-88.128-65.344-113.152-116.288 24.96-22.592-15.232a287.616 287.616 0 0 0-34.752-20.096l-24.448-11.904L577.344 128zM512 320a192 192 0 1 1 0 384 192 192 0 0 1 0-384zm0 64a128 128 0 1 0 0 256 128 128 0 0 0 0-256z"
- },
- null,
- -1
- ), _hoisted_3230 = [
- _hoisted_2231
- ];
- function _sfc_render231(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_1231, _hoisted_3230);
- }
- var setting_default = /* @__PURE__ */ export_helper_default(setting_vue_vue_type_script_lang_default, [["render", _sfc_render231], ["__file", "setting.vue"]]);
- var view_vue_vue_type_script_lang_default = {
- name: "View"
- };
- var _hoisted_1283 = {
- xmlns: "http://www.w3.org/2000/svg",
- viewBox: "0 0 1024 1024"
- }, _hoisted_2283 = /* @__PURE__ */ createElementVNode(
- "path",
- {
- fill: "currentColor",
- d: "M512 160c320 0 512 352 512 352S832 864 512 864 0 512 0 512s192-352 512-352zm0 64c-225.28 0-384.128 208.064-436.8 288 52.608 79.872 211.456 288 436.8 288 225.28 0 384.128-208.064 436.8-288-52.608-79.872-211.456-288-436.8-288zm0 64a224 224 0 1 1 0 448 224 224 0 0 1 0-448zm0 64a160.192 160.192 0 0 0-160 160c0 88.192 71.744 160 160 160s160-71.808 160-160-71.744-160-160-160z"
- },
- null,
- -1
- ), _hoisted_3282 = [
- _hoisted_2283
- ];
- function _sfc_render283(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("svg", _hoisted_1283, _hoisted_3282);
- }
- var view_default = /* @__PURE__ */ export_helper_default(view_vue_vue_type_script_lang_default, [["render", _sfc_render283], ["__file", "view.vue"]]);
- const epPropKey = "__epPropKey";
- const definePropType = (val) => val;
- const isEpProp = (val) => isObject$5(val) && !!val[epPropKey];
- const buildProp = (prop, key) => {
- if (!isObject$5(prop) || isEpProp(prop))
- return prop;
- const { values: values3, required, default: defaultValue2, type: type2, validator } = prop;
- const _validator = values3 || validator ? (val) => {
- let valid = false;
- let allowedValues = [];
- if (values3) {
- allowedValues = Array.from(values3);
- if (hasOwn(prop, "default")) {
- allowedValues.push(defaultValue2);
- }
- valid || (valid = allowedValues.includes(val));
- }
- if (validator)
- valid || (valid = validator(val));
- if (!valid && allowedValues.length > 0) {
- const allowValuesText = [...new Set(allowedValues)].map((value) => JSON.stringify(value)).join(", ");
- warn(`Invalid prop: validation failed${key ? ` for prop "${key}"` : ""}. Expected one of [${allowValuesText}], got value ${JSON.stringify(val)}.`);
- }
- return valid;
- } : void 0;
- const epProp = {
- type: type2,
- required: !!required,
- validator: _validator,
- [epPropKey]: true
- };
- if (hasOwn(prop, "default"))
- epProp.default = defaultValue2;
- return epProp;
- };
- const buildProps = (props) => fromPairs(Object.entries(props).map(([key, option]) => [
- key,
- buildProp(option, key)
- ]));
- const iconPropType = definePropType([
- String,
- Object,
- Function
- ]);
- const CloseComponents = {
- Close: close_default
- };
- const ValidateComponentsMap = {
- validating: loading_default,
- success: circle_check_default,
- error: circle_close_default
- };
- const withInstall = (main, extra) => {
- main.install = (app) => {
- for (const comp of [main, ...Object.values(extra != null ? extra : {})]) {
- app.component(comp.name, comp);
- }
- };
- if (extra) {
- for (const [key, comp] of Object.entries(extra)) {
- main[key] = comp;
- }
- }
- return main;
- };
- const withNoopInstall = (component) => {
- component.install = NOOP;
- return component;
- };
- const composeRefs = (...refs) => {
- return (el) => {
- refs.forEach((ref2) => {
- if (isFunction$3(ref2)) {
- ref2(el);
- } else {
- ref2.value = el;
- }
- });
- };
- };
- const EVENT_CODE = {
- tab: "Tab",
- enter: "Enter",
- space: "Space",
- left: "ArrowLeft",
- up: "ArrowUp",
- right: "ArrowRight",
- down: "ArrowDown",
- esc: "Escape",
- delete: "Delete",
- backspace: "Backspace",
- numpadEnter: "NumpadEnter",
- pageUp: "PageUp",
- pageDown: "PageDown",
- home: "Home",
- end: "End"
- };
- const UPDATE_MODEL_EVENT = "update:modelValue";
- const CHANGE_EVENT = "change";
- const INPUT_EVENT = "input";
- const componentSizes = ["", "default", "small", "large"];
- const componentSizeMap = {
- large: 40,
- default: 32,
- small: 24
- };
- const getComponentSize = (size) => {
- return componentSizeMap[size || "default"];
- };
- const isValidComponentSize = (val) => ["", ...componentSizes].includes(val);
- var PatchFlags = /* @__PURE__ */ ((PatchFlags2) => {
- PatchFlags2[PatchFlags2["TEXT"] = 1] = "TEXT";
- PatchFlags2[PatchFlags2["CLASS"] = 2] = "CLASS";
- PatchFlags2[PatchFlags2["STYLE"] = 4] = "STYLE";
- PatchFlags2[PatchFlags2["PROPS"] = 8] = "PROPS";
- PatchFlags2[PatchFlags2["FULL_PROPS"] = 16] = "FULL_PROPS";
- PatchFlags2[PatchFlags2["HYDRATE_EVENTS"] = 32] = "HYDRATE_EVENTS";
- PatchFlags2[PatchFlags2["STABLE_FRAGMENT"] = 64] = "STABLE_FRAGMENT";
- PatchFlags2[PatchFlags2["KEYED_FRAGMENT"] = 128] = "KEYED_FRAGMENT";
- PatchFlags2[PatchFlags2["UNKEYED_FRAGMENT"] = 256] = "UNKEYED_FRAGMENT";
- PatchFlags2[PatchFlags2["NEED_PATCH"] = 512] = "NEED_PATCH";
- PatchFlags2[PatchFlags2["DYNAMIC_SLOTS"] = 1024] = "DYNAMIC_SLOTS";
- PatchFlags2[PatchFlags2["HOISTED"] = -1] = "HOISTED";
- PatchFlags2[PatchFlags2["BAIL"] = -2] = "BAIL";
- return PatchFlags2;
- })(PatchFlags || {});
- const isKorean = (text) => /([\uAC00-\uD7AF\u3130-\u318F])+/gi.test(text);
- const generateId = () => Math.floor(Math.random() * 1e4);
- const mutable = (val) => val;
- const DEFAULT_EXCLUDE_KEYS = ["class", "style"];
- const LISTENER_PREFIX = /^on[A-Z]/;
- const useAttrs = (params = {}) => {
- const { excludeListeners = false, excludeKeys } = params;
- const allExcludeKeys = computed$1(() => {
- return ((excludeKeys == null ? void 0 : excludeKeys.value) || []).concat(DEFAULT_EXCLUDE_KEYS);
- });
- const instance = getCurrentInstance();
- if (!instance) {
- return computed$1(() => ({}));
- }
- return computed$1(() => {
- var _a2;
- return fromPairs(Object.entries((_a2 = instance.proxy) == null ? void 0 : _a2.$attrs).filter(([key]) => !allExcludeKeys.value.includes(key) && !(excludeListeners && LISTENER_PREFIX.test(key))));
- });
- };
- const useDeprecated = ({ from: from3, replacement, scope, version: version2, ref: ref2, type: type2 = "API" }, condition) => {
- watch(() => unref(condition), (val) => {
- }, {
- immediate: true
- });
- };
- const useDraggable = (targetRef, dragRef, draggable2) => {
- let transform3 = {
- offsetX: 0,
- offsetY: 0
- };
- const onMousedown = (e) => {
- const downX = e.clientX;
- const downY = e.clientY;
- const { offsetX, offsetY } = transform3;
- const targetRect = targetRef.value.getBoundingClientRect();
- const targetLeft = targetRect.left;
- const targetTop = targetRect.top;
- const targetWidth = targetRect.width;
- const targetHeight = targetRect.height;
- const clientWidth = document.documentElement.clientWidth;
- const clientHeight = document.documentElement.clientHeight;
- const minLeft = -targetLeft + offsetX;
- const minTop = -targetTop + offsetY;
- const maxLeft = clientWidth - targetLeft - targetWidth + offsetX;
- const maxTop = clientHeight - targetTop - targetHeight + offsetY;
- const onMousemove = (e2) => {
- const moveX = Math.min(Math.max(offsetX + e2.clientX - downX, minLeft), maxLeft);
- const moveY = Math.min(Math.max(offsetY + e2.clientY - downY, minTop), maxTop);
- transform3 = {
- offsetX: moveX,
- offsetY: moveY
- };
- targetRef.value.style.transform = `translate(${addUnit(moveX)}, ${addUnit(moveY)})`;
- };
- const onMouseup = () => {
- document.removeEventListener("mousemove", onMousemove);
- document.removeEventListener("mouseup", onMouseup);
- };
- document.addEventListener("mousemove", onMousemove);
- document.addEventListener("mouseup", onMouseup);
- };
- const onDraggable = () => {
- if (dragRef.value && targetRef.value) {
- dragRef.value.addEventListener("mousedown", onMousedown);
- }
- };
- const offDraggable = () => {
- if (dragRef.value && targetRef.value) {
- dragRef.value.removeEventListener("mousedown", onMousedown);
- }
- };
- onMounted(() => {
- watchEffect(() => {
- if (draggable2.value) {
- onDraggable();
- } else {
- offDraggable();
- }
- });
- });
- onBeforeUnmount(() => {
- offDraggable();
- });
- };
- const useFocus = (el) => {
- return {
- focus: () => {
- var _a2, _b;
- (_b = (_a2 = el.value) == null ? void 0 : _a2.focus) == null ? void 0 : _b.call(_a2);
- }
- };
- };
- var English = {
- name: "en",
- el: {
- colorpicker: {
- confirm: "OK",
- clear: "Clear",
- defaultLabel: "color picker",
- description: "current color is {color}. press enter to select a new color."
- },
- datepicker: {
- now: "Now",
- today: "Today",
- cancel: "Cancel",
- clear: "Clear",
- confirm: "OK",
- dateTablePrompt: "Use the arrow keys and enter to select the day of the month",
- monthTablePrompt: "Use the arrow keys and enter to select the month",
- yearTablePrompt: "Use the arrow keys and enter to select the year",
- selectedDate: "Selected date",
- selectDate: "Select date",
- selectTime: "Select time",
- startDate: "Start Date",
- startTime: "Start Time",
- endDate: "End Date",
- endTime: "End Time",
- prevYear: "Previous Year",
- nextYear: "Next Year",
- prevMonth: "Previous Month",
- nextMonth: "Next Month",
- year: "",
- month1: "January",
- month2: "February",
- month3: "March",
- month4: "April",
- month5: "May",
- month6: "June",
- month7: "July",
- month8: "August",
- month9: "September",
- month10: "October",
- month11: "November",
- month12: "December",
- week: "week",
- weeks: {
- sun: "Sun",
- mon: "Mon",
- tue: "Tue",
- wed: "Wed",
- thu: "Thu",
- fri: "Fri",
- sat: "Sat"
- },
- weeksFull: {
- sun: "Sunday",
- mon: "Monday",
- tue: "Tuesday",
- wed: "Wednesday",
- thu: "Thursday",
- fri: "Friday",
- sat: "Saturday"
- },
- months: {
- jan: "Jan",
- feb: "Feb",
- mar: "Mar",
- apr: "Apr",
- may: "May",
- jun: "Jun",
- jul: "Jul",
- aug: "Aug",
- sep: "Sep",
- oct: "Oct",
- nov: "Nov",
- dec: "Dec"
- }
- },
- inputNumber: {
- decrease: "decrease number",
- increase: "increase number"
- },
- select: {
- loading: "Loading",
- noMatch: "No matching data",
- noData: "No data",
- placeholder: "Select"
- },
- dropdown: {
- toggleDropdown: "Toggle Dropdown"
- },
- cascader: {
- noMatch: "No matching data",
- loading: "Loading",
- placeholder: "Select",
- noData: "No data"
- },
- pagination: {
- goto: "Go to",
- pagesize: "/page",
- total: "Total {total}",
- pageClassifier: "",
- page: "Page",
- prev: "Go to previous page",
- next: "Go to next page",
- currentPage: "page {pager}",
- prevPages: "Previous {pager} pages",
- nextPages: "Next {pager} pages",
- deprecationWarning: "Deprecated usages detected, please refer to the el-pagination documentation for more details"
- },
- dialog: {
- close: "Close this dialog"
- },
- drawer: {
- close: "Close this dialog"
- },
- messagebox: {
- title: "Message",
- confirm: "OK",
- cancel: "Cancel",
- error: "Illegal input",
- close: "Close this dialog"
- },
- upload: {
- deleteTip: "press delete to remove",
- delete: "Delete",
- preview: "Preview",
- continue: "Continue"
- },
- slider: {
- defaultLabel: "slider between {min} and {max}",
- defaultRangeStartLabel: "pick start value",
- defaultRangeEndLabel: "pick end value"
- },
- table: {
- emptyText: "No Data",
- confirmFilter: "Confirm",
- resetFilter: "Reset",
- clearFilter: "All",
- sumText: "Sum"
- },
- tree: {
- emptyText: "No Data"
- },
- transfer: {
- noMatch: "No matching data",
- noData: "No data",
- titles: ["List 1", "List 2"],
- filterPlaceholder: "Enter keyword",
- noCheckedFormat: "{total} items",
- hasCheckedFormat: "{checked}/{total} checked"
- },
- image: {
- error: "FAILED"
- },
- pageHeader: {
- title: "Back"
- },
- popconfirm: {
- confirmButtonText: "Yes",
- cancelButtonText: "No"
- }
- }
- };
- const buildTranslator = (locale) => (path, option) => translate(path, option, unref(locale));
- const translate = (path, option, locale) => get$2(locale, path, path).replace(/\{(\w+)\}/g, (_, key) => {
- var _a2;
- return `${(_a2 = option == null ? void 0 : option[key]) != null ? _a2 : `{${key}}`}`;
- });
- const buildLocaleContext = (locale) => {
- const lang = computed$1(() => unref(locale).name);
- const localeRef = isRef(locale) ? locale : ref(locale);
- return {
- lang,
- locale: localeRef,
- t: buildTranslator(locale)
- };
- };
- const localeContextKey = Symbol("localeContextKey");
- const useLocale = (localeOverrides) => {
- const locale = localeOverrides || inject(localeContextKey, ref());
- return buildLocaleContext(computed$1(() => locale.value || English));
- };
- let activeEffectScope;
- function recordEffectScope(effect, scope = activeEffectScope) {
- if (scope && scope.active) {
- scope.effects.push(effect);
- }
- }
- const createDep = (effects) => {
- const dep = new Set(effects);
- dep.w = 0;
- dep.n = 0;
- return dep;
- };
- const wasTracked = (dep) => (dep.w & trackOpBit) > 0;
- const newTracked = (dep) => (dep.n & trackOpBit) > 0;
- const initDepMarkers = ({ deps }) => {
- if (deps.length) {
- for (let i2 = 0; i2 < deps.length; i2++) {
- deps[i2].w |= trackOpBit;
- }
- }
- };
- const finalizeDepMarkers = (effect) => {
- const { deps } = effect;
- if (deps.length) {
- let ptr = 0;
- for (let i2 = 0; i2 < deps.length; i2++) {
- const dep = deps[i2];
- if (wasTracked(dep) && !newTracked(dep)) {
- dep.delete(effect);
- } else {
- deps[ptr++] = dep;
- }
- dep.w &= ~trackOpBit;
- dep.n &= ~trackOpBit;
- }
- deps.length = ptr;
- }
- };
- let effectTrackDepth = 0;
- let trackOpBit = 1;
- const maxMarkerBits = 30;
- let activeEffect;
- class ReactiveEffect {
- constructor(fn2, scheduler = null, scope) {
- this.fn = fn2;
- this.scheduler = scheduler;
- this.active = true;
- this.deps = [];
- this.parent = void 0;
- recordEffectScope(this, scope);
- }
- run() {
- if (!this.active) {
- return this.fn();
- }
- let parent = activeEffect;
- let lastShouldTrack = shouldTrack;
- while (parent) {
- if (parent === this) {
- return;
- }
- parent = parent.parent;
- }
- try {
- this.parent = activeEffect;
- activeEffect = this;
- shouldTrack = true;
- trackOpBit = 1 << ++effectTrackDepth;
- if (effectTrackDepth <= maxMarkerBits) {
- initDepMarkers(this);
- } else {
- cleanupEffect(this);
- }
- return this.fn();
- } finally {
- if (effectTrackDepth <= maxMarkerBits) {
- finalizeDepMarkers(this);
- }
- trackOpBit = 1 << --effectTrackDepth;
- activeEffect = this.parent;
- shouldTrack = lastShouldTrack;
- this.parent = void 0;
- if (this.deferStop) {
- this.stop();
- }
- }
- }
- stop() {
- if (activeEffect === this) {
- this.deferStop = true;
- } else if (this.active) {
- cleanupEffect(this);
- if (this.onStop) {
- this.onStop();
- }
- this.active = false;
- }
- }
- }
- function cleanupEffect(effect2) {
- const { deps } = effect2;
- if (deps.length) {
- for (let i2 = 0; i2 < deps.length; i2++) {
- deps[i2].delete(effect2);
- }
- deps.length = 0;
- }
- }
- let shouldTrack = true;
- function trackEffects(dep, debuggerEventExtraInfo) {
- let shouldTrack2 = false;
- if (effectTrackDepth <= maxMarkerBits) {
- if (!newTracked(dep)) {
- dep.n |= trackOpBit;
- shouldTrack2 = !wasTracked(dep);
- }
- } else {
- shouldTrack2 = !dep.has(activeEffect);
- }
- if (shouldTrack2) {
- dep.add(activeEffect);
- activeEffect.deps.push(dep);
- }
- }
- function triggerEffects(dep, debuggerEventExtraInfo) {
- const effects = isArray$2(dep) ? dep : [...dep];
- for (const effect2 of effects) {
- if (effect2.computed) {
- triggerEffect(effect2);
- }
- }
- for (const effect2 of effects) {
- if (!effect2.computed) {
- triggerEffect(effect2);
- }
- }
- }
- function triggerEffect(effect2, debuggerEventExtraInfo) {
- if (effect2 !== activeEffect || effect2.allowRecurse) {
- if (effect2.scheduler) {
- effect2.scheduler();
- } else {
- effect2.run();
- }
- }
- }
- function toRaw(observed) {
- const raw = observed && observed["__v_raw"];
- return raw ? toRaw(raw) : observed;
- }
- function trackRefValue(ref2) {
- if (shouldTrack && activeEffect) {
- ref2 = toRaw(ref2);
- {
- trackEffects(ref2.dep || (ref2.dep = createDep()));
- }
- }
- }
- function triggerRefValue(ref2, newVal) {
- ref2 = toRaw(ref2);
- const dep = ref2.dep;
- if (dep) {
- {
- triggerEffects(dep);
- }
- }
- }
- class ComputedRefImpl {
- constructor(getter, _setter, isReadonly, isSSR) {
- this._setter = _setter;
- this.dep = void 0;
- this.__v_isRef = true;
- this["__v_isReadonly"] = false;
- this._dirty = true;
- this.effect = new ReactiveEffect(getter, () => {
- if (!this._dirty) {
- this._dirty = true;
- triggerRefValue(this);
- }
- });
- this.effect.computed = this;
- this.effect.active = this._cacheable = !isSSR;
- this["__v_isReadonly"] = isReadonly;
- }
- get value() {
- const self2 = toRaw(this);
- trackRefValue(self2);
- if (self2._dirty || !self2._cacheable) {
- self2._dirty = false;
- self2._value = self2.effect.run();
- }
- return self2._value;
- }
- set value(newValue) {
- this._setter(newValue);
- }
- }
- function computed(getterOrOptions, debugOptions, isSSR = false) {
- let getter;
- let setter;
- const onlyGetter = isFunction$3(getterOrOptions);
- if (onlyGetter) {
- getter = getterOrOptions;
- setter = NOOP;
- } else {
- getter = getterOrOptions.get;
- setter = getterOrOptions.set;
- }
- const cRef = new ComputedRefImpl(getter, setter, onlyGetter || !setter, isSSR);
- return cRef;
- }
- const defaultNamespace = "el";
- const statePrefix = "is-";
- const _bem = (namespace, block, blockSuffix, element, modifier) => {
- let cls = `${namespace}-${block}`;
- if (blockSuffix) {
- cls += `-${blockSuffix}`;
- }
- if (element) {
- cls += `__${element}`;
- }
- if (modifier) {
- cls += `--${modifier}`;
- }
- return cls;
- };
- const namespaceContextKey = Symbol("namespaceContextKey");
- const useGetDerivedNamespace = (namespaceOverrides) => {
- const derivedNamespace = namespaceOverrides || inject(namespaceContextKey, ref(defaultNamespace));
- const namespace = computed$1(() => {
- return unref(derivedNamespace) || defaultNamespace;
- });
- return namespace;
- };
- const useNamespace = (block, namespaceOverrides) => {
- const namespace = useGetDerivedNamespace(namespaceOverrides);
- const b = (blockSuffix = "") => _bem(namespace.value, block, blockSuffix, "", "");
- const e = (element) => element ? _bem(namespace.value, block, "", element, "") : "";
- const m = (modifier) => modifier ? _bem(namespace.value, block, "", "", modifier) : "";
- const be2 = (blockSuffix, element) => blockSuffix && element ? _bem(namespace.value, block, blockSuffix, element, "") : "";
- const em = (element, modifier) => element && modifier ? _bem(namespace.value, block, "", element, modifier) : "";
- const bm = (blockSuffix, modifier) => blockSuffix && modifier ? _bem(namespace.value, block, blockSuffix, "", modifier) : "";
- const bem = (blockSuffix, element, modifier) => blockSuffix && element && modifier ? _bem(namespace.value, block, blockSuffix, element, modifier) : "";
- const is = (name, ...args) => {
- const state = args.length >= 1 ? args[0] : true;
- return name && state ? `${statePrefix}${name}` : "";
- };
- const cssVar = (object) => {
- const styles = {};
- for (const key in object) {
- if (object[key]) {
- styles[`--${namespace.value}-${key}`] = object[key];
- }
- }
- return styles;
- };
- const cssVarBlock = (object) => {
- const styles = {};
- for (const key in object) {
- if (object[key]) {
- styles[`--${namespace.value}-${block}-${key}`] = object[key];
- }
- }
- return styles;
- };
- const cssVarName = (name) => `--${namespace.value}-${name}`;
- const cssVarBlockName = (name) => `--${namespace.value}-${block}-${name}`;
- return {
- namespace,
- b,
- e,
- m,
- be: be2,
- em,
- bm,
- bem,
- is,
- cssVar,
- cssVarName,
- cssVarBlock,
- cssVarBlockName
- };
- };
- const useLockscreen = (trigger2, options2 = {}) => {
- if (!isRef(trigger2)) {
- throwError("[useLockscreen]", "You need to pass a ref param to this function");
- }
- const ns = options2.ns || useNamespace("popup");
- const hiddenCls = computed(() => ns.bm("parent", "hidden"));
- if (!isClient || hasClass$2(document.body, hiddenCls.value)) {
- return;
- }
- let scrollBarWidth2 = 0;
- let withoutHiddenClass = false;
- let bodyWidth = "0";
- const cleanup = () => {
- setTimeout(() => {
- removeClass$2(document == null ? void 0 : document.body, hiddenCls.value);
- if (withoutHiddenClass && document) {
- document.body.style.width = bodyWidth;
- }
- }, 200);
- };
- watch(trigger2, (val) => {
- if (!val) {
- cleanup();
- return;
- }
- withoutHiddenClass = !hasClass$2(document.body, hiddenCls.value);
- if (withoutHiddenClass) {
- bodyWidth = document.body.style.width;
- }
- scrollBarWidth2 = getScrollBarWidth(ns.namespace.value);
- const bodyHasOverflow = document.documentElement.clientHeight < document.body.scrollHeight;
- const bodyOverflowY = getStyle(document.body, "overflowY");
- if (scrollBarWidth2 > 0 && (bodyHasOverflow || bodyOverflowY === "scroll") && withoutHiddenClass) {
- document.body.style.width = `calc(100% - ${scrollBarWidth2}px)`;
- }
- addClass$2(document.body, hiddenCls.value);
- });
- onScopeDispose(() => cleanup());
- };
- const _prop = buildProp({
- type: definePropType(Boolean),
- default: null
- });
- const _event = buildProp({
- type: definePropType(Function)
- });
- const createModelToggleComposable = (name) => {
- const updateEventKey = `update:${name}`;
- const updateEventKeyRaw = `onUpdate:${name}`;
- const useModelToggleEmits2 = [updateEventKey];
- const useModelToggleProps2 = {
- [name]: _prop,
- [updateEventKeyRaw]: _event
- };
- const useModelToggle2 = ({
- indicator,
- toggleReason,
- shouldHideWhenRouteChanges,
- shouldProceed,
- onShow,
- onHide
- }) => {
- const instance = getCurrentInstance();
- const { emit } = instance;
- const props = instance.props;
- const hasUpdateHandler = computed$1(() => isFunction$3(props[updateEventKeyRaw]));
- const isModelBindingAbsent = computed$1(() => props[name] === null);
- const doShow = (event2) => {
- if (indicator.value === true) {
- return;
- }
- indicator.value = true;
- if (toggleReason) {
- toggleReason.value = event2;
- }
- if (isFunction$3(onShow)) {
- onShow(event2);
- }
- };
- const doHide = (event2) => {
- if (indicator.value === false) {
- return;
- }
- indicator.value = false;
- if (toggleReason) {
- toggleReason.value = event2;
- }
- if (isFunction$3(onHide)) {
- onHide(event2);
- }
- };
- const show = (event2) => {
- if (props.disabled === true || isFunction$3(shouldProceed) && !shouldProceed())
- return;
- const shouldEmit = hasUpdateHandler.value && isClient;
- if (shouldEmit) {
- emit(updateEventKey, true);
- }
- if (isModelBindingAbsent.value || !shouldEmit) {
- doShow(event2);
- }
- };
- const hide = (event2) => {
- if (props.disabled === true || !isClient)
- return;
- const shouldEmit = hasUpdateHandler.value && isClient;
- if (shouldEmit) {
- emit(updateEventKey, false);
- }
- if (isModelBindingAbsent.value || !shouldEmit) {
- doHide(event2);
- }
- };
- const onChange = (val) => {
- if (!isBoolean(val))
- return;
- if (props.disabled && val) {
- if (hasUpdateHandler.value) {
- emit(updateEventKey, false);
- }
- } else if (indicator.value !== val) {
- if (val) {
- doShow();
- } else {
- doHide();
- }
- }
- };
- const toggle = () => {
- if (indicator.value) {
- hide();
- } else {
- show();
- }
- };
- watch(() => props[name], onChange);
- if (shouldHideWhenRouteChanges && instance.appContext.config.globalProperties.$route !== void 0) {
- watch(() => ({
- ...instance.proxy.$route
- }), () => {
- if (shouldHideWhenRouteChanges.value && indicator.value) {
- hide();
- }
- });
- }
- onMounted(() => {
- onChange(props[name]);
- });
- return {
- hide,
- show,
- toggle,
- hasUpdateHandler
- };
- };
- return {
- useModelToggle: useModelToggle2,
- useModelToggleProps: useModelToggleProps2,
- useModelToggleEmits: useModelToggleEmits2
- };
- };
- const useProp = (name) => {
- const vm = getCurrentInstance();
- return computed$1(() => {
- var _a2, _b;
- return (_b = (_a2 = vm == null ? void 0 : vm.proxy) == null ? void 0 : _a2.$props) == null ? void 0 : _b[name];
- });
- };
- var E = "top", R = "bottom", W = "right", P = "left", me = "auto", G = [E, R, W, P], U = "start", J = "end", Xe = "clippingParents", je = "viewport", K = "popper", Ye = "reference", De = G.reduce(function(t2, e) {
- return t2.concat([e + "-" + U, e + "-" + J]);
- }, []), Ee = [].concat(G, [me]).reduce(function(t2, e) {
- return t2.concat([e, e + "-" + U, e + "-" + J]);
- }, []), Ge = "beforeRead", Je = "read", Ke = "afterRead", Qe = "beforeMain", Ze = "main", et = "afterMain", tt = "beforeWrite", nt = "write", rt = "afterWrite", ot = [Ge, Je, Ke, Qe, Ze, et, tt, nt, rt];
- function C(t2) {
- return t2 ? (t2.nodeName || "").toLowerCase() : null;
- }
- function H(t2) {
- if (t2 == null)
- return window;
- if (t2.toString() !== "[object Window]") {
- var e = t2.ownerDocument;
- return e && e.defaultView || window;
- }
- return t2;
- }
- function Q(t2) {
- var e = H(t2).Element;
- return t2 instanceof e || t2 instanceof Element;
- }
- function B(t2) {
- var e = H(t2).HTMLElement;
- return t2 instanceof e || t2 instanceof HTMLElement;
- }
- function Pe(t2) {
- if (typeof ShadowRoot == "undefined")
- return false;
- var e = H(t2).ShadowRoot;
- return t2 instanceof e || t2 instanceof ShadowRoot;
- }
- function Mt(t2) {
- var e = t2.state;
- Object.keys(e.elements).forEach(function(n) {
- var r2 = e.styles[n] || {}, o = e.attributes[n] || {}, i2 = e.elements[n];
- !B(i2) || !C(i2) || (Object.assign(i2.style, r2), Object.keys(o).forEach(function(a) {
- var s = o[a];
- s === false ? i2.removeAttribute(a) : i2.setAttribute(a, s === true ? "" : s);
- }));
- });
- }
- function Rt(t2) {
- var e = t2.state, n = { popper: { position: e.options.strategy, left: "0", top: "0", margin: "0" }, arrow: { position: "absolute" }, reference: {} };
- return Object.assign(e.elements.popper.style, n.popper), e.styles = n, e.elements.arrow && Object.assign(e.elements.arrow.style, n.arrow), function() {
- Object.keys(e.elements).forEach(function(r2) {
- var o = e.elements[r2], i2 = e.attributes[r2] || {}, a = Object.keys(e.styles.hasOwnProperty(r2) ? e.styles[r2] : n[r2]), s = a.reduce(function(f, c) {
- return f[c] = "", f;
- }, {});
- !B(o) || !C(o) || (Object.assign(o.style, s), Object.keys(i2).forEach(function(f) {
- o.removeAttribute(f);
- }));
- });
- };
- }
- var Ae = { name: "applyStyles", enabled: true, phase: "write", fn: Mt, effect: Rt, requires: ["computeStyles"] };
- function q(t2) {
- return t2.split("-")[0];
- }
- var X = Math.max, ve = Math.min, Z = Math.round;
- function ee(t2, e) {
- e === void 0 && (e = false);
- var n = t2.getBoundingClientRect(), r2 = 1, o = 1;
- if (B(t2) && e) {
- var i2 = t2.offsetHeight, a = t2.offsetWidth;
- a > 0 && (r2 = Z(n.width) / a || 1), i2 > 0 && (o = Z(n.height) / i2 || 1);
- }
- return { width: n.width / r2, height: n.height / o, top: n.top / o, right: n.right / r2, bottom: n.bottom / o, left: n.left / r2, x: n.left / r2, y: n.top / o };
- }
- function ke(t2) {
- var e = ee(t2), n = t2.offsetWidth, r2 = t2.offsetHeight;
- return Math.abs(e.width - n) <= 1 && (n = e.width), Math.abs(e.height - r2) <= 1 && (r2 = e.height), { x: t2.offsetLeft, y: t2.offsetTop, width: n, height: r2 };
- }
- function it(t2, e) {
- var n = e.getRootNode && e.getRootNode();
- if (t2.contains(e))
- return true;
- if (n && Pe(n)) {
- var r2 = e;
- do {
- if (r2 && t2.isSameNode(r2))
- return true;
- r2 = r2.parentNode || r2.host;
- } while (r2);
- }
- return false;
- }
- function N(t2) {
- return H(t2).getComputedStyle(t2);
- }
- function Wt(t2) {
- return ["table", "td", "th"].indexOf(C(t2)) >= 0;
- }
- function I(t2) {
- return ((Q(t2) ? t2.ownerDocument : t2.document) || window.document).documentElement;
- }
- function ge(t2) {
- return C(t2) === "html" ? t2 : t2.assignedSlot || t2.parentNode || (Pe(t2) ? t2.host : null) || I(t2);
- }
- function at(t2) {
- return !B(t2) || N(t2).position === "fixed" ? null : t2.offsetParent;
- }
- function Bt(t2) {
- var e = navigator.userAgent.toLowerCase().indexOf("firefox") !== -1, n = navigator.userAgent.indexOf("Trident") !== -1;
- if (n && B(t2)) {
- var r2 = N(t2);
- if (r2.position === "fixed")
- return null;
- }
- var o = ge(t2);
- for (Pe(o) && (o = o.host); B(o) && ["html", "body"].indexOf(C(o)) < 0; ) {
- var i2 = N(o);
- if (i2.transform !== "none" || i2.perspective !== "none" || i2.contain === "paint" || ["transform", "perspective"].indexOf(i2.willChange) !== -1 || e && i2.willChange === "filter" || e && i2.filter && i2.filter !== "none")
- return o;
- o = o.parentNode;
- }
- return null;
- }
- function se(t2) {
- for (var e = H(t2), n = at(t2); n && Wt(n) && N(n).position === "static"; )
- n = at(n);
- return n && (C(n) === "html" || C(n) === "body" && N(n).position === "static") ? e : n || Bt(t2) || e;
- }
- function Le(t2) {
- return ["top", "bottom"].indexOf(t2) >= 0 ? "x" : "y";
- }
- function fe(t2, e, n) {
- return X(t2, ve(e, n));
- }
- function St(t2, e, n) {
- var r2 = fe(t2, e, n);
- return r2 > n ? n : r2;
- }
- function st() {
- return { top: 0, right: 0, bottom: 0, left: 0 };
- }
- function ft(t2) {
- return Object.assign({}, st(), t2);
- }
- function ct(t2, e) {
- return e.reduce(function(n, r2) {
- return n[r2] = t2, n;
- }, {});
- }
- var Tt = function(t2, e) {
- return t2 = typeof t2 == "function" ? t2(Object.assign({}, e.rects, { placement: e.placement })) : t2, ft(typeof t2 != "number" ? t2 : ct(t2, G));
- };
- function Ht(t2) {
- var e, n = t2.state, r2 = t2.name, o = t2.options, i2 = n.elements.arrow, a = n.modifiersData.popperOffsets, s = q(n.placement), f = Le(s), c = [P, W].indexOf(s) >= 0, u = c ? "height" : "width";
- if (!(!i2 || !a)) {
- var m = Tt(o.padding, n), v = ke(i2), l = f === "y" ? E : P, h2 = f === "y" ? R : W, p = n.rects.reference[u] + n.rects.reference[f] - a[f] - n.rects.popper[u], g = a[f] - n.rects.reference[f], x = se(i2), y = x ? f === "y" ? x.clientHeight || 0 : x.clientWidth || 0 : 0, $2 = p / 2 - g / 2, d2 = m[l], b = y - v[u] - m[h2], w = y / 2 - v[u] / 2 + $2, O = fe(d2, w, b), j = f;
- n.modifiersData[r2] = (e = {}, e[j] = O, e.centerOffset = O - w, e);
- }
- }
- function Ct(t2) {
- var e = t2.state, n = t2.options, r2 = n.element, o = r2 === void 0 ? "[data-popper-arrow]" : r2;
- o != null && (typeof o == "string" && (o = e.elements.popper.querySelector(o), !o) || !it(e.elements.popper, o) || (e.elements.arrow = o));
- }
- var pt = { name: "arrow", enabled: true, phase: "main", fn: Ht, effect: Ct, requires: ["popperOffsets"], requiresIfExists: ["preventOverflow"] };
- function te(t2) {
- return t2.split("-")[1];
- }
- var qt = { top: "auto", right: "auto", bottom: "auto", left: "auto" };
- function Vt(t2) {
- var e = t2.x, n = t2.y, r2 = window, o = r2.devicePixelRatio || 1;
- return { x: Z(e * o) / o || 0, y: Z(n * o) / o || 0 };
- }
- function ut(t2) {
- var e, n = t2.popper, r2 = t2.popperRect, o = t2.placement, i2 = t2.variation, a = t2.offsets, s = t2.position, f = t2.gpuAcceleration, c = t2.adaptive, u = t2.roundOffsets, m = t2.isFixed, v = a.x, l = v === void 0 ? 0 : v, h2 = a.y, p = h2 === void 0 ? 0 : h2, g = typeof u == "function" ? u({ x: l, y: p }) : { x: l, y: p };
- l = g.x, p = g.y;
- var x = a.hasOwnProperty("x"), y = a.hasOwnProperty("y"), $2 = P, d2 = E, b = window;
- if (c) {
- var w = se(n), O = "clientHeight", j = "clientWidth";
- if (w === H(n) && (w = I(n), N(w).position !== "static" && s === "absolute" && (O = "scrollHeight", j = "scrollWidth")), w = w, o === E || (o === P || o === W) && i2 === J) {
- d2 = R;
- var A = m && w === b && b.visualViewport ? b.visualViewport.height : w[O];
- p -= A - r2.height, p *= f ? 1 : -1;
- }
- if (o === P || (o === E || o === R) && i2 === J) {
- $2 = W;
- var k = m && w === b && b.visualViewport ? b.visualViewport.width : w[j];
- l -= k - r2.width, l *= f ? 1 : -1;
- }
- }
- var D = Object.assign({ position: s }, c && qt), S = u === true ? Vt({ x: l, y: p }) : { x: l, y: p };
- if (l = S.x, p = S.y, f) {
- var L;
- return Object.assign({}, D, (L = {}, L[d2] = y ? "0" : "", L[$2] = x ? "0" : "", L.transform = (b.devicePixelRatio || 1) <= 1 ? "translate(" + l + "px, " + p + "px)" : "translate3d(" + l + "px, " + p + "px, 0)", L));
- }
- return Object.assign({}, D, (e = {}, e[d2] = y ? p + "px" : "", e[$2] = x ? l + "px" : "", e.transform = "", e));
- }
- function Nt(t2) {
- var e = t2.state, n = t2.options, r2 = n.gpuAcceleration, o = r2 === void 0 ? true : r2, i2 = n.adaptive, a = i2 === void 0 ? true : i2, s = n.roundOffsets, f = s === void 0 ? true : s, c = { placement: q(e.placement), variation: te(e.placement), popper: e.elements.popper, popperRect: e.rects.popper, gpuAcceleration: o, isFixed: e.options.strategy === "fixed" };
- e.modifiersData.popperOffsets != null && (e.styles.popper = Object.assign({}, e.styles.popper, ut(Object.assign({}, c, { offsets: e.modifiersData.popperOffsets, position: e.options.strategy, adaptive: a, roundOffsets: f })))), e.modifiersData.arrow != null && (e.styles.arrow = Object.assign({}, e.styles.arrow, ut(Object.assign({}, c, { offsets: e.modifiersData.arrow, position: "absolute", adaptive: false, roundOffsets: f })))), e.attributes.popper = Object.assign({}, e.attributes.popper, { "data-popper-placement": e.placement });
- }
- var Me = { name: "computeStyles", enabled: true, phase: "beforeWrite", fn: Nt, data: {} }, ye = { passive: true };
- function It(t2) {
- var e = t2.state, n = t2.instance, r2 = t2.options, o = r2.scroll, i2 = o === void 0 ? true : o, a = r2.resize, s = a === void 0 ? true : a, f = H(e.elements.popper), c = [].concat(e.scrollParents.reference, e.scrollParents.popper);
- return i2 && c.forEach(function(u) {
- u.addEventListener("scroll", n.update, ye);
- }), s && f.addEventListener("resize", n.update, ye), function() {
- i2 && c.forEach(function(u) {
- u.removeEventListener("scroll", n.update, ye);
- }), s && f.removeEventListener("resize", n.update, ye);
- };
- }
- var Re = { name: "eventListeners", enabled: true, phase: "write", fn: function() {
- }, effect: It, data: {} }, _t = { left: "right", right: "left", bottom: "top", top: "bottom" };
- function be(t2) {
- return t2.replace(/left|right|bottom|top/g, function(e) {
- return _t[e];
- });
- }
- var zt = { start: "end", end: "start" };
- function lt(t2) {
- return t2.replace(/start|end/g, function(e) {
- return zt[e];
- });
- }
- function We(t2) {
- var e = H(t2), n = e.pageXOffset, r2 = e.pageYOffset;
- return { scrollLeft: n, scrollTop: r2 };
- }
- function Be(t2) {
- return ee(I(t2)).left + We(t2).scrollLeft;
- }
- function Ft(t2) {
- var e = H(t2), n = I(t2), r2 = e.visualViewport, o = n.clientWidth, i2 = n.clientHeight, a = 0, s = 0;
- return r2 && (o = r2.width, i2 = r2.height, /^((?!chrome|android).)*safari/i.test(navigator.userAgent) || (a = r2.offsetLeft, s = r2.offsetTop)), { width: o, height: i2, x: a + Be(t2), y: s };
- }
- function Ut(t2) {
- var e, n = I(t2), r2 = We(t2), o = (e = t2.ownerDocument) == null ? void 0 : e.body, i2 = X(n.scrollWidth, n.clientWidth, o ? o.scrollWidth : 0, o ? o.clientWidth : 0), a = X(n.scrollHeight, n.clientHeight, o ? o.scrollHeight : 0, o ? o.clientHeight : 0), s = -r2.scrollLeft + Be(t2), f = -r2.scrollTop;
- return N(o || n).direction === "rtl" && (s += X(n.clientWidth, o ? o.clientWidth : 0) - i2), { width: i2, height: a, x: s, y: f };
- }
- function Se(t2) {
- var e = N(t2), n = e.overflow, r2 = e.overflowX, o = e.overflowY;
- return /auto|scroll|overlay|hidden/.test(n + o + r2);
- }
- function dt(t2) {
- return ["html", "body", "#document"].indexOf(C(t2)) >= 0 ? t2.ownerDocument.body : B(t2) && Se(t2) ? t2 : dt(ge(t2));
- }
- function ce(t2, e) {
- var n;
- e === void 0 && (e = []);
- var r2 = dt(t2), o = r2 === ((n = t2.ownerDocument) == null ? void 0 : n.body), i2 = H(r2), a = o ? [i2].concat(i2.visualViewport || [], Se(r2) ? r2 : []) : r2, s = e.concat(a);
- return o ? s : s.concat(ce(ge(a)));
- }
- function Te(t2) {
- return Object.assign({}, t2, { left: t2.x, top: t2.y, right: t2.x + t2.width, bottom: t2.y + t2.height });
- }
- function Xt(t2) {
- var e = ee(t2);
- return e.top = e.top + t2.clientTop, e.left = e.left + t2.clientLeft, e.bottom = e.top + t2.clientHeight, e.right = e.left + t2.clientWidth, e.width = t2.clientWidth, e.height = t2.clientHeight, e.x = e.left, e.y = e.top, e;
- }
- function ht(t2, e) {
- return e === je ? Te(Ft(t2)) : Q(e) ? Xt(e) : Te(Ut(I(t2)));
- }
- function Yt(t2) {
- var e = ce(ge(t2)), n = ["absolute", "fixed"].indexOf(N(t2).position) >= 0, r2 = n && B(t2) ? se(t2) : t2;
- return Q(r2) ? e.filter(function(o) {
- return Q(o) && it(o, r2) && C(o) !== "body";
- }) : [];
- }
- function Gt(t2, e, n) {
- var r2 = e === "clippingParents" ? Yt(t2) : [].concat(e), o = [].concat(r2, [n]), i2 = o[0], a = o.reduce(function(s, f) {
- var c = ht(t2, f);
- return s.top = X(c.top, s.top), s.right = ve(c.right, s.right), s.bottom = ve(c.bottom, s.bottom), s.left = X(c.left, s.left), s;
- }, ht(t2, i2));
- return a.width = a.right - a.left, a.height = a.bottom - a.top, a.x = a.left, a.y = a.top, a;
- }
- function mt(t2) {
- var e = t2.reference, n = t2.element, r2 = t2.placement, o = r2 ? q(r2) : null, i2 = r2 ? te(r2) : null, a = e.x + e.width / 2 - n.width / 2, s = e.y + e.height / 2 - n.height / 2, f;
- switch (o) {
- case E:
- f = { x: a, y: e.y - n.height };
- break;
- case R:
- f = { x: a, y: e.y + e.height };
- break;
- case W:
- f = { x: e.x + e.width, y: s };
- break;
- case P:
- f = { x: e.x - n.width, y: s };
- break;
- default:
- f = { x: e.x, y: e.y };
- }
- var c = o ? Le(o) : null;
- if (c != null) {
- var u = c === "y" ? "height" : "width";
- switch (i2) {
- case U:
- f[c] = f[c] - (e[u] / 2 - n[u] / 2);
- break;
- case J:
- f[c] = f[c] + (e[u] / 2 - n[u] / 2);
- break;
- }
- }
- return f;
- }
- function ne(t2, e) {
- e === void 0 && (e = {});
- var n = e, r2 = n.placement, o = r2 === void 0 ? t2.placement : r2, i2 = n.boundary, a = i2 === void 0 ? Xe : i2, s = n.rootBoundary, f = s === void 0 ? je : s, c = n.elementContext, u = c === void 0 ? K : c, m = n.altBoundary, v = m === void 0 ? false : m, l = n.padding, h2 = l === void 0 ? 0 : l, p = ft(typeof h2 != "number" ? h2 : ct(h2, G)), g = u === K ? Ye : K, x = t2.rects.popper, y = t2.elements[v ? g : u], $2 = Gt(Q(y) ? y : y.contextElement || I(t2.elements.popper), a, f), d2 = ee(t2.elements.reference), b = mt({ reference: d2, element: x, strategy: "absolute", placement: o }), w = Te(Object.assign({}, x, b)), O = u === K ? w : d2, j = { top: $2.top - O.top + p.top, bottom: O.bottom - $2.bottom + p.bottom, left: $2.left - O.left + p.left, right: O.right - $2.right + p.right }, A = t2.modifiersData.offset;
- if (u === K && A) {
- var k = A[o];
- Object.keys(j).forEach(function(D) {
- var S = [W, R].indexOf(D) >= 0 ? 1 : -1, L = [E, R].indexOf(D) >= 0 ? "y" : "x";
- j[D] += k[L] * S;
- });
- }
- return j;
- }
- function Jt(t2, e) {
- e === void 0 && (e = {});
- var n = e, r2 = n.placement, o = n.boundary, i2 = n.rootBoundary, a = n.padding, s = n.flipVariations, f = n.allowedAutoPlacements, c = f === void 0 ? Ee : f, u = te(r2), m = u ? s ? De : De.filter(function(h2) {
- return te(h2) === u;
- }) : G, v = m.filter(function(h2) {
- return c.indexOf(h2) >= 0;
- });
- v.length === 0 && (v = m);
- var l = v.reduce(function(h2, p) {
- return h2[p] = ne(t2, { placement: p, boundary: o, rootBoundary: i2, padding: a })[q(p)], h2;
- }, {});
- return Object.keys(l).sort(function(h2, p) {
- return l[h2] - l[p];
- });
- }
- function Kt(t2) {
- if (q(t2) === me)
- return [];
- var e = be(t2);
- return [lt(t2), e, lt(e)];
- }
- function Qt(t2) {
- var e = t2.state, n = t2.options, r2 = t2.name;
- if (!e.modifiersData[r2]._skip) {
- for (var o = n.mainAxis, i2 = o === void 0 ? true : o, a = n.altAxis, s = a === void 0 ? true : a, f = n.fallbackPlacements, c = n.padding, u = n.boundary, m = n.rootBoundary, v = n.altBoundary, l = n.flipVariations, h2 = l === void 0 ? true : l, p = n.allowedAutoPlacements, g = e.options.placement, x = q(g), y = x === g, $2 = f || (y || !h2 ? [be(g)] : Kt(g)), d2 = [g].concat($2).reduce(function(z, V) {
- return z.concat(q(V) === me ? Jt(e, { placement: V, boundary: u, rootBoundary: m, padding: c, flipVariations: h2, allowedAutoPlacements: p }) : V);
- }, []), b = e.rects.reference, w = e.rects.popper, O = /* @__PURE__ */ new Map(), j = true, A = d2[0], k = 0; k < d2.length; k++) {
- var D = d2[k], S = q(D), L = te(D) === U, re = [E, R].indexOf(S) >= 0, oe = re ? "width" : "height", M = ne(e, { placement: D, boundary: u, rootBoundary: m, altBoundary: v, padding: c }), T = re ? L ? W : P : L ? R : E;
- b[oe] > w[oe] && (T = be(T));
- var pe = be(T), _ = [];
- if (i2 && _.push(M[S] <= 0), s && _.push(M[T] <= 0, M[pe] <= 0), _.every(function(z) {
- return z;
- })) {
- A = D, j = false;
- break;
- }
- O.set(D, _);
- }
- if (j)
- for (var ue = h2 ? 3 : 1, xe = function(z) {
- var V = d2.find(function(de) {
- var ae = O.get(de);
- if (ae)
- return ae.slice(0, z).every(function(Y) {
- return Y;
- });
- });
- if (V)
- return A = V, "break";
- }, ie = ue; ie > 0; ie--) {
- var le = xe(ie);
- if (le === "break")
- break;
- }
- e.placement !== A && (e.modifiersData[r2]._skip = true, e.placement = A, e.reset = true);
- }
- }
- var vt = { name: "flip", enabled: true, phase: "main", fn: Qt, requiresIfExists: ["offset"], data: { _skip: false } };
- function gt(t2, e, n) {
- return n === void 0 && (n = { x: 0, y: 0 }), { top: t2.top - e.height - n.y, right: t2.right - e.width + n.x, bottom: t2.bottom - e.height + n.y, left: t2.left - e.width - n.x };
- }
- function yt(t2) {
- return [E, W, R, P].some(function(e) {
- return t2[e] >= 0;
- });
- }
- function Zt(t2) {
- var e = t2.state, n = t2.name, r2 = e.rects.reference, o = e.rects.popper, i2 = e.modifiersData.preventOverflow, a = ne(e, { elementContext: "reference" }), s = ne(e, { altBoundary: true }), f = gt(a, r2), c = gt(s, o, i2), u = yt(f), m = yt(c);
- e.modifiersData[n] = { referenceClippingOffsets: f, popperEscapeOffsets: c, isReferenceHidden: u, hasPopperEscaped: m }, e.attributes.popper = Object.assign({}, e.attributes.popper, { "data-popper-reference-hidden": u, "data-popper-escaped": m });
- }
- var bt = { name: "hide", enabled: true, phase: "main", requiresIfExists: ["preventOverflow"], fn: Zt };
- function en$1(t2, e, n) {
- var r2 = q(t2), o = [P, E].indexOf(r2) >= 0 ? -1 : 1, i2 = typeof n == "function" ? n(Object.assign({}, e, { placement: t2 })) : n, a = i2[0], s = i2[1];
- return a = a || 0, s = (s || 0) * o, [P, W].indexOf(r2) >= 0 ? { x: s, y: a } : { x: a, y: s };
- }
- function tn(t2) {
- var e = t2.state, n = t2.options, r2 = t2.name, o = n.offset, i2 = o === void 0 ? [0, 0] : o, a = Ee.reduce(function(u, m) {
- return u[m] = en$1(m, e.rects, i2), u;
- }, {}), s = a[e.placement], f = s.x, c = s.y;
- e.modifiersData.popperOffsets != null && (e.modifiersData.popperOffsets.x += f, e.modifiersData.popperOffsets.y += c), e.modifiersData[r2] = a;
- }
- var wt = { name: "offset", enabled: true, phase: "main", requires: ["popperOffsets"], fn: tn };
- function nn(t2) {
- var e = t2.state, n = t2.name;
- e.modifiersData[n] = mt({ reference: e.rects.reference, element: e.rects.popper, strategy: "absolute", placement: e.placement });
- }
- var He = { name: "popperOffsets", enabled: true, phase: "read", fn: nn, data: {} };
- function rn(t2) {
- return t2 === "x" ? "y" : "x";
- }
- function on$2(t2) {
- var e = t2.state, n = t2.options, r2 = t2.name, o = n.mainAxis, i2 = o === void 0 ? true : o, a = n.altAxis, s = a === void 0 ? false : a, f = n.boundary, c = n.rootBoundary, u = n.altBoundary, m = n.padding, v = n.tether, l = v === void 0 ? true : v, h2 = n.tetherOffset, p = h2 === void 0 ? 0 : h2, g = ne(e, { boundary: f, rootBoundary: c, padding: m, altBoundary: u }), x = q(e.placement), y = te(e.placement), $2 = !y, d2 = Le(x), b = rn(d2), w = e.modifiersData.popperOffsets, O = e.rects.reference, j = e.rects.popper, A = typeof p == "function" ? p(Object.assign({}, e.rects, { placement: e.placement })) : p, k = typeof A == "number" ? { mainAxis: A, altAxis: A } : Object.assign({ mainAxis: 0, altAxis: 0 }, A), D = e.modifiersData.offset ? e.modifiersData.offset[e.placement] : null, S = { x: 0, y: 0 };
- if (w) {
- if (i2) {
- var L, re = d2 === "y" ? E : P, oe = d2 === "y" ? R : W, M = d2 === "y" ? "height" : "width", T = w[d2], pe = T + g[re], _ = T - g[oe], ue = l ? -j[M] / 2 : 0, xe = y === U ? O[M] : j[M], ie = y === U ? -j[M] : -O[M], le = e.elements.arrow, z = l && le ? ke(le) : { width: 0, height: 0 }, V = e.modifiersData["arrow#persistent"] ? e.modifiersData["arrow#persistent"].padding : st(), de = V[re], ae = V[oe], Y = fe(0, O[M], z[M]), jt = $2 ? O[M] / 2 - ue - Y - de - k.mainAxis : xe - Y - de - k.mainAxis, Dt = $2 ? -O[M] / 2 + ue + Y + ae + k.mainAxis : ie + Y + ae + k.mainAxis, Oe = e.elements.arrow && se(e.elements.arrow), Et = Oe ? d2 === "y" ? Oe.clientTop || 0 : Oe.clientLeft || 0 : 0, Ce = (L = D == null ? void 0 : D[d2]) != null ? L : 0, Pt = T + jt - Ce - Et, At = T + Dt - Ce, qe = fe(l ? ve(pe, Pt) : pe, T, l ? X(_, At) : _);
- w[d2] = qe, S[d2] = qe - T;
- }
- if (s) {
- var Ve, kt = d2 === "x" ? E : P, Lt = d2 === "x" ? R : W, F = w[b], he = b === "y" ? "height" : "width", Ne = F + g[kt], Ie = F - g[Lt], $e = [E, P].indexOf(x) !== -1, _e = (Ve = D == null ? void 0 : D[b]) != null ? Ve : 0, ze = $e ? Ne : F - O[he] - j[he] - _e + k.altAxis, Fe = $e ? F + O[he] + j[he] - _e - k.altAxis : Ie, Ue = l && $e ? St(ze, F, Fe) : fe(l ? ze : Ne, F, l ? Fe : Ie);
- w[b] = Ue, S[b] = Ue - F;
- }
- e.modifiersData[r2] = S;
- }
- }
- var xt = { name: "preventOverflow", enabled: true, phase: "main", fn: on$2, requiresIfExists: ["offset"] };
- function an(t2) {
- return { scrollLeft: t2.scrollLeft, scrollTop: t2.scrollTop };
- }
- function sn(t2) {
- return t2 === H(t2) || !B(t2) ? We(t2) : an(t2);
- }
- function fn(t2) {
- var e = t2.getBoundingClientRect(), n = Z(e.width) / t2.offsetWidth || 1, r2 = Z(e.height) / t2.offsetHeight || 1;
- return n !== 1 || r2 !== 1;
- }
- function cn(t2, e, n) {
- n === void 0 && (n = false);
- var r2 = B(e), o = B(e) && fn(e), i2 = I(e), a = ee(t2, o), s = { scrollLeft: 0, scrollTop: 0 }, f = { x: 0, y: 0 };
- return (r2 || !r2 && !n) && ((C(e) !== "body" || Se(i2)) && (s = sn(e)), B(e) ? (f = ee(e, true), f.x += e.clientLeft, f.y += e.clientTop) : i2 && (f.x = Be(i2))), { x: a.left + s.scrollLeft - f.x, y: a.top + s.scrollTop - f.y, width: a.width, height: a.height };
- }
- function pn(t2) {
- var e = /* @__PURE__ */ new Map(), n = /* @__PURE__ */ new Set(), r2 = [];
- t2.forEach(function(i2) {
- e.set(i2.name, i2);
- });
- function o(i2) {
- n.add(i2.name);
- var a = [].concat(i2.requires || [], i2.requiresIfExists || []);
- a.forEach(function(s) {
- if (!n.has(s)) {
- var f = e.get(s);
- f && o(f);
- }
- }), r2.push(i2);
- }
- return t2.forEach(function(i2) {
- n.has(i2.name) || o(i2);
- }), r2;
- }
- function un(t2) {
- var e = pn(t2);
- return ot.reduce(function(n, r2) {
- return n.concat(e.filter(function(o) {
- return o.phase === r2;
- }));
- }, []);
- }
- function ln(t2) {
- var e;
- return function() {
- return e || (e = new Promise(function(n) {
- Promise.resolve().then(function() {
- e = void 0, n(t2());
- });
- })), e;
- };
- }
- function dn(t2) {
- var e = t2.reduce(function(n, r2) {
- var o = n[r2.name];
- return n[r2.name] = o ? Object.assign({}, o, r2, { options: Object.assign({}, o.options, r2.options), data: Object.assign({}, o.data, r2.data) }) : r2, n;
- }, {});
- return Object.keys(e).map(function(n) {
- return e[n];
- });
- }
- var Ot = { placement: "bottom", modifiers: [], strategy: "absolute" };
- function $t() {
- for (var t2 = arguments.length, e = new Array(t2), n = 0; n < t2; n++)
- e[n] = arguments[n];
- return !e.some(function(r2) {
- return !(r2 && typeof r2.getBoundingClientRect == "function");
- });
- }
- function we(t2) {
- t2 === void 0 && (t2 = {});
- var e = t2, n = e.defaultModifiers, r2 = n === void 0 ? [] : n, o = e.defaultOptions, i2 = o === void 0 ? Ot : o;
- return function(a, s, f) {
- f === void 0 && (f = i2);
- var c = { placement: "bottom", orderedModifiers: [], options: Object.assign({}, Ot, i2), modifiersData: {}, elements: { reference: a, popper: s }, attributes: {}, styles: {} }, u = [], m = false, v = { state: c, setOptions: function(p) {
- var g = typeof p == "function" ? p(c.options) : p;
- h2(), c.options = Object.assign({}, i2, c.options, g), c.scrollParents = { reference: Q(a) ? ce(a) : a.contextElement ? ce(a.contextElement) : [], popper: ce(s) };
- var x = un(dn([].concat(r2, c.options.modifiers)));
- return c.orderedModifiers = x.filter(function(y) {
- return y.enabled;
- }), l(), v.update();
- }, forceUpdate: function() {
- if (!m) {
- var p = c.elements, g = p.reference, x = p.popper;
- if ($t(g, x)) {
- c.rects = { reference: cn(g, se(x), c.options.strategy === "fixed"), popper: ke(x) }, c.reset = false, c.placement = c.options.placement, c.orderedModifiers.forEach(function(j) {
- return c.modifiersData[j.name] = Object.assign({}, j.data);
- });
- for (var y = 0; y < c.orderedModifiers.length; y++) {
- if (c.reset === true) {
- c.reset = false, y = -1;
- continue;
- }
- var $2 = c.orderedModifiers[y], d2 = $2.fn, b = $2.options, w = b === void 0 ? {} : b, O = $2.name;
- typeof d2 == "function" && (c = d2({ state: c, options: w, name: O, instance: v }) || c);
- }
- }
- }
- }, update: ln(function() {
- return new Promise(function(p) {
- v.forceUpdate(), p(c);
- });
- }), destroy: function() {
- h2(), m = true;
- } };
- if (!$t(a, s))
- return v;
- v.setOptions(f).then(function(p) {
- !m && f.onFirstUpdate && f.onFirstUpdate(p);
- });
- function l() {
- c.orderedModifiers.forEach(function(p) {
- var g = p.name, x = p.options, y = x === void 0 ? {} : x, $2 = p.effect;
- if (typeof $2 == "function") {
- var d2 = $2({ state: c, name: g, instance: v, options: y }), b = function() {
- };
- u.push(d2 || b);
- }
- });
- }
- function h2() {
- u.forEach(function(p) {
- return p();
- }), u = [];
- }
- return v;
- };
- }
- we();
- var mn = [Re, He, Me, Ae];
- we({ defaultModifiers: mn });
- var gn = [Re, He, Me, Ae, wt, vt, xt, pt, bt], yn = we({ defaultModifiers: gn });
- const usePopper = (referenceElementRef, popperElementRef, opts = {}) => {
- const stateUpdater = {
- name: "updateState",
- enabled: true,
- phase: "write",
- fn: ({ state }) => {
- const derivedState = deriveState(state);
- Object.assign(states.value, derivedState);
- },
- requires: ["computeStyles"]
- };
- const options2 = computed$1(() => {
- const { onFirstUpdate, placement, strategy, modifiers } = unref(opts);
- return {
- onFirstUpdate,
- placement: placement || "bottom",
- strategy: strategy || "absolute",
- modifiers: [
- ...modifiers || [],
- stateUpdater,
- { name: "applyStyles", enabled: false }
- ]
- };
- });
- const instanceRef = shallowRef();
- const states = ref({
- styles: {
- popper: {
- position: unref(options2).strategy,
- left: "0",
- top: "0"
- },
- arrow: {
- position: "absolute"
- }
- },
- attributes: {}
- });
- const destroy = () => {
- if (!instanceRef.value)
- return;
- instanceRef.value.destroy();
- instanceRef.value = void 0;
- };
- watch(options2, (newOptions) => {
- const instance = unref(instanceRef);
- if (instance) {
- instance.setOptions(newOptions);
- }
- }, {
- deep: true
- });
- watch([referenceElementRef, popperElementRef], ([referenceElement, popperElement]) => {
- destroy();
- if (!referenceElement || !popperElement)
- return;
- instanceRef.value = yn(referenceElement, popperElement, unref(options2));
- });
- onBeforeUnmount(() => {
- destroy();
- });
- return {
- state: computed$1(() => {
- var _a2;
- return { ...((_a2 = unref(instanceRef)) == null ? void 0 : _a2.state) || {} };
- }),
- styles: computed$1(() => unref(states).styles),
- attributes: computed$1(() => unref(states).attributes),
- update: () => {
- var _a2;
- return (_a2 = unref(instanceRef)) == null ? void 0 : _a2.update();
- },
- forceUpdate: () => {
- var _a2;
- return (_a2 = unref(instanceRef)) == null ? void 0 : _a2.forceUpdate();
- },
- instanceRef: computed$1(() => unref(instanceRef))
- };
- };
- function deriveState(state) {
- const elements = Object.keys(state.elements);
- const styles = fromPairs(elements.map((element) => [element, state.styles[element] || {}]));
- const attributes = fromPairs(elements.map((element) => [element, state.attributes[element]]));
- return {
- styles,
- attributes
- };
- }
- const useSameTarget = (handleClick) => {
- if (!handleClick) {
- return { onClick: NOOP, onMousedown: NOOP, onMouseup: NOOP };
- }
- let mousedownTarget = false;
- let mouseupTarget = false;
- const onClick = (e) => {
- if (mousedownTarget && mouseupTarget) {
- handleClick(e);
- }
- mousedownTarget = mouseupTarget = false;
- };
- const onMousedown = (e) => {
- mousedownTarget = e.target === e.currentTarget;
- };
- const onMouseup = (e) => {
- mouseupTarget = e.target === e.currentTarget;
- };
- return { onClick, onMousedown, onMouseup };
- };
- function useTimeout() {
- let timeoutHandle;
- const registerTimeout = (fn2, delay) => {
- cancelTimeout();
- timeoutHandle = window.setTimeout(fn2, delay);
- };
- const cancelTimeout = () => window.clearTimeout(timeoutHandle);
- tryOnScopeDispose(() => cancelTimeout());
- return {
- registerTimeout,
- cancelTimeout
- };
- }
- const defaultIdInjection = {
- prefix: Math.floor(Math.random() * 1e4),
- current: 0
- };
- const ID_INJECTION_KEY = Symbol("elIdInjection");
- const useIdInjection = () => {
- return getCurrentInstance() ? inject(ID_INJECTION_KEY, defaultIdInjection) : defaultIdInjection;
- };
- const useId = (deterministicId) => {
- const idInjection = useIdInjection();
- const namespace = useGetDerivedNamespace();
- const idRef = computed$1(() => unref(deterministicId) || `${namespace.value}-id-${idInjection.prefix}-${idInjection.current++}`);
- return idRef;
- };
- let registeredEscapeHandlers = [];
- const cachedHandler = (e) => {
- const event2 = e;
- if (event2.key === EVENT_CODE.esc) {
- registeredEscapeHandlers.forEach((registeredHandler) => registeredHandler(event2));
- }
- };
- const useEscapeKeydown = (handler) => {
- onMounted(() => {
- if (registeredEscapeHandlers.length === 0) {
- document.addEventListener("keydown", cachedHandler);
- }
- if (isClient)
- registeredEscapeHandlers.push(handler);
- });
- onBeforeUnmount(() => {
- registeredEscapeHandlers = registeredEscapeHandlers.filter((registeredHandler) => registeredHandler !== handler);
- if (registeredEscapeHandlers.length === 0) {
- if (isClient)
- document.removeEventListener("keydown", cachedHandler);
- }
- });
- };
- let cachedContainer;
- const usePopperContainerId = () => {
- const namespace = useGetDerivedNamespace();
- const idInjection = useIdInjection();
- const id = computed$1(() => {
- return `${namespace.value}-popper-container-${idInjection.prefix}`;
- });
- const selector = computed$1(() => `#${id.value}`);
- return {
- id,
- selector
- };
- };
- const createContainer = (id) => {
- const container = document.createElement("div");
- container.id = id;
- document.body.appendChild(container);
- return container;
- };
- const usePopperContainer = () => {
- const { id, selector } = usePopperContainerId();
- onBeforeMount(() => {
- if (!isClient)
- return;
- if (!cachedContainer && !document.body.querySelector(selector.value)) {
- cachedContainer = createContainer(id.value);
- }
- });
- return {
- id,
- selector
- };
- };
- const useDelayedToggleProps = buildProps({
- showAfter: {
- type: Number,
- default: 0
- },
- hideAfter: {
- type: Number,
- default: 200
- },
- autoClose: {
- type: Number,
- default: 0
- }
- });
- const useDelayedToggle = ({
- showAfter,
- hideAfter,
- autoClose,
- open,
- close
- }) => {
- const { registerTimeout } = useTimeout();
- const {
- registerTimeout: registerTimeoutForAutoClose,
- cancelTimeout: cancelTimeoutForAutoClose
- } = useTimeout();
- const onOpen = (event2) => {
- registerTimeout(() => {
- open(event2);
- const _autoClose = unref(autoClose);
- if (isNumber(_autoClose) && _autoClose > 0) {
- registerTimeoutForAutoClose(() => {
- close(event2);
- }, _autoClose);
- }
- }, unref(showAfter));
- };
- const onClose = (event2) => {
- cancelTimeoutForAutoClose();
- registerTimeout(() => {
- close(event2);
- }, unref(hideAfter));
- };
- return {
- onOpen,
- onClose
- };
- };
- const FORWARD_REF_INJECTION_KEY = Symbol("elForwardRef");
- const useForwardRef = (forwardRef) => {
- const setForwardRef = (el) => {
- forwardRef.value = el;
- };
- provide(FORWARD_REF_INJECTION_KEY, {
- setForwardRef
- });
- };
- const useForwardRefDirective = (setForwardRef) => {
- return {
- mounted(el) {
- setForwardRef(el);
- },
- updated(el) {
- setForwardRef(el);
- },
- unmounted() {
- setForwardRef(null);
- }
- };
- };
- const zIndex = ref(0);
- const defaultInitialZIndex = 2e3;
- const zIndexContextKey = Symbol("zIndexContextKey");
- const useZIndex = (zIndexOverrides) => {
- const zIndexInjection = zIndexOverrides || inject(zIndexContextKey, void 0);
- const initialZIndex = computed$1(() => {
- const zIndexFromInjection = unref(zIndexInjection);
- return isNumber(zIndexFromInjection) ? zIndexFromInjection : defaultInitialZIndex;
- });
- const currentZIndex = computed$1(() => initialZIndex.value + zIndex.value);
- const nextZIndex = () => {
- zIndex.value++;
- return currentZIndex.value;
- };
- return {
- initialZIndex,
- currentZIndex,
- nextZIndex
- };
- };
- function useCursor(input) {
- const selectionRef = ref();
- function recordCursor() {
- if (input.value == void 0)
- return;
- const { selectionStart, selectionEnd, value } = input.value;
- if (selectionStart == null || selectionEnd == null)
- return;
- const beforeTxt = value.slice(0, Math.max(0, selectionStart));
- const afterTxt = value.slice(Math.max(0, selectionEnd));
- selectionRef.value = {
- selectionStart,
- selectionEnd,
- value,
- beforeTxt,
- afterTxt
- };
- }
- function setCursor() {
- if (input.value == void 0 || selectionRef.value == void 0)
- return;
- const { value } = input.value;
- const { beforeTxt, afterTxt, selectionStart } = selectionRef.value;
- if (beforeTxt == void 0 || afterTxt == void 0 || selectionStart == void 0)
- return;
- let startPos = value.length;
- if (value.endsWith(afterTxt)) {
- startPos = value.length - afterTxt.length;
- } else if (value.startsWith(beforeTxt)) {
- startPos = beforeTxt.length;
- } else {
- const beforeLastChar = beforeTxt[selectionStart - 1];
- const newIndex = value.indexOf(beforeLastChar, selectionStart - 1);
- if (newIndex !== -1) {
- startPos = newIndex + 1;
- }
- }
- input.value.setSelectionRange(startPos, startPos);
- }
- return [recordCursor, setCursor];
- }
- const useSizeProp = buildProp({
- type: String,
- values: componentSizes,
- required: false
- });
- const SIZE_INJECTION_KEY = Symbol("size");
- const useGlobalSize = () => {
- const injectedSize = inject(SIZE_INJECTION_KEY, {});
- return computed$1(() => {
- return unref(injectedSize.size) || "";
- });
- };
- const configProviderContextKey = Symbol();
- const globalConfig = ref();
- function useGlobalConfig(key, defaultValue2 = void 0) {
- const config = getCurrentInstance() ? inject(configProviderContextKey, globalConfig) : globalConfig;
- if (key) {
- return computed$1(() => {
- var _a2, _b;
- return (_b = (_a2 = config.value) == null ? void 0 : _a2[key]) != null ? _b : defaultValue2;
- });
- } else {
- return config;
- }
- }
- const provideGlobalConfig = (config, app, global2 = false) => {
- var _a2;
- const inSetup = !!getCurrentInstance();
- const oldConfig = inSetup ? useGlobalConfig() : void 0;
- const provideFn = (_a2 = app == null ? void 0 : app.provide) != null ? _a2 : inSetup ? provide : void 0;
- if (!provideFn) {
- return;
- }
- const context = computed$1(() => {
- const cfg = unref(config);
- if (!(oldConfig == null ? void 0 : oldConfig.value))
- return cfg;
- return mergeConfig(oldConfig.value, cfg);
- });
- provideFn(configProviderContextKey, context);
- provideFn(localeContextKey, computed$1(() => context.value.locale));
- provideFn(namespaceContextKey, computed$1(() => context.value.namespace));
- provideFn(zIndexContextKey, computed$1(() => context.value.zIndex));
- provideFn(SIZE_INJECTION_KEY, {
- size: computed$1(() => context.value.size || "")
- });
- if (global2 || !globalConfig.value) {
- globalConfig.value = context.value;
- }
- return context;
- };
- const mergeConfig = (a, b) => {
- var _a2;
- const keys3 = [.../* @__PURE__ */ new Set([...keysOf(a), ...keysOf(b)])];
- const obj = {};
- for (const key of keys3) {
- obj[key] = (_a2 = b[key]) != null ? _a2 : a[key];
- }
- return obj;
- };
- const configProviderProps = buildProps({
- a11y: {
- type: Boolean,
- default: true
- },
- locale: {
- type: definePropType(Object)
- },
- size: useSizeProp,
- button: {
- type: definePropType(Object)
- },
- experimentalFeatures: {
- type: definePropType(Object)
- },
- keyboardNavigation: {
- type: Boolean,
- default: true
- },
- message: {
- type: definePropType(Object)
- },
- zIndex: Number,
- namespace: {
- type: String,
- default: "el"
- }
- });
- const messageConfig = {};
- const ConfigProvider = defineComponent({
- name: "ElConfigProvider",
- props: configProviderProps,
- setup(props, { slots }) {
- watch(() => props.message, (val) => {
- Object.assign(messageConfig, val != null ? val : {});
- }, { immediate: true, deep: true });
- const config = provideGlobalConfig(props);
- return () => renderSlot(slots, "default", { config: config == null ? void 0 : config.value });
- }
- });
- const ElConfigProvider = withInstall(ConfigProvider);
- var _export_sfc$1 = (sfc, props) => {
- const target = sfc.__vccOpts || sfc;
- for (const [key, val] of props) {
- target[key] = val;
- }
- return target;
- };
- const iconProps = buildProps({
- size: {
- type: definePropType([Number, String])
- },
- color: {
- type: String
- }
- });
- const __default__$o = defineComponent({
- name: "ElIcon",
- inheritAttrs: false
- });
- const _sfc_main$B = /* @__PURE__ */ defineComponent({
- ...__default__$o,
- props: iconProps,
- setup(__props) {
- const props = __props;
- const ns = useNamespace("icon");
- const style = computed$1(() => {
- const { size, color: color2 } = props;
- if (!size && !color2)
- return {};
- return {
- fontSize: isUndefined(size) ? void 0 : addUnit(size),
- "--color": color2
- };
- });
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("i", mergeProps({
- class: unref(ns).b(),
- style: unref(style)
- }, _ctx.$attrs), [
- renderSlot(_ctx.$slots, "default")
- ], 16);
- };
- }
- });
- var Icon = /* @__PURE__ */ _export_sfc$1(_sfc_main$B, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/icon/src/icon.vue"]]);
- const ElIcon = withInstall(Icon);
- const formContextKey = Symbol("formContextKey");
- const formItemContextKey = Symbol("formItemContextKey");
- const useFormSize = (fallback, ignore = {}) => {
- const emptyRef = ref(void 0);
- const size = ignore.prop ? emptyRef : useProp("size");
- const globalConfig2 = ignore.global ? emptyRef : useGlobalSize();
- const form = ignore.form ? { size: void 0 } : inject(formContextKey, void 0);
- const formItem = ignore.formItem ? { size: void 0 } : inject(formItemContextKey, void 0);
- return computed$1(() => size.value || unref(fallback) || (formItem == null ? void 0 : formItem.size) || (form == null ? void 0 : form.size) || globalConfig2.value || "");
- };
- const useFormDisabled = (fallback) => {
- const disabled = useProp("disabled");
- const form = inject(formContextKey, void 0);
- return computed$1(() => disabled.value || unref(fallback) || (form == null ? void 0 : form.disabled) || false);
- };
- const useFormItem = () => {
- const form = inject(formContextKey, void 0);
- const formItem = inject(formItemContextKey, void 0);
- return {
- form,
- formItem
- };
- };
- const useFormItemInputId = (props, {
- formItemContext,
- disableIdGeneration,
- disableIdManagement
- }) => {
- if (!disableIdGeneration) {
- disableIdGeneration = ref(false);
- }
- if (!disableIdManagement) {
- disableIdManagement = ref(false);
- }
- const inputId = ref();
- let idUnwatch = void 0;
- const isLabeledByFormItem = computed$1(() => {
- var _a2;
- return !!(!props.label && formItemContext && formItemContext.inputIds && ((_a2 = formItemContext.inputIds) == null ? void 0 : _a2.length) <= 1);
- });
- onMounted(() => {
- idUnwatch = watch([toRef(props, "id"), disableIdGeneration], ([id, disableIdGeneration2]) => {
- const newId = id != null ? id : !disableIdGeneration2 ? useId().value : void 0;
- if (newId !== inputId.value) {
- if (formItemContext == null ? void 0 : formItemContext.removeInputId) {
- inputId.value && formItemContext.removeInputId(inputId.value);
- if (!(disableIdManagement == null ? void 0 : disableIdManagement.value) && !disableIdGeneration2 && newId) {
- formItemContext.addInputId(newId);
- }
- }
- inputId.value = newId;
- }
- }, { immediate: true });
- });
- onUnmounted(() => {
- idUnwatch && idUnwatch();
- if (formItemContext == null ? void 0 : formItemContext.removeInputId) {
- inputId.value && formItemContext.removeInputId(inputId.value);
- }
- });
- return {
- isLabeledByFormItem,
- inputId
- };
- };
- let hiddenTextarea = void 0;
- const HIDDEN_STYLE = `
- height:0 !important;
- visibility:hidden !important;
- ${isFirefox() ? "" : "overflow:hidden !important;"}
- position:absolute !important;
- z-index:-1000 !important;
- top:0 !important;
- right:0 !important;
- `;
- const CONTEXT_STYLE = [
- "letter-spacing",
- "line-height",
- "padding-top",
- "padding-bottom",
- "font-family",
- "font-weight",
- "font-size",
- "text-rendering",
- "text-transform",
- "width",
- "text-indent",
- "padding-left",
- "padding-right",
- "border-width",
- "box-sizing"
- ];
- function calculateNodeStyling(targetElement) {
- const style = window.getComputedStyle(targetElement);
- const boxSizing = style.getPropertyValue("box-sizing");
- const paddingSize = Number.parseFloat(style.getPropertyValue("padding-bottom")) + Number.parseFloat(style.getPropertyValue("padding-top"));
- const borderSize = Number.parseFloat(style.getPropertyValue("border-bottom-width")) + Number.parseFloat(style.getPropertyValue("border-top-width"));
- const contextStyle = CONTEXT_STYLE.map((name) => `${name}:${style.getPropertyValue(name)}`).join(";");
- return { contextStyle, paddingSize, borderSize, boxSizing };
- }
- function calcTextareaHeight(targetElement, minRows = 1, maxRows) {
- var _a2;
- if (!hiddenTextarea) {
- hiddenTextarea = document.createElement("textarea");
- document.body.appendChild(hiddenTextarea);
- }
- const { paddingSize, borderSize, boxSizing, contextStyle } = calculateNodeStyling(targetElement);
- hiddenTextarea.setAttribute("style", `${contextStyle};${HIDDEN_STYLE}`);
- hiddenTextarea.value = targetElement.value || targetElement.placeholder || "";
- let height2 = hiddenTextarea.scrollHeight;
- const result = {};
- if (boxSizing === "border-box") {
- height2 = height2 + borderSize;
- } else if (boxSizing === "content-box") {
- height2 = height2 - paddingSize;
- }
- hiddenTextarea.value = "";
- const singleRowHeight = hiddenTextarea.scrollHeight - paddingSize;
- if (isNumber(minRows)) {
- let minHeight = singleRowHeight * minRows;
- if (boxSizing === "border-box") {
- minHeight = minHeight + paddingSize + borderSize;
- }
- height2 = Math.max(minHeight, height2);
- result.minHeight = `${minHeight}px`;
- }
- if (isNumber(maxRows)) {
- let maxHeight = singleRowHeight * maxRows;
- if (boxSizing === "border-box") {
- maxHeight = maxHeight + paddingSize + borderSize;
- }
- height2 = Math.min(maxHeight, height2);
- }
- result.height = `${height2}px`;
- (_a2 = hiddenTextarea.parentNode) == null ? void 0 : _a2.removeChild(hiddenTextarea);
- hiddenTextarea = void 0;
- return result;
- }
- const inputProps = buildProps({
- id: {
- type: String,
- default: void 0
- },
- size: useSizeProp,
- disabled: Boolean,
- modelValue: {
- type: definePropType([
- String,
- Number,
- Object
- ]),
- default: ""
- },
- type: {
- type: String,
- default: "text"
- },
- resize: {
- type: String,
- values: ["none", "both", "horizontal", "vertical"]
- },
- autosize: {
- type: definePropType([Boolean, Object]),
- default: false
- },
- autocomplete: {
- type: String,
- default: "off"
- },
- formatter: {
- type: Function
- },
- parser: {
- type: Function
- },
- placeholder: {
- type: String
- },
- form: {
- type: String
- },
- readonly: {
- type: Boolean,
- default: false
- },
- clearable: {
- type: Boolean,
- default: false
- },
- showPassword: {
- type: Boolean,
- default: false
- },
- showWordLimit: {
- type: Boolean,
- default: false
- },
- suffixIcon: {
- type: iconPropType
- },
- prefixIcon: {
- type: iconPropType
- },
- containerRole: {
- type: String,
- default: void 0
- },
- label: {
- type: String,
- default: void 0
- },
- tabindex: {
- type: [String, Number],
- default: 0
- },
- validateEvent: {
- type: Boolean,
- default: true
- },
- inputStyle: {
- type: definePropType([Object, Array, String]),
- default: () => mutable({})
- }
- });
- const inputEmits = {
- [UPDATE_MODEL_EVENT]: (value) => isString(value),
- input: (value) => isString(value),
- change: (value) => isString(value),
- focus: (evt) => evt instanceof FocusEvent,
- blur: (evt) => evt instanceof FocusEvent,
- clear: () => true,
- mouseleave: (evt) => evt instanceof MouseEvent,
- mouseenter: (evt) => evt instanceof MouseEvent,
- keydown: (evt) => evt instanceof Event,
- compositionstart: (evt) => evt instanceof CompositionEvent,
- compositionupdate: (evt) => evt instanceof CompositionEvent,
- compositionend: (evt) => evt instanceof CompositionEvent
- };
- const _hoisted_1$g = ["role"];
- const _hoisted_2$a = ["id", "type", "disabled", "formatter", "parser", "readonly", "autocomplete", "tabindex", "aria-label", "placeholder", "form"];
- const _hoisted_3$6 = ["id", "tabindex", "disabled", "readonly", "autocomplete", "aria-label", "placeholder", "form"];
- const __default__$n = defineComponent({
- name: "ElInput",
- inheritAttrs: false
- });
- const _sfc_main$A = /* @__PURE__ */ defineComponent({
- ...__default__$n,
- props: inputProps,
- emits: inputEmits,
- setup(__props, { expose, emit }) {
- const props = __props;
- const rawAttrs = useAttrs$1();
- const slots = useSlots();
- const containerAttrs = computed$1(() => {
- const comboBoxAttrs = {};
- if (props.containerRole === "combobox") {
- comboBoxAttrs["aria-haspopup"] = rawAttrs["aria-haspopup"];
- comboBoxAttrs["aria-owns"] = rawAttrs["aria-owns"];
- comboBoxAttrs["aria-expanded"] = rawAttrs["aria-expanded"];
- }
- return comboBoxAttrs;
- });
- const containerKls = computed$1(() => [
- props.type === "textarea" ? nsTextarea.b() : nsInput.b(),
- nsInput.m(inputSize.value),
- nsInput.is("disabled", inputDisabled.value),
- nsInput.is("exceed", inputExceed.value),
- {
- [nsInput.b("group")]: slots.prepend || slots.append,
- [nsInput.bm("group", "append")]: slots.append,
- [nsInput.bm("group", "prepend")]: slots.prepend,
- [nsInput.m("prefix")]: slots.prefix || props.prefixIcon,
- [nsInput.m("suffix")]: slots.suffix || props.suffixIcon || props.clearable || props.showPassword,
- [nsInput.bm("suffix", "password-clear")]: showClear.value && showPwdVisible.value
- },
- rawAttrs.class
- ]);
- const wrapperKls = computed$1(() => [
- nsInput.e("wrapper"),
- nsInput.is("focus", focused.value)
- ]);
- const attrs = useAttrs({
- excludeKeys: computed$1(() => {
- return Object.keys(containerAttrs.value);
- })
- });
- const { form, formItem } = useFormItem();
- const { inputId } = useFormItemInputId(props, {
- formItemContext: formItem
- });
- const inputSize = useFormSize();
- const inputDisabled = useFormDisabled();
- const nsInput = useNamespace("input");
- const nsTextarea = useNamespace("textarea");
- const input = shallowRef();
- const textarea = shallowRef();
- const focused = ref(false);
- const hovering = ref(false);
- const isComposing = ref(false);
- const passwordVisible = ref(false);
- const countStyle = ref();
- const textareaCalcStyle = shallowRef(props.inputStyle);
- const _ref = computed$1(() => input.value || textarea.value);
- const needStatusIcon = computed$1(() => {
- var _a2;
- return (_a2 = form == null ? void 0 : form.statusIcon) != null ? _a2 : false;
- });
- const validateState = computed$1(() => (formItem == null ? void 0 : formItem.validateState) || "");
- const validateIcon = computed$1(() => validateState.value && ValidateComponentsMap[validateState.value]);
- const passwordIcon = computed$1(() => passwordVisible.value ? view_default : hide_default);
- const containerStyle = computed$1(() => [
- rawAttrs.style,
- props.inputStyle
- ]);
- const textareaStyle = computed$1(() => [
- props.inputStyle,
- textareaCalcStyle.value,
- { resize: props.resize }
- ]);
- const nativeInputValue = computed$1(() => isNil(props.modelValue) ? "" : String(props.modelValue));
- const showClear = computed$1(() => props.clearable && !inputDisabled.value && !props.readonly && !!nativeInputValue.value && (focused.value || hovering.value));
- const showPwdVisible = computed$1(() => props.showPassword && !inputDisabled.value && !props.readonly && !!nativeInputValue.value && (!!nativeInputValue.value || focused.value));
- const isWordLimitVisible = computed$1(() => props.showWordLimit && !!attrs.value.maxlength && (props.type === "text" || props.type === "textarea") && !inputDisabled.value && !props.readonly && !props.showPassword);
- const textLength = computed$1(() => nativeInputValue.value.length);
- const inputExceed = computed$1(() => !!isWordLimitVisible.value && textLength.value > Number(attrs.value.maxlength));
- const suffixVisible = computed$1(() => !!slots.suffix || !!props.suffixIcon || showClear.value || props.showPassword || isWordLimitVisible.value || !!validateState.value && needStatusIcon.value);
- const [recordCursor, setCursor] = useCursor(input);
- useResizeObserver(textarea, (entries) => {
- onceInitSizeTextarea();
- if (!isWordLimitVisible.value || props.resize !== "both")
- return;
- const entry = entries[0];
- const { width: width2 } = entry.contentRect;
- countStyle.value = {
- right: `calc(100% - ${width2 + 15 + 6}px)`
- };
- });
- const resizeTextarea = () => {
- const { type: type2, autosize } = props;
- if (!isClient || type2 !== "textarea" || !textarea.value)
- return;
- if (autosize) {
- const minRows = isObject$5(autosize) ? autosize.minRows : void 0;
- const maxRows = isObject$5(autosize) ? autosize.maxRows : void 0;
- const textareaStyle2 = calcTextareaHeight(textarea.value, minRows, maxRows);
- textareaCalcStyle.value = {
- overflowY: "hidden",
- ...textareaStyle2
- };
- nextTick(() => {
- textarea.value.offsetHeight;
- textareaCalcStyle.value = textareaStyle2;
- });
- } else {
- textareaCalcStyle.value = {
- minHeight: calcTextareaHeight(textarea.value).minHeight
- };
- }
- };
- const createOnceInitResize = (resizeTextarea2) => {
- let isInit = false;
- return () => {
- var _a2;
- if (isInit || !props.autosize)
- return;
- const isElHidden = ((_a2 = textarea.value) == null ? void 0 : _a2.offsetParent) === null;
- if (!isElHidden) {
- resizeTextarea2();
- isInit = true;
- }
- };
- };
- const onceInitSizeTextarea = createOnceInitResize(resizeTextarea);
- const setNativeInputValue = () => {
- const input2 = _ref.value;
- if (!input2 || input2.value === nativeInputValue.value)
- return;
- input2.value = nativeInputValue.value;
- };
- const handleInput = async (event2) => {
- recordCursor();
- let { value } = event2.target;
- if (props.formatter) {
- value = props.parser ? props.parser(value) : value;
- value = props.formatter(value);
- }
- if (isComposing.value)
- return;
- if (value === nativeInputValue.value) {
- setNativeInputValue();
- return;
- }
- emit(UPDATE_MODEL_EVENT, value);
- emit("input", value);
- await nextTick();
- setNativeInputValue();
- setCursor();
- };
- const handleChange = (event2) => {
- emit("change", event2.target.value);
- };
- const handleCompositionStart = (event2) => {
- emit("compositionstart", event2);
- isComposing.value = true;
- };
- const handleCompositionUpdate = (event2) => {
- var _a2;
- emit("compositionupdate", event2);
- const text = (_a2 = event2.target) == null ? void 0 : _a2.value;
- const lastCharacter = text[text.length - 1] || "";
- isComposing.value = !isKorean(lastCharacter);
- };
- const handleCompositionEnd = (event2) => {
- emit("compositionend", event2);
- if (isComposing.value) {
- isComposing.value = false;
- handleInput(event2);
- }
- };
- const handlePasswordVisible = () => {
- passwordVisible.value = !passwordVisible.value;
- focus();
- };
- const focus = async () => {
- var _a2;
- await nextTick();
- (_a2 = _ref.value) == null ? void 0 : _a2.focus();
- };
- const blur = () => {
- var _a2;
- return (_a2 = _ref.value) == null ? void 0 : _a2.blur();
- };
- const handleFocus = (event2) => {
- focused.value = true;
- emit("focus", event2);
- };
- const handleBlur = (event2) => {
- var _a2;
- focused.value = false;
- emit("blur", event2);
- if (props.validateEvent) {
- (_a2 = formItem == null ? void 0 : formItem.validate) == null ? void 0 : _a2.call(formItem, "blur").catch((err) => debugWarn());
- }
- };
- const handleMouseLeave = (evt) => {
- hovering.value = false;
- emit("mouseleave", evt);
- };
- const handleMouseEnter = (evt) => {
- hovering.value = true;
- emit("mouseenter", evt);
- };
- const handleKeydown = (evt) => {
- emit("keydown", evt);
- };
- const select = () => {
- var _a2;
- (_a2 = _ref.value) == null ? void 0 : _a2.select();
- };
- const clear = () => {
- emit(UPDATE_MODEL_EVENT, "");
- emit("change", "");
- emit("clear");
- emit("input", "");
- };
- watch(() => props.modelValue, () => {
- var _a2;
- nextTick(() => resizeTextarea());
- if (props.validateEvent) {
- (_a2 = formItem == null ? void 0 : formItem.validate) == null ? void 0 : _a2.call(formItem, "change").catch((err) => debugWarn());
- }
- });
- watch(nativeInputValue, () => setNativeInputValue());
- watch(() => props.type, async () => {
- await nextTick();
- setNativeInputValue();
- resizeTextarea();
- });
- onMounted(() => {
- if (!props.formatter && props.parser)
- ;
- setNativeInputValue();
- nextTick(resizeTextarea);
- });
- expose({
- input,
- textarea,
- ref: _ref,
- textareaStyle,
- autosize: toRef(props, "autosize"),
- focus,
- blur,
- select,
- clear,
- resizeTextarea
- });
- return (_ctx, _cache) => {
- return withDirectives((openBlock(), createElementBlock("div", mergeProps(unref(containerAttrs), {
- class: unref(containerKls),
- style: unref(containerStyle),
- role: _ctx.containerRole,
- onMouseenter: handleMouseEnter,
- onMouseleave: handleMouseLeave
- }), [
- createCommentVNode(" input "),
- _ctx.type !== "textarea" ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
- createCommentVNode(" prepend slot "),
- _ctx.$slots.prepend ? (openBlock(), createElementBlock("div", {
- key: 0,
- class: normalizeClass(unref(nsInput).be("group", "prepend"))
- }, [
- renderSlot(_ctx.$slots, "prepend")
- ], 2)) : createCommentVNode("v-if", true),
- createElementVNode("div", {
- class: normalizeClass(unref(wrapperKls))
- }, [
- createCommentVNode(" prefix slot "),
- _ctx.$slots.prefix || _ctx.prefixIcon ? (openBlock(), createElementBlock("span", {
- key: 0,
- class: normalizeClass(unref(nsInput).e("prefix"))
- }, [
- createElementVNode("span", {
- class: normalizeClass(unref(nsInput).e("prefix-inner")),
- onClick: focus
- }, [
- renderSlot(_ctx.$slots, "prefix"),
- _ctx.prefixIcon ? (openBlock(), createBlock(unref(ElIcon), {
- key: 0,
- class: normalizeClass(unref(nsInput).e("icon"))
- }, {
- default: withCtx(() => [
- (openBlock(), createBlock(resolveDynamicComponent(_ctx.prefixIcon)))
- ]),
- _: 1
- }, 8, ["class"])) : createCommentVNode("v-if", true)
- ], 2)
- ], 2)) : createCommentVNode("v-if", true),
- createElementVNode("input", mergeProps({
- id: unref(inputId),
- ref_key: "input",
- ref: input,
- class: unref(nsInput).e("inner")
- }, unref(attrs), {
- type: _ctx.showPassword ? passwordVisible.value ? "text" : "password" : _ctx.type,
- disabled: unref(inputDisabled),
- formatter: _ctx.formatter,
- parser: _ctx.parser,
- readonly: _ctx.readonly,
- autocomplete: _ctx.autocomplete,
- tabindex: _ctx.tabindex,
- "aria-label": _ctx.label,
- placeholder: _ctx.placeholder,
- style: _ctx.inputStyle,
- form: props.form,
- onCompositionstart: handleCompositionStart,
- onCompositionupdate: handleCompositionUpdate,
- onCompositionend: handleCompositionEnd,
- onInput: handleInput,
- onFocus: handleFocus,
- onBlur: handleBlur,
- onChange: handleChange,
- onKeydown: handleKeydown
- }), null, 16, _hoisted_2$a),
- createCommentVNode(" suffix slot "),
- unref(suffixVisible) ? (openBlock(), createElementBlock("span", {
- key: 1,
- class: normalizeClass(unref(nsInput).e("suffix"))
- }, [
- createElementVNode("span", {
- class: normalizeClass(unref(nsInput).e("suffix-inner")),
- onClick: focus
- }, [
- !unref(showClear) || !unref(showPwdVisible) || !unref(isWordLimitVisible) ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
- renderSlot(_ctx.$slots, "suffix"),
- _ctx.suffixIcon ? (openBlock(), createBlock(unref(ElIcon), {
- key: 0,
- class: normalizeClass(unref(nsInput).e("icon"))
- }, {
- default: withCtx(() => [
- (openBlock(), createBlock(resolveDynamicComponent(_ctx.suffixIcon)))
- ]),
- _: 1
- }, 8, ["class"])) : createCommentVNode("v-if", true)
- ], 64)) : createCommentVNode("v-if", true),
- unref(showClear) ? (openBlock(), createBlock(unref(ElIcon), {
- key: 1,
- class: normalizeClass([unref(nsInput).e("icon"), unref(nsInput).e("clear")]),
- onMousedown: withModifiers(unref(NOOP), ["prevent"]),
- onClick: clear
- }, {
- default: withCtx(() => [
- createVNode(unref(circle_close_default))
- ]),
- _: 1
- }, 8, ["class", "onMousedown"])) : createCommentVNode("v-if", true),
- unref(showPwdVisible) ? (openBlock(), createBlock(unref(ElIcon), {
- key: 2,
- class: normalizeClass([unref(nsInput).e("icon"), unref(nsInput).e("password")]),
- onClick: handlePasswordVisible
- }, {
- default: withCtx(() => [
- (openBlock(), createBlock(resolveDynamicComponent(unref(passwordIcon))))
- ]),
- _: 1
- }, 8, ["class"])) : createCommentVNode("v-if", true),
- unref(isWordLimitVisible) ? (openBlock(), createElementBlock("span", {
- key: 3,
- class: normalizeClass(unref(nsInput).e("count"))
- }, [
- createElementVNode("span", {
- class: normalizeClass(unref(nsInput).e("count-inner"))
- }, toDisplayString(unref(textLength)) + " / " + toDisplayString(unref(attrs).maxlength), 3)
- ], 2)) : createCommentVNode("v-if", true),
- unref(validateState) && unref(validateIcon) && unref(needStatusIcon) ? (openBlock(), createBlock(unref(ElIcon), {
- key: 4,
- class: normalizeClass([
- unref(nsInput).e("icon"),
- unref(nsInput).e("validateIcon"),
- unref(nsInput).is("loading", unref(validateState) === "validating")
- ])
- }, {
- default: withCtx(() => [
- (openBlock(), createBlock(resolveDynamicComponent(unref(validateIcon))))
- ]),
- _: 1
- }, 8, ["class"])) : createCommentVNode("v-if", true)
- ], 2)
- ], 2)) : createCommentVNode("v-if", true)
- ], 2),
- createCommentVNode(" append slot "),
- _ctx.$slots.append ? (openBlock(), createElementBlock("div", {
- key: 1,
- class: normalizeClass(unref(nsInput).be("group", "append"))
- }, [
- renderSlot(_ctx.$slots, "append")
- ], 2)) : createCommentVNode("v-if", true)
- ], 64)) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [
- createCommentVNode(" textarea "),
- createElementVNode("textarea", mergeProps({
- id: unref(inputId),
- ref_key: "textarea",
- ref: textarea,
- class: unref(nsTextarea).e("inner")
- }, unref(attrs), {
- tabindex: _ctx.tabindex,
- disabled: unref(inputDisabled),
- readonly: _ctx.readonly,
- autocomplete: _ctx.autocomplete,
- style: unref(textareaStyle),
- "aria-label": _ctx.label,
- placeholder: _ctx.placeholder,
- form: props.form,
- onCompositionstart: handleCompositionStart,
- onCompositionupdate: handleCompositionUpdate,
- onCompositionend: handleCompositionEnd,
- onInput: handleInput,
- onFocus: handleFocus,
- onBlur: handleBlur,
- onChange: handleChange,
- onKeydown: handleKeydown
- }), null, 16, _hoisted_3$6),
- unref(isWordLimitVisible) ? (openBlock(), createElementBlock("span", {
- key: 0,
- style: normalizeStyle(countStyle.value),
- class: normalizeClass(unref(nsInput).e("count"))
- }, toDisplayString(unref(textLength)) + " / " + toDisplayString(unref(attrs).maxlength), 7)) : createCommentVNode("v-if", true)
- ], 64))
- ], 16, _hoisted_1$g)), [
- [vShow, _ctx.type !== "hidden"]
- ]);
- };
- }
- });
- var Input = /* @__PURE__ */ _export_sfc$1(_sfc_main$A, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/input/src/input.vue"]]);
- const ElInput = withInstall(Input);
- const GAP = 4;
- const BAR_MAP = {
- vertical: {
- offset: "offsetHeight",
- scroll: "scrollTop",
- scrollSize: "scrollHeight",
- size: "height",
- key: "vertical",
- axis: "Y",
- client: "clientY",
- direction: "top"
- },
- horizontal: {
- offset: "offsetWidth",
- scroll: "scrollLeft",
- scrollSize: "scrollWidth",
- size: "width",
- key: "horizontal",
- axis: "X",
- client: "clientX",
- direction: "left"
- }
- };
- const renderThumbStyle = ({
- move,
- size,
- bar
- }) => ({
- [bar.size]: size,
- transform: `translate${bar.axis}(${move}%)`
- });
- const scrollbarContextKey = Symbol("scrollbarContextKey");
- const thumbProps = buildProps({
- vertical: Boolean,
- size: String,
- move: Number,
- ratio: {
- type: Number,
- required: true
- },
- always: Boolean
- });
- const COMPONENT_NAME$4 = "Thumb";
- const _sfc_main$z = /* @__PURE__ */ defineComponent({
- __name: "thumb",
- props: thumbProps,
- setup(__props) {
- const props = __props;
- const scrollbar = inject(scrollbarContextKey);
- const ns = useNamespace("scrollbar");
- if (!scrollbar)
- throwError(COMPONENT_NAME$4, "can not inject scrollbar context");
- const instance = ref();
- const thumb = ref();
- const thumbState = ref({});
- const visible = ref(false);
- let cursorDown = false;
- let cursorLeave = false;
- let originalOnSelectStart = isClient ? document.onselectstart : null;
- const bar = computed$1(() => BAR_MAP[props.vertical ? "vertical" : "horizontal"]);
- const thumbStyle = computed$1(() => renderThumbStyle({
- size: props.size,
- move: props.move,
- bar: bar.value
- }));
- const offsetRatio = computed$1(() => instance.value[bar.value.offset] ** 2 / scrollbar.wrapElement[bar.value.scrollSize] / props.ratio / thumb.value[bar.value.offset]);
- const clickThumbHandler = (e) => {
- var _a2;
- e.stopPropagation();
- if (e.ctrlKey || [1, 2].includes(e.button))
- return;
- (_a2 = window.getSelection()) == null ? void 0 : _a2.removeAllRanges();
- startDrag(e);
- const el = e.currentTarget;
- if (!el)
- return;
- thumbState.value[bar.value.axis] = el[bar.value.offset] - (e[bar.value.client] - el.getBoundingClientRect()[bar.value.direction]);
- };
- const clickTrackHandler = (e) => {
- if (!thumb.value || !instance.value || !scrollbar.wrapElement)
- return;
- const offset = Math.abs(e.target.getBoundingClientRect()[bar.value.direction] - e[bar.value.client]);
- const thumbHalf = thumb.value[bar.value.offset] / 2;
- const thumbPositionPercentage = (offset - thumbHalf) * 100 * offsetRatio.value / instance.value[bar.value.offset];
- scrollbar.wrapElement[bar.value.scroll] = thumbPositionPercentage * scrollbar.wrapElement[bar.value.scrollSize] / 100;
- };
- const startDrag = (e) => {
- e.stopImmediatePropagation();
- cursorDown = true;
- document.addEventListener("mousemove", mouseMoveDocumentHandler);
- document.addEventListener("mouseup", mouseUpDocumentHandler);
- originalOnSelectStart = document.onselectstart;
- document.onselectstart = () => false;
- };
- const mouseMoveDocumentHandler = (e) => {
- if (!instance.value || !thumb.value)
- return;
- if (cursorDown === false)
- return;
- const prevPage = thumbState.value[bar.value.axis];
- if (!prevPage)
- return;
- const offset = (instance.value.getBoundingClientRect()[bar.value.direction] - e[bar.value.client]) * -1;
- const thumbClickPosition = thumb.value[bar.value.offset] - prevPage;
- const thumbPositionPercentage = (offset - thumbClickPosition) * 100 * offsetRatio.value / instance.value[bar.value.offset];
- scrollbar.wrapElement[bar.value.scroll] = thumbPositionPercentage * scrollbar.wrapElement[bar.value.scrollSize] / 100;
- };
- const mouseUpDocumentHandler = () => {
- cursorDown = false;
- thumbState.value[bar.value.axis] = 0;
- document.removeEventListener("mousemove", mouseMoveDocumentHandler);
- document.removeEventListener("mouseup", mouseUpDocumentHandler);
- restoreOnselectstart();
- if (cursorLeave)
- visible.value = false;
- };
- const mouseMoveScrollbarHandler = () => {
- cursorLeave = false;
- visible.value = !!props.size;
- };
- const mouseLeaveScrollbarHandler = () => {
- cursorLeave = true;
- visible.value = cursorDown;
- };
- onBeforeUnmount(() => {
- restoreOnselectstart();
- document.removeEventListener("mouseup", mouseUpDocumentHandler);
- });
- const restoreOnselectstart = () => {
- if (document.onselectstart !== originalOnSelectStart)
- document.onselectstart = originalOnSelectStart;
- };
- useEventListener(toRef(scrollbar, "scrollbarElement"), "mousemove", mouseMoveScrollbarHandler);
- useEventListener(toRef(scrollbar, "scrollbarElement"), "mouseleave", mouseLeaveScrollbarHandler);
- return (_ctx, _cache) => {
- return openBlock(), createBlock(Transition, {
- name: unref(ns).b("fade"),
- persisted: ""
- }, {
- default: withCtx(() => [
- withDirectives(createElementVNode("div", {
- ref_key: "instance",
- ref: instance,
- class: normalizeClass([unref(ns).e("bar"), unref(ns).is(unref(bar).key)]),
- onMousedown: clickTrackHandler
- }, [
- createElementVNode("div", {
- ref_key: "thumb",
- ref: thumb,
- class: normalizeClass(unref(ns).e("thumb")),
- style: normalizeStyle(unref(thumbStyle)),
- onMousedown: clickThumbHandler
- }, null, 38)
- ], 34), [
- [vShow, _ctx.always || visible.value]
- ])
- ]),
- _: 1
- }, 8, ["name"]);
- };
- }
- });
- var Thumb = /* @__PURE__ */ _export_sfc$1(_sfc_main$z, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/scrollbar/src/thumb.vue"]]);
- const barProps = buildProps({
- always: {
- type: Boolean,
- default: true
- },
- width: String,
- height: String,
- ratioX: {
- type: Number,
- default: 1
- },
- ratioY: {
- type: Number,
- default: 1
- }
- });
- const _sfc_main$y = /* @__PURE__ */ defineComponent({
- __name: "bar",
- props: barProps,
- setup(__props, { expose }) {
- const props = __props;
- const moveX = ref(0);
- const moveY = ref(0);
- const handleScroll = (wrap) => {
- if (wrap) {
- const offsetHeight = wrap.offsetHeight - GAP;
- const offsetWidth = wrap.offsetWidth - GAP;
- moveY.value = wrap.scrollTop * 100 / offsetHeight * props.ratioY;
- moveX.value = wrap.scrollLeft * 100 / offsetWidth * props.ratioX;
- }
- };
- expose({
- handleScroll
- });
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock(Fragment, null, [
- createVNode(Thumb, {
- move: moveX.value,
- ratio: _ctx.ratioX,
- size: _ctx.width,
- always: _ctx.always
- }, null, 8, ["move", "ratio", "size", "always"]),
- createVNode(Thumb, {
- move: moveY.value,
- ratio: _ctx.ratioY,
- size: _ctx.height,
- vertical: "",
- always: _ctx.always
- }, null, 8, ["move", "ratio", "size", "always"])
- ], 64);
- };
- }
- });
- var Bar = /* @__PURE__ */ _export_sfc$1(_sfc_main$y, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/scrollbar/src/bar.vue"]]);
- const scrollbarProps = buildProps({
- height: {
- type: [String, Number],
- default: ""
- },
- maxHeight: {
- type: [String, Number],
- default: ""
- },
- native: {
- type: Boolean,
- default: false
- },
- wrapStyle: {
- type: definePropType([String, Object, Array]),
- default: ""
- },
- wrapClass: {
- type: [String, Array],
- default: ""
- },
- viewClass: {
- type: [String, Array],
- default: ""
- },
- viewStyle: {
- type: [String, Array, Object],
- default: ""
- },
- noresize: Boolean,
- tag: {
- type: String,
- default: "div"
- },
- always: Boolean,
- minSize: {
- type: Number,
- default: 20
- }
- });
- const scrollbarEmits = {
- scroll: ({
- scrollTop,
- scrollLeft
- }) => [scrollTop, scrollLeft].every(isNumber)
- };
- const COMPONENT_NAME$3 = "ElScrollbar";
- const __default__$m = defineComponent({
- name: COMPONENT_NAME$3
- });
- const _sfc_main$x = /* @__PURE__ */ defineComponent({
- ...__default__$m,
- props: scrollbarProps,
- emits: scrollbarEmits,
- setup(__props, { expose, emit }) {
- const props = __props;
- const ns = useNamespace("scrollbar");
- let stopResizeObserver = void 0;
- let stopResizeListener = void 0;
- const scrollbarRef = ref();
- const wrapRef = ref();
- const resizeRef = ref();
- const sizeWidth = ref("0");
- const sizeHeight = ref("0");
- const barRef = ref();
- const ratioY = ref(1);
- const ratioX = ref(1);
- const style = computed$1(() => {
- const style2 = {};
- if (props.height)
- style2.height = addUnit(props.height);
- if (props.maxHeight)
- style2.maxHeight = addUnit(props.maxHeight);
- return [props.wrapStyle, style2];
- });
- const wrapKls = computed$1(() => {
- return [
- props.wrapClass,
- ns.e("wrap"),
- { [ns.em("wrap", "hidden-default")]: !props.native }
- ];
- });
- const resizeKls = computed$1(() => {
- return [ns.e("view"), props.viewClass];
- });
- const handleScroll = () => {
- var _a2;
- if (wrapRef.value) {
- (_a2 = barRef.value) == null ? void 0 : _a2.handleScroll(wrapRef.value);
- emit("scroll", {
- scrollTop: wrapRef.value.scrollTop,
- scrollLeft: wrapRef.value.scrollLeft
- });
- }
- };
- function scrollTo(arg1, arg2) {
- if (isObject$5(arg1)) {
- wrapRef.value.scrollTo(arg1);
- } else if (isNumber(arg1) && isNumber(arg2)) {
- wrapRef.value.scrollTo(arg1, arg2);
- }
- }
- const setScrollTop = (value) => {
- if (!isNumber(value)) {
- return;
- }
- wrapRef.value.scrollTop = value;
- };
- const setScrollLeft = (value) => {
- if (!isNumber(value)) {
- return;
- }
- wrapRef.value.scrollLeft = value;
- };
- const update = () => {
- if (!wrapRef.value)
- return;
- const offsetHeight = wrapRef.value.offsetHeight - GAP;
- const offsetWidth = wrapRef.value.offsetWidth - GAP;
- const originalHeight = offsetHeight ** 2 / wrapRef.value.scrollHeight;
- const originalWidth = offsetWidth ** 2 / wrapRef.value.scrollWidth;
- const height2 = Math.max(originalHeight, props.minSize);
- const width2 = Math.max(originalWidth, props.minSize);
- ratioY.value = originalHeight / (offsetHeight - originalHeight) / (height2 / (offsetHeight - height2));
- ratioX.value = originalWidth / (offsetWidth - originalWidth) / (width2 / (offsetWidth - width2));
- sizeHeight.value = height2 + GAP < offsetHeight ? `${height2}px` : "";
- sizeWidth.value = width2 + GAP < offsetWidth ? `${width2}px` : "";
- };
- watch(() => props.noresize, (noresize) => {
- if (noresize) {
- stopResizeObserver == null ? void 0 : stopResizeObserver();
- stopResizeListener == null ? void 0 : stopResizeListener();
- } else {
- ({ stop: stopResizeObserver } = useResizeObserver(resizeRef, update));
- stopResizeListener = useEventListener("resize", update);
- }
- }, { immediate: true });
- watch(() => [props.maxHeight, props.height], () => {
- if (!props.native)
- nextTick(() => {
- var _a2;
- update();
- if (wrapRef.value) {
- (_a2 = barRef.value) == null ? void 0 : _a2.handleScroll(wrapRef.value);
- }
- });
- });
- provide(scrollbarContextKey, reactive({
- scrollbarElement: scrollbarRef,
- wrapElement: wrapRef
- }));
- onMounted(() => {
- if (!props.native)
- nextTick(() => {
- update();
- });
- });
- onUpdated(() => update());
- expose({
- wrapRef,
- update,
- scrollTo,
- setScrollTop,
- setScrollLeft,
- handleScroll
- });
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", {
- ref_key: "scrollbarRef",
- ref: scrollbarRef,
- class: normalizeClass(unref(ns).b())
- }, [
- createElementVNode("div", {
- ref_key: "wrapRef",
- ref: wrapRef,
- class: normalizeClass(unref(wrapKls)),
- style: normalizeStyle(unref(style)),
- onScroll: handleScroll
- }, [
- (openBlock(), createBlock(resolveDynamicComponent(_ctx.tag), {
- ref_key: "resizeRef",
- ref: resizeRef,
- class: normalizeClass(unref(resizeKls)),
- style: normalizeStyle(_ctx.viewStyle)
- }, {
- default: withCtx(() => [
- renderSlot(_ctx.$slots, "default")
- ]),
- _: 3
- }, 8, ["class", "style"]))
- ], 38),
- !_ctx.native ? (openBlock(), createBlock(Bar, {
- key: 0,
- ref_key: "barRef",
- ref: barRef,
- height: sizeHeight.value,
- width: sizeWidth.value,
- always: _ctx.always,
- "ratio-x": ratioX.value,
- "ratio-y": ratioY.value
- }, null, 8, ["height", "width", "always", "ratio-x", "ratio-y"])) : createCommentVNode("v-if", true)
- ], 2);
- };
- }
- });
- var Scrollbar = /* @__PURE__ */ _export_sfc$1(_sfc_main$x, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/scrollbar/src/scrollbar.vue"]]);
- const ElScrollbar = withInstall(Scrollbar);
- const POPPER_INJECTION_KEY = Symbol("popper");
- const POPPER_CONTENT_INJECTION_KEY = Symbol("popperContent");
- const roleTypes = [
- "dialog",
- "grid",
- "group",
- "listbox",
- "menu",
- "navigation",
- "tooltip",
- "tree"
- ];
- const popperProps = buildProps({
- role: {
- type: String,
- values: roleTypes,
- default: "tooltip"
- }
- });
- const __default__$l = defineComponent({
- name: "ElPopper",
- inheritAttrs: false
- });
- const _sfc_main$w = /* @__PURE__ */ defineComponent({
- ...__default__$l,
- props: popperProps,
- setup(__props, { expose }) {
- const props = __props;
- const triggerRef2 = ref();
- const popperInstanceRef = ref();
- const contentRef = ref();
- const referenceRef = ref();
- const role = computed$1(() => props.role);
- const popperProvides = {
- triggerRef: triggerRef2,
- popperInstanceRef,
- contentRef,
- referenceRef,
- role
- };
- expose(popperProvides);
- provide(POPPER_INJECTION_KEY, popperProvides);
- return (_ctx, _cache) => {
- return renderSlot(_ctx.$slots, "default");
- };
- }
- });
- var Popper = /* @__PURE__ */ _export_sfc$1(_sfc_main$w, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/popper/src/popper.vue"]]);
- const popperArrowProps = buildProps({
- arrowOffset: {
- type: Number,
- default: 5
- }
- });
- const __default__$k = defineComponent({
- name: "ElPopperArrow",
- inheritAttrs: false
- });
- const _sfc_main$v = /* @__PURE__ */ defineComponent({
- ...__default__$k,
- props: popperArrowProps,
- setup(__props, { expose }) {
- const props = __props;
- const ns = useNamespace("popper");
- const { arrowOffset, arrowRef, arrowStyle } = inject(POPPER_CONTENT_INJECTION_KEY, void 0);
- watch(() => props.arrowOffset, (val) => {
- arrowOffset.value = val;
- });
- onBeforeUnmount(() => {
- arrowRef.value = void 0;
- });
- expose({
- arrowRef
- });
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("span", {
- ref_key: "arrowRef",
- ref: arrowRef,
- class: normalizeClass(unref(ns).e("arrow")),
- style: normalizeStyle(unref(arrowStyle)),
- "data-popper-arrow": ""
- }, null, 6);
- };
- }
- });
- var ElPopperArrow = /* @__PURE__ */ _export_sfc$1(_sfc_main$v, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/popper/src/arrow.vue"]]);
- const NAME = "ElOnlyChild";
- const OnlyChild = defineComponent({
- name: NAME,
- setup(_, {
- slots,
- attrs
- }) {
- var _a2;
- const forwardRefInjection = inject(FORWARD_REF_INJECTION_KEY);
- const forwardRefDirective = useForwardRefDirective((_a2 = forwardRefInjection == null ? void 0 : forwardRefInjection.setForwardRef) != null ? _a2 : NOOP);
- return () => {
- var _a22;
- const defaultSlot = (_a22 = slots.default) == null ? void 0 : _a22.call(slots, attrs);
- if (!defaultSlot)
- return null;
- if (defaultSlot.length > 1) {
- return null;
- }
- const firstLegitNode = findFirstLegitChild(defaultSlot);
- if (!firstLegitNode) {
- return null;
- }
- return withDirectives(cloneVNode(firstLegitNode, attrs), [[forwardRefDirective]]);
- };
- }
- });
- function findFirstLegitChild(node) {
- if (!node)
- return null;
- const children = node;
- for (const child of children) {
- if (isObject$5(child)) {
- switch (child.type) {
- case Comment$1:
- continue;
- case Text$1:
- case "svg":
- return wrapTextContent(child);
- case Fragment:
- return findFirstLegitChild(child.children);
- default:
- return child;
- }
- }
- return wrapTextContent(child);
- }
- return null;
- }
- function wrapTextContent(s) {
- const ns = useNamespace("only-child");
- return createVNode("span", {
- "class": ns.e("content")
- }, [s]);
- }
- const popperTriggerProps = buildProps({
- virtualRef: {
- type: definePropType(Object)
- },
- virtualTriggering: Boolean,
- onMouseenter: {
- type: definePropType(Function)
- },
- onMouseleave: {
- type: definePropType(Function)
- },
- onClick: {
- type: definePropType(Function)
- },
- onKeydown: {
- type: definePropType(Function)
- },
- onFocus: {
- type: definePropType(Function)
- },
- onBlur: {
- type: definePropType(Function)
- },
- onContextmenu: {
- type: definePropType(Function)
- },
- id: String,
- open: Boolean
- });
- const __default__$j = defineComponent({
- name: "ElPopperTrigger",
- inheritAttrs: false
- });
- const _sfc_main$u = /* @__PURE__ */ defineComponent({
- ...__default__$j,
- props: popperTriggerProps,
- setup(__props, { expose }) {
- const props = __props;
- const { role, triggerRef: triggerRef2 } = inject(POPPER_INJECTION_KEY, void 0);
- useForwardRef(triggerRef2);
- const ariaControls = computed$1(() => {
- return ariaHaspopup.value ? props.id : void 0;
- });
- const ariaDescribedby = computed$1(() => {
- if (role && role.value === "tooltip") {
- return props.open && props.id ? props.id : void 0;
- }
- return void 0;
- });
- const ariaHaspopup = computed$1(() => {
- if (role && role.value !== "tooltip") {
- return role.value;
- }
- return void 0;
- });
- const ariaExpanded = computed$1(() => {
- return ariaHaspopup.value ? `${props.open}` : void 0;
- });
- let virtualTriggerAriaStopWatch = void 0;
- onMounted(() => {
- watch(() => props.virtualRef, (virtualEl) => {
- if (virtualEl) {
- triggerRef2.value = unrefElement(virtualEl);
- }
- }, {
- immediate: true
- });
- watch(triggerRef2, (el, prevEl) => {
- virtualTriggerAriaStopWatch == null ? void 0 : virtualTriggerAriaStopWatch();
- virtualTriggerAriaStopWatch = void 0;
- if (isElement(el)) {
- [
- "onMouseenter",
- "onMouseleave",
- "onClick",
- "onKeydown",
- "onFocus",
- "onBlur",
- "onContextmenu"
- ].forEach((eventName) => {
- var _a2;
- const handler = props[eventName];
- if (handler) {
- el.addEventListener(eventName.slice(2).toLowerCase(), handler);
- (_a2 = prevEl == null ? void 0 : prevEl.removeEventListener) == null ? void 0 : _a2.call(prevEl, eventName.slice(2).toLowerCase(), handler);
- }
- });
- virtualTriggerAriaStopWatch = watch([ariaControls, ariaDescribedby, ariaHaspopup, ariaExpanded], (watches) => {
- [
- "aria-controls",
- "aria-describedby",
- "aria-haspopup",
- "aria-expanded"
- ].forEach((key, idx) => {
- isNil(watches[idx]) ? el.removeAttribute(key) : el.setAttribute(key, watches[idx]);
- });
- }, { immediate: true });
- }
- if (isElement(prevEl)) {
- [
- "aria-controls",
- "aria-describedby",
- "aria-haspopup",
- "aria-expanded"
- ].forEach((key) => prevEl.removeAttribute(key));
- }
- }, {
- immediate: true
- });
- });
- onBeforeUnmount(() => {
- virtualTriggerAriaStopWatch == null ? void 0 : virtualTriggerAriaStopWatch();
- virtualTriggerAriaStopWatch = void 0;
- });
- expose({
- triggerRef: triggerRef2
- });
- return (_ctx, _cache) => {
- return !_ctx.virtualTriggering ? (openBlock(), createBlock(unref(OnlyChild), mergeProps({ key: 0 }, _ctx.$attrs, {
- "aria-controls": unref(ariaControls),
- "aria-describedby": unref(ariaDescribedby),
- "aria-expanded": unref(ariaExpanded),
- "aria-haspopup": unref(ariaHaspopup)
- }), {
- default: withCtx(() => [
- renderSlot(_ctx.$slots, "default")
- ]),
- _: 3
- }, 16, ["aria-controls", "aria-describedby", "aria-expanded", "aria-haspopup"])) : createCommentVNode("v-if", true);
- };
- }
- });
- var ElPopperTrigger = /* @__PURE__ */ _export_sfc$1(_sfc_main$u, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/popper/src/trigger.vue"]]);
- const FOCUS_AFTER_TRAPPED = "focus-trap.focus-after-trapped";
- const FOCUS_AFTER_RELEASED = "focus-trap.focus-after-released";
- const FOCUSOUT_PREVENTED = "focus-trap.focusout-prevented";
- const FOCUS_AFTER_TRAPPED_OPTS = {
- cancelable: true,
- bubbles: false
- };
- const FOCUSOUT_PREVENTED_OPTS = {
- cancelable: true,
- bubbles: false
- };
- const ON_TRAP_FOCUS_EVT = "focusAfterTrapped";
- const ON_RELEASE_FOCUS_EVT = "focusAfterReleased";
- const FOCUS_TRAP_INJECTION_KEY = Symbol("elFocusTrap");
- const focusReason = ref();
- const lastUserFocusTimestamp = ref(0);
- const lastAutomatedFocusTimestamp = ref(0);
- let focusReasonUserCount = 0;
- const obtainAllFocusableElements = (element) => {
- const nodes = [];
- const walker = document.createTreeWalker(element, NodeFilter.SHOW_ELEMENT, {
- acceptNode: (node) => {
- const isHiddenInput = node.tagName === "INPUT" && node.type === "hidden";
- if (node.disabled || node.hidden || isHiddenInput)
- return NodeFilter.FILTER_SKIP;
- return node.tabIndex >= 0 || node === document.activeElement ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP;
- }
- });
- while (walker.nextNode())
- nodes.push(walker.currentNode);
- return nodes;
- };
- const getVisibleElement = (elements, container) => {
- for (const element of elements) {
- if (!isHidden(element, container))
- return element;
- }
- };
- const isHidden = (element, container) => {
- if (getComputedStyle(element).visibility === "hidden")
- return true;
- while (element) {
- if (container && element === container)
- return false;
- if (getComputedStyle(element).display === "none")
- return true;
- element = element.parentElement;
- }
- return false;
- };
- const getEdges = (container) => {
- const focusable = obtainAllFocusableElements(container);
- const first = getVisibleElement(focusable, container);
- const last = getVisibleElement(focusable.reverse(), container);
- return [first, last];
- };
- const isSelectable = (element) => {
- return element instanceof HTMLInputElement && "select" in element;
- };
- const tryFocus = (element, shouldSelect) => {
- if (element && element.focus) {
- const prevFocusedElement = document.activeElement;
- element.focus({ preventScroll: true });
- lastAutomatedFocusTimestamp.value = window.performance.now();
- if (element !== prevFocusedElement && isSelectable(element) && shouldSelect) {
- element.select();
- }
- }
- };
- function removeFromStack(list, item) {
- const copy2 = [...list];
- const idx = list.indexOf(item);
- if (idx !== -1) {
- copy2.splice(idx, 1);
- }
- return copy2;
- }
- const createFocusableStack = () => {
- let stack = [];
- const push = (layer) => {
- const currentLayer = stack[0];
- if (currentLayer && layer !== currentLayer) {
- currentLayer.pause();
- }
- stack = removeFromStack(stack, layer);
- stack.unshift(layer);
- };
- const remove2 = (layer) => {
- var _a2, _b;
- stack = removeFromStack(stack, layer);
- (_b = (_a2 = stack[0]) == null ? void 0 : _a2.resume) == null ? void 0 : _b.call(_a2);
- };
- return {
- push,
- remove: remove2
- };
- };
- const focusFirstDescendant = (elements, shouldSelect = false) => {
- const prevFocusedElement = document.activeElement;
- for (const element of elements) {
- tryFocus(element, shouldSelect);
- if (document.activeElement !== prevFocusedElement)
- return;
- }
- };
- const focusableStack = createFocusableStack();
- const isFocusCausedByUserEvent = () => {
- return lastUserFocusTimestamp.value > lastAutomatedFocusTimestamp.value;
- };
- const notifyFocusReasonPointer = () => {
- focusReason.value = "pointer";
- lastUserFocusTimestamp.value = window.performance.now();
- };
- const notifyFocusReasonKeydown = () => {
- focusReason.value = "keyboard";
- lastUserFocusTimestamp.value = window.performance.now();
- };
- const useFocusReason = () => {
- onMounted(() => {
- if (focusReasonUserCount === 0) {
- document.addEventListener("mousedown", notifyFocusReasonPointer);
- document.addEventListener("touchstart", notifyFocusReasonPointer);
- document.addEventListener("keydown", notifyFocusReasonKeydown);
- }
- focusReasonUserCount++;
- });
- onBeforeUnmount(() => {
- focusReasonUserCount--;
- if (focusReasonUserCount <= 0) {
- document.removeEventListener("mousedown", notifyFocusReasonPointer);
- document.removeEventListener("touchstart", notifyFocusReasonPointer);
- document.removeEventListener("keydown", notifyFocusReasonKeydown);
- }
- });
- return {
- focusReason,
- lastUserFocusTimestamp,
- lastAutomatedFocusTimestamp
- };
- };
- const createFocusOutPreventedEvent = (detail) => {
- return new CustomEvent(FOCUSOUT_PREVENTED, {
- ...FOCUSOUT_PREVENTED_OPTS,
- detail
- });
- };
- const _sfc_main$t = defineComponent({
- name: "ElFocusTrap",
- inheritAttrs: false,
- props: {
- loop: Boolean,
- trapped: Boolean,
- focusTrapEl: Object,
- focusStartEl: {
- type: [Object, String],
- default: "first"
- }
- },
- emits: [
- ON_TRAP_FOCUS_EVT,
- ON_RELEASE_FOCUS_EVT,
- "focusin",
- "focusout",
- "focusout-prevented",
- "release-requested"
- ],
- setup(props, { emit }) {
- const forwardRef = ref();
- let lastFocusBeforeTrapped;
- let lastFocusAfterTrapped;
- const { focusReason: focusReason2 } = useFocusReason();
- useEscapeKeydown((event2) => {
- if (props.trapped && !focusLayer.paused) {
- emit("release-requested", event2);
- }
- });
- const focusLayer = {
- paused: false,
- pause() {
- this.paused = true;
- },
- resume() {
- this.paused = false;
- }
- };
- const onKeydown = (e) => {
- if (!props.loop && !props.trapped)
- return;
- if (focusLayer.paused)
- return;
- const { key, altKey, ctrlKey, metaKey, currentTarget, shiftKey } = e;
- const { loop } = props;
- const isTabbing = key === EVENT_CODE.tab && !altKey && !ctrlKey && !metaKey;
- const currentFocusingEl = document.activeElement;
- if (isTabbing && currentFocusingEl) {
- const container = currentTarget;
- const [first, last] = getEdges(container);
- const isTabbable = first && last;
- if (!isTabbable) {
- if (currentFocusingEl === container) {
- const focusoutPreventedEvent = createFocusOutPreventedEvent({
- focusReason: focusReason2.value
- });
- emit("focusout-prevented", focusoutPreventedEvent);
- if (!focusoutPreventedEvent.defaultPrevented) {
- e.preventDefault();
- }
- }
- } else {
- if (!shiftKey && currentFocusingEl === last) {
- const focusoutPreventedEvent = createFocusOutPreventedEvent({
- focusReason: focusReason2.value
- });
- emit("focusout-prevented", focusoutPreventedEvent);
- if (!focusoutPreventedEvent.defaultPrevented) {
- e.preventDefault();
- if (loop)
- tryFocus(first, true);
- }
- } else if (shiftKey && [first, container].includes(currentFocusingEl)) {
- const focusoutPreventedEvent = createFocusOutPreventedEvent({
- focusReason: focusReason2.value
- });
- emit("focusout-prevented", focusoutPreventedEvent);
- if (!focusoutPreventedEvent.defaultPrevented) {
- e.preventDefault();
- if (loop)
- tryFocus(last, true);
- }
- }
- }
- }
- };
- provide(FOCUS_TRAP_INJECTION_KEY, {
- focusTrapRef: forwardRef,
- onKeydown
- });
- watch(() => props.focusTrapEl, (focusTrapEl) => {
- if (focusTrapEl) {
- forwardRef.value = focusTrapEl;
- }
- }, { immediate: true });
- watch([forwardRef], ([forwardRef2], [oldForwardRef]) => {
- if (forwardRef2) {
- forwardRef2.addEventListener("keydown", onKeydown);
- forwardRef2.addEventListener("focusin", onFocusIn);
- forwardRef2.addEventListener("focusout", onFocusOut);
- }
- if (oldForwardRef) {
- oldForwardRef.removeEventListener("keydown", onKeydown);
- oldForwardRef.removeEventListener("focusin", onFocusIn);
- oldForwardRef.removeEventListener("focusout", onFocusOut);
- }
- });
- const trapOnFocus = (e) => {
- emit(ON_TRAP_FOCUS_EVT, e);
- };
- const releaseOnFocus = (e) => emit(ON_RELEASE_FOCUS_EVT, e);
- const onFocusIn = (e) => {
- const trapContainer = unref(forwardRef);
- if (!trapContainer)
- return;
- const target = e.target;
- const relatedTarget = e.relatedTarget;
- const isFocusedInTrap = target && trapContainer.contains(target);
- if (!props.trapped) {
- const isPrevFocusedInTrap = relatedTarget && trapContainer.contains(relatedTarget);
- if (!isPrevFocusedInTrap) {
- lastFocusBeforeTrapped = relatedTarget;
- }
- }
- if (isFocusedInTrap)
- emit("focusin", e);
- if (focusLayer.paused)
- return;
- if (props.trapped) {
- if (isFocusedInTrap) {
- lastFocusAfterTrapped = target;
- } else {
- tryFocus(lastFocusAfterTrapped, true);
- }
- }
- };
- const onFocusOut = (e) => {
- const trapContainer = unref(forwardRef);
- if (focusLayer.paused || !trapContainer)
- return;
- if (props.trapped) {
- const relatedTarget = e.relatedTarget;
- if (!isNil(relatedTarget) && !trapContainer.contains(relatedTarget)) {
- setTimeout(() => {
- if (!focusLayer.paused && props.trapped) {
- const focusoutPreventedEvent = createFocusOutPreventedEvent({
- focusReason: focusReason2.value
- });
- emit("focusout-prevented", focusoutPreventedEvent);
- if (!focusoutPreventedEvent.defaultPrevented) {
- tryFocus(lastFocusAfterTrapped, true);
- }
- }
- }, 0);
- }
- } else {
- const target = e.target;
- const isFocusedInTrap = target && trapContainer.contains(target);
- if (!isFocusedInTrap)
- emit("focusout", e);
- }
- };
- async function startTrap() {
- await nextTick();
- const trapContainer = unref(forwardRef);
- if (trapContainer) {
- focusableStack.push(focusLayer);
- const prevFocusedElement = trapContainer.contains(document.activeElement) ? lastFocusBeforeTrapped : document.activeElement;
- lastFocusBeforeTrapped = prevFocusedElement;
- const isPrevFocusContained = trapContainer.contains(prevFocusedElement);
- if (!isPrevFocusContained) {
- const focusEvent = new Event(FOCUS_AFTER_TRAPPED, FOCUS_AFTER_TRAPPED_OPTS);
- trapContainer.addEventListener(FOCUS_AFTER_TRAPPED, trapOnFocus);
- trapContainer.dispatchEvent(focusEvent);
- if (!focusEvent.defaultPrevented) {
- nextTick(() => {
- let focusStartEl = props.focusStartEl;
- if (!isString(focusStartEl)) {
- tryFocus(focusStartEl);
- if (document.activeElement !== focusStartEl) {
- focusStartEl = "first";
- }
- }
- if (focusStartEl === "first") {
- focusFirstDescendant(obtainAllFocusableElements(trapContainer), true);
- }
- if (document.activeElement === prevFocusedElement || focusStartEl === "container") {
- tryFocus(trapContainer);
- }
- });
- }
- }
- }
- }
- function stopTrap() {
- const trapContainer = unref(forwardRef);
- if (trapContainer) {
- trapContainer.removeEventListener(FOCUS_AFTER_TRAPPED, trapOnFocus);
- const releasedEvent = new CustomEvent(FOCUS_AFTER_RELEASED, {
- ...FOCUS_AFTER_TRAPPED_OPTS,
- detail: {
- focusReason: focusReason2.value
- }
- });
- trapContainer.addEventListener(FOCUS_AFTER_RELEASED, releaseOnFocus);
- trapContainer.dispatchEvent(releasedEvent);
- if (!releasedEvent.defaultPrevented && (focusReason2.value == "keyboard" || !isFocusCausedByUserEvent() || trapContainer.contains(document.activeElement))) {
- tryFocus(lastFocusBeforeTrapped != null ? lastFocusBeforeTrapped : document.body);
- }
- trapContainer.removeEventListener(FOCUS_AFTER_RELEASED, trapOnFocus);
- focusableStack.remove(focusLayer);
- }
- }
- onMounted(() => {
- if (props.trapped) {
- startTrap();
- }
- watch(() => props.trapped, (trapped) => {
- if (trapped) {
- startTrap();
- } else {
- stopTrap();
- }
- });
- });
- onBeforeUnmount(() => {
- if (props.trapped) {
- stopTrap();
- }
- });
- return {
- onKeydown
- };
- }
- });
- function _sfc_render$7(_ctx, _cache, $props, $setup, $data, $options) {
- return renderSlot(_ctx.$slots, "default", { handleKeydown: _ctx.onKeydown });
- }
- var ElFocusTrap = /* @__PURE__ */ _export_sfc$1(_sfc_main$t, [["render", _sfc_render$7], ["__file", "/home/runner/work/element-plus/element-plus/packages/components/focus-trap/src/focus-trap.vue"]]);
- const POSITIONING_STRATEGIES = ["fixed", "absolute"];
- const popperCoreConfigProps = buildProps({
- boundariesPadding: {
- type: Number,
- default: 0
- },
- fallbackPlacements: {
- type: definePropType(Array),
- default: void 0
- },
- gpuAcceleration: {
- type: Boolean,
- default: true
- },
- offset: {
- type: Number,
- default: 12
- },
- placement: {
- type: String,
- values: Ee,
- default: "bottom"
- },
- popperOptions: {
- type: definePropType(Object),
- default: () => ({})
- },
- strategy: {
- type: String,
- values: POSITIONING_STRATEGIES,
- default: "absolute"
- }
- });
- const popperContentProps = buildProps({
- ...popperCoreConfigProps,
- id: String,
- style: {
- type: definePropType([String, Array, Object])
- },
- className: {
- type: definePropType([String, Array, Object])
- },
- effect: {
- type: String,
- default: "dark"
- },
- visible: Boolean,
- enterable: {
- type: Boolean,
- default: true
- },
- pure: Boolean,
- focusOnShow: {
- type: Boolean,
- default: false
- },
- trapping: {
- type: Boolean,
- default: false
- },
- popperClass: {
- type: definePropType([String, Array, Object])
- },
- popperStyle: {
- type: definePropType([String, Array, Object])
- },
- referenceEl: {
- type: definePropType(Object)
- },
- triggerTargetEl: {
- type: definePropType(Object)
- },
- stopPopperMouseEvent: {
- type: Boolean,
- default: true
- },
- ariaLabel: {
- type: String,
- default: void 0
- },
- virtualTriggering: Boolean,
- zIndex: Number
- });
- const popperContentEmits = {
- mouseenter: (evt) => evt instanceof MouseEvent,
- mouseleave: (evt) => evt instanceof MouseEvent,
- focus: () => true,
- blur: () => true,
- close: () => true
- };
- const buildPopperOptions = (props, modifiers = []) => {
- const { placement, strategy, popperOptions } = props;
- const options2 = {
- placement,
- strategy,
- ...popperOptions,
- modifiers: [...genModifiers(props), ...modifiers]
- };
- deriveExtraModifiers(options2, popperOptions == null ? void 0 : popperOptions.modifiers);
- return options2;
- };
- const unwrapMeasurableEl = ($el) => {
- if (!isClient)
- return;
- return unrefElement($el);
- };
- function genModifiers(options2) {
- const { offset, gpuAcceleration, fallbackPlacements } = options2;
- return [
- {
- name: "offset",
- options: {
- offset: [0, offset != null ? offset : 12]
- }
- },
- {
- name: "preventOverflow",
- options: {
- padding: {
- top: 2,
- bottom: 2,
- left: 5,
- right: 5
- }
- }
- },
- {
- name: "flip",
- options: {
- padding: 5,
- fallbackPlacements
- }
- },
- {
- name: "computeStyles",
- options: {
- gpuAcceleration
- }
- }
- ];
- }
- function deriveExtraModifiers(options2, modifiers) {
- if (modifiers) {
- options2.modifiers = [...options2.modifiers, ...modifiers != null ? modifiers : []];
- }
- }
- const DEFAULT_ARROW_OFFSET = 0;
- const usePopperContent = (props) => {
- const { popperInstanceRef, contentRef, triggerRef: triggerRef2, role } = inject(POPPER_INJECTION_KEY, void 0);
- const arrowRef = ref();
- const arrowOffset = ref();
- const eventListenerModifier = computed$1(() => {
- return {
- name: "eventListeners",
- enabled: !!props.visible
- };
- });
- const arrowModifier = computed$1(() => {
- var _a2;
- const arrowEl = unref(arrowRef);
- const offset = (_a2 = unref(arrowOffset)) != null ? _a2 : DEFAULT_ARROW_OFFSET;
- return {
- name: "arrow",
- enabled: !isUndefined$1(arrowEl),
- options: {
- element: arrowEl,
- padding: offset
- }
- };
- });
- const options2 = computed$1(() => {
- return {
- onFirstUpdate: () => {
- update();
- },
- ...buildPopperOptions(props, [
- unref(arrowModifier),
- unref(eventListenerModifier)
- ])
- };
- });
- const computedReference = computed$1(() => unwrapMeasurableEl(props.referenceEl) || unref(triggerRef2));
- const { attributes, state, styles, update, forceUpdate, instanceRef } = usePopper(computedReference, contentRef, options2);
- watch(instanceRef, (instance) => popperInstanceRef.value = instance);
- onMounted(() => {
- watch(() => {
- var _a2;
- return (_a2 = unref(computedReference)) == null ? void 0 : _a2.getBoundingClientRect();
- }, () => {
- update();
- });
- });
- return {
- attributes,
- arrowRef,
- contentRef,
- instanceRef,
- state,
- styles,
- role,
- forceUpdate,
- update
- };
- };
- const usePopperContentDOM = (props, {
- attributes,
- styles,
- role
- }) => {
- const { nextZIndex } = useZIndex();
- const ns = useNamespace("popper");
- const contentAttrs = computed$1(() => unref(attributes).popper);
- const contentZIndex = ref(props.zIndex || nextZIndex());
- const contentClass = computed$1(() => [
- ns.b(),
- ns.is("pure", props.pure),
- ns.is(props.effect),
- props.popperClass
- ]);
- const contentStyle = computed$1(() => {
- return [
- { zIndex: unref(contentZIndex) },
- props.popperStyle || {},
- unref(styles).popper
- ];
- });
- const ariaModal = computed$1(() => role.value === "dialog" ? "false" : void 0);
- const arrowStyle = computed$1(() => unref(styles).arrow || {});
- const updateZIndex = () => {
- contentZIndex.value = props.zIndex || nextZIndex();
- };
- return {
- ariaModal,
- arrowStyle,
- contentAttrs,
- contentClass,
- contentStyle,
- contentZIndex,
- updateZIndex
- };
- };
- const usePopperContentFocusTrap = (props, emit) => {
- const trapped = ref(false);
- const focusStartRef = ref();
- const onFocusAfterTrapped = () => {
- emit("focus");
- };
- const onFocusAfterReleased = (event2) => {
- var _a2;
- if (((_a2 = event2.detail) == null ? void 0 : _a2.focusReason) !== "pointer") {
- focusStartRef.value = "first";
- emit("blur");
- }
- };
- const onFocusInTrap = (event2) => {
- if (props.visible && !trapped.value) {
- if (event2.target) {
- focusStartRef.value = event2.target;
- }
- trapped.value = true;
- }
- };
- const onFocusoutPrevented = (event2) => {
- if (!props.trapping) {
- if (event2.detail.focusReason === "pointer") {
- event2.preventDefault();
- }
- trapped.value = false;
- }
- };
- const onReleaseRequested = () => {
- trapped.value = false;
- emit("close");
- };
- return {
- focusStartRef,
- trapped,
- onFocusAfterReleased,
- onFocusAfterTrapped,
- onFocusInTrap,
- onFocusoutPrevented,
- onReleaseRequested
- };
- };
- const __default__$i = defineComponent({
- name: "ElPopperContent"
- });
- const _sfc_main$s = /* @__PURE__ */ defineComponent({
- ...__default__$i,
- props: popperContentProps,
- emits: popperContentEmits,
- setup(__props, { expose, emit }) {
- const props = __props;
- const {
- focusStartRef,
- trapped,
- onFocusAfterReleased,
- onFocusAfterTrapped,
- onFocusInTrap,
- onFocusoutPrevented,
- onReleaseRequested
- } = usePopperContentFocusTrap(props, emit);
- const { attributes, arrowRef, contentRef, styles, instanceRef, role, update } = usePopperContent(props);
- const {
- ariaModal,
- arrowStyle,
- contentAttrs,
- contentClass,
- contentStyle,
- updateZIndex
- } = usePopperContentDOM(props, {
- styles,
- attributes,
- role
- });
- const formItemContext = inject(formItemContextKey, void 0);
- const arrowOffset = ref();
- provide(POPPER_CONTENT_INJECTION_KEY, {
- arrowStyle,
- arrowRef,
- arrowOffset
- });
- if (formItemContext && (formItemContext.addInputId || formItemContext.removeInputId)) {
- provide(formItemContextKey, {
- ...formItemContext,
- addInputId: NOOP,
- removeInputId: NOOP
- });
- }
- let triggerTargetAriaStopWatch = void 0;
- const updatePopper = (shouldUpdateZIndex = true) => {
- update();
- shouldUpdateZIndex && updateZIndex();
- };
- const togglePopperAlive = () => {
- updatePopper(false);
- if (props.visible && props.focusOnShow) {
- trapped.value = true;
- } else if (props.visible === false) {
- trapped.value = false;
- }
- };
- onMounted(() => {
- watch(() => props.triggerTargetEl, (triggerTargetEl, prevTriggerTargetEl) => {
- triggerTargetAriaStopWatch == null ? void 0 : triggerTargetAriaStopWatch();
- triggerTargetAriaStopWatch = void 0;
- const el = unref(triggerTargetEl || contentRef.value);
- const prevEl = unref(prevTriggerTargetEl || contentRef.value);
- if (isElement(el)) {
- triggerTargetAriaStopWatch = watch([role, () => props.ariaLabel, ariaModal, () => props.id], (watches) => {
- ["role", "aria-label", "aria-modal", "id"].forEach((key, idx) => {
- isNil(watches[idx]) ? el.removeAttribute(key) : el.setAttribute(key, watches[idx]);
- });
- }, { immediate: true });
- }
- if (prevEl !== el && isElement(prevEl)) {
- ["role", "aria-label", "aria-modal", "id"].forEach((key) => {
- prevEl.removeAttribute(key);
- });
- }
- }, { immediate: true });
- watch(() => props.visible, togglePopperAlive, { immediate: true });
- });
- onBeforeUnmount(() => {
- triggerTargetAriaStopWatch == null ? void 0 : triggerTargetAriaStopWatch();
- triggerTargetAriaStopWatch = void 0;
- });
- expose({
- popperContentRef: contentRef,
- popperInstanceRef: instanceRef,
- updatePopper,
- contentStyle
- });
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", mergeProps({
- ref_key: "contentRef",
- ref: contentRef
- }, unref(contentAttrs), {
- style: unref(contentStyle),
- class: unref(contentClass),
- tabindex: "-1",
- onMouseenter: _cache[0] || (_cache[0] = (e) => _ctx.$emit("mouseenter", e)),
- onMouseleave: _cache[1] || (_cache[1] = (e) => _ctx.$emit("mouseleave", e))
- }), [
- createVNode(unref(ElFocusTrap), {
- trapped: unref(trapped),
- "trap-on-focus-in": true,
- "focus-trap-el": unref(contentRef),
- "focus-start-el": unref(focusStartRef),
- onFocusAfterTrapped: unref(onFocusAfterTrapped),
- onFocusAfterReleased: unref(onFocusAfterReleased),
- onFocusin: unref(onFocusInTrap),
- onFocusoutPrevented: unref(onFocusoutPrevented),
- onReleaseRequested: unref(onReleaseRequested)
- }, {
- default: withCtx(() => [
- renderSlot(_ctx.$slots, "default")
- ]),
- _: 3
- }, 8, ["trapped", "focus-trap-el", "focus-start-el", "onFocusAfterTrapped", "onFocusAfterReleased", "onFocusin", "onFocusoutPrevented", "onReleaseRequested"])
- ], 16);
- };
- }
- });
- var ElPopperContent = /* @__PURE__ */ _export_sfc$1(_sfc_main$s, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/popper/src/content.vue"]]);
- const ElPopper = withInstall(Popper);
- const TOOLTIP_INJECTION_KEY = Symbol("elTooltip");
- const useTooltipContentProps = buildProps({
- ...useDelayedToggleProps,
- ...popperContentProps,
- appendTo: {
- type: definePropType([String, Object])
- },
- content: {
- type: String,
- default: ""
- },
- rawContent: {
- type: Boolean,
- default: false
- },
- persistent: Boolean,
- ariaLabel: String,
- visible: {
- type: definePropType(Boolean),
- default: null
- },
- transition: String,
- teleported: {
- type: Boolean,
- default: true
- },
- disabled: Boolean
- });
- const useTooltipTriggerProps = buildProps({
- ...popperTriggerProps,
- disabled: Boolean,
- trigger: {
- type: definePropType([String, Array]),
- default: "hover"
- },
- triggerKeys: {
- type: definePropType(Array),
- default: () => [EVENT_CODE.enter, EVENT_CODE.space]
- }
- });
- const {
- useModelToggleProps: useTooltipModelToggleProps,
- useModelToggleEmits: useTooltipModelToggleEmits,
- useModelToggle: useTooltipModelToggle
- } = createModelToggleComposable("visible");
- const useTooltipProps = buildProps({
- ...popperProps,
- ...useTooltipModelToggleProps,
- ...useTooltipContentProps,
- ...useTooltipTriggerProps,
- ...popperArrowProps,
- showArrow: {
- type: Boolean,
- default: true
- }
- });
- const tooltipEmits = [
- ...useTooltipModelToggleEmits,
- "before-show",
- "before-hide",
- "show",
- "hide",
- "open",
- "close"
- ];
- const isTriggerType = (trigger2, type2) => {
- if (isArray$2(trigger2)) {
- return trigger2.includes(type2);
- }
- return trigger2 === type2;
- };
- const whenTrigger = (trigger2, type2, handler) => {
- return (e) => {
- isTriggerType(unref(trigger2), type2) && handler(e);
- };
- };
- const __default__$h = defineComponent({
- name: "ElTooltipTrigger"
- });
- const _sfc_main$r = /* @__PURE__ */ defineComponent({
- ...__default__$h,
- props: useTooltipTriggerProps,
- setup(__props, { expose }) {
- const props = __props;
- const ns = useNamespace("tooltip");
- const { controlled, id, open, onOpen, onClose, onToggle } = inject(TOOLTIP_INJECTION_KEY, void 0);
- const triggerRef2 = ref(null);
- const stopWhenControlledOrDisabled = () => {
- if (unref(controlled) || props.disabled) {
- return true;
- }
- };
- const trigger2 = toRef(props, "trigger");
- const onMouseenter = composeEventHandlers(stopWhenControlledOrDisabled, whenTrigger(trigger2, "hover", onOpen));
- const onMouseleave = composeEventHandlers(stopWhenControlledOrDisabled, whenTrigger(trigger2, "hover", onClose));
- const onClick = composeEventHandlers(stopWhenControlledOrDisabled, whenTrigger(trigger2, "click", (e) => {
- if (e.button === 0) {
- onToggle(e);
- }
- }));
- const onFocus = composeEventHandlers(stopWhenControlledOrDisabled, whenTrigger(trigger2, "focus", onOpen));
- const onBlur = composeEventHandlers(stopWhenControlledOrDisabled, whenTrigger(trigger2, "focus", onClose));
- const onContextMenu = composeEventHandlers(stopWhenControlledOrDisabled, whenTrigger(trigger2, "contextmenu", (e) => {
- e.preventDefault();
- onToggle(e);
- }));
- const onKeydown = composeEventHandlers(stopWhenControlledOrDisabled, (e) => {
- const { code } = e;
- if (props.triggerKeys.includes(code)) {
- e.preventDefault();
- onToggle(e);
- }
- });
- expose({
- triggerRef: triggerRef2
- });
- return (_ctx, _cache) => {
- return openBlock(), createBlock(unref(ElPopperTrigger), {
- id: unref(id),
- "virtual-ref": _ctx.virtualRef,
- open: unref(open),
- "virtual-triggering": _ctx.virtualTriggering,
- class: normalizeClass(unref(ns).e("trigger")),
- onBlur: unref(onBlur),
- onClick: unref(onClick),
- onContextmenu: unref(onContextMenu),
- onFocus: unref(onFocus),
- onMouseenter: unref(onMouseenter),
- onMouseleave: unref(onMouseleave),
- onKeydown: unref(onKeydown)
- }, {
- default: withCtx(() => [
- renderSlot(_ctx.$slots, "default")
- ]),
- _: 3
- }, 8, ["id", "virtual-ref", "open", "virtual-triggering", "class", "onBlur", "onClick", "onContextmenu", "onFocus", "onMouseenter", "onMouseleave", "onKeydown"]);
- };
- }
- });
- var ElTooltipTrigger = /* @__PURE__ */ _export_sfc$1(_sfc_main$r, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/tooltip/src/trigger.vue"]]);
- const __default__$g = defineComponent({
- name: "ElTooltipContent",
- inheritAttrs: false
- });
- const _sfc_main$q = /* @__PURE__ */ defineComponent({
- ...__default__$g,
- props: useTooltipContentProps,
- setup(__props, { expose }) {
- const props = __props;
- const { selector } = usePopperContainerId();
- const ns = useNamespace("tooltip");
- const contentRef = ref(null);
- const destroyed = ref(false);
- const {
- controlled,
- id,
- open,
- trigger: trigger2,
- onClose,
- onOpen,
- onShow,
- onHide,
- onBeforeShow,
- onBeforeHide
- } = inject(TOOLTIP_INJECTION_KEY, void 0);
- const transitionClass = computed$1(() => {
- return props.transition || `${ns.namespace.value}-fade-in-linear`;
- });
- const persistentRef = computed$1(() => {
- return props.persistent;
- });
- onBeforeUnmount(() => {
- destroyed.value = true;
- });
- const shouldRender = computed$1(() => {
- return unref(persistentRef) ? true : unref(open);
- });
- const shouldShow = computed$1(() => {
- return props.disabled ? false : unref(open);
- });
- const appendTo = computed$1(() => {
- return props.appendTo || selector.value;
- });
- const contentStyle = computed$1(() => {
- var _a2;
- return (_a2 = props.style) != null ? _a2 : {};
- });
- const ariaHidden = computed$1(() => !unref(open));
- const onTransitionLeave = () => {
- onHide();
- };
- const stopWhenControlled = () => {
- if (unref(controlled))
- return true;
- };
- const onContentEnter = composeEventHandlers(stopWhenControlled, () => {
- if (props.enterable && unref(trigger2) === "hover") {
- onOpen();
- }
- });
- const onContentLeave = composeEventHandlers(stopWhenControlled, () => {
- if (unref(trigger2) === "hover") {
- onClose();
- }
- });
- const onBeforeEnter = () => {
- var _a2, _b;
- (_b = (_a2 = contentRef.value) == null ? void 0 : _a2.updatePopper) == null ? void 0 : _b.call(_a2);
- onBeforeShow == null ? void 0 : onBeforeShow();
- };
- const onBeforeLeave = () => {
- onBeforeHide == null ? void 0 : onBeforeHide();
- };
- const onAfterShow = () => {
- onShow();
- stopHandle = onClickOutside(computed$1(() => {
- var _a2;
- return (_a2 = contentRef.value) == null ? void 0 : _a2.popperContentRef;
- }), () => {
- if (unref(controlled))
- return;
- const $trigger = unref(trigger2);
- if ($trigger !== "hover") {
- onClose();
- }
- });
- };
- const onBlur = () => {
- if (!props.virtualTriggering) {
- onClose();
- }
- };
- let stopHandle;
- watch(() => unref(open), (val) => {
- if (!val) {
- stopHandle == null ? void 0 : stopHandle();
- }
- }, {
- flush: "post"
- });
- watch(() => props.content, () => {
- var _a2, _b;
- (_b = (_a2 = contentRef.value) == null ? void 0 : _a2.updatePopper) == null ? void 0 : _b.call(_a2);
- });
- expose({
- contentRef
- });
- return (_ctx, _cache) => {
- return openBlock(), createBlock(Teleport, {
- disabled: !_ctx.teleported,
- to: unref(appendTo)
- }, [
- createVNode(Transition, {
- name: unref(transitionClass),
- onAfterLeave: onTransitionLeave,
- onBeforeEnter,
- onAfterEnter: onAfterShow,
- onBeforeLeave
- }, {
- default: withCtx(() => [
- unref(shouldRender) ? withDirectives((openBlock(), createBlock(unref(ElPopperContent), mergeProps({
- key: 0,
- id: unref(id),
- ref_key: "contentRef",
- ref: contentRef
- }, _ctx.$attrs, {
- "aria-label": _ctx.ariaLabel,
- "aria-hidden": unref(ariaHidden),
- "boundaries-padding": _ctx.boundariesPadding,
- "fallback-placements": _ctx.fallbackPlacements,
- "gpu-acceleration": _ctx.gpuAcceleration,
- offset: _ctx.offset,
- placement: _ctx.placement,
- "popper-options": _ctx.popperOptions,
- strategy: _ctx.strategy,
- effect: _ctx.effect,
- enterable: _ctx.enterable,
- pure: _ctx.pure,
- "popper-class": _ctx.popperClass,
- "popper-style": [_ctx.popperStyle, unref(contentStyle)],
- "reference-el": _ctx.referenceEl,
- "trigger-target-el": _ctx.triggerTargetEl,
- visible: unref(shouldShow),
- "z-index": _ctx.zIndex,
- onMouseenter: unref(onContentEnter),
- onMouseleave: unref(onContentLeave),
- onBlur,
- onClose: unref(onClose)
- }), {
- default: withCtx(() => [
- !destroyed.value ? renderSlot(_ctx.$slots, "default", { key: 0 }) : createCommentVNode("v-if", true)
- ]),
- _: 3
- }, 16, ["id", "aria-label", "aria-hidden", "boundaries-padding", "fallback-placements", "gpu-acceleration", "offset", "placement", "popper-options", "strategy", "effect", "enterable", "pure", "popper-class", "popper-style", "reference-el", "trigger-target-el", "visible", "z-index", "onMouseenter", "onMouseleave", "onClose"])), [
- [vShow, unref(shouldShow)]
- ]) : createCommentVNode("v-if", true)
- ]),
- _: 3
- }, 8, ["name"])
- ], 8, ["disabled", "to"]);
- };
- }
- });
- var ElTooltipContent = /* @__PURE__ */ _export_sfc$1(_sfc_main$q, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/tooltip/src/content.vue"]]);
- const _hoisted_1$f = ["innerHTML"];
- const _hoisted_2$9 = { key: 1 };
- const __default__$f = defineComponent({
- name: "ElTooltip"
- });
- const _sfc_main$p = /* @__PURE__ */ defineComponent({
- ...__default__$f,
- props: useTooltipProps,
- emits: tooltipEmits,
- setup(__props, { expose, emit }) {
- const props = __props;
- usePopperContainer();
- const id = useId();
- const popperRef = ref();
- const contentRef = ref();
- const updatePopper = () => {
- var _a2;
- const popperComponent = unref(popperRef);
- if (popperComponent) {
- (_a2 = popperComponent.popperInstanceRef) == null ? void 0 : _a2.update();
- }
- };
- const open = ref(false);
- const toggleReason = ref();
- const { show, hide, hasUpdateHandler } = useTooltipModelToggle({
- indicator: open,
- toggleReason
- });
- const { onOpen, onClose } = useDelayedToggle({
- showAfter: toRef(props, "showAfter"),
- hideAfter: toRef(props, "hideAfter"),
- autoClose: toRef(props, "autoClose"),
- open: show,
- close: hide
- });
- const controlled = computed$1(() => isBoolean(props.visible) && !hasUpdateHandler.value);
- provide(TOOLTIP_INJECTION_KEY, {
- controlled,
- id,
- open: readonly(open),
- trigger: toRef(props, "trigger"),
- onOpen: (event2) => {
- onOpen(event2);
- },
- onClose: (event2) => {
- onClose(event2);
- },
- onToggle: (event2) => {
- if (unref(open)) {
- onClose(event2);
- } else {
- onOpen(event2);
- }
- },
- onShow: () => {
- emit("show", toggleReason.value);
- },
- onHide: () => {
- emit("hide", toggleReason.value);
- },
- onBeforeShow: () => {
- emit("before-show", toggleReason.value);
- },
- onBeforeHide: () => {
- emit("before-hide", toggleReason.value);
- },
- updatePopper
- });
- watch(() => props.disabled, (disabled) => {
- if (disabled && open.value) {
- open.value = false;
- }
- });
- const isFocusInsideContent = () => {
- var _a2, _b;
- const popperContent = (_b = (_a2 = contentRef.value) == null ? void 0 : _a2.contentRef) == null ? void 0 : _b.popperContentRef;
- return popperContent && popperContent.contains(document.activeElement);
- };
- onDeactivated(() => open.value && hide());
- expose({
- popperRef,
- contentRef,
- isFocusInsideContent,
- updatePopper,
- onOpen,
- onClose,
- hide
- });
- return (_ctx, _cache) => {
- return openBlock(), createBlock(unref(ElPopper), {
- ref_key: "popperRef",
- ref: popperRef,
- role: _ctx.role
- }, {
- default: withCtx(() => [
- createVNode(ElTooltipTrigger, {
- disabled: _ctx.disabled,
- trigger: _ctx.trigger,
- "trigger-keys": _ctx.triggerKeys,
- "virtual-ref": _ctx.virtualRef,
- "virtual-triggering": _ctx.virtualTriggering
- }, {
- default: withCtx(() => [
- _ctx.$slots.default ? renderSlot(_ctx.$slots, "default", { key: 0 }) : createCommentVNode("v-if", true)
- ]),
- _: 3
- }, 8, ["disabled", "trigger", "trigger-keys", "virtual-ref", "virtual-triggering"]),
- createVNode(ElTooltipContent, {
- ref_key: "contentRef",
- ref: contentRef,
- "aria-label": _ctx.ariaLabel,
- "boundaries-padding": _ctx.boundariesPadding,
- content: _ctx.content,
- disabled: _ctx.disabled,
- effect: _ctx.effect,
- enterable: _ctx.enterable,
- "fallback-placements": _ctx.fallbackPlacements,
- "hide-after": _ctx.hideAfter,
- "gpu-acceleration": _ctx.gpuAcceleration,
- offset: _ctx.offset,
- persistent: _ctx.persistent,
- "popper-class": _ctx.popperClass,
- "popper-style": _ctx.popperStyle,
- placement: _ctx.placement,
- "popper-options": _ctx.popperOptions,
- pure: _ctx.pure,
- "raw-content": _ctx.rawContent,
- "reference-el": _ctx.referenceEl,
- "trigger-target-el": _ctx.triggerTargetEl,
- "show-after": _ctx.showAfter,
- strategy: _ctx.strategy,
- teleported: _ctx.teleported,
- transition: _ctx.transition,
- "virtual-triggering": _ctx.virtualTriggering,
- "z-index": _ctx.zIndex,
- "append-to": _ctx.appendTo
- }, {
- default: withCtx(() => [
- renderSlot(_ctx.$slots, "content", {}, () => [
- _ctx.rawContent ? (openBlock(), createElementBlock("span", {
- key: 0,
- innerHTML: _ctx.content
- }, null, 8, _hoisted_1$f)) : (openBlock(), createElementBlock("span", _hoisted_2$9, toDisplayString(_ctx.content), 1))
- ]),
- _ctx.showArrow ? (openBlock(), createBlock(unref(ElPopperArrow), {
- key: 0,
- "arrow-offset": _ctx.arrowOffset
- }, null, 8, ["arrow-offset"])) : createCommentVNode("v-if", true)
- ]),
- _: 3
- }, 8, ["aria-label", "boundaries-padding", "content", "disabled", "effect", "enterable", "fallback-placements", "hide-after", "gpu-acceleration", "offset", "persistent", "popper-class", "popper-style", "placement", "popper-options", "pure", "raw-content", "reference-el", "trigger-target-el", "show-after", "strategy", "teleported", "transition", "virtual-triggering", "z-index", "append-to"])
- ]),
- _: 3
- }, 8, ["role"]);
- };
- }
- });
- var Tooltip = /* @__PURE__ */ _export_sfc$1(_sfc_main$p, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/tooltip/src/tooltip.vue"]]);
- const ElTooltip = withInstall(Tooltip);
- const buttonGroupContextKey = Symbol("buttonGroupContextKey");
- const useButton = (props, emit) => {
- useDeprecated({
- from: "type.text",
- replacement: "link",
- version: "3.0.0",
- scope: "props",
- ref: "https://element-plus.org/en-US/component/button.html#button-attributes"
- }, computed$1(() => props.type === "text"));
- const buttonGroupContext = inject(buttonGroupContextKey, void 0);
- const globalConfig2 = useGlobalConfig("button");
- const { form } = useFormItem();
- const _size = useFormSize(computed$1(() => buttonGroupContext == null ? void 0 : buttonGroupContext.size));
- const _disabled = useFormDisabled();
- const _ref = ref();
- const slots = useSlots();
- const _type = computed$1(() => props.type || (buttonGroupContext == null ? void 0 : buttonGroupContext.type) || "");
- const autoInsertSpace = computed$1(() => {
- var _a2, _b, _c;
- return (_c = (_b = props.autoInsertSpace) != null ? _b : (_a2 = globalConfig2.value) == null ? void 0 : _a2.autoInsertSpace) != null ? _c : false;
- });
- const _props = computed$1(() => {
- if (props.tag === "button") {
- return {
- ariaDisabled: _disabled.value || props.loading,
- disabled: _disabled.value || props.loading,
- autofocus: props.autofocus,
- type: props.nativeType
- };
- }
- return {};
- });
- const shouldAddSpace = computed$1(() => {
- var _a2;
- const defaultSlot = (_a2 = slots.default) == null ? void 0 : _a2.call(slots);
- if (autoInsertSpace.value && (defaultSlot == null ? void 0 : defaultSlot.length) === 1) {
- const slot = defaultSlot[0];
- if ((slot == null ? void 0 : slot.type) === Text$1) {
- const text = slot.children;
- return /^\p{Unified_Ideograph}{2}$/u.test(text.trim());
- }
- }
- return false;
- });
- const handleClick = (evt) => {
- if (props.nativeType === "reset") {
- form == null ? void 0 : form.resetFields();
- }
- emit("click", evt);
- };
- return {
- _disabled,
- _size,
- _type,
- _ref,
- _props,
- shouldAddSpace,
- handleClick
- };
- };
- const buttonTypes = [
- "default",
- "primary",
- "success",
- "warning",
- "info",
- "danger",
- "text",
- ""
- ];
- const buttonNativeTypes = ["button", "submit", "reset"];
- const buttonProps = buildProps({
- size: useSizeProp,
- disabled: Boolean,
- type: {
- type: String,
- values: buttonTypes,
- default: ""
- },
- icon: {
- type: iconPropType
- },
- nativeType: {
- type: String,
- values: buttonNativeTypes,
- default: "button"
- },
- loading: Boolean,
- loadingIcon: {
- type: iconPropType,
- default: () => loading_default
- },
- plain: Boolean,
- text: Boolean,
- link: Boolean,
- bg: Boolean,
- autofocus: Boolean,
- round: Boolean,
- circle: Boolean,
- color: String,
- dark: Boolean,
- autoInsertSpace: {
- type: Boolean,
- default: void 0
- },
- tag: {
- type: definePropType([String, Object]),
- default: "button"
- }
- });
- const buttonEmits = {
- click: (evt) => evt instanceof MouseEvent
- };
- function bound01$1(n, max2) {
- if (isOnePointZero$1(n)) {
- n = "100%";
- }
- var isPercent = isPercentage$1(n);
- n = max2 === 360 ? n : Math.min(max2, Math.max(0, parseFloat(n)));
- if (isPercent) {
- n = parseInt(String(n * max2), 10) / 100;
- }
- if (Math.abs(n - max2) < 1e-6) {
- return 1;
- }
- if (max2 === 360) {
- n = (n < 0 ? n % max2 + max2 : n % max2) / parseFloat(String(max2));
- } else {
- n = n % max2 / parseFloat(String(max2));
- }
- return n;
- }
- function clamp01(val) {
- return Math.min(1, Math.max(0, val));
- }
- function isOnePointZero$1(n) {
- return typeof n === "string" && n.indexOf(".") !== -1 && parseFloat(n) === 1;
- }
- function isPercentage$1(n) {
- return typeof n === "string" && n.indexOf("%") !== -1;
- }
- function boundAlpha(a) {
- a = parseFloat(a);
- if (isNaN(a) || a < 0 || a > 1) {
- a = 1;
- }
- return a;
- }
- function convertToPercentage(n) {
- if (n <= 1) {
- return "".concat(Number(n) * 100, "%");
- }
- return n;
- }
- function pad2(c) {
- return c.length === 1 ? "0" + c : String(c);
- }
- function rgbToRgb(r2, g, b) {
- return {
- r: bound01$1(r2, 255) * 255,
- g: bound01$1(g, 255) * 255,
- b: bound01$1(b, 255) * 255
- };
- }
- function rgbToHsl(r2, g, b) {
- r2 = bound01$1(r2, 255);
- g = bound01$1(g, 255);
- b = bound01$1(b, 255);
- var max2 = Math.max(r2, g, b);
- var min2 = Math.min(r2, g, b);
- var h2 = 0;
- var s = 0;
- var l = (max2 + min2) / 2;
- if (max2 === min2) {
- s = 0;
- h2 = 0;
- } else {
- var d2 = max2 - min2;
- s = l > 0.5 ? d2 / (2 - max2 - min2) : d2 / (max2 + min2);
- switch (max2) {
- case r2:
- h2 = (g - b) / d2 + (g < b ? 6 : 0);
- break;
- case g:
- h2 = (b - r2) / d2 + 2;
- break;
- case b:
- h2 = (r2 - g) / d2 + 4;
- break;
- }
- h2 /= 6;
- }
- return { h: h2, s, l };
- }
- function hue2rgb(p, q2, t2) {
- if (t2 < 0) {
- t2 += 1;
- }
- if (t2 > 1) {
- t2 -= 1;
- }
- if (t2 < 1 / 6) {
- return p + (q2 - p) * (6 * t2);
- }
- if (t2 < 1 / 2) {
- return q2;
- }
- if (t2 < 2 / 3) {
- return p + (q2 - p) * (2 / 3 - t2) * 6;
- }
- return p;
- }
- function hslToRgb(h2, s, l) {
- var r2;
- var g;
- var b;
- h2 = bound01$1(h2, 360);
- s = bound01$1(s, 100);
- l = bound01$1(l, 100);
- if (s === 0) {
- g = l;
- b = l;
- r2 = l;
- } else {
- var q2 = l < 0.5 ? l * (1 + s) : l + s - l * s;
- var p = 2 * l - q2;
- r2 = hue2rgb(p, q2, h2 + 1 / 3);
- g = hue2rgb(p, q2, h2);
- b = hue2rgb(p, q2, h2 - 1 / 3);
- }
- return { r: r2 * 255, g: g * 255, b: b * 255 };
- }
- function rgbToHsv(r2, g, b) {
- r2 = bound01$1(r2, 255);
- g = bound01$1(g, 255);
- b = bound01$1(b, 255);
- var max2 = Math.max(r2, g, b);
- var min2 = Math.min(r2, g, b);
- var h2 = 0;
- var v = max2;
- var d2 = max2 - min2;
- var s = max2 === 0 ? 0 : d2 / max2;
- if (max2 === min2) {
- h2 = 0;
- } else {
- switch (max2) {
- case r2:
- h2 = (g - b) / d2 + (g < b ? 6 : 0);
- break;
- case g:
- h2 = (b - r2) / d2 + 2;
- break;
- case b:
- h2 = (r2 - g) / d2 + 4;
- break;
- }
- h2 /= 6;
- }
- return { h: h2, s, v };
- }
- function hsvToRgb(h2, s, v) {
- h2 = bound01$1(h2, 360) * 6;
- s = bound01$1(s, 100);
- v = bound01$1(v, 100);
- var i2 = Math.floor(h2);
- var f = h2 - i2;
- var p = v * (1 - s);
- var q2 = v * (1 - f * s);
- var t2 = v * (1 - (1 - f) * s);
- var mod = i2 % 6;
- var r2 = [v, q2, p, p, t2, v][mod];
- var g = [t2, v, v, q2, p, p][mod];
- var b = [p, p, t2, v, v, q2][mod];
- return { r: r2 * 255, g: g * 255, b: b * 255 };
- }
- function rgbToHex(r2, g, b, allow3Char) {
- var hex = [
- pad2(Math.round(r2).toString(16)),
- pad2(Math.round(g).toString(16)),
- pad2(Math.round(b).toString(16))
- ];
- if (allow3Char && hex[0].startsWith(hex[0].charAt(1)) && hex[1].startsWith(hex[1].charAt(1)) && hex[2].startsWith(hex[2].charAt(1))) {
- return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0);
- }
- return hex.join("");
- }
- function rgbaToHex(r2, g, b, a, allow4Char) {
- var hex = [
- pad2(Math.round(r2).toString(16)),
- pad2(Math.round(g).toString(16)),
- pad2(Math.round(b).toString(16)),
- pad2(convertDecimalToHex(a))
- ];
- if (allow4Char && hex[0].startsWith(hex[0].charAt(1)) && hex[1].startsWith(hex[1].charAt(1)) && hex[2].startsWith(hex[2].charAt(1)) && hex[3].startsWith(hex[3].charAt(1))) {
- return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0) + hex[3].charAt(0);
- }
- return hex.join("");
- }
- function convertDecimalToHex(d2) {
- return Math.round(parseFloat(d2) * 255).toString(16);
- }
- function convertHexToDecimal(h2) {
- return parseIntFromHex(h2) / 255;
- }
- function parseIntFromHex(val) {
- return parseInt(val, 16);
- }
- function numberInputToObject(color2) {
- return {
- r: color2 >> 16,
- g: (color2 & 65280) >> 8,
- b: color2 & 255
- };
- }
- var names = {
- aliceblue: "#f0f8ff",
- antiquewhite: "#faebd7",
- aqua: "#00ffff",
- aquamarine: "#7fffd4",
- azure: "#f0ffff",
- beige: "#f5f5dc",
- bisque: "#ffe4c4",
- black: "#000000",
- blanchedalmond: "#ffebcd",
- blue: "#0000ff",
- blueviolet: "#8a2be2",
- brown: "#a52a2a",
- burlywood: "#deb887",
- cadetblue: "#5f9ea0",
- chartreuse: "#7fff00",
- chocolate: "#d2691e",
- coral: "#ff7f50",
- cornflowerblue: "#6495ed",
- cornsilk: "#fff8dc",
- crimson: "#dc143c",
- cyan: "#00ffff",
- darkblue: "#00008b",
- darkcyan: "#008b8b",
- darkgoldenrod: "#b8860b",
- darkgray: "#a9a9a9",
- darkgreen: "#006400",
- darkgrey: "#a9a9a9",
- darkkhaki: "#bdb76b",
- darkmagenta: "#8b008b",
- darkolivegreen: "#556b2f",
- darkorange: "#ff8c00",
- darkorchid: "#9932cc",
- darkred: "#8b0000",
- darksalmon: "#e9967a",
- darkseagreen: "#8fbc8f",
- darkslateblue: "#483d8b",
- darkslategray: "#2f4f4f",
- darkslategrey: "#2f4f4f",
- darkturquoise: "#00ced1",
- darkviolet: "#9400d3",
- deeppink: "#ff1493",
- deepskyblue: "#00bfff",
- dimgray: "#696969",
- dimgrey: "#696969",
- dodgerblue: "#1e90ff",
- firebrick: "#b22222",
- floralwhite: "#fffaf0",
- forestgreen: "#228b22",
- fuchsia: "#ff00ff",
- gainsboro: "#dcdcdc",
- ghostwhite: "#f8f8ff",
- goldenrod: "#daa520",
- gold: "#ffd700",
- gray: "#808080",
- green: "#008000",
- greenyellow: "#adff2f",
- grey: "#808080",
- honeydew: "#f0fff0",
- hotpink: "#ff69b4",
- indianred: "#cd5c5c",
- indigo: "#4b0082",
- ivory: "#fffff0",
- khaki: "#f0e68c",
- lavenderblush: "#fff0f5",
- lavender: "#e6e6fa",
- lawngreen: "#7cfc00",
- lemonchiffon: "#fffacd",
- lightblue: "#add8e6",
- lightcoral: "#f08080",
- lightcyan: "#e0ffff",
- lightgoldenrodyellow: "#fafad2",
- lightgray: "#d3d3d3",
- lightgreen: "#90ee90",
- lightgrey: "#d3d3d3",
- lightpink: "#ffb6c1",
- lightsalmon: "#ffa07a",
- lightseagreen: "#20b2aa",
- lightskyblue: "#87cefa",
- lightslategray: "#778899",
- lightslategrey: "#778899",
- lightsteelblue: "#b0c4de",
- lightyellow: "#ffffe0",
- lime: "#00ff00",
- limegreen: "#32cd32",
- linen: "#faf0e6",
- magenta: "#ff00ff",
- maroon: "#800000",
- mediumaquamarine: "#66cdaa",
- mediumblue: "#0000cd",
- mediumorchid: "#ba55d3",
- mediumpurple: "#9370db",
- mediumseagreen: "#3cb371",
- mediumslateblue: "#7b68ee",
- mediumspringgreen: "#00fa9a",
- mediumturquoise: "#48d1cc",
- mediumvioletred: "#c71585",
- midnightblue: "#191970",
- mintcream: "#f5fffa",
- mistyrose: "#ffe4e1",
- moccasin: "#ffe4b5",
- navajowhite: "#ffdead",
- navy: "#000080",
- oldlace: "#fdf5e6",
- olive: "#808000",
- olivedrab: "#6b8e23",
- orange: "#ffa500",
- orangered: "#ff4500",
- orchid: "#da70d6",
- palegoldenrod: "#eee8aa",
- palegreen: "#98fb98",
- paleturquoise: "#afeeee",
- palevioletred: "#db7093",
- papayawhip: "#ffefd5",
- peachpuff: "#ffdab9",
- peru: "#cd853f",
- pink: "#ffc0cb",
- plum: "#dda0dd",
- powderblue: "#b0e0e6",
- purple: "#800080",
- rebeccapurple: "#663399",
- red: "#ff0000",
- rosybrown: "#bc8f8f",
- royalblue: "#4169e1",
- saddlebrown: "#8b4513",
- salmon: "#fa8072",
- sandybrown: "#f4a460",
- seagreen: "#2e8b57",
- seashell: "#fff5ee",
- sienna: "#a0522d",
- silver: "#c0c0c0",
- skyblue: "#87ceeb",
- slateblue: "#6a5acd",
- slategray: "#708090",
- slategrey: "#708090",
- snow: "#fffafa",
- springgreen: "#00ff7f",
- steelblue: "#4682b4",
- tan: "#d2b48c",
- teal: "#008080",
- thistle: "#d8bfd8",
- tomato: "#ff6347",
- turquoise: "#40e0d0",
- violet: "#ee82ee",
- wheat: "#f5deb3",
- white: "#ffffff",
- whitesmoke: "#f5f5f5",
- yellow: "#ffff00",
- yellowgreen: "#9acd32"
- };
- function inputToRGB(color2) {
- var rgb = { r: 0, g: 0, b: 0 };
- var a = 1;
- var s = null;
- var v = null;
- var l = null;
- var ok = false;
- var format = false;
- if (typeof color2 === "string") {
- color2 = stringInputToObject(color2);
- }
- if (typeof color2 === "object") {
- if (isValidCSSUnit(color2.r) && isValidCSSUnit(color2.g) && isValidCSSUnit(color2.b)) {
- rgb = rgbToRgb(color2.r, color2.g, color2.b);
- ok = true;
- format = String(color2.r).substr(-1) === "%" ? "prgb" : "rgb";
- } else if (isValidCSSUnit(color2.h) && isValidCSSUnit(color2.s) && isValidCSSUnit(color2.v)) {
- s = convertToPercentage(color2.s);
- v = convertToPercentage(color2.v);
- rgb = hsvToRgb(color2.h, s, v);
- ok = true;
- format = "hsv";
- } else if (isValidCSSUnit(color2.h) && isValidCSSUnit(color2.s) && isValidCSSUnit(color2.l)) {
- s = convertToPercentage(color2.s);
- l = convertToPercentage(color2.l);
- rgb = hslToRgb(color2.h, s, l);
- ok = true;
- format = "hsl";
- }
- if (Object.prototype.hasOwnProperty.call(color2, "a")) {
- a = color2.a;
- }
- }
- a = boundAlpha(a);
- return {
- ok,
- format: color2.format || format,
- r: Math.min(255, Math.max(rgb.r, 0)),
- g: Math.min(255, Math.max(rgb.g, 0)),
- b: Math.min(255, Math.max(rgb.b, 0)),
- a
- };
- }
- var CSS_INTEGER = "[-\\+]?\\d+%?";
- var CSS_NUMBER = "[-\\+]?\\d*\\.\\d+%?";
- var CSS_UNIT = "(?:".concat(CSS_NUMBER, ")|(?:").concat(CSS_INTEGER, ")");
- var PERMISSIVE_MATCH3 = "[\\s|\\(]+(".concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")\\s*\\)?");
- var PERMISSIVE_MATCH4 = "[\\s|\\(]+(".concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")[,|\\s]+(").concat(CSS_UNIT, ")\\s*\\)?");
- var matchers = {
- CSS_UNIT: new RegExp(CSS_UNIT),
- rgb: new RegExp("rgb" + PERMISSIVE_MATCH3),
- rgba: new RegExp("rgba" + PERMISSIVE_MATCH4),
- hsl: new RegExp("hsl" + PERMISSIVE_MATCH3),
- hsla: new RegExp("hsla" + PERMISSIVE_MATCH4),
- hsv: new RegExp("hsv" + PERMISSIVE_MATCH3),
- hsva: new RegExp("hsva" + PERMISSIVE_MATCH4),
- hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,
- hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,
- hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,
- hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/
- };
- function stringInputToObject(color2) {
- color2 = color2.trim().toLowerCase();
- if (color2.length === 0) {
- return false;
- }
- var named = false;
- if (names[color2]) {
- color2 = names[color2];
- named = true;
- } else if (color2 === "transparent") {
- return { r: 0, g: 0, b: 0, a: 0, format: "name" };
- }
- var match = matchers.rgb.exec(color2);
- if (match) {
- return { r: match[1], g: match[2], b: match[3] };
- }
- match = matchers.rgba.exec(color2);
- if (match) {
- return { r: match[1], g: match[2], b: match[3], a: match[4] };
- }
- match = matchers.hsl.exec(color2);
- if (match) {
- return { h: match[1], s: match[2], l: match[3] };
- }
- match = matchers.hsla.exec(color2);
- if (match) {
- return { h: match[1], s: match[2], l: match[3], a: match[4] };
- }
- match = matchers.hsv.exec(color2);
- if (match) {
- return { h: match[1], s: match[2], v: match[3] };
- }
- match = matchers.hsva.exec(color2);
- if (match) {
- return { h: match[1], s: match[2], v: match[3], a: match[4] };
- }
- match = matchers.hex8.exec(color2);
- if (match) {
- return {
- r: parseIntFromHex(match[1]),
- g: parseIntFromHex(match[2]),
- b: parseIntFromHex(match[3]),
- a: convertHexToDecimal(match[4]),
- format: named ? "name" : "hex8"
- };
- }
- match = matchers.hex6.exec(color2);
- if (match) {
- return {
- r: parseIntFromHex(match[1]),
- g: parseIntFromHex(match[2]),
- b: parseIntFromHex(match[3]),
- format: named ? "name" : "hex"
- };
- }
- match = matchers.hex4.exec(color2);
- if (match) {
- return {
- r: parseIntFromHex(match[1] + match[1]),
- g: parseIntFromHex(match[2] + match[2]),
- b: parseIntFromHex(match[3] + match[3]),
- a: convertHexToDecimal(match[4] + match[4]),
- format: named ? "name" : "hex8"
- };
- }
- match = matchers.hex3.exec(color2);
- if (match) {
- return {
- r: parseIntFromHex(match[1] + match[1]),
- g: parseIntFromHex(match[2] + match[2]),
- b: parseIntFromHex(match[3] + match[3]),
- format: named ? "name" : "hex"
- };
- }
- return false;
- }
- function isValidCSSUnit(color2) {
- return Boolean(matchers.CSS_UNIT.exec(String(color2)));
- }
- var TinyColor = function() {
- function TinyColor2(color2, opts) {
- if (color2 === void 0) {
- color2 = "";
- }
- if (opts === void 0) {
- opts = {};
- }
- var _a2;
- if (color2 instanceof TinyColor2) {
- return color2;
- }
- if (typeof color2 === "number") {
- color2 = numberInputToObject(color2);
- }
- this.originalInput = color2;
- var rgb = inputToRGB(color2);
- this.originalInput = color2;
- this.r = rgb.r;
- this.g = rgb.g;
- this.b = rgb.b;
- this.a = rgb.a;
- this.roundA = Math.round(100 * this.a) / 100;
- this.format = (_a2 = opts.format) !== null && _a2 !== void 0 ? _a2 : rgb.format;
- this.gradientType = opts.gradientType;
- if (this.r < 1) {
- this.r = Math.round(this.r);
- }
- if (this.g < 1) {
- this.g = Math.round(this.g);
- }
- if (this.b < 1) {
- this.b = Math.round(this.b);
- }
- this.isValid = rgb.ok;
- }
- TinyColor2.prototype.isDark = function() {
- return this.getBrightness() < 128;
- };
- TinyColor2.prototype.isLight = function() {
- return !this.isDark();
- };
- TinyColor2.prototype.getBrightness = function() {
- var rgb = this.toRgb();
- return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1e3;
- };
- TinyColor2.prototype.getLuminance = function() {
- var rgb = this.toRgb();
- var R2;
- var G2;
- var B2;
- var RsRGB = rgb.r / 255;
- var GsRGB = rgb.g / 255;
- var BsRGB = rgb.b / 255;
- if (RsRGB <= 0.03928) {
- R2 = RsRGB / 12.92;
- } else {
- R2 = Math.pow((RsRGB + 0.055) / 1.055, 2.4);
- }
- if (GsRGB <= 0.03928) {
- G2 = GsRGB / 12.92;
- } else {
- G2 = Math.pow((GsRGB + 0.055) / 1.055, 2.4);
- }
- if (BsRGB <= 0.03928) {
- B2 = BsRGB / 12.92;
- } else {
- B2 = Math.pow((BsRGB + 0.055) / 1.055, 2.4);
- }
- return 0.2126 * R2 + 0.7152 * G2 + 0.0722 * B2;
- };
- TinyColor2.prototype.getAlpha = function() {
- return this.a;
- };
- TinyColor2.prototype.setAlpha = function(alpha) {
- this.a = boundAlpha(alpha);
- this.roundA = Math.round(100 * this.a) / 100;
- return this;
- };
- TinyColor2.prototype.isMonochrome = function() {
- var s = this.toHsl().s;
- return s === 0;
- };
- TinyColor2.prototype.toHsv = function() {
- var hsv = rgbToHsv(this.r, this.g, this.b);
- return { h: hsv.h * 360, s: hsv.s, v: hsv.v, a: this.a };
- };
- TinyColor2.prototype.toHsvString = function() {
- var hsv = rgbToHsv(this.r, this.g, this.b);
- var h2 = Math.round(hsv.h * 360);
- var s = Math.round(hsv.s * 100);
- var v = Math.round(hsv.v * 100);
- return this.a === 1 ? "hsv(".concat(h2, ", ").concat(s, "%, ").concat(v, "%)") : "hsva(".concat(h2, ", ").concat(s, "%, ").concat(v, "%, ").concat(this.roundA, ")");
- };
- TinyColor2.prototype.toHsl = function() {
- var hsl = rgbToHsl(this.r, this.g, this.b);
- return { h: hsl.h * 360, s: hsl.s, l: hsl.l, a: this.a };
- };
- TinyColor2.prototype.toHslString = function() {
- var hsl = rgbToHsl(this.r, this.g, this.b);
- var h2 = Math.round(hsl.h * 360);
- var s = Math.round(hsl.s * 100);
- var l = Math.round(hsl.l * 100);
- return this.a === 1 ? "hsl(".concat(h2, ", ").concat(s, "%, ").concat(l, "%)") : "hsla(".concat(h2, ", ").concat(s, "%, ").concat(l, "%, ").concat(this.roundA, ")");
- };
- TinyColor2.prototype.toHex = function(allow3Char) {
- if (allow3Char === void 0) {
- allow3Char = false;
- }
- return rgbToHex(this.r, this.g, this.b, allow3Char);
- };
- TinyColor2.prototype.toHexString = function(allow3Char) {
- if (allow3Char === void 0) {
- allow3Char = false;
- }
- return "#" + this.toHex(allow3Char);
- };
- TinyColor2.prototype.toHex8 = function(allow4Char) {
- if (allow4Char === void 0) {
- allow4Char = false;
- }
- return rgbaToHex(this.r, this.g, this.b, this.a, allow4Char);
- };
- TinyColor2.prototype.toHex8String = function(allow4Char) {
- if (allow4Char === void 0) {
- allow4Char = false;
- }
- return "#" + this.toHex8(allow4Char);
- };
- TinyColor2.prototype.toHexShortString = function(allowShortChar) {
- if (allowShortChar === void 0) {
- allowShortChar = false;
- }
- return this.a === 1 ? this.toHexString(allowShortChar) : this.toHex8String(allowShortChar);
- };
- TinyColor2.prototype.toRgb = function() {
- return {
- r: Math.round(this.r),
- g: Math.round(this.g),
- b: Math.round(this.b),
- a: this.a
- };
- };
- TinyColor2.prototype.toRgbString = function() {
- var r2 = Math.round(this.r);
- var g = Math.round(this.g);
- var b = Math.round(this.b);
- return this.a === 1 ? "rgb(".concat(r2, ", ").concat(g, ", ").concat(b, ")") : "rgba(".concat(r2, ", ").concat(g, ", ").concat(b, ", ").concat(this.roundA, ")");
- };
- TinyColor2.prototype.toPercentageRgb = function() {
- var fmt = function(x) {
- return "".concat(Math.round(bound01$1(x, 255) * 100), "%");
- };
- return {
- r: fmt(this.r),
- g: fmt(this.g),
- b: fmt(this.b),
- a: this.a
- };
- };
- TinyColor2.prototype.toPercentageRgbString = function() {
- var rnd = function(x) {
- return Math.round(bound01$1(x, 255) * 100);
- };
- return this.a === 1 ? "rgb(".concat(rnd(this.r), "%, ").concat(rnd(this.g), "%, ").concat(rnd(this.b), "%)") : "rgba(".concat(rnd(this.r), "%, ").concat(rnd(this.g), "%, ").concat(rnd(this.b), "%, ").concat(this.roundA, ")");
- };
- TinyColor2.prototype.toName = function() {
- if (this.a === 0) {
- return "transparent";
- }
- if (this.a < 1) {
- return false;
- }
- var hex = "#" + rgbToHex(this.r, this.g, this.b, false);
- for (var _i = 0, _a2 = Object.entries(names); _i < _a2.length; _i++) {
- var _b = _a2[_i], key = _b[0], value = _b[1];
- if (hex === value) {
- return key;
- }
- }
- return false;
- };
- TinyColor2.prototype.toString = function(format) {
- var formatSet = Boolean(format);
- format = format !== null && format !== void 0 ? format : this.format;
- var formattedString = false;
- var hasAlpha = this.a < 1 && this.a >= 0;
- var needsAlphaFormat = !formatSet && hasAlpha && (format.startsWith("hex") || format === "name");
- if (needsAlphaFormat) {
- if (format === "name" && this.a === 0) {
- return this.toName();
- }
- return this.toRgbString();
- }
- if (format === "rgb") {
- formattedString = this.toRgbString();
- }
- if (format === "prgb") {
- formattedString = this.toPercentageRgbString();
- }
- if (format === "hex" || format === "hex6") {
- formattedString = this.toHexString();
- }
- if (format === "hex3") {
- formattedString = this.toHexString(true);
- }
- if (format === "hex4") {
- formattedString = this.toHex8String(true);
- }
- if (format === "hex8") {
- formattedString = this.toHex8String();
- }
- if (format === "name") {
- formattedString = this.toName();
- }
- if (format === "hsl") {
- formattedString = this.toHslString();
- }
- if (format === "hsv") {
- formattedString = this.toHsvString();
- }
- return formattedString || this.toHexString();
- };
- TinyColor2.prototype.toNumber = function() {
- return (Math.round(this.r) << 16) + (Math.round(this.g) << 8) + Math.round(this.b);
- };
- TinyColor2.prototype.clone = function() {
- return new TinyColor2(this.toString());
- };
- TinyColor2.prototype.lighten = function(amount) {
- if (amount === void 0) {
- amount = 10;
- }
- var hsl = this.toHsl();
- hsl.l += amount / 100;
- hsl.l = clamp01(hsl.l);
- return new TinyColor2(hsl);
- };
- TinyColor2.prototype.brighten = function(amount) {
- if (amount === void 0) {
- amount = 10;
- }
- var rgb = this.toRgb();
- rgb.r = Math.max(0, Math.min(255, rgb.r - Math.round(255 * -(amount / 100))));
- rgb.g = Math.max(0, Math.min(255, rgb.g - Math.round(255 * -(amount / 100))));
- rgb.b = Math.max(0, Math.min(255, rgb.b - Math.round(255 * -(amount / 100))));
- return new TinyColor2(rgb);
- };
- TinyColor2.prototype.darken = function(amount) {
- if (amount === void 0) {
- amount = 10;
- }
- var hsl = this.toHsl();
- hsl.l -= amount / 100;
- hsl.l = clamp01(hsl.l);
- return new TinyColor2(hsl);
- };
- TinyColor2.prototype.tint = function(amount) {
- if (amount === void 0) {
- amount = 10;
- }
- return this.mix("white", amount);
- };
- TinyColor2.prototype.shade = function(amount) {
- if (amount === void 0) {
- amount = 10;
- }
- return this.mix("black", amount);
- };
- TinyColor2.prototype.desaturate = function(amount) {
- if (amount === void 0) {
- amount = 10;
- }
- var hsl = this.toHsl();
- hsl.s -= amount / 100;
- hsl.s = clamp01(hsl.s);
- return new TinyColor2(hsl);
- };
- TinyColor2.prototype.saturate = function(amount) {
- if (amount === void 0) {
- amount = 10;
- }
- var hsl = this.toHsl();
- hsl.s += amount / 100;
- hsl.s = clamp01(hsl.s);
- return new TinyColor2(hsl);
- };
- TinyColor2.prototype.greyscale = function() {
- return this.desaturate(100);
- };
- TinyColor2.prototype.spin = function(amount) {
- var hsl = this.toHsl();
- var hue = (hsl.h + amount) % 360;
- hsl.h = hue < 0 ? 360 + hue : hue;
- return new TinyColor2(hsl);
- };
- TinyColor2.prototype.mix = function(color2, amount) {
- if (amount === void 0) {
- amount = 50;
- }
- var rgb1 = this.toRgb();
- var rgb2 = new TinyColor2(color2).toRgb();
- var p = amount / 100;
- var rgba = {
- r: (rgb2.r - rgb1.r) * p + rgb1.r,
- g: (rgb2.g - rgb1.g) * p + rgb1.g,
- b: (rgb2.b - rgb1.b) * p + rgb1.b,
- a: (rgb2.a - rgb1.a) * p + rgb1.a
- };
- return new TinyColor2(rgba);
- };
- TinyColor2.prototype.analogous = function(results, slices) {
- if (results === void 0) {
- results = 6;
- }
- if (slices === void 0) {
- slices = 30;
- }
- var hsl = this.toHsl();
- var part = 360 / slices;
- var ret = [this];
- for (hsl.h = (hsl.h - (part * results >> 1) + 720) % 360; --results; ) {
- hsl.h = (hsl.h + part) % 360;
- ret.push(new TinyColor2(hsl));
- }
- return ret;
- };
- TinyColor2.prototype.complement = function() {
- var hsl = this.toHsl();
- hsl.h = (hsl.h + 180) % 360;
- return new TinyColor2(hsl);
- };
- TinyColor2.prototype.monochromatic = function(results) {
- if (results === void 0) {
- results = 6;
- }
- var hsv = this.toHsv();
- var h2 = hsv.h;
- var s = hsv.s;
- var v = hsv.v;
- var res = [];
- var modification = 1 / results;
- while (results--) {
- res.push(new TinyColor2({ h: h2, s, v }));
- v = (v + modification) % 1;
- }
- return res;
- };
- TinyColor2.prototype.splitcomplement = function() {
- var hsl = this.toHsl();
- var h2 = hsl.h;
- return [
- this,
- new TinyColor2({ h: (h2 + 72) % 360, s: hsl.s, l: hsl.l }),
- new TinyColor2({ h: (h2 + 216) % 360, s: hsl.s, l: hsl.l })
- ];
- };
- TinyColor2.prototype.onBackground = function(background) {
- var fg = this.toRgb();
- var bg = new TinyColor2(background).toRgb();
- var alpha = fg.a + bg.a * (1 - fg.a);
- return new TinyColor2({
- r: (fg.r * fg.a + bg.r * bg.a * (1 - fg.a)) / alpha,
- g: (fg.g * fg.a + bg.g * bg.a * (1 - fg.a)) / alpha,
- b: (fg.b * fg.a + bg.b * bg.a * (1 - fg.a)) / alpha,
- a: alpha
- });
- };
- TinyColor2.prototype.triad = function() {
- return this.polyad(3);
- };
- TinyColor2.prototype.tetrad = function() {
- return this.polyad(4);
- };
- TinyColor2.prototype.polyad = function(n) {
- var hsl = this.toHsl();
- var h2 = hsl.h;
- var result = [this];
- var increment = 360 / n;
- for (var i2 = 1; i2 < n; i2++) {
- result.push(new TinyColor2({ h: (h2 + i2 * increment) % 360, s: hsl.s, l: hsl.l }));
- }
- return result;
- };
- TinyColor2.prototype.equals = function(color2) {
- return this.toRgbString() === new TinyColor2(color2).toRgbString();
- };
- return TinyColor2;
- }();
- function darken(color2, amount = 20) {
- return color2.mix("#141414", amount).toString();
- }
- function useButtonCustomStyle(props) {
- const _disabled = useFormDisabled();
- const ns = useNamespace("button");
- return computed$1(() => {
- let styles = {};
- const buttonColor = props.color;
- if (buttonColor) {
- const color2 = new TinyColor(buttonColor);
- const activeBgColor = props.dark ? color2.tint(20).toString() : darken(color2, 20);
- if (props.plain) {
- styles = ns.cssVarBlock({
- "bg-color": props.dark ? darken(color2, 90) : color2.tint(90).toString(),
- "text-color": buttonColor,
- "border-color": props.dark ? darken(color2, 50) : color2.tint(50).toString(),
- "hover-text-color": `var(${ns.cssVarName("color-white")})`,
- "hover-bg-color": buttonColor,
- "hover-border-color": buttonColor,
- "active-bg-color": activeBgColor,
- "active-text-color": `var(${ns.cssVarName("color-white")})`,
- "active-border-color": activeBgColor
- });
- if (_disabled.value) {
- styles[ns.cssVarBlockName("disabled-bg-color")] = props.dark ? darken(color2, 90) : color2.tint(90).toString();
- styles[ns.cssVarBlockName("disabled-text-color")] = props.dark ? darken(color2, 50) : color2.tint(50).toString();
- styles[ns.cssVarBlockName("disabled-border-color")] = props.dark ? darken(color2, 80) : color2.tint(80).toString();
- }
- } else {
- const hoverBgColor = props.dark ? darken(color2, 30) : color2.tint(30).toString();
- const textColor = color2.isDark() ? `var(${ns.cssVarName("color-white")})` : `var(${ns.cssVarName("color-black")})`;
- styles = ns.cssVarBlock({
- "bg-color": buttonColor,
- "text-color": textColor,
- "border-color": buttonColor,
- "hover-bg-color": hoverBgColor,
- "hover-text-color": textColor,
- "hover-border-color": hoverBgColor,
- "active-bg-color": activeBgColor,
- "active-border-color": activeBgColor
- });
- if (_disabled.value) {
- const disabledButtonColor = props.dark ? darken(color2, 50) : color2.tint(50).toString();
- styles[ns.cssVarBlockName("disabled-bg-color")] = disabledButtonColor;
- styles[ns.cssVarBlockName("disabled-text-color")] = props.dark ? "rgba(255, 255, 255, 0.5)" : `var(${ns.cssVarName("color-white")})`;
- styles[ns.cssVarBlockName("disabled-border-color")] = disabledButtonColor;
- }
- }
- }
- return styles;
- });
- }
- const __default__$e = defineComponent({
- name: "ElButton"
- });
- const _sfc_main$o = /* @__PURE__ */ defineComponent({
- ...__default__$e,
- props: buttonProps,
- emits: buttonEmits,
- setup(__props, { expose, emit }) {
- const props = __props;
- const buttonStyle = useButtonCustomStyle(props);
- const ns = useNamespace("button");
- const { _ref, _size, _type, _disabled, _props, shouldAddSpace, handleClick } = useButton(props, emit);
- expose({
- ref: _ref,
- size: _size,
- type: _type,
- disabled: _disabled,
- shouldAddSpace
- });
- return (_ctx, _cache) => {
- return openBlock(), createBlock(resolveDynamicComponent(_ctx.tag), mergeProps({
- ref_key: "_ref",
- ref: _ref
- }, unref(_props), {
- class: [
- unref(ns).b(),
- unref(ns).m(unref(_type)),
- unref(ns).m(unref(_size)),
- unref(ns).is("disabled", unref(_disabled)),
- unref(ns).is("loading", _ctx.loading),
- unref(ns).is("plain", _ctx.plain),
- unref(ns).is("round", _ctx.round),
- unref(ns).is("circle", _ctx.circle),
- unref(ns).is("text", _ctx.text),
- unref(ns).is("link", _ctx.link),
- unref(ns).is("has-bg", _ctx.bg)
- ],
- style: unref(buttonStyle),
- onClick: unref(handleClick)
- }), {
- default: withCtx(() => [
- _ctx.loading ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
- _ctx.$slots.loading ? renderSlot(_ctx.$slots, "loading", { key: 0 }) : (openBlock(), createBlock(unref(ElIcon), {
- key: 1,
- class: normalizeClass(unref(ns).is("loading"))
- }, {
- default: withCtx(() => [
- (openBlock(), createBlock(resolveDynamicComponent(_ctx.loadingIcon)))
- ]),
- _: 1
- }, 8, ["class"]))
- ], 64)) : _ctx.icon || _ctx.$slots.icon ? (openBlock(), createBlock(unref(ElIcon), { key: 1 }, {
- default: withCtx(() => [
- _ctx.icon ? (openBlock(), createBlock(resolveDynamicComponent(_ctx.icon), { key: 0 })) : renderSlot(_ctx.$slots, "icon", { key: 1 })
- ]),
- _: 3
- })) : createCommentVNode("v-if", true),
- _ctx.$slots.default ? (openBlock(), createElementBlock("span", {
- key: 2,
- class: normalizeClass({ [unref(ns).em("text", "expand")]: unref(shouldAddSpace) })
- }, [
- renderSlot(_ctx.$slots, "default")
- ], 2)) : createCommentVNode("v-if", true)
- ]),
- _: 3
- }, 16, ["class", "style", "onClick"]);
- };
- }
- });
- var Button$2 = /* @__PURE__ */ _export_sfc$1(_sfc_main$o, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/button/src/button.vue"]]);
- const buttonGroupProps = {
- size: buttonProps.size,
- type: buttonProps.type
- };
- const __default__$d = defineComponent({
- name: "ElButtonGroup"
- });
- const _sfc_main$n = /* @__PURE__ */ defineComponent({
- ...__default__$d,
- props: buttonGroupProps,
- setup(__props) {
- const props = __props;
- provide(buttonGroupContextKey, reactive({
- size: toRef(props, "size"),
- type: toRef(props, "type")
- }));
- const ns = useNamespace("button");
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", {
- class: normalizeClass(`${unref(ns).b("group")}`)
- }, [
- renderSlot(_ctx.$slots, "default")
- ], 2);
- };
- }
- });
- var ButtonGroup = /* @__PURE__ */ _export_sfc$1(_sfc_main$n, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/button/src/button-group.vue"]]);
- const ElButton = withInstall(Button$2, {
- ButtonGroup
- });
- const ElButtonGroup = withNoopInstall(ButtonGroup);
- const nodeList = /* @__PURE__ */ new Map();
- let startClick;
- if (isClient) {
- document.addEventListener("mousedown", (e) => startClick = e);
- document.addEventListener("mouseup", (e) => {
- for (const handlers of nodeList.values()) {
- for (const { documentHandler } of handlers) {
- documentHandler(e, startClick);
- }
- }
- });
- }
- function createDocumentHandler(el, binding) {
- let excludes = [];
- if (Array.isArray(binding.arg)) {
- excludes = binding.arg;
- } else if (isElement(binding.arg)) {
- excludes.push(binding.arg);
- }
- return function(mouseup, mousedown) {
- const popperRef = binding.instance.popperRef;
- const mouseUpTarget = mouseup.target;
- const mouseDownTarget = mousedown == null ? void 0 : mousedown.target;
- const isBound = !binding || !binding.instance;
- const isTargetExists = !mouseUpTarget || !mouseDownTarget;
- const isContainedByEl = el.contains(mouseUpTarget) || el.contains(mouseDownTarget);
- const isSelf = el === mouseUpTarget;
- const isTargetExcluded = excludes.length && excludes.some((item) => item == null ? void 0 : item.contains(mouseUpTarget)) || excludes.length && excludes.includes(mouseDownTarget);
- const isContainedByPopper = popperRef && (popperRef.contains(mouseUpTarget) || popperRef.contains(mouseDownTarget));
- if (isBound || isTargetExists || isContainedByEl || isSelf || isTargetExcluded || isContainedByPopper) {
- return;
- }
- binding.value(mouseup, mousedown);
- };
- }
- const ClickOutside = {
- beforeMount(el, binding) {
- if (!nodeList.has(el)) {
- nodeList.set(el, []);
- }
- nodeList.get(el).push({
- documentHandler: createDocumentHandler(el, binding),
- bindingFn: binding.value
- });
- },
- updated(el, binding) {
- if (!nodeList.has(el)) {
- nodeList.set(el, []);
- }
- const handlers = nodeList.get(el);
- const oldHandlerIndex = handlers.findIndex((item) => item.bindingFn === binding.oldValue);
- const newHandler = {
- documentHandler: createDocumentHandler(el, binding),
- bindingFn: binding.value
- };
- if (oldHandlerIndex >= 0) {
- handlers.splice(oldHandlerIndex, 1, newHandler);
- } else {
- handlers.push(newHandler);
- }
- },
- unmounted(el) {
- nodeList.delete(el);
- }
- };
- const REPEAT_INTERVAL = 100;
- const REPEAT_DELAY = 600;
- const vRepeatClick = {
- beforeMount(el, binding) {
- const value = binding.value;
- const { interval = REPEAT_INTERVAL, delay = REPEAT_DELAY } = isFunction$3(value) ? {} : value;
- let intervalId;
- let delayId;
- const handler = () => isFunction$3(value) ? value() : value.handler();
- const clear = () => {
- if (delayId) {
- clearTimeout(delayId);
- delayId = void 0;
- }
- if (intervalId) {
- clearInterval(intervalId);
- intervalId = void 0;
- }
- };
- el.addEventListener("mousedown", (evt) => {
- if (evt.button !== 0)
- return;
- clear();
- handler();
- document.addEventListener("mouseup", () => clear(), {
- once: true
- });
- delayId = setTimeout(() => {
- intervalId = setInterval(() => {
- handler();
- }, interval);
- }, delay);
- });
- }
- };
- const radioPropsBase = buildProps({
- size: useSizeProp,
- disabled: Boolean,
- label: {
- type: [String, Number, Boolean],
- default: ""
- }
- });
- const radioProps = buildProps({
- ...radioPropsBase,
- modelValue: {
- type: [String, Number, Boolean],
- default: ""
- },
- name: {
- type: String,
- default: ""
- },
- border: Boolean
- });
- const radioEmits = {
- [UPDATE_MODEL_EVENT]: (val) => isString(val) || isNumber(val) || isBoolean(val),
- [CHANGE_EVENT]: (val) => isString(val) || isNumber(val) || isBoolean(val)
- };
- const radioGroupKey = Symbol("radioGroupKey");
- const useRadio = (props, emit) => {
- const radioRef = ref();
- const radioGroup = inject(radioGroupKey, void 0);
- const isGroup = computed$1(() => !!radioGroup);
- const modelValue = computed$1({
- get() {
- return isGroup.value ? radioGroup.modelValue : props.modelValue;
- },
- set(val) {
- if (isGroup.value) {
- radioGroup.changeEvent(val);
- } else {
- emit && emit(UPDATE_MODEL_EVENT, val);
- }
- radioRef.value.checked = props.modelValue === props.label;
- }
- });
- const size = useFormSize(computed$1(() => radioGroup == null ? void 0 : radioGroup.size));
- const disabled = useFormDisabled(computed$1(() => radioGroup == null ? void 0 : radioGroup.disabled));
- const focus = ref(false);
- const tabIndex = computed$1(() => {
- return disabled.value || isGroup.value && modelValue.value !== props.label ? -1 : 0;
- });
- return {
- radioRef,
- isGroup,
- radioGroup,
- focus,
- size,
- disabled,
- tabIndex,
- modelValue
- };
- };
- const _hoisted_1$e = ["value", "name", "disabled"];
- const __default__$c = defineComponent({
- name: "ElRadio"
- });
- const _sfc_main$m = /* @__PURE__ */ defineComponent({
- ...__default__$c,
- props: radioProps,
- emits: radioEmits,
- setup(__props, { emit }) {
- const props = __props;
- const ns = useNamespace("radio");
- const { radioRef, radioGroup, focus, size, disabled, modelValue } = useRadio(props, emit);
- function handleChange() {
- nextTick(() => emit("change", modelValue.value));
- }
- return (_ctx, _cache) => {
- var _a2;
- return openBlock(), createElementBlock("label", {
- class: normalizeClass([
- unref(ns).b(),
- unref(ns).is("disabled", unref(disabled)),
- unref(ns).is("focus", unref(focus)),
- unref(ns).is("bordered", _ctx.border),
- unref(ns).is("checked", unref(modelValue) === _ctx.label),
- unref(ns).m(unref(size))
- ])
- }, [
- createElementVNode("span", {
- class: normalizeClass([
- unref(ns).e("input"),
- unref(ns).is("disabled", unref(disabled)),
- unref(ns).is("checked", unref(modelValue) === _ctx.label)
- ])
- }, [
- withDirectives(createElementVNode("input", {
- ref_key: "radioRef",
- ref: radioRef,
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => isRef(modelValue) ? modelValue.value = $event : null),
- class: normalizeClass(unref(ns).e("original")),
- value: _ctx.label,
- name: _ctx.name || ((_a2 = unref(radioGroup)) == null ? void 0 : _a2.name),
- disabled: unref(disabled),
- type: "radio",
- onFocus: _cache[1] || (_cache[1] = ($event) => focus.value = true),
- onBlur: _cache[2] || (_cache[2] = ($event) => focus.value = false),
- onChange: handleChange
- }, null, 42, _hoisted_1$e), [
- [vModelRadio, unref(modelValue)]
- ]),
- createElementVNode("span", {
- class: normalizeClass(unref(ns).e("inner"))
- }, null, 2)
- ], 2),
- createElementVNode("span", {
- class: normalizeClass(unref(ns).e("label")),
- onKeydown: _cache[3] || (_cache[3] = withModifiers(() => {
- }, ["stop"]))
- }, [
- renderSlot(_ctx.$slots, "default", {}, () => [
- createTextVNode(toDisplayString(_ctx.label), 1)
- ])
- ], 34)
- ], 2);
- };
- }
- });
- var Radio = /* @__PURE__ */ _export_sfc$1(_sfc_main$m, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio.vue"]]);
- const radioButtonProps = buildProps({
- ...radioPropsBase,
- name: {
- type: String,
- default: ""
- }
- });
- const _hoisted_1$d = ["value", "name", "disabled"];
- const __default__$b = defineComponent({
- name: "ElRadioButton"
- });
- const _sfc_main$l = /* @__PURE__ */ defineComponent({
- ...__default__$b,
- props: radioButtonProps,
- setup(__props) {
- const props = __props;
- const ns = useNamespace("radio");
- const { radioRef, focus, size, disabled, modelValue, radioGroup } = useRadio(props);
- const activeStyle = computed$1(() => {
- return {
- backgroundColor: (radioGroup == null ? void 0 : radioGroup.fill) || "",
- borderColor: (radioGroup == null ? void 0 : radioGroup.fill) || "",
- boxShadow: (radioGroup == null ? void 0 : radioGroup.fill) ? `-1px 0 0 0 ${radioGroup.fill}` : "",
- color: (radioGroup == null ? void 0 : radioGroup.textColor) || ""
- };
- });
- return (_ctx, _cache) => {
- var _a2;
- return openBlock(), createElementBlock("label", {
- class: normalizeClass([
- unref(ns).b("button"),
- unref(ns).is("active", unref(modelValue) === _ctx.label),
- unref(ns).is("disabled", unref(disabled)),
- unref(ns).is("focus", unref(focus)),
- unref(ns).bm("button", unref(size))
- ])
- }, [
- withDirectives(createElementVNode("input", {
- ref_key: "radioRef",
- ref: radioRef,
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => isRef(modelValue) ? modelValue.value = $event : null),
- class: normalizeClass(unref(ns).be("button", "original-radio")),
- value: _ctx.label,
- type: "radio",
- name: _ctx.name || ((_a2 = unref(radioGroup)) == null ? void 0 : _a2.name),
- disabled: unref(disabled),
- onFocus: _cache[1] || (_cache[1] = ($event) => focus.value = true),
- onBlur: _cache[2] || (_cache[2] = ($event) => focus.value = false)
- }, null, 42, _hoisted_1$d), [
- [vModelRadio, unref(modelValue)]
- ]),
- createElementVNode("span", {
- class: normalizeClass(unref(ns).be("button", "inner")),
- style: normalizeStyle(unref(modelValue) === _ctx.label ? unref(activeStyle) : {}),
- onKeydown: _cache[3] || (_cache[3] = withModifiers(() => {
- }, ["stop"]))
- }, [
- renderSlot(_ctx.$slots, "default", {}, () => [
- createTextVNode(toDisplayString(_ctx.label), 1)
- ])
- ], 38)
- ], 2);
- };
- }
- });
- var RadioButton = /* @__PURE__ */ _export_sfc$1(_sfc_main$l, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio-button.vue"]]);
- const radioGroupProps = buildProps({
- id: {
- type: String,
- default: void 0
- },
- size: useSizeProp,
- disabled: Boolean,
- modelValue: {
- type: [String, Number, Boolean],
- default: ""
- },
- fill: {
- type: String,
- default: ""
- },
- label: {
- type: String,
- default: void 0
- },
- textColor: {
- type: String,
- default: ""
- },
- name: {
- type: String,
- default: void 0
- },
- validateEvent: {
- type: Boolean,
- default: true
- }
- });
- const radioGroupEmits = radioEmits;
- const _hoisted_1$c = ["id", "aria-label", "aria-labelledby"];
- const __default__$a = defineComponent({
- name: "ElRadioGroup"
- });
- const _sfc_main$k = /* @__PURE__ */ defineComponent({
- ...__default__$a,
- props: radioGroupProps,
- emits: radioGroupEmits,
- setup(__props, { emit }) {
- const props = __props;
- const ns = useNamespace("radio");
- const radioId = useId();
- const radioGroupRef = ref();
- const { formItem } = useFormItem();
- const { inputId: groupId, isLabeledByFormItem } = useFormItemInputId(props, {
- formItemContext: formItem
- });
- const changeEvent = (value) => {
- emit(UPDATE_MODEL_EVENT, value);
- nextTick(() => emit("change", value));
- };
- onMounted(() => {
- const radios = radioGroupRef.value.querySelectorAll("[type=radio]");
- const firstLabel = radios[0];
- if (!Array.from(radios).some((radio) => radio.checked) && firstLabel) {
- firstLabel.tabIndex = 0;
- }
- });
- const name = computed$1(() => {
- return props.name || radioId.value;
- });
- provide(radioGroupKey, reactive({
- ...toRefs(props),
- changeEvent,
- name
- }));
- watch(() => props.modelValue, () => {
- if (props.validateEvent) {
- formItem == null ? void 0 : formItem.validate("change").catch((err) => debugWarn());
- }
- });
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", {
- id: unref(groupId),
- ref_key: "radioGroupRef",
- ref: radioGroupRef,
- class: normalizeClass(unref(ns).b("group")),
- role: "radiogroup",
- "aria-label": !unref(isLabeledByFormItem) ? _ctx.label || "radio-group" : void 0,
- "aria-labelledby": unref(isLabeledByFormItem) ? unref(formItem).labelId : void 0
- }, [
- renderSlot(_ctx.$slots, "default")
- ], 10, _hoisted_1$c);
- };
- }
- });
- var RadioGroup = /* @__PURE__ */ _export_sfc$1(_sfc_main$k, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio-group.vue"]]);
- withInstall(Radio, {
- RadioButton,
- RadioGroup
- });
- const ElRadioGroup = withNoopInstall(RadioGroup);
- const ElRadioButton = withNoopInstall(RadioButton);
- const tagProps = buildProps({
- closable: Boolean,
- type: {
- type: String,
- values: ["success", "info", "warning", "danger", ""],
- default: ""
- },
- hit: Boolean,
- disableTransitions: Boolean,
- color: {
- type: String,
- default: ""
- },
- size: {
- type: String,
- values: componentSizes,
- default: ""
- },
- effect: {
- type: String,
- values: ["dark", "light", "plain"],
- default: "light"
- },
- round: Boolean
- });
- const tagEmits = {
- close: (evt) => evt instanceof MouseEvent,
- click: (evt) => evt instanceof MouseEvent
- };
- const __default__$9 = defineComponent({
- name: "ElTag"
- });
- const _sfc_main$j = /* @__PURE__ */ defineComponent({
- ...__default__$9,
- props: tagProps,
- emits: tagEmits,
- setup(__props, { emit }) {
- const props = __props;
- const tagSize = useFormSize();
- const ns = useNamespace("tag");
- const classes = computed$1(() => {
- const { type: type2, hit, effect, closable, round: round2 } = props;
- return [
- ns.b(),
- ns.is("closable", closable),
- ns.m(type2),
- ns.m(tagSize.value),
- ns.m(effect),
- ns.is("hit", hit),
- ns.is("round", round2)
- ];
- });
- const handleClose = (event2) => {
- emit("close", event2);
- };
- const handleClick = (event2) => {
- emit("click", event2);
- };
- return (_ctx, _cache) => {
- return _ctx.disableTransitions ? (openBlock(), createElementBlock("span", {
- key: 0,
- class: normalizeClass(unref(classes)),
- style: normalizeStyle({ backgroundColor: _ctx.color }),
- onClick: handleClick
- }, [
- createElementVNode("span", {
- class: normalizeClass(unref(ns).e("content"))
- }, [
- renderSlot(_ctx.$slots, "default")
- ], 2),
- _ctx.closable ? (openBlock(), createBlock(unref(ElIcon), {
- key: 0,
- class: normalizeClass(unref(ns).e("close")),
- onClick: withModifiers(handleClose, ["stop"])
- }, {
- default: withCtx(() => [
- createVNode(unref(close_default))
- ]),
- _: 1
- }, 8, ["class", "onClick"])) : createCommentVNode("v-if", true)
- ], 6)) : (openBlock(), createBlock(Transition, {
- key: 1,
- name: `${unref(ns).namespace.value}-zoom-in-center`,
- appear: ""
- }, {
- default: withCtx(() => [
- createElementVNode("span", {
- class: normalizeClass(unref(classes)),
- style: normalizeStyle({ backgroundColor: _ctx.color }),
- onClick: handleClick
- }, [
- createElementVNode("span", {
- class: normalizeClass(unref(ns).e("content"))
- }, [
- renderSlot(_ctx.$slots, "default")
- ], 2),
- _ctx.closable ? (openBlock(), createBlock(unref(ElIcon), {
- key: 0,
- class: normalizeClass(unref(ns).e("close")),
- onClick: withModifiers(handleClose, ["stop"])
- }, {
- default: withCtx(() => [
- createVNode(unref(close_default))
- ]),
- _: 1
- }, 8, ["class", "onClick"])) : createCommentVNode("v-if", true)
- ], 6)
- ]),
- _: 3
- }, 8, ["name"]));
- };
- }
- });
- var Tag = /* @__PURE__ */ _export_sfc$1(_sfc_main$j, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/tag/src/tag.vue"]]);
- const ElTag = withInstall(Tag);
- const emitChangeFn = (value) => typeof isNumber(value);
- const collapseProps = buildProps({
- accordion: Boolean,
- modelValue: {
- type: definePropType([Array, String, Number]),
- default: () => mutable([])
- }
- });
- const collapseEmits = {
- [UPDATE_MODEL_EVENT]: emitChangeFn,
- [CHANGE_EVENT]: emitChangeFn
- };
- const collapseContextKey = Symbol("collapseContextKey");
- const useCollapse = (props, emit) => {
- const activeNames = ref(castArray(props.modelValue));
- const setActiveNames = (_activeNames) => {
- activeNames.value = _activeNames;
- const value = props.accordion ? activeNames.value[0] : activeNames.value;
- emit(UPDATE_MODEL_EVENT, value);
- emit(CHANGE_EVENT, value);
- };
- const handleItemClick = (name) => {
- if (props.accordion) {
- setActiveNames([activeNames.value[0] === name ? "" : name]);
- } else {
- const _activeNames = [...activeNames.value];
- const index2 = _activeNames.indexOf(name);
- if (index2 > -1) {
- _activeNames.splice(index2, 1);
- } else {
- _activeNames.push(name);
- }
- setActiveNames(_activeNames);
- }
- };
- watch(() => props.modelValue, () => activeNames.value = castArray(props.modelValue), { deep: true });
- provide(collapseContextKey, {
- activeNames,
- handleItemClick
- });
- return {
- activeNames,
- setActiveNames
- };
- };
- const useCollapseDOM = () => {
- const ns = useNamespace("collapse");
- const rootKls = computed$1(() => ns.b());
- return {
- rootKls
- };
- };
- const __default__$8 = defineComponent({
- name: "ElCollapse"
- });
- const _sfc_main$i = /* @__PURE__ */ defineComponent({
- ...__default__$8,
- props: collapseProps,
- emits: collapseEmits,
- setup(__props, { expose, emit }) {
- const props = __props;
- const { activeNames, setActiveNames } = useCollapse(props, emit);
- const { rootKls } = useCollapseDOM();
- expose({
- activeNames,
- setActiveNames
- });
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", {
- class: normalizeClass(unref(rootKls)),
- role: "tablist",
- "aria-multiselectable": "true"
- }, [
- renderSlot(_ctx.$slots, "default")
- ], 2);
- };
- }
- });
- var Collapse = /* @__PURE__ */ _export_sfc$1(_sfc_main$i, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/collapse/src/collapse.vue"]]);
- const __default__$7 = defineComponent({
- name: "ElCollapseTransition"
- });
- const _sfc_main$h = /* @__PURE__ */ defineComponent({
- ...__default__$7,
- setup(__props) {
- const ns = useNamespace("collapse-transition");
- const on3 = {
- beforeEnter(el) {
- if (!el.dataset)
- el.dataset = {};
- el.dataset.oldPaddingTop = el.style.paddingTop;
- el.dataset.oldPaddingBottom = el.style.paddingBottom;
- el.style.maxHeight = 0;
- el.style.paddingTop = 0;
- el.style.paddingBottom = 0;
- },
- enter(el) {
- el.dataset.oldOverflow = el.style.overflow;
- if (el.scrollHeight !== 0) {
- el.style.maxHeight = `${el.scrollHeight}px`;
- el.style.paddingTop = el.dataset.oldPaddingTop;
- el.style.paddingBottom = el.dataset.oldPaddingBottom;
- } else {
- el.style.maxHeight = 0;
- el.style.paddingTop = el.dataset.oldPaddingTop;
- el.style.paddingBottom = el.dataset.oldPaddingBottom;
- }
- el.style.overflow = "hidden";
- },
- afterEnter(el) {
- el.style.maxHeight = "";
- el.style.overflow = el.dataset.oldOverflow;
- },
- beforeLeave(el) {
- if (!el.dataset)
- el.dataset = {};
- el.dataset.oldPaddingTop = el.style.paddingTop;
- el.dataset.oldPaddingBottom = el.style.paddingBottom;
- el.dataset.oldOverflow = el.style.overflow;
- el.style.maxHeight = `${el.scrollHeight}px`;
- el.style.overflow = "hidden";
- },
- leave(el) {
- if (el.scrollHeight !== 0) {
- el.style.maxHeight = 0;
- el.style.paddingTop = 0;
- el.style.paddingBottom = 0;
- }
- },
- afterLeave(el) {
- el.style.maxHeight = "";
- el.style.overflow = el.dataset.oldOverflow;
- el.style.paddingTop = el.dataset.oldPaddingTop;
- el.style.paddingBottom = el.dataset.oldPaddingBottom;
- }
- };
- return (_ctx, _cache) => {
- return openBlock(), createBlock(Transition, mergeProps({
- name: unref(ns).b()
- }, toHandlers(on3)), {
- default: withCtx(() => [
- renderSlot(_ctx.$slots, "default")
- ]),
- _: 3
- }, 16, ["name"]);
- };
- }
- });
- var CollapseTransition = /* @__PURE__ */ _export_sfc$1(_sfc_main$h, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/collapse-transition/src/collapse-transition.vue"]]);
- CollapseTransition.install = (app) => {
- app.component(CollapseTransition.name, CollapseTransition);
- };
- const _CollapseTransition = CollapseTransition;
- const collapseItemProps = buildProps({
- title: {
- type: String,
- default: ""
- },
- name: {
- type: definePropType([String, Number]),
- default: () => generateId()
- },
- disabled: Boolean
- });
- const useCollapseItem = (props) => {
- const collapse = inject(collapseContextKey);
- const focusing = ref(false);
- const isClick = ref(false);
- const id = ref(generateId());
- const isActive = computed$1(() => collapse == null ? void 0 : collapse.activeNames.value.includes(props.name));
- const handleFocus = () => {
- setTimeout(() => {
- if (!isClick.value) {
- focusing.value = true;
- } else {
- isClick.value = false;
- }
- }, 50);
- };
- const handleHeaderClick = () => {
- if (props.disabled)
- return;
- collapse == null ? void 0 : collapse.handleItemClick(props.name);
- focusing.value = false;
- isClick.value = true;
- };
- const handleEnterClick = () => {
- collapse == null ? void 0 : collapse.handleItemClick(props.name);
- };
- return {
- focusing,
- id,
- isActive,
- handleFocus,
- handleHeaderClick,
- handleEnterClick
- };
- };
- const useCollapseItemDOM = (props, { focusing, isActive, id }) => {
- const ns = useNamespace("collapse");
- const rootKls = computed$1(() => [
- ns.b("item"),
- ns.is("active", unref(isActive)),
- ns.is("disabled", props.disabled)
- ]);
- const headKls = computed$1(() => [
- ns.be("item", "header"),
- ns.is("active", unref(isActive)),
- { focusing: unref(focusing) && !props.disabled }
- ]);
- const arrowKls = computed$1(() => [
- ns.be("item", "arrow"),
- ns.is("active", unref(isActive))
- ]);
- const itemWrapperKls = computed$1(() => ns.be("item", "wrap"));
- const itemContentKls = computed$1(() => ns.be("item", "content"));
- const scopedContentId = computed$1(() => ns.b(`content-${unref(id)}`));
- const scopedHeadId = computed$1(() => ns.b(`head-${unref(id)}`));
- return {
- arrowKls,
- headKls,
- rootKls,
- itemWrapperKls,
- itemContentKls,
- scopedContentId,
- scopedHeadId
- };
- };
- const _hoisted_1$b = ["aria-expanded", "aria-controls", "aria-describedby"];
- const _hoisted_2$8 = ["id", "tabindex"];
- const _hoisted_3$5 = ["id", "aria-hidden", "aria-labelledby"];
- const __default__$6 = defineComponent({
- name: "ElCollapseItem"
- });
- const _sfc_main$g = /* @__PURE__ */ defineComponent({
- ...__default__$6,
- props: collapseItemProps,
- setup(__props, { expose }) {
- const props = __props;
- const {
- focusing,
- id,
- isActive,
- handleFocus,
- handleHeaderClick,
- handleEnterClick
- } = useCollapseItem(props);
- const {
- arrowKls,
- headKls,
- rootKls,
- itemWrapperKls,
- itemContentKls,
- scopedContentId,
- scopedHeadId
- } = useCollapseItemDOM(props, { focusing, isActive, id });
- expose({
- isActive
- });
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", {
- class: normalizeClass(unref(rootKls))
- }, [
- createElementVNode("div", {
- role: "tab",
- "aria-expanded": unref(isActive),
- "aria-controls": unref(scopedContentId),
- "aria-describedby": unref(scopedContentId)
- }, [
- createElementVNode("div", {
- id: unref(scopedHeadId),
- class: normalizeClass(unref(headKls)),
- role: "button",
- tabindex: _ctx.disabled ? -1 : 0,
- onClick: _cache[0] || (_cache[0] = (...args) => unref(handleHeaderClick) && unref(handleHeaderClick)(...args)),
- onKeypress: _cache[1] || (_cache[1] = withKeys(withModifiers((...args) => unref(handleEnterClick) && unref(handleEnterClick)(...args), ["stop", "prevent"]), ["space", "enter"])),
- onFocus: _cache[2] || (_cache[2] = (...args) => unref(handleFocus) && unref(handleFocus)(...args)),
- onBlur: _cache[3] || (_cache[3] = ($event) => focusing.value = false)
- }, [
- renderSlot(_ctx.$slots, "title", {}, () => [
- createTextVNode(toDisplayString(_ctx.title), 1)
- ]),
- createVNode(unref(ElIcon), {
- class: normalizeClass(unref(arrowKls))
- }, {
- default: withCtx(() => [
- createVNode(unref(arrow_right_default))
- ]),
- _: 1
- }, 8, ["class"])
- ], 42, _hoisted_2$8)
- ], 8, _hoisted_1$b),
- createVNode(unref(_CollapseTransition), null, {
- default: withCtx(() => [
- withDirectives(createElementVNode("div", {
- id: unref(scopedContentId),
- class: normalizeClass(unref(itemWrapperKls)),
- role: "tabpanel",
- "aria-hidden": !unref(isActive),
- "aria-labelledby": unref(scopedHeadId)
- }, [
- createElementVNode("div", {
- class: normalizeClass(unref(itemContentKls))
- }, [
- renderSlot(_ctx.$slots, "default")
- ], 2)
- ], 10, _hoisted_3$5), [
- [vShow, unref(isActive)]
- ])
- ]),
- _: 3
- })
- ], 2);
- };
- }
- });
- var CollapseItem = /* @__PURE__ */ _export_sfc$1(_sfc_main$g, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/collapse/src/collapse-item.vue"]]);
- const ElCollapse = withInstall(Collapse, {
- CollapseItem
- });
- const ElCollapseItem = withNoopInstall(CollapseItem);
- const alphaSliderProps = buildProps({
- color: {
- type: definePropType(Object),
- required: true
- },
- vertical: {
- type: Boolean,
- default: false
- }
- });
- let isDragging = false;
- function draggable(element, options2) {
- if (!isClient)
- return;
- const moveFn = function(event2) {
- var _a2;
- (_a2 = options2.drag) == null ? void 0 : _a2.call(options2, event2);
- };
- const upFn = function(event2) {
- var _a2;
- document.removeEventListener("mousemove", moveFn);
- document.removeEventListener("mouseup", upFn);
- document.removeEventListener("touchmove", moveFn);
- document.removeEventListener("touchend", upFn);
- document.onselectstart = null;
- document.ondragstart = null;
- isDragging = false;
- (_a2 = options2.end) == null ? void 0 : _a2.call(options2, event2);
- };
- const downFn = function(event2) {
- var _a2;
- if (isDragging)
- return;
- event2.preventDefault();
- document.onselectstart = () => false;
- document.ondragstart = () => false;
- document.addEventListener("mousemove", moveFn);
- document.addEventListener("mouseup", upFn);
- document.addEventListener("touchmove", moveFn);
- document.addEventListener("touchend", upFn);
- isDragging = true;
- (_a2 = options2.start) == null ? void 0 : _a2.call(options2, event2);
- };
- element.addEventListener("mousedown", downFn);
- element.addEventListener("touchstart", downFn);
- }
- const useAlphaSlider = (props) => {
- const instance = getCurrentInstance();
- const thumb = shallowRef();
- const bar = shallowRef();
- function handleClick(event2) {
- const target = event2.target;
- if (target !== thumb.value) {
- handleDrag(event2);
- }
- }
- function handleDrag(event2) {
- if (!bar.value || !thumb.value)
- return;
- const el = instance.vnode.el;
- const rect = el.getBoundingClientRect();
- const { clientX, clientY } = getClientXY(event2);
- if (!props.vertical) {
- let left = clientX - rect.left;
- left = Math.max(thumb.value.offsetWidth / 2, left);
- left = Math.min(left, rect.width - thumb.value.offsetWidth / 2);
- props.color.set("alpha", Math.round((left - thumb.value.offsetWidth / 2) / (rect.width - thumb.value.offsetWidth) * 100));
- } else {
- let top = clientY - rect.top;
- top = Math.max(thumb.value.offsetHeight / 2, top);
- top = Math.min(top, rect.height - thumb.value.offsetHeight / 2);
- props.color.set("alpha", Math.round((top - thumb.value.offsetHeight / 2) / (rect.height - thumb.value.offsetHeight) * 100));
- }
- }
- return {
- thumb,
- bar,
- handleDrag,
- handleClick
- };
- };
- const useAlphaSliderDOM = (props, {
- bar,
- thumb,
- handleDrag
- }) => {
- const instance = getCurrentInstance();
- const ns = useNamespace("color-alpha-slider");
- const thumbLeft = ref(0);
- const thumbTop = ref(0);
- const background = ref();
- function getThumbLeft() {
- if (!thumb.value)
- return 0;
- if (props.vertical)
- return 0;
- const el = instance.vnode.el;
- const alpha = props.color.get("alpha");
- if (!el)
- return 0;
- return Math.round(alpha * (el.offsetWidth - thumb.value.offsetWidth / 2) / 100);
- }
- function getThumbTop() {
- if (!thumb.value)
- return 0;
- const el = instance.vnode.el;
- if (!props.vertical)
- return 0;
- const alpha = props.color.get("alpha");
- if (!el)
- return 0;
- return Math.round(alpha * (el.offsetHeight - thumb.value.offsetHeight / 2) / 100);
- }
- function getBackground() {
- if (props.color && props.color.value) {
- const { r: r2, g, b } = props.color.toRgb();
- return `linear-gradient(to right, rgba(${r2}, ${g}, ${b}, 0) 0%, rgba(${r2}, ${g}, ${b}, 1) 100%)`;
- }
- return "";
- }
- function update() {
- thumbLeft.value = getThumbLeft();
- thumbTop.value = getThumbTop();
- background.value = getBackground();
- }
- onMounted(() => {
- if (!bar.value || !thumb.value)
- return;
- const dragConfig = {
- drag: (event2) => {
- handleDrag(event2);
- },
- end: (event2) => {
- handleDrag(event2);
- }
- };
- draggable(bar.value, dragConfig);
- draggable(thumb.value, dragConfig);
- update();
- });
- watch(() => props.color.get("alpha"), () => update());
- watch(() => props.color.value, () => update());
- const rootKls = computed$1(() => [ns.b(), ns.is("vertical", props.vertical)]);
- const barKls = computed$1(() => ns.e("bar"));
- const thumbKls = computed$1(() => ns.e("thumb"));
- const barStyle = computed$1(() => ({ background: background.value }));
- const thumbStyle = computed$1(() => ({
- left: addUnit(thumbLeft.value),
- top: addUnit(thumbTop.value)
- }));
- return { rootKls, barKls, barStyle, thumbKls, thumbStyle, update };
- };
- const COMPONENT_NAME$2 = "ElColorAlphaSlider";
- const __default__$5 = defineComponent({
- name: COMPONENT_NAME$2
- });
- const _sfc_main$f = /* @__PURE__ */ defineComponent({
- ...__default__$5,
- props: alphaSliderProps,
- setup(__props, { expose }) {
- const props = __props;
- const { bar, thumb, handleDrag, handleClick } = useAlphaSlider(props);
- const { rootKls, barKls, barStyle, thumbKls, thumbStyle, update } = useAlphaSliderDOM(props, {
- bar,
- thumb,
- handleDrag
- });
- expose({
- update,
- bar,
- thumb
- });
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", {
- class: normalizeClass(unref(rootKls))
- }, [
- createElementVNode("div", {
- ref_key: "bar",
- ref: bar,
- class: normalizeClass(unref(barKls)),
- style: normalizeStyle(unref(barStyle)),
- onClick: _cache[0] || (_cache[0] = (...args) => unref(handleClick) && unref(handleClick)(...args))
- }, null, 6),
- createElementVNode("div", {
- ref_key: "thumb",
- ref: thumb,
- class: normalizeClass(unref(thumbKls)),
- style: normalizeStyle(unref(thumbStyle))
- }, null, 6)
- ], 2);
- };
- }
- });
- var AlphaSlider = /* @__PURE__ */ _export_sfc$1(_sfc_main$f, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/color-picker/src/components/alpha-slider.vue"]]);
- const _sfc_main$e = defineComponent({
- name: "ElColorHueSlider",
- props: {
- color: {
- type: Object,
- required: true
- },
- vertical: Boolean
- },
- setup(props) {
- const ns = useNamespace("color-hue-slider");
- const instance = getCurrentInstance();
- const thumb = ref();
- const bar = ref();
- const thumbLeft = ref(0);
- const thumbTop = ref(0);
- const hueValue = computed$1(() => {
- return props.color.get("hue");
- });
- watch(() => hueValue.value, () => {
- update();
- });
- function handleClick(event2) {
- const target = event2.target;
- if (target !== thumb.value) {
- handleDrag(event2);
- }
- }
- function handleDrag(event2) {
- if (!bar.value || !thumb.value)
- return;
- const el = instance.vnode.el;
- const rect = el.getBoundingClientRect();
- const { clientX, clientY } = getClientXY(event2);
- let hue;
- if (!props.vertical) {
- let left = clientX - rect.left;
- left = Math.min(left, rect.width - thumb.value.offsetWidth / 2);
- left = Math.max(thumb.value.offsetWidth / 2, left);
- hue = Math.round((left - thumb.value.offsetWidth / 2) / (rect.width - thumb.value.offsetWidth) * 360);
- } else {
- let top = clientY - rect.top;
- top = Math.min(top, rect.height - thumb.value.offsetHeight / 2);
- top = Math.max(thumb.value.offsetHeight / 2, top);
- hue = Math.round((top - thumb.value.offsetHeight / 2) / (rect.height - thumb.value.offsetHeight) * 360);
- }
- props.color.set("hue", hue);
- }
- function getThumbLeft() {
- if (!thumb.value)
- return 0;
- const el = instance.vnode.el;
- if (props.vertical)
- return 0;
- const hue = props.color.get("hue");
- if (!el)
- return 0;
- return Math.round(hue * (el.offsetWidth - thumb.value.offsetWidth / 2) / 360);
- }
- function getThumbTop() {
- if (!thumb.value)
- return 0;
- const el = instance.vnode.el;
- if (!props.vertical)
- return 0;
- const hue = props.color.get("hue");
- if (!el)
- return 0;
- return Math.round(hue * (el.offsetHeight - thumb.value.offsetHeight / 2) / 360);
- }
- function update() {
- thumbLeft.value = getThumbLeft();
- thumbTop.value = getThumbTop();
- }
- onMounted(() => {
- if (!bar.value || !thumb.value)
- return;
- const dragConfig = {
- drag: (event2) => {
- handleDrag(event2);
- },
- end: (event2) => {
- handleDrag(event2);
- }
- };
- draggable(bar.value, dragConfig);
- draggable(thumb.value, dragConfig);
- update();
- });
- return {
- bar,
- thumb,
- thumbLeft,
- thumbTop,
- hueValue,
- handleClick,
- update,
- ns
- };
- }
- });
- function _sfc_render$6(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("div", {
- class: normalizeClass([_ctx.ns.b(), _ctx.ns.is("vertical", _ctx.vertical)])
- }, [
- createElementVNode("div", {
- ref: "bar",
- class: normalizeClass(_ctx.ns.e("bar")),
- onClick: _cache[0] || (_cache[0] = (...args) => _ctx.handleClick && _ctx.handleClick(...args))
- }, null, 2),
- createElementVNode("div", {
- ref: "thumb",
- class: normalizeClass(_ctx.ns.e("thumb")),
- style: normalizeStyle({
- left: _ctx.thumbLeft + "px",
- top: _ctx.thumbTop + "px"
- })
- }, null, 6)
- ], 2);
- }
- var HueSlider = /* @__PURE__ */ _export_sfc$1(_sfc_main$e, [["render", _sfc_render$6], ["__file", "/home/runner/work/element-plus/element-plus/packages/components/color-picker/src/components/hue-slider.vue"]]);
- const colorPickerProps = buildProps({
- modelValue: String,
- id: String,
- showAlpha: Boolean,
- colorFormat: String,
- disabled: Boolean,
- size: useSizeProp,
- popperClass: {
- type: String,
- default: ""
- },
- label: {
- type: String,
- default: void 0
- },
- tabindex: {
- type: [String, Number],
- default: 0
- },
- predefine: {
- type: definePropType(Array)
- },
- validateEvent: {
- type: Boolean,
- default: true
- }
- });
- const colorPickerEmits = {
- [UPDATE_MODEL_EVENT]: (val) => isString(val) || isNil(val),
- [CHANGE_EVENT]: (val) => isString(val) || isNil(val),
- activeChange: (val) => isString(val) || isNil(val)
- };
- const colorPickerContextKey = Symbol("colorPickerContextKey");
- const hsv2hsl = function(hue, sat, val) {
- return [
- hue,
- sat * val / ((hue = (2 - sat) * val) < 1 ? hue : 2 - hue) || 0,
- hue / 2
- ];
- };
- const isOnePointZero = function(n) {
- return typeof n === "string" && n.includes(".") && Number.parseFloat(n) === 1;
- };
- const isPercentage = function(n) {
- return typeof n === "string" && n.includes("%");
- };
- const bound01 = function(value, max2) {
- if (isOnePointZero(value))
- value = "100%";
- const processPercent = isPercentage(value);
- value = Math.min(max2, Math.max(0, Number.parseFloat(`${value}`)));
- if (processPercent) {
- value = Number.parseInt(`${value * max2}`, 10) / 100;
- }
- if (Math.abs(value - max2) < 1e-6) {
- return 1;
- }
- return value % max2 / Number.parseFloat(max2);
- };
- const INT_HEX_MAP = {
- 10: "A",
- 11: "B",
- 12: "C",
- 13: "D",
- 14: "E",
- 15: "F"
- };
- const hexOne = (value) => {
- value = Math.min(Math.round(value), 255);
- const high = Math.floor(value / 16);
- const low = value % 16;
- return `${INT_HEX_MAP[high] || high}${INT_HEX_MAP[low] || low}`;
- };
- const toHex = function({ r: r2, g, b }) {
- if (Number.isNaN(+r2) || Number.isNaN(+g) || Number.isNaN(+b))
- return "";
- return `#${hexOne(r2)}${hexOne(g)}${hexOne(b)}`;
- };
- const HEX_INT_MAP = {
- A: 10,
- B: 11,
- C: 12,
- D: 13,
- E: 14,
- F: 15
- };
- const parseHexChannel = function(hex) {
- if (hex.length === 2) {
- return (HEX_INT_MAP[hex[0].toUpperCase()] || +hex[0]) * 16 + (HEX_INT_MAP[hex[1].toUpperCase()] || +hex[1]);
- }
- return HEX_INT_MAP[hex[1].toUpperCase()] || +hex[1];
- };
- const hsl2hsv = function(hue, sat, light) {
- sat = sat / 100;
- light = light / 100;
- let smin = sat;
- const lmin = Math.max(light, 0.01);
- light *= 2;
- sat *= light <= 1 ? light : 2 - light;
- smin *= lmin <= 1 ? lmin : 2 - lmin;
- const v = (light + sat) / 2;
- const sv = light === 0 ? 2 * smin / (lmin + smin) : 2 * sat / (light + sat);
- return {
- h: hue,
- s: sv * 100,
- v: v * 100
- };
- };
- const rgb2hsv = (r2, g, b) => {
- r2 = bound01(r2, 255);
- g = bound01(g, 255);
- b = bound01(b, 255);
- const max2 = Math.max(r2, g, b);
- const min2 = Math.min(r2, g, b);
- let h2;
- const v = max2;
- const d2 = max2 - min2;
- const s = max2 === 0 ? 0 : d2 / max2;
- if (max2 === min2) {
- h2 = 0;
- } else {
- switch (max2) {
- case r2: {
- h2 = (g - b) / d2 + (g < b ? 6 : 0);
- break;
- }
- case g: {
- h2 = (b - r2) / d2 + 2;
- break;
- }
- case b: {
- h2 = (r2 - g) / d2 + 4;
- break;
- }
- }
- h2 /= 6;
- }
- return { h: h2 * 360, s: s * 100, v: v * 100 };
- };
- const hsv2rgb = function(h2, s, v) {
- h2 = bound01(h2, 360) * 6;
- s = bound01(s, 100);
- v = bound01(v, 100);
- const i2 = Math.floor(h2);
- const f = h2 - i2;
- const p = v * (1 - s);
- const q2 = v * (1 - f * s);
- const t2 = v * (1 - (1 - f) * s);
- const mod = i2 % 6;
- const r2 = [v, q2, p, p, t2, v][mod];
- const g = [t2, v, v, q2, p, p][mod];
- const b = [p, p, t2, v, v, q2][mod];
- return {
- r: Math.round(r2 * 255),
- g: Math.round(g * 255),
- b: Math.round(b * 255)
- };
- };
- class Color$1 {
- constructor(options2 = {}) {
- this._hue = 0;
- this._saturation = 100;
- this._value = 100;
- this._alpha = 100;
- this.enableAlpha = false;
- this.format = "hex";
- this.value = "";
- for (const option in options2) {
- if (hasOwn(options2, option)) {
- this[option] = options2[option];
- }
- }
- if (options2.value) {
- this.fromString(options2.value);
- } else {
- this.doOnChange();
- }
- }
- set(prop, value) {
- if (arguments.length === 1 && typeof prop === "object") {
- for (const p in prop) {
- if (hasOwn(prop, p)) {
- this.set(p, prop[p]);
- }
- }
- return;
- }
- this[`_${prop}`] = value;
- this.doOnChange();
- }
- get(prop) {
- if (prop === "alpha") {
- return Math.floor(this[`_${prop}`]);
- }
- return this[`_${prop}`];
- }
- toRgb() {
- return hsv2rgb(this._hue, this._saturation, this._value);
- }
- fromString(value) {
- if (!value) {
- this._hue = 0;
- this._saturation = 100;
- this._value = 100;
- this.doOnChange();
- return;
- }
- const fromHSV = (h2, s, v) => {
- this._hue = Math.max(0, Math.min(360, h2));
- this._saturation = Math.max(0, Math.min(100, s));
- this._value = Math.max(0, Math.min(100, v));
- this.doOnChange();
- };
- if (value.includes("hsl")) {
- const parts = value.replace(/hsla|hsl|\(|\)/gm, "").split(/\s|,/g).filter((val) => val !== "").map((val, index2) => index2 > 2 ? Number.parseFloat(val) : Number.parseInt(val, 10));
- if (parts.length === 4) {
- this._alpha = Number.parseFloat(parts[3]) * 100;
- } else if (parts.length === 3) {
- this._alpha = 100;
- }
- if (parts.length >= 3) {
- const { h: h2, s, v } = hsl2hsv(parts[0], parts[1], parts[2]);
- fromHSV(h2, s, v);
- }
- } else if (value.includes("hsv")) {
- const parts = value.replace(/hsva|hsv|\(|\)/gm, "").split(/\s|,/g).filter((val) => val !== "").map((val, index2) => index2 > 2 ? Number.parseFloat(val) : Number.parseInt(val, 10));
- if (parts.length === 4) {
- this._alpha = Number.parseFloat(parts[3]) * 100;
- } else if (parts.length === 3) {
- this._alpha = 100;
- }
- if (parts.length >= 3) {
- fromHSV(parts[0], parts[1], parts[2]);
- }
- } else if (value.includes("rgb")) {
- const parts = value.replace(/rgba|rgb|\(|\)/gm, "").split(/\s|,/g).filter((val) => val !== "").map((val, index2) => index2 > 2 ? Number.parseFloat(val) : Number.parseInt(val, 10));
- if (parts.length === 4) {
- this._alpha = Number.parseFloat(parts[3]) * 100;
- } else if (parts.length === 3) {
- this._alpha = 100;
- }
- if (parts.length >= 3) {
- const { h: h2, s, v } = rgb2hsv(parts[0], parts[1], parts[2]);
- fromHSV(h2, s, v);
- }
- } else if (value.includes("#")) {
- const hex = value.replace("#", "").trim();
- if (!/^[0-9a-fA-F]{3}$|^[0-9a-fA-F]{6}$|^[0-9a-fA-F]{8}$/.test(hex))
- return;
- let r2, g, b;
- if (hex.length === 3) {
- r2 = parseHexChannel(hex[0] + hex[0]);
- g = parseHexChannel(hex[1] + hex[1]);
- b = parseHexChannel(hex[2] + hex[2]);
- } else if (hex.length === 6 || hex.length === 8) {
- r2 = parseHexChannel(hex.slice(0, 2));
- g = parseHexChannel(hex.slice(2, 4));
- b = parseHexChannel(hex.slice(4, 6));
- }
- if (hex.length === 8) {
- this._alpha = parseHexChannel(hex.slice(6)) / 255 * 100;
- } else if (hex.length === 3 || hex.length === 6) {
- this._alpha = 100;
- }
- const { h: h2, s, v } = rgb2hsv(r2, g, b);
- fromHSV(h2, s, v);
- }
- }
- compare(color2) {
- return Math.abs(color2._hue - this._hue) < 2 && Math.abs(color2._saturation - this._saturation) < 1 && Math.abs(color2._value - this._value) < 1 && Math.abs(color2._alpha - this._alpha) < 1;
- }
- doOnChange() {
- const { _hue, _saturation, _value, _alpha, format } = this;
- if (this.enableAlpha) {
- switch (format) {
- case "hsl": {
- const hsl = hsv2hsl(_hue, _saturation / 100, _value / 100);
- this.value = `hsla(${_hue}, ${Math.round(hsl[1] * 100)}%, ${Math.round(hsl[2] * 100)}%, ${this.get("alpha") / 100})`;
- break;
- }
- case "hsv": {
- this.value = `hsva(${_hue}, ${Math.round(_saturation)}%, ${Math.round(_value)}%, ${this.get("alpha") / 100})`;
- break;
- }
- case "hex": {
- this.value = `${toHex(hsv2rgb(_hue, _saturation, _value))}${hexOne(_alpha * 255 / 100)}`;
- break;
- }
- default: {
- const { r: r2, g, b } = hsv2rgb(_hue, _saturation, _value);
- this.value = `rgba(${r2}, ${g}, ${b}, ${this.get("alpha") / 100})`;
- }
- }
- } else {
- switch (format) {
- case "hsl": {
- const hsl = hsv2hsl(_hue, _saturation / 100, _value / 100);
- this.value = `hsl(${_hue}, ${Math.round(hsl[1] * 100)}%, ${Math.round(hsl[2] * 100)}%)`;
- break;
- }
- case "hsv": {
- this.value = `hsv(${_hue}, ${Math.round(_saturation)}%, ${Math.round(_value)}%)`;
- break;
- }
- case "rgb": {
- const { r: r2, g, b } = hsv2rgb(_hue, _saturation, _value);
- this.value = `rgb(${r2}, ${g}, ${b})`;
- break;
- }
- default: {
- this.value = toHex(hsv2rgb(_hue, _saturation, _value));
- }
- }
- }
- }
- }
- const _sfc_main$d = defineComponent({
- props: {
- colors: {
- type: Array,
- required: true
- },
- color: {
- type: Object,
- required: true
- }
- },
- setup(props) {
- const ns = useNamespace("color-predefine");
- const { currentColor } = inject(colorPickerContextKey);
- const rgbaColors = ref(parseColors(props.colors, props.color));
- watch(() => currentColor.value, (val) => {
- const color2 = new Color$1();
- color2.fromString(val);
- rgbaColors.value.forEach((item) => {
- item.selected = color2.compare(item);
- });
- });
- watchEffect(() => {
- rgbaColors.value = parseColors(props.colors, props.color);
- });
- function handleSelect(index2) {
- props.color.fromString(props.colors[index2]);
- }
- function parseColors(colors, color2) {
- return colors.map((value) => {
- const c = new Color$1();
- c.enableAlpha = true;
- c.format = "rgba";
- c.fromString(value);
- c.selected = c.value === color2.value;
- return c;
- });
- }
- return {
- rgbaColors,
- handleSelect,
- ns
- };
- }
- });
- const _hoisted_1$a = ["onClick"];
- function _sfc_render$5(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("div", {
- class: normalizeClass(_ctx.ns.b())
- }, [
- createElementVNode("div", {
- class: normalizeClass(_ctx.ns.e("colors"))
- }, [
- (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.rgbaColors, (item, index2) => {
- return openBlock(), createElementBlock("div", {
- key: _ctx.colors[index2],
- class: normalizeClass([
- _ctx.ns.e("color-selector"),
- _ctx.ns.is("alpha", item._alpha < 100),
- { selected: item.selected }
- ]),
- onClick: ($event) => _ctx.handleSelect(index2)
- }, [
- createElementVNode("div", {
- style: normalizeStyle({ backgroundColor: item.value })
- }, null, 4)
- ], 10, _hoisted_1$a);
- }), 128))
- ], 2)
- ], 2);
- }
- var Predefine = /* @__PURE__ */ _export_sfc$1(_sfc_main$d, [["render", _sfc_render$5], ["__file", "/home/runner/work/element-plus/element-plus/packages/components/color-picker/src/components/predefine.vue"]]);
- const _sfc_main$c = defineComponent({
- name: "ElSlPanel",
- props: {
- color: {
- type: Object,
- required: true
- }
- },
- setup(props) {
- const ns = useNamespace("color-svpanel");
- const instance = getCurrentInstance();
- const cursorTop = ref(0);
- const cursorLeft = ref(0);
- const background = ref("hsl(0, 100%, 50%)");
- const colorValue = computed$1(() => {
- const hue = props.color.get("hue");
- const value = props.color.get("value");
- return { hue, value };
- });
- function update() {
- const saturation = props.color.get("saturation");
- const value = props.color.get("value");
- const el = instance.vnode.el;
- const { clientWidth: width2, clientHeight: height2 } = el;
- cursorLeft.value = saturation * width2 / 100;
- cursorTop.value = (100 - value) * height2 / 100;
- background.value = `hsl(${props.color.get("hue")}, 100%, 50%)`;
- }
- function handleDrag(event2) {
- const el = instance.vnode.el;
- const rect = el.getBoundingClientRect();
- const { clientX, clientY } = getClientXY(event2);
- let left = clientX - rect.left;
- let top = clientY - rect.top;
- left = Math.max(0, left);
- left = Math.min(left, rect.width);
- top = Math.max(0, top);
- top = Math.min(top, rect.height);
- cursorLeft.value = left;
- cursorTop.value = top;
- props.color.set({
- saturation: left / rect.width * 100,
- value: 100 - top / rect.height * 100
- });
- }
- watch(() => colorValue.value, () => {
- update();
- });
- onMounted(() => {
- draggable(instance.vnode.el, {
- drag: (event2) => {
- handleDrag(event2);
- },
- end: (event2) => {
- handleDrag(event2);
- }
- });
- update();
- });
- return {
- cursorTop,
- cursorLeft,
- background,
- colorValue,
- handleDrag,
- update,
- ns
- };
- }
- });
- const _hoisted_1$9 = /* @__PURE__ */ createElementVNode("div", null, null, -1);
- const _hoisted_2$7 = [
- _hoisted_1$9
- ];
- function _sfc_render$4(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("div", {
- class: normalizeClass(_ctx.ns.b()),
- style: normalizeStyle({
- backgroundColor: _ctx.background
- })
- }, [
- createElementVNode("div", {
- class: normalizeClass(_ctx.ns.e("white"))
- }, null, 2),
- createElementVNode("div", {
- class: normalizeClass(_ctx.ns.e("black"))
- }, null, 2),
- createElementVNode("div", {
- class: normalizeClass(_ctx.ns.e("cursor")),
- style: normalizeStyle({
- top: _ctx.cursorTop + "px",
- left: _ctx.cursorLeft + "px"
- })
- }, _hoisted_2$7, 6)
- ], 6);
- }
- var SvPanel = /* @__PURE__ */ _export_sfc$1(_sfc_main$c, [["render", _sfc_render$4], ["__file", "/home/runner/work/element-plus/element-plus/packages/components/color-picker/src/components/sv-panel.vue"]]);
- const _hoisted_1$8 = ["id", "aria-label", "aria-labelledby", "aria-description", "tabindex", "onKeydown"];
- const __default__$4 = defineComponent({
- name: "ElColorPicker"
- });
- const _sfc_main$b = /* @__PURE__ */ defineComponent({
- ...__default__$4,
- props: colorPickerProps,
- emits: colorPickerEmits,
- setup(__props, { expose, emit }) {
- const props = __props;
- const { t: t2 } = useLocale();
- const ns = useNamespace("color");
- const { formItem } = useFormItem();
- const colorSize = useFormSize();
- const colorDisabled = useFormDisabled();
- const { inputId: buttonId, isLabeledByFormItem } = useFormItemInputId(props, {
- formItemContext: formItem
- });
- const hue = ref();
- const sv = ref();
- const alpha = ref();
- const popper = ref();
- let shouldActiveChange = true;
- const color2 = reactive(new Color$1({
- enableAlpha: props.showAlpha,
- format: props.colorFormat || "",
- value: props.modelValue
- }));
- const showPicker = ref(false);
- const showPanelColor = ref(false);
- const customInput = ref("");
- const displayedColor = computed$1(() => {
- if (!props.modelValue && !showPanelColor.value) {
- return "transparent";
- }
- return displayedRgb(color2, props.showAlpha);
- });
- const currentColor = computed$1(() => {
- return !props.modelValue && !showPanelColor.value ? "" : color2.value;
- });
- const buttonAriaLabel = computed$1(() => {
- return !isLabeledByFormItem.value ? props.label || t2("el.colorpicker.defaultLabel") : void 0;
- });
- const buttonAriaLabelledby = computed$1(() => {
- return isLabeledByFormItem.value ? formItem == null ? void 0 : formItem.labelId : void 0;
- });
- const btnKls = computed$1(() => {
- return [
- ns.b("picker"),
- ns.is("disabled", colorDisabled.value),
- ns.bm("picker", colorSize.value)
- ];
- });
- function displayedRgb(color22, showAlpha) {
- if (!(color22 instanceof Color$1)) {
- throw new TypeError("color should be instance of _color Class");
- }
- const { r: r2, g, b } = color22.toRgb();
- return showAlpha ? `rgba(${r2}, ${g}, ${b}, ${color22.get("alpha") / 100})` : `rgb(${r2}, ${g}, ${b})`;
- }
- function setShowPicker(value) {
- showPicker.value = value;
- }
- const debounceSetShowPicker = debounce$2(setShowPicker, 100);
- function show() {
- if (colorDisabled.value)
- return;
- setShowPicker(true);
- }
- function hide() {
- debounceSetShowPicker(false);
- resetColor();
- }
- function resetColor() {
- nextTick(() => {
- if (props.modelValue) {
- color2.fromString(props.modelValue);
- } else {
- color2.value = "";
- nextTick(() => {
- showPanelColor.value = false;
- });
- }
- });
- }
- function handleTrigger() {
- if (colorDisabled.value)
- return;
- debounceSetShowPicker(!showPicker.value);
- }
- function handleConfirm() {
- color2.fromString(customInput.value);
- }
- function confirmValue() {
- const value = color2.value;
- emit(UPDATE_MODEL_EVENT, value);
- emit("change", value);
- if (props.validateEvent) {
- formItem == null ? void 0 : formItem.validate("change").catch((err) => debugWarn());
- }
- debounceSetShowPicker(false);
- nextTick(() => {
- const newColor = new Color$1({
- enableAlpha: props.showAlpha,
- format: props.colorFormat || "",
- value: props.modelValue
- });
- if (!color2.compare(newColor)) {
- resetColor();
- }
- });
- }
- function clear() {
- debounceSetShowPicker(false);
- emit(UPDATE_MODEL_EVENT, null);
- emit("change", null);
- if (props.modelValue !== null && props.validateEvent) {
- formItem == null ? void 0 : formItem.validate("change").catch((err) => debugWarn());
- }
- resetColor();
- }
- onMounted(() => {
- if (props.modelValue) {
- customInput.value = currentColor.value;
- }
- });
- watch(() => props.modelValue, (newVal) => {
- if (!newVal) {
- showPanelColor.value = false;
- } else if (newVal && newVal !== color2.value) {
- shouldActiveChange = false;
- color2.fromString(newVal);
- }
- });
- watch(() => currentColor.value, (val) => {
- customInput.value = val;
- shouldActiveChange && emit("activeChange", val);
- shouldActiveChange = true;
- });
- watch(() => color2.value, () => {
- if (!props.modelValue && !showPanelColor.value) {
- showPanelColor.value = true;
- }
- });
- watch(() => showPicker.value, () => {
- nextTick(() => {
- var _a2, _b, _c;
- (_a2 = hue.value) == null ? void 0 : _a2.update();
- (_b = sv.value) == null ? void 0 : _b.update();
- (_c = alpha.value) == null ? void 0 : _c.update();
- });
- });
- provide(colorPickerContextKey, {
- currentColor
- });
- expose({
- color: color2,
- show,
- hide
- });
- return (_ctx, _cache) => {
- return openBlock(), createBlock(unref(ElTooltip), {
- ref_key: "popper",
- ref: popper,
- visible: showPicker.value,
- "show-arrow": false,
- "fallback-placements": ["bottom", "top", "right", "left"],
- offset: 0,
- "gpu-acceleration": false,
- "popper-class": [unref(ns).be("picker", "panel"), unref(ns).b("dropdown"), _ctx.popperClass],
- "stop-popper-mouse-event": false,
- effect: "light",
- trigger: "click",
- transition: `${unref(ns).namespace.value}-zoom-in-top`,
- persistent: ""
- }, {
- content: withCtx(() => [
- withDirectives((openBlock(), createElementBlock("div", null, [
- createElementVNode("div", {
- class: normalizeClass(unref(ns).be("dropdown", "main-wrapper"))
- }, [
- createVNode(HueSlider, {
- ref_key: "hue",
- ref: hue,
- class: "hue-slider",
- color: unref(color2),
- vertical: ""
- }, null, 8, ["color"]),
- createVNode(SvPanel, {
- ref: "svPanel",
- color: unref(color2)
- }, null, 8, ["color"])
- ], 2),
- _ctx.showAlpha ? (openBlock(), createBlock(AlphaSlider, {
- key: 0,
- ref_key: "alpha",
- ref: alpha,
- color: unref(color2)
- }, null, 8, ["color"])) : createCommentVNode("v-if", true),
- _ctx.predefine ? (openBlock(), createBlock(Predefine, {
- key: 1,
- ref: "predefine",
- color: unref(color2),
- colors: _ctx.predefine
- }, null, 8, ["color", "colors"])) : createCommentVNode("v-if", true),
- createElementVNode("div", {
- class: normalizeClass(unref(ns).be("dropdown", "btns"))
- }, [
- createElementVNode("span", {
- class: normalizeClass(unref(ns).be("dropdown", "value"))
- }, [
- createVNode(unref(ElInput), {
- modelValue: customInput.value,
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => customInput.value = $event),
- "validate-event": false,
- size: "small",
- onKeyup: withKeys(handleConfirm, ["enter"]),
- onBlur: handleConfirm
- }, null, 8, ["modelValue", "onKeyup"])
- ], 2),
- createVNode(unref(ElButton), {
- class: normalizeClass(unref(ns).be("dropdown", "link-btn")),
- text: "",
- size: "small",
- onClick: clear
- }, {
- default: withCtx(() => [
- createTextVNode(toDisplayString(unref(t2)("el.colorpicker.clear")), 1)
- ]),
- _: 1
- }, 8, ["class"]),
- createVNode(unref(ElButton), {
- plain: "",
- size: "small",
- class: normalizeClass(unref(ns).be("dropdown", "btn")),
- onClick: confirmValue
- }, {
- default: withCtx(() => [
- createTextVNode(toDisplayString(unref(t2)("el.colorpicker.confirm")), 1)
- ]),
- _: 1
- }, 8, ["class"])
- ], 2)
- ])), [
- [unref(ClickOutside), hide]
- ])
- ]),
- default: withCtx(() => [
- createElementVNode("div", {
- id: unref(buttonId),
- class: normalizeClass(unref(btnKls)),
- role: "button",
- "aria-label": unref(buttonAriaLabel),
- "aria-labelledby": unref(buttonAriaLabelledby),
- "aria-description": unref(t2)("el.colorpicker.description", { color: _ctx.modelValue || "" }),
- tabindex: _ctx.tabindex,
- onKeydown: withKeys(handleTrigger, ["enter"])
- }, [
- unref(colorDisabled) ? (openBlock(), createElementBlock("div", {
- key: 0,
- class: normalizeClass(unref(ns).be("picker", "mask"))
- }, null, 2)) : createCommentVNode("v-if", true),
- createElementVNode("div", {
- class: normalizeClass(unref(ns).be("picker", "trigger")),
- onClick: handleTrigger
- }, [
- createElementVNode("span", {
- class: normalizeClass([unref(ns).be("picker", "color"), unref(ns).is("alpha", _ctx.showAlpha)])
- }, [
- createElementVNode("span", {
- class: normalizeClass(unref(ns).be("picker", "color-inner")),
- style: normalizeStyle({
- backgroundColor: unref(displayedColor)
- })
- }, [
- withDirectives(createVNode(unref(ElIcon), {
- class: normalizeClass([unref(ns).be("picker", "icon"), unref(ns).is("icon-arrow-down")])
- }, {
- default: withCtx(() => [
- createVNode(unref(arrow_down_default))
- ]),
- _: 1
- }, 8, ["class"]), [
- [vShow, _ctx.modelValue || showPanelColor.value]
- ]),
- !_ctx.modelValue && !showPanelColor.value ? (openBlock(), createBlock(unref(ElIcon), {
- key: 0,
- class: normalizeClass([unref(ns).be("picker", "empty"), unref(ns).is("icon-close")])
- }, {
- default: withCtx(() => [
- createVNode(unref(close_default))
- ]),
- _: 1
- }, 8, ["class"])) : createCommentVNode("v-if", true)
- ], 6)
- ], 2)
- ], 2)
- ], 42, _hoisted_1$8)
- ]),
- _: 1
- }, 8, ["visible", "popper-class", "transition"]);
- };
- }
- });
- var ColorPicker = /* @__PURE__ */ _export_sfc$1(_sfc_main$b, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/color-picker/src/color-picker.vue"]]);
- const ElColorPicker = withInstall(ColorPicker);
- const overlayProps = buildProps({
- mask: {
- type: Boolean,
- default: true
- },
- customMaskEvent: {
- type: Boolean,
- default: false
- },
- overlayClass: {
- type: definePropType([
- String,
- Array,
- Object
- ])
- },
- zIndex: {
- type: definePropType([String, Number])
- }
- });
- const overlayEmits = {
- click: (evt) => evt instanceof MouseEvent
- };
- const BLOCK = "overlay";
- var Overlay = defineComponent({
- name: "ElOverlay",
- props: overlayProps,
- emits: overlayEmits,
- setup(props, { slots, emit }) {
- const ns = useNamespace(BLOCK);
- const onMaskClick = (e) => {
- emit("click", e);
- };
- const { onClick, onMousedown, onMouseup } = useSameTarget(props.customMaskEvent ? void 0 : onMaskClick);
- return () => {
- return props.mask ? createVNode("div", {
- class: [ns.b(), props.overlayClass],
- style: {
- zIndex: props.zIndex
- },
- onClick,
- onMousedown,
- onMouseup
- }, [renderSlot(slots, "default")], PatchFlags.STYLE | PatchFlags.CLASS | PatchFlags.PROPS, ["onClick", "onMouseup", "onMousedown"]) : h("div", {
- class: props.overlayClass,
- style: {
- zIndex: props.zIndex,
- position: "fixed",
- top: "0px",
- right: "0px",
- bottom: "0px",
- left: "0px"
- }
- }, [renderSlot(slots, "default")]);
- };
- }
- });
- const ElOverlay = Overlay;
- const dialogInjectionKey = Symbol("dialogInjectionKey");
- const dialogContentProps = buildProps({
- center: {
- type: Boolean,
- default: false
- },
- alignCenter: {
- type: Boolean,
- default: false
- },
- closeIcon: {
- type: iconPropType
- },
- customClass: {
- type: String,
- default: ""
- },
- draggable: {
- type: Boolean,
- default: false
- },
- fullscreen: {
- type: Boolean,
- default: false
- },
- showClose: {
- type: Boolean,
- default: true
- },
- title: {
- type: String,
- default: ""
- }
- });
- const dialogContentEmits = {
- close: () => true
- };
- const _hoisted_1$7 = ["aria-label"];
- const _hoisted_2$6 = ["id"];
- const __default__$3 = defineComponent({ name: "ElDialogContent" });
- const _sfc_main$a = /* @__PURE__ */ defineComponent({
- ...__default__$3,
- props: dialogContentProps,
- emits: dialogContentEmits,
- setup(__props) {
- const props = __props;
- const { t: t2 } = useLocale();
- const { Close } = CloseComponents;
- const { dialogRef, headerRef, bodyId, ns, style } = inject(dialogInjectionKey);
- const { focusTrapRef } = inject(FOCUS_TRAP_INJECTION_KEY);
- const composedDialogRef = composeRefs(focusTrapRef, dialogRef);
- const draggable2 = computed$1(() => props.draggable);
- useDraggable(dialogRef, headerRef, draggable2);
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", {
- ref: unref(composedDialogRef),
- class: normalizeClass([
- unref(ns).b(),
- unref(ns).is("fullscreen", _ctx.fullscreen),
- unref(ns).is("draggable", unref(draggable2)),
- unref(ns).is("align-center", _ctx.alignCenter),
- { [unref(ns).m("center")]: _ctx.center },
- _ctx.customClass
- ]),
- style: normalizeStyle(unref(style)),
- tabindex: "-1"
- }, [
- createElementVNode("header", {
- ref_key: "headerRef",
- ref: headerRef,
- class: normalizeClass(unref(ns).e("header"))
- }, [
- renderSlot(_ctx.$slots, "header", {}, () => [
- createElementVNode("span", {
- role: "heading",
- class: normalizeClass(unref(ns).e("title"))
- }, toDisplayString(_ctx.title), 3)
- ]),
- _ctx.showClose ? (openBlock(), createElementBlock("button", {
- key: 0,
- "aria-label": unref(t2)("el.dialog.close"),
- class: normalizeClass(unref(ns).e("headerbtn")),
- type: "button",
- onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$emit("close"))
- }, [
- createVNode(unref(ElIcon), {
- class: normalizeClass(unref(ns).e("close"))
- }, {
- default: withCtx(() => [
- (openBlock(), createBlock(resolveDynamicComponent(_ctx.closeIcon || unref(Close))))
- ]),
- _: 1
- }, 8, ["class"])
- ], 10, _hoisted_1$7)) : createCommentVNode("v-if", true)
- ], 2),
- createElementVNode("div", {
- id: unref(bodyId),
- class: normalizeClass(unref(ns).e("body"))
- }, [
- renderSlot(_ctx.$slots, "default")
- ], 10, _hoisted_2$6),
- _ctx.$slots.footer ? (openBlock(), createElementBlock("footer", {
- key: 0,
- class: normalizeClass(unref(ns).e("footer"))
- }, [
- renderSlot(_ctx.$slots, "footer")
- ], 2)) : createCommentVNode("v-if", true)
- ], 6);
- };
- }
- });
- var ElDialogContent = /* @__PURE__ */ _export_sfc$1(_sfc_main$a, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/dialog/src/dialog-content.vue"]]);
- const dialogProps = buildProps({
- ...dialogContentProps,
- appendToBody: {
- type: Boolean,
- default: false
- },
- beforeClose: {
- type: definePropType(Function)
- },
- destroyOnClose: {
- type: Boolean,
- default: false
- },
- closeOnClickModal: {
- type: Boolean,
- default: true
- },
- closeOnPressEscape: {
- type: Boolean,
- default: true
- },
- lockScroll: {
- type: Boolean,
- default: true
- },
- modal: {
- type: Boolean,
- default: true
- },
- openDelay: {
- type: Number,
- default: 0
- },
- closeDelay: {
- type: Number,
- default: 0
- },
- top: {
- type: String
- },
- modelValue: {
- type: Boolean,
- default: false
- },
- modalClass: String,
- width: {
- type: [String, Number]
- },
- zIndex: {
- type: Number
- },
- trapFocus: {
- type: Boolean,
- default: false
- }
- });
- const dialogEmits = {
- open: () => true,
- opened: () => true,
- close: () => true,
- closed: () => true,
- [UPDATE_MODEL_EVENT]: (value) => isBoolean(value),
- openAutoFocus: () => true,
- closeAutoFocus: () => true
- };
- const useDialog = (props, targetRef) => {
- const instance = getCurrentInstance();
- const emit = instance.emit;
- const { nextZIndex } = useZIndex();
- let lastPosition = "";
- const titleId = useId();
- const bodyId = useId();
- const visible = ref(false);
- const closed = ref(false);
- const rendered = ref(false);
- const zIndex2 = ref(props.zIndex || nextZIndex());
- let openTimer = void 0;
- let closeTimer = void 0;
- const namespace = useGlobalConfig("namespace", defaultNamespace);
- const style = computed$1(() => {
- const style2 = {};
- const varPrefix = `--${namespace.value}-dialog`;
- if (!props.fullscreen) {
- if (props.top) {
- style2[`${varPrefix}-margin-top`] = props.top;
- }
- if (props.width) {
- style2[`${varPrefix}-width`] = addUnit(props.width);
- }
- }
- return style2;
- });
- const overlayDialogStyle = computed$1(() => {
- if (props.alignCenter) {
- return { display: "flex" };
- }
- return {};
- });
- function afterEnter() {
- emit("opened");
- }
- function afterLeave() {
- emit("closed");
- emit(UPDATE_MODEL_EVENT, false);
- if (props.destroyOnClose) {
- rendered.value = false;
- }
- }
- function beforeLeave() {
- emit("close");
- }
- function open() {
- closeTimer == null ? void 0 : closeTimer();
- openTimer == null ? void 0 : openTimer();
- if (props.openDelay && props.openDelay > 0) {
- ({ stop: openTimer } = useTimeoutFn(() => doOpen(), props.openDelay));
- } else {
- doOpen();
- }
- }
- function close() {
- openTimer == null ? void 0 : openTimer();
- closeTimer == null ? void 0 : closeTimer();
- if (props.closeDelay && props.closeDelay > 0) {
- ({ stop: closeTimer } = useTimeoutFn(() => doClose(), props.closeDelay));
- } else {
- doClose();
- }
- }
- function handleClose() {
- function hide(shouldCancel) {
- if (shouldCancel)
- return;
- closed.value = true;
- visible.value = false;
- }
- if (props.beforeClose) {
- props.beforeClose(hide);
- } else {
- close();
- }
- }
- function onModalClick() {
- if (props.closeOnClickModal) {
- handleClose();
- }
- }
- function doOpen() {
- if (!isClient)
- return;
- visible.value = true;
- }
- function doClose() {
- visible.value = false;
- }
- function onOpenAutoFocus() {
- emit("openAutoFocus");
- }
- function onCloseAutoFocus() {
- emit("closeAutoFocus");
- }
- function onFocusoutPrevented(event2) {
- var _a2;
- if (((_a2 = event2.detail) == null ? void 0 : _a2.focusReason) === "pointer") {
- event2.preventDefault();
- }
- }
- if (props.lockScroll) {
- useLockscreen(visible);
- }
- function onCloseRequested() {
- if (props.closeOnPressEscape) {
- handleClose();
- }
- }
- watch(() => props.modelValue, (val) => {
- if (val) {
- closed.value = false;
- open();
- rendered.value = true;
- zIndex2.value = props.zIndex ? zIndex2.value++ : nextZIndex();
- nextTick(() => {
- emit("open");
- if (targetRef.value) {
- targetRef.value.scrollTop = 0;
- }
- });
- } else {
- if (visible.value) {
- close();
- }
- }
- });
- watch(() => props.fullscreen, (val) => {
- if (!targetRef.value)
- return;
- if (val) {
- lastPosition = targetRef.value.style.transform;
- targetRef.value.style.transform = "";
- } else {
- targetRef.value.style.transform = lastPosition;
- }
- });
- onMounted(() => {
- if (props.modelValue) {
- visible.value = true;
- rendered.value = true;
- open();
- }
- });
- return {
- afterEnter,
- afterLeave,
- beforeLeave,
- handleClose,
- onModalClick,
- close,
- doClose,
- onOpenAutoFocus,
- onCloseAutoFocus,
- onCloseRequested,
- onFocusoutPrevented,
- titleId,
- bodyId,
- closed,
- style,
- overlayDialogStyle,
- rendered,
- visible,
- zIndex: zIndex2
- };
- };
- const _hoisted_1$6 = ["aria-label", "aria-labelledby", "aria-describedby"];
- const __default__$2 = defineComponent({
- name: "ElDialog",
- inheritAttrs: false
- });
- const _sfc_main$9 = /* @__PURE__ */ defineComponent({
- ...__default__$2,
- props: dialogProps,
- emits: dialogEmits,
- setup(__props, { expose }) {
- const props = __props;
- const slots = useSlots();
- useDeprecated({
- scope: "el-dialog",
- from: "the title slot",
- replacement: "the header slot",
- version: "3.0.0",
- ref: "https://element-plus.org/en-US/component/dialog.html#slots"
- }, computed$1(() => !!slots.title));
- useDeprecated({
- scope: "el-dialog",
- from: "custom-class",
- replacement: "class",
- version: "2.3.0",
- ref: "https://element-plus.org/en-US/component/dialog.html#attributes",
- type: "Attribute"
- }, computed$1(() => !!props.customClass));
- const ns = useNamespace("dialog");
- const dialogRef = ref();
- const headerRef = ref();
- const dialogContentRef = ref();
- const {
- visible,
- titleId,
- bodyId,
- style,
- overlayDialogStyle,
- rendered,
- zIndex: zIndex2,
- afterEnter,
- afterLeave,
- beforeLeave,
- handleClose,
- onModalClick,
- onOpenAutoFocus,
- onCloseAutoFocus,
- onCloseRequested,
- onFocusoutPrevented
- } = useDialog(props, dialogRef);
- provide(dialogInjectionKey, {
- dialogRef,
- headerRef,
- bodyId,
- ns,
- rendered,
- style
- });
- const overlayEvent = useSameTarget(onModalClick);
- const draggable2 = computed$1(() => props.draggable && !props.fullscreen);
- expose({
- visible,
- dialogContentRef
- });
- return (_ctx, _cache) => {
- return openBlock(), createBlock(Teleport, {
- to: "body",
- disabled: !_ctx.appendToBody
- }, [
- createVNode(Transition, {
- name: "dialog-fade",
- onAfterEnter: unref(afterEnter),
- onAfterLeave: unref(afterLeave),
- onBeforeLeave: unref(beforeLeave),
- persisted: ""
- }, {
- default: withCtx(() => [
- withDirectives(createVNode(unref(ElOverlay), {
- "custom-mask-event": "",
- mask: _ctx.modal,
- "overlay-class": _ctx.modalClass,
- "z-index": unref(zIndex2)
- }, {
- default: withCtx(() => [
- createElementVNode("div", {
- role: "dialog",
- "aria-modal": "true",
- "aria-label": _ctx.title || void 0,
- "aria-labelledby": !_ctx.title ? unref(titleId) : void 0,
- "aria-describedby": unref(bodyId),
- class: normalizeClass(`${unref(ns).namespace.value}-overlay-dialog`),
- style: normalizeStyle(unref(overlayDialogStyle)),
- onClick: _cache[0] || (_cache[0] = (...args) => unref(overlayEvent).onClick && unref(overlayEvent).onClick(...args)),
- onMousedown: _cache[1] || (_cache[1] = (...args) => unref(overlayEvent).onMousedown && unref(overlayEvent).onMousedown(...args)),
- onMouseup: _cache[2] || (_cache[2] = (...args) => unref(overlayEvent).onMouseup && unref(overlayEvent).onMouseup(...args))
- }, [
- createVNode(unref(ElFocusTrap), {
- loop: "",
- trapped: unref(visible),
- "focus-start-el": "container",
- onFocusAfterTrapped: unref(onOpenAutoFocus),
- onFocusAfterReleased: unref(onCloseAutoFocus),
- onFocusoutPrevented: unref(onFocusoutPrevented),
- onReleaseRequested: unref(onCloseRequested)
- }, {
- default: withCtx(() => [
- unref(rendered) ? (openBlock(), createBlock(ElDialogContent, mergeProps({
- key: 0,
- ref_key: "dialogContentRef",
- ref: dialogContentRef
- }, _ctx.$attrs, {
- "custom-class": _ctx.customClass,
- center: _ctx.center,
- "align-center": _ctx.alignCenter,
- "close-icon": _ctx.closeIcon,
- draggable: unref(draggable2),
- fullscreen: _ctx.fullscreen,
- "show-close": _ctx.showClose,
- title: _ctx.title,
- onClose: unref(handleClose)
- }), createSlots({
- header: withCtx(() => [
- !_ctx.$slots.title ? renderSlot(_ctx.$slots, "header", {
- key: 0,
- close: unref(handleClose),
- titleId: unref(titleId),
- titleClass: unref(ns).e("title")
- }) : renderSlot(_ctx.$slots, "title", { key: 1 })
- ]),
- default: withCtx(() => [
- renderSlot(_ctx.$slots, "default")
- ]),
- _: 2
- }, [
- _ctx.$slots.footer ? {
- name: "footer",
- fn: withCtx(() => [
- renderSlot(_ctx.$slots, "footer")
- ])
- } : void 0
- ]), 1040, ["custom-class", "center", "align-center", "close-icon", "draggable", "fullscreen", "show-close", "title", "onClose"])) : createCommentVNode("v-if", true)
- ]),
- _: 3
- }, 8, ["trapped", "onFocusAfterTrapped", "onFocusAfterReleased", "onFocusoutPrevented", "onReleaseRequested"])
- ], 46, _hoisted_1$6)
- ]),
- _: 3
- }, 8, ["mask", "overlay-class", "z-index"]), [
- [vShow, unref(visible)]
- ])
- ]),
- _: 3
- }, 8, ["onAfterEnter", "onAfterLeave", "onBeforeLeave"])
- ], 8, ["disabled"]);
- };
- }
- });
- var Dialog = /* @__PURE__ */ _export_sfc$1(_sfc_main$9, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/dialog/src/dialog.vue"]]);
- const ElDialog = withInstall(Dialog);
- const inputNumberProps = buildProps({
- id: {
- type: String,
- default: void 0
- },
- step: {
- type: Number,
- default: 1
- },
- stepStrictly: Boolean,
- max: {
- type: Number,
- default: Number.POSITIVE_INFINITY
- },
- min: {
- type: Number,
- default: Number.NEGATIVE_INFINITY
- },
- modelValue: Number,
- readonly: Boolean,
- disabled: Boolean,
- size: useSizeProp,
- controls: {
- type: Boolean,
- default: true
- },
- controlsPosition: {
- type: String,
- default: "",
- values: ["", "right"]
- },
- valueOnClear: {
- type: [String, Number, null],
- validator: (val) => val === null || isNumber(val) || ["min", "max"].includes(val),
- default: null
- },
- name: String,
- label: String,
- placeholder: String,
- precision: {
- type: Number,
- validator: (val) => val >= 0 && val === Number.parseInt(`${val}`, 10)
- },
- validateEvent: {
- type: Boolean,
- default: true
- }
- });
- const inputNumberEmits = {
- [CHANGE_EVENT]: (cur, prev) => prev !== cur,
- blur: (e) => e instanceof FocusEvent,
- focus: (e) => e instanceof FocusEvent,
- [INPUT_EVENT]: (val) => isNumber(val) || isNil(val),
- [UPDATE_MODEL_EVENT]: (val) => isNumber(val) || isNil(val)
- };
- const _hoisted_1$5 = ["aria-label", "onKeydown"];
- const _hoisted_2$5 = ["aria-label", "onKeydown"];
- const __default__$1 = defineComponent({
- name: "ElInputNumber"
- });
- const _sfc_main$8 = /* @__PURE__ */ defineComponent({
- ...__default__$1,
- props: inputNumberProps,
- emits: inputNumberEmits,
- setup(__props, { expose, emit }) {
- const props = __props;
- const { t: t2 } = useLocale();
- const ns = useNamespace("input-number");
- const input = ref();
- const data = reactive({
- currentValue: props.modelValue,
- userInput: null
- });
- const { formItem } = useFormItem();
- const minDisabled = computed$1(() => isNumber(props.modelValue) && props.modelValue <= props.min);
- const maxDisabled = computed$1(() => isNumber(props.modelValue) && props.modelValue >= props.max);
- const numPrecision = computed$1(() => {
- const stepPrecision = getPrecision(props.step);
- if (!isUndefined(props.precision)) {
- if (stepPrecision > props.precision)
- ;
- return props.precision;
- } else {
- return Math.max(getPrecision(props.modelValue), stepPrecision);
- }
- });
- const controlsAtRight = computed$1(() => {
- return props.controls && props.controlsPosition === "right";
- });
- const inputNumberSize = useFormSize();
- const inputNumberDisabled = useFormDisabled();
- const displayValue = computed$1(() => {
- if (data.userInput !== null) {
- return data.userInput;
- }
- let currentValue = data.currentValue;
- if (isNil(currentValue))
- return "";
- if (isNumber(currentValue)) {
- if (Number.isNaN(currentValue))
- return "";
- if (!isUndefined(props.precision)) {
- currentValue = currentValue.toFixed(props.precision);
- }
- }
- return currentValue;
- });
- const toPrecision = (num, pre) => {
- if (isUndefined(pre))
- pre = numPrecision.value;
- if (pre === 0)
- return Math.round(num);
- let snum = String(num);
- const pointPos = snum.indexOf(".");
- if (pointPos === -1)
- return num;
- const nums = snum.replace(".", "").split("");
- const datum = nums[pointPos + pre];
- if (!datum)
- return num;
- const length = snum.length;
- if (snum.charAt(length - 1) === "5") {
- snum = `${snum.slice(0, Math.max(0, length - 1))}6`;
- }
- return Number.parseFloat(Number(snum).toFixed(pre));
- };
- const getPrecision = (value) => {
- if (isNil(value))
- return 0;
- const valueString = value.toString();
- const dotPosition = valueString.indexOf(".");
- let precision = 0;
- if (dotPosition !== -1) {
- precision = valueString.length - dotPosition - 1;
- }
- return precision;
- };
- const ensurePrecision = (val, coefficient = 1) => {
- if (!isNumber(val))
- return data.currentValue;
- return toPrecision(val + props.step * coefficient);
- };
- const increase = () => {
- if (props.readonly || inputNumberDisabled.value || maxDisabled.value)
- return;
- const value = Number(displayValue.value) || 0;
- const newVal = ensurePrecision(value);
- setCurrentValue(newVal);
- emit(INPUT_EVENT, data.currentValue);
- };
- const decrease = () => {
- if (props.readonly || inputNumberDisabled.value || minDisabled.value)
- return;
- const value = Number(displayValue.value) || 0;
- const newVal = ensurePrecision(value, -1);
- setCurrentValue(newVal);
- emit(INPUT_EVENT, data.currentValue);
- };
- const verifyValue = (value, update) => {
- const { max: max2, min: min2, step, precision, stepStrictly, valueOnClear } = props;
- let newVal = Number(value);
- if (isNil(value) || Number.isNaN(newVal)) {
- return null;
- }
- if (value === "") {
- if (valueOnClear === null) {
- return null;
- }
- newVal = isString(valueOnClear) ? { min: min2, max: max2 }[valueOnClear] : valueOnClear;
- }
- if (stepStrictly) {
- newVal = toPrecision(Math.round(newVal / step) * step, precision);
- }
- if (!isUndefined(precision)) {
- newVal = toPrecision(newVal, precision);
- }
- if (newVal > max2 || newVal < min2) {
- newVal = newVal > max2 ? max2 : min2;
- update && emit(UPDATE_MODEL_EVENT, newVal);
- }
- return newVal;
- };
- const setCurrentValue = (value, emitChange = true) => {
- var _a2;
- const oldVal = data.currentValue;
- const newVal = verifyValue(value);
- if (!emitChange) {
- emit(UPDATE_MODEL_EVENT, newVal);
- return;
- }
- if (oldVal === newVal)
- return;
- data.userInput = null;
- emit(UPDATE_MODEL_EVENT, newVal);
- emit(CHANGE_EVENT, newVal, oldVal);
- if (props.validateEvent) {
- (_a2 = formItem == null ? void 0 : formItem.validate) == null ? void 0 : _a2.call(formItem, "change").catch((err) => debugWarn());
- }
- data.currentValue = newVal;
- };
- const handleInput = (value) => {
- data.userInput = value;
- const newVal = value === "" ? null : Number(value);
- emit(INPUT_EVENT, newVal);
- setCurrentValue(newVal, false);
- };
- const handleInputChange = (value) => {
- const newVal = value !== "" ? Number(value) : "";
- if (isNumber(newVal) && !Number.isNaN(newVal) || value === "") {
- setCurrentValue(newVal);
- }
- data.userInput = null;
- };
- const focus = () => {
- var _a2, _b;
- (_b = (_a2 = input.value) == null ? void 0 : _a2.focus) == null ? void 0 : _b.call(_a2);
- };
- const blur = () => {
- var _a2, _b;
- (_b = (_a2 = input.value) == null ? void 0 : _a2.blur) == null ? void 0 : _b.call(_a2);
- };
- const handleFocus = (event2) => {
- emit("focus", event2);
- };
- const handleBlur = (event2) => {
- var _a2;
- emit("blur", event2);
- if (props.validateEvent) {
- (_a2 = formItem == null ? void 0 : formItem.validate) == null ? void 0 : _a2.call(formItem, "blur").catch((err) => debugWarn());
- }
- };
- watch(() => props.modelValue, (value) => {
- const userInput = verifyValue(data.userInput);
- const newValue = verifyValue(value, true);
- if (!isNumber(userInput) && (!userInput || userInput !== newValue)) {
- data.currentValue = newValue;
- data.userInput = null;
- }
- }, { immediate: true });
- onMounted(() => {
- var _a2;
- const { min: min2, max: max2, modelValue } = props;
- const innerInput = (_a2 = input.value) == null ? void 0 : _a2.input;
- innerInput.setAttribute("role", "spinbutton");
- if (Number.isFinite(max2)) {
- innerInput.setAttribute("aria-valuemax", String(max2));
- } else {
- innerInput.removeAttribute("aria-valuemax");
- }
- if (Number.isFinite(min2)) {
- innerInput.setAttribute("aria-valuemin", String(min2));
- } else {
- innerInput.removeAttribute("aria-valuemin");
- }
- innerInput.setAttribute("aria-valuenow", String(data.currentValue));
- innerInput.setAttribute("aria-disabled", String(inputNumberDisabled.value));
- if (!isNumber(modelValue) && modelValue != null) {
- let val = Number(modelValue);
- if (Number.isNaN(val)) {
- val = null;
- }
- emit(UPDATE_MODEL_EVENT, val);
- }
- });
- onUpdated(() => {
- var _a2;
- const innerInput = (_a2 = input.value) == null ? void 0 : _a2.input;
- innerInput == null ? void 0 : innerInput.setAttribute("aria-valuenow", `${data.currentValue}`);
- });
- expose({
- focus,
- blur
- });
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", {
- class: normalizeClass([
- unref(ns).b(),
- unref(ns).m(unref(inputNumberSize)),
- unref(ns).is("disabled", unref(inputNumberDisabled)),
- unref(ns).is("without-controls", !_ctx.controls),
- unref(ns).is("controls-right", unref(controlsAtRight))
- ]),
- onDragstart: _cache[1] || (_cache[1] = withModifiers(() => {
- }, ["prevent"]))
- }, [
- _ctx.controls ? withDirectives((openBlock(), createElementBlock("span", {
- key: 0,
- role: "button",
- "aria-label": unref(t2)("el.inputNumber.decrease"),
- class: normalizeClass([unref(ns).e("decrease"), unref(ns).is("disabled", unref(minDisabled))]),
- onKeydown: withKeys(decrease, ["enter"])
- }, [
- createVNode(unref(ElIcon), null, {
- default: withCtx(() => [
- unref(controlsAtRight) ? (openBlock(), createBlock(unref(arrow_down_default), { key: 0 })) : (openBlock(), createBlock(unref(minus_default), { key: 1 }))
- ]),
- _: 1
- })
- ], 42, _hoisted_1$5)), [
- [unref(vRepeatClick), decrease]
- ]) : createCommentVNode("v-if", true),
- _ctx.controls ? withDirectives((openBlock(), createElementBlock("span", {
- key: 1,
- role: "button",
- "aria-label": unref(t2)("el.inputNumber.increase"),
- class: normalizeClass([unref(ns).e("increase"), unref(ns).is("disabled", unref(maxDisabled))]),
- onKeydown: withKeys(increase, ["enter"])
- }, [
- createVNode(unref(ElIcon), null, {
- default: withCtx(() => [
- unref(controlsAtRight) ? (openBlock(), createBlock(unref(arrow_up_default), { key: 0 })) : (openBlock(), createBlock(unref(plus_default), { key: 1 }))
- ]),
- _: 1
- })
- ], 42, _hoisted_2$5)), [
- [unref(vRepeatClick), increase]
- ]) : createCommentVNode("v-if", true),
- createVNode(unref(ElInput), {
- id: _ctx.id,
- ref_key: "input",
- ref: input,
- type: "number",
- step: _ctx.step,
- "model-value": unref(displayValue),
- placeholder: _ctx.placeholder,
- readonly: _ctx.readonly,
- disabled: unref(inputNumberDisabled),
- size: unref(inputNumberSize),
- max: _ctx.max,
- min: _ctx.min,
- name: _ctx.name,
- label: _ctx.label,
- "validate-event": false,
- onWheel: _cache[0] || (_cache[0] = withModifiers(() => {
- }, ["prevent"])),
- onKeydown: [
- withKeys(withModifiers(increase, ["prevent"]), ["up"]),
- withKeys(withModifiers(decrease, ["prevent"]), ["down"])
- ],
- onBlur: handleBlur,
- onFocus: handleFocus,
- onInput: handleInput,
- onChange: handleInputChange
- }, null, 8, ["id", "step", "model-value", "placeholder", "readonly", "disabled", "size", "max", "min", "name", "label", "onKeydown"])
- ], 34);
- };
- }
- });
- var InputNumber = /* @__PURE__ */ _export_sfc$1(_sfc_main$8, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/input-number/src/input-number.vue"]]);
- const ElInputNumber = withInstall(InputNumber);
- const selectGroupKey = Symbol("ElSelectGroup");
- const selectKey = Symbol("ElSelect");
- function useOption(props, states) {
- const select = inject(selectKey);
- const selectGroup = inject(selectGroupKey, { disabled: false });
- const isObject3 = computed$1(() => {
- return Object.prototype.toString.call(props.value).toLowerCase() === "[object object]";
- });
- const itemSelected = computed$1(() => {
- if (!select.props.multiple) {
- return isEqual2(props.value, select.props.modelValue);
- } else {
- return contains(select.props.modelValue, props.value);
- }
- });
- const limitReached = computed$1(() => {
- if (select.props.multiple) {
- const modelValue = select.props.modelValue || [];
- return !itemSelected.value && modelValue.length >= select.props.multipleLimit && select.props.multipleLimit > 0;
- } else {
- return false;
- }
- });
- const currentLabel = computed$1(() => {
- return props.label || (isObject3.value ? "" : props.value);
- });
- const currentValue = computed$1(() => {
- return props.value || props.label || "";
- });
- const isDisabled3 = computed$1(() => {
- return props.disabled || states.groupDisabled || limitReached.value;
- });
- const instance = getCurrentInstance();
- const contains = (arr = [], target) => {
- if (!isObject3.value) {
- return arr && arr.includes(target);
- } else {
- const valueKey = select.props.valueKey;
- return arr && arr.some((item) => {
- return toRaw$1(get$2(item, valueKey)) === get$2(target, valueKey);
- });
- }
- };
- const isEqual2 = (a, b) => {
- if (!isObject3.value) {
- return a === b;
- } else {
- const { valueKey } = select.props;
- return get$2(a, valueKey) === get$2(b, valueKey);
- }
- };
- const hoverItem = () => {
- if (!props.disabled && !selectGroup.disabled) {
- select.hoverIndex = select.optionsArray.indexOf(instance.proxy);
- }
- };
- watch(() => currentLabel.value, () => {
- if (!props.created && !select.props.remote)
- select.setSelected();
- });
- watch(() => props.value, (val, oldVal) => {
- const { remote, valueKey } = select.props;
- if (!Object.is(val, oldVal)) {
- select.onOptionDestroy(oldVal, instance.proxy);
- select.onOptionCreate(instance.proxy);
- }
- if (!props.created && !remote) {
- if (valueKey && typeof val === "object" && typeof oldVal === "object" && val[valueKey] === oldVal[valueKey]) {
- return;
- }
- select.setSelected();
- }
- });
- watch(() => selectGroup.disabled, () => {
- states.groupDisabled = selectGroup.disabled;
- }, { immediate: true });
- const { queryChange } = toRaw$1(select);
- watch(queryChange, (changes) => {
- const { query } = unref(changes);
- const regexp = new RegExp(escapeStringRegexp(query), "i");
- states.visible = regexp.test(currentLabel.value) || props.created;
- if (!states.visible) {
- select.filteredOptionsCount--;
- }
- }, { immediate: true });
- return {
- select,
- currentLabel,
- currentValue,
- itemSelected,
- isDisabled: isDisabled3,
- hoverItem
- };
- }
- const _sfc_main$7 = defineComponent({
- name: "ElOption",
- componentName: "ElOption",
- props: {
- value: {
- required: true,
- type: [String, Number, Boolean, Object]
- },
- label: [String, Number],
- created: Boolean,
- disabled: {
- type: Boolean,
- default: false
- }
- },
- setup(props) {
- const ns = useNamespace("select");
- const states = reactive({
- index: -1,
- groupDisabled: false,
- visible: true,
- hitState: false,
- hover: false
- });
- const { currentLabel, itemSelected, isDisabled: isDisabled3, select, hoverItem } = useOption(props, states);
- const { visible, hover } = toRefs(states);
- const vm = getCurrentInstance().proxy;
- select.onOptionCreate(vm);
- onBeforeUnmount(() => {
- const key = vm.value;
- const { selected } = select;
- const selectedOptions = select.props.multiple ? selected : [selected];
- const doesSelected = selectedOptions.some((item) => {
- return item.value === vm.value;
- });
- nextTick(() => {
- if (select.cachedOptions.get(key) === vm && !doesSelected) {
- select.cachedOptions.delete(key);
- }
- });
- select.onOptionDestroy(key, vm);
- });
- function selectOptionClick() {
- if (props.disabled !== true && states.groupDisabled !== true) {
- select.handleOptionSelect(vm, true);
- }
- }
- return {
- ns,
- currentLabel,
- itemSelected,
- isDisabled: isDisabled3,
- select,
- hoverItem,
- visible,
- hover,
- selectOptionClick,
- states
- };
- }
- });
- function _sfc_render$3(_ctx, _cache, $props, $setup, $data, $options) {
- return withDirectives((openBlock(), createElementBlock("li", {
- class: normalizeClass([
- _ctx.ns.be("dropdown", "item"),
- _ctx.ns.is("disabled", _ctx.isDisabled),
- {
- selected: _ctx.itemSelected,
- hover: _ctx.hover
- }
- ]),
- onMouseenter: _cache[0] || (_cache[0] = (...args) => _ctx.hoverItem && _ctx.hoverItem(...args)),
- onClick: _cache[1] || (_cache[1] = withModifiers((...args) => _ctx.selectOptionClick && _ctx.selectOptionClick(...args), ["stop"]))
- }, [
- renderSlot(_ctx.$slots, "default", {}, () => [
- createElementVNode("span", null, toDisplayString(_ctx.currentLabel), 1)
- ])
- ], 34)), [
- [vShow, _ctx.visible]
- ]);
- }
- var Option = /* @__PURE__ */ _export_sfc$1(_sfc_main$7, [["render", _sfc_render$3], ["__file", "/home/runner/work/element-plus/element-plus/packages/components/select/src/option.vue"]]);
- const _sfc_main$6 = defineComponent({
- name: "ElSelectDropdown",
- componentName: "ElSelectDropdown",
- setup() {
- const select = inject(selectKey);
- const ns = useNamespace("select");
- const popperClass = computed$1(() => select.props.popperClass);
- const isMultiple = computed$1(() => select.props.multiple);
- const isFitInputWidth = computed$1(() => select.props.fitInputWidth);
- const minWidth = ref("");
- function updateMinWidth() {
- var _a2;
- minWidth.value = `${(_a2 = select.selectWrapper) == null ? void 0 : _a2.offsetWidth}px`;
- }
- onMounted(() => {
- updateMinWidth();
- useResizeObserver(select.selectWrapper, updateMinWidth);
- });
- return {
- ns,
- minWidth,
- popperClass,
- isMultiple,
- isFitInputWidth
- };
- }
- });
- function _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("div", {
- class: normalizeClass([_ctx.ns.b("dropdown"), _ctx.ns.is("multiple", _ctx.isMultiple), _ctx.popperClass]),
- style: normalizeStyle({ [_ctx.isFitInputWidth ? "width" : "minWidth"]: _ctx.minWidth })
- }, [
- renderSlot(_ctx.$slots, "default")
- ], 6);
- }
- var ElSelectMenu = /* @__PURE__ */ _export_sfc$1(_sfc_main$6, [["render", _sfc_render$2], ["__file", "/home/runner/work/element-plus/element-plus/packages/components/select/src/select-dropdown.vue"]]);
- function useSelectStates(props) {
- const { t: t2 } = useLocale();
- return reactive({
- options: /* @__PURE__ */ new Map(),
- cachedOptions: /* @__PURE__ */ new Map(),
- createdLabel: null,
- createdSelected: false,
- selected: props.multiple ? [] : {},
- inputLength: 20,
- inputWidth: 0,
- optionsCount: 0,
- filteredOptionsCount: 0,
- visible: false,
- softFocus: false,
- selectedLabel: "",
- hoverIndex: -1,
- query: "",
- previousQuery: null,
- inputHovering: false,
- cachedPlaceHolder: "",
- currentPlaceholder: t2("el.select.placeholder"),
- menuVisibleOnFocus: false,
- isOnComposition: false,
- isSilentBlur: false,
- prefixWidth: 11,
- tagInMultiLine: false,
- mouseEnter: false
- });
- }
- const useSelect = (props, states, ctx) => {
- const { t: t2 } = useLocale();
- const ns = useNamespace("select");
- useDeprecated({
- from: "suffixTransition",
- replacement: "override style scheme",
- version: "2.3.0",
- scope: "props",
- ref: "https://element-plus.org/en-US/component/select.html#select-attributes"
- }, computed$1(() => props.suffixTransition === false));
- const reference = ref(null);
- const input = ref(null);
- const iOSInput = ref(null);
- const tooltipRef = ref(null);
- const tags = ref(null);
- const selectWrapper = ref(null);
- const scrollbar = ref(null);
- const hoverOption = ref(-1);
- const queryChange = shallowRef({ query: "" });
- const groupQueryChange = shallowRef("");
- const optionList = ref([]);
- let originClientHeight = 0;
- const { form, formItem } = useFormItem();
- const readonly2 = computed$1(() => !props.filterable || props.multiple || !states.visible);
- const selectDisabled = computed$1(() => props.disabled || (form == null ? void 0 : form.disabled));
- const showClose = computed$1(() => {
- const hasValue = props.multiple ? Array.isArray(props.modelValue) && props.modelValue.length > 0 : props.modelValue !== void 0 && props.modelValue !== null && props.modelValue !== "";
- const criteria = props.clearable && !selectDisabled.value && states.inputHovering && hasValue;
- return criteria;
- });
- const iconComponent = computed$1(() => props.remote && props.filterable && !props.remoteShowSuffix ? "" : props.suffixIcon);
- const iconReverse = computed$1(() => ns.is("reverse", iconComponent.value && states.visible && props.suffixTransition));
- const debounce$12 = computed$1(() => props.remote ? 300 : 0);
- const emptyText = computed$1(() => {
- if (props.loading) {
- return props.loadingText || t2("el.select.loading");
- } else {
- if (props.remote && states.query === "" && states.options.size === 0)
- return false;
- if (props.filterable && states.query && states.options.size > 0 && states.filteredOptionsCount === 0) {
- return props.noMatchText || t2("el.select.noMatch");
- }
- if (states.options.size === 0) {
- return props.noDataText || t2("el.select.noData");
- }
- }
- return null;
- });
- const optionsArray = computed$1(() => {
- const list = Array.from(states.options.values());
- const newList = [];
- optionList.value.forEach((item) => {
- const index2 = list.findIndex((i2) => i2.currentLabel === item);
- if (index2 > -1) {
- newList.push(list[index2]);
- }
- });
- return newList.length ? newList : list;
- });
- const cachedOptionsArray = computed$1(() => Array.from(states.cachedOptions.values()));
- const showNewOption = computed$1(() => {
- const hasExistingOption = optionsArray.value.filter((option) => {
- return !option.created;
- }).some((option) => {
- return option.currentLabel === states.query;
- });
- return props.filterable && props.allowCreate && states.query !== "" && !hasExistingOption;
- });
- const selectSize = useFormSize();
- const collapseTagSize = computed$1(() => ["small"].includes(selectSize.value) ? "small" : "default");
- const dropMenuVisible = computed$1({
- get() {
- return states.visible && emptyText.value !== false;
- },
- set(val) {
- states.visible = val;
- }
- });
- watch([() => selectDisabled.value, () => selectSize.value, () => form == null ? void 0 : form.size], () => {
- nextTick(() => {
- resetInputHeight();
- });
- });
- watch(() => props.placeholder, (val) => {
- states.cachedPlaceHolder = states.currentPlaceholder = val;
- });
- watch(() => props.modelValue, (val, oldVal) => {
- if (props.multiple) {
- resetInputHeight();
- if (val && val.length > 0 || input.value && states.query !== "") {
- states.currentPlaceholder = "";
- } else {
- states.currentPlaceholder = states.cachedPlaceHolder;
- }
- if (props.filterable && !props.reserveKeyword) {
- states.query = "";
- handleQueryChange(states.query);
- }
- }
- setSelected();
- if (props.filterable && !props.multiple) {
- states.inputLength = 20;
- }
- if (!isEqual(val, oldVal) && props.validateEvent) {
- formItem == null ? void 0 : formItem.validate("change").catch((err) => debugWarn());
- }
- }, {
- flush: "post",
- deep: true
- });
- watch(() => states.visible, (val) => {
- var _a2, _b, _c, _d, _e;
- if (!val) {
- if (props.filterable) {
- if (isFunction$3(props.filterMethod)) {
- props.filterMethod("");
- }
- if (isFunction$3(props.remoteMethod)) {
- props.remoteMethod("");
- }
- }
- input.value && input.value.blur();
- states.query = "";
- states.previousQuery = null;
- states.selectedLabel = "";
- states.inputLength = 20;
- states.menuVisibleOnFocus = false;
- resetHoverIndex();
- nextTick(() => {
- if (input.value && input.value.value === "" && states.selected.length === 0) {
- states.currentPlaceholder = states.cachedPlaceHolder;
- }
- });
- if (!props.multiple) {
- if (states.selected) {
- if (props.filterable && props.allowCreate && states.createdSelected && states.createdLabel) {
- states.selectedLabel = states.createdLabel;
- } else {
- states.selectedLabel = states.selected.currentLabel;
- }
- if (props.filterable)
- states.query = states.selectedLabel;
- }
- if (props.filterable) {
- states.currentPlaceholder = states.cachedPlaceHolder;
- }
- }
- } else {
- (_b = (_a2 = tooltipRef.value) == null ? void 0 : _a2.updatePopper) == null ? void 0 : _b.call(_a2);
- if (props.filterable) {
- states.filteredOptionsCount = states.optionsCount;
- states.query = props.remote ? "" : states.selectedLabel;
- (_d = (_c = iOSInput.value) == null ? void 0 : _c.focus) == null ? void 0 : _d.call(_c);
- if (props.multiple) {
- (_e = input.value) == null ? void 0 : _e.focus();
- } else {
- if (states.selectedLabel) {
- states.currentPlaceholder = `${states.selectedLabel}`;
- states.selectedLabel = "";
- }
- }
- handleQueryChange(states.query);
- if (!props.multiple && !props.remote) {
- queryChange.value.query = "";
- triggerRef(queryChange);
- triggerRef(groupQueryChange);
- }
- }
- }
- ctx.emit("visible-change", val);
- });
- watch(() => states.options.entries(), () => {
- var _a2, _b, _c;
- if (!isClient)
- return;
- (_b = (_a2 = tooltipRef.value) == null ? void 0 : _a2.updatePopper) == null ? void 0 : _b.call(_a2);
- if (props.multiple) {
- resetInputHeight();
- }
- const inputs = ((_c = selectWrapper.value) == null ? void 0 : _c.querySelectorAll("input")) || [];
- if (!Array.from(inputs).includes(document.activeElement)) {
- setSelected();
- }
- if (props.defaultFirstOption && (props.filterable || props.remote) && states.filteredOptionsCount) {
- checkDefaultFirstOption();
- }
- }, {
- flush: "post"
- });
- watch(() => states.hoverIndex, (val) => {
- if (isNumber(val) && val > -1) {
- hoverOption.value = optionsArray.value[val] || {};
- } else {
- hoverOption.value = {};
- }
- optionsArray.value.forEach((option) => {
- option.hover = hoverOption.value === option;
- });
- });
- const resetInputHeight = () => {
- nextTick(() => {
- var _a2, _b;
- if (!reference.value)
- return;
- const input2 = reference.value.$el.querySelector("input");
- originClientHeight = originClientHeight || (input2.clientHeight > 0 ? input2.clientHeight + 2 : 0);
- const _tags = tags.value;
- const gotSize = getComponentSize(selectSize.value || (form == null ? void 0 : form.size));
- const sizeInMap = selectSize.value || gotSize === originClientHeight || originClientHeight <= 0 ? gotSize : originClientHeight;
- const isElHidden = input2.offsetParent === null;
- !isElHidden && (input2.style.height = `${(states.selected.length === 0 ? sizeInMap : Math.max(_tags ? _tags.clientHeight + (_tags.clientHeight > sizeInMap ? 6 : 0) : 0, sizeInMap)) - 2}px`);
- states.tagInMultiLine = Number.parseFloat(input2.style.height) >= sizeInMap;
- if (states.visible && emptyText.value !== false) {
- (_b = (_a2 = tooltipRef.value) == null ? void 0 : _a2.updatePopper) == null ? void 0 : _b.call(_a2);
- }
- });
- };
- const handleQueryChange = async (val) => {
- if (states.previousQuery === val || states.isOnComposition)
- return;
- if (states.previousQuery === null && (isFunction$3(props.filterMethod) || isFunction$3(props.remoteMethod))) {
- states.previousQuery = val;
- return;
- }
- states.previousQuery = val;
- nextTick(() => {
- var _a2, _b;
- if (states.visible)
- (_b = (_a2 = tooltipRef.value) == null ? void 0 : _a2.updatePopper) == null ? void 0 : _b.call(_a2);
- });
- states.hoverIndex = -1;
- if (props.multiple && props.filterable) {
- nextTick(() => {
- const length = input.value.value.length * 15 + 20;
- states.inputLength = props.collapseTags ? Math.min(50, length) : length;
- managePlaceholder();
- resetInputHeight();
- });
- }
- if (props.remote && isFunction$3(props.remoteMethod)) {
- states.hoverIndex = -1;
- props.remoteMethod(val);
- } else if (isFunction$3(props.filterMethod)) {
- props.filterMethod(val);
- triggerRef(groupQueryChange);
- } else {
- states.filteredOptionsCount = states.optionsCount;
- queryChange.value.query = val;
- triggerRef(queryChange);
- triggerRef(groupQueryChange);
- }
- if (props.defaultFirstOption && (props.filterable || props.remote) && states.filteredOptionsCount) {
- await nextTick();
- checkDefaultFirstOption();
- }
- };
- const managePlaceholder = () => {
- if (states.currentPlaceholder !== "") {
- states.currentPlaceholder = input.value.value ? "" : states.cachedPlaceHolder;
- }
- };
- const checkDefaultFirstOption = () => {
- const optionsInDropdown = optionsArray.value.filter((n) => n.visible && !n.disabled && !n.states.groupDisabled);
- const userCreatedOption = optionsInDropdown.find((n) => n.created);
- const firstOriginOption = optionsInDropdown[0];
- states.hoverIndex = getValueIndex(optionsArray.value, userCreatedOption || firstOriginOption);
- };
- const setSelected = () => {
- var _a2;
- if (!props.multiple) {
- const option = getOption(props.modelValue);
- if ((_a2 = option.props) == null ? void 0 : _a2.created) {
- states.createdLabel = option.props.value;
- states.createdSelected = true;
- } else {
- states.createdSelected = false;
- }
- states.selectedLabel = option.currentLabel;
- states.selected = option;
- if (props.filterable)
- states.query = states.selectedLabel;
- return;
- } else {
- states.selectedLabel = "";
- }
- const result = [];
- if (Array.isArray(props.modelValue)) {
- props.modelValue.forEach((value) => {
- result.push(getOption(value));
- });
- }
- states.selected = result;
- nextTick(() => {
- resetInputHeight();
- });
- };
- const getOption = (value) => {
- let option;
- const isObjectValue = toRawType(value).toLowerCase() === "object";
- const isNull = toRawType(value).toLowerCase() === "null";
- const isUndefined2 = toRawType(value).toLowerCase() === "undefined";
- for (let i2 = states.cachedOptions.size - 1; i2 >= 0; i2--) {
- const cachedOption = cachedOptionsArray.value[i2];
- const isEqualValue = isObjectValue ? get$2(cachedOption.value, props.valueKey) === get$2(value, props.valueKey) : cachedOption.value === value;
- if (isEqualValue) {
- option = {
- value,
- currentLabel: cachedOption.currentLabel,
- isDisabled: cachedOption.isDisabled
- };
- break;
- }
- }
- if (option)
- return option;
- const label2 = isObjectValue ? value.label : !isNull && !isUndefined2 ? value : "";
- const newOption = {
- value,
- currentLabel: label2
- };
- if (props.multiple) {
- newOption.hitState = false;
- }
- return newOption;
- };
- const resetHoverIndex = () => {
- setTimeout(() => {
- const valueKey = props.valueKey;
- if (!props.multiple) {
- states.hoverIndex = optionsArray.value.findIndex((item) => {
- return getValueKey(item) === getValueKey(states.selected);
- });
- } else {
- if (states.selected.length > 0) {
- states.hoverIndex = Math.min.apply(null, states.selected.map((selected) => {
- return optionsArray.value.findIndex((item) => {
- return get$2(item, valueKey) === get$2(selected, valueKey);
- });
- }));
- } else {
- states.hoverIndex = -1;
- }
- }
- }, 300);
- };
- const handleResize = () => {
- var _a2, _b;
- resetInputWidth();
- (_b = (_a2 = tooltipRef.value) == null ? void 0 : _a2.updatePopper) == null ? void 0 : _b.call(_a2);
- if (props.multiple)
- resetInputHeight();
- };
- const resetInputWidth = () => {
- var _a2;
- states.inputWidth = (_a2 = reference.value) == null ? void 0 : _a2.$el.offsetWidth;
- };
- const onInputChange = () => {
- if (props.filterable && states.query !== states.selectedLabel) {
- states.query = states.selectedLabel;
- handleQueryChange(states.query);
- }
- };
- const debouncedOnInputChange = debounce$2(() => {
- onInputChange();
- }, debounce$12.value);
- const debouncedQueryChange = debounce$2((e) => {
- handleQueryChange(e.target.value);
- }, debounce$12.value);
- const emitChange = (val) => {
- if (!isEqual(props.modelValue, val)) {
- ctx.emit(CHANGE_EVENT, val);
- }
- };
- const deletePrevTag = (e) => {
- if (e.code === EVENT_CODE.delete)
- return;
- if (e.target.value.length <= 0 && !toggleLastOptionHitState()) {
- const value = props.modelValue.slice();
- value.pop();
- ctx.emit(UPDATE_MODEL_EVENT, value);
- emitChange(value);
- }
- if (e.target.value.length === 1 && props.modelValue.length === 0) {
- states.currentPlaceholder = states.cachedPlaceHolder;
- }
- };
- const deleteTag = (event2, tag) => {
- const index2 = states.selected.indexOf(tag);
- if (index2 > -1 && !selectDisabled.value) {
- const value = props.modelValue.slice();
- value.splice(index2, 1);
- ctx.emit(UPDATE_MODEL_EVENT, value);
- emitChange(value);
- ctx.emit("remove-tag", tag.value);
- }
- event2.stopPropagation();
- };
- const deleteSelected = (event2) => {
- event2.stopPropagation();
- const value = props.multiple ? [] : "";
- if (!isString(value)) {
- for (const item of states.selected) {
- if (item.isDisabled)
- value.push(item.value);
- }
- }
- ctx.emit(UPDATE_MODEL_EVENT, value);
- emitChange(value);
- states.hoverIndex = -1;
- states.visible = false;
- ctx.emit("clear");
- };
- const handleOptionSelect = (option, byClick) => {
- var _a2;
- if (props.multiple) {
- const value = (props.modelValue || []).slice();
- const optionIndex = getValueIndex(value, option.value);
- if (optionIndex > -1) {
- value.splice(optionIndex, 1);
- } else if (props.multipleLimit <= 0 || value.length < props.multipleLimit) {
- value.push(option.value);
- }
- ctx.emit(UPDATE_MODEL_EVENT, value);
- emitChange(value);
- if (option.created) {
- states.query = "";
- handleQueryChange("");
- states.inputLength = 20;
- }
- if (props.filterable)
- (_a2 = input.value) == null ? void 0 : _a2.focus();
- } else {
- ctx.emit(UPDATE_MODEL_EVENT, option.value);
- emitChange(option.value);
- states.visible = false;
- }
- states.isSilentBlur = byClick;
- setSoftFocus();
- if (states.visible)
- return;
- nextTick(() => {
- scrollToOption(option);
- });
- };
- const getValueIndex = (arr = [], value) => {
- if (!isObject$5(value))
- return arr.indexOf(value);
- const valueKey = props.valueKey;
- let index2 = -1;
- arr.some((item, i2) => {
- if (toRaw$1(get$2(item, valueKey)) === get$2(value, valueKey)) {
- index2 = i2;
- return true;
- }
- return false;
- });
- return index2;
- };
- const setSoftFocus = () => {
- states.softFocus = true;
- const _input = input.value || reference.value;
- if (_input) {
- _input == null ? void 0 : _input.focus();
- }
- };
- const scrollToOption = (option) => {
- var _a2, _b, _c, _d, _e;
- const targetOption = Array.isArray(option) ? option[0] : option;
- let target = null;
- if (targetOption == null ? void 0 : targetOption.value) {
- const options2 = optionsArray.value.filter((item) => item.value === targetOption.value);
- if (options2.length > 0) {
- target = options2[0].$el;
- }
- }
- if (tooltipRef.value && target) {
- const menu = (_d = (_c = (_b = (_a2 = tooltipRef.value) == null ? void 0 : _a2.popperRef) == null ? void 0 : _b.contentRef) == null ? void 0 : _c.querySelector) == null ? void 0 : _d.call(_c, `.${ns.be("dropdown", "wrap")}`);
- if (menu) {
- scrollIntoView(menu, target);
- }
- }
- (_e = scrollbar.value) == null ? void 0 : _e.handleScroll();
- };
- const onOptionCreate = (vm) => {
- states.optionsCount++;
- states.filteredOptionsCount++;
- states.options.set(vm.value, vm);
- states.cachedOptions.set(vm.value, vm);
- };
- const onOptionDestroy = (key, vm) => {
- if (states.options.get(key) === vm) {
- states.optionsCount--;
- states.filteredOptionsCount--;
- states.options.delete(key);
- }
- };
- const resetInputState = (e) => {
- if (e.code !== EVENT_CODE.backspace)
- toggleLastOptionHitState(false);
- states.inputLength = input.value.value.length * 15 + 20;
- resetInputHeight();
- };
- const toggleLastOptionHitState = (hit) => {
- if (!Array.isArray(states.selected))
- return;
- const option = states.selected[states.selected.length - 1];
- if (!option)
- return;
- if (hit === true || hit === false) {
- option.hitState = hit;
- return hit;
- }
- option.hitState = !option.hitState;
- return option.hitState;
- };
- const handleComposition = (event2) => {
- const text = event2.target.value;
- if (event2.type === "compositionend") {
- states.isOnComposition = false;
- nextTick(() => handleQueryChange(text));
- } else {
- const lastCharacter = text[text.length - 1] || "";
- states.isOnComposition = !isKorean(lastCharacter);
- }
- };
- const handleMenuEnter = () => {
- nextTick(() => scrollToOption(states.selected));
- };
- const handleFocus = (event2) => {
- if (!states.softFocus) {
- if (props.automaticDropdown || props.filterable) {
- if (props.filterable && !states.visible) {
- states.menuVisibleOnFocus = true;
- }
- states.visible = true;
- }
- ctx.emit("focus", event2);
- } else {
- states.softFocus = false;
- }
- };
- const blur = () => {
- var _a2, _b, _c;
- states.visible = false;
- (_a2 = reference.value) == null ? void 0 : _a2.blur();
- (_c = (_b = iOSInput.value) == null ? void 0 : _b.blur) == null ? void 0 : _c.call(_b);
- };
- const handleBlur = (event2) => {
- nextTick(() => {
- if (states.isSilentBlur) {
- states.isSilentBlur = false;
- } else {
- ctx.emit("blur", event2);
- }
- });
- states.softFocus = false;
- };
- const handleClearClick = (event2) => {
- deleteSelected(event2);
- };
- const handleClose = () => {
- states.visible = false;
- };
- const handleKeydownEscape = (event2) => {
- if (states.visible) {
- event2.preventDefault();
- event2.stopPropagation();
- states.visible = false;
- }
- };
- const toggleMenu = (e) => {
- var _a2;
- if (e && !states.mouseEnter) {
- return;
- }
- if (!selectDisabled.value) {
- if (states.menuVisibleOnFocus) {
- states.menuVisibleOnFocus = false;
- } else {
- if (!tooltipRef.value || !tooltipRef.value.isFocusInsideContent()) {
- states.visible = !states.visible;
- }
- }
- if (states.visible) {
- (_a2 = input.value || reference.value) == null ? void 0 : _a2.focus();
- }
- }
- };
- const selectOption = () => {
- if (!states.visible) {
- toggleMenu();
- } else {
- if (optionsArray.value[states.hoverIndex]) {
- handleOptionSelect(optionsArray.value[states.hoverIndex], void 0);
- }
- }
- };
- const getValueKey = (item) => {
- return isObject$5(item.value) ? get$2(item.value, props.valueKey) : item.value;
- };
- const optionsAllDisabled = computed$1(() => optionsArray.value.filter((option) => option.visible).every((option) => option.disabled));
- const showTagList = computed$1(() => states.selected.slice(0, props.maxCollapseTags));
- const collapseTagList = computed$1(() => states.selected.slice(props.maxCollapseTags));
- const navigateOptions = (direction) => {
- if (!states.visible) {
- states.visible = true;
- return;
- }
- if (states.options.size === 0 || states.filteredOptionsCount === 0)
- return;
- if (states.isOnComposition)
- return;
- if (!optionsAllDisabled.value) {
- if (direction === "next") {
- states.hoverIndex++;
- if (states.hoverIndex === states.options.size) {
- states.hoverIndex = 0;
- }
- } else if (direction === "prev") {
- states.hoverIndex--;
- if (states.hoverIndex < 0) {
- states.hoverIndex = states.options.size - 1;
- }
- }
- const option = optionsArray.value[states.hoverIndex];
- if (option.disabled === true || option.states.groupDisabled === true || !option.visible) {
- navigateOptions(direction);
- }
- nextTick(() => scrollToOption(hoverOption.value));
- }
- };
- const handleMouseEnter = () => {
- states.mouseEnter = true;
- };
- const handleMouseLeave = () => {
- states.mouseEnter = false;
- };
- return {
- optionList,
- optionsArray,
- selectSize,
- handleResize,
- debouncedOnInputChange,
- debouncedQueryChange,
- deletePrevTag,
- deleteTag,
- deleteSelected,
- handleOptionSelect,
- scrollToOption,
- readonly: readonly2,
- resetInputHeight,
- showClose,
- iconComponent,
- iconReverse,
- showNewOption,
- collapseTagSize,
- setSelected,
- managePlaceholder,
- selectDisabled,
- emptyText,
- toggleLastOptionHitState,
- resetInputState,
- handleComposition,
- onOptionCreate,
- onOptionDestroy,
- handleMenuEnter,
- handleFocus,
- blur,
- handleBlur,
- handleClearClick,
- handleClose,
- handleKeydownEscape,
- toggleMenu,
- selectOption,
- getValueKey,
- navigateOptions,
- dropMenuVisible,
- queryChange,
- groupQueryChange,
- showTagList,
- collapseTagList,
- reference,
- input,
- iOSInput,
- tooltipRef,
- tags,
- selectWrapper,
- scrollbar,
- handleMouseEnter,
- handleMouseLeave
- };
- };
- var ElOptions = defineComponent({
- name: "ElOptions",
- emits: ["update-options"],
- setup(_, { slots, emit }) {
- let cachedOptions = [];
- function isSameOptions(a, b) {
- if (a.length !== b.length)
- return false;
- for (const [index2] of a.entries()) {
- if (a[index2] != b[index2]) {
- return false;
- }
- }
- return true;
- }
- return () => {
- var _a2, _b;
- const children = (_a2 = slots.default) == null ? void 0 : _a2.call(slots);
- const filteredOptions = [];
- function filterOptions(children2) {
- if (!Array.isArray(children2))
- return;
- children2.forEach((item) => {
- var _a22, _b2, _c, _d;
- const name = (_a22 = (item == null ? void 0 : item.type) || {}) == null ? void 0 : _a22.name;
- if (name === "ElOptionGroup") {
- filterOptions(!isString(item.children) && !Array.isArray(item.children) && isFunction$3((_b2 = item.children) == null ? void 0 : _b2.default) ? (_c = item.children) == null ? void 0 : _c.default() : item.children);
- } else if (name === "ElOption") {
- filteredOptions.push((_d = item.props) == null ? void 0 : _d.label);
- } else if (Array.isArray(item.children)) {
- filterOptions(item.children);
- }
- });
- }
- if (children.length) {
- filterOptions((_b = children[0]) == null ? void 0 : _b.children);
- }
- if (!isSameOptions(filteredOptions, cachedOptions)) {
- cachedOptions = filteredOptions;
- emit("update-options", filteredOptions);
- }
- return children;
- };
- }
- });
- const COMPONENT_NAME$1 = "ElSelect";
- const _sfc_main$5 = defineComponent({
- name: COMPONENT_NAME$1,
- componentName: COMPONENT_NAME$1,
- components: {
- ElInput,
- ElSelectMenu,
- ElOption: Option,
- ElOptions,
- ElTag,
- ElScrollbar,
- ElTooltip,
- ElIcon
- },
- directives: { ClickOutside },
- props: {
- name: String,
- id: String,
- modelValue: {
- type: [Array, String, Number, Boolean, Object],
- default: void 0
- },
- autocomplete: {
- type: String,
- default: "off"
- },
- automaticDropdown: Boolean,
- size: {
- type: String,
- validator: isValidComponentSize
- },
- effect: {
- type: String,
- default: "light"
- },
- disabled: Boolean,
- clearable: Boolean,
- filterable: Boolean,
- allowCreate: Boolean,
- loading: Boolean,
- popperClass: {
- type: String,
- default: ""
- },
- popperOptions: {
- type: Object,
- default: () => ({})
- },
- remote: Boolean,
- loadingText: String,
- noMatchText: String,
- noDataText: String,
- remoteMethod: Function,
- filterMethod: Function,
- multiple: Boolean,
- multipleLimit: {
- type: Number,
- default: 0
- },
- placeholder: {
- type: String
- },
- defaultFirstOption: Boolean,
- reserveKeyword: {
- type: Boolean,
- default: true
- },
- valueKey: {
- type: String,
- default: "value"
- },
- collapseTags: Boolean,
- collapseTagsTooltip: {
- type: Boolean,
- default: false
- },
- maxCollapseTags: {
- type: Number,
- default: 1
- },
- teleported: useTooltipContentProps.teleported,
- persistent: {
- type: Boolean,
- default: true
- },
- clearIcon: {
- type: iconPropType,
- default: circle_close_default
- },
- fitInputWidth: {
- type: Boolean,
- default: false
- },
- suffixIcon: {
- type: iconPropType,
- default: arrow_down_default
- },
- tagType: { ...tagProps.type, default: "info" },
- validateEvent: {
- type: Boolean,
- default: true
- },
- remoteShowSuffix: {
- type: Boolean,
- default: false
- },
- suffixTransition: {
- type: Boolean,
- default: true
- },
- placement: {
- type: String,
- values: Ee,
- default: "bottom-start"
- }
- },
- emits: [
- UPDATE_MODEL_EVENT,
- CHANGE_EVENT,
- "remove-tag",
- "clear",
- "visible-change",
- "focus",
- "blur"
- ],
- setup(props, ctx) {
- const nsSelect = useNamespace("select");
- const nsInput = useNamespace("input");
- const { t: t2 } = useLocale();
- const states = useSelectStates(props);
- const {
- optionList,
- optionsArray,
- selectSize,
- readonly: readonly2,
- handleResize,
- collapseTagSize,
- debouncedOnInputChange,
- debouncedQueryChange,
- deletePrevTag,
- deleteTag,
- deleteSelected,
- handleOptionSelect,
- scrollToOption,
- setSelected,
- resetInputHeight,
- managePlaceholder,
- showClose,
- selectDisabled,
- iconComponent,
- iconReverse,
- showNewOption,
- emptyText,
- toggleLastOptionHitState,
- resetInputState,
- handleComposition,
- onOptionCreate,
- onOptionDestroy,
- handleMenuEnter,
- handleFocus,
- blur,
- handleBlur,
- handleClearClick,
- handleClose,
- handleKeydownEscape,
- toggleMenu,
- selectOption,
- getValueKey,
- navigateOptions,
- dropMenuVisible,
- reference,
- input,
- iOSInput,
- tooltipRef,
- tags,
- selectWrapper,
- scrollbar,
- queryChange,
- groupQueryChange,
- handleMouseEnter,
- handleMouseLeave,
- showTagList,
- collapseTagList
- } = useSelect(props, states, ctx);
- const { focus } = useFocus(reference);
- const {
- inputWidth,
- selected,
- inputLength,
- filteredOptionsCount,
- visible,
- softFocus,
- selectedLabel,
- hoverIndex,
- query,
- inputHovering,
- currentPlaceholder,
- menuVisibleOnFocus,
- isOnComposition,
- isSilentBlur,
- options: options2,
- cachedOptions,
- optionsCount,
- prefixWidth,
- tagInMultiLine
- } = toRefs(states);
- const wrapperKls = computed$1(() => {
- const classList = [nsSelect.b()];
- const _selectSize = unref(selectSize);
- if (_selectSize) {
- classList.push(nsSelect.m(_selectSize));
- }
- if (props.disabled) {
- classList.push(nsSelect.m("disabled"));
- }
- return classList;
- });
- const selectTagsStyle = computed$1(() => ({
- maxWidth: `${unref(inputWidth) - 32}px`,
- width: "100%"
- }));
- const tagTextStyle = computed$1(() => {
- const maxWidth = unref(inputWidth) > 123 ? unref(inputWidth) - 123 : unref(inputWidth) - 75;
- return { maxWidth: `${maxWidth}px` };
- });
- provide(selectKey, reactive({
- props,
- options: options2,
- optionsArray,
- cachedOptions,
- optionsCount,
- filteredOptionsCount,
- hoverIndex,
- handleOptionSelect,
- onOptionCreate,
- onOptionDestroy,
- selectWrapper,
- selected,
- setSelected,
- queryChange,
- groupQueryChange
- }));
- onMounted(() => {
- states.cachedPlaceHolder = currentPlaceholder.value = props.placeholder || (() => t2("el.select.placeholder"));
- if (props.multiple && Array.isArray(props.modelValue) && props.modelValue.length > 0) {
- currentPlaceholder.value = "";
- }
- useResizeObserver(selectWrapper, handleResize);
- if (props.remote && props.multiple) {
- resetInputHeight();
- }
- nextTick(() => {
- const refEl = reference.value && reference.value.$el;
- if (!refEl)
- return;
- inputWidth.value = refEl.getBoundingClientRect().width;
- if (ctx.slots.prefix) {
- const prefix = refEl.querySelector(`.${nsInput.e("prefix")}`);
- prefixWidth.value = Math.max(prefix.getBoundingClientRect().width + 5, 30);
- }
- });
- setSelected();
- });
- if (props.multiple && !Array.isArray(props.modelValue)) {
- ctx.emit(UPDATE_MODEL_EVENT, []);
- }
- if (!props.multiple && Array.isArray(props.modelValue)) {
- ctx.emit(UPDATE_MODEL_EVENT, "");
- }
- const popperPaneRef = computed$1(() => {
- var _a2, _b;
- return (_b = (_a2 = tooltipRef.value) == null ? void 0 : _a2.popperRef) == null ? void 0 : _b.contentRef;
- });
- const onOptionsRendered = (v) => {
- optionList.value = v;
- };
- return {
- isIOS,
- onOptionsRendered,
- tagInMultiLine,
- prefixWidth,
- selectSize,
- readonly: readonly2,
- handleResize,
- collapseTagSize,
- debouncedOnInputChange,
- debouncedQueryChange,
- deletePrevTag,
- deleteTag,
- deleteSelected,
- handleOptionSelect,
- scrollToOption,
- inputWidth,
- selected,
- inputLength,
- filteredOptionsCount,
- visible,
- softFocus,
- selectedLabel,
- hoverIndex,
- query,
- inputHovering,
- currentPlaceholder,
- menuVisibleOnFocus,
- isOnComposition,
- isSilentBlur,
- options: options2,
- resetInputHeight,
- managePlaceholder,
- showClose,
- selectDisabled,
- iconComponent,
- iconReverse,
- showNewOption,
- emptyText,
- toggleLastOptionHitState,
- resetInputState,
- handleComposition,
- handleMenuEnter,
- handleFocus,
- blur,
- handleBlur,
- handleClearClick,
- handleClose,
- handleKeydownEscape,
- toggleMenu,
- selectOption,
- getValueKey,
- navigateOptions,
- dropMenuVisible,
- focus,
- reference,
- input,
- iOSInput,
- tooltipRef,
- popperPaneRef,
- tags,
- selectWrapper,
- scrollbar,
- wrapperKls,
- selectTagsStyle,
- nsSelect,
- tagTextStyle,
- handleMouseEnter,
- handleMouseLeave,
- showTagList,
- collapseTagList
- };
- }
- });
- const _hoisted_1$4 = ["disabled", "autocomplete"];
- const _hoisted_2$4 = ["disabled"];
- const _hoisted_3$4 = { style: { "height": "100%", "display": "flex", "justify-content": "center", "align-items": "center" } };
- function _sfc_render$1(_ctx, _cache, $props, $setup, $data, $options) {
- const _component_el_tag = resolveComponent("el-tag");
- const _component_el_tooltip = resolveComponent("el-tooltip");
- const _component_el_icon = resolveComponent("el-icon");
- const _component_el_input = resolveComponent("el-input");
- const _component_el_option = resolveComponent("el-option");
- const _component_el_options = resolveComponent("el-options");
- const _component_el_scrollbar = resolveComponent("el-scrollbar");
- const _component_el_select_menu = resolveComponent("el-select-menu");
- const _directive_click_outside = resolveDirective("click-outside");
- return withDirectives((openBlock(), createElementBlock("div", {
- ref: "selectWrapper",
- class: normalizeClass(_ctx.wrapperKls),
- onMouseenter: _cache[21] || (_cache[21] = (...args) => _ctx.handleMouseEnter && _ctx.handleMouseEnter(...args)),
- onMouseleave: _cache[22] || (_cache[22] = (...args) => _ctx.handleMouseLeave && _ctx.handleMouseLeave(...args)),
- onClick: _cache[23] || (_cache[23] = withModifiers((...args) => _ctx.toggleMenu && _ctx.toggleMenu(...args), ["stop"]))
- }, [
- createVNode(_component_el_tooltip, {
- ref: "tooltipRef",
- visible: _ctx.dropMenuVisible,
- placement: _ctx.placement,
- teleported: _ctx.teleported,
- "popper-class": [_ctx.nsSelect.e("popper"), _ctx.popperClass],
- "popper-options": _ctx.popperOptions,
- "fallback-placements": ["bottom-start", "top-start", "right", "left"],
- effect: _ctx.effect,
- pure: "",
- trigger: "click",
- transition: `${_ctx.nsSelect.namespace.value}-zoom-in-top`,
- "stop-popper-mouse-event": false,
- "gpu-acceleration": false,
- persistent: _ctx.persistent,
- onShow: _ctx.handleMenuEnter
- }, {
- default: withCtx(() => [
- createElementVNode("div", {
- class: "select-trigger",
- onMouseenter: _cache[19] || (_cache[19] = ($event) => _ctx.inputHovering = true),
- onMouseleave: _cache[20] || (_cache[20] = ($event) => _ctx.inputHovering = false)
- }, [
- _ctx.multiple ? (openBlock(), createElementBlock("div", {
- key: 0,
- ref: "tags",
- class: normalizeClass([
- _ctx.nsSelect.e("tags"),
- _ctx.nsSelect.is("disabled", _ctx.selectDisabled)
- ]),
- style: normalizeStyle(_ctx.selectTagsStyle)
- }, [
- _ctx.collapseTags && _ctx.selected.length ? (openBlock(), createBlock(Transition, {
- key: 0,
- onAfterLeave: _ctx.resetInputHeight
- }, {
- default: withCtx(() => [
- createElementVNode("span", {
- class: normalizeClass([
- _ctx.nsSelect.b("tags-wrapper"),
- { "has-prefix": _ctx.prefixWidth && _ctx.selected.length }
- ])
- }, [
- (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.showTagList, (item) => {
- return openBlock(), createBlock(_component_el_tag, {
- key: _ctx.getValueKey(item),
- closable: !_ctx.selectDisabled && !item.isDisabled,
- size: _ctx.collapseTagSize,
- hit: item.hitState,
- type: _ctx.tagType,
- "disable-transitions": "",
- onClose: ($event) => _ctx.deleteTag($event, item)
- }, {
- default: withCtx(() => [
- createElementVNode("span", {
- class: normalizeClass(_ctx.nsSelect.e("tags-text")),
- style: normalizeStyle(_ctx.tagTextStyle)
- }, toDisplayString(item.currentLabel), 7)
- ]),
- _: 2
- }, 1032, ["closable", "size", "hit", "type", "onClose"]);
- }), 128)),
- _ctx.selected.length > _ctx.maxCollapseTags ? (openBlock(), createBlock(_component_el_tag, {
- key: 0,
- closable: false,
- size: _ctx.collapseTagSize,
- type: _ctx.tagType,
- "disable-transitions": ""
- }, {
- default: withCtx(() => [
- _ctx.collapseTagsTooltip ? (openBlock(), createBlock(_component_el_tooltip, {
- key: 0,
- disabled: _ctx.dropMenuVisible,
- "fallback-placements": ["bottom", "top", "right", "left"],
- effect: _ctx.effect,
- placement: "bottom",
- teleported: _ctx.teleported
- }, {
- default: withCtx(() => [
- createElementVNode("span", {
- class: normalizeClass(_ctx.nsSelect.e("tags-text"))
- }, "+ " + toDisplayString(_ctx.selected.length - _ctx.maxCollapseTags), 3)
- ]),
- content: withCtx(() => [
- createElementVNode("div", {
- class: normalizeClass(_ctx.nsSelect.e("collapse-tags"))
- }, [
- (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.collapseTagList, (item) => {
- return openBlock(), createElementBlock("div", {
- key: _ctx.getValueKey(item),
- class: normalizeClass(_ctx.nsSelect.e("collapse-tag"))
- }, [
- createVNode(_component_el_tag, {
- class: "in-tooltip",
- closable: !_ctx.selectDisabled && !item.isDisabled,
- size: _ctx.collapseTagSize,
- hit: item.hitState,
- type: _ctx.tagType,
- "disable-transitions": "",
- style: { margin: "2px" },
- onClose: ($event) => _ctx.deleteTag($event, item)
- }, {
- default: withCtx(() => [
- createElementVNode("span", {
- class: normalizeClass(_ctx.nsSelect.e("tags-text")),
- style: normalizeStyle({
- maxWidth: _ctx.inputWidth - 75 + "px"
- })
- }, toDisplayString(item.currentLabel), 7)
- ]),
- _: 2
- }, 1032, ["closable", "size", "hit", "type", "onClose"])
- ], 2);
- }), 128))
- ], 2)
- ]),
- _: 1
- }, 8, ["disabled", "effect", "teleported"])) : (openBlock(), createElementBlock("span", {
- key: 1,
- class: normalizeClass(_ctx.nsSelect.e("tags-text"))
- }, "+ " + toDisplayString(_ctx.selected.length - _ctx.maxCollapseTags), 3))
- ]),
- _: 1
- }, 8, ["size", "type"])) : createCommentVNode("v-if", true)
- ], 2)
- ]),
- _: 1
- }, 8, ["onAfterLeave"])) : createCommentVNode("v-if", true),
- !_ctx.collapseTags ? (openBlock(), createBlock(Transition, {
- key: 1,
- onAfterLeave: _ctx.resetInputHeight
- }, {
- default: withCtx(() => [
- createElementVNode("span", {
- class: normalizeClass([
- _ctx.nsSelect.b("tags-wrapper"),
- { "has-prefix": _ctx.prefixWidth && _ctx.selected.length }
- ])
- }, [
- (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.selected, (item) => {
- return openBlock(), createBlock(_component_el_tag, {
- key: _ctx.getValueKey(item),
- closable: !_ctx.selectDisabled && !item.isDisabled,
- size: _ctx.collapseTagSize,
- hit: item.hitState,
- type: _ctx.tagType,
- "disable-transitions": "",
- onClose: ($event) => _ctx.deleteTag($event, item)
- }, {
- default: withCtx(() => [
- createElementVNode("span", {
- class: normalizeClass(_ctx.nsSelect.e("tags-text")),
- style: normalizeStyle({ maxWidth: _ctx.inputWidth - 75 + "px" })
- }, toDisplayString(item.currentLabel), 7)
- ]),
- _: 2
- }, 1032, ["closable", "size", "hit", "type", "onClose"]);
- }), 128))
- ], 2)
- ]),
- _: 1
- }, 8, ["onAfterLeave"])) : createCommentVNode("v-if", true),
- _ctx.filterable ? withDirectives((openBlock(), createElementBlock("input", {
- key: 2,
- ref: "input",
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => _ctx.query = $event),
- type: "text",
- class: normalizeClass([
- _ctx.nsSelect.e("input"),
- _ctx.nsSelect.is(_ctx.selectSize),
- _ctx.nsSelect.is("disabled", _ctx.selectDisabled)
- ]),
- disabled: _ctx.selectDisabled,
- autocomplete: _ctx.autocomplete,
- style: normalizeStyle({
- marginLeft: _ctx.prefixWidth && !_ctx.selected.length || _ctx.tagInMultiLine ? `${_ctx.prefixWidth}px` : "",
- flexGrow: 1,
- width: `${_ctx.inputLength / (_ctx.inputWidth - 32)}%`,
- maxWidth: `${_ctx.inputWidth - 42}px`
- }),
- onFocus: _cache[1] || (_cache[1] = (...args) => _ctx.handleFocus && _ctx.handleFocus(...args)),
- onBlur: _cache[2] || (_cache[2] = (...args) => _ctx.handleBlur && _ctx.handleBlur(...args)),
- onKeyup: _cache[3] || (_cache[3] = (...args) => _ctx.managePlaceholder && _ctx.managePlaceholder(...args)),
- onKeydown: [
- _cache[4] || (_cache[4] = (...args) => _ctx.resetInputState && _ctx.resetInputState(...args)),
- _cache[5] || (_cache[5] = withKeys(withModifiers(($event) => _ctx.navigateOptions("next"), ["prevent"]), ["down"])),
- _cache[6] || (_cache[6] = withKeys(withModifiers(($event) => _ctx.navigateOptions("prev"), ["prevent"]), ["up"])),
- _cache[7] || (_cache[7] = withKeys((...args) => _ctx.handleKeydownEscape && _ctx.handleKeydownEscape(...args), ["esc"])),
- _cache[8] || (_cache[8] = withKeys(withModifiers((...args) => _ctx.selectOption && _ctx.selectOption(...args), ["stop", "prevent"]), ["enter"])),
- _cache[9] || (_cache[9] = withKeys((...args) => _ctx.deletePrevTag && _ctx.deletePrevTag(...args), ["delete"])),
- _cache[10] || (_cache[10] = withKeys(($event) => _ctx.visible = false, ["tab"]))
- ],
- onCompositionstart: _cache[11] || (_cache[11] = (...args) => _ctx.handleComposition && _ctx.handleComposition(...args)),
- onCompositionupdate: _cache[12] || (_cache[12] = (...args) => _ctx.handleComposition && _ctx.handleComposition(...args)),
- onCompositionend: _cache[13] || (_cache[13] = (...args) => _ctx.handleComposition && _ctx.handleComposition(...args)),
- onInput: _cache[14] || (_cache[14] = (...args) => _ctx.debouncedQueryChange && _ctx.debouncedQueryChange(...args))
- }, null, 46, _hoisted_1$4)), [
- [vModelText, _ctx.query]
- ]) : createCommentVNode("v-if", true)
- ], 6)) : createCommentVNode("v-if", true),
- createCommentVNode(" fix: https://github.com/element-plus/element-plus/issues/11415 "),
- _ctx.isIOS && !_ctx.multiple && _ctx.filterable && _ctx.readonly ? (openBlock(), createElementBlock("input", {
- key: 1,
- ref: "iOSInput",
- class: normalizeClass([
- _ctx.nsSelect.e("input"),
- _ctx.nsSelect.is(_ctx.selectSize),
- _ctx.nsSelect.em("input", "iOS")
- ]),
- disabled: _ctx.selectDisabled,
- type: "text"
- }, null, 10, _hoisted_2$4)) : createCommentVNode("v-if", true),
- createVNode(_component_el_input, {
- id: _ctx.id,
- ref: "reference",
- modelValue: _ctx.selectedLabel,
- "onUpdate:modelValue": _cache[15] || (_cache[15] = ($event) => _ctx.selectedLabel = $event),
- type: "text",
- placeholder: typeof _ctx.currentPlaceholder === "function" ? _ctx.currentPlaceholder() : _ctx.currentPlaceholder,
- name: _ctx.name,
- autocomplete: _ctx.autocomplete,
- size: _ctx.selectSize,
- disabled: _ctx.selectDisabled,
- readonly: _ctx.readonly,
- "validate-event": false,
- class: normalizeClass([_ctx.nsSelect.is("focus", _ctx.visible)]),
- tabindex: _ctx.multiple && _ctx.filterable ? -1 : void 0,
- onFocus: _ctx.handleFocus,
- onBlur: _ctx.handleBlur,
- onInput: _ctx.debouncedOnInputChange,
- onPaste: _ctx.debouncedOnInputChange,
- onCompositionstart: _ctx.handleComposition,
- onCompositionupdate: _ctx.handleComposition,
- onCompositionend: _ctx.handleComposition,
- onKeydown: [
- _cache[16] || (_cache[16] = withKeys(withModifiers(($event) => _ctx.navigateOptions("next"), ["stop", "prevent"]), ["down"])),
- _cache[17] || (_cache[17] = withKeys(withModifiers(($event) => _ctx.navigateOptions("prev"), ["stop", "prevent"]), ["up"])),
- withKeys(withModifiers(_ctx.selectOption, ["stop", "prevent"]), ["enter"]),
- withKeys(_ctx.handleKeydownEscape, ["esc"]),
- _cache[18] || (_cache[18] = withKeys(($event) => _ctx.visible = false, ["tab"]))
- ]
- }, createSlots({
- suffix: withCtx(() => [
- _ctx.iconComponent && !_ctx.showClose ? (openBlock(), createBlock(_component_el_icon, {
- key: 0,
- class: normalizeClass([_ctx.nsSelect.e("caret"), _ctx.nsSelect.e("icon"), _ctx.iconReverse])
- }, {
- default: withCtx(() => [
- (openBlock(), createBlock(resolveDynamicComponent(_ctx.iconComponent)))
- ]),
- _: 1
- }, 8, ["class"])) : createCommentVNode("v-if", true),
- _ctx.showClose && _ctx.clearIcon ? (openBlock(), createBlock(_component_el_icon, {
- key: 1,
- class: normalizeClass([_ctx.nsSelect.e("caret"), _ctx.nsSelect.e("icon")]),
- onClick: _ctx.handleClearClick
- }, {
- default: withCtx(() => [
- (openBlock(), createBlock(resolveDynamicComponent(_ctx.clearIcon)))
- ]),
- _: 1
- }, 8, ["class", "onClick"])) : createCommentVNode("v-if", true)
- ]),
- _: 2
- }, [
- _ctx.$slots.prefix ? {
- name: "prefix",
- fn: withCtx(() => [
- createElementVNode("div", _hoisted_3$4, [
- renderSlot(_ctx.$slots, "prefix")
- ])
- ])
- } : void 0
- ]), 1032, ["id", "modelValue", "placeholder", "name", "autocomplete", "size", "disabled", "readonly", "class", "tabindex", "onFocus", "onBlur", "onInput", "onPaste", "onCompositionstart", "onCompositionupdate", "onCompositionend", "onKeydown"])
- ], 32)
- ]),
- content: withCtx(() => [
- createVNode(_component_el_select_menu, null, {
- default: withCtx(() => [
- withDirectives(createVNode(_component_el_scrollbar, {
- ref: "scrollbar",
- tag: "ul",
- "wrap-class": _ctx.nsSelect.be("dropdown", "wrap"),
- "view-class": _ctx.nsSelect.be("dropdown", "list"),
- class: normalizeClass([
- _ctx.nsSelect.is("empty", !_ctx.allowCreate && Boolean(_ctx.query) && _ctx.filteredOptionsCount === 0)
- ])
- }, {
- default: withCtx(() => [
- _ctx.showNewOption ? (openBlock(), createBlock(_component_el_option, {
- key: 0,
- value: _ctx.query,
- created: true
- }, null, 8, ["value"])) : createCommentVNode("v-if", true),
- createVNode(_component_el_options, { onUpdateOptions: _ctx.onOptionsRendered }, {
- default: withCtx(() => [
- renderSlot(_ctx.$slots, "default")
- ]),
- _: 3
- }, 8, ["onUpdateOptions"])
- ]),
- _: 3
- }, 8, ["wrap-class", "view-class", "class"]), [
- [vShow, _ctx.options.size > 0 && !_ctx.loading]
- ]),
- _ctx.emptyText && (!_ctx.allowCreate || _ctx.loading || _ctx.allowCreate && _ctx.options.size === 0) ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
- _ctx.$slots.empty ? renderSlot(_ctx.$slots, "empty", { key: 0 }) : (openBlock(), createElementBlock("p", {
- key: 1,
- class: normalizeClass(_ctx.nsSelect.be("dropdown", "empty"))
- }, toDisplayString(_ctx.emptyText), 3))
- ], 64)) : createCommentVNode("v-if", true)
- ]),
- _: 3
- })
- ]),
- _: 3
- }, 8, ["visible", "placement", "teleported", "popper-class", "popper-options", "effect", "transition", "persistent", "onShow"])
- ], 34)), [
- [_directive_click_outside, _ctx.handleClose, _ctx.popperPaneRef]
- ]);
- }
- var Select = /* @__PURE__ */ _export_sfc$1(_sfc_main$5, [["render", _sfc_render$1], ["__file", "/home/runner/work/element-plus/element-plus/packages/components/select/src/select.vue"]]);
- const _sfc_main$4 = defineComponent({
- name: "ElOptionGroup",
- componentName: "ElOptionGroup",
- props: {
- label: String,
- disabled: {
- type: Boolean,
- default: false
- }
- },
- setup(props) {
- const ns = useNamespace("select");
- const visible = ref(true);
- const instance = getCurrentInstance();
- const children = ref([]);
- provide(selectGroupKey, reactive({
- ...toRefs(props)
- }));
- const select = inject(selectKey);
- onMounted(() => {
- children.value = flattedChildren(instance.subTree);
- });
- const flattedChildren = (node) => {
- const children2 = [];
- if (Array.isArray(node.children)) {
- node.children.forEach((child) => {
- var _a2;
- if (child.type && child.type.name === "ElOption" && child.component && child.component.proxy) {
- children2.push(child.component.proxy);
- } else if ((_a2 = child.children) == null ? void 0 : _a2.length) {
- children2.push(...flattedChildren(child));
- }
- });
- }
- return children2;
- };
- const { groupQueryChange } = toRaw$1(select);
- watch(groupQueryChange, () => {
- visible.value = children.value.some((option) => option.visible === true);
- }, { flush: "post" });
- return {
- visible,
- ns
- };
- }
- });
- function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
- return withDirectives((openBlock(), createElementBlock("ul", {
- class: normalizeClass(_ctx.ns.be("group", "wrap"))
- }, [
- createElementVNode("li", {
- class: normalizeClass(_ctx.ns.be("group", "title"))
- }, toDisplayString(_ctx.label), 3),
- createElementVNode("li", null, [
- createElementVNode("ul", {
- class: normalizeClass(_ctx.ns.b("group"))
- }, [
- renderSlot(_ctx.$slots, "default")
- ], 2)
- ])
- ], 2)), [
- [vShow, _ctx.visible]
- ]);
- }
- var OptionGroup = /* @__PURE__ */ _export_sfc$1(_sfc_main$4, [["render", _sfc_render], ["__file", "/home/runner/work/element-plus/element-plus/packages/components/select/src/option-group.vue"]]);
- const ElSelect = withInstall(Select, {
- Option,
- OptionGroup
- });
- const ElOption = withNoopInstall(Option);
- withNoopInstall(OptionGroup);
- const switchProps = buildProps({
- modelValue: {
- type: [Boolean, String, Number],
- default: false
- },
- value: {
- type: [Boolean, String, Number],
- default: false
- },
- disabled: {
- type: Boolean,
- default: false
- },
- width: {
- type: [String, Number],
- default: ""
- },
- inlinePrompt: {
- type: Boolean,
- default: false
- },
- activeIcon: {
- type: iconPropType
- },
- inactiveIcon: {
- type: iconPropType
- },
- activeText: {
- type: String,
- default: ""
- },
- inactiveText: {
- type: String,
- default: ""
- },
- activeColor: {
- type: String,
- default: ""
- },
- inactiveColor: {
- type: String,
- default: ""
- },
- borderColor: {
- type: String,
- default: ""
- },
- activeValue: {
- type: [Boolean, String, Number],
- default: true
- },
- inactiveValue: {
- type: [Boolean, String, Number],
- default: false
- },
- name: {
- type: String,
- default: ""
- },
- validateEvent: {
- type: Boolean,
- default: true
- },
- id: String,
- loading: {
- type: Boolean,
- default: false
- },
- beforeChange: {
- type: definePropType(Function)
- },
- size: {
- type: String,
- validator: isValidComponentSize
- },
- tabindex: {
- type: [String, Number]
- }
- });
- const switchEmits = {
- [UPDATE_MODEL_EVENT]: (val) => isBoolean(val) || isString(val) || isNumber(val),
- [CHANGE_EVENT]: (val) => isBoolean(val) || isString(val) || isNumber(val),
- [INPUT_EVENT]: (val) => isBoolean(val) || isString(val) || isNumber(val)
- };
- const _hoisted_1$3 = ["onClick"];
- const _hoisted_2$3 = ["id", "aria-checked", "aria-disabled", "name", "true-value", "false-value", "disabled", "tabindex", "onKeydown"];
- const _hoisted_3$3 = ["aria-hidden"];
- const _hoisted_4$3 = ["aria-hidden"];
- const _hoisted_5$3 = ["aria-hidden"];
- const COMPONENT_NAME = "ElSwitch";
- const __default__ = defineComponent({
- name: COMPONENT_NAME
- });
- const _sfc_main$3 = /* @__PURE__ */ defineComponent({
- ...__default__,
- props: switchProps,
- emits: switchEmits,
- setup(__props, { expose, emit }) {
- const props = __props;
- const vm = getCurrentInstance();
- const { formItem } = useFormItem();
- const switchSize = useFormSize();
- const ns = useNamespace("switch");
- useDeprecated({
- from: '"value"',
- replacement: '"model-value" or "v-model"',
- scope: COMPONENT_NAME,
- version: "2.3.0",
- ref: "https://element-plus.org/en-US/component/switch.html#attributes",
- type: "Attribute"
- }, computed$1(() => {
- var _a2;
- return !!((_a2 = vm.vnode.props) == null ? void 0 : _a2.value);
- }));
- const { inputId } = useFormItemInputId(props, {
- formItemContext: formItem
- });
- const switchDisabled = useFormDisabled(computed$1(() => props.loading));
- const isControlled = ref(props.modelValue !== false);
- const input = ref();
- const core = ref();
- const switchKls = computed$1(() => [
- ns.b(),
- ns.m(switchSize.value),
- ns.is("disabled", switchDisabled.value),
- ns.is("checked", checked.value)
- ]);
- const coreStyle = computed$1(() => ({
- width: addUnit(props.width)
- }));
- watch(() => props.modelValue, () => {
- isControlled.value = true;
- });
- watch(() => props.value, () => {
- isControlled.value = false;
- });
- const actualValue = computed$1(() => {
- return isControlled.value ? props.modelValue : props.value;
- });
- const checked = computed$1(() => actualValue.value === props.activeValue);
- if (![props.activeValue, props.inactiveValue].includes(actualValue.value)) {
- emit(UPDATE_MODEL_EVENT, props.inactiveValue);
- emit(CHANGE_EVENT, props.inactiveValue);
- emit(INPUT_EVENT, props.inactiveValue);
- }
- watch(checked, (val) => {
- var _a2;
- input.value.checked = val;
- if (props.validateEvent) {
- (_a2 = formItem == null ? void 0 : formItem.validate) == null ? void 0 : _a2.call(formItem, "change").catch((err) => debugWarn());
- }
- });
- const handleChange = () => {
- const val = checked.value ? props.inactiveValue : props.activeValue;
- emit(UPDATE_MODEL_EVENT, val);
- emit(CHANGE_EVENT, val);
- emit(INPUT_EVENT, val);
- nextTick(() => {
- input.value.checked = checked.value;
- });
- };
- const switchValue = () => {
- if (switchDisabled.value)
- return;
- const { beforeChange } = props;
- if (!beforeChange) {
- handleChange();
- return;
- }
- const shouldChange = beforeChange();
- const isPromiseOrBool = [
- isPromise$2(shouldChange),
- isBoolean(shouldChange)
- ].includes(true);
- if (!isPromiseOrBool) {
- throwError(COMPONENT_NAME, "beforeChange must return type `Promise<boolean>` or `boolean`");
- }
- if (isPromise$2(shouldChange)) {
- shouldChange.then((result) => {
- if (result) {
- handleChange();
- }
- }).catch((e) => {
- });
- } else if (shouldChange) {
- handleChange();
- }
- };
- const styles = computed$1(() => {
- return ns.cssVarBlock({
- ...props.activeColor ? { "on-color": props.activeColor } : null,
- ...props.inactiveColor ? { "off-color": props.inactiveColor } : null,
- ...props.borderColor ? { "border-color": props.borderColor } : null
- });
- });
- const focus = () => {
- var _a2, _b;
- (_b = (_a2 = input.value) == null ? void 0 : _a2.focus) == null ? void 0 : _b.call(_a2);
- };
- onMounted(() => {
- input.value.checked = checked.value;
- });
- expose({
- focus,
- checked
- });
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", {
- class: normalizeClass(unref(switchKls)),
- style: normalizeStyle(unref(styles)),
- onClick: withModifiers(switchValue, ["prevent"])
- }, [
- createElementVNode("input", {
- id: unref(inputId),
- ref_key: "input",
- ref: input,
- class: normalizeClass(unref(ns).e("input")),
- type: "checkbox",
- role: "switch",
- "aria-checked": unref(checked),
- "aria-disabled": unref(switchDisabled),
- name: _ctx.name,
- "true-value": _ctx.activeValue,
- "false-value": _ctx.inactiveValue,
- disabled: unref(switchDisabled),
- tabindex: _ctx.tabindex,
- onChange: handleChange,
- onKeydown: withKeys(switchValue, ["enter"])
- }, null, 42, _hoisted_2$3),
- !_ctx.inlinePrompt && (_ctx.inactiveIcon || _ctx.inactiveText) ? (openBlock(), createElementBlock("span", {
- key: 0,
- class: normalizeClass([
- unref(ns).e("label"),
- unref(ns).em("label", "left"),
- unref(ns).is("active", !unref(checked))
- ])
- }, [
- _ctx.inactiveIcon ? (openBlock(), createBlock(unref(ElIcon), { key: 0 }, {
- default: withCtx(() => [
- (openBlock(), createBlock(resolveDynamicComponent(_ctx.inactiveIcon)))
- ]),
- _: 1
- })) : createCommentVNode("v-if", true),
- !_ctx.inactiveIcon && _ctx.inactiveText ? (openBlock(), createElementBlock("span", {
- key: 1,
- "aria-hidden": unref(checked)
- }, toDisplayString(_ctx.inactiveText), 9, _hoisted_3$3)) : createCommentVNode("v-if", true)
- ], 2)) : createCommentVNode("v-if", true),
- createElementVNode("span", {
- ref_key: "core",
- ref: core,
- class: normalizeClass(unref(ns).e("core")),
- style: normalizeStyle(unref(coreStyle))
- }, [
- _ctx.inlinePrompt ? (openBlock(), createElementBlock("div", {
- key: 0,
- class: normalizeClass(unref(ns).e("inner"))
- }, [
- _ctx.activeIcon || _ctx.inactiveIcon ? (openBlock(), createBlock(unref(ElIcon), {
- key: 0,
- class: normalizeClass(unref(ns).is("icon"))
- }, {
- default: withCtx(() => [
- (openBlock(), createBlock(resolveDynamicComponent(unref(checked) ? _ctx.activeIcon : _ctx.inactiveIcon)))
- ]),
- _: 1
- }, 8, ["class"])) : _ctx.activeText || _ctx.inactiveText ? (openBlock(), createElementBlock("span", {
- key: 1,
- class: normalizeClass(unref(ns).is("text")),
- "aria-hidden": !unref(checked)
- }, toDisplayString(unref(checked) ? _ctx.activeText : _ctx.inactiveText), 11, _hoisted_4$3)) : createCommentVNode("v-if", true)
- ], 2)) : createCommentVNode("v-if", true),
- createElementVNode("div", {
- class: normalizeClass(unref(ns).e("action"))
- }, [
- _ctx.loading ? (openBlock(), createBlock(unref(ElIcon), {
- key: 0,
- class: normalizeClass(unref(ns).is("loading"))
- }, {
- default: withCtx(() => [
- createVNode(unref(loading_default))
- ]),
- _: 1
- }, 8, ["class"])) : createCommentVNode("v-if", true)
- ], 2)
- ], 6),
- !_ctx.inlinePrompt && (_ctx.activeIcon || _ctx.activeText) ? (openBlock(), createElementBlock("span", {
- key: 1,
- class: normalizeClass([
- unref(ns).e("label"),
- unref(ns).em("label", "right"),
- unref(ns).is("active", unref(checked))
- ])
- }, [
- _ctx.activeIcon ? (openBlock(), createBlock(unref(ElIcon), { key: 0 }, {
- default: withCtx(() => [
- (openBlock(), createBlock(resolveDynamicComponent(_ctx.activeIcon)))
- ]),
- _: 1
- })) : createCommentVNode("v-if", true),
- !_ctx.activeIcon && _ctx.activeText ? (openBlock(), createElementBlock("span", {
- key: 1,
- "aria-hidden": !unref(checked)
- }, toDisplayString(_ctx.activeText), 9, _hoisted_5$3)) : createCommentVNode("v-if", true)
- ], 2)) : createCommentVNode("v-if", true)
- ], 14, _hoisted_1$3);
- };
- }
- });
- var Switch = /* @__PURE__ */ _export_sfc$1(_sfc_main$3, [["__file", "/home/runner/work/element-plus/element-plus/packages/components/switch/src/switch.vue"]]);
- const ElSwitch = withInstall(Switch);
- /*! Element Plus v2.3.4 */
- var zhCn = {
- name: "zh-cn",
- el: {
- colorpicker: {
- confirm: "\u786E\u5B9A",
- clear: "\u6E05\u7A7A"
- },
- datepicker: {
- now: "\u6B64\u523B",
- today: "\u4ECA\u5929",
- cancel: "\u53D6\u6D88",
- clear: "\u6E05\u7A7A",
- confirm: "\u786E\u5B9A",
- selectDate: "\u9009\u62E9\u65E5\u671F",
- selectTime: "\u9009\u62E9\u65F6\u95F4",
- startDate: "\u5F00\u59CB\u65E5\u671F",
- startTime: "\u5F00\u59CB\u65F6\u95F4",
- endDate: "\u7ED3\u675F\u65E5\u671F",
- endTime: "\u7ED3\u675F\u65F6\u95F4",
- prevYear: "\u524D\u4E00\u5E74",
- nextYear: "\u540E\u4E00\u5E74",
- prevMonth: "\u4E0A\u4E2A\u6708",
- nextMonth: "\u4E0B\u4E2A\u6708",
- year: "\u5E74",
- month1: "1 \u6708",
- month2: "2 \u6708",
- month3: "3 \u6708",
- month4: "4 \u6708",
- month5: "5 \u6708",
- month6: "6 \u6708",
- month7: "7 \u6708",
- month8: "8 \u6708",
- month9: "9 \u6708",
- month10: "10 \u6708",
- month11: "11 \u6708",
- month12: "12 \u6708",
- weeks: {
- sun: "\u65E5",
- mon: "\u4E00",
- tue: "\u4E8C",
- wed: "\u4E09",
- thu: "\u56DB",
- fri: "\u4E94",
- sat: "\u516D"
- },
- months: {
- jan: "\u4E00\u6708",
- feb: "\u4E8C\u6708",
- mar: "\u4E09\u6708",
- apr: "\u56DB\u6708",
- may: "\u4E94\u6708",
- jun: "\u516D\u6708",
- jul: "\u4E03\u6708",
- aug: "\u516B\u6708",
- sep: "\u4E5D\u6708",
- oct: "\u5341\u6708",
- nov: "\u5341\u4E00\u6708",
- dec: "\u5341\u4E8C\u6708"
- }
- },
- select: {
- loading: "\u52A0\u8F7D\u4E2D",
- noMatch: "\u65E0\u5339\u914D\u6570\u636E",
- noData: "\u65E0\u6570\u636E",
- placeholder: "\u8BF7\u9009\u62E9"
- },
- cascader: {
- noMatch: "\u65E0\u5339\u914D\u6570\u636E",
- loading: "\u52A0\u8F7D\u4E2D",
- placeholder: "\u8BF7\u9009\u62E9",
- noData: "\u6682\u65E0\u6570\u636E"
- },
- pagination: {
- goto: "\u524D\u5F80",
- pagesize: "\u6761/\u9875",
- total: "\u5171 {total} \u6761",
- pageClassifier: "\u9875",
- page: "\u9875",
- prev: "\u4E0A\u4E00\u9875",
- next: "\u4E0B\u4E00\u9875",
- currentPage: "\u7B2C {pager} \u9875",
- prevPages: "\u5411\u524D {pager} \u9875",
- nextPages: "\u5411\u540E {pager} \u9875",
- deprecationWarning: "\u4F60\u4F7F\u7528\u4E86\u4E00\u4E9B\u5DF2\u88AB\u5E9F\u5F03\u7684\u7528\u6CD5\uFF0C\u8BF7\u53C2\u8003 el-pagination \u7684\u5B98\u65B9\u6587\u6863"
- },
- messagebox: {
- title: "\u63D0\u793A",
- confirm: "\u786E\u5B9A",
- cancel: "\u53D6\u6D88",
- error: "\u8F93\u5165\u7684\u6570\u636E\u4E0D\u5408\u6CD5!"
- },
- upload: {
- deleteTip: "\u6309 delete \u952E\u53EF\u5220\u9664",
- delete: "\u5220\u9664",
- preview: "\u67E5\u770B\u56FE\u7247",
- continue: "\u7EE7\u7EED\u4E0A\u4F20"
- },
- table: {
- emptyText: "\u6682\u65E0\u6570\u636E",
- confirmFilter: "\u7B5B\u9009",
- resetFilter: "\u91CD\u7F6E",
- clearFilter: "\u5168\u90E8",
- sumText: "\u5408\u8BA1"
- },
- tree: {
- emptyText: "\u6682\u65E0\u6570\u636E"
- },
- transfer: {
- noMatch: "\u65E0\u5339\u914D\u6570\u636E",
- noData: "\u65E0\u6570\u636E",
- titles: ["\u5217\u8868 1", "\u5217\u8868 2"],
- filterPlaceholder: "\u8BF7\u8F93\u5165\u641C\u7D22\u5185\u5BB9",
- noCheckedFormat: "\u5171 {total} \u9879",
- hasCheckedFormat: "\u5DF2\u9009 {checked}/{total} \u9879"
- },
- image: {
- error: "\u52A0\u8F7D\u5931\u8D25"
- },
- pageHeader: {
- title: "\u8FD4\u56DE"
- },
- popconfirm: {
- confirmButtonText: "\u786E\u5B9A",
- cancelButtonText: "\u53D6\u6D88"
- }
- }
- };
- /*! Element Plus v2.3.4 */
- var en = {
- name: "en",
- el: {
- colorpicker: {
- confirm: "OK",
- clear: "Clear",
- defaultLabel: "color picker",
- description: "current color is {color}. press enter to select a new color."
- },
- datepicker: {
- now: "Now",
- today: "Today",
- cancel: "Cancel",
- clear: "Clear",
- confirm: "OK",
- dateTablePrompt: "Use the arrow keys and enter to select the day of the month",
- monthTablePrompt: "Use the arrow keys and enter to select the month",
- yearTablePrompt: "Use the arrow keys and enter to select the year",
- selectedDate: "Selected date",
- selectDate: "Select date",
- selectTime: "Select time",
- startDate: "Start Date",
- startTime: "Start Time",
- endDate: "End Date",
- endTime: "End Time",
- prevYear: "Previous Year",
- nextYear: "Next Year",
- prevMonth: "Previous Month",
- nextMonth: "Next Month",
- year: "",
- month1: "January",
- month2: "February",
- month3: "March",
- month4: "April",
- month5: "May",
- month6: "June",
- month7: "July",
- month8: "August",
- month9: "September",
- month10: "October",
- month11: "November",
- month12: "December",
- week: "week",
- weeks: {
- sun: "Sun",
- mon: "Mon",
- tue: "Tue",
- wed: "Wed",
- thu: "Thu",
- fri: "Fri",
- sat: "Sat"
- },
- weeksFull: {
- sun: "Sunday",
- mon: "Monday",
- tue: "Tuesday",
- wed: "Wednesday",
- thu: "Thursday",
- fri: "Friday",
- sat: "Saturday"
- },
- months: {
- jan: "Jan",
- feb: "Feb",
- mar: "Mar",
- apr: "Apr",
- may: "May",
- jun: "Jun",
- jul: "Jul",
- aug: "Aug",
- sep: "Sep",
- oct: "Oct",
- nov: "Nov",
- dec: "Dec"
- }
- },
- inputNumber: {
- decrease: "decrease number",
- increase: "increase number"
- },
- select: {
- loading: "Loading",
- noMatch: "No matching data",
- noData: "No data",
- placeholder: "Select"
- },
- dropdown: {
- toggleDropdown: "Toggle Dropdown"
- },
- cascader: {
- noMatch: "No matching data",
- loading: "Loading",
- placeholder: "Select",
- noData: "No data"
- },
- pagination: {
- goto: "Go to",
- pagesize: "/page",
- total: "Total {total}",
- pageClassifier: "",
- page: "Page",
- prev: "Go to previous page",
- next: "Go to next page",
- currentPage: "page {pager}",
- prevPages: "Previous {pager} pages",
- nextPages: "Next {pager} pages",
- deprecationWarning: "Deprecated usages detected, please refer to the el-pagination documentation for more details"
- },
- dialog: {
- close: "Close this dialog"
- },
- drawer: {
- close: "Close this dialog"
- },
- messagebox: {
- title: "Message",
- confirm: "OK",
- cancel: "Cancel",
- error: "Illegal input",
- close: "Close this dialog"
- },
- upload: {
- deleteTip: "press delete to remove",
- delete: "Delete",
- preview: "Preview",
- continue: "Continue"
- },
- slider: {
- defaultLabel: "slider between {min} and {max}",
- defaultRangeStartLabel: "pick start value",
- defaultRangeEndLabel: "pick end value"
- },
- table: {
- emptyText: "No Data",
- confirmFilter: "Confirm",
- resetFilter: "Reset",
- clearFilter: "All",
- sumText: "Sum"
- },
- tree: {
- emptyText: "No Data"
- },
- transfer: {
- noMatch: "No matching data",
- noData: "No data",
- titles: ["List 1", "List 2"],
- filterPlaceholder: "Enter keyword",
- noCheckedFormat: "{total} items",
- hasCheckedFormat: "{checked}/{total} checked"
- },
- image: {
- error: "FAILED"
- },
- pageHeader: {
- title: "Back"
- },
- popconfirm: {
- confirmButtonText: "Yes",
- cancelButtonText: "No"
- }
- }
- };
- var _style_0$2 = `@charset "UTF-8";:root{--el-color-white:#ffffff;--el-color-black:#000000;--el-color-primary-rgb:64,158,255;--el-color-success-rgb:103,194,58;--el-color-warning-rgb:230,162,60;--el-color-danger-rgb:245,108,108;--el-color-error-rgb:245,108,108;--el-color-info-rgb:144,147,153;--el-font-size-extra-large:20px;--el-font-size-large:18px;--el-font-size-medium:16px;--el-font-size-base:14px;--el-font-size-small:13px;--el-font-size-extra-small:12px;--el-font-family:"Helvetica Neue",Helvetica,"PingFang SC","Hiragino Sans GB","Microsoft YaHei","\\5fae\\8f6f\\96c5\\9ed1",Arial,sans-serif;--el-font-weight-primary:500;--el-font-line-height-primary:24px;--el-index-normal:1;--el-index-top:1000;--el-index-popper:2000;--el-border-radius-base:4px;--el-border-radius-small:2px;--el-border-radius-round:20px;--el-border-radius-circle:100%;--el-transition-duration:.3s;--el-transition-duration-fast:.2s;--el-transition-function-ease-in-out-bezier:cubic-bezier(.645, .045, .355, 1);--el-transition-function-fast-bezier:cubic-bezier(.23, 1, .32, 1);--el-transition-all:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);--el-transition-fade:opacity var(--el-transition-duration) var(--el-transition-function-fast-bezier);--el-transition-md-fade:transform var(--el-transition-duration) var(--el-transition-function-fast-bezier),opacity var(--el-transition-duration) var(--el-transition-function-fast-bezier);--el-transition-fade-linear:opacity var(--el-transition-duration-fast) linear;--el-transition-border:border-color var(--el-transition-duration-fast) var(--el-transition-function-ease-in-out-bezier);--el-transition-box-shadow:box-shadow var(--el-transition-duration-fast) var(--el-transition-function-ease-in-out-bezier);--el-transition-color:color var(--el-transition-duration-fast) var(--el-transition-function-ease-in-out-bezier);--el-component-size-large:40px;--el-component-size:32px;--el-component-size-small:24px}:root{color-scheme:light;--el-color-white:#ffffff;--el-color-black:#000000;--el-color-primary:#409eff;--el-color-primary-light-3:#79bbff;--el-color-primary-light-5:#a0cfff;--el-color-primary-light-7:#c6e2ff;--el-color-primary-light-8:#d9ecff;--el-color-primary-light-9:#ecf5ff;--el-color-primary-dark-2:#337ecc;--el-color-success:#67c23a;--el-color-success-light-3:#95d475;--el-color-success-light-5:#b3e19d;--el-color-success-light-7:#d1edc4;--el-color-success-light-8:#e1f3d8;--el-color-success-light-9:#f0f9eb;--el-color-success-dark-2:#529b2e;--el-color-warning:#e6a23c;--el-color-warning-light-3:#eebe77;--el-color-warning-light-5:#f3d19e;--el-color-warning-light-7:#f8e3c5;--el-color-warning-light-8:#faecd8;--el-color-warning-light-9:#fdf6ec;--el-color-warning-dark-2:#b88230;--el-color-danger:#f56c6c;--el-color-danger-light-3:#f89898;--el-color-danger-light-5:#fab6b6;--el-color-danger-light-7:#fcd3d3;--el-color-danger-light-8:#fde2e2;--el-color-danger-light-9:#fef0f0;--el-color-danger-dark-2:#c45656;--el-color-error:#f56c6c;--el-color-error-light-3:#f89898;--el-color-error-light-5:#fab6b6;--el-color-error-light-7:#fcd3d3;--el-color-error-light-8:#fde2e2;--el-color-error-light-9:#fef0f0;--el-color-error-dark-2:#c45656;--el-color-info:#909399;--el-color-info-light-3:#b1b3b8;--el-color-info-light-5:#c8c9cc;--el-color-info-light-7:#dedfe0;--el-color-info-light-8:#e9e9eb;--el-color-info-light-9:#f4f4f5;--el-color-info-dark-2:#73767a;--el-bg-color:#ffffff;--el-bg-color-page:#f2f3f5;--el-bg-color-overlay:#ffffff;--el-text-color-primary:#303133;--el-text-color-regular:#606266;--el-text-color-secondary:#909399;--el-text-color-placeholder:#a8abb2;--el-text-color-disabled:#c0c4cc;--el-border-color:#dcdfe6;--el-border-color-light:#e4e7ed;--el-border-color-lighter:#ebeef5;--el-border-color-extra-light:#f2f6fc;--el-border-color-dark:#d4d7de;--el-border-color-darker:#cdd0d6;--el-fill-color:#f0f2f5;--el-fill-color-light:#f5f7fa;--el-fill-color-lighter:#fafafa;--el-fill-color-extra-light:#fafcff;--el-fill-color-dark:#ebedf0;--el-fill-color-darker:#e6e8eb;--el-fill-color-blank:#ffffff;--el-box-shadow:0px 12px 32px 4px rgba(0, 0, 0, .04),0px 8px 20px rgba(0, 0, 0, .08);--el-box-shadow-light:0px 0px 12px rgba(0, 0, 0, .12);--el-box-shadow-lighter:0px 0px 6px rgba(0, 0, 0, .12);--el-box-shadow-dark:0px 16px 48px 16px rgba(0, 0, 0, .08),0px 12px 32px rgba(0, 0, 0, .12),0px 8px 16px -8px rgba(0, 0, 0, .16);--el-disabled-bg-color:var(--el-fill-color-light);--el-disabled-text-color:var(--el-text-color-placeholder);--el-disabled-border-color:var(--el-border-color-light);--el-overlay-color:rgba(0, 0, 0, .8);--el-overlay-color-light:rgba(0, 0, 0, .7);--el-overlay-color-lighter:rgba(0, 0, 0, .5);--el-mask-color:rgba(255, 255, 255, .9);--el-mask-color-extra-light:rgba(255, 255, 255, .3);--el-border-width:1px;--el-border-style:solid;--el-border-color-hover:var(--el-text-color-disabled);--el-border:var(--el-border-width) var(--el-border-style) var(--el-border-color);--el-svg-monochrome-grey:var(--el-border-color)}.fade-in-linear-enter-active,.fade-in-linear-leave-active{transition:var(--el-transition-fade-linear)}.fade-in-linear-enter-from,.fade-in-linear-leave-to{opacity:0}.el-fade-in-linear-enter-active,.el-fade-in-linear-leave-active{transition:var(--el-transition-fade-linear)}.el-fade-in-linear-enter-from,.el-fade-in-linear-leave-to{opacity:0}.el-fade-in-enter-active,.el-fade-in-leave-active{transition:all var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}.el-fade-in-enter-from,.el-fade-in-leave-active{opacity:0}.el-zoom-in-center-enter-active,.el-zoom-in-center-leave-active{transition:all var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}.el-zoom-in-center-enter-from,.el-zoom-in-center-leave-active{opacity:0;transform:scaleX(0)}.el-zoom-in-top-enter-active,.el-zoom-in-top-leave-active{opacity:1;transform:scaleY(1);transition:var(--el-transition-md-fade);transform-origin:center top}.el-zoom-in-top-enter-active[data-popper-placement^=top],.el-zoom-in-top-leave-active[data-popper-placement^=top]{transform-origin:center bottom}.el-zoom-in-top-enter-from,.el-zoom-in-top-leave-active{opacity:0;transform:scaleY(0)}.el-zoom-in-bottom-enter-active,.el-zoom-in-bottom-leave-active{opacity:1;transform:scaleY(1);transition:var(--el-transition-md-fade);transform-origin:center bottom}.el-zoom-in-bottom-enter-from,.el-zoom-in-bottom-leave-active{opacity:0;transform:scaleY(0)}.el-zoom-in-left-enter-active,.el-zoom-in-left-leave-active{opacity:1;transform:scale(1);transition:var(--el-transition-md-fade);transform-origin:top left}.el-zoom-in-left-enter-from,.el-zoom-in-left-leave-active{opacity:0;transform:scale(.45)}.collapse-transition{transition:var(--el-transition-duration) height ease-in-out,var(--el-transition-duration) padding-top ease-in-out,var(--el-transition-duration) padding-bottom ease-in-out}.el-collapse-transition-enter-active,.el-collapse-transition-leave-active{transition:var(--el-transition-duration) max-height ease-in-out,var(--el-transition-duration) padding-top ease-in-out,var(--el-transition-duration) padding-bottom ease-in-out}.horizontal-collapse-transition{transition:var(--el-transition-duration) width ease-in-out,var(--el-transition-duration) padding-left ease-in-out,var(--el-transition-duration) padding-right ease-in-out}.el-list-enter-active,.el-list-leave-active{transition:all 1s}.el-list-enter-from,.el-list-leave-to{opacity:0;transform:translateY(-30px)}.el-list-leave-active{position:absolute!important}.el-opacity-transition{transition:opacity var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}.el-icon-loading{-webkit-animation:rotating 2s linear infinite;animation:rotating 2s linear infinite}.el-icon--right{margin-left:5px}.el-icon--left{margin-right:5px}@-webkit-keyframes rotating{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes rotating{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.el-icon{--color:inherit;height:1em;width:1em;line-height:1em;display:inline-flex;justify-content:center;align-items:center;position:relative;fill:currentColor;color:var(--color);font-size:inherit}.el-icon.is-loading{-webkit-animation:rotating 2s linear infinite;animation:rotating 2s linear infinite}.el-icon svg{height:1em;width:1em}.el-affix--fixed{position:fixed}.el-alert{--el-alert-padding:8px 16px;--el-alert-border-radius-base:var(--el-border-radius-base);--el-alert-title-font-size:13px;--el-alert-description-font-size:12px;--el-alert-close-font-size:12px;--el-alert-close-customed-font-size:13px;--el-alert-icon-size:16px;--el-alert-icon-large-size:28px;width:100%;padding:var(--el-alert-padding);margin:0;box-sizing:border-box;border-radius:var(--el-alert-border-radius-base);position:relative;background-color:var(--el-color-white);overflow:hidden;opacity:1;display:flex;align-items:center;transition:opacity var(--el-transition-duration-fast)}.el-alert.is-light .el-alert__close-btn{color:var(--el-text-color-placeholder)}.el-alert.is-dark .el-alert__close-btn,.el-alert.is-dark .el-alert__description{color:var(--el-color-white)}.el-alert.is-center{justify-content:center}.el-alert--success{--el-alert-bg-color:var(--el-color-success-light-9)}.el-alert--success.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-success)}.el-alert--success.is-light .el-alert__description{color:var(--el-color-success)}.el-alert--success.is-dark{background-color:var(--el-color-success);color:var(--el-color-white)}.el-alert--info{--el-alert-bg-color:var(--el-color-info-light-9)}.el-alert--info.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-info)}.el-alert--info.is-light .el-alert__description{color:var(--el-color-info)}.el-alert--info.is-dark{background-color:var(--el-color-info);color:var(--el-color-white)}.el-alert--warning{--el-alert-bg-color:var(--el-color-warning-light-9)}.el-alert--warning.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-warning)}.el-alert--warning.is-light .el-alert__description{color:var(--el-color-warning)}.el-alert--warning.is-dark{background-color:var(--el-color-warning);color:var(--el-color-white)}.el-alert--error{--el-alert-bg-color:var(--el-color-error-light-9)}.el-alert--error.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-error)}.el-alert--error.is-light .el-alert__description{color:var(--el-color-error)}.el-alert--error.is-dark{background-color:var(--el-color-error);color:var(--el-color-white)}.el-alert__content{display:table-cell;padding:0 8px}.el-alert .el-alert__icon{font-size:var(--el-alert-icon-size);width:var(--el-alert-icon-size)}.el-alert .el-alert__icon.is-big{font-size:var(--el-alert-icon-large-size);width:var(--el-alert-icon-large-size)}.el-alert__title{font-size:var(--el-alert-title-font-size);line-height:18px;vertical-align:text-top}.el-alert__title.is-bold{font-weight:700}.el-alert .el-alert__description{font-size:var(--el-alert-description-font-size);margin:5px 0 0}.el-alert .el-alert__close-btn{font-size:var(--el-alert-close-font-size);opacity:1;position:absolute;top:12px;right:15px;cursor:pointer}.el-alert .el-alert__close-btn.is-customed{font-style:normal;font-size:var(--el-alert-close-customed-font-size);top:9px}.el-alert-fade-enter-from,.el-alert-fade-leave-active{opacity:0}.el-aside{overflow:auto;box-sizing:border-box;flex-shrink:0;width:var(--el-aside-width,300px)}.el-autocomplete{position:relative;display:inline-block}.el-autocomplete__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-box-shadow-light)}.el-autocomplete__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-autocomplete__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-autocomplete__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-autocomplete__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-autocomplete__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-autocomplete-suggestion{border-radius:var(--el-border-radius-base);box-sizing:border-box}.el-autocomplete-suggestion__wrap{max-height:280px;padding:10px 0;box-sizing:border-box}.el-autocomplete-suggestion__list{margin:0;padding:0}.el-autocomplete-suggestion li{padding:0 20px;margin:0;line-height:34px;cursor:pointer;color:var(--el-text-color-regular);font-size:var(--el-font-size-base);list-style:none;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.el-autocomplete-suggestion li:hover,.el-autocomplete-suggestion li.highlighted{background-color:var(--el-fill-color-light)}.el-autocomplete-suggestion li.divider{margin-top:6px;border-top:1px solid var(--el-color-black)}.el-autocomplete-suggestion li.divider:last-child{margin-bottom:-6px}.el-autocomplete-suggestion.is-loading li{text-align:center;height:100px;line-height:100px;font-size:20px;color:var(--el-text-color-secondary)}.el-autocomplete-suggestion.is-loading li:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-autocomplete-suggestion.is-loading li:hover{background-color:var(--el-bg-color-overlay)}.el-autocomplete-suggestion.is-loading .el-icon-loading{vertical-align:middle}.el-avatar{--el-avatar-text-color:var(--el-color-white);--el-avatar-bg-color:var(--el-text-color-disabled);--el-avatar-text-size:14px;--el-avatar-icon-size:18px;--el-avatar-border-radius:var(--el-border-radius-base);--el-avatar-size-large:56px;--el-avatar-size-small:24px;--el-avatar-size:40px;display:inline-flex;justify-content:center;align-items:center;box-sizing:border-box;text-align:center;overflow:hidden;color:var(--el-avatar-text-color);background:var(--el-avatar-bg-color);width:var(--el-avatar-size);height:var(--el-avatar-size);font-size:var(--el-avatar-text-size)}.el-avatar>img{display:block;height:100%}.el-avatar--circle{border-radius:50%}.el-avatar--square{border-radius:var(--el-avatar-border-radius)}.el-avatar--icon{font-size:var(--el-avatar-icon-size)}.el-avatar--small{--el-avatar-size:24px}.el-avatar--large{--el-avatar-size:56px}.el-backtop{--el-backtop-bg-color:var(--el-bg-color-overlay);--el-backtop-text-color:var(--el-color-primary);--el-backtop-hover-bg-color:var(--el-border-color-extra-light);position:fixed;background-color:var(--el-backtop-bg-color);width:40px;height:40px;border-radius:50%;color:var(--el-backtop-text-color);display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:var(--el-box-shadow-lighter);cursor:pointer;z-index:5}.el-backtop:hover{background-color:var(--el-backtop-hover-bg-color)}.el-backtop__icon{font-size:20px}.el-badge{--el-badge-bg-color:var(--el-color-danger);--el-badge-radius:10px;--el-badge-font-size:12px;--el-badge-padding:6px;--el-badge-size:18px;position:relative;vertical-align:middle;display:inline-block;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.el-badge__content{background-color:var(--el-badge-bg-color);border-radius:var(--el-badge-radius);color:var(--el-color-white);display:inline-flex;justify-content:center;align-items:center;font-size:var(--el-badge-font-size);height:var(--el-badge-size);padding:0 var(--el-badge-padding);white-space:nowrap;border:1px solid var(--el-bg-color)}.el-badge__content.is-fixed{position:absolute;top:0;right:calc(1px + var(--el-badge-size)/ 2);transform:translateY(-50%) translate(100%);z-index:var(--el-index-normal)}.el-badge__content.is-fixed.is-dot{right:5px}.el-badge__content.is-dot{height:8px;width:8px;padding:0;right:0;border-radius:50%}.el-badge__content--primary{background-color:var(--el-color-primary)}.el-badge__content--success{background-color:var(--el-color-success)}.el-badge__content--warning{background-color:var(--el-color-warning)}.el-badge__content--info{background-color:var(--el-color-info)}.el-badge__content--danger{background-color:var(--el-color-danger)}.el-breadcrumb{font-size:14px;line-height:1}.el-breadcrumb:after,.el-breadcrumb:before{display:table;content:""}.el-breadcrumb:after{clear:both}.el-breadcrumb__separator{margin:0 9px;font-weight:700;color:var(--el-text-color-placeholder)}.el-breadcrumb__separator.el-icon{margin:0 6px;font-weight:400}.el-breadcrumb__separator.el-icon svg{vertical-align:middle}.el-breadcrumb__item{float:left;display:inline-flex;align-items:center}.el-breadcrumb__inner{color:var(--el-text-color-regular)}.el-breadcrumb__inner a,.el-breadcrumb__inner.is-link{font-weight:700;text-decoration:none;transition:var(--el-transition-color);color:var(--el-text-color-primary)}.el-breadcrumb__inner a:hover,.el-breadcrumb__inner.is-link:hover{color:var(--el-color-primary);cursor:pointer}.el-breadcrumb__item:last-child .el-breadcrumb__inner,.el-breadcrumb__item:last-child .el-breadcrumb__inner a,.el-breadcrumb__item:last-child .el-breadcrumb__inner a:hover,.el-breadcrumb__item:last-child .el-breadcrumb__inner:hover{font-weight:400;color:var(--el-text-color-regular);cursor:text}.el-breadcrumb__item:last-child .el-breadcrumb__separator{display:none}.el-button-group{display:inline-block;vertical-align:middle}.el-button-group:after,.el-button-group:before{display:table;content:""}.el-button-group:after{clear:both}.el-button-group>.el-button{float:left;position:relative}.el-button-group>.el-button+.el-button{margin-left:0}.el-button-group>.el-button:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.el-button-group>.el-button:last-child{border-top-left-radius:0;border-bottom-left-radius:0}.el-button-group>.el-button:first-child:last-child{border-top-right-radius:var(--el-border-radius-base);border-bottom-right-radius:var(--el-border-radius-base);border-top-left-radius:var(--el-border-radius-base);border-bottom-left-radius:var(--el-border-radius-base)}.el-button-group>.el-button:first-child:last-child.is-round{border-radius:var(--el-border-radius-round)}.el-button-group>.el-button:first-child:last-child.is-circle{border-radius:50%}.el-button-group>.el-button:not(:first-child):not(:last-child){border-radius:0}.el-button-group>.el-button:not(:last-child){margin-right:-1px}.el-button-group>.el-button:active,.el-button-group>.el-button:focus,.el-button-group>.el-button:hover{z-index:1}.el-button-group>.el-button.is-active{z-index:1}.el-button-group>.el-dropdown>.el-button{border-top-left-radius:0;border-bottom-left-radius:0;border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--primary:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--primary:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--primary:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--success:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--success:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--success:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--warning:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--warning:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--warning:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--danger:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--danger:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--danger:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--info:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--info:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--info:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button{--el-button-font-weight:var(--el-font-weight-primary);--el-button-border-color:var(--el-border-color);--el-button-bg-color:var(--el-fill-color-blank);--el-button-text-color:var(--el-text-color-regular);--el-button-disabled-text-color:var(--el-disabled-text-color);--el-button-disabled-bg-color:var(--el-fill-color-blank);--el-button-disabled-border-color:var(--el-border-color-light);--el-button-divide-border-color:rgba(255, 255, 255, .5);--el-button-hover-text-color:var(--el-color-primary);--el-button-hover-bg-color:var(--el-color-primary-light-9);--el-button-hover-border-color:var(--el-color-primary-light-7);--el-button-active-text-color:var(--el-button-hover-text-color);--el-button-active-border-color:var(--el-color-primary);--el-button-active-bg-color:var(--el-button-hover-bg-color);--el-button-outline-color:var(--el-color-primary-light-5);--el-button-hover-link-text-color:var(--el-color-info);--el-button-active-color:var(--el-text-color-primary)}.el-button{display:inline-flex;justify-content:center;align-items:center;line-height:1;height:32px;white-space:nowrap;cursor:pointer;color:var(--el-button-text-color);text-align:center;box-sizing:border-box;outline:0;transition:.1s;font-weight:var(--el-button-font-weight);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;vertical-align:middle;-webkit-appearance:none;background-color:var(--el-button-bg-color);border:var(--el-border);border-color:var(--el-button-border-color);padding:8px 15px;font-size:var(--el-font-size-base);border-radius:var(--el-border-radius-base)}.el-button:focus,.el-button:hover{color:var(--el-button-hover-text-color);border-color:var(--el-button-hover-border-color);background-color:var(--el-button-hover-bg-color);outline:0}.el-button:active{color:var(--el-button-active-text-color);border-color:var(--el-button-active-border-color);background-color:var(--el-button-active-bg-color);outline:0}.el-button:focus-visible{outline:2px solid var(--el-button-outline-color);outline-offset:1px}.el-button>span{display:inline-flex;align-items:center}.el-button+.el-button{margin-left:12px}.el-button.is-round{padding:8px 15px}.el-button::-moz-focus-inner{border:0}.el-button [class*=el-icon]+span{margin-left:6px}.el-button [class*=el-icon] svg{vertical-align:bottom}.el-button.is-plain{--el-button-hover-text-color:var(--el-color-primary);--el-button-hover-bg-color:var(--el-fill-color-blank);--el-button-hover-border-color:var(--el-color-primary)}.el-button.is-active{color:var(--el-button-active-text-color);border-color:var(--el-button-active-border-color);background-color:var(--el-button-active-bg-color);outline:0}.el-button.is-disabled,.el-button.is-disabled:focus,.el-button.is-disabled:hover{color:var(--el-button-disabled-text-color);cursor:not-allowed;background-image:none;background-color:var(--el-button-disabled-bg-color);border-color:var(--el-button-disabled-border-color)}.el-button.is-loading{position:relative;pointer-events:none}.el-button.is-loading:before{z-index:1;pointer-events:none;content:"";position:absolute;left:-1px;top:-1px;right:-1px;bottom:-1px;border-radius:inherit;background-color:var(--el-mask-color-extra-light)}.el-button.is-round{border-radius:var(--el-border-radius-round)}.el-button.is-circle{border-radius:50%;padding:8px}.el-button.is-text{color:var(--el-button-text-color);border:0 solid transparent;background-color:transparent}.el-button.is-text.is-disabled{color:var(--el-button-disabled-text-color);background-color:transparent!important}.el-button.is-text:not(.is-disabled):focus,.el-button.is-text:not(.is-disabled):hover{background-color:var(--el-fill-color-light)}.el-button.is-text:not(.is-disabled):focus-visible{outline:2px solid var(--el-button-outline-color);outline-offset:1px}.el-button.is-text:not(.is-disabled):active{background-color:var(--el-fill-color)}.el-button.is-text:not(.is-disabled).is-has-bg{background-color:var(--el-fill-color-light)}.el-button.is-text:not(.is-disabled).is-has-bg:focus,.el-button.is-text:not(.is-disabled).is-has-bg:hover{background-color:var(--el-fill-color)}.el-button.is-text:not(.is-disabled).is-has-bg:active{background-color:var(--el-fill-color-dark)}.el-button__text--expand{letter-spacing:.3em;margin-right:-.3em}.el-button.is-link{border-color:transparent;color:var(--el-button-text-color);background:0 0;padding:2px;height:auto}.el-button.is-link:focus,.el-button.is-link:hover{color:var(--el-button-hover-link-text-color)}.el-button.is-link.is-disabled{color:var(--el-button-disabled-text-color);background-color:transparent!important;border-color:transparent!important}.el-button.is-link:not(.is-disabled):focus,.el-button.is-link:not(.is-disabled):hover{border-color:transparent;background-color:transparent}.el-button.is-link:not(.is-disabled):active{color:var(--el-button-active-color);border-color:transparent;background-color:transparent}.el-button--text{border-color:transparent;background:0 0;color:var(--el-color-primary);padding-left:0;padding-right:0}.el-button--text.is-disabled{color:var(--el-button-disabled-text-color);background-color:transparent!important;border-color:transparent!important}.el-button--text:not(.is-disabled):focus,.el-button--text:not(.is-disabled):hover{color:var(--el-color-primary-light-3);border-color:transparent;background-color:transparent}.el-button--text:not(.is-disabled):active{color:var(--el-color-primary-dark-2);border-color:transparent;background-color:transparent}.el-button__link--expand{letter-spacing:.3em;margin-right:-.3em}.el-button--primary{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-primary);--el-button-border-color:var(--el-color-primary);--el-button-outline-color:var(--el-color-primary-light-5);--el-button-active-color:var(--el-color-primary-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-primary-light-5);--el-button-hover-bg-color:var(--el-color-primary-light-3);--el-button-hover-border-color:var(--el-color-primary-light-3);--el-button-active-bg-color:var(--el-color-primary-dark-2);--el-button-active-border-color:var(--el-color-primary-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-primary-light-5);--el-button-disabled-border-color:var(--el-color-primary-light-5)}.el-button--primary.is-link,.el-button--primary.is-plain,.el-button--primary.is-text{--el-button-text-color:var(--el-color-primary);--el-button-bg-color:var(--el-color-primary-light-9);--el-button-border-color:var(--el-color-primary-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-primary);--el-button-hover-border-color:var(--el-color-primary);--el-button-active-text-color:var(--el-color-white)}.el-button--primary.is-link.is-disabled,.el-button--primary.is-link.is-disabled:active,.el-button--primary.is-link.is-disabled:focus,.el-button--primary.is-link.is-disabled:hover,.el-button--primary.is-plain.is-disabled,.el-button--primary.is-plain.is-disabled:active,.el-button--primary.is-plain.is-disabled:focus,.el-button--primary.is-plain.is-disabled:hover,.el-button--primary.is-text.is-disabled,.el-button--primary.is-text.is-disabled:active,.el-button--primary.is-text.is-disabled:focus,.el-button--primary.is-text.is-disabled:hover{color:var(--el-color-primary-light-5);background-color:var(--el-color-primary-light-9);border-color:var(--el-color-primary-light-8)}.el-button--success{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-success);--el-button-border-color:var(--el-color-success);--el-button-outline-color:var(--el-color-success-light-5);--el-button-active-color:var(--el-color-success-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-success-light-5);--el-button-hover-bg-color:var(--el-color-success-light-3);--el-button-hover-border-color:var(--el-color-success-light-3);--el-button-active-bg-color:var(--el-color-success-dark-2);--el-button-active-border-color:var(--el-color-success-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-success-light-5);--el-button-disabled-border-color:var(--el-color-success-light-5)}.el-button--success.is-link,.el-button--success.is-plain,.el-button--success.is-text{--el-button-text-color:var(--el-color-success);--el-button-bg-color:var(--el-color-success-light-9);--el-button-border-color:var(--el-color-success-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-success);--el-button-hover-border-color:var(--el-color-success);--el-button-active-text-color:var(--el-color-white)}.el-button--success.is-link.is-disabled,.el-button--success.is-link.is-disabled:active,.el-button--success.is-link.is-disabled:focus,.el-button--success.is-link.is-disabled:hover,.el-button--success.is-plain.is-disabled,.el-button--success.is-plain.is-disabled:active,.el-button--success.is-plain.is-disabled:focus,.el-button--success.is-plain.is-disabled:hover,.el-button--success.is-text.is-disabled,.el-button--success.is-text.is-disabled:active,.el-button--success.is-text.is-disabled:focus,.el-button--success.is-text.is-disabled:hover{color:var(--el-color-success-light-5);background-color:var(--el-color-success-light-9);border-color:var(--el-color-success-light-8)}.el-button--warning{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-warning);--el-button-border-color:var(--el-color-warning);--el-button-outline-color:var(--el-color-warning-light-5);--el-button-active-color:var(--el-color-warning-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-warning-light-5);--el-button-hover-bg-color:var(--el-color-warning-light-3);--el-button-hover-border-color:var(--el-color-warning-light-3);--el-button-active-bg-color:var(--el-color-warning-dark-2);--el-button-active-border-color:var(--el-color-warning-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-warning-light-5);--el-button-disabled-border-color:var(--el-color-warning-light-5)}.el-button--warning.is-link,.el-button--warning.is-plain,.el-button--warning.is-text{--el-button-text-color:var(--el-color-warning);--el-button-bg-color:var(--el-color-warning-light-9);--el-button-border-color:var(--el-color-warning-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-warning);--el-button-hover-border-color:var(--el-color-warning);--el-button-active-text-color:var(--el-color-white)}.el-button--warning.is-link.is-disabled,.el-button--warning.is-link.is-disabled:active,.el-button--warning.is-link.is-disabled:focus,.el-button--warning.is-link.is-disabled:hover,.el-button--warning.is-plain.is-disabled,.el-button--warning.is-plain.is-disabled:active,.el-button--warning.is-plain.is-disabled:focus,.el-button--warning.is-plain.is-disabled:hover,.el-button--warning.is-text.is-disabled,.el-button--warning.is-text.is-disabled:active,.el-button--warning.is-text.is-disabled:focus,.el-button--warning.is-text.is-disabled:hover{color:var(--el-color-warning-light-5);background-color:var(--el-color-warning-light-9);border-color:var(--el-color-warning-light-8)}.el-button--danger{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-danger);--el-button-border-color:var(--el-color-danger);--el-button-outline-color:var(--el-color-danger-light-5);--el-button-active-color:var(--el-color-danger-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-danger-light-5);--el-button-hover-bg-color:var(--el-color-danger-light-3);--el-button-hover-border-color:var(--el-color-danger-light-3);--el-button-active-bg-color:var(--el-color-danger-dark-2);--el-button-active-border-color:var(--el-color-danger-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-danger-light-5);--el-button-disabled-border-color:var(--el-color-danger-light-5)}.el-button--danger.is-link,.el-button--danger.is-plain,.el-button--danger.is-text{--el-button-text-color:var(--el-color-danger);--el-button-bg-color:var(--el-color-danger-light-9);--el-button-border-color:var(--el-color-danger-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-danger);--el-button-hover-border-color:var(--el-color-danger);--el-button-active-text-color:var(--el-color-white)}.el-button--danger.is-link.is-disabled,.el-button--danger.is-link.is-disabled:active,.el-button--danger.is-link.is-disabled:focus,.el-button--danger.is-link.is-disabled:hover,.el-button--danger.is-plain.is-disabled,.el-button--danger.is-plain.is-disabled:active,.el-button--danger.is-plain.is-disabled:focus,.el-button--danger.is-plain.is-disabled:hover,.el-button--danger.is-text.is-disabled,.el-button--danger.is-text.is-disabled:active,.el-button--danger.is-text.is-disabled:focus,.el-button--danger.is-text.is-disabled:hover{color:var(--el-color-danger-light-5);background-color:var(--el-color-danger-light-9);border-color:var(--el-color-danger-light-8)}.el-button--info{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-info);--el-button-border-color:var(--el-color-info);--el-button-outline-color:var(--el-color-info-light-5);--el-button-active-color:var(--el-color-info-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-info-light-5);--el-button-hover-bg-color:var(--el-color-info-light-3);--el-button-hover-border-color:var(--el-color-info-light-3);--el-button-active-bg-color:var(--el-color-info-dark-2);--el-button-active-border-color:var(--el-color-info-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-info-light-5);--el-button-disabled-border-color:var(--el-color-info-light-5)}.el-button--info.is-link,.el-button--info.is-plain,.el-button--info.is-text{--el-button-text-color:var(--el-color-info);--el-button-bg-color:var(--el-color-info-light-9);--el-button-border-color:var(--el-color-info-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-info);--el-button-hover-border-color:var(--el-color-info);--el-button-active-text-color:var(--el-color-white)}.el-button--info.is-link.is-disabled,.el-button--info.is-link.is-disabled:active,.el-button--info.is-link.is-disabled:focus,.el-button--info.is-link.is-disabled:hover,.el-button--info.is-plain.is-disabled,.el-button--info.is-plain.is-disabled:active,.el-button--info.is-plain.is-disabled:focus,.el-button--info.is-plain.is-disabled:hover,.el-button--info.is-text.is-disabled,.el-button--info.is-text.is-disabled:active,.el-button--info.is-text.is-disabled:focus,.el-button--info.is-text.is-disabled:hover{color:var(--el-color-info-light-5);background-color:var(--el-color-info-light-9);border-color:var(--el-color-info-light-8)}.el-button--large{--el-button-size:40px;height:var(--el-button-size);padding:12px 19px;font-size:var(--el-font-size-base);border-radius:var(--el-border-radius-base)}.el-button--large [class*=el-icon]+span{margin-left:8px}.el-button--large.is-round{padding:12px 19px}.el-button--large.is-circle{width:var(--el-button-size);padding:12px}.el-button--small{--el-button-size:24px;height:var(--el-button-size);padding:5px 11px;font-size:12px;border-radius:calc(var(--el-border-radius-base) - 1px)}.el-button--small [class*=el-icon]+span{margin-left:4px}.el-button--small.is-round{padding:5px 11px}.el-button--small.is-circle{width:var(--el-button-size);padding:5px}.el-calendar{--el-calendar-border:var(--el-table-border, 1px solid var(--el-border-color-lighter));--el-calendar-header-border-bottom:var(--el-calendar-border);--el-calendar-selected-bg-color:var(--el-color-primary-light-9);--el-calendar-cell-width:85px;background-color:var(--el-fill-color-blank)}.el-calendar__header{display:flex;justify-content:space-between;padding:12px 20px;border-bottom:var(--el-calendar-header-border-bottom)}.el-calendar__title{color:var(--el-text-color);align-self:center}.el-calendar__body{padding:12px 20px 35px}.el-calendar-table{table-layout:fixed;width:100%}.el-calendar-table thead th{padding:12px 0;color:var(--el-text-color-regular);font-weight:400}.el-calendar-table:not(.is-range) td.next,.el-calendar-table:not(.is-range) td.prev{color:var(--el-text-color-placeholder)}.el-calendar-table td{border-bottom:var(--el-calendar-border);border-right:var(--el-calendar-border);vertical-align:top;transition:background-color var(--el-transition-duration-fast) ease}.el-calendar-table td.is-selected{background-color:var(--el-calendar-selected-bg-color)}.el-calendar-table td.is-today{color:var(--el-color-primary)}.el-calendar-table tr:first-child td{border-top:var(--el-calendar-border)}.el-calendar-table tr td:first-child{border-left:var(--el-calendar-border)}.el-calendar-table tr.el-calendar-table__row--hide-border td{border-top:none}.el-calendar-table .el-calendar-day{box-sizing:border-box;padding:8px;height:var(--el-calendar-cell-width)}.el-calendar-table .el-calendar-day:hover{cursor:pointer;background-color:var(--el-calendar-selected-bg-color)}.el-card{--el-card-border-color:var(--el-border-color-light);--el-card-border-radius:4px;--el-card-padding:20px;--el-card-bg-color:var(--el-fill-color-blank)}.el-card{border-radius:var(--el-card-border-radius);border:1px solid var(--el-card-border-color);background-color:var(--el-card-bg-color);overflow:hidden;color:var(--el-text-color-primary);transition:var(--el-transition-duration)}.el-card.is-always-shadow{box-shadow:var(--el-box-shadow-light)}.el-card.is-hover-shadow:focus,.el-card.is-hover-shadow:hover{box-shadow:var(--el-box-shadow-light)}.el-card__header{padding:calc(var(--el-card-padding) - 2px) var(--el-card-padding);border-bottom:1px solid var(--el-card-border-color);box-sizing:border-box}.el-card__body{padding:var(--el-card-padding)}.el-carousel__item{position:absolute;top:0;left:0;width:100%;height:100%;display:inline-block;overflow:hidden;z-index:calc(var(--el-index-normal) - 1)}.el-carousel__item.is-active{z-index:calc(var(--el-index-normal) - 1)}.el-carousel__item.is-animating{transition:transform .4s ease-in-out}.el-carousel__item--card{width:50%;transition:transform .4s ease-in-out}.el-carousel__item--card.is-in-stage{cursor:pointer;z-index:var(--el-index-normal)}.el-carousel__item--card.is-in-stage.is-hover .el-carousel__mask,.el-carousel__item--card.is-in-stage:hover .el-carousel__mask{opacity:.12}.el-carousel__item--card.is-active{z-index:calc(var(--el-index-normal) + 1)}.el-carousel__mask{position:absolute;width:100%;height:100%;top:0;left:0;background-color:var(--el-color-white);opacity:.24;transition:var(--el-transition-duration-fast)}.el-carousel{--el-carousel-arrow-font-size:12px;--el-carousel-arrow-size:36px;--el-carousel-arrow-background:rgba(31, 45, 61, .11);--el-carousel-arrow-hover-background:rgba(31, 45, 61, .23);--el-carousel-indicator-width:30px;--el-carousel-indicator-height:2px;--el-carousel-indicator-padding-horizontal:4px;--el-carousel-indicator-padding-vertical:12px;--el-carousel-indicator-out-color:var(--el-border-color-hover);position:relative}.el-carousel--horizontal{overflow-x:hidden}.el-carousel--vertical{overflow-y:hidden}.el-carousel__container{position:relative;height:300px}.el-carousel__arrow{border:none;outline:0;padding:0;margin:0;height:var(--el-carousel-arrow-size);width:var(--el-carousel-arrow-size);cursor:pointer;transition:var(--el-transition-duration);border-radius:50%;background-color:var(--el-carousel-arrow-background);color:#fff;position:absolute;top:50%;z-index:10;transform:translateY(-50%);text-align:center;font-size:var(--el-carousel-arrow-font-size);display:inline-flex;justify-content:center;align-items:center}.el-carousel__arrow--left{left:16px}.el-carousel__arrow--right{right:16px}.el-carousel__arrow:hover{background-color:var(--el-carousel-arrow-hover-background)}.el-carousel__arrow i{cursor:pointer}.el-carousel__indicators{position:absolute;list-style:none;margin:0;padding:0;z-index:calc(var(--el-index-normal) + 1)}.el-carousel__indicators--horizontal{bottom:0;left:50%;transform:translate(-50%)}.el-carousel__indicators--vertical{right:0;top:50%;transform:translateY(-50%)}.el-carousel__indicators--outside{bottom:calc(var(--el-carousel-indicator-height) + var(--el-carousel-indicator-padding-vertical) * 2);text-align:center;position:static;transform:none}.el-carousel__indicators--outside .el-carousel__indicator:hover button{opacity:.64}.el-carousel__indicators--outside button{background-color:var(--el-carousel-indicator-out-color);opacity:.24}.el-carousel__indicators--labels{left:0;right:0;transform:none;text-align:center}.el-carousel__indicators--labels .el-carousel__button{height:auto;width:auto;padding:2px 18px;font-size:12px;color:#000}.el-carousel__indicators--labels .el-carousel__indicator{padding:6px 4px}.el-carousel__indicator{background-color:transparent;cursor:pointer}.el-carousel__indicator:hover button{opacity:.72}.el-carousel__indicator--horizontal{display:inline-block;padding:var(--el-carousel-indicator-padding-vertical) var(--el-carousel-indicator-padding-horizontal)}.el-carousel__indicator--vertical{padding:var(--el-carousel-indicator-padding-horizontal) var(--el-carousel-indicator-padding-vertical)}.el-carousel__indicator--vertical .el-carousel__button{width:var(--el-carousel-indicator-height);height:calc(var(--el-carousel-indicator-width)/ 2)}.el-carousel__indicator.is-active button{opacity:1}.el-carousel__button{display:block;opacity:.48;width:var(--el-carousel-indicator-width);height:var(--el-carousel-indicator-height);background-color:#fff;border:none;outline:0;padding:0;margin:0;cursor:pointer;transition:var(--el-transition-duration)}.carousel-arrow-left-enter-from,.carousel-arrow-left-leave-active{transform:translateY(-50%) translate(-10px);opacity:0}.carousel-arrow-right-enter-from,.carousel-arrow-right-leave-active{transform:translateY(-50%) translate(10px);opacity:0}.el-cascader-panel{--el-cascader-menu-text-color:var(--el-text-color-regular);--el-cascader-menu-selected-text-color:var(--el-color-primary);--el-cascader-menu-fill:var(--el-bg-color-overlay);--el-cascader-menu-font-size:var(--el-font-size-base);--el-cascader-menu-radius:var(--el-border-radius-base);--el-cascader-menu-border:solid 1px var(--el-border-color-light);--el-cascader-menu-shadow:var(--el-box-shadow-light);--el-cascader-node-background-hover:var(--el-fill-color-light);--el-cascader-node-color-disabled:var(--el-text-color-placeholder);--el-cascader-color-empty:var(--el-text-color-placeholder);--el-cascader-tag-background:var(--el-fill-color)}.el-cascader-panel{display:flex;border-radius:var(--el-cascader-menu-radius);font-size:var(--el-cascader-menu-font-size)}.el-cascader-panel.is-bordered{border:var(--el-cascader-menu-border);border-radius:var(--el-cascader-menu-radius)}.el-cascader-menu{min-width:180px;box-sizing:border-box;color:var(--el-cascader-menu-text-color);border-right:var(--el-cascader-menu-border)}.el-cascader-menu:last-child{border-right:none}.el-cascader-menu:last-child .el-cascader-node{padding-right:20px}.el-cascader-menu__wrap.el-scrollbar__wrap{height:204px}.el-cascader-menu__list{position:relative;min-height:100%;margin:0;padding:6px 0;list-style:none;box-sizing:border-box}.el-cascader-menu__hover-zone{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.el-cascader-menu__empty-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;color:var(--el-cascader-color-empty)}.el-cascader-menu__empty-text .is-loading{margin-right:2px}.el-cascader-node{position:relative;display:flex;align-items:center;padding:0 30px 0 20px;height:34px;line-height:34px;outline:0}.el-cascader-node.is-selectable.in-active-path{color:var(--el-cascader-menu-text-color)}.el-cascader-node.in-active-path,.el-cascader-node.is-active,.el-cascader-node.is-selectable.in-checked-path{color:var(--el-cascader-menu-selected-text-color);font-weight:700}.el-cascader-node:not(.is-disabled){cursor:pointer}.el-cascader-node:not(.is-disabled):focus,.el-cascader-node:not(.is-disabled):hover{background:var(--el-cascader-node-background-hover)}.el-cascader-node.is-disabled{color:var(--el-cascader-node-color-disabled);cursor:not-allowed}.el-cascader-node__prefix{position:absolute;left:10px}.el-cascader-node__postfix{position:absolute;right:10px}.el-cascader-node__label{flex:1;text-align:left;padding:0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.el-cascader-node>.el-checkbox{margin-right:0}.el-cascader-node>.el-radio{margin-right:0}.el-cascader-node>.el-radio .el-radio__label{padding-left:0}.el-cascader{--el-cascader-menu-text-color:var(--el-text-color-regular);--el-cascader-menu-selected-text-color:var(--el-color-primary);--el-cascader-menu-fill:var(--el-bg-color-overlay);--el-cascader-menu-font-size:var(--el-font-size-base);--el-cascader-menu-radius:var(--el-border-radius-base);--el-cascader-menu-border:solid 1px var(--el-border-color-light);--el-cascader-menu-shadow:var(--el-box-shadow-light);--el-cascader-node-background-hover:var(--el-fill-color-light);--el-cascader-node-color-disabled:var(--el-text-color-placeholder);--el-cascader-color-empty:var(--el-text-color-placeholder);--el-cascader-tag-background:var(--el-fill-color);display:inline-block;vertical-align:middle;position:relative;font-size:var(--el-font-size-base);line-height:32px;outline:0}.el-cascader:not(.is-disabled):hover .el-input__wrapper{cursor:pointer;box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-cascader .el-input{display:flex;cursor:pointer}.el-cascader .el-input .el-input__inner{text-overflow:ellipsis;cursor:pointer}.el-cascader .el-input .el-input__suffix-inner .el-icon{height:calc(100% - 2px)}.el-cascader .el-input .el-input__suffix-inner .el-icon svg{vertical-align:middle}.el-cascader .el-input .icon-arrow-down{transition:transform var(--el-transition-duration);font-size:14px}.el-cascader .el-input .icon-arrow-down.is-reverse{transform:rotate(180deg)}.el-cascader .el-input .icon-circle-close:hover{color:var(--el-input-clear-hover-color,var(--el-text-color-secondary))}.el-cascader .el-input.is-focus .el-input__wrapper{box-shadow:0 0 0 1px var(--el-input-focus-border-color,var(--el-color-primary)) inset}.el-cascader--large{font-size:14px;line-height:40px}.el-cascader--small{font-size:12px;line-height:24px}.el-cascader.is-disabled .el-cascader__label{z-index:calc(var(--el-index-normal) + 1);color:var(--el-disabled-text-color)}.el-cascader__dropdown{--el-cascader-menu-text-color:var(--el-text-color-regular);--el-cascader-menu-selected-text-color:var(--el-color-primary);--el-cascader-menu-fill:var(--el-bg-color-overlay);--el-cascader-menu-font-size:var(--el-font-size-base);--el-cascader-menu-radius:var(--el-border-radius-base);--el-cascader-menu-border:solid 1px var(--el-border-color-light);--el-cascader-menu-shadow:var(--el-box-shadow-light);--el-cascader-node-background-hover:var(--el-fill-color-light);--el-cascader-node-color-disabled:var(--el-text-color-placeholder);--el-cascader-color-empty:var(--el-text-color-placeholder);--el-cascader-tag-background:var(--el-fill-color)}.el-cascader__dropdown{font-size:var(--el-cascader-menu-font-size);border-radius:var(--el-cascader-menu-radius)}.el-cascader__dropdown.el-popper{background:var(--el-cascader-menu-fill);border:var(--el-cascader-menu-border);box-shadow:var(--el-cascader-menu-shadow)}.el-cascader__dropdown.el-popper .el-popper__arrow:before{border:var(--el-cascader-menu-border)}.el-cascader__dropdown.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-cascader__dropdown.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-cascader__dropdown.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-cascader__dropdown.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-cascader__dropdown.el-popper{box-shadow:var(--el-cascader-menu-shadow)}.el-cascader__tags{position:absolute;left:0;right:30px;top:50%;transform:translateY(-50%);display:flex;flex-wrap:wrap;line-height:normal;text-align:left;box-sizing:border-box}.el-cascader__tags .el-tag{display:inline-flex;align-items:center;max-width:100%;margin:2px 0 2px 6px;text-overflow:ellipsis;background:var(--el-cascader-tag-background)}.el-cascader__tags .el-tag:not(.is-hit){border-color:transparent}.el-cascader__tags .el-tag>span{flex:1;overflow:hidden;text-overflow:ellipsis}.el-cascader__tags .el-tag .el-icon-close{flex:none;background-color:var(--el-text-color-placeholder);color:var(--el-color-white)}.el-cascader__tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-cascader__collapse-tags{white-space:normal;z-index:var(--el-index-normal)}.el-cascader__collapse-tags .el-tag{display:inline-flex;align-items:center;max-width:100%;margin:2px 0 2px 6px;text-overflow:ellipsis;background:var(--el-fill-color)}.el-cascader__collapse-tags .el-tag:not(.is-hit){border-color:transparent}.el-cascader__collapse-tags .el-tag>span{flex:1;overflow:hidden;text-overflow:ellipsis}.el-cascader__collapse-tags .el-tag .el-icon-close{flex:none;background-color:var(--el-text-color-placeholder);color:var(--el-color-white)}.el-cascader__collapse-tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-cascader__suggestion-panel{border-radius:var(--el-cascader-menu-radius)}.el-cascader__suggestion-list{max-height:204px;margin:0;padding:6px 0;font-size:var(--el-font-size-base);color:var(--el-cascader-menu-text-color);text-align:center}.el-cascader__suggestion-item{display:flex;justify-content:space-between;align-items:center;height:34px;padding:0 15px;text-align:left;outline:0;cursor:pointer}.el-cascader__suggestion-item:focus,.el-cascader__suggestion-item:hover{background:var(--el-cascader-node-background-hover)}.el-cascader__suggestion-item.is-checked{color:var(--el-cascader-menu-selected-text-color);font-weight:700}.el-cascader__suggestion-item>span{margin-right:10px}.el-cascader__empty-text{margin:10px 0;color:var(--el-cascader-color-empty)}.el-cascader__search-input{flex:1;height:24px;min-width:60px;margin:2px 0 2px 11px;padding:0;color:var(--el-cascader-menu-text-color);border:none;outline:0;box-sizing:border-box;background:0 0}.el-cascader__search-input::-moz-placeholder{color:transparent}.el-cascader__search-input:-ms-input-placeholder{color:transparent}.el-cascader__search-input::placeholder{color:transparent}.el-check-tag{background-color:var(--el-color-info-light-9);border-radius:var(--el-border-radius-base);color:var(--el-color-info);cursor:pointer;display:inline-block;font-size:var(--el-font-size-base);line-height:var(--el-font-size-base);padding:7px 15px;transition:var(--el-transition-all);font-weight:700}.el-check-tag:hover{background-color:var(--el-color-info-light-7)}.el-check-tag.is-checked{background-color:var(--el-color-primary-light-8);color:var(--el-color-primary)}.el-check-tag.is-checked:hover{background-color:var(--el-color-primary-light-7)}.el-checkbox-button{--el-checkbox-button-checked-bg-color:var(--el-color-primary);--el-checkbox-button-checked-text-color:var(--el-color-white);--el-checkbox-button-checked-border-color:var(--el-color-primary)}.el-checkbox-button{position:relative;display:inline-block}.el-checkbox-button__inner{display:inline-block;line-height:1;font-weight:var(--el-checkbox-font-weight);white-space:nowrap;vertical-align:middle;cursor:pointer;background:var(--el-button-bg-color,var(--el-fill-color-blank));border:var(--el-border);border-left:0;color:var(--el-button-text-color,var(--el-text-color-regular));-webkit-appearance:none;text-align:center;box-sizing:border-box;outline:0;margin:0;position:relative;transition:var(--el-transition-all);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;padding:8px 15px;font-size:var(--el-font-size-base);border-radius:0}.el-checkbox-button__inner.is-round{padding:8px 15px}.el-checkbox-button__inner:hover{color:var(--el-color-primary)}.el-checkbox-button__inner [class*=el-icon-]{line-height:.9}.el-checkbox-button__inner [class*=el-icon-]+span{margin-left:5px}.el-checkbox-button__original{opacity:0;outline:0;position:absolute;margin:0;z-index:-1}.el-checkbox-button.is-checked .el-checkbox-button__inner{color:var(--el-checkbox-button-checked-text-color);background-color:var(--el-checkbox-button-checked-bg-color);border-color:var(--el-checkbox-button-checked-border-color);box-shadow:-1px 0 0 0 var(--el-color-primary-light-7)}.el-checkbox-button.is-checked:first-child .el-checkbox-button__inner{border-left-color:var(--el-checkbox-button-checked-border-color)}.el-checkbox-button.is-disabled .el-checkbox-button__inner{color:var(--el-disabled-text-color);cursor:not-allowed;background-image:none;background-color:var(--el-button-disabled-bg-color,var(--el-fill-color-blank));border-color:var(--el-button-disabled-border-color,var(--el-border-color-light));box-shadow:none}.el-checkbox-button.is-disabled:first-child .el-checkbox-button__inner{border-left-color:var(--el-button-disabled-border-color,var(--el-border-color-light))}.el-checkbox-button:first-child .el-checkbox-button__inner{border-left:var(--el-border);border-top-left-radius:var(--el-border-radius-base);border-bottom-left-radius:var(--el-border-radius-base);box-shadow:none!important}.el-checkbox-button.is-focus .el-checkbox-button__inner{border-color:var(--el-checkbox-button-checked-border-color)}.el-checkbox-button:last-child .el-checkbox-button__inner{border-top-right-radius:var(--el-border-radius-base);border-bottom-right-radius:var(--el-border-radius-base)}.el-checkbox-button--large .el-checkbox-button__inner{padding:12px 19px;font-size:var(--el-font-size-base);border-radius:0}.el-checkbox-button--large .el-checkbox-button__inner.is-round{padding:12px 19px}.el-checkbox-button--small .el-checkbox-button__inner{padding:5px 11px;font-size:12px;border-radius:0}.el-checkbox-button--small .el-checkbox-button__inner.is-round{padding:5px 11px}.el-checkbox-group{font-size:0;line-height:0}.el-checkbox{--el-checkbox-font-size:14px;--el-checkbox-font-weight:var(--el-font-weight-primary);--el-checkbox-text-color:var(--el-text-color-regular);--el-checkbox-input-height:14px;--el-checkbox-input-width:14px;--el-checkbox-border-radius:var(--el-border-radius-small);--el-checkbox-bg-color:var(--el-fill-color-blank);--el-checkbox-input-border:var(--el-border);--el-checkbox-disabled-border-color:var(--el-border-color);--el-checkbox-disabled-input-fill:var(--el-fill-color-light);--el-checkbox-disabled-icon-color:var(--el-text-color-placeholder);--el-checkbox-disabled-checked-input-fill:var(--el-border-color-extra-light);--el-checkbox-disabled-checked-input-border-color:var(--el-border-color);--el-checkbox-disabled-checked-icon-color:var(--el-text-color-placeholder);--el-checkbox-checked-text-color:var(--el-color-primary);--el-checkbox-checked-input-border-color:var(--el-color-primary);--el-checkbox-checked-bg-color:var(--el-color-primary);--el-checkbox-checked-icon-color:var(--el-color-white);--el-checkbox-input-border-color-hover:var(--el-color-primary)}.el-checkbox{color:var(--el-checkbox-text-color);font-weight:var(--el-checkbox-font-weight);font-size:var(--el-font-size-base);position:relative;cursor:pointer;display:inline-flex;align-items:center;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;margin-right:30px;height:32px}.el-checkbox.is-disabled{cursor:not-allowed}.el-checkbox.is-bordered{padding:0 15px 0 9px;border-radius:var(--el-border-radius-base);border:var(--el-border);box-sizing:border-box}.el-checkbox.is-bordered.is-checked{border-color:var(--el-color-primary)}.el-checkbox.is-bordered.is-disabled{border-color:var(--el-border-color-lighter)}.el-checkbox.is-bordered.el-checkbox--large{padding:0 19px 0 11px;border-radius:var(--el-border-radius-base)}.el-checkbox.is-bordered.el-checkbox--large .el-checkbox__label{font-size:var(--el-font-size-base)}.el-checkbox.is-bordered.el-checkbox--large .el-checkbox__inner{height:14px;width:14px}.el-checkbox.is-bordered.el-checkbox--small{padding:0 11px 0 7px;border-radius:calc(var(--el-border-radius-base) - 1px)}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__label{font-size:12px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__inner{height:12px;width:12px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__inner:after{height:6px;width:2px}.el-checkbox input:focus-visible+.el-checkbox__inner{outline:2px solid var(--el-checkbox-input-border-color-hover);outline-offset:1px;border-radius:var(--el-checkbox-border-radius)}.el-checkbox__input{white-space:nowrap;cursor:pointer;outline:0;display:inline-flex;position:relative}.el-checkbox__input.is-disabled .el-checkbox__inner{background-color:var(--el-checkbox-disabled-input-fill);border-color:var(--el-checkbox-disabled-border-color);cursor:not-allowed}.el-checkbox__input.is-disabled .el-checkbox__inner:after{cursor:not-allowed;border-color:var(--el-checkbox-disabled-icon-color)}.el-checkbox__input.is-disabled.is-checked .el-checkbox__inner{background-color:var(--el-checkbox-disabled-checked-input-fill);border-color:var(--el-checkbox-disabled-checked-input-border-color)}.el-checkbox__input.is-disabled.is-checked .el-checkbox__inner:after{border-color:var(--el-checkbox-disabled-checked-icon-color)}.el-checkbox__input.is-disabled.is-indeterminate .el-checkbox__inner{background-color:var(--el-checkbox-disabled-checked-input-fill);border-color:var(--el-checkbox-disabled-checked-input-border-color)}.el-checkbox__input.is-disabled.is-indeterminate .el-checkbox__inner:before{background-color:var(--el-checkbox-disabled-checked-icon-color);border-color:var(--el-checkbox-disabled-checked-icon-color)}.el-checkbox__input.is-disabled+span.el-checkbox__label{color:var(--el-disabled-text-color);cursor:not-allowed}.el-checkbox__input.is-checked .el-checkbox__inner{background-color:var(--el-checkbox-checked-bg-color);border-color:var(--el-checkbox-checked-input-border-color)}.el-checkbox__input.is-checked .el-checkbox__inner:after{transform:rotate(45deg) scaleY(1)}.el-checkbox__input.is-checked+.el-checkbox__label{color:var(--el-checkbox-checked-text-color)}.el-checkbox__input.is-focus:not(.is-checked) .el-checkbox__original:not(:focus-visible){border-color:var(--el-checkbox-input-border-color-hover)}.el-checkbox__input.is-indeterminate .el-checkbox__inner{background-color:var(--el-checkbox-checked-bg-color);border-color:var(--el-checkbox-checked-input-border-color)}.el-checkbox__input.is-indeterminate .el-checkbox__inner:before{content:"";position:absolute;display:block;background-color:var(--el-checkbox-checked-icon-color);height:2px;transform:scale(.5);left:0;right:0;top:5px}.el-checkbox__input.is-indeterminate .el-checkbox__inner:after{display:none}.el-checkbox__inner{display:inline-block;position:relative;border:var(--el-checkbox-input-border);border-radius:var(--el-checkbox-border-radius);box-sizing:border-box;width:var(--el-checkbox-input-width);height:var(--el-checkbox-input-height);background-color:var(--el-checkbox-bg-color);z-index:var(--el-index-normal);transition:border-color .25s cubic-bezier(.71,-.46,.29,1.46),background-color .25s cubic-bezier(.71,-.46,.29,1.46),outline .25s cubic-bezier(.71,-.46,.29,1.46)}.el-checkbox__inner:hover{border-color:var(--el-checkbox-input-border-color-hover)}.el-checkbox__inner:after{box-sizing:content-box;content:"";border:1px solid var(--el-checkbox-checked-icon-color);border-left:0;border-top:0;height:7px;left:4px;position:absolute;top:1px;transform:rotate(45deg) scaleY(0);width:3px;transition:transform .15s ease-in 50ms;transform-origin:center}.el-checkbox__original{opacity:0;outline:0;position:absolute;margin:0;width:0;height:0;z-index:-1}.el-checkbox__label{display:inline-block;padding-left:8px;line-height:1;font-size:var(--el-checkbox-font-size)}.el-checkbox.el-checkbox--large{height:40px}.el-checkbox.el-checkbox--large .el-checkbox__label{font-size:14px}.el-checkbox.el-checkbox--large .el-checkbox__inner{width:14px;height:14px}.el-checkbox.el-checkbox--small{height:24px}.el-checkbox.el-checkbox--small .el-checkbox__label{font-size:12px}.el-checkbox.el-checkbox--small .el-checkbox__inner{width:12px;height:12px}.el-checkbox.el-checkbox--small .el-checkbox__input.is-indeterminate .el-checkbox__inner:before{top:4px}.el-checkbox.el-checkbox--small .el-checkbox__inner:after{width:2px;height:6px}.el-checkbox:last-of-type{margin-right:0}[class*=el-col-]{box-sizing:border-box}[class*=el-col-].is-guttered{display:block;min-height:1px}.el-col-0,.el-col-0.is-guttered{display:none}.el-col-0{max-width:0%;flex:0 0 0%}.el-col-offset-0{margin-left:0}.el-col-pull-0{position:relative;right:0}.el-col-push-0{position:relative;left:0}.el-col-1{max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-offset-1{margin-left:4.1666666667%}.el-col-pull-1{position:relative;right:4.1666666667%}.el-col-push-1{position:relative;left:4.1666666667%}.el-col-2{max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-offset-2{margin-left:8.3333333333%}.el-col-pull-2{position:relative;right:8.3333333333%}.el-col-push-2{position:relative;left:8.3333333333%}.el-col-3{max-width:12.5%;flex:0 0 12.5%}.el-col-offset-3{margin-left:12.5%}.el-col-pull-3{position:relative;right:12.5%}.el-col-push-3{position:relative;left:12.5%}.el-col-4{max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-offset-4{margin-left:16.6666666667%}.el-col-pull-4{position:relative;right:16.6666666667%}.el-col-push-4{position:relative;left:16.6666666667%}.el-col-5{max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-offset-5{margin-left:20.8333333333%}.el-col-pull-5{position:relative;right:20.8333333333%}.el-col-push-5{position:relative;left:20.8333333333%}.el-col-6{max-width:25%;flex:0 0 25%}.el-col-offset-6{margin-left:25%}.el-col-pull-6{position:relative;right:25%}.el-col-push-6{position:relative;left:25%}.el-col-7{max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-offset-7{margin-left:29.1666666667%}.el-col-pull-7{position:relative;right:29.1666666667%}.el-col-push-7{position:relative;left:29.1666666667%}.el-col-8{max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-offset-8{margin-left:33.3333333333%}.el-col-pull-8{position:relative;right:33.3333333333%}.el-col-push-8{position:relative;left:33.3333333333%}.el-col-9{max-width:37.5%;flex:0 0 37.5%}.el-col-offset-9{margin-left:37.5%}.el-col-pull-9{position:relative;right:37.5%}.el-col-push-9{position:relative;left:37.5%}.el-col-10{max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-offset-10{margin-left:41.6666666667%}.el-col-pull-10{position:relative;right:41.6666666667%}.el-col-push-10{position:relative;left:41.6666666667%}.el-col-11{max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-offset-11{margin-left:45.8333333333%}.el-col-pull-11{position:relative;right:45.8333333333%}.el-col-push-11{position:relative;left:45.8333333333%}.el-col-12{max-width:50%;flex:0 0 50%}.el-col-offset-12{margin-left:50%}.el-col-pull-12{position:relative;right:50%}.el-col-push-12{position:relative;left:50%}.el-col-13{max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-offset-13{margin-left:54.1666666667%}.el-col-pull-13{position:relative;right:54.1666666667%}.el-col-push-13{position:relative;left:54.1666666667%}.el-col-14{max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-offset-14{margin-left:58.3333333333%}.el-col-pull-14{position:relative;right:58.3333333333%}.el-col-push-14{position:relative;left:58.3333333333%}.el-col-15{max-width:62.5%;flex:0 0 62.5%}.el-col-offset-15{margin-left:62.5%}.el-col-pull-15{position:relative;right:62.5%}.el-col-push-15{position:relative;left:62.5%}.el-col-16{max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-offset-16{margin-left:66.6666666667%}.el-col-pull-16{position:relative;right:66.6666666667%}.el-col-push-16{position:relative;left:66.6666666667%}.el-col-17{max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-offset-17{margin-left:70.8333333333%}.el-col-pull-17{position:relative;right:70.8333333333%}.el-col-push-17{position:relative;left:70.8333333333%}.el-col-18{max-width:75%;flex:0 0 75%}.el-col-offset-18{margin-left:75%}.el-col-pull-18{position:relative;right:75%}.el-col-push-18{position:relative;left:75%}.el-col-19{max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-offset-19{margin-left:79.1666666667%}.el-col-pull-19{position:relative;right:79.1666666667%}.el-col-push-19{position:relative;left:79.1666666667%}.el-col-20{max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-offset-20{margin-left:83.3333333333%}.el-col-pull-20{position:relative;right:83.3333333333%}.el-col-push-20{position:relative;left:83.3333333333%}.el-col-21{max-width:87.5%;flex:0 0 87.5%}.el-col-offset-21{margin-left:87.5%}.el-col-pull-21{position:relative;right:87.5%}.el-col-push-21{position:relative;left:87.5%}.el-col-22{max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-offset-22{margin-left:91.6666666667%}.el-col-pull-22{position:relative;right:91.6666666667%}.el-col-push-22{position:relative;left:91.6666666667%}.el-col-23{max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-offset-23{margin-left:95.8333333333%}.el-col-pull-23{position:relative;right:95.8333333333%}.el-col-push-23{position:relative;left:95.8333333333%}.el-col-24{max-width:100%;flex:0 0 100%}.el-col-offset-24{margin-left:100%}.el-col-pull-24{position:relative;right:100%}.el-col-push-24{position:relative;left:100%}@media only screen and (max-width:768px){.el-col-xs-0,.el-col-xs-0.is-guttered{display:none}.el-col-xs-0{max-width:0%;flex:0 0 0%}.el-col-xs-offset-0{margin-left:0}.el-col-xs-pull-0{position:relative;right:0}.el-col-xs-push-0{position:relative;left:0}.el-col-xs-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-xs-offset-1{margin-left:4.1666666667%}.el-col-xs-pull-1{position:relative;right:4.1666666667%}.el-col-xs-push-1{position:relative;left:4.1666666667%}.el-col-xs-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-xs-offset-2{margin-left:8.3333333333%}.el-col-xs-pull-2{position:relative;right:8.3333333333%}.el-col-xs-push-2{position:relative;left:8.3333333333%}.el-col-xs-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-xs-offset-3{margin-left:12.5%}.el-col-xs-pull-3{position:relative;right:12.5%}.el-col-xs-push-3{position:relative;left:12.5%}.el-col-xs-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-xs-offset-4{margin-left:16.6666666667%}.el-col-xs-pull-4{position:relative;right:16.6666666667%}.el-col-xs-push-4{position:relative;left:16.6666666667%}.el-col-xs-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-xs-offset-5{margin-left:20.8333333333%}.el-col-xs-pull-5{position:relative;right:20.8333333333%}.el-col-xs-push-5{position:relative;left:20.8333333333%}.el-col-xs-6{display:block;max-width:25%;flex:0 0 25%}.el-col-xs-offset-6{margin-left:25%}.el-col-xs-pull-6{position:relative;right:25%}.el-col-xs-push-6{position:relative;left:25%}.el-col-xs-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-xs-offset-7{margin-left:29.1666666667%}.el-col-xs-pull-7{position:relative;right:29.1666666667%}.el-col-xs-push-7{position:relative;left:29.1666666667%}.el-col-xs-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-xs-offset-8{margin-left:33.3333333333%}.el-col-xs-pull-8{position:relative;right:33.3333333333%}.el-col-xs-push-8{position:relative;left:33.3333333333%}.el-col-xs-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-xs-offset-9{margin-left:37.5%}.el-col-xs-pull-9{position:relative;right:37.5%}.el-col-xs-push-9{position:relative;left:37.5%}.el-col-xs-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-xs-offset-10{margin-left:41.6666666667%}.el-col-xs-pull-10{position:relative;right:41.6666666667%}.el-col-xs-push-10{position:relative;left:41.6666666667%}.el-col-xs-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-xs-offset-11{margin-left:45.8333333333%}.el-col-xs-pull-11{position:relative;right:45.8333333333%}.el-col-xs-push-11{position:relative;left:45.8333333333%}.el-col-xs-12{display:block;max-width:50%;flex:0 0 50%}.el-col-xs-offset-12{margin-left:50%}.el-col-xs-pull-12{position:relative;right:50%}.el-col-xs-push-12{position:relative;left:50%}.el-col-xs-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-xs-offset-13{margin-left:54.1666666667%}.el-col-xs-pull-13{position:relative;right:54.1666666667%}.el-col-xs-push-13{position:relative;left:54.1666666667%}.el-col-xs-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-xs-offset-14{margin-left:58.3333333333%}.el-col-xs-pull-14{position:relative;right:58.3333333333%}.el-col-xs-push-14{position:relative;left:58.3333333333%}.el-col-xs-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-xs-offset-15{margin-left:62.5%}.el-col-xs-pull-15{position:relative;right:62.5%}.el-col-xs-push-15{position:relative;left:62.5%}.el-col-xs-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-xs-offset-16{margin-left:66.6666666667%}.el-col-xs-pull-16{position:relative;right:66.6666666667%}.el-col-xs-push-16{position:relative;left:66.6666666667%}.el-col-xs-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-xs-offset-17{margin-left:70.8333333333%}.el-col-xs-pull-17{position:relative;right:70.8333333333%}.el-col-xs-push-17{position:relative;left:70.8333333333%}.el-col-xs-18{display:block;max-width:75%;flex:0 0 75%}.el-col-xs-offset-18{margin-left:75%}.el-col-xs-pull-18{position:relative;right:75%}.el-col-xs-push-18{position:relative;left:75%}.el-col-xs-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-xs-offset-19{margin-left:79.1666666667%}.el-col-xs-pull-19{position:relative;right:79.1666666667%}.el-col-xs-push-19{position:relative;left:79.1666666667%}.el-col-xs-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-xs-offset-20{margin-left:83.3333333333%}.el-col-xs-pull-20{position:relative;right:83.3333333333%}.el-col-xs-push-20{position:relative;left:83.3333333333%}.el-col-xs-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-xs-offset-21{margin-left:87.5%}.el-col-xs-pull-21{position:relative;right:87.5%}.el-col-xs-push-21{position:relative;left:87.5%}.el-col-xs-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-xs-offset-22{margin-left:91.6666666667%}.el-col-xs-pull-22{position:relative;right:91.6666666667%}.el-col-xs-push-22{position:relative;left:91.6666666667%}.el-col-xs-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-xs-offset-23{margin-left:95.8333333333%}.el-col-xs-pull-23{position:relative;right:95.8333333333%}.el-col-xs-push-23{position:relative;left:95.8333333333%}.el-col-xs-24{display:block;max-width:100%;flex:0 0 100%}.el-col-xs-offset-24{margin-left:100%}.el-col-xs-pull-24{position:relative;right:100%}.el-col-xs-push-24{position:relative;left:100%}}@media only screen and (min-width:768px){.el-col-sm-0,.el-col-sm-0.is-guttered{display:none}.el-col-sm-0{max-width:0%;flex:0 0 0%}.el-col-sm-offset-0{margin-left:0}.el-col-sm-pull-0{position:relative;right:0}.el-col-sm-push-0{position:relative;left:0}.el-col-sm-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-sm-offset-1{margin-left:4.1666666667%}.el-col-sm-pull-1{position:relative;right:4.1666666667%}.el-col-sm-push-1{position:relative;left:4.1666666667%}.el-col-sm-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-sm-offset-2{margin-left:8.3333333333%}.el-col-sm-pull-2{position:relative;right:8.3333333333%}.el-col-sm-push-2{position:relative;left:8.3333333333%}.el-col-sm-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-sm-offset-3{margin-left:12.5%}.el-col-sm-pull-3{position:relative;right:12.5%}.el-col-sm-push-3{position:relative;left:12.5%}.el-col-sm-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-sm-offset-4{margin-left:16.6666666667%}.el-col-sm-pull-4{position:relative;right:16.6666666667%}.el-col-sm-push-4{position:relative;left:16.6666666667%}.el-col-sm-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-sm-offset-5{margin-left:20.8333333333%}.el-col-sm-pull-5{position:relative;right:20.8333333333%}.el-col-sm-push-5{position:relative;left:20.8333333333%}.el-col-sm-6{display:block;max-width:25%;flex:0 0 25%}.el-col-sm-offset-6{margin-left:25%}.el-col-sm-pull-6{position:relative;right:25%}.el-col-sm-push-6{position:relative;left:25%}.el-col-sm-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-sm-offset-7{margin-left:29.1666666667%}.el-col-sm-pull-7{position:relative;right:29.1666666667%}.el-col-sm-push-7{position:relative;left:29.1666666667%}.el-col-sm-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-sm-offset-8{margin-left:33.3333333333%}.el-col-sm-pull-8{position:relative;right:33.3333333333%}.el-col-sm-push-8{position:relative;left:33.3333333333%}.el-col-sm-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-sm-offset-9{margin-left:37.5%}.el-col-sm-pull-9{position:relative;right:37.5%}.el-col-sm-push-9{position:relative;left:37.5%}.el-col-sm-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-sm-offset-10{margin-left:41.6666666667%}.el-col-sm-pull-10{position:relative;right:41.6666666667%}.el-col-sm-push-10{position:relative;left:41.6666666667%}.el-col-sm-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-sm-offset-11{margin-left:45.8333333333%}.el-col-sm-pull-11{position:relative;right:45.8333333333%}.el-col-sm-push-11{position:relative;left:45.8333333333%}.el-col-sm-12{display:block;max-width:50%;flex:0 0 50%}.el-col-sm-offset-12{margin-left:50%}.el-col-sm-pull-12{position:relative;right:50%}.el-col-sm-push-12{position:relative;left:50%}.el-col-sm-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-sm-offset-13{margin-left:54.1666666667%}.el-col-sm-pull-13{position:relative;right:54.1666666667%}.el-col-sm-push-13{position:relative;left:54.1666666667%}.el-col-sm-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-sm-offset-14{margin-left:58.3333333333%}.el-col-sm-pull-14{position:relative;right:58.3333333333%}.el-col-sm-push-14{position:relative;left:58.3333333333%}.el-col-sm-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-sm-offset-15{margin-left:62.5%}.el-col-sm-pull-15{position:relative;right:62.5%}.el-col-sm-push-15{position:relative;left:62.5%}.el-col-sm-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-sm-offset-16{margin-left:66.6666666667%}.el-col-sm-pull-16{position:relative;right:66.6666666667%}.el-col-sm-push-16{position:relative;left:66.6666666667%}.el-col-sm-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-sm-offset-17{margin-left:70.8333333333%}.el-col-sm-pull-17{position:relative;right:70.8333333333%}.el-col-sm-push-17{position:relative;left:70.8333333333%}.el-col-sm-18{display:block;max-width:75%;flex:0 0 75%}.el-col-sm-offset-18{margin-left:75%}.el-col-sm-pull-18{position:relative;right:75%}.el-col-sm-push-18{position:relative;left:75%}.el-col-sm-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-sm-offset-19{margin-left:79.1666666667%}.el-col-sm-pull-19{position:relative;right:79.1666666667%}.el-col-sm-push-19{position:relative;left:79.1666666667%}.el-col-sm-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-sm-offset-20{margin-left:83.3333333333%}.el-col-sm-pull-20{position:relative;right:83.3333333333%}.el-col-sm-push-20{position:relative;left:83.3333333333%}.el-col-sm-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-sm-offset-21{margin-left:87.5%}.el-col-sm-pull-21{position:relative;right:87.5%}.el-col-sm-push-21{position:relative;left:87.5%}.el-col-sm-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-sm-offset-22{margin-left:91.6666666667%}.el-col-sm-pull-22{position:relative;right:91.6666666667%}.el-col-sm-push-22{position:relative;left:91.6666666667%}.el-col-sm-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-sm-offset-23{margin-left:95.8333333333%}.el-col-sm-pull-23{position:relative;right:95.8333333333%}.el-col-sm-push-23{position:relative;left:95.8333333333%}.el-col-sm-24{display:block;max-width:100%;flex:0 0 100%}.el-col-sm-offset-24{margin-left:100%}.el-col-sm-pull-24{position:relative;right:100%}.el-col-sm-push-24{position:relative;left:100%}}@media only screen and (min-width:992px){.el-col-md-0,.el-col-md-0.is-guttered{display:none}.el-col-md-0{max-width:0%;flex:0 0 0%}.el-col-md-offset-0{margin-left:0}.el-col-md-pull-0{position:relative;right:0}.el-col-md-push-0{position:relative;left:0}.el-col-md-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-md-offset-1{margin-left:4.1666666667%}.el-col-md-pull-1{position:relative;right:4.1666666667%}.el-col-md-push-1{position:relative;left:4.1666666667%}.el-col-md-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-md-offset-2{margin-left:8.3333333333%}.el-col-md-pull-2{position:relative;right:8.3333333333%}.el-col-md-push-2{position:relative;left:8.3333333333%}.el-col-md-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-md-offset-3{margin-left:12.5%}.el-col-md-pull-3{position:relative;right:12.5%}.el-col-md-push-3{position:relative;left:12.5%}.el-col-md-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-md-offset-4{margin-left:16.6666666667%}.el-col-md-pull-4{position:relative;right:16.6666666667%}.el-col-md-push-4{position:relative;left:16.6666666667%}.el-col-md-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-md-offset-5{margin-left:20.8333333333%}.el-col-md-pull-5{position:relative;right:20.8333333333%}.el-col-md-push-5{position:relative;left:20.8333333333%}.el-col-md-6{display:block;max-width:25%;flex:0 0 25%}.el-col-md-offset-6{margin-left:25%}.el-col-md-pull-6{position:relative;right:25%}.el-col-md-push-6{position:relative;left:25%}.el-col-md-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-md-offset-7{margin-left:29.1666666667%}.el-col-md-pull-7{position:relative;right:29.1666666667%}.el-col-md-push-7{position:relative;left:29.1666666667%}.el-col-md-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-md-offset-8{margin-left:33.3333333333%}.el-col-md-pull-8{position:relative;right:33.3333333333%}.el-col-md-push-8{position:relative;left:33.3333333333%}.el-col-md-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-md-offset-9{margin-left:37.5%}.el-col-md-pull-9{position:relative;right:37.5%}.el-col-md-push-9{position:relative;left:37.5%}.el-col-md-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-md-offset-10{margin-left:41.6666666667%}.el-col-md-pull-10{position:relative;right:41.6666666667%}.el-col-md-push-10{position:relative;left:41.6666666667%}.el-col-md-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-md-offset-11{margin-left:45.8333333333%}.el-col-md-pull-11{position:relative;right:45.8333333333%}.el-col-md-push-11{position:relative;left:45.8333333333%}.el-col-md-12{display:block;max-width:50%;flex:0 0 50%}.el-col-md-offset-12{margin-left:50%}.el-col-md-pull-12{position:relative;right:50%}.el-col-md-push-12{position:relative;left:50%}.el-col-md-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-md-offset-13{margin-left:54.1666666667%}.el-col-md-pull-13{position:relative;right:54.1666666667%}.el-col-md-push-13{position:relative;left:54.1666666667%}.el-col-md-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-md-offset-14{margin-left:58.3333333333%}.el-col-md-pull-14{position:relative;right:58.3333333333%}.el-col-md-push-14{position:relative;left:58.3333333333%}.el-col-md-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-md-offset-15{margin-left:62.5%}.el-col-md-pull-15{position:relative;right:62.5%}.el-col-md-push-15{position:relative;left:62.5%}.el-col-md-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-md-offset-16{margin-left:66.6666666667%}.el-col-md-pull-16{position:relative;right:66.6666666667%}.el-col-md-push-16{position:relative;left:66.6666666667%}.el-col-md-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-md-offset-17{margin-left:70.8333333333%}.el-col-md-pull-17{position:relative;right:70.8333333333%}.el-col-md-push-17{position:relative;left:70.8333333333%}.el-col-md-18{display:block;max-width:75%;flex:0 0 75%}.el-col-md-offset-18{margin-left:75%}.el-col-md-pull-18{position:relative;right:75%}.el-col-md-push-18{position:relative;left:75%}.el-col-md-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-md-offset-19{margin-left:79.1666666667%}.el-col-md-pull-19{position:relative;right:79.1666666667%}.el-col-md-push-19{position:relative;left:79.1666666667%}.el-col-md-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-md-offset-20{margin-left:83.3333333333%}.el-col-md-pull-20{position:relative;right:83.3333333333%}.el-col-md-push-20{position:relative;left:83.3333333333%}.el-col-md-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-md-offset-21{margin-left:87.5%}.el-col-md-pull-21{position:relative;right:87.5%}.el-col-md-push-21{position:relative;left:87.5%}.el-col-md-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-md-offset-22{margin-left:91.6666666667%}.el-col-md-pull-22{position:relative;right:91.6666666667%}.el-col-md-push-22{position:relative;left:91.6666666667%}.el-col-md-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-md-offset-23{margin-left:95.8333333333%}.el-col-md-pull-23{position:relative;right:95.8333333333%}.el-col-md-push-23{position:relative;left:95.8333333333%}.el-col-md-24{display:block;max-width:100%;flex:0 0 100%}.el-col-md-offset-24{margin-left:100%}.el-col-md-pull-24{position:relative;right:100%}.el-col-md-push-24{position:relative;left:100%}}@media only screen and (min-width:1200px){.el-col-lg-0,.el-col-lg-0.is-guttered{display:none}.el-col-lg-0{max-width:0%;flex:0 0 0%}.el-col-lg-offset-0{margin-left:0}.el-col-lg-pull-0{position:relative;right:0}.el-col-lg-push-0{position:relative;left:0}.el-col-lg-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-lg-offset-1{margin-left:4.1666666667%}.el-col-lg-pull-1{position:relative;right:4.1666666667%}.el-col-lg-push-1{position:relative;left:4.1666666667%}.el-col-lg-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-lg-offset-2{margin-left:8.3333333333%}.el-col-lg-pull-2{position:relative;right:8.3333333333%}.el-col-lg-push-2{position:relative;left:8.3333333333%}.el-col-lg-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-lg-offset-3{margin-left:12.5%}.el-col-lg-pull-3{position:relative;right:12.5%}.el-col-lg-push-3{position:relative;left:12.5%}.el-col-lg-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-lg-offset-4{margin-left:16.6666666667%}.el-col-lg-pull-4{position:relative;right:16.6666666667%}.el-col-lg-push-4{position:relative;left:16.6666666667%}.el-col-lg-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-lg-offset-5{margin-left:20.8333333333%}.el-col-lg-pull-5{position:relative;right:20.8333333333%}.el-col-lg-push-5{position:relative;left:20.8333333333%}.el-col-lg-6{display:block;max-width:25%;flex:0 0 25%}.el-col-lg-offset-6{margin-left:25%}.el-col-lg-pull-6{position:relative;right:25%}.el-col-lg-push-6{position:relative;left:25%}.el-col-lg-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-lg-offset-7{margin-left:29.1666666667%}.el-col-lg-pull-7{position:relative;right:29.1666666667%}.el-col-lg-push-7{position:relative;left:29.1666666667%}.el-col-lg-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-lg-offset-8{margin-left:33.3333333333%}.el-col-lg-pull-8{position:relative;right:33.3333333333%}.el-col-lg-push-8{position:relative;left:33.3333333333%}.el-col-lg-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-lg-offset-9{margin-left:37.5%}.el-col-lg-pull-9{position:relative;right:37.5%}.el-col-lg-push-9{position:relative;left:37.5%}.el-col-lg-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-lg-offset-10{margin-left:41.6666666667%}.el-col-lg-pull-10{position:relative;right:41.6666666667%}.el-col-lg-push-10{position:relative;left:41.6666666667%}.el-col-lg-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-lg-offset-11{margin-left:45.8333333333%}.el-col-lg-pull-11{position:relative;right:45.8333333333%}.el-col-lg-push-11{position:relative;left:45.8333333333%}.el-col-lg-12{display:block;max-width:50%;flex:0 0 50%}.el-col-lg-offset-12{margin-left:50%}.el-col-lg-pull-12{position:relative;right:50%}.el-col-lg-push-12{position:relative;left:50%}.el-col-lg-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-lg-offset-13{margin-left:54.1666666667%}.el-col-lg-pull-13{position:relative;right:54.1666666667%}.el-col-lg-push-13{position:relative;left:54.1666666667%}.el-col-lg-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-lg-offset-14{margin-left:58.3333333333%}.el-col-lg-pull-14{position:relative;right:58.3333333333%}.el-col-lg-push-14{position:relative;left:58.3333333333%}.el-col-lg-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-lg-offset-15{margin-left:62.5%}.el-col-lg-pull-15{position:relative;right:62.5%}.el-col-lg-push-15{position:relative;left:62.5%}.el-col-lg-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-lg-offset-16{margin-left:66.6666666667%}.el-col-lg-pull-16{position:relative;right:66.6666666667%}.el-col-lg-push-16{position:relative;left:66.6666666667%}.el-col-lg-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-lg-offset-17{margin-left:70.8333333333%}.el-col-lg-pull-17{position:relative;right:70.8333333333%}.el-col-lg-push-17{position:relative;left:70.8333333333%}.el-col-lg-18{display:block;max-width:75%;flex:0 0 75%}.el-col-lg-offset-18{margin-left:75%}.el-col-lg-pull-18{position:relative;right:75%}.el-col-lg-push-18{position:relative;left:75%}.el-col-lg-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-lg-offset-19{margin-left:79.1666666667%}.el-col-lg-pull-19{position:relative;right:79.1666666667%}.el-col-lg-push-19{position:relative;left:79.1666666667%}.el-col-lg-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-lg-offset-20{margin-left:83.3333333333%}.el-col-lg-pull-20{position:relative;right:83.3333333333%}.el-col-lg-push-20{position:relative;left:83.3333333333%}.el-col-lg-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-lg-offset-21{margin-left:87.5%}.el-col-lg-pull-21{position:relative;right:87.5%}.el-col-lg-push-21{position:relative;left:87.5%}.el-col-lg-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-lg-offset-22{margin-left:91.6666666667%}.el-col-lg-pull-22{position:relative;right:91.6666666667%}.el-col-lg-push-22{position:relative;left:91.6666666667%}.el-col-lg-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-lg-offset-23{margin-left:95.8333333333%}.el-col-lg-pull-23{position:relative;right:95.8333333333%}.el-col-lg-push-23{position:relative;left:95.8333333333%}.el-col-lg-24{display:block;max-width:100%;flex:0 0 100%}.el-col-lg-offset-24{margin-left:100%}.el-col-lg-pull-24{position:relative;right:100%}.el-col-lg-push-24{position:relative;left:100%}}@media only screen and (min-width:1920px){.el-col-xl-0,.el-col-xl-0.is-guttered{display:none}.el-col-xl-0{max-width:0%;flex:0 0 0%}.el-col-xl-offset-0{margin-left:0}.el-col-xl-pull-0{position:relative;right:0}.el-col-xl-push-0{position:relative;left:0}.el-col-xl-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-xl-offset-1{margin-left:4.1666666667%}.el-col-xl-pull-1{position:relative;right:4.1666666667%}.el-col-xl-push-1{position:relative;left:4.1666666667%}.el-col-xl-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-xl-offset-2{margin-left:8.3333333333%}.el-col-xl-pull-2{position:relative;right:8.3333333333%}.el-col-xl-push-2{position:relative;left:8.3333333333%}.el-col-xl-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-xl-offset-3{margin-left:12.5%}.el-col-xl-pull-3{position:relative;right:12.5%}.el-col-xl-push-3{position:relative;left:12.5%}.el-col-xl-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-xl-offset-4{margin-left:16.6666666667%}.el-col-xl-pull-4{position:relative;right:16.6666666667%}.el-col-xl-push-4{position:relative;left:16.6666666667%}.el-col-xl-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-xl-offset-5{margin-left:20.8333333333%}.el-col-xl-pull-5{position:relative;right:20.8333333333%}.el-col-xl-push-5{position:relative;left:20.8333333333%}.el-col-xl-6{display:block;max-width:25%;flex:0 0 25%}.el-col-xl-offset-6{margin-left:25%}.el-col-xl-pull-6{position:relative;right:25%}.el-col-xl-push-6{position:relative;left:25%}.el-col-xl-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-xl-offset-7{margin-left:29.1666666667%}.el-col-xl-pull-7{position:relative;right:29.1666666667%}.el-col-xl-push-7{position:relative;left:29.1666666667%}.el-col-xl-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-xl-offset-8{margin-left:33.3333333333%}.el-col-xl-pull-8{position:relative;right:33.3333333333%}.el-col-xl-push-8{position:relative;left:33.3333333333%}.el-col-xl-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-xl-offset-9{margin-left:37.5%}.el-col-xl-pull-9{position:relative;right:37.5%}.el-col-xl-push-9{position:relative;left:37.5%}.el-col-xl-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-xl-offset-10{margin-left:41.6666666667%}.el-col-xl-pull-10{position:relative;right:41.6666666667%}.el-col-xl-push-10{position:relative;left:41.6666666667%}.el-col-xl-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-xl-offset-11{margin-left:45.8333333333%}.el-col-xl-pull-11{position:relative;right:45.8333333333%}.el-col-xl-push-11{position:relative;left:45.8333333333%}.el-col-xl-12{display:block;max-width:50%;flex:0 0 50%}.el-col-xl-offset-12{margin-left:50%}.el-col-xl-pull-12{position:relative;right:50%}.el-col-xl-push-12{position:relative;left:50%}.el-col-xl-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-xl-offset-13{margin-left:54.1666666667%}.el-col-xl-pull-13{position:relative;right:54.1666666667%}.el-col-xl-push-13{position:relative;left:54.1666666667%}.el-col-xl-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-xl-offset-14{margin-left:58.3333333333%}.el-col-xl-pull-14{position:relative;right:58.3333333333%}.el-col-xl-push-14{position:relative;left:58.3333333333%}.el-col-xl-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-xl-offset-15{margin-left:62.5%}.el-col-xl-pull-15{position:relative;right:62.5%}.el-col-xl-push-15{position:relative;left:62.5%}.el-col-xl-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-xl-offset-16{margin-left:66.6666666667%}.el-col-xl-pull-16{position:relative;right:66.6666666667%}.el-col-xl-push-16{position:relative;left:66.6666666667%}.el-col-xl-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-xl-offset-17{margin-left:70.8333333333%}.el-col-xl-pull-17{position:relative;right:70.8333333333%}.el-col-xl-push-17{position:relative;left:70.8333333333%}.el-col-xl-18{display:block;max-width:75%;flex:0 0 75%}.el-col-xl-offset-18{margin-left:75%}.el-col-xl-pull-18{position:relative;right:75%}.el-col-xl-push-18{position:relative;left:75%}.el-col-xl-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-xl-offset-19{margin-left:79.1666666667%}.el-col-xl-pull-19{position:relative;right:79.1666666667%}.el-col-xl-push-19{position:relative;left:79.1666666667%}.el-col-xl-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-xl-offset-20{margin-left:83.3333333333%}.el-col-xl-pull-20{position:relative;right:83.3333333333%}.el-col-xl-push-20{position:relative;left:83.3333333333%}.el-col-xl-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-xl-offset-21{margin-left:87.5%}.el-col-xl-pull-21{position:relative;right:87.5%}.el-col-xl-push-21{position:relative;left:87.5%}.el-col-xl-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-xl-offset-22{margin-left:91.6666666667%}.el-col-xl-pull-22{position:relative;right:91.6666666667%}.el-col-xl-push-22{position:relative;left:91.6666666667%}.el-col-xl-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-xl-offset-23{margin-left:95.8333333333%}.el-col-xl-pull-23{position:relative;right:95.8333333333%}.el-col-xl-push-23{position:relative;left:95.8333333333%}.el-col-xl-24{display:block;max-width:100%;flex:0 0 100%}.el-col-xl-offset-24{margin-left:100%}.el-col-xl-pull-24{position:relative;right:100%}.el-col-xl-push-24{position:relative;left:100%}}.el-collapse{--el-collapse-border-color:var(--el-border-color-lighter);--el-collapse-header-height:48px;--el-collapse-header-bg-color:var(--el-fill-color-blank);--el-collapse-header-text-color:var(--el-text-color-primary);--el-collapse-header-font-size:13px;--el-collapse-content-bg-color:var(--el-fill-color-blank);--el-collapse-content-font-size:13px;--el-collapse-content-text-color:var(--el-text-color-primary);border-top:1px solid var(--el-collapse-border-color);border-bottom:1px solid var(--el-collapse-border-color)}.el-collapse-item.is-disabled .el-collapse-item__header{color:var(--el-text-color-disabled);cursor:not-allowed}.el-collapse-item__header{display:flex;align-items:center;height:var(--el-collapse-header-height);line-height:var(--el-collapse-header-height);background-color:var(--el-collapse-header-bg-color);color:var(--el-collapse-header-text-color);cursor:pointer;border-bottom:1px solid var(--el-collapse-border-color);font-size:var(--el-collapse-header-font-size);font-weight:500;transition:border-bottom-color var(--el-transition-duration);outline:0}.el-collapse-item__arrow{margin:0 8px 0 auto;transition:transform var(--el-transition-duration);font-weight:300}.el-collapse-item__arrow.is-active{transform:rotate(90deg)}.el-collapse-item__header.focusing:focus:not(:hover){color:var(--el-color-primary)}.el-collapse-item__header.is-active{border-bottom-color:transparent}.el-collapse-item__wrap{will-change:height;background-color:var(--el-collapse-content-bg-color);overflow:hidden;box-sizing:border-box;border-bottom:1px solid var(--el-collapse-border-color)}.el-collapse-item__content{padding-bottom:25px;font-size:var(--el-collapse-content-font-size);color:var(--el-collapse-content-text-color);line-height:1.7692307692}.el-collapse-item:last-child{margin-bottom:-1px}.el-color-predefine{display:flex;font-size:12px;margin-top:8px;width:280px}.el-color-predefine__colors{display:flex;flex:1;flex-wrap:wrap}.el-color-predefine__color-selector{margin:0 0 8px 8px;width:20px;height:20px;border-radius:4px;cursor:pointer}.el-color-predefine__color-selector:nth-child(10n+1){margin-left:0}.el-color-predefine__color-selector.selected{box-shadow:0 0 3px 2px var(--el-color-primary)}.el-color-predefine__color-selector>div{display:flex;height:100%;border-radius:3px}.el-color-predefine__color-selector.is-alpha{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAIAAADZF8uwAAAAGUlEQVQYV2M4gwH+YwCGIasIUwhT25BVBADtzYNYrHvv4gAAAABJRU5ErkJggg==)}.el-color-hue-slider{position:relative;box-sizing:border-box;width:280px;height:12px;background-color:red;padding:0 2px;float:right}.el-color-hue-slider__bar{position:relative;background:linear-gradient(to right,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%);height:100%}.el-color-hue-slider__thumb{position:absolute;cursor:pointer;box-sizing:border-box;left:0;top:0;width:4px;height:100%;border-radius:1px;background:#fff;border:1px solid var(--el-border-color-lighter);box-shadow:0 0 2px #0009;z-index:1}.el-color-hue-slider.is-vertical{width:12px;height:180px;padding:2px 0}.el-color-hue-slider.is-vertical .el-color-hue-slider__bar{background:linear-gradient(to bottom,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%)}.el-color-hue-slider.is-vertical .el-color-hue-slider__thumb{left:0;top:0;width:100%;height:4px}.el-color-svpanel{position:relative;width:280px;height:180px}.el-color-svpanel__black,.el-color-svpanel__white{position:absolute;top:0;left:0;right:0;bottom:0}.el-color-svpanel__white{background:linear-gradient(to right,#fff,rgba(255,255,255,0))}.el-color-svpanel__black{background:linear-gradient(to top,#000,rgba(0,0,0,0))}.el-color-svpanel__cursor{position:absolute}.el-color-svpanel__cursor>div{cursor:head;width:4px;height:4px;box-shadow:0 0 0 1.5px #fff,inset 0 0 1px 1px #0000004d,0 0 1px 2px #0006;border-radius:50%;transform:translate(-2px,-2px)}.el-color-alpha-slider{position:relative;box-sizing:border-box;width:280px;height:12px;background-image:linear-gradient(45deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(45deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%);background-size:12px 12px;background-position:0 0,6px 0,6px -6px,0 6px}.el-color-alpha-slider__bar{position:relative;background:linear-gradient(to right,rgba(255,255,255,0) 0,var(--el-bg-color) 100%);height:100%}.el-color-alpha-slider__thumb{position:absolute;cursor:pointer;box-sizing:border-box;left:0;top:0;width:4px;height:100%;border-radius:1px;background:#fff;border:1px solid var(--el-border-color-lighter);box-shadow:0 0 2px #0009;z-index:1}.el-color-alpha-slider.is-vertical{width:20px;height:180px}.el-color-alpha-slider.is-vertical .el-color-alpha-slider__bar{background:linear-gradient(to bottom,rgba(255,255,255,0) 0,#fff 100%)}.el-color-alpha-slider.is-vertical .el-color-alpha-slider__thumb{left:0;top:0;width:100%;height:4px}.el-color-dropdown{width:300px}.el-color-dropdown__main-wrapper{margin-bottom:6px}.el-color-dropdown__main-wrapper:after{content:"";display:table;clear:both}.el-color-dropdown__btns{margin-top:12px;text-align:right}.el-color-dropdown__value{float:left;line-height:26px;font-size:12px;color:#000;width:160px}.el-color-picker{display:inline-block;position:relative;line-height:normal;outline:0}.el-color-picker:hover:not(.is-disabled) .el-color-picker__trigger{border:1px solid var(--el-border-color-hover)}.el-color-picker:focus-visible:not(.is-disabled) .el-color-picker__trigger{outline:2px solid var(--el-color-primary);outline-offset:1px}.el-color-picker.is-disabled .el-color-picker__trigger{cursor:not-allowed}.el-color-picker--large{height:40px}.el-color-picker--large .el-color-picker__trigger{height:40px;width:40px}.el-color-picker--large .el-color-picker__mask{height:38px;width:38px}.el-color-picker--small{height:24px}.el-color-picker--small .el-color-picker__trigger{height:24px;width:24px}.el-color-picker--small .el-color-picker__mask{height:22px;width:22px}.el-color-picker--small .el-color-picker__empty,.el-color-picker--small .el-color-picker__icon{transform:scale(.8)}.el-color-picker__mask{height:30px;width:30px;border-radius:4px;position:absolute;top:1px;left:1px;z-index:1;cursor:not-allowed;background-color:#ffffffb3}.el-color-picker__trigger{display:inline-flex;justify-content:center;align-items:center;box-sizing:border-box;height:32px;width:32px;padding:4px;border:1px solid var(--el-border-color);border-radius:4px;font-size:0;position:relative;cursor:pointer}.el-color-picker__color{position:relative;display:block;box-sizing:border-box;border:1px solid var(--el-text-color-secondary);border-radius:var(--el-border-radius-small);width:100%;height:100%;text-align:center}.el-color-picker__color.is-alpha{background-image:linear-gradient(45deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(45deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%);background-size:12px 12px;background-position:0 0,6px 0,6px -6px,0 6px}.el-color-picker__color-inner{display:inline-flex;justify-content:center;align-items:center;width:100%;height:100%}.el-color-picker .el-color-picker__empty{font-size:12px;color:var(--el-text-color-secondary)}.el-color-picker .el-color-picker__icon{display:inline-flex;justify-content:center;align-items:center;color:#fff;font-size:12px}.el-color-picker__panel{position:absolute;z-index:10;padding:6px;box-sizing:content-box;background-color:#fff;border-radius:var(--el-border-radius-base);box-shadow:var(--el-box-shadow-light)}.el-color-picker__panel.el-popper{border:1px solid var(--el-border-color-lighter)}.el-color-picker,.el-color-picker__panel{--el-color-picker-alpha-bg-a:#ccc;--el-color-picker-alpha-bg-b:transparent}.dark .el-color-picker,.dark .el-color-picker__panel{--el-color-picker-alpha-bg-a:#333333}.el-container{display:flex;flex-direction:row;flex:1;flex-basis:auto;box-sizing:border-box;min-width:0}.el-container.is-vertical{flex-direction:column}.el-date-table{font-size:12px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-date-table.is-week-mode .el-date-table__row:hover .el-date-table-cell{background-color:var(--el-datepicker-inrange-bg-color)}.el-date-table.is-week-mode .el-date-table__row:hover td.available:hover{color:var(--el-datepicker-text-color)}.el-date-table.is-week-mode .el-date-table__row:hover td:first-child .el-date-table-cell{margin-left:5px;border-top-left-radius:15px;border-bottom-left-radius:15px}.el-date-table.is-week-mode .el-date-table__row:hover td:last-child .el-date-table-cell{margin-right:5px;border-top-right-radius:15px;border-bottom-right-radius:15px}.el-date-table.is-week-mode .el-date-table__row.current .el-date-table-cell{background-color:var(--el-datepicker-inrange-bg-color)}.el-date-table td{width:32px;height:30px;padding:4px 0;box-sizing:border-box;text-align:center;cursor:pointer;position:relative}.el-date-table td .el-date-table-cell{height:30px;padding:3px 0;box-sizing:border-box}.el-date-table td .el-date-table-cell .el-date-table-cell__text{width:24px;height:24px;display:block;margin:0 auto;line-height:24px;position:absolute;left:50%;transform:translate(-50%);border-radius:50%}.el-date-table td.next-month,.el-date-table td.prev-month{color:var(--el-datepicker-off-text-color)}.el-date-table td.today{position:relative}.el-date-table td.today .el-date-table-cell__text{color:var(--el-color-primary);font-weight:700}.el-date-table td.today.end-date .el-date-table-cell__text,.el-date-table td.today.start-date .el-date-table-cell__text{color:#fff}.el-date-table td.available:hover{color:var(--el-datepicker-hover-text-color)}.el-date-table td.in-range .el-date-table-cell{background-color:var(--el-datepicker-inrange-bg-color)}.el-date-table td.in-range .el-date-table-cell:hover{background-color:var(--el-datepicker-inrange-hover-bg-color)}.el-date-table td.current:not(.disabled) .el-date-table-cell__text{color:#fff;background-color:var(--el-datepicker-active-color)}.el-date-table td.current:not(.disabled):focus-visible .el-date-table-cell__text{outline:2px solid var(--el-datepicker-active-color);outline-offset:1px}.el-date-table td.end-date .el-date-table-cell,.el-date-table td.start-date .el-date-table-cell{color:#fff}.el-date-table td.end-date .el-date-table-cell__text,.el-date-table td.start-date .el-date-table-cell__text{background-color:var(--el-datepicker-active-color)}.el-date-table td.start-date .el-date-table-cell{margin-left:5px;border-top-left-radius:15px;border-bottom-left-radius:15px}.el-date-table td.end-date .el-date-table-cell{margin-right:5px;border-top-right-radius:15px;border-bottom-right-radius:15px}.el-date-table td.disabled .el-date-table-cell{background-color:var(--el-fill-color-light);opacity:1;cursor:not-allowed;color:var(--el-text-color-placeholder)}.el-date-table td.selected .el-date-table-cell{margin-left:5px;margin-right:5px;background-color:var(--el-datepicker-inrange-bg-color);border-radius:15px}.el-date-table td.selected .el-date-table-cell:hover{background-color:var(--el-datepicker-inrange-hover-bg-color)}.el-date-table td.selected .el-date-table-cell__text{background-color:var(--el-datepicker-active-color);color:#fff;border-radius:15px}.el-date-table td.week{font-size:80%;color:var(--el-datepicker-header-text-color)}.el-date-table td:focus{outline:0}.el-date-table th{padding:5px;color:var(--el-datepicker-header-text-color);font-weight:400;border-bottom:solid 1px var(--el-border-color-lighter)}.el-month-table{font-size:12px;margin:-1px;border-collapse:collapse}.el-month-table td{text-align:center;padding:8px 0;cursor:pointer}.el-month-table td div{height:48px;padding:6px 0;box-sizing:border-box}.el-month-table td.today .cell{color:var(--el-color-primary);font-weight:700}.el-month-table td.today.end-date .cell,.el-month-table td.today.start-date .cell{color:#fff}.el-month-table td.disabled .cell{background-color:var(--el-fill-color-light);cursor:not-allowed;color:var(--el-text-color-placeholder)}.el-month-table td.disabled .cell:hover{color:var(--el-text-color-placeholder)}.el-month-table td .cell{width:60px;height:36px;display:block;line-height:36px;color:var(--el-datepicker-text-color);margin:0 auto;border-radius:18px}.el-month-table td .cell:hover{color:var(--el-datepicker-hover-text-color)}.el-month-table td.in-range div{background-color:var(--el-datepicker-inrange-bg-color)}.el-month-table td.in-range div:hover{background-color:var(--el-datepicker-inrange-hover-bg-color)}.el-month-table td.end-date div,.el-month-table td.start-date div{color:#fff}.el-month-table td.end-date .cell,.el-month-table td.start-date .cell{color:#fff;background-color:var(--el-datepicker-active-color)}.el-month-table td.start-date div{border-top-left-radius:24px;border-bottom-left-radius:24px}.el-month-table td.end-date div{border-top-right-radius:24px;border-bottom-right-radius:24px}.el-month-table td.current:not(.disabled) .cell{color:var(--el-datepicker-active-color)}.el-month-table td:focus-visible{outline:0}.el-month-table td:focus-visible .cell{outline:2px solid var(--el-datepicker-active-color)}.el-year-table{font-size:12px;margin:-1px;border-collapse:collapse}.el-year-table .el-icon{color:var(--el-datepicker-icon-color)}.el-year-table td{text-align:center;padding:20px 3px;cursor:pointer}.el-year-table td.today .cell{color:var(--el-color-primary);font-weight:700}.el-year-table td.disabled .cell{background-color:var(--el-fill-color-light);cursor:not-allowed;color:var(--el-text-color-placeholder)}.el-year-table td.disabled .cell:hover{color:var(--el-text-color-placeholder)}.el-year-table td .cell{width:48px;height:36px;display:block;line-height:36px;color:var(--el-datepicker-text-color);border-radius:18px;margin:0 auto}.el-year-table td .cell:hover{color:var(--el-datepicker-hover-text-color)}.el-year-table td.current:not(.disabled) .cell{color:var(--el-datepicker-active-color)}.el-year-table td:focus-visible{outline:0}.el-year-table td:focus-visible .cell{outline:2px solid var(--el-datepicker-active-color)}.el-time-spinner.has-seconds .el-time-spinner__wrapper{width:33.3%}.el-time-spinner__wrapper{max-height:192px;overflow:auto;display:inline-block;width:50%;vertical-align:top;position:relative}.el-time-spinner__wrapper.el-scrollbar__wrap:not(.el-scrollbar__wrap--hidden-default){padding-bottom:15px}.el-time-spinner__wrapper.is-arrow{box-sizing:border-box;text-align:center;overflow:hidden}.el-time-spinner__wrapper.is-arrow .el-time-spinner__list{transform:translateY(-32px)}.el-time-spinner__wrapper.is-arrow .el-time-spinner__item:hover:not(.is-disabled):not(.is-active){background:var(--el-fill-color-light);cursor:default}.el-time-spinner__arrow{font-size:12px;color:var(--el-text-color-secondary);position:absolute;left:0;width:100%;z-index:var(--el-index-normal);text-align:center;height:30px;line-height:30px;cursor:pointer}.el-time-spinner__arrow:hover{color:var(--el-color-primary)}.el-time-spinner__arrow.arrow-up{top:10px}.el-time-spinner__arrow.arrow-down{bottom:10px}.el-time-spinner__input.el-input{width:70%}.el-time-spinner__input.el-input .el-input__inner{padding:0;text-align:center}.el-time-spinner__list{padding:0;margin:0;list-style:none;text-align:center}.el-time-spinner__list:after,.el-time-spinner__list:before{content:"";display:block;width:100%;height:80px}.el-time-spinner__item{height:32px;line-height:32px;font-size:12px;color:var(--el-text-color-regular)}.el-time-spinner__item:hover:not(.is-disabled):not(.is-active){background:var(--el-fill-color-light);cursor:pointer}.el-time-spinner__item.is-active:not(.is-disabled){color:var(--el-text-color-primary);font-weight:700}.el-time-spinner__item.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-picker__popper{--el-datepicker-border-color:var(--el-disabled-border-color)}.el-picker__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-datepicker-border-color);box-shadow:var(--el-box-shadow-light)}.el-picker__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-datepicker-border-color)}.el-picker__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-picker__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-picker__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-picker__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-date-editor{--el-date-editor-width:220px;--el-date-editor-monthrange-width:300px;--el-date-editor-daterange-width:350px;--el-date-editor-datetimerange-width:400px;--el-input-text-color:var(--el-text-color-regular);--el-input-border:var(--el-border);--el-input-hover-border:var(--el-border-color-hover);--el-input-focus-border:var(--el-color-primary);--el-input-transparent-border:0 0 0 1px transparent inset;--el-input-border-color:var(--el-border-color);--el-input-border-radius:var(--el-border-radius-base);--el-input-bg-color:var(--el-fill-color-blank);--el-input-icon-color:var(--el-text-color-placeholder);--el-input-placeholder-color:var(--el-text-color-placeholder);--el-input-hover-border-color:var(--el-border-color-hover);--el-input-clear-hover-color:var(--el-text-color-secondary);--el-input-focus-border-color:var(--el-color-primary);position:relative;display:inline-block;text-align:left}.el-date-editor.el-input__wrapper{box-shadow:0 0 0 1px var(--el-input-border-color,var(--el-border-color)) inset}.el-date-editor.el-input__wrapper:hover{box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-date-editor.el-input,.el-date-editor.el-input__wrapper{width:var(--el-date-editor-width);height:var(--el-input-height,var(--el-component-size))}.el-date-editor--monthrange{--el-date-editor-width:var(--el-date-editor-monthrange-width)}.el-date-editor--daterange,.el-date-editor--timerange{--el-date-editor-width:var(--el-date-editor-daterange-width)}.el-date-editor--datetimerange{--el-date-editor-width:var(--el-date-editor-datetimerange-width)}.el-date-editor--dates .el-input__wrapper{text-overflow:ellipsis;white-space:nowrap}.el-date-editor .close-icon,.el-date-editor .clear-icon{cursor:pointer}.el-date-editor .clear-icon:hover{color:var(--el-text-color-secondary)}.el-date-editor .el-range__icon{height:inherit;font-size:14px;color:var(--el-text-color-placeholder);float:left}.el-date-editor .el-range__icon svg{vertical-align:middle}.el-date-editor .el-range-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;outline:0;display:inline-block;height:30px;line-height:30px;margin:0;padding:0;width:39%;text-align:center;font-size:var(--el-font-size-base);color:var(--el-text-color-regular);background-color:transparent}.el-date-editor .el-range-input::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-date-editor .el-range-input:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-date-editor .el-range-input::placeholder{color:var(--el-text-color-placeholder)}.el-date-editor .el-range-separator{flex:1;display:inline-flex;justify-content:center;align-items:center;height:100%;padding:0 5px;margin:0;font-size:14px;word-break:keep-all;color:var(--el-text-color-primary)}.el-date-editor .el-range__close-icon{font-size:14px;color:var(--el-text-color-placeholder);height:inherit;width:unset;cursor:pointer}.el-date-editor .el-range__close-icon:hover{color:var(--el-text-color-secondary)}.el-date-editor .el-range__close-icon svg{vertical-align:middle}.el-date-editor .el-range__close-icon--hidden{opacity:0;visibility:hidden}.el-range-editor.el-input__wrapper{display:inline-flex;align-items:center;padding:0 10px}.el-range-editor.is-active,.el-range-editor.is-active:hover{box-shadow:0 0 0 1px var(--el-input-focus-border-color) inset}.el-range-editor--large{line-height:var(--el-component-size-large)}.el-range-editor--large.el-input__wrapper{height:var(--el-component-size-large)}.el-range-editor--large .el-range-separator{line-height:40px;font-size:14px}.el-range-editor--large .el-range-input{height:38px;line-height:38px;font-size:14px}.el-range-editor--small{line-height:var(--el-component-size-small)}.el-range-editor--small.el-input__wrapper{height:var(--el-component-size-small)}.el-range-editor--small .el-range-separator{line-height:24px;font-size:12px}.el-range-editor--small .el-range-input{height:22px;line-height:22px;font-size:12px}.el-range-editor.is-disabled{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color);color:var(--el-disabled-text-color);cursor:not-allowed}.el-range-editor.is-disabled:focus,.el-range-editor.is-disabled:hover{border-color:var(--el-disabled-border-color)}.el-range-editor.is-disabled input{background-color:var(--el-disabled-bg-color);color:var(--el-disabled-text-color);cursor:not-allowed}.el-range-editor.is-disabled input::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-range-editor.is-disabled input:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-range-editor.is-disabled input::placeholder{color:var(--el-text-color-placeholder)}.el-range-editor.is-disabled .el-range-separator{color:var(--el-disabled-text-color)}.el-picker-panel{color:var(--el-text-color-regular);background:var(--el-bg-color-overlay);border-radius:var(--el-border-radius-base);line-height:30px}.el-picker-panel .el-time-panel{margin:5px 0;border:solid 1px var(--el-datepicker-border-color);background-color:var(--el-bg-color-overlay);box-shadow:var(--el-box-shadow-light)}.el-picker-panel__body-wrapper:after,.el-picker-panel__body:after{content:"";display:table;clear:both}.el-picker-panel__content{position:relative;margin:15px}.el-picker-panel__footer{border-top:1px solid var(--el-datepicker-inner-border-color);padding:4px 12px;text-align:right;background-color:var(--el-bg-color-overlay);position:relative;font-size:0}.el-picker-panel__shortcut{display:block;width:100%;border:0;background-color:transparent;line-height:28px;font-size:14px;color:var(--el-datepicker-text-color);padding-left:12px;text-align:left;outline:0;cursor:pointer}.el-picker-panel__shortcut:hover{color:var(--el-datepicker-hover-text-color)}.el-picker-panel__shortcut.active{background-color:#e6f1fe;color:var(--el-datepicker-active-color)}.el-picker-panel__btn{border:1px solid var(--el-fill-color-darker);color:var(--el-text-color-primary);line-height:24px;border-radius:2px;padding:0 20px;cursor:pointer;background-color:transparent;outline:0;font-size:12px}.el-picker-panel__btn[disabled]{color:var(--el-text-color-disabled);cursor:not-allowed}.el-picker-panel__icon-btn{font-size:12px;color:var(--el-datepicker-icon-color);border:0;background:0 0;cursor:pointer;outline:0;margin-top:8px}.el-picker-panel__icon-btn:hover{color:var(--el-datepicker-hover-text-color)}.el-picker-panel__icon-btn:focus-visible{color:var(--el-datepicker-hover-text-color)}.el-picker-panel__icon-btn.is-disabled{color:var(--el-text-color-disabled)}.el-picker-panel__icon-btn.is-disabled:hover{cursor:not-allowed}.el-picker-panel__icon-btn .el-icon{cursor:pointer;font-size:inherit}.el-picker-panel__link-btn{vertical-align:middle}.el-picker-panel [slot=sidebar],.el-picker-panel__sidebar{position:absolute;top:0;bottom:0;width:110px;border-right:1px solid var(--el-datepicker-inner-border-color);box-sizing:border-box;padding-top:6px;background-color:var(--el-bg-color-overlay);overflow:auto}.el-picker-panel [slot=sidebar]+.el-picker-panel__body,.el-picker-panel__sidebar+.el-picker-panel__body{margin-left:110px}.el-date-picker{--el-datepicker-text-color:var(--el-text-color-regular);--el-datepicker-off-text-color:var(--el-text-color-placeholder);--el-datepicker-header-text-color:var(--el-text-color-regular);--el-datepicker-icon-color:var(--el-text-color-primary);--el-datepicker-border-color:var(--el-disabled-border-color);--el-datepicker-inner-border-color:var(--el-border-color-light);--el-datepicker-inrange-bg-color:var(--el-border-color-extra-light);--el-datepicker-inrange-hover-bg-color:var(--el-border-color-extra-light);--el-datepicker-active-color:var(--el-color-primary);--el-datepicker-hover-text-color:var(--el-color-primary)}.el-date-picker{width:322px}.el-date-picker.has-sidebar.has-time{width:434px}.el-date-picker.has-sidebar{width:438px}.el-date-picker.has-time .el-picker-panel__body-wrapper{position:relative}.el-date-picker .el-picker-panel__content{width:292px}.el-date-picker table{table-layout:fixed;width:100%}.el-date-picker__editor-wrap{position:relative;display:table-cell;padding:0 5px}.el-date-picker__time-header{position:relative;border-bottom:1px solid var(--el-datepicker-inner-border-color);font-size:12px;padding:8px 5px 5px;display:table;width:100%;box-sizing:border-box}.el-date-picker__header{margin:12px;text-align:center}.el-date-picker__header--bordered{margin-bottom:0;padding-bottom:12px;border-bottom:solid 1px var(--el-border-color-lighter)}.el-date-picker__header--bordered+.el-picker-panel__content{margin-top:0}.el-date-picker__header-label{font-size:16px;font-weight:500;padding:0 5px;line-height:22px;text-align:center;cursor:pointer;color:var(--el-text-color-regular)}.el-date-picker__header-label:hover{color:var(--el-datepicker-hover-text-color)}.el-date-picker__header-label:focus-visible{outline:0;color:var(--el-datepicker-hover-text-color)}.el-date-picker__header-label.active{color:var(--el-datepicker-active-color)}.el-date-picker__prev-btn{float:left}.el-date-picker__next-btn{float:right}.el-date-picker__time-wrap{padding:10px;text-align:center}.el-date-picker__time-label{float:left;cursor:pointer;line-height:30px;margin-left:10px}.el-date-picker .el-time-panel{position:absolute}.el-date-range-picker{--el-datepicker-text-color:var(--el-text-color-regular);--el-datepicker-off-text-color:var(--el-text-color-placeholder);--el-datepicker-header-text-color:var(--el-text-color-regular);--el-datepicker-icon-color:var(--el-text-color-primary);--el-datepicker-border-color:var(--el-disabled-border-color);--el-datepicker-inner-border-color:var(--el-border-color-light);--el-datepicker-inrange-bg-color:var(--el-border-color-extra-light);--el-datepicker-inrange-hover-bg-color:var(--el-border-color-extra-light);--el-datepicker-active-color:var(--el-color-primary);--el-datepicker-hover-text-color:var(--el-color-primary)}.el-date-range-picker{width:646px}.el-date-range-picker.has-sidebar{width:756px}.el-date-range-picker.has-time .el-picker-panel__body-wrapper{position:relative}.el-date-range-picker table{table-layout:fixed;width:100%}.el-date-range-picker .el-picker-panel__body{min-width:513px}.el-date-range-picker .el-picker-panel__content{margin:0}.el-date-range-picker__header{position:relative;text-align:center;height:28px}.el-date-range-picker__header [class*=arrow-left]{float:left}.el-date-range-picker__header [class*=arrow-right]{float:right}.el-date-range-picker__header div{font-size:16px;font-weight:500;margin-right:50px}.el-date-range-picker__content{float:left;width:50%;box-sizing:border-box;margin:0;padding:16px}.el-date-range-picker__content.is-left{border-right:1px solid var(--el-datepicker-inner-border-color)}.el-date-range-picker__content .el-date-range-picker__header div{margin-left:50px;margin-right:50px}.el-date-range-picker__editors-wrap{box-sizing:border-box;display:table-cell}.el-date-range-picker__editors-wrap.is-right{text-align:right}.el-date-range-picker__time-header{position:relative;border-bottom:1px solid var(--el-datepicker-inner-border-color);font-size:12px;padding:8px 5px 5px;display:table;width:100%;box-sizing:border-box}.el-date-range-picker__time-header>.el-icon-arrow-right{font-size:20px;vertical-align:middle;display:table-cell;color:var(--el-datepicker-icon-color)}.el-date-range-picker__time-picker-wrap{position:relative;display:table-cell;padding:0 5px}.el-date-range-picker__time-picker-wrap .el-picker-panel{position:absolute;top:13px;right:0;z-index:1;background:#fff}.el-date-range-picker__time-picker-wrap .el-time-panel{position:absolute}.el-time-range-picker{width:354px;overflow:visible}.el-time-range-picker__content{position:relative;text-align:center;padding:10px;z-index:1}.el-time-range-picker__cell{box-sizing:border-box;margin:0;padding:4px 7px 7px;width:50%;display:inline-block}.el-time-range-picker__header{margin-bottom:5px;text-align:center;font-size:14px}.el-time-range-picker__body{border-radius:2px;border:1px solid var(--el-datepicker-border-color)}.el-time-panel{border-radius:2px;position:relative;width:180px;left:0;z-index:var(--el-index-top);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;box-sizing:content-box}.el-time-panel__content{font-size:0;position:relative;overflow:hidden}.el-time-panel__content:after,.el-time-panel__content:before{content:"";top:50%;position:absolute;margin-top:-16px;height:32px;z-index:-1;left:0;right:0;box-sizing:border-box;padding-top:6px;text-align:left}.el-time-panel__content:after{left:50%;margin-left:12%;margin-right:12%}.el-time-panel__content:before{padding-left:50%;margin-right:12%;margin-left:12%;border-top:1px solid var(--el-border-color-light);border-bottom:1px solid var(--el-border-color-light)}.el-time-panel__content.has-seconds:after{left:66.6666666667%}.el-time-panel__content.has-seconds:before{padding-left:33.3333333333%}.el-time-panel__footer{border-top:1px solid var(--el-timepicker-inner-border-color,var(--el-border-color-light));padding:4px;height:36px;line-height:25px;text-align:right;box-sizing:border-box}.el-time-panel__btn{border:none;line-height:28px;padding:0 5px;margin:0 5px;cursor:pointer;background-color:transparent;outline:0;font-size:12px;color:var(--el-text-color-primary)}.el-time-panel__btn.confirm{font-weight:800;color:var(--el-timepicker-active-color,var(--el-color-primary))}.el-descriptions{--el-descriptions-table-border:1px solid var(--el-border-color-lighter);--el-descriptions-item-bordered-label-background:var(--el-fill-color-light);box-sizing:border-box;font-size:var(--el-font-size-base);color:var(--el-text-color-primary)}.el-descriptions__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.el-descriptions__title{color:var(--el-text-color-primary);font-size:16px;font-weight:700}.el-descriptions__body{background-color:var(--el-fill-color-blank)}.el-descriptions__body .el-descriptions__table{border-collapse:collapse;width:100%}.el-descriptions__body .el-descriptions__table .el-descriptions__cell{box-sizing:border-box;text-align:left;font-weight:400;line-height:23px;font-size:14px}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-left{text-align:left}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-center{text-align:center}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-right{text-align:right}.el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{border:var(--el-descriptions-table-border);padding:8px 11px}.el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:12px}.el-descriptions--large{font-size:14px}.el-descriptions--large .el-descriptions__header{margin-bottom:20px}.el-descriptions--large .el-descriptions__header .el-descriptions__title{font-size:16px}.el-descriptions--large .el-descriptions__body .el-descriptions__table .el-descriptions__cell{font-size:14px}.el-descriptions--large .el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{padding:12px 15px}.el-descriptions--large .el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:16px}.el-descriptions--small{font-size:12px}.el-descriptions--small .el-descriptions__header{margin-bottom:12px}.el-descriptions--small .el-descriptions__header .el-descriptions__title{font-size:14px}.el-descriptions--small .el-descriptions__body .el-descriptions__table .el-descriptions__cell{font-size:12px}.el-descriptions--small .el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{padding:4px 7px}.el-descriptions--small .el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:8px}.el-descriptions__label.el-descriptions__cell.is-bordered-label{font-weight:700;color:var(--el-text-color-regular);background:var(--el-descriptions-item-bordered-label-background)}.el-descriptions__label:not(.is-bordered-label){color:var(--el-text-color-primary);margin-right:16px}.el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:6px}.el-descriptions__content.el-descriptions__cell.is-bordered-content{color:var(--el-text-color-primary)}.el-descriptions__content:not(.is-bordered-label){color:var(--el-text-color-regular)}.el-descriptions--large .el-descriptions__label:not(.is-bordered-label){margin-right:16px}.el-descriptions--large .el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:8px}.el-descriptions--small .el-descriptions__label:not(.is-bordered-label){margin-right:12px}.el-descriptions--small .el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:4px}:root{--el-popup-modal-bg-color:var(--el-color-black);--el-popup-modal-opacity:.5}.v-modal-enter{-webkit-animation:v-modal-in var(--el-transition-duration-fast) ease;animation:v-modal-in var(--el-transition-duration-fast) ease}.v-modal-leave{-webkit-animation:v-modal-out var(--el-transition-duration-fast) ease forwards;animation:v-modal-out var(--el-transition-duration-fast) ease forwards}@-webkit-keyframes v-modal-in{0%{opacity:0}}@keyframes v-modal-in{0%{opacity:0}}@-webkit-keyframes v-modal-out{to{opacity:0}}@keyframes v-modal-out{to{opacity:0}}.v-modal{position:fixed;left:0;top:0;width:100%;height:100%;opacity:var(--el-popup-modal-opacity);background:var(--el-popup-modal-bg-color)}.el-popup-parent--hidden{overflow:hidden}.el-dialog{--el-dialog-width:50%;--el-dialog-margin-top:15vh;--el-dialog-bg-color:var(--el-bg-color);--el-dialog-box-shadow:var(--el-box-shadow);--el-dialog-title-font-size:var(--el-font-size-large);--el-dialog-content-font-size:14px;--el-dialog-font-line-height:var(--el-font-line-height-primary);--el-dialog-padding-primary:20px;--el-dialog-border-radius:var(--el-border-radius-small);position:relative;margin:var(--el-dialog-margin-top,15vh) auto 50px;background:var(--el-dialog-bg-color);border-radius:var(--el-dialog-border-radius);box-shadow:var(--el-dialog-box-shadow);box-sizing:border-box;width:var(--el-dialog-width,50%)}.el-dialog:focus{outline:0!important}.el-dialog.is-align-center{margin:auto}.el-dialog.is-fullscreen{--el-dialog-width:100%;--el-dialog-margin-top:0;margin-bottom:0;height:100%;overflow:auto}.el-dialog__wrapper{position:fixed;top:0;right:0;bottom:0;left:0;overflow:auto;margin:0}.el-dialog.is-draggable .el-dialog__header{cursor:move;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-dialog__header{padding:var(--el-dialog-padding-primary);padding-bottom:10px;margin-right:16px}.el-dialog__headerbtn{position:absolute;top:6px;right:0;padding:0;width:54px;height:54px;background:0 0;border:none;outline:0;cursor:pointer;font-size:var(--el-message-close-size,16px)}.el-dialog__headerbtn .el-dialog__close{color:var(--el-color-info);font-size:inherit}.el-dialog__headerbtn:focus .el-dialog__close,.el-dialog__headerbtn:hover .el-dialog__close{color:var(--el-color-primary)}.el-dialog__title{line-height:var(--el-dialog-font-line-height);font-size:var(--el-dialog-title-font-size);color:var(--el-text-color-primary)}.el-dialog__body{padding:calc(var(--el-dialog-padding-primary) + 10px) var(--el-dialog-padding-primary);color:var(--el-text-color-regular);font-size:var(--el-dialog-content-font-size)}.el-dialog__footer{padding:var(--el-dialog-padding-primary);padding-top:10px;text-align:right;box-sizing:border-box}.el-dialog--center{text-align:center}.el-dialog--center .el-dialog__body{text-align:initial;padding:25px calc(var(--el-dialog-padding-primary) + 5px) 30px}.el-dialog--center .el-dialog__footer{text-align:inherit}.el-overlay-dialog{position:fixed;top:0;right:0;bottom:0;left:0;overflow:auto}.dialog-fade-enter-active{-webkit-animation:modal-fade-in var(--el-transition-duration);animation:modal-fade-in var(--el-transition-duration)}.dialog-fade-enter-active .el-overlay-dialog{-webkit-animation:dialog-fade-in var(--el-transition-duration);animation:dialog-fade-in var(--el-transition-duration)}.dialog-fade-leave-active{-webkit-animation:modal-fade-out var(--el-transition-duration);animation:modal-fade-out var(--el-transition-duration)}.dialog-fade-leave-active .el-overlay-dialog{-webkit-animation:dialog-fade-out var(--el-transition-duration);animation:dialog-fade-out var(--el-transition-duration)}@-webkit-keyframes dialog-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@keyframes dialog-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@-webkit-keyframes dialog-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@keyframes dialog-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@-webkit-keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@-webkit-keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}@keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}.el-divider{position:relative}.el-divider--horizontal{display:block;height:1px;width:100%;margin:24px 0;border-top:1px var(--el-border-color) var(--el-border-style)}.el-divider--vertical{display:inline-block;width:1px;height:1em;margin:0 8px;vertical-align:middle;position:relative;border-left:1px var(--el-border-color) var(--el-border-style)}.el-divider__text{position:absolute;background-color:var(--el-bg-color);padding:0 20px;font-weight:500;color:var(--el-text-color-primary);font-size:14px}.el-divider__text.is-left{left:20px;transform:translateY(-50%)}.el-divider__text.is-center{left:50%;transform:translate(-50%) translateY(-50%)}.el-divider__text.is-right{right:20px;transform:translateY(-50%)}.el-drawer{--el-drawer-bg-color:var(--el-dialog-bg-color, var(--el-bg-color));--el-drawer-padding-primary:var(--el-dialog-padding-primary, 20px)}.el-drawer{position:absolute;box-sizing:border-box;background-color:var(--el-drawer-bg-color);display:flex;flex-direction:column;box-shadow:var(--el-box-shadow-dark);overflow:hidden;transition:all var(--el-transition-duration)}.el-drawer .rtl,.el-drawer .ltr,.el-drawer .ttb,.el-drawer .btt{transform:translate(0)}.el-drawer__sr-focus:focus{outline:0!important}.el-drawer__header{align-items:center;color:#72767b;display:flex;margin-bottom:32px;padding:var(--el-drawer-padding-primary);padding-bottom:0}.el-drawer__header>:first-child{flex:1}.el-drawer__title{margin:0;flex:1;line-height:inherit;font-size:1rem}.el-drawer__footer{padding:var(--el-drawer-padding-primary);padding-top:10px;text-align:right}.el-drawer__close-btn{display:inline-flex;border:none;cursor:pointer;font-size:var(--el-font-size-extra-large);color:inherit;background-color:transparent;outline:0}.el-drawer__close-btn:focus i,.el-drawer__close-btn:hover i{color:var(--el-color-primary)}.el-drawer__body{flex:1;padding:var(--el-drawer-padding-primary);overflow:auto}.el-drawer__body>*{box-sizing:border-box}.el-drawer.ltr,.el-drawer.rtl{height:100%;top:0;bottom:0}.el-drawer.btt,.el-drawer.ttb{width:100%;left:0;right:0}.el-drawer.ltr{left:0}.el-drawer.rtl{right:0}.el-drawer.ttb{top:0}.el-drawer.btt{bottom:0}.el-drawer-fade-enter-active,.el-drawer-fade-leave-active{transition:all var(--el-transition-duration)}.el-drawer-fade-enter-active,.el-drawer-fade-enter-from,.el-drawer-fade-enter-to,.el-drawer-fade-leave-active,.el-drawer-fade-leave-from,.el-drawer-fade-leave-to{overflow:hidden!important}.el-drawer-fade-enter-from,.el-drawer-fade-leave-to{opacity:0}.el-drawer-fade-enter-to,.el-drawer-fade-leave-from{opacity:1}.el-drawer-fade-enter-from .rtl,.el-drawer-fade-leave-to .rtl{transform:translate(100%)}.el-drawer-fade-enter-from .ltr,.el-drawer-fade-leave-to .ltr{transform:translate(-100%)}.el-drawer-fade-enter-from .ttb,.el-drawer-fade-leave-to .ttb{transform:translateY(-100%)}.el-drawer-fade-enter-from .btt,.el-drawer-fade-leave-to .btt{transform:translateY(100%)}.el-dropdown{--el-dropdown-menu-box-shadow:var(--el-box-shadow-light);--el-dropdown-menuItem-hover-fill:var(--el-color-primary-light-9);--el-dropdown-menuItem-hover-color:var(--el-color-primary);--el-dropdown-menu-index:10;display:inline-flex;position:relative;color:var(--el-text-color-regular);font-size:var(--el-font-size-base);line-height:1;vertical-align:top}.el-dropdown.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-dropdown__popper{--el-dropdown-menu-box-shadow:var(--el-box-shadow-light);--el-dropdown-menuItem-hover-fill:var(--el-color-primary-light-9);--el-dropdown-menuItem-hover-color:var(--el-color-primary);--el-dropdown-menu-index:10}.el-dropdown__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-dropdown-menu-box-shadow)}.el-dropdown__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-dropdown__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-dropdown__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-dropdown__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-dropdown__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-dropdown__popper .el-dropdown-menu{border:none}.el-dropdown__popper .el-dropdown__popper-selfdefine{outline:0}.el-dropdown__popper .el-scrollbar__bar{z-index:calc(var(--el-dropdown-menu-index) + 1)}.el-dropdown__popper .el-dropdown__list{list-style:none;padding:0;margin:0;box-sizing:border-box}.el-dropdown .el-dropdown__caret-button{padding-left:0;padding-right:0;display:inline-flex;justify-content:center;align-items:center;width:32px;border-left:none}.el-dropdown .el-dropdown__caret-button>span{display:inline-flex}.el-dropdown .el-dropdown__caret-button:before{content:"";position:absolute;display:block;width:1px;top:-1px;bottom:-1px;left:0;background:var(--el-overlay-color-lighter)}.el-dropdown .el-dropdown__caret-button.el-button:before{background:var(--el-border-color);opacity:.5}.el-dropdown .el-dropdown__caret-button .el-dropdown__icon{font-size:inherit;padding-left:0}.el-dropdown .el-dropdown-selfdefine{outline:0}.el-dropdown--large .el-dropdown__caret-button{width:40px}.el-dropdown--small .el-dropdown__caret-button{width:24px}.el-dropdown-menu{position:relative;top:0;left:0;z-index:var(--el-dropdown-menu-index);padding:5px 0;margin:0;background-color:var(--el-bg-color-overlay);border:none;border-radius:var(--el-border-radius-base);box-shadow:none;list-style:none}.el-dropdown-menu__item{display:flex;align-items:center;white-space:nowrap;list-style:none;line-height:22px;padding:5px 16px;margin:0;font-size:var(--el-font-size-base);color:var(--el-text-color-regular);cursor:pointer;outline:0}.el-dropdown-menu__item:not(.is-disabled):focus{background-color:var(--el-dropdown-menuItem-hover-fill);color:var(--el-dropdown-menuItem-hover-color)}.el-dropdown-menu__item i{margin-right:5px}.el-dropdown-menu__item--divided{margin:6px 0;border-top:1px solid var(--el-border-color-lighter)}.el-dropdown-menu__item.is-disabled{cursor:not-allowed;color:var(--el-text-color-disabled)}.el-dropdown-menu--large{padding:7px 0}.el-dropdown-menu--large .el-dropdown-menu__item{padding:7px 20px;line-height:22px;font-size:14px}.el-dropdown-menu--large .el-dropdown-menu__item--divided{margin:8px 0}.el-dropdown-menu--small{padding:3px 0}.el-dropdown-menu--small .el-dropdown-menu__item{padding:2px 12px;line-height:20px;font-size:12px}.el-dropdown-menu--small .el-dropdown-menu__item--divided{margin:4px 0}.el-empty{--el-empty-padding:40px 0;--el-empty-image-width:160px;--el-empty-description-margin-top:20px;--el-empty-bottom-margin-top:20px;--el-empty-fill-color-0:var(--el-color-white);--el-empty-fill-color-1:#fcfcfd;--el-empty-fill-color-2:#f8f9fb;--el-empty-fill-color-3:#f7f8fc;--el-empty-fill-color-4:#eeeff3;--el-empty-fill-color-5:#edeef2;--el-empty-fill-color-6:#e9ebef;--el-empty-fill-color-7:#e5e7e9;--el-empty-fill-color-8:#e0e3e9;--el-empty-fill-color-9:#d5d7de;display:flex;justify-content:center;align-items:center;flex-direction:column;text-align:center;box-sizing:border-box;padding:var(--el-empty-padding)}.el-empty__image{width:var(--el-empty-image-width)}.el-empty__image img{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;width:100%;height:100%;vertical-align:top;-o-object-fit:contain;object-fit:contain}.el-empty__image svg{color:var(--el-svg-monochrome-grey);fill:currentColor;width:100%;height:100%;vertical-align:top}.el-empty__description{margin-top:var(--el-empty-description-margin-top)}.el-empty__description p{margin:0;font-size:var(--el-font-size-base);color:var(--el-text-color-secondary)}.el-empty__bottom{margin-top:var(--el-empty-bottom-margin-top)}.el-footer{--el-footer-padding:0 20px;--el-footer-height:60px;padding:var(--el-footer-padding);box-sizing:border-box;flex-shrink:0;height:var(--el-footer-height)}.el-form{--el-form-label-font-size:var(--el-font-size-base)}.el-form--label-left .el-form-item__label{justify-content:flex-start}.el-form--label-top .el-form-item{display:block}.el-form--label-top .el-form-item .el-form-item__label{display:block;height:auto;text-align:left;margin-bottom:8px;line-height:22px}.el-form--inline .el-form-item{display:inline-flex;vertical-align:middle;margin-right:32px}.el-form--inline.el-form--label-top{display:flex;flex-wrap:wrap}.el-form--inline.el-form--label-top .el-form-item{display:block}.el-form--large.el-form--label-top .el-form-item .el-form-item__label{margin-bottom:12px;line-height:22px}.el-form--default.el-form--label-top .el-form-item .el-form-item__label{margin-bottom:8px;line-height:22px}.el-form--small.el-form--label-top .el-form-item .el-form-item__label{margin-bottom:4px;line-height:20px}.el-form-item{display:flex;--font-size:14px;margin-bottom:18px}.el-form-item .el-form-item{margin-bottom:0}.el-form-item .el-input__validateIcon{display:none}.el-form-item--large{--font-size:14px;--el-form-label-font-size:var(--font-size);margin-bottom:22px}.el-form-item--large .el-form-item__label{height:40px;line-height:40px}.el-form-item--large .el-form-item__content{line-height:40px}.el-form-item--large .el-form-item__error{padding-top:4px}.el-form-item--default{--font-size:14px;--el-form-label-font-size:var(--font-size);margin-bottom:18px}.el-form-item--default .el-form-item__label{height:32px;line-height:32px}.el-form-item--default .el-form-item__content{line-height:32px}.el-form-item--default .el-form-item__error{padding-top:2px}.el-form-item--small{--font-size:12px;--el-form-label-font-size:var(--font-size);margin-bottom:18px}.el-form-item--small .el-form-item__label{height:24px;line-height:24px}.el-form-item--small .el-form-item__content{line-height:24px}.el-form-item--small .el-form-item__error{padding-top:2px}.el-form-item__label-wrap{display:flex}.el-form-item__label{display:inline-flex;justify-content:flex-end;align-items:flex-start;flex:0 0 auto;font-size:var(--el-form-label-font-size);color:var(--el-text-color-regular);height:32px;line-height:32px;padding:0 12px 0 0;box-sizing:border-box}.el-form-item__content{display:flex;flex-wrap:wrap;align-items:center;flex:1;line-height:32px;position:relative;font-size:var(--font-size);min-width:0}.el-form-item__content .el-input-group{vertical-align:top}.el-form-item__error{color:var(--el-color-danger);font-size:12px;line-height:1;padding-top:2px;position:absolute;top:100%;left:0}.el-form-item__error--inline{position:relative;top:auto;left:auto;display:inline-block;margin-left:10px}.el-form-item.is-required:not(.is-no-asterisk).asterisk-left>.el-form-item__label-wrap>.el-form-item__label:before,.el-form-item.is-required:not(.is-no-asterisk).asterisk-left>.el-form-item__label:before{content:"*";color:var(--el-color-danger);margin-right:4px}.el-form-item.is-required:not(.is-no-asterisk).asterisk-right>.el-form-item__label-wrap>.el-form-item__label:after,.el-form-item.is-required:not(.is-no-asterisk).asterisk-right>.el-form-item__label:after{content:"*";color:var(--el-color-danger);margin-left:4px}.el-form-item.is-error .el-select-v2__wrapper,.el-form-item.is-error .el-select-v2__wrapper:focus,.el-form-item.is-error .el-textarea__inner,.el-form-item.is-error .el-textarea__inner:focus{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-form-item.is-error .el-input__wrapper{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-form-item.is-error .el-input-group__append .el-input__wrapper,.el-form-item.is-error .el-input-group__prepend .el-input__wrapper{box-shadow:0 0 0 1px transparent inset}.el-form-item.is-error .el-input__validateIcon{color:var(--el-color-danger)}.el-form-item--feedback .el-input__validateIcon{display:inline-flex}.el-header{--el-header-padding:0 20px;--el-header-height:60px;padding:var(--el-header-padding);box-sizing:border-box;flex-shrink:0;height:var(--el-header-height)}.el-image-viewer__wrapper{position:fixed;top:0;right:0;bottom:0;left:0}.el-image-viewer__btn{position:absolute;z-index:1;display:flex;align-items:center;justify-content:center;border-radius:50%;opacity:.8;cursor:pointer;box-sizing:border-box;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-image-viewer__btn .el-icon{font-size:inherit;cursor:pointer}.el-image-viewer__close{top:40px;right:40px;width:40px;height:40px;font-size:40px}.el-image-viewer__canvas{position:static;width:100%;height:100%;display:flex;justify-content:center;align-items:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-image-viewer__actions{left:50%;bottom:30px;transform:translate(-50%);width:282px;height:44px;padding:0 23px;background-color:var(--el-text-color-regular);border-color:#fff;border-radius:22px}.el-image-viewer__actions__inner{width:100%;height:100%;text-align:justify;cursor:default;font-size:23px;color:#fff;display:flex;align-items:center;justify-content:space-around}.el-image-viewer__prev{top:50%;transform:translateY(-50%);left:40px;width:44px;height:44px;font-size:24px;color:#fff;background-color:var(--el-text-color-regular);border-color:#fff}.el-image-viewer__next{top:50%;transform:translateY(-50%);right:40px;text-indent:2px;width:44px;height:44px;font-size:24px;color:#fff;background-color:var(--el-text-color-regular);border-color:#fff}.el-image-viewer__close{width:44px;height:44px;font-size:24px;color:#fff;background-color:var(--el-text-color-regular);border-color:#fff}.el-image-viewer__mask{position:absolute;width:100%;height:100%;top:0;left:0;opacity:.5;background:#000}.viewer-fade-enter-active{-webkit-animation:viewer-fade-in var(--el-transition-duration);animation:viewer-fade-in var(--el-transition-duration)}.viewer-fade-leave-active{-webkit-animation:viewer-fade-out var(--el-transition-duration);animation:viewer-fade-out var(--el-transition-duration)}@-webkit-keyframes viewer-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@keyframes viewer-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@-webkit-keyframes viewer-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@keyframes viewer-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}.el-image__error,.el-image__inner,.el-image__placeholder,.el-image__wrapper{width:100%;height:100%}.el-image{position:relative;display:inline-block;overflow:hidden}.el-image__inner{vertical-align:top;opacity:1}.el-image__inner.is-loading{opacity:0}.el-image__wrapper{position:absolute;top:0;left:0}.el-image__placeholder{background:var(--el-fill-color-light)}.el-image__error{display:flex;justify-content:center;align-items:center;font-size:14px;background:var(--el-fill-color-light);color:var(--el-text-color-placeholder);vertical-align:middle}.el-image__preview{cursor:pointer}.el-input-number{position:relative;display:inline-flex;width:150px;line-height:30px}.el-input-number .el-input__wrapper{padding-left:42px;padding-right:42px}.el-input-number .el-input__inner{-webkit-appearance:none;-moz-appearance:textfield;text-align:center;line-height:1}.el-input-number .el-input__inner::-webkit-inner-spin-button,.el-input-number .el-input__inner::-webkit-outer-spin-button{margin:0;-webkit-appearance:none}.el-input-number__decrease,.el-input-number__increase{display:flex;justify-content:center;align-items:center;height:auto;position:absolute;z-index:1;top:1px;bottom:1px;width:32px;background:var(--el-fill-color-light);color:var(--el-text-color-regular);cursor:pointer;font-size:13px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-input-number__decrease:hover,.el-input-number__increase:hover{color:var(--el-color-primary)}.el-input-number__decrease:hover~.el-input:not(.is-disabled) .el-input_wrapper,.el-input-number__increase:hover~.el-input:not(.is-disabled) .el-input_wrapper{box-shadow:0 0 0 1px var(--el-input-focus-border-color,var(--el-color-primary)) inset}.el-input-number__decrease.is-disabled,.el-input-number__increase.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-input-number__increase{right:1px;border-radius:0 var(--el-border-radius-base) var(--el-border-radius-base) 0;border-left:var(--el-border)}.el-input-number__decrease{left:1px;border-radius:var(--el-border-radius-base) 0 0 var(--el-border-radius-base);border-right:var(--el-border)}.el-input-number.is-disabled .el-input-number__decrease,.el-input-number.is-disabled .el-input-number__increase{border-color:var(--el-disabled-border-color);color:var(--el-disabled-border-color)}.el-input-number.is-disabled .el-input-number__decrease:hover,.el-input-number.is-disabled .el-input-number__increase:hover{color:var(--el-disabled-border-color);cursor:not-allowed}.el-input-number--large{width:180px;line-height:38px}.el-input-number--large .el-input-number__decrease,.el-input-number--large .el-input-number__increase{width:40px;font-size:14px}.el-input-number--large .el-input__wrapper{padding-left:47px;padding-right:47px}.el-input-number--small{width:120px;line-height:22px}.el-input-number--small .el-input-number__decrease,.el-input-number--small .el-input-number__increase{width:24px;font-size:12px}.el-input-number--small .el-input__wrapper{padding-left:31px;padding-right:31px}.el-input-number--small .el-input-number__decrease [class*=el-icon],.el-input-number--small .el-input-number__increase [class*=el-icon]{transform:scale(.9)}.el-input-number.is-without-controls .el-input__wrapper{padding-left:15px;padding-right:15px}.el-input-number.is-controls-right .el-input__wrapper{padding-left:15px;padding-right:42px}.el-input-number.is-controls-right .el-input-number__decrease,.el-input-number.is-controls-right .el-input-number__increase{--el-input-number-controls-height:15px;height:var(--el-input-number-controls-height);line-height:var(--el-input-number-controls-height)}.el-input-number.is-controls-right .el-input-number__decrease [class*=el-icon],.el-input-number.is-controls-right .el-input-number__increase [class*=el-icon]{transform:scale(.8)}.el-input-number.is-controls-right .el-input-number__increase{bottom:auto;left:auto;border-radius:0 var(--el-border-radius-base) 0 0;border-bottom:var(--el-border)}.el-input-number.is-controls-right .el-input-number__decrease{right:1px;top:auto;left:auto;border-right:none;border-left:var(--el-border);border-radius:0 0 var(--el-border-radius-base) 0}.el-input-number.is-controls-right[class*=large] [class*=decrease],.el-input-number.is-controls-right[class*=large] [class*=increase]{--el-input-number-controls-height:19px}.el-input-number.is-controls-right[class*=small] [class*=decrease],.el-input-number.is-controls-right[class*=small] [class*=increase]{--el-input-number-controls-height:11px}.el-textarea{--el-input-text-color:var(--el-text-color-regular);--el-input-border:var(--el-border);--el-input-hover-border:var(--el-border-color-hover);--el-input-focus-border:var(--el-color-primary);--el-input-transparent-border:0 0 0 1px transparent inset;--el-input-border-color:var(--el-border-color);--el-input-border-radius:var(--el-border-radius-base);--el-input-bg-color:var(--el-fill-color-blank);--el-input-icon-color:var(--el-text-color-placeholder);--el-input-placeholder-color:var(--el-text-color-placeholder);--el-input-hover-border-color:var(--el-border-color-hover);--el-input-clear-hover-color:var(--el-text-color-secondary);--el-input-focus-border-color:var(--el-color-primary)}.el-textarea{position:relative;display:inline-block;width:100%;vertical-align:bottom;font-size:var(--el-font-size-base)}.el-textarea__inner{position:relative;display:block;resize:vertical;padding:5px 11px;line-height:1.5;box-sizing:border-box;width:100%;font-size:inherit;font-family:inherit;color:var(--el-input-text-color,var(--el-text-color-regular));background-color:var(--el-input-bg-color,var(--el-fill-color-blank));background-image:none;-webkit-appearance:none;box-shadow:0 0 0 1px var(--el-input-border-color,var(--el-border-color)) inset;border-radius:var(--el-input-border-radius,var(--el-border-radius-base));transition:var(--el-transition-box-shadow);border:none}.el-textarea__inner::-moz-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-textarea__inner:-ms-input-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-textarea__inner::placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-textarea__inner:hover{box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-textarea__inner:focus{outline:0;box-shadow:0 0 0 1px var(--el-input-focus-border-color) inset}.el-textarea .el-input__count{color:var(--el-color-info);background:var(--el-fill-color-blank);position:absolute;font-size:12px;line-height:14px;bottom:5px;right:10px}.el-textarea.is-disabled .el-textarea__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color);color:var(--el-disabled-text-color);cursor:not-allowed}.el-textarea.is-disabled .el-textarea__inner::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-textarea.is-disabled .el-textarea__inner:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-textarea.is-disabled .el-textarea__inner::placeholder{color:var(--el-text-color-placeholder)}.el-textarea.is-exceed .el-textarea__inner{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-textarea.is-exceed .el-input__count{color:var(--el-color-danger)}.el-input{--el-input-text-color:var(--el-text-color-regular);--el-input-border:var(--el-border);--el-input-hover-border:var(--el-border-color-hover);--el-input-focus-border:var(--el-color-primary);--el-input-transparent-border:0 0 0 1px transparent inset;--el-input-border-color:var(--el-border-color);--el-input-border-radius:var(--el-border-radius-base);--el-input-bg-color:var(--el-fill-color-blank);--el-input-icon-color:var(--el-text-color-placeholder);--el-input-placeholder-color:var(--el-text-color-placeholder);--el-input-hover-border-color:var(--el-border-color-hover);--el-input-clear-hover-color:var(--el-text-color-secondary);--el-input-focus-border-color:var(--el-color-primary)}.el-input{--el-input-height:var(--el-component-size);position:relative;font-size:var(--el-font-size-base);display:inline-flex;width:100%;line-height:var(--el-input-height);box-sizing:border-box;vertical-align:middle}.el-input::-webkit-scrollbar{z-index:11;width:6px}.el-input::-webkit-scrollbar:horizontal{height:6px}.el-input::-webkit-scrollbar-thumb{border-radius:5px;width:6px;background:var(--el-text-color-disabled)}.el-input::-webkit-scrollbar-corner{background:var(--el-fill-color-blank)}.el-input::-webkit-scrollbar-track{background:var(--el-fill-color-blank)}.el-input::-webkit-scrollbar-track-piece{background:var(--el-fill-color-blank);width:6px}.el-input .el-input__clear,.el-input .el-input__password{color:var(--el-input-icon-color);font-size:14px;cursor:pointer}.el-input .el-input__clear:hover,.el-input .el-input__password:hover{color:var(--el-input-clear-hover-color)}.el-input .el-input__count{height:100%;display:inline-flex;align-items:center;color:var(--el-color-info);font-size:12px}.el-input .el-input__count .el-input__count-inner{background:var(--el-fill-color-blank);line-height:initial;display:inline-block;padding-left:8px}.el-input__wrapper{display:inline-flex;flex-grow:1;align-items:center;justify-content:center;padding:1px 11px;background-color:var(--el-input-bg-color,var(--el-fill-color-blank));background-image:none;border-radius:var(--el-input-border-radius,var(--el-border-radius-base));transition:var(--el-transition-box-shadow);transform:translateZ(0);box-shadow:0 0 0 1px var(--el-input-border-color,var(--el-border-color)) inset}.el-input__wrapper:hover{box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-input__wrapper.is-focus{box-shadow:0 0 0 1px var(--el-input-focus-border-color) inset}.el-input__inner{--el-input-inner-height:calc(var(--el-input-height, 32px) - 2px);width:100%;flex-grow:1;-webkit-appearance:none;color:var(--el-input-text-color,var(--el-text-color-regular));font-size:inherit;height:var(--el-input-inner-height);line-height:var(--el-input-inner-height);padding:0;outline:0;border:none;background:0 0;box-sizing:border-box}.el-input__inner:focus{outline:0}.el-input__inner::-moz-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-input__inner:-ms-input-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-input__inner::placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-input__inner[type=password]::-ms-reveal{display:none}.el-input__prefix{display:inline-flex;white-space:nowrap;flex-shrink:0;flex-wrap:nowrap;height:100%;text-align:center;color:var(--el-input-icon-color,var(--el-text-color-placeholder));transition:all var(--el-transition-duration);pointer-events:none}.el-input__prefix-inner{pointer-events:all;display:inline-flex;align-items:center;justify-content:center}.el-input__prefix-inner>:last-child{margin-right:8px}.el-input__prefix-inner>:first-child,.el-input__prefix-inner>:first-child.el-input__icon{margin-left:0}.el-input__suffix{display:inline-flex;white-space:nowrap;flex-shrink:0;flex-wrap:nowrap;height:100%;text-align:center;color:var(--el-input-icon-color,var(--el-text-color-placeholder));transition:all var(--el-transition-duration);pointer-events:none}.el-input__suffix-inner{pointer-events:all;display:inline-flex;align-items:center;justify-content:center}.el-input__suffix-inner>:first-child{margin-left:8px}.el-input .el-input__icon{height:inherit;line-height:inherit;display:flex;justify-content:center;align-items:center;transition:all var(--el-transition-duration);margin-left:8px}.el-input__validateIcon{pointer-events:none}.el-input.is-active .el-input__wrapper{box-shadow:0 0 0 1px var(--el-input-focus-color,) inset}.el-input.is-disabled{cursor:not-allowed}.el-input.is-disabled .el-input__wrapper{background-color:var(--el-disabled-bg-color);box-shadow:0 0 0 1px var(--el-disabled-border-color) inset}.el-input.is-disabled .el-input__inner{color:var(--el-disabled-text-color);-webkit-text-fill-color:var(--el-disabled-text-color);cursor:not-allowed}.el-input.is-disabled .el-input__inner::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-input.is-disabled .el-input__inner:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-input.is-disabled .el-input__inner::placeholder{color:var(--el-text-color-placeholder)}.el-input.is-disabled .el-input__icon{cursor:not-allowed}.el-input.is-exceed .el-input__wrapper{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-input.is-exceed .el-input__suffix .el-input__count{color:var(--el-color-danger)}.el-input--large{--el-input-height:var(--el-component-size-large);font-size:14px}.el-input--large .el-input__wrapper{padding:1px 15px}.el-input--large .el-input__inner{--el-input-inner-height:calc(var(--el-input-height, 40px) - 2px)}.el-input--small{--el-input-height:var(--el-component-size-small);font-size:12px}.el-input--small .el-input__wrapper{padding:1px 7px}.el-input--small .el-input__inner{--el-input-inner-height:calc(var(--el-input-height, 24px) - 2px)}.el-input-group{display:inline-flex;width:100%;align-items:stretch}.el-input-group__append,.el-input-group__prepend{background-color:var(--el-fill-color-light);color:var(--el-color-info);position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:100%;border-radius:var(--el-input-border-radius);padding:0 20px;white-space:nowrap}.el-input-group__append:focus,.el-input-group__prepend:focus{outline:0}.el-input-group__append .el-button,.el-input-group__append .el-select,.el-input-group__prepend .el-button,.el-input-group__prepend .el-select{display:inline-block;margin:0 -20px}.el-input-group__append button.el-button,.el-input-group__append button.el-button:hover,.el-input-group__append div.el-select .el-input__wrapper,.el-input-group__append div.el-select:hover .el-input__wrapper,.el-input-group__prepend button.el-button,.el-input-group__prepend button.el-button:hover,.el-input-group__prepend div.el-select .el-input__wrapper,.el-input-group__prepend div.el-select:hover .el-input__wrapper{border-color:transparent;background-color:transparent;color:inherit}.el-input-group__append .el-button,.el-input-group__append .el-input,.el-input-group__prepend .el-button,.el-input-group__prepend .el-input{font-size:inherit}.el-input-group__prepend{border-right:0;border-top-right-radius:0;border-bottom-right-radius:0;box-shadow:1px 0 0 0 var(--el-input-border-color) inset,0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset}.el-input-group__append{border-left:0;border-top-left-radius:0;border-bottom-left-radius:0;box-shadow:0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset,-1px 0 0 0 var(--el-input-border-color) inset}.el-input-group--prepend>.el-input__wrapper{border-top-left-radius:0;border-bottom-left-radius:0}.el-input-group--prepend .el-input-group__prepend .el-select .el-input .el-input__inner{box-shadow:none!important}.el-input-group--prepend .el-input-group__prepend .el-select .el-input .el-input__wrapper{border-top-right-radius:0;border-bottom-right-radius:0;box-shadow:1px 0 0 0 var(--el-input-border-color) inset,0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset}.el-input-group--prepend .el-input-group__prepend .el-select .el-input.is-focus .el-input__inner{box-shadow:none!important}.el-input-group--prepend .el-input-group__prepend .el-select .el-input.is-focus .el-input__wrapper{box-shadow:1px 0 0 0 var(--el-input-focus-border-color) inset,1px 0 0 0 var(--el-input-focus-border-color),0 1px 0 0 var(--el-input-focus-border-color) inset,0 -1px 0 0 var(--el-input-focus-border-color) inset!important;z-index:2}.el-input-group--prepend .el-input-group__prepend .el-select .el-input.is-focus .el-input__wrapper:focus{outline:0;z-index:2;box-shadow:1px 0 0 0 var(--el-input-focus-border-color) inset,1px 0 0 0 var(--el-input-focus-border-color),0 1px 0 0 var(--el-input-focus-border-color) inset,0 -1px 0 0 var(--el-input-focus-border-color) inset!important}.el-input-group--prepend .el-input-group__prepend .el-select:hover .el-input__inner{box-shadow:none!important}.el-input-group--prepend .el-input-group__prepend .el-select:hover .el-input__wrapper{z-index:1;box-shadow:1px 0 0 0 var(--el-input-hover-border-color) inset,1px 0 0 0 var(--el-input-hover-border-color),0 1px 0 0 var(--el-input-hover-border-color) inset,0 -1px 0 0 var(--el-input-hover-border-color) inset!important}.el-input-group--append>.el-input__wrapper{border-top-right-radius:0;border-bottom-right-radius:0}.el-input-group--append .el-input-group__append .el-select .el-input .el-input__inner{box-shadow:none!important}.el-input-group--append .el-input-group__append .el-select .el-input .el-input__wrapper{border-top-left-radius:0;border-bottom-left-radius:0;box-shadow:0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset,-1px 0 0 0 var(--el-input-border-color) inset}.el-input-group--append .el-input-group__append .el-select .el-input.is-focus .el-input__inner{box-shadow:none!important}.el-input-group--append .el-input-group__append .el-select .el-input.is-focus .el-input__wrapper{z-index:2;box-shadow:-1px 0 0 0 var(--el-input-focus-border-color),-1px 0 0 0 var(--el-input-focus-border-color) inset,0 1px 0 0 var(--el-input-focus-border-color) inset,0 -1px 0 0 var(--el-input-focus-border-color) inset!important}.el-input-group--append .el-input-group__append .el-select:hover .el-input__inner{box-shadow:none!important}.el-input-group--append .el-input-group__append .el-select:hover .el-input__wrapper{z-index:1;box-shadow:-1px 0 0 0 var(--el-input-hover-border-color),-1px 0 0 0 var(--el-input-hover-border-color) inset,0 1px 0 0 var(--el-input-hover-border-color) inset,0 -1px 0 0 var(--el-input-hover-border-color) inset!important}.el-link{--el-link-font-size:var(--el-font-size-base);--el-link-font-weight:var(--el-font-weight-primary);--el-link-text-color:var(--el-text-color-regular);--el-link-hover-text-color:var(--el-color-primary);--el-link-disabled-text-color:var(--el-text-color-placeholder)}.el-link{display:inline-flex;flex-direction:row;align-items:center;justify-content:center;vertical-align:middle;position:relative;text-decoration:none;outline:0;cursor:pointer;padding:0;font-size:var(--el-link-font-size);font-weight:var(--el-link-font-weight);color:var(--el-link-text-color)}.el-link:hover{color:var(--el-link-hover-text-color)}.el-link.is-underline:hover:after{content:"";position:absolute;left:0;right:0;height:0;bottom:0;border-bottom:1px solid var(--el-link-hover-text-color)}.el-link.is-disabled{color:var(--el-link-disabled-text-color);cursor:not-allowed}.el-link [class*=el-icon-]+span{margin-left:5px}.el-link.el-link--default:after{border-color:var(--el-link-hover-text-color)}.el-link__inner{display:inline-flex;justify-content:center;align-items:center}.el-link.el-link--primary{--el-link-text-color:var(--el-color-primary);--el-link-hover-text-color:var(--el-color-primary-light-3);--el-link-disabled-text-color:var(--el-color-primary-light-5)}.el-link.el-link--primary:after{border-color:var(--el-link-text-color)}.el-link.el-link--primary.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--success{--el-link-text-color:var(--el-color-success);--el-link-hover-text-color:var(--el-color-success-light-3);--el-link-disabled-text-color:var(--el-color-success-light-5)}.el-link.el-link--success:after{border-color:var(--el-link-text-color)}.el-link.el-link--success.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--warning{--el-link-text-color:var(--el-color-warning);--el-link-hover-text-color:var(--el-color-warning-light-3);--el-link-disabled-text-color:var(--el-color-warning-light-5)}.el-link.el-link--warning:after{border-color:var(--el-link-text-color)}.el-link.el-link--warning.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--danger{--el-link-text-color:var(--el-color-danger);--el-link-hover-text-color:var(--el-color-danger-light-3);--el-link-disabled-text-color:var(--el-color-danger-light-5)}.el-link.el-link--danger:after{border-color:var(--el-link-text-color)}.el-link.el-link--danger.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--error{--el-link-text-color:var(--el-color-error);--el-link-hover-text-color:var(--el-color-error-light-3);--el-link-disabled-text-color:var(--el-color-error-light-5)}.el-link.el-link--error:after{border-color:var(--el-link-text-color)}.el-link.el-link--error.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--info{--el-link-text-color:var(--el-color-info);--el-link-hover-text-color:var(--el-color-info-light-3);--el-link-disabled-text-color:var(--el-color-info-light-5)}.el-link.el-link--info:after{border-color:var(--el-link-text-color)}.el-link.el-link--info.is-underline:hover:after{border-color:var(--el-link-text-color)}:root{--el-loading-spinner-size:42px;--el-loading-fullscreen-spinner-size:50px}.el-loading-parent--relative{position:relative!important}.el-loading-parent--hidden{overflow:hidden!important}.el-loading-mask{position:absolute;z-index:2000;background-color:var(--el-mask-color);margin:0;top:0;right:0;bottom:0;left:0;transition:opacity var(--el-transition-duration)}.el-loading-mask.is-fullscreen{position:fixed}.el-loading-mask.is-fullscreen .el-loading-spinner{margin-top:calc((0px - var(--el-loading-fullscreen-spinner-size))/ 2)}.el-loading-mask.is-fullscreen .el-loading-spinner .circular{height:var(--el-loading-fullscreen-spinner-size);width:var(--el-loading-fullscreen-spinner-size)}.el-loading-spinner{top:50%;margin-top:calc((0px - var(--el-loading-spinner-size))/ 2);width:100%;text-align:center;position:absolute}.el-loading-spinner .el-loading-text{color:var(--el-color-primary);margin:3px 0;font-size:14px}.el-loading-spinner .circular{display:inline;height:var(--el-loading-spinner-size);width:var(--el-loading-spinner-size);-webkit-animation:loading-rotate 2s linear infinite;animation:loading-rotate 2s linear infinite}.el-loading-spinner .path{-webkit-animation:loading-dash 1.5s ease-in-out infinite;animation:loading-dash 1.5s ease-in-out infinite;stroke-dasharray:90,150;stroke-dashoffset:0;stroke-width:2;stroke:var(--el-color-primary);stroke-linecap:round}.el-loading-spinner i{color:var(--el-color-primary)}.el-loading-fade-enter-from,.el-loading-fade-leave-to{opacity:0}@-webkit-keyframes loading-rotate{to{transform:rotate(360deg)}}@keyframes loading-rotate{to{transform:rotate(360deg)}}@-webkit-keyframes loading-dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-40px}to{stroke-dasharray:90,150;stroke-dashoffset:-120px}}@keyframes loading-dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-40px}to{stroke-dasharray:90,150;stroke-dashoffset:-120px}}.el-main{--el-main-padding:20px;display:block;flex:1;flex-basis:auto;overflow:auto;box-sizing:border-box;padding:var(--el-main-padding)}:root{--el-menu-active-color:var(--el-color-primary);--el-menu-text-color:var(--el-text-color-primary);--el-menu-hover-text-color:var(--el-color-primary);--el-menu-bg-color:var(--el-fill-color-blank);--el-menu-hover-bg-color:var(--el-color-primary-light-9);--el-menu-item-height:56px;--el-menu-sub-item-height:calc(var(--el-menu-item-height) - 6px);--el-menu-horizontal-sub-item-height:36px;--el-menu-item-font-size:var(--el-font-size-base);--el-menu-item-hover-fill:var(--el-color-primary-light-9);--el-menu-border-color:var(--el-border-color);--el-menu-base-level-padding:20px;--el-menu-level-padding:20px;--el-menu-icon-width:24px}.el-menu{border-right:solid 1px var(--el-menu-border-color);list-style:none;position:relative;margin:0;padding-left:0;background-color:var(--el-menu-bg-color);box-sizing:border-box}.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-menu-item,.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-menu-item-group__title,.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-sub-menu__title{white-space:nowrap;padding-left:calc(var(--el-menu-base-level-padding) + var(--el-menu-level) * var(--el-menu-level-padding))}.el-menu--horizontal{display:flex;flex-wrap:nowrap;border-bottom:solid 1px var(--el-menu-border-color);border-right:none}.el-menu--horizontal>.el-menu-item{display:inline-flex;justify-content:center;align-items:center;height:100%;margin:0;border-bottom:2px solid transparent;color:var(--el-menu-text-color)}.el-menu--horizontal>.el-menu-item a,.el-menu--horizontal>.el-menu-item a:hover{color:inherit}.el-menu--horizontal>.el-menu-item:not(.is-disabled):focus,.el-menu--horizontal>.el-menu-item:not(.is-disabled):hover{background-color:#fff}.el-menu--horizontal>.el-sub-menu:focus,.el-menu--horizontal>.el-sub-menu:hover{outline:0}.el-menu--horizontal>.el-sub-menu:hover .el-sub-menu__title{color:var(--el-menu-hover-text-color)}.el-menu--horizontal>.el-sub-menu.is-active .el-sub-menu__title{border-bottom:2px solid var(--el-menu-active-color);color:var(--el-menu-active-color)}.el-menu--horizontal>.el-sub-menu .el-sub-menu__title{height:100%;border-bottom:2px solid transparent;color:var(--el-menu-text-color)}.el-menu--horizontal>.el-sub-menu .el-sub-menu__title:hover{background-color:var(--el-bg-color-overlay)}.el-menu--horizontal .el-menu .el-menu-item,.el-menu--horizontal .el-menu .el-sub-menu__title{background-color:var(--el-menu-bg-color);display:flex;align-items:center;height:var(--el-menu-horizontal-sub-item-height);line-height:var(--el-menu-horizontal-sub-item-height);padding:0 10px;color:var(--el-menu-text-color)}.el-menu--horizontal .el-menu .el-sub-menu__title{padding-right:40px}.el-menu--horizontal .el-menu .el-menu-item.is-active,.el-menu--horizontal .el-menu .el-sub-menu.is-active>.el-sub-menu__title{color:var(--el-menu-active-color)}.el-menu--horizontal .el-menu-item:not(.is-disabled):focus,.el-menu--horizontal .el-menu-item:not(.is-disabled):hover{outline:0;color:var(--el-menu-hover-text-color);background-color:var(--el-menu-hover-bg-color)}.el-menu--horizontal>.el-menu-item.is-active{border-bottom:2px solid var(--el-menu-active-color);color:var(--el-menu-active-color)!important}.el-menu--collapse{width:calc(var(--el-menu-icon-width) + var(--el-menu-base-level-padding) * 2)}.el-menu--collapse>.el-menu-item [class^=el-icon],.el-menu--collapse>.el-menu-item-group>ul>.el-sub-menu>.el-sub-menu__title [class^=el-icon],.el-menu--collapse>.el-sub-menu>.el-sub-menu__title [class^=el-icon]{margin:0;vertical-align:middle;width:var(--el-menu-icon-width);text-align:center}.el-menu--collapse>.el-menu-item .el-sub-menu__icon-arrow,.el-menu--collapse>.el-menu-item-group>ul>.el-sub-menu>.el-sub-menu__title .el-sub-menu__icon-arrow,.el-menu--collapse>.el-sub-menu>.el-sub-menu__title .el-sub-menu__icon-arrow{display:none}.el-menu--collapse>.el-menu-item-group>ul>.el-sub-menu>.el-sub-menu__title>span,.el-menu--collapse>.el-menu-item>span,.el-menu--collapse>.el-sub-menu>.el-sub-menu__title>span{height:0;width:0;overflow:hidden;visibility:hidden;display:inline-block}.el-menu--collapse>.el-menu-item.is-active i{color:inherit}.el-menu--collapse .el-menu .el-sub-menu{min-width:200px}.el-menu--popup{z-index:100;min-width:200px;border:none;padding:5px 0;border-radius:var(--el-border-radius-small);box-shadow:var(--el-box-shadow-light)}.el-menu .el-icon{flex-shrink:0}.el-menu-item{display:flex;align-items:center;height:var(--el-menu-item-height);line-height:var(--el-menu-item-height);font-size:var(--el-menu-item-font-size);color:var(--el-menu-text-color);padding:0 var(--el-menu-base-level-padding);list-style:none;cursor:pointer;position:relative;transition:border-color var(--el-transition-duration),background-color var(--el-transition-duration),color var(--el-transition-duration);box-sizing:border-box;white-space:nowrap}.el-menu-item *{vertical-align:bottom}.el-menu-item i{color:inherit}.el-menu-item:focus,.el-menu-item:hover{outline:0}.el-menu-item:hover{background-color:var(--el-menu-hover-bg-color)}.el-menu-item.is-disabled{opacity:.25;cursor:not-allowed;background:0 0!important}.el-menu-item [class^=el-icon]{margin-right:5px;width:var(--el-menu-icon-width);text-align:center;font-size:18px;vertical-align:middle}.el-menu-item.is-active{color:var(--el-menu-active-color)}.el-menu-item.is-active i{color:inherit}.el-menu-item .el-menu-tooltip__trigger{position:absolute;left:0;top:0;height:100%;width:100%;display:inline-flex;align-items:center;box-sizing:border-box;padding:0 var(--el-menu-base-level-padding)}.el-sub-menu{list-style:none;margin:0;padding-left:0}.el-sub-menu__title{display:flex;align-items:center;height:var(--el-menu-item-height);line-height:var(--el-menu-item-height);font-size:var(--el-menu-item-font-size);color:var(--el-menu-text-color);padding:0 var(--el-menu-base-level-padding);list-style:none;cursor:pointer;position:relative;transition:border-color var(--el-transition-duration),background-color var(--el-transition-duration),color var(--el-transition-duration);box-sizing:border-box;white-space:nowrap;padding-right:calc(var(--el-menu-base-level-padding) + var(--el-menu-icon-width))}.el-sub-menu__title *{vertical-align:bottom}.el-sub-menu__title i{color:inherit}.el-sub-menu__title:focus,.el-sub-menu__title:hover{outline:0}.el-sub-menu__title.is-disabled{opacity:.25;cursor:not-allowed;background:0 0!important}.el-sub-menu__title:hover{background-color:var(--el-menu-hover-bg-color)}.el-sub-menu .el-menu{border:none}.el-sub-menu .el-menu-item{height:var(--el-menu-sub-item-height);line-height:var(--el-menu-sub-item-height)}.el-sub-menu__hide-arrow .el-sub-menu__icon-arrow{display:none!important}.el-sub-menu.is-active .el-sub-menu__title{border-bottom-color:var(--el-menu-active-color)}.el-sub-menu.is-disabled .el-menu-item,.el-sub-menu.is-disabled .el-sub-menu__title{opacity:.25;cursor:not-allowed;background:0 0!important}.el-sub-menu .el-icon{vertical-align:middle;margin-right:5px;width:var(--el-menu-icon-width);text-align:center;font-size:18px}.el-sub-menu .el-icon.el-sub-menu__icon-more{margin-right:0!important}.el-sub-menu .el-sub-menu__icon-arrow{position:absolute;top:50%;right:var(--el-menu-base-level-padding);margin-top:-6px;transition:transform var(--el-transition-duration);font-size:12px;margin-right:0;width:inherit}.el-menu-item-group>ul{padding:0}.el-menu-item-group__title{padding:7px 0 7px var(--el-menu-base-level-padding);line-height:normal;font-size:12px;color:var(--el-text-color-secondary)}.horizontal-collapse-transition .el-sub-menu__title .el-sub-menu__icon-arrow{transition:var(--el-transition-duration-fast);opacity:0}.el-message-box{--el-messagebox-title-color:var(--el-text-color-primary);--el-messagebox-width:420px;--el-messagebox-border-radius:4px;--el-messagebox-font-size:var(--el-font-size-large);--el-messagebox-content-font-size:var(--el-font-size-base);--el-messagebox-content-color:var(--el-text-color-regular);--el-messagebox-error-font-size:12px;--el-messagebox-padding-primary:15px}.el-message-box{display:inline-block;max-width:var(--el-messagebox-width);width:100%;padding-bottom:10px;vertical-align:middle;background-color:var(--el-bg-color);border-radius:var(--el-messagebox-border-radius);border:1px solid var(--el-border-color-lighter);font-size:var(--el-messagebox-font-size);box-shadow:var(--el-box-shadow-light);text-align:left;overflow:hidden;-webkit-backface-visibility:hidden;backface-visibility:hidden;box-sizing:border-box}.el-message-box:focus{outline:0!important}.el-overlay.is-message-box .el-overlay-message-box{text-align:center;position:fixed;top:0;right:0;bottom:0;left:0;padding:16px;overflow:auto}.el-overlay.is-message-box .el-overlay-message-box:after{content:"";display:inline-block;height:100%;width:0;vertical-align:middle}.el-message-box.is-draggable .el-message-box__header{cursor:move;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-message-box__header{position:relative;padding:var(--el-messagebox-padding-primary);padding-bottom:10px}.el-message-box__title{padding-left:0;margin-bottom:0;font-size:var(--el-messagebox-font-size);line-height:1;color:var(--el-messagebox-title-color)}.el-message-box__headerbtn{position:absolute;top:var(--el-messagebox-padding-primary);right:var(--el-messagebox-padding-primary);padding:0;border:none;outline:0;background:0 0;font-size:var(--el-message-close-size,16px);cursor:pointer}.el-message-box__headerbtn .el-message-box__close{color:var(--el-color-info);font-size:inherit}.el-message-box__headerbtn:focus .el-message-box__close,.el-message-box__headerbtn:hover .el-message-box__close{color:var(--el-color-primary)}.el-message-box__content{padding:10px var(--el-messagebox-padding-primary);color:var(--el-messagebox-content-color);font-size:var(--el-messagebox-content-font-size)}.el-message-box__container{position:relative}.el-message-box__input{padding-top:15px}.el-message-box__input div.invalid>input{border-color:var(--el-color-error)}.el-message-box__input div.invalid>input:focus{border-color:var(--el-color-error)}.el-message-box__status{position:absolute;top:50%;transform:translateY(-50%);font-size:24px!important}.el-message-box__status:before{padding-left:1px}.el-message-box__status.el-icon{position:absolute}.el-message-box__status+.el-message-box__message{padding-left:36px;padding-right:12px;word-break:break-word}.el-message-box__status.el-message-box-icon--success{--el-messagebox-color:var(--el-color-success);color:var(--el-messagebox-color)}.el-message-box__status.el-message-box-icon--info{--el-messagebox-color:var(--el-color-info);color:var(--el-messagebox-color)}.el-message-box__status.el-message-box-icon--warning{--el-messagebox-color:var(--el-color-warning);color:var(--el-messagebox-color)}.el-message-box__status.el-message-box-icon--error{--el-messagebox-color:var(--el-color-error);color:var(--el-messagebox-color)}.el-message-box__message{margin:0}.el-message-box__message p{margin:0;line-height:24px}.el-message-box__errormsg{color:var(--el-color-error);font-size:var(--el-messagebox-error-font-size);min-height:18px;margin-top:2px}.el-message-box__btns{padding:5px 15px 0;display:flex;flex-wrap:wrap;justify-content:flex-end;align-items:center}.el-message-box__btns button:nth-child(2){margin-left:10px}.el-message-box__btns-reverse{flex-direction:row-reverse}.el-message-box--center .el-message-box__title{position:relative;display:flex;align-items:center;justify-content:center}.el-message-box--center .el-message-box__status{position:relative;top:auto;padding-right:5px;text-align:center;transform:translateY(-1px)}.el-message-box--center .el-message-box__message{margin-left:0}.el-message-box--center .el-message-box__btns{justify-content:center}.el-message-box--center .el-message-box__content{padding-left:calc(var(--el-messagebox-padding-primary) + 12px);padding-right:calc(var(--el-messagebox-padding-primary) + 12px);text-align:center}.fade-in-linear-enter-active .el-overlay-message-box{-webkit-animation:msgbox-fade-in var(--el-transition-duration);animation:msgbox-fade-in var(--el-transition-duration)}.fade-in-linear-leave-active .el-overlay-message-box{animation:msgbox-fade-in var(--el-transition-duration) reverse}@-webkit-keyframes msgbox-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@keyframes msgbox-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@-webkit-keyframes msgbox-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@keyframes msgbox-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}.el-message{--el-message-bg-color:var(--el-color-info-light-9);--el-message-border-color:var(--el-border-color-lighter);--el-message-padding:15px 19px;--el-message-close-size:16px;--el-message-close-icon-color:var(--el-text-color-placeholder);--el-message-close-hover-color:var(--el-text-color-secondary)}.el-message{width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;max-width:calc(100% - 32px);box-sizing:border-box;border-radius:var(--el-border-radius-base);border-width:var(--el-border-width);border-style:var(--el-border-style);border-color:var(--el-message-border-color);position:fixed;left:50%;top:20px;transform:translate(-50%);background-color:var(--el-message-bg-color);transition:opacity var(--el-transition-duration),transform .4s,top .4s;padding:var(--el-message-padding);display:flex;align-items:center}.el-message.is-center{justify-content:center}.el-message.is-closable .el-message__content{padding-right:31px}.el-message p{margin:0}.el-message--success{--el-message-bg-color:var(--el-color-success-light-9);--el-message-border-color:var(--el-color-success-light-8);--el-message-text-color:var(--el-color-success)}.el-message--success .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--success{color:var(--el-message-text-color)}.el-message--info{--el-message-bg-color:var(--el-color-info-light-9);--el-message-border-color:var(--el-color-info-light-8);--el-message-text-color:var(--el-color-info)}.el-message--info .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--info{color:var(--el-message-text-color)}.el-message--warning{--el-message-bg-color:var(--el-color-warning-light-9);--el-message-border-color:var(--el-color-warning-light-8);--el-message-text-color:var(--el-color-warning)}.el-message--warning .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--warning{color:var(--el-message-text-color)}.el-message--error{--el-message-bg-color:var(--el-color-error-light-9);--el-message-border-color:var(--el-color-error-light-8);--el-message-text-color:var(--el-color-error)}.el-message--error .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--error{color:var(--el-message-text-color)}.el-message__icon{margin-right:10px}.el-message .el-message__badge{position:absolute;top:-8px;right:-8px}.el-message__content{padding:0;font-size:14px;line-height:1}.el-message__content:focus{outline-width:0}.el-message .el-message__closeBtn{position:absolute;top:50%;right:19px;transform:translateY(-50%);cursor:pointer;color:var(--el-message-close-icon-color);font-size:var(--el-message-close-size)}.el-message .el-message__closeBtn:focus{outline-width:0}.el-message .el-message__closeBtn:hover{color:var(--el-message-close-hover-color)}.el-message-fade-enter-from,.el-message-fade-leave-to{opacity:0;transform:translate(-50%,-100%)}.el-notification{--el-notification-width:330px;--el-notification-padding:14px 26px 14px 13px;--el-notification-radius:8px;--el-notification-shadow:var(--el-box-shadow-light);--el-notification-border-color:var(--el-border-color-lighter);--el-notification-icon-size:24px;--el-notification-close-font-size:var(--el-message-close-size, 16px);--el-notification-group-margin-left:13px;--el-notification-group-margin-right:8px;--el-notification-content-font-size:var(--el-font-size-base);--el-notification-content-color:var(--el-text-color-regular);--el-notification-title-font-size:16px;--el-notification-title-color:var(--el-text-color-primary);--el-notification-close-color:var(--el-text-color-secondary);--el-notification-close-hover-color:var(--el-text-color-regular)}.el-notification{display:flex;width:var(--el-notification-width);padding:var(--el-notification-padding);border-radius:var(--el-notification-radius);box-sizing:border-box;border:1px solid var(--el-notification-border-color);position:fixed;background-color:var(--el-bg-color-overlay);box-shadow:var(--el-notification-shadow);transition:opacity var(--el-transition-duration),transform var(--el-transition-duration),left var(--el-transition-duration),right var(--el-transition-duration),top .4s,bottom var(--el-transition-duration);overflow-wrap:anywhere;overflow:hidden;z-index:9999}.el-notification.right{right:16px}.el-notification.left{left:16px}.el-notification__group{margin-left:var(--el-notification-group-margin-left);margin-right:var(--el-notification-group-margin-right)}.el-notification__title{font-weight:700;font-size:var(--el-notification-title-font-size);line-height:var(--el-notification-icon-size);color:var(--el-notification-title-color);margin:0}.el-notification__content{font-size:var(--el-notification-content-font-size);line-height:24px;margin:6px 0 0;color:var(--el-notification-content-color);text-align:justify}.el-notification__content p{margin:0}.el-notification .el-notification__icon{height:var(--el-notification-icon-size);width:var(--el-notification-icon-size);font-size:var(--el-notification-icon-size)}.el-notification .el-notification__closeBtn{position:absolute;top:18px;right:15px;cursor:pointer;color:var(--el-notification-close-color);font-size:var(--el-notification-close-font-size)}.el-notification .el-notification__closeBtn:hover{color:var(--el-notification-close-hover-color)}.el-notification .el-notification--success{--el-notification-icon-color:var(--el-color-success);color:var(--el-notification-icon-color)}.el-notification .el-notification--info{--el-notification-icon-color:var(--el-color-info);color:var(--el-notification-icon-color)}.el-notification .el-notification--warning{--el-notification-icon-color:var(--el-color-warning);color:var(--el-notification-icon-color)}.el-notification .el-notification--error{--el-notification-icon-color:var(--el-color-error);color:var(--el-notification-icon-color)}.el-notification-fade-enter-from.right{right:0;transform:translate(100%)}.el-notification-fade-enter-from.left{left:0;transform:translate(-100%)}.el-notification-fade-leave-to{opacity:0}.el-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;height:100%;background-color:var(--el-overlay-color-lighter);overflow:auto}.el-overlay .el-overlay-root{height:0}.el-page-header.is-contentful .el-page-header__main{border-top:1px solid var(--el-border-color-light);margin-top:16px}.el-page-header__header{display:flex;align-items:center;justify-content:space-between;line-height:24px}.el-page-header__left{display:flex;align-items:center;margin-right:40px;position:relative}.el-page-header__back{display:flex;align-items:center;cursor:pointer}.el-page-header__left .el-divider--vertical{margin:0 16px}.el-page-header__icon{font-size:16px;margin-right:10px;display:flex;align-items:center}.el-page-header__icon .el-icon{font-size:inherit}.el-page-header__title{font-size:14px;font-weight:500}.el-page-header__content{font-size:18px;color:var(--el-text-color-primary)}.el-page-header__breadcrumb{margin-bottom:16px}.el-pagination{--el-pagination-font-size:14px;--el-pagination-bg-color:var(--el-fill-color-blank);--el-pagination-text-color:var(--el-text-color-primary);--el-pagination-border-radius:2px;--el-pagination-button-color:var(--el-text-color-primary);--el-pagination-button-width:32px;--el-pagination-button-height:32px;--el-pagination-button-disabled-color:var(--el-text-color-placeholder);--el-pagination-button-disabled-bg-color:var(--el-fill-color-blank);--el-pagination-button-bg-color:var(--el-fill-color);--el-pagination-hover-color:var(--el-color-primary);--el-pagination-font-size-small:12px;--el-pagination-button-width-small:24px;--el-pagination-button-height-small:24px;--el-pagination-item-gap:16px;white-space:nowrap;color:var(--el-pagination-text-color);font-size:var(--el-pagination-font-size);font-weight:400;display:flex;align-items:center}.el-pagination .el-input__inner{text-align:center;-moz-appearance:textfield}.el-pagination .el-select .el-input{width:128px}.el-pagination button{display:flex;justify-content:center;align-items:center;font-size:var(--el-pagination-font-size);min-width:var(--el-pagination-button-width);height:var(--el-pagination-button-height);line-height:var(--el-pagination-button-height);color:var(--el-pagination-button-color);background:var(--el-pagination-bg-color);padding:0 4px;border:none;border-radius:var(--el-pagination-border-radius);cursor:pointer;text-align:center;box-sizing:border-box}.el-pagination button *{pointer-events:none}.el-pagination button:focus{outline:0}.el-pagination button:hover{color:var(--el-pagination-hover-color)}.el-pagination button.is-active{color:var(--el-pagination-hover-color);cursor:default;font-weight:700}.el-pagination button.is-active.is-disabled{font-weight:700;color:var(--el-text-color-secondary)}.el-pagination button.is-disabled,.el-pagination button:disabled{color:var(--el-pagination-button-disabled-color);background-color:var(--el-pagination-button-disabled-bg-color);cursor:not-allowed}.el-pagination button:focus-visible{outline:1px solid var(--el-pagination-hover-color);outline-offset:-1px}.el-pagination .btn-next .el-icon,.el-pagination .btn-prev .el-icon{display:block;font-size:12px;font-weight:700;width:inherit}.el-pagination>.is-first{margin-left:0!important}.el-pagination>.is-last{margin-right:0!important}.el-pagination .btn-prev{margin-left:var(--el-pagination-item-gap)}.el-pagination__sizes,.el-pagination__total{margin-left:var(--el-pagination-item-gap);font-weight:400;color:var(--el-text-color-regular)}.el-pagination__total[disabled=true]{color:var(--el-text-color-placeholder)}.el-pagination__jump{display:flex;align-items:center;margin-left:var(--el-pagination-item-gap);font-weight:400;color:var(--el-text-color-regular)}.el-pagination__jump[disabled=true]{color:var(--el-text-color-placeholder)}.el-pagination__goto{margin-right:8px}.el-pagination__editor{text-align:center;box-sizing:border-box}.el-pagination__editor.el-input{width:56px}.el-pagination__editor .el-input__inner::-webkit-inner-spin-button,.el-pagination__editor .el-input__inner::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.el-pagination__classifier{margin-left:8px}.el-pagination__rightwrapper{flex:1;display:flex;align-items:center;justify-content:flex-end}.el-pagination.is-background .btn-next,.el-pagination.is-background .btn-prev,.el-pagination.is-background .el-pager li{margin:0 4px;background-color:var(--el-pagination-button-bg-color)}.el-pagination.is-background .btn-next.is-active,.el-pagination.is-background .btn-prev.is-active,.el-pagination.is-background .el-pager li.is-active{background-color:var(--el-color-primary);color:var(--el-color-white)}.el-pagination.is-background .btn-next.is-disabled,.el-pagination.is-background .btn-next:disabled,.el-pagination.is-background .btn-prev.is-disabled,.el-pagination.is-background .btn-prev:disabled,.el-pagination.is-background .el-pager li.is-disabled,.el-pagination.is-background .el-pager li:disabled{color:var(--el-text-color-placeholder);background-color:var(--el-disabled-bg-color)}.el-pagination.is-background .btn-next.is-disabled.is-active,.el-pagination.is-background .btn-next:disabled.is-active,.el-pagination.is-background .btn-prev.is-disabled.is-active,.el-pagination.is-background .btn-prev:disabled.is-active,.el-pagination.is-background .el-pager li.is-disabled.is-active,.el-pagination.is-background .el-pager li:disabled.is-active{color:var(--el-text-color-secondary);background-color:var(--el-fill-color-dark)}.el-pagination.is-background .btn-prev{margin-left:var(--el-pagination-item-gap)}.el-pagination--small .btn-next,.el-pagination--small .btn-prev,.el-pagination--small .el-pager li{height:var(--el-pagination-button-height-small);line-height:var(--el-pagination-button-height-small);font-size:var(--el-pagination-font-size-small);min-width:var(--el-pagination-button-width-small)}.el-pagination--small button,.el-pagination--small span:not([class*=suffix]){font-size:var(--el-pagination-font-size-small)}.el-pagination--small .el-select .el-input{width:100px}.el-pager{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;list-style:none;font-size:0;padding:0;margin:0;display:flex;align-items:center}.el-pager li{display:flex;justify-content:center;align-items:center;font-size:var(--el-pagination-font-size);min-width:var(--el-pagination-button-width);height:var(--el-pagination-button-height);line-height:var(--el-pagination-button-height);color:var(--el-pagination-button-color);background:var(--el-pagination-bg-color);padding:0 4px;border:none;border-radius:var(--el-pagination-border-radius);cursor:pointer;text-align:center;box-sizing:border-box}.el-pager li *{pointer-events:none}.el-pager li:focus{outline:0}.el-pager li:hover{color:var(--el-pagination-hover-color)}.el-pager li.is-active{color:var(--el-pagination-hover-color);cursor:default;font-weight:700}.el-pager li.is-active.is-disabled{font-weight:700;color:var(--el-text-color-secondary)}.el-pager li.is-disabled,.el-pager li:disabled{color:var(--el-pagination-button-disabled-color);background-color:var(--el-pagination-button-disabled-bg-color);cursor:not-allowed}.el-pager li:focus-visible{outline:1px solid var(--el-pagination-hover-color);outline-offset:-1px}.el-popconfirm__main{display:flex;align-items:center}.el-popconfirm__icon{margin-right:5px}.el-popconfirm__action{text-align:right;margin-top:8px}.el-popover{--el-popover-bg-color:var(--el-bg-color-overlay);--el-popover-font-size:var(--el-font-size-base);--el-popover-border-color:var(--el-border-color-lighter);--el-popover-padding:12px;--el-popover-padding-large:18px 20px;--el-popover-title-font-size:16px;--el-popover-title-text-color:var(--el-text-color-primary);--el-popover-border-radius:4px}.el-popover.el-popper{background:var(--el-popover-bg-color);min-width:150px;border-radius:var(--el-popover-border-radius);border:1px solid var(--el-popover-border-color);padding:var(--el-popover-padding);z-index:var(--el-index-popper);color:var(--el-text-color-regular);line-height:1.4;text-align:justify;font-size:var(--el-popover-font-size);box-shadow:var(--el-box-shadow-light);word-break:break-all;box-sizing:border-box}.el-popover.el-popper--plain{padding:var(--el-popover-padding-large)}.el-popover__title{color:var(--el-popover-title-text-color);font-size:var(--el-popover-title-font-size);line-height:1;margin-bottom:12px}.el-popover__reference:focus:hover,.el-popover__reference:focus:not(.focusing){outline-width:0}.el-popover.el-popper.is-dark{--el-popover-bg-color:var(--el-text-color-primary);--el-popover-border-color:var(--el-text-color-primary);--el-popover-title-text-color:var(--el-bg-color);color:var(--el-bg-color)}.el-popover.el-popper:focus,.el-popover.el-popper:focus:active{outline-width:0}.el-progress{position:relative;line-height:1;display:flex;align-items:center}.el-progress__text{font-size:14px;color:var(--el-text-color-regular);margin-left:5px;min-width:50px;line-height:1}.el-progress__text i{vertical-align:middle;display:block}.el-progress--circle,.el-progress--dashboard{display:inline-block}.el-progress--circle .el-progress__text,.el-progress--dashboard .el-progress__text{position:absolute;top:50%;left:0;width:100%;text-align:center;margin:0;transform:translateY(-50%)}.el-progress--circle .el-progress__text i,.el-progress--dashboard .el-progress__text i{vertical-align:middle;display:inline-block}.el-progress--without-text .el-progress__text{display:none}.el-progress--without-text .el-progress-bar{padding-right:0;margin-right:0;display:block}.el-progress--text-inside .el-progress-bar{padding-right:0;margin-right:0}.el-progress.is-success .el-progress-bar__inner{background-color:var(--el-color-success)}.el-progress.is-success .el-progress__text{color:var(--el-color-success)}.el-progress.is-warning .el-progress-bar__inner{background-color:var(--el-color-warning)}.el-progress.is-warning .el-progress__text{color:var(--el-color-warning)}.el-progress.is-exception .el-progress-bar__inner{background-color:var(--el-color-danger)}.el-progress.is-exception .el-progress__text{color:var(--el-color-danger)}.el-progress-bar{flex-grow:1;box-sizing:border-box}.el-progress-bar__outer{height:6px;border-radius:100px;background-color:var(--el-border-color-lighter);overflow:hidden;position:relative;vertical-align:middle}.el-progress-bar__inner{position:absolute;left:0;top:0;height:100%;background-color:var(--el-color-primary);text-align:right;border-radius:100px;line-height:1;white-space:nowrap;transition:width .6s ease}.el-progress-bar__inner:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-progress-bar__inner--indeterminate{transform:translateZ(0);-webkit-animation:indeterminate 3s infinite;animation:indeterminate 3s infinite}.el-progress-bar__inner--striped{background-image:linear-gradient(45deg,rgba(0,0,0,.1) 25%,transparent 25%,transparent 50%,rgba(0,0,0,.1) 50%,rgba(0,0,0,.1) 75%,transparent 75%,transparent);background-size:1.25em 1.25em}.el-progress-bar__inner--striped.el-progress-bar__inner--striped-flow{-webkit-animation:striped-flow 3s linear infinite;animation:striped-flow 3s linear infinite}.el-progress-bar__innerText{display:inline-block;vertical-align:middle;color:#fff;font-size:12px;margin:0 5px}@-webkit-keyframes progress{0%{background-position:0 0}to{background-position:32px 0}}@keyframes progress{0%{background-position:0 0}to{background-position:32px 0}}@-webkit-keyframes indeterminate{0%{left:-100%}to{left:100%}}@keyframes indeterminate{0%{left:-100%}to{left:100%}}@-webkit-keyframes striped-flow{0%{background-position:-100%}to{background-position:100%}}@keyframes striped-flow{0%{background-position:-100%}to{background-position:100%}}.el-radio-button{--el-radio-button-checked-bg-color:var(--el-color-primary);--el-radio-button-checked-text-color:var(--el-color-white);--el-radio-button-checked-border-color:var(--el-color-primary);--el-radio-button-disabled-checked-fill:var(--el-border-color-extra-light)}.el-radio-button{position:relative;display:inline-block;outline:0}.el-radio-button__inner{display:inline-block;line-height:1;white-space:nowrap;vertical-align:middle;background:var(--el-button-bg-color,var(--el-fill-color-blank));border:var(--el-border);font-weight:var(--el-button-font-weight,var(--el-font-weight-primary));border-left:0;color:var(--el-button-text-color,var(--el-text-color-regular));-webkit-appearance:none;text-align:center;box-sizing:border-box;outline:0;margin:0;position:relative;cursor:pointer;transition:var(--el-transition-all);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;padding:8px 15px;font-size:var(--el-font-size-base);border-radius:0}.el-radio-button__inner.is-round{padding:8px 15px}.el-radio-button__inner:hover{color:var(--el-color-primary)}.el-radio-button__inner [class*=el-icon-]{line-height:.9}.el-radio-button__inner [class*=el-icon-]+span{margin-left:5px}.el-radio-button:first-child .el-radio-button__inner{border-left:var(--el-border);border-radius:var(--el-border-radius-base) 0 0 var(--el-border-radius-base);box-shadow:none!important}.el-radio-button__original-radio{opacity:0;outline:0;position:absolute;z-index:-1}.el-radio-button__original-radio:checked+.el-radio-button__inner{color:var(--el-radio-button-checked-text-color,var(--el-color-white));background-color:var(--el-radio-button-checked-bg-color,var(--el-color-primary));border-color:var(--el-radio-button-checked-border-color,var(--el-color-primary));box-shadow:-1px 0 0 0 var(--el-radio-button-checked-border-color,var(--el-color-primary))}.el-radio-button__original-radio:focus-visible+.el-radio-button__inner{border-left:var(--el-border);border-left-color:var(--el-radio-button-checked-border-color,var(--el-color-primary));outline:2px solid var(--el-radio-button-checked-border-color);outline-offset:1px;z-index:2;border-radius:var(--el-border-radius-base);box-shadow:none}.el-radio-button__original-radio:disabled+.el-radio-button__inner{color:var(--el-disabled-text-color);cursor:not-allowed;background-image:none;background-color:var(--el-button-disabled-bg-color,var(--el-fill-color-blank));border-color:var(--el-button-disabled-border-color,var(--el-border-color-light));box-shadow:none}.el-radio-button__original-radio:disabled:checked+.el-radio-button__inner{background-color:var(--el-radio-button-disabled-checked-fill)}.el-radio-button:last-child .el-radio-button__inner{border-radius:0 var(--el-border-radius-base) var(--el-border-radius-base) 0}.el-radio-button:first-child:last-child .el-radio-button__inner{border-radius:var(--el-border-radius-base)}.el-radio-button--large .el-radio-button__inner{padding:12px 19px;font-size:var(--el-font-size-base);border-radius:0}.el-radio-button--large .el-radio-button__inner.is-round{padding:12px 19px}.el-radio-button--small .el-radio-button__inner{padding:5px 11px;font-size:12px;border-radius:0}.el-radio-button--small .el-radio-button__inner.is-round{padding:5px 11px}.el-radio-group{display:inline-flex;align-items:center;flex-wrap:wrap;font-size:0}.el-radio{--el-radio-font-size:var(--el-font-size-base);--el-radio-text-color:var(--el-text-color-regular);--el-radio-font-weight:var(--el-font-weight-primary);--el-radio-input-height:14px;--el-radio-input-width:14px;--el-radio-input-border-radius:var(--el-border-radius-circle);--el-radio-input-bg-color:var(--el-fill-color-blank);--el-radio-input-border:var(--el-border);--el-radio-input-border-color:var(--el-border-color);--el-radio-input-border-color-hover:var(--el-color-primary)}.el-radio{color:var(--el-radio-text-color);font-weight:var(--el-radio-font-weight);position:relative;cursor:pointer;display:inline-flex;align-items:center;white-space:nowrap;outline:0;font-size:var(--el-font-size-base);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;margin-right:32px;height:32px}.el-radio.el-radio--large{height:40px}.el-radio.el-radio--small{height:24px}.el-radio.is-bordered{padding:0 15px 0 9px;border-radius:var(--el-border-radius-base);border:var(--el-border);box-sizing:border-box}.el-radio.is-bordered.is-checked{border-color:var(--el-color-primary)}.el-radio.is-bordered.is-disabled{cursor:not-allowed;border-color:var(--el-border-color-lighter)}.el-radio.is-bordered.el-radio--large{padding:0 19px 0 11px;border-radius:var(--el-border-radius-base)}.el-radio.is-bordered.el-radio--large .el-radio__label{font-size:var(--el-font-size-base)}.el-radio.is-bordered.el-radio--large .el-radio__inner{height:14px;width:14px}.el-radio.is-bordered.el-radio--small{padding:0 11px 0 7px;border-radius:var(--el-border-radius-base)}.el-radio.is-bordered.el-radio--small .el-radio__label{font-size:12px}.el-radio.is-bordered.el-radio--small .el-radio__inner{height:12px;width:12px}.el-radio:last-child{margin-right:0}.el-radio__input{white-space:nowrap;cursor:pointer;outline:0;display:inline-flex;position:relative;vertical-align:middle}.el-radio__input.is-disabled .el-radio__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color);cursor:not-allowed}.el-radio__input.is-disabled .el-radio__inner:after{cursor:not-allowed;background-color:var(--el-disabled-bg-color)}.el-radio__input.is-disabled .el-radio__inner+.el-radio__label{cursor:not-allowed}.el-radio__input.is-disabled.is-checked .el-radio__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color)}.el-radio__input.is-disabled.is-checked .el-radio__inner:after{background-color:var(--el-text-color-placeholder)}.el-radio__input.is-disabled+span.el-radio__label{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-radio__input.is-checked .el-radio__inner{border-color:var(--el-color-primary);background:var(--el-color-primary)}.el-radio__input.is-checked .el-radio__inner:after{transform:translate(-50%,-50%) scale(1)}.el-radio__input.is-checked+.el-radio__label{color:var(--el-color-primary)}.el-radio__input.is-focus .el-radio__inner{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner{border:var(--el-radio-input-border);border-radius:var(--el-radio-input-border-radius);width:var(--el-radio-input-width);height:var(--el-radio-input-height);background-color:var(--el-radio-input-bg-color);position:relative;cursor:pointer;display:inline-block;box-sizing:border-box}.el-radio__inner:hover{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner:after{width:4px;height:4px;border-radius:var(--el-radio-input-border-radius);background-color:var(--el-color-white);content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(0);transition:transform .15s ease-in}.el-radio__original{opacity:0;outline:0;position:absolute;z-index:-1;top:0;left:0;right:0;bottom:0;margin:0}.el-radio__original:focus-visible+.el-radio__inner{outline:2px solid var(--el-radio-input-border-color-hover);outline-offset:1px;border-radius:var(--el-radio-input-border-radius)}.el-radio:focus:not(:focus-visible):not(.is-focus):not(:active):not(.is-disabled) .el-radio__inner{box-shadow:0 0 2px 2px var(--el-radio-input-border-color-hover)}.el-radio__label{font-size:var(--el-radio-font-size);padding-left:8px}.el-radio.el-radio--large .el-radio__label{font-size:14px}.el-radio.el-radio--large .el-radio__inner{width:14px;height:14px}.el-radio.el-radio--small .el-radio__label{font-size:12px}.el-radio.el-radio--small .el-radio__inner{width:12px;height:12px}.el-rate{--el-rate-height:20px;--el-rate-font-size:var(--el-font-size-base);--el-rate-icon-size:18px;--el-rate-icon-margin:6px;--el-rate-void-color:var(--el-border-color-darker);--el-rate-fill-color:#f7ba2a;--el-rate-disabled-void-color:var(--el-fill-color);--el-rate-text-color:var(--el-text-color-primary)}.el-rate{display:inline-flex;align-items:center;height:32px}.el-rate:active,.el-rate:focus{outline:0}.el-rate__item{cursor:pointer;display:inline-block;position:relative;font-size:0;vertical-align:middle;color:var(--el-rate-void-color);line-height:normal}.el-rate .el-rate__icon{position:relative;display:inline-block;font-size:var(--el-rate-icon-size);margin-right:var(--el-rate-icon-margin);transition:var(--el-transition-duration)}.el-rate .el-rate__icon.hover{transform:scale(1.15)}.el-rate .el-rate__icon .path2{position:absolute;left:0;top:0}.el-rate .el-rate__icon.is-active{color:var(--el-rate-fill-color)}.el-rate__decimal{position:absolute;top:0;left:0;display:inline-block;overflow:hidden;color:var(--el-rate-fill-color)}.el-rate__text{font-size:var(--el-rate-font-size);vertical-align:middle;color:var(--el-rate-text-color)}.el-rate--large{height:40px}.el-rate--small{height:24px}.el-rate--small .el-rate__icon{font-size:14px}.el-rate.is-disabled .el-rate__item{cursor:auto;color:var(--el-rate-disabled-void-color)}.el-result{--el-result-padding:40px 30px;--el-result-icon-font-size:64px;--el-result-title-font-size:20px;--el-result-title-margin-top:20px;--el-result-subtitle-margin-top:10px;--el-result-extra-margin-top:30px}.el-result{display:flex;justify-content:center;align-items:center;flex-direction:column;text-align:center;box-sizing:border-box;padding:var(--el-result-padding)}.el-result__icon svg{width:var(--el-result-icon-font-size);height:var(--el-result-icon-font-size)}.el-result__title{margin-top:var(--el-result-title-margin-top)}.el-result__title p{margin:0;font-size:var(--el-result-title-font-size);color:var(--el-text-color-primary);line-height:1.3}.el-result__subtitle{margin-top:var(--el-result-subtitle-margin-top)}.el-result__subtitle p{margin:0;font-size:var(--el-font-size-base);color:var(--el-text-color-regular);line-height:1.3}.el-result__extra{margin-top:var(--el-result-extra-margin-top)}.el-result .icon-primary{--el-result-color:var(--el-color-primary);color:var(--el-result-color)}.el-result .icon-success{--el-result-color:var(--el-color-success);color:var(--el-result-color)}.el-result .icon-warning{--el-result-color:var(--el-color-warning);color:var(--el-result-color)}.el-result .icon-danger{--el-result-color:var(--el-color-danger);color:var(--el-result-color)}.el-result .icon-error{--el-result-color:var(--el-color-error);color:var(--el-result-color)}.el-result .icon-info{--el-result-color:var(--el-color-info);color:var(--el-result-color)}.el-row{display:flex;flex-wrap:wrap;position:relative;box-sizing:border-box}.el-row.is-justify-center{justify-content:center}.el-row.is-justify-end{justify-content:flex-end}.el-row.is-justify-space-between{justify-content:space-between}.el-row.is-justify-space-around{justify-content:space-around}.el-row.is-justify-space-evenly{justify-content:space-evenly}.el-row.is-align-middle{align-items:center}.el-row.is-align-bottom{align-items:flex-end}.el-scrollbar{--el-scrollbar-opacity:.3;--el-scrollbar-bg-color:var(--el-text-color-secondary);--el-scrollbar-hover-opacity:.5;--el-scrollbar-hover-bg-color:var(--el-text-color-secondary)}.el-scrollbar{overflow:hidden;position:relative;height:100%}.el-scrollbar__wrap{overflow:auto;height:100%}.el-scrollbar__wrap--hidden-default{scrollbar-width:none}.el-scrollbar__wrap--hidden-default::-webkit-scrollbar{display:none}.el-scrollbar__thumb{position:relative;display:block;width:0;height:0;cursor:pointer;border-radius:inherit;background-color:var(--el-scrollbar-bg-color,var(--el-text-color-secondary));transition:var(--el-transition-duration) background-color;opacity:var(--el-scrollbar-opacity,.3)}.el-scrollbar__thumb:hover{background-color:var(--el-scrollbar-hover-bg-color,var(--el-text-color-secondary));opacity:var(--el-scrollbar-hover-opacity,.5)}.el-scrollbar__bar{position:absolute;right:2px;bottom:2px;z-index:1;border-radius:4px}.el-scrollbar__bar.is-vertical{width:6px;top:2px}.el-scrollbar__bar.is-vertical>div{width:100%}.el-scrollbar__bar.is-horizontal{height:6px;left:2px}.el-scrollbar__bar.is-horizontal>div{height:100%}.el-scrollbar-fade-enter-active{transition:opacity .34s ease-out}.el-scrollbar-fade-leave-active{transition:opacity .12s ease-out}.el-scrollbar-fade-enter-from,.el-scrollbar-fade-leave-active{opacity:0}.el-select-dropdown{z-index:calc(var(--el-index-top) + 1);border-radius:var(--el-border-radius-base);box-sizing:border-box}.el-select-dropdown .el-scrollbar.is-empty .el-select-dropdown__list{padding:0}.el-select-dropdown__option-item.is-selected:not(.is-multiple).is-disabled{color:var(--el-text-color-disabled)}.el-select-dropdown__option-item.is-selected:not(.is-multiple).is-disabled:after{background-color:var(--el-text-color-disabled)}.el-select-dropdown__option-item:hover:not(.hover){background-color:transparent}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-disabled.is-selected{color:var(--el-text-color-disabled)}.el-select-dropdown__empty{padding:10px 0;margin:0;text-align:center;color:var(--el-text-color-secondary);font-size:var(--el-select-font-size)}.el-select-dropdown__wrap{max-height:274px}.el-select-dropdown__list{list-style:none;margin:6px 0!important;padding:0!important;box-sizing:border-box}.el-select-dropdown__option-item{font-size:var(--el-select-font-size);padding:0 32px 0 20px;position:relative;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--el-text-color-regular);height:34px;line-height:34px;box-sizing:border-box;cursor:pointer}.el-select-dropdown__option-item.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-select-dropdown__option-item.is-disabled:hover{background-color:var(--el-bg-color)}.el-select-dropdown__option-item.is-selected{background-color:var(--el-fill-color-light);font-weight:700}.el-select-dropdown__option-item.is-selected:not(.is-multiple){color:var(--el-color-primary)}.el-select-dropdown__option-item.hover{background-color:var(--el-fill-color-light)!important}.el-select-dropdown__option-item:hover{background-color:var(--el-fill-color-light)}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-selected{color:var(--el-color-primary);background-color:var(--el-bg-color-overlay)}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-selected .el-icon{position:absolute;right:20px;top:0;height:inherit;font-size:12px}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-selected .el-icon svg{height:inherit;vertical-align:middle}.el-select-group{margin:0;padding:0}.el-select-group__wrap{position:relative;list-style:none;margin:0;padding:0}.el-select-group__wrap:not(:last-of-type){padding-bottom:24px}.el-select-group__wrap:not(:last-of-type):after{content:"";position:absolute;display:block;left:20px;right:20px;bottom:12px;height:1px;background:var(--el-border-color-light)}.el-select-group__split-dash{position:absolute;left:20px;right:20px;height:1px;background:var(--el-border-color-light)}.el-select-group__title{padding-left:20px;font-size:12px;color:var(--el-color-info);line-height:30px}.el-select-group .el-select-dropdown__item{padding-left:20px}.el-select-v2{--el-select-border-color-hover:var(--el-border-color-hover);--el-select-disabled-border:var(--el-disabled-border-color);--el-select-font-size:var(--el-font-size-base);--el-select-close-hover-color:var(--el-text-color-secondary);--el-select-input-color:var(--el-text-color-placeholder);--el-select-multiple-input-color:var(--el-text-color-regular);--el-select-input-focus-border-color:var(--el-color-primary);--el-select-input-font-size:14px}.el-select-v2{display:inline-block;position:relative;vertical-align:middle;font-size:14px}.el-select-v2__wrapper{display:flex;align-items:center;flex-wrap:wrap;position:relative;box-sizing:border-box;cursor:pointer;padding:1px 30px 1px 0;border:1px solid var(--el-border-color);border-radius:var(--el-border-radius-base);background-color:var(--el-fill-color-blank);transition:var(--el-transition-duration)}.el-select-v2__wrapper:hover{border-color:var(--el-text-color-placeholder)}.el-select-v2__wrapper.is-filterable{cursor:text}.el-select-v2__wrapper.is-focused{border-color:var(--el-color-primary)}.el-select-v2__wrapper.is-hovering:not(.is-focused){border-color:var(--el-border-color-hover)}.el-select-v2__wrapper.is-disabled{cursor:not-allowed;background-color:var(--el-fill-color-light);color:var(--el-text-color-placeholder);border-color:var(--el-select-disabled-border)}.el-select-v2__wrapper.is-disabled:hover{border-color:var(--el-select-disabled-border)}.el-select-v2__wrapper.is-disabled.is-focus{border-color:var(--el-input-focus-border-color)}.el-select-v2__wrapper.is-disabled .is-transparent{opacity:1;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-select-v2__wrapper.is-disabled .el-select-v2__caret,.el-select-v2__wrapper.is-disabled .el-select-v2__combobox-input{cursor:not-allowed}.el-select-v2__wrapper .el-select-v2__input-wrapper{box-sizing:border-box;position:relative;-webkit-margin-start:12px;margin-inline-start:12px;max-width:100%;overflow:hidden}.el-select-v2__wrapper,.el-select-v2__wrapper .el-select-v2__input-wrapper{line-height:32px}.el-select-v2__wrapper .el-select-v2__input-wrapper input{--el-input-inner-height:calc(var(--el-component-size, 32px) - 8px);height:var(--el-input-inner-height);line-height:var(--el-input-inner-height);min-width:4px;width:100%;background-color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:0 0;border:none;margin:2px 0;outline:0;padding:0}.el-select-v2 .el-select-v2__tags-text{display:inline-block;line-height:normal;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-select-v2__empty{padding:10px 0;margin:0;text-align:center;color:var(--el-text-color-secondary);font-size:14px}.el-select-v2__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-box-shadow-light)}.el-select-v2__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-select-v2__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-select-v2__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-select-v2__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-select-v2__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-select-v2--large .el-select-v2__wrapper .el-select-v2__combobox-input{height:32px}.el-select-v2--large .el-select-v2__caret,.el-select-v2--large .el-select-v2__suffix{height:40px}.el-select-v2--large .el-select-v2__placeholder{font-size:14px;line-height:40px}.el-select-v2--small .el-select-v2__wrapper .el-select-v2__combobox-input{height:16px}.el-select-v2--small .el-select-v2__caret,.el-select-v2--small .el-select-v2__suffix{height:24px}.el-select-v2--small .el-select-v2__placeholder{font-size:12px;line-height:24px}.el-select-v2 .el-select-v2__selection>span{display:inline-block}.el-select-v2:hover .el-select-v2__combobox-input{border-color:var(--el-select-border-color-hover)}.el-select-v2 .el-select__selection-text{text-overflow:ellipsis;display:inline-block;overflow-x:hidden;vertical-align:bottom}.el-select-v2 .el-select-v2__combobox-input{padding-right:35px;display:block;color:var(--el-text-color-regular)}.el-select-v2 .el-select-v2__combobox-input:focus{border-color:var(--el-select-input-focus-border-color)}.el-select-v2__input{border:none;outline:0;padding:0;margin-left:15px;color:var(--el-select-multiple-input-color);font-size:var(--el-select-font-size);-webkit-appearance:none;-moz-appearance:none;appearance:none;height:28px}.el-select-v2__input.is-small{height:14px}.el-select-v2__close{cursor:pointer;position:absolute;top:8px;z-index:var(--el-index-top);right:25px;color:var(--el-select-input-color);line-height:18px;font-size:var(--el-select-input-font-size)}.el-select-v2__close:hover{color:var(--el-select-close-hover-color)}.el-select-v2__suffix{display:inline-flex;position:absolute;right:12px;height:32px;top:50%;transform:translateY(-50%);color:var(--el-input-icon-color,var(--el-text-color-placeholder))}.el-select-v2__suffix .el-input__icon{height:inherit}.el-select-v2__suffix .el-input__icon:not(:first-child){margin-left:8px}.el-select-v2__caret{color:var(--el-select-input-color);font-size:var(--el-select-input-font-size);transition:var(--el-transition-duration);transform:rotate(180deg);cursor:pointer}.el-select-v2__caret.is-reverse{transform:rotate(0)}.el-select-v2__caret.is-show-close{font-size:var(--el-select-font-size);text-align:center;transform:rotate(180deg);border-radius:var(--el-border-radius-circle);color:var(--el-select-input-color);transition:var(--el-transition-color)}.el-select-v2__caret.is-show-close:hover{color:var(--el-select-close-hover-color)}.el-select-v2__caret.el-icon{height:inherit}.el-select-v2__caret.el-icon svg{vertical-align:middle}.el-select-v2__selection{white-space:normal;z-index:var(--el-index-normal);display:flex;align-items:center;flex-wrap:wrap;width:100%}.el-select-v2__input-calculator{left:0;position:absolute;top:0;visibility:hidden;white-space:pre;z-index:999}.el-select-v2__selected-item{line-height:inherit;height:inherit;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;display:flex;flex-wrap:wrap}.el-select-v2__placeholder{position:absolute;top:50%;transform:translateY(-50%);-webkit-margin-start:12px;margin-inline-start:12px;width:calc(100% - 52px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--el-input-text-color,var(--el-text-color-regular))}.el-select-v2__placeholder.is-transparent{color:var(--el-text-color-placeholder)}.el-select-v2 .el-select-v2__selection .el-tag{box-sizing:border-box;border-color:transparent;margin:2px 0 2px 6px;background-color:var(--el-fill-color)}.el-select-v2 .el-select-v2__selection .el-tag .el-icon-close{background-color:var(--el-text-color-placeholder);right:-7px;color:var(--el-color-white)}.el-select-v2 .el-select-v2__selection .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-select-v2 .el-select-v2__selection .el-tag .el-icon-close:before{display:block;transform:translateY(.5px)}.el-select-v2.el-select-v2--small .el-select-v2__selection .el-tag{margin:1px 0 1px 6px;height:18px}.el-select-dropdown{z-index:calc(var(--el-index-top) + 1);border-radius:var(--el-border-radius-base);box-sizing:border-box}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected{color:var(--el-color-primary);background-color:var(--el-bg-color-overlay)}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected.hover{background-color:var(--el-fill-color-light)}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected:after{content:"";position:absolute;top:50%;right:20px;border-top:none;border-right:none;background-repeat:no-repeat;background-position:center;background-color:var(--el-color-primary);-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask-size:100% 100%;-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;-webkit-mask-size:100% 100%;transform:translateY(-50%);width:12px;height:12px}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected.is-disabled:after{background-color:var(--el-text-color-disabled)}.el-select-dropdown .el-select-dropdown__option-item.is-selected:after{content:"";position:absolute;top:50%;right:20px;border-top:none;border-right:none;background-repeat:no-repeat;background-position:center;background-color:var(--el-color-primary);-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask-size:100% 100%;-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;-webkit-mask-size:100% 100%;transform:translateY(-50%);width:12px;height:12px}.el-select-dropdown .el-scrollbar.is-empty .el-select-dropdown__list{padding:0}.el-select-dropdown .el-select-dropdown__item.is-disabled:hover{background-color:unset}.el-select-dropdown .el-select-dropdown__item.is-disabled.selected{color:var(--el-text-color-disabled)}.el-select-dropdown__empty{padding:10px 0;margin:0;text-align:center;color:var(--el-text-color-secondary);font-size:var(--el-select-font-size)}.el-select-dropdown__wrap{max-height:274px}.el-select-dropdown__list{list-style:none;padding:6px 0;margin:0;box-sizing:border-box}.el-select{--el-select-border-color-hover:var(--el-border-color-hover);--el-select-disabled-border:var(--el-disabled-border-color);--el-select-font-size:var(--el-font-size-base);--el-select-close-hover-color:var(--el-text-color-secondary);--el-select-input-color:var(--el-text-color-placeholder);--el-select-multiple-input-color:var(--el-text-color-regular);--el-select-input-focus-border-color:var(--el-color-primary);--el-select-input-font-size:14px}.el-select{display:inline-block;position:relative;vertical-align:middle;line-height:32px}.el-select__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-box-shadow-light)}.el-select__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-select__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-select__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-select__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-select__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-select .el-select-tags-wrapper.has-prefix{margin-left:6px}.el-select--large{line-height:40px}.el-select--large .el-select-tags-wrapper.has-prefix{margin-left:8px}.el-select--small{line-height:24px}.el-select--small .el-select-tags-wrapper.has-prefix{margin-left:4px}.el-select .el-select__tags>span{display:inline-block}.el-select:hover:not(.el-select--disabled) .el-input__wrapper{box-shadow:0 0 0 1px var(--el-select-border-color-hover) inset}.el-select .el-select__tags-text{display:inline-block;line-height:normal;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-select .el-input__wrapper{cursor:pointer}.el-select .el-input__wrapper.is-focus{box-shadow:0 0 0 1px var(--el-select-input-focus-border-color) inset!important}.el-select .el-input__inner{cursor:pointer}.el-select .el-input{display:flex}.el-select .el-input .el-select__caret{color:var(--el-select-input-color);font-size:var(--el-select-input-font-size);transition:transform var(--el-transition-duration);transform:rotate(0);cursor:pointer}.el-select .el-input .el-select__caret.is-reverse{transform:rotate(-180deg)}.el-select .el-input .el-select__caret.is-show-close{font-size:var(--el-select-font-size);text-align:center;transform:rotate(0);border-radius:var(--el-border-radius-circle);color:var(--el-select-input-color);transition:var(--el-transition-color)}.el-select .el-input .el-select__caret.is-show-close:hover{color:var(--el-select-close-hover-color)}.el-select .el-input .el-select__caret.el-icon{position:relative;height:inherit;z-index:2}.el-select .el-input.is-disabled .el-input__wrapper{cursor:not-allowed}.el-select .el-input.is-disabled .el-input__wrapper:hover{box-shadow:0 0 0 1px var(--el-select-disabled-border) inset}.el-select .el-input.is-disabled .el-input__inner,.el-select .el-input.is-disabled .el-select__caret{cursor:not-allowed}.el-select .el-input.is-focus .el-input__wrapper{box-shadow:0 0 0 1px var(--el-select-input-focus-border-color) inset!important}.el-select__input{border:none;outline:0;padding:0;margin-left:15px;color:var(--el-select-multiple-input-color);font-size:var(--el-select-font-size);-webkit-appearance:none;-moz-appearance:none;appearance:none;height:28px;background-color:transparent}.el-select__input.is-disabled{cursor:not-allowed}.el-select__input--iOS{position:absolute;left:0;top:0;z-index:6}.el-select__input.is-small{height:14px}.el-select__close{cursor:pointer;position:absolute;top:8px;z-index:var(--el-index-top);right:25px;color:var(--el-select-input-color);line-height:18px;font-size:var(--el-select-input-font-size)}.el-select__close:hover{color:var(--el-select-close-hover-color)}.el-select__tags{position:absolute;line-height:normal;top:50%;transform:translateY(-50%);white-space:normal;z-index:var(--el-index-normal);display:flex;align-items:center;flex-wrap:wrap;cursor:pointer}.el-select__tags .el-tag{box-sizing:border-box;border-color:transparent;margin:2px 6px 2px 0}.el-select__tags .el-tag:last-child{margin-right:0}.el-select__tags .el-tag .el-icon-close{background-color:var(--el-text-color-placeholder);right:-7px;top:0;color:#fff}.el-select__tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-select__tags .el-tag .el-icon-close:before{display:block;transform:translateY(.5px)}.el-select__tags .el-tag--info{background-color:var(--el-fill-color)}.el-select__tags.is-disabled{cursor:not-allowed}.el-select__collapse-tags{white-space:normal;z-index:var(--el-index-normal);display:flex;align-items:center;flex-wrap:wrap;cursor:pointer}.el-select__collapse-tags .el-tag{box-sizing:border-box;border-color:transparent;margin:2px 6px 2px 0}.el-select__collapse-tags .el-tag:last-child{margin-right:0}.el-select__collapse-tags .el-tag .el-icon-close{background-color:var(--el-text-color-placeholder);right:-7px;top:0;color:#fff}.el-select__collapse-tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-select__collapse-tags .el-tag .el-icon-close:before{display:block;transform:translateY(.5px)}.el-select__collapse-tags .el-tag--info{background-color:var(--el-fill-color)}.el-select__collapse-tag{line-height:inherit;height:inherit;display:flex}.el-skeleton{--el-skeleton-circle-size:var(--el-avatar-size)}.el-skeleton__item{background:var(--el-skeleton-color);display:inline-block;height:16px;border-radius:var(--el-border-radius-base);width:100%}.el-skeleton__circle{border-radius:50%;width:var(--el-skeleton-circle-size);height:var(--el-skeleton-circle-size);line-height:var(--el-skeleton-circle-size)}.el-skeleton__button{height:40px;width:64px;border-radius:4px}.el-skeleton__p{width:100%}.el-skeleton__p.is-last{width:61%}.el-skeleton__p.is-first{width:33%}.el-skeleton__text{width:100%;height:var(--el-font-size-small)}.el-skeleton__caption{height:var(--el-font-size-extra-small)}.el-skeleton__h1{height:var(--el-font-size-extra-large)}.el-skeleton__h3{height:var(--el-font-size-large)}.el-skeleton__h5{height:var(--el-font-size-medium)}.el-skeleton__image{width:unset;display:flex;align-items:center;justify-content:center;border-radius:0}.el-skeleton__image svg{color:var(--el-svg-monochrome-grey);fill:currentColor;width:22%;height:22%}.el-skeleton{--el-skeleton-color:var(--el-fill-color);--el-skeleton-to-color:var(--el-fill-color-darker)}@-webkit-keyframes el-skeleton-loading{0%{background-position:100% 50%}to{background-position:0 50%}}@keyframes el-skeleton-loading{0%{background-position:100% 50%}to{background-position:0 50%}}.el-skeleton{width:100%}.el-skeleton__first-line,.el-skeleton__paragraph{height:16px;margin-top:16px;background:var(--el-skeleton-color)}.el-skeleton.is-animated .el-skeleton__item{background:linear-gradient(90deg,var(--el-skeleton-color) 25%,var(--el-skeleton-to-color) 37%,var(--el-skeleton-color) 63%);background-size:400% 100%;-webkit-animation:el-skeleton-loading 1.4s ease infinite;animation:el-skeleton-loading 1.4s ease infinite}.el-slider{--el-slider-main-bg-color:var(--el-color-primary);--el-slider-runway-bg-color:var(--el-border-color-light);--el-slider-stop-bg-color:var(--el-color-white);--el-slider-disabled-color:var(--el-text-color-placeholder);--el-slider-border-radius:3px;--el-slider-height:6px;--el-slider-button-size:20px;--el-slider-button-wrapper-size:36px;--el-slider-button-wrapper-offset:-15px}.el-slider{width:100%;height:32px;display:flex;align-items:center}.el-slider__runway{flex:1;height:var(--el-slider-height);background-color:var(--el-slider-runway-bg-color);border-radius:var(--el-slider-border-radius);position:relative;cursor:pointer}.el-slider__runway.show-input{margin-right:30px;width:auto}.el-slider__runway.is-disabled{cursor:default}.el-slider__runway.is-disabled .el-slider__bar{background-color:var(--el-slider-disabled-color)}.el-slider__runway.is-disabled .el-slider__button{border-color:var(--el-slider-disabled-color)}.el-slider__runway.is-disabled .el-slider__button-wrapper.hover,.el-slider__runway.is-disabled .el-slider__button-wrapper:hover,.el-slider__runway.is-disabled .el-slider__button-wrapper.dragging{cursor:not-allowed}.el-slider__runway.is-disabled .el-slider__button.dragging,.el-slider__runway.is-disabled .el-slider__button.hover,.el-slider__runway.is-disabled .el-slider__button:hover{transform:scale(1)}.el-slider__runway.is-disabled .el-slider__button.hover,.el-slider__runway.is-disabled .el-slider__button:hover,.el-slider__runway.is-disabled .el-slider__button.dragging{cursor:not-allowed}.el-slider__input{flex-shrink:0;width:130px}.el-slider__bar{height:var(--el-slider-height);background-color:var(--el-slider-main-bg-color);border-top-left-radius:var(--el-slider-border-radius);border-bottom-left-radius:var(--el-slider-border-radius);position:absolute}.el-slider__button-wrapper{height:var(--el-slider-button-wrapper-size);width:var(--el-slider-button-wrapper-size);position:absolute;z-index:1;top:var(--el-slider-button-wrapper-offset);transform:translate(-50%);background-color:transparent;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;line-height:normal;outline:0}.el-slider__button-wrapper:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-slider__button-wrapper.hover,.el-slider__button-wrapper:hover{cursor:-webkit-grab;cursor:grab}.el-slider__button-wrapper.dragging{cursor:-webkit-grabbing;cursor:grabbing}.el-slider__button{display:inline-block;width:var(--el-slider-button-size);height:var(--el-slider-button-size);vertical-align:middle;border:solid 2px var(--el-slider-main-bg-color);background-color:var(--el-color-white);border-radius:50%;box-sizing:border-box;transition:var(--el-transition-duration-fast);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-slider__button.dragging,.el-slider__button.hover,.el-slider__button:hover{transform:scale(1.2)}.el-slider__button.hover,.el-slider__button:hover{cursor:-webkit-grab;cursor:grab}.el-slider__button.dragging{cursor:-webkit-grabbing;cursor:grabbing}.el-slider__stop{position:absolute;height:var(--el-slider-height);width:var(--el-slider-height);border-radius:var(--el-border-radius-circle);background-color:var(--el-slider-stop-bg-color);transform:translate(-50%)}.el-slider__marks{top:0;left:12px;width:18px;height:100%}.el-slider__marks-text{position:absolute;transform:translate(-50%);font-size:14px;color:var(--el-color-info);margin-top:15px;white-space:pre}.el-slider.is-vertical{position:relative;display:inline-flex;width:auto;height:100%;flex:0}.el-slider.is-vertical .el-slider__runway{width:var(--el-slider-height);height:100%;margin:0 16px}.el-slider.is-vertical .el-slider__bar{width:var(--el-slider-height);height:auto;border-radius:0 0 3px 3px}.el-slider.is-vertical .el-slider__button-wrapper{top:auto;left:var(--el-slider-button-wrapper-offset);transform:translateY(50%)}.el-slider.is-vertical .el-slider__stop{transform:translateY(50%)}.el-slider.is-vertical .el-slider__marks-text{margin-top:0;left:15px;transform:translateY(50%)}.el-slider--large{height:40px}.el-slider--small{height:24px}.el-space{display:inline-flex;vertical-align:top}.el-space__item{display:flex;flex-wrap:wrap}.el-space__item>*{flex:1}.el-space--vertical{flex-direction:column}.el-time-spinner{width:100%;white-space:nowrap}.el-spinner{display:inline-block;vertical-align:middle}.el-spinner-inner{-webkit-animation:rotate 2s linear infinite;animation:rotate 2s linear infinite;width:50px;height:50px}.el-spinner-inner .path{stroke:var(--el-border-color-lighter);stroke-linecap:round;-webkit-animation:dash 1.5s ease-in-out infinite;animation:dash 1.5s ease-in-out infinite}@-webkit-keyframes rotate{to{transform:rotate(360deg)}}@keyframes rotate{to{transform:rotate(360deg)}}@-webkit-keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}@keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.el-step{position:relative;flex-shrink:1}.el-step:last-of-type .el-step__line{display:none}.el-step:last-of-type.is-flex{flex-basis:auto!important;flex-shrink:0;flex-grow:0}.el-step:last-of-type .el-step__description,.el-step:last-of-type .el-step__main{padding-right:0}.el-step__head{position:relative;width:100%}.el-step__head.is-process{color:var(--el-text-color-primary);border-color:var(--el-text-color-primary)}.el-step__head.is-wait{color:var(--el-text-color-placeholder);border-color:var(--el-text-color-placeholder)}.el-step__head.is-success{color:var(--el-color-success);border-color:var(--el-color-success)}.el-step__head.is-error{color:var(--el-color-danger);border-color:var(--el-color-danger)}.el-step__head.is-finish{color:var(--el-color-primary);border-color:var(--el-color-primary)}.el-step__icon{position:relative;z-index:1;display:inline-flex;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;box-sizing:border-box;background:var(--el-bg-color);transition:.15s ease-out}.el-step__icon.is-text{border-radius:50%;border:2px solid;border-color:inherit}.el-step__icon.is-icon{width:40px}.el-step__icon-inner{display:inline-block;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;text-align:center;font-weight:700;line-height:1;color:inherit}.el-step__icon-inner[class*=el-icon]:not(.is-status){font-size:25px;font-weight:400}.el-step__icon-inner.is-status{transform:translateY(1px)}.el-step__line{position:absolute;border-color:inherit;background-color:var(--el-text-color-placeholder)}.el-step__line-inner{display:block;border-width:1px;border-style:solid;border-color:inherit;transition:.15s ease-out;box-sizing:border-box;width:0;height:0}.el-step__main{white-space:normal;text-align:left}.el-step__title{font-size:16px;line-height:38px}.el-step__title.is-process{font-weight:700;color:var(--el-text-color-primary)}.el-step__title.is-wait{color:var(--el-text-color-placeholder)}.el-step__title.is-success{color:var(--el-color-success)}.el-step__title.is-error{color:var(--el-color-danger)}.el-step__title.is-finish{color:var(--el-color-primary)}.el-step__description{padding-right:10%;margin-top:-5px;font-size:12px;line-height:20px;font-weight:400}.el-step__description.is-process{color:var(--el-text-color-primary)}.el-step__description.is-wait{color:var(--el-text-color-placeholder)}.el-step__description.is-success{color:var(--el-color-success)}.el-step__description.is-error{color:var(--el-color-danger)}.el-step__description.is-finish{color:var(--el-color-primary)}.el-step.is-horizontal{display:inline-block}.el-step.is-horizontal .el-step__line{height:2px;top:11px;left:0;right:0}.el-step.is-vertical{display:flex}.el-step.is-vertical .el-step__head{flex-grow:0;width:24px}.el-step.is-vertical .el-step__main{padding-left:10px;flex-grow:1}.el-step.is-vertical .el-step__title{line-height:24px;padding-bottom:8px}.el-step.is-vertical .el-step__line{width:2px;top:0;bottom:0;left:11px}.el-step.is-vertical .el-step__icon.is-icon{width:24px}.el-step.is-center .el-step__head,.el-step.is-center .el-step__main{text-align:center}.el-step.is-center .el-step__description{padding-left:20%;padding-right:20%}.el-step.is-center .el-step__line{left:50%;right:-50%}.el-step.is-simple{display:flex;align-items:center}.el-step.is-simple .el-step__head{width:auto;font-size:0;padding-right:10px}.el-step.is-simple .el-step__icon{background:0 0;width:16px;height:16px;font-size:12px}.el-step.is-simple .el-step__icon-inner[class*=el-icon]:not(.is-status){font-size:18px}.el-step.is-simple .el-step__icon-inner.is-status{transform:scale(.8) translateY(1px)}.el-step.is-simple .el-step__main{position:relative;display:flex;align-items:stretch;flex-grow:1}.el-step.is-simple .el-step__title{font-size:16px;line-height:20px}.el-step.is-simple:not(:last-of-type) .el-step__title{max-width:50%;word-break:break-all}.el-step.is-simple .el-step__arrow{flex-grow:1;display:flex;align-items:center;justify-content:center}.el-step.is-simple .el-step__arrow:after,.el-step.is-simple .el-step__arrow:before{content:"";display:inline-block;position:absolute;height:15px;width:1px;background:var(--el-text-color-placeholder)}.el-step.is-simple .el-step__arrow:before{transform:rotate(-45deg) translateY(-4px);transform-origin:0 0}.el-step.is-simple .el-step__arrow:after{transform:rotate(45deg) translateY(4px);transform-origin:100% 100%}.el-step.is-simple:last-of-type .el-step__arrow{display:none}.el-steps{display:flex}.el-steps--simple{padding:13px 8%;border-radius:4px;background:var(--el-fill-color-light)}.el-steps--horizontal{white-space:nowrap}.el-steps--vertical{height:100%;flex-flow:column}.el-switch{--el-switch-on-color:var(--el-color-primary);--el-switch-off-color:var(--el-border-color)}.el-switch{display:inline-flex;align-items:center;position:relative;font-size:14px;line-height:20px;height:32px;vertical-align:middle}.el-switch.is-disabled .el-switch__core,.el-switch.is-disabled .el-switch__label{cursor:not-allowed}.el-switch__label{transition:var(--el-transition-duration-fast);height:20px;display:inline-block;font-size:14px;font-weight:500;cursor:pointer;vertical-align:middle;color:var(--el-text-color-primary)}.el-switch__label.is-active{color:var(--el-color-primary)}.el-switch__label--left{margin-right:10px}.el-switch__label--right{margin-left:10px}.el-switch__label *{line-height:1;font-size:14px;display:inline-block}.el-switch__label .el-icon{height:inherit}.el-switch__label .el-icon svg{vertical-align:middle}.el-switch__input{position:absolute;width:0;height:0;opacity:0;margin:0}.el-switch__input:focus-visible~.el-switch__core{outline:2px solid var(--el-switch-on-color);outline-offset:1px}.el-switch__core{display:inline-flex;position:relative;align-items:center;min-width:40px;height:20px;border:1px solid var(--el-switch-border-color,var(--el-switch-off-color));outline:0;border-radius:10px;box-sizing:border-box;background:var(--el-switch-off-color);cursor:pointer;transition:border-color var(--el-transition-duration),background-color var(--el-transition-duration)}.el-switch__core .el-switch__inner{width:100%;transition:all var(--el-transition-duration);height:16px;display:flex;justify-content:center;align-items:center;overflow:hidden;padding:0 4px 0 18px}.el-switch__core .el-switch__inner .is-icon,.el-switch__core .el-switch__inner .is-text{font-size:12px;color:var(--el-color-white);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-switch__core .el-switch__action{position:absolute;left:1px;border-radius:var(--el-border-radius-circle);transition:all var(--el-transition-duration);width:16px;height:16px;background-color:var(--el-color-white);display:flex;justify-content:center;align-items:center;color:var(--el-switch-off-color)}.el-switch.is-checked .el-switch__core{border-color:var(--el-switch-border-color,var(--el-switch-on-color));background-color:var(--el-switch-on-color)}.el-switch.is-checked .el-switch__core .el-switch__action{left:calc(100% - 17px);color:var(--el-switch-on-color)}.el-switch.is-checked .el-switch__core .el-switch__inner{padding:0 18px 0 4px}.el-switch.is-disabled{opacity:.6}.el-switch--wide .el-switch__label.el-switch__label--left span{left:10px}.el-switch--wide .el-switch__label.el-switch__label--right span{right:10px}.el-switch .label-fade-enter-from,.el-switch .label-fade-leave-active{opacity:0}.el-switch--large{font-size:14px;line-height:24px;height:40px}.el-switch--large .el-switch__label{height:24px;font-size:14px}.el-switch--large .el-switch__label *{font-size:14px}.el-switch--large .el-switch__core{min-width:50px;height:24px;border-radius:12px}.el-switch--large .el-switch__core .el-switch__inner{height:20px;padding:0 6px 0 22px}.el-switch--large .el-switch__core .el-switch__action{width:20px;height:20px}.el-switch--large.is-checked .el-switch__core .el-switch__action{left:calc(100% - 21px)}.el-switch--large.is-checked .el-switch__core .el-switch__inner{padding:0 22px 0 6px}.el-switch--small{font-size:12px;line-height:16px;height:24px}.el-switch--small .el-switch__label{height:16px;font-size:12px}.el-switch--small .el-switch__label *{font-size:12px}.el-switch--small .el-switch__core{min-width:30px;height:16px;border-radius:8px}.el-switch--small .el-switch__core .el-switch__inner{height:12px;padding:0 2px 0 14px}.el-switch--small .el-switch__core .el-switch__action{width:12px;height:12px}.el-switch--small.is-checked .el-switch__core .el-switch__action{left:calc(100% - 13px)}.el-switch--small.is-checked .el-switch__core .el-switch__inner{padding:0 14px 0 2px}.el-table-column--selection .cell{padding-left:14px;padding-right:14px}.el-table-filter{border:solid 1px var(--el-border-color-lighter);border-radius:2px;background-color:#fff;box-shadow:var(--el-box-shadow-light);box-sizing:border-box}.el-table-filter__list{padding:5px 0;margin:0;list-style:none;min-width:100px}.el-table-filter__list-item{line-height:36px;padding:0 10px;cursor:pointer;font-size:var(--el-font-size-base)}.el-table-filter__list-item:hover{background-color:var(--el-color-primary-light-9);color:var(--el-color-primary)}.el-table-filter__list-item.is-active{background-color:var(--el-color-primary);color:#fff}.el-table-filter__content{min-width:100px}.el-table-filter__bottom{border-top:1px solid var(--el-border-color-lighter);padding:8px}.el-table-filter__bottom button{background:0 0;border:none;color:var(--el-text-color-regular);cursor:pointer;font-size:var(--el-font-size-small);padding:0 3px}.el-table-filter__bottom button:hover{color:var(--el-color-primary)}.el-table-filter__bottom button:focus{outline:0}.el-table-filter__bottom button.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-table-filter__wrap{max-height:280px}.el-table-filter__checkbox-group{padding:10px}.el-table-filter__checkbox-group label.el-checkbox{display:flex;align-items:center;margin-right:5px;margin-bottom:12px;margin-left:5px;height:unset}.el-table-filter__checkbox-group .el-checkbox:last-child{margin-bottom:0}.el-table{--el-table-border-color:var(--el-border-color-lighter);--el-table-border:1px solid var(--el-table-border-color);--el-table-text-color:var(--el-text-color-regular);--el-table-header-text-color:var(--el-text-color-secondary);--el-table-row-hover-bg-color:var(--el-fill-color-light);--el-table-current-row-bg-color:var(--el-color-primary-light-9);--el-table-header-bg-color:var(--el-bg-color);--el-table-fixed-box-shadow:var(--el-box-shadow-light);--el-table-bg-color:var(--el-fill-color-blank);--el-table-tr-bg-color:var(--el-fill-color-blank);--el-table-expanded-cell-bg-color:var(--el-fill-color-blank);--el-table-fixed-left-column:inset 10px 0 10px -10px rgba(0, 0, 0, .15);--el-table-fixed-right-column:inset -10px 0 10px -10px rgba(0, 0, 0, .15)}.el-table{position:relative;overflow:hidden;box-sizing:border-box;height:-webkit-fit-content;height:-moz-fit-content;height:fit-content;width:100%;max-width:100%;background-color:var(--el-table-bg-color);font-size:14px;color:var(--el-table-text-color)}.el-table__inner-wrapper{position:relative;display:flex;flex-direction:column;height:100%}.el-table__inner-wrapper:before{left:0;bottom:0;width:100%;height:1px}.el-table.has-footer.el-table--fluid-height tr:last-child td.el-table__cell,.el-table.has-footer.el-table--scrollable-y tr:last-child td.el-table__cell{border-bottom-color:transparent}.el-table__empty-block{position:-webkit-sticky;position:sticky;left:0;min-height:60px;text-align:center;width:100%;display:flex;justify-content:center;align-items:center}.el-table__empty-text{line-height:60px;width:50%;color:var(--el-text-color-secondary)}.el-table__expand-column .cell{padding:0;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-table__expand-icon{position:relative;cursor:pointer;color:var(--el-text-color-regular);font-size:12px;transition:transform var(--el-transition-duration-fast) ease-in-out;height:20px}.el-table__expand-icon--expanded{transform:rotate(90deg)}.el-table__expand-icon>.el-icon{font-size:12px}.el-table__expanded-cell{background-color:var(--el-table-expanded-cell-bg-color)}.el-table__expanded-cell[class*=cell]{padding:20px 50px}.el-table__expanded-cell:hover{background-color:transparent!important}.el-table__placeholder{display:inline-block;width:20px}.el-table__append-wrapper{overflow:hidden}.el-table--fit{border-right:0;border-bottom:0}.el-table--fit .el-table__cell.gutter{border-right-width:1px}.el-table thead{color:var(--el-table-header-text-color);font-weight:500}.el-table thead.is-group th.el-table__cell{background:var(--el-fill-color-light)}.el-table .el-table__cell{padding:8px 0;min-width:0;box-sizing:border-box;text-overflow:ellipsis;vertical-align:middle;position:relative;text-align:left;z-index:1}.el-table .el-table__cell.is-center{text-align:center}.el-table .el-table__cell.is-right{text-align:right}.el-table .el-table__cell.gutter{width:15px;border-right-width:0;border-bottom-width:0;padding:0}.el-table .el-table__cell.is-hidden>*{visibility:hidden}.el-table .cell{box-sizing:border-box;overflow:hidden;text-overflow:ellipsis;white-space:normal;word-break:break-all;line-height:23px;padding:0 12px}.el-table .cell.el-tooltip{white-space:nowrap;min-width:50px}.el-table--large{font-size:var(--el-font-size-base)}.el-table--large .el-table__cell{padding:12px 0}.el-table--large .cell{padding:0 16px}.el-table--default{font-size:14px}.el-table--default .el-table__cell{padding:8px 0}.el-table--default .cell{padding:0 12px}.el-table--small{font-size:12px}.el-table--small .el-table__cell{padding:4px 0}.el-table--small .cell{padding:0 8px}.el-table tr{background-color:var(--el-table-tr-bg-color)}.el-table tr input[type=checkbox]{margin:0}.el-table td.el-table__cell,.el-table th.el-table__cell.is-leaf{border-bottom:var(--el-table-border)}.el-table th.el-table__cell.is-sortable{cursor:pointer}.el-table th.el-table__cell{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:var(--el-table-header-bg-color)}.el-table th.el-table__cell>.cell.highlight{color:var(--el-color-primary)}.el-table th.el-table__cell.required>div:before{display:inline-block;content:"";width:8px;height:8px;border-radius:50%;background:#ff4d51;margin-right:5px;vertical-align:middle}.el-table td.el-table__cell div{box-sizing:border-box}.el-table td.el-table__cell.gutter{width:0}.el-table__footer-wrapper{border-top:var(--el-table-border)}.el-table--border .el-table__inner-wrapper:after,.el-table--border:after,.el-table--border:before,.el-table__inner-wrapper:before{content:"";position:absolute;background-color:var(--el-table-border-color);z-index:3}.el-table--border .el-table__inner-wrapper:after{left:0;top:0;width:100%;height:1px}.el-table--border:before{top:-1px;left:0;width:1px;height:100%}.el-table--border:after{top:-1px;right:0;width:1px;height:100%}.el-table--border .el-table__inner-wrapper{border-right:none;border-bottom:none}.el-table--border .el-table__footer-wrapper{position:relative;flex-shrink:0}.el-table--border .el-table__cell{border-right:var(--el-table-border)}.el-table--border th.el-table__cell.gutter:last-of-type{border-bottom:var(--el-table-border);border-bottom-width:1px}.el-table--border th.el-table__cell{border-bottom:var(--el-table-border)}.el-table--hidden{visibility:hidden}.el-table__body-wrapper,.el-table__footer-wrapper,.el-table__header-wrapper{width:100%}.el-table__body-wrapper tr td.el-table-fixed-column--left,.el-table__body-wrapper tr td.el-table-fixed-column--right,.el-table__body-wrapper tr th.el-table-fixed-column--left,.el-table__body-wrapper tr th.el-table-fixed-column--right,.el-table__footer-wrapper tr td.el-table-fixed-column--left,.el-table__footer-wrapper tr td.el-table-fixed-column--right,.el-table__footer-wrapper tr th.el-table-fixed-column--left,.el-table__footer-wrapper tr th.el-table-fixed-column--right,.el-table__header-wrapper tr td.el-table-fixed-column--left,.el-table__header-wrapper tr td.el-table-fixed-column--right,.el-table__header-wrapper tr th.el-table-fixed-column--left,.el-table__header-wrapper tr th.el-table-fixed-column--right{position:-webkit-sticky!important;position:sticky!important;z-index:2;background:var(--el-bg-color)}.el-table__body-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-last-column:before{content:"";position:absolute;top:0;width:10px;bottom:-1px;overflow-x:hidden;overflow-y:hidden;box-shadow:none;touch-action:none;pointer-events:none}.el-table__body-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-first-column:before{left:-10px}.el-table__body-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-last-column:before{right:-10px;box-shadow:none}.el-table__body-wrapper tr td.el-table__fixed-right-patch,.el-table__body-wrapper tr th.el-table__fixed-right-patch,.el-table__footer-wrapper tr td.el-table__fixed-right-patch,.el-table__footer-wrapper tr th.el-table__fixed-right-patch,.el-table__header-wrapper tr td.el-table__fixed-right-patch,.el-table__header-wrapper tr th.el-table__fixed-right-patch{position:-webkit-sticky!important;position:sticky!important;z-index:2;background:#fff;right:0}.el-table__header-wrapper{flex-shrink:0}.el-table__header-wrapper tr th.el-table-fixed-column--left,.el-table__header-wrapper tr th.el-table-fixed-column--right{background-color:var(--el-table-header-bg-color)}.el-table__body,.el-table__footer,.el-table__header{table-layout:fixed;border-collapse:separate}.el-table__footer-wrapper,.el-table__header-wrapper{overflow:hidden}.el-table__footer-wrapper tbody td.el-table__cell,.el-table__header-wrapper tbody td.el-table__cell{background-color:var(--el-table-row-hover-bg-color);color:var(--el-table-text-color)}.el-table__body-wrapper .el-table-column--selection>.cell,.el-table__header-wrapper .el-table-column--selection>.cell{display:inline-flex;align-items:center;height:23px}.el-table__body-wrapper .el-table-column--selection .el-checkbox,.el-table__header-wrapper .el-table-column--selection .el-checkbox{height:unset}.el-table.is-scrolling-left .el-table-fixed-column--right.is-first-column:before{box-shadow:var(--el-table-fixed-right-column)}.el-table.is-scrolling-left.el-table--border .el-table-fixed-column--left.is-last-column.el-table__cell{border-right:var(--el-table-border)}.el-table.is-scrolling-left th.el-table-fixed-column--left{background-color:var(--el-table-header-bg-color)}.el-table.is-scrolling-right .el-table-fixed-column--left.is-last-column:before{box-shadow:var(--el-table-fixed-left-column)}.el-table.is-scrolling-right .el-table-fixed-column--left.is-last-column.el-table__cell{border-right:none}.el-table.is-scrolling-right th.el-table-fixed-column--right{background-color:var(--el-table-header-bg-color)}.el-table.is-scrolling-middle .el-table-fixed-column--left.is-last-column.el-table__cell{border-right:none}.el-table.is-scrolling-middle .el-table-fixed-column--right.is-first-column:before{box-shadow:var(--el-table-fixed-right-column)}.el-table.is-scrolling-middle .el-table-fixed-column--left.is-last-column:before{box-shadow:var(--el-table-fixed-left-column)}.el-table.is-scrolling-none .el-table-fixed-column--left.is-first-column:before,.el-table.is-scrolling-none .el-table-fixed-column--left.is-last-column:before,.el-table.is-scrolling-none .el-table-fixed-column--right.is-first-column:before,.el-table.is-scrolling-none .el-table-fixed-column--right.is-last-column:before{box-shadow:none}.el-table.is-scrolling-none th.el-table-fixed-column--left,.el-table.is-scrolling-none th.el-table-fixed-column--right{background-color:var(--el-table-header-bg-color)}.el-table__body-wrapper{overflow:hidden;position:relative;flex:1}.el-table__body-wrapper .el-scrollbar__bar{z-index:2}.el-table .caret-wrapper{display:inline-flex;flex-direction:column;align-items:center;height:14px;width:24px;vertical-align:middle;cursor:pointer;overflow:initial;position:relative}.el-table .sort-caret{width:0;height:0;border:solid 5px transparent;position:absolute;left:7px}.el-table .sort-caret.ascending{border-bottom-color:var(--el-text-color-placeholder);top:-5px}.el-table .sort-caret.descending{border-top-color:var(--el-text-color-placeholder);bottom:-3px}.el-table .ascending .sort-caret.ascending{border-bottom-color:var(--el-color-primary)}.el-table .descending .sort-caret.descending{border-top-color:var(--el-color-primary)}.el-table .hidden-columns{visibility:hidden;position:absolute;z-index:-1}.el-table--striped .el-table__body tr.el-table__row--striped td.el-table__cell{background:var(--el-fill-color-lighter)}.el-table--striped .el-table__body tr.el-table__row--striped.current-row td.el-table__cell{background-color:var(--el-table-current-row-bg-color)}.el-table__body tr.hover-row.current-row>td.el-table__cell,.el-table__body tr.hover-row.el-table__row--striped.current-row>td.el-table__cell,.el-table__body tr.hover-row.el-table__row--striped>td.el-table__cell,.el-table__body tr.hover-row>td.el-table__cell{background-color:var(--el-table-row-hover-bg-color)}.el-table__body tr.current-row>td.el-table__cell{background-color:var(--el-table-current-row-bg-color)}.el-table__column-resize-proxy{position:absolute;left:200px;top:0;bottom:0;width:0;border-left:var(--el-table-border);z-index:10}.el-table__column-filter-trigger{display:inline-block;cursor:pointer}.el-table__column-filter-trigger i{color:var(--el-color-info);font-size:14px;vertical-align:middle}.el-table__border-left-patch{top:0;left:0;width:1px;height:100%;z-index:3;position:absolute;background-color:var(--el-table-border-color)}.el-table__border-bottom-patch{left:0;height:1px;z-index:3;position:absolute;background-color:var(--el-table-border-color)}.el-table__border-right-patch{top:0;height:100%;width:1px;z-index:3;position:absolute;background-color:var(--el-table-border-color)}.el-table--enable-row-transition .el-table__body td.el-table__cell{transition:background-color .25s ease}.el-table--enable-row-hover .el-table__body tr:hover>td.el-table__cell{background-color:var(--el-table-row-hover-bg-color)}.el-table [class*=el-table__row--level] .el-table__expand-icon{display:inline-block;width:12px;line-height:12px;height:12px;text-align:center;margin-right:8px}.el-table .el-table.el-table--border .el-table__cell{border-right:var(--el-table-border)}.el-table:not(.el-table--border) .el-table__cell{border-right:none}.el-table:not(.el-table--border)>.el-table__inner-wrapper:after{content:none}.el-table-v2{--el-table-border-color:var(--el-border-color-lighter);--el-table-border:1px solid var(--el-table-border-color);--el-table-text-color:var(--el-text-color-regular);--el-table-header-text-color:var(--el-text-color-secondary);--el-table-row-hover-bg-color:var(--el-fill-color-light);--el-table-current-row-bg-color:var(--el-color-primary-light-9);--el-table-header-bg-color:var(--el-bg-color);--el-table-fixed-box-shadow:var(--el-box-shadow-light);--el-table-bg-color:var(--el-fill-color-blank);--el-table-tr-bg-color:var(--el-fill-color-blank);--el-table-expanded-cell-bg-color:var(--el-fill-color-blank);--el-table-fixed-left-column:inset 10px 0 10px -10px rgba(0, 0, 0, .15);--el-table-fixed-right-column:inset -10px 0 10px -10px rgba(0, 0, 0, .15)}.el-table-v2{font-size:14px}.el-table-v2 *{box-sizing:border-box}.el-table-v2__root{position:relative}.el-table-v2__root:hover .el-table-v2__main .el-virtual-scrollbar{opacity:1}.el-table-v2__main{display:flex;flex-direction:column-reverse;position:absolute;overflow:hidden;top:0;background-color:var(--el-bg-color);left:0}.el-table-v2__main .el-vl__horizontal,.el-table-v2__main .el-vl__vertical{z-index:2}.el-table-v2__left{display:flex;flex-direction:column-reverse;position:absolute;overflow:hidden;top:0;background-color:var(--el-bg-color);left:0;box-shadow:2px 0 4px #0000000f}.el-table-v2__left .el-virtual-scrollbar{opacity:0}.el-table-v2__left .el-vl__horizontal,.el-table-v2__left .el-vl__vertical{z-index:-1}.el-table-v2__right{display:flex;flex-direction:column-reverse;position:absolute;overflow:hidden;top:0;background-color:var(--el-bg-color);right:0;box-shadow:-2px 0 4px #0000000f}.el-table-v2__right .el-virtual-scrollbar{opacity:0}.el-table-v2__right .el-vl__horizontal,.el-table-v2__right .el-vl__vertical{z-index:-1}.el-table-v2__header-row,.el-table-v2__row{-webkit-padding-end:var(--el-table-scrollbar-size);padding-inline-end:var(--el-table-scrollbar-size)}.el-table-v2__header-wrapper{overflow:hidden}.el-table-v2__header{position:relative;overflow:hidden}.el-table-v2__footer{position:absolute;left:0;right:0;bottom:0;overflow:hidden}.el-table-v2__empty{position:absolute;left:0}.el-table-v2__overlay{position:absolute;left:0;right:0;top:0;bottom:0;z-index:9999}.el-table-v2__header-row{display:flex;border-bottom:var(--el-table-border)}.el-table-v2__header-cell{display:flex;align-items:center;padding:0 8px;height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;background-color:var(--el-table-header-bg-color);color:var(--el-table-header-text-color);font-weight:700}.el-table-v2__header-cell.is-align-center{justify-content:center;text-align:center}.el-table-v2__header-cell.is-align-right{justify-content:flex-end;text-align:right}.el-table-v2__header-cell.is-sortable{cursor:pointer}.el-table-v2__header-cell:hover .el-icon{display:block}.el-table-v2__sort-icon{transition:opacity,display var(--el-transition-duration);opacity:.6;display:none}.el-table-v2__sort-icon.is-sorting{display:block;opacity:1}.el-table-v2__row{border-bottom:var(--el-table-border);display:flex;align-items:center;transition:background-color var(--el-transition-duration)}.el-table-v2__row.is-hovered,.el-table-v2__row:hover{background-color:var(--el-table-row-hover-bg-color)}.el-table-v2__row-cell{height:100%;overflow:hidden;display:flex;align-items:center;padding:0 8px}.el-table-v2__row-cell.is-align-center{justify-content:center;text-align:center}.el-table-v2__row-cell.is-align-right{justify-content:flex-end;text-align:right}.el-table-v2__expand-icon{margin:0 4px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-table-v2__expand-icon svg{transition:transform var(--el-transition-duration)}.el-table-v2__expand-icon.is-expanded svg{transform:rotate(90deg)}.el-table-v2:not(.is-dynamic) .el-table-v2__cell-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-table-v2.is-dynamic .el-table-v2__row{overflow:hidden;align-items:stretch}.el-table-v2.is-dynamic .el-table-v2__row .el-table-v2__row-cell{word-break:break-all}.el-tabs{--el-tabs-header-height:40px}.el-tabs__header{padding:0;position:relative;margin:0 0 15px}.el-tabs__active-bar{position:absolute;bottom:0;left:0;height:2px;background-color:var(--el-color-primary);z-index:1;transition:width var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier),transform var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);list-style:none}.el-tabs__new-tab{display:flex;align-items:center;justify-content:center;float:right;border:1px solid var(--el-border-color);height:20px;width:20px;line-height:20px;margin:10px 0 10px 10px;border-radius:3px;text-align:center;font-size:12px;color:var(--el-text-color-primary);cursor:pointer;transition:all .15s}.el-tabs__new-tab .is-icon-plus{height:inherit;width:inherit;transform:scale(.8)}.el-tabs__new-tab .is-icon-plus svg{vertical-align:middle}.el-tabs__new-tab:hover{color:var(--el-color-primary)}.el-tabs__nav-wrap{overflow:hidden;margin-bottom:-1px;position:relative}.el-tabs__nav-wrap:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background-color:var(--el-border-color-light);z-index:var(--el-index-normal)}.el-tabs__nav-wrap.is-scrollable{padding:0 20px;box-sizing:border-box}.el-tabs__nav-scroll{overflow:hidden}.el-tabs__nav-next,.el-tabs__nav-prev{position:absolute;cursor:pointer;line-height:44px;font-size:12px;color:var(--el-text-color-secondary);width:20px;text-align:center}.el-tabs__nav-next{right:0}.el-tabs__nav-prev{left:0}.el-tabs__nav{display:flex;white-space:nowrap;position:relative;transition:transform var(--el-transition-duration);float:left;z-index:calc(var(--el-index-normal) + 1)}.el-tabs__nav.is-stretch{min-width:100%;display:flex}.el-tabs__nav.is-stretch>*{flex:1;text-align:center}.el-tabs__item{padding:0 20px;height:var(--el-tabs-header-height);box-sizing:border-box;display:flex;align-items:center;justify-content:center;list-style:none;font-size:var(--el-font-size-base);font-weight:500;color:var(--el-text-color-primary);position:relative}.el-tabs__item:focus,.el-tabs__item:focus:active{outline:0}.el-tabs__item:focus-visible{box-shadow:0 0 2px 2px var(--el-color-primary) inset;border-radius:3px}.el-tabs__item .is-icon-close{border-radius:50%;text-align:center;transition:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);margin-left:5px}.el-tabs__item .is-icon-close:before{transform:scale(.9);display:inline-block}.el-tabs__item .is-icon-close:hover{background-color:var(--el-text-color-placeholder);color:#fff}.el-tabs__item.is-active{color:var(--el-color-primary)}.el-tabs__item:hover{color:var(--el-color-primary);cursor:pointer}.el-tabs__item.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-tabs__content{overflow:hidden;position:relative}.el-tabs--card>.el-tabs__header{border-bottom:1px solid var(--el-border-color-light);height:var(--el-tabs-header-height)}.el-tabs--card>.el-tabs__header .el-tabs__nav-wrap:after{content:none}.el-tabs--card>.el-tabs__header .el-tabs__nav{border:1px solid var(--el-border-color-light);border-bottom:none;border-radius:4px 4px 0 0;box-sizing:border-box}.el-tabs--card>.el-tabs__header .el-tabs__active-bar{display:none}.el-tabs--card>.el-tabs__header .el-tabs__item .is-icon-close{position:relative;font-size:12px;width:0;height:14px;overflow:hidden;right:-2px;transform-origin:100% 50%}.el-tabs--card>.el-tabs__header .el-tabs__item{border-bottom:1px solid transparent;border-left:1px solid var(--el-border-color-light);transition:color var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier),padding var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier)}.el-tabs--card>.el-tabs__header .el-tabs__item:first-child{border-left:none}.el-tabs--card>.el-tabs__header .el-tabs__item.is-closable:hover{padding-left:13px;padding-right:13px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-closable:hover .is-icon-close{width:14px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active{border-bottom-color:var(--el-bg-color)}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active.is-closable{padding-left:20px;padding-right:20px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active.is-closable .is-icon-close{width:14px}.el-tabs--border-card{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color)}.el-tabs--border-card>.el-tabs__content{padding:15px}.el-tabs--border-card>.el-tabs__header{background-color:var(--el-fill-color-light);border-bottom:1px solid var(--el-border-color-light);margin:0}.el-tabs--border-card>.el-tabs__header .el-tabs__nav-wrap:after{content:none}.el-tabs--border-card>.el-tabs__header .el-tabs__item{transition:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);border:1px solid transparent;margin-top:-1px;color:var(--el-text-color-secondary)}.el-tabs--border-card>.el-tabs__header .el-tabs__item:first-child{margin-left:-1px}.el-tabs--border-card>.el-tabs__header .el-tabs__item+.el-tabs__item{margin-left:-1px}.el-tabs--border-card>.el-tabs__header .el-tabs__item.is-active{color:var(--el-color-primary);background-color:var(--el-bg-color-overlay);border-right-color:var(--el-border-color);border-left-color:var(--el-border-color)}.el-tabs--border-card>.el-tabs__header .el-tabs__item:not(.is-disabled):hover{color:var(--el-color-primary)}.el-tabs--border-card>.el-tabs__header .el-tabs__item.is-disabled{color:var(--el-disabled-text-color)}.el-tabs--border-card>.el-tabs__header .is-scrollable .el-tabs__item:first-child{margin-left:0}.el-tabs--bottom .el-tabs__item.is-bottom:nth-child(2),.el-tabs--bottom .el-tabs__item.is-top:nth-child(2),.el-tabs--top .el-tabs__item.is-bottom:nth-child(2),.el-tabs--top .el-tabs__item.is-top:nth-child(2){padding-left:0}.el-tabs--bottom .el-tabs__item.is-bottom:last-child,.el-tabs--bottom .el-tabs__item.is-top:last-child,.el-tabs--top .el-tabs__item.is-bottom:last-child,.el-tabs--top .el-tabs__item.is-top:last-child{padding-right:0}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2){padding-left:20px}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover{padding-left:13px}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:last-child,.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:last-child,.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:last-child{padding-right:20px}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover{padding-right:13px}.el-tabs--bottom .el-tabs__header.is-bottom{margin-bottom:0;margin-top:10px}.el-tabs--bottom.el-tabs--border-card .el-tabs__header.is-bottom{border-bottom:0;border-top:1px solid var(--el-border-color)}.el-tabs--bottom.el-tabs--border-card .el-tabs__nav-wrap.is-bottom{margin-top:-1px;margin-bottom:0}.el-tabs--bottom.el-tabs--border-card .el-tabs__item.is-bottom:not(.is-active){border:1px solid transparent}.el-tabs--bottom.el-tabs--border-card .el-tabs__item.is-bottom{margin:0 -1px -1px}.el-tabs--left,.el-tabs--right{overflow:hidden}.el-tabs--left .el-tabs__header.is-left,.el-tabs--left .el-tabs__header.is-right,.el-tabs--left .el-tabs__nav-scroll,.el-tabs--left .el-tabs__nav-wrap.is-left,.el-tabs--left .el-tabs__nav-wrap.is-right,.el-tabs--right .el-tabs__header.is-left,.el-tabs--right .el-tabs__header.is-right,.el-tabs--right .el-tabs__nav-scroll,.el-tabs--right .el-tabs__nav-wrap.is-left,.el-tabs--right .el-tabs__nav-wrap.is-right{height:100%}.el-tabs--left .el-tabs__active-bar.is-left,.el-tabs--left .el-tabs__active-bar.is-right,.el-tabs--right .el-tabs__active-bar.is-left,.el-tabs--right .el-tabs__active-bar.is-right{top:0;bottom:auto;width:2px;height:auto}.el-tabs--left .el-tabs__nav-wrap.is-left,.el-tabs--left .el-tabs__nav-wrap.is-right,.el-tabs--right .el-tabs__nav-wrap.is-left,.el-tabs--right .el-tabs__nav-wrap.is-right{margin-bottom:0}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev{height:30px;line-height:30px;width:100%;text-align:center;cursor:pointer}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next i,.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev i,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next i,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev i,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next i,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev i,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next i,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev i{transform:rotate(90deg)}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev{left:auto;top:0}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next{right:auto;bottom:0}.el-tabs--left .el-tabs__nav-wrap.is-left.is-scrollable,.el-tabs--left .el-tabs__nav-wrap.is-right.is-scrollable,.el-tabs--right .el-tabs__nav-wrap.is-left.is-scrollable,.el-tabs--right .el-tabs__nav-wrap.is-right.is-scrollable{padding:30px 0}.el-tabs--left .el-tabs__nav-wrap.is-left:after,.el-tabs--left .el-tabs__nav-wrap.is-right:after,.el-tabs--right .el-tabs__nav-wrap.is-left:after,.el-tabs--right .el-tabs__nav-wrap.is-right:after{height:100%;width:2px;bottom:auto;top:0}.el-tabs--left .el-tabs__nav.is-left,.el-tabs--left .el-tabs__nav.is-right,.el-tabs--right .el-tabs__nav.is-left,.el-tabs--right .el-tabs__nav.is-right{flex-direction:column}.el-tabs--left .el-tabs__item.is-left,.el-tabs--right .el-tabs__item.is-left{justify-content:flex-end}.el-tabs--left .el-tabs__item.is-right,.el-tabs--right .el-tabs__item.is-right{justify-content:flex-start}.el-tabs--left .el-tabs__header.is-left{float:left;margin-bottom:0;margin-right:10px}.el-tabs--left .el-tabs__nav-wrap.is-left{margin-right:-1px}.el-tabs--left .el-tabs__nav-wrap.is-left:after{left:auto;right:0}.el-tabs--left .el-tabs__active-bar.is-left{right:0;left:auto}.el-tabs--left .el-tabs__item.is-left{text-align:right}.el-tabs--left.el-tabs--card .el-tabs__active-bar.is-left{display:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left{border-left:none;border-right:1px solid var(--el-border-color-light);border-bottom:none;border-top:1px solid var(--el-border-color-light);text-align:left}.el-tabs--left.el-tabs--card .el-tabs__item.is-left:first-child{border-right:1px solid var(--el-border-color-light);border-top:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active{border:1px solid var(--el-border-color-light);border-right-color:#fff;border-left:none;border-bottom:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active:first-child{border-top:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active:last-child{border-bottom:none}.el-tabs--left.el-tabs--card .el-tabs__nav{border-radius:4px 0 0 4px;border-bottom:1px solid var(--el-border-color-light);border-right:none}.el-tabs--left.el-tabs--card .el-tabs__new-tab{float:none}.el-tabs--left.el-tabs--border-card .el-tabs__header.is-left{border-right:1px solid var(--el-border-color)}.el-tabs--left.el-tabs--border-card .el-tabs__item.is-left{border:1px solid transparent;margin:-1px 0 -1px -1px}.el-tabs--left.el-tabs--border-card .el-tabs__item.is-left.is-active{border-color:transparent;border-top-color:#d1dbe5;border-bottom-color:#d1dbe5}.el-tabs--right .el-tabs__header.is-right{float:right;margin-bottom:0;margin-left:10px}.el-tabs--right .el-tabs__nav-wrap.is-right{margin-left:-1px}.el-tabs--right .el-tabs__nav-wrap.is-right:after{left:0;right:auto}.el-tabs--right .el-tabs__active-bar.is-right{left:0}.el-tabs--right.el-tabs--card .el-tabs__active-bar.is-right{display:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right{border-bottom:none;border-top:1px solid var(--el-border-color-light)}.el-tabs--right.el-tabs--card .el-tabs__item.is-right:first-child{border-left:1px solid var(--el-border-color-light);border-top:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active{border:1px solid var(--el-border-color-light);border-left-color:#fff;border-right:none;border-bottom:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active:first-child{border-top:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active:last-child{border-bottom:none}.el-tabs--right.el-tabs--card .el-tabs__nav{border-radius:0 4px 4px 0;border-bottom:1px solid var(--el-border-color-light);border-left:none}.el-tabs--right.el-tabs--border-card .el-tabs__header.is-right{border-left:1px solid var(--el-border-color)}.el-tabs--right.el-tabs--border-card .el-tabs__item.is-right{border:1px solid transparent;margin:-1px -1px -1px 0}.el-tabs--right.el-tabs--border-card .el-tabs__item.is-right.is-active{border-color:transparent;border-top-color:#d1dbe5;border-bottom-color:#d1dbe5}.slideInLeft-transition,.slideInRight-transition{display:inline-block}.slideInRight-enter{-webkit-animation:slideInRight-enter var(--el-transition-duration);animation:slideInRight-enter var(--el-transition-duration)}.slideInRight-leave{position:absolute;left:0;right:0;-webkit-animation:slideInRight-leave var(--el-transition-duration);animation:slideInRight-leave var(--el-transition-duration)}.slideInLeft-enter{-webkit-animation:slideInLeft-enter var(--el-transition-duration);animation:slideInLeft-enter var(--el-transition-duration)}.slideInLeft-leave{position:absolute;left:0;right:0;-webkit-animation:slideInLeft-leave var(--el-transition-duration);animation:slideInLeft-leave var(--el-transition-duration)}@-webkit-keyframes slideInRight-enter{0%{opacity:0;transform-origin:0 0;transform:translate(100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@keyframes slideInRight-enter{0%{opacity:0;transform-origin:0 0;transform:translate(100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@-webkit-keyframes slideInRight-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(100%);opacity:0}}@keyframes slideInRight-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(100%);opacity:0}}@-webkit-keyframes slideInLeft-enter{0%{opacity:0;transform-origin:0 0;transform:translate(-100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@keyframes slideInLeft-enter{0%{opacity:0;transform-origin:0 0;transform:translate(-100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@-webkit-keyframes slideInLeft-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(-100%);opacity:0}}@keyframes slideInLeft-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(-100%);opacity:0}}.el-tag{--el-tag-font-size:12px;--el-tag-border-radius:4px;--el-tag-border-radius-rounded:9999px}.el-tag{--el-tag-bg-color:var(--el-color-primary-light-9);--el-tag-border-color:var(--el-color-primary-light-8);--el-tag-hover-color:var(--el-color-primary);--el-tag-text-color:var(--el-color-primary);background-color:var(--el-tag-bg-color);border-color:var(--el-tag-border-color);color:var(--el-tag-text-color);display:inline-flex;justify-content:center;align-items:center;height:24px;padding:0 9px;font-size:var(--el-tag-font-size);line-height:1;border-width:1px;border-style:solid;border-radius:var(--el-tag-border-radius);box-sizing:border-box;white-space:nowrap;--el-icon-size:14px}.el-tag.el-tag--primary{--el-tag-bg-color:var(--el-color-primary-light-9);--el-tag-border-color:var(--el-color-primary-light-8);--el-tag-hover-color:var(--el-color-primary)}.el-tag.el-tag--success{--el-tag-bg-color:var(--el-color-success-light-9);--el-tag-border-color:var(--el-color-success-light-8);--el-tag-hover-color:var(--el-color-success)}.el-tag.el-tag--warning{--el-tag-bg-color:var(--el-color-warning-light-9);--el-tag-border-color:var(--el-color-warning-light-8);--el-tag-hover-color:var(--el-color-warning)}.el-tag.el-tag--danger{--el-tag-bg-color:var(--el-color-danger-light-9);--el-tag-border-color:var(--el-color-danger-light-8);--el-tag-hover-color:var(--el-color-danger)}.el-tag.el-tag--error{--el-tag-bg-color:var(--el-color-error-light-9);--el-tag-border-color:var(--el-color-error-light-8);--el-tag-hover-color:var(--el-color-error)}.el-tag.el-tag--info{--el-tag-bg-color:var(--el-color-info-light-9);--el-tag-border-color:var(--el-color-info-light-8);--el-tag-hover-color:var(--el-color-info)}.el-tag.el-tag--primary{--el-tag-text-color:var(--el-color-primary)}.el-tag.el-tag--success{--el-tag-text-color:var(--el-color-success)}.el-tag.el-tag--warning{--el-tag-text-color:var(--el-color-warning)}.el-tag.el-tag--danger{--el-tag-text-color:var(--el-color-danger)}.el-tag.el-tag--error{--el-tag-text-color:var(--el-color-error)}.el-tag.el-tag--info{--el-tag-text-color:var(--el-color-info)}.el-tag.is-hit{border-color:var(--el-color-primary)}.el-tag.is-round{border-radius:var(--el-tag-border-radius-rounded)}.el-tag .el-tag__close{color:var(--el-tag-text-color)}.el-tag .el-tag__close:hover{color:var(--el-color-white);background-color:var(--el-tag-hover-color)}.el-tag .el-icon{border-radius:50%;cursor:pointer;font-size:calc(var(--el-icon-size) - 2px);height:var(--el-icon-size);width:var(--el-icon-size)}.el-tag .el-tag__close{margin-left:6px}.el-tag--dark{--el-tag-bg-color:var(--el-color-primary);--el-tag-border-color:var(--el-color-primary);--el-tag-hover-color:var(--el-color-primary-light-3);--el-tag-text-color:var(--el-color-white)}.el-tag--dark.el-tag--primary{--el-tag-bg-color:var(--el-color-primary);--el-tag-border-color:var(--el-color-primary);--el-tag-hover-color:var(--el-color-primary-light-3)}.el-tag--dark.el-tag--success{--el-tag-bg-color:var(--el-color-success);--el-tag-border-color:var(--el-color-success);--el-tag-hover-color:var(--el-color-success-light-3)}.el-tag--dark.el-tag--warning{--el-tag-bg-color:var(--el-color-warning);--el-tag-border-color:var(--el-color-warning);--el-tag-hover-color:var(--el-color-warning-light-3)}.el-tag--dark.el-tag--danger{--el-tag-bg-color:var(--el-color-danger);--el-tag-border-color:var(--el-color-danger);--el-tag-hover-color:var(--el-color-danger-light-3)}.el-tag--dark.el-tag--error{--el-tag-bg-color:var(--el-color-error);--el-tag-border-color:var(--el-color-error);--el-tag-hover-color:var(--el-color-error-light-3)}.el-tag--dark.el-tag--info{--el-tag-bg-color:var(--el-color-info);--el-tag-border-color:var(--el-color-info);--el-tag-hover-color:var(--el-color-info-light-3)}.el-tag--dark.el-tag--primary,.el-tag--dark.el-tag--success,.el-tag--dark.el-tag--warning,.el-tag--dark.el-tag--danger,.el-tag--dark.el-tag--error,.el-tag--dark.el-tag--info{--el-tag-text-color:var(--el-color-white)}.el-tag--plain{--el-tag-border-color:var(--el-color-primary-light-5);--el-tag-hover-color:var(--el-color-primary);--el-tag-bg-color:var(--el-fill-color-blank)}.el-tag--plain.el-tag--primary{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-primary-light-5);--el-tag-hover-color:var(--el-color-primary)}.el-tag--plain.el-tag--success{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-success-light-5);--el-tag-hover-color:var(--el-color-success)}.el-tag--plain.el-tag--warning{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-warning-light-5);--el-tag-hover-color:var(--el-color-warning)}.el-tag--plain.el-tag--danger{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-danger-light-5);--el-tag-hover-color:var(--el-color-danger)}.el-tag--plain.el-tag--error{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-error-light-5);--el-tag-hover-color:var(--el-color-error)}.el-tag--plain.el-tag--info{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-info-light-5);--el-tag-hover-color:var(--el-color-info)}.el-tag.is-closable{padding-right:5px}.el-tag--large{padding:0 11px;height:32px;--el-icon-size:16px}.el-tag--large .el-tag__close{margin-left:8px}.el-tag--large.is-closable{padding-right:7px}.el-tag--small{padding:0 7px;height:20px;--el-icon-size:12px}.el-tag--small .el-tag__close{margin-left:4px}.el-tag--small.is-closable{padding-right:3px}.el-tag--small .el-icon-close{transform:scale(.8)}.el-tag.el-tag--primary.is-hit{border-color:var(--el-color-primary)}.el-tag.el-tag--success.is-hit{border-color:var(--el-color-success)}.el-tag.el-tag--warning.is-hit{border-color:var(--el-color-warning)}.el-tag.el-tag--danger.is-hit{border-color:var(--el-color-danger)}.el-tag.el-tag--error.is-hit{border-color:var(--el-color-error)}.el-tag.el-tag--info.is-hit{border-color:var(--el-color-info)}.el-text{--el-text-font-size:var(--el-font-size-base);--el-text-color:var(--el-text-color-regular)}.el-text{align-self:center;margin:0;padding:0;font-size:var(--el-text-font-size);color:var(--el-text-color);word-break:break-all}.el-text.is-truncated{display:inline-block;max-width:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.el-text--large{--el-text-font-size:var(--el-font-size-medium)}.el-text--default{--el-text-font-size:var(--el-font-size-base)}.el-text--small{--el-text-font-size:var(--el-font-size-extra-small)}.el-text.el-text--primary{--el-text-color:var(--el-color-primary)}.el-text.el-text--success{--el-text-color:var(--el-color-success)}.el-text.el-text--warning{--el-text-color:var(--el-color-warning)}.el-text.el-text--danger{--el-text-color:var(--el-color-danger)}.el-text.el-text--error{--el-text-color:var(--el-color-error)}.el-text.el-text--info{--el-text-color:var(--el-color-info)}.el-text>.el-icon{vertical-align:-2px}.time-select{margin:5px 0;min-width:0}.time-select .el-picker-panel__content{max-height:200px;margin:0}.time-select-item{padding:8px 10px;font-size:14px;line-height:20px}.time-select-item.disabled{color:var(--el-datepicker-border-color);cursor:not-allowed}.time-select-item:hover{background-color:var(--el-fill-color-light);font-weight:700;cursor:pointer}.time-select .time-select-item.selected:not(.disabled){color:var(--el-color-primary);font-weight:700}.el-timeline-item{position:relative;padding-bottom:20px}.el-timeline-item__wrapper{position:relative;padding-left:28px;top:-3px}.el-timeline-item__tail{position:absolute;left:4px;height:100%;border-left:2px solid var(--el-timeline-node-color)}.el-timeline-item .el-timeline-item__icon{color:var(--el-color-white);font-size:var(--el-font-size-small)}.el-timeline-item__node{position:absolute;background-color:var(--el-timeline-node-color);border-color:var(--el-timeline-node-color);border-radius:50%;box-sizing:border-box;display:flex;justify-content:center;align-items:center}.el-timeline-item__node--normal{left:-1px;width:var(--el-timeline-node-size-normal);height:var(--el-timeline-node-size-normal)}.el-timeline-item__node--large{left:-2px;width:var(--el-timeline-node-size-large);height:var(--el-timeline-node-size-large)}.el-timeline-item__node.is-hollow{background:var(--el-color-white);border-style:solid;border-width:2px}.el-timeline-item__node--primary{background-color:var(--el-color-primary);border-color:var(--el-color-primary)}.el-timeline-item__node--success{background-color:var(--el-color-success);border-color:var(--el-color-success)}.el-timeline-item__node--warning{background-color:var(--el-color-warning);border-color:var(--el-color-warning)}.el-timeline-item__node--danger{background-color:var(--el-color-danger);border-color:var(--el-color-danger)}.el-timeline-item__node--info{background-color:var(--el-color-info);border-color:var(--el-color-info)}.el-timeline-item__dot{position:absolute;display:flex;justify-content:center;align-items:center}.el-timeline-item__content{color:var(--el-text-color-primary)}.el-timeline-item__timestamp{color:var(--el-text-color-secondary);line-height:1;font-size:var(--el-font-size-small)}.el-timeline-item__timestamp.is-top{margin-bottom:8px;padding-top:4px}.el-timeline-item__timestamp.is-bottom{margin-top:8px}.el-timeline{--el-timeline-node-size-normal:12px;--el-timeline-node-size-large:14px;--el-timeline-node-color:var(--el-border-color-light)}.el-timeline{margin:0;font-size:var(--el-font-size-base);list-style:none}.el-timeline .el-timeline-item:last-child .el-timeline-item__tail{display:none}.el-timeline .el-timeline-item__center{display:flex;align-items:center}.el-timeline .el-timeline-item__center .el-timeline-item__wrapper{width:100%}.el-timeline .el-timeline-item__center .el-timeline-item__tail{top:0}.el-timeline .el-timeline-item__center:first-child .el-timeline-item__tail{height:calc(50% + 10px);top:calc(50% - 10px)}.el-timeline .el-timeline-item__center:last-child .el-timeline-item__tail{display:block;height:calc(50% - 10px)}.el-tooltip-v2__content{--el-tooltip-v2-padding:5px 10px;--el-tooltip-v2-border-radius:4px;--el-tooltip-v2-border-color:var(--el-border-color);border-radius:var(--el-tooltip-v2-border-radius);color:var(--el-color-black);background-color:var(--el-color-white);padding:var(--el-tooltip-v2-padding);border:1px solid var(--el-border-color)}.el-tooltip-v2__arrow{position:absolute;color:var(--el-color-white);width:var(--el-tooltip-v2-arrow-width);height:var(--el-tooltip-v2-arrow-height);pointer-events:none;left:var(--el-tooltip-v2-arrow-x);top:var(--el-tooltip-v2-arrow-y)}.el-tooltip-v2__arrow:before{content:"";width:0;height:0;border:var(--el-tooltip-v2-arrow-border-width) solid transparent;position:absolute}.el-tooltip-v2__arrow:after{content:"";width:0;height:0;border:var(--el-tooltip-v2-arrow-border-width) solid transparent;position:absolute}.el-tooltip-v2__content[data-side^=top] .el-tooltip-v2__arrow{bottom:0}.el-tooltip-v2__content[data-side^=top] .el-tooltip-v2__arrow:before{border-top-color:var(--el-color-white);border-top-width:var(--el-tooltip-v2-arrow-border-width);border-bottom:0;top:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=top] .el-tooltip-v2__arrow:after{border-top-color:var(--el-border-color);border-top-width:var(--el-tooltip-v2-arrow-border-width);border-bottom:0;top:100%;z-index:-1}.el-tooltip-v2__content[data-side^=bottom] .el-tooltip-v2__arrow{top:0}.el-tooltip-v2__content[data-side^=bottom] .el-tooltip-v2__arrow:before{border-bottom-color:var(--el-color-white);border-bottom-width:var(--el-tooltip-v2-arrow-border-width);border-top:0;bottom:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=bottom] .el-tooltip-v2__arrow:after{border-bottom-color:var(--el-border-color);border-bottom-width:var(--el-tooltip-v2-arrow-border-width);border-top:0;bottom:100%;z-index:-1}.el-tooltip-v2__content[data-side^=left] .el-tooltip-v2__arrow{right:0}.el-tooltip-v2__content[data-side^=left] .el-tooltip-v2__arrow:before{border-left-color:var(--el-color-white);border-left-width:var(--el-tooltip-v2-arrow-border-width);border-right:0;left:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=left] .el-tooltip-v2__arrow:after{border-left-color:var(--el-border-color);border-left-width:var(--el-tooltip-v2-arrow-border-width);border-right:0;left:100%;z-index:-1}.el-tooltip-v2__content[data-side^=right] .el-tooltip-v2__arrow{left:0}.el-tooltip-v2__content[data-side^=right] .el-tooltip-v2__arrow:before{border-right-color:var(--el-color-white);border-right-width:var(--el-tooltip-v2-arrow-border-width);border-left:0;right:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=right] .el-tooltip-v2__arrow:after{border-right-color:var(--el-border-color);border-right-width:var(--el-tooltip-v2-arrow-border-width);border-left:0;right:100%;z-index:-1}.el-tooltip-v2__content.is-dark{--el-tooltip-v2-border-color:transparent;background-color:var(--el-color-black);color:var(--el-color-white);border-color:transparent}.el-tooltip-v2__content.is-dark .el-tooltip-v2__arrow{background-color:var(--el-color-black);border-color:transparent}.el-transfer{--el-transfer-border-color:var(--el-border-color-lighter);--el-transfer-border-radius:var(--el-border-radius-base);--el-transfer-panel-width:200px;--el-transfer-panel-header-height:40px;--el-transfer-panel-header-bg-color:var(--el-fill-color-light);--el-transfer-panel-footer-height:40px;--el-transfer-panel-body-height:278px;--el-transfer-item-height:30px;--el-transfer-filter-height:32px}.el-transfer{font-size:var(--el-font-size-base)}.el-transfer__buttons{display:inline-block;vertical-align:middle;padding:0 30px}.el-transfer__button{vertical-align:top}.el-transfer__button:nth-child(2){margin:0 0 0 10px}.el-transfer__button i,.el-transfer__button span{font-size:14px}.el-transfer__button .el-icon+span{margin-left:0}.el-transfer-panel{overflow:hidden;background:var(--el-bg-color-overlay);display:inline-block;text-align:left;vertical-align:middle;width:var(--el-transfer-panel-width);max-height:100%;box-sizing:border-box;position:relative}.el-transfer-panel__body{height:var(--el-transfer-panel-body-height);border-left:1px solid var(--el-transfer-border-color);border-right:1px solid var(--el-transfer-border-color);border-bottom:1px solid var(--el-transfer-border-color);border-bottom-left-radius:var(--el-transfer-border-radius);border-bottom-right-radius:var(--el-transfer-border-radius);overflow:hidden}.el-transfer-panel__body.is-with-footer{border-bottom:none;border-bottom-left-radius:0;border-bottom-right-radius:0}.el-transfer-panel__list{margin:0;padding:6px 0;list-style:none;height:var(--el-transfer-panel-body-height);overflow:auto;box-sizing:border-box}.el-transfer-panel__list.is-filterable{height:calc(100% - var(--el-transfer-filter-height) - 30px);padding-top:0}.el-transfer-panel__item{height:var(--el-transfer-item-height);line-height:var(--el-transfer-item-height);padding-left:15px;display:block!important}.el-transfer-panel__item+.el-transfer-panel__item{margin-left:0}.el-transfer-panel__item.el-checkbox{color:var(--el-text-color-regular)}.el-transfer-panel__item:hover{color:var(--el-color-primary)}.el-transfer-panel__item.el-checkbox .el-checkbox__label{width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;box-sizing:border-box;padding-left:22px;line-height:var(--el-transfer-item-height)}.el-transfer-panel__item .el-checkbox__input{position:absolute;top:8px}.el-transfer-panel__filter{text-align:center;padding:15px;box-sizing:border-box}.el-transfer-panel__filter .el-input__inner{height:var(--el-transfer-filter-height);width:100%;font-size:12px;display:inline-block;box-sizing:border-box;border-radius:calc(var(--el-transfer-filter-height)/ 2)}.el-transfer-panel__filter .el-icon-circle-close{cursor:pointer}.el-transfer-panel .el-transfer-panel__header{display:flex;align-items:center;height:var(--el-transfer-panel-header-height);background:var(--el-transfer-panel-header-bg-color);margin:0;padding-left:15px;border:1px solid var(--el-transfer-border-color);border-top-left-radius:var(--el-transfer-border-radius);border-top-right-radius:var(--el-transfer-border-radius);box-sizing:border-box;color:var(--el-color-black)}.el-transfer-panel .el-transfer-panel__header .el-checkbox{position:relative;display:flex;width:100%;align-items:center}.el-transfer-panel .el-transfer-panel__header .el-checkbox .el-checkbox__label{font-size:16px;color:var(--el-text-color-primary);font-weight:400}.el-transfer-panel .el-transfer-panel__header .el-checkbox .el-checkbox__label span{position:absolute;right:15px;top:50%;transform:translate3d(0,-50%,0);color:var(--el-text-color-secondary);font-size:12px;font-weight:400}.el-transfer-panel .el-transfer-panel__footer{height:var(--el-transfer-panel-footer-height);background:var(--el-bg-color-overlay);margin:0;padding:0;border:1px solid var(--el-transfer-border-color);border-bottom-left-radius:var(--el-transfer-border-radius);border-bottom-right-radius:var(--el-transfer-border-radius)}.el-transfer-panel .el-transfer-panel__footer:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-transfer-panel .el-transfer-panel__footer .el-checkbox{padding-left:20px;color:var(--el-text-color-regular)}.el-transfer-panel .el-transfer-panel__empty{margin:0;height:var(--el-transfer-item-height);line-height:var(--el-transfer-item-height);padding:6px 15px 0;color:var(--el-text-color-secondary);text-align:center}.el-transfer-panel .el-checkbox__label{padding-left:8px}.el-transfer-panel .el-checkbox__inner{height:14px;width:14px;border-radius:3px}.el-transfer-panel .el-checkbox__inner:after{height:6px;width:3px;left:4px}.el-tree{--el-tree-node-hover-bg-color:var(--el-fill-color-light);--el-tree-text-color:var(--el-text-color-regular);--el-tree-expand-icon-color:var(--el-text-color-placeholder)}.el-tree{position:relative;cursor:default;background:var(--el-fill-color-blank);color:var(--el-tree-text-color);font-size:var(--el-font-size-base)}.el-tree__empty-block{position:relative;min-height:60px;text-align:center;width:100%;height:100%}.el-tree__empty-text{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:var(--el-text-color-secondary);font-size:var(--el-font-size-base)}.el-tree__drop-indicator{position:absolute;left:0;right:0;height:1px;background-color:var(--el-color-primary)}.el-tree-node{white-space:nowrap;outline:0}.el-tree-node:focus>.el-tree-node__content{background-color:var(--el-tree-node-hover-bg-color)}.el-tree-node.is-drop-inner>.el-tree-node__content .el-tree-node__label{background-color:var(--el-color-primary);color:#fff}.el-tree-node__content{display:flex;align-items:center;height:26px;cursor:pointer}.el-tree-node__content>.el-tree-node__expand-icon{padding:6px;box-sizing:content-box}.el-tree-node__content>label.el-checkbox{margin-right:8px}.el-tree-node__content:hover{background-color:var(--el-tree-node-hover-bg-color)}.el-tree.is-dragging .el-tree-node__content{cursor:move}.el-tree.is-dragging .el-tree-node__content *{pointer-events:none}.el-tree.is-dragging.is-drop-not-allow .el-tree-node__content{cursor:not-allowed}.el-tree-node__expand-icon{cursor:pointer;color:var(--el-tree-expand-icon-color);font-size:12px;transform:rotate(0);transition:transform var(--el-transition-duration) ease-in-out}.el-tree-node__expand-icon.expanded{transform:rotate(90deg)}.el-tree-node__expand-icon.is-leaf{color:transparent;cursor:default}.el-tree-node__expand-icon.is-hidden{visibility:hidden}.el-tree-node__loading-icon{margin-right:8px;font-size:var(--el-font-size-base);color:var(--el-tree-expand-icon-color)}.el-tree-node>.el-tree-node__children{overflow:hidden;background-color:transparent}.el-tree-node.is-expanded>.el-tree-node__children{display:block}.el-tree--highlight-current .el-tree-node.is-current>.el-tree-node__content{background-color:var(--el-color-primary-light-9)}.el-tree-select{--el-tree-node-hover-bg-color:var(--el-fill-color-light);--el-tree-text-color:var(--el-text-color-regular);--el-tree-expand-icon-color:var(--el-text-color-placeholder)}.el-tree-select__popper .el-tree-node__expand-icon{margin-left:8px}.el-tree-select__popper .el-tree-node.is-checked>.el-tree-node__content .el-select-dropdown__item.selected:after{content:none}.el-tree-select__popper .el-select-dropdown__item{flex:1;background:0 0!important;padding-left:0;height:20px;line-height:20px}.el-upload{--el-upload-dragger-padding-horizontal:40px;--el-upload-dragger-padding-vertical:10px}.el-upload{display:inline-flex;justify-content:center;align-items:center;cursor:pointer;outline:0}.el-upload__input{display:none}.el-upload__tip{font-size:12px;color:var(--el-text-color-regular);margin-top:7px}.el-upload iframe{position:absolute;z-index:-1;top:0;left:0;opacity:0}.el-upload--picture-card{--el-upload-picture-card-size:148px;background-color:var(--el-fill-color-lighter);border:1px dashed var(--el-border-color-darker);border-radius:6px;box-sizing:border-box;width:var(--el-upload-picture-card-size);height:var(--el-upload-picture-card-size);cursor:pointer;vertical-align:top;display:inline-flex;justify-content:center;align-items:center}.el-upload--picture-card i{font-size:28px;color:var(--el-text-color-secondary)}.el-upload--picture-card:hover{border-color:var(--el-color-primary);color:var(--el-color-primary)}.el-upload.is-drag{display:block}.el-upload:focus{border-color:var(--el-color-primary);color:var(--el-color-primary)}.el-upload:focus .el-upload-dragger{border-color:var(--el-color-primary)}.el-upload-dragger{padding:var(--el-upload-dragger-padding-horizontal) var(--el-upload-dragger-padding-vertical);background-color:var(--el-fill-color-blank);border:1px dashed var(--el-border-color);border-radius:6px;box-sizing:border-box;text-align:center;cursor:pointer;position:relative;overflow:hidden}.el-upload-dragger .el-icon--upload{font-size:67px;color:var(--el-text-color-placeholder);margin-bottom:16px;line-height:50px}.el-upload-dragger+.el-upload__tip{text-align:center}.el-upload-dragger~.el-upload__files{border-top:var(--el-border);margin-top:7px;padding-top:5px}.el-upload-dragger .el-upload__text{color:var(--el-text-color-regular);font-size:14px;text-align:center}.el-upload-dragger .el-upload__text em{color:var(--el-color-primary);font-style:normal}.el-upload-dragger:hover{border-color:var(--el-color-primary)}.el-upload-dragger.is-dragover{padding:calc(var(--el-upload-dragger-padding-horizontal) - 1px) calc(var(--el-upload-dragger-padding-vertical) - 1px);background-color:var(--el-color-primary-light-9);border:2px dashed var(--el-color-primary)}.el-upload-list{margin:10px 0 0;padding:0;list-style:none;position:relative}.el-upload-list__item{transition:all .5s cubic-bezier(.55,0,.1,1);font-size:14px;color:var(--el-text-color-regular);margin-bottom:5px;position:relative;box-sizing:border-box;border-radius:4px;width:100%}.el-upload-list__item .el-progress{position:absolute;top:20px;width:100%}.el-upload-list__item .el-progress__text{position:absolute;right:0;top:-13px}.el-upload-list__item .el-progress-bar{margin-right:0;padding-right:0}.el-upload-list__item .el-icon--upload-success{color:var(--el-color-success)}.el-upload-list__item .el-icon--close{display:none;position:absolute;right:5px;top:50%;cursor:pointer;opacity:.75;color:var(--el-text-color-regular);transition:opacity var(--el-transition-duration);transform:translateY(-50%)}.el-upload-list__item .el-icon--close:hover{opacity:1;color:var(--el-color-primary)}.el-upload-list__item .el-icon--close-tip{display:none;position:absolute;top:1px;right:5px;font-size:12px;cursor:pointer;opacity:1;color:var(--el-color-primary);font-style:normal}.el-upload-list__item:hover{background-color:var(--el-fill-color-light)}.el-upload-list__item:hover .el-icon--close{display:inline-flex}.el-upload-list__item:hover .el-progress__text{display:none}.el-upload-list__item .el-upload-list__item-info{display:inline-flex;justify-content:center;flex-direction:column;width:calc(100% - 30px);margin-left:4px}.el-upload-list__item.is-success .el-upload-list__item-status-label{display:inline-flex}.el-upload-list__item.is-success .el-upload-list__item-name:focus,.el-upload-list__item.is-success .el-upload-list__item-name:hover{color:var(--el-color-primary);cursor:pointer}.el-upload-list__item.is-success:focus:not(:hover) .el-icon--close-tip{display:inline-block}.el-upload-list__item.is-success:active,.el-upload-list__item.is-success:not(.focusing):focus{outline-width:0}.el-upload-list__item.is-success:active .el-icon--close-tip,.el-upload-list__item.is-success:not(.focusing):focus .el-icon--close-tip{display:none}.el-upload-list__item.is-success:focus .el-upload-list__item-status-label,.el-upload-list__item.is-success:hover .el-upload-list__item-status-label{display:none;opacity:0}.el-upload-list__item-name{color:var(--el-text-color-regular);display:inline-flex;text-align:center;align-items:center;padding:0 4px;transition:color var(--el-transition-duration);font-size:var(--el-font-size-base)}.el-upload-list__item-name .el-icon{margin-right:6px;color:var(--el-text-color-secondary)}.el-upload-list__item-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-upload-list__item-status-label{position:absolute;right:5px;top:0;line-height:inherit;display:none;height:100%;justify-content:center;align-items:center;transition:opacity var(--el-transition-duration)}.el-upload-list__item-delete{position:absolute;right:10px;top:0;font-size:12px;color:var(--el-text-color-regular);display:none}.el-upload-list__item-delete:hover{color:var(--el-color-primary)}.el-upload-list--picture-card{--el-upload-list-picture-card-size:148px;display:inline-flex;flex-wrap:wrap;margin:0}.el-upload-list--picture-card .el-upload-list__item{overflow:hidden;background-color:var(--el-fill-color-blank);border:1px solid var(--el-border-color);border-radius:6px;box-sizing:border-box;width:var(--el-upload-list-picture-card-size);height:var(--el-upload-list-picture-card-size);margin:0 8px 8px 0;padding:0;display:inline-flex}.el-upload-list--picture-card .el-upload-list__item .el-icon--check,.el-upload-list--picture-card .el-upload-list__item .el-icon--circle-check{color:#fff}.el-upload-list--picture-card .el-upload-list__item .el-icon--close{display:none}.el-upload-list--picture-card .el-upload-list__item:hover .el-upload-list__item-status-label{opacity:0;display:block}.el-upload-list--picture-card .el-upload-list__item:hover .el-progress__text{display:block}.el-upload-list--picture-card .el-upload-list__item .el-upload-list__item-name{display:none}.el-upload-list--picture-card .el-upload-list__item-thumbnail{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.el-upload-list--picture-card .el-upload-list__item-status-label{right:-15px;top:-6px;width:40px;height:24px;background:var(--el-color-success);text-align:center;transform:rotate(45deg)}.el-upload-list--picture-card .el-upload-list__item-status-label i{font-size:12px;margin-top:11px;transform:rotate(-45deg)}.el-upload-list--picture-card .el-upload-list__item-actions{position:absolute;width:100%;height:100%;left:0;top:0;cursor:default;display:inline-flex;justify-content:center;align-items:center;color:#fff;opacity:0;font-size:20px;background-color:var(--el-overlay-color-lighter);transition:opacity var(--el-transition-duration)}.el-upload-list--picture-card .el-upload-list__item-actions span{display:none;cursor:pointer}.el-upload-list--picture-card .el-upload-list__item-actions span+span{margin-left:1rem}.el-upload-list--picture-card .el-upload-list__item-actions .el-upload-list__item-delete{position:static;font-size:inherit;color:inherit}.el-upload-list--picture-card .el-upload-list__item-actions:hover{opacity:1}.el-upload-list--picture-card .el-upload-list__item-actions:hover span{display:inline-flex}.el-upload-list--picture-card .el-progress{top:50%;left:50%;transform:translate(-50%,-50%);bottom:auto;width:126px}.el-upload-list--picture-card .el-progress .el-progress__text{top:50%}.el-upload-list--picture .el-upload-list__item{overflow:hidden;z-index:0;background-color:var(--el-fill-color-blank);border:1px solid var(--el-border-color);border-radius:6px;box-sizing:border-box;margin-top:10px;padding:10px;display:flex;align-items:center}.el-upload-list--picture .el-upload-list__item .el-icon--check,.el-upload-list--picture .el-upload-list__item .el-icon--circle-check{color:#fff}.el-upload-list--picture .el-upload-list__item:hover .el-upload-list__item-status-label{opacity:0;display:inline-flex}.el-upload-list--picture .el-upload-list__item:hover .el-progress__text{display:block}.el-upload-list--picture .el-upload-list__item.is-success .el-upload-list__item-name i{display:none}.el-upload-list--picture .el-upload-list__item .el-icon--close{top:5px;transform:translateY(0)}.el-upload-list--picture .el-upload-list__item-thumbnail{display:inline-flex;justify-content:center;align-items:center;width:70px;height:70px;-o-object-fit:contain;object-fit:contain;position:relative;z-index:1;background-color:var(--el-color-white)}.el-upload-list--picture .el-upload-list__item-status-label{position:absolute;right:-17px;top:-7px;width:46px;height:26px;background:var(--el-color-success);text-align:center;transform:rotate(45deg)}.el-upload-list--picture .el-upload-list__item-status-label i{font-size:12px;margin-top:12px;transform:rotate(-45deg)}.el-upload-list--picture .el-progress{position:relative;top:-7px}.el-upload-cover{position:absolute;left:0;top:0;width:100%;height:100%;overflow:hidden;z-index:10;cursor:default}.el-upload-cover:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-upload-cover img{display:block;width:100%;height:100%}.el-upload-cover__label{right:-15px;top:-6px;width:40px;height:24px;background:var(--el-color-success);text-align:center;transform:rotate(45deg)}.el-upload-cover__label i{font-size:12px;margin-top:11px;transform:rotate(-45deg);color:#fff}.el-upload-cover__progress{display:inline-block;vertical-align:middle;position:static;width:243px}.el-upload-cover__progress+.el-upload__inner{opacity:0}.el-upload-cover__content{position:absolute;top:0;left:0;width:100%;height:100%}.el-upload-cover__interact{position:absolute;bottom:0;left:0;width:100%;height:100%;background-color:var(--el-overlay-color-light);text-align:center}.el-upload-cover__interact .btn{display:inline-block;color:#fff;font-size:14px;cursor:pointer;vertical-align:middle;transition:var(--el-transition-md-fade);margin-top:60px}.el-upload-cover__interact .btn i{margin-top:0}.el-upload-cover__interact .btn span{opacity:0;transition:opacity .15s linear}.el-upload-cover__interact .btn:not(:first-child){margin-left:35px}.el-upload-cover__interact .btn:hover{transform:translateY(-13px)}.el-upload-cover__interact .btn:hover span{opacity:1}.el-upload-cover__interact .btn i{color:#fff;display:block;font-size:24px;line-height:inherit;margin:0 auto 5px}.el-upload-cover__title{position:absolute;bottom:0;left:0;background-color:#fff;height:36px;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:400;text-align:left;padding:0 10px;margin:0;line-height:36px;font-size:14px;color:var(--el-text-color-primary)}.el-upload-cover+.el-upload__inner{opacity:0;position:relative;z-index:1}.el-vl__wrapper{position:relative}.el-vl__wrapper:hover .el-virtual-scrollbar,.el-vl__wrapper.always-on .el-virtual-scrollbar{opacity:1}.el-vl__window{scrollbar-width:none}.el-vl__window::-webkit-scrollbar{display:none}.el-virtual-scrollbar{opacity:0;transition:opacity .34s ease-out}.el-virtual-scrollbar.always-on{opacity:1}.el-vg__wrapper{position:relative}.el-popper{--el-popper-border-radius:var(--el-popover-border-radius, 4px)}.el-popper{position:absolute;border-radius:var(--el-popper-border-radius);padding:5px 11px;z-index:2000;font-size:12px;line-height:20px;min-width:10px;word-wrap:break-word;visibility:visible}.el-popper.is-dark{color:var(--el-bg-color);background:var(--el-text-color-primary);border:1px solid var(--el-text-color-primary)}.el-popper.is-dark .el-popper__arrow:before{border:1px solid var(--el-text-color-primary);background:var(--el-text-color-primary);right:0}.el-popper.is-light{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light)}.el-popper.is-light .el-popper__arrow:before{border:1px solid var(--el-border-color-light);background:var(--el-bg-color-overlay);right:0}.el-popper.is-pure{padding:0}.el-popper__arrow{position:absolute;width:10px;height:10px;z-index:-1}.el-popper__arrow:before{position:absolute;width:10px;height:10px;z-index:-1;content:" ";transform:rotate(45deg);background:var(--el-text-color-primary);box-sizing:border-box}.el-popper[data-popper-placement^=top]>.el-popper__arrow{bottom:-5px}.el-popper[data-popper-placement^=top]>.el-popper__arrow:before{border-bottom-right-radius:2px}.el-popper[data-popper-placement^=bottom]>.el-popper__arrow{top:-5px}.el-popper[data-popper-placement^=bottom]>.el-popper__arrow:before{border-top-left-radius:2px}.el-popper[data-popper-placement^=left]>.el-popper__arrow{right:-5px}.el-popper[data-popper-placement^=left]>.el-popper__arrow:before{border-top-right-radius:2px}.el-popper[data-popper-placement^=right]>.el-popper__arrow{left:-5px}.el-popper[data-popper-placement^=right]>.el-popper__arrow:before{border-bottom-left-radius:2px}.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent!important;border-left-color:transparent!important}.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent!important;border-right-color:transparent!important}.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent!important;border-bottom-color:transparent!important}.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent!important;border-top-color:transparent!important}.el-select-dropdown__item{font-size:var(--el-font-size-base);padding:0 32px 0 20px;position:relative;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--el-text-color-regular);height:34px;line-height:34px;box-sizing:border-box;cursor:pointer}.el-select-dropdown__item.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-select-dropdown__item.hover,.el-select-dropdown__item:hover{background-color:var(--el-fill-color-light)}.el-select-dropdown__item.selected{color:var(--el-color-primary);font-weight:700}.el-statistic{--el-statistic-title-font-weight:400;--el-statistic-title-font-size:var(--el-font-size-extra-small);--el-statistic-title-color:var(--el-text-color-regular);--el-statistic-content-font-weight:400;--el-statistic-content-font-size:var(--el-font-size-extra-large);--el-statistic-content-color:var(--el-text-color-primary)}.el-statistic__head{font-weight:var(--el-statistic-title-font-weight);font-size:var(--el-statistic-title-font-size);color:var(--el-statistic-title-color);line-height:20px;margin-bottom:4px}.el-statistic__content{font-weight:var(--el-statistic-content-font-weight);font-size:var(--el-statistic-content-font-size);color:var(--el-statistic-content-color)}.el-statistic__value{display:inline-block}.el-statistic__prefix{margin-right:4px;display:inline-block}.el-statistic__suffix{margin-left:4px;display:inline-block}.el-button{height:32rem!important;padding:8rem 15rem!important;font-size:14rem!important}.el-input__wrapper{padding:1rem 11rem!important}.el-input{height:32rem!important;font-size:14rem!important}.jt-wall-row .col-left{font-size:14rem!important}.el-color-picker__trigger{height:32rem!important;padding:4rem!important}.el-radio-button__inner{padding:8rem 15rem!important;font-size:14rem}.el-textarea__inner{padding:5rem 11rem!important;font-size:14rem}.el-input__inner{height:32rem!important;font-size:14rem!important}.jt-wall-row{display:flex;flex-direction:row;height:40rem;align-items:center}.jt-wall-row .col-left{display:flex;align-items:center;justify-content:right;width:60rem;font-family:Alimama_ShuHeiTi_Bold;font-weight:700;margin-right:8rem}.jt-wall-row .col-main{flex:1;display:flex;flex-direction:row}.jt-wall-row .col-main .el-input--suffix{background-color:#fff0}.jt-wall-row .col-main .el-input--suffix *{background-color:#fff0;color:#fff}.jt-wall-row .col-main .el-input-number__decrease,.jt-wall-row .col-main .el-input-number__increase{background-color:#3489ff;color:#fff}.jt-wall-dialog{pointer-events:none}.jt-wall-dialog .el-dialog{pointer-events:auto;position:absolute!important;background:rgba(5,45,155,.7);min-width:280rem;overflow:hidden;margin-top:0rem}.jt-wall-dialog .el-dialog .el-dialog__header{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZAAAAAyCAIAAAD9fhrKAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDo4NTc1YTY2Yi1hY2U5LTUyNDctODM5MS01MGJjMjM4MDkxMDkiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6RDY4MTUxMzk2RDM1MTFFRDkzM0JDNEQ5N0IwQTIxRjYiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6RDY4MTUxMzg2RDM1MTFFRDkzM0JDNEQ5N0IwQTIxRjYiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6YjZlNTUzODYtMzRjZC02NDQyLWI4OTktODY4YTdiYTNkMzgyIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjg1NzVhNjZiLWFjZTktNTI0Ny04MzkxLTUwYmMyMzgwOTEwOSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Po+VQtwAACdUSURBVHja7H1bluM4kiUMfEjuHpFZtY4+/TGLmQ3MmTMbnf1MdUX6QyIJ2MAAAjC8+JB7ZHZXh7LKQ6IoECSBy2sXFwb4/X/+X2FfEqDv5dh35mXeC+k2CzD/+XfxL72BeVbv04KI7uP6ByD7pZTy6ToMnUTwv3f7rgWG/cNXrhz7AcVtUfOiwP/kOg6mLGRVoq1JUewjsAoLWJQ2RdlTg7CD+y+eJW3MziVU1dfK/wV2LIhXJpQJ/nQhOUFWWxDJRYjnwnfItkB2Z8w/yC7sr9fnXpj8Y/9d27hw/2D4zm/0/4V92EcRtq+bMP9J+AX98UdadxN8oy/D/tXdBeWAvsBQM7/FvwklxzemJ0xyfrflu6JG1T+Hc1mrhKEA/wfTQ9BfAD119x9Ca2R1ZjuEqwdq/Kb7C9vO3oQzZJ9AKdAzqDuoGVC5r3r3j8Gp62XoJaT9g3WBDK3crwwIdfB+mxUmyJP0HXNGAj/uM1zNQWTs8MChMOvJEQYMuDxdepBAQGM7810t2MHIioItnEqwbOx66GBadMSXHHQiCgBHFmDV8h+rJcQPEUaLk+WIFi5YDnyQXPoUs0R+oyTfEWvdkKFaskPYju0t1RLCDrxM/luoHejIm+0qbZ9g6+P2/snOBWDRQVPAggLOgMEBFRh7PoY+DPaJvUIYIvjeb3eG9b39tH6zFoL0Q9eHzVt6A1qOKMdYE7cD+lsBDCtdya7B2QINBEj1YZqMxSAwIKL7J3DVdI0WHbWgY4HdyIp2Z7d+lvreTa+hfHep/M/ZhZS9Gr7pbthqXsmtsdXpepS9MHXTi5xf5XIzX3XXf/tfBkmer2MHkPKdGr0SOckyXGzoO60IYIGBUcEdYFZKSuikFMBLT7pxQprYwXrifAZwtfto3pi9bVEcXVKSVcKtPYT5lSnMlOAaQMKKUobEv2UXF9a7kx4vbkRWnGsxAKxnAIRnrPAtg9FFYM8l93Pg/YA9A31zZCeJfOOBv3znykOv2KG6W/YVpu+xtlHUjlvWXGzu3Dqd6rflx/ZRkH+0vEFofssYCXAbtSNB7O6gxylGfNhRGFFJOdT6jbbFR4jEcHa4EqKrlkOsD2LKs2J9AlGKdVtucv4I9TdQpftrrH88BUSO3QVHI7RaboRWiJW7zy+zoW/jd4Ie0b472y+Q2F+AwHXuXv79f39/GiHr3pCgXQpSxaMeYOx7cxYGBHIKkHIKQhxJ6MOimxQI25jVdWBCy0Up941DSE4JAfKQtUURDcqawrT21YUUnVHkUVoJfByheE0DCGLysIiwkiEX6zwZctkHb3JHofU0ivee7aJx/QoxOTT6b2OVMCmE/0RU0SctOfsqnOz6rS9KszI5Umh2dJHWNjsFXSsw+7nIcCEtKuys2VfILxcWwIf8TdGrI3wxQpQHU/zi5JEjD8HWclhMxX4ecMHgi4ZesOgyBGsZWokCrWD5kPM9otXwbOLK9OphesYiOWvWFA3qddNbivHFc81iq7r8ZrrvJ2Jz/zjuRqnuvQm46rtmsFO0Yaql4w7U4fH5YuJD+JiWsB3Dj9HRYdp0J81LGE7nySMmPZfxflbAemw6wGW42RLMj+bZHEtcL1145NmiPEMWGKmNAwOMkYchZyaenRYiWmgpLx0xcGfXrjwXdMw5xSG/3ZJ/5LKXa0D++I4+R9gKVwwtuVrpNzj6HS7syt/Fuj+E5ghJAAblHeFxG2rhzyWNfgRrZ2HPNDDCVjQm2P4ltPk9kZUfRRmssXRMgzGIhftL7zdCpBuClYxYi02LC7KWwK+JSH4Yj5tEhZiyjLwfBaiq4lSKGonKgzUBK5xdQr5C9wfT/5HCfx5vJhcRkQtYKVrN77BMnjtJPT5pGHK4LCCKHSBidDe/rzQt2S+7CEINL4bBsX7XiNURcTdot5/18NIPXVfiFK8GNB/tGZYhiWBSvt/n8gnN7+9kEccCJSSH4Ai4fsG+stU3BzDI+OEPMS/K7GXgz0foAf6wgVkiYIkJMk2F7/NimBayADDClrZIJDCHLUQBGTdCcKAsPXcKWqODsqABuJPFJApGpx+sskHE20jmINK6KFuAbxvgmR2cCoTE3le5KAoeODNymG7ZKP/IcbdjNrEZTmzVfzMaySEojcE3QeokTnEoYVCFCSxGAT4e3uCU7i/oxMokDCzQKq8MFeTRyv1OquEZoU/pURFgisp1oFhnfiWaxgYCkkEGH8SZMJDi1kBadlvEEcol+x6q4tQ2TwMGw8ClHzF2snu6vN0nFx4mwOUAyILQNNPY4tN1WKUeKDAr/Cj/Cg3QPBnMmhxm4bKoD1PUSML8SmcCZmCmC+dUCwizumlWobYFbEWUs3o8psoXijTeElqsCBeCVE+4wFcEIQsVg9IZNC3hyZhgI7AY1LUVv9KWFJhM/SZioY23iHN1O6bsJGd2lS1VZra/AzY0/HatTsQXG6Vl75MOhoySNjhIHlCzvq6xxMEmVCXH4sSms9wKMmLFeA0bHMxEK9Nl5jehZrEerTM8BUHmaIU5WvHzCvWW06u0NC2pJSZohXJQw3eUXfOZggX1wYMwhn1xU2EfqjZfHYhv1/F9MhGbZjw9xIkrAM0GJG6zoUs5ZhUHRR+PhWCKMGscDDlaNPUUgzcf9+V6IUVLJFSLUSp+ahC3m/9f+v6+UHDoQ9EYCAewWu81rILXyrY4cYMkdHfEyjNNYONMPOLDVd3L1MqVeWGmSqVgiyJ1j2AYptSYtACA2Haz94jN1gOprhSLFbEThhIAErkEIO7TIkOhwPA3+6EQ9cNhUUnEdAvW+0A4SnYdmCiZGhdwHfZCkTMpjlDZD9t8KtlFp+4ATNSuyJjcc1T2KC/rOGQmtIs04uc7uC+0MtxK6GVFFei14VY0QFiEfZipdpiVCajl/RXU1Azi7DaS2HoCRNzlVOmFzTt949XvwlMlKqzoWYnqZIDjZRxvcrkZJiWYkuUwa90NDUi836fn67h2X4dZWHKi+JMANJIMWf1tMphlbj4obTFr7GjokGNSEo95LMIUtgAvfTct2haFERQgYAF6FuMxCDzaoR+rDvQOfIQc+6Af0XaCFPjWYDvV+pEPVmCizfvxv3DqfqgA07sb9sRjARdgfVS/UoLHR31svBBwn/aHa8WPlf8Q07rh1pM6KZBHytXSMB1cx1z+YnQoFYOygQjMhB6RGaZ4ed6jkIRgmuNUihYrWg0erdoxYM7+AlotFAnqZQUxOej+2QNfDa0QK5aOiFZ/gKVp6eGTM9Xjt5UJihpdrYfsFbjKHxWHAAtqStYeyUKv0Zj+dB36DoCcpVHAQd+DV2xaFnz7mEyIZ5AmpeWV2DCQHS8rCcOzDGaZkI7uDmEW6Vl2FBIjI8mU+IxFetgiRZ94n2LUA1Cu5peAm8IjUgA17nnx7qqIXLGXeG0fU9sHYm5eozMNJg9kmldiOsn516qC4TGjS/JgwEQWxYY0iqWqDbVYK2tnpddKJPeCl4O1nbG0TImKmSyOdWJxUuXZ8aFMVp9Ej6/7G3MWUIv4ivFELH7H+UsyIBf0b3qZzt8NmPC1TaiKLlZBZkuDVqjWAcFuxP4pRSseyWJlWNAfjmxQ0ysQTcvFdX6t1OW3fMyxQZ8OhO/YstLtM6xtLEuCAshgEkcDWXbo0KBJMnDDBHIb0M3Xceh7mQwacg0+CEAx1lsDNYN1Xn2nb2/3ZRz70WEWRHaUR4jZaVgY6SU5/KdZRRjSvDH7wUR/wyCQJe/bWI9WQ66oka8RIUMAiD67YDFksV6ira3UD6E+BhLHBDBvIomCE4Ij1vigaFbY3hh/y0+zRLBsH5Ect8nUjo0MZKcTY3NMj4gN8QsTXplrzFgPUhKvQC42p0JVWVobpxjbWiFNWrOVzmkIYhEAZo4EZw1dPhC1R6sLmv8hVAc9c90qPTUTA8r5DbQSVZP/GjF1epXYGSVtaZen4WsHsA4oVbgl0kc6Zv8MUkrrRZiUghSzwqGUJiv8FXuac4NxxKuCWVl4aPe72LlE93mxCIP3aca+uww976xHYMsAUkeeMhMeLkyLYtw1nUyUMAQdmVGIFpPBO0g4R2YchsTXtQ5HYsmngY0JZJxLeDK4WiYgC+fdxvVvwTggMW/7UNmF6aLYjuxYfh+Moj/E5p55rzBy8Ky1MLkwfw85ugh+UrGqaRzBL0V5IhBHNzBUOF6ZFmxhJU5JFHRRM3ChyKV0kUlOLFa0rZogBvpV6joCVWzqDCw3WO4GrcRqtnrScvScvDaMkGIU307AZ2mawIo1awW6/qJ6O+aYjH4WV6+lTNQC9w0w6wvqdHjcBWqerHwECq0MDzS9ZobJYgp3ZoEnSuZBcrPB42iBJlItZM5xfmUhkhZYA7r+Ns3OFzUtNPPIY9YGbHE6sApMvZ1UeafpRrhq2SH049okePiARMLw4lIAL2+CwGAYxSihQxwKTQbbgJ011EZTEmoAcVQxzo7wY4eiFo1gHtIhYh7YAVblTxRYcehAnYwgYJPwM+kzfx/tEsmbvLbpr4oZfuifDeysoer+wvwnDfE3g5u8f2Y6OvPclsyljPKCkkWRoOhyt0DFXZXSGdcXlg+DVqFwsi/IIYw9J7/dGBB0bUfdOppvqEVuTGWiVfesB6ptKwKsq1e1GL3p0jrAsKLWzW9wLmPhASeE35nG9WiqItzmmd/LBLNMQDfRCRPQ+EaZ+rASfYYNLNJbwiwraaEdXnHOCRNpMmBKzYIJT0oIlzWoyvuiHacOdxWCuB4mzMTJW4nOFWLGCF7pYBRzKXD+hWGnAsICPEM6oue9W7w34THCvTHf5SxZx5PbDz5Rsb3bkXrioYd2qz6lnbIYjShoVKmgi9b0acyIp30nSbSGrjL8V8BNIue75mDYkJoCoBDxkSNW5nLvo5UkT/yHcEpO6hwL2K/6b6K/rA6JClDhgYaHVVfABnj1BzlU3XNQkqzcDRBVGYrdCFTgY55pvJYZHSJh0po8oQ5ooPSOlkJLgAp6axDxeumtFZ5uyETWCXwaRyjHgJyzPM4ByglXJ+DSy7stAeIMU4xhIvg5oOEmQp6IghEBhBBCCREjx/wWOgTiJ4pMiq8RaEgTNZz1JW37m6pTnOEMhMGmEWx746PGmkdk2WzAZ2e0HUuUryBUVfAqQS3wF9nbSLDjc4MqlIr7DxjsyOkN1OIIEUppw7Qh82okgSd/yKVfyflNqpufv5Wq7KsPVSJNZh7Z3Kl8TAL3BpMfe/WfuvEbnsAc19ZJ3yOZ4ccPa9bkGBSAyZIjUtBX/3qCSpXRw2yH3lK526Jc+cus3jWNQoJzfmKpH6/IVRAuh1n95CxagkndGI0O6wgiJBHOqnuDV6OK0EzkdlAGupzeBh7lpHRZPLggxqxRAn+AFlV9KgcF8W0sOGhiP96yP9no8djVEJsUoKQPmDHcAqRSllZKQuQ5IPtCJ1JOk5ujcs+XC9A0KU1q9o/VTnWJqFSyqhaxstbQN7ncc6s741ZU1eEbTWbG2nAg7t2kDXp1GrCSYReoh4TbjyYW9jByxNUW4kHP43BfFhqP416H4KhEpOk7Gp+crbROtZpsy7C4a9/d7Pij2dcAzjtSUVIyACiTiTCsCFFXZxX9SSwmvgRgNIrxRwZegXn5CxbAy2teXCjn/IsBNwsMRRxQDUOWaazPGJmom+MqTKe1s6i5FHaHXDAxdjSfZAefbdtjO9sqRHV/qPgudmgjxqmKUNGxMm6CdUcRZrQMc5BiGKENBHQOrbASVWFuSk06vFYWrRYvufc2Euwy2wH3WGEWikZzAxVl0UpkM28i3HVXbcvPoRMrcWc9Kj/+9Dnnwzry5IQ2Zomq+LXyF8KUwZAheZ/mKOMB8PDQORWeiJJBMhWw9D2kwz8UgUthMOtu0MoG4d450TtbaUKpMoWLcS53LHPwsTO332b+g6hkIRTBMpefgcdqq8GCtTsoc/ghcNMApn6FypjgCvIC6mmudjnLKennBCU5ecQjT1k8+ZOW4HWcNmI+Oo9lbFUFstT/WTHxYq4cYTcSt0KZKWIlXytN8zZRFFlDPfe5rBK4LghdVgBmDIuK6pwEJnJraMA7pMnMV+2n9TTQCnG/gT3Ok0+EhFsToUVNzCoHiZidU4LBLJK0bjQrMEkesMIWwEqOKAuqDIbPQoxnT1X2OLVW+O4+WS+ozWxDVvih7zvws5UxyWNTm0kQQjea9oNioudYbpVKfVJ8XF9wR3Uy5TKQMiZrMU9DRClg4335nYYGSgFUmkU546r8Nkxtyaa5ZGUC7Nz96v6t7aIyKbV+lPIn6cDpVgnVw7X2wdzqpetDXylyYdkVOWyl7CiOsl3IyM5mHdVxKnMMrKN4s1wMWik/zc9wn6sFvtKBgQW3S6bjmKI6MlstCUtMJHZJLvZ+jLkLt9Fq+/nBc5N8FrCwkavveGBYbC80+FWutvP4ZCfHt/uEGvPgyB5LUeIr7CqD+QXbKgY3zR+DiQagboasadPs1IfWhmcNfZdoWJlchKkRwu9mqJ6JESfL+9bWHow/btoKBPk+72+BOsYLBd51EHP9CZ6lETMuloBYDIErwyDVprDdPrI5vVgkOWq9P/IIPVjO9semovRogYjtjRW2VSFVWCN+WAwL5mN03BNwNWhFG3RuW03izAwf3SieJoeUWHO6CdU/CWlzOeRDmY0AUGS2We2Cyhx2HHEzR7v8roNoVUrseKxl7KpX+ABgcR4koFQNEsxqznfnuVFCT8x+yNKzZVZk5hd9smb5vDLMLs/dAbnt3v4ldjarkAQFsOEVcbmrWrTL/mS0ye7vk4rPniwNRGqPggihMXrlwI18HDAHKEhd2lAMswtRptvHhgiFNcnpSBIF3EztUOYthk0hbEM/2tCnWukcoK277Ra7e5VEKyVKYbMSMQNaBZ5SM0FoDXp4sjmOM3cw1jTskrqhz4bqDi0RHPepCVVZYIiVM6P8CuPzmuU9y7EVjG8t/MdCad/RCo6hFZ4OCc8PIO8NG5eYdZvUnXIuhPAoWpjJDHXpx76LFwViGJVJrPlIov/e8CE7P9qlVKYg0TCudlDJ8CZNehXwC8Is1liLkGwP02uHmIOsiIlmipCk9HGJIidpYV/AChAkOUiTjIgs711mCYN0lLNIQ1oLlwW3rSTWxNp2URwUoTEqB7VsL1D0lXTkBCE95W37FbsgmOUmbJAsgaK0QebyFFZOByu2hyhKlOGeaKf6ZMRHw4D9C9lEcTE8S06vujcIOKSzeEoZqyqHU0NE+YSDpDmD2WIZ1K5VN/3Q3RNl46tEvXhC2dyXT/FhDasJPznuiE2exakWwywT6H3cab5OktvXN8K+k7Q6Tj4jmvdkyJNGBsnMZz2YFj3Ns7K4YOK5y2BFdxS5vsZM862Hc8gX6JKUQvZcTrCWJXthaQCAz5CJxApZsIciW0YIc7isdKZKVFjLebCT/a6aL6GWGXd3GgXUdJzyPWw0zloNoWa5Fzmgi329t9WxzgUplVwCmOdbqIANf5Dod+gvdtLMBkhhbXzAcy8YoAfKdaUXsUw03a9/CtOPMZsSVD/v5DsNF4NZ3fSHsGJWUn2tpDIHUoRZ0InD8nqJ4J/0pRxjWHjU0d4IHDDDLEN8XJaFJE+m7+WDW8JnYzA7S7fHx/j80/U2zwawHFEywHexqSO22l8ZWjKVyZRzV2omHwYKkSZ9BagkFUe+gg3E7HcpdeISdAWReQIErmQlEnLE3Gya3iMv/MS3x/cR5+1U+BPK3H7I46Z81p6+k/OxQujxd3ghkVsqaxaVB0Eqe2Bo0RHPwndKqqdMgW+yWwwVQoBK1dpQxeynvRq/Ww/qvWCUKOcPA4uqt8FsKwzcGhHG/cv+IGDt+WgSHf3Qz6O6ZEiKiQSVc/1DYByr/D0OPVkZoKmF1YplUAVonjS3ZVkIXOzSXkN3GX1i1Wpa8SQzShYJWkVT4X1Wi8s8k156nhVUlOv1IE+7VxqF0gm5KVEFwGRr1jSgblKqDMtycnTKCYXHrOdiM4dnS9jaaGDbrvcjVqwjRxENh1ruvMIkC01xZXErCMIKVPGWa5q+fpdEW+J0nJyLYK3HJ8I5YRaSt/2D0vVpO25oMCtbpWYTp/hhNPQ4fpMTgLpVfrvcpV7IimXqvE2jTyVmOOxceSQkPB0bhmtheMq83OcF+SoyEH95HbqrAxcshr22YCsSk2XBm4nc1LryoCnQzabO5ihB3gqbwa8piuA1DCqloniZHymP5yCBLpHYqlBUkoqKQn7HjTpCNjdxe07fWSfU2TmJu213e4mn4673I/U5mPm9PtbHODSyYBObqCU2+EbT1uCm/N0Is9zKXfVflzJ/VhqgzczXLR/W9X4HpZUT9RvCXAlVKcBKZTBr7uJiq5we6MWEjdrAljkEdIemamJtXtmW2vDJkPAx3T0Fl0Vpw1MmZ78sVFiyTQ09raZTldghs97Uqzk5CV+vdIfQqu8SjZytiZPKQ9kzdd3bxICGrPFlXIJ7NZtIA4xUlY2YLQ+RZrKCjWud5bfL3sY1Lb4+KPr1arCPkvI0o5qG36IeFS0zmIDOhFrdRbQTrOLm0hhIijjYbDAa1NQh6U0GB7cEsupEGj+mQY55w9+Wd9TlUdFimbKu92FniAPxAUf7YwyrETqJzdiwHCo2UKJMGOgn5XGvlX3XSfl06Ya+q1A2n4evrulCSMsviLstyolWPZBoZTX7QqHHVB1PleCgYZmazospcEGsqeDFslIY85pm05DrRIyFnGno1zDBQf4M2EjP8cCz5fO9G35m+X8BWNXPBkUtrKqB3J7PO0cKraV+050yoda6jncp7Vdni7LPWl7FADC909ChWqR+FR3BFgpZ54QNW1l4q4dn4hKL85TmR5XLjXyS4zMdt41Wpy82PgBYZ6bLb9vfHZTcbLKXPGSyb/uOsmX1UlbCTN4OIGUUTJNSdIh5nZloE4f6RMkF2c2MEal2HhoIha6TmgMZLBJyYmEyh4L05USswqegGjnklzcTs1p3B44/sHiEA5sL11eZelWmqu5/ZK345orxj76gfeiNyYQHw0aWB34/LK3pXFk3jhEomKck6HehFeUyZpLWIe+431XDKAbZza+gZ1vgm9XI7OzCwzjFi9X9BcDZHWZRRA9mY3f/Q/SuzrIJzQcHOg60gv44MLW+qpMsu4lWxpkWytvX8JTaAUGPVjG/diW3ZKbVBPVn1vo+LbNPwWxiwKdxoOmH22pXJtUzVFpIYrcqmEi9YZgDZco+sSRighsgdtOmQyaOQ1yTFFpaSQZtojqvqJiXgmxjdVXBZHSKz9sJBB8gtka2Q2Uwvz2T50S2qnLWULtwTGtbXTMxmdBbu0QHKMF2KpVKYFjrnLEeIafVTSpF4Vg3tPVEbFaHWkuvhu9SvIKdxgzzh8EsNbxg1MiwyYGwgriUV/7yrfNDh8U56lXS6l+i0i+OORjw6ODgkZDwXARQMqN50WsamYokj26yyxNN0gOBVb26mNaTA6JBFn2b5yBaDUP/vGr2KAAqFxfaiqmFuHnSVgXLGBmnL1AfWhJ1CzqKRk2iEgk5LysXXqjhWnEfYGM2S2aPxWxNp222EYxumoVFNYnmgUlBTQ5X3DinJCazTnGr8Gq1N/bE0hNbUiRo3sdC1cYd6G3zOJrZp/6gUIskLWhL+yV8+V1BquGbFNKuz2xiECdpvawZrNp8qv7coL49WLuDlMtH9daa7WCo3PBijWAHiBUbADuFWUcWoajj04aehda78GHgJNONg2nIoNXQPV+GZtNOO3nJuQykGGL1MS1hcayL9UM0L3uJGmn9tc3DdbNJnKHiVQ2F5E0tXdXmKJAxRoQbD+forirjTcECT8RzefV2Ap9jfOin6UWHdI1Thi98qFolHOoDkCRaeYLZt43RRr4GDS2r1S+pAlU3SDTwizALSYanoUOhlFR/iOHJurTkgcGFgsFBZzCLlkxf3vMUo+tk7KnTCw7fRHfRZXh4JBh8XMP6xEtR1lCS2JM6MBphut86ILg1fQxbQGPAS9tI826Xt6GpmTZpHy2fkyQ2SDt5uawmbx2UnXmenQoGdcjn+dmrpyYKrYy5w6pcCXfVQww+1a2ui4fUzUPyT4KPWJH095+HrX2SpSK+6JWtT5EVDnztyXz1sc9VBvER2N0FiLRYks8NBHQ81MJ2eZVy7EKE0i57o0mUn96sDP9sC9yoRusj0JLOVOA7CFXjerq7/9DDM5Dj4euxZQ+wiuG8xrfxtVjX0ryoFiOTkhZtNvRquxwhapqXAxdafpXSgLrfdlIaptb3sBHrVfwB7GLPBH8+dG3oDlUU8ws0ayhWOcuJD1ak5nwAYaOVAx7puzvi44EYP1mlAo49Dzf2Sd2bmKX4hXOaQ6N1NNa/SD+2ltIol7eoD0VUq3cojT3iQcirajqmdvNdmqZpuJKVtHD7oVWNU8nZAHJ6FZp6JSzW9jW+RNvXSdg1oSUtezC/0lhkRfgSNkWXUiNTzeoaIB5F+UcZViM29AIQpa8yYaBuNva+k08XP0Nwo6OCaA032MWi55CfyBT4fLVzbtLHbHuIh0MYwYC13S+6EbXBtk4BqbyYS0pBs2jEKNC8SblJO2eLmyu+PUZfHo65Ho7IPj8N6EvqeTz7YO74PXB8bPbJ0k5fy6jlJS39TxPf6f4iBGzDU7XZazni+BuN9Nn8fLTU4E0Jg1mmQISj15P7J8iaL+X0B+i53oDVvbstNoXWRZTDcY+ilXl1f/8f/+fQo7uJJS60x2kitEJs7mxw6sUm/dwOglrfart41/stHsKU9Xwdu2q0DBUqlNeZbPcktCFurrN4dBvDISzoVmNqFWD726zc/6KWpn/JF+7lLMd16cA85MS2nrWj5KAd8gM78bg+utLy2fuZ0pI4GhkdLM8y4aG6U5sysSHA+cCWfPVCjiZidQXW+og5xI26nuxESFL6uQcPoDobZ1biN7cManQtFVWg8bu+f74OsL1OQftbskcEp5WdczN23ZMpsFS7anythHMT0X9MNDs616NKqo9Qj4ZbQNZSlPJhr4biDq1blYW3B7D+1+vLEOpAXFwfIdWPcMSGhEQ5ZPSC/bOQ/S5C1YLNTo2/CfFKsw4tdJKkZYf2cr3piOuV3O4dXn43PIsvWpH92ESOAhfdf3My3Ofly/7Q5awjEdgw0MRok9bYCusMulyG7skPCDYDt3ZU6MJA5Z1WNk9p/3Tpd5577eeGKertvkTRih0RK1DUQKeaAoV7UAK7T+m6hgWNFAK/wOunw9ODPOtIqZtTqutaLrm0KNQK8hCeOwtSzUnSIncCtX/rVl/U5TdaE0wcwqm0E0h1+V3AD1OOKNF5lbToEHr8rkiGg58PWO1TuM+LgZKNLiMNWo1+hmBDmm3mXLZ/5sVFmhgKvI6DHRDc66hY84zbRXTephmx6kwvbnViJoQWfxQbcJaVcyYchlN949c8wv9UyIbtBz9ugtg2sKGVtG7/VG15aLcyZHcgBeqN1qAn3jH3t3+o4beiQDzYuAxxQ+i6+U20GKVe5O0fOH5HK379fMAqerehVB/TdPcpXCrhonMbXNIBwRZXrSEXUk6r5WOKgNjR+mDjMMidltFAAeu0IutWGcU14WKbaycCaGvZLAH7I0rH0O0Xk/oLkQmOjR5ud/At/wmeePCg6u7/BPWih+fcVAWHRjN090wJv0k1t92B7Aj/Afgtc2kdfwiauJLmBJsCUbVmi6+G+PEFoXv4Qds/cO9MMPV2CzFarmqtKUMNuDiJ/fgQNUMujWiIVZgeKOyA4MuVkqrvx0Glux1dgtPZ5oqAY0/JDZ0bjksHtWRKsF3j3Zw+p3EL/nT+Be2nAB77yfbHLyz50PXBnbykR4ZNTtPhHdGAco3ioofvO/2/UQwlDrx0BviEXjkBTK/QKcwA5ThmUYYs2U0/nN2hqunZZX4mikDlg+HhOcBy67+/TxPiltA1kNvAgstDUsuiVHRa2V/0fWfQSsIBbKrdYFLBDMLyyR01negw48cDJwJnpIttgBON9RK+WpT5E4Kl40s6f2YtQnGyKPyiM8SvukxHi5LLfVWgilTLW304TAQ1+HT5m7z/sHYHl4Dhw3Audflet1Dt1Ra7UV3/1q0FNhq4XvqPf5hDGDb3AGYdsDUEBEVhSArFaLglKhta9e3pIuWBqtQggjSmSN/sgODQPz8NUC5ceuxKzrZAvfEQ3C0Pzj8K4Iv3+/X6VxK4HgG4RgMGJIOCgRo7DAe7vy3GwIHyMZh/9ZIUCJ1N8ACn6k9eDvJPXIJ/onWSZKqgSSrDqc51wtagNL7ZjFZ5XdOEwmPfv1yHo1ZlzMWg+7x8cBUf8DoOmWZfzrHYuMW3UOCGnWo/1sDTcIYPNesvgK9treVsOAQNEotbttctblhmkoF2lpvqQbEotrry9cEz/dLkNp9nsrsOr/p2bSM7ZdNXPZDREdZJgiG/KGlk/yHwe1lgC6dSEHRDh3/YqddNKmoN8bMaf09yPHw+JAwkBbGd2Mx2WwMuT2N/JlqL+66L6Ni5x2FlwKeLHRA8pnyVtz5RwfCEHHTunuNJV+fGI+ULYjc8GZKd9ZufNdTjsXL2AkKopk/HM+e1a4v8OZHzTxjhrfq27OQb63h4SIFyQ4edKcRXuLOSfCwQT/Q+KnAFwbfqLBGPlHN/+39qLAYoHwYscwjDULKZzOVOkiT2YV1DsFlSs0KLxne7LkVS4MXEgg+OgCbzDc83lyPmg0+kJv6ijgH/ncLJv9C0keXi+vk1x0eLIlOVVqcVqKD59M800nf/4ewOlgRZSWv8LSvwoP/TgmDfTT/EhoHWDVDqFzV+O4JZWxqWpjAwGaqrXyYJ3wy56rozcU3cycSZbx+TinmjaT7zt6dLZRJPK85IX4YPvt5mrfVfoBnBA/X9RB8+wjAOrb/0ic6En/7JLh3ELzovPEDpML28eIC2HrsAcNa39VgDjApU/0AtDb5gdwE1gYeYtUDZafkIcbMFDrBMsIn1JjaUlJdiFJsuLVrStQVY86JfOetpMbSuDS4HOqjhbm+3iZ/KYDX7TsJDV4eSZL3f5p+COn8F0ok9XefX68+hd3AcVfBPq1TzK5rEBwI3nOXtBTpJNe+vJJmjih1ruQk3G/GBChr07A0IzrA5UcmAEc2XlP0G1DZF948pEb9bL0OrXi4jwIFLCnWN6e5EK7/rZbBTDh+6gYaivVNSK/VpFMIvw5gvPSb+Jf3i1+vPu9rngHEn7pleBU2I+W3XWV7JvQNyuf7eTa8kw4e4Z/pheJAev+8UiHWepa5/l5OdwbNNoG7/EON3sqG2GFK5JI9hKNOidq8IgctlAHjksUPB5n3KNKansb9eBmhGyFsAobNBzPI3B1dmgD+hDVeHun69/lWZGZ4Zf8RzrW+zYC9p/a7lA1owOFGJZi/HAp1L63e3pMU5LyBITVOvIUmyXFWpbNYaC7WVAcr/L8AA+dSd3OMf2BsAAAAASUVORK5CYII=) no-repeat;background-size:100%;margin-right:0rem;padding:6rem;text-align:center}.jt-wall-dialog .el-dialog .el-dialog__headerbtn{height:34rem}.jt-wall-dialog .el-dialog .el-dialog__body{padding:10rem;color:#fff}.jt-wall-dialog .el-dialog .el-color-picker__trigger{width:120rem}.jt-wall-dialog .el-dialog .el-body-foot{position:absolute;bottom:8rem;right:8rem;width:calc(100% - 16rem)}.jt-wall-dialog .el-dialog .el-body-foot .el-button-group{display:flex}.jt-wall-dialog .el-dialog .el-body-foot .el-button-group .el-button{border:solid 0rem rgb(255,0,0);flex:1}
- `;
- var _export_sfc = (sfc, props) => {
- const target = sfc.__vccOpts || sfc;
- for (const [key, val] of props) {
- target[key] = val;
- }
- return target;
- };
- const _hoisted_1$2 = { class: "jt-wall-dialog" };
- const _hoisted_2$2 = {
- slot: "title",
- class: "header-title"
- };
- const _hoisted_3$2 = { style: { "line-height": "24rem", "font-size": "16rem", "color": "#fff", "font-family": "'Alimama_ShuHeiTi_Bold'" } };
- const _hoisted_4$2 = { class: "odin-dialog__content" };
- const _hoisted_5$2 = { class: "jt-wall-row" };
- const _hoisted_6$2 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u9AD8\u5EA6", -1);
- const _hoisted_7$2 = { class: "col-main" };
- const _hoisted_8$2 = { class: "jt-wall-row" };
- const _hoisted_9$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u5F2F\u66F2\u5EA6", -1);
- const _hoisted_10$1 = { class: "col-main" };
- const _hoisted_11$1 = { class: "jt-wall-row" };
- const _hoisted_12$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u7EBF\u5BBD", -1);
- const _hoisted_13$1 = { class: "col-main" };
- const _hoisted_14$1 = { class: "jt-wall-row" };
- const _hoisted_15$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u53D1\u5149\u5F3A\u5EA6", -1);
- const _hoisted_16$1 = { class: "col-main" };
- const _hoisted_17$1 = { class: "jt-wall-row" };
- const _hoisted_18$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u989C\u8272", -1);
- const _hoisted_19$1 = { class: "col-main" };
- const _hoisted_20$1 = { class: "jt-wall-row" };
- const _hoisted_21$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u6D41\u52A8\u65B9\u5411", -1);
- const _hoisted_22$1 = { class: "col-main" };
- const _hoisted_23$1 = { class: "jt-wall-row" };
- const _hoisted_24$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u6D41\u52A8\u987A\u5E8F", -1);
- const _hoisted_25$1 = { class: "col-main" };
- const _hoisted_26$1 = { class: "jt-wall-row" };
- const _hoisted_27$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u6D41\u52A8\u65F6\u95F4", -1);
- const _hoisted_28$1 = { class: "col-main" };
- const _hoisted_29$1 = { class: "col-main" };
- const _hoisted_30$1 = { class: "jt-wall-row" };
- const _hoisted_31$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u91CD\u590D\u6570\u91CF", -1);
- const _hoisted_32$1 = { class: "col-main" };
- const _hoisted_33$1 = {
- class: "jt-wall-row",
- style: { "height": "60rem" }
- };
- const _hoisted_34$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u6587\u5B57\u5185\u5BB9", -1);
- const _hoisted_35$1 = { class: "col-main" };
- const _hoisted_36$1 = { class: "jt-wall-row" };
- const _hoisted_37$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u63CF\u8FB9\u5BBD\u5EA6", -1);
- const _hoisted_38$1 = { class: "col-main" };
- const _hoisted_39$1 = { class: "jt-wall-row" };
- const _hoisted_40$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u63CF\u8FB9\u989C\u8272", -1);
- const _hoisted_41$1 = { class: "col-main" };
- const _hoisted_42$1 = {
- class: "jt-wall-row",
- style: { "height": "100rem" }
- };
- const _hoisted_43$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u89C6\u9891\u5730\u5740", -1);
- const _hoisted_44$1 = { class: "col-main" };
- const _hoisted_45$1 = { class: "jt-wall-row" };
- const _hoisted_46$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "X\u8F74\u5E73\u79FB", -1);
- const _hoisted_47$1 = { class: "col-main" };
- const _hoisted_48$1 = { class: "jt-wall-row" };
- const _hoisted_49$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "Y\u8F74\u5E73\u79FB", -1);
- const _hoisted_50$1 = { class: "col-main" };
- const _hoisted_51$1 = { class: "jt-wall-row" };
- const _hoisted_52$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "Z\u8F74\u5E73\u79FB", -1);
- const _hoisted_53$1 = { class: "col-main" };
- const _hoisted_54$1 = { class: "el-body-foot" };
- const _sfc_main$2 = {
- __name: "CrEditProperty.ce",
- props: {
- params: {
- id: {
- type: String,
- default: () => void 0
- },
- height: {
- type: Number,
- default: () => 13
- },
- bottomHeight: {
- type: Number,
- default: () => 0
- },
- color: {
- type: String,
- default: () => "255,255,0,0.9"
- },
- direction: {
- type: String,
- default: () => "horizontal"
- },
- order: {
- type: String,
- default: () => "+"
- },
- count: {
- type: Number,
- default: () => 2
- },
- text: {
- type: String,
- default: () => ""
- },
- lineWidth: {
- type: Number,
- default: () => 2
- },
- glowPower: {
- type: Number,
- default: () => 0.25
- },
- outlineWidth: {
- type: Number,
- default: () => 0
- },
- outlineColor: {
- type: String,
- default: () => "255,255,0,0.9"
- },
- speed: {
- type: Number,
- default: () => 1.5
- },
- videoUrl: {
- type: String,
- default: () => ""
- },
- arcHeight: {
- type: Number,
- default: () => 1e3
- },
- axisX: {
- type: Number,
- default: () => 0
- },
- axisY: {
- type: Number,
- default: () => 0
- },
- axisZ: {
- type: Number,
- default: () => 0
- }
- },
- showDialog: {
- type: Boolean,
- default: () => false
- }
- },
- emits: ["submit", "update:showDialog", "update:params", "remove"],
- setup(__props, { expose: __expose, emit }) {
- const props = __props;
- const language = ref("zh-cn");
- const locale = computed$1(() => language.value === "zh-cn" ? zhCn : en);
- const {
- proxy
- } = getCurrentInstance();
- const predefineColors = ref([
- "#ff4500",
- "#ff8c00",
- "#ffd700",
- "#90ee90",
- "#00ced1",
- "#1e90ff",
- "#c71585",
- "rgba(255, 69, 0, 0.68)",
- "rgb(255, 120, 0)",
- "hsv(51, 100, 98)",
- "hsva(120, 40, 94, 0.5)",
- "hsl(181, 100%, 37%)",
- "hsla(209, 100%, 56%, 0.73)",
- "#c7158577"
- ]);
- const isShowColor = ref(false);
- const isShowText = ref(false);
- const isShowHeight = ref(false);
- const isShowDirection = ref(false);
- const isShowOrder = ref(false);
- const isShowCount = ref(false);
- ref(false);
- const isShowLineWidth = ref(false);
- const isShowGlowpower = ref(false);
- const isShowOutlineWidth = ref(false);
- const isShowOutlineColor = ref(false);
- const isShowSpeed = ref(false);
- const isShowVideoUrl = ref(false);
- const isShowArcHeight = ref(false);
- const isShowAxis = ref(false);
- const color2 = ref(props.params.color);
- const title = ref("\u5C5E\u6027\u7F16\u8F91");
- const dialogVisible = ref(props.showDialog);
- const directions = reactive([{
- key: "\u5DE6\u53F3",
- value: "horizontal"
- }, {
- key: "\u4E0A\u4E0B",
- value: "vertical"
- }]);
- const orders = reactive([]);
- const radioDirection = ref("");
- const radioOrder = ref("");
- const wallHeight = ref(0);
- const yCount = ref(0);
- const txtContent = ref("");
- const lineWidth = ref(0);
- const glowPower = ref(0.25);
- const outlineWidth = ref(0);
- const outlineColor = ref(props.params.outlineColor);
- const speed = ref(1.5);
- const txtVideoUrl = ref("");
- const arcHeight = ref(1e3);
- const axisX = ref(0);
- const axisY = ref(0);
- const axisZ = ref(0);
- updateParams(props.params);
- function updateParams(params) {
- proxy._params = params;
- _setShowControls(false);
- if (params.id === DrawTools.DrawType.TextWall) {
- title.value = "\u5E7F\u544A\u724C\u7F16\u8F91";
- isShowColor.value = true;
- isShowText.value = true;
- isShowHeight.value = true;
- } else if (params.id === DrawTools.DrawType.DynamicWall) {
- title.value = "\u52A8\u6001\u56F4\u680F\u7F16\u8F91";
- isShowColor.value = true;
- isShowDirection.value = true;
- isShowOrder.value = true;
- isShowCount.value = true;
- isShowHeight.value = true;
- isShowSpeed.value = true;
- } else if (params.id === DrawTools.DrawType.NormalWall) {
- title.value = "\u666E\u901A\u56F4\u680F\u7F16\u8F91";
- isShowColor.value = true;
- isShowHeight.value = true;
- } else if (params.id === DrawTools.DrawType.Circle) {
- title.value = "\u8D34\u5730\u5706\u7F16\u8F91";
- isShowColor.value = true;
- isShowOutlineColor.value = true;
- isShowOutlineWidth.value = true;
- } else if (params.id === DrawTools.DrawType.DynamicCircle) {
- title.value = "\u6269\u6563\u5706\u7F16\u8F91";
- isShowColor.value = true;
- isShowCount.value = true;
- isShowSpeed.value = true;
- } else if (params.id === DrawTools.DrawType.House) {
- title.value = "\u623F\u5C4B\u7F16\u8F91";
- isShowColor.value = true;
- isShowHeight.value = true;
- } else if (params.id === DrawTools.DrawType.VideoWall) {
- title.value = "\u89C6\u9891\u5899\u7F16\u8F91";
- isShowHeight.value = true;
- isShowVideoUrl.value = true;
- isShowAxis.value = true;
- } else if (params.id === DrawTools.DrawType.Polyline) {
- title.value = "\u8D34\u5730\u7EBF\u7F16\u8F91";
- isShowColor.value = true;
- isShowLineWidth.value = true;
- } else if (params.id === DrawTools.DrawType.ArrowPolyline) {
- title.value = "\u7BAD\u5934\u7EBF\u7F16\u8F91";
- isShowColor.value = true;
- isShowLineWidth.value = true;
- } else if (params.id === DrawTools.DrawType.DynamicPolyline) {
- title.value = "\u52A8\u6001\u7EBF\u7F16\u8F91";
- isShowColor.value = true;
- isShowOrder.value = true;
- isShowCount.value = true;
- isShowLineWidth.value = true;
- isShowSpeed.value = true;
- } else if (params.id === DrawTools.DrawType.GrowPolyline) {
- title.value = "\u53D1\u5149\u7EBF\u7F16\u8F91";
- isShowColor.value = true;
- isShowLineWidth.value = true;
- isShowGlowpower.value = true;
- } else if (params.id === DrawTools.DrawType.OutlinePolyline) {
- title.value = "\u63CF\u8FB9\u7EBF\u7F16\u8F91";
- isShowColor.value = true;
- isShowLineWidth.value = true;
- isShowOutlineColor.value = true;
- isShowOutlineWidth.value = true;
- } else if (params.id === DrawTools.DrawType.Polygon) {
- title.value = "\u8D34\u5730\u9762\u7F16\u8F91";
- isShowColor.value = true;
- isShowOutlineColor.value = true;
- isShowOutlineWidth.value = true;
- } else if (params.id === DrawTools.DrawType.Rectangle) {
- title.value = "\u77E9\u5F62\u7F16\u8F91";
- isShowColor.value = true;
- isShowOutlineColor.value = true;
- isShowOutlineWidth.value = true;
- } else if (params.id === DrawTools.DrawType.SpatialLine) {
- title.value = "\u7A7A\u95F4\u7EBF\u7F16\u8F91";
- isShowColor.value = true;
- isShowLineWidth.value = true;
- } else if (params.id === DrawTools.DrawType.OdLine) {
- title.value = "OD\u7EBF\u7F16\u8F91";
- isShowSpeed.value = true;
- isShowColor.value = true;
- isShowLineWidth.value = true;
- isShowOrder.value = true;
- isShowArcHeight.value = true;
- } else {
- _setShowControls(false);
- }
- color2.value = params.color;
- if (params.direction === "horizontal") {
- radioDirection.value = directions[0].key;
- Object.assign(orders, [{
- key: "\u81EA\u5DE6\u81F3\u53F3",
- value: "-"
- }, {
- key: "\u81EA\u53F3\u81F3\u5DE6",
- value: "+"
- }]);
- if (params.order === "-") {
- radioOrder.value = orders[0].key;
- } else {
- radioOrder.value = orders[1].key;
- }
- } else {
- radioDirection.value = directions[1].key;
- Object.assign(orders, [{
- key: "\u81EA\u4E0A\u81F3\u4E0B",
- value: "+"
- }, {
- key: "\u81EA\u4E0B\u81F3\u4E0A",
- value: "-"
- }]);
- if (params.order === "+") {
- radioOrder.value = orders[0].key;
- } else {
- radioOrder.value = orders[1].key;
- }
- }
- if (params.id === DrawTools.DrawType.OdLine) {
- Object.assign(orders, [{
- key: "\u6C47\u805A",
- value: "+"
- }, {
- key: "\u6269\u6563",
- value: "-"
- }]);
- if (params.order === "+") {
- radioOrder.value = orders[0].key;
- } else {
- radioOrder.value = orders[1].key;
- }
- }
- wallHeight.value = parseFloat(params.height).toFixed(2);
- yCount.value = params.count;
- txtContent.value = params.text;
- lineWidth.value = params.lineWidth;
- glowPower.value = params.power;
- outlineColor.value = params.outlineColor;
- outlineWidth.value = params.outlineWidth;
- speed.value = (parseFloat(params.duration) / 1e3).toFixed(2);
- txtVideoUrl.value = params.videoUrl;
- arcHeight.value = params.odlineHeight;
- axisX.value = params.axisX;
- axisY.value = params.axisY;
- axisZ.value = params.axisZ;
- }
- function _setShowControls(isShow) {
- isShowColor.value = isShow;
- isShowText.value = isShow;
- isShowDirection.value = isShow;
- isShowOrder.value = isShow;
- isShowCount.value = isShow;
- isShowHeight.value = isShow;
- isShowLineWidth.value = isShow;
- isShowGlowpower.value = isShow;
- isShowOutlineColor.value = isShow;
- isShowOutlineWidth.value = isShow;
- isShowSpeed.value = isShow;
- isShowVideoUrl.value = isShow;
- isShowArcHeight.value = isShow;
- isShowAxis.value = isShow;
- }
- __expose({});
- function submit() {
- let outParam = proxy._params;
- outParam.height = wallHeight.value;
- outParam.color = color2.value;
- outParam.direction = directions.filter((item) => {
- return item.key === radioDirection.value;
- })[0].value;
- outParam.order = orders.filter((item) => {
- return item.key === radioOrder.value;
- })[0].value;
- outParam.count = yCount.value;
- outParam.text = txtContent.value;
- outParam.lineWidth = lineWidth.value;
- outParam.power = glowPower.value;
- outParam.outlineColor = outlineColor.value;
- outParam.outlineWidth = outlineWidth.value;
- outParam.duration = speed.value * 1e3;
- outParam.videoUrl = txtVideoUrl.value;
- outParam.odlineHeight = arcHeight.value;
- outParam.bottomHeight = props.params.bottomHeight;
- outParam.axisX = axisX.value;
- outParam.axisY = axisY.value;
- outParam.axisZ = axisZ.value;
- emit("submit", outParam);
- axisX.value = axisY.value = axisZ.value = 0;
- }
- function close() {
- dialogVisible.value = false;
- }
- function remove2() {
- emit("remove", {});
- dialogVisible.value = false;
- }
- function directionChange(e) {
- if (e.target.value === directions[0].key) {
- Object.assign(orders, [{
- key: "\u81EA\u5DE6\u81F3\u53F3",
- value: "-"
- }, {
- key: "\u81EA\u53F3\u81F3\u5DE6",
- value: "+"
- }]);
- radioOrder.value = orders[0].key;
- } else if (e.target.value === directions[1].key) {
- Object.assign(orders, [{
- key: "\u81EA\u4E0A\u81F3\u4E0B",
- value: "-"
- }, {
- key: "\u81EA\u4E0B\u81F3\u4E0A",
- value: "+"
- }]);
- radioOrder.value = orders[0].key;
- }
- }
- function closeDialog() {
- emit("update:showDialog", false);
- }
- function openDialog() {
- updateParams(props.params);
- }
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", _hoisted_1$2, [
- createVNode(unref(ElDialog), {
- modal: false,
- "destroy-on-close": false,
- modelValue: dialogVisible.value,
- "onUpdate:modelValue": _cache[19] || (_cache[19] = ($event) => dialogVisible.value = $event),
- title: title.value,
- style: normalizeStyle({ left: "10rem", background: "rgb(0 44 126 / 68%)", height: "calc(100% - 175rem)", width: "180rem", top: "125rem" }),
- onClose: closeDialog,
- onOpen: openDialog,
- "show-close": false
- }, {
- header: withCtx(() => [
- createElementVNode("div", _hoisted_2$2, [
- createElementVNode("span", _hoisted_3$2, toDisplayString(title.value), 1)
- ])
- ]),
- default: withCtx(() => [
- createElementVNode("div", _hoisted_4$2, [
- withDirectives(createElementVNode("div", _hoisted_5$2, [
- _hoisted_6$2,
- createElementVNode("div", _hoisted_7$2, [
- createVNode(unref(ElInput), {
- modelValue: wallHeight.value,
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => wallHeight.value = $event),
- placeholder: "\u8F93\u5165\u9AD8\u5EA6\u503C",
- clearable: ""
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowHeight.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_8$2, [
- _hoisted_9$1,
- createElementVNode("div", _hoisted_10$1, [
- createVNode(unref(ElInput), {
- modelValue: arcHeight.value,
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => arcHeight.value = $event),
- placeholder: "\u8F93\u5165\u5F2F\u66F2\u5EA60\uFF5E9000",
- clearable: ""
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowArcHeight.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_11$1, [
- _hoisted_12$1,
- createElementVNode("div", _hoisted_13$1, [
- createVNode(unref(ElInput), {
- modelValue: lineWidth.value,
- "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => lineWidth.value = $event),
- placeholder: "\u8F93\u5165\u5BBD\u5EA6\u503C",
- clearable: ""
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowLineWidth.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_14$1, [
- _hoisted_15$1,
- createElementVNode("div", _hoisted_16$1, [
- createVNode(unref(ElInput), {
- modelValue: glowPower.value,
- "onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => glowPower.value = $event),
- placeholder: "\u8F93\u5165\u53D1\u5149\u5F3A\u5EA60\uFF5E1",
- clearable: ""
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowGlowpower.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_17$1, [
- _hoisted_18$1,
- createElementVNode("div", _hoisted_19$1, [
- createVNode(unref(ElConfigProvider), { locale: locale.value }, {
- default: withCtx(() => [
- createVNode(unref(ElColorPicker), {
- modelValue: color2.value,
- "onUpdate:modelValue": _cache[4] || (_cache[4] = ($event) => color2.value = $event),
- "show-alpha": "",
- predefine: predefineColors.value,
- label: "12"
- }, null, 8, ["modelValue", "predefine"])
- ]),
- _: 1
- }, 8, ["locale"])
- ])
- ], 512), [
- [vShow, isShowColor.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_20$1, [
- _hoisted_21$1,
- createElementVNode("div", _hoisted_22$1, [
- createVNode(unref(ElRadioGroup), {
- modelValue: radioDirection.value,
- "onUpdate:modelValue": _cache[5] || (_cache[5] = ($event) => radioDirection.value = $event)
- }, {
- default: withCtx(() => [
- (openBlock(true), createElementBlock(Fragment, null, renderList(directions, (item, index2) => {
- return openBlock(), createBlock(unref(ElRadioButton), {
- label: item.key,
- modelValue: item.value,
- "onUpdate:modelValue": ($event) => item.value = $event,
- onChange: directionChange
- }, null, 8, ["label", "modelValue", "onUpdate:modelValue"]);
- }), 256))
- ]),
- _: 1
- }, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowDirection.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_23$1, [
- _hoisted_24$1,
- createElementVNode("div", _hoisted_25$1, [
- createVNode(unref(ElRadioGroup), {
- modelValue: radioOrder.value,
- "onUpdate:modelValue": _cache[6] || (_cache[6] = ($event) => radioOrder.value = $event)
- }, {
- default: withCtx(() => [
- (openBlock(true), createElementBlock(Fragment, null, renderList(orders, (item, index2) => {
- return openBlock(), createBlock(unref(ElRadioButton), {
- label: item.key,
- modelValue: item.value,
- "onUpdate:modelValue": ($event) => item.value = $event
- }, null, 8, ["label", "modelValue", "onUpdate:modelValue"]);
- }), 256))
- ]),
- _: 1
- }, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowOrder.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_26$1, [
- _hoisted_27$1,
- createElementVNode("div", _hoisted_28$1, [
- createElementVNode("div", _hoisted_29$1, [
- createVNode(unref(ElInput), {
- modelValue: speed.value,
- "onUpdate:modelValue": _cache[7] || (_cache[7] = ($event) => speed.value = $event),
- placeholder: "\u8F93\u5165\u6D41\u52A8\u65F6\u95F40\uFF5E10",
- clearable: ""
- }, null, 8, ["modelValue"])
- ])
- ])
- ], 512), [
- [vShow, isShowSpeed.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_30$1, [
- _hoisted_31$1,
- createElementVNode("div", _hoisted_32$1, [
- createVNode(unref(ElInput), {
- modelValue: yCount.value,
- "onUpdate:modelValue": _cache[8] || (_cache[8] = ($event) => yCount.value = $event),
- placeholder: "\u8F93\u51651\uFF5E100",
- clearable: ""
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowCount.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_33$1, [
- _hoisted_34$1,
- createElementVNode("div", _hoisted_35$1, [
- createVNode(unref(ElInput), {
- modelValue: txtContent.value,
- "onUpdate:modelValue": _cache[9] || (_cache[9] = ($event) => txtContent.value = $event),
- placeholder: "\u8F93\u5165\u663E\u793A\u7684\u6587\u5B57\u5185\u5BB9",
- clearable: "",
- type: "textarea",
- rows: 2
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowText.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_36$1, [
- _hoisted_37$1,
- createElementVNode("div", _hoisted_38$1, [
- createVNode(unref(ElInput), {
- modelValue: outlineWidth.value,
- "onUpdate:modelValue": _cache[10] || (_cache[10] = ($event) => outlineWidth.value = $event),
- placeholder: "\u8F93\u5165\u5BBD\u5EA6\u503C",
- clearable: ""
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowOutlineWidth.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_39$1, [
- _hoisted_40$1,
- createElementVNode("div", _hoisted_41$1, [
- createVNode(unref(ElConfigProvider), { locale: locale.value }, {
- default: withCtx(() => [
- createVNode(unref(ElColorPicker), {
- modelValue: outlineColor.value,
- "onUpdate:modelValue": _cache[11] || (_cache[11] = ($event) => outlineColor.value = $event),
- "show-alpha": "",
- predefine: predefineColors.value,
- label: "12"
- }, null, 8, ["modelValue", "predefine"])
- ]),
- _: 1
- }, 8, ["locale"])
- ])
- ], 512), [
- [vShow, isShowOutlineColor.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_42$1, [
- _hoisted_43$1,
- createElementVNode("div", _hoisted_44$1, [
- createVNode(unref(ElInput), {
- modelValue: txtVideoUrl.value,
- "onUpdate:modelValue": _cache[12] || (_cache[12] = ($event) => txtVideoUrl.value = $event),
- placeholder: "\u8F93\u5165\u64AD\u653E\u89C6\u9891\u7684\u5730\u5740",
- clearable: "",
- type: "textarea",
- rows: 4
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowVideoUrl.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_45$1, [
- _hoisted_46$1,
- createElementVNode("div", _hoisted_47$1, [
- createVNode(unref(ElInputNumber), {
- modelValue: axisX.value,
- "onUpdate:modelValue": _cache[13] || (_cache[13] = ($event) => axisX.value = $event),
- precision: 2,
- step: 0.1,
- max: 10
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowAxis.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_48$1, [
- _hoisted_49$1,
- createElementVNode("div", _hoisted_50$1, [
- createVNode(unref(ElInputNumber), {
- modelValue: axisY.value,
- "onUpdate:modelValue": _cache[14] || (_cache[14] = ($event) => axisY.value = $event),
- precision: 2,
- step: 0.1,
- max: 10
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowAxis.value]
- ]),
- withDirectives(createElementVNode("div", _hoisted_51$1, [
- _hoisted_52$1,
- createElementVNode("div", _hoisted_53$1, [
- createVNode(unref(ElInputNumber), {
- modelValue: axisZ.value,
- "onUpdate:modelValue": _cache[15] || (_cache[15] = ($event) => axisZ.value = $event),
- precision: 2,
- step: 0.1,
- max: 10
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, isShowAxis.value]
- ]),
- createElementVNode("div", _hoisted_54$1, [
- createVNode(unref(ElButtonGroup), null, {
- default: withCtx(() => [
- createVNode(unref(ElButton), {
- type: "primary",
- icon: unref(edit_default),
- onClick: _cache[16] || (_cache[16] = ($event) => submit())
- }, {
- default: withCtx(() => [
- createTextVNode("\u4FEE\u6539")
- ]),
- _: 1
- }, 8, ["icon"]),
- createVNode(unref(ElButton), {
- type: "primary",
- style: { "background-color": "rgb(222, 146, 47)" },
- icon: unref(delete_default),
- onClick: _cache[17] || (_cache[17] = ($event) => remove2())
- }, {
- default: withCtx(() => [
- createTextVNode("\u5220\u9664")
- ]),
- _: 1
- }, 8, ["icon"]),
- createVNode(unref(ElButton), {
- type: "primary",
- style: { "background-color": "rgb(126, 128, 135)" },
- icon: unref(close_default),
- onClick: _cache[18] || (_cache[18] = ($event) => close())
- }, {
- default: withCtx(() => [
- createTextVNode("\u5173\u95ED")
- ]),
- _: 1
- }, 8, ["icon"])
- ]),
- _: 1
- })
- ])
- ])
- ]),
- _: 1
- }, 8, ["modelValue", "title", "style"])
- ]);
- };
- }
- };
- var DialogEditProperty$2 = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["styles", [_style_0$2]]]);
- Array.prototype.last = function() {
- if (this === void 0 || this.length === void 0 || this.length === 0)
- return void 0;
- return this[this.length - 1];
- };
- Array.prototype.first = function() {
- if (this === void 0 || this.length === void 0 || this.length === 0)
- return void 0;
- return this[0];
- };
- Cesium.Entity.prototype.setEditType = function(options2) {
- this._editType = options2;
- };
- Cesium.Entity.prototype.getEditType = function() {
- return this._editType;
- };
- Cesium.Entity.prototype.setEntityType = function(entityType) {
- this._entityType = entityType;
- };
- Cesium.Entity.prototype.getEntityType = function(entityType) {
- return this._entityType;
- };
- Cesium.Entity.prototype.setIsEdit = function(isEdit) {
- this._isEdit = isEdit;
- };
- Cesium.Entity.prototype.getIsEdit = function() {
- return this._isEdit;
- };
- Cesium.Entity.prototype.setParams = function(params) {
- this._params = params;
- };
- Cesium.Entity.prototype.getParams = function() {
- return this._params;
- };
- Cesium.Entity.prototype.bindEntity = function(entity) {
- this._bindEntity = entity;
- };
- Cesium.Entity.prototype.getBindEntity = function() {
- return this._bindEntity;
- };
- class DrawTools {
- constructor(viewer2, options2) {
- this._viewer = viewer2;
- this._init(options2);
- }
- static initEditPropertyParams() {
- return {
- id: void 0,
- height: 20,
- bottomHeight: 0,
- color: "rgba(0,255,0,0.75)",
- direction: "horizontal",
- order: "-",
- count: 2,
- text: "",
- lineWidth: 0,
- power: 0.25,
- outlineWidth: 0,
- outlineColor: "rgba(255,255,255,1)",
- videoUrl: "",
- duration: 1500,
- odlineHeight: 1e3,
- odlineCount: 50,
- axisX: 0,
- axisY: 0,
- axisZ: 0
- };
- }
- _init(options2) {
- this._viewer.scene.globe.depthTestAgainstTerrain = true;
- this._viewer.cesiumWidget.screenSpaceEventHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
- this._sketchEntityName = this._guid();
- let dataSource = new Cesium.CustomDataSource(this._sketchEntityName);
- this._viewer.dataSources.add(dataSource);
- this._entities = dataSource.entities;
- this._pointEntitys = [];
- this._sketchPointImage = void 0;
- this._iconNormal = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABwAAAAcEAYAAAAinQPXAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAAASAAAAEgARslrPgAAB2FJREFUWMO9mHtQlNcZxn/nW65GxHtEqTEajUxVoLYRSIyipHG4qG0lajtxVIRFubgqXuOI28ZE7FAvCLKLSNKxg/FSIzdvqNE62kaRitqpYMxovBGigo4I4n6nfwjsCrsLrtjnn53vnPe87/Oc9/2+854VdBhCd6ZP6dMHlAXO/lOngrzMLz/8EEQ0ASNGANNY2aOHxYIdfHr3LuBCwPnzQIKcf/AgiJ8pQV99BfmvR4+orHxZVsLxpZFT0qd07gyP7zqrej3IInF47lwQkTLV3d1xv3KXWPT4MYhLzMzIgHpn10+Sk+Gw74w+jx79HwSGnzUYhg4FED4FBcBq/jtokOOC2oSb0FZUgHpKVoeHQ9GtGM/y8lcgMLxf5juDBwNDlOWnTgGvUdWz5wsQ7c179fUWzz9y0tX1BdZPILeqCpTtil9QEOT9c876K1faWqS07XeMzJFuboCXkpaX1w5hqxl14QJIKYRWCzLV5OXtDQXbon3c3c2/TeMoYvncucAgPrl40Y7fA0zv1QtMydKwb58FL7toRwbDYo3/0utB3OD8qlX2hIkLqalwO0b9+fLlUHJOG9vQ0P4EjfyFIdPZGfqsURampIBIlxsWLLBtL/NltF4PhUIrVq92QGDIeEOmpye4pYju164Bq6n29LTiopy8tDTIL48pSExsDq/Oj9is/eAD4CRbli1DMEFUBAYCewnUaJD8jr2lpQjpJ7M2bBBi0+L47Tt2mP2G5xhNaWnAHrLj461tKF1rasA0rW5b//6w/0rigQcPWhrZKVFXP8TkybaFyb3kXbkCbiO6fpyU1Dwq58vNG3U6BJvEiYMHEcwQW8aNA3pT7O4OaPmTiwuCnlwcNQrEDRGYmytloilj5vr1Zv+mNXVhSUnmOFYEVnt6gtM9t+8mTbKlwo5AoWdySIjteWUcIwwG2LX7o6lPnkiZULTlj/7+wEThm5oKbCBeCOANUisqkNRxLCEBSSzrYmOB3jw6c8Yi3kL5K51OyvkZGXUTJz7LSH09CIPwMBpt85CHhMf48Q4IJFPofHzsbMAAJfjIEQtXC9TZWi0wkEuKAmjEyspKpNN2pyVBQULZaIjbvXmzUDb6xF0zGJCqv+no6NGAK5fLyiz8JssVcXEWgQLUsZZxWmGbrLTN057Agfh7eNiefhpRb7h922LgOzFp2DDzxnJXrsvLE0rqOW3sTz+12h4lLfRZhuQybuXmWmQkgPzhwy0o1jlV37ljh+e3/L1LF0cEXqX04UPb0075rlovLwtBHuqZ5845T5Z37UqbEAPkzOfsUvlHXZ35saFnQ4++fe04eIfftv64tEfgdvkXeweprFIvBQaaebJH+f3x4xbPvsRPnixlQlHGtDFjWq2Wuqj0yz4+QKk4FxNjMVXD2998Y0FRKEsCAuzwzBKv2eZpR6DspxQcPWpnvrNYoNNBZOTOnRoN0ilJMzYjA3ibsKoqoIxezs6gLJbpxcVSTbyePurwYSkT76VPKSgAWQslJcAmenTrBszgP7W1wBlRmZICY2SydHIC8ZCvdTo7Ak+ri44dcySDNDTs2mVufluhThoGD4bHp6or4uOb3zWJnoqwMGAVLnfuACHscHJCiFRmhISA0BMcFob52PDC/8EDkLfkR5GRQmycN8/t8mXw8O73WVwctnvdJ3SqrQXNSJeY3bttaWhHJxMxzDh97VqQAwheutR2IC6pm/z8oOBm7LcVFVJNKNo0oUsXhBKmGR0VBfI0vkFBINzExxoNEKP+ePYsktefFmVnC2Vjvm5SZSVEpGUNefNNUH8ti8rKQCziaOfOVuL2563PP4eCjJhxK1a8hMCJJ7NTPDxAXWIaefEi0J2r/ftbMfyryDhxAkZ2u1EaHAx6oReq2rb/JiTLZKkoUHLf2//YMWCGnPf++1YM7zHw+nVQ1mlKhg2DvPeiltr+GLaj2W524Kd6zZ4NhGOQ0ophI6GSkr4Gq61VGyjx7vdZQoIdYY1xVZ06RKttS1gTHLkPLjVmGo3AJZToaCsGjSWrPFBKfH3bvta0uyR3ySlGIxS4a7trte1l244MtoRpT93XSUk0l0oruFDbqROYUtQ9X3xhLr2WaBpX4+WnOTl2hHkw9eZN0Li5dLP6Dehogc1dexslK/7MynffhbNDvZXnWq9GNJWyiKC69TlphvobtWbOHNgnZonq6hdl+xL/yTQhbKUxeOtWEP9melSUFYMWJSv/IAtNprZLUu4Rf9u6FQpdo49bfRXaBQcy2BL1p+XURYtAZrLwhx+sGDSWrDpc3ZeVBbJMPt22zY6wRj/1oep08zXMUXRABpsQFmqcHhICYiLlhw4BBWiFA/5FOXmhoc8u0Pv3vyyrDshgEwqLYnKLi4FO5OfkvPh66UdudnZHCXsFAptQ96XMW7jQTsm2xAF23roFlD6NXLy4o9m8AoHFR7SxNTWgjGOsVovtxqBxXAzEbc4cKCycN+/+/Y7n88oRvjarcNYsCDtprP/+ewjvZ1xz9SpERBp3zpz5qqP/D5zQE33tptaiAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDIyLTA0LTA5VDE2OjQyOjI5KzA4OjAwjRBbGwAAACV0RVh0ZGF0ZTptb2RpZnkAMjAyMi0wNC0wOVQxNjo0MjoyOSswODowMPxN46cAAABKdEVYdHN2ZzpiYXNlLXVyaQBmaWxlOi8vL2hvbWUvYWRtaW4vaWNvbi1mb250L3RtcC9pY29uXzJhcHo1b3VpcnV4L2Rpbmd3ZWkuc3ZncY9vkgAAAABJRU5ErkJggg==";
- this._iconBlue = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDozNjZmZDYyMy02NmE4LWYzNDUtODc4MC00YmMwY2IzZWM4OTMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MkEyMUE1MDg3NTAyMTFFREI0RUY4MjBCRjRGRDc0QUIiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MkEyMUE1MDc3NTAyMTFFREI0RUY4MjBCRjRGRDc0QUIiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6OWFmM2ZiODktNzQ4OS1kMDRkLTkyNzUtZDM5MWNhYzYwMGE1IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjM2NmZkNjIzLTY2YTgtZjM0NS04NzgwLTRiYzBjYjNlYzg5MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pv/grmkAAAhxSURBVHjazFoLUFVFGN49597LBdFUEpEQI0IpyxIfqU1ZkY/pNZg1RZlWY2lW4yMncxq18oHZ0+lhOaWZUo0zPjIr8W1NiubI+AxBIkRQQsQE7us8tv3P7qGL7gXOPRdzZ3bmcnf3+7/v/Lv/+f/lYkIIMpur2yBktQVO5yM7LRybIvsOFKFGCeHyQz/dFO2Ousflcg6UJSlVlqVEjHEMjNMH5tE0vVLT9ZJAQNnn9fm3d+9z3xEYioR9bNcjW9Z8Gtv35l7PUAFjnU5HLytrFUU9TgV9XXD4+PJhoyfV2/GIFO4TGD8my1lVuGXSHYNuPdyhfbv5VkVAgzWwFjAACzAvp0fwoV++uz6lxzXLolzOW1AEmz+gHCwtq3i2z52Pn2jtlgvXI1LpgQ0jeqYm74y0CGiACdjUxkir3KxMlsoKNj6WmNAlV5Kk9qiNGmBTG6vAlhV+rd1aUuGeNSNSeiSuolGo2X1cdDogbThQ79h21CMfP6NKtR4dw/edYiTSK8GhZ/aO0R7KiFV7dnPpzeFQXkppWeWY9MGj8+ifektbqzVC8KbVH6UNHdJvOw2nHUIB7vrDI89df861p0SRsUSjuiSzB4qxyYzx0TVEdBUNTnVqs7I6B4beEKOFwqThuu7X/IJ7hj/yYlGoM9NqIakpSVH7t67c3C4muq8IyKcQ9EpuddSK3xqcSHJR7g7WsSkCm8+YiSEgRuU9gMbd3k5578kufrcTC8U0eLwF/e99anhJ6Sm/HSHSid/Xv5CclJAjAjlXr+GHP6x07z9JZCSDCBfzBJapBomJabJfdKqFCiGa4RkQgrQA6p+MtbVTEn2dY2XhUz956szM6wdkLRFtsVZFrReeeaRTQte46aIxT4DgrA9ABJKRw42QTLsjimqATgUZwpxNO/0OGz3KmMvWuBFgABZgimwBB+ASbtSSp0zIHutyOuNEg9NW/e06UE49YRBi5LFB2NxaMoQg5iGJfza+Y+MwlwlmogALMIXpD+UAXIBTOEKi4rt0zg51sFft8TjN7YQbnzrbVpeeD8Q+w3fYFCQba9ha5kHABGyRTcrlCeBkVQjO/Wxeb3rA00WDb62rcbHzAARML0hBAloK+lyQ4TEHx2B4BragUS69vl06/6aLnk6LQuQ+vdMyRQMHT/ql/D9VGfEQi00PGFDYwqsP8/AsMQyJbTvABhuiFb3TU+8Otb1CCXFd1SF2gGhg/f56Bw4+B9iCJ0J5Bv93fgAbbIimd7yq/UDgZklITLQ7RTSwp9grs7MgBYXYMEQ0OTtBWBR7d5FX+NQ5J0tCHG63K0GYglSpkrklGkXY1GGKMbdo8d+qkBfn5LB0RpwOeDlc2mo9NNYHbyOMIuCRptvNsCGqXxgnS2dEoslhxMrgSDXOSbL0HlFVzSv6vlMMJigorWGpnJ2ymzRdTrENGxY4NSeE+PwBYQ3ds6tDN1IewvvFRMLQwTBMPB2lxTuEaTvnRKwI0S/U1ZeLBganRWtGwteYAOoR8EgQFsUe3DNamNpzTroVIWp1TW2xaCCrf6xKzDScaP89SRKGGBLkCSMjVo1aZRS1IZrOOalWhCgHjxTvEw3ckhylD7rOobF6ghZJphhk1TO80DK8Yab1KgJssCHMKhgnxYqQQM7i5bv9AaVONDh7VFzAqCWMekLhRZIFzzQWWLzIMjAY3qwsii2+YakDTsDNkkdoRVZbXHLyN9EglKdjh8QoUBSBcaIDEYU91cbtRi7yUFCF2OgBha9lBRZg3nWjuPQFLsDJqkfAtfWfr1jzDSHiR/zuk/GBjO5YQyqtQDU/5WYKCjo/Oicd/JmPw1xYA2sBA7AAM8RFBAEuwMnqYTei3Q95vx47U1VzTJj3uDBZNzXRl9EdUTE+SshnECJcFPOWwraNxj0GYo3OyLM1PgQYgAWYIlvAAbgAp3AKK6XyTPXZ56bOm0f3p/BFFEdr7LwZSd5xQ9wKUukUo/u4h8SdecCHzPmwdtOMJF9ciHodbE+cvmA+cAm1rVoSAsD1m3fmH127cfvSUJOiXRh98nS8/8dpXb0DknWNKB5qzsOIKlwYdIULpWMwB+ZunNrVC2tDeQIa2P552+4jfFsROxd0sbRfm5/31dyMPumZLQWkwsqA9EOTCzqCzdTGvKB7MCNWTU9s/oIOWsHh41tvGz5uNv34Fxdi64IOvNaxQ/t2aXvzVixKTUnqezkSRBqhCm4bMW7GhboGuJw7H+qQW7nEBoALFPCvOx8cP+toYUl+W4v4o6h0L9iiNkvBdnNXplYvsSEtOFddc75owLCxc6jLd7aVCMDulzlmDtgCm6FSEju38RAxztJUumTkoy+9faqyqjDSIgDzgezJi6gN+P9Is1HKjpBGz9T+U1cy+ulXZ9XU/lMRKRGABZjUEyeseCJcIY1i6BY4NmHagjlen/+CXREUow6wADMcEeEKQTxxq96wadfvCz9cvpBuBSVcEbCWYuQAFmCGSgrbSojx0qW9KmfxV5u/zP1+MTEqI6vlCNFhLWAAFsdEl1sIvIAgdTn98muL1mzZtXe1VYCtv+xbDWsBg2OR/0OIKaaB9ooHsqcsoXt8h4Uwu+P+xyfD/zwqOIatHw7YFQJvVthSUICVDxs9Kae0rOJwS2vKyk8fgbmwhq/V7fKwLYSLgWLoPLz9s59//c3mwjKMPTZ+5hswl6ceWiQ4REQIF2OE5QOHCo9NfCVndoPHW3vxHPgOxmAOzOVr0BUlhIuB0Hn2+5937p/77hcLgsMyfF7wwbKFMAZz+Fx0RQoJDsvvL8ndYYZlM8y+8/HKbXbDbKgW8ftd+qQJLQcglFZCaE3qFn81wogEh1mYE/F74bb64RnFAm/DDwy6mPdrkJLzKGfLpsj+vwIMACSZzfDJFmOPAAAAAElFTkSuQmCC";
- this._iconGreen = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDozNjZmZDYyMy02NmE4LWYzNDUtODc4MC00YmMwY2IzZWM4OTMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MjI1NDIwOUU3NTAyMTFFRDk0MTJGQzhGMTFCQkREODIiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MjI1NDIwOUQ3NTAyMTFFRDk0MTJGQzhGMTFCQkREODIiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6OWFmM2ZiODktNzQ4OS1kMDRkLTkyNzUtZDM5MWNhYzYwMGE1IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjM2NmZkNjIzLTY2YTgtZjM0NS04NzgwLTRiYzBjYjNlYzg5MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PgEE4igAAAgKSURBVHjazFoJbFRVFP3L/OlMoQXKImAFm0JbFtFKShEQI6UsggmkGKghIKTIIgZUohIDKEuLaFTQiIKyKKghqSyyF0pZbcHQsJVpoRkKbYFAW+iU2f78/313+qY+hvc78+dPkZfcMJ377rn3/Pve/fe9gVUUhfENY5eBjNbhvlnI6Bmh+KT5NzBhGigg9sb5vX3NpohhRqMwgOe4eJ7nurIsGwl69MDskiRXS7Jc7naLpx1OV/4z/V67CKpw+Gf1ZiQv9/vWyc8lTkMEpgiCIVGLrSh6ShGhX4ovlG5Mz5jToCcjXKhPIGvyOOG2JW/OywNfuBAd1WqFVhIwwAZsAQOwAPNxZoQ9f+yPHnHdn94QYRSeZ8I4XG7xnLWianq/oZOuBrvkQs0IZz27a2RCfLeCcJOAAZiAjXyM0hqblslcRfHuiV07d9zKcVwU00IDsJGPLeBLS3zBLi3O8nfuyLjuXbegKtTsOrY4Ldz22u2GPFue4bL7MlfrqWXh+xhDjNLL2EtOj0r3jI8Z70kyJcnN4aC4RGtF9eSklzIOoD/lQEsrGCLs/m3f9nxlUP98VE6j1QDz6/P5xZWLI06KJ3lGwIWdB2tfZEgkJB4oVwwzWBgsLY1d6hoWPUxSw0Tl2na8sHjYiAnvlKntmaD3SHxcrDG1f9/1aiScspOZYZ1hGm4dHnmSRyRglk+i/ITQwVywAVvAoA3kMyolufc6iEHv0uKuntkxu1ts5xyacY2nhh1TNsZcpBTxjBl2K4AQ2eD8MiITWXFDmULiYJhUNlXak7DH0d7QnvrUr1feWtgjZdxa2hILKiOzp01o1/mp9gtoOrtsZ0eXjjYXMYhEa/RFKyxmLCaCmBF/NhF633xkCxiABZg0XxADxBJq1eLnz8ycYhSE9jTl3Iq5EWeYM/wjwUPQvj1CEwHP8SMFWIBJbX9QDBALzrNmIhGdOsZkqm3sTfWbhKbgTcSSMhBLiiYcMc9I2CMswARsmk8Uy5s4r5qIsFt/WN6nVaQ5iaZcVLkoQjEpjbD++4IM+hFUQniCDMYBTMCm+USxJP6+bkVfFWRVIny/Pj3TaIpiezF3SjzFN619AaNwRLABSwzhnSOWGxLABh80sz5J8a+qLS81IsY20a1TaIrc2lzhoX3A+2Ui6FcxkRn+4f3j9UEZbdtEDcCUgycSaTbF0RQnGk7wTY79S2xIbSvGIDCPNxynPnUckyYiBpPJ2JmmKBVLuSYCXIA9EWxWWAIPYZeJZdS4cEwGTXtEMBhMNEWthHonVieB5gix2Aft/NIYk6Y9wqHmMGzH4HANHBOn6T3i8UgO2vcxfIzibTdI0Tv88Lw+NMTUHBHF6XJTz9CJQqLs7ZdkLHoIkbbyf71YgpBAbdtxTIoWInK9reEGTTGk9RCpqfGTCDJ6skE2kxL2QRk4JlkLEc+dmrorNEVGTIbo7VxFgowUQlYU4oxCnFMAe0LMBJFmgmPyaCEinrt45TRNkRyZLA8SBkleMj5CMvGclCBJMIQdJgAC2OCDZoZjErUQcees3njK5RZtNOWy2GUu1sk2nidcOAiPX2aUAHvC/1yCBDDh1Khyw2KDmLBF8Bkpt1bWXSm/fpKmhOPp9OjpIhyKGCcWHxkPpQj4b2oPQcJnj7AAMy06jbo/IBaISWtGwF3Dj5tzf1PIIyQx1nRf40phUiTmQWMQTaTI/ePx2wPEPvAF7xWEAViAqXIRoUAsEJPWze6tdn8dOF5y63ZNCbXv4SKVvYl7HSkKItPQGMwjpFx+4he8V5AtYAAWYNJ8QQwQC0bQfLASq2/duTvjveXL0fqkvog6GDooR3sdtWdFZomsjW18Xj5SdhXBwYOADdgW9CpwAJbK3nDMWpC9AmJRW1aBiABww8GCwkt/7s5fpzbJzJmZ9XHrnYfiDtkHSgMlph59CSXC9y8phA7m5sXl2cFWLRMwwPe+w6cuYvqKngs6uFp4tvDApmUv9ktKC1RZSxwl3I66HYaD9QcNFtHC+RpAaDuShCR5RPQIz7h24zy9zb3lQFjFF0oPpY6Yuhh9vIaJ6Lqgg6y1jY5q1bPowOZV8XGxyY+jQUQVqjh15NSP6m0P4HLuntom13KJDQD1CPDa0NezFl2ylBe2NInLZdYi8IV8WvGCDJi9YC+JoXDW3qm5V5aSPmUJSnlBS5EA7P5pk5eAL/Cp1pLouY2HinEXtdLlo96Y+3ll9W1LuEkA5tjMeauQD/h9pNkqpYdIU2bq7tvKM976cFFN3f2qcJEALMBEmbiqJROhEmkig5ZAycz3s5c4nK56vSQQhg2wADMUEqESYXCTcWfX/qNnVn6zcSVaCmKoJMAWYeQAFmCqNYUtRYTBTcftnNWbDv68dedqVMZlrQBgA7aAAVgYk3ncRBTcNd189+NVuXlHi7ZpBTh07PQ2sAUMjKX8H0R8ZKB7qhqbOX8tWuNHNJTZI2MmzYPfPKowhq5rDL1E4M0q4w7qRnrGnBxrRdWFQDYVN25ehLlgg21lvXHoJoLJwInjHrz9M9/+5LPmyjLoJmYt/BTm4tZDCkcMYSGCyXjL8tnzlpJZH+QsfmB31PnPge9AB3NgLrZhnigimAyUzrs79xX8s+zLn7LJsgyfs7/esBJ0MAfPZZ5IImRZ/mrt1iO+suwrs1989+thvWVWbYT9fhc9aQUdB6CUVkNpje3SqQPDMgpZZmFO2O+FW+o/niEsyDb8qt7Rd78GLTmucrp80vz/K8AAYAEv1AHM/GwAAAAASUVORK5CYII=";
- this._iconViolet = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDozNjZmZDYyMy02NmE4LWYzNDUtODc4MC00YmMwY2IzZWM4OTMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MzFDREU3Mjk3NTAyMTFFREE4MThDODBGNzMxNDBCQzEiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MzFDREU3Mjg3NTAyMTFFREE4MThDODBGNzMxNDBCQzEiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6OWFmM2ZiODktNzQ4OS1kMDRkLTkyNzUtZDM5MWNhYzYwMGE1IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjM2NmZkNjIzLTY2YTgtZjM0NS04NzgwLTRiYzBjYjNlYzg5MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Ppb+WxIAAAhcSURBVHjazFoLcFTVGb6vvdnNY0lEEJOIxhCSKTEFKSC1osIgjqIyA62mZfAxWJU+tC3TVh2lHSGhtNOKOqK0ii+0QwcfFB+IAsKIITpJhUBDHhMiSSBCTMgm2d377PnungubnXOT3L0b6rlzmM2e83/n+87/n/+ecxbeNE3OLvLFV3Fui3KiivNSkhmTNb7EpagQQvzxg++VBvxpc2XZN1MUhEJRFHJ5nk9HO5mwAV03OnTDaFYUtTocie66pOymOjSlYnzeq0d2bn02c9oVxXcTAct8PqnYja2qakeJoFdqDx3dNH/xij4vHhGSnYHlSxf5Out3rrjmqqmHglkZa9yKQIENbIEBLGCeT4/wB/f+c1LBpXkvpsm+73IpLFFF/bKltf2esjl3NI005JL1iNBSs23B5MKJe1ItAgWYwCZj3OiWm5vOQmvt9ttzJ4zbLAhCFjdKBdhkjNcwlht+Iw0tof6zrQsKLs19jWShIeM40hASure3S727O0WloV/QehTeSo/ZsilPzjCC11+k5yzM0/yTs4yhcAgvtaW1Y2nJ7MU7yJ/GcKE1EiH8B1ueLrr2+9N3kXQadAIM7f1abK84LEcOnBFFXuREMpk8TyrHx4jhMQ1OJ5x0U+f8s8boeY9MUbLmjNedMEm6Du2rqp17w5KfNTitmRGvkcKCfHnW9NK/O4kwIjp37JdfpDUv+jSgVw+IASHAofpRef/gSttQ0Rc2sAUGq5Axs2ZM+85GcPAaWkLT528/MDF/QiXLWPtG4Rt/tM+v1vSLMi9zPl4iniCVeASeEPjB82QQj8Az8IjOaZxqapxiKpzvygy9aMs1EekCmTnrX7WdfHjSjEUbWCE2Io88cPeSnAkXjV3J9ERY5xuX7PNrNQOin0/j0kiVUQUI8llVSnjs79FHpjawBQawgMkaCxzAJdmsJT50X/ky2ecby5yllTWy+p9+MY2PkYonb60RUuER1udBoixBMgcsYDK3P4QDuIBTMkLSxo+7oNxpYfe80eaLhZPMSSSkUAU8vPWvFVr2QrdimD7xfWw7nzUZMgdMYLPGJFx+DE5uhfCbn1s9JSM9UMJqbF9TJ5O5tNZEooh48o4Lk66fwWJIJZjAZtkQLsVvbFxTapm7ECKWTSmax2oYONgjRKp7RSluYbsRwRITS9cxQcDGGCybKSWF1zuFl5MQeUwwcwaroXtbmyTRWLdFkJekKxGDwo3nz4nB+iEVY7D6Z4/JmgluroSkB/wFrIa+z7rE2DyeWwfJiEhcO2fXD3n69p9mzjrl5EqI5PfLE5hv0qZ+gach4TacRhJmwFaaB5i8KCfJ1RrxSZKfuW3oUflE8l49kvg3xmCeX2KcXK0RMut8yo7BqSqUk+DqPaJpepjpqmyfaSbs30wPx24WFsZww2koIWYkqjDP0PKkDAO7WOuheyevBRgGxQS2XJjO3LZTTqYbIUZvqO84qyFz9lidyohtzenjRYT92LiZsy9kbocpJ8ONEO1UV3cjqyHn1nxNw+6V1tgsJicmdkaJCbDxgJ1zW77G6k85aW6EqF/WNVYzc3lZtuGfGdQ1sgXHVtwW4zbM4sPJ3tYDE9gYg2VDOaluhCiV6zftjypqiNWY92iponKKdZ7QaHUjJl6EbQ8sYOY+Uqo43LCEwAncXHmkuaWtu7H5q09ZjTieZv/kEhWHIpXURDHx6ydxLcT3OSdCsQ5YwAxeyz76ggs4ufUIXNv3/MtbXzfjj5BxZeK6aYpvaoYetUhECRnVqhoNNyvkTIP5WbNOh7H+sAUGsIDpcBFhggs4uV3sVrb79459R052dh1hGgZEs+hfP4hIU9P1iEUmapFSDGWQqPjnLHlDoQKiHGyBASxgssYCB3ABp2QOVmrHyVOn7/3V6tUkPpkvImlsmln83nXh4NJcNWKGuYgRIxcTpcQIx1fynd2OvrCBbfG710WA5bA2wvevrFgDLk5hNZwQAPd9uKfq8Jvbd210BPCL3GVPfS9a+PbVYWF6QA8bEBSrYYgzI1a1Ptvfk4q+l791dRi2Tp5Awdjvf7y/joaV6eWCLpPUy6p2vPTElWUl84bLSOH6XqHn3Xapd9fXotLUJ+jdmrUBFHMkU56UaQTnkkRxc54WKAkaw2HVHjr60awb7nycfDxGhXi6oIPXsoNZGUUHdry8rrAgf9r52CCSDFU7a8Gdv+sN9eNyrsdpkbu5xAZALwE8NueW5Y8drm+uGm0R/21oOYCxyJgtGHuoK1O3l9jYFnxzqqunYcb8ZauIy/eMlghgT5+3dBXGwphOWxIvt/HIGKfJVrr5xh/+/E9tHZ31qRYBzIXlD64jY+D3kSGzlBchZz3TfSbUvPiu3z7W1X2mPVUigAVM4okmN55IVshZMSQEjtz364pV4Ui016sIghECFjCTEZGsEI5u3E5t++CTz9c+uWktCQU1WRGwJRiVwAKm06ZwtIRYL11SOyvXv/ThC5vfWW/iaOf2PEJsYAsMYFFM7nwLwQsIW5cTv/j9uq07PzmwxS3AR3urt8AWGBTL/H8IscX04zp4YflDG0iM73aRZnfffMeD+M2jnWJ4Ovx7FYI3K0IKB7Dj8xevqGxpbT80nE3r8RN16Asbamt45eFZCBWDw1AP3v7lP330j0OlZbTdvvzhP6Av3XroqeCQEiFUjJWWaw7WH7n/N5WP9w+EuxP74Du0oQ/6UhvuWyWEikHqPP3O+3u+eOIv/6iIT8v4XPG3F9eiDX1oX+5bKSQ+Lf91w+bddlq20+yfn3n1Y69p1qmk/H6XzLRJjgNIpR1IrfkXj7+Q4zkzPs2iT8rvhUfrP54RLHgbv82Ps+/XsCWnWc7TmKzx/yfAAHo1CtU9myPWAAAAAElFTkSuQmCC";
- this._image_arrow_forward = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAAgCAYAAABkS8DlAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA4FpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ4IDc5LjE2NDAzNiwgMjAxOS8wOC8xMy0wMTowNjo1NyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDplMWFmZGVkNi00MTJhLTc5NDAtYjQxMC04NDExNjRiMzQ0ODciIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6QTA3MThEMzhCMjc3MTFFRDg1ODdDNkY4OTc4ODRCRjUiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6QTA3MThEMzdCMjc3MTFFRDg1ODdDNkY4OTc4ODRCRjUiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIDIxLjAgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6YjI3YWU1YjEtZmRkMy0wOTQyLWIyMzUtMDFkYWY3YTJlNGUyIiBzdFJlZjpkb2N1bWVudElEPSJhZG9iZTpkb2NpZDpwaG90b3Nob3A6YWUwMWJjYWItYzAxZS04YTQyLTg4MjAtNDU1NmY4NDVmMjBiIi8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+BD9OfQAAEDhJREFUeNrsXT3PJEcRrho2QQ5IkAj4HfwJEhLInUHAjwBBgEACCRC2gAA5MEiQ2QRYpCQgPiJbsiAxyMYGm+O48927u+8WPd6Zd3t7u6qe6lnfe3tvt9Sa3Zmej+6uruep6i9+9NxzTPvAh4MQHf+Z09RCfsPRzUXInyOVa9b/Hnq4zMBdmnv9dhnp7enpDKtToJf9f04/5OZajQiwQhK4UmWskAUtTa3avSAV8aj9Ro7a7/JcDz34UtkVba/fp1JGLrCSpQvmx0EASnAfwZ8V650rgMugdAkA7lIhGGSQkMP1wxs1oqJds64jxIZOyg8jGTmZ2BXXdzfXOf2WozRykub4XAeWbiktK+deR5299G9+mhXgd1N8McU3z+wBqFrqNTLAQE0xYNE7ROKkS0J/n5hppJJXAQgBBT0SrBCH4yNP0K6TjsP3SfUZHlGxiA9ViEeNXOyyNLsszXVxXxmv1fTyDECL2Yazi7dJduRp1Vs9dJdQJ11nCF9K8ZMpfj/FN5pr9XQMgGptt1jPFEhvWd9FGp59Qdo9Gvk4h5XvfbsFvEPQMxF5JgeOZf0OgW8ZjPKI3jd/wzD9Lo+7gohcT+e3Bbko4674v90fOUXZHf7TLnvWdddwPfTQw4WEzaS7fp3ij1N8bYkHQLPec+bHDdZwrsxF8SZoYC8KYFDWETRUniv1fJieCDGAq/Z8bSwDWgZEtW4X37MiFSCV4LElTwwSQ494kXOfFP8/UXipNDLjkZ35sRGylBMXOX4X5zK4qxCOmVhsMwKSx43yf5OlXxf3dnLSQw89lPj9hRQ/m+KnU3w1xfvn8gBQ0JpHLFvb2q/34deUvxjWvgb0kT58Bq1hxPL13uNZ6QP4Tu97Ix4C6x2IFwUpj4hXQ3sH8u3oteg57TuQMkO+r/Xbau/PycmmIBzr7Pfj7Pp87Sr7vT785hRlk5GcHp5U6N74HvbtMJeI91J8IcWXU/xbCwGwQNvrG/cG7KGg7H2DRwyQ5wwKkUCfMVTyFiEELfdEAMRIV+06iRIA9PuRb1wK4lGiYZWRlq7iAQgTiyUEhQnv8tHS1fI9BGXMqmO0fq137DJisi7i1URO5uPj6fx4/DD7X6Zbd3LSwzNOAErMemkiAn8pSELIA+BZqwIAjzc1EL0HJSje/S1WeASQlzwXsbARr8K5PQHnsuqXehdQS/j0+n5Cq/atshBQ0XuigGqBfQuZGgJ5o4bvjJIjPkvdtsssSmZr77iavB8jyXiUkY2RiDyczj3Kfj+Yrn2YpZt/bzuO9XAmD0DeJfnHFL+T4m8mOTQJwED1PnAEqJda8BqAc+B7UOtaAGBBr0UHEUa+tQZcVlcABZWkl1YMMEIsYdS6jIAc6vmIgLTlGVpq0aNl3jImoREMmQ3vD0pUEALHhpyg+YwAey6XA0AgozNpWtoQ0v6HkD6IEc9tRkRmYvIgi/ez3/em4/+m45x2Qz1cEgEoceftFH9G+wGCf496AFr6/C0vAmLdKySDWZkGyNQ+6wAhHC0uejLARah9vECrm5waFFNUCVmgN5yWdwiIxsNQ1H/Uy+DlCx1vQADI1cBwiTKPkpHl3RKH6amtXo0ocYl6LILyeCNvVt2j71hC9lrG1ESeHSH2pOjWCBmJfFftnGTk5P5ERMb43+n/Byn+OzuXX3t89NS7OR5iA3jRxy6w36b4rRR/F+0CiPb7e258aQTw0gL20nrjDWrPo4pbGPVG5B4UT1miwNkKuMh5VPFFXP8RBbhUqbVaXUxtHpOlsw9axwNoRCPaBeC882ZciEcKqLCyW8BwaCgvVBZQr1K0Tmr1ER0/YbzrCITR5wr5U4qXkoaIt7Ce7uDFXGrkRL22BHo1kfdcTWTkPym+P5GSf9F+0N3b0//3p3MfTKTmNgkAVbDr9RS/meIvLAJgWebeNaL4QMCWlflQdhmZmRBhsS1MN2qha982NL4zYBFADXQIlsUSwGtR/i19wxGS0gpemLV5rDSHj58AwIAZ6FY5IhUWEQ6AOXM2HRm15j2PD/KcqCejdTYJUVvXFS98XlQnDQFdvAToOfunLYaG4gY34gWqbxEvMOopR7zn6AJ2+e/Re/K9FH+S4ju1ymwJEVIghjVuFYoEGpL1DXkQsFKIsLUKECdUba47WnZWHpD8ksMQvWfXGGb5OgG+Q1tVMvqM8t7IEtNI2VvpxCkvtEyl+l3ilgEiP1q55jIoC/NuvFfYaMMElE9lczGxvo0b86DVpSzQhWiQxvtr+kiMMhanDUXzKISvr4J4bP16FHd/FqTurXYrICC31BNSJ2zIXjkxXoB2VMvPp1L8Woo/TfFzHgEQowAFLMDagjxcqUA/87oClYAyJ6XhREBTAvfVCIYYjVCAckbA2RJycQSFi5+sAEe+uI6leFhRHlEm3KJEBbB4tPITkOwyqFS1bjJk4SdEYUfkWQy5jACCR0CI6otfeRa/V67aQl8CKO4WHdEOnAzLbfRJUskvA+DikVEEsDQ9jui0aSqySbzYAVAkPy1BFmALGwZOxEjQu4TFXKRNHHzLr30+xV+m+HyKn5m7AKIsDun3j/7mhvdaFSCAuxeZdsgN744+h2l5l4D3HM2diPZpou9t7Y/kQF644T1L3LWeaxidf3/OkfBaHpeU//H3H/f9L51aiHxvax211Dc6Y6Hl2+y9Pc4jk0u6ABHdQKAcU7DMiOJufG09EwGIJOKab+2eRvR+BNPQay33l+U1jm14ZWkXAOLGRdiWtyMgwlS5YG7sMGEBLUfEOkI2B0LvQayUSFeC57KNHKPWYst+EFFvTov3hSqeDW/cS83iQrtmOOB2RNtRixsQUSaHe8VU9uLLJyPtwHPtCpDO86awo7ti9ciwXrQs9mjdWN8kDe2vxTpmMD/syLJXl863SkQfH+sutrzbWXcmm1vXe5a2AN5YT68zWJ4Casmq7AyKwvAEp6XwLUUgZG+ZS6DLiEFBR9YxkEAjkqAyQIkJohxa6oYbFZKnTCOKBumSEPCd7NSfp+ijOz8iZRx1US6RM1baBBmuTISIWG3QyydX+u2lkq3IeB5PFoXaBluhXT45MYoYRXWChZPEsq2KAcLR8Q61vAoom7WxJZ7coWSnTCaAnvHSlLMSiu/NBpmKWocCkOzIFveahR4h2/Z7T+9+K8WvpPjVAQQhcVwe3qA6MQqOlYxG9xhA+8JrDVEChYsCnShPbLHUCWDT5DRmURpqpIxR0EStXAZkDQEetHykoazF8FIJQESQvFnAICH5wrInAcvcIgZWPpV3iNUGI4NzEY+HOHUaLVNkDECE7EmQwJfGS8Qjxwu/2+prZooPxEXD9GzxNiQD88za96K6PGIMoeO4JNjOI56c8v5x98Av0n6RoH8OhkUsgRcgzDHafyFKYxEQQKKj7cXJjwDP1nY95IyNSYBsRZUyWgcRa9ADfw4KJUK20MGlrcCOKuiagovOICDCBxp6HiiEVHBxyfPIWXKlDTBjhda2TBVm0DPIwLdansAzWKGmvLIB7l6/bMSrihJDDsihAM9EZrGgso2Ut+ZdEDBfClEQRM8tGVQYGQ+HzqjgRlnIwzgN8Ospfjk94g/zyVWgceQL5HhuIc2NoW1L28JbvalsnmJh0l3hVtcCG+RkVoaSuQnRDYc0j4onIBJQdJGpY0T1LYUHUJFGWLrnoq2VkCdDkcWrPBlG9r4gh0wPhocGXWZbew7apiJWk9Zm60RFTCJXey4B8sYV/dNKvgT0aFkyUNMBg6NbvHyDg7g+uh1tUyh5x9pbnawg7QuRI03movPoa3p7AGW4xQMTbVe2YViXj3yRoX9Mv9+lvQv/JcczldfFGyl+g24WAsoaa8NCQHkYCJ8T2rKgD9JAoqsORhd0QI6WVUPA957jHZHvtlcRq2+gg74/siOdZQW2bK1L1L4KHJKvc64EiD4HSVdZclm9Z2iUjSUb6Gh7EZTph2A5WGVTy0skr6i8DwvaSPS7tbIWalvds2X5cDrjEWmnSBu2cGm+Pu6P8HCyhMcV+8b9DsbV/O5NwPredP4eHZYgHuMVPZ1hA+CjuxTwymHiOaCK40KuMZjWUbkUuP9wD9+42D2LGbGgIiPRxWGibFg5FqNGLHbPJW+5n+vCI6bl6b2fHE8KSo4igxSt+cMSlLn8dq4UBiKTkXn4iOcqQqzF8Rp49eYt2d3igSNjvQjNChycNJ6F7xGhljU8kFlTeTqtrMXw9NW8C0L24EV2dAgH2i5ax1s63unwwQSu8wZDI9iOGwyNS+jOa/3fn9KO6caNinbUw5JgyRa0GdDKAARRFLG2+AYFG5jnMkVchcfXxHTdiuOytZSOVejS2IC8iszeXe0HMdxtVeCKEiPNnUkG2A+Om8xTWFYdDUG3YsTNq8iJIKSPi+pBVy9ESKEF2uKAH5tk2RfHSBtBlVWETFl6wUuHki7U4CjbFgfbCmLZbiaLbd5mON9e+PEEpjPQPiyAd073cEq7DpssPVxyyLs7RlL1pxS/TcB2wKvTB90IuFQ8AB7bVBqrKnFRDwHaFy4KMEWtaALf4ylZbzlhtr0BQgB4ZdfFy5vQMitVUymn9+XDH22PAkoKo91U1iJRnifCA2zLY6Kl1/oovXtbPQ6R+pSK/LSQWlEs5+hAPQHPkWKhXk3AupkAcjMB5Ayy60lBbjLwvJqANU/3+ADOcvnQ2cH/GQF9zrFhrtWXU/xRin/+SK4dsrc6VSriWRfIspGFkpOWxoxaz4hLNToTAPVgsML+I6QGAT0UCCygtFb+I8dNGtnKWahcubo+gLSlqwWx6C2wQWUw6i2QLFfeltgEeFUsMuN1B1nuZ3Y8CdaztxmYXhf/1wXYrqfj1RTXWZp1FrcTuG6n2EMPlxuerGeFC8NwHMPwQoo/T/GvKNlbATwRcYtrykb7BGQhHgZca0SxEdh4FR6P5EcsO9QyQ6bRRTd6sfpErbXfkVH/5RKcrVaZZ1Eu8UoI4BmxtoC2ABdfXEYgi3j+v52AdDfF6+zcNvu9no4zuO4ygN1mxxyQt0XsNl8Pt45Yd8Emv6Xw+xR/mOKrtB9nAYeVAVxWP3wNlL3FIKzlZJGFJFpdksgKS6cgJJDF71mRiNehVYxQELY2S4m4l6XY4tUjIMrzquMTKOAN0DbSmcFUClC9zq7PabbF9esCgL1z+bN66OFCgb2D/4WHUQe9Qvstfl9recAKAMxaPz7iXkUGEVrWaHS0bmR+prezUmSN+cg3Bqxtt3VHRjWj3QRz2BWWKhXgqh132f/r7Pz14Zzk13fF9fIZPfTQwwWZoj08sfAO7Vf1+0GKr7dywJUBTBGhQheI8abLnQJsm5cq0reqLUHsjWL33scFoFrLD9eWRC1jDYRr50T5Lx1Ye+hWcA/PRpWdo34vWkZ+leKLKb65hAPm2wHrGxacTnPSRq7nA5G8qTBWvzS6ap4G4LVZCzXQ9YBYA2frd1dcXXH1cJfq86z134Wpy9uTCyvAYt4Vq8LlVm0NdLm4tmSnPLp7rUG6BF9avqTX0Z1ugnLOcu51dOdE9xbz9n8BBgASWdK5g1XGVgAAAABJRU5ErkJggg==";
- this._image_arrow_reverse = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAAgCAYAAABkS8DlAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA4FpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ4IDc5LjE2NDAzNiwgMjAxOS8wOC8xMy0wMTowNjo1NyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDplMWFmZGVkNi00MTJhLTc5NDAtYjQxMC04NDExNjRiMzQ0ODciIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6QThBQTYyN0ZCMjc2MTFFREIzM0E4RjQ4Q0YwQTgyMzgiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6QThBQTYyN0VCMjc2MTFFREIzM0E4RjQ4Q0YwQTgyMzgiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIDIxLjAgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6YmIzYjdkNGEtYmQwYi04YjRjLTkwNmQtMTRhMTNkNjEwZWUxIiBzdFJlZjpkb2N1bWVudElEPSJhZG9iZTpkb2NpZDpwaG90b3Nob3A6YWUwMWJjYWItYzAxZS04YTQyLTg4MjAtNDU1NmY4NDVmMjBiIi8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+EmbDrAAAEJdJREFUeNrsXTuPJEkRjujpmdnd2b1bYFkEAhwkpMPi7eCiQ+LuPAyEEMLhcQiQDgmEARL8AhxMDHxsHH4C+Hg4CAMDIYGziBMVZO1k7WRnZ0R8kdWz2zObKeVUVU898hEZX0RkZCQ/ubigkQ6UOGUZzfDc2mq096CRkUa6WRSNXEvjf61R4Y0Q2b1n5/anJ9vRJwdMchM51gsqsxzJOwaQHvF4Gl03UpjSuQJTNs6RY+vcAmiPgqU4SuN3Nu6pn6/vpaYAcXlX+it7zx5CAPh4yt9N+UdD5B9cdqRb2MVDEx+C2lXaFEC65M3e9WVdNo17qLimxrtQUK4BT4JAK8a79Puu+sh6PzsAbfU4eh83hIGWYLBb6upZXjkF8FrKP0z5zZQ/Mkbw4CQjje6/vroYFbs9dS4B86Q4X643jazdvylAe6OA9qYBrhYQWsCn3cPF+T7YcjpK6LseaCP3i6JRTwYga4KGouk/rTZaXsti4Akr1rUYAsMqC8DrKX875TdoTCUMrX6k0f3XXhc5VJ25ANNtAZ7pnNO5nFxd00mRN9X1SQW62+Ld1ADpqXGsAXJJUwDAIs+Vx6mhNUqwHaegOLqvqcrevPYUpBJ26iBgucT4vdayq3ex5J+l+qwlmrID/K2yMnC/oNaDHuB+JWv8P0j5s4PbjjTSSApz2xYgelacn+bz0+Ke1vW2AOJtA4ALcN1hwNLQ6ATTKoUqAPKeE0c71jRNUTRvD6AsIBADyFogwQ6AIMcIeCMAHRUErHl0ZF4dMa9b78/lFDa+L2A7tMo9BWik+p1dISQqAHws5a+l/HbKj4eqOZJLiiNdZ1q01gSccpZB9jQfl/Pz4nzJdwqwPasA+bQCWc3Ui4IeApbe8572Kw3iYwWgxKFWSwuManHeNy2Q9kaTOPXSwKp3zrlHSy4BDNXMyzZloF0toYDJd7SjgBZOQLvYNKKXuvWtloCItkfp9Ke2FyoAzEzhkxn4vzHY/kgm+d4+kD3LoHleHJff7uXjct26r8wL0G46gbNxnyAg7Wlz0wG0Me0+uQYq85hbbQHwTKceOEgQoJl057AImGvz59c0Ck2nC0SAsSwEqHUj8i2tv7W+pUa7liA7AZYAcjR9XdgRWKjQ2pEBywI8jhABYPYS/FLKP075M44JY6SRetK2ANN71fn9lO9mOrxbnN8rQDb9xudZCz4HwJQCGiqBYCrgdy0mEQE5URibKMylBSyTo915jDwyt6oxPA9E2Dm3NH1vbpsbWqsoJdO0X68fUS3dA3A22l2CVgkPG7yyS/D9njCDrGsXh75QS4vnG4GAMgP9x+AYQdf0E/AeBvjIznOeADB79s+Oft9M+UMdHT/S8aTTDKYX+fggHx/m45xfKc7vF0C7AO8W1IpQMEU0UNDbWFBty5ofZEcLbmkOEziAGRw/GuAJyCQQTcn5bcd7mQDNFxG2LOBH6hRhlhJoBwZaCtWEkekGASwmaN9pQoUlVEVAlp1xbD13ZfrfXzqHCCkofSA0JqBAbbUTg2MgMi4twQ39dlRw2HmvJQB8IeWfpvzFbLrs/eDtTfstcSeD6KsZWJfjo5TfW/3vYb5eQJZBCdUC0QjoSsXsraU7iObqMVbLgckzBzL5c55rrFKKRsZSRc5q1S3yXTkotelOQ+1nd9mxYVYUAjTuKIhbtIy8R8hehsVAm7cAaAKEC+kQxObb5nnY1vun9ruejUV07hrR/D0rQ49AgDgPlrCPll8DYDZ4j7XKAPX94ICiwri1gEuLCgMKR6v9vPpq/JaBMqvLAL+a8s9S/gQ4yJ5nupfB9P0pvy+D62ydeJx/e5R/f0++75zwtaM1o2ETbMVkEhbD84A+Im55modjOhNES/YGbO2tKo4Jc6qKxEGQtPquZWZEwFP7DOpVjWjZiBNaRNjSn69DgTRLxajzXI+w52nvHASwCMP3hCgUzHumLsrHUS18GYvsCBwC1Kc13iyTeY8JGp3TZ0f7RpwNifS1+Uy+74qQ7ZDI4Phkh883VkMIO+2D8lbNzB9RLqBVAB9M+Vspv5M1VW9wlum/hikqEDzBNO2g0Zs8k6VHpIjJkU2T3GVwCwl0kucbiswptjRAD+gQT1tkTi0aSMQyM0faHPm/xTBaXstEWJANhUaYC00OnSJwono1wVoTgBbx1KFfeV6WvCXgSxnyBZ33D5k0wXFCDlj0Wm487dYTJGVlu7ToF5nKWcrlOechJmzptE5EV2VooI2sXkBC8EZB1uOHETrRcDTSvlDfbIobPpfyb1L+RQP8EQmbi4GOgDgDxBQdgKz8xgEtEjGbeYO3Bf51Ga0wl8g1NcxKPVYai2ARKZgp7nTEnQyWgMFFjgk5aiJG+1EarxFQqyWDuS2XDJgwo3WghoUPmS+NMJ3yK0hYVqTNidYt2+qxOiCgzEFabwFb4B1sjePI8jEkLgEFtU82ymLRT9STXYzvInSEWi0JrCOTv6lP6/9s/I7wn640CwAfoEsnv9+l/GWDcLgxANsgJeoAYqBCHlPmQOcQ2V6n67UaHUQ5rmWwxVSteSNR+icCusi8Uk0L3txcb3v2vMVjwuibGHiHN6fp0UOLltmhFXTuMsI4OWhdQTScqGc7U3tumcE+ZpApinOftWGMHEB4RcBdwH7hhgVNW+/P1WcZsKwi1lOvLSLToBauRPi8p2R69BzhERq2eMKkF6CICfOVQKze7vTYPAXw65Tfot3lU0joQURjRADdezcDDeqBmOVUQgEmaAxIKGh5xCQbCVrSIkZ0Hr/H1N6zjCliSmv5Dfd6BaPmNc9aIAB9IVpMj8ORpqWX72yvv991/EOdsBzggaaU0PlyRNhsTeG0fD0kQGMe86SOtkKdYxFTsxfAhwxeUT0jmrVhopiDncVDJgfEEQ98hD45MA4j1iKEJ3GwnZhiFu+eUMzRlU4743ijAjmHGbllykL2OY7Ov4hjFSijL3HDbCaN+6yYz86cjiASoyWtevPh7GikvWDsCXYMCB8eYUfNaXGLDYcFUwaB2tJavb6MrNRQ+pq9cWNZ47gYyWJoVwyMcwnQDKJ9e2M/2o8REyriF4Bqodw5rjxLROT91jr2iBPyGq2bO9ug12rHYHsglhxv/r4WNiOR+lBlM7qK6CCr8WYB4Pt0uZ3vX5VPiaOdR5mSx4QY+C4FTFaL41EmKGkxZi6eZpBIjHsYnXdETVTWGlUBGYeA7ewJdhpYiwGMKHMXh2Fb1Magqdeia89EyyvGAzkCawn2rQ1FPCuX1p6IjwfiVc+geRUBlOhe6lHHKhS4PcHQmvZA55kRS5KAdEPgN3sEbu5oYw7wMwRoI4AYoTNkejDCs9Glx0jYbERpphV9Q4Y18akA8PeUf5vyV1L+fdCc6g02r2GQzpdOoo9oLHkAMKrlki3YCFP/sknUAUnzqxCKaWQ9dZaGaYw7Bi3qfISWmzrrboVaFZB+UdrUYi5QNYXEwPcsCxCqOTtty7SiXwQU9BgoKwFWNE1joyAv8KyOEdrzIvihfg89q18iIG3F/kAdC6NtXf+3Z4kbO/2AWJwlKGBxsI3Z4N1k8AWP/jkwnpt9WqwC4D+lP99J+Zcp/6tz0HNAo7I0CnYkr54EgJNQh8VC03Yjkd/QAYoyBwGYlQDaMjqtENW+BGCAVuAMDkjGa6wvVjkQJzVP0udA/3PFJhFth4GyOhqHRIUGDmpgFKBDxFqmMdm1MUw4MB5RK0uUR1lttMZ7noFzRINHhfT2+8TkC9b6fYuvWb4XkdUJiACH+JoxyGu8PlizVPYqAMuTi4vWA3MgoJ+n/Brhc/PzJkEfpctVBXMgng/TbrAezUENia2Nrmm1rAiexcGKaDWB1gkw+p4Zcx2dR7aes9YDR8oIhOBtlWMnAlb0vRIc2JOjya/dKAfdHwAtU3RLWWQnPuQ7E+mOc2v2MfA2FbKesTZu6WnDKA1QR9u3/78b9yM6hhDa4JXtb9WLKBbILDoevMBqGt+eqvb16hUJXYzu54A4hbYDFTG1lr4SyN/ZqKMn6HjOnc+e0QSAOWmhgDUgPaXjTPPqhiX07qN8nCMEPs7CycN8fj//PsdAmBtl22j4ySESCRDPmqiBIBBDAk6UGZECKMh3J5DxXBfgaO0+AXWlFQBtlbnRLyyN8Mw9ghRaV689NQbrtT3ar2u2G+4V6iJClSeY9AgPER4xrR67+2DUQxu9gsEa3nXIb3jPeXTChCsmPd9DlF5PQQ1ZoywBYE7aZkCtRjlWAeAmpHkq5m4WPuZQx6/Q1V4Bc0jjB1koWTbueTUfyx3ztp2DskeIiOxJ4DFNlPFqjHBS7mNQi0QZOVK3ifRoglMH+EXLI53PdAoqXaArnXWK0BGy10VUWOwBME+Dj7RppEyI0HAIUEXvYcAipT1v3cNgOTxAR33S6o2NohFue3zfPMFhTXRD8QQAoqvtgH+S8qczWLXW4w4B4CYnbEZp2fN+2Zr3ohJEyusH+d5y+9672SJzVtBLr3m2cT+XexusmWpAtaFDaX+HAnOj3Grb9AJO77bHqNXALs+VyV0UZh6d9ukRsiLadKStvBgHiBUCsXagZW7RjyO47O0oGVEsKDBOkSkGMqyXUYuBrHjWExYQS4J3D0esErYAcFXNmVl/KuXvpfz13Rc96+izgaIjHYkoc14IK4vQcScLIeeFEHOaj2fVfaf5+jTn+fcTAACmgCaGaINTh7a1dj6/R+CJmOFbYBed70fKjW4vjQJ1r6WmVzDy/AqY4r4RnjUHEWx6rIsR4Eetikhdestujd2Ipr5ipdveTqSIMKAFAFpWue1t/rY1WenVre+m/MeU/5nyX1J+my7nzctNT45JUx3p5U0zdfwn538fcTm3Od/Jx7Min1fn51kQOauEkvJ6m4WU5fqEsI1GagZiMTJrsySieIRNVsBMX3XiO4N5dSGD4Vtm1hoUDrFHuxG+N31H1LKx044tM7AV26DeLY8I22iHwTbUVn71cPneXQx7o1MeIupodBe/cmfISIRFZzO7/YiQyBRAneZ56TfpMoDQ5+n4nQBHGhLVSP3Esa1yKXBsi/NFQNlUQshZPm4LIWU5bnI+KSwsh7Z4oJaNXl8DxMrQ40/Qqbk/G88Rh75JAcs1/kOW1SKqjaNWgbaVYFdoZMId+CZHiNDKiewsiTqMW/2NRBM0HQR7BIAlvU6XWwe/VWgeIw1BYaSRnncqhYg6b8HfNvn3WiA5qYQVLs4twIwuRaWAw2IEFFF/AUR4QQQfpKxr6oPWAxEeiGK+A9Hl6hG/AFEsBl55kT1fVGFhu4L3/yHlv6X8j5TfGDzotqcB/iMdbZpyfvfIJehNJUhUVhDhQgAp/8/Fb5uGMKIdl+9agYO0zZusQa9NOSCmew8gUY3Dm9rQmJi2MRFS7poZRsvYalukHtrUhXL+9NSaynmWMAFAr+KfU/5Vyk9ebs028I6hSA/rx0gvqwT9v5yPndg3tB9JcqNcbxrP1cJHKyqlFvu+tRcDExZ2WByQZ2Ng90Q7RdgGg2AeES5qfw2kqM33rZkCGDx1pBfX6dFXDXobpDTSbeo0K6S2F2obDb/bCv+NOBIigYy8CLgtE34dO4FVwWd/Q/Wmc+j2hdGCDFp/OZWgAzWqDHp7qYlXXvaBeBPrJYd+mdyQjrJ+4+DzJfBPDYKo91Uw9wz5vwADAFVdqz1vyN8hAAAAAElFTkSuQmCC";
- this._image_h_l_r = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAAgCAYAAABkS8DlAAABIklEQVR4nO3WbQuCMBiG0dn//80tiAp6WT4zi+A+54vTTdMKuZZ20Y/H2/is9/r+aFxdNz5/qa7t1/Gr+dlj79ZX5mrnvz93p+3T9zKznbnnynW/OPfwnLXP/v2xqXvolXv8dH7Ld7Vhvs+cf/2v/d/vd3dfq8/0zbm1a1d/18L2o3fIzHbtnVi51p5zK8f6q3Xj8cza8XjrusH+oQEAcQQAAAQSAAAQSAAAQCABAACBBAAABBIAABBIAABAIAEAAIEEAAAEEgAAEEgAAEAgAQAAgQQAAAQSAAAQSAAAQCABAACBBAAABBIAABBIAABAIAEAAIEEAAAEEgAAEEgAAEAgAQAAgQQAAAQSAAAQSAAAQCABAACBBAAABBIAAJCmtXYCutDwWwUr9cEAAAAASUVORK5CYII=";
- this._image_h_r_l = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAAgCAYAAABkS8DlAAAAAXNSR0IArs4c6QAAAFBlWElmTU0AKgAAAAgAAgESAAMAAAABAAEAAIdpAAQAAAABAAAAJgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAACAKADAAQAAAABAAAAIAAAAACVLBWUAAABWWlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iWE1QIENvcmUgNi4wLjAiPgogICA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPgogICAgICA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIgogICAgICAgICAgICB4bWxuczp0aWZmPSJodHRwOi8vbnMuYWRvYmUuY29tL3RpZmYvMS4wLyI+CiAgICAgICAgIDx0aWZmOk9yaWVudGF0aW9uPjE8L3RpZmY6T3JpZW50YXRpb24+CiAgICAgIDwvcmRmOkRlc2NyaXB0aW9uPgogICA8L3JkZjpSREY+CjwveDp4bXBtZXRhPgoZXuEHAAAC90lEQVR4Ae3WzVbbMBAG0PzBgcOa93/M7nCj2F8zUUILdDmXjWTNSLauBMz+19vbstvvl139+c5zza39sd7hUNe99mveZ/3dbs3/LF7W3j/IXbZ5hzI/Yzf7TXxux/fPY3n+W+wrOfP3Zs5P26wXk22d/bzenJf8jNf82h/73XLOh7KeS51b++fEw/R8uQfzetvzsubmbtyuPXLmteo6W/9Qv2lZ7te4fde6l6xT52Ysbf22jK3t+o7j8frdt/H1HTWe96RdY+v8OnfrX84u45kznrPm6Cde2/THnPRrW/vjK+e8OT6e61j6OZcaH/ZbfDvXy+/Qsc5Jv55TxtKOWNY/t39+bx/NSV6dk3VGrM4Zu/2fsbFW/Ou69RvGO2rOFlvq2Pwdc2w8Z/0tdpqeL/HTab0/iaWd1xt5iaWd587PyXt6evyOOT939LP8jCcv66d9fn78nsSH2cvLv3OS//p6mzvmJza3Izb+D64/ae/zR/zR3IyN+MfH/fz39+tY9j9yv9//6pw57+45/xvOfzv9ECBAgAABAt0EFADdTtx+CRAgQIDAWUAB4BoQIECAAIGGAgqAhoduywQIECBAQAHgDhAgQIAAgYYCCoCGh27LBAgQIEBAAeAOECBAgACBhgIKgIaHbssECBAgQEAB4A4QIECAAIGGAgqAhoduywQIECBAQAHgDhAgQIAAgYYCCoCGh27LBAgQIEBAAeAOECBAgACBhgIKgIaHbssECBAgQEAB4A4QIECAAIGGAgqAhoduywQIECBAQAHgDhAgQIAAgYYCCoCGh27LBAgQIEBAAeAOECBAgACBhgIKgIaHbssECBAgQEAB4A4QIECAAIGGAgqAhoduywQIECBAQAHgDhAgQIAAgYYCCoCGh27LBAgQIEBAAeAOECBAgACBhgIKgIaHbssECBAgQEAB4A4QIECAAIGGAgqAhoduywQIECBAQAHgDhAgQIAAgYYCCoCGh27LBAgQIEBAAeAOECBAgACBhgK/AX08dE/3SOoSAAAAAElFTkSuQmCC";
- this._image_v_b_t = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAAgCAYAAABkS8DlAAADcklEQVR4nO3di27bMAyFYdpWLuv2/o+aJfFFgxOp5VjKdjDM6rD/A4KkbZyhwIBzTMluE/s+CAAA+J/EIH1/SL9ws/KLR/5rAADwZb2S4zHIMBzVN9YOzh8QN74XAAD8HTmLt2Z3Ns3PId7vR/MB9oPihtcAAGBfOq9Lr3WOR/0Icrt5BaAxb14rAwAA4OsUAC/HPxWAk4i0hSmAF/iT8zMAALCvnNXtQiHwwn/O8WkuAGdTALy1hFhoEQAAoA5ver+W4aoAXK8UAAAA/j1/UgDGED8mAHYZQB/ofYBQAgAAqMIL/qXN/L+F/6MAyPX6TUS6lQLgPYQCAABAFaUCsJbjY3oMQS4XXQDaFwoAywAAANRRCv6lApDP/odHAYi3Wy4A3YYCMFEAAACozgv9tUn+qApAnycA4cUCMFEAAACoxgv+LQVgSI8Q5OdPWwDawoE2/CcKAAAAVZTC3zuRn5wC0M0F4LuIHJx9AHb3/2TCnwIAAEAdugC0zmtRWW4LwP0xAYjPCcAhTQHswZ9uHOAUAQAAsC971t8WLunXBeD97H9+X14COBT2Adj1flsCKAAAAOzPC35vGcBb/291ATguFIBS8FMAAACoo1QASpP8993/7wUgLQGcUgEICxMAHfojVwIAAFCNLQDdCwUgPDcBXi5vqQAcCgUgOsFv9wIAAID9NE74ezf1swXgnt7X6CWAo7oh0FIBGLkSAACAqvJGPxv+paX8UW8AnH+Q7wR4NhsBvQIwqgnASAEAAKAaO/7fUgB6lfEx3wnwbDYCLhWAkQIAAEBVXgHwbuufc3xQ9/xJBeB6PacCcFooAF74jxQAAACqWAp/fVdfXQD6lO+PE/ggH0sA+koAUQdKOpACAADA1/BKARC1AbDNpSDE5wQgXwrYpQKwNgEYKQAAAFRTKgD27/roCYC+1f84TwDOZg9AMAfa9f+BCQAAAFW16iqAYJ717YBzjg9qiX96/jng2+2Uzv6PqgSUJgCDKQHcDRAAgP3Zs/9gvvY2Abb6ioC5AOTgP5vw17p0QKueKQAAANThFYCgzvytLn2dpwHHEO/3tfCX9P2ggr8zlwICAIB9NGb8vxT8OsePefw/XxIYpO9/mJ3/S/LGgqDW/ikAAADsp9kQ+J45v9/S9+NcALaGv5X/4W77IQAAoLI3EWl/AQ/TsX9wLtbWAAAAAElFTkSuQmCC";
- this._image_v_t_b = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAAgCAYAAABkS8DlAAAAAXNSR0IArs4c6QAAAFBlWElmTU0AKgAAAAgAAgESAAMAAAABAAEAAIdpAAQAAAABAAAAJgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAACAKADAAQAAAABAAAAIAAAAACVLBWUAAABWWlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iWE1QIENvcmUgNi4wLjAiPgogICA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPgogICAgICA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIgogICAgICAgICAgICB4bWxuczp0aWZmPSJodHRwOi8vbnMuYWRvYmUuY29tL3RpZmYvMS4wLyI+CiAgICAgICAgIDx0aWZmOk9yaWVudGF0aW9uPjE8L3RpZmY6T3JpZW50YXRpb24+CiAgICAgIDwvcmRmOkRlc2NyaXB0aW9uPgogICA8L3JkZjpSREY+CjwveDp4bXBtZXRhPgoZXuEHAAAHhUlEQVR4Ae2d2W7bSBREucmy7IcA+f+fnAePtXCZqr68IhVLSGLATIA5DbS72QspHT9U9UbV79++vVdV9axIgAAEIAABCEDgf0Kgq3a7f/RdR8WXT37nSf0yfvIWdIMABCAAAQhA4DcJNHP7+jf7uXlvA/CmTHb2TEDe0A3uhRT7XpWOg+JU1bXLCRCAAAQgAAEIbEFgmqzXjq1iN+d/ruF13dfT9NbVT08XdXI8zZ33StMQKHsN94R/UMNBFZ5BIEAAAhCAAAQgsBEB6W8j/U0T4MF4GgGnj3TcA/ej4rmr9vuzM4rpHpQteXfOG1j8ffOMvSos/CWqHAMgCAQIQAACEIDAVgRW4m8TYB1uNRs/VtNkA5AmYK3jFv+zCs7qe+6m/f6ki92qsW+SZsAdLf6OLrcBKNP+Kuj1oEEPyjpVESAAAQhAAAIQ2IhALR1uZsH3TH4n0W4lymkAbAys4w7W8F5t+6muPeg/dbUMgAp25SYh9BZ5G4BavUpH3cwd0wBY9Ici/mEI7DZcR4AABCAAAQhAYCsCtWX6ugfAot9rTO5ZgDQAax33YN0GwPrtJf9j18gAyA3kVEGO5m0AHIoB0J8QeU8thOjnUoDTNAduT4AABCAAAQhAYAsC0xQzADHi92g/xD+WAH7UcQ3xp75qGpuAMADT4XDUbsBaJqCeR/Ke4i8zAEqLAVCaIn9rAGIJYJTjcDkBAhCAAAQgAIGNCEi2lxmAZSkgR/85sE8d9wA/l/FPujh6E+BRmUYi3tSNNhTaIaQBsLtw8BG/2FhwHfmrj5cCxkblaoQBKKD4AwEIQAACENiIQAzcGwlwGf3rsq3GMZcAYv1/reOzAZB+n1UpA/Dy4uMAthFW+0E32in94BzUwSI/qFNJnVcc53KXESAAAQhAAAIQ2I6A5Lpq9MfRum0zUGYAXKZr1zs6eMe+Ndyn+C7KH7v6+fmoYo3xPZxvBqVlF6HLZAuio+rKDIA6W/B1A5//TyOgonJKoDyBPxCAAAQgAAEIbELAS/eN9NknAWppeCsNb10m+S5lNzpuDdfSvTS8HP/vqsPhXY2t4EXY9ZG9/u8phFqL+8UA6E7aJFDW+Yvou63arDcA2gQQIAABCEAAAhDYjoA12iP9YgK0lu+0GIC57J6O9xLsi3T/1E0vL+8e/auxR/flHKHyZQlAdy4GQOWut+hnXIu/y1xPgAAEIAABCEBgOwIxUz9q/C7h1+g+zEBcF3NwR8fLuwDU/tQ1h8O/cgLe0NdrE6BfCNQpbwdxuwRg8W+8vHA1Abn730cEMQDb/cN5EgQgAAEIQCAJlNG/hD7Ef53e03Gf3ov3BehVwN4DMIu6VDxmAGQAtALgtYUyAyCnYIVPob8xAaWvTwkQIAABCEAAAhDYmkARfonwYgBm4S+m4KOOFwMgXb/EEsA4xuheGwD1yTtVWNFjA4G/ii9jlL+IfxwLtPCPpd7tCBCAAAQgAAEIbEkgtNrr/2kCmqaUze/3uQ7kVT/qmKB13C8EunRtnAKwiNsVxAZAO4b5BldxTwOwFv6cFfD7AwgQgAAEIAABCGxLYPSreDRgT81OI+BZfEeHmBGYZvH3gN96X2YAvAegV7uz0usJAFXaTSwhDYDTtQmIlwdhABZS5CAAAQhAAALbELDIW/Rz4G5DkGYgDcDySXIGwL8H0PsYoN8DMEjXPfUf7wBwp3AVS7dZ6DWlEHsBMg1DgAFYSJGDAAQgAAEIbEMgRvf5PoCSSsLzdEDMAOQnkY5PsQQwGwAdA5TY+6d9y+hfSh5vAfzROcQMwDL693WO/qMuH0EKAQhAAAIQgMAWBNZi77xmA8rav4/x39PxeKePlwCGbtrtjmqT7//3C4CaMvq/19GC7zP/FnwMwBb/Wp4BAQhAAAIQeEzAWu3oWfvMW/zzet0zdPu6DNB1r69HqX+e/S9vANQ97joH9Q3hb9vFBPjmLidAAAIQgAAEILAtAeu1Q+r2oDf1W8QVStn601jEFTR7P1bDMJQfA+r860F++Y83DrhT39feFbju17mTQ9ct4p9lma47kIcABCAAAQhA4GsJpFan4M8a7ofe1XFruPcBKHZV256qp6dWbiDE352fnrQb8NYAlG9goc/oAud9MwIEIAABCEAAAn+GgAbt19H+rOG+9sa+m5D67bRtZQBeX09l5H+5LAbAN/hVA+A9AQQIQAACEIAABP4MgU4H+FKzU7/zev2J1gZAmwE7jfaP89T/YgC8gcAhb+BOS4h8HCWo1H9dt7QiBwEIQAACEIDA1xM4n0OzvYwfYVnC/6jjMZO/28kANM1ZsdZvAoSDyMaR5k2iQ36NtSFY57OeFAIQgAAEIACBbQgcDqnVy8DdT36k4/NMQFd9/352s+rt7Z4BWD78Wugf5ZfW5CAAAQhAAAIQ2IJADtz9rEd516V2Xw3A6WQDUFX7fU4d3N6gVN75M9/g5mF3mlEEAQhAAAIQgMAXErAeW/jX4v/ocWkCVK/f+Z2ena7arvOr4muWNf8rCjIQgAAEIACBv47AL+m4TwlcFH/W+K/7dnwgCEAAAhCAAAQ+T+A/hVJn6rP9qnIAAAAASUVORK5CYII=";
- this._sketchTempPoints = [];
- this._sketchPoints = [];
- this._sketchOutputPoints = [];
- this._sketchWallHeights = [];
- this._drawEntity = void 0;
- this._lineLabel = void 0;
- this._polygonLabel = void 0;
- if (options2 && options2.isDrawPoint)
- this._isDrawPoint = options2.isDrawPoint;
- else
- this._isDrawPoint = false;
- if (options2 && options2.isRetainDrawPoint)
- this._isRetainDrawPoint = options2.isRetainDrawPoint;
- else
- this._isRetainDrawPoint = false;
- this._param = {
- lineWidth: 3,
- lineColor: "rgba(0,255,0,0.75)",
- outlineWidth: 2,
- outlineColor: "rgba(255,255,255,1)",
- polygonColor: "rgba(0,255,0,0.5)",
- wallHeight: 30,
- power: 0.25,
- odlineHeight: 1e3,
- odlineCount: 50,
- text: "\u91D1\u7530\u4EA7\u4E1A\u96C6\u56E2",
- duration: 1500,
- count: 1,
- direction_h: "horizontal",
- direction_v: "vertical",
- order_add: "+",
- order_minus: "-",
- houseColor: "rgba(0,255,0,0.95)"
- };
- if (options2 && options2.iconType) {
- switch (options2.iconType) {
- case DrawTools.IconType.Normal:
- this._sketchPointImage = this._iconNormal;
- break;
- case DrawTools.IconType.Blue:
- this._sketchPointImage = this._iconBlue;
- break;
- case DrawTools.IconType.Green:
- this._sketchPointImage = this._iconGreen;
- break;
- case DrawTools.IconType.Violet:
- this._sketchPointImage = this._iconViolet;
- break;
- default:
- this._sketchPointImage = this._iconNormal;
- break;
- }
- } else {
- this._sketchPointImage = this._iconNormal;
- }
- this._canvasWidth = this._viewer.scene.canvas.width;
- this._canvasHeight = this._viewer.scene.canvas.height;
- if (this._isRuntimeApp()) {
- this._viewer._cesiumWidget._supportsImageRenderingPixelated = Cesium.FeatureDetection.supportsImageRenderingPixelated();
- this._viewer._cesiumWidget._forceResize = true;
- if (Cesium.FeatureDetection.supportsImageRenderingPixelated()) {
- this._viewer.resolutionScale = 2.6;
- }
- }
- }
- _arcToDegree(arc) {
- return arc / Math.PI * 180;
- }
- _toColor(red, green, blue, alpha) {
- let normalColor = new Cesium.Color(0, 0, 0, 1);
- if (typeof red != "number")
- return normalColor;
- if (typeof green != "number")
- return normalColor;
- if (typeof blue != "number")
- return normalColor;
- if (typeof alpha != "number")
- return normalColor;
- if (red < 0 || red > 255 || green < 0 || green > 255 || blue < 0 || blue > 255 || alpha < 0 || alpha > 1)
- return normalColor;
- return new Cesium.Color(red / 255, green / 255, blue / 255, alpha);
- }
- _toColorFromArray(array) {
- if (!array || array.length === void 0 || array.length === 0)
- return new Cesium.Color(255 / 255, 255 / 255, 255 / 255, 1);
- let r2 = 255, g = 255, b = 255, a = 1;
- if (array.length === 1) {
- r2 = parseInt(array[0]);
- } else if (array.length === 2) {
- r2 = parseInt(array[0]);
- g = parseInt(array[1]);
- } else if (array.length === 3) {
- r2 = parseInt(array[0]);
- g = parseInt(array[1]);
- b = parseInt(array[2]);
- } else if (array.length >= 4) {
- r2 = parseInt(array[0]);
- g = parseInt(array[1]);
- b = parseInt(array[2]);
- a = parseFloat(array[3]);
- }
- return new Cesium.Color(r2 / 255, g / 255, b / 255, a);
- }
- _updateScene() {
- this._viewer.scene.requestRender();
- }
- _getScreenClickPosition(screenPosition) {
- let resCartesian = void 0;
- let ray = this._viewer.scene.camera.getPickRay(screenPosition);
- let position2 = this._viewer.scene.globe.pick(ray, this._viewer.scene);
- Cesium.Ellipsoid.WGS84.cartesianToCartographic(position2);
- if (Cesium.defined(position2)) {
- resCartesian = {
- x: position2.x,
- y: position2.y,
- z: position2.z
- };
- }
- return resCartesian;
- }
- _getScreenClickPositionAndHeight(screenPoint) {
- var lng = void 0, lat = void 0, height2 = void 0;
- var ray = this._viewer.scene.camera.getPickRay(screenPoint);
- var position2 = this._viewer.scene.globe.pick(ray, this._viewer.scene);
- var cartographic = Cesium.Ellipsoid.WGS84.cartesianToCartographic(position2);
- cartographic = Cesium.Cartographic.fromCartesian(position2);
- var feature2 = this._viewer.scene.pick(screenPoint);
- if (feature2 === void 0 && Cesium.defined(cartographic)) {
- lng = this._arcToDegree(cartographic.longitude);
- lat = this._arcToDegree(cartographic.latitude);
- height2 = cartographic.height;
- } else {
- var cartesian = this._viewer.scene.pickPosition(screenPoint);
- if (Cesium.defined(cartesian)) {
- var cartographic = Cesium.Cartographic.fromCartesian(cartesian);
- if (Cesium.defined(cartographic)) {
- lng = this._arcToDegree(cartographic.longitude);
- lat = this._arcToDegree(cartographic.latitude);
- height2 = cartographic.height;
- }
- }
- }
- return {
- lng,
- lat,
- height: height2
- };
- }
- _transfromFromScreenPoint(screenPosition) {
- let location = this._getScreenClickPositionAndHeight(screenPosition);
- if (location.lng != void 0) {
- var cartesian = Cesium.Cartesian3.fromDegrees(location.lng, location.lat, location.height);
- return {
- gLocation: location,
- sLocation: cartesian
- };
- } else {
- return {
- gLocation: void 0,
- sLocation: void 0
- };
- }
- }
- _removeEntityByName(entityName) {
- var entities2 = this._entities;
- if (!entities2 || !entities2.values)
- return;
- var delEntitys = [];
- for (var i2 = 0; i2 < entities2.values.length; i2++) {
- if (entities2.values[i2].name == entityName) {
- delEntitys.push(entities2.values[i2]);
- }
- }
- for (var i2 = 0; i2 < delEntitys.length; i2++) {
- entities2.remove(delEntitys[i2]);
- }
- this._updateScene();
- }
- _removeEntityByObject(objEntity) {
- if (!Cesium.defined(objEntity))
- return;
- this._entities.remove(objEntity);
- }
- _createPoint(coord, label2) {
- let _self = this;
- let entity = new Cesium.Entity({
- name: _self._sketchEntityName + "_Point",
- position: coord,
- billboard: {
- image: _self._sketchPointImage,
- horizontalOrigin: Cesium.HorizontalOrigin.center,
- verticalOrigin: Cesium.VerticalOrigin.bottom,
- scale: 0.5,
- pixelOffset: new Cesium.Cartesian2(0, -11),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- }
- });
- if (label2) {
- entity.label = {
- text: label2,
- font: "12px sans-serif",
- fillColor: this._toColor(255, 255, 255, 1),
- outlineColor: this._toColor(0, 154, 94, 1),
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- outlineWidth: 1,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- pixelOffset: new Cesium.Cartesian2(0, -28),
- showBackground: true,
- backgroundColor: this._toColor(0, 0, 0, 0.6),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- };
- }
- this._entities.add(entity);
- this._pointEntitys.push(entity);
- this._updateScene();
- }
- _removePointEntitys() {
- this._removeEntityByName(this._sketchEntityName + "_Point");
- this._pointEntitys = [];
- }
- _callUpdaeEllipseCenterPosition() {
- let _self = this;
- return function() {
- let point1cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[0]);
- let point2cartographic = Cesium.Cartographic.fromCartesian(_self._sketchTempPoints[1]);
- _self._sketchEllipseCenterPosition = Cesium.Cartesian3.fromDegrees(
- Cesium.Math.toDegrees(
- point1cartographic.longitude
- ),
- Cesium.Math.toDegrees(point1cartographic.latitude),
- point2cartographic.height
- );
- return _self._sketchEllipseCenterPosition;
- };
- }
- _callUpdateEllipseMinorAxis(positions) {
- let _self = this;
- return function() {
- if (positions === void 0 || positions.length === void 0 || positions.length < 2) {
- _self._sketchEllipseRadius = 0;
- } else {
- _self._sketchEllipseRadius = _self._calculateEllipseMinorAxis(positions[0], positions[1]);
- if (_self._sketchEllipseRadius <= 0)
- _self._sketchEllipseRadius = 1;
- }
- return _self._sketchEllipseRadius;
- };
- }
- _calculateEllipseMinorAxis(position1, position2) {
- let point1cartographic = Cesium.Cartographic.fromCartesian(position1);
- let point2cartographic = Cesium.Cartographic.fromCartesian(position2);
- let geodesic = new Cesium.EllipsoidGeodesic();
- geodesic.setEndPoints(point1cartographic, point2cartographic);
- return geodesic.surfaceDistance;
- }
- _calculateEllipseOutlineCoordinate(position1, position2) {
- let positionCenter = position1;
- let positionRotate = position2;
- let ellipseOutlineCoordinates = [];
- for (let angle = 5; angle < 360; ) {
- let newPosition = this._rotatedPointByAngle(positionRotate, positionCenter, angle);
- ellipseOutlineCoordinates.push(newPosition);
- angle = angle + 5;
- }
- ellipseOutlineCoordinates.push(ellipseOutlineCoordinates[0]);
- return ellipseOutlineCoordinates;
- }
- _callEllipseOutlineCoordinate(positions) {
- let _self = this;
- return function() {
- _self._ellipseOutlineCoordinates = _self._calculateEllipseOutlineCoordinate(positions[0], positions[1]);
- return _self._ellipseOutlineCoordinates;
- };
- }
- _rotatedPointByAngle(position_A, position_B, angle) {
- var localToWorld_Matrix = Cesium.Transforms.eastNorthUpToFixedFrame(position_B);
- var worldToLocal_Matrix = Cesium.Matrix4.inverse(localToWorld_Matrix, new Cesium.Matrix4());
- Cesium.Matrix4.multiplyByPoint(worldToLocal_Matrix, position_B, new Cesium.Cartesian3());
- var localPosition_A = Cesium.Matrix4.multiplyByPoint(worldToLocal_Matrix, position_A, new Cesium.Cartesian3());
- var new_x = localPosition_A.x * Math.cos(Cesium.Math.toRadians(angle)) + localPosition_A.y * Math.sin(Cesium.Math.toRadians(angle));
- var new_y = localPosition_A.y * Math.cos(Cesium.Math.toRadians(angle)) - localPosition_A.x * Math.sin(Cesium.Math.toRadians(angle));
- var new_z = localPosition_A.z;
- return Cesium.Matrix4.multiplyByPoint(
- localToWorld_Matrix,
- new Cesium.Cartesian3(new_x, new_y, new_z),
- new Cesium.Cartesian3()
- );
- }
- _callUpdateRectangleCoordinates(positions) {
- let _self = this;
- return function() {
- let g0 = Cesium.Ellipsoid.WGS84.cartesianToCartographic(positions[0]);
- let g1 = Cesium.Ellipsoid.WGS84.cartesianToCartographic(positions[1]);
- let lng0 = Cesium.Math.toDegrees(g0.longitude);
- let lat0 = Cesium.Math.toDegrees(g0.latitude);
- let lng1 = Cesium.Math.toDegrees(g1.longitude);
- let lat1 = Cesium.Math.toDegrees(g1.latitude);
- _self._rectangleCoordinates = [0, 0, 1, 1];
- if (lng0 < lng1) {
- _self._rectangleCoordinates[0] = lng0;
- _self._rectangleCoordinates[2] = lng1;
- } else {
- _self._rectangleCoordinates[0] = lng1;
- _self._rectangleCoordinates[2] = lng0;
- }
- if (lat0 < lat1) {
- _self._rectangleCoordinates[1] = lat0;
- _self._rectangleCoordinates[3] = lat1;
- } else {
- _self._rectangleCoordinates[1] = lat1;
- _self._rectangleCoordinates[3] = lat0;
- }
- let rectangle = Cesium.Rectangle.fromDegrees(
- _self._rectangleCoordinates[0],
- _self._rectangleCoordinates[1],
- _self._rectangleCoordinates[2],
- _self._rectangleCoordinates[3]
- );
- let res = _self._calculateRectangleOutlineCoordinates(rectangle);
- _self._rectangleOutlineCoordinates = res.cPoints;
- _self._sketchOutputPoints = res.gPoints;
- return rectangle;
- };
- }
- _calculateRectangleOutlineCoordinates(rectangle) {
- let south_east = Cesium.Rectangle.southeast(rectangle);
- let se2 = Cesium.Cartographic.toCartesian(south_east);
- let south_west = Cesium.Rectangle.southwest(rectangle);
- let sw = Cesium.Cartographic.toCartesian(south_west);
- let north_east = Cesium.Rectangle.northeast(rectangle);
- let ne2 = Cesium.Cartographic.toCartesian(north_east);
- let north_west = Cesium.Rectangle.northwest(rectangle);
- let nw = Cesium.Cartographic.toCartesian(north_west);
- let gPoints = [];
- gPoints.push({
- lng: Cesium.Math.toDegrees(south_west.longitude),
- lat: Cesium.Math.toDegrees(south_west.latitude),
- height: south_west.height
- });
- gPoints.push({
- lng: Cesium.Math.toDegrees(south_east.longitude),
- lat: Cesium.Math.toDegrees(south_east.latitude),
- height: south_east.height
- });
- gPoints.push({
- lng: Cesium.Math.toDegrees(north_east.longitude),
- lat: Cesium.Math.toDegrees(north_east.latitude),
- height: north_east.height
- });
- gPoints.push({
- lng: Cesium.Math.toDegrees(north_west.longitude),
- lat: Cesium.Math.toDegrees(north_west.latitude),
- height: north_west.height
- });
- gPoints.push({
- lng: Cesium.Math.toDegrees(south_west.longitude),
- lat: Cesium.Math.toDegrees(south_west.latitude),
- height: south_west.height
- });
- return {
- cPoints: [sw, se2, ne2, nw, sw],
- gPoints
- };
- }
- _callUpdateRectangleOutlineCoordinates() {
- let _self = this;
- return function() {
- return _self._rectangleOutlineCoordinates;
- };
- }
- _materialTextImageProperty(options2) {
- this._canvasId = "canvasJt";
- let canvasObj = document.getElementById(this._canvasId);
- if (canvasObj != null) {
- document.body.removeChild(canvasObj);
- }
- canvasObj = document.createElement("canvas");
- canvasObj.id = this._canvasId;
- canvasObj.setAttribute("width", "1024px");
- canvasObj.setAttribute("height", "256px");
- document.body.appendChild(canvasObj);
- let context = canvasObj.getContext("2d");
- context.fillStyle = options2.color === void 0 ? "rgba(255,0,0,1)" : options2.color;
- context.font = "bold 240px \u5FAE\u8F6F\u96C5\u9ED1";
- context.textAlign = "left";
- context.textBaseline = "bottom";
- context.fillText(options2.text, 12, 250, 1e3);
- let textMaterial = new Cesium.ImageMaterialProperty({
- image: canvasObj,
- transparent: true
- });
- textMaterial._param = {
- color: context.fillStyle,
- text: options2.text
- };
- return textMaterial;
- }
- _materialColorProperty(options2) {
- let mColor = "rgba(0,255,0,1)";
- if (options2 !== void 0 && options2.color !== void 0)
- mColor = options2.color;
- let colorMaterial = new Cesium.ColorMaterialProperty(Cesium.Color.fromCssColorString(mColor));
- colorMaterial._param = {
- color: mColor
- };
- return colorMaterial;
- }
- _materialPolylineArrowProperty(options2) {
- let mColor = "rgba(0,255,0,1)";
- if (options2 !== void 0 && options2.color !== void 0)
- mColor = options2.color;
- let colorMaterial = new Cesium.PolylineArrowMaterialProperty(Cesium.Color.fromCssColorString(mColor));
- colorMaterial._param = {
- color: mColor
- };
- return colorMaterial;
- }
- _materialPolylineGlowProperty(options2) {
- let mColor = "rgba(0,255,0,1)";
- if (options2 !== void 0 && options2.color !== void 0)
- mColor = options2.color;
- let power = 0.25;
- if (options2 !== void 0 && options2.power !== void 0 && typeof options2.power === "number")
- power = options2.power;
- let colorMaterial = new Cesium.PolylineGlowMaterialProperty({
- color: Cesium.Color.fromCssColorString(mColor),
- glowPower: power
- });
- colorMaterial._param = {
- color: mColor,
- power
- };
- return colorMaterial;
- }
- _materialPolylineOutlineProperty(options2) {
- let mColor = "rgba(0,255,0,1)";
- let outlineColor = "rgba(255,255,255,1.0)";
- let outlineWidth = 1.2;
- if (options2 !== void 0 && options2.color !== void 0)
- mColor = options2.color;
- if (options2 !== void 0 && options2.outlineColor !== void 0)
- outlineColor = options2.outlineColor;
- if (options2 !== void 0 && options2.outlineWidth !== void 0 && typeof options2.outlineWidth === "number")
- outlineWidth = options2.outlineWidth;
- let colorMaterial = new Cesium.PolylineOutlineMaterialProperty({
- color: Cesium.Color.fromCssColorString(mColor),
- outlineColor: Cesium.Color.fromCssColorString(outlineColor),
- outlineWidth
- });
- colorMaterial._param = {
- color: mColor,
- outlineColor,
- outlineWidth
- };
- return colorMaterial;
- }
- _clear(isAll) {
- if (isAll != void 0 && isAll === true) {
- this._removeEntityByName(this._sketchEntityName);
- this._removePointEntitys();
- }
- this._sketchTempPoints = [];
- this._sketchPoints = [];
- this._sketchOutputPoints = [];
- this._sketchWallHeights = [];
- this._drawEntity = void 0;
- this._removeOperationDom();
- this._tooltipRemove();
- if (this._drawEventHandler !== null && this._drawEventHandler !== void 0 && this._drawEventHandler.isDestroyed() === false) {
- this._clearEvent(this._drawEventHandler);
- }
- }
- }
- Object.assign(DrawTools.prototype, {
- setLabel: function(options2) {
- if (!options2) {
- options2 = {
- lineLabel: void 0,
- polygonLabel: void 0
- };
- }
- if (options2.lineLabel)
- this._lineLabel = options2.lineLabel;
- if (options2.polygonLabel)
- this._lineLabel = options2.polygonLabel;
- }
- });
- Object.assign(DrawTools.prototype, {
- _registerLeftClickEvent: function(handler, callChange) {
- let _self = this;
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- _self._lock = true;
- clearTimeout(_self._timer);
- _self._timer = setTimeout(function() {
- if (callChange)
- callChange(event2);
- _self._lock = false;
- }, 200);
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- },
- _registerLeftDoubleClickEvent: function(handler, callChange) {
- let _self = this;
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- clearTimeout(_self._timer);
- _self._lock = false;
- if (callChange)
- callChange(event2);
- }, Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
- },
- _registerMouseMoveEvent: function(handler, callChange) {
- let _self = this;
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (_self._lock === void 0 || _self._lock === false) {
- if (callChange)
- callChange(event2);
- }
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- },
- _registerRightClickEvent: function(handler, callChange) {
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (callChange)
- callChange(event2);
- }, Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- },
- _registerLeftDownEvent: function(handler, callChange) {
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (callChange)
- callChange(event2);
- }, Cesium.ScreenSpaceEventType.LEFT_DOWN);
- },
- _registerLeftUpEvent: function(handler, callChange) {
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (callChange)
- callChange(event2);
- }, Cesium.ScreenSpaceEventType.LEFT_UP);
- },
- _clearEvent: function(handler) {
- this._endTooltip();
- this._removeOperationDom();
- if (!handler)
- return;
- handler.destroy();
- handler = null;
- }
- });
- Object.assign(DrawTools.prototype, {
- _createPolyline: function(polylineType) {
- let _self = this;
- let entityParam = DrawTools.initEditPropertyParams();
- let polylineWidth = _self._param.lineWidth;
- let polylineMaterial = this._materialColorProperty({
- color: _self._param.lineColor
- });
- entityParam.id = DrawTools.DrawType.Polyline;
- if (polylineType !== void 0 && polylineType === DrawTools.PolylineType.ArrowsPolyline) {
- polylineMaterial = this._materialPolylineArrowProperty({
- color: _self._param.lineColor
- });
- polylineWidth = _self._param.lineWidth * 3;
- entityParam.color = _self._param.lineColor;
- entityParam.id = DrawTools.DrawType.ArrowPolyline;
- } else if (polylineType !== void 0 && polylineType === DrawTools.PolylineType.GrowPolyline) {
- polylineMaterial = this._materialPolylineGlowProperty({
- color: _self._param.lineColor,
- power: _self._param.power
- });
- polylineWidth = _self._param.lineWidth * 3;
- entityParam.color = _self._param.lineColor;
- entityParam.power = _self._param.power;
- entityParam.id = DrawTools.DrawType.GrowPolyline;
- } else if (polylineType !== void 0 && polylineType === DrawTools.PolylineType.OutlinePolyline) {
- polylineMaterial = this._materialPolylineOutlineProperty({
- color: _self._param.lineColor,
- outlineColor: _self._param.outlineColor,
- outlineWidth: _self._param.outlineWidth
- });
- polylineWidth = _self._param.lineWidth * 2;
- entityParam.color = _self._param.lineColor;
- entityParam.outlineColor = _self._param.outlineColor;
- entityParam.outlineWidth = _self._param.outlineWidth;
- entityParam.id = DrawTools.DrawType.OutlinePolyline;
- } else if (polylineType !== void 0 && polylineType === DrawTools.PolylineType.DynamicPolyline) {
- polylineMaterial = new WallMaterialProperty({
- viewer: _self._viewer,
- trailImage: _self._image_h_l_r,
- duration: _self._param.duration,
- color: Cesium.Color.fromCssColorString(_self._param.lineColor),
- param: {
- direction: _self._param.direction_h,
- count: _self._param.count,
- order: _self._param.order_minus
- }
- });
- polylineWidth = _self._param.lineWidth;
- entityParam.color = _self._param.lineColor;
- entityParam.duration = _self._param.duration;
- entityParam.direction = _self._param.direction_h;
- entityParam.count = _self._param.count;
- entityParam.order = _self._param.order_minus;
- entityParam.id = DrawTools.DrawType.DynamicPolyline;
- }
- entityParam.lineWidth = polylineWidth;
- let entityPolyline = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(function() {
- return _self._sketchTempPoints;
- }, false),
- material: polylineMaterial,
- width: polylineWidth,
- clampToGround: true
- }
- });
- this._drawEntity = this._entities.add(entityPolyline);
- this._drawEntity.setParams(entityParam);
- },
- _updatePolyline: function(isEdit) {
- this._drawEntity.polyline.positions = this._sketchPoints;
- this._drawEntity.setEntityType(DrawTools.DrawType.Polyline);
- if (isEdit != void 0 && isEdit === true) {
- this._removePointEntitys();
- this._setEntityIsEdit(this._drawEntity);
- }
- },
- _createSpatialPolyline: function() {
- let _self = this;
- let entityParam = DrawTools.initEditPropertyParams();
- let lineMaterial = this._materialColorProperty({
- color: _self._param.lineColor
- });
- entityParam.id = DrawTools.DrawType.SpatialLine;
- entityParam.color = _self._param.lineColor;
- entityParam.lineWidth = _self._param.lineWidth;
- let entity = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(function() {
- return _self._sketchTempPoints;
- }, false),
- material: lineMaterial,
- width: _self._param.lineWidth,
- clampToGround: false
- }
- });
- this._drawEntity = this._entities.add(entity);
- this._drawEntity.setParams(entityParam);
- },
- _updateSpatialPolyline: function(isEdit) {
- this._drawEntity.polyline.positions = this._sketchPoints;
- this._drawEntity.setEntityType(DrawTools.DrawType.SpatialLine);
- if (isEdit != void 0 && isEdit === true) {
- this._removePointEntitys();
- this._setEntityIsEdit(this._drawEntity);
- }
- },
- _createPolygon: function(polygonType) {
- let _self = this;
- let entityParam = DrawTools.initEditPropertyParams();
- let polygonMaterial = this._materialColorProperty({
- color: _self._param.polygonColor
- });
- let lineMaterial = this._materialColorProperty({
- color: _self._param.outlineColor
- });
- let entityPolygon = new Cesium.Entity({
- name: _self._sketchEntityName,
- polygon: {
- show: true,
- hierarchy: new Cesium.CallbackProperty(function() {
- return {
- positions: _self._sketchTempPoints
- };
- }, false),
- material: polygonMaterial,
- classificationType: Cesium.ClassificationType.BOTH
- },
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(function() {
- return _self._sketchTempPoints;
- }, false),
- material: lineMaterial,
- width: _self._param.outlineWidth,
- clampToGround: true
- }
- });
- entityParam.color = _self._param.polygonColor;
- entityParam.outlineColor = _self._param.outlineColor;
- entityParam.outlineWidth = _self._param.outlineWidth;
- this._drawEntity = this._entities.add(entityPolygon);
- if (polygonType !== void 0 && polygonType === DrawTools.PolygonType.NormalPolygon) {
- this._drawEntity.setEntityType(DrawTools.DrawType.Polygon);
- entityParam.id = DrawTools.DrawType.Polygon;
- } else if (polygonType !== void 0 && polygonType === DrawTools.PolygonType.HousePolygon) {
- this._drawEntity.setEntityType(DrawTools.DrawType.House);
- entityParam.id = DrawTools.DrawType.House;
- }
- this._drawEntity.setParams(entityParam);
- },
- _updatePolygon: function(isEdit) {
- let _self = this;
- let houseMaterial = this._materialColorProperty({
- color: _self._param.houseColor
- });
- let entityType = this._drawEntity.getEntityType();
- if (entityType === DrawTools.DrawType.Polygon) {
- this._drawEntity.polygon.hierarchy = {
- positions: _self._sketchPoints
- };
- this._drawEntity.polyline.positions = this._sketchPoints;
- } else if (entityType === DrawTools.DrawType.House) {
- let entityParam = this._drawEntity.getParams();
- this._removeEntityByObject(this._drawEntity);
- let height2 = parseFloat(this._sketchOutputPoints[0].height);
- let houseHeight = height2 + parseInt(_self._param.wallHeight);
- let houseEntity = new Cesium.Entity({
- name: _self._sketchEntityName,
- polygon: {
- show: true,
- hierarchy: {
- positions: _self._sketchPoints
- },
- extrudedHeight: houseHeight,
- material: houseMaterial
- }
- });
- this._drawEntity = this._entities.add(houseEntity);
- this._drawEntity.setEntityType(entityType);
- entityParam.height = _self._param.wallHeight;
- entityParam.bottomHeight = height2;
- entityParam.color = _self._param.houseColor;
- this._drawEntity.setParams(entityParam);
- }
- if (isEdit != void 0 && isEdit === true) {
- this._removePointEntitys();
- this._setEntityIsEdit(this._drawEntity);
- }
- },
- _createRectangle: function() {
- let _self = this;
- let entityParam = DrawTools.initEditPropertyParams();
- let rectMaterial = this._materialColorProperty({
- color: _self._param.polygonColor
- });
- let lineMaterial = this._materialColorProperty({
- color: _self._param.outlineColor
- });
- let entityRectangle = new Cesium.Entity({
- name: _self._sketchEntityName,
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(
- _self._callUpdateRectangleOutlineCoordinates(),
- false
- ),
- material: lineMaterial,
- width: _self._param.outlineWidth,
- clampToGround: true
- },
- rectangle: {
- show: true,
- coordinates: new Cesium.CallbackProperty(
- _self._callUpdateRectangleCoordinates(
- _self._sketchTempPoints
- ),
- false
- ),
- material: rectMaterial,
- classificationType: Cesium.ClassificationType.BOTH
- }
- });
- entityParam.id = DrawTools.DrawType.Rectangle;
- entityParam.color = _self._param.polygonColor;
- entityParam.outlineColor = _self._param.outlineColor;
- entityParam.outlineWidth = _self._param.outlineWidth;
- this._drawEntity = this._entities.add(entityRectangle);
- this._drawEntity.setParams(entityParam);
- },
- _updateRectangle(isEdit) {
- this._drawEntity.polyline.positions = this._rectangleOutlineCoordinates;
- let coordinates = this._rectangleCoordinates;
- this._drawEntity.rectangle.coordinates = Cesium.Rectangle.fromDegrees(coordinates[0], coordinates[1], coordinates[2], coordinates[3]);
- this._drawEntity.setEntityType(DrawTools.DrawType.Rectangle);
- if (isEdit != void 0 && isEdit === true) {
- this._setEntityIsEdit(this._drawEntity);
- }
- },
- _createCircle: function(centerPosition, circleType) {
- let _self = this;
- let entityParam = DrawTools.initEditPropertyParams();
- let circleMaterial = this._materialColorProperty({
- color: _self._param.polygonColor
- });
- let lineMaterial = this._materialColorProperty({
- color: _self._param.outlineColor
- });
- if (circleType != void 0 && circleType === DrawTools.CircleType.DynamicCircle) {
- circleMaterial = new CircleMaterialProperty({
- viewer: _self._viewer,
- duration: _self._param.duration,
- color: Cesium.Color.fromCssColorString(_self._param.polygonColor),
- count: _self._param.count
- });
- }
- this._sketchEllipseCenterPosition = centerPosition.clone();
- let entityCircle = new Cesium.Entity({
- name: _self._sketchEntityName,
- position: centerPosition,
- ellipse: {
- show: true,
- semiMinorAxis: new Cesium.CallbackProperty(_self._callUpdateEllipseMinorAxis(
- _self._sketchTempPoints
- ), false),
- semiMajorAxis: new Cesium.CallbackProperty(_self._callUpdateEllipseMinorAxis(
- _self._sketchTempPoints
- ), false),
- material: circleMaterial,
- classificationType: Cesium.ClassificationType.BOTH
- }
- });
- if (circleType === void 0 || circleType === DrawTools.CircleType.ColorCircle) {
- entityCircle.polyline = {
- show: true,
- positions: new Cesium.CallbackProperty(_self._callEllipseOutlineCoordinate(
- _self._sketchTempPoints
- ), false),
- material: lineMaterial,
- width: _self._param.outlineWidth,
- clampToGround: true
- };
- }
- this._drawEntity = this._entities.add(entityCircle);
- if (circleType === void 0 || circleType === DrawTools.CircleType.ColorCircle) {
- this._drawEntity.setEntityType(DrawTools.DrawType.Circle);
- entityParam.id = DrawTools.DrawType.Circle;
- entityParam.color = _self._param.polygonColor;
- entityParam.outlineColor = _self._param.outlineColor;
- entityParam.outlineWidth = _self._param.outlineWidth;
- } else if (circleType != void 0 && circleType === DrawTools.CircleType.DynamicCircle) {
- this._drawEntity.setEntityType(DrawTools.DrawType.DynamicCircle);
- entityParam.id = DrawTools.DrawType.DynamicCircle;
- entityParam.color = _self._param.polygonColor;
- entityParam.duration = _self._param.duration;
- entityParam.count = _self._param.count;
- }
- this._drawEntity.setParams(entityParam);
- },
- _updateCircle(isEdit) {
- this._drawEntity.position = this._sketchEllipseCenterPosition;
- let center2 = this._sketchTempPoints.first();
- let outpoint = this._sketchTempPoints.last();
- this._ellipseOutlineCoordinates = this._calculateEllipseOutlineCoordinate(center2, outpoint);
- this._sketchEllipseRadius = this._calculateEllipseMinorAxis(center2, outpoint);
- if (this._drawEntity.polyline != void 0) {
- this._drawEntity.polyline.positions = this._ellipseOutlineCoordinates;
- }
- this._drawEntity.ellipse.semiMajorAxis = this._sketchEllipseRadius;
- this._drawEntity.ellipse.semiMinorAxis = this._sketchEllipseRadius;
- if (isEdit != void 0 && isEdit === true) {
- this._setEntityIsEdit(this._drawEntity);
- }
- },
- _createWall: function(wallType) {
- let _self = this;
- let entityParam = DrawTools.initEditPropertyParams();
- let wallMaterial = this._materialColorProperty({
- color: _self._param.polygonColor
- });
- entityParam.color = _self._param.polygonColor;
- if (wallType !== void 0 && wallType === DrawTools.WallType.TextWall) {
- wallMaterial = this._materialTextImageProperty({
- color: _self._param.polygonColor,
- text: _self._param.text
- });
- entityParam.text = _self._param.text;
- entityParam.color = _self._param.polygonColor;
- } else if (wallType !== void 0 && wallType === DrawTools.WallType.DynamicWall) {
- wallMaterial = new WallMaterialProperty({
- viewer: _self._viewer,
- trailImage: _self._image_v_t_b,
- duration: _self._param.duration,
- color: Cesium.Color.fromCssColorString(_self._param.polygonColor),
- param: {
- count: _self._param.count,
- direction: _self._param.direction_v,
- order: _self._param.order_minus
- }
- });
- entityParam.color = _self._param.polygonColor;
- entityParam.duration = _self._param.duration;
- entityParam.direction = _self._param.direction_v;
- entityParam.count = _self._param.count;
- entityParam.order = _self._param.order_minus;
- }
- let normalWall = new Cesium.Entity({
- name: _self._sketchEntityName,
- wall: {
- show: true,
- positions: new Cesium.CallbackProperty(function() {
- return _self._sketchTempPoints;
- }, false),
- minimumHeights: new Cesium.CallbackProperty(function() {
- return _self._sketchWallHeights;
- }, false),
- maximumHeights: new Cesium.CallbackProperty(function() {
- _self._sketchWallMaxHeights = [];
- for (let i2 = 0; i2 < _self._sketchWallHeights.length; i2++) {
- _self._sketchWallMaxHeights.push(_self._sketchWallHeights[i2] + _self._param.wallHeight);
- }
- return _self._sketchWallMaxHeights;
- }, false),
- material: wallMaterial
- }
- });
- this._drawEntity = this._entities.add(normalWall);
- entityParam.height = this._param.wallHeight;
- if (wallType === void 0 || wallType === DrawTools.WallType.ColorWall) {
- this._drawEntity.setEntityType(DrawTools.DrawType.NormalWall);
- entityParam.id = DrawTools.DrawType.NormalWall;
- } else if (wallType !== void 0 && wallType === DrawTools.WallType.DynamicWall) {
- this._drawEntity.setEntityType(DrawTools.DrawType.DynamicWall);
- entityParam.id = DrawTools.DrawType.DynamicWall;
- } else if (wallType !== void 0 && wallType === DrawTools.WallType.TextWall) {
- this._drawEntity.setEntityType(DrawTools.DrawType.TextWall);
- entityParam.id = DrawTools.DrawType.TextWall;
- }
- this._drawEntity.setParams(entityParam);
- },
- _updateWall: function(isEdit) {
- let hLength = this._sketchWallHeights.length;
- let mhLength = this._sketchWallMaxHeights.length;
- let pLength = this._sketchPoints.length;
- if (hLength === mhLength && hLength - pLength === 1) {
- this._sketchWallHeights.pop();
- this._sketchWallMaxHeights.pop();
- this._drawEntity.wall.positions = this._sketchPoints;
- this._drawEntity.wall.minimumHeights = this._sketchWallHeights;
- this._drawEntity.wall.maximumHeights = this._sketchWallMaxHeights;
- if (isEdit != void 0 && isEdit === true) {
- this._removePointEntitys();
- this._setEntityIsEdit(this._drawEntity);
- }
- }
- },
- _createVideoWall: function() {
- let _self = this;
- let entityWall = new Cesium.Entity({
- name: _self._sketchEntityName,
- position: _self._sketchOutputPoints[0],
- wall: {
- show: true,
- positions: new Cesium.CallbackProperty(function() {
- let pt0 = _self._sketchOutputPoints[0];
- let pt1 = _self._sketchOutputPoints[1];
- _self._wallPositions = [];
- _self._wallPositions.push(Cesium.Cartesian3.fromDegrees(
- pt0.lng,
- pt0.lat,
- pt0.height
- ));
- _self._wallPositions.push(Cesium.Cartesian3.fromDegrees(
- pt1.lng,
- pt1.lat,
- pt0.height
- ));
- return _self._wallPositions;
- }, false),
- maximumHeights: new Cesium.CallbackProperty(function() {
- _self._sketchWallHeights = [];
- let pt2 = _self._sketchOutputPoints[0];
- _self._sketchWallHeights.push(pt2.height);
- _self._sketchWallHeights.push(pt2.height);
- return _self._sketchWallHeights;
- }, false),
- minimumHeights: new Cesium.CallbackProperty(function() {
- _self._sketchWallMaxHeights = [];
- let pt2 = _self._sketchOutputPoints[1];
- _self._sketchWallMaxHeights.push(pt2.height);
- _self._sketchWallMaxHeights.push(pt2.height);
- return _self._sketchWallMaxHeights;
- }, false),
- material: Cesium.Color.fromCssColorString(_self._param.polygonColor),
- outline: true,
- outlineColor: Cesium.Color.fromCssColorString(_self._param.outlineColor),
- outlineWidth: _self._param.outlineWidth
- }
- });
- _self._drawEntity = _self._entities.add(entityWall);
- },
- _updateVideoWall: function(isEdit) {
- let entityParam = DrawTools.initEditPropertyParams();
- entityParam.id = DrawTools.DrawType.VideoWall;
- let videoElement = document.getElementById("wallVideo");
- if (videoElement !== null) {
- document.body.removeChild(videoElement);
- }
- videoElement = document.createElement("video");
- videoElement.id = "wallVideo";
- videoElement.setAttribute("crossorigin", "anonymous");
- videoElement.setAttribute("width", "1024px");
- videoElement.setAttribute("height", "256px");
- videoElement.setAttribute("controls", "controls");
- videoElement.setAttribute(
- "src",
- "https://lf3-cdn-tos.bytescm.com/obj/eden-cn/lmeh7pfuho/campus/campus_intro_20200522.mp4"
- );
- videoElement.setAttribute("loop", "loop");
- videoElement.play();
- document.body.appendChild(videoElement);
- this._drawEntity.wall.positions = this._wallPositions;
- this._drawEntity.wall.minimumHeights = this._sketchWallHeights;
- this._drawEntity.wall.maximumHeights = this._sketchWallMaxHeights;
- entityParam.height = this._sketchWallMaxHeights[0] - this._sketchWallHeights[0];
- this._drawEntity.wall.material = videoElement;
- this._removePointEntitys();
- this._drawEntity.setEntityType(DrawTools.DrawType.VideoWall);
- entityParam.videoUrl = "https://lf3-cdn-tos.bytescm.com/obj/eden-cn/lmeh7pfuho/campus/campus_intro_20200522.mp4";
- entityParam.id = DrawTools.DrawType.VideoWall;
- this._drawEntity.setParams(entityParam);
- if (isEdit != void 0 && isEdit === true) {
- this._setEntityIsEdit(this._drawEntity);
- }
- },
- _calculateOdlinePositios: function(strPoint, endPoint, height2, count) {
- let pt1 = this._cartesian3ToGeo(strPoint);
- let pt2 = this._cartesian3ToGeo(endPoint);
- var h2 = height2 && height2 < 1e3 ? height2 : 1e3;
- var L = Math.abs(pt1.longitude - pt2.longitude) > Math.abs(pt1.latitude - pt2.latitude) ? Math.abs(pt1.longitude - pt2.longitude) : Math.abs(pt1.latitude - pt2.latitude);
- var num = count && count > 50 ? count : 50;
- var result = [];
- var tempResult = [];
- var dlt = L / num;
- var addHeight = pt1.height > pt2.height ? pt1.height : pt2.height;
- var maxHeight = addHeight + h2;
- var minHeight1 = pt1.height;
- var minHeight2 = pt2.height;
- if (Math.abs(pt1.longitude - pt2.longitude) > Math.abs(pt1.latitude - pt2.latitude)) {
- var delLat = (pt2.latitude - pt1.latitude) / num;
- if (pt1.longitude - pt2.longitude > 0) {
- dlt = -dlt;
- }
- for (var i2 = 1; i2 < num; i2++) {
- var tempH = h2 - Math.pow(-0.5 * L + Math.abs(dlt) * i2, 2) * 4 * h2 / Math.pow(L, 2);
- var lon = pt1.longitude + dlt * i2;
- var lat = pt1.latitude + delLat * i2;
- var alt = void 0;
- if (Math.abs(dlt) * i2 == 0.5 * L) {
- alt = maxHeight;
- } else if (Math.abs(dlt) * i2 < 0.5 * L) {
- alt = (maxHeight - minHeight1) / h2 * tempH + minHeight1;
- } else {
- alt = (maxHeight - minHeight2) / h2 * tempH + minHeight2;
- }
- tempResult.push([lon, lat, alt]);
- }
- } else {
- var delLon = (pt2.longitude - pt1.longitude) / num;
- if (pt1.latitude - pt2.latitude > 0) {
- dlt = -dlt;
- }
- for (var i2 = 1; i2 < num; i2++) {
- var tempH = h2 - Math.pow(-0.5 * L + Math.abs(dlt) * i2, 2) * 4 * h2 / Math.pow(L, 2);
- var lon = pt1.longitude + delLon * i2;
- var lat = pt1.latitude + dlt * i2;
- var alt = void 0;
- if (Math.abs(dlt) * i2 == 0.5 * L) {
- alt = maxHeight;
- } else if (Math.abs(dlt) * i2 < 0.5 * L) {
- alt = (maxHeight - minHeight1) / h2 * tempH + minHeight1;
- } else {
- alt = (maxHeight - minHeight2) / h2 * tempH + minHeight2;
- }
- tempResult.push([lon, lat, alt]);
- }
- }
- result.push([pt1.longitude, pt1.latitude, pt1.height]);
- for (var i2 = 0; i2 < tempResult.length; i2++) {
- result.push(tempResult[i2]);
- }
- result.push([pt2.longitude, pt2.latitude, pt2.height]);
- let results = [];
- for (let i3 = 0; i3 < result.length; i3++) {
- results.push(Cesium.Cartesian3.fromDegrees(result[i3][0], result[i3][1], result[i3][2]));
- }
- return results;
- },
- _createOdline: function(isFirst) {
- let _self = this;
- if (isFirst !== void 0 && isFirst === true) {
- let fatherEntity = new Cesium.Entity({
- name: this._sketchEntityName
- });
- this._odlineFatherEntity = this._entities.add(fatherEntity);
- let entityParam = DrawTools.initEditPropertyParams();
- entityParam.id = DrawTools.DrawType.OdLine;
- entityParam.color = _self._param.polygonColor;
- entityParam.duration = _self._param.duration;
- entityParam.direction = _self._param.direction_h;
- entityParam.count = _self._param.count;
- entityParam.order = _self._param.order_add;
- entityParam.odlineHeight = _self._param.odlineHeight;
- entityParam.odlineCount = _self._param.odlineCount;
- entityParam.lineWidth = _self._param.lineWidth * 3;
- this._odlineFatherEntity.setParams(entityParam);
- this._odlineEntitys = [];
- }
- let faterParam = this._odlineFatherEntity.getParams();
- let odLineMaterial = new WallMaterialProperty({
- viewer: _self._viewer,
- trailImage: _self._image_arrow_reverse,
- duration: faterParam.duration,
- color: Cesium.Color.fromCssColorString(faterParam.color),
- param: {
- direction: faterParam.direction,
- count: faterParam.count,
- order: faterParam.order
- }
- });
- let entity = new Cesium.Entity({
- name: _self._sketchEntityName,
- parent: this._odlineFatherEntity,
- polyline: {
- show: true,
- positions: new Cesium.CallbackProperty(function() {
- let center2 = _self._sketchTempPoints[0];
- let endPoint = _self._sketchTempPoints[_self._sketchTempPoints.length - 1];
- let results = _self._calculateOdlinePositios(
- center2,
- endPoint,
- parseInt(
- faterParam.odlineHeight
- ),
- parseInt(faterParam.odlineCount)
- );
- return results;
- }, false),
- material: odLineMaterial,
- width: faterParam.lineWidth,
- clampToGround: false
- }
- });
- this._drawEntity = this._entities.add(entity);
- },
- _updateOdline: function(isLast, isEdit) {
- if (isLast !== void 0 && isLast === true) {
- if (isEdit !== void 0 && isEdit === true) {
- this._drawEntity.setEntityType(DrawTools.DrawType.OdLine);
- this._setEntityIsEdit(this._drawEntity);
- this._drawEntity.parent.setIsEdit(true);
- }
- } else {
- let params = this._drawEntity.parent.getParams();
- let center2 = this._sketchTempPoints[0];
- let endPoint = this._sketchTempPoints[this._sketchTempPoints.length - 1];
- let results = this._calculateOdlinePositios(
- center2,
- endPoint,
- parseInt(params.odlineHeight),
- parseInt(params.odlineCount)
- );
- this._drawEntity.polyline.positions = results;
- this._drawEntity.setEntityType(DrawTools.DrawType.OdLine);
- this._odlineEntitys.push(this._drawEntity);
- if (isEdit !== void 0 && isEdit === true) {
- this._drawEntity.setIsEdit(true);
- }
- }
- },
- _guid() {
- function S4() {
- return ((1 + Math.random()) * 65536 | 0).toString(16).substring(1);
- }
- return S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4();
- },
- _console(...rest) {
- console.log("===>>>", rest);
- }
- });
- Object.assign(DrawTools.prototype, {
- _drawMovingDoubleTooltip(position2) {
- this._updateTooltip("\u5DE6\u952E\u5355\u51FB\u7ED8\u5236,\u53F3\u952E\u5355\u51FB\u64A4\u9500<br>\u5DE6\u952E\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236", position2);
- },
- _drawMovingSimpleTooltip(position2) {
- this._updateTooltip("\u5DE6\u952E\u5355\u51FB\u7ED3\u675F\u7ED8\u5236", position2);
- },
- _removeLastDrawPointEntity() {
- let lastPointEntity = this._pointEntitys.last();
- if (lastPointEntity !== void 0) {
- this._removeEntityByObject(lastPointEntity);
- this._pointEntitys.pop();
- }
- },
- _sketchDrawPoint(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let scene = _self._viewer.scene;
- if (scene.mode !== Cesium.SceneMode.MORPHING) {
- var pickedObject = scene.pick(event2.position);
- if (scene.pickPositionSupported && Cesium.defined(pickedObject)) {
- var cartesian = scene.pickPosition(event2.position);
- if (Cesium.defined(cartesian)) {
- var cartographic = Cesium.Cartographic.fromCartesian(cartesian);
- var lng = Cesium.Math.toDegrees(cartographic.longitude);
- var lat = Cesium.Math.toDegrees(cartographic.latitude);
- var height2 = cartographic.height;
- _self._sketchOutputPoints.push({
- lng,
- lat,
- height: height2
- });
- }
- _self._createPoint(cartesian, "\u70B9");
- _self._sketchPoints.push(cartesian.clone());
- if (_self._sketchPoints.length >= 2) {
- _self._createVideoWall();
- _self._clearEvent(handler);
- }
- }
- }
- if (options2.onComplete)
- options2.onComplete(loc.sLocation, loc.gLocation);
- });
- },
- _sketchDrawMultiplePoint(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- _self._sketchPoints.push(loc2.sLocation);
- _self._sketchOutputPoints.push(loc2.gLocation);
- if (options2.onAdded)
- options2.onAdded(loc2.sLocation, loc2.gLocation);
- });
- this._registerRightClickEvent(handler, function(event2) {
- if (_self._sketchPoints.length > 0) {
- _self._sketchPoints.pop();
- _self._sketchOutputPoints.pop();
- if (options2.onUndo)
- options2.onUndo();
- }
- });
- this._registerLeftDoubleClickEvent(handler, function(event2) {
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchPoints, _self._sketchOutputPoints);
- });
- },
- _sketchDrawPolyline(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- if (_self._sketchTempPoints.length === 0) {
- _self._createPolyline(options2.polylineType);
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- }
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation.clone());
- _self._sketchOutputPoints.push(loc2.gLocation);
- if (options2.onAdded)
- options2.onAdded(_self._sketchPoints, _self._sketchOutputPoints);
- _self._createOperationDom();
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchTempPoints.length > 1) {
- _self._drawMovingDoubleTooltip(event2.endPosition);
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- if (options2.onMoving)
- options2.onMoving(loc2.sLocation);
- }
- });
- this._registerRightClickEvent(handler, function(event2) {
- if (_self._sketchTempPoints.length > 2) {
- _self._drawByUndo();
- if (options2.onUndo)
- options2.onUndo();
- }
- });
- this._registerLeftDoubleClickEvent(handler, function(event2) {
- if (_self._sketchPoints.length < 2) {
- if (options2.onError)
- options2.onError("\u70B9\u6570\u5C11\u4E8E\u4E24\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._updatePolyline(options2.isEdit);
- if (!_self._isRetainDrawPoint)
- _self._removePointEntitys();
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchPoints, _self._sketchOutputPoints);
- });
- },
- _sketchDrawSpatialPolyline(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- if (_self._sketchTempPoints.length === 0) {
- _self._createSpatialPolyline();
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- }
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation.clone());
- _self._sketchOutputPoints.push(loc2.gLocation);
- if (options2.onAdded)
- options2.onAdded(_self._sketchPoints, _self._sketchOutputPoints);
- _self._createOperationDom();
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchTempPoints.length > 1) {
- _self._drawMovingDoubleTooltip(event2.endPosition);
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- if (options2.onMoving)
- options2.onMoving(loc2.sLocation);
- }
- });
- this._registerLeftDoubleClickEvent(handler, function(event2) {
- if (_self._sketchPoints.length < 2) {
- if (options2.onError)
- options2.onError("\u7ED8\u5236\u70B9\u5C11\u4E8E2\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._updateSpatialPolyline(options2.isEdit);
- _self._removePointEntitys();
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchPoints, _self._sketchOutputPoints);
- });
- this._registerRightClickEvent(handler, function(event2) {
- if (_self._sketchTempPoints.length > 2) {
- _self._drawByUndo();
- if (options2.onUndo)
- options2.onUndo();
- }
- });
- },
- _sketchDrawOdline(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- if (_self._isRuntimeApp()) {
- _self._showTooltipMessage("\u518D\u6B21\u5355\u51FB\u7ED8\u5236\u4E00\u6761OD\u7EBF\uFF01");
- }
- if (_self._sketchTempPoints.length === 0) {
- _self._createOdline(true);
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- } else {
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- _self._updateOdline(false, options2.isEdit);
- _self._createOdline();
- }
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation.clone());
- _self._sketchOutputPoints.push(loc2.gLocation);
- if (options2.onAdded)
- options2.onAdded(_self._sketchPoints, _self._sketchOutputPoints);
- _self._createOperationDom();
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchTempPoints.length > 1) {
- _self._drawMovingDoubleTooltip(event2.endPosition);
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- if (options2.onMoving)
- options2.onMoving(loc2.sLocation);
- }
- });
- this._registerLeftDoubleClickEvent(handler, function(event2) {
- _self._removeEntityByObject(_self._drawEntity);
- _self._updateOdline(true, options2.isEdit);
- _self._removePointEntitys();
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchPoints, _self._sketchOutputPoints);
- });
- this._registerRightClickEvent(handler, function(event2) {
- if (_self._odlineEntitys.length > 0) {
- if (_self._isDrawPoint) {
- _self._removeLastDrawPointEntity();
- }
- _self._removeEntityByObject(_self._odlineEntitys.last());
- _self._odlineEntitys.pop();
- if (options2.onUndo)
- options2.onUndo();
- }
- });
- },
- _sketchDrawPolygon(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- if (_self._sketchTempPoints.length === 0) {
- _self._createPolygon(options2.polygonType);
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- }
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation.clone());
- _self._sketchOutputPoints.push(loc2.gLocation);
- if (options2.onAdded)
- options2.onAdded(_self._sketchPoints, _self._sketchOutputPoints);
- _self._createOperationDom();
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchTempPoints.length > 1) {
- _self._drawMovingDoubleTooltip(event2.endPosition);
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- if (options2.onMoving)
- options2.onMoving(loc2.sLocation);
- }
- });
- this._registerRightClickEvent(handler, function(event2) {
- if (_self._sketchTempPoints.length > 2) {
- _self._drawByUndo();
- if (options2.onUndo)
- options2.onUndo();
- }
- });
- this._registerLeftDoubleClickEvent(handler, function(event2) {
- if (_self._sketchPoints.length < 3) {
- if (options2.onError)
- options2.onError("\u70B9\u6570\u5C11\u4E8E3\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._updatePolygon(options2.isEdit);
- if (!_self._isRetainDrawPoint)
- _self._removePointEntitys();
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchPoints, _self._sketchOutputPoints);
- });
- },
- _sketchDrawCircle: function(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchTempPoints.length === 0) {
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, "\u8D77\u70B9");
- }
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.sLocation.clone());
- _self._sketchOutputPoints.push(loc2.gLocation);
- _self._createCircle(loc2.sLocation, options2.circleType);
- if (_self._isRuntimeApp()) {
- _self._showTooltipMessage("\u518D\u6B21\u5355\u51FB\u7ED3\u675F\u7ED8\u5236\uFF01");
- }
- if (options2.onAdded)
- options2.onAdded(loc2.sLocation);
- } else {
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- _self._removePointEntitys();
- _self._updateCircle(options2.isEdit);
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchOutputPoints[0], _self._sketchEllipseRadius);
- }
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp()) {
- return;
- }
- if (_self._sketchTempPoints.length <= 0)
- return;
- _self._drawMovingSimpleTooltip(event2.endPosition);
- var cartesian = _self._viewer.scene.pickPosition(event2.endPosition);
- if (cartesian == void 0)
- return;
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(cartesian);
- });
- },
- _sketchDrawRectangle: function(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- if (_self._sketchTempPoints.length === 0) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, "\u8D77\u70B9");
- }
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchPoints.push(loc2.gLocation);
- _self._createRectangle();
- if (options2.onAdded)
- options2.onAdded(loc2.sLocation);
- if (_self._isRuntimeApp()) {
- _self._showTooltipMessage("\u518D\u6B21\u5355\u51FB\u7ED3\u675F\u7ED8\u5236\uFF01");
- }
- } else {
- _self._removePointEntitys();
- _self._removeEntityByObject(_self._sketchTempRectangle);
- _self._updateRectangle(options2.isEdit);
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(_self._sketchOutputPoints);
- }
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._sketchTempPoints.length < 1)
- return;
- _self._drawMovingSimpleTooltip(event2.endPosition);
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- });
- },
- _sketchDrawWall: function(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- if (_self._sketchTempPoints.length === 0) {
- _self._createWall(options2.wallType);
- _self._sketchTempPoints.push(loc2.sLocation.clone());
- _self._sketchWallHeights.push(loc2.gLocation.height);
- }
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchWallHeights.push(loc2.gLocation.height);
- _self._sketchPoints.push(loc2.sLocation.clone());
- _self._createOperationDom();
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp()) {
- return;
- }
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchTempPoints.length > 1) {
- _self._drawMovingDoubleTooltip(event2.endPosition);
- _self._sketchTempPoints.pop();
- _self._sketchTempPoints.push(loc2.sLocation);
- _self._sketchWallHeights.pop();
- _self._sketchWallHeights.push(loc2.gLocation.height);
- }
- });
- this._registerRightClickEvent(handler, function(event2) {
- if (_self._sketchTempPoints.length > 2) {
- _self._sketchPoints.pop();
- if (_self._isRuntimeApp()) {
- _self._sketchTempPoints.splice(_self._sketchTempPoints.length - 1, 1);
- _self._sketchWallHeights.splice(_self._sketchWallHeights.length - 1, 1);
- } else {
- _self._sketchTempPoints.splice(_self._sketchTempPoints.length - 2, 1);
- _self._sketchWallHeights.splice(_self._sketchWallHeights.length - 2, 1);
- }
- if (_self._isDrawPoint) {
- _self._removeLastDrawPointEntity();
- }
- }
- });
- this._registerLeftDoubleClickEvent(handler, function(event2) {
- if (_self._sketchPoints.length < 2) {
- if (options2.onError)
- options2.onError("\u70B9\u6570\u5C11\u4E8E\u4E24\u4E2A\uFF0C\u7981\u6B62\u7ED3\u675F\u7ED8\u5236\uFF01");
- return;
- }
- _self._updateWall(options2.isEdit);
- if (!_self._isRetainDrawPoint)
- _self._removePointEntitys();
- _self._clearEvent(handler);
- });
- },
- _sketchDrawVideoWall: function(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._isDrawPoint) {
- _self._createPoint(loc2.sLocation, _self._lineLabel);
- }
- if (_self._sketchOutputPoints.length === 0) {
- _self._sketchOutputPoints.push(loc2.gLocation);
- _self._sketchOutputPoints.push(loc2.gLocation);
- _self._createVideoWall();
- if (_self._isRuntimeApp()) {
- _self._showTooltipMessage("\u518D\u6B21\u5355\u51FB\u7ED3\u675F\u7ED8\u5236");
- }
- } else {
- _self._updateVideoWall(options2.isEdit);
- _self._clearEvent(handler);
- }
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- if (_self._isRuntimeApp())
- return;
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- if (_self._sketchOutputPoints.length > 1) {
- _self._drawMovingSimpleTooltip(event2.endPosition);
- _self._sketchOutputPoints.pop();
- _self._sketchOutputPoints.push(loc2.gLocation);
- }
- });
- },
- _drawByUndo: function() {
- this._sketchPoints.pop();
- if (this._isRuntimeApp()) {
- this._sketchTempPoints.splice(this._sketchTempPoints.length - 1, 1);
- } else {
- this._sketchTempPoints.splice(this._sketchTempPoints.length - 2, 1);
- }
- if (this._isDrawPoint) {
- this._removeLastDrawPointEntity();
- }
- },
- draw: function(type2, options2) {
- let _self = this;
- this._clear();
- this._drawEventHandler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- if (this._isRuntimeApp()) {
- this._showTooltipMessage("\u5355\u51FB\u7ED8\u5236");
- } else {
- this._beginTooltip("\u5DE6\u952E\u5355\u51FB\u7ED8\u5236", void 0);
- }
- this._drawType = type2;
- switch (type2) {
- case DrawTools.DrawType.Point:
- _self._sketchDrawPoint(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.Polyline:
- options2.polylineType = DrawTools.PolylineType.NormalPolyline;
- _self._sketchDrawPolyline(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.ArrowPolyline:
- options2.polylineType = DrawTools.PolylineType.ArrowsPolyline;
- _self._sketchDrawPolyline(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.DynamicPolyline:
- options2.polylineType = DrawTools.PolylineType.DynamicPolyline;
- _self._sketchDrawPolyline(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.GrowPolyline:
- options2.polylineType = DrawTools.PolylineType.GrowPolyline;
- _self._sketchDrawPolyline(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.OutlinePolyline:
- options2.polylineType = DrawTools.PolylineType.OutlinePolyline;
- _self._sketchDrawPolyline(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.Polygon:
- options2.polygonType = DrawTools.PolygonType.NormalPolygon;
- _self._sketchDrawPolygon(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.SpatialLine:
- _self._sketchDrawSpatialPolyline(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.Circle:
- options2.circleType = DrawTools.CircleType.ColorCircle;
- _self._sketchDrawCircle(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.Rectangle:
- _self._sketchDrawRectangle(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.NormalWall:
- options2.wallType = DrawTools.WallType.ColorWall;
- _self._sketchDrawWall(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.DynamicWall:
- options2.wallType = DrawTools.WallType.DynamicWall;
- _self._sketchDrawWall(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.TextWall:
- options2.wallType = DrawTools.WallType.TextWall;
- _self._sketchDrawWall(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.DynamicCircle:
- options2.circleType = DrawTools.CircleType.DynamicCircle;
- _self._sketchDrawCircle(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.House:
- options2.polygonType = DrawTools.PolygonType.HousePolygon;
- _self._sketchDrawPolygon(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.VideoWall:
- _self._sketchDrawVideoWall(_self._drawEventHandler, options2);
- break;
- case DrawTools.DrawType.OdLine:
- _self._sketchDrawOdline(_self._drawEventHandler, options2);
- break;
- }
- },
- Clear: function() {
- this._clear(true);
- this._unActivateEdit();
- this._closePropertyEditDialog();
- this._removeOperationDom();
- },
- sketchInit: function() {
- this._clear(false);
- },
- _checkAppOrWeb() {
- if (window.navigator.userAgent.match(
- /(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i
- )) {
- return DrawTools.RuntimeEnvironment.App;
- } else {
- return DrawTools.RuntimeEnvironment.Web;
- }
- },
- _isRuntimeApp() {
- if (this._checkAppOrWeb() === DrawTools.RuntimeEnvironment.App) {
- return true;
- }
- return false;
- }
- });
- Object.assign(DrawTools.prototype, {
- _tooltipInit: function(text, mousePosition) {
- let _self = this;
- this._tooltipId = "tooltipSketchmodel";
- let tooltipObj = document.getElementById(this._tooltipId);
- if (tooltipObj === null) {
- tooltipObj = document.createElement("div");
- tooltipObj.id = this._tooltipId;
- document.body.appendChild(tooltipObj);
- let divStyle = "";
- divStyle += "top: 30px;";
- divStyle += "left: 30px;";
- divStyle += "position: absolute;";
- divStyle += "display: flex;";
- divStyle += "align-items: center;";
- divStyle += "width: 12x0px;";
- divStyle += "height: auto;";
- divStyle += "background-color: rgba(0, 0, 0, 0.65);";
- divStyle += "border-radius: 5px;";
- divStyle += "color: rgb(255, 255, 255);";
- divStyle += "font-size: 12px;";
- divStyle += "font-family: 'Alimama_ShuHeiTi_Bold';";
- divStyle += "padding: 8px;";
- divStyle += "border:solid 1px rgb(255,0,0);";
- tooltipObj.setAttribute("style", divStyle);
- }
- if (text != void 0)
- tooltipObj.innerHTML = text;
- if (mousePosition === void 0) {
- document.onmousemove = function(event2) {
- if (event2.clientX < 100 || event2.clientX > _self._canvasWidth - 100 || event2.clientY < 100 || event2.clientY > _self._canvasHeight - 100) {
- tooltipObj.style.display = "none";
- } else {
- tooltipObj.style.display = "flex";
- tooltipObj.style.left = event2.clientX + 10 + "px";
- tooltipObj.style.top = event2.clientY - tooltipObj.offsetHeight / 2 + "px";
- }
- };
- } else {
- if (mousePosition.x < 100 || mousePosition.x > _self._canvasWidth - 100 || mousePosition.y < 100 || mousePosition.y > _self._canvasHeight - 100) {
- tooltipObj.style.display = "none";
- } else {
- tooltipObj.style.display = "flex";
- tooltipObj.style.left = mousePosition.x + 10 + "px";
- tooltipObj.style.top = mousePosition.y - tooltipObj.offsetHeight / 2 + "px";
- }
- }
- },
- _tooltipRemove: function() {
- let tooltipObj = document.getElementById(this._tooltipId);
- if (tooltipObj != null) {
- document.body.removeChild(tooltipObj);
- }
- },
- _tooltipSetText: function(text, mousePosition) {
- let tooltipObj = document.getElementById(this._tooltipId);
- if (tooltipObj != null) {
- if (text != void 0)
- tooltipObj.innerHTML = text;
- if (mousePosition != void 0) {
- if (mousePosition.x < 100 || mousePosition.x > this._canvasWidth - 100 || mousePosition.y < 100 || mousePosition.y > this._canvasHeight - 100) {
- tooltipObj.style.display = "none";
- } else {
- tooltipObj.style.display = "flex";
- tooltipObj.style.left = mousePosition.x + 10 + "px";
- tooltipObj.style.top = mousePosition.y - tooltipObj.offsetHeight / 2 + "px";
- }
- }
- }
- },
- _setMousePointerStyle: function() {
- document.querySelector("body").style.cursor = "crosshair";
- },
- _setMouseDefaultStyle: function() {
- document.querySelector("body").style.cursor = "default";
- },
- _beginTooltip(text, position2) {
- this._tooltipInit(text, position2);
- this._setMousePointerStyle();
- },
- _updateTooltip(text, position2) {
- this._tooltipSetText(text, position2);
- },
- _endTooltip() {
- this._tooltipRemove();
- this._setMouseDefaultStyle();
- },
- _showTooltipMessage: function(message) {
- let msgMainDom = document.getElementById("messageMainDom");
- if (msgMainDom !== null && msgMainDom !== void 0) {
- document.body.removeChild(msgMainDom);
- }
- msgMainDom = document.createElement("div");
- msgMainDom.style.width = "30%";
- msgMainDom.style.backgroundColor = "rgba(237, 248, 230, 1.0)";
- msgMainDom.style.height = "45px";
- msgMainDom.style.border = "solid 2px rgb(219, 241, 208)";
- msgMainDom.style.borderRadius = "8px";
- msgMainDom.style.display = "flex";
- msgMainDom.style.alignItems = "center";
- msgMainDom.style.paddingLeft = "10px";
- msgMainDom.style.color = "rgb(91, 188, 48)";
- msgMainDom.style.fontSize = "14px";
- msgMainDom.style.fontWeight = "600";
- msgMainDom.style.position = "absolute";
- msgMainDom.style.left = "35%";
- msgMainDom.style.transition = "transform 1s";
- msgMainDom.style.transform = "translateY(-90px)";
- msgMainDom.style.top = "0px";
- msgMainDom.style.zIndex = 1e3;
- document.body.appendChild(msgMainDom);
- let strHtml = "";
- strHtml += "<div style='";
- strHtml += "background-color: rgb(88, 185, 45);";
- strHtml += "color: rgb(255, 255, 255);";
- strHtml += "height: 24px;";
- strHtml += "width: 24px;";
- strHtml += "border-radius: 20px;";
- strHtml += "display: flex;";
- strHtml += "justify-content: center;";
- strHtml += "align-items: center;";
- strHtml += "font-size: 14px;";
- strHtml += "margin-right: 18px;";
- strHtml += "'>✓</div>";
- strHtml += "<div>" + message + "</div>";
- msgMainDom.innerHTML = strHtml;
- msgMainDom.addEventListener("transitionend", function() {
- setTimeout(function() {
- document.body.removeChild(msgMainDom);
- }, 1e3);
- }, false);
- setTimeout(function() {
- msgMainDom.style.transform = "translateY(50px)";
- }, 100);
- }
- });
- Object.assign(DrawTools.prototype, {
- _createSingleCoordinateAxisArrow(positions, color2, axisEntityId) {
- let _self = this;
- let coordinateAxisEntity = new Cesium.Entity({
- id: axisEntityId,
- name: _self._coordinateAxisEntityName,
- position: positions[0],
- polyline: {
- positions,
- width: 10,
- material: _self._materialPolylineArrowProperty({
- color: color2
- })
- }
- });
- coordinateAxisEntity.setEditType({
- type: DrawTools.EditPointType.CoordinateAxis
- });
- return this._entities.add(coordinateAxisEntity);
- },
- _getTranslatePostion: function(originPosition, translateCartesian) {
- let transform3 = Cesium.Transforms.eastNorthUpToFixedFrame(originPosition);
- let m = new Cesium.Matrix4();
- Cesium.Matrix4.setTranslation(
- Cesium.Matrix4.IDENTITY,
- translateCartesian,
- m
- );
- let modelMatrix = Cesium.Matrix4.multiply(transform3, m, transform3);
- let outPosition = new Cesium.Cartesian3(0, 0, 0);
- Cesium.Matrix4.getTranslation(modelMatrix, outPosition);
- return outPosition;
- },
- _createCoordinateAxis: function(position2) {
- this._showTooltipMessage("\u5355\u51FB\u53F3\u952E\u79FB\u9664\u8C03\u6574\u8F74\u7EBF\uFF01");
- this._removeCoorinateAxis();
- let _self = this;
- let cameraRight = this._viewer.scene.camera.rightWC;
- this._tx = cameraRight.x > 0 ? 150 : -150;
- this._ty = cameraRight.y > 0 ? 150 : -150;
- this._tz = 150;
- this._coordinateAxisEntityId_x = "coordinateAxisId_x";
- this._coordinateAxisEntityId_y = "coordinateAxisId_y";
- this._coordinateAxisEntityId_z = "coordinateAxisId_z";
- this._coordinateAxisEntityName = "coordinateAxisEntity";
- let translateCartesian = new Cesium.Cartesian3(this._tx, 0, 0);
- let endPosition = this._getTranslatePostion(position2, translateCartesian);
- const xPos = [position2, endPosition];
- this._coordinateEntity_x = this._createSingleCoordinateAxisArrow(xPos, "rgba(0,255,0,1.0)", this._coordinateAxisEntityId_x);
- this._coordinateAxisBindEntity(this._coordinateEntity_x);
- translateCartesian = new Cesium.Cartesian3(0, this._ty, 0);
- endPosition = this._getTranslatePostion(position2, translateCartesian);
- const yPos = [position2, endPosition];
- this._coordinateEntity_y = this._createSingleCoordinateAxisArrow(yPos, "rgba(0,0,255,1.0)", this._coordinateAxisEntityId_y);
- this._coordinateAxisBindEntity(this._coordinateEntity_y);
- translateCartesian = new Cesium.Cartesian3(0, 0, this._tz);
- endPosition = this._getTranslatePostion(position2, translateCartesian);
- const zPos = [position2, endPosition];
- this._coordinateEntity_z = this._createSingleCoordinateAxisArrow(zPos, "rgba(255,0,0,1.0)", this._coordinateAxisEntityId_z);
- this._coordinateAxisBindEntity(this._coordinateEntity_z);
- this._eventCoorinateAxis = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- this._registerLeftDownEvent(this._eventCoorinateAxis, function(event2) {
- _self._coorinateAxisMouseDown(event2);
- });
- this._registerMouseMoveEvent(this._eventCoorinateAxis, function(event2) {
- _self._coorinateAxisMouseMove(event2);
- });
- this._registerLeftUpEvent(this._eventCoorinateAxis, function(event2) {
- _self._coorinateAxisMouseUp(event2);
- });
- this._registerRightClickEvent(this._eventCoorinateAxis, function(event2) {
- _self._removeCoorinateAxis();
- });
- },
- _coordinateAxisBindEntity: function(axisEntity) {
- if (this._editEntity === void 0)
- return;
- let editEntityType = this._editEntity.getEntityType();
- if (editEntityType === void 0)
- return;
- if (editEntityType === DrawTools.DrawType.VideoWall) {
- axisEntity.bindEntity(this._editEntity);
- }
- },
- _coorinateAxisMouseDown: function(event2) {
- let _self = this;
- let feature2 = this._viewer.scene.pick(event2.position);
- if (feature2 === void 0)
- return;
- if (feature2.id != void 0 && feature2.id instanceof Cesium.Entity) {
- this._viewer.scene.screenSpaceCameraController.enableRotate = false;
- if (feature2.id.getEditType() === void 0)
- return;
- let entityType = feature2.id.getEditType().type;
- if (entityType !== DrawTools.EditPointType.CoordinateAxis)
- return;
- this._editCoorinateAxis = feature2.id;
- this._editCoorinateAxis.polyline.width = 15;
- this._coordinateAxisMoveStartPosition = this._viewer.scene.camera.pickEllipsoid(
- event2.position,
- this._viewer.scene.globe.ellipsoid
- );
- this._coordinateAxisMoveStartScreen = event2.position;
- this._coorinateAxisPosition = this._editCoorinateAxis.position._value;
- this._coordinateEntity_x.polyline.positions = new Cesium.CallbackProperty(function() {
- let translateCartesian = new Cesium.Cartesian3(_self._tx, 0, 0);
- let endPosition = _self._getTranslatePostion(
- _self._coorinateAxisPosition,
- translateCartesian
- );
- return [_self._coorinateAxisPosition, endPosition];
- }, false);
- this._coordinateEntity_y.polyline.positions = new Cesium.CallbackProperty(function() {
- let translateCartesian = new Cesium.Cartesian3(0, _self._ty, 0);
- let endPosition = _self._getTranslatePostion(
- _self._coorinateAxisPosition,
- translateCartesian
- );
- return [_self._coorinateAxisPosition, endPosition];
- }, false);
- this._coordinateEntity_z.polyline.positions = new Cesium.CallbackProperty(function() {
- let translateCartesian = new Cesium.Cartesian3(0, 0, _self._tz);
- let endPosition = _self._getTranslatePostion(
- _self._coorinateAxisPosition,
- translateCartesian
- );
- return [_self._coorinateAxisPosition, endPosition];
- }, false);
- this._coordinateAxisActivateEditEntity(this._editCoorinateAxis);
- }
- },
- _coorinateAxisMouseMove: function(event2) {
- if (!Cesium.defined(this._editCoorinateAxis))
- return;
- let position2 = this._viewer.scene.camera.pickEllipsoid(
- event2.endPosition,
- this._viewer.scene.globe.ellipsoid
- );
- if (!position2)
- return;
- let strGeo = this._cartesian3ToGeo(this._coordinateAxisMoveStartPosition);
- let endGeo = this._cartesian3ToGeo(position2);
- let entityId = this._editCoorinateAxis.id;
- let entityPosition = this._editCoorinateAxis.position._value;
- let entityGeo = this._cartesian3ToGeo(entityPosition);
- let heightDifference = 0;
- if (entityId === this._coordinateAxisEntityId_x) {
- let difference = strGeo.longitude - endGeo.longitude;
- entityGeo.longitude = entityGeo.longitude - difference;
- } else if (entityId === this._coordinateAxisEntityId_y) {
- let difference = strGeo.latitude - endGeo.latitude;
- entityGeo.latitude = entityGeo.latitude - difference;
- } else if (entityId === this._coordinateAxisEntityId_z) {
- heightDifference = event2.endPosition.y - this._coordinateAxisMoveStartScreen.y;
- heightDifference = heightDifference * 0.5;
- entityGeo.height = entityGeo.height - heightDifference;
- }
- this._coorinateAxisPosition = Cesium.Cartesian3.fromDegrees(entityGeo.longitude, entityGeo.latitude, entityGeo.height);
- this._moveEditEntityByCoordinateAxis(entityPosition, this._coorinateAxisPosition, heightDifference);
- },
- _coorinateAxisMouseUp: function(event2) {
- this._viewer.scene.screenSpaceCameraController.enableRotate = true;
- if (this._editCoorinateAxis !== void 0) {
- this._editCoorinateAxis.polyline.width = 10;
- let translateCartesian = new Cesium.Cartesian3(this._tx, 0, 0);
- let endPosition = this._getTranslatePostion(this._coorinateAxisPosition, translateCartesian);
- this._coordinateEntity_x.polyline.positions = [this._coorinateAxisPosition, endPosition];
- translateCartesian = new Cesium.Cartesian3(0, this._ty, 0);
- endPosition = this._getTranslatePostion(this._coorinateAxisPosition, translateCartesian);
- this._coordinateEntity_y.polyline.positions = [this._coorinateAxisPosition, endPosition];
- translateCartesian = new Cesium.Cartesian3(0, 0, this._tz);
- endPosition = this._getTranslatePostion(this._coorinateAxisPosition, translateCartesian);
- this._coordinateEntity_z.polyline.positions = [this._coorinateAxisPosition, endPosition];
- this._coordinateEntity_x.position = this._coorinateAxisPosition;
- this._coordinateEntity_y.position = this._coorinateAxisPosition;
- this._coordinateEntity_z.position = this._coorinateAxisPosition;
- this._coordinateAxisUpdateEditEntity(this._editCoorinateAxis);
- this._editCoorinateAxis = void 0;
- }
- },
- _moveEditEntityByCoordinateAxis: function(strPosition, endPosition, heightDifference) {
- let movePosition = Cesium.Cartesian3.subtract(endPosition, strPosition, new Cesium.Cartesian3());
- for (let i2 = 0; i2 < this._moveInitPositions.length; i2++) {
- let moveResult = Cesium.Cartesian3.add(this._moveInitPositions[i2], movePosition, new Cesium.Cartesian3());
- this._moveUpdatePositions[i2] = moveResult.clone();
- }
- for (let i2 = 0; i2 < this._moveInitHeights.length; i2++) {
- this._moveUpdateHeights[i2] = parseFloat(this._moveInitHeights[i2]) + heightDifference * -1;
- }
- },
- _coordinateAxisActivateEditEntity: function(moveAxisEntity) {
- let _self = this;
- let bindEntity = moveAxisEntity.getBindEntity();
- if (bindEntity === void 0)
- return;
- let bindEntityType = bindEntity.getEntityType();
- if (bindEntityType === DrawTools.DrawType.VideoWall) {
- let wall = bindEntity.wall;
- this._moveInitPositions = wall.positions._value;
- this._moveInitHeights = wall.minimumHeights._value;
- this._moveInitHeight = wall.maximumHeights._value[0] - wall.minimumHeights._value[0];
- this._moveUpdatePositions = [];
- for (let i2 = 0; i2 < this._moveInitPositions.length; i2++) {
- this._moveUpdatePositions.push(this._moveInitPositions[i2].clone());
- }
- wall.positions = new Cesium.CallbackProperty(function() {
- return _self._moveUpdatePositions;
- }, false);
- this._moveUpdateHeights = [];
- for (let i2 = 0; i2 < this._moveInitHeights.length; i2++) {
- this._moveUpdateHeights.push(this._moveInitHeights[i2]);
- }
- wall.minimumHeights = new Cesium.CallbackProperty(function() {
- return _self._moveUpdateHeights;
- }, false);
- wall.maximumHeights = new Cesium.CallbackProperty(function() {
- let maxHeights = [];
- for (let i2 = 0; i2 < _self._moveUpdateHeights.length; i2++) {
- maxHeights.push(parseFloat(_self._moveUpdateHeights[i2]) + _self._moveInitHeight);
- }
- return maxHeights;
- }, false);
- }
- },
- _coordinateAxisUpdateEditEntity: function(moveAxisEntity) {
- let bindEntity = moveAxisEntity.getBindEntity();
- if (bindEntity === void 0)
- return;
- let bindEntityType = bindEntity.getEntityType();
- if (bindEntityType === DrawTools.DrawType.VideoWall) {
- let wall = bindEntity.wall;
- wall.positions = this._moveUpdatePositions;
- wall.minimumHeights = this._moveUpdateHeights;
- let maxHeights = [];
- for (let i2 = 0; i2 < this._moveUpdateHeights.length; i2++) {
- maxHeights.push(parseFloat(this._moveUpdateHeights[i2]) + this._moveInitHeight);
- }
- wall.maximumHeights = maxHeights;
- }
- },
- _coordinateCalculateEntityOrientation: function(entity, options2) {
- let position2 = entity.position._value;
- let orientation = entity.orientation === void 0 ? new Cesium.Cartesian3(0, 0, 0) : entity.orientation._value;
- let transform3 = Cesium.Matrix4.fromTranslationQuaternionRotationScale(
- position2,
- orientation,
- new Cesium.Cartesian3(1, 1, 1),
- new Cesium.Matrix4()
- );
- let _rotateX = Cesium.Matrix3.fromRotationX(Cesium.Math.toRadians(options2.x));
- let _rotateY = Cesium.Matrix3.fromRotationX(Cesium.Math.toRadians(options2.y));
- let _rotateZ = Cesium.Matrix3.fromRotationX(Cesium.Math.toRadians(options2.z));
- transform3 = Cesium.Matrix4.multiplyByMatrix3(transform3, _rotateX, transform3);
- transform3 = Cesium.Matrix4.multiplyByMatrix3(transform3, _rotateY, transform3);
- transform3 = Cesium.Matrix4.multiplyByMatrix3(transform3, _rotateZ, transform3);
- let m3 = Cesium.Matrix4.getRotation(transform3, new Cesium.Matrix3());
- let resOrientation = new Cesium.Quaternion();
- Cesium.Quaternion.fromRotationMatrix(m3, resOrientation);
- return resOrientation;
- },
- _removeCoorinateAxis: function() {
- if (this._coordinateAxisEntityName !== void 0) {
- this._removeEntityByName(this._coordinateAxisEntityName);
- }
- if (this._eventCoorinateAxis !== void 0) {
- this._clearEvent(this._eventCoorinateAxis);
- this._eventCoorinateAxis = void 0;
- }
- }
- });
- Object.assign(DrawTools.prototype, {
- _setEntityIsEdit(entity) {
- let _self = this;
- entity.setIsEdit(true);
- this._unActivateEdit();
- this._sendShowPropertyDialog(entity);
- let handler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- this._registerLeftClickEvent(handler, function(event2) {
- _self._unActivateEdit();
- let feature2 = _self._viewer.scene.pick(event2.position);
- if (feature2 !== void 0 && feature2.id instanceof Cesium.Entity) {
- let featureType = feature2.id.getEditType();
- let entityType = feature2.id.getEntityType();
- if (featureType === DrawTools.EditPointType.Node || featureType === DrawTools.EditPointType.Middle || featureType === DrawTools.EditPointType.Center || featureType === DrawTools.EditPointType.CoordinateAxis || featureType === DrawTools.EditPointType.OdlineStrartNode || featureType === DrawTools.EditPointType.OdlineEndNode || entityType === DrawTools.DrawType.Polyline || entityType === DrawTools.DrawType.ArrowPolyline || entityType === DrawTools.DrawType.DynamicPolyline || entityType === DrawTools.DrawType.GrowPolyline || entityType === DrawTools.DrawType.OutlinePolyline || entityType === DrawTools.DrawType.OdLine || entityType === DrawTools.DrawType.Polygon || entityType === DrawTools.DrawType.SpatialLine || entityType === DrawTools.DrawType.Circle || entityType === DrawTools.DrawType.DynamicCircle || entityType === DrawTools.DrawType.Rectangle || entityType === DrawTools.DrawType.NormalWall || entityType === DrawTools.DrawType.DynamicWall || entityType === DrawTools.DrawType.House || entityType === DrawTools.DrawType.TextWall || entityType === DrawTools.DrawType.VideoWall) {
- _self._sendShowPropertyDialog(feature2.id);
- }
- }
- });
- },
- _sendShowPropertyDialog(entity) {
- let _self = this;
- let editEntityType = entity.getEntityType();
- if (entity.getIsEdit() === void 0 || entity.getIsEdit() === false || editEntityType === void 0) {
- this._unActivateEdit();
- return;
- }
- let editProperty = entity.getParams();
- if (editEntityType === DrawTools.DrawType.OdLine) {
- editProperty = entity.parent.getParams();
- }
- if (editProperty !== void 0 && this.onEditProperty !== void 0) {
- this._openPropertyEditDialog(editProperty, function(params) {
- _self.updateEditEntityProperty(params);
- }, function() {
- _self._removeEditEntity();
- });
- }
- this._activateEdit(entity);
- },
- _removeEditEntity() {
- if (this._editEntity !== void 0) {
- let entityType = this._editEntity.getEntityType();
- if (entityType === DrawTools.DrawType.OdLine) {
- let fatherEntityId = this._editEntity.parent.id;
- let removeEntitys = [];
- for (let entity of this._entities.values) {
- if (entity.parent !== void 0 && entity.parent.id === fatherEntityId) {
- removeEntitys.push(entity);
- }
- }
- for (let removeEntity of removeEntitys) {
- this._removeEntityByObject(removeEntity);
- }
- } else {
- this._removeEntityByObject(this._editEntity);
- }
- this._unActivateEdit();
- this._editEntity = void 0;
- }
- },
- updateEditEntityProperty: function(params) {
- if (this._editEntity === void 0)
- return;
- if (this._editEntity.getIsEdit() === void 0 || this._editEntity.getIsEdit() === false)
- return;
- let editEntityType = this._editEntity.getEntityType();
- if (editEntityType === void 0)
- return;
- if (editEntityType === DrawTools.DrawType.NormalWall || editEntityType === DrawTools.DrawType.DynamicWall || editEntityType === DrawTools.DrawType.TextWall) {
- this._updateWallProperty(params);
- } else if (editEntityType === DrawTools.DrawType.Circle || editEntityType === DrawTools.DrawType.DynamicCircle) {
- this._updateCircleProperty(params);
- } else if (editEntityType === DrawTools.DrawType.House) {
- this._updateHouseProperty(params);
- } else if (editEntityType === DrawTools.DrawType.VideoWall) {
- this._updateVideoWallProperty(params);
- } else if (editEntityType === DrawTools.DrawType.Polyline) {
- this._updatePolylineProperty(params);
- } else if (editEntityType === DrawTools.DrawType.Polygon) {
- this._updatePolygonProperty(params);
- } else if (editEntityType === DrawTools.DrawType.Rectangle) {
- this._updateRectangleProperty(params);
- } else if (editEntityType === DrawTools.DrawType.SpatialLine) {
- this._updateSpatialPolylineProperty(params);
- } else if (editEntityType === DrawTools.DrawType.OdLine) {
- this._updateOdlineProperty(params);
- }
- },
- _updateOdlineProperty(params) {
- let _self = this;
- let fatherEntity = this._editEntity.parent;
- this._editOdlineEntities = [];
- for (let entity of this._entities.values) {
- if (entity.parent !== void 0 && entity.parent.id === fatherEntity.id) {
- this._editOdlineEntities.push(entity);
- }
- }
- let meterialImage = this._image_arrow_reverse;
- if (params.order === this._param.order_add) {
- meterialImage = this._image_arrow_reverse;
- } else if (params.order === this._param.order_minus) {
- meterialImage = this._image_arrow_forward;
- }
- let odLineMaterial = new WallMaterialProperty({
- viewer: _self._viewer,
- trailImage: meterialImage,
- duration: params.duration,
- color: Cesium.Color.fromCssColorString(params.color),
- param: {
- direction: params.direction,
- count: params.count,
- order: params.order
- }
- });
- for (let entity of this._editOdlineEntities) {
- entity.polyline.material = odLineMaterial;
- let positions = entity.polyline.positions._value;
- let strPoint = positions.first();
- let endPoint = positions.last();
- let newPositios = this._calculateOdlinePositios(
- strPoint,
- endPoint,
- parseInt(params.odlineHeight),
- parseInt(params.odlineCount)
- );
- entity.polyline.positions = newPositios;
- entity.polyline.width = parseInt(params.lineWidth);
- }
- fatherEntity.setParams(params);
- },
- _updateSpatialPolylineProperty(params) {
- let material = this._editEntity.polyline.material;
- let newMaterial = void 0;
- if (material instanceof Cesium.ColorMaterialProperty) {
- newMaterial = this._materialColorProperty({
- color: params.color
- });
- }
- if (newMaterial !== void 0)
- this._editEntity.polyline.material = newMaterial;
- this._editEntity.polyline.width = parseFloat(params.lineWidth);
- this._editEntity.setParams(params);
- },
- _updateRectangleProperty(params) {
- let material = this._editEntity.rectangle.material;
- if (material instanceof Cesium.ColorMaterialProperty) {
- let newMaterial = this._materialColorProperty({
- color: params.color
- });
- this._editEntity.rectangle.material = newMaterial;
- }
- if (this._editEntity.polyline !== void 0) {
- let newMaterial = this._materialColorProperty({
- color: params.outlineColor
- });
- this._editEntity.polyline.material = newMaterial;
- this._editEntity.polyline.width = parseFloat(params.outlineWidth);
- }
- this._editEntity.setParams(params);
- },
- _updatePolygonProperty(params) {
- let material = this._editEntity.polygon.material;
- if (material instanceof Cesium.ColorMaterialProperty) {
- let newMaterial = this._materialColorProperty({
- color: params.color
- });
- this._editEntity.polygon.material = newMaterial;
- }
- if (this._editEntity.polyline !== void 0) {
- let newMaterial = this._materialColorProperty({
- color: params.outlineColor
- });
- this._editEntity.polyline.material = newMaterial;
- this._editEntity.polyline.width = parseFloat(params.outlineWidth);
- }
- this._editEntity.setParams(params);
- },
- _updatePolylineProperty(params) {
- let material = this._editEntity.polyline.material;
- let newMaterial = void 0;
- if (material instanceof Cesium.ColorMaterialProperty) {
- newMaterial = this._materialColorProperty({
- color: params.color
- });
- } else if (material instanceof Cesium.PolylineArrowMaterialProperty) {
- newMaterial = this._materialPolylineArrowProperty({
- color: params.color
- });
- } else if (material instanceof WallMaterialProperty) {
- let materialImage = this._image_h_l_r;
- if (params.order === this._param.order_minus) {
- materialImage = this._image_h_r_l;
- } else if (params.order === this._param.order_add) {
- materialImage = this._image_h_l_r;
- }
- newMaterial = new WallMaterialProperty({
- viewer: this._viewer,
- trailImage: materialImage,
- duration: params.duration,
- color: Cesium.Color.fromCssColorString(params.color),
- param: {
- count: parseInt(params.count),
- direction: params.direction,
- order: params.order
- }
- });
- } else if (material instanceof Cesium.PolylineGlowMaterialProperty) {
- newMaterial = this._materialPolylineGlowProperty({
- color: params.color,
- power: parseFloat(params.power)
- });
- } else if (material instanceof Cesium.PolylineOutlineMaterialProperty) {
- newMaterial = this._materialPolylineOutlineProperty({
- color: params.color,
- outlineWidth: parseFloat(params.outlineWidth),
- outlineColor: params.outlineColor
- });
- }
- if (newMaterial !== void 0)
- this._editEntity.polyline.material = newMaterial;
- this._editEntity.polyline.width = params.lineWidth;
- this._editEntity.setParams(params);
- },
- _updateHouseProperty(params) {
- let entityParams = this._editEntity.getParams();
- let polygonMaterial = this._editEntity.polygon.material;
- if (polygonMaterial instanceof Cesium.ColorMaterialProperty) {
- let material = this._materialColorProperty({
- color: params.color
- });
- this._editEntity.polygon.material = material;
- this._editEntity.polygon.extrudedHeight = parseFloat(params.height) + parseFloat(
- entityParams.bottomHeight
- );
- this._editEntity.setParams(params);
- }
- },
- _updateCircleProperty(params) {
- let circleMaterial = this._editEntity.ellipse.material;
- if (circleMaterial instanceof CircleMaterialProperty) {
- let material = new CircleMaterialProperty({
- viewer: this._viewer,
- duration: params.duration,
- color: Cesium.Color.fromCssColorString(params.color),
- count: parseFloat(params.count)
- });
- this._editEntity.ellipse.material = material;
- } else if (circleMaterial instanceof Cesium.ColorMaterialProperty) {
- let material = this._materialColorProperty({
- color: params.color
- });
- this._editEntity.ellipse.material = material;
- if (this._editEntity.polyline !== void 0) {
- let newMaterial = this._materialColorProperty({
- color: params.outlineColor
- });
- this._editEntity.polyline.material = newMaterial;
- this._editEntity.polyline.width = parseFloat(params.outlineWidth);
- }
- }
- this._editEntity.setParams(params);
- },
- _updateVideoWallProperty(params) {
- let videoElement = document.getElementById("wallVideo");
- if (videoElement !== null) {
- document.body.removeChild(videoElement);
- }
- videoElement = document.createElement("video");
- videoElement.id = "wallVideo";
- videoElement.setAttribute("crossorigin", "anonymous");
- videoElement.setAttribute("width", "1024px");
- videoElement.setAttribute("height", "256px");
- videoElement.setAttribute("controls", "controls");
- videoElement.setAttribute("src", params.videoUrl);
- videoElement.setAttribute("loop", "loop");
- videoElement.play();
- document.body.appendChild(videoElement);
- let minimumHeights = this._editEntity.wall.minimumHeights._value;
- let maximumHeights = [];
- for (let i2 = 0; i2 < minimumHeights.length; i2++) {
- maximumHeights.push(minimumHeights[i2] + parseFloat(params.height));
- }
- this._editEntity.wall.maximumHeights = maximumHeights;
- this._editEntity.wall.material = videoElement;
- let wallPositions = this._editEntity.wall.positions._value;
- let newPositions = [];
- for (let wallPosition of wallPositions) {
- let transform3 = Cesium.Transforms.eastNorthUpToFixedFrame(wallPosition);
- let m = new Cesium.Matrix4();
- Cesium.Matrix4.setTranslation(Cesium.Matrix4.IDENTITY, new Cesium.Cartesian3(
- parseFloat(params.axisX),
- parseFloat(params.axisY),
- parseFloat(params.axisZ)
- ), m);
- let moveMatrix = Cesium.Matrix4.multiply(transform3, m, transform3);
- let newPosition = new Cesium.Cartesian3();
- Cesium.Matrix4.getTranslation(moveMatrix, newPosition);
- newPositions.push(newPosition);
- }
- this._editEntity.wall.positions = newPositions;
- params.axisX = params.axisY = params.axisZ = 0;
- this._editEntity.setParams(params);
- this._activateEdit(this._editEntity);
- },
- _updateWallProperty(params) {
- let minHeights = this._editEntity.wall.minimumHeights._value;
- let maxHeights = [];
- for (let i2 = 0; i2 < minHeights.length; i2++) {
- maxHeights.push(minHeights[i2] + parseFloat(params.height));
- }
- this._editEntity.wall.maximumHeights = maxHeights;
- this._sketchWallMaxHeights = maxHeights;
- let wallMaterial = this._editEntity.wall.material;
- if (wallMaterial instanceof Cesium.ImageMaterialProperty) {
- let material = this._materialTextImageProperty({
- color: params.color,
- text: params.text
- });
- this._editEntity.wall.material = material;
- } else if (wallMaterial instanceof WallMaterialProperty) {
- let materialImage = this._image_h_l_r;
- if (params.direction === this._param.direction_h && params.order === this._param.order_add) {
- materialImage = this._image_h_l_r;
- } else if (params.direction === this._param.direction_h && params.order === this._param.order_add) {
- materialImage = this._image_h_r_l;
- } else if (params.direction === this._param.direction_v && params.order === this._param.order_minus) {
- materialImage = this._image_v_t_b;
- } else if (params.direction === this._param.direction_v && params.order === this._param.order_add) {
- materialImage = this._image_v_b_t;
- }
- let material = new WallMaterialProperty({
- viewer: this._viewer,
- trailImage: materialImage,
- duration: params.duration,
- color: Cesium.Color.fromCssColorString(params.color),
- param: {
- count: parseFloat(params.count),
- direction: params.direction,
- order: params.order
- }
- });
- this._editEntity.wall.material = material;
- } else if (wallMaterial instanceof Cesium.ColorMaterialProperty) {
- let material = this._materialColorProperty({
- color: params.color
- });
- this._editEntity.wall.material = material;
- }
- this._editEntity.setParams(params);
- },
- rotationEntity(options2) {
- if (this._editEntity === void 0)
- return;
- this._coordinateCalculateEntityOrientation(this._editEntity, options2);
- },
- _getEntityEditData: function(entity) {
- if (entity instanceof Cesium.Entity) {
- let editEntityType = entity.getEntityType();
- if (editEntityType === DrawTools.DrawType.Polyline || editEntityType === DrawTools.DrawType.SpatialLine) {
- return entity.polyline.positions._value;
- } else if (editEntityType === DrawTools.DrawType.Polygon || editEntityType === DrawTools.DrawType.House) {
- let positions = entity.polygon.hierarchy._value.positions;
- if (positions[0].x !== positions[positions.length - 1].x) {
- positions.push(positions[0].clone());
- }
- return positions;
- } else if (editEntityType === DrawTools.DrawType.Rectangle) {
- let rect = entity.rectangle.coordinates._value;
- let gNw = Cesium.Rectangle.northwest(rect);
- if (gNw.height <= 0) {
- let height2 = this._queryHeightFromGeo(Cesium.Math.toDegrees(gNw.longitude), Cesium.Math.toDegrees(gNw.latitude));
- gNw.height = height2;
- }
- let cNw = Cesium.Cartesian3.fromRadians(gNw.longitude, gNw.latitude, gNw.height);
- let gSe = Cesium.Rectangle.southeast(rect);
- if (gSe.height <= 0) {
- let height2 = this._queryHeightFromGeo(Cesium.Math.toDegrees(gSe.longitude), Cesium.Math.toDegrees(gSe.latitude));
- gSe.height = height2;
- }
- let cSe = Cesium.Cartesian3.fromRadians(gSe.longitude, gSe.latitude, gSe.height);
- return [cNw, cSe];
- } else if (editEntityType === DrawTools.DrawType.Circle || editEntityType === DrawTools.DrawType.DynamicCircle) {
- let centerPosition = entity.position._value;
- let radius = entity.ellipse.semiMajorAxis._value;
- let cbPoint = this._calculateCircleBoundaryPoint(centerPosition, radius);
- return [centerPosition, cbPoint];
- } else if (editEntityType === DrawTools.DrawType.NormalWall || editEntityType === DrawTools.DrawType.DynamicWall || editEntityType === DrawTools.DrawType.TextWall) {
- this._sketchWallHeights = [];
- this._sketchWallMaxHeights = [];
- let minHeights = entity.wall.minimumHeights._value;
- let maxHeights = entity.wall.maximumHeights._value;
- for (let i2 = 0; i2 < minHeights.length; i2++) {
- this._sketchWallHeights.push(minHeights[i2]);
- this._sketchWallMaxHeights.push(maxHeights[i2]);
- }
- return entity.wall.positions._value;
- } else if (editEntityType === DrawTools.DrawType.VideoWall) {
- let positions = entity.wall.positions._value;
- return [positions[0].clone()];
- } else {
- return [];
- }
- } else {
- return [];
- }
- },
- _calculateCircleBoundaryPoint: function(centerPosition, radius) {
- let gCenter = Cesium.Ellipsoid.WGS84.cartesianToCartographic(centerPosition);
- let cPoint = point([Cesium.Math.toDegrees(gCenter.longitude), Cesium.Math.toDegrees(
- gCenter.latitude
- )]);
- let boundaryPoint = destination(cPoint, radius / 1e3, 90, {
- units: "kilometers"
- }).geometry.coordinates;
- let height2 = this._queryHeightFromGeo(boundaryPoint[0], boundaryPoint[1]);
- let cbPoint = Cesium.Cartesian3.fromDegrees(boundaryPoint[0], boundaryPoint[1], height2);
- return cbPoint;
- },
- _calculateCenterPosition: function(positions) {
- if (positions === void 0 || positions.length === 0)
- return void 0;
- else if (positions.length === 1) {
- return positions[0];
- } else if (positions.length === 2) {
- let pt0 = this._cartesian3ToGeo(positions[0]);
- let pt1 = this._cartesian3ToGeo(positions[1]);
- let point0 = point([pt0.longitude, pt0.latitude]);
- let point1 = point([pt1.longitude, pt1.latitude]);
- let center2 = midpoint(point0, point1).geometry.coordinates;
- let height2 = this._queryHeightFromGeo(center2[0], center2[1]);
- return Cesium.Cartesian3.fromDegrees(center2[0], center2[1], height2);
- } else {
- let geoPoints = [
- []
- ];
- for (let i2 = 0; i2 < positions.length; i2++) {
- let geoPoint = this._cartesian3ToGeo(positions[i2]);
- geoPoints[0].push([geoPoint.longitude, geoPoint.latitude]);
- }
- geoPoints[0].push(geoPoints[0][0]);
- let polygon$1 = polygon(geoPoints);
- let center2 = centerOfMass(polygon$1).geometry.coordinates;
- let height2 = this._queryHeightFromGeo(center2[0], center2[1]);
- return Cesium.Cartesian3.fromDegrees(center2[0], center2[1], height2);
- }
- },
- _calculateTransformPosition: function(position2, distance2, bearing2, options2) {
- let geoPoint = this._cartesian3ToGeo(position2);
- let point$1 = point([geoPoint.longitude, geoPoint.latitude]);
- let resPoint = destination(point$1, distance2, bearing2, options2).geometry.coordinates;
- let height2 = geoPoint.height;
- if (options2 !== void 0 && options2.calculateHeight !== void 0 && options2.calculateHeight === true) {
- height2 = this._queryHeightFromGeo(resPoint[0], resPoint[1]);
- }
- let cPosition = Cesium.Cartesian3.fromDegrees(
- resPoint[0],
- resPoint[1],
- height2
- );
- return cPosition;
- },
- _unActivateEdit: function() {
- this._clearEditPoint();
- this._removeCoorinateAxis();
- this._closePropertyEditDialog();
- },
- _activateEdit: function(editEntity) {
- let entityType = editEntity.getEntityType();
- let entityIsEdit = editEntity.getIsEdit();
- if (entityIsEdit === void 0 || entityType === void 0 || entityIsEdit === false) {
- return;
- }
- if (entityType === DrawTools.DrawType.OdLine) {
- this._activeteOdlineEdit(editEntity);
- } else {
- this._activeteNormalEdit(editEntity);
- }
- },
- _activeteOdlineEdit: function(editEntity) {
- let _self = this;
- let entityType = editEntity.getEntityType();
- if (entityType === void 0 || entityType !== DrawTools.DrawType.OdLine) {
- return;
- }
- let faterEntityId = editEntity.parent.id;
- this._editOdlineEntities = [];
- for (let entity of this._entities.values) {
- if (entity.parent !== void 0 && entity.parent.id === faterEntityId) {
- this._editOdlineEntities.push(entity);
- }
- }
- if (this._editOdlineEntities.length === 0)
- return;
- this._editEntity = this._editOdlineEntities[0];
- for (let i2 = 0; i2 < this._editOdlineEntities.length; i2++) {
- let entity = this._editOdlineEntities[i2];
- let positions = entity.polyline.positions._value;
- if (i2 === 0) {
- this._createEditOdlineStartPoint(positions.first(), entity);
- this._createEditOdlineEndPoint(positions.last(), entity);
- } else {
- this._createEditOdlineEndPoint(positions.last(), entity);
- }
- }
- if (this._sketchEditHandler === void 0) {
- this._sketchEditHandler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- }
- this._registerLeftDownEvent(this._sketchEditHandler, function(event2) {
- _self._eventEditMouseDown(event2);
- });
- this._registerMouseMoveEvent(this._sketchEditHandler, function(event2) {
- _self._eventEditMouseMove(event2);
- });
- this._registerLeftUpEvent(this._sketchEditHandler, function(event2) {
- _self._eventEditMouseUp(event2);
- });
- },
- _activeteNormalEdit: function(editEntity) {
- let _self = this;
- let positions = this._getEntityEditData(editEntity);
- this._removePointEntitys();
- let entityType = editEntity.getEntityType();
- this._editEntity = editEntity;
- if (entityType === DrawTools.DrawType.Circle || entityType === DrawTools.DrawType.DynamicCircle) {
- this._createEditCenterPoint(positions[0]);
- this._createEditNodePoint(positions, 1);
- } else if (entityType === DrawTools.DrawType.VideoWall) {
- if (!this._isRuntimeApp()) {
- let position2 = positions[0];
- this._removeCoorinateAxis();
- this._createCoordinateAxis(position2);
- }
- } else {
- this._createEditNodePoint(positions);
- let centerPosition = this._calculateCenterPosition(positions);
- if (centerPosition !== void 0) {
- this._createEditCenterPoint(centerPosition);
- }
- }
- if (entityType !== DrawTools.DrawType.Rectangle && entityType !== DrawTools.DrawType.Circle && entityType !== DrawTools.DrawType.DynamicCircle && entityType !== DrawTools.DrawType.VideoWall) {
- if (entityType === DrawTools.DrawType.SpatialLine) {
- this._createEditMiddlePoint(positions, true);
- } else {
- this._createEditMiddlePoint(positions);
- }
- }
- if (this._sketchEditHandler === void 0) {
- this._sketchEditHandler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- }
- this._registerLeftDownEvent(this._sketchEditHandler, function(event2) {
- _self._eventEditMouseDown(event2);
- });
- this._registerMouseMoveEvent(this._sketchEditHandler, function(event2) {
- _self._eventEditMouseMove(event2);
- });
- this._registerLeftUpEvent(this._sketchEditHandler, function(event2) {
- _self._eventEditMouseUp(event2);
- });
- },
- _eventEditMouseDown: function(event2) {
- let _self = this;
- let feature2 = _self._viewer.scene.pick(event2.position);
- if (feature2 != void 0 && feature2.id instanceof Cesium.Entity) {
- let featureType = feature2.id.getEditType();
- if (featureType === void 0)
- return;
- _self._viewer.scene.screenSpaceCameraController.enableRotate = false;
- let entityPosition = feature2.id.position._value;
- _self._editPointEntity = feature2.id;
- _self._setMousePointerStyle();
- if (featureType.type === DrawTools.EditPointType.Node || featureType.type === DrawTools.EditPointType.Middle) {
- _self._entityCallbackPropertyByMouseDown();
- _self._removeEntityByObject(_self._editPointEntity);
- if (_self._sketchEditEntitySpatialName != void 0) {
- _self._removeEntityByName(_self._sketchEditEntitySpatialName);
- }
- } else if (featureType.type === DrawTools.EditPointType.Center) {
- _self._entityCenterMouseDownEvent();
- } else if (featureType.type === DrawTools.EditPointType.OdlineEndNode) {
- _self._removeEntityByObject(_self._editPointEntity);
- _self._editEntity = featureType.joinEntity;
- let params = _self._editEntity.parent.getParams();
- _self._sketchEditPoints = [];
- let joinEntityPositions = _self._editEntity.polyline.positions._value;
- _self._sketchEditPoints.push(joinEntityPositions.first());
- _self._sketchEditPoints.push(joinEntityPositions.last());
- _self._editEntity.polyline.positions = new Cesium.CallbackProperty(function() {
- let positions = _self._calculateOdlinePositios(_self._sketchEditPoints[0], _self._sketchEditPoints[1], parseInt(params.odlineHeight), parseInt(params.odlineCount));
- return positions;
- }, false);
- } else if (featureType.type === DrawTools.EditPointType.OdlineStrartNode) {
- _self._removeEntityByObject(_self._editPointEntity);
- _self._editEntity = featureType.joinEntity;
- let params = _self._editEntity.parent.getParams();
- _self._sketchEditPoints = [];
- let joinEntityPositions = _self._editEntity.polyline.positions._value;
- _self._sketchEditPoints.push(joinEntityPositions.first());
- for (let odEntity of _self._editOdlineEntities) {
- let odEntityPositions = odEntity.polyline.positions._value;
- let lastPosition = odEntityPositions.last();
- _self._sketchEditPoints.push(lastPosition.clone());
- odEntity.polyline.positions = new Cesium.CallbackProperty(function() {
- let positions = _self._calculateOdlinePositios(
- _self._sketchEditPoints[0],
- lastPosition,
- parseInt(params.odlineHeight),
- parseInt(params.odlineCount)
- );
- return positions;
- }, false);
- }
- }
- if (featureType.type === DrawTools.EditPointType.Middle) {
- let index2 = featureType.index;
- _self._sketchEditPoints.splice(index2, 0, entityPosition);
- _self._sketchEditIndex = index2;
- if (_self._sketchWallHeights != void 0 && _self._sketchWallHeights.length > 0) {
- let geoPoint = _self._cartesian3ToGeo(entityPosition);
- let height2 = _self._queryHeightFromGeo(geoPoint.longitude, geoPoint.latitude);
- _self._sketchWallHeights.splice(index2, 0, height2);
- let heightDifference = _self._sketchWallMaxHeights[0] - _self._sketchWallHeights[0];
- _self._sketchWallMaxHeights.splice(index2, 0, height2 + heightDifference);
- }
- _self._tooltipInit("\u62D6\u52A8\u4E2D\u70B9\uFF0C\u6539\u53D8\u5F62\u72B6", event2.position);
- } else if (featureType.type === DrawTools.EditPointType.Node) {
- _self._sketchEditIndex = featureType.index;
- _self._tooltipInit("\u62D6\u52A8\u8282\u70B9\uFF0C\u6539\u53D8\u5F62\u72B6", event2.position);
- } else if (featureType.type === DrawTools.EditPointType.Spatial) {
- _self._sketchEditIndex = featureType.index;
- _self._tooltipInit("\u62D6\u52A8\u8282\u70B9\uFF0C\u6539\u53D8\u9AD8\u5EA6", event2.position);
- } else if (featureType.type === DrawTools.EditPointType.CoordinateAxis) {
- _self._tooltipInit("\u62D6\u52A8\u5750\u6807\u8F74\uFF0C\u6539\u53D8\u4F4D\u7F6E", event2.position);
- } else if (featureType.type === DrawTools.EditPointType.OdlineEndNode || featureType.type === DrawTools.EditPointType.OdlineStrartNode) {
- _self._tooltipInit("\u62D6\u52A8\u8282\u70B9\uFF0C\u6539\u53D8OD\u7EBF\u4F4D\u7F6E", event2.position);
- }
- }
- },
- _eventEditMouseMove: function(event2) {
- let _self = this;
- if (_self._editPointEntity != void 0) {
- let loc2 = _self._transfromFromScreenPoint(event2.endPosition);
- if (!Cesium.defined(loc2.sLocation))
- return;
- _self._editPosition = loc2.sLocation;
- let editEntityType = _self._editPointEntity.getEditType();
- if (editEntityType.type === DrawTools.EditPointType.Node) {
- _self._sketchEditPoints[_self._sketchEditIndex] = loc2.sLocation;
- let editEntityType2 = _self._editEntity.getEntityType();
- if (editEntityType2 != DrawTools.DrawType.Rectangle && editEntityType2 != DrawTools.DrawType.Circle && editEntityType2 != DrawTools.DrawType.DynamicCircle) {
- if ((editEntityType2 === DrawTools.DrawType.Polygon || editEntityType2 === DrawTools.DrawType.House) && _self._sketchEditIndex === 0) {
- _self._sketchEditPoints[_self._sketchEditPoints.length - 1] = loc2.sLocation;
- } else if (editEntityType2 === DrawTools.DrawType.NormalWall || editEntityType2 === DrawTools.DrawType.DynamicWall || editEntityType2 === DrawTools.DrawType.TextWall) {
- _self._sketchWallHeights[_self._sketchEditIndex] = loc2.gLocation.height;
- }
- _self._removeEntityByName(_self._sketchEditEntityMiddleName);
- if (editEntityType2 === DrawTools.DrawType.SpatialLine) {
- _self._createEditMiddlePoint(_self._sketchEditPoints, true);
- } else {
- _self._createEditMiddlePoint(_self._sketchEditPoints);
- }
- }
- } else if (editEntityType.type === DrawTools.EditPointType.Middle) {
- _self._sketchEditPoints[_self._sketchEditIndex] = loc2.sLocation;
- } else if (editEntityType.type === DrawTools.EditPointType.Center) {
- _self._entityCenterMouseMoveEvent(event2);
- } else if (editEntityType.type === DrawTools.EditPointType.Spatial) {
- let ellipsoid = _self._viewer.scene.globe.ellipsoid;
- let cartesian = _self._viewer.camera.pickEllipsoid(
- event2.endPosition,
- ellipsoid
- );
- let bottomPoint = _self._sketchEditPoints[_self._sketchEditIndex];
- let heightDifference = cartesian.z - bottomPoint.z;
- if (heightDifference > 0 && heightDifference < 500) {
- for (let i2 = 0; i2 < _self._sketchWallHeights.length; i2++) {
- _self._sketchWallMaxHeights[i2] = _self._sketchWallHeights[i2] + heightDifference;
- }
- }
- } else if (editEntityType.type === DrawTools.EditPointType.OdlineEndNode) {
- _self._sketchEditPoints[_self._sketchEditPoints.length - 1] = loc2.sLocation;
- } else if (editEntityType.type === DrawTools.EditPointType.OdlineStrartNode) {
- _self._sketchEditPoints[0] = loc2.sLocation;
- }
- _self._tooltipInit("\u62AC\u8D77\u9F20\u6807\uFF0C\u5B8C\u6210\u66F4\u6539", event2.endPosition);
- }
- },
- _eventEditMouseUp: function(event2) {
- let _self = this;
- if (_self._editPointEntity != void 0) {
- _self._viewer.scene.screenSpaceCameraController.enableRotate = true;
- _self._tooltipRemove();
- _self._setMouseDefaultStyle();
- let editEntityPointType = _self._editPointEntity.getEditType().type;
- let entityType = _self._editEntity.getEntityType();
- if (editEntityPointType === DrawTools.EditPointType.CoordinateAxis)
- ;
- else if (editEntityPointType === DrawTools.EditPointType.OdlineEndNode) {
- let params = _self._editEntity.parent.getParams();
- let positions = _self._calculateOdlinePositios(_self._sketchEditPoints[0], _self._sketchEditPoints[1], parseInt(params.odlineHeight), parseInt(params.odlineCount));
- _self._editEntity.polyline.positions = positions;
- _self._createEditOdlineEndPoint(_self._sketchEditPoints[1], _self._editEntity);
- } else if (editEntityPointType === DrawTools.EditPointType.OdlineStrartNode) {
- let params = _self._editEntity.parent.getParams();
- let index2 = 1;
- for (let odEntity of _self._editOdlineEntities) {
- let lastPosition = _self._sketchEditPoints[index2++];
- let positions = _self._calculateOdlinePositios(
- _self._sketchEditPoints[0],
- lastPosition,
- parseInt(params.odlineHeight),
- parseInt(params.odlineCount)
- );
- odEntity.polyline.positions = positions;
- }
- _self._createEditOdlineStartPoint(_self._sketchEditPoints[0], _self._editOdlineEntities[0]);
- } else {
- if (editEntityPointType === DrawTools.EditPointType.Node || editEntityPointType === DrawTools.EditPointType.Middle) {
- _self._entityCallbackPropertyByMouseUp();
- } else if (editEntityPointType === DrawTools.EditPointType.Center) {
- _self._entityCenterMouseUpEvent(event2);
- }
- _self._removeEntityByName(_self._sketchEditEntityNodeName);
- _self._removeEntityByName(_self._sketchEditEntityMiddleName);
- _self._removeEntityByName(_self._sketchEditEntityCenterName);
- if (entityType === DrawTools.DrawType.Circle || entityType === DrawTools.DrawType.DynamicCircle) {
- let centerPosition = _self._editEntity.position._value;
- let boundaryPosition = _self._calculateCircleBoundaryPoint(
- centerPosition,
- _self._sketchEllipseRadius
- );
- _self._sketchEditPoints[0] = centerPosition;
- _self._sketchEditPoints[1] = boundaryPosition;
- _self._createEditNodePoint(_self._sketchEditPoints, 1);
- _self._createEditCenterPoint(centerPosition);
- } else {
- _self._createEditNodePoint(_self._sketchEditPoints);
- let centerPosition = _self._calculateCenterPosition(_self._sketchEditPoints);
- _self._createEditCenterPoint(centerPosition);
- }
- if (entityType != DrawTools.DrawType.Rectangle && entityType != DrawTools.DrawType.Circle && entityType != DrawTools.DrawType.DynamicCircle) {
- if (entityType === DrawTools.DrawType.SpatialLine) {
- _self._createEditMiddlePoint(_self._sketchEditPoints, true);
- } else {
- _self._createEditMiddlePoint(_self._sketchEditPoints);
- }
- }
- }
- _self._editPointEntity = void 0;
- }
- },
- _entityCenterMouseDownEvent: function() {
- let _self = this;
- let entityPosition = this._editEntity.position._value;
- this._removeEntityByName(this._sketchEditEntityNodeName);
- this._removeEntityByName(this._sketchEditEntityMiddleName);
- this._removeEntityByName(this._sketchEditEntityCenterName);
- this._startPoint = entityPosition;
- this._startMovePoints = [];
- this._movePoint = entityPosition;
- let editEntityType = this._editEntity.getEntityType();
- if (editEntityType === DrawTools.DrawType.Circle || editEntityType === DrawTools.DrawType.DynamicCircle) {
- if (this._editEntity.polyline !== void 0) {
- for (let i2 = 0; i2 < this._ellipseOutlineCoordinates.length; i2++) {
- this._startMovePoints.push(this._ellipseOutlineCoordinates[i2]);
- }
- this._editEntity.polyline.positions = new Cesium.CallbackProperty(
- function() {
- return _self._ellipseOutlineCoordinates;
- },
- false
- );
- }
- this._editEntity.position = new Cesium.CallbackProperty(function() {
- return _self._movePoint;
- }, false);
- } else if (editEntityType === DrawTools.DrawType.Polygon || editEntityType === DrawTools.DrawType.House) {
- for (let i2 = 0; i2 < this._sketchEditPoints.length; i2++) {
- this._startMovePoints.push(this._sketchEditPoints[i2]);
- }
- _self._editEntity.polygon.hierarchy = new Cesium.CallbackProperty(function() {
- return {
- positions: _self._sketchEditPoints
- };
- }, false);
- if (_self._editEntity.polyline != void 0) {
- _self._editEntity.polyline.positions = new Cesium.CallbackProperty(function() {
- return _self._sketchEditPoints;
- }, false);
- }
- } else if (editEntityType === DrawTools.DrawType.Polyline || editEntityType === DrawTools.DrawType.SpatialLine) {
- for (let i2 = 0; i2 < this._sketchEditPoints.length; i2++) {
- this._startMovePoints.push(this._sketchEditPoints[i2]);
- }
- _self._editEntity.polyline.positions = new Cesium.CallbackProperty(function() {
- return _self._sketchEditPoints;
- }, false);
- } else if (editEntityType === DrawTools.DrawType.Rectangle) {
- for (let i2 = 0; i2 < this._sketchEditPoints.length; i2++) {
- this._startMovePoints.push(this._sketchEditPoints[i2]);
- }
- _self._editEntity.rectangle.coordinates = new Cesium.CallbackProperty(_self._callUpdateRectangleCoordinates(_self._sketchEditPoints), false);
- if (_self._editEntity.polyline != void 0) {
- _self._editEntity.polyline.positions = new Cesium.CallbackProperty(
- _self._callUpdateRectangleOutlineCoordinates(),
- false
- );
- }
- }
- },
- _entityCenterMouseMoveEvent: function(event2) {
- this._calculatePositionsByCenter(event2.endPosition, false);
- },
- _calculatePositionsByCenter: function(screenPosition, calculateHeight) {
- let strLoc = this._cartesian3ToGeo(this._startPoint);
- let endLoc = this._transfromFromScreenPoint(screenPosition);
- var point1 = point([strLoc.longitude, strLoc.latitude]);
- var point2 = point([endLoc.gLocation.lng, endLoc.gLocation.lat]);
- var bearing$1 = bearing(point1, point2);
- var options2 = {
- units: "kilometers",
- calculateHeight
- };
- var distance$1 = distance(point1, point2, options2);
- let editEntityType = this._editEntity.getEntityType();
- if (editEntityType === DrawTools.DrawType.Circle || editEntityType === DrawTools.DrawType.DynamicCircle) {
- for (let i2 = 0; i2 < this._startMovePoints.length; i2++) {
- let position2 = this._calculateTransformPosition(
- this._startMovePoints[i2],
- distance$1,
- bearing$1,
- options2
- );
- this._ellipseOutlineCoordinates[i2] = position2.clone();
- }
- this._movePoint = endLoc.sLocation;
- } else {
- for (let i2 = 0; i2 < this._startMovePoints.length; i2++) {
- let position2 = this._calculateTransformPosition(
- this._startMovePoints[i2],
- distance$1,
- bearing$1,
- options2
- );
- this._sketchEditPoints[i2] = position2.clone();
- }
- }
- },
- _entityCenterMouseUpEvent: function(event2) {
- this._calculatePositionsByCenter(event2.position, true);
- let _self = this;
- let editEntityType = this._editEntity.getEntityType();
- if (editEntityType === DrawTools.DrawType.Circle || editEntityType === DrawTools.DrawType.DynamicCircle) {
- this._editEntity.position = this._movePoint;
- if (this._editEntity.polyline !== void 0) {
- this._editEntity.polyline.positions = this._ellipseOutlineCoordinates;
- }
- } else if (editEntityType === DrawTools.DrawType.Polyline || editEntityType === DrawTools.DrawType.SpatialLine) {
- this._editEntity.polyline.positions = this._sketchEditPoints;
- } else if (editEntityType === DrawTools.DrawType.Polygon || editEntityType === DrawTools.DrawType.House) {
- this._editEntity.polygon.hierarchy = {
- positions: _self._sketchEditPoints
- };
- if (this._editEntity.polyline != void 0) {
- this._editEntity.polyline.positions = this._sketchEditPoints;
- }
- } else if (editEntityType === DrawTools.DrawType.Rectangle) {
- this._editEntity.rectangle.coordinates = Cesium.Rectangle.fromDegrees(_self._rectangleCoordinates[0], _self._rectangleCoordinates[1], _self._rectangleCoordinates[2], _self._rectangleCoordinates[3]);
- if (this._editEntity.polyline != void 0) {
- this._editEntity.polyline.positions = _self._rectangleOutlineCoordinates;
- }
- }
- },
- _entityCallbackPropertyByMouseUp: function() {
- let _self = this;
- let entityType = _self._editEntity.getEntityType();
- if (entityType === DrawTools.DrawType.Polyline) {
- _self._editEntity.polyline.positions = _self._sketchEditPoints;
- } else if (entityType === DrawTools.DrawType.Polygon || entityType === DrawTools.DrawType.House) {
- _self._editEntity.polygon.hierarchy = {
- positions: _self._sketchEditPoints
- };
- if (_self._editEntity.polyline != void 0) {
- let polygonPositions = _self._editEntity.polygon.hierarchy._value.positions;
- let linePositions = [];
- for (let i2 = 0; i2 < polygonPositions.length; i2++) {
- linePositions.push(polygonPositions[i2].clone());
- }
- if (linePositions[0].x !== linePositions[linePositions.length - 1].x) {
- linePositions.push(linePositions[0].clone());
- }
- _self._editEntity.polyline.positions = linePositions;
- }
- } else if (entityType === DrawTools.DrawType.Rectangle) {
- _self._editEntity.rectangle.coordinates = Cesium.Rectangle.fromDegrees(_self._rectangleCoordinates[0], _self._rectangleCoordinates[1], _self._rectangleCoordinates[2], _self._rectangleCoordinates[3]);
- if (_self._editEntity.polyline != void 0) {
- _self._editEntity.polyline.positions = _self._rectangleOutlineCoordinates;
- }
- } else if (entityType === DrawTools.DrawType.Circle || entityType === DrawTools.DrawType.DynamicCircle) {
- _self._editEntity.ellipse.semiMajorAxis = _self._sketchEllipseRadius;
- _self._editEntity.ellipse.semiMinorAxis = _self._sketchEllipseRadius;
- if (_self._editEntity.polyline != void 0) {
- _self._editEntity.polyline.positions = _self._ellipseOutlineCoordinates;
- }
- } else if (entityType === DrawTools.DrawType.NormalWall || entityType === DrawTools.DrawType.DynamicWall || entityType === DrawTools.DrawType.TextWall) {
- _self._editEntity.wall.positions = _self._sketchEditPoints;
- _self._editEntity.wall.minimumHeights = _self._sketchWallHeights;
- _self._editEntity.wall.maximumHeights = _self._sketchWallMaxHeights;
- }
- },
- _entityCallbackPropertyByMouseDown: function() {
- let _self = this;
- let entityType = _self._editEntity.getEntityType();
- if (entityType === DrawTools.DrawType.Polyline || entityType === DrawTools.DrawType.SpatialLine) {
- _self._editEntity.polyline.positions = new Cesium.CallbackProperty(
- function() {
- return _self._sketchEditPoints;
- },
- false
- );
- } else if (entityType === DrawTools.DrawType.Polygon || entityType === DrawTools.DrawType.House) {
- _self._editEntity.polygon.hierarchy = new Cesium.CallbackProperty(
- function() {
- return {
- positions: _self._sketchEditPoints
- };
- },
- false
- );
- if (_self._editEntity.polyline != void 0) {
- _self._editEntity.polyline.positions = new Cesium.CallbackProperty(
- function() {
- let polygonPositions = _self._sketchEditPoints;
- let linePositions = [];
- for (let i2 = 0; i2 < polygonPositions.length; i2++) {
- linePositions.push(polygonPositions[i2].clone());
- }
- if (linePositions[0].x !== linePositions[linePositions.length - 1].x) {
- linePositions.push(linePositions[0].clone());
- }
- return linePositions;
- },
- false
- );
- }
- } else if (entityType === DrawTools.DrawType.Rectangle) {
- _self._editEntity.rectangle.coordinates = new Cesium.CallbackProperty(
- _self._callUpdateRectangleCoordinates(_self._sketchEditPoints),
- false
- );
- if (_self._editEntity.polyline != void 0) {
- _self._editEntity.polyline.positions = new Cesium.CallbackProperty(
- _self._callUpdateRectangleOutlineCoordinates(),
- false
- );
- }
- } else if (entityType === DrawTools.DrawType.Circle || entityType === DrawTools.DrawType.DynamicCircle) {
- if (_self._editPointEntity.getEditType().index === 1) {
- _self._editEntity.ellipse.semiMajorAxis = new Cesium.CallbackProperty(
- _self._callUpdateEllipseMinorAxis(_self._sketchEditPoints),
- false
- );
- _self._editEntity.ellipse.semiMinorAxis = new Cesium.CallbackProperty(
- _self._callUpdateEllipseMinorAxis(_self._sketchEditPoints),
- false
- );
- }
- if (_self._editEntity.polyline != void 0) {
- _self._editEntity.polyline.positions = new Cesium.CallbackProperty(
- _self._callEllipseOutlineCoordinate(_self._sketchEditPoints),
- false
- );
- }
- } else if (entityType === DrawTools.DrawType.NormalWall || entityType === DrawTools.DrawType.DynamicWall || entityType === DrawTools.DrawType.TextWall) {
- _self._editEntity.wall.positions = new Cesium.CallbackProperty(function() {
- return _self._sketchEditPoints;
- }, false);
- _self._editEntity.wall.minimumHeights = new Cesium.CallbackProperty(function() {
- return _self._sketchWallHeights;
- }, false);
- _self._editEntity.wall.maximumHeights = new Cesium.CallbackProperty(function() {
- return _self._sketchWallMaxHeights;
- }, false);
- }
- },
- _createEditPointEntity(options2) {
- let _self = this;
- if (options2 === void 0 || options2.position === void 0)
- return;
- if (options2 === void 0 || options2.editType === void 0)
- return;
- let color2 = options2.color != void 0 ? options2.color : [255, 0, 0, 1];
- let size = options2.size != void 0 && typeof options2.size === "number" ? options2.size : 9;
- let outlineWidth = options2.outlineWidth != void 0 && typeof options2.outlineWidth === "number" ? options2.outlineWidth : 1;
- let outlineColor = options2.outlineColor != void 0 ? options2.outlineColor : [255, 255, 255, 1];
- let pointEntity = new Cesium.Entity({
- name: options2.name != void 0 ? options2.name : _self._sketchEntityName,
- position: options2.position,
- point: {
- show: true,
- pixelSize: size,
- heightReference: Cesium.HeightReference.NONE,
- color: _self._toColorFromArray(color2),
- outlineWidth,
- outlineColor: _self._toColorFromArray(outlineColor),
- disableDepthTestDistance: 15e11
- }
- });
- pointEntity.setEditType(options2.editType);
- _self._entities.add(pointEntity);
- },
- _createEditNodePoint(positions, startIndex) {
- this._sketchEditEntityNodeName = "SketchEditEntityNode";
- let _self = this;
- this._sketchEditPoints = [];
- let strIndex = startIndex === void 0 ? 0 : startIndex;
- for (let i2 = 0; i2 < positions.length; i2++) {
- let position2 = positions[i2];
- this._sketchEditPoints.push(position2.clone());
- if (i2 < strIndex)
- continue;
- if (i2 !== 0 && position2.x === positions[0].x && position2.y === positions[0].y && position2.z === positions[0].z) {
- continue;
- }
- let geoPoint = this._cartesian3ToGeo(position2);
- let height2 = this._queryHeightFromGeo(geoPoint.longitude, geoPoint.latitude);
- let newPosition = Cesium.Cartesian3.fromDegrees(geoPoint.longitude, geoPoint.latitude, height2);
- _self._createEditPointEntity({
- name: _self._sketchEditEntityNodeName,
- position: newPosition,
- size: 12,
- color: [0, 0, 255, 1],
- editType: {
- type: DrawTools.EditPointType.Node,
- index: i2
- }
- });
- }
- },
- _createEditSpatialPoint(positions, heights, startIndex) {
- return;
- },
- _createEditMiddlePoint(positions, isSpatial = false) {
- this._sketchEditEntityMiddleName = "SketchEditEntityMiddle";
- let _self = this;
- if (!isSpatial) {
- for (let i2 = 1; i2 < positions.length; i2++) {
- let p1 = positions[i2 - 1];
- let p2 = positions[i2];
- let pCenter = this._calculateMiddlePoint(p1, p2);
- this._createEditPointEntity({
- name: _self._sketchEditEntityMiddleName,
- position: pCenter,
- size: 9,
- color: [255, 255, 0, 1],
- editType: {
- type: DrawTools.EditPointType.Middle,
- index: i2
- }
- });
- }
- } else {
- for (let i2 = 1; i2 < positions.length; i2++) {
- let p1 = positions[i2 - 1];
- let p2 = positions[i2];
- let pCenter = {
- x: (p1.x + p2.x) / 2,
- y: (p1.y + p2.y) / 2,
- z: (p1.z + p2.z) / 2
- };
- this._createEditPointEntity({
- name: _self._sketchEditEntityMiddleName,
- position: pCenter,
- size: 9,
- color: [255, 255, 0, 1],
- editType: {
- type: DrawTools.EditPointType.Middle,
- index: i2
- }
- });
- }
- }
- },
- _createEditCenterPoint(position2) {
- let _self = this;
- this._sketchEditEntityCenterName = "SketchEditEntityCenter";
- this._createEditPointEntity({
- name: _self._sketchEditEntityCenterName,
- position: position2,
- size: 12,
- color: [0, 255, 0, 0.1],
- outlineWidth: 2,
- outlineColor: [255, 255, 255, 1],
- editType: {
- type: DrawTools.EditPointType.Center
- }
- });
- if (this._editEntity != void 0) {
- this._editEntity.position = position2.clone();
- }
- },
- _createEditOdlineEndPoint(position2, joinEntity) {
- this._sketchEditEntityNodeName = "SketchEditEntityNode";
- let _self = this;
- let geoPoint = this._cartesian3ToGeo(position2);
- let height2 = this._queryHeightFromGeo(geoPoint.longitude, geoPoint.latitude);
- Cesium.Cartesian3.fromDegrees(geoPoint.longitude, geoPoint.latitude, height2);
- _self._createEditPointEntity({
- name: _self._sketchEditEntityNodeName,
- position: position2,
- size: 12,
- color: [0, 0, 255, 1],
- editType: {
- type: DrawTools.EditPointType.OdlineEndNode,
- joinEntity
- }
- });
- },
- _createEditOdlineStartPoint(position2, joinEntity) {
- this._sketchEditEntityNodeName = "SketchEditEntityNode";
- let _self = this;
- let geoPoint = this._cartesian3ToGeo(position2);
- let height2 = this._queryHeightFromGeo(geoPoint.longitude, geoPoint.latitude);
- Cesium.Cartesian3.fromDegrees(geoPoint.longitude, geoPoint.latitude, height2);
- _self._createEditPointEntity({
- name: _self._sketchEditEntityNodeName,
- position: position2,
- size: 12,
- color: [0, 255, 0, 0.6],
- editType: {
- type: DrawTools.EditPointType.OdlineStrartNode,
- joinEntity
- }
- });
- },
- _calculateMiddlePoint(position1, position2) {
- let g1 = Cesium.Ellipsoid.WGS84.cartesianToCartographic(position1);
- let g2 = Cesium.Ellipsoid.WGS84.cartesianToCartographic(position2);
- let pt1 = [Cesium.Math.toDegrees(g1.longitude), Cesium.Math.toDegrees(g1.latitude)];
- let pt2 = [Cesium.Math.toDegrees(g2.longitude), Cesium.Math.toDegrees(g2.latitude)];
- let tpt1 = point(pt1);
- let tpt2 = point(pt2);
- let midpoint$1 = midpoint(tpt1, tpt2).geometry.coordinates;
- let height2 = this._queryHeightFromGeo(midpoint$1[0], midpoint$1[1]);
- let result = Cesium.Cartesian3.fromDegrees(midpoint$1[0], midpoint$1[1], height2);
- return result;
- },
- _cartesian3ToGeo: function(position2) {
- let g = Cesium.Ellipsoid.WGS84.cartesianToCartographic(position2);
- return {
- longitude: Cesium.Math.toDegrees(g.longitude),
- latitude: Cesium.Math.toDegrees(g.latitude),
- height: g.height
- };
- },
- _queryHeightFromGeo: function(longitude, latitude) {
- if (longitude === void 0 || latitude === void 0 || typeof longitude != "number" || typeof latitude != "number")
- return 0;
- let rLng = Cesium.Math.toRadians(longitude);
- let rLat = Cesium.Math.toRadians(latitude);
- let cartographic = new Cesium.Cartographic(rLng, rLat);
- let noQueryEntities = [];
- for (let i2 = 0; i2 < this._entities.values.length; i2++) {
- if (this._entities.values[i2].name === this._sketchEntityName) {
- noQueryEntities.push(this._entities.values[i2]);
- }
- }
- let height2 = this._viewer.scene.sampleHeight(cartographic, noQueryEntities);
- if (height2 === void 0)
- return 0;
- else
- return height2;
- },
- _queryHeightFromGeoAsync: function(longitude, latitude, callComplete) {
- if (longitude === void 0 || latitude === void 0 || typeof longitude != "number" || typeof latitude != "number")
- return 0;
- let rLng = Cesium.Math.toRadians(longitude);
- let rLat = Cesium.Math.toRadians(latitude);
- let cartographic = new Cesium.Cartographic(rLng, rLat);
- let promise = this._viewer.scene.sampleHeightMostDetailed([cartographic]);
- promise.then(function(updatedPositions) {
- if (callComplete)
- callComplete(updatedPositions[0].height);
- });
- },
- _clearEditPoint: function() {
- if (this._sketchEditHandler != void 0) {
- this._sketchEditHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_DOWN);
- this._sketchEditHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_UP);
- this._sketchEditHandler.removeInputAction(Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- }
- this._sketchEditPoints = [];
- this._sketchEditIndex = void 0;
- this._editEntity = void 0;
- this._removeEntityByName(this._sketchEditEntityNodeName);
- this._removeEntityByName(this._sketchEditEntityMiddleName);
- this._removeEntityByName(this._sketchEditEntityCenterName);
- this._removeEntityByName(this._sketchEditEntitySpatialName);
- }
- });
- Object.assign(DrawTools.prototype, {
- _checkColor: function(color2) {
- if (color2 === void 0 || color2 === null)
- return false;
- if (typeof color2 != "number")
- return false;
- let intColor = parseInt(color2);
- if (intColor < 0 || intColor > 255)
- return false;
- return true;
- },
- _checkAlpha: function(alpha) {
- if (alpha === void 0 || alpha === null)
- return false;
- if (typeof alpha != "number")
- return false;
- let floatAlpha = parseFloat(alpha);
- if (floatAlpha < 0 || floatAlpha > 1)
- return false;
- return true;
- },
- _checkColorAndAlpha: function(colorAndAlpah) {
- let setColor = void 0;
- if (!colorAndAlpah || colorAndAlpah.length === void 0 || colorAndAlpah.length === 0)
- return void 0;
- if (colorAndAlpah.length === 1 && this._checkColor(colorAndAlpah[0])) {
- setColor = [colorAndAlpah[0], 0, 0, 1];
- } else if (colorAndAlpah.length === 2 && this._checkColor(colorAndAlpah[0]) && this._checkColor(
- colorAndAlpah[1]
- )) {
- setColor = [colorAndAlpah[0], colorAndAlpah[1], 0, 1];
- } else if (colorAndAlpah.length === 3 && this._checkColor(colorAndAlpah[0]) && this._checkColor(
- colorAndAlpah[1]
- ) && this._checkColor(colorAndAlpah[2])) {
- setColor = [colorAndAlpah[0], colorAndAlpah[1], colorAndAlpah[2], 1];
- } else if (colorAndAlpah.length === 4 && this._checkColor(colorAndAlpah[0]) && this._checkColor(
- colorAndAlpah[1]
- ) && this._checkColor(colorAndAlpah[2]) && this._checkAlpha(
- colorAndAlpah[3]
- )) {
- setColor = [colorAndAlpah[0], colorAndAlpah[1], colorAndAlpah[2], colorAndAlpah[3]];
- }
- return setColor;
- }
- });
- Object.assign(DrawTools.prototype, {
- _initOperationDom: function() {
- let _self = this;
- this._operationDomId = "drawButtonDiv";
- this._operationDom = document.getElementById(this._operationDomId);
- this._removeOperationDom();
- this._createOperationMainDom();
- if ([
- DrawTools.DrawType.Rectangle,
- DrawTools.DrawType.Circle,
- DrawTools.DrawType.DynamicCircle,
- DrawTools.DrawType.VideoWall
- ].indexOf(this._drawType) === -1) {
- let btnUndo = this._createOperationUndoButtonDom();
- btnUndo.onclick = function() {
- _self._operationExecuteEvent(Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- };
- }
- if ([
- DrawTools.DrawType.Rectangle,
- DrawTools.DrawType.Circle,
- DrawTools.DrawType.DynamicCircle,
- DrawTools.DrawType.VideoWall
- ] === -1) {
- let btnCompletion = this._crateOperationCompletionButtonDom();
- btnCompletion.onclick = function() {
- _self._operationExecuteEvent(Cesium.ScreenSpaceEventType.LEFT_CLICK);
- };
- } else {
- let btnCompletion = this._crateOperationCompletionButtonDom();
- btnCompletion.onclick = function() {
- _self._operationExecuteEvent(Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
- };
- }
- },
- _operationExecuteEvent(eventType) {
- if (this._drawEventHandler !== void 0 && this._drawEventHandler.isDestroyed() === false) {
- let event2 = {
- position: new Cesium.Cartesian2(300, 300)
- };
- let action = this._drawEventHandler.getInputAction(eventType);
- action(event2);
- }
- },
- _createOperationMainDom: function() {
- this._operationDom = document.createElement("div");
- this._operationDom.id = this._operationDomId;
- this._operationDom.style.width = "80px";
- this._operationDom.style.backgroundColor = "rgba(5, 45, 155, 0.7)";
- this._operationDom.style.borderRadius = "5px";
- this._operationDom.style.display = "flex";
- this._operationDom.style.flexDirection = "column";
- this._operationDom.style.padding = "8px";
- this._operationDom.style.justifyContent = "center";
- this._operationDom.style.position = "absolute";
- this._operationDom.style.bottom = "150px";
- this._operationDom.style.right = "10px";
- document.body.appendChild(this._operationDom);
- },
- _createOperationUndoButtonDom: function() {
- let btnUndo = document.createElement("button");
- btnUndo.id = "btnDrawBackout";
- btnUndo.style.height = "30px";
- btnUndo.style.marginBottom = "8px";
- btnUndo.style.backgroundColor = "rgba(52, 137, 255, 1.0)";
- btnUndo.style.color = "rgb(255, 255, 255)";
- btnUndo.style.border = "0px solid red";
- btnUndo.style.borderRadius = "5px";
- btnUndo.innerHTML = "\u56DE\u9000";
- btnUndo.style.fontSize = "13px";
- btnUndo.style.cursor = "pointer";
- this._operationDom.appendChild(btnUndo);
- return btnUndo;
- },
- _crateOperationCompletionButtonDom: function() {
- let btnCompletion = document.createElement("button");
- btnCompletion.id = "btnDrawComplete";
- btnCompletion.style.height = "30px";
- btnCompletion.style.backgroundColor = "rgba(88, 185, 45, 1.0)";
- btnCompletion.style.color = "rgb(255, 255, 255)";
- btnCompletion.style.border = "0px solid red";
- btnCompletion.style.borderRadius = "5px";
- btnCompletion.innerHTML = "\u5B8C\u6210";
- btnCompletion.style.fontSize = "13px";
- btnCompletion.style.cursor = "pointer";
- this._operationDom.appendChild(btnCompletion);
- return btnCompletion;
- },
- _removeOperationDom: function() {
- if (this._operationDom !== null && this._operationDom !== void 0) {
- document.body.removeChild(this._operationDom);
- this._operationDom = void 0;
- }
- },
- _createOperationDom: function() {
- if (this._isRuntimeApp()) {
- this._initOperationDom();
- }
- }
- });
- Object.assign(DrawTools.prototype, {
- _openPropertyEditDialog: function(params, callEdit, callRemove) {
- this._editPropertyDialogDomId = "dialog-property-dom";
- this._registerDOMPropertyEdit = "dialog-edit-property";
- let PropertyEditComponent = customElements.get(this._registerDOMPropertyEdit);
- if (PropertyEditComponent === void 0) {
- PropertyEditComponent = defineCustomElement(DialogEditProperty$2);
- customElements.define(this._registerDOMPropertyEdit, PropertyEditComponent);
- }
- this._closePropertyEditDialog();
- let dialogPropertyElement = new PropertyEditComponent({
- params
- });
- dialogPropertyElement.id = this._editPropertyDialogDomId;
- dialogPropertyElement.showDialog = true;
- document.body.appendChild(dialogPropertyElement);
- dialogPropertyElement.addEventListener(
- "submit",
- (e) => {
- if (callEdit)
- callEdit(e.detail[0]);
- },
- false
- );
- dialogPropertyElement.addEventListener(
- "remove",
- (e) => {
- if (callRemove)
- callRemove();
- },
- false
- );
- },
- _closePropertyEditDialog() {
- let dom2 = document.getElementById(this._editPropertyDialogDomId);
- if (dom2 !== null && dom2 !== void 0) {
- document.body.removeChild(dom2);
- }
- }
- });
- DrawTools.DrawType = Object.freeze({
- Point: "point",
- Polyline: "polyline",
- ArrowPolyline: "arrowPolyline",
- DynamicPolyline: "dynamicPolyline",
- GrowPolyline: "\u53D1\u5149\u7EBF",
- OutlinePolyline: "outlinePolyline",
- OdLine: "odLine",
- Polygon: "polygon",
- SpatialLine: "spatialLine",
- Circle: "circle",
- DynamicCircle: "dynamicCircle",
- Rectangle: "rectangle",
- NormalWall: "normalWall",
- DynamicWall: "dynamicWall",
- House: "house",
- TextWall: "text",
- VideoWall: "videoWall"
- });
- DrawTools.IconType = Object.freeze({
- Normal: "normal",
- Blue: "blue",
- Green: "green",
- Violet: "violter"
- });
- DrawTools.EditPointType = Object.freeze({
- Node: "node",
- Middle: "middle",
- Center: "center",
- CoordinateAxis: "coordinateAxis",
- OdlineStrartNode: "odlineStartNode",
- OdlineEndNode: "odlineEndNode"
- });
- DrawTools.WallType = Object.freeze({
- ColorWall: "colorWall",
- DynamicWall: "dynamicWall",
- TextWall: "textWall"
- });
- DrawTools.CircleType = Object.freeze({
- ColorCircle: "colorCircle",
- DynamicCircle: "dynamicCircle"
- });
- DrawTools.PolylineType = Object.freeze({
- NormalPolyline: "normalPolyline",
- ArrowsPolyline: "arrowsPolyline",
- DynamicPolyline: "dynamicPolyline",
- DottedPolyline: "dottedPolyline",
- GrowPolyline: "growPolyline",
- OutlinePolyline: "outlinePolyline"
- });
- DrawTools.PolygonType = Object.freeze({
- NormalPolygon: "normalPolygon",
- HousePolygon: "housePolygon"
- });
- DrawTools.RuntimeEnvironment = Object.freeze({
- App: "app",
- Web: "web"
- });
- class WallMaterialProperty {
- constructor(options2) {
- this._viewer = options2.viewer;
- this._definitionChanged = new Cesium.Event();
- this._color = void 0;
- this.color = options2.color || Cesium.Color.BLUE;
- this.duration = options2.duration || 1e3;
- this.trailImage = options2.trailImage;
- this._time = new Date().getTime();
- this._materialTypeName = "WallMaterial" + this._guid();
- this._param = {
- color: this.color._value.toCssColorString(),
- image: this.trailImage,
- duration: this.duration,
- count: 0,
- direction: "",
- order: ""
- };
- Cesium.Material._materialCache.addMaterial(this._materialTypeName, {
- fabric: {
- type: this._materialTypeName,
- uniforms: {
- time: -20,
- color: new Cesium.Color(1, 0, 0, 0.5),
- image: options2.trailImage
- },
- source: this._getDirectionWallShader(options2.param)
- },
- translucent: function(material) {
- return true;
- }
- });
- }
- _guid() {
- function S4() {
- return ((1 + Math.random()) * 65536 | 0).toString(16).substring(1);
- }
- return S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4();
- }
- getType(time) {
- return this._materialTypeName;
- }
- getValue(time, result) {
- if (!Cesium.defined(result)) {
- result = {};
- }
- result.color = Cesium.Property.getValueOrClonedDefault(this._color, time, Cesium.Color.BLUE, result.color);
- result.image = this.trailImage;
- if (this.duration) {
- result.time = (new Date().getTime() - this._time) % this.duration / this.duration;
- }
- this._viewer.scene.requestRender();
- return result;
- }
- equals(other) {
- return this === other || other instanceof WallMaterialProperty && Cesium.Property.equals(this._color, other._color) && other._param.order === this._param.order && other._param.count === this._param.count && other._param.direction === this._param.direction && other.duration === this.duration;
- }
- _getDirectionWallShader(options2) {
- let op = Cesium.defaultValue(options2, {});
- let count = op.count !== void 0 && typeof op.count === "number" && op.count > 0 ? op.count : 1;
- let direction = op.direction === "horizontal" ? "horizontal" : "vertical";
- let order = op.order === "+" ? "+" : "-";
- this._param.count = count;
- this._param.direction = direction;
- this._param.order = order;
- let materail = "";
- materail += "czm_material czm_getMaterial(czm_materialInput materialInput){\n czm_material material = czm_getDefaultMaterial(materialInput);\n vec2 st = materialInput.st;\n";
- if (direction === "vertical") {
- materail += " vec4 colorImage = texture2D(image,vec2(st.s,fract(float(" + count + ")*st.t " + order + " time)));\n";
- } else if (direction === "horizontal") {
- materail += " vec4 colorImage = texture2D(image, vec2(fract(float(" + count + ")*st.s " + order + " time), st.t));\n";
- }
- materail += " vec4 fragColor;\n fragColor.rgb = color.rgb / 1.0;\n fragColor = czm_gammaCorrect(fragColor);\n material.alpha = colorImage.a * color.a;\n material.diffuse = color.rgb;\n material.emission = fragColor.rgb;\n return material;\n}";
- return materail;
- }
- }
- Object.defineProperties(WallMaterialProperty.prototype, {
- isConstant: {
- get: function() {
- return false;
- }
- },
- definitionChanged: {
- get: function() {
- return this._definitionChanged;
- }
- },
- color: Cesium.createPropertyDescriptor("color")
- });
- class CircleMaterialProperty {
- constructor(options2) {
- this._viewer = options2.viewer;
- this._definitionChanged = new Cesium.Event();
- this._color = void 0;
- this.color = options2.color || Cesium.Color.BLUE;
- this.count = options2.count || 1;
- this.duration = options2.duration || 1e3;
- this._time = new Date().getTime();
- this._materialTypeName = "jtCircleMaterial";
- this._param = {
- color: this.color._value.toCssColorString(),
- duration: this.duration,
- count: this.count
- };
- Cesium.Material._materialCache.addMaterial(this._materialTypeName, {
- fabric: {
- type: this._materialTypeName,
- uniforms: {
- time: 0,
- color: new Cesium.Color(1, 0, 0, 0.5),
- count: 1
- },
- source: this._getCircleMaterial()
- },
- translucent: function(material) {
- return true;
- }
- });
- }
- _getCircleMaterial() {
- let circleMaterial = "czm_material czm_getMaterial(czm_materialInput materialInput)\n{\n czm_material material = czm_getDefaultMaterial(materialInput);\n material.diffuse = 1.5 * color.rgb;\n vec2 st = materialInput.st;\n vec3 str = materialInput.str;\n float dis = distance(st, vec2(0.5, 0.5));\n float per = fract(time);\n if (abs(str.z) > 0.001)\n {\n //\u7740\u8272\u5668\u6E32\u67D3\u505C\u6B62\uFF0C\u4E0D\u5728\u7ED8\u5236\u5185\u5BB9 \n discard;\n }\n if (dis > 0.5)\n {\n //\u8D85\u51FA\u534A\u5F84\u8303\u56F4\u65F6\uFF0C\u7740\u8272\u5668\u6E32\u67D3\u505C\u6B62 \n discard;\n } else {\n //\u628A\u534A\u5F84\u5206\u6210count\u4EFD\uFF0C\u6BCF\u4E24\u4EFD\u4E4B\u95F4\u7684\u95F4\u9694\u8DDD\u79BB \n float perDis = 0.5 / count;\n float disNum;\n float bl = 0.0;\n //\u5FAA\u73AF\uFF0C\u6700\u591A999\u4E2A\u73AF \n for (int i = 0; i <= 999; i++)\n {\n //\u5224\u65AD\u662F\u5426\u5C5E\u4E8E\u6570\u91CF\u5185\u7684\u73AF \n if (float(i) <= count)\n {\n disNum = perDis * float(i) - dis + per / count;\n if (disNum > 0.0)\n {\n if (disNum < perDis)\n {\n bl = 1.0 - disNum / perDis;\n } else if (disNum - perDis < perDis) {\n bl = 1.0 - abs(1.0 - disNum / perDis);\n }\n material.alpha = color.a * pow(bl, 3.0);\n }\n }\n }\n }\n return material;\n}\n";
- return circleMaterial;
- }
- }
- Object.assign(CircleMaterialProperty.prototype, {
- getType: function(time) {
- return this._materialTypeName;
- },
- getValue: function(time, result) {
- if (!Cesium.defined(result)) {
- result = {};
- }
- result.color = Cesium.Property.getValueOrClonedDefault(this._color, time, Cesium.Color.BLUE, result.color);
- result.count = this.count;
- if (this.duration) {
- result.time = (new Date().getTime() - this._time) % this.duration / this.duration;
- }
- this._viewer.scene.requestRender();
- return result;
- },
- equals: function(other) {
- return this === other || other instanceof CircleMaterialProperty && Cesium.Property.equals(this._color, other._color);
- }
- });
- Object.defineProperties(CircleMaterialProperty.prototype, {
- isConstant: {
- get: function() {
- return false;
- }
- },
- definitionChanged: {
- get: function() {
- return this._definitionChanged;
- }
- },
- color: Cesium.createPropertyDescriptor("color")
- });
- const _checkAppOrWeb = function() {
- if (window.navigator.userAgent.match(
- /(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i
- )) {
- return "App";
- } else {
- return "Web";
- }
- };
- const isRuntimeApp = function() {
- if (_checkAppOrWeb() === "App") {
- return true;
- }
- return false;
- };
- const isRuntimeWeb = function() {
- if (_checkAppOrWeb() === "Web") {
- return true;
- }
- return false;
- };
- function createOperationMainDom() {
- let buttonDiv = document.createElement("div");
- buttonDiv.id = "drawButtonDiv";
- buttonDiv.style.width = "80px";
- buttonDiv.style.backgroundColor = "rgba(5, 45, 155, 0.7)";
- buttonDiv.style.borderRadius = "5px";
- buttonDiv.style.display = "flex";
- buttonDiv.style.flexDirection = "column";
- buttonDiv.style.padding = "8px";
- buttonDiv.style.justifyContent = "center";
- buttonDiv.style.position = "absolute";
- buttonDiv.style.bottom = "150px";
- buttonDiv.style.right = "10px";
- let btnUndo = document.createElement("button");
- btnUndo.id = "btnDrawBackout";
- btnUndo.style.height = "30px";
- btnUndo.style.marginBottom = "8px";
- btnUndo.style.backgroundColor = "rgba(52, 137, 255, 1.0)";
- btnUndo.style.color = "rgb(255, 255, 255)";
- btnUndo.style.border = "0px solid red";
- btnUndo.style.borderRadius = "5px";
- btnUndo.innerHTML = "\u56DE\u9000";
- btnUndo.style.fontSize = "13px";
- btnUndo.style.cursor = "pointer";
- buttonDiv.appendChild(btnUndo);
- let btnCompletion = document.createElement("button");
- btnCompletion.id = "btnDrawComplete";
- btnCompletion.style.height = "30px";
- btnCompletion.style.backgroundColor = "rgba(88, 185, 45, 1.0)";
- btnCompletion.style.color = "rgb(255, 255, 255)";
- btnCompletion.style.border = "0px solid red";
- btnCompletion.style.borderRadius = "5px";
- btnCompletion.innerHTML = "\u5B8C\u6210";
- btnCompletion.style.fontSize = "13px";
- btnCompletion.style.cursor = "pointer";
- buttonDiv.appendChild(btnCompletion);
- document.body.appendChild(buttonDiv);
- }
- function showTooltipMessage(message) {
- let msgMainDom = document.getElementById("messageMainDom");
- if (msgMainDom !== null && msgMainDom !== void 0) {
- document.body.removeChild(msgMainDom);
- }
- msgMainDom = document.createElement("div");
- msgMainDom.style.width = "30%";
- msgMainDom.style.backgroundColor = "rgba(237, 248, 230, 1.0)";
- msgMainDom.style.height = "45px";
- msgMainDom.style.border = "solid 2px rgb(219, 241, 208)";
- msgMainDom.style.borderRadius = "8px";
- msgMainDom.style.display = "flex";
- msgMainDom.style.alignItems = "center";
- msgMainDom.style.paddingLeft = "10px";
- msgMainDom.style.color = "rgb(91, 188, 48)";
- msgMainDom.style.fontSize = "14px";
- msgMainDom.style.fontWeight = "600";
- msgMainDom.style.position = "absolute";
- msgMainDom.style.left = "35%";
- msgMainDom.style.transition = "transform 1s";
- msgMainDom.style.transform = "translateY(-90px)";
- msgMainDom.style.top = "0px";
- msgMainDom.style.zIndex = 1e3;
- document.body.appendChild(msgMainDom);
- let strHtml = "";
- strHtml += "<div style='";
- strHtml += "background-color: rgb(88, 185, 45);";
- strHtml += "color: rgb(255, 255, 255);";
- strHtml += "height: 24px;";
- strHtml += "width: 24px;";
- strHtml += "border-radius: 20px;";
- strHtml += "display: flex;";
- strHtml += "justify-content: center;";
- strHtml += "align-items: center;";
- strHtml += "font-size: 14px;";
- strHtml += "margin-right: 18px;";
- strHtml += "'>✓</div>";
- strHtml += "<div>" + message + "</div>";
- msgMainDom.innerHTML = strHtml;
- msgMainDom.addEventListener("transitionend", function() {
- setTimeout(function() {
- document.body.removeChild(msgMainDom);
- }, 1e3);
- }, false);
- setTimeout(function() {
- msgMainDom.style.transform = "translateY(50px)";
- }, 100);
- }
- var RuntimeEnvironment = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
- __proto__: null,
- isRuntimeApp,
- isRuntimeWeb,
- createOperationMainDom,
- showTooltipMessage
- }, Symbol.toStringTag, { value: "Module" }));
- class DrawStraightArrow {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.floatingPoint = null;
- this._straightArrow = null;
- this._straightArrowLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_straightArrow = [];
- this._straightArrowData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._tooltip = createTooltip(this.viewer.container);
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get straightArrow() {
- return this._straightArrowLast;
- }
- getData() {
- return this._straightArrowData;
- }
- computePosition(data) {
- var $this = this;
- var length = data.length;
- var p1 = data[0];
- var p2 = data[length - 1];
- var firstPoint = $this.cartesianToLatlng(p1);
- var endPoints = $this.cartesianToLatlng(p2);
- var arrow = [];
- var res = $this.fineArrow([firstPoint[0], firstPoint[1]], [endPoints[0], endPoints[1]]);
- for (var i2 = 0; i2 < res.length; i2++) {
- var cart3 = new $this.Cesium.Cartesian3(res[i2].x, res[i2].y, res[i2].z);
- arrow.push(cart3);
- }
- $this._straightArrowData = [firstPoint, endPoints];
- return new $this.Cesium.PolygonHierarchy(arrow);
- }
- addload(data) {
- var $this = this;
- if (data.length < 2) {
- return null;
- }
- var length = data.length;
- var p1 = data[0];
- var p2 = data[length - 1];
- var arrow = [];
- var res = $this.fineArrow([p1[0], p1[1]], [p2[0], p2[1]]);
- for (var i2 = 0; i2 < res.length; i2++) {
- var cart3 = new $this.Cesium.Cartesian3(res[i2].x, res[i2].y, res[i2].z);
- arrow.push(cart3);
- }
- var arrowEntity = $this.viewer.entities.add({
- Type: "DrawStraightArrow",
- Position: data,
- id: data.id || $this.objId,
- polygon: {
- hierarchy: new $this.Cesium.PolygonHierarchy(arrow),
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.polygonMaterial
- }
- });
- return arrowEntity;
- }
- startCreate(drawType) {
- if (isRuntimeApp()) {
- showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- }
- var $this = this;
- this.drawType = drawType;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- if (isRuntimeApp()) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if (!cartesian) {
- return;
- }
- $this.createPoint(cartesian);
- $this._positions.push(cartesian);
- if ($this._positions.length === 2) {
- showTooltipMessage("\u70B9\u51FB\u5B8C\u6210\u6309\u94AE\uFF0C\u7ED3\u675F\u7ED8\u5236");
- $this.destroy();
- if (!$this.Cesium.defined($this._straightArrow)) {
- $this._straightArrow = $this.createStraightArrow();
- createOperationMainDom();
- document.getElementById("btnDrawBackout").style.display = "none";
- document.getElementById("btnDrawComplete").onclick = () => {
- $this._straightArrowData = $this._positions.concat();
- $this.viewer.entities.remove($this._straightArrow);
- $this._straightArrow = null;
- $this._positions = [];
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._straightArrowData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._straightArrowData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._straightArrowData = lnglatArr;
- var straightArrow = $this.addload($this._straightArrowData);
- $this._entities_straightArrow.push(straightArrow);
- $this._straightArrowLast = straightArrow;
- $this.clearPoint();
- $this.destroy();
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv) {
- document.body.removeChild(buttonDiv);
- }
- };
- }
- }
- } else {
- clearTimeout($this._timer);
- $this._timer = setTimeout(function() {
- var cartesian2 = $this.getCatesian3FromPX(evt.position);
- if ($this._positions.length == 0) {
- $this._positions.push(cartesian2.clone());
- $this.floatingPoint = $this.createPoint(cartesian2);
- $this._positions.push(cartesian2);
- }
- if (!$this._straightArrow) {
- $this.createPoint(cartesian2);
- } else {
- $this._straightArrowData = $this._positions.concat();
- $this.viewer.entities.remove($this._straightArrow);
- $this._straightArrow = null;
- $this._positions = [];
- $this.floatingPoint.position.setValue(cartesian2);
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._straightArrowData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._straightArrowData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._straightArrowData = lnglatArr;
- var straightArrow = $this.addload($this._straightArrowData);
- $this._entities_straightArrow.push(straightArrow);
- $this._straightArrowLast = straightArrow;
- $this.clearPoint();
- $this.destroy();
- $this._tooltip.setVisible(false);
- }
- }, 200);
- }
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if (isRuntimeApp())
- return;
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- if ($this._positions.length < 2)
- return;
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u7ED3\u675F\u7ED8\u5236");
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if (!$this.Cesium.defined($this._straightArrow)) {
- $this._straightArrow = $this.createStraightArrow();
- }
- $this.floatingPoint.position.setValue(cartesian);
- if ($this._straightArrow) {
- $this._positions.pop();
- $this._positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- }
- createStraightArrow() {
- var $this = this;
- var arrowEntity = $this.viewer.entities.add({
- polygon: {
- hierarchy: new $this.Cesium.CallbackProperty(
- function() {
- var length = $this._positions.length;
- var p1 = $this._positions[0];
- var p2 = $this._positions[length - 1];
- var firstPoint = $this.cartesianToLatlng(p1);
- var endPoints = $this.cartesianToLatlng(p2);
- var arrow = [];
- var res = $this.fineArrow([firstPoint[0], firstPoint[1]], [endPoints[0], endPoints[1]]);
- for (var i2 = 0; i2 < res.length; i2++) {
- var cart3 = new $this.Cesium.Cartesian3(res[i2].x, res[i2].y, res[i2].z);
- arrow.push(cart3);
- }
- return new $this.Cesium.PolygonHierarchy(arrow);
- },
- false
- ),
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.polygonMaterial
- }
- });
- $this._entities_straightArrow.push(arrowEntity);
- return arrowEntity;
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- cartesianToLatlng(cartesian) {
- var latlng = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- var lat = this.Cesium.Math.toDegrees(latlng.latitude);
- var lng = this.Cesium.Math.toDegrees(latlng.longitude);
- return [lng, lat];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._straightArrowLast, this._straightArrowData, this.drawType);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_straightArrow.length; i2++) {
- this.viewer.entities.remove(this._entities_straightArrow[i2]);
- }
- this.floatingPoint = null;
- this._straightArrow = null;
- this._straightArrowLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_straightArrow = [];
- this._straightArrowData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- fineArrowDefualParam() {
- return {
- tailWidthFactor: 0.15,
- neckWidthFactor: 0.2,
- headWidthFactor: 0.25,
- headAngle: Math.PI / 8.5,
- neckAngle: Math.PI / 13
- };
- }
- fineArrow(tailPoint, headerPoint) {
- var $this = this;
- if (tailPoint.length < 2 || headerPoint.length < 2)
- return;
- let tailWidthFactor = $this.fineArrowDefualParam().tailWidthFactor;
- let neckWidthFactor = $this.fineArrowDefualParam().neckWidthFactor;
- let headWidthFactor = $this.fineArrowDefualParam().headWidthFactor;
- let headAngle = $this.fineArrowDefualParam().headAngle;
- let neckAngle = $this.fineArrowDefualParam().neckAngle;
- var o = [];
- o[0] = tailPoint;
- o[1] = headerPoint;
- var e = o[0], r2 = o[1], n = $this.getBaseLength(o), g = n * tailWidthFactor, i2 = n * neckWidthFactor, s = n * headWidthFactor, a = $this.getThirdPoint(r2, e, Math.PI / 2, g, true), l = $this.getThirdPoint(r2, e, Math.PI / 2, g, false), u = $this.getThirdPoint(e, r2, headAngle, s, false), c = $this.getThirdPoint(e, r2, headAngle, s, true), p = $this.getThirdPoint(e, r2, neckAngle, i2, false), h2 = $this.getThirdPoint(e, r2, neckAngle, i2, true), d2 = [];
- d2.push(a[0], a[1], p[0], p[1], u[0], u[1], r2[0], r2[1], c[0], c[1], h2[0], h2[1], l[0], l[1], e[0], e[1]);
- return $this.Cesium.Cartesian3.fromDegreesArray(d2);
- }
- getBaseLength(t2) {
- return Math.pow(this.wholeDistance(t2), 0.99);
- }
- wholeDistance(t2) {
- for (var o = 0, e = 0; e < t2.length - 1; e++)
- o += this.distance(t2[e], t2[e + 1]);
- return o;
- }
- distance(t2, o) {
- return Math.sqrt(Math.pow(t2[0] - o[0], 2) + Math.pow(t2[1] - o[1], 2));
- }
- getThirdPoint(t2, o, e, r2, n) {
- var g = this.getAzimuth(t2, o), i2 = n ? g + e : g - e, s = r2 * Math.cos(i2), a = r2 * Math.sin(i2);
- return [o[0] + s, o[1] + a];
- }
- getAzimuth(t2, o) {
- var e, r2 = Math.asin(Math.abs(o[1] - t2[1]) / this.distance(t2, o));
- return o[1] >= t2[1] && o[0] >= t2[0] ? e = r2 + Math.PI : o[1] >= t2[1] && o[0] < t2[0] ? e = 2 * Math.PI - r2 : o[1] < t2[1] && o[0] < t2[0] ? e = r2 : o[1] < t2[1] && o[0] >= t2[0] && (e = Math.PI - r2), e;
- }
- }
- class DrawAttackArrow {
- constructor(arg) {
- __publicField(this, "getAttackArrowBodyPoints", function(t2, o, e, r2) {
- var $this = this;
- for (var n = $this.wholeDistance(t2), g = $this.getBaseLength(t2), i2 = g * r2, s = $this.distance(o, e), a = (i2 - s) / 2, l = 0, u = [], c = [], p = 1; p < t2.length - 1; p++) {
- var h2 = $this.getAngleOfThreePoints(t2[p - 1], t2[p], t2[p + 1]) / 2;
- l += $this.distance(t2[p - 1], t2[p]);
- var d2 = (i2 / 2 - l / n * a) / Math.sin(h2), f = $this.getThirdPoint(t2[p - 1], t2[p], Math.PI - h2, d2, true), E2 = $this.getThirdPoint(t2[p - 1], t2[p], h2, d2, false);
- u.push(f), c.push(E2);
- }
- return u.concat(c);
- });
- __publicField(this, "getQBSplinePoints", function(t2) {
- if (t2.length <= 2)
- return t2;
- var o = 2, e = [], r2 = t2.length - o - 1, y = 0;
- e.push(t2[0]);
- for (var n = 0; r2 >= n; n++)
- for (var g = 0; 1 >= g; g += 0.05) {
- for (var i2 = y = 0, s = 0; o >= s; s++) {
- var a = this.getQuadricBSplineFactor(s, g);
- i2 += a * t2[n + s][0], y += a * t2[n + s][1];
- }
- e.push([i2, y]);
- }
- return e.push(t2[t2.length - 1]), e;
- });
- __publicField(this, "getQuadricBSplineFactor", function(t2, o) {
- return 0 == t2 ? Math.pow(o - 1, 2) / 2 : 1 == t2 ? (-2 * Math.pow(o, 2) + 2 * o + 1) / 2 : 2 == t2 ? Math.pow(o, 2) / 2 : 0;
- });
- __publicField(this, "array2Dto1D", function(array) {
- var newArray = [];
- array.forEach(function(elt) {
- newArray.push(elt[0]);
- newArray.push(elt[1]);
- });
- return newArray;
- });
- this.objId = Number(new Date().getTime() + "" + Number(Math.random() * 1e3).toFixed(0));
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.floatingPoint = null;
- this._AttackArrow = null;
- this._AttackArrowLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_AttackArrow = [];
- this._AttackArrowData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._tooltip = createTooltip(this.viewer.container);
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get AttackArrow() {
- return this._AttackArrowLast;
- }
- getData() {
- return this._AttackArrowData;
- }
- addload(data) {
- var $this = this;
- if (data.length < 3) {
- return null;
- }
- var res = $this.fineArrow(data);
- var returnData = res.polygonalPoint;
- var arrowEntity = $this.viewer.entities.add({
- Type: "DrawAttackArrow",
- Position: data,
- id: data.id || $this.objId,
- polygon: {
- hierarchy: new $this.Cesium.PolygonHierarchy(returnData),
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.polygonMaterial
- }
- });
- return arrowEntity;
- }
- computePosition(data) {
- let $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.cartesianToLatlng(data[i2]);
- lnglatArr.push(lnglat);
- }
- $this._AttackArrowData = lnglatArr;
- var res = $this.fineArrow(lnglatArr);
- var returnData = res.polygonalPoint;
- return new $this.Cesium.PolygonHierarchy(returnData);
- }
- startCreate(drawType) {
- if (isRuntimeApp()) {
- showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- }
- var $this = this;
- this.drawType = drawType;
- this.handler = new $this.Cesium.ScreenSpaceEventHandler($this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- if (isRuntimeApp()) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if (!cartesian) {
- return;
- }
- $this.createPoint(cartesian);
- $this._positions.push(cartesian);
- if ($this._positions.length <= 2) {
- showTooltipMessage("\u70B9\u51FB\u6DFB\u52A0\u70B9");
- } else {
- showTooltipMessage("\u70B9\u51FB\u6DFB\u52A0\u70B9\uFF0C\u70B9\u51FB\u5B8C\u6210\u6309\u94AE\uFF0C\u7ED3\u675F\u7ED8\u5236");
- if ($this._positions.length === 3) {
- if (!$this.Cesium.defined($this._AttackArrow)) {
- $this._AttackArrow = $this.createAttackArrow();
- createOperationMainDom();
- document.getElementById("btnDrawBackout").style.display = "none";
- document.getElementById("btnDrawComplete").onclick = () => {
- $this._AttackArrowData = $this._positions.concat();
- $this.viewer.entities.remove($this._AttackArrow);
- $this._AttackArrow = null;
- $this._positions = [];
- let lnglatArr = [];
- for (var i2 = 0; i2 < $this._AttackArrowData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._AttackArrowData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._AttackArrowData = lnglatArr;
- var straightArrow = $this.addload(lnglatArr);
- $this._entities_AttackArrow.push(straightArrow);
- $this._AttackArrowLast = straightArrow;
- $this.clearPoint();
- $this.destroy();
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv) {
- document.body.removeChild(buttonDiv);
- }
- };
- }
- }
- }
- } else {
- clearTimeout($this._timer);
- $this._timer = setTimeout(function() {
- var cartesian2 = $this.getCatesian3FromPX(evt.position);
- if (!cartesian2) {
- return;
- }
- if ($this._positions.length == 0) {
- $this.floatingPoint = $this.createPoint(cartesian2);
- $this.createPoint(cartesian2);
- }
- if ($this._positions.length == 1) {
- $this._positions.push(cartesian2.clone());
- $this.createPoint(cartesian2);
- }
- $this._positions.push(cartesian2);
- }, 200);
- }
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if (isRuntimeApp())
- return;
- if ($this._positions.length == 0) {
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- } else {
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u6DFB\u52A0\u70B9");
- }
- if ($this._positions.length < 3)
- return;
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u6DFB\u52A0\u70B9\uFF0C\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236");
- if (!$this.Cesium.defined($this._AttackArrow)) {
- $this._AttackArrow = $this.createAttackArrow();
- }
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if (!cartesian) {
- return;
- }
- $this.floatingPoint.position.setValue(cartesian);
- if ($this._AttackArrow) {
- $this._positions.pop();
- $this._positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- this.handler.setInputAction(function(evt) {
- if (isRuntimeApp())
- return;
- clearTimeout($this._timer);
- var cartesian = $this.getCatesian3FromPX(evt.position);
- $this._positions.pop();
- $this._positions.push(cartesian);
- $this._AttackArrowData = $this._positions.concat();
- $this.viewer.entities.remove($this._AttackArrow);
- $this._AttackArrow = null;
- $this._positions = [];
- $this.floatingPoint.position.setValue(cartesian);
- let lnglatArr = [];
- for (var i2 = 0; i2 < $this._AttackArrowData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._AttackArrowData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._AttackArrowData = lnglatArr;
- var straightArrow = $this.addload(lnglatArr);
- $this._entities_AttackArrow.push(straightArrow);
- $this._AttackArrowLast = straightArrow;
- $this.clearPoint();
- $this.destroy();
- $this._tooltip.setVisible(false);
- }, $this.Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
- }
- createAttackArrow() {
- var $this = this;
- var arrowEntity = $this.viewer.entities.add({
- polygon: {
- hierarchy: new $this.Cesium.CallbackProperty(
- function() {
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._positions.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._positions[i2]);
- lnglatArr.push(lnglat);
- }
- var res = $this.fineArrow(lnglatArr);
- var returnData = res.polygonalPoint;
- return new $this.Cesium.PolygonHierarchy(returnData);
- },
- false
- ),
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.polygonMaterial
- }
- });
- $this._entities_AttackArrow.push(arrowEntity);
- return arrowEntity;
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- point2.objId = this.objId;
- $this._entities_point.push(point2);
- return point2;
- }
- cartesianToLatlng(cartesian) {
- let cartographic = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- let lat = this.Cesium.Math.toDegrees(cartographic.latitude);
- let lng = this.Cesium.Math.toDegrees(cartographic.longitude);
- let alt = cartographic.height;
- return [lng, lat, alt];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._AttackArrowLast, this._AttackArrowData, this.drawType);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_AttackArrow.length; i2++) {
- this.viewer.entities.remove(this._entities_AttackArrow[i2]);
- }
- this.floatingPoint = null;
- this._AttackArrow = null;
- this._AttackArrowLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_AttackArrow = [];
- this._AttackArrowData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- fineArrowDefualParam() {
- return {
- headHeightFactor: 0.18,
- headWidthFactor: 0.3,
- neckHeightFactor: 0.85,
- neckWidthFactor: 0.15,
- tailWidthFactor: 0.1,
- headTailFactor: 0.8,
- swallowTailFactor: 1
- };
- }
- fineArrow(inputPoint) {
- var $this = this;
- inputPoint = $this.dereplication(inputPoint);
- let tailWidthFactor = $this.fineArrowDefualParam().tailWidthFactor;
- let swallowTailFactor = $this.fineArrowDefualParam().swallowTailFactor;
- let swallowTailPnt = $this.fineArrowDefualParam().swallowTailPnt;
- var result = {
- controlPoint: null,
- polygonalPoint: null
- };
- result.controlPoint = inputPoint;
- var t2 = inputPoint.length;
- if (!(2 > t2)) {
- if (2 == inputPoint.length) {
- result.polygonalPoint = inputPoint;
- return result;
- }
- var o = inputPoint, e = o[0], r2 = o[1];
- $this.isClockWise(o[0], o[1], o[2]) && (e = o[1], r2 = o[0]);
- var n = $this.mid(e, r2), g = [n].concat(o.slice(2)), i2 = $this.getAttackArrowHeadPoints(g, e, r2, $this.fineArrowDefualParam()), s = i2[0], a = i2[4], l = $this.distance(e, r2), u = $this.getBaseLength(g), c = u * tailWidthFactor * swallowTailFactor;
- swallowTailPnt = $this.getThirdPoint(g[1], g[0], 0, c, true);
- var p = l / u, h2 = $this.getAttackArrowBodyPoints(g, s, a, p), t2 = h2.length, d2 = [e].concat(h2.slice(0, t2 / 2));
- d2.push(s);
- var f = [r2].concat(h2.slice(t2 / 2, t2));
- var newArray = [];
- f.push(a), d2 = $this.getQBSplinePoints(d2), f = $this.getQBSplinePoints(f), newArray = $this.array2Dto1D(d2.concat(i2, f.reverse(), [swallowTailPnt, d2[0]]));
- result.polygonalPoint = $this.Cesium.Cartesian3.fromDegreesArray(newArray);
- }
- return result;
- }
- getArrowBodyPoints(t2, o, e, r2) {
- var $this = this;
- for (var n = $this.wholeDistance(t2), g = $this.getBaseLength(t2), i2 = g * r2, s = $this.distance(o, e), a = (i2 - s) / 2, l = 0, u = [], c = [], p = 1; p < t2.length - 1; p++) {
- var h2 = $this.getAngleOfThreePoints(t2[p - 1], t2[p], t2[p + 1]) / 2;
- l += $this.distance(t2[p - 1], t2[p]);
- var d2 = (i2 / 2 - l / n * a) / Math.sin(h2), f = $this.getThirdPoint(t2[p - 1], t2[p], Math.PI - h2, d2, true), E2 = $this.getThirdPoint(t2[p - 1], t2[p], h2, d2, false);
- u.push(f), c.push(E2);
- }
- return u.concat(c);
- }
- getAttackArrowHeadPoints(t2, o, e, defaultParam) {
- var $this = this;
- let headHeightFactor = defaultParam.headHeightFactor;
- let headTailFactor = defaultParam.headTailFactor;
- let headWidthFactor = defaultParam.headWidthFactor;
- let neckWidthFactor = defaultParam.neckWidthFactor;
- let neckHeightFactor = defaultParam.neckHeightFactor;
- var r2 = $this.getBaseLength(t2), n = r2 * headHeightFactor, g = t2[t2.length - 1];
- r2 = $this.distance(g, t2[t2.length - 2]);
- var i2 = $this.distance(o, e);
- n > i2 * headTailFactor && (n = i2 * headTailFactor);
- var s = n * headWidthFactor, a = n * neckWidthFactor;
- n = n > r2 ? r2 : n;
- var l = n * neckHeightFactor, u = $this.getThirdPoint(t2[t2.length - 2], g, 0, n, true), c = $this.getThirdPoint(t2[t2.length - 2], g, 0, l, true), p = $this.getThirdPoint(g, u, Math.PI / 2, s, false), h2 = $this.getThirdPoint(g, u, Math.PI / 2, s, true), d2 = $this.getThirdPoint(g, c, Math.PI / 2, a, false), f = $this.getThirdPoint(g, c, Math.PI / 2, a, true);
- return [d2, p, g, h2, f];
- }
- getAngleOfThreePoints(t2, o, e) {
- var r2 = this.getAzimuth(o, t2) - this.getAzimuth(o, e);
- return 0 > r2 ? r2 + Math.PI * 2 : r2;
- }
- dereplication(array) {
- var last = array[array.length - 1];
- var change = false;
- var newArray = [];
- newArray = array.filter(function(i2) {
- if (i2[0] != last[0] && i2[1] != last[1]) {
- return i2;
- }
- change = true;
- });
- if (change)
- newArray.push(last);
- return newArray;
- }
- getBaseLength(t2) {
- return Math.pow(this.wholeDistance(t2), 0.99);
- }
- wholeDistance(t2) {
- for (var o = 0, e = 0; e < t2.length - 1; e++)
- o += this.distance(t2[e], t2[e + 1]);
- return o;
- }
- distance(t2, o) {
- return Math.sqrt(Math.pow(t2[0] - o[0], 2) + Math.pow(t2[1] - o[1], 2));
- }
- getThirdPoint(t2, o, e, r2, n) {
- var g = this.getAzimuth(t2, o), i2 = n ? g + e : g - e, s = r2 * Math.cos(i2), a = r2 * Math.sin(i2);
- return [o[0] + s, o[1] + a];
- }
- getAzimuth(t2, o) {
- var e, r2 = Math.asin(Math.abs(o[1] - t2[1]) / this.distance(t2, o));
- return o[1] >= t2[1] && o[0] >= t2[0] ? e = r2 + Math.PI : o[1] >= t2[1] && o[0] < t2[0] ? e = 2 * Math.PI - r2 : o[1] < t2[1] && o[0] < t2[0] ? e = r2 : o[1] < t2[1] && o[0] >= t2[0] && (e = Math.PI - r2), e;
- }
- isClockWise(t2, o, e) {
- return (e[1] - t2[1]) * (o[0] - t2[0]) > (o[1] - t2[1]) * (e[0] - t2[0]);
- }
- mid(t2, o) {
- return [(t2[0] + o[0]) / 2, (t2[1] + o[1]) / 2];
- }
- }
- class DrawPincerArrow {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.floatingPoint = null;
- this._PincerArrow = null;
- this._PincerArrowLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_PincerArrow = [];
- this._PincerArrowData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._tooltip = createTooltip(this.viewer.container);
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get PincerArrow() {
- return this._PincerArrowLast;
- }
- getData() {
- return this._PincerArrowData;
- }
- addload(data) {
- var $this = this;
- if (data.length < 3) {
- return;
- }
- var res = $this.doubleArrow(data);
- var returnData = res.polygonalPoint;
- var arrowEntity = $this.viewer.entities.add({
- Type: "DrawPincerArrow",
- Position: data,
- id: data.id || $this.objId,
- polygon: {
- hierarchy: new $this.Cesium.PolygonHierarchy(returnData),
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.polygonMaterial
- }
- });
- return arrowEntity;
- }
- computePosition(data) {
- let $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.cartesianToLatlng(data[i2]);
- lnglatArr.push(lnglat);
- }
- $this._PincerArrowData = lnglatArr;
- var res = $this.doubleArrow(lnglatArr);
- var returnData = res.polygonalPoint;
- return new $this.Cesium.PolygonHierarchy(returnData);
- }
- startCreate(drawType) {
- if (isRuntimeApp()) {
- showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- }
- var $this = this;
- this.drawType = drawType;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- if (isRuntimeApp()) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if (!cartesian) {
- return;
- }
- $this.createPoint(cartesian);
- $this._positions.push(cartesian);
- if ($this._positions.length < 3 || $this._positions.length === 4) {
- showTooltipMessage("\u70B9\u51FB\u6DFB\u52A0\u70B9");
- }
- if ($this._positions.length === 2) {
- if (!$this.Cesium.defined($this._PincerArrow)) {
- $this._PincerArrow = $this.createPincerArrow();
- }
- }
- if ($this._positions.length === 3) {
- $this._positions.pop();
- $this._positions.push(cartesian);
- showTooltipMessage("\u70B9\u51FB\u6DFB\u52A0\u70B9\uFF0C\u70B9\u51FB\u5B8C\u6210\u6309\u94AE\uFF0C\u7ED3\u675F\u7ED8\u5236");
- createOperationMainDom();
- document.getElementById("btnDrawBackout").style.display = "none";
- document.getElementById("btnDrawComplete").onclick = () => {
- $this._PincerArrowData = $this._positions.concat();
- $this.viewer.entities.remove($this._PincerArrow);
- $this._PincerArrow = null;
- $this._positions = [];
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._PincerArrowData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._PincerArrowData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._PincerArrowData = lnglatArr;
- var pincerArrow = $this.addload(lnglatArr);
- $this._entities_PincerArrow.push(pincerArrow);
- $this._PincerArrowLast = pincerArrow;
- $this.clearPoint();
- $this.destroy();
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv) {
- document.body.removeChild(buttonDiv);
- }
- };
- }
- if ($this._positions.length === 5) {
- showTooltipMessage("\u70B9\u51FB\u5B8C\u6210\u6309\u94AE\uFF0C\u7ED3\u675F\u7ED8\u5236");
- $this.destroy();
- }
- } else {
- clearTimeout($this._timer);
- $this._timer = setTimeout(function() {
- var cartesian2 = $this.getCatesian3FromPX(evt.position);
- if (!cartesian2) {
- return;
- }
- if ($this._positions.length == 0) {
- $this.floatingPoint = $this.createPoint(cartesian2);
- }
- if ($this._positions.length < 5) {
- $this._positions.push(cartesian2);
- $this.createPoint(cartesian2);
- }
- if ($this._positions.length == 5) {
- $this._positions[4] = cartesian2;
- $this.floatingPoint.position.setValue(cartesian2);
- }
- }, 200);
- }
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if (isRuntimeApp())
- return;
- if ($this._positions.length == 0) {
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- } else {
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u6DFB\u52A0\u70B9");
- }
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if (!cartesian)
- return;
- if ($this._positions.length < 2)
- return;
- if (!$this.Cesium.defined($this._PincerArrow)) {
- if ($this._positions.length == 2) {
- $this._positions.push(cartesian);
- }
- $this._PincerArrow = $this.createPincerArrow();
- }
- $this.floatingPoint.position.setValue(cartesian);
- if ($this._positions.length == 3) {
- $this._positions[2] = cartesian;
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u6DFB\u52A0\u70B9\uFF0C\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236");
- }
- if ($this._positions.length > 3) {
- $this._positions.pop();
- $this._positions.push(cartesian);
- if ($this._positions === 4) {
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u6DFB\u52A0\u70B9");
- }
- if ($this._positions.length == 5) {
- $this._tooltip.showAt(evt.endPosition, "\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236");
- }
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- this.handler.setInputAction(function(evt) {
- if (isRuntimeApp())
- return;
- clearTimeout($this._timer);
- if (!$this._PincerArrow) {
- return;
- }
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if (!cartesian)
- return;
- $this._positions.pop();
- $this._PincerArrowData = $this._positions.concat();
- $this.viewer.entities.remove($this._PincerArrow);
- $this._PincerArrow = null;
- $this._positions = [];
- $this.floatingPoint.position.setValue(cartesian);
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._PincerArrowData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._PincerArrowData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._PincerArrowData = lnglatArr;
- var pincerArrow = $this.addload(lnglatArr);
- $this._entities_PincerArrow.push(pincerArrow);
- $this._PincerArrowLast = pincerArrow;
- $this.clearPoint();
- $this.destroy();
- $this._tooltip.setVisible(false);
- }, $this.Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
- }
- createPincerArrow() {
- var $this = this;
- $this._computeTempPositions();
- var arrowEntity = $this.viewer.entities.add({
- polygon: {
- hierarchy: new $this.Cesium.CallbackProperty(
- function() {
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._positions.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._positions[i2]);
- lnglatArr.push(lnglat);
- }
- var res = $this.doubleArrow(lnglatArr);
- var returnData = res.polygonalPoint;
- return new $this.Cesium.PolygonHierarchy(returnData);
- },
- false
- ),
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.polygonMaterial
- }
- });
- $this._entities_PincerArrow.push(arrowEntity);
- return arrowEntity;
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- cartesianToLatlng(cartesian) {
- let cartographic = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- let lat = this.Cesium.Math.toDegrees(cartographic.latitude);
- let lng = this.Cesium.Math.toDegrees(cartographic.longitude);
- let alt = cartographic.height;
- return [lng, lat, alt];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._PincerArrowLast, this._PincerArrowData, this.drawType);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_PincerArrow.length; i2++) {
- this.viewer.entities.remove(this._entities_PincerArrow[i2]);
- }
- this.floatingPoint = null;
- this._PincerArrow = null;
- this._PincerArrowLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_PincerArrow = [];
- this._PincerArrowData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- _computeTempPositions() {
- var _this = this;
- var pnts = [].concat(_this._positions);
- var num = pnts.length;
- var first = pnts[0];
- var last = pnts[num - 1];
- if (_this._isSimpleXYZ(first, last) == false) {
- pnts.push(first);
- num += 1;
- }
- _this.tempPositions = [];
- for (var i2 = 1; i2 < num; i2++) {
- var p1 = pnts[i2 - 1];
- var p2 = pnts[i2];
- var cp = _this._computeCenterPotition(p1, p2);
- _this.tempPositions.push(p1);
- _this.tempPositions.push(cp);
- }
- }
- _isSimpleXYZ(p1, p2) {
- if (p1.x == p2.x && p1.y == p2.y && p1.z == p2.z) {
- return true;
- }
- return false;
- }
- _computeCenterPotition(p1, p2) {
- var _this = this;
- var c1 = _this.viewer.scene.globe.ellipsoid.cartesianToCartographic(p1);
- var c2 = _this.viewer.scene.globe.ellipsoid.cartesianToCartographic(p2);
- var cm = new _this.Cesium.EllipsoidGeodesic(c1, c2).interpolateUsingFraction(0.5);
- var cp = _this.viewer.scene.globe.ellipsoid.cartographicToCartesian(cm);
- return cp;
- }
- doubleArrow(inputPoint) {
- var $this = this;
- this.connPoint = null;
- this.tempPoint4 = null;
- this.points = inputPoint;
- var result = {
- controlPoint: null,
- polygonalPoint: null
- };
- var t2 = inputPoint.length;
- if (!(2 > t2)) {
- if (2 == t2)
- return inputPoint;
- var o = this.points[0], e = this.points[1], r2 = this.points[2], t2 = inputPoint.length;
- 3 == t2 ? this.tempPoint4 = $this.getTempPoint4(o, e, r2) : this.tempPoint4 = this.points[3], 3 == t2 || 4 == t2 ? this.connPoint = $this.mid(o, e) : this.connPoint = this.points[4];
- var n, g;
- $this.isClockWise(o, e, r2) ? (n = $this.getArrowPoints(o, this.connPoint, this.tempPoint4, false), g = $this.getArrowPoints(this.connPoint, e, r2, true)) : (n = $this.getArrowPoints(e, this.connPoint, r2, false), g = $this.getArrowPoints(this.connPoint, o, this.tempPoint4, true));
- var i2 = n.length, s = (i2 - 5) / 2, a = n.slice(0, s), l = n.slice(s, s + 5), u = n.slice(s + 5, i2), c = g.slice(0, s), p = g.slice(s, s + 5), h2 = g.slice(s + 5, i2);
- c = $this.getBezierPoints(c);
- var d2 = $this.getBezierPoints(h2.concat(a.slice(1)));
- u = $this.getBezierPoints(u);
- var f = c.concat(p, d2, l, u);
- var newArray = $this.array2Dto1D(f);
- result.controlPoint = [o, e, r2, this.tempPoint4, this.connPoint];
- result.polygonalPoint = $this.Cesium.Cartesian3.fromDegreesArray(newArray);
- }
- return result;
- }
- getTempPoint4(t2, o, e) {
- var $this = this;
- var r2, n, g, i2, s = $this.mid(t2, o), a = $this.distance(s, e), l = $this.getAngleOfThreePoints(t2, s, e);
- return l < Math.PI / 2 ? (n = a * Math.sin(l), g = a * Math.cos(l), i2 = $this.getThirdPoint(t2, s, Math.PI / 2, n, false), r2 = $this.getThirdPoint(s, i2, Math.PI / 2, g, true)) : l >= Math.PI / 2 && l < Math.PI ? (n = a * Math.sin(Math.PI - l), g = a * Math.cos(Math.PI - l), i2 = $this.getThirdPoint(t2, s, Math.PI / 2, n, false), r2 = $this.getThirdPoint(s, i2, Math.PI / 2, g, false)) : l >= Math.PI && l < 1.5 * Math.PI ? (n = a * Math.sin(l - Math.PI), g = a * Math.cos(l - Math.PI), i2 = $this.getThirdPoint(t2, s, Math.PI / 2, n, true), r2 = $this.getThirdPoint(s, i2, Math.PI / 2, g, true)) : (n = a * Math.sin(2 * Math.PI - l), g = a * Math.cos(2 * Math.PI - l), i2 = $this.getThirdPoint(t2, s, Math.PI / 2, n, true), r2 = $this.getThirdPoint(s, i2, Math.PI / 2, g, false)), r2;
- }
- mid(t2, o) {
- return [(t2[0] + o[0]) / 2, (t2[1] + o[1]) / 2];
- }
- isClockWise(t2, o, e) {
- return (e[1] - t2[1]) * (o[0] - t2[0]) > (o[1] - t2[1]) * (e[0] - t2[0]);
- }
- getArrowPoints(t2, o, e, r2) {
- var $this = this;
- var doubleArrowDefualParam = {
- type: "doublearrow",
- headHeightFactor: 0.25,
- headWidthFactor: 0.3,
- neckHeightFactor: 0.85,
- fixPointCount: 4,
- neckWidthFactor: 0.15
- };
- this.type = doubleArrowDefualParam.type, this.headHeightFactor = doubleArrowDefualParam.headHeightFactor, this.headWidthFactor = doubleArrowDefualParam.headWidthFactor, this.neckHeightFactor = doubleArrowDefualParam.neckHeightFactor, this.neckWidthFactor = doubleArrowDefualParam.neckWidthFactor;
- var n = $this.mid(t2, o), g = $this.distance(n, e), i2 = $this.getThirdPoint(e, n, 0, 0.3 * g, true), s = $this.getThirdPoint(e, n, 0, 0.5 * g, true);
- i2 = $this.getThirdPoint(n, i2, Math.PI / 2, g / 5, r2), s = $this.getThirdPoint(n, s, Math.PI / 2, g / 4, r2);
- var a = [n, i2, s, e], l = $this.getArrowHeadPoints(a, this.headHeightFactor, this.headWidthFactor, this.neckHeightFactor, this.neckWidthFactor), u = l[0], c = l[4], p = $this.distance(t2, o) / $this.getBaseLength(a) / 2, h2 = $this.getArrowBodyPoints(a, u, c, p), d2 = h2.length, f = h2.slice(0, d2 / 2), E2 = h2.slice(d2 / 2, d2);
- return f.push(u), E2.push(c), f = f.reverse(), f.push(o), E2 = E2.reverse(), E2.push(t2), f.reverse().concat(l, E2);
- }
- getArrowHeadPoints(t2, o, e) {
- var $this = this;
- var doubleArrowDefualParam = {
- type: "doublearrow",
- headHeightFactor: 0.25,
- headWidthFactor: 0.3,
- neckHeightFactor: 0.85,
- fixPointCount: 4,
- neckWidthFactor: 0.15
- };
- this.type = doubleArrowDefualParam.type, this.headHeightFactor = doubleArrowDefualParam.headHeightFactor, this.headWidthFactor = doubleArrowDefualParam.headWidthFactor, this.neckHeightFactor = doubleArrowDefualParam.neckHeightFactor, this.neckWidthFactor = doubleArrowDefualParam.neckWidthFactor;
- var r2 = $this.getBaseLength(t2), n = r2 * this.headHeightFactor, g = t2[t2.length - 1], i2 = ($this.distance(o, e), n * this.headWidthFactor), s = n * this.neckWidthFactor, a = n * this.neckHeightFactor, l = $this.getThirdPoint(t2[t2.length - 2], g, 0, n, true), u = $this.getThirdPoint(t2[t2.length - 2], g, 0, a, true), c = $this.getThirdPoint(g, l, Math.PI / 2, i2, false), p = $this.getThirdPoint(g, l, Math.PI / 2, i2, true), h2 = $this.getThirdPoint(g, u, Math.PI / 2, s, false), d2 = $this.getThirdPoint(g, u, Math.PI / 2, s, true);
- return [h2, c, g, p, d2];
- }
- getArrowBodyPoints(t2, o, e, r2) {
- var $this = this;
- for (var n = $this.wholeDistance(t2), g = $this.getBaseLength(t2), i2 = g * r2, s = $this.distance(o, e), a = (i2 - s) / 2, l = 0, u = [], c = [], p = 1; p < t2.length - 1; p++) {
- var h2 = $this.getAngleOfThreePoints(t2[p - 1], t2[p], t2[p + 1]) / 2;
- l += $this.distance(t2[p - 1], t2[p]);
- var d2 = (i2 / 2 - l / n * a) / Math.sin(h2), f = $this.getThirdPoint(t2[p - 1], t2[p], Math.PI - h2, d2, true), E2 = $this.getThirdPoint(t2[p - 1], t2[p], h2, d2, false);
- u.push(f), c.push(E2);
- }
- return u.concat(c);
- }
- getBezierPoints(t2) {
- if (t2.length <= 2)
- return t2;
- for (var o = [], e = t2.length - 1, r2 = 0; 1 >= r2; r2 += 0.01) {
- for (var n = 0, y = 0, g = 0; e >= g; g++) {
- var i2 = this.getBinomialFactor(e, g), s = Math.pow(r2, g), a = Math.pow(1 - r2, e - g);
- n += i2 * s * a * t2[g][0], y += i2 * s * a * t2[g][1];
- }
- o.push([n, y]);
- }
- return o.push(t2[e]), o;
- }
- getBaseLength(t2) {
- return Math.pow(this.wholeDistance(t2), 0.99);
- }
- wholeDistance(t2) {
- for (var o = 0, e = 0; e < t2.length - 1; e++)
- o += this.distance(t2[e], t2[e + 1]);
- return o;
- }
- getBinomialFactor(t2, o) {
- return this.getFactorial(t2) / (this.getFactorial(o) * this.getFactorial(t2 - o));
- }
- getFactorial(t2) {
- if (1 >= t2)
- return 1;
- if (2 == t2)
- return 2;
- if (3 == t2)
- return 6;
- if (4 == t2)
- return 24;
- if (5 == t2)
- return 120;
- for (var o = 1, e = 1; t2 >= e; e++)
- o *= e;
- return o;
- }
- array2Dto1D(array) {
- var newArray = [];
- array.forEach(function(elt) {
- newArray.push(elt[0]);
- newArray.push(elt[1]);
- });
- return newArray;
- }
- distance(t2, o) {
- return Math.sqrt(Math.pow(t2[0] - o[0], 2) + Math.pow(t2[1] - o[1], 2));
- }
- getAngleOfThreePoints(t2, o, e) {
- var r2 = this.getAzimuth(o, t2) - this.getAzimuth(o, e);
- return 0 > r2 ? r2 + 2 * Math.PI : r2;
- }
- getAzimuth(t2, o) {
- var e, r2 = Math.asin(Math.abs(o[1] - t2[1]) / this.distance(t2, o));
- return o[1] >= t2[1] && o[0] >= t2[0] ? e = r2 + Math.PI : o[1] >= t2[1] && o[0] < t2[0] ? e = 2 * Math.PI - r2 : o[1] < t2[1] && o[0] < t2[0] ? e = r2 : o[1] < t2[1] && o[0] >= t2[0] && (e = Math.PI - r2), e;
- }
- getThirdPoint(t2, o, e, r2, n) {
- var g = this.getAzimuth(t2, o), i2 = n ? g + e : g - e, s = r2 * Math.cos(i2), a = r2 * Math.sin(i2);
- return [o[0] + s, o[1] + a];
- }
- }
- class DrawGatheringPlace {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.tt = 0.4;
- this.floatingPoint = null;
- this.drawHandler = null;
- this.gatheringPlace = null;
- this._gatheringPlaceLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_PincerArrow = [];
- this._gatheringPlaceData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._tooltip = createTooltip(this.viewer.container);
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get PincerArrow() {
- return this._gatheringPlaceLast;
- }
- getData() {
- return this._gatheringPlaceData;
- }
- computePosition(data) {
- var $this = this;
- if (data.length < 3) {
- return;
- }
- var gatheringPlace = [];
- var lonLats = [];
- var res = $this.fineGatheringPlace(data);
- for (var i2 = 0; i2 < res.length; i2++) {
- var cart3 = new $this.Cesium.Cartesian3(res[i2].x, res[i2].y, res[i2].z);
- gatheringPlace.push(cart3);
- }
- for (let q2 = 0; q2 < data.length; q2++) {
- lonLats.push($this.cartesianToLatlng(data[q2]));
- }
- this._gatheringPlaceData = lonLats;
- return new $this.Cesium.PolygonHierarchy(gatheringPlace);
- }
- addload(data) {
- var $this = this;
- if (data.length < 3) {
- return;
- }
- var gatheringPlace = [];
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.LatlngTocartesian(data[i2]);
- lnglatArr.push(lnglat);
- }
- var res = $this.fineGatheringPlace(lnglatArr);
- for (var i2 = 0; i2 < res.length; i2++) {
- var cart3 = new $this.Cesium.Cartesian3(res[i2].x, res[i2].y, res[i2].z);
- gatheringPlace.push(cart3);
- }
- var pHierarchy = new $this.Cesium.PolygonHierarchy(gatheringPlace);
- var arrowEntity = $this.viewer.entities.add({
- Type: "DrawGatheringPlace",
- Position: data,
- id: data.id || $this.objId,
- polygon: {
- hierarchy: pHierarchy,
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.polygonMaterial
- }
- });
- return arrowEntity;
- }
- startCreate(drawType) {
- if (isRuntimeApp()) {
- showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- }
- var $this = this;
- this.drawType = drawType;
- this.handler = new $this.Cesium.ScreenSpaceEventHandler($this.viewer.scene.canvas);
- this.handler.setInputAction(function(event2) {
- if (isRuntimeApp()) {
- var cartesian = $this.getCatesian3FromPX(event2.position);
- if (!cartesian) {
- return;
- }
- $this.createPoint(cartesian);
- $this._positions.push(cartesian);
- if ($this._positions.length < 3) {
- showTooltipMessage("\u70B9\u51FB\u6DFB\u52A0\u70B9");
- }
- if ($this._positions.length === 3) {
- showTooltipMessage("\u70B9\u51FB\u5B8C\u6210\u6309\u94AE\uFF0C\u7ED3\u675F\u7ED8\u5236");
- $this.destroy();
- if (!$this.Cesium.defined($this.gatheringPlace)) {
- $this.gatheringPlace = $this.createGatheringPlace();
- createOperationMainDom();
- document.getElementById("btnDrawBackout").style.display = "none";
- document.getElementById("btnDrawComplete").onclick = () => {
- $this._gatheringPlaceData = $this._positions.concat();
- $this.viewer.entities.remove($this.gatheringPlace);
- $this.gatheringPlace = null;
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._gatheringPlaceData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._gatheringPlaceData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._gatheringPlaceData = lnglatArr;
- var pincerArrow = $this.addload(lnglatArr);
- $this._entities_PincerArrow.push(pincerArrow);
- $this._gatheringPlaceLast = pincerArrow;
- $this.viewer.entities.remove($this.floatingPoint);
- $this.floatingPoint = null;
- $this.clearPoint();
- $this.destroy();
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv) {
- document.body.removeChild(buttonDiv);
- }
- };
- }
- }
- } else {
- clearTimeout($this._timer);
- $this._timer = setTimeout(function() {
- var position2 = event2.position;
- if (!$this.Cesium.defined(position2)) {
- return;
- }
- var ray = $this.viewer.camera.getPickRay(position2);
- if (!$this.Cesium.defined(ray)) {
- return;
- }
- var cartesian2 = $this.viewer.scene.globe.pick(ray, $this.viewer.scene);
- if (!$this.Cesium.defined(cartesian2)) {
- return;
- }
- if ($this._positions.length == 0) {
- $this._positions.push(cartesian2.clone());
- $this.floatingPoint = $this.createPoint(cartesian2);
- }
- if ($this._positions.length <= 2) {
- $this.createPoint(cartesian2);
- $this._positions.push(cartesian2);
- }
- }, 200);
- }
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(event2) {
- if (isRuntimeApp())
- return;
- if ($this._positions.length == 0) {
- $this._tooltip.showAt(event2.endPosition, "\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- } else {
- $this._tooltip.showAt(event2.endPosition, "\u70B9\u51FB\u6DFB\u52A0\u70B9");
- }
- if ($this._positions.length < 2) {
- return;
- }
- if ($this._positions.length == 3) {
- $this._tooltip.showAt(event2.endPosition, "\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236");
- }
- var position2 = event2.endPosition;
- if (!$this.Cesium.defined(position2)) {
- return;
- }
- var ray = $this.viewer.camera.getPickRay(position2);
- if (!$this.Cesium.defined(ray)) {
- return;
- }
- var cartesian = $this.viewer.scene.globe.pick(ray, $this.viewer.scene);
- if (!$this.Cesium.defined(cartesian)) {
- return;
- }
- if (!$this.Cesium.defined($this.gatheringPlace)) {
- $this.gatheringPlace = $this.createGatheringPlace();
- }
- $this.floatingPoint.position.setValue(cartesian);
- if ($this.gatheringPlace) {
- if ($this._positions.length == 3) {
- $this._positions[1] = cartesian;
- } else {
- $this._positions.pop();
- $this._positions.push(cartesian);
- }
- }
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(movement) {
- }, Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- this.handler.setInputAction(function(movement) {
- if (isRuntimeApp())
- return;
- clearTimeout($this._timer);
- if ($this._positions.length >= 3) {
- $this._gatheringPlaceData = $this._positions.concat();
- $this.viewer.entities.remove($this.gatheringPlace);
- $this.gatheringPlace = null;
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._gatheringPlaceData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._gatheringPlaceData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._gatheringPlaceData = lnglatArr;
- var pincerArrow = $this.addload(lnglatArr);
- $this._entities_PincerArrow.push(pincerArrow);
- $this._gatheringPlaceLast = pincerArrow;
- $this.viewer.entities.remove($this.floatingPoint);
- $this.floatingPoint = null;
- $this.clearPoint();
- $this.destroy();
- $this._tooltip.setVisible(false);
- }
- }, Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
- }
- createGatheringPlace() {
- let $this = this;
- var gatheringPlaceEntity = $this.viewer.entities.add({
- polygon: {
- hierarchy: new $this.Cesium.CallbackProperty(function() {
- if ($this._positions.length < 3) {
- return;
- }
- var gatheringPlace = [];
- var res = $this.fineGatheringPlace($this._positions);
- for (var i2 = 0; i2 < res.length; i2++) {
- var cart3 = new $this.Cesium.Cartesian3(res[i2].x, res[i2].y, res[i2].z);
- gatheringPlace.push(cart3);
- }
- var pHierarchy = new $this.Cesium.PolygonHierarchy(gatheringPlace);
- var lonLats = $this.cartesianToLatlng($this._positions);
- pHierarchy.keyPoints = lonLats;
- return pHierarchy;
- }, false),
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.polygonMaterial
- }
- });
- $this._entities_PincerArrow.push(gatheringPlaceEntity);
- return gatheringPlaceEntity;
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- cartesianToLatlng(cartesian) {
- let cartographic = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- let lat = this.Cesium.Math.toDegrees(cartographic.latitude);
- let lng = this.Cesium.Math.toDegrees(cartographic.longitude);
- let alt = cartographic.height;
- return [lng, lat, alt];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._gatheringPlaceLast, this._gatheringPlaceData, this.drawType);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_PincerArrow.length; i2++) {
- this.viewer.entities.remove(this._entities_PincerArrow[i2]);
- }
- this.floatingPoint = null;
- this._PincerArrow = null;
- this._PincerArrowLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_PincerArrow = [];
- this._PincerArrowData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- _computeTempPositions() {
- var _this = this;
- var pnts = [].concat(_this._positions);
- var num = pnts.length;
- var first = pnts[0];
- var last = pnts[num - 1];
- if (_this._isSimpleXYZ(first, last) == false) {
- pnts.push(first);
- num += 1;
- }
- _this.tempPositions = [];
- for (var i2 = 1; i2 < num; i2++) {
- var p1 = pnts[i2 - 1];
- var p2 = pnts[i2];
- var cp = _this._computeCenterPotition(p1, p2);
- _this.tempPositions.push(p1);
- _this.tempPositions.push(cp);
- }
- }
- _isSimpleXYZ(p1, p2) {
- if (p1.x == p2.x && p1.y == p2.y && p1.z == p2.z) {
- return true;
- }
- return false;
- }
- _computeCenterPotition(p1, p2) {
- var _this = this;
- var c1 = _this.viewer.scene.globe.ellipsoid.cartesianToCartographic(p1);
- var c2 = _this.viewer.scene.globe.ellipsoid.cartesianToCartographic(p2);
- var cm = new _this.Cesium.EllipsoidGeodesic(c1, c2).interpolateUsingFraction(0.5);
- var cp = _this.viewer.scene.globe.ellipsoid.cartographicToCartesian(cm);
- return cp;
- }
- getLonLat(cartesian) {
- var cartographic = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- cartographic.height = this.viewer.scene.globe.getHeight(cartographic);
- var pos = {
- lon: cartographic.longitude,
- lat: cartographic.latitude,
- alt: cartographic.height
- };
- pos.lon = this.Cesium.Math.toDegrees(pos.lon);
- pos.lat = this.Cesium.Math.toDegrees(pos.lat);
- return pos;
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- fineGatheringPlace(gatherPosition) {
- let $this = this;
- let points2 = gatherPosition.length;
- if (points2 < 2) {
- return false;
- } else {
- let pnts = new Array();
- gatherPosition.forEach(function(item) {
- var posLonLat = $this.getLonLat(item);
- pnts.push([posLonLat.lon, posLonLat.lat]);
- });
- if (pnts.length === 2) {
- let mid2 = $this.mid(pnts[0], pnts[1]);
- let d2 = $this.distance(pnts[0], mid2) / 0.9;
- let pnt = $this.getThirdPoint(pnts[0], mid2, Math.PI / 2, d2, true);
- pnts = [pnts[0], pnt, pnts[1]];
- }
- let mid = $this.mid(pnts[0], pnts[2]);
- pnts.push(mid, pnts[0], pnts[1]);
- let [normals, pnt1, pnt2, pnt3, pList] = [
- [],
- void 0,
- void 0,
- void 0,
- []
- ];
- for (let i2 = 0; i2 < pnts.length - 2; i2++) {
- pnt1 = pnts[i2];
- pnt2 = pnts[i2 + 1];
- pnt3 = pnts[i2 + 2];
- let normalPoints = $this.getBisectorNormals($this.tt, pnt1, pnt2, pnt3);
- normals = normals.concat(normalPoints);
- }
- let count = normals.length;
- normals = [normals[count - 1]].concat(normals.slice(0, count - 1));
- for (let i2 = 0; i2 < pnts.length - 2; i2++) {
- pnt1 = pnts[i2];
- pnt2 = pnts[i2 + 1];
- pList = pList.concat(pnt1);
- for (let t2 = 0; t2 <= 100; t2++) {
- let pnt = $this.getCubicValue(t2 / 100, pnt1, normals[i2 * 2], normals[i2 * 2 + 1], pnt2);
- pList = pList.concat(pnt);
- }
- pList = pList.concat(pnt2);
- }
- return Cesium.Cartesian3.fromDegreesArray(pList);
- }
- }
- mid(t2, o) {
- return [(t2[0] + o[0]) / 2, (t2[1] + o[1]) / 2];
- }
- distance(t2, o) {
- return Math.sqrt(Math.pow(t2[0] - o[0], 2) + Math.pow(t2[1] - o[1], 2));
- }
- getThirdPoint(t2, o, e, r2, n) {
- var g = this.getAzimuth(t2, o), i2 = n ? g + e : g - e, s = r2 * Math.cos(i2), a = r2 * Math.sin(i2);
- return [o[0] + s, o[1] + a];
- }
- getAzimuth(t2, o) {
- var e, r2 = Math.asin(Math.abs(o[1] - t2[1]) / this.distance(t2, o));
- return o[1] >= t2[1] && o[0] >= t2[0] ? e = r2 + Math.PI : o[1] >= t2[1] && o[0] < t2[0] ? e = 2 * Math.PI - r2 : o[1] < t2[1] && o[0] < t2[0] ? e = r2 : o[1] < t2[1] && o[0] >= t2[0] && (e = Math.PI - r2), e;
- }
- getBisectorNormals(t2, o, e, r2) {
- var n = this.getNormal(o, e, r2), g = Math.sqrt(n[0] * n[0] + n[1] * n[1]), i2 = n[0] / g, s = n[1] / g, a = this.distance(o, e), l = this.distance(e, r2);
- if (g > 1e-4)
- if (this.isClockWise(o, e, r2)) {
- var u = t2 * a, c = e[0] - u * s, p = e[1] + u * i2, h2 = [c, p];
- u = t2 * l, c = e[0] + u * s, p = e[1] - u * i2;
- var d2 = [c, p];
- } else
- u = t2 * a, c = e[0] + u * s, p = e[1] - u * i2, h2 = [c, p], u = t2 * l, c = e[0] - u * s, p = e[1] + u * i2, d2 = [c, p];
- else
- c = e[0] + t2 * (o[0] - e[0]), p = e[1] + t2 * (o[1] - e[1]), h2 = [c, p], c = e[0] + t2 * (r2[0] - e[0]), p = e[1] + t2 * (r2[1] - e[1]), d2 = [c, p];
- return [h2, d2];
- }
- getNormal(t2, o, e) {
- var r2 = t2[0] - o[0], n = t2[1] - o[1], g = Math.sqrt(r2 * r2 + n * n);
- r2 /= g, n /= g;
- var i2 = e[0] - o[0], s = e[1] - o[1], a = Math.sqrt(i2 * i2 + s * s);
- i2 /= a, s /= a;
- var l = r2 + i2, u = n + s;
- return [l, u];
- }
- isClockWise(t2, o, e) {
- return (e[1] - t2[1]) * (o[0] - t2[0]) > (o[1] - t2[1]) * (e[0] - t2[0]);
- }
- getCubicValue(t2, o, e, r2, n) {
- t2 = Math.max(Math.min(t2, 1), 0);
- var g = 1 - t2, i2 = t2 * t2, s = i2 * t2, a = g * g, l = a * g, u = l * o[0] + 3 * a * t2 * e[0] + 3 * g * i2 * r2[0] + s * n[0], c = l * o[1] + 3 * a * t2 * e[1] + 3 * g * i2 * r2[1] + s * n[1];
- return [u, c];
- }
- }
- class DrawClosedCurve {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.floatingPoint = null;
- this._ClosedCurve = null;
- this._ClosedCurveLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_ClosedCurve = [];
- this._ClosedCurveData = null;
- this.ZERO_TOLERANCE = 1e-4;
- this.FITTING_COUNT = 100;
- this.t = 0.3;
- this.objId = Number(new Date().getTime() + "" + Number(Math.random() * 1e3).toFixed(0));
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._tooltip = createTooltip(this.viewer.container);
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get ClosedCurve() {
- return this._ClosedCurveLast;
- }
- getData() {
- return this._ClosedCurveData;
- }
- computePosition(data) {
- let $this = this;
- if (data.length < 2)
- return;
- let pnts = [];
- for (let p = 0; p < data.length; p++) {
- pnts.push($this.cartesianToLatlng(data[p]));
- }
- this._ClosedCurveData = Array.from(pnts);
- pnts.push(pnts[0], pnts[1]);
- let [normals, pList] = [
- [],
- []
- ];
- for (let i2 = 0; i2 < pnts.length - 2; i2++) {
- let normalPoints = $this.getBisectorNormals($this.t, pnts[i2], pnts[i2 + 1], pnts[i2 + 2]);
- normals = normals.concat(normalPoints);
- }
- let count = normals.length;
- normals = [normals[count - 1]].concat(normals.slice(0, count - 1));
- for (let i2 = 0; i2 < pnts.length - 2; i2++) {
- let pnt1 = pnts[i2];
- let pnt2 = pnts[i2 + 1];
- pList.push($this.LatlngTocartesian(pnt1));
- for (let t2 = 0; t2 <= $this.FITTING_COUNT; t2++) {
- let pnt = $this.getCubicValue(t2 / $this.FITTING_COUNT, pnt1, normals[i2 * 2], normals[i2 * 2 + 1], pnt2);
- pList.push($this.LatlngTocartesian(pnt));
- }
- pList.push($this.LatlngTocartesian(pnt2));
- }
- let PolygonHierarchy = new $this.Cesium.PolygonHierarchy(pList);
- return {
- PolygonHierarchy,
- pList
- };
- }
- addload(data) {
- let $this = this;
- if (data.length < 2)
- return;
- let pnts = Array.from(data);
- pnts.push(pnts[0], pnts[1]);
- let [normals, pList] = [
- [],
- []
- ];
- for (let i2 = 0; i2 < pnts.length - 2; i2++) {
- let normalPoints = $this.getBisectorNormals($this.t, pnts[i2], pnts[i2 + 1], pnts[i2 + 2]);
- normals = normals.concat(normalPoints);
- }
- let count = normals.length;
- normals = [normals[count - 1]].concat(normals.slice(0, count - 1));
- for (let i2 = 0; i2 < pnts.length - 2; i2++) {
- let pnt1 = pnts[i2];
- let pnt2 = pnts[i2 + 1];
- pList.push($this.LatlngTocartesian(pnt1));
- for (let t2 = 0; t2 <= $this.FITTING_COUNT; t2++) {
- let pnt = $this.getCubicValue(t2 / $this.FITTING_COUNT, pnt1, normals[i2 * 2], normals[i2 * 2 + 1], pnt2);
- pList.push($this.LatlngTocartesian(pnt));
- }
- pList.push($this.LatlngTocartesian(pnt2));
- }
- var arrowEntity = $this.viewer.entities.add({
- Type: "DrawClosedCurve",
- Position: data,
- id: data.id || $this.objId,
- polygon: {
- hierarchy: new $this.Cesium.PolygonHierarchy(pList),
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.polygonMaterial
- },
- polyline: {
- positions: pList,
- show: true,
- material: new Cesium.PolylineDashMaterialProperty({
- color: Cesium.Color.YELLOW
- }),
- width: 3,
- clampToGround: true
- }
- });
- return arrowEntity;
- }
- startCreate(drawType) {
- if (isRuntimeApp()) {
- showTooltipMessage("\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- }
- var $this = this;
- this.drawType = drawType;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- if (isRuntimeApp()) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if (!cartesian) {
- return;
- }
- $this.createPoint(cartesian);
- $this._positions.push(cartesian);
- if ($this._positions.length > 2) {
- showTooltipMessage("\u70B9\u51FB\u6DFB\u52A0\u70B9\uFF0C\u70B9\u51FB\u5B8C\u6210\u6309\u94AE\uFF0C\u7ED3\u675F\u7ED8\u5236");
- if ($this._positions.length === 3) {
- if (!$this.Cesium.defined($this._ClosedCurve)) {
- $this._ClosedCurve = $this.createClosedCurve();
- createOperationMainDom();
- document.getElementById("btnDrawBackout").style.display = "none";
- document.getElementById("btnDrawComplete").onclick = () => {
- $this._ClosedCurveData = $this._positions.concat();
- $this.viewer.entities.remove($this._ClosedCurve);
- $this._ClosedCurve = null;
- $this._positions = [];
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._ClosedCurveData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._ClosedCurveData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._ClosedCurveData = lnglatArr;
- var ClosedCurve = $this.addload(lnglatArr);
- $this._entities_ClosedCurve.push(ClosedCurve);
- $this._ClosedCurveLast = ClosedCurve;
- $this.clearPoint();
- $this.destroy();
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv) {
- document.body.removeChild(buttonDiv);
- }
- };
- }
- }
- } else {
- showTooltipMessage("\u70B9\u51FB\u6DFB\u52A0\u70B9");
- }
- } else {
- clearTimeout($this._timer);
- $this._timer = setTimeout(function() {
- var cartesian2 = $this.getCatesian3FromPX(evt.position);
- if ($this._positions.length == 0) {
- $this.floatingPoint = $this.createPoint(cartesian2);
- }
- $this._positions.push(cartesian2);
- $this.createPoint(cartesian2);
- }, 200);
- }
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if (isRuntimeApp())
- return;
- if ($this._positions.length == 0) {
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u5F00\u59CB\u7ED8\u5236");
- } else {
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u6DFB\u52A0\u70B9");
- }
- if ($this._positions.length < 2)
- return;
- $this._tooltip.showAt(evt.endPosition, "\u70B9\u51FB\u6DFB\u52A0\u70B9\uFF0C\u53CC\u51FB\u7ED3\u675F\u7ED8\u5236");
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if ($this._positions.length == 2) {
- $this._positions.push(cartesian);
- }
- $this._positions.pop();
- $this._positions.push(cartesian);
- if (!$this.Cesium.defined($this._ClosedCurve)) {
- $this._ClosedCurve = $this.createClosedCurve();
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- this.handler.setInputAction(function(evt) {
- if (isRuntimeApp())
- return;
- clearTimeout($this._timer);
- if (!$this._ClosedCurve)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.position);
- $this._positions.pop();
- $this._positions.push(cartesian);
- $this._ClosedCurveData = $this._positions.concat();
- $this.viewer.entities.remove($this._ClosedCurve);
- $this._ClosedCurve = null;
- $this._positions = [];
- $this.floatingPoint.position.setValue(cartesian);
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._ClosedCurveData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._ClosedCurveData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._ClosedCurveData = lnglatArr;
- var ClosedCurve = $this.addload(lnglatArr);
- $this._entities_ClosedCurve.push(ClosedCurve);
- $this._ClosedCurveLast = ClosedCurve;
- $this.clearPoint();
- $this.destroy();
- $this._tooltip.setVisible(false);
- }, $this.Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
- }
- createClosedCurve() {
- var $this = this;
- $this.pLists = "";
- var arrowEntity = $this.viewer.entities.add({
- polygon: {
- hierarchy: new $this.Cesium.CallbackProperty(
- function() {
- if ($this._positions.length < 2)
- return;
- let pnts = [];
- for (let p = 0; p < $this._positions.length; p++) {
- pnts.push($this.cartesianToLatlng($this._positions[p]));
- }
- pnts.push(pnts[0], pnts[1]);
- let [normals, pList] = [
- [],
- []
- ];
- for (let i2 = 0; i2 < pnts.length - 2; i2++) {
- let normalPoints = $this.getBisectorNormals($this.t, pnts[i2], pnts[i2 + 1], pnts[i2 + 2]);
- normals = normals.concat(normalPoints);
- }
- let count = normals.length;
- normals = [normals[count - 1]].concat(normals.slice(0, count - 1));
- for (let i2 = 0; i2 < pnts.length - 2; i2++) {
- let pnt1 = pnts[i2];
- let pnt2 = pnts[i2 + 1];
- pList.push($this.LatlngTocartesian(pnt1));
- for (let t2 = 0; t2 <= $this.FITTING_COUNT; t2++) {
- let pnt = $this.getCubicValue(t2 / $this.FITTING_COUNT, pnt1, normals[i2 * 2], normals[i2 * 2 + 1], pnt2);
- pList.push($this.LatlngTocartesian(pnt));
- }
- pList.push($this.LatlngTocartesian(pnt2));
- }
- $this.pLists = pList;
- return new $this.Cesium.PolygonHierarchy(pList);
- },
- false
- ),
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.polygonMaterial
- },
- polyline: {
- positions: new $this.Cesium.CallbackProperty(
- function() {
- return $this.pLists;
- },
- false
- ),
- show: true,
- material: new Cesium.PolylineDashMaterialProperty({
- color: Cesium.Color.YELLOW
- }),
- width: 3,
- clampToGround: true
- }
- });
- $this._entities_ClosedCurve.push(arrowEntity);
- return arrowEntity;
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- cartesianToLatlng(cartesian) {
- var latlng = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- var lat = this.Cesium.Math.toDegrees(latlng.latitude);
- var lng = this.Cesium.Math.toDegrees(latlng.longitude);
- return [lng, lat];
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- lonLatToMercator(Latlng) {
- var E2 = Latlng[0];
- var N2 = Latlng[1];
- var x = E2 * 2003750834e-2 / 180;
- var y = Math.log(Math.tan((90 + N2) * Math.PI / 360)) / (Math.PI / 180);
- y = y * 2003750834e-2 / 180;
- return [x, y];
- }
- WebMercator2lonLat(mercator) {
- let x = mercator[0] / 2003750834e-2 * 180;
- let ly = mercator[1] / 2003750834e-2 * 180;
- let y = 180 / Math.PI * (2 * Math.atan(Math.exp(ly * Math.PI / 180)) - Math.PI / 2);
- return [x, y];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._ClosedCurveLast, this._ClosedCurveData);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_ClosedCurve.length; i2++) {
- this.viewer.entities.remove(this._entities_ClosedCurve[i2]);
- }
- this.floatingPoint = null;
- this._ClosedCurve = null;
- this._ClosedCurveLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_ClosedCurve = [];
- this._ClosedCurveData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- getBisectorNormals(t2, pnt1, pnt2, pnt3) {
- let $this = this;
- let normal = $this.getNormal(pnt1, pnt2, pnt3);
- let [bisectorNormalRight, bisectorNormalLeft, dt2, x, y] = [null, null, null, null, null];
- let dist = Math.sqrt(normal[0] * normal[0] + normal[1] * normal[1]);
- let uX = normal[0] / dist;
- let uY = normal[1] / dist;
- let d1 = $this.MathDistance(pnt1, pnt2);
- let d2 = $this.MathDistance(pnt2, pnt3);
- if (dist > $this.ZERO_TOLERANCE) {
- if ($this.isClockWise(pnt1, pnt2, pnt3)) {
- dt2 = t2 * d1;
- x = pnt2[0] - dt2 * uY;
- y = pnt2[1] + dt2 * uX;
- bisectorNormalRight = [x, y];
- dt2 = t2 * d2;
- x = pnt2[0] + dt2 * uY;
- y = pnt2[1] - dt2 * uX;
- bisectorNormalLeft = [x, y];
- } else {
- dt2 = t2 * d1;
- x = pnt2[0] + dt2 * uY;
- y = pnt2[1] - dt2 * uX;
- bisectorNormalRight = [x, y];
- dt2 = t2 * d2;
- x = pnt2[0] - dt2 * uY;
- y = pnt2[1] + dt2 * uX;
- bisectorNormalLeft = [x, y];
- }
- } else {
- x = pnt2[0] + t2 * (pnt1[0] - pnt2[0]);
- y = pnt2[1] + t2 * (pnt1[1] - pnt2[1]);
- bisectorNormalRight = [x, y];
- x = pnt2[0] + t2 * (pnt3[0] - pnt2[0]);
- y = pnt2[1] + t2 * (pnt3[1] - pnt2[1]);
- bisectorNormalLeft = [x, y];
- }
- return [bisectorNormalRight, bisectorNormalLeft];
- }
- getNormal(pnt1, pnt2, pnt3) {
- let dX1 = pnt1[0] - pnt2[0];
- let dY1 = pnt1[1] - pnt2[1];
- let d1 = Math.sqrt(dX1 * dX1 + dY1 * dY1);
- dX1 /= d1;
- dY1 /= d1;
- let dX2 = pnt3[0] - pnt2[0];
- let dY2 = pnt3[1] - pnt2[1];
- let d2 = Math.sqrt(dX2 * dX2 + dY2 * dY2);
- dX2 /= d2;
- dY2 /= d2;
- let uX = dX1 + dX2;
- let uY = dY1 + dY2;
- return [uX, uY];
- }
- MathDistance(pnt1, pnt2) {
- return Math.sqrt(Math.pow(pnt1[0] - pnt2[0], 2) + Math.pow(pnt1[1] - pnt2[1], 2));
- }
- isClockWise(pnt1, pnt2, pnt3) {
- return (pnt3[1] - pnt1[1]) * (pnt2[0] - pnt1[0]) > (pnt2[1] - pnt1[1]) * (pnt3[0] - pnt1[0]);
- }
- getCubicValue(t2, startPnt, cPnt1, cPnt2, endPnt) {
- t2 = Math.max(Math.min(t2, 1), 0);
- let [tp, t22] = [1 - t2, t2 * t2];
- let t3 = t22 * t2;
- let tp2 = tp * tp;
- let tp3 = tp2 * tp;
- let x = tp3 * startPnt[0] + 3 * tp2 * t2 * cPnt1[0] + 3 * tp * t22 * cPnt2[0] + t3 * endPnt[0];
- let y = tp3 * startPnt[1] + 3 * tp2 * t2 * cPnt1[1] + 3 * tp * t22 * cPnt2[1] + t3 * endPnt[1];
- return [x, y];
- }
- }
- class DrawSector {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.floatingPoint = null;
- this._sector = null;
- this._sectorLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_sector = [];
- this._sectorData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get sector() {
- return this._sectorLast;
- }
- getData() {
- return this._sectorData;
- }
- computePosition(data) {
- let $this = this;
- let pnts = data;
- let center2 = $this.lonLatToMercator($this.cartesianToLatlng(pnts[0]));
- let pnt2 = $this.lonLatToMercator($this.cartesianToLatlng(pnts[1]));
- let pnt3 = $this.lonLatToMercator($this.cartesianToLatlng(pnts[2]));
- var radius = $this.MathDistance(pnt2, center2);
- var startAngle = $this.getAzimuth(pnt2, center2);
- var endAngle = $this.getAzimuth(pnt3, center2);
- var pList = $this.getArcPoints(center2, radius, startAngle, endAngle);
- pList.push(pnts[0], pList[0]);
- let arrow = [];
- for (var i2 = 0; i2 < pList.length; i2++) {
- var cart3 = new $this.Cesium.Cartesian3(pList[i2].x, pList[i2].y, pList[i2].z);
- arrow.push(cart3);
- }
- var lnglatArr = [];
- for (var d2 = 0; d2 < data.length; d2++) {
- lnglatArr.push($this.cartesianToLatlng(data[d2]));
- }
- $this._sectorData = lnglatArr;
- return new $this.Cesium.PolygonHierarchy(arrow);
- }
- addload(data) {
- var $this = this;
- let pnts = data;
- let center2 = $this.lonLatToMercator(pnts[0]);
- let pnt2 = $this.lonLatToMercator(pnts[1]);
- let pnt3 = $this.lonLatToMercator(pnts[2]);
- var radius = $this.MathDistance(pnt2, center2);
- var startAngle = $this.getAzimuth(pnt2, center2);
- var endAngle = $this.getAzimuth(pnt3, center2);
- var pList = $this.getArcPoints(center2, radius, startAngle, endAngle);
- let pntsc = $this.Cesium.Cartesian3.fromDegrees(pnts[0][0], pnts[0][1]);
- pList.push(pntsc, pList[0]);
- let arrow = [];
- for (var i2 = 0; i2 < pList.length; i2++) {
- var cart3 = new $this.Cesium.Cartesian3(pList[i2].x, pList[i2].y, pList[i2].z);
- arrow.push(cart3);
- }
- var arrowEntity = $this.viewer.entities.add({
- Type: "DrawSector",
- Position: data,
- id: data.id || $this.objId,
- polygon: {
- hierarchy: new $this.Cesium.PolygonHierarchy(arrow),
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.Cesium.Color.AQUA.withAlpha(0.9)
- }
- });
- return arrowEntity;
- }
- startCreate() {
- var $this = this;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if ($this._positions.length < 3) {
- $this.floatingPoint = $this.createPoint(cartesian);
- $this._positions.push(cartesian);
- }
- if (!$this._sector)
- ;
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if ($this._positions.length < 2)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if ($this._positions.length == 2) {
- $this._positions.push(cartesian);
- }
- if ($this._positions.length == 3) {
- $this._positions.pop();
- $this._positions.push(cartesian);
- if (!$this.Cesium.defined($this._sector)) {
- $this._sector = $this.createsector();
- }
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- if (!$this._sector)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.position);
- $this._positions.pop();
- $this._positions.push(cartesian);
- $this._sectorData = $this._positions.concat();
- $this.viewer.entities.remove($this._sector);
- $this._sector = null;
- $this._positions = [];
- $this.floatingPoint.position.setValue(cartesian);
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._sectorData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._sectorData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._sectorData = lnglatArr;
- var sector = $this.addload(lnglatArr);
- $this._entities_sector.push(sector);
- $this._sectorLast = sector;
- $this.clearPoint();
- $this.destroy();
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- }
- createsector() {
- var $this = this;
- var arrowEntity = $this.viewer.entities.add(
- {
- polygon: {
- hierarchy: new $this.Cesium.CallbackProperty(
- function() {
- let pnts = $this._positions;
- let center2 = $this.lonLatToMercator($this.cartesianToLatlng(pnts[0]));
- let pnt2 = $this.lonLatToMercator($this.cartesianToLatlng(pnts[1]));
- let pnt3 = $this.lonLatToMercator($this.cartesianToLatlng(pnts[2]));
- var radius = $this.MathDistance(pnt2, center2);
- var startAngle = $this.getAzimuth(pnt2, center2);
- var endAngle = $this.getAzimuth(pnt3, center2);
- var pList = $this.getArcPoints(center2, radius, startAngle, endAngle);
- pList.push(pnts[0], pList[0]);
- for (var i2 = 0; i2 < pList.length; i2++) {
- new $this.Cesium.Cartesian3(pList[i2].x, pList[i2].y, pList[i2].z);
- }
- return new $this.Cesium.PolygonHierarchy(pList);
- },
- false
- ),
- show: true,
- fill: true,
- clampToGround: true,
- material: $this.Cesium.Color.AQUA.withAlpha(0.5)
- }
- }
- );
- $this._entities_sector.push(arrowEntity);
- return arrowEntity;
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- cartesianToLatlng(cartesian) {
- var latlng = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- var lat = this.Cesium.Math.toDegrees(latlng.latitude);
- var lng = this.Cesium.Math.toDegrees(latlng.longitude);
- return [lng, lat];
- }
- lonLatToMercator(Latlng) {
- var E2 = Latlng[0];
- var N2 = Latlng[1];
- var x = E2 * 2003750834e-2 / 180;
- var y = Math.log(Math.tan((90 + N2) * Math.PI / 360)) / (Math.PI / 180);
- y = y * 2003750834e-2 / 180;
- return [x, y];
- }
- WebMercator2lonLat(mercator) {
- let x = mercator[0] / 2003750834e-2 * 180;
- let ly = mercator[1] / 2003750834e-2 * 180;
- let y = 180 / Math.PI * (2 * Math.atan(Math.exp(ly * Math.PI / 180)) - Math.PI / 2);
- return [x, y];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._sectorLast, this._sectorData);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_sector.length; i2++) {
- this.viewer.entities.remove(this._entities_sector[i2]);
- }
- this.floatingPoint = null;
- this._sector = null;
- this._sectorLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_sector = [];
- this._sectorData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- MathDistance(pnt1, pnt2) {
- return Math.sqrt(Math.pow(pnt1[0] - pnt2[0], 2) + Math.pow(pnt1[1] - pnt2[1], 2));
- }
- getAzimuth(startPoint, endPoint) {
- var azimuth;
- var angle = Math.asin(Math.abs(endPoint[1] - startPoint[1]) / this.MathDistance(startPoint, endPoint));
- if (endPoint[1] >= startPoint[1] && endPoint[0] >= startPoint[0]) {
- azimuth = angle + Math.PI;
- } else if (endPoint[1] >= startPoint[1] && endPoint[0] < startPoint[0]) {
- azimuth = Math.PI * 2 - angle;
- } else if (endPoint[1] < startPoint[1] && endPoint[0] < startPoint[0]) {
- azimuth = angle;
- } else if (endPoint[1] < startPoint[1] && endPoint[0] >= startPoint[0]) {
- azimuth = Math.PI - angle;
- }
- return azimuth;
- }
- getArcPoints(center2, radius, startAngle, endAngle) {
- var x = null, y = null, pnts = [], angleDiff = endAngle - startAngle;
- angleDiff = angleDiff < 0 ? angleDiff + Math.PI * 2 : angleDiff;
- for (var i2 = 0; i2 <= 100; i2++) {
- var angle = startAngle + angleDiff * i2 / 100;
- x = center2[0] + radius * Math.cos(angle);
- y = center2[1] + radius * Math.sin(angle);
- let latlon = this.WebMercator2lonLat([x, y]);
- pnts.push(this.Cesium.Cartesian3.fromDegrees(latlon[0], latlon[1]));
- }
- return pnts;
- }
- }
- class DrawBowLine {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.tt = 0.4;
- this.floatingPoint = null;
- this.drawHandler = null;
- this.DrawBowLine = null;
- this._DrawBowLineLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_PincerArrow = [];
- this._DrawBowLineData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get PincerArrow() {
- return this._DrawBowLineLast;
- }
- getData() {
- return this._DrawBowLineData;
- }
- computePosition(data) {
- var $this = this;
- if (data.length < 3) {
- return;
- }
- var DrawBowLine2 = [];
- let positions = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- positions.push($this.cartesianToLatlng(data[i2]));
- var cart3 = $this.lonLatToMercator($this.cartesianToLatlng(data[i2]));
- DrawBowLine2.push(cart3);
- }
- let [pnt1, pnt2, pnt3, startAngle, endAngle] = [DrawBowLine2[0], DrawBowLine2[2], DrawBowLine2[1], null, null];
- let center2 = $this.getCircleCenterOfThreePoints(pnt1, pnt2, pnt3);
- let radius = $this.MathDistance(pnt1, center2);
- let angle1 = $this.getAzimuth(pnt1, center2);
- let angle2 = $this.getAzimuth(pnt2, center2);
- if ($this.isClockWise(pnt1, pnt2, pnt3)) {
- startAngle = angle2;
- endAngle = angle1;
- } else {
- startAngle = angle1;
- endAngle = angle2;
- }
- let getArcPoint = $this.getArcPoints(center2, radius, startAngle, endAngle);
- let pHierarchy = [];
- for (var l = 0; l < getArcPoint.length; l++) {
- var cart3 = $this.LatlngTocartesian($this.WebMercator2lonLat(getArcPoint[l]));
- pHierarchy.push(cart3);
- }
- $this._DrawBowLineData = positions;
- return pHierarchy;
- }
- addload(data) {
- var $this = this;
- if (data.length < 3) {
- return;
- }
- var DrawBowLine2 = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var cart3 = $this.lonLatToMercator(data[i2]);
- DrawBowLine2.push(cart3);
- }
- let [pnt1, pnt2, pnt3, startAngle, endAngle] = [DrawBowLine2[0], DrawBowLine2[2], DrawBowLine2[1], null, null];
- let center2 = $this.getCircleCenterOfThreePoints(pnt1, pnt2, pnt3);
- let radius = $this.MathDistance(pnt1, center2);
- let angle1 = $this.getAzimuth(pnt1, center2);
- let angle2 = $this.getAzimuth(pnt2, center2);
- if ($this.isClockWise(pnt1, pnt2, pnt3)) {
- startAngle = angle2;
- endAngle = angle1;
- } else {
- startAngle = angle1;
- endAngle = angle2;
- }
- let getArcPoint = $this.getArcPoints(center2, radius, startAngle, endAngle);
- let pHierarchy = [];
- for (var l = 0; l < getArcPoint.length; l++) {
- var cart3 = $this.LatlngTocartesian($this.WebMercator2lonLat(getArcPoint[l]));
- pHierarchy.push(cart3);
- }
- var arrowEntity = $this.viewer.entities.add({
- Type: "DrawBowLine",
- Position: data,
- id: data.id || $this.objId,
- polyline: {
- positions: pHierarchy,
- show: true,
- material: $this.Cesium.Color.YELLOW,
- width: 3,
- clampToGround: true
- }
- });
- return arrowEntity;
- }
- startCreate(drawType) {
- this.drawType = drawType;
- var $this = this;
- this.handler = new $this.Cesium.ScreenSpaceEventHandler($this.viewer.scene.canvas);
- this.handler.setInputAction(function(event2) {
- var position2 = event2.position;
- if (!$this.Cesium.defined(position2)) {
- return;
- }
- var ray = $this.viewer.camera.getPickRay(position2);
- if (!$this.Cesium.defined(ray)) {
- return;
- }
- var cartesian = $this.viewer.scene.globe.pick(ray, $this.viewer.scene);
- if (!$this.Cesium.defined(cartesian)) {
- return;
- }
- if ($this._positions.length == 0) {
- $this._positions.push(cartesian.clone());
- $this.floatingPoint = $this.createPoint(cartesian);
- }
- if ($this._positions.length <= 2) {
- $this.createPoint(cartesian);
- $this._positions.push(cartesian);
- }
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(event2) {
- if ($this._positions.length < 2) {
- return;
- }
- var position2 = event2.endPosition;
- if (!$this.Cesium.defined(position2)) {
- return;
- }
- var ray = $this.viewer.camera.getPickRay(position2);
- if (!$this.Cesium.defined(ray)) {
- return;
- }
- var cartesian = $this.viewer.scene.globe.pick(ray, $this.viewer.scene);
- if (!$this.Cesium.defined(cartesian)) {
- return;
- }
- if (!$this.Cesium.defined($this.DrawBowLine)) {
- $this.DrawBowLine = $this.createDrawBowLine();
- }
- $this.floatingPoint.position.setValue(cartesian);
- if ($this.DrawBowLine) {
- if ($this._positions.length == 3) {
- $this._positions[1] = cartesian;
- } else {
- $this._positions.pop();
- $this._positions.push(cartesian);
- }
- }
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(movement) {
- if ($this._positions.length >= 3) {
- $this._DrawBowLineData = $this._positions.concat();
- $this.viewer.entities.remove($this.DrawBowLine);
- $this.DrawBowLine = null;
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._DrawBowLineData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._DrawBowLineData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._DrawBowLineData = lnglatArr;
- var pincerArrow = $this.addload(lnglatArr);
- $this._entities_PincerArrow.push(pincerArrow);
- $this._DrawBowLineLast = pincerArrow;
- $this.viewer.entities.remove($this.floatingPoint);
- $this.floatingPoint = null;
- $this.clearPoint();
- $this.destroy();
- }
- }, Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- }
- createDrawBowLine() {
- let $this = this;
- var DrawBowLineEntity = $this.viewer.entities.add({
- polyline: {
- positions: new $this.Cesium.CallbackProperty(function() {
- if ($this._positions.length < 3) {
- return;
- }
- var DrawBowLine2 = [];
- for (var i2 = 0; i2 < $this._positions.length; i2++) {
- var cart3 = $this.lonLatToMercator($this.cartesianToLatlng($this._positions[i2]));
- DrawBowLine2.push(cart3);
- }
- let [pnt1, pnt2, pnt3, startAngle, endAngle] = [DrawBowLine2[0], DrawBowLine2[2], DrawBowLine2[1], null, null];
- let center2 = $this.getCircleCenterOfThreePoints(pnt1, pnt2, pnt3);
- let radius = $this.MathDistance(pnt1, center2);
- let angle1 = $this.getAzimuth(pnt1, center2);
- let angle2 = $this.getAzimuth(pnt2, center2);
- if ($this.isClockWise(pnt1, pnt2, pnt3)) {
- startAngle = angle2;
- endAngle = angle1;
- } else {
- startAngle = angle1;
- endAngle = angle2;
- }
- let getArcPoint = $this.getArcPoints(center2, radius, startAngle, endAngle);
- let pHierarchy = [];
- for (var l = 0; l < getArcPoint.length; l++) {
- var cart3 = $this.LatlngTocartesian($this.WebMercator2lonLat(getArcPoint[l]));
- pHierarchy.push(cart3);
- }
- return pHierarchy;
- }, false),
- show: true,
- material: $this.Cesium.Color.YELLOW,
- width: 3,
- clampToGround: true
- }
- });
- $this._entities_PincerArrow.push(DrawBowLineEntity);
- return DrawBowLineEntity;
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- cartesianToLatlng(cartesian) {
- let cartographic = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- let lat = this.Cesium.Math.toDegrees(cartographic.latitude);
- let lng = this.Cesium.Math.toDegrees(cartographic.longitude);
- cartographic.height;
- return [lng, lat];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._DrawBowLineLast, this._DrawBowLineData, this.drawType);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_PincerArrow.length; i2++) {
- this.viewer.entities.remove(this._entities_PincerArrow[i2]);
- }
- this.floatingPoint = null;
- this._PincerArrow = null;
- this._PincerArrowLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_PincerArrow = [];
- this._PincerArrowData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- _computeTempPositions() {
- var _this = this;
- var pnts = [].concat(_this._positions);
- var num = pnts.length;
- var first = pnts[0];
- var last = pnts[num - 1];
- if (_this._isSimpleXYZ(first, last) == false) {
- pnts.push(first);
- num += 1;
- }
- _this.tempPositions = [];
- for (var i2 = 1; i2 < num; i2++) {
- var p1 = pnts[i2 - 1];
- var p2 = pnts[i2];
- var cp = _this._computeCenterPotition(p1, p2);
- _this.tempPositions.push(p1);
- _this.tempPositions.push(cp);
- }
- }
- _isSimpleXYZ(p1, p2) {
- if (p1.x == p2.x && p1.y == p2.y && p1.z == p2.z) {
- return true;
- }
- return false;
- }
- _computeCenterPotition(p1, p2) {
- var _this = this;
- var c1 = _this.viewer.scene.globe.ellipsoid.cartesianToCartographic(p1);
- var c2 = _this.viewer.scene.globe.ellipsoid.cartesianToCartographic(p2);
- var cm = new _this.Cesium.EllipsoidGeodesic(c1, c2).interpolateUsingFraction(0.5);
- var cp = _this.viewer.scene.globe.ellipsoid.cartographicToCartesian(cm);
- return cp;
- }
- getLonLat(cartesian) {
- var cartographic = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- cartographic.height = this.viewer.scene.globe.getHeight(cartographic);
- var pos = {
- lon: cartographic.longitude,
- lat: cartographic.latitude,
- alt: cartographic.height
- };
- pos.lon = this.Cesium.Math.toDegrees(pos.lon);
- pos.lat = this.Cesium.Math.toDegrees(pos.lat);
- return pos;
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- lonLatToMercator(Latlng) {
- var E2 = Latlng[0];
- var N2 = Latlng[1];
- var x = E2 * 2003750834e-2 / 180;
- var y = Math.log(Math.tan((90 + N2) * Math.PI / 360)) / (Math.PI / 180);
- y = y * 2003750834e-2 / 180;
- return [x, y];
- }
- WebMercator2lonLat(mercator) {
- let x = mercator[0] / 2003750834e-2 * 180;
- let ly = mercator[1] / 2003750834e-2 * 180;
- let y = 180 / Math.PI * (2 * Math.atan(Math.exp(ly * Math.PI / 180)) - Math.PI / 2);
- return [x, y];
- }
- getCircleCenterOfThreePoints(point1, point2, point3) {
- let pntA = [(point1[0] + point2[0]) / 2, (point1[1] + point2[1]) / 2];
- let pntB = [pntA[0] - point1[1] + point2[1], pntA[1] + point1[0] - point2[0]];
- let pntC = [(point1[0] + point3[0]) / 2, (point1[1] + point3[1]) / 2];
- let pntD = [pntC[0] - point1[1] + point3[1], pntC[1] + point1[0] - point3[0]];
- return this.getIntersectPoint(pntA, pntB, pntC, pntD);
- }
- getIntersectPoint(pntA, pntB, pntC, pntD) {
- if (pntA[1] === pntB[1]) {
- let f2 = (pntD[0] - pntC[0]) / (pntD[1] - pntC[1]);
- let x2 = f2 * (pntA[1] - pntC[1]) + pntC[0];
- let y2 = pntA[1];
- return [x2, y2];
- }
- if (pntC[1] === pntD[1]) {
- let e2 = (pntB[0] - pntA[0]) / (pntB[1] - pntA[1]);
- let x2 = e2 * (pntC[1] - pntA[1]) + pntA[0];
- let y2 = pntC[1];
- return [x2, y2];
- }
- let e = (pntB[0] - pntA[0]) / (pntB[1] - pntA[1]);
- let f = (pntD[0] - pntC[0]) / (pntD[1] - pntC[1]);
- let y = (e * pntA[1] - pntA[0] - f * pntC[1] + pntC[0]) / (e - f);
- let x = e * y - e * pntA[1] + pntA[0];
- return [x, y];
- }
- MathDistance(pnt1, pnt2) {
- return Math.sqrt(Math.pow(pnt1[0] - pnt2[0], 2) + Math.pow(pnt1[1] - pnt2[1], 2));
- }
- getAzimuth(startPoint, endPoint) {
- let azimuth;
- let angle = Math.asin(Math.abs(endPoint[1] - startPoint[1]) / this.MathDistance(startPoint, endPoint));
- if (endPoint[1] >= startPoint[1] && endPoint[0] >= startPoint[0]) {
- azimuth = angle + Math.PI;
- } else if (endPoint[1] >= startPoint[1] && endPoint[0] < startPoint[0]) {
- azimuth = Math.PI * 2 - angle;
- } else if (endPoint[1] < startPoint[1] && endPoint[0] < startPoint[0]) {
- azimuth = angle;
- } else if (endPoint[1] < startPoint[1] && endPoint[0] >= startPoint[0]) {
- azimuth = Math.PI - angle;
- }
- return azimuth;
- }
- isClockWise(pnt1, pnt2, pnt3) {
- return (pnt3[1] - pnt1[1]) * (pnt2[0] - pnt1[0]) > (pnt2[1] - pnt1[1]) * (pnt3[0] - pnt1[0]);
- }
- getArcPoints(center2, radius, startAngle, endAngle) {
- let [x, y, pnts, angleDiff] = [null, null, [], endAngle - startAngle];
- angleDiff = angleDiff < 0 ? angleDiff + Math.PI * 2 : angleDiff;
- for (let i2 = 0; i2 <= 100; i2++) {
- let angle = startAngle + angleDiff * i2 / 100;
- x = center2[0] + radius * Math.cos(angle);
- y = center2[1] + radius * Math.sin(angle);
- pnts.push([x, y]);
- }
- return pnts;
- }
- }
- class DrawBowPlane {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.tt = 0.4;
- this.floatingPoint = null;
- this.drawHandler = null;
- this.DrawBowPlane = null;
- this._DrawBowPlaneLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_PincerArrow = [];
- this._DrawBowPlaneData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get PincerArrow() {
- return this._DrawBowPlaneLast;
- }
- getData() {
- return this._DrawBowPlaneData;
- }
- computePosition(data) {
- var $this = this;
- if (data.length < 3) {
- return;
- }
- var DrawBowPlane2 = [];
- let positions = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- positions.push($this.cartesianToLatlng(data[i2]));
- var cart3 = $this.lonLatToMercator($this.cartesianToLatlng(data[i2]));
- DrawBowPlane2.push(cart3);
- }
- let [pnt1, pnt2, pnt3, startAngle, endAngle] = [DrawBowPlane2[0], DrawBowPlane2[2], DrawBowPlane2[1], null, null];
- let center2 = $this.getCircleCenterOfThreePoints(pnt1, pnt2, pnt3);
- let radius = $this.MathDistance(pnt1, center2);
- let angle1 = $this.getAzimuth(pnt1, center2);
- let angle2 = $this.getAzimuth(pnt2, center2);
- if ($this.isClockWise(pnt1, pnt2, pnt3)) {
- startAngle = angle2;
- endAngle = angle1;
- } else {
- startAngle = angle1;
- endAngle = angle2;
- }
- let getArcPoint = $this.getArcPoints(center2, radius, startAngle, endAngle);
- let pHierarchy = [];
- for (var l = 0; l < getArcPoint.length; l++) {
- var cart3 = $this.LatlngTocartesian($this.WebMercator2lonLat(getArcPoint[l]));
- pHierarchy.push(cart3);
- }
- pHierarchy.push(pHierarchy[0]);
- $this._DrawBowPlaneData = positions;
- return new $this.Cesium.PolygonHierarchy(pHierarchy);
- }
- addload(data) {
- var $this = this;
- if (data.length < 3) {
- return;
- }
- var DrawBowPlane2 = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var cart3 = $this.lonLatToMercator(data[i2]);
- DrawBowPlane2.push(cart3);
- }
- let [pnt1, pnt2, pnt3, startAngle, endAngle] = [DrawBowPlane2[0], DrawBowPlane2[2], DrawBowPlane2[1], null, null];
- let center2 = $this.getCircleCenterOfThreePoints(pnt1, pnt2, pnt3);
- let radius = $this.MathDistance(pnt1, center2);
- let angle1 = $this.getAzimuth(pnt1, center2);
- let angle2 = $this.getAzimuth(pnt2, center2);
- if ($this.isClockWise(pnt1, pnt2, pnt3)) {
- startAngle = angle2;
- endAngle = angle1;
- } else {
- startAngle = angle1;
- endAngle = angle2;
- }
- let getArcPoint = $this.getArcPoints(center2, radius, startAngle, endAngle);
- let pHierarchy = [];
- for (var l = 0; l < getArcPoint.length; l++) {
- var cart3 = $this.LatlngTocartesian($this.WebMercator2lonLat(getArcPoint[l]));
- pHierarchy.push(cart3);
- }
- pHierarchy.push(pHierarchy[0]);
- var arrowEntity = $this.viewer.entities.add(
- {
- Type: "DrawBowPlane",
- Position: data,
- id: data.id || $this.objId,
- polygon: {
- hierarchy: new $this.Cesium.PolygonHierarchy(pHierarchy),
- show: true,
- material: $this.Cesium.Color.YELLOW,
- width: 3,
- clampToGround: true,
- outlineWidth: 3,
- outline: true,
- outlineColor: Cesium.Color.MAGENTA
- }
- }
- );
- return arrowEntity;
- }
- startCreate(drawType) {
- this.drawType = drawType;
- var $this = this;
- this.handler = new $this.Cesium.ScreenSpaceEventHandler($this.viewer.scene.canvas);
- this.handler.setInputAction(function(event2) {
- var position2 = event2.position;
- if (!$this.Cesium.defined(position2)) {
- return;
- }
- var ray = $this.viewer.camera.getPickRay(position2);
- if (!$this.Cesium.defined(ray)) {
- return;
- }
- var cartesian = $this.viewer.scene.globe.pick(ray, $this.viewer.scene);
- if (!$this.Cesium.defined(cartesian)) {
- return;
- }
- if ($this._positions.length == 0) {
- $this._positions.push(cartesian.clone());
- $this.floatingPoint = $this.createPoint(cartesian);
- }
- if ($this._positions.length <= 2) {
- $this.createPoint(cartesian);
- $this._positions.push(cartesian);
- }
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(event2) {
- if ($this._positions.length < 2) {
- return;
- }
- var position2 = event2.endPosition;
- if (!$this.Cesium.defined(position2)) {
- return;
- }
- var ray = $this.viewer.camera.getPickRay(position2);
- if (!$this.Cesium.defined(ray)) {
- return;
- }
- var cartesian = $this.viewer.scene.globe.pick(ray, $this.viewer.scene);
- if (!$this.Cesium.defined(cartesian)) {
- return;
- }
- if (!$this.Cesium.defined($this.DrawBowPlane)) {
- $this.DrawBowPlane = $this.createDrawBowPlane();
- }
- $this.floatingPoint.position.setValue(cartesian);
- if ($this.DrawBowPlane) {
- if ($this._positions.length == 3) {
- $this._positions[1] = cartesian;
- } else {
- $this._positions.pop();
- $this._positions.push(cartesian);
- }
- }
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(movement) {
- if ($this._positions.length >= 3) {
- $this._DrawBowPlaneData = $this._positions.concat();
- $this.viewer.entities.remove($this.DrawBowPlane);
- $this.DrawBowPlane = null;
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._DrawBowPlaneData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._DrawBowPlaneData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._DrawBowPlaneData = lnglatArr;
- var pincerArrow = $this.addload(lnglatArr);
- $this._entities_PincerArrow.push(pincerArrow);
- $this._DrawBowPlaneLast = pincerArrow;
- $this.viewer.entities.remove($this.floatingPoint);
- $this.floatingPoint = null;
- $this.clearPoint();
- $this.destroy();
- }
- }, Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- }
- createDrawBowPlane() {
- let $this = this;
- var DrawBowPlaneEntity = $this.viewer.entities.add(
- {
- polygon: {
- hierarchy: new $this.Cesium.CallbackProperty(function() {
- if ($this._positions.length < 3) {
- return;
- }
- var DrawBowPlane2 = [];
- for (var i2 = 0; i2 < $this._positions.length; i2++) {
- var cart3 = $this.lonLatToMercator($this.cartesianToLatlng($this._positions[i2]));
- DrawBowPlane2.push(cart3);
- }
- let [pnt1, pnt2, pnt3, startAngle, endAngle] = [DrawBowPlane2[0], DrawBowPlane2[2], DrawBowPlane2[1], null, null];
- let center2 = $this.getCircleCenterOfThreePoints(pnt1, pnt2, pnt3);
- let radius = $this.MathDistance(pnt1, center2);
- let angle1 = $this.getAzimuth(pnt1, center2);
- let angle2 = $this.getAzimuth(pnt2, center2);
- if ($this.isClockWise(pnt1, pnt2, pnt3)) {
- startAngle = angle2;
- endAngle = angle1;
- } else {
- startAngle = angle1;
- endAngle = angle2;
- }
- let getArcPoint = $this.getArcPoints(center2, radius, startAngle, endAngle);
- let pHierarchy = [];
- for (var l = 0; l < getArcPoint.length; l++) {
- var cart3 = $this.LatlngTocartesian($this.WebMercator2lonLat(getArcPoint[l]));
- pHierarchy.push(cart3);
- }
- pHierarchy.push(pHierarchy[0]);
- return new $this.Cesium.PolygonHierarchy(pHierarchy);
- }, false),
- show: true,
- material: $this.Cesium.Color.YELLOW,
- clampToGround: true
- }
- }
- );
- $this._entities_PincerArrow.push(DrawBowPlaneEntity);
- return DrawBowPlaneEntity;
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- cartesianToLatlng(cartesian) {
- let cartographic = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- let lat = this.Cesium.Math.toDegrees(cartographic.latitude);
- let lng = this.Cesium.Math.toDegrees(cartographic.longitude);
- cartographic.height;
- return [lng, lat];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._DrawBowPlaneLast, this._DrawBowPlaneData, this.drawType);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_PincerArrow.length; i2++) {
- this.viewer.entities.remove(this._entities_PincerArrow[i2]);
- }
- this.floatingPoint = null;
- this._PincerArrow = null;
- this._PincerArrowLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_PincerArrow = [];
- this._PincerArrowData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- _computeTempPositions() {
- var _this = this;
- var pnts = [].concat(_this._positions);
- var num = pnts.length;
- var first = pnts[0];
- var last = pnts[num - 1];
- if (_this._isSimpleXYZ(first, last) == false) {
- pnts.push(first);
- num += 1;
- }
- _this.tempPositions = [];
- for (var i2 = 1; i2 < num; i2++) {
- var p1 = pnts[i2 - 1];
- var p2 = pnts[i2];
- var cp = _this._computeCenterPotition(p1, p2);
- _this.tempPositions.push(p1);
- _this.tempPositions.push(cp);
- }
- }
- _isSimpleXYZ(p1, p2) {
- if (p1.x == p2.x && p1.y == p2.y && p1.z == p2.z) {
- return true;
- }
- return false;
- }
- _computeCenterPotition(p1, p2) {
- var _this = this;
- var c1 = _this.viewer.scene.globe.ellipsoid.cartesianToCartographic(p1);
- var c2 = _this.viewer.scene.globe.ellipsoid.cartesianToCartographic(p2);
- var cm = new _this.Cesium.EllipsoidGeodesic(c1, c2).interpolateUsingFraction(0.5);
- var cp = _this.viewer.scene.globe.ellipsoid.cartographicToCartesian(cm);
- return cp;
- }
- getLonLat(cartesian) {
- var cartographic = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- cartographic.height = this.viewer.scene.globe.getHeight(cartographic);
- var pos = {
- lon: cartographic.longitude,
- lat: cartographic.latitude,
- alt: cartographic.height
- };
- pos.lon = this.Cesium.Math.toDegrees(pos.lon);
- pos.lat = this.Cesium.Math.toDegrees(pos.lat);
- return pos;
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- lonLatToMercator(Latlng) {
- var E2 = Latlng[0];
- var N2 = Latlng[1];
- var x = E2 * 2003750834e-2 / 180;
- var y = Math.log(Math.tan((90 + N2) * Math.PI / 360)) / (Math.PI / 180);
- y = y * 2003750834e-2 / 180;
- return [x, y];
- }
- WebMercator2lonLat(mercator) {
- let x = mercator[0] / 2003750834e-2 * 180;
- let ly = mercator[1] / 2003750834e-2 * 180;
- let y = 180 / Math.PI * (2 * Math.atan(Math.exp(ly * Math.PI / 180)) - Math.PI / 2);
- return [x, y];
- }
- getCircleCenterOfThreePoints(point1, point2, point3) {
- let pntA = [(point1[0] + point2[0]) / 2, (point1[1] + point2[1]) / 2];
- let pntB = [pntA[0] - point1[1] + point2[1], pntA[1] + point1[0] - point2[0]];
- let pntC = [(point1[0] + point3[0]) / 2, (point1[1] + point3[1]) / 2];
- let pntD = [pntC[0] - point1[1] + point3[1], pntC[1] + point1[0] - point3[0]];
- return this.getIntersectPoint(pntA, pntB, pntC, pntD);
- }
- getIntersectPoint(pntA, pntB, pntC, pntD) {
- if (pntA[1] === pntB[1]) {
- let f2 = (pntD[0] - pntC[0]) / (pntD[1] - pntC[1]);
- let x2 = f2 * (pntA[1] - pntC[1]) + pntC[0];
- let y2 = pntA[1];
- return [x2, y2];
- }
- if (pntC[1] === pntD[1]) {
- let e2 = (pntB[0] - pntA[0]) / (pntB[1] - pntA[1]);
- let x2 = e2 * (pntC[1] - pntA[1]) + pntA[0];
- let y2 = pntC[1];
- return [x2, y2];
- }
- let e = (pntB[0] - pntA[0]) / (pntB[1] - pntA[1]);
- let f = (pntD[0] - pntC[0]) / (pntD[1] - pntC[1]);
- let y = (e * pntA[1] - pntA[0] - f * pntC[1] + pntC[0]) / (e - f);
- let x = e * y - e * pntA[1] + pntA[0];
- return [x, y];
- }
- MathDistance(pnt1, pnt2) {
- return Math.sqrt(Math.pow(pnt1[0] - pnt2[0], 2) + Math.pow(pnt1[1] - pnt2[1], 2));
- }
- getAzimuth(startPoint, endPoint) {
- let azimuth;
- let angle = Math.asin(Math.abs(endPoint[1] - startPoint[1]) / this.MathDistance(startPoint, endPoint));
- if (endPoint[1] >= startPoint[1] && endPoint[0] >= startPoint[0]) {
- azimuth = angle + Math.PI;
- } else if (endPoint[1] >= startPoint[1] && endPoint[0] < startPoint[0]) {
- azimuth = Math.PI * 2 - angle;
- } else if (endPoint[1] < startPoint[1] && endPoint[0] < startPoint[0]) {
- azimuth = angle;
- } else if (endPoint[1] < startPoint[1] && endPoint[0] >= startPoint[0]) {
- azimuth = Math.PI - angle;
- }
- return azimuth;
- }
- isClockWise(pnt1, pnt2, pnt3) {
- return (pnt3[1] - pnt1[1]) * (pnt2[0] - pnt1[0]) > (pnt2[1] - pnt1[1]) * (pnt3[0] - pnt1[0]);
- }
- getArcPoints(center2, radius, startAngle, endAngle) {
- let [x, y, pnts, angleDiff] = [null, null, [], endAngle - startAngle];
- angleDiff = angleDiff < 0 ? angleDiff + Math.PI * 2 : angleDiff;
- for (let i2 = 0; i2 <= 100; i2++) {
- let angle = startAngle + angleDiff * i2 / 100;
- x = center2[0] + radius * Math.cos(angle);
- y = center2[1] + radius * Math.sin(angle);
- pnts.push([x, y]);
- }
- return pnts;
- }
- }
- class DrawCurve {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.floatingPoint = null;
- this._curveline = null;
- this._curvelineLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_line = [];
- this._curvelineData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this.ZERO_TOLERANCE = 1e-4;
- this.FITTING_COUNT = 100;
- this.t = 0.3;
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get curveline() {
- return this._curvelineLast;
- }
- getData() {
- return this._curvelineData;
- }
- addload(data) {
- var $this = this;
- let pnts = [];
- for (let p = 0; p < data.length; p++) {
- pnts.push($this.lonLatToMercator(data[p]));
- }
- let CurvePoints = $this.getCurvePoints(pnts);
- let point2 = [];
- for (let i2 = 0; i2 < CurvePoints.length; i2++) {
- point2.push($this.LatlngTocartesian($this.WebMercator2lonLat(CurvePoints[i2])));
- }
- var polyline = this.viewer.entities.add({
- Type: "DrawCurve",
- Position: data,
- id: data.id || $this.objId,
- polyline: {
- positions: point2,
- show: true,
- material: $this.Cesium.Color.YELLOW,
- width: 3,
- clampToGround: true
- }
- });
- return polyline;
- }
- computePosition(data) {
- let pnts = [];
- let position2 = [];
- for (let p = 0; p < data.length; p++) {
- position2.push(this.cartesianToLatlng(data[p]));
- pnts.push(this.lonLatToMercator(this.cartesianToLatlng(data[p])));
- }
- this._curvelineData = position2;
- let CurvePoints = this.getCurvePoints(pnts);
- let point2 = [];
- for (let i2 = 0; i2 < CurvePoints.length; i2++) {
- point2.push(this.LatlngTocartesian(this.WebMercator2lonLat(CurvePoints[i2])));
- }
- return point2;
- }
- startCreate(drawType) {
- this.drawType = drawType;
- var $this = this;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if ($this._positions.length == 0) {
- $this._positions.push(cartesian.clone());
- $this.floatingPoint = $this.createPoint(cartesian);
- $this.createPoint(cartesian);
- }
- $this._positions.push(cartesian);
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if ($this._positions.length < 3)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if (!$this.Cesium.defined($this._curveline)) {
- $this._curveline = $this.createCurveline();
- }
- $this.floatingPoint.position.setValue(cartesian);
- if ($this._curveline) {
- $this._positions.pop();
- $this._positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- if (!$this._curveline)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.position);
- $this._positions.pop();
- $this._positions.push(cartesian);
- $this.createPoint(cartesian);
- $this._curvelineData = $this._positions.concat();
- $this.viewer.entities.remove($this._curveline);
- $this._curveline = null;
- $this._positions = [];
- $this.floatingPoint.position.setValue(cartesian);
- let lnglatArr = [];
- for (var i2 = 0; i2 < $this._curvelineData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._curvelineData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._curvelineData = lnglatArr;
- var line = $this.addload($this._curvelineData);
- $this._entities_line.push(line);
- $this._curvelineLast = line;
- $this.clearPoint();
- $this.destroy();
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- createCurveline() {
- var $this = this;
- var polyline = this.viewer.entities.add({
- polyline: {
- positions: new $this.Cesium.CallbackProperty(function() {
- let pnts = [];
- for (let p = 0; p < $this._positions.length; p++) {
- pnts.push($this.lonLatToMercator($this.cartesianToLatlng($this._positions[p])));
- }
- let CurvePoints = $this.getCurvePoints(pnts);
- let point2 = [];
- for (let i2 = 0; i2 < CurvePoints.length; i2++) {
- point2.push($this.LatlngTocartesian($this.WebMercator2lonLat(CurvePoints[i2])));
- }
- return point2;
- }, false),
- show: true,
- material: $this.Cesium.Color.YELLOW,
- width: 3,
- clampToGround: true
- }
- });
- $this._entities_line.push(polyline);
- return polyline;
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._curvelineLast, this._curvelineData, this.drawType);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_line.length; i2++) {
- this.viewer.entities.remove(this._entities_line[i2]);
- }
- this.floatingPoint = null;
- this._curveline = null;
- this._curvelineLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_line = [];
- this._curvelineData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- cartesianToLatlng(cartesian) {
- var latlng = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- var lat = this.Cesium.Math.toDegrees(latlng.latitude);
- var lng = this.Cesium.Math.toDegrees(latlng.longitude);
- return [lng, lat];
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- lonLatToMercator(Latlng) {
- var E2 = Latlng[0];
- var N2 = Latlng[1];
- var x = E2 * 2003750834e-2 / 180;
- var y = Math.log(Math.tan((90 + N2) * Math.PI / 360)) / (Math.PI / 180);
- y = y * 2003750834e-2 / 180;
- return [x, y];
- }
- WebMercator2lonLat(mercator) {
- let x = mercator[0] / 2003750834e-2 * 180;
- let ly = mercator[1] / 2003750834e-2 * 180;
- let y = 180 / Math.PI * (2 * Math.atan(Math.exp(ly * Math.PI / 180)) - Math.PI / 2);
- return [x, y];
- }
- getCurvePoints(controlPoints) {
- let leftControl = this.getLeftMostControlPoint(controlPoints, this.t);
- let [pnt1, pnt2, pnt3, normals, points2] = [null, null, null, [leftControl], []];
- for (let i2 = 0; i2 < controlPoints.length - 2; i2++) {
- [pnt1, pnt2, pnt3] = [controlPoints[i2], controlPoints[i2 + 1], controlPoints[i2 + 2]];
- let normalPoints = this.getBisectorNormals(this.t, pnt1, pnt2, pnt3);
- normals = normals.concat(normalPoints);
- }
- let rightControl = this.getRightMostControlPoint(controlPoints, this.t);
- if (rightControl) {
- normals.push(rightControl);
- }
- for (let i2 = 0; i2 < controlPoints.length - 1; i2++) {
- pnt1 = controlPoints[i2];
- pnt2 = controlPoints[i2 + 1];
- points2.push(pnt1);
- for (let t2 = 0; t2 < this.FITTING_COUNT; t2++) {
- let pnt = this.getCubicValue(t2 / this.FITTING_COUNT, pnt1, normals[i2 * 2], normals[i2 * 2 + 1], pnt2);
- points2.push(pnt);
- }
- points2.push(pnt2);
- }
- return points2;
- }
- getLeftMostControlPoint(controlPoints, t2) {
- let [pnt1, pnt2, pnt3, controlX, controlY] = [controlPoints[0], controlPoints[1], controlPoints[2], null, null];
- let pnts = this.getBisectorNormals(0, pnt1, pnt2, pnt3);
- let normalRight = pnts[0];
- let normal = this.getNormal(pnt1, pnt2, pnt3);
- let dist = Math.sqrt(normal[0] * normal[0] + normal[1] * normal[1]);
- if (dist > this.ZERO_TOLERANCE) {
- let mid = this.Mid(pnt1, pnt2);
- let pX = pnt1[0] - mid[0];
- let pY = pnt1[1] - mid[1];
- let d1 = this.MathDistance(pnt1, pnt2);
- let n = 2 / d1;
- let nX = -n * pY;
- let nY = n * pX;
- let a11 = nX * nX - nY * nY;
- let a12 = 2 * nX * nY;
- let a22 = nY * nY - nX * nX;
- let dX = normalRight[0] - mid[0];
- let dY = normalRight[1] - mid[1];
- controlX = mid[0] + a11 * dX + a12 * dY;
- controlY = mid[1] + a12 * dX + a22 * dY;
- } else {
- controlX = pnt1[0] + t2 * (pnt2[0] - pnt1[0]);
- controlY = pnt1[1] + t2 * (pnt2[1] - pnt1[1]);
- }
- return [controlX, controlY];
- }
- getBisectorNormals(t2, pnt1, pnt2, pnt3) {
- let normal = this.getNormal(pnt1, pnt2, pnt3);
- let [bisectorNormalRight, bisectorNormalLeft, dt2, x, y] = [null, null, null, null, null];
- let dist = Math.sqrt(normal[0] * normal[0] + normal[1] * normal[1]);
- let uX = normal[0] / dist;
- let uY = normal[1] / dist;
- let d1 = this.MathDistance(pnt1, pnt2);
- let d2 = this.MathDistance(pnt2, pnt3);
- if (dist > this.ZERO_TOLERANCE) {
- if (this.isClockWise(pnt1, pnt2, pnt3)) {
- dt2 = t2 * d1;
- x = pnt2[0] - dt2 * uY;
- y = pnt2[1] + dt2 * uX;
- bisectorNormalRight = [x, y];
- dt2 = t2 * d2;
- x = pnt2[0] + dt2 * uY;
- y = pnt2[1] - dt2 * uX;
- bisectorNormalLeft = [x, y];
- } else {
- dt2 = t2 * d1;
- x = pnt2[0] + dt2 * uY;
- y = pnt2[1] - dt2 * uX;
- bisectorNormalRight = [x, y];
- dt2 = t2 * d2;
- x = pnt2[0] - dt2 * uY;
- y = pnt2[1] + dt2 * uX;
- bisectorNormalLeft = [x, y];
- }
- } else {
- x = pnt2[0] + t2 * (pnt1[0] - pnt2[0]);
- y = pnt2[1] + t2 * (pnt1[1] - pnt2[1]);
- bisectorNormalRight = [x, y];
- x = pnt2[0] + t2 * (pnt3[0] - pnt2[0]);
- y = pnt2[1] + t2 * (pnt3[1] - pnt2[1]);
- bisectorNormalLeft = [x, y];
- }
- return [bisectorNormalRight, bisectorNormalLeft];
- }
- getNormal(pnt1, pnt2, pnt3) {
- let dX1 = pnt1[0] - pnt2[0];
- let dY1 = pnt1[1] - pnt2[1];
- let d1 = Math.sqrt(dX1 * dX1 + dY1 * dY1);
- dX1 /= d1;
- dY1 /= d1;
- let dX2 = pnt3[0] - pnt2[0];
- let dY2 = pnt3[1] - pnt2[1];
- let d2 = Math.sqrt(dX2 * dX2 + dY2 * dY2);
- dX2 /= d2;
- dY2 /= d2;
- let uX = dX1 + dX2;
- let uY = dY1 + dY2;
- return [uX, uY];
- }
- isClockWise(pnt1, pnt2, pnt3) {
- return (pnt3[1] - pnt1[1]) * (pnt2[0] - pnt1[0]) > (pnt2[1] - pnt1[1]) * (pnt3[0] - pnt1[0]);
- }
- Mid(point1, point2) {
- return [(point1[0] + point2[0]) / 2, (point1[1] + point2[1]) / 2];
- }
- MathDistance(pnt1, pnt2) {
- return Math.sqrt(Math.pow(pnt1[0] - pnt2[0], 2) + Math.pow(pnt1[1] - pnt2[1], 2));
- }
- getRightMostControlPoint(controlPoints, t2) {
- let count = controlPoints.length;
- let pnt1 = controlPoints[count - 3];
- let pnt2 = controlPoints[count - 2];
- let pnt3 = controlPoints[count - 1];
- let pnts = this.getBisectorNormals(0, pnt1, pnt2, pnt3);
- let normalLeft = pnts[1];
- let normal = this.getNormal(pnt1, pnt2, pnt3);
- let dist = Math.sqrt(normal[0] * normal[0] + normal[1] * normal[1]);
- let [controlX, controlY] = [null, null];
- if (dist > this.ZERO_TOLERANCE) {
- let mid = this.Mid(pnt2, pnt3);
- let pX = pnt3[0] - mid[0];
- let pY = pnt3[1] - mid[1];
- let d1 = this.MathDistance(pnt2, pnt3);
- let n = 2 / d1;
- let nX = -n * pY;
- let nY = n * pX;
- let a11 = nX * nX - nY * nY;
- let a12 = 2 * nX * nY;
- let a22 = nY * nY - nX * nX;
- let dX = normalLeft[0] - mid[0];
- let dY = normalLeft[1] - mid[1];
- controlX = mid[0] + a11 * dX + a12 * dY;
- controlY = mid[1] + a12 * dX + a22 * dY;
- } else {
- controlX = pnt3[0] + t2 * (pnt2[0] - pnt3[0]);
- controlY = pnt3[1] + t2 * (pnt2[1] - pnt3[1]);
- }
- return [controlX, controlY];
- }
- getCubicValue(t2, startPnt, cPnt1, cPnt2, endPnt) {
- t2 = Math.max(Math.min(t2, 1), 0);
- let [tp, t22] = [1 - t2, t2 * t2];
- let t3 = t22 * t2;
- let tp2 = tp * tp;
- let tp3 = tp2 * tp;
- let x = tp3 * startPnt[0] + 3 * tp2 * t2 * cPnt1[0] + 3 * tp * t22 * cPnt2[0] + t3 * endPnt[0];
- let y = tp3 * startPnt[1] + 3 * tp2 * t2 * cPnt1[1] + 3 * tp * t22 * cPnt2[1] + t3 * endPnt[1];
- return [x, y];
- }
- }
- class DrawCurveFlag {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.identificationPoint = null;
- this.CurveFlag = null;
- this.CurveFlagLast = null;
- this.positions = [];
- this.entitiesPoint = [];
- this.entitiesCurveFlag = [];
- this.CurveFlagData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- getData() {
- return this.CurveFlagData;
- }
- computePosition(data) {
- let $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.cartesianToLatlng(data[i2]);
- lnglatArr.push(lnglat);
- }
- let startPoint = lnglatArr[0];
- let endPoint = lnglatArr[lnglatArr.length - 1];
- let point1 = startPoint;
- let point2 = [(endPoint[0] - startPoint[0]) / 4 + startPoint[0], (endPoint[1] - startPoint[1]) / 8 + startPoint[1]];
- let point3 = [(startPoint[0] + endPoint[0]) / 2, startPoint[1]];
- let point4 = [(endPoint[0] - startPoint[0]) * 3 / 4 + startPoint[0], -(endPoint[1] - startPoint[1]) / 8 + startPoint[1]];
- let point5 = [endPoint[0], startPoint[1]];
- let point6 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- let point7 = [(endPoint[0] - startPoint[0]) * 3 / 4 + startPoint[0], (endPoint[1] - startPoint[1]) * 3 / 8 + startPoint[1]];
- let point8 = [(startPoint[0] + endPoint[0]) / 2, (startPoint[1] + endPoint[1]) / 2];
- let point9 = [(endPoint[0] - startPoint[0]) / 4 + startPoint[0], (endPoint[1] - startPoint[1]) * 5 / 8 + startPoint[1]];
- let point10 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- let point11 = [startPoint[0], endPoint[1]];
- let curve1 = $this.getBezierPoints([point1, point2, point3, point4, point5]);
- let curve2 = $this.getBezierPoints([point6, point7, point8, point9, point10]);
- let componentspolygon = [];
- componentspolygon = curve1.concat(curve2);
- let PolygonHierarchy = new $this.Cesium.PolygonHierarchy(componentspolygon);
- let componentspolyline = [];
- componentspolyline = curve1.concat(curve2);
- componentspolyline.push($this.LatlngTocartesian(point1));
- componentspolyline.push($this.LatlngTocartesian(point11));
- $this.CurveFlagData = lnglatArr;
- return [PolygonHierarchy, componentspolyline];
- }
- addload(data) {
- var $this = this;
- if (data.length < 2)
- return;
- let startPoint = data[0];
- let endPoint = data[data.length - 1];
- let point1 = startPoint;
- let point2 = [(endPoint[0] - startPoint[0]) / 4 + startPoint[0], (endPoint[1] - startPoint[1]) / 8 + startPoint[1]];
- let point3 = [(startPoint[0] + endPoint[0]) / 2, startPoint[1]];
- let point4 = [(endPoint[0] - startPoint[0]) * 3 / 4 + startPoint[0], -(endPoint[1] - startPoint[1]) / 8 + startPoint[1]];
- let point5 = [endPoint[0], startPoint[1]];
- let point6 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- let point7 = [(endPoint[0] - startPoint[0]) * 3 / 4 + startPoint[0], (endPoint[1] - startPoint[1]) * 3 / 8 + startPoint[1]];
- let point8 = [(startPoint[0] + endPoint[0]) / 2, (startPoint[1] + endPoint[1]) / 2];
- let point9 = [(endPoint[0] - startPoint[0]) / 4 + startPoint[0], (endPoint[1] - startPoint[1]) * 5 / 8 + startPoint[1]];
- let point10 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- let point11 = [startPoint[0], endPoint[1]];
- let curve1 = $this.getBezierPoints([point1, point2, point3, point4, point5]);
- let curve2 = $this.getBezierPoints([point6, point7, point8, point9, point10]);
- let componentspolygon = [];
- componentspolygon = curve1.concat(curve2);
- let componentspolyline = [];
- componentspolyline = curve1.concat(curve2);
- componentspolyline.push($this.LatlngTocartesian(point1));
- componentspolyline.push($this.LatlngTocartesian(point11));
- var shape = this.viewer.entities.add({
- Type: "DrawCurveFlag",
- Position: data,
- id: data.id || $this.objId,
- polygon: {
- hierarchy: new $this.Cesium.PolygonHierarchy(componentspolygon),
- extrudedHeight: 1,
- material: $this.Cesium.Color.RED
- },
- polyline: {
- positions: componentspolyline,
- show: true,
- material: $this.Cesium.Color.YELLOW,
- width: 5,
- clampToGround: true
- }
- });
- $this.entitiesCurveFlag.push(shape);
- return shape;
- }
- startCreate(drawType) {
- this.drawType = drawType;
- var $this = this;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if ($this.positions.length == 0) {
- $this.positions.push(cartesian.clone());
- $this.identificationPoint = $this.createPoint(cartesian);
- $this.createPoint(cartesian);
- $this.positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if ($this.positions.length < 2)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if (!$this.Cesium.defined($this.CurveFlag)) {
- $this.CurveFlag = $this.createCurveFlag();
- }
- $this.identificationPoint.position.setValue(cartesian);
- if ($this.CurveFlag) {
- $this.positions.pop();
- $this.positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- if (!$this.CurveFlag)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.position);
- $this.positions.pop();
- $this.positions.push(cartesian);
- $this.createPoint(cartesian);
- $this.CurveFlagData = $this.positions.concat();
- $this.viewer.entities.remove($this.CurveFlag);
- $this.CurveFlag = null;
- $this.positions = [];
- $this.identificationPoint.position.setValue(cartesian);
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this.CurveFlagData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this.CurveFlagData[i2]);
- lnglatArr.push(lnglat);
- }
- $this.CurveFlagData = lnglatArr;
- var CurveFlag = $this.addload([$this.CurveFlagData[0], $this.CurveFlagData[$this.CurveFlagData.length - 1]]);
- $this.entitiesCurveFlag.push(CurveFlag);
- $this.CurveFlagLast = CurveFlag;
- $this.clearPoint();
- $this.destroy();
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this.entitiesPoint.push(point2);
- return point2;
- }
- createCurveFlag() {
- var $this = this;
- var polygon2 = this.viewer.entities.add({
- polygon: {
- hierarchy: new $this.Cesium.CallbackProperty(function() {
- if ($this.positions.length < 2)
- return;
- let lonlat = [];
- let components = [];
- let length = $this.positions.length;
- for (let i2 = 0; i2 < length; i2++) {
- lonlat.push($this.cartesianToLatlng($this.positions[i2]));
- }
- let startPoint = lonlat[0];
- let endPoint = lonlat[lonlat.length - 1];
- let point1 = startPoint;
- let point2 = [(endPoint[0] - startPoint[0]) / 4 + startPoint[0], (endPoint[1] - startPoint[1]) / 8 + startPoint[1]];
- let point3 = [(startPoint[0] + endPoint[0]) / 2, startPoint[1]];
- let point4 = [(endPoint[0] - startPoint[0]) * 3 / 4 + startPoint[0], -(endPoint[1] - startPoint[1]) / 8 + startPoint[1]];
- let point5 = [endPoint[0], startPoint[1]];
- let point6 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- let point7 = [(endPoint[0] - startPoint[0]) * 3 / 4 + startPoint[0], (endPoint[1] - startPoint[1]) * 3 / 8 + startPoint[1]];
- let point8 = [(startPoint[0] + endPoint[0]) / 2, (startPoint[1] + endPoint[1]) / 2];
- let point9 = [(endPoint[0] - startPoint[0]) / 4 + startPoint[0], (endPoint[1] - startPoint[1]) * 5 / 8 + startPoint[1]];
- let point10 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- [startPoint[0], endPoint[1]];
- let curve1 = $this.getBezierPoints([point1, point2, point3, point4, point5]);
- let curve2 = $this.getBezierPoints([point6, point7, point8, point9, point10]);
- components = curve1.concat(curve2);
- return new $this.Cesium.PolygonHierarchy(components);
- }, false),
- extrudedHeight: 1,
- material: $this.Cesium.Color.RED
- },
- polyline: {
- positions: new $this.Cesium.CallbackProperty(function() {
- if ($this.positions.length < 2)
- return;
- let lonlat = [];
- let components = [];
- let length = $this.positions.length;
- for (let i2 = 0; i2 < length; i2++) {
- lonlat.push($this.cartesianToLatlng($this.positions[i2]));
- }
- let startPoint = lonlat[0];
- let endPoint = lonlat[lonlat.length - 1];
- let point1 = startPoint;
- let point2 = [(endPoint[0] - startPoint[0]) / 4 + startPoint[0], (endPoint[1] - startPoint[1]) / 8 + startPoint[1]];
- let point3 = [(startPoint[0] + endPoint[0]) / 2, startPoint[1]];
- let point4 = [(endPoint[0] - startPoint[0]) * 3 / 4 + startPoint[0], -(endPoint[1] - startPoint[1]) / 8 + startPoint[1]];
- let point5 = [endPoint[0], startPoint[1]];
- let point6 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- let point7 = [(endPoint[0] - startPoint[0]) * 3 / 4 + startPoint[0], (endPoint[1] - startPoint[1]) * 3 / 8 + startPoint[1]];
- let point8 = [(startPoint[0] + endPoint[0]) / 2, (startPoint[1] + endPoint[1]) / 2];
- let point9 = [(endPoint[0] - startPoint[0]) / 4 + startPoint[0], (endPoint[1] - startPoint[1]) * 5 / 8 + startPoint[1]];
- let point10 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- let point11 = [startPoint[0], endPoint[1]];
- let curve1 = $this.getBezierPoints([point1, point2, point3, point4, point5]);
- let curve2 = $this.getBezierPoints([point6, point7, point8, point9, point10]);
- components = curve1.concat(curve2);
- components.push($this.LatlngTocartesian(point1));
- components.push($this.LatlngTocartesian(point11));
- return components;
- }, false),
- show: true,
- material: $this.Cesium.Color.YELLOW,
- width: 5,
- clampToGround: true
- }
- });
- $this.entitiesCurveFlag.push(polygon2);
- return polygon2;
- }
- cartesianToLatlng(cartesian) {
- var latlng = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- var lat = this.Cesium.Math.toDegrees(latlng.latitude);
- var lng = this.Cesium.Math.toDegrees(latlng.longitude);
- return [lng, lat];
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this.CurveFlagLast, [this.CurveFlagData[0], this.CurveFlagData[this.CurveFlagData.length - 1]], this.drawType);
- for (var i2 = 0; i2 < this.entitiesPoint.length; i2++) {
- this.viewer.entities.remove(this.entitiesPoint[i2]);
- }
- this.entitiesPoint = [];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clear() {
- for (var i2 = 0; i2 < this.entitiesPoint.length; i2++) {
- this.viewer.entities.remove(this.entitiesPoint[i2]);
- }
- for (var i2 = 0; i2 < this.entitiesCurveFlag.length; i2++) {
- this.viewer.entities.remove(this.entitiesCurveFlag[i2]);
- }
- this.identificationPoint = null;
- this.CurveFlag = null;
- this.CurveFlagLast = null;
- this.positions = [];
- this.entitiesPoint = [];
- this.entitiesCurveFlag = [];
- this.CurveFlagData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- getBezierPoints(points2) {
- let $this = this;
- if (points2.length <= 2) {
- return points2;
- } else {
- let bezierPoints = [];
- let n = points2.length - 1;
- for (let t2 = 0; t2 <= 1; t2 += 0.01) {
- let [x, y] = [0, 0];
- for (let index2 = 0; index2 <= n; index2++) {
- let factor = $this.getBinomialFactor(n, index2);
- let a = Math.pow(t2, index2);
- let b = Math.pow(1 - t2, n - index2);
- x += factor * a * b * points2[index2][0];
- y += factor * a * b * points2[index2][1];
- }
- bezierPoints.push($this.LatlngTocartesian([x, y]));
- }
- bezierPoints.push($this.LatlngTocartesian(points2[n]));
- return bezierPoints;
- }
- }
- getBinomialFactor(n, index2) {
- return this.getFactorial(n) / (this.getFactorial(index2) * this.getFactorial(n - index2));
- }
- getFactorial(n) {
- let result = 1;
- switch (n) {
- case n <= 1:
- result = 1;
- break;
- case n === 2:
- result = 2;
- break;
- case n === 3:
- result = 6;
- break;
- case n === 24:
- result = 24;
- break;
- case n === 5:
- result = 120;
- break;
- default:
- for (let i2 = 1; i2 <= n; i2++) {
- result *= i2;
- }
- break;
- }
- return result;
- }
- }
- class DrawRectFlag {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.identificationPoint = null;
- this.RectFlag = null;
- this.RectFlagLast = null;
- this.positions = [];
- this.entitiesPoint = [];
- this.entitiesRectFlag = [];
- this.RectFlagData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- getData() {
- return this.RectFlagData;
- }
- computePosition(data) {
- let $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.cartesianToLatlng(data[i2]);
- lnglatArr.push(lnglat);
- }
- let startPoint = lnglatArr[0];
- let endPoint = lnglatArr[lnglatArr.length - 1];
- let point0 = lnglatArr[0];
- var point1 = [endPoint[0], startPoint[1]];
- var point2 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point3 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point4 = [startPoint[0], endPoint[1]];
- let componentspolygon = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point3, ...point0]);
- let componentspolyline = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point3, ...point0, ...point4]);
- let PolygonHierarchy = new $this.Cesium.PolygonHierarchy(componentspolygon);
- $this.RectFlagData = lnglatArr;
- return [PolygonHierarchy, componentspolyline];
- }
- addload(data) {
- var $this = this;
- if (data.length < 2)
- return;
- let startPoint = data[0];
- let endPoint = data[data.length - 1];
- let point0 = data[0];
- var point1 = [endPoint[0], startPoint[1]];
- var point2 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point3 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point4 = [startPoint[0], endPoint[1]];
- let componentspolygon = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point3, ...point0]);
- let componentspolyline = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point3, ...point0, ...point4]);
- var shape = this.viewer.entities.add({
- Type: "DrawRectFlag",
- Position: data,
- id: data.id || $this.objId,
- polygon: {
- hierarchy: new $this.Cesium.PolygonHierarchy(componentspolygon),
- extrudedHeight: 1,
- material: $this.Cesium.Color.RED
- },
- polyline: {
- positions: componentspolyline,
- show: true,
- material: $this.Cesium.Color.YELLOW,
- width: 5,
- clampToGround: true
- }
- });
- $this.entitiesRectFlag.push(shape);
- return shape;
- }
- startCreate(drawType) {
- this.drawType = drawType;
- var $this = this;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if ($this.positions.length == 0) {
- $this.positions.push(cartesian.clone());
- $this.identificationPoint = $this.createPoint(cartesian);
- $this.createPoint(cartesian);
- $this.positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if ($this.positions.length < 2)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if (!$this.Cesium.defined($this.RectFlag)) {
- $this.RectFlag = $this.createRectFlag();
- }
- $this.identificationPoint.position.setValue(cartesian);
- if ($this.RectFlag) {
- $this.positions.pop();
- $this.positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- if (!$this.RectFlag)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.position);
- $this.positions.pop();
- $this.positions.push(cartesian);
- $this.createPoint(cartesian);
- $this.RectFlagData = $this.positions.concat();
- $this.viewer.entities.remove($this.RectFlag);
- $this.RectFlag = null;
- $this.positions = [];
- $this.identificationPoint.position.setValue(cartesian);
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this.RectFlagData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this.RectFlagData[i2]);
- lnglatArr.push(lnglat);
- }
- $this.RectFlagData = lnglatArr;
- var RectFlag = $this.addload([$this.RectFlagData[0], $this.RectFlagData[$this.RectFlagData.length - 1]]);
- $this.entitiesRectFlag.push(RectFlag);
- $this.RectFlagLast = RectFlag;
- $this.clearPoint();
- $this.destroy();
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this.entitiesPoint.push(point2);
- return point2;
- }
- createRectFlag() {
- var $this = this;
- var polygon2 = this.viewer.entities.add({
- polygon: {
- hierarchy: new $this.Cesium.CallbackProperty(function() {
- if ($this.positions.length < 2)
- return;
- let lonlat = [];
- let length = $this.positions.length;
- for (let i2 = 0; i2 < length; i2++) {
- lonlat.push($this.cartesianToLatlng($this.positions[i2]));
- }
- let startPoint = lonlat[0];
- let endPoint = lonlat[lonlat.length - 1];
- let point0 = lonlat[0];
- var point1 = [endPoint[0], startPoint[1]];
- var point2 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point3 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- [startPoint[0], endPoint[1]];
- let components = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point3, ...point0]);
- return new $this.Cesium.PolygonHierarchy(components);
- }, false),
- extrudedHeight: 1,
- material: $this.Cesium.Color.RED
- },
- polyline: {
- positions: new $this.Cesium.CallbackProperty(function() {
- if ($this.positions.length < 2)
- return;
- let lonlat = [];
- let length = $this.positions.length;
- for (let i2 = 0; i2 < length; i2++) {
- lonlat.push($this.cartesianToLatlng($this.positions[i2]));
- }
- let startPoint = lonlat[0];
- let endPoint = lonlat[lonlat.length - 1];
- let point0 = lonlat[0];
- var point1 = [endPoint[0], startPoint[1]];
- var point2 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point3 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point4 = [startPoint[0], endPoint[1]];
- let components = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point3, ...point0, ...point4]);
- return components;
- }, false),
- show: true,
- material: $this.Cesium.Color.YELLOW,
- width: 5,
- clampToGround: true
- }
- });
- $this.entitiesRectFlag.push(polygon2);
- return polygon2;
- }
- cartesianToLatlng(cartesian) {
- var latlng = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- var lat = this.Cesium.Math.toDegrees(latlng.latitude);
- var lng = this.Cesium.Math.toDegrees(latlng.longitude);
- return [lng, lat];
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this.RectFlagLast, [this.RectFlagData[0], this.RectFlagData[this.RectFlagData.length - 1]], this.drawType);
- for (var i2 = 0; i2 < this.entitiesPoint.length; i2++) {
- this.viewer.entities.remove(this.entitiesPoint[i2]);
- }
- this.entitiesPoint = [];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clear() {
- for (var i2 = 0; i2 < this.entitiesPoint.length; i2++) {
- this.viewer.entities.remove(this.entitiesPoint[i2]);
- }
- for (var i2 = 0; i2 < this.entitiesRectFlag.length; i2++) {
- this.viewer.entities.remove(this.entitiesRectFlag[i2]);
- }
- this.identificationPoint = null;
- this.RectFlag = null;
- this.RectFlagLast = null;
- this.positions = [];
- this.entitiesPoint = [];
- this.entitiesRectFlag = [];
- this.RectFlagData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- }
- class DrawTriangleFlag {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.identificationPoint = null;
- this.TriangleFlag = null;
- this.TriangleFlagLast = null;
- this.positions = [];
- this.entitiesPoint = [];
- this.entitiesTriangleFlag = [];
- this.TriangleFlagData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- getData() {
- return this.TriangleFlagData;
- }
- computePosition(data) {
- let $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.cartesianToLatlng(data[i2]);
- lnglatArr.push(lnglat);
- }
- let startPoint = lnglatArr[0];
- let endPoint = lnglatArr[lnglatArr.length - 1];
- let point0 = lnglatArr[0];
- var point1 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point2 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point3 = [startPoint[0], endPoint[1]];
- let componentspolygon = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point0]);
- let componentspolyline = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point0, ...point3]);
- let PolygonHierarchy = new $this.Cesium.PolygonHierarchy(componentspolygon);
- $this.TriangleFlagData = lnglatArr;
- return [PolygonHierarchy, componentspolyline];
- }
- addload(data) {
- var $this = this;
- if (data.length < 2)
- return;
- let startPoint = data[0];
- let endPoint = data[data.length - 1];
- let point0 = data[0];
- var point1 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point2 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point3 = [startPoint[0], endPoint[1]];
- let componentspolygon = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point0]);
- let componentspolyline = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point0, ...point3]);
- var shape = this.viewer.entities.add({
- Type: "DrawTriangleFlag",
- Position: data,
- id: data.id || $this.objId,
- polygon: {
- hierarchy: new $this.Cesium.PolygonHierarchy(componentspolygon),
- extrudedHeight: 1,
- material: $this.Cesium.Color.RED
- },
- polyline: {
- positions: componentspolyline,
- show: true,
- material: $this.Cesium.Color.YELLOW,
- width: 5,
- clampToGround: true
- }
- });
- $this.entitiesTriangleFlag.push(shape);
- return shape;
- }
- startCreate(drawType) {
- this.drawType = drawType;
- var $this = this;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if ($this.positions.length == 0) {
- $this.positions.push(cartesian.clone());
- $this.identificationPoint = $this.createPoint(cartesian);
- $this.createPoint(cartesian);
- $this.positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if ($this.positions.length < 2)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if (!$this.Cesium.defined($this.TriangleFlag)) {
- $this.TriangleFlag = $this.createTriangleFlag();
- }
- $this.identificationPoint.position.setValue(cartesian);
- if ($this.TriangleFlag) {
- $this.positions.pop();
- $this.positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- if (!$this.TriangleFlag)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.position);
- $this.positions.pop();
- $this.positions.push(cartesian);
- $this.createPoint(cartesian);
- $this.TriangleFlagData = $this.positions.concat();
- $this.viewer.entities.remove($this.TriangleFlag);
- $this.TriangleFlag = null;
- $this.positions = [];
- $this.identificationPoint.position.setValue(cartesian);
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this.TriangleFlagData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this.TriangleFlagData[i2]);
- lnglatArr.push(lnglat);
- }
- $this.TriangleFlagData = lnglatArr;
- var TriangleFlag = $this.addload([$this.TriangleFlagData[0], $this.TriangleFlagData[$this.TriangleFlagData.length - 1]]);
- $this.entitiesTriangleFlag.push(TriangleFlag);
- $this.TriangleFlagLast = TriangleFlag;
- $this.clearPoint();
- $this.destroy();
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this.entitiesPoint.push(point2);
- return point2;
- }
- createTriangleFlag() {
- var $this = this;
- var polygon2 = this.viewer.entities.add({
- polygon: {
- hierarchy: new $this.Cesium.CallbackProperty(function() {
- if ($this.positions.length < 2)
- return;
- let lonlat = [];
- let length = $this.positions.length;
- for (let i2 = 0; i2 < length; i2++) {
- lonlat.push($this.cartesianToLatlng($this.positions[i2]));
- }
- let startPoint = lonlat[0];
- let endPoint = lonlat[lonlat.length - 1];
- let point0 = lonlat[0];
- var point1 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point2 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- [startPoint[0], endPoint[1]];
- let components = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point0]);
- return new $this.Cesium.PolygonHierarchy(components);
- }, false),
- extrudedHeight: 1,
- material: $this.Cesium.Color.RED
- },
- polyline: {
- positions: new $this.Cesium.CallbackProperty(function() {
- if ($this.positions.length < 2)
- return;
- let lonlat = [];
- let length = $this.positions.length;
- for (let i2 = 0; i2 < length; i2++) {
- lonlat.push($this.cartesianToLatlng($this.positions[i2]));
- }
- let startPoint = lonlat[0];
- let endPoint = lonlat[lonlat.length - 1];
- let point0 = lonlat[0];
- var point1 = [endPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point2 = [startPoint[0], (startPoint[1] + endPoint[1]) / 2];
- var point3 = [startPoint[0], endPoint[1]];
- let components = $this.Cesium.Cartesian3.fromDegreesArray([...point0, ...point1, ...point2, ...point0, ...point3]);
- return components;
- }, false),
- show: true,
- material: $this.Cesium.Color.YELLOW,
- width: 5,
- clampToGround: true
- }
- });
- $this.entitiesTriangleFlag.push(polygon2);
- return polygon2;
- }
- cartesianToLatlng(cartesian) {
- var latlng = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- var lat = this.Cesium.Math.toDegrees(latlng.latitude);
- var lng = this.Cesium.Math.toDegrees(latlng.longitude);
- return [lng, lat];
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this.TriangleFlagLast, [this.TriangleFlagData[0], this.TriangleFlagData[this.TriangleFlagData.length - 1]], this.drawType);
- for (var i2 = 0; i2 < this.entitiesPoint.length; i2++) {
- this.viewer.entities.remove(this.entitiesPoint[i2]);
- }
- this.entitiesPoint = [];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clear() {
- for (var i2 = 0; i2 < this.entitiesPoint.length; i2++) {
- this.viewer.entities.remove(this.entitiesPoint[i2]);
- }
- for (var i2 = 0; i2 < this.entitiesTriangleFlag.length; i2++) {
- this.viewer.entities.remove(this.entitiesTriangleFlag[i2]);
- }
- this.identificationPoint = null;
- this.TriangleFlag = null;
- this.TriangleFlagLast = null;
- this.positions = [];
- this.entitiesPoint = [];
- this.entitiesTriangleFlag = [];
- this.TriangleFlagData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- }
- class DrawPoint$1 {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this._point = null;
- this._pointData = null;
- this._entities = [];
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get point() {
- return this._point;
- }
- addload(data) {
- return this.createPoint(data);
- }
- getData() {
- return this._pointData;
- }
- computePosition(data) {
- let $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.cartesianToLatlng(data[i2]);
- lnglatArr.push(lnglat);
- }
- $this._pointData = lnglatArr;
- let point2 = lnglatArr[0];
- return $this.Cesium.Cartesian3.fromDegrees(point2[0], point2[1]);
- }
- startCreate(drawType) {
- this.drawType = drawType;
- var $this = this;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if (!cartesian)
- return;
- let latlon = $this.cartesianToLatlng(cartesian);
- var point2 = $this.createPoint(latlon);
- $this._pointData = cartesian;
- $this._point = point2;
- $this.DrawEndEvent.raiseEvent($this._point, latlon, $this.drawType);
- $this.destroy();
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- Type: "DrawPoint",
- Position: [cartesian],
- position: $this.Cesium.Cartesian3.fromDegrees(cartesian[0], cartesian[1]),
- id: cartesian.id || $this.objId,
- billboard: {
- image: "./static/poi2.png",
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM
- }
- });
- $this._entities.push(point2);
- return point2;
- }
- cartesianToLatlng(cartesian) {
- let ellipsoid = this.viewer.scene.globe.ellipsoid;
- let cartographic = ellipsoid.cartesianToCartographic(cartesian);
- let lat = Cesium.Math.toDegrees(cartographic.latitude);
- let lng = Cesium.Math.toDegrees(cartographic.longitude);
- return [lng, lat];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clear() {
- for (var i2 = 0; i2 < this._entities.length; i2++) {
- this.viewer.entities.remove(this._entities[i2]);
- }
- this._entities = [];
- this._point = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- }
- class DrawPolyline {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this._polyline = null;
- this._polylineLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_line = [];
- this._polylineData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get line() {
- return this._polylineLast;
- }
- getData() {
- return this._polylineData;
- }
- computePosition(data) {
- let $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.cartesianToLatlng(data[i2]);
- lnglatArr.push(lnglat);
- }
- $this._polylineData = lnglatArr;
- return data;
- }
- addload(data) {
- var $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.LatlngTocartesian(data[i2]);
- lnglatArr.push(lnglat);
- }
- var polyline = this.viewer.entities.add({
- Type: "DrawPolyline",
- Position: data,
- id: data.id || $this.objId,
- polyline: {
- positions: lnglatArr,
- show: true,
- material: $this.Cesium.Color.RED,
- width: 3,
- clampToGround: true
- }
- });
- return polyline;
- }
- startCreate(drawType) {
- this.drawType = drawType;
- var $this = this;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if ($this._positions.length == 0) {
- $this._positions.push(cartesian.clone());
- }
- $this._positions.push(cartesian);
- $this.createPoint(cartesian);
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if ($this._positions.length < 1)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if (!$this.Cesium.defined($this._polyline)) {
- $this._polyline = $this.createPolyline();
- }
- if ($this._polyline) {
- $this._positions.pop();
- $this._positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- if (!$this._polyline)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.position);
- $this._positions.pop();
- $this.createPoint(cartesian);
- $this._polylineData = $this._positions.concat();
- $this.viewer.entities.remove($this._polyline);
- $this._polyline = null;
- $this._positions = [];
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._polylineData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._polylineData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._polylineData = lnglatArr;
- var line = $this.addload($this._polylineData);
- $this._entities_line.push(line);
- $this._polylineLast = line;
- $this.clearPoint();
- $this.destroy();
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- createPolyline() {
- var $this = this;
- var polyline = this.viewer.entities.add({
- polyline: {
- positions: new $this.Cesium.CallbackProperty(function() {
- return $this._positions;
- }, false),
- show: true,
- material: $this.Cesium.Color.RED,
- width: 3,
- clampToGround: true
- }
- });
- $this._entities_line.push(polyline);
- return polyline;
- }
- cartesianToLatlng(cartesian) {
- var latlng = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- var lat = this.Cesium.Math.toDegrees(latlng.latitude);
- var lng = this.Cesium.Math.toDegrees(latlng.longitude);
- return [lng, lat];
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._polylineLast, this._polylineData, this.drawType);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_line.length; i2++) {
- this.viewer.entities.remove(this._entities_line[i2]);
- }
- this._polyline = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_line = [];
- this._polylineData = null;
- this._polylineLast = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- }
- class DrawPolygon {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this._polygon = null;
- this._polygonLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_polygon = [];
- this._polygonData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get polygon() {
- return this._polygonLast;
- }
- getData() {
- return this._polygonData;
- }
- computePosition(data) {
- let $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.cartesianToLatlng(data[i2]);
- lnglatArr.push(lnglat);
- }
- $this._polygonData = lnglatArr;
- return new $this.Cesium.PolygonHierarchy(data);
- }
- addload(data) {
- var $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.LatlngTocartesian(data[i2]);
- lnglatArr.push(lnglat);
- }
- return this.viewer.entities.add({
- Type: "DrawPolygon",
- Position: data,
- id: data.id || $this.objId,
- polygon: {
- hierarchy: new $this.Cesium.PolygonHierarchy(lnglatArr),
- clampToGround: true,
- show: true,
- fill: true,
- material: $this.Cesium.Color.RED.withAlpha(0.9),
- width: 3,
- outlineColor: $this.Cesium.Color.BLACK,
- outlineWidth: 1,
- outline: false
- }
- });
- }
- startCreate(drawType) {
- this.drawType = drawType;
- var $this = this;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if ($this._positions.length == 0) {
- $this._positions.push(cartesian.clone());
- }
- $this.createPoint(cartesian);
- $this._positions.push(cartesian);
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if ($this._positions.length < 1)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if ($this._positions.length == 3) {
- if (!$this.Cesium.defined($this._polygon)) {
- $this._polygon = $this.createPolygon();
- }
- }
- $this._positions.pop();
- $this._positions.push(cartesian);
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- if (!$this._polygon)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.position);
- $this._positions.pop();
- $this.createPoint(cartesian);
- $this._polygonData = $this._positions.concat();
- $this.viewer.entities.remove($this._positions);
- $this._positions = null;
- $this._positions = [];
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._polygonData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._polygonData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._polygonData = lnglatArr;
- var Polygon = $this.addload($this._polygonData);
- $this._entities_polygon.push(Polygon);
- $this._polygonLast = Polygon;
- $this.clearPoint();
- $this.destroy();
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- }
- createPolygon() {
- var $this = this;
- var polygon2 = this.viewer.entities.add({
- polygon: {
- hierarchy: new $this.Cesium.CallbackProperty(function() {
- return new $this.Cesium.PolygonHierarchy($this._positions);
- }, false),
- clampToGround: true,
- show: true,
- fill: true,
- material: $this.Cesium.Color.RED.withAlpha(0.5),
- width: 3,
- outlineColor: $this.Cesium.Color.BLACK,
- outlineWidth: 1,
- outline: false
- }
- });
- $this._entities_polygon.push(polygon2);
- return polygon2;
- }
- cartesianToLatlng(cartesian) {
- var latlng = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- var lat = this.Cesium.Math.toDegrees(latlng.latitude);
- var lng = this.Cesium.Math.toDegrees(latlng.longitude);
- return [lng, lat];
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._polygonLast, this._polygonData, this.drawType);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_polygon.length; i2++) {
- this.viewer.entities.remove(this._entities_polygon[i2]);
- }
- this._polygon = null;
- this._polygonLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_polygon = [];
- this._polygonData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- }
- class DrawRectangle {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this.floatingPoint = null;
- this._rectangle = null;
- this._rectangleLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_rectangle = [];
- this._rectangleData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get line() {
- return this._rectangleLast;
- }
- getData() {
- return this._rectangleData;
- }
- computePosition(data) {
- let $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.cartesianToLatlng(data[i2]);
- lnglatArr.push(lnglat);
- }
- $this._rectangleData = lnglatArr;
- return new $this.Cesium.Rectangle.fromCartesianArray(data);
- }
- addload(data) {
- var $this = this;
- var lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = $this.LatlngTocartesian(data[i2]);
- lnglatArr.push(lnglat);
- }
- var shape = this.viewer.entities.add({
- Type: "DrawRectangle",
- Position: data,
- id: data.id || $this.objId,
- rectangle: {
- coordinates: $this.Cesium.Rectangle.fromCartesianArray(lnglatArr),
- material: $this.Cesium.Color.RED.withAlpha(0.9)
- }
- });
- $this._entities_rectangle.push(shape);
- return shape;
- }
- startCreate(drawType) {
- this.drawType = drawType;
- var $this = this;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.handler.setInputAction(function(evt) {
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if ($this._positions.length == 0) {
- $this._positions.push(cartesian.clone());
- $this.floatingPoint = $this.createPoint(cartesian);
- $this.createPoint(cartesian);
- $this._positions.push(cartesian);
- }
- if ($this._positions.length == 2) {
- $this._positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if ($this._positions.length < 3)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.endPosition);
- if (!$this.Cesium.defined($this._rectangle)) {
- $this._rectangle = $this.createRectangle();
- }
- $this.floatingPoint.position.setValue(cartesian);
- if ($this._rectangle) {
- $this._positions.pop();
- $this._positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- if (!$this._rectangle)
- return;
- var cartesian = $this.getCatesian3FromPX(evt.position);
- $this._positions.pop();
- $this._positions.push(cartesian);
- $this.createPoint(cartesian);
- $this._rectangleData = $this._positions.concat();
- $this.viewer.entities.remove($this._rectangle);
- $this._rectangle = null;
- $this._positions = [];
- $this.floatingPoint.position.setValue(cartesian);
- var lnglatArr = [];
- for (var i2 = 0; i2 < $this._rectangleData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._rectangleData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._rectangleData = lnglatArr;
- var rectangle = $this.addload([$this._rectangleData[0], $this._rectangleData[$this._rectangleData.length - 1]]);
- $this._entities_rectangle.push(rectangle);
- $this._rectangleLast = rectangle;
- $this.clearPoint();
- $this.destroy();
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- createRectangle() {
- var $this = this;
- var shape = this.viewer.entities.add({
- name: "rectangle",
- rectangle: {
- coordinates: new $this.Cesium.CallbackProperty(function() {
- var obj = $this.Cesium.Rectangle.fromCartesianArray($this._positions);
- return obj;
- }, false),
- material: $this.Cesium.Color.RED.withAlpha(0.5)
- }
- });
- $this._entities_rectangle.push(shape);
- return shape;
- }
- cartesianToLatlng(cartesian) {
- var latlng = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- var lat = this.Cesium.Math.toDegrees(latlng.latitude);
- var lng = this.Cesium.Math.toDegrees(latlng.longitude);
- return [lng, lat];
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._rectangleLast, [this._rectangleData[0], this._rectangleData[this._rectangleData.length - 1]], this.drawType);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_rectangle.length; i2++) {
- this.viewer.entities.remove(this._entities_rectangle[i2]);
- }
- this.floatingPoint = null;
- this._rectangle = null;
- this._rectangleLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_rectangle = [];
- this._rectangleData = null;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- }
- class DrawCircle {
- constructor(arg) {
- this.viewer = arg.viewer;
- this.Cesium = arg.Cesium;
- this._cicle = null;
- this.floatingPoint = null;
- this._cicleLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_cicle = [];
- this._cicleData = null;
- this.DrawStartEvent = new Cesium.Event();
- this.DrawEndEvent = new Cesium.Event();
- this._param = {
- id: "DrawStraightArrow",
- polygonColor: "rgba(0,255,0,0.5)",
- outlineColor: "rgba(255, 255, 255, 1)",
- outlineWidth: 1
- };
- this.polygonMaterial = Cesium.Color.fromCssColorString(this._param.polygonColor);
- this.outlineMaterial = Cesium.Color.fromCssColorString(this._param.outlineColor);
- }
- get cicle() {
- return this._cicleLast;
- }
- addload(data) {
- var that = this;
- let lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = that.LatlngTocartesian(data[i2]);
- lnglatArr.push(lnglat);
- }
- var value = lnglatArr;
- var r2 = Math.sqrt(
- Math.pow(value[0].x - value[value.length - 1].x, 2) + Math.pow(value[0].y - value[value.length - 1].y, 2)
- );
- var position2 = value[0];
- var shape = that.viewer.entities.add({
- Type: "DrawCircle",
- Position: [data[0], data[data.length - 1]],
- position: position2,
- id: data.id || that.objId,
- ellipse: {
- semiMinorAxis: r2,
- semiMajorAxis: r2,
- material: that.Cesium.Color.RED.withAlpha(0.9),
- show: true,
- clampToGround: true
- }
- });
- return shape;
- }
- getData() {
- return this._cicleData;
- }
- computePosition(data) {
- var that = this;
- let lnglatArr = [];
- for (var i2 = 0; i2 < data.length; i2++) {
- var lnglat = that.cartesianToLatlng(data[i2]);
- lnglatArr.push(lnglat);
- }
- that._cicleData = lnglatArr;
- var value = data;
- var r2 = Math.sqrt(
- Math.pow(value[0].x - value[value.length - 1].x, 2) + Math.pow(value[0].y - value[value.length - 1].y, 2)
- );
- var position2 = value[0];
- return { position: position2, r: r2 };
- }
- startCreate(drawType) {
- this.drawType = drawType;
- this.handler = new this.Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.viewer.scene.globe.depthTestAgainstTerrain = true;
- var $this = this;
- this.handler.setInputAction(function(evt) {
- $this.viewer.scene.globe.depthTestAgainstTerrain = true;
- var cartesian = $this.getCatesian3FromPX(evt.position);
- if ($this._positions.length == 0) {
- $this._positions.push(cartesian.clone());
- $this.floatingPoint = $this.createPoint(cartesian);
- $this._positions.push(cartesian);
- }
- if (!$this._cicle) {
- $this.createPoint(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.handler.setInputAction(function(evt) {
- if ($this._positions.length < 1)
- return;
- var cartesian = $this.viewer.scene.pickPosition(evt.endPosition);
- if (!$this.Cesium.defined($this._cicle)) {
- $this._cicle = $this.createCicle();
- }
- $this.floatingPoint.position.setValue(cartesian);
- if ($this._cicle) {
- $this._positions.pop();
- $this._positions.push(cartesian);
- }
- }, $this.Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- this.handler.setInputAction(function(evt) {
- if (!$this._cicle)
- return;
- $this.viewer.scene.globe.depthTestAgainstTerrain = false;
- var cartesian = $this.viewer.scene.pickPosition(evt.position);
- $this._positions.pop();
- $this._positions.push(cartesian);
- $this._cicleData = $this._positions.concat();
- $this.viewer.entities.remove($this._cicle);
- $this._cicle = null;
- $this._positions = [];
- $this.floatingPoint.position.setValue(cartesian);
- let lnglatArr = [];
- for (var i2 = 0; i2 < $this._cicleData.length; i2++) {
- var lnglat = $this.cartesianToLatlng($this._cicleData[i2]);
- lnglatArr.push(lnglat);
- }
- $this._cicleData = lnglatArr;
- var cicle = $this.addload($this._cicleData);
- $this._entities_cicle.push(cicle);
- $this._cicleLast = cicle;
- $this.clearPoint();
- $this.destroy();
- }, $this.Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- }
- createCicle() {
- var that = this;
- var shape = this.viewer.entities.add({
- position: that._positions[0],
- ellipse: {
- semiMinorAxis: new that.Cesium.CallbackProperty(function() {
- var r2 = Math.sqrt(
- Math.pow(that._positions[0].x - that._positions[that._positions.length - 1].x, 2) + Math.pow(that._positions[0].y - that._positions[that._positions.length - 1].y, 2)
- );
- return r2 ? r2 : r2 + 1;
- }, false),
- semiMajorAxis: new that.Cesium.CallbackProperty(function() {
- var r2 = Math.sqrt(
- Math.pow(that._positions[0].x - that._positions[that._positions.length - 1].x, 2) + Math.pow(that._positions[0].y - that._positions[that._positions.length - 1].y, 2)
- );
- return r2 ? r2 : r2 + 1;
- }, false),
- material: that.Cesium.Color.RED.withAlpha(0.5),
- outline: true
- }
- });
- that._entities_cicle.push(shape);
- return shape;
- }
- createPoint(cartesian) {
- var $this = this;
- var point2 = this.viewer.entities.add({
- position: cartesian,
- point: {
- pixelSize: 10,
- color: $this.Cesium.Color.RED,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- $this._entities_point.push(point2);
- return point2;
- }
- getCatesian3FromPX(px) {
- var cartesian;
- var ray = this.viewer.camera.getPickRay(px);
- if (!ray)
- return null;
- cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- return cartesian;
- }
- cartesianToLatlng(cartesian) {
- let cartographic = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- let lat = this.Cesium.Math.toDegrees(cartographic.latitude);
- let lng = this.Cesium.Math.toDegrees(cartographic.longitude);
- cartographic.height;
- return [lng, lat];
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = this.Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1], 0);
- return cartesian3;
- }
- destroy() {
- if (this.handler) {
- this.handler.destroy();
- this.handler = null;
- }
- }
- clearPoint() {
- this.DrawEndEvent.raiseEvent(this._cicleLast, this._cicleData, this.drawType);
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- this._entities_point = [];
- }
- clear() {
- for (var i2 = 0; i2 < this._entities_point.length; i2++) {
- this.viewer.entities.remove(this._entities_point[i2]);
- }
- for (var i2 = 0; i2 < this._entities_cicle.length; i2++) {
- this.viewer.entities.remove(this._entities_cicle[i2]);
- }
- this._cicle = null;
- this.floatingPoint = null;
- this._cicleLast = null;
- this._positions = [];
- this._entities_point = [];
- this._entities_cicle = [];
- this._cicleData = null;
- }
- }
- let MilitaryPlot = {
- DrawStraightArrow,
- DrawAttackArrow,
- DrawPincerArrow,
- DrawGatheringPlace,
- DrawClosedCurve,
- DrawSector,
- DrawBowLine,
- DrawBowPlane,
- DrawCurve,
- DrawCurveFlag,
- DrawRectFlag,
- DrawTriangleFlag,
- DrawPoint: DrawPoint$1,
- DrawPolyline,
- DrawPolygon,
- DrawRectangle,
- DrawCircle
- };
- class EntityEdit {
- constructor(viewer2) {
- this.viewer = viewer2;
- this.DrawExample = "";
- this.midVertexEntities = [];
- this.initEventHandler();
- }
- initEventHandler() {
- this.eventHandler = new Cesium.ScreenSpaceEventHandler(this.viewer.scene.canvas);
- this.EditEndEvent = new Cesium.Event();
- this.EditEndEntity = new Cesium.Event();
- }
- activate() {
- this.deactivate();
- this.initLeftClickEventHandler();
- }
- deactivate() {
- this.DrawExample = "";
- this.eventHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_CLICK);
- this.unRegisterEvents();
- this.clearAllEditVertex();
- }
- clearAllEditVertex() {
- this.clearEditVertex();
- this.clearMidVertex();
- }
- initLeftClickEventHandler() {
- this.eventHandler.setInputAction((e) => {
- let id = this.viewer.scene.pick(e.position);
- if (!id || !id.id) {
- this.handleEditEntity();
- return;
- }
- if (!id.id || !id.id.Type)
- return;
- if (this.editEntity && this.editEntity.id == id.id.id)
- return;
- this.handleEditEntity();
- this.handlePickEditEntity(id.id);
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- }
- handleEditEntity() {
- this.unRegisterEvents();
- this.clearAllEditVertex();
- let editEntity = this.editEntity;
- if (!editEntity)
- return;
- this.closeEntityEditMode();
- this.editEntity = void 0;
- if (!this.isEdited)
- return;
- this.EditEndEvent.raiseEvent(editEntity);
- this.isEdited = false;
- this.isEditing = false;
- }
- handlePickEditEntity(pickId) {
- const EditableTypes = ["DrawAttackArrow", "DrawCircle", "DrawCurve", "DrawPincerArrow", "DrawPoint", "DrawPolygon", "DrawPolyline", "DrawRectangle", "DrawStraightArrow", "DrawGatheringPlace", "DrawSector", "DrawClosedCurve", "DrawBowLine", "DrawBowPlane", "DrawRectFlag", "DrawTriangleFlag", "DrawCurveFlag"];
- if (EditableTypes.indexOf(pickId.Type) == -1)
- return;
- this.editEntity = pickId;
- this.EditEndEntity.raiseEvent(this.editEntity);
- this.isEditing = false;
- this.isEdited = false;
- this.editPositions = this.getEditEntityPositions();
- this.EditMoveCenterPositoin = this.getCenterPosition();
- this.openEntityEditModel();
- this.clearAllEditVertex();
- this.unRegisterEvents();
- this.createEditVertex();
- this.createMidVertex();
- this.registerEvents();
- }
- openEntityEditModel() {
- if (this.DrawExample == "")
- return;
- switch (this.editEntity.Type) {
- case "DrawStraightArrow":
- this.editEntity.polygon.hierarchy = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions);
- }, false);
- break;
- case "DrawAttackArrow":
- this.editEntity.polygon.hierarchy = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions);
- }, false);
- break;
- case "DrawPincerArrow":
- this.editEntity.polygon.hierarchy = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions);
- }, false);
- break;
- case "DrawGatheringPlace":
- this.editEntity.polygon.hierarchy = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions);
- }, false);
- break;
- case "DrawClosedCurve":
- this.editEntity.polygon.hierarchy = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions).PolygonHierarchy;
- }, false);
- this.editEntity.polyline.positions = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions).pList;
- }, false);
- break;
- case "DrawCircle":
- this.editEntity.position = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions).position;
- }, false);
- this.editEntity.ellipse.semiMinorAxis = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions).r;
- }, false);
- this.editEntity.ellipse.semiMajorAxis = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions).r;
- }, false);
- break;
- case "DrawCurve":
- this.editEntity.polyline.positions = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions);
- }, false);
- break;
- case "DrawPoint":
- this.editEntity.position = new Cesium.CallbackProperty((e) => {
- return this.editPositions[0];
- }, false);
- break;
- case "DrawPolygon":
- this.editEntity.polygon.hierarchy = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions);
- }, false);
- break;
- case "DrawPolyline":
- this.editEntity.polyline.positions = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions);
- }, false);
- break;
- case "DrawRectangle":
- this.editEntity.rectangle.coordinates = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions);
- }, false);
- break;
- case "DrawSector":
- this.editEntity.polygon.hierarchy = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions);
- }, false);
- break;
- case "DrawBowLine":
- this.editEntity.polyline.positions = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions);
- }, false);
- break;
- case "DrawBowPlane":
- this.editEntity.polygon.hierarchy = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions);
- }, false);
- break;
- case "DrawRectFlag":
- this.editEntity.polygon.hierarchy = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions)[0];
- }, false);
- this.editEntity.polyline.positions = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions)[1];
- }, false);
- break;
- case "DrawTriangleFlag":
- this.editEntity.polygon.hierarchy = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions)[0];
- }, false);
- this.editEntity.polyline.positions = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions)[1];
- }, false);
- break;
- case "DrawCurveFlag":
- this.editEntity.polygon.hierarchy = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions)[0];
- }, false);
- this.editEntity.polyline.positions = new Cesium.CallbackProperty((e) => {
- return this.DrawExample.computePosition(this.editPositions)[1];
- }, false);
- break;
- }
- }
- closeEntityEditMode() {
- if (this.DrawExample == "")
- return;
- let position2 = "";
- switch (this.editEntity.Type) {
- case "DrawStraightArrow":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polygon.hierarchy = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawAttackArrow":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polygon.hierarchy = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawPincerArrow":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polygon.hierarchy = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawGatheringPlace":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polygon.hierarchy = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawClosedCurve":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polygon.hierarchy = position2.PolygonHierarchy;
- this.editEntity.polyline.positions = position2.pList;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawCircle":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.position = position2.position;
- this.editEntity.ellipse.semiMinorAxis = position2.r;
- this.editEntity.ellipse.semiMajorAxis = position2.r;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawCurve":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polyline.positions = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawPoint":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.position = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawPolygon":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polygon.hierarchy = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawPolyline":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polyline.positions = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawRectangle":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.rectangle.coordinates = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawSector":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polygon.hierarchy = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawBowLine":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polyline.positions = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawBowPlane":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polygon.hierarchy = position2;
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawRectFlag":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polygon.hierarchy = position2[0];
- this.editEntity.polyline.positions = position2[1];
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawTriangleFlag":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polygon.hierarchy = position2[0];
- this.editEntity.polyline.positions = position2[1];
- this.editEntity.Position = this.DrawExample.getData();
- break;
- case "DrawCurveFlag":
- position2 = this.DrawExample.computePosition(this.editPositions);
- this.editEntity.polygon.hierarchy = position2[0];
- this.editEntity.polyline.positions = position2[1];
- this.editEntity.Position = this.DrawExample.getData();
- break;
- }
- }
- getEditEntityPositions() {
- let position2 = this.editEntity.Position;
- let positionArr = [];
- switch (this.editEntity.Type) {
- case "DrawAttackArrow":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawCircle":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawCurve":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawPincerArrow":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawPoint":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawPolygon":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawPolyline":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawRectangle":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawStraightArrow":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawGatheringPlace":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawSector":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawClosedCurve":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawBowLine":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawBowPlane":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawRectFlag":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawTriangleFlag":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- case "DrawCurveFlag":
- for (let i2 = 0; i2 < position2.length; i2++) {
- positionArr.push(this.LatlngTocartesian(position2[i2]));
- }
- return positionArr;
- }
- }
- registerEvents() {
- this.initLeftDownEventHandler();
- this.initMouseMoveEventHandler();
- this.initLeftUpEventHandler();
- }
- unRegisterEvents() {
- this.eventHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_DOWN);
- this.eventHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_UP);
- this.eventHandler.removeInputAction(Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- }
- initLeftDownEventHandler() {
- this.eventHandler.setInputAction((e) => {
- let id = this.viewer.scene.pick(e.position);
- if (!id || !id.id || !id.id.type)
- return;
- if (id.id.type == "EditVertex" || id.id.type == "EditMove") {
- this.isEditing = true;
- this.viewer.scene.screenSpaceCameraController.enableRotate = false;
- this.viewer.enableCursorStyle = false;
- this.viewer._element.style.cursor = "";
- document.body.style.cursor = "move";
- this.editVertext = id.id;
- this.editVertext.show = false;
- this.clearMidVertex();
- } else if (id.id.type == "EditMidVertex") {
- this.editPositions.splice(id.id.vertexIndex, 0, id.id.position._value);
- this.clearAllEditVertex();
- this.createEditVertex();
- this.createMidVertex();
- this.isEdited = true;
- } else {
- return;
- }
- }, Cesium.ScreenSpaceEventType.LEFT_DOWN);
- }
- initLeftUpEventHandler() {
- this.eventHandler.setInputAction((e) => {
- if (!this.isEditing)
- return;
- this.viewer.enableCursorStyle = true;
- document.body.style.cursor = "default";
- this.viewer.scene.screenSpaceCameraController.enableRotate = true;
- this.editVertext.show = true;
- this.isEditing = false;
- this.clearMidVertex();
- this.createMidVertex();
- }, Cesium.ScreenSpaceEventType.LEFT_UP);
- }
- initMouseMoveEventHandler() {
- this.eventHandler.setInputAction((e) => {
- var position2 = e.endPosition;
- var ray = this.viewer.scene.camera.getPickRay(position2);
- var cartesian = this.viewer.scene.globe.pick(ray, this.viewer.scene);
- if (!cartesian)
- return;
- if (!this.isEditing)
- return;
- if (this.editVertext.type == "EditMove") {
- let startPosition = this.EditMoveCenterPositoin;
- if (!startPosition)
- return;
- this.moveEntityByOffset(startPosition, cartesian);
- } else if (this.editVertext.type == "EditVertex" || this.editVertext.type == "EditMidVertex") {
- this.editPositions[this.editVertext.vertexIndex] = cartesian;
- }
- this.isEdited = true;
- this.EditMoveCenterPositoin = this.getCenterPosition();
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- }
- getCenterPosition() {
- let points2 = [];
- let maxHeight = 0;
- if (this.editEntity.Type == "DrawCircle" || this.editEntity.Type == "DrawPoint" || this.editEntity.Type == "DrawSector") {
- return this.editPositions[0];
- }
- this.editPositions.forEach((position2) => {
- const point3d = this.cartesian3ToPoint3D(position2);
- points2.push([point3d.x, point3d.y]);
- if (maxHeight < point3d.z)
- maxHeight = point3d.z;
- });
- let geo = lineString(points2);
- let bbox2 = bbox$1(geo);
- let bboxPolygon$1 = bboxPolygon(bbox2);
- let pointOnFeature = center(bboxPolygon$1);
- let lonLat = pointOnFeature.geometry.coordinates;
- return Cesium.Cartesian3.fromDegrees(lonLat[0], lonLat[1], maxHeight);
- }
- moveEntityByOffset(startPosition, endPosition) {
- let startPoint3d = this.cartesian3ToPoint3D(startPosition);
- let endPoint3d = this.cartesian3ToPoint3D(endPosition);
- let offsetX = endPoint3d.x - startPoint3d.x;
- let offsetY = endPoint3d.y - startPoint3d.y;
- let element;
- for (let i2 = 0; i2 < this.editPositions.length; i2++) {
- element = this.cartesian3ToPoint3D(this.editPositions[i2]);
- element.x += offsetX;
- element.y += offsetY;
- this.editPositions[i2] = Cesium.Cartesian3.fromDegrees(element.x, element.y, element.z);
- }
- }
- createEditVertex() {
- this.vertexEntities = [];
- this.editPositions.forEach((p, index2) => {
- const entity = this.viewer.entities.add({
- position: new Cesium.CallbackProperty((e) => {
- return this.editPositions[index2];
- }, false),
- type: "EditVertex",
- vertexIndex: index2,
- point: {
- show: true,
- pixelSize: 10,
- color: new Cesium.Color(0, 0, 1, 1),
- outlineWidth: 1,
- outlineColor: new Cesium.Color(1, 1, 1, 1),
- disableDepthTestDistance: 15e11,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- this.vertexEntities.push(entity);
- });
- if (this.editEntity.Type == "DrawCircle") {
- this.vertexEntities[0].show = false;
- }
- if (this.editPositions.length == 1) {
- return;
- }
- this.createEditMoveCenterEntity();
- }
- createEditMoveCenterEntity() {
- this.EditMoveCenterEntity = this.viewer.entities.add({
- position: new Cesium.CallbackProperty((e) => {
- return this.EditMoveCenterPositoin;
- }, false),
- type: "EditMove",
- point: {
- show: true,
- pixelSize: 12,
- color: new Cesium.Color(0, 1, 0, 0.1),
- outlineWidth: 2,
- outlineColor: new Cesium.Color(1, 1, 1, 1),
- disableDepthTestDistance: 15e11,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- }
- clearEditVertex() {
- if (this.vertexEntities) {
- this.vertexEntities.forEach((item) => {
- this.viewer.entities.remove(item);
- });
- }
- this.vertexEntities = [];
- this.viewer.entities.remove(this.EditMoveCenterEntity);
- }
- createMidVertex() {
- if (this.editEntity.Type == "DrawCircle" || this.editEntity.Type == "DrawPincerArrow" || this.editEntity.Type == "DrawRectangle" || this.editEntity.Type == "DrawStraightArrow" || this.editEntity.Type == "DrawGatheringPlace" || this.editEntity.Type == "DrawSector" || this.editEntity.Type == "DrawBowLine" || this.editEntity.Type == "DrawBowPlane" || this.editEntity.Type == "DrawRectFlag" || this.editEntity.Type == "DrawTriangleFlag" || this.editEntity.Type == "DrawCurveFlag") {
- return;
- }
- this.midVertexEntities = [];
- for (let i2 = 0; i2 < this.editPositions.length; i2++) {
- const p1 = this.editPositions[i2];
- const p2 = this.editPositions[i2 + 1];
- let mideP = this.midPosition(p1, p2);
- const entity = this.viewer.entities.add({
- position: mideP,
- type: "EditMidVertex",
- vertexIndex: i2 + 1,
- point: {
- show: true,
- pixelSize: 10,
- color: new Cesium.Color(0, 1, 0, 1),
- outlineWidth: 1,
- outlineColor: new Cesium.Color(1, 1, 1, 1),
- disableDepthTestDistance: 15e11,
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND
- }
- });
- this.midVertexEntities.push(entity);
- }
- }
- clearMidVertex() {
- if (this.midVertexEntities) {
- this.midVertexEntities.forEach((item) => {
- this.viewer.entities.remove(item);
- });
- }
- this.midVertexEntities = [];
- }
- cartesian3ToPoint3D(position2) {
- const cartographic = Cesium.Cartographic.fromCartesian(position2);
- const lon = Cesium.Math.toDegrees(cartographic.longitude);
- const lat = Cesium.Math.toDegrees(cartographic.latitude);
- return {
- x: lon,
- y: lat,
- z: cartographic.height
- };
- }
- midPosition(first, second) {
- if (!first || !second)
- return null;
- let point3d1 = this.cartesian3ToPoint3D(first);
- let point3d2 = this.cartesian3ToPoint3D(second);
- let midLonLat = {
- x: (point3d1.x + point3d2.x) / 2,
- y: (point3d1.y + point3d2.y) / 2,
- z: (point3d1.z + point3d2.z) / 2
- };
- return Cesium.Cartesian3.fromDegrees(midLonLat.x, midLonLat.y, midLonLat.z);
- }
- cartesianToLatlng(cartesian) {
- let cartographic = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
- let lat = new Cesium.Math.toDegrees(cartographic.latitude);
- let lng = new Cesium.Math.toDegrees(cartographic.longitude);
- cartographic.height;
- return [lng, lat];
- }
- LatlngTocartesian(latlng) {
- let cartesian3 = new Cesium.Cartesian3.fromDegrees(latlng[0], latlng[1]);
- return cartesian3;
- }
- }
- var _style_0$1 = `@charset "UTF-8";:root{--el-color-white:#ffffff;--el-color-black:#000000;--el-color-primary-rgb:64,158,255;--el-color-success-rgb:103,194,58;--el-color-warning-rgb:230,162,60;--el-color-danger-rgb:245,108,108;--el-color-error-rgb:245,108,108;--el-color-info-rgb:144,147,153;--el-font-size-extra-large:20px;--el-font-size-large:18px;--el-font-size-medium:16px;--el-font-size-base:14px;--el-font-size-small:13px;--el-font-size-extra-small:12px;--el-font-family:"Helvetica Neue",Helvetica,"PingFang SC","Hiragino Sans GB","Microsoft YaHei","\\5fae\\8f6f\\96c5\\9ed1",Arial,sans-serif;--el-font-weight-primary:500;--el-font-line-height-primary:24px;--el-index-normal:1;--el-index-top:1000;--el-index-popper:2000;--el-border-radius-base:4px;--el-border-radius-small:2px;--el-border-radius-round:20px;--el-border-radius-circle:100%;--el-transition-duration:.3s;--el-transition-duration-fast:.2s;--el-transition-function-ease-in-out-bezier:cubic-bezier(.645, .045, .355, 1);--el-transition-function-fast-bezier:cubic-bezier(.23, 1, .32, 1);--el-transition-all:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);--el-transition-fade:opacity var(--el-transition-duration) var(--el-transition-function-fast-bezier);--el-transition-md-fade:transform var(--el-transition-duration) var(--el-transition-function-fast-bezier),opacity var(--el-transition-duration) var(--el-transition-function-fast-bezier);--el-transition-fade-linear:opacity var(--el-transition-duration-fast) linear;--el-transition-border:border-color var(--el-transition-duration-fast) var(--el-transition-function-ease-in-out-bezier);--el-transition-box-shadow:box-shadow var(--el-transition-duration-fast) var(--el-transition-function-ease-in-out-bezier);--el-transition-color:color var(--el-transition-duration-fast) var(--el-transition-function-ease-in-out-bezier);--el-component-size-large:40px;--el-component-size:32px;--el-component-size-small:24px}:root{color-scheme:light;--el-color-white:#ffffff;--el-color-black:#000000;--el-color-primary:#409eff;--el-color-primary-light-3:#79bbff;--el-color-primary-light-5:#a0cfff;--el-color-primary-light-7:#c6e2ff;--el-color-primary-light-8:#d9ecff;--el-color-primary-light-9:#ecf5ff;--el-color-primary-dark-2:#337ecc;--el-color-success:#67c23a;--el-color-success-light-3:#95d475;--el-color-success-light-5:#b3e19d;--el-color-success-light-7:#d1edc4;--el-color-success-light-8:#e1f3d8;--el-color-success-light-9:#f0f9eb;--el-color-success-dark-2:#529b2e;--el-color-warning:#e6a23c;--el-color-warning-light-3:#eebe77;--el-color-warning-light-5:#f3d19e;--el-color-warning-light-7:#f8e3c5;--el-color-warning-light-8:#faecd8;--el-color-warning-light-9:#fdf6ec;--el-color-warning-dark-2:#b88230;--el-color-danger:#f56c6c;--el-color-danger-light-3:#f89898;--el-color-danger-light-5:#fab6b6;--el-color-danger-light-7:#fcd3d3;--el-color-danger-light-8:#fde2e2;--el-color-danger-light-9:#fef0f0;--el-color-danger-dark-2:#c45656;--el-color-error:#f56c6c;--el-color-error-light-3:#f89898;--el-color-error-light-5:#fab6b6;--el-color-error-light-7:#fcd3d3;--el-color-error-light-8:#fde2e2;--el-color-error-light-9:#fef0f0;--el-color-error-dark-2:#c45656;--el-color-info:#909399;--el-color-info-light-3:#b1b3b8;--el-color-info-light-5:#c8c9cc;--el-color-info-light-7:#dedfe0;--el-color-info-light-8:#e9e9eb;--el-color-info-light-9:#f4f4f5;--el-color-info-dark-2:#73767a;--el-bg-color:#ffffff;--el-bg-color-page:#f2f3f5;--el-bg-color-overlay:#ffffff;--el-text-color-primary:#303133;--el-text-color-regular:#606266;--el-text-color-secondary:#909399;--el-text-color-placeholder:#a8abb2;--el-text-color-disabled:#c0c4cc;--el-border-color:#dcdfe6;--el-border-color-light:#e4e7ed;--el-border-color-lighter:#ebeef5;--el-border-color-extra-light:#f2f6fc;--el-border-color-dark:#d4d7de;--el-border-color-darker:#cdd0d6;--el-fill-color:#f0f2f5;--el-fill-color-light:#f5f7fa;--el-fill-color-lighter:#fafafa;--el-fill-color-extra-light:#fafcff;--el-fill-color-dark:#ebedf0;--el-fill-color-darker:#e6e8eb;--el-fill-color-blank:#ffffff;--el-box-shadow:0px 12px 32px 4px rgba(0, 0, 0, .04),0px 8px 20px rgba(0, 0, 0, .08);--el-box-shadow-light:0px 0px 12px rgba(0, 0, 0, .12);--el-box-shadow-lighter:0px 0px 6px rgba(0, 0, 0, .12);--el-box-shadow-dark:0px 16px 48px 16px rgba(0, 0, 0, .08),0px 12px 32px rgba(0, 0, 0, .12),0px 8px 16px -8px rgba(0, 0, 0, .16);--el-disabled-bg-color:var(--el-fill-color-light);--el-disabled-text-color:var(--el-text-color-placeholder);--el-disabled-border-color:var(--el-border-color-light);--el-overlay-color:rgba(0, 0, 0, .8);--el-overlay-color-light:rgba(0, 0, 0, .7);--el-overlay-color-lighter:rgba(0, 0, 0, .5);--el-mask-color:rgba(255, 255, 255, .9);--el-mask-color-extra-light:rgba(255, 255, 255, .3);--el-border-width:1px;--el-border-style:solid;--el-border-color-hover:var(--el-text-color-disabled);--el-border:var(--el-border-width) var(--el-border-style) var(--el-border-color);--el-svg-monochrome-grey:var(--el-border-color)}.fade-in-linear-enter-active,.fade-in-linear-leave-active{transition:var(--el-transition-fade-linear)}.fade-in-linear-enter-from,.fade-in-linear-leave-to{opacity:0}.el-fade-in-linear-enter-active,.el-fade-in-linear-leave-active{transition:var(--el-transition-fade-linear)}.el-fade-in-linear-enter-from,.el-fade-in-linear-leave-to{opacity:0}.el-fade-in-enter-active,.el-fade-in-leave-active{transition:all var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}.el-fade-in-enter-from,.el-fade-in-leave-active{opacity:0}.el-zoom-in-center-enter-active,.el-zoom-in-center-leave-active{transition:all var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}.el-zoom-in-center-enter-from,.el-zoom-in-center-leave-active{opacity:0;transform:scaleX(0)}.el-zoom-in-top-enter-active,.el-zoom-in-top-leave-active{opacity:1;transform:scaleY(1);transition:var(--el-transition-md-fade);transform-origin:center top}.el-zoom-in-top-enter-active[data-popper-placement^=top],.el-zoom-in-top-leave-active[data-popper-placement^=top]{transform-origin:center bottom}.el-zoom-in-top-enter-from,.el-zoom-in-top-leave-active{opacity:0;transform:scaleY(0)}.el-zoom-in-bottom-enter-active,.el-zoom-in-bottom-leave-active{opacity:1;transform:scaleY(1);transition:var(--el-transition-md-fade);transform-origin:center bottom}.el-zoom-in-bottom-enter-from,.el-zoom-in-bottom-leave-active{opacity:0;transform:scaleY(0)}.el-zoom-in-left-enter-active,.el-zoom-in-left-leave-active{opacity:1;transform:scale(1);transition:var(--el-transition-md-fade);transform-origin:top left}.el-zoom-in-left-enter-from,.el-zoom-in-left-leave-active{opacity:0;transform:scale(.45)}.collapse-transition{transition:var(--el-transition-duration) height ease-in-out,var(--el-transition-duration) padding-top ease-in-out,var(--el-transition-duration) padding-bottom ease-in-out}.el-collapse-transition-enter-active,.el-collapse-transition-leave-active{transition:var(--el-transition-duration) max-height ease-in-out,var(--el-transition-duration) padding-top ease-in-out,var(--el-transition-duration) padding-bottom ease-in-out}.horizontal-collapse-transition{transition:var(--el-transition-duration) width ease-in-out,var(--el-transition-duration) padding-left ease-in-out,var(--el-transition-duration) padding-right ease-in-out}.el-list-enter-active,.el-list-leave-active{transition:all 1s}.el-list-enter-from,.el-list-leave-to{opacity:0;transform:translateY(-30px)}.el-list-leave-active{position:absolute!important}.el-opacity-transition{transition:opacity var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}.el-icon-loading{-webkit-animation:rotating 2s linear infinite;animation:rotating 2s linear infinite}.el-icon--right{margin-left:5px}.el-icon--left{margin-right:5px}@-webkit-keyframes rotating{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes rotating{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.el-icon{--color:inherit;height:1em;width:1em;line-height:1em;display:inline-flex;justify-content:center;align-items:center;position:relative;fill:currentColor;color:var(--color);font-size:inherit}.el-icon.is-loading{-webkit-animation:rotating 2s linear infinite;animation:rotating 2s linear infinite}.el-icon svg{height:1em;width:1em}.el-affix--fixed{position:fixed}.el-alert{--el-alert-padding:8px 16px;--el-alert-border-radius-base:var(--el-border-radius-base);--el-alert-title-font-size:13px;--el-alert-description-font-size:12px;--el-alert-close-font-size:12px;--el-alert-close-customed-font-size:13px;--el-alert-icon-size:16px;--el-alert-icon-large-size:28px;width:100%;padding:var(--el-alert-padding);margin:0;box-sizing:border-box;border-radius:var(--el-alert-border-radius-base);position:relative;background-color:var(--el-color-white);overflow:hidden;opacity:1;display:flex;align-items:center;transition:opacity var(--el-transition-duration-fast)}.el-alert.is-light .el-alert__close-btn{color:var(--el-text-color-placeholder)}.el-alert.is-dark .el-alert__close-btn,.el-alert.is-dark .el-alert__description{color:var(--el-color-white)}.el-alert.is-center{justify-content:center}.el-alert--success{--el-alert-bg-color:var(--el-color-success-light-9)}.el-alert--success.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-success)}.el-alert--success.is-light .el-alert__description{color:var(--el-color-success)}.el-alert--success.is-dark{background-color:var(--el-color-success);color:var(--el-color-white)}.el-alert--info{--el-alert-bg-color:var(--el-color-info-light-9)}.el-alert--info.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-info)}.el-alert--info.is-light .el-alert__description{color:var(--el-color-info)}.el-alert--info.is-dark{background-color:var(--el-color-info);color:var(--el-color-white)}.el-alert--warning{--el-alert-bg-color:var(--el-color-warning-light-9)}.el-alert--warning.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-warning)}.el-alert--warning.is-light .el-alert__description{color:var(--el-color-warning)}.el-alert--warning.is-dark{background-color:var(--el-color-warning);color:var(--el-color-white)}.el-alert--error{--el-alert-bg-color:var(--el-color-error-light-9)}.el-alert--error.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-error)}.el-alert--error.is-light .el-alert__description{color:var(--el-color-error)}.el-alert--error.is-dark{background-color:var(--el-color-error);color:var(--el-color-white)}.el-alert__content{display:table-cell;padding:0 8px}.el-alert .el-alert__icon{font-size:var(--el-alert-icon-size);width:var(--el-alert-icon-size)}.el-alert .el-alert__icon.is-big{font-size:var(--el-alert-icon-large-size);width:var(--el-alert-icon-large-size)}.el-alert__title{font-size:var(--el-alert-title-font-size);line-height:18px;vertical-align:text-top}.el-alert__title.is-bold{font-weight:700}.el-alert .el-alert__description{font-size:var(--el-alert-description-font-size);margin:5px 0 0}.el-alert .el-alert__close-btn{font-size:var(--el-alert-close-font-size);opacity:1;position:absolute;top:12px;right:15px;cursor:pointer}.el-alert .el-alert__close-btn.is-customed{font-style:normal;font-size:var(--el-alert-close-customed-font-size);top:9px}.el-alert-fade-enter-from,.el-alert-fade-leave-active{opacity:0}.el-aside{overflow:auto;box-sizing:border-box;flex-shrink:0;width:var(--el-aside-width,300px)}.el-autocomplete{position:relative;display:inline-block}.el-autocomplete__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-box-shadow-light)}.el-autocomplete__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-autocomplete__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-autocomplete__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-autocomplete__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-autocomplete__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-autocomplete-suggestion{border-radius:var(--el-border-radius-base);box-sizing:border-box}.el-autocomplete-suggestion__wrap{max-height:280px;padding:10px 0;box-sizing:border-box}.el-autocomplete-suggestion__list{margin:0;padding:0}.el-autocomplete-suggestion li{padding:0 20px;margin:0;line-height:34px;cursor:pointer;color:var(--el-text-color-regular);font-size:var(--el-font-size-base);list-style:none;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.el-autocomplete-suggestion li:hover,.el-autocomplete-suggestion li.highlighted{background-color:var(--el-fill-color-light)}.el-autocomplete-suggestion li.divider{margin-top:6px;border-top:1px solid var(--el-color-black)}.el-autocomplete-suggestion li.divider:last-child{margin-bottom:-6px}.el-autocomplete-suggestion.is-loading li{text-align:center;height:100px;line-height:100px;font-size:20px;color:var(--el-text-color-secondary)}.el-autocomplete-suggestion.is-loading li:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-autocomplete-suggestion.is-loading li:hover{background-color:var(--el-bg-color-overlay)}.el-autocomplete-suggestion.is-loading .el-icon-loading{vertical-align:middle}.el-avatar{--el-avatar-text-color:var(--el-color-white);--el-avatar-bg-color:var(--el-text-color-disabled);--el-avatar-text-size:14px;--el-avatar-icon-size:18px;--el-avatar-border-radius:var(--el-border-radius-base);--el-avatar-size-large:56px;--el-avatar-size-small:24px;--el-avatar-size:40px;display:inline-flex;justify-content:center;align-items:center;box-sizing:border-box;text-align:center;overflow:hidden;color:var(--el-avatar-text-color);background:var(--el-avatar-bg-color);width:var(--el-avatar-size);height:var(--el-avatar-size);font-size:var(--el-avatar-text-size)}.el-avatar>img{display:block;height:100%}.el-avatar--circle{border-radius:50%}.el-avatar--square{border-radius:var(--el-avatar-border-radius)}.el-avatar--icon{font-size:var(--el-avatar-icon-size)}.el-avatar--small{--el-avatar-size:24px}.el-avatar--large{--el-avatar-size:56px}.el-backtop{--el-backtop-bg-color:var(--el-bg-color-overlay);--el-backtop-text-color:var(--el-color-primary);--el-backtop-hover-bg-color:var(--el-border-color-extra-light);position:fixed;background-color:var(--el-backtop-bg-color);width:40px;height:40px;border-radius:50%;color:var(--el-backtop-text-color);display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:var(--el-box-shadow-lighter);cursor:pointer;z-index:5}.el-backtop:hover{background-color:var(--el-backtop-hover-bg-color)}.el-backtop__icon{font-size:20px}.el-badge{--el-badge-bg-color:var(--el-color-danger);--el-badge-radius:10px;--el-badge-font-size:12px;--el-badge-padding:6px;--el-badge-size:18px;position:relative;vertical-align:middle;display:inline-block;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.el-badge__content{background-color:var(--el-badge-bg-color);border-radius:var(--el-badge-radius);color:var(--el-color-white);display:inline-flex;justify-content:center;align-items:center;font-size:var(--el-badge-font-size);height:var(--el-badge-size);padding:0 var(--el-badge-padding);white-space:nowrap;border:1px solid var(--el-bg-color)}.el-badge__content.is-fixed{position:absolute;top:0;right:calc(1px + var(--el-badge-size)/ 2);transform:translateY(-50%) translate(100%);z-index:var(--el-index-normal)}.el-badge__content.is-fixed.is-dot{right:5px}.el-badge__content.is-dot{height:8px;width:8px;padding:0;right:0;border-radius:50%}.el-badge__content--primary{background-color:var(--el-color-primary)}.el-badge__content--success{background-color:var(--el-color-success)}.el-badge__content--warning{background-color:var(--el-color-warning)}.el-badge__content--info{background-color:var(--el-color-info)}.el-badge__content--danger{background-color:var(--el-color-danger)}.el-breadcrumb{font-size:14px;line-height:1}.el-breadcrumb:after,.el-breadcrumb:before{display:table;content:""}.el-breadcrumb:after{clear:both}.el-breadcrumb__separator{margin:0 9px;font-weight:700;color:var(--el-text-color-placeholder)}.el-breadcrumb__separator.el-icon{margin:0 6px;font-weight:400}.el-breadcrumb__separator.el-icon svg{vertical-align:middle}.el-breadcrumb__item{float:left;display:inline-flex;align-items:center}.el-breadcrumb__inner{color:var(--el-text-color-regular)}.el-breadcrumb__inner a,.el-breadcrumb__inner.is-link{font-weight:700;text-decoration:none;transition:var(--el-transition-color);color:var(--el-text-color-primary)}.el-breadcrumb__inner a:hover,.el-breadcrumb__inner.is-link:hover{color:var(--el-color-primary);cursor:pointer}.el-breadcrumb__item:last-child .el-breadcrumb__inner,.el-breadcrumb__item:last-child .el-breadcrumb__inner a,.el-breadcrumb__item:last-child .el-breadcrumb__inner a:hover,.el-breadcrumb__item:last-child .el-breadcrumb__inner:hover{font-weight:400;color:var(--el-text-color-regular);cursor:text}.el-breadcrumb__item:last-child .el-breadcrumb__separator{display:none}.el-button-group{display:inline-block;vertical-align:middle}.el-button-group:after,.el-button-group:before{display:table;content:""}.el-button-group:after{clear:both}.el-button-group>.el-button{float:left;position:relative}.el-button-group>.el-button+.el-button{margin-left:0}.el-button-group>.el-button:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.el-button-group>.el-button:last-child{border-top-left-radius:0;border-bottom-left-radius:0}.el-button-group>.el-button:first-child:last-child{border-top-right-radius:var(--el-border-radius-base);border-bottom-right-radius:var(--el-border-radius-base);border-top-left-radius:var(--el-border-radius-base);border-bottom-left-radius:var(--el-border-radius-base)}.el-button-group>.el-button:first-child:last-child.is-round{border-radius:var(--el-border-radius-round)}.el-button-group>.el-button:first-child:last-child.is-circle{border-radius:50%}.el-button-group>.el-button:not(:first-child):not(:last-child){border-radius:0}.el-button-group>.el-button:not(:last-child){margin-right:-1px}.el-button-group>.el-button:active,.el-button-group>.el-button:focus,.el-button-group>.el-button:hover{z-index:1}.el-button-group>.el-button.is-active{z-index:1}.el-button-group>.el-dropdown>.el-button{border-top-left-radius:0;border-bottom-left-radius:0;border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--primary:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--primary:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--primary:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--success:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--success:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--success:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--warning:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--warning:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--warning:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--danger:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--danger:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--danger:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--info:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--info:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--info:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button{--el-button-font-weight:var(--el-font-weight-primary);--el-button-border-color:var(--el-border-color);--el-button-bg-color:var(--el-fill-color-blank);--el-button-text-color:var(--el-text-color-regular);--el-button-disabled-text-color:var(--el-disabled-text-color);--el-button-disabled-bg-color:var(--el-fill-color-blank);--el-button-disabled-border-color:var(--el-border-color-light);--el-button-divide-border-color:rgba(255, 255, 255, .5);--el-button-hover-text-color:var(--el-color-primary);--el-button-hover-bg-color:var(--el-color-primary-light-9);--el-button-hover-border-color:var(--el-color-primary-light-7);--el-button-active-text-color:var(--el-button-hover-text-color);--el-button-active-border-color:var(--el-color-primary);--el-button-active-bg-color:var(--el-button-hover-bg-color);--el-button-outline-color:var(--el-color-primary-light-5);--el-button-hover-link-text-color:var(--el-color-info);--el-button-active-color:var(--el-text-color-primary)}.el-button{display:inline-flex;justify-content:center;align-items:center;line-height:1;height:32px;white-space:nowrap;cursor:pointer;color:var(--el-button-text-color);text-align:center;box-sizing:border-box;outline:0;transition:.1s;font-weight:var(--el-button-font-weight);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;vertical-align:middle;-webkit-appearance:none;background-color:var(--el-button-bg-color);border:var(--el-border);border-color:var(--el-button-border-color);padding:8px 15px;font-size:var(--el-font-size-base);border-radius:var(--el-border-radius-base)}.el-button:focus,.el-button:hover{color:var(--el-button-hover-text-color);border-color:var(--el-button-hover-border-color);background-color:var(--el-button-hover-bg-color);outline:0}.el-button:active{color:var(--el-button-active-text-color);border-color:var(--el-button-active-border-color);background-color:var(--el-button-active-bg-color);outline:0}.el-button:focus-visible{outline:2px solid var(--el-button-outline-color);outline-offset:1px}.el-button>span{display:inline-flex;align-items:center}.el-button+.el-button{margin-left:12px}.el-button.is-round{padding:8px 15px}.el-button::-moz-focus-inner{border:0}.el-button [class*=el-icon]+span{margin-left:6px}.el-button [class*=el-icon] svg{vertical-align:bottom}.el-button.is-plain{--el-button-hover-text-color:var(--el-color-primary);--el-button-hover-bg-color:var(--el-fill-color-blank);--el-button-hover-border-color:var(--el-color-primary)}.el-button.is-active{color:var(--el-button-active-text-color);border-color:var(--el-button-active-border-color);background-color:var(--el-button-active-bg-color);outline:0}.el-button.is-disabled,.el-button.is-disabled:focus,.el-button.is-disabled:hover{color:var(--el-button-disabled-text-color);cursor:not-allowed;background-image:none;background-color:var(--el-button-disabled-bg-color);border-color:var(--el-button-disabled-border-color)}.el-button.is-loading{position:relative;pointer-events:none}.el-button.is-loading:before{z-index:1;pointer-events:none;content:"";position:absolute;left:-1px;top:-1px;right:-1px;bottom:-1px;border-radius:inherit;background-color:var(--el-mask-color-extra-light)}.el-button.is-round{border-radius:var(--el-border-radius-round)}.el-button.is-circle{border-radius:50%;padding:8px}.el-button.is-text{color:var(--el-button-text-color);border:0 solid transparent;background-color:transparent}.el-button.is-text.is-disabled{color:var(--el-button-disabled-text-color);background-color:transparent!important}.el-button.is-text:not(.is-disabled):focus,.el-button.is-text:not(.is-disabled):hover{background-color:var(--el-fill-color-light)}.el-button.is-text:not(.is-disabled):focus-visible{outline:2px solid var(--el-button-outline-color);outline-offset:1px}.el-button.is-text:not(.is-disabled):active{background-color:var(--el-fill-color)}.el-button.is-text:not(.is-disabled).is-has-bg{background-color:var(--el-fill-color-light)}.el-button.is-text:not(.is-disabled).is-has-bg:focus,.el-button.is-text:not(.is-disabled).is-has-bg:hover{background-color:var(--el-fill-color)}.el-button.is-text:not(.is-disabled).is-has-bg:active{background-color:var(--el-fill-color-dark)}.el-button__text--expand{letter-spacing:.3em;margin-right:-.3em}.el-button.is-link{border-color:transparent;color:var(--el-button-text-color);background:0 0;padding:2px;height:auto}.el-button.is-link:focus,.el-button.is-link:hover{color:var(--el-button-hover-link-text-color)}.el-button.is-link.is-disabled{color:var(--el-button-disabled-text-color);background-color:transparent!important;border-color:transparent!important}.el-button.is-link:not(.is-disabled):focus,.el-button.is-link:not(.is-disabled):hover{border-color:transparent;background-color:transparent}.el-button.is-link:not(.is-disabled):active{color:var(--el-button-active-color);border-color:transparent;background-color:transparent}.el-button--text{border-color:transparent;background:0 0;color:var(--el-color-primary);padding-left:0;padding-right:0}.el-button--text.is-disabled{color:var(--el-button-disabled-text-color);background-color:transparent!important;border-color:transparent!important}.el-button--text:not(.is-disabled):focus,.el-button--text:not(.is-disabled):hover{color:var(--el-color-primary-light-3);border-color:transparent;background-color:transparent}.el-button--text:not(.is-disabled):active{color:var(--el-color-primary-dark-2);border-color:transparent;background-color:transparent}.el-button__link--expand{letter-spacing:.3em;margin-right:-.3em}.el-button--primary{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-primary);--el-button-border-color:var(--el-color-primary);--el-button-outline-color:var(--el-color-primary-light-5);--el-button-active-color:var(--el-color-primary-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-primary-light-5);--el-button-hover-bg-color:var(--el-color-primary-light-3);--el-button-hover-border-color:var(--el-color-primary-light-3);--el-button-active-bg-color:var(--el-color-primary-dark-2);--el-button-active-border-color:var(--el-color-primary-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-primary-light-5);--el-button-disabled-border-color:var(--el-color-primary-light-5)}.el-button--primary.is-link,.el-button--primary.is-plain,.el-button--primary.is-text{--el-button-text-color:var(--el-color-primary);--el-button-bg-color:var(--el-color-primary-light-9);--el-button-border-color:var(--el-color-primary-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-primary);--el-button-hover-border-color:var(--el-color-primary);--el-button-active-text-color:var(--el-color-white)}.el-button--primary.is-link.is-disabled,.el-button--primary.is-link.is-disabled:active,.el-button--primary.is-link.is-disabled:focus,.el-button--primary.is-link.is-disabled:hover,.el-button--primary.is-plain.is-disabled,.el-button--primary.is-plain.is-disabled:active,.el-button--primary.is-plain.is-disabled:focus,.el-button--primary.is-plain.is-disabled:hover,.el-button--primary.is-text.is-disabled,.el-button--primary.is-text.is-disabled:active,.el-button--primary.is-text.is-disabled:focus,.el-button--primary.is-text.is-disabled:hover{color:var(--el-color-primary-light-5);background-color:var(--el-color-primary-light-9);border-color:var(--el-color-primary-light-8)}.el-button--success{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-success);--el-button-border-color:var(--el-color-success);--el-button-outline-color:var(--el-color-success-light-5);--el-button-active-color:var(--el-color-success-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-success-light-5);--el-button-hover-bg-color:var(--el-color-success-light-3);--el-button-hover-border-color:var(--el-color-success-light-3);--el-button-active-bg-color:var(--el-color-success-dark-2);--el-button-active-border-color:var(--el-color-success-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-success-light-5);--el-button-disabled-border-color:var(--el-color-success-light-5)}.el-button--success.is-link,.el-button--success.is-plain,.el-button--success.is-text{--el-button-text-color:var(--el-color-success);--el-button-bg-color:var(--el-color-success-light-9);--el-button-border-color:var(--el-color-success-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-success);--el-button-hover-border-color:var(--el-color-success);--el-button-active-text-color:var(--el-color-white)}.el-button--success.is-link.is-disabled,.el-button--success.is-link.is-disabled:active,.el-button--success.is-link.is-disabled:focus,.el-button--success.is-link.is-disabled:hover,.el-button--success.is-plain.is-disabled,.el-button--success.is-plain.is-disabled:active,.el-button--success.is-plain.is-disabled:focus,.el-button--success.is-plain.is-disabled:hover,.el-button--success.is-text.is-disabled,.el-button--success.is-text.is-disabled:active,.el-button--success.is-text.is-disabled:focus,.el-button--success.is-text.is-disabled:hover{color:var(--el-color-success-light-5);background-color:var(--el-color-success-light-9);border-color:var(--el-color-success-light-8)}.el-button--warning{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-warning);--el-button-border-color:var(--el-color-warning);--el-button-outline-color:var(--el-color-warning-light-5);--el-button-active-color:var(--el-color-warning-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-warning-light-5);--el-button-hover-bg-color:var(--el-color-warning-light-3);--el-button-hover-border-color:var(--el-color-warning-light-3);--el-button-active-bg-color:var(--el-color-warning-dark-2);--el-button-active-border-color:var(--el-color-warning-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-warning-light-5);--el-button-disabled-border-color:var(--el-color-warning-light-5)}.el-button--warning.is-link,.el-button--warning.is-plain,.el-button--warning.is-text{--el-button-text-color:var(--el-color-warning);--el-button-bg-color:var(--el-color-warning-light-9);--el-button-border-color:var(--el-color-warning-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-warning);--el-button-hover-border-color:var(--el-color-warning);--el-button-active-text-color:var(--el-color-white)}.el-button--warning.is-link.is-disabled,.el-button--warning.is-link.is-disabled:active,.el-button--warning.is-link.is-disabled:focus,.el-button--warning.is-link.is-disabled:hover,.el-button--warning.is-plain.is-disabled,.el-button--warning.is-plain.is-disabled:active,.el-button--warning.is-plain.is-disabled:focus,.el-button--warning.is-plain.is-disabled:hover,.el-button--warning.is-text.is-disabled,.el-button--warning.is-text.is-disabled:active,.el-button--warning.is-text.is-disabled:focus,.el-button--warning.is-text.is-disabled:hover{color:var(--el-color-warning-light-5);background-color:var(--el-color-warning-light-9);border-color:var(--el-color-warning-light-8)}.el-button--danger{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-danger);--el-button-border-color:var(--el-color-danger);--el-button-outline-color:var(--el-color-danger-light-5);--el-button-active-color:var(--el-color-danger-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-danger-light-5);--el-button-hover-bg-color:var(--el-color-danger-light-3);--el-button-hover-border-color:var(--el-color-danger-light-3);--el-button-active-bg-color:var(--el-color-danger-dark-2);--el-button-active-border-color:var(--el-color-danger-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-danger-light-5);--el-button-disabled-border-color:var(--el-color-danger-light-5)}.el-button--danger.is-link,.el-button--danger.is-plain,.el-button--danger.is-text{--el-button-text-color:var(--el-color-danger);--el-button-bg-color:var(--el-color-danger-light-9);--el-button-border-color:var(--el-color-danger-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-danger);--el-button-hover-border-color:var(--el-color-danger);--el-button-active-text-color:var(--el-color-white)}.el-button--danger.is-link.is-disabled,.el-button--danger.is-link.is-disabled:active,.el-button--danger.is-link.is-disabled:focus,.el-button--danger.is-link.is-disabled:hover,.el-button--danger.is-plain.is-disabled,.el-button--danger.is-plain.is-disabled:active,.el-button--danger.is-plain.is-disabled:focus,.el-button--danger.is-plain.is-disabled:hover,.el-button--danger.is-text.is-disabled,.el-button--danger.is-text.is-disabled:active,.el-button--danger.is-text.is-disabled:focus,.el-button--danger.is-text.is-disabled:hover{color:var(--el-color-danger-light-5);background-color:var(--el-color-danger-light-9);border-color:var(--el-color-danger-light-8)}.el-button--info{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-info);--el-button-border-color:var(--el-color-info);--el-button-outline-color:var(--el-color-info-light-5);--el-button-active-color:var(--el-color-info-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-info-light-5);--el-button-hover-bg-color:var(--el-color-info-light-3);--el-button-hover-border-color:var(--el-color-info-light-3);--el-button-active-bg-color:var(--el-color-info-dark-2);--el-button-active-border-color:var(--el-color-info-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-info-light-5);--el-button-disabled-border-color:var(--el-color-info-light-5)}.el-button--info.is-link,.el-button--info.is-plain,.el-button--info.is-text{--el-button-text-color:var(--el-color-info);--el-button-bg-color:var(--el-color-info-light-9);--el-button-border-color:var(--el-color-info-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-info);--el-button-hover-border-color:var(--el-color-info);--el-button-active-text-color:var(--el-color-white)}.el-button--info.is-link.is-disabled,.el-button--info.is-link.is-disabled:active,.el-button--info.is-link.is-disabled:focus,.el-button--info.is-link.is-disabled:hover,.el-button--info.is-plain.is-disabled,.el-button--info.is-plain.is-disabled:active,.el-button--info.is-plain.is-disabled:focus,.el-button--info.is-plain.is-disabled:hover,.el-button--info.is-text.is-disabled,.el-button--info.is-text.is-disabled:active,.el-button--info.is-text.is-disabled:focus,.el-button--info.is-text.is-disabled:hover{color:var(--el-color-info-light-5);background-color:var(--el-color-info-light-9);border-color:var(--el-color-info-light-8)}.el-button--large{--el-button-size:40px;height:var(--el-button-size);padding:12px 19px;font-size:var(--el-font-size-base);border-radius:var(--el-border-radius-base)}.el-button--large [class*=el-icon]+span{margin-left:8px}.el-button--large.is-round{padding:12px 19px}.el-button--large.is-circle{width:var(--el-button-size);padding:12px}.el-button--small{--el-button-size:24px;height:var(--el-button-size);padding:5px 11px;font-size:12px;border-radius:calc(var(--el-border-radius-base) - 1px)}.el-button--small [class*=el-icon]+span{margin-left:4px}.el-button--small.is-round{padding:5px 11px}.el-button--small.is-circle{width:var(--el-button-size);padding:5px}.el-calendar{--el-calendar-border:var(--el-table-border, 1px solid var(--el-border-color-lighter));--el-calendar-header-border-bottom:var(--el-calendar-border);--el-calendar-selected-bg-color:var(--el-color-primary-light-9);--el-calendar-cell-width:85px;background-color:var(--el-fill-color-blank)}.el-calendar__header{display:flex;justify-content:space-between;padding:12px 20px;border-bottom:var(--el-calendar-header-border-bottom)}.el-calendar__title{color:var(--el-text-color);align-self:center}.el-calendar__body{padding:12px 20px 35px}.el-calendar-table{table-layout:fixed;width:100%}.el-calendar-table thead th{padding:12px 0;color:var(--el-text-color-regular);font-weight:400}.el-calendar-table:not(.is-range) td.next,.el-calendar-table:not(.is-range) td.prev{color:var(--el-text-color-placeholder)}.el-calendar-table td{border-bottom:var(--el-calendar-border);border-right:var(--el-calendar-border);vertical-align:top;transition:background-color var(--el-transition-duration-fast) ease}.el-calendar-table td.is-selected{background-color:var(--el-calendar-selected-bg-color)}.el-calendar-table td.is-today{color:var(--el-color-primary)}.el-calendar-table tr:first-child td{border-top:var(--el-calendar-border)}.el-calendar-table tr td:first-child{border-left:var(--el-calendar-border)}.el-calendar-table tr.el-calendar-table__row--hide-border td{border-top:none}.el-calendar-table .el-calendar-day{box-sizing:border-box;padding:8px;height:var(--el-calendar-cell-width)}.el-calendar-table .el-calendar-day:hover{cursor:pointer;background-color:var(--el-calendar-selected-bg-color)}.el-card{--el-card-border-color:var(--el-border-color-light);--el-card-border-radius:4px;--el-card-padding:20px;--el-card-bg-color:var(--el-fill-color-blank)}.el-card{border-radius:var(--el-card-border-radius);border:1px solid var(--el-card-border-color);background-color:var(--el-card-bg-color);overflow:hidden;color:var(--el-text-color-primary);transition:var(--el-transition-duration)}.el-card.is-always-shadow{box-shadow:var(--el-box-shadow-light)}.el-card.is-hover-shadow:focus,.el-card.is-hover-shadow:hover{box-shadow:var(--el-box-shadow-light)}.el-card__header{padding:calc(var(--el-card-padding) - 2px) var(--el-card-padding);border-bottom:1px solid var(--el-card-border-color);box-sizing:border-box}.el-card__body{padding:var(--el-card-padding)}.el-carousel__item{position:absolute;top:0;left:0;width:100%;height:100%;display:inline-block;overflow:hidden;z-index:calc(var(--el-index-normal) - 1)}.el-carousel__item.is-active{z-index:calc(var(--el-index-normal) - 1)}.el-carousel__item.is-animating{transition:transform .4s ease-in-out}.el-carousel__item--card{width:50%;transition:transform .4s ease-in-out}.el-carousel__item--card.is-in-stage{cursor:pointer;z-index:var(--el-index-normal)}.el-carousel__item--card.is-in-stage.is-hover .el-carousel__mask,.el-carousel__item--card.is-in-stage:hover .el-carousel__mask{opacity:.12}.el-carousel__item--card.is-active{z-index:calc(var(--el-index-normal) + 1)}.el-carousel__mask{position:absolute;width:100%;height:100%;top:0;left:0;background-color:var(--el-color-white);opacity:.24;transition:var(--el-transition-duration-fast)}.el-carousel{--el-carousel-arrow-font-size:12px;--el-carousel-arrow-size:36px;--el-carousel-arrow-background:rgba(31, 45, 61, .11);--el-carousel-arrow-hover-background:rgba(31, 45, 61, .23);--el-carousel-indicator-width:30px;--el-carousel-indicator-height:2px;--el-carousel-indicator-padding-horizontal:4px;--el-carousel-indicator-padding-vertical:12px;--el-carousel-indicator-out-color:var(--el-border-color-hover);position:relative}.el-carousel--horizontal{overflow-x:hidden}.el-carousel--vertical{overflow-y:hidden}.el-carousel__container{position:relative;height:300px}.el-carousel__arrow{border:none;outline:0;padding:0;margin:0;height:var(--el-carousel-arrow-size);width:var(--el-carousel-arrow-size);cursor:pointer;transition:var(--el-transition-duration);border-radius:50%;background-color:var(--el-carousel-arrow-background);color:#fff;position:absolute;top:50%;z-index:10;transform:translateY(-50%);text-align:center;font-size:var(--el-carousel-arrow-font-size);display:inline-flex;justify-content:center;align-items:center}.el-carousel__arrow--left{left:16px}.el-carousel__arrow--right{right:16px}.el-carousel__arrow:hover{background-color:var(--el-carousel-arrow-hover-background)}.el-carousel__arrow i{cursor:pointer}.el-carousel__indicators{position:absolute;list-style:none;margin:0;padding:0;z-index:calc(var(--el-index-normal) + 1)}.el-carousel__indicators--horizontal{bottom:0;left:50%;transform:translate(-50%)}.el-carousel__indicators--vertical{right:0;top:50%;transform:translateY(-50%)}.el-carousel__indicators--outside{bottom:calc(var(--el-carousel-indicator-height) + var(--el-carousel-indicator-padding-vertical) * 2);text-align:center;position:static;transform:none}.el-carousel__indicators--outside .el-carousel__indicator:hover button{opacity:.64}.el-carousel__indicators--outside button{background-color:var(--el-carousel-indicator-out-color);opacity:.24}.el-carousel__indicators--labels{left:0;right:0;transform:none;text-align:center}.el-carousel__indicators--labels .el-carousel__button{height:auto;width:auto;padding:2px 18px;font-size:12px;color:#000}.el-carousel__indicators--labels .el-carousel__indicator{padding:6px 4px}.el-carousel__indicator{background-color:transparent;cursor:pointer}.el-carousel__indicator:hover button{opacity:.72}.el-carousel__indicator--horizontal{display:inline-block;padding:var(--el-carousel-indicator-padding-vertical) var(--el-carousel-indicator-padding-horizontal)}.el-carousel__indicator--vertical{padding:var(--el-carousel-indicator-padding-horizontal) var(--el-carousel-indicator-padding-vertical)}.el-carousel__indicator--vertical .el-carousel__button{width:var(--el-carousel-indicator-height);height:calc(var(--el-carousel-indicator-width)/ 2)}.el-carousel__indicator.is-active button{opacity:1}.el-carousel__button{display:block;opacity:.48;width:var(--el-carousel-indicator-width);height:var(--el-carousel-indicator-height);background-color:#fff;border:none;outline:0;padding:0;margin:0;cursor:pointer;transition:var(--el-transition-duration)}.carousel-arrow-left-enter-from,.carousel-arrow-left-leave-active{transform:translateY(-50%) translate(-10px);opacity:0}.carousel-arrow-right-enter-from,.carousel-arrow-right-leave-active{transform:translateY(-50%) translate(10px);opacity:0}.el-cascader-panel{--el-cascader-menu-text-color:var(--el-text-color-regular);--el-cascader-menu-selected-text-color:var(--el-color-primary);--el-cascader-menu-fill:var(--el-bg-color-overlay);--el-cascader-menu-font-size:var(--el-font-size-base);--el-cascader-menu-radius:var(--el-border-radius-base);--el-cascader-menu-border:solid 1px var(--el-border-color-light);--el-cascader-menu-shadow:var(--el-box-shadow-light);--el-cascader-node-background-hover:var(--el-fill-color-light);--el-cascader-node-color-disabled:var(--el-text-color-placeholder);--el-cascader-color-empty:var(--el-text-color-placeholder);--el-cascader-tag-background:var(--el-fill-color)}.el-cascader-panel{display:flex;border-radius:var(--el-cascader-menu-radius);font-size:var(--el-cascader-menu-font-size)}.el-cascader-panel.is-bordered{border:var(--el-cascader-menu-border);border-radius:var(--el-cascader-menu-radius)}.el-cascader-menu{min-width:180px;box-sizing:border-box;color:var(--el-cascader-menu-text-color);border-right:var(--el-cascader-menu-border)}.el-cascader-menu:last-child{border-right:none}.el-cascader-menu:last-child .el-cascader-node{padding-right:20px}.el-cascader-menu__wrap.el-scrollbar__wrap{height:204px}.el-cascader-menu__list{position:relative;min-height:100%;margin:0;padding:6px 0;list-style:none;box-sizing:border-box}.el-cascader-menu__hover-zone{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.el-cascader-menu__empty-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;color:var(--el-cascader-color-empty)}.el-cascader-menu__empty-text .is-loading{margin-right:2px}.el-cascader-node{position:relative;display:flex;align-items:center;padding:0 30px 0 20px;height:34px;line-height:34px;outline:0}.el-cascader-node.is-selectable.in-active-path{color:var(--el-cascader-menu-text-color)}.el-cascader-node.in-active-path,.el-cascader-node.is-active,.el-cascader-node.is-selectable.in-checked-path{color:var(--el-cascader-menu-selected-text-color);font-weight:700}.el-cascader-node:not(.is-disabled){cursor:pointer}.el-cascader-node:not(.is-disabled):focus,.el-cascader-node:not(.is-disabled):hover{background:var(--el-cascader-node-background-hover)}.el-cascader-node.is-disabled{color:var(--el-cascader-node-color-disabled);cursor:not-allowed}.el-cascader-node__prefix{position:absolute;left:10px}.el-cascader-node__postfix{position:absolute;right:10px}.el-cascader-node__label{flex:1;text-align:left;padding:0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.el-cascader-node>.el-checkbox{margin-right:0}.el-cascader-node>.el-radio{margin-right:0}.el-cascader-node>.el-radio .el-radio__label{padding-left:0}.el-cascader{--el-cascader-menu-text-color:var(--el-text-color-regular);--el-cascader-menu-selected-text-color:var(--el-color-primary);--el-cascader-menu-fill:var(--el-bg-color-overlay);--el-cascader-menu-font-size:var(--el-font-size-base);--el-cascader-menu-radius:var(--el-border-radius-base);--el-cascader-menu-border:solid 1px var(--el-border-color-light);--el-cascader-menu-shadow:var(--el-box-shadow-light);--el-cascader-node-background-hover:var(--el-fill-color-light);--el-cascader-node-color-disabled:var(--el-text-color-placeholder);--el-cascader-color-empty:var(--el-text-color-placeholder);--el-cascader-tag-background:var(--el-fill-color);display:inline-block;vertical-align:middle;position:relative;font-size:var(--el-font-size-base);line-height:32px;outline:0}.el-cascader:not(.is-disabled):hover .el-input__wrapper{cursor:pointer;box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-cascader .el-input{display:flex;cursor:pointer}.el-cascader .el-input .el-input__inner{text-overflow:ellipsis;cursor:pointer}.el-cascader .el-input .el-input__suffix-inner .el-icon{height:calc(100% - 2px)}.el-cascader .el-input .el-input__suffix-inner .el-icon svg{vertical-align:middle}.el-cascader .el-input .icon-arrow-down{transition:transform var(--el-transition-duration);font-size:14px}.el-cascader .el-input .icon-arrow-down.is-reverse{transform:rotate(180deg)}.el-cascader .el-input .icon-circle-close:hover{color:var(--el-input-clear-hover-color,var(--el-text-color-secondary))}.el-cascader .el-input.is-focus .el-input__wrapper{box-shadow:0 0 0 1px var(--el-input-focus-border-color,var(--el-color-primary)) inset}.el-cascader--large{font-size:14px;line-height:40px}.el-cascader--small{font-size:12px;line-height:24px}.el-cascader.is-disabled .el-cascader__label{z-index:calc(var(--el-index-normal) + 1);color:var(--el-disabled-text-color)}.el-cascader__dropdown{--el-cascader-menu-text-color:var(--el-text-color-regular);--el-cascader-menu-selected-text-color:var(--el-color-primary);--el-cascader-menu-fill:var(--el-bg-color-overlay);--el-cascader-menu-font-size:var(--el-font-size-base);--el-cascader-menu-radius:var(--el-border-radius-base);--el-cascader-menu-border:solid 1px var(--el-border-color-light);--el-cascader-menu-shadow:var(--el-box-shadow-light);--el-cascader-node-background-hover:var(--el-fill-color-light);--el-cascader-node-color-disabled:var(--el-text-color-placeholder);--el-cascader-color-empty:var(--el-text-color-placeholder);--el-cascader-tag-background:var(--el-fill-color)}.el-cascader__dropdown{font-size:var(--el-cascader-menu-font-size);border-radius:var(--el-cascader-menu-radius)}.el-cascader__dropdown.el-popper{background:var(--el-cascader-menu-fill);border:var(--el-cascader-menu-border);box-shadow:var(--el-cascader-menu-shadow)}.el-cascader__dropdown.el-popper .el-popper__arrow:before{border:var(--el-cascader-menu-border)}.el-cascader__dropdown.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-cascader__dropdown.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-cascader__dropdown.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-cascader__dropdown.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-cascader__dropdown.el-popper{box-shadow:var(--el-cascader-menu-shadow)}.el-cascader__tags{position:absolute;left:0;right:30px;top:50%;transform:translateY(-50%);display:flex;flex-wrap:wrap;line-height:normal;text-align:left;box-sizing:border-box}.el-cascader__tags .el-tag{display:inline-flex;align-items:center;max-width:100%;margin:2px 0 2px 6px;text-overflow:ellipsis;background:var(--el-cascader-tag-background)}.el-cascader__tags .el-tag:not(.is-hit){border-color:transparent}.el-cascader__tags .el-tag>span{flex:1;overflow:hidden;text-overflow:ellipsis}.el-cascader__tags .el-tag .el-icon-close{flex:none;background-color:var(--el-text-color-placeholder);color:var(--el-color-white)}.el-cascader__tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-cascader__collapse-tags{white-space:normal;z-index:var(--el-index-normal)}.el-cascader__collapse-tags .el-tag{display:inline-flex;align-items:center;max-width:100%;margin:2px 0 2px 6px;text-overflow:ellipsis;background:var(--el-fill-color)}.el-cascader__collapse-tags .el-tag:not(.is-hit){border-color:transparent}.el-cascader__collapse-tags .el-tag>span{flex:1;overflow:hidden;text-overflow:ellipsis}.el-cascader__collapse-tags .el-tag .el-icon-close{flex:none;background-color:var(--el-text-color-placeholder);color:var(--el-color-white)}.el-cascader__collapse-tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-cascader__suggestion-panel{border-radius:var(--el-cascader-menu-radius)}.el-cascader__suggestion-list{max-height:204px;margin:0;padding:6px 0;font-size:var(--el-font-size-base);color:var(--el-cascader-menu-text-color);text-align:center}.el-cascader__suggestion-item{display:flex;justify-content:space-between;align-items:center;height:34px;padding:0 15px;text-align:left;outline:0;cursor:pointer}.el-cascader__suggestion-item:focus,.el-cascader__suggestion-item:hover{background:var(--el-cascader-node-background-hover)}.el-cascader__suggestion-item.is-checked{color:var(--el-cascader-menu-selected-text-color);font-weight:700}.el-cascader__suggestion-item>span{margin-right:10px}.el-cascader__empty-text{margin:10px 0;color:var(--el-cascader-color-empty)}.el-cascader__search-input{flex:1;height:24px;min-width:60px;margin:2px 0 2px 11px;padding:0;color:var(--el-cascader-menu-text-color);border:none;outline:0;box-sizing:border-box;background:0 0}.el-cascader__search-input::-moz-placeholder{color:transparent}.el-cascader__search-input:-ms-input-placeholder{color:transparent}.el-cascader__search-input::placeholder{color:transparent}.el-check-tag{background-color:var(--el-color-info-light-9);border-radius:var(--el-border-radius-base);color:var(--el-color-info);cursor:pointer;display:inline-block;font-size:var(--el-font-size-base);line-height:var(--el-font-size-base);padding:7px 15px;transition:var(--el-transition-all);font-weight:700}.el-check-tag:hover{background-color:var(--el-color-info-light-7)}.el-check-tag.is-checked{background-color:var(--el-color-primary-light-8);color:var(--el-color-primary)}.el-check-tag.is-checked:hover{background-color:var(--el-color-primary-light-7)}.el-checkbox-button{--el-checkbox-button-checked-bg-color:var(--el-color-primary);--el-checkbox-button-checked-text-color:var(--el-color-white);--el-checkbox-button-checked-border-color:var(--el-color-primary)}.el-checkbox-button{position:relative;display:inline-block}.el-checkbox-button__inner{display:inline-block;line-height:1;font-weight:var(--el-checkbox-font-weight);white-space:nowrap;vertical-align:middle;cursor:pointer;background:var(--el-button-bg-color,var(--el-fill-color-blank));border:var(--el-border);border-left:0;color:var(--el-button-text-color,var(--el-text-color-regular));-webkit-appearance:none;text-align:center;box-sizing:border-box;outline:0;margin:0;position:relative;transition:var(--el-transition-all);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;padding:8px 15px;font-size:var(--el-font-size-base);border-radius:0}.el-checkbox-button__inner.is-round{padding:8px 15px}.el-checkbox-button__inner:hover{color:var(--el-color-primary)}.el-checkbox-button__inner [class*=el-icon-]{line-height:.9}.el-checkbox-button__inner [class*=el-icon-]+span{margin-left:5px}.el-checkbox-button__original{opacity:0;outline:0;position:absolute;margin:0;z-index:-1}.el-checkbox-button.is-checked .el-checkbox-button__inner{color:var(--el-checkbox-button-checked-text-color);background-color:var(--el-checkbox-button-checked-bg-color);border-color:var(--el-checkbox-button-checked-border-color);box-shadow:-1px 0 0 0 var(--el-color-primary-light-7)}.el-checkbox-button.is-checked:first-child .el-checkbox-button__inner{border-left-color:var(--el-checkbox-button-checked-border-color)}.el-checkbox-button.is-disabled .el-checkbox-button__inner{color:var(--el-disabled-text-color);cursor:not-allowed;background-image:none;background-color:var(--el-button-disabled-bg-color,var(--el-fill-color-blank));border-color:var(--el-button-disabled-border-color,var(--el-border-color-light));box-shadow:none}.el-checkbox-button.is-disabled:first-child .el-checkbox-button__inner{border-left-color:var(--el-button-disabled-border-color,var(--el-border-color-light))}.el-checkbox-button:first-child .el-checkbox-button__inner{border-left:var(--el-border);border-top-left-radius:var(--el-border-radius-base);border-bottom-left-radius:var(--el-border-radius-base);box-shadow:none!important}.el-checkbox-button.is-focus .el-checkbox-button__inner{border-color:var(--el-checkbox-button-checked-border-color)}.el-checkbox-button:last-child .el-checkbox-button__inner{border-top-right-radius:var(--el-border-radius-base);border-bottom-right-radius:var(--el-border-radius-base)}.el-checkbox-button--large .el-checkbox-button__inner{padding:12px 19px;font-size:var(--el-font-size-base);border-radius:0}.el-checkbox-button--large .el-checkbox-button__inner.is-round{padding:12px 19px}.el-checkbox-button--small .el-checkbox-button__inner{padding:5px 11px;font-size:12px;border-radius:0}.el-checkbox-button--small .el-checkbox-button__inner.is-round{padding:5px 11px}.el-checkbox-group{font-size:0;line-height:0}.el-checkbox{--el-checkbox-font-size:14px;--el-checkbox-font-weight:var(--el-font-weight-primary);--el-checkbox-text-color:var(--el-text-color-regular);--el-checkbox-input-height:14px;--el-checkbox-input-width:14px;--el-checkbox-border-radius:var(--el-border-radius-small);--el-checkbox-bg-color:var(--el-fill-color-blank);--el-checkbox-input-border:var(--el-border);--el-checkbox-disabled-border-color:var(--el-border-color);--el-checkbox-disabled-input-fill:var(--el-fill-color-light);--el-checkbox-disabled-icon-color:var(--el-text-color-placeholder);--el-checkbox-disabled-checked-input-fill:var(--el-border-color-extra-light);--el-checkbox-disabled-checked-input-border-color:var(--el-border-color);--el-checkbox-disabled-checked-icon-color:var(--el-text-color-placeholder);--el-checkbox-checked-text-color:var(--el-color-primary);--el-checkbox-checked-input-border-color:var(--el-color-primary);--el-checkbox-checked-bg-color:var(--el-color-primary);--el-checkbox-checked-icon-color:var(--el-color-white);--el-checkbox-input-border-color-hover:var(--el-color-primary)}.el-checkbox{color:var(--el-checkbox-text-color);font-weight:var(--el-checkbox-font-weight);font-size:var(--el-font-size-base);position:relative;cursor:pointer;display:inline-flex;align-items:center;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;margin-right:30px;height:32px}.el-checkbox.is-disabled{cursor:not-allowed}.el-checkbox.is-bordered{padding:0 15px 0 9px;border-radius:var(--el-border-radius-base);border:var(--el-border);box-sizing:border-box}.el-checkbox.is-bordered.is-checked{border-color:var(--el-color-primary)}.el-checkbox.is-bordered.is-disabled{border-color:var(--el-border-color-lighter)}.el-checkbox.is-bordered.el-checkbox--large{padding:0 19px 0 11px;border-radius:var(--el-border-radius-base)}.el-checkbox.is-bordered.el-checkbox--large .el-checkbox__label{font-size:var(--el-font-size-base)}.el-checkbox.is-bordered.el-checkbox--large .el-checkbox__inner{height:14px;width:14px}.el-checkbox.is-bordered.el-checkbox--small{padding:0 11px 0 7px;border-radius:calc(var(--el-border-radius-base) - 1px)}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__label{font-size:12px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__inner{height:12px;width:12px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__inner:after{height:6px;width:2px}.el-checkbox input:focus-visible+.el-checkbox__inner{outline:2px solid var(--el-checkbox-input-border-color-hover);outline-offset:1px;border-radius:var(--el-checkbox-border-radius)}.el-checkbox__input{white-space:nowrap;cursor:pointer;outline:0;display:inline-flex;position:relative}.el-checkbox__input.is-disabled .el-checkbox__inner{background-color:var(--el-checkbox-disabled-input-fill);border-color:var(--el-checkbox-disabled-border-color);cursor:not-allowed}.el-checkbox__input.is-disabled .el-checkbox__inner:after{cursor:not-allowed;border-color:var(--el-checkbox-disabled-icon-color)}.el-checkbox__input.is-disabled.is-checked .el-checkbox__inner{background-color:var(--el-checkbox-disabled-checked-input-fill);border-color:var(--el-checkbox-disabled-checked-input-border-color)}.el-checkbox__input.is-disabled.is-checked .el-checkbox__inner:after{border-color:var(--el-checkbox-disabled-checked-icon-color)}.el-checkbox__input.is-disabled.is-indeterminate .el-checkbox__inner{background-color:var(--el-checkbox-disabled-checked-input-fill);border-color:var(--el-checkbox-disabled-checked-input-border-color)}.el-checkbox__input.is-disabled.is-indeterminate .el-checkbox__inner:before{background-color:var(--el-checkbox-disabled-checked-icon-color);border-color:var(--el-checkbox-disabled-checked-icon-color)}.el-checkbox__input.is-disabled+span.el-checkbox__label{color:var(--el-disabled-text-color);cursor:not-allowed}.el-checkbox__input.is-checked .el-checkbox__inner{background-color:var(--el-checkbox-checked-bg-color);border-color:var(--el-checkbox-checked-input-border-color)}.el-checkbox__input.is-checked .el-checkbox__inner:after{transform:rotate(45deg) scaleY(1)}.el-checkbox__input.is-checked+.el-checkbox__label{color:var(--el-checkbox-checked-text-color)}.el-checkbox__input.is-focus:not(.is-checked) .el-checkbox__original:not(:focus-visible){border-color:var(--el-checkbox-input-border-color-hover)}.el-checkbox__input.is-indeterminate .el-checkbox__inner{background-color:var(--el-checkbox-checked-bg-color);border-color:var(--el-checkbox-checked-input-border-color)}.el-checkbox__input.is-indeterminate .el-checkbox__inner:before{content:"";position:absolute;display:block;background-color:var(--el-checkbox-checked-icon-color);height:2px;transform:scale(.5);left:0;right:0;top:5px}.el-checkbox__input.is-indeterminate .el-checkbox__inner:after{display:none}.el-checkbox__inner{display:inline-block;position:relative;border:var(--el-checkbox-input-border);border-radius:var(--el-checkbox-border-radius);box-sizing:border-box;width:var(--el-checkbox-input-width);height:var(--el-checkbox-input-height);background-color:var(--el-checkbox-bg-color);z-index:var(--el-index-normal);transition:border-color .25s cubic-bezier(.71,-.46,.29,1.46),background-color .25s cubic-bezier(.71,-.46,.29,1.46),outline .25s cubic-bezier(.71,-.46,.29,1.46)}.el-checkbox__inner:hover{border-color:var(--el-checkbox-input-border-color-hover)}.el-checkbox__inner:after{box-sizing:content-box;content:"";border:1px solid var(--el-checkbox-checked-icon-color);border-left:0;border-top:0;height:7px;left:4px;position:absolute;top:1px;transform:rotate(45deg) scaleY(0);width:3px;transition:transform .15s ease-in 50ms;transform-origin:center}.el-checkbox__original{opacity:0;outline:0;position:absolute;margin:0;width:0;height:0;z-index:-1}.el-checkbox__label{display:inline-block;padding-left:8px;line-height:1;font-size:var(--el-checkbox-font-size)}.el-checkbox.el-checkbox--large{height:40px}.el-checkbox.el-checkbox--large .el-checkbox__label{font-size:14px}.el-checkbox.el-checkbox--large .el-checkbox__inner{width:14px;height:14px}.el-checkbox.el-checkbox--small{height:24px}.el-checkbox.el-checkbox--small .el-checkbox__label{font-size:12px}.el-checkbox.el-checkbox--small .el-checkbox__inner{width:12px;height:12px}.el-checkbox.el-checkbox--small .el-checkbox__input.is-indeterminate .el-checkbox__inner:before{top:4px}.el-checkbox.el-checkbox--small .el-checkbox__inner:after{width:2px;height:6px}.el-checkbox:last-of-type{margin-right:0}[class*=el-col-]{box-sizing:border-box}[class*=el-col-].is-guttered{display:block;min-height:1px}.el-col-0,.el-col-0.is-guttered{display:none}.el-col-0{max-width:0%;flex:0 0 0%}.el-col-offset-0{margin-left:0}.el-col-pull-0{position:relative;right:0}.el-col-push-0{position:relative;left:0}.el-col-1{max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-offset-1{margin-left:4.1666666667%}.el-col-pull-1{position:relative;right:4.1666666667%}.el-col-push-1{position:relative;left:4.1666666667%}.el-col-2{max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-offset-2{margin-left:8.3333333333%}.el-col-pull-2{position:relative;right:8.3333333333%}.el-col-push-2{position:relative;left:8.3333333333%}.el-col-3{max-width:12.5%;flex:0 0 12.5%}.el-col-offset-3{margin-left:12.5%}.el-col-pull-3{position:relative;right:12.5%}.el-col-push-3{position:relative;left:12.5%}.el-col-4{max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-offset-4{margin-left:16.6666666667%}.el-col-pull-4{position:relative;right:16.6666666667%}.el-col-push-4{position:relative;left:16.6666666667%}.el-col-5{max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-offset-5{margin-left:20.8333333333%}.el-col-pull-5{position:relative;right:20.8333333333%}.el-col-push-5{position:relative;left:20.8333333333%}.el-col-6{max-width:25%;flex:0 0 25%}.el-col-offset-6{margin-left:25%}.el-col-pull-6{position:relative;right:25%}.el-col-push-6{position:relative;left:25%}.el-col-7{max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-offset-7{margin-left:29.1666666667%}.el-col-pull-7{position:relative;right:29.1666666667%}.el-col-push-7{position:relative;left:29.1666666667%}.el-col-8{max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-offset-8{margin-left:33.3333333333%}.el-col-pull-8{position:relative;right:33.3333333333%}.el-col-push-8{position:relative;left:33.3333333333%}.el-col-9{max-width:37.5%;flex:0 0 37.5%}.el-col-offset-9{margin-left:37.5%}.el-col-pull-9{position:relative;right:37.5%}.el-col-push-9{position:relative;left:37.5%}.el-col-10{max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-offset-10{margin-left:41.6666666667%}.el-col-pull-10{position:relative;right:41.6666666667%}.el-col-push-10{position:relative;left:41.6666666667%}.el-col-11{max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-offset-11{margin-left:45.8333333333%}.el-col-pull-11{position:relative;right:45.8333333333%}.el-col-push-11{position:relative;left:45.8333333333%}.el-col-12{max-width:50%;flex:0 0 50%}.el-col-offset-12{margin-left:50%}.el-col-pull-12{position:relative;right:50%}.el-col-push-12{position:relative;left:50%}.el-col-13{max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-offset-13{margin-left:54.1666666667%}.el-col-pull-13{position:relative;right:54.1666666667%}.el-col-push-13{position:relative;left:54.1666666667%}.el-col-14{max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-offset-14{margin-left:58.3333333333%}.el-col-pull-14{position:relative;right:58.3333333333%}.el-col-push-14{position:relative;left:58.3333333333%}.el-col-15{max-width:62.5%;flex:0 0 62.5%}.el-col-offset-15{margin-left:62.5%}.el-col-pull-15{position:relative;right:62.5%}.el-col-push-15{position:relative;left:62.5%}.el-col-16{max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-offset-16{margin-left:66.6666666667%}.el-col-pull-16{position:relative;right:66.6666666667%}.el-col-push-16{position:relative;left:66.6666666667%}.el-col-17{max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-offset-17{margin-left:70.8333333333%}.el-col-pull-17{position:relative;right:70.8333333333%}.el-col-push-17{position:relative;left:70.8333333333%}.el-col-18{max-width:75%;flex:0 0 75%}.el-col-offset-18{margin-left:75%}.el-col-pull-18{position:relative;right:75%}.el-col-push-18{position:relative;left:75%}.el-col-19{max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-offset-19{margin-left:79.1666666667%}.el-col-pull-19{position:relative;right:79.1666666667%}.el-col-push-19{position:relative;left:79.1666666667%}.el-col-20{max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-offset-20{margin-left:83.3333333333%}.el-col-pull-20{position:relative;right:83.3333333333%}.el-col-push-20{position:relative;left:83.3333333333%}.el-col-21{max-width:87.5%;flex:0 0 87.5%}.el-col-offset-21{margin-left:87.5%}.el-col-pull-21{position:relative;right:87.5%}.el-col-push-21{position:relative;left:87.5%}.el-col-22{max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-offset-22{margin-left:91.6666666667%}.el-col-pull-22{position:relative;right:91.6666666667%}.el-col-push-22{position:relative;left:91.6666666667%}.el-col-23{max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-offset-23{margin-left:95.8333333333%}.el-col-pull-23{position:relative;right:95.8333333333%}.el-col-push-23{position:relative;left:95.8333333333%}.el-col-24{max-width:100%;flex:0 0 100%}.el-col-offset-24{margin-left:100%}.el-col-pull-24{position:relative;right:100%}.el-col-push-24{position:relative;left:100%}@media only screen and (max-width:768px){.el-col-xs-0,.el-col-xs-0.is-guttered{display:none}.el-col-xs-0{max-width:0%;flex:0 0 0%}.el-col-xs-offset-0{margin-left:0}.el-col-xs-pull-0{position:relative;right:0}.el-col-xs-push-0{position:relative;left:0}.el-col-xs-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-xs-offset-1{margin-left:4.1666666667%}.el-col-xs-pull-1{position:relative;right:4.1666666667%}.el-col-xs-push-1{position:relative;left:4.1666666667%}.el-col-xs-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-xs-offset-2{margin-left:8.3333333333%}.el-col-xs-pull-2{position:relative;right:8.3333333333%}.el-col-xs-push-2{position:relative;left:8.3333333333%}.el-col-xs-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-xs-offset-3{margin-left:12.5%}.el-col-xs-pull-3{position:relative;right:12.5%}.el-col-xs-push-3{position:relative;left:12.5%}.el-col-xs-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-xs-offset-4{margin-left:16.6666666667%}.el-col-xs-pull-4{position:relative;right:16.6666666667%}.el-col-xs-push-4{position:relative;left:16.6666666667%}.el-col-xs-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-xs-offset-5{margin-left:20.8333333333%}.el-col-xs-pull-5{position:relative;right:20.8333333333%}.el-col-xs-push-5{position:relative;left:20.8333333333%}.el-col-xs-6{display:block;max-width:25%;flex:0 0 25%}.el-col-xs-offset-6{margin-left:25%}.el-col-xs-pull-6{position:relative;right:25%}.el-col-xs-push-6{position:relative;left:25%}.el-col-xs-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-xs-offset-7{margin-left:29.1666666667%}.el-col-xs-pull-7{position:relative;right:29.1666666667%}.el-col-xs-push-7{position:relative;left:29.1666666667%}.el-col-xs-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-xs-offset-8{margin-left:33.3333333333%}.el-col-xs-pull-8{position:relative;right:33.3333333333%}.el-col-xs-push-8{position:relative;left:33.3333333333%}.el-col-xs-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-xs-offset-9{margin-left:37.5%}.el-col-xs-pull-9{position:relative;right:37.5%}.el-col-xs-push-9{position:relative;left:37.5%}.el-col-xs-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-xs-offset-10{margin-left:41.6666666667%}.el-col-xs-pull-10{position:relative;right:41.6666666667%}.el-col-xs-push-10{position:relative;left:41.6666666667%}.el-col-xs-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-xs-offset-11{margin-left:45.8333333333%}.el-col-xs-pull-11{position:relative;right:45.8333333333%}.el-col-xs-push-11{position:relative;left:45.8333333333%}.el-col-xs-12{display:block;max-width:50%;flex:0 0 50%}.el-col-xs-offset-12{margin-left:50%}.el-col-xs-pull-12{position:relative;right:50%}.el-col-xs-push-12{position:relative;left:50%}.el-col-xs-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-xs-offset-13{margin-left:54.1666666667%}.el-col-xs-pull-13{position:relative;right:54.1666666667%}.el-col-xs-push-13{position:relative;left:54.1666666667%}.el-col-xs-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-xs-offset-14{margin-left:58.3333333333%}.el-col-xs-pull-14{position:relative;right:58.3333333333%}.el-col-xs-push-14{position:relative;left:58.3333333333%}.el-col-xs-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-xs-offset-15{margin-left:62.5%}.el-col-xs-pull-15{position:relative;right:62.5%}.el-col-xs-push-15{position:relative;left:62.5%}.el-col-xs-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-xs-offset-16{margin-left:66.6666666667%}.el-col-xs-pull-16{position:relative;right:66.6666666667%}.el-col-xs-push-16{position:relative;left:66.6666666667%}.el-col-xs-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-xs-offset-17{margin-left:70.8333333333%}.el-col-xs-pull-17{position:relative;right:70.8333333333%}.el-col-xs-push-17{position:relative;left:70.8333333333%}.el-col-xs-18{display:block;max-width:75%;flex:0 0 75%}.el-col-xs-offset-18{margin-left:75%}.el-col-xs-pull-18{position:relative;right:75%}.el-col-xs-push-18{position:relative;left:75%}.el-col-xs-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-xs-offset-19{margin-left:79.1666666667%}.el-col-xs-pull-19{position:relative;right:79.1666666667%}.el-col-xs-push-19{position:relative;left:79.1666666667%}.el-col-xs-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-xs-offset-20{margin-left:83.3333333333%}.el-col-xs-pull-20{position:relative;right:83.3333333333%}.el-col-xs-push-20{position:relative;left:83.3333333333%}.el-col-xs-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-xs-offset-21{margin-left:87.5%}.el-col-xs-pull-21{position:relative;right:87.5%}.el-col-xs-push-21{position:relative;left:87.5%}.el-col-xs-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-xs-offset-22{margin-left:91.6666666667%}.el-col-xs-pull-22{position:relative;right:91.6666666667%}.el-col-xs-push-22{position:relative;left:91.6666666667%}.el-col-xs-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-xs-offset-23{margin-left:95.8333333333%}.el-col-xs-pull-23{position:relative;right:95.8333333333%}.el-col-xs-push-23{position:relative;left:95.8333333333%}.el-col-xs-24{display:block;max-width:100%;flex:0 0 100%}.el-col-xs-offset-24{margin-left:100%}.el-col-xs-pull-24{position:relative;right:100%}.el-col-xs-push-24{position:relative;left:100%}}@media only screen and (min-width:768px){.el-col-sm-0,.el-col-sm-0.is-guttered{display:none}.el-col-sm-0{max-width:0%;flex:0 0 0%}.el-col-sm-offset-0{margin-left:0}.el-col-sm-pull-0{position:relative;right:0}.el-col-sm-push-0{position:relative;left:0}.el-col-sm-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-sm-offset-1{margin-left:4.1666666667%}.el-col-sm-pull-1{position:relative;right:4.1666666667%}.el-col-sm-push-1{position:relative;left:4.1666666667%}.el-col-sm-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-sm-offset-2{margin-left:8.3333333333%}.el-col-sm-pull-2{position:relative;right:8.3333333333%}.el-col-sm-push-2{position:relative;left:8.3333333333%}.el-col-sm-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-sm-offset-3{margin-left:12.5%}.el-col-sm-pull-3{position:relative;right:12.5%}.el-col-sm-push-3{position:relative;left:12.5%}.el-col-sm-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-sm-offset-4{margin-left:16.6666666667%}.el-col-sm-pull-4{position:relative;right:16.6666666667%}.el-col-sm-push-4{position:relative;left:16.6666666667%}.el-col-sm-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-sm-offset-5{margin-left:20.8333333333%}.el-col-sm-pull-5{position:relative;right:20.8333333333%}.el-col-sm-push-5{position:relative;left:20.8333333333%}.el-col-sm-6{display:block;max-width:25%;flex:0 0 25%}.el-col-sm-offset-6{margin-left:25%}.el-col-sm-pull-6{position:relative;right:25%}.el-col-sm-push-6{position:relative;left:25%}.el-col-sm-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-sm-offset-7{margin-left:29.1666666667%}.el-col-sm-pull-7{position:relative;right:29.1666666667%}.el-col-sm-push-7{position:relative;left:29.1666666667%}.el-col-sm-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-sm-offset-8{margin-left:33.3333333333%}.el-col-sm-pull-8{position:relative;right:33.3333333333%}.el-col-sm-push-8{position:relative;left:33.3333333333%}.el-col-sm-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-sm-offset-9{margin-left:37.5%}.el-col-sm-pull-9{position:relative;right:37.5%}.el-col-sm-push-9{position:relative;left:37.5%}.el-col-sm-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-sm-offset-10{margin-left:41.6666666667%}.el-col-sm-pull-10{position:relative;right:41.6666666667%}.el-col-sm-push-10{position:relative;left:41.6666666667%}.el-col-sm-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-sm-offset-11{margin-left:45.8333333333%}.el-col-sm-pull-11{position:relative;right:45.8333333333%}.el-col-sm-push-11{position:relative;left:45.8333333333%}.el-col-sm-12{display:block;max-width:50%;flex:0 0 50%}.el-col-sm-offset-12{margin-left:50%}.el-col-sm-pull-12{position:relative;right:50%}.el-col-sm-push-12{position:relative;left:50%}.el-col-sm-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-sm-offset-13{margin-left:54.1666666667%}.el-col-sm-pull-13{position:relative;right:54.1666666667%}.el-col-sm-push-13{position:relative;left:54.1666666667%}.el-col-sm-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-sm-offset-14{margin-left:58.3333333333%}.el-col-sm-pull-14{position:relative;right:58.3333333333%}.el-col-sm-push-14{position:relative;left:58.3333333333%}.el-col-sm-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-sm-offset-15{margin-left:62.5%}.el-col-sm-pull-15{position:relative;right:62.5%}.el-col-sm-push-15{position:relative;left:62.5%}.el-col-sm-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-sm-offset-16{margin-left:66.6666666667%}.el-col-sm-pull-16{position:relative;right:66.6666666667%}.el-col-sm-push-16{position:relative;left:66.6666666667%}.el-col-sm-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-sm-offset-17{margin-left:70.8333333333%}.el-col-sm-pull-17{position:relative;right:70.8333333333%}.el-col-sm-push-17{position:relative;left:70.8333333333%}.el-col-sm-18{display:block;max-width:75%;flex:0 0 75%}.el-col-sm-offset-18{margin-left:75%}.el-col-sm-pull-18{position:relative;right:75%}.el-col-sm-push-18{position:relative;left:75%}.el-col-sm-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-sm-offset-19{margin-left:79.1666666667%}.el-col-sm-pull-19{position:relative;right:79.1666666667%}.el-col-sm-push-19{position:relative;left:79.1666666667%}.el-col-sm-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-sm-offset-20{margin-left:83.3333333333%}.el-col-sm-pull-20{position:relative;right:83.3333333333%}.el-col-sm-push-20{position:relative;left:83.3333333333%}.el-col-sm-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-sm-offset-21{margin-left:87.5%}.el-col-sm-pull-21{position:relative;right:87.5%}.el-col-sm-push-21{position:relative;left:87.5%}.el-col-sm-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-sm-offset-22{margin-left:91.6666666667%}.el-col-sm-pull-22{position:relative;right:91.6666666667%}.el-col-sm-push-22{position:relative;left:91.6666666667%}.el-col-sm-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-sm-offset-23{margin-left:95.8333333333%}.el-col-sm-pull-23{position:relative;right:95.8333333333%}.el-col-sm-push-23{position:relative;left:95.8333333333%}.el-col-sm-24{display:block;max-width:100%;flex:0 0 100%}.el-col-sm-offset-24{margin-left:100%}.el-col-sm-pull-24{position:relative;right:100%}.el-col-sm-push-24{position:relative;left:100%}}@media only screen and (min-width:992px){.el-col-md-0,.el-col-md-0.is-guttered{display:none}.el-col-md-0{max-width:0%;flex:0 0 0%}.el-col-md-offset-0{margin-left:0}.el-col-md-pull-0{position:relative;right:0}.el-col-md-push-0{position:relative;left:0}.el-col-md-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-md-offset-1{margin-left:4.1666666667%}.el-col-md-pull-1{position:relative;right:4.1666666667%}.el-col-md-push-1{position:relative;left:4.1666666667%}.el-col-md-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-md-offset-2{margin-left:8.3333333333%}.el-col-md-pull-2{position:relative;right:8.3333333333%}.el-col-md-push-2{position:relative;left:8.3333333333%}.el-col-md-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-md-offset-3{margin-left:12.5%}.el-col-md-pull-3{position:relative;right:12.5%}.el-col-md-push-3{position:relative;left:12.5%}.el-col-md-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-md-offset-4{margin-left:16.6666666667%}.el-col-md-pull-4{position:relative;right:16.6666666667%}.el-col-md-push-4{position:relative;left:16.6666666667%}.el-col-md-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-md-offset-5{margin-left:20.8333333333%}.el-col-md-pull-5{position:relative;right:20.8333333333%}.el-col-md-push-5{position:relative;left:20.8333333333%}.el-col-md-6{display:block;max-width:25%;flex:0 0 25%}.el-col-md-offset-6{margin-left:25%}.el-col-md-pull-6{position:relative;right:25%}.el-col-md-push-6{position:relative;left:25%}.el-col-md-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-md-offset-7{margin-left:29.1666666667%}.el-col-md-pull-7{position:relative;right:29.1666666667%}.el-col-md-push-7{position:relative;left:29.1666666667%}.el-col-md-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-md-offset-8{margin-left:33.3333333333%}.el-col-md-pull-8{position:relative;right:33.3333333333%}.el-col-md-push-8{position:relative;left:33.3333333333%}.el-col-md-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-md-offset-9{margin-left:37.5%}.el-col-md-pull-9{position:relative;right:37.5%}.el-col-md-push-9{position:relative;left:37.5%}.el-col-md-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-md-offset-10{margin-left:41.6666666667%}.el-col-md-pull-10{position:relative;right:41.6666666667%}.el-col-md-push-10{position:relative;left:41.6666666667%}.el-col-md-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-md-offset-11{margin-left:45.8333333333%}.el-col-md-pull-11{position:relative;right:45.8333333333%}.el-col-md-push-11{position:relative;left:45.8333333333%}.el-col-md-12{display:block;max-width:50%;flex:0 0 50%}.el-col-md-offset-12{margin-left:50%}.el-col-md-pull-12{position:relative;right:50%}.el-col-md-push-12{position:relative;left:50%}.el-col-md-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-md-offset-13{margin-left:54.1666666667%}.el-col-md-pull-13{position:relative;right:54.1666666667%}.el-col-md-push-13{position:relative;left:54.1666666667%}.el-col-md-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-md-offset-14{margin-left:58.3333333333%}.el-col-md-pull-14{position:relative;right:58.3333333333%}.el-col-md-push-14{position:relative;left:58.3333333333%}.el-col-md-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-md-offset-15{margin-left:62.5%}.el-col-md-pull-15{position:relative;right:62.5%}.el-col-md-push-15{position:relative;left:62.5%}.el-col-md-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-md-offset-16{margin-left:66.6666666667%}.el-col-md-pull-16{position:relative;right:66.6666666667%}.el-col-md-push-16{position:relative;left:66.6666666667%}.el-col-md-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-md-offset-17{margin-left:70.8333333333%}.el-col-md-pull-17{position:relative;right:70.8333333333%}.el-col-md-push-17{position:relative;left:70.8333333333%}.el-col-md-18{display:block;max-width:75%;flex:0 0 75%}.el-col-md-offset-18{margin-left:75%}.el-col-md-pull-18{position:relative;right:75%}.el-col-md-push-18{position:relative;left:75%}.el-col-md-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-md-offset-19{margin-left:79.1666666667%}.el-col-md-pull-19{position:relative;right:79.1666666667%}.el-col-md-push-19{position:relative;left:79.1666666667%}.el-col-md-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-md-offset-20{margin-left:83.3333333333%}.el-col-md-pull-20{position:relative;right:83.3333333333%}.el-col-md-push-20{position:relative;left:83.3333333333%}.el-col-md-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-md-offset-21{margin-left:87.5%}.el-col-md-pull-21{position:relative;right:87.5%}.el-col-md-push-21{position:relative;left:87.5%}.el-col-md-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-md-offset-22{margin-left:91.6666666667%}.el-col-md-pull-22{position:relative;right:91.6666666667%}.el-col-md-push-22{position:relative;left:91.6666666667%}.el-col-md-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-md-offset-23{margin-left:95.8333333333%}.el-col-md-pull-23{position:relative;right:95.8333333333%}.el-col-md-push-23{position:relative;left:95.8333333333%}.el-col-md-24{display:block;max-width:100%;flex:0 0 100%}.el-col-md-offset-24{margin-left:100%}.el-col-md-pull-24{position:relative;right:100%}.el-col-md-push-24{position:relative;left:100%}}@media only screen and (min-width:1200px){.el-col-lg-0,.el-col-lg-0.is-guttered{display:none}.el-col-lg-0{max-width:0%;flex:0 0 0%}.el-col-lg-offset-0{margin-left:0}.el-col-lg-pull-0{position:relative;right:0}.el-col-lg-push-0{position:relative;left:0}.el-col-lg-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-lg-offset-1{margin-left:4.1666666667%}.el-col-lg-pull-1{position:relative;right:4.1666666667%}.el-col-lg-push-1{position:relative;left:4.1666666667%}.el-col-lg-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-lg-offset-2{margin-left:8.3333333333%}.el-col-lg-pull-2{position:relative;right:8.3333333333%}.el-col-lg-push-2{position:relative;left:8.3333333333%}.el-col-lg-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-lg-offset-3{margin-left:12.5%}.el-col-lg-pull-3{position:relative;right:12.5%}.el-col-lg-push-3{position:relative;left:12.5%}.el-col-lg-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-lg-offset-4{margin-left:16.6666666667%}.el-col-lg-pull-4{position:relative;right:16.6666666667%}.el-col-lg-push-4{position:relative;left:16.6666666667%}.el-col-lg-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-lg-offset-5{margin-left:20.8333333333%}.el-col-lg-pull-5{position:relative;right:20.8333333333%}.el-col-lg-push-5{position:relative;left:20.8333333333%}.el-col-lg-6{display:block;max-width:25%;flex:0 0 25%}.el-col-lg-offset-6{margin-left:25%}.el-col-lg-pull-6{position:relative;right:25%}.el-col-lg-push-6{position:relative;left:25%}.el-col-lg-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-lg-offset-7{margin-left:29.1666666667%}.el-col-lg-pull-7{position:relative;right:29.1666666667%}.el-col-lg-push-7{position:relative;left:29.1666666667%}.el-col-lg-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-lg-offset-8{margin-left:33.3333333333%}.el-col-lg-pull-8{position:relative;right:33.3333333333%}.el-col-lg-push-8{position:relative;left:33.3333333333%}.el-col-lg-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-lg-offset-9{margin-left:37.5%}.el-col-lg-pull-9{position:relative;right:37.5%}.el-col-lg-push-9{position:relative;left:37.5%}.el-col-lg-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-lg-offset-10{margin-left:41.6666666667%}.el-col-lg-pull-10{position:relative;right:41.6666666667%}.el-col-lg-push-10{position:relative;left:41.6666666667%}.el-col-lg-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-lg-offset-11{margin-left:45.8333333333%}.el-col-lg-pull-11{position:relative;right:45.8333333333%}.el-col-lg-push-11{position:relative;left:45.8333333333%}.el-col-lg-12{display:block;max-width:50%;flex:0 0 50%}.el-col-lg-offset-12{margin-left:50%}.el-col-lg-pull-12{position:relative;right:50%}.el-col-lg-push-12{position:relative;left:50%}.el-col-lg-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-lg-offset-13{margin-left:54.1666666667%}.el-col-lg-pull-13{position:relative;right:54.1666666667%}.el-col-lg-push-13{position:relative;left:54.1666666667%}.el-col-lg-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-lg-offset-14{margin-left:58.3333333333%}.el-col-lg-pull-14{position:relative;right:58.3333333333%}.el-col-lg-push-14{position:relative;left:58.3333333333%}.el-col-lg-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-lg-offset-15{margin-left:62.5%}.el-col-lg-pull-15{position:relative;right:62.5%}.el-col-lg-push-15{position:relative;left:62.5%}.el-col-lg-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-lg-offset-16{margin-left:66.6666666667%}.el-col-lg-pull-16{position:relative;right:66.6666666667%}.el-col-lg-push-16{position:relative;left:66.6666666667%}.el-col-lg-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-lg-offset-17{margin-left:70.8333333333%}.el-col-lg-pull-17{position:relative;right:70.8333333333%}.el-col-lg-push-17{position:relative;left:70.8333333333%}.el-col-lg-18{display:block;max-width:75%;flex:0 0 75%}.el-col-lg-offset-18{margin-left:75%}.el-col-lg-pull-18{position:relative;right:75%}.el-col-lg-push-18{position:relative;left:75%}.el-col-lg-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-lg-offset-19{margin-left:79.1666666667%}.el-col-lg-pull-19{position:relative;right:79.1666666667%}.el-col-lg-push-19{position:relative;left:79.1666666667%}.el-col-lg-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-lg-offset-20{margin-left:83.3333333333%}.el-col-lg-pull-20{position:relative;right:83.3333333333%}.el-col-lg-push-20{position:relative;left:83.3333333333%}.el-col-lg-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-lg-offset-21{margin-left:87.5%}.el-col-lg-pull-21{position:relative;right:87.5%}.el-col-lg-push-21{position:relative;left:87.5%}.el-col-lg-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-lg-offset-22{margin-left:91.6666666667%}.el-col-lg-pull-22{position:relative;right:91.6666666667%}.el-col-lg-push-22{position:relative;left:91.6666666667%}.el-col-lg-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-lg-offset-23{margin-left:95.8333333333%}.el-col-lg-pull-23{position:relative;right:95.8333333333%}.el-col-lg-push-23{position:relative;left:95.8333333333%}.el-col-lg-24{display:block;max-width:100%;flex:0 0 100%}.el-col-lg-offset-24{margin-left:100%}.el-col-lg-pull-24{position:relative;right:100%}.el-col-lg-push-24{position:relative;left:100%}}@media only screen and (min-width:1920px){.el-col-xl-0,.el-col-xl-0.is-guttered{display:none}.el-col-xl-0{max-width:0%;flex:0 0 0%}.el-col-xl-offset-0{margin-left:0}.el-col-xl-pull-0{position:relative;right:0}.el-col-xl-push-0{position:relative;left:0}.el-col-xl-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-xl-offset-1{margin-left:4.1666666667%}.el-col-xl-pull-1{position:relative;right:4.1666666667%}.el-col-xl-push-1{position:relative;left:4.1666666667%}.el-col-xl-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-xl-offset-2{margin-left:8.3333333333%}.el-col-xl-pull-2{position:relative;right:8.3333333333%}.el-col-xl-push-2{position:relative;left:8.3333333333%}.el-col-xl-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-xl-offset-3{margin-left:12.5%}.el-col-xl-pull-3{position:relative;right:12.5%}.el-col-xl-push-3{position:relative;left:12.5%}.el-col-xl-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-xl-offset-4{margin-left:16.6666666667%}.el-col-xl-pull-4{position:relative;right:16.6666666667%}.el-col-xl-push-4{position:relative;left:16.6666666667%}.el-col-xl-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-xl-offset-5{margin-left:20.8333333333%}.el-col-xl-pull-5{position:relative;right:20.8333333333%}.el-col-xl-push-5{position:relative;left:20.8333333333%}.el-col-xl-6{display:block;max-width:25%;flex:0 0 25%}.el-col-xl-offset-6{margin-left:25%}.el-col-xl-pull-6{position:relative;right:25%}.el-col-xl-push-6{position:relative;left:25%}.el-col-xl-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-xl-offset-7{margin-left:29.1666666667%}.el-col-xl-pull-7{position:relative;right:29.1666666667%}.el-col-xl-push-7{position:relative;left:29.1666666667%}.el-col-xl-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-xl-offset-8{margin-left:33.3333333333%}.el-col-xl-pull-8{position:relative;right:33.3333333333%}.el-col-xl-push-8{position:relative;left:33.3333333333%}.el-col-xl-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-xl-offset-9{margin-left:37.5%}.el-col-xl-pull-9{position:relative;right:37.5%}.el-col-xl-push-9{position:relative;left:37.5%}.el-col-xl-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-xl-offset-10{margin-left:41.6666666667%}.el-col-xl-pull-10{position:relative;right:41.6666666667%}.el-col-xl-push-10{position:relative;left:41.6666666667%}.el-col-xl-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-xl-offset-11{margin-left:45.8333333333%}.el-col-xl-pull-11{position:relative;right:45.8333333333%}.el-col-xl-push-11{position:relative;left:45.8333333333%}.el-col-xl-12{display:block;max-width:50%;flex:0 0 50%}.el-col-xl-offset-12{margin-left:50%}.el-col-xl-pull-12{position:relative;right:50%}.el-col-xl-push-12{position:relative;left:50%}.el-col-xl-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-xl-offset-13{margin-left:54.1666666667%}.el-col-xl-pull-13{position:relative;right:54.1666666667%}.el-col-xl-push-13{position:relative;left:54.1666666667%}.el-col-xl-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-xl-offset-14{margin-left:58.3333333333%}.el-col-xl-pull-14{position:relative;right:58.3333333333%}.el-col-xl-push-14{position:relative;left:58.3333333333%}.el-col-xl-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-xl-offset-15{margin-left:62.5%}.el-col-xl-pull-15{position:relative;right:62.5%}.el-col-xl-push-15{position:relative;left:62.5%}.el-col-xl-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-xl-offset-16{margin-left:66.6666666667%}.el-col-xl-pull-16{position:relative;right:66.6666666667%}.el-col-xl-push-16{position:relative;left:66.6666666667%}.el-col-xl-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-xl-offset-17{margin-left:70.8333333333%}.el-col-xl-pull-17{position:relative;right:70.8333333333%}.el-col-xl-push-17{position:relative;left:70.8333333333%}.el-col-xl-18{display:block;max-width:75%;flex:0 0 75%}.el-col-xl-offset-18{margin-left:75%}.el-col-xl-pull-18{position:relative;right:75%}.el-col-xl-push-18{position:relative;left:75%}.el-col-xl-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-xl-offset-19{margin-left:79.1666666667%}.el-col-xl-pull-19{position:relative;right:79.1666666667%}.el-col-xl-push-19{position:relative;left:79.1666666667%}.el-col-xl-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-xl-offset-20{margin-left:83.3333333333%}.el-col-xl-pull-20{position:relative;right:83.3333333333%}.el-col-xl-push-20{position:relative;left:83.3333333333%}.el-col-xl-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-xl-offset-21{margin-left:87.5%}.el-col-xl-pull-21{position:relative;right:87.5%}.el-col-xl-push-21{position:relative;left:87.5%}.el-col-xl-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-xl-offset-22{margin-left:91.6666666667%}.el-col-xl-pull-22{position:relative;right:91.6666666667%}.el-col-xl-push-22{position:relative;left:91.6666666667%}.el-col-xl-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-xl-offset-23{margin-left:95.8333333333%}.el-col-xl-pull-23{position:relative;right:95.8333333333%}.el-col-xl-push-23{position:relative;left:95.8333333333%}.el-col-xl-24{display:block;max-width:100%;flex:0 0 100%}.el-col-xl-offset-24{margin-left:100%}.el-col-xl-pull-24{position:relative;right:100%}.el-col-xl-push-24{position:relative;left:100%}}.el-collapse{--el-collapse-border-color:var(--el-border-color-lighter);--el-collapse-header-height:48px;--el-collapse-header-bg-color:var(--el-fill-color-blank);--el-collapse-header-text-color:var(--el-text-color-primary);--el-collapse-header-font-size:13px;--el-collapse-content-bg-color:var(--el-fill-color-blank);--el-collapse-content-font-size:13px;--el-collapse-content-text-color:var(--el-text-color-primary);border-top:1px solid var(--el-collapse-border-color);border-bottom:1px solid var(--el-collapse-border-color)}.el-collapse-item.is-disabled .el-collapse-item__header{color:var(--el-text-color-disabled);cursor:not-allowed}.el-collapse-item__header{display:flex;align-items:center;height:var(--el-collapse-header-height);line-height:var(--el-collapse-header-height);background-color:var(--el-collapse-header-bg-color);color:var(--el-collapse-header-text-color);cursor:pointer;border-bottom:1px solid var(--el-collapse-border-color);font-size:var(--el-collapse-header-font-size);font-weight:500;transition:border-bottom-color var(--el-transition-duration);outline:0}.el-collapse-item__arrow{margin:0 8px 0 auto;transition:transform var(--el-transition-duration);font-weight:300}.el-collapse-item__arrow.is-active{transform:rotate(90deg)}.el-collapse-item__header.focusing:focus:not(:hover){color:var(--el-color-primary)}.el-collapse-item__header.is-active{border-bottom-color:transparent}.el-collapse-item__wrap{will-change:height;background-color:var(--el-collapse-content-bg-color);overflow:hidden;box-sizing:border-box;border-bottom:1px solid var(--el-collapse-border-color)}.el-collapse-item__content{padding-bottom:25px;font-size:var(--el-collapse-content-font-size);color:var(--el-collapse-content-text-color);line-height:1.7692307692}.el-collapse-item:last-child{margin-bottom:-1px}.el-color-predefine{display:flex;font-size:12px;margin-top:8px;width:280px}.el-color-predefine__colors{display:flex;flex:1;flex-wrap:wrap}.el-color-predefine__color-selector{margin:0 0 8px 8px;width:20px;height:20px;border-radius:4px;cursor:pointer}.el-color-predefine__color-selector:nth-child(10n+1){margin-left:0}.el-color-predefine__color-selector.selected{box-shadow:0 0 3px 2px var(--el-color-primary)}.el-color-predefine__color-selector>div{display:flex;height:100%;border-radius:3px}.el-color-predefine__color-selector.is-alpha{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAIAAADZF8uwAAAAGUlEQVQYV2M4gwH+YwCGIasIUwhT25BVBADtzYNYrHvv4gAAAABJRU5ErkJggg==)}.el-color-hue-slider{position:relative;box-sizing:border-box;width:280px;height:12px;background-color:red;padding:0 2px;float:right}.el-color-hue-slider__bar{position:relative;background:linear-gradient(to right,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%);height:100%}.el-color-hue-slider__thumb{position:absolute;cursor:pointer;box-sizing:border-box;left:0;top:0;width:4px;height:100%;border-radius:1px;background:#fff;border:1px solid var(--el-border-color-lighter);box-shadow:0 0 2px #0009;z-index:1}.el-color-hue-slider.is-vertical{width:12px;height:180px;padding:2px 0}.el-color-hue-slider.is-vertical .el-color-hue-slider__bar{background:linear-gradient(to bottom,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%)}.el-color-hue-slider.is-vertical .el-color-hue-slider__thumb{left:0;top:0;width:100%;height:4px}.el-color-svpanel{position:relative;width:280px;height:180px}.el-color-svpanel__black,.el-color-svpanel__white{position:absolute;top:0;left:0;right:0;bottom:0}.el-color-svpanel__white{background:linear-gradient(to right,#fff,rgba(255,255,255,0))}.el-color-svpanel__black{background:linear-gradient(to top,#000,rgba(0,0,0,0))}.el-color-svpanel__cursor{position:absolute}.el-color-svpanel__cursor>div{cursor:head;width:4px;height:4px;box-shadow:0 0 0 1.5px #fff,inset 0 0 1px 1px #0000004d,0 0 1px 2px #0006;border-radius:50%;transform:translate(-2px,-2px)}.el-color-alpha-slider{position:relative;box-sizing:border-box;width:280px;height:12px;background-image:linear-gradient(45deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(45deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%);background-size:12px 12px;background-position:0 0,6px 0,6px -6px,0 6px}.el-color-alpha-slider__bar{position:relative;background:linear-gradient(to right,rgba(255,255,255,0) 0,var(--el-bg-color) 100%);height:100%}.el-color-alpha-slider__thumb{position:absolute;cursor:pointer;box-sizing:border-box;left:0;top:0;width:4px;height:100%;border-radius:1px;background:#fff;border:1px solid var(--el-border-color-lighter);box-shadow:0 0 2px #0009;z-index:1}.el-color-alpha-slider.is-vertical{width:20px;height:180px}.el-color-alpha-slider.is-vertical .el-color-alpha-slider__bar{background:linear-gradient(to bottom,rgba(255,255,255,0) 0,#fff 100%)}.el-color-alpha-slider.is-vertical .el-color-alpha-slider__thumb{left:0;top:0;width:100%;height:4px}.el-color-dropdown{width:300px}.el-color-dropdown__main-wrapper{margin-bottom:6px}.el-color-dropdown__main-wrapper:after{content:"";display:table;clear:both}.el-color-dropdown__btns{margin-top:12px;text-align:right}.el-color-dropdown__value{float:left;line-height:26px;font-size:12px;color:#000;width:160px}.el-color-picker{display:inline-block;position:relative;line-height:normal;outline:0}.el-color-picker:hover:not(.is-disabled) .el-color-picker__trigger{border:1px solid var(--el-border-color-hover)}.el-color-picker:focus-visible:not(.is-disabled) .el-color-picker__trigger{outline:2px solid var(--el-color-primary);outline-offset:1px}.el-color-picker.is-disabled .el-color-picker__trigger{cursor:not-allowed}.el-color-picker--large{height:40px}.el-color-picker--large .el-color-picker__trigger{height:40px;width:40px}.el-color-picker--large .el-color-picker__mask{height:38px;width:38px}.el-color-picker--small{height:24px}.el-color-picker--small .el-color-picker__trigger{height:24px;width:24px}.el-color-picker--small .el-color-picker__mask{height:22px;width:22px}.el-color-picker--small .el-color-picker__empty,.el-color-picker--small .el-color-picker__icon{transform:scale(.8)}.el-color-picker__mask{height:30px;width:30px;border-radius:4px;position:absolute;top:1px;left:1px;z-index:1;cursor:not-allowed;background-color:#ffffffb3}.el-color-picker__trigger{display:inline-flex;justify-content:center;align-items:center;box-sizing:border-box;height:32px;width:32px;padding:4px;border:1px solid var(--el-border-color);border-radius:4px;font-size:0;position:relative;cursor:pointer}.el-color-picker__color{position:relative;display:block;box-sizing:border-box;border:1px solid var(--el-text-color-secondary);border-radius:var(--el-border-radius-small);width:100%;height:100%;text-align:center}.el-color-picker__color.is-alpha{background-image:linear-gradient(45deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(45deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%);background-size:12px 12px;background-position:0 0,6px 0,6px -6px,0 6px}.el-color-picker__color-inner{display:inline-flex;justify-content:center;align-items:center;width:100%;height:100%}.el-color-picker .el-color-picker__empty{font-size:12px;color:var(--el-text-color-secondary)}.el-color-picker .el-color-picker__icon{display:inline-flex;justify-content:center;align-items:center;color:#fff;font-size:12px}.el-color-picker__panel{position:absolute;z-index:10;padding:6px;box-sizing:content-box;background-color:#fff;border-radius:var(--el-border-radius-base);box-shadow:var(--el-box-shadow-light)}.el-color-picker__panel.el-popper{border:1px solid var(--el-border-color-lighter)}.el-color-picker,.el-color-picker__panel{--el-color-picker-alpha-bg-a:#ccc;--el-color-picker-alpha-bg-b:transparent}.dark .el-color-picker,.dark .el-color-picker__panel{--el-color-picker-alpha-bg-a:#333333}.el-container{display:flex;flex-direction:row;flex:1;flex-basis:auto;box-sizing:border-box;min-width:0}.el-container.is-vertical{flex-direction:column}.el-date-table{font-size:12px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-date-table.is-week-mode .el-date-table__row:hover .el-date-table-cell{background-color:var(--el-datepicker-inrange-bg-color)}.el-date-table.is-week-mode .el-date-table__row:hover td.available:hover{color:var(--el-datepicker-text-color)}.el-date-table.is-week-mode .el-date-table__row:hover td:first-child .el-date-table-cell{margin-left:5px;border-top-left-radius:15px;border-bottom-left-radius:15px}.el-date-table.is-week-mode .el-date-table__row:hover td:last-child .el-date-table-cell{margin-right:5px;border-top-right-radius:15px;border-bottom-right-radius:15px}.el-date-table.is-week-mode .el-date-table__row.current .el-date-table-cell{background-color:var(--el-datepicker-inrange-bg-color)}.el-date-table td{width:32px;height:30px;padding:4px 0;box-sizing:border-box;text-align:center;cursor:pointer;position:relative}.el-date-table td .el-date-table-cell{height:30px;padding:3px 0;box-sizing:border-box}.el-date-table td .el-date-table-cell .el-date-table-cell__text{width:24px;height:24px;display:block;margin:0 auto;line-height:24px;position:absolute;left:50%;transform:translate(-50%);border-radius:50%}.el-date-table td.next-month,.el-date-table td.prev-month{color:var(--el-datepicker-off-text-color)}.el-date-table td.today{position:relative}.el-date-table td.today .el-date-table-cell__text{color:var(--el-color-primary);font-weight:700}.el-date-table td.today.end-date .el-date-table-cell__text,.el-date-table td.today.start-date .el-date-table-cell__text{color:#fff}.el-date-table td.available:hover{color:var(--el-datepicker-hover-text-color)}.el-date-table td.in-range .el-date-table-cell{background-color:var(--el-datepicker-inrange-bg-color)}.el-date-table td.in-range .el-date-table-cell:hover{background-color:var(--el-datepicker-inrange-hover-bg-color)}.el-date-table td.current:not(.disabled) .el-date-table-cell__text{color:#fff;background-color:var(--el-datepicker-active-color)}.el-date-table td.current:not(.disabled):focus-visible .el-date-table-cell__text{outline:2px solid var(--el-datepicker-active-color);outline-offset:1px}.el-date-table td.end-date .el-date-table-cell,.el-date-table td.start-date .el-date-table-cell{color:#fff}.el-date-table td.end-date .el-date-table-cell__text,.el-date-table td.start-date .el-date-table-cell__text{background-color:var(--el-datepicker-active-color)}.el-date-table td.start-date .el-date-table-cell{margin-left:5px;border-top-left-radius:15px;border-bottom-left-radius:15px}.el-date-table td.end-date .el-date-table-cell{margin-right:5px;border-top-right-radius:15px;border-bottom-right-radius:15px}.el-date-table td.disabled .el-date-table-cell{background-color:var(--el-fill-color-light);opacity:1;cursor:not-allowed;color:var(--el-text-color-placeholder)}.el-date-table td.selected .el-date-table-cell{margin-left:5px;margin-right:5px;background-color:var(--el-datepicker-inrange-bg-color);border-radius:15px}.el-date-table td.selected .el-date-table-cell:hover{background-color:var(--el-datepicker-inrange-hover-bg-color)}.el-date-table td.selected .el-date-table-cell__text{background-color:var(--el-datepicker-active-color);color:#fff;border-radius:15px}.el-date-table td.week{font-size:80%;color:var(--el-datepicker-header-text-color)}.el-date-table td:focus{outline:0}.el-date-table th{padding:5px;color:var(--el-datepicker-header-text-color);font-weight:400;border-bottom:solid 1px var(--el-border-color-lighter)}.el-month-table{font-size:12px;margin:-1px;border-collapse:collapse}.el-month-table td{text-align:center;padding:8px 0;cursor:pointer}.el-month-table td div{height:48px;padding:6px 0;box-sizing:border-box}.el-month-table td.today .cell{color:var(--el-color-primary);font-weight:700}.el-month-table td.today.end-date .cell,.el-month-table td.today.start-date .cell{color:#fff}.el-month-table td.disabled .cell{background-color:var(--el-fill-color-light);cursor:not-allowed;color:var(--el-text-color-placeholder)}.el-month-table td.disabled .cell:hover{color:var(--el-text-color-placeholder)}.el-month-table td .cell{width:60px;height:36px;display:block;line-height:36px;color:var(--el-datepicker-text-color);margin:0 auto;border-radius:18px}.el-month-table td .cell:hover{color:var(--el-datepicker-hover-text-color)}.el-month-table td.in-range div{background-color:var(--el-datepicker-inrange-bg-color)}.el-month-table td.in-range div:hover{background-color:var(--el-datepicker-inrange-hover-bg-color)}.el-month-table td.end-date div,.el-month-table td.start-date div{color:#fff}.el-month-table td.end-date .cell,.el-month-table td.start-date .cell{color:#fff;background-color:var(--el-datepicker-active-color)}.el-month-table td.start-date div{border-top-left-radius:24px;border-bottom-left-radius:24px}.el-month-table td.end-date div{border-top-right-radius:24px;border-bottom-right-radius:24px}.el-month-table td.current:not(.disabled) .cell{color:var(--el-datepicker-active-color)}.el-month-table td:focus-visible{outline:0}.el-month-table td:focus-visible .cell{outline:2px solid var(--el-datepicker-active-color)}.el-year-table{font-size:12px;margin:-1px;border-collapse:collapse}.el-year-table .el-icon{color:var(--el-datepicker-icon-color)}.el-year-table td{text-align:center;padding:20px 3px;cursor:pointer}.el-year-table td.today .cell{color:var(--el-color-primary);font-weight:700}.el-year-table td.disabled .cell{background-color:var(--el-fill-color-light);cursor:not-allowed;color:var(--el-text-color-placeholder)}.el-year-table td.disabled .cell:hover{color:var(--el-text-color-placeholder)}.el-year-table td .cell{width:48px;height:36px;display:block;line-height:36px;color:var(--el-datepicker-text-color);border-radius:18px;margin:0 auto}.el-year-table td .cell:hover{color:var(--el-datepicker-hover-text-color)}.el-year-table td.current:not(.disabled) .cell{color:var(--el-datepicker-active-color)}.el-year-table td:focus-visible{outline:0}.el-year-table td:focus-visible .cell{outline:2px solid var(--el-datepicker-active-color)}.el-time-spinner.has-seconds .el-time-spinner__wrapper{width:33.3%}.el-time-spinner__wrapper{max-height:192px;overflow:auto;display:inline-block;width:50%;vertical-align:top;position:relative}.el-time-spinner__wrapper.el-scrollbar__wrap:not(.el-scrollbar__wrap--hidden-default){padding-bottom:15px}.el-time-spinner__wrapper.is-arrow{box-sizing:border-box;text-align:center;overflow:hidden}.el-time-spinner__wrapper.is-arrow .el-time-spinner__list{transform:translateY(-32px)}.el-time-spinner__wrapper.is-arrow .el-time-spinner__item:hover:not(.is-disabled):not(.is-active){background:var(--el-fill-color-light);cursor:default}.el-time-spinner__arrow{font-size:12px;color:var(--el-text-color-secondary);position:absolute;left:0;width:100%;z-index:var(--el-index-normal);text-align:center;height:30px;line-height:30px;cursor:pointer}.el-time-spinner__arrow:hover{color:var(--el-color-primary)}.el-time-spinner__arrow.arrow-up{top:10px}.el-time-spinner__arrow.arrow-down{bottom:10px}.el-time-spinner__input.el-input{width:70%}.el-time-spinner__input.el-input .el-input__inner{padding:0;text-align:center}.el-time-spinner__list{padding:0;margin:0;list-style:none;text-align:center}.el-time-spinner__list:after,.el-time-spinner__list:before{content:"";display:block;width:100%;height:80px}.el-time-spinner__item{height:32px;line-height:32px;font-size:12px;color:var(--el-text-color-regular)}.el-time-spinner__item:hover:not(.is-disabled):not(.is-active){background:var(--el-fill-color-light);cursor:pointer}.el-time-spinner__item.is-active:not(.is-disabled){color:var(--el-text-color-primary);font-weight:700}.el-time-spinner__item.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-picker__popper{--el-datepicker-border-color:var(--el-disabled-border-color)}.el-picker__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-datepicker-border-color);box-shadow:var(--el-box-shadow-light)}.el-picker__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-datepicker-border-color)}.el-picker__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-picker__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-picker__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-picker__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-date-editor{--el-date-editor-width:220px;--el-date-editor-monthrange-width:300px;--el-date-editor-daterange-width:350px;--el-date-editor-datetimerange-width:400px;--el-input-text-color:var(--el-text-color-regular);--el-input-border:var(--el-border);--el-input-hover-border:var(--el-border-color-hover);--el-input-focus-border:var(--el-color-primary);--el-input-transparent-border:0 0 0 1px transparent inset;--el-input-border-color:var(--el-border-color);--el-input-border-radius:var(--el-border-radius-base);--el-input-bg-color:var(--el-fill-color-blank);--el-input-icon-color:var(--el-text-color-placeholder);--el-input-placeholder-color:var(--el-text-color-placeholder);--el-input-hover-border-color:var(--el-border-color-hover);--el-input-clear-hover-color:var(--el-text-color-secondary);--el-input-focus-border-color:var(--el-color-primary);position:relative;display:inline-block;text-align:left}.el-date-editor.el-input__wrapper{box-shadow:0 0 0 1px var(--el-input-border-color,var(--el-border-color)) inset}.el-date-editor.el-input__wrapper:hover{box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-date-editor.el-input,.el-date-editor.el-input__wrapper{width:var(--el-date-editor-width);height:var(--el-input-height,var(--el-component-size))}.el-date-editor--monthrange{--el-date-editor-width:var(--el-date-editor-monthrange-width)}.el-date-editor--daterange,.el-date-editor--timerange{--el-date-editor-width:var(--el-date-editor-daterange-width)}.el-date-editor--datetimerange{--el-date-editor-width:var(--el-date-editor-datetimerange-width)}.el-date-editor--dates .el-input__wrapper{text-overflow:ellipsis;white-space:nowrap}.el-date-editor .close-icon,.el-date-editor .clear-icon{cursor:pointer}.el-date-editor .clear-icon:hover{color:var(--el-text-color-secondary)}.el-date-editor .el-range__icon{height:inherit;font-size:14px;color:var(--el-text-color-placeholder);float:left}.el-date-editor .el-range__icon svg{vertical-align:middle}.el-date-editor .el-range-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;outline:0;display:inline-block;height:30px;line-height:30px;margin:0;padding:0;width:39%;text-align:center;font-size:var(--el-font-size-base);color:var(--el-text-color-regular);background-color:transparent}.el-date-editor .el-range-input::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-date-editor .el-range-input:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-date-editor .el-range-input::placeholder{color:var(--el-text-color-placeholder)}.el-date-editor .el-range-separator{flex:1;display:inline-flex;justify-content:center;align-items:center;height:100%;padding:0 5px;margin:0;font-size:14px;word-break:keep-all;color:var(--el-text-color-primary)}.el-date-editor .el-range__close-icon{font-size:14px;color:var(--el-text-color-placeholder);height:inherit;width:unset;cursor:pointer}.el-date-editor .el-range__close-icon:hover{color:var(--el-text-color-secondary)}.el-date-editor .el-range__close-icon svg{vertical-align:middle}.el-date-editor .el-range__close-icon--hidden{opacity:0;visibility:hidden}.el-range-editor.el-input__wrapper{display:inline-flex;align-items:center;padding:0 10px}.el-range-editor.is-active,.el-range-editor.is-active:hover{box-shadow:0 0 0 1px var(--el-input-focus-border-color) inset}.el-range-editor--large{line-height:var(--el-component-size-large)}.el-range-editor--large.el-input__wrapper{height:var(--el-component-size-large)}.el-range-editor--large .el-range-separator{line-height:40px;font-size:14px}.el-range-editor--large .el-range-input{height:38px;line-height:38px;font-size:14px}.el-range-editor--small{line-height:var(--el-component-size-small)}.el-range-editor--small.el-input__wrapper{height:var(--el-component-size-small)}.el-range-editor--small .el-range-separator{line-height:24px;font-size:12px}.el-range-editor--small .el-range-input{height:22px;line-height:22px;font-size:12px}.el-range-editor.is-disabled{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color);color:var(--el-disabled-text-color);cursor:not-allowed}.el-range-editor.is-disabled:focus,.el-range-editor.is-disabled:hover{border-color:var(--el-disabled-border-color)}.el-range-editor.is-disabled input{background-color:var(--el-disabled-bg-color);color:var(--el-disabled-text-color);cursor:not-allowed}.el-range-editor.is-disabled input::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-range-editor.is-disabled input:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-range-editor.is-disabled input::placeholder{color:var(--el-text-color-placeholder)}.el-range-editor.is-disabled .el-range-separator{color:var(--el-disabled-text-color)}.el-picker-panel{color:var(--el-text-color-regular);background:var(--el-bg-color-overlay);border-radius:var(--el-border-radius-base);line-height:30px}.el-picker-panel .el-time-panel{margin:5px 0;border:solid 1px var(--el-datepicker-border-color);background-color:var(--el-bg-color-overlay);box-shadow:var(--el-box-shadow-light)}.el-picker-panel__body-wrapper:after,.el-picker-panel__body:after{content:"";display:table;clear:both}.el-picker-panel__content{position:relative;margin:15px}.el-picker-panel__footer{border-top:1px solid var(--el-datepicker-inner-border-color);padding:4px 12px;text-align:right;background-color:var(--el-bg-color-overlay);position:relative;font-size:0}.el-picker-panel__shortcut{display:block;width:100%;border:0;background-color:transparent;line-height:28px;font-size:14px;color:var(--el-datepicker-text-color);padding-left:12px;text-align:left;outline:0;cursor:pointer}.el-picker-panel__shortcut:hover{color:var(--el-datepicker-hover-text-color)}.el-picker-panel__shortcut.active{background-color:#e6f1fe;color:var(--el-datepicker-active-color)}.el-picker-panel__btn{border:1px solid var(--el-fill-color-darker);color:var(--el-text-color-primary);line-height:24px;border-radius:2px;padding:0 20px;cursor:pointer;background-color:transparent;outline:0;font-size:12px}.el-picker-panel__btn[disabled]{color:var(--el-text-color-disabled);cursor:not-allowed}.el-picker-panel__icon-btn{font-size:12px;color:var(--el-datepicker-icon-color);border:0;background:0 0;cursor:pointer;outline:0;margin-top:8px}.el-picker-panel__icon-btn:hover{color:var(--el-datepicker-hover-text-color)}.el-picker-panel__icon-btn:focus-visible{color:var(--el-datepicker-hover-text-color)}.el-picker-panel__icon-btn.is-disabled{color:var(--el-text-color-disabled)}.el-picker-panel__icon-btn.is-disabled:hover{cursor:not-allowed}.el-picker-panel__icon-btn .el-icon{cursor:pointer;font-size:inherit}.el-picker-panel__link-btn{vertical-align:middle}.el-picker-panel [slot=sidebar],.el-picker-panel__sidebar{position:absolute;top:0;bottom:0;width:110px;border-right:1px solid var(--el-datepicker-inner-border-color);box-sizing:border-box;padding-top:6px;background-color:var(--el-bg-color-overlay);overflow:auto}.el-picker-panel [slot=sidebar]+.el-picker-panel__body,.el-picker-panel__sidebar+.el-picker-panel__body{margin-left:110px}.el-date-picker{--el-datepicker-text-color:var(--el-text-color-regular);--el-datepicker-off-text-color:var(--el-text-color-placeholder);--el-datepicker-header-text-color:var(--el-text-color-regular);--el-datepicker-icon-color:var(--el-text-color-primary);--el-datepicker-border-color:var(--el-disabled-border-color);--el-datepicker-inner-border-color:var(--el-border-color-light);--el-datepicker-inrange-bg-color:var(--el-border-color-extra-light);--el-datepicker-inrange-hover-bg-color:var(--el-border-color-extra-light);--el-datepicker-active-color:var(--el-color-primary);--el-datepicker-hover-text-color:var(--el-color-primary)}.el-date-picker{width:322px}.el-date-picker.has-sidebar.has-time{width:434px}.el-date-picker.has-sidebar{width:438px}.el-date-picker.has-time .el-picker-panel__body-wrapper{position:relative}.el-date-picker .el-picker-panel__content{width:292px}.el-date-picker table{table-layout:fixed;width:100%}.el-date-picker__editor-wrap{position:relative;display:table-cell;padding:0 5px}.el-date-picker__time-header{position:relative;border-bottom:1px solid var(--el-datepicker-inner-border-color);font-size:12px;padding:8px 5px 5px;display:table;width:100%;box-sizing:border-box}.el-date-picker__header{margin:12px;text-align:center}.el-date-picker__header--bordered{margin-bottom:0;padding-bottom:12px;border-bottom:solid 1px var(--el-border-color-lighter)}.el-date-picker__header--bordered+.el-picker-panel__content{margin-top:0}.el-date-picker__header-label{font-size:16px;font-weight:500;padding:0 5px;line-height:22px;text-align:center;cursor:pointer;color:var(--el-text-color-regular)}.el-date-picker__header-label:hover{color:var(--el-datepicker-hover-text-color)}.el-date-picker__header-label:focus-visible{outline:0;color:var(--el-datepicker-hover-text-color)}.el-date-picker__header-label.active{color:var(--el-datepicker-active-color)}.el-date-picker__prev-btn{float:left}.el-date-picker__next-btn{float:right}.el-date-picker__time-wrap{padding:10px;text-align:center}.el-date-picker__time-label{float:left;cursor:pointer;line-height:30px;margin-left:10px}.el-date-picker .el-time-panel{position:absolute}.el-date-range-picker{--el-datepicker-text-color:var(--el-text-color-regular);--el-datepicker-off-text-color:var(--el-text-color-placeholder);--el-datepicker-header-text-color:var(--el-text-color-regular);--el-datepicker-icon-color:var(--el-text-color-primary);--el-datepicker-border-color:var(--el-disabled-border-color);--el-datepicker-inner-border-color:var(--el-border-color-light);--el-datepicker-inrange-bg-color:var(--el-border-color-extra-light);--el-datepicker-inrange-hover-bg-color:var(--el-border-color-extra-light);--el-datepicker-active-color:var(--el-color-primary);--el-datepicker-hover-text-color:var(--el-color-primary)}.el-date-range-picker{width:646px}.el-date-range-picker.has-sidebar{width:756px}.el-date-range-picker.has-time .el-picker-panel__body-wrapper{position:relative}.el-date-range-picker table{table-layout:fixed;width:100%}.el-date-range-picker .el-picker-panel__body{min-width:513px}.el-date-range-picker .el-picker-panel__content{margin:0}.el-date-range-picker__header{position:relative;text-align:center;height:28px}.el-date-range-picker__header [class*=arrow-left]{float:left}.el-date-range-picker__header [class*=arrow-right]{float:right}.el-date-range-picker__header div{font-size:16px;font-weight:500;margin-right:50px}.el-date-range-picker__content{float:left;width:50%;box-sizing:border-box;margin:0;padding:16px}.el-date-range-picker__content.is-left{border-right:1px solid var(--el-datepicker-inner-border-color)}.el-date-range-picker__content .el-date-range-picker__header div{margin-left:50px;margin-right:50px}.el-date-range-picker__editors-wrap{box-sizing:border-box;display:table-cell}.el-date-range-picker__editors-wrap.is-right{text-align:right}.el-date-range-picker__time-header{position:relative;border-bottom:1px solid var(--el-datepicker-inner-border-color);font-size:12px;padding:8px 5px 5px;display:table;width:100%;box-sizing:border-box}.el-date-range-picker__time-header>.el-icon-arrow-right{font-size:20px;vertical-align:middle;display:table-cell;color:var(--el-datepicker-icon-color)}.el-date-range-picker__time-picker-wrap{position:relative;display:table-cell;padding:0 5px}.el-date-range-picker__time-picker-wrap .el-picker-panel{position:absolute;top:13px;right:0;z-index:1;background:#fff}.el-date-range-picker__time-picker-wrap .el-time-panel{position:absolute}.el-time-range-picker{width:354px;overflow:visible}.el-time-range-picker__content{position:relative;text-align:center;padding:10px;z-index:1}.el-time-range-picker__cell{box-sizing:border-box;margin:0;padding:4px 7px 7px;width:50%;display:inline-block}.el-time-range-picker__header{margin-bottom:5px;text-align:center;font-size:14px}.el-time-range-picker__body{border-radius:2px;border:1px solid var(--el-datepicker-border-color)}.el-time-panel{border-radius:2px;position:relative;width:180px;left:0;z-index:var(--el-index-top);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;box-sizing:content-box}.el-time-panel__content{font-size:0;position:relative;overflow:hidden}.el-time-panel__content:after,.el-time-panel__content:before{content:"";top:50%;position:absolute;margin-top:-16px;height:32px;z-index:-1;left:0;right:0;box-sizing:border-box;padding-top:6px;text-align:left}.el-time-panel__content:after{left:50%;margin-left:12%;margin-right:12%}.el-time-panel__content:before{padding-left:50%;margin-right:12%;margin-left:12%;border-top:1px solid var(--el-border-color-light);border-bottom:1px solid var(--el-border-color-light)}.el-time-panel__content.has-seconds:after{left:66.6666666667%}.el-time-panel__content.has-seconds:before{padding-left:33.3333333333%}.el-time-panel__footer{border-top:1px solid var(--el-timepicker-inner-border-color,var(--el-border-color-light));padding:4px;height:36px;line-height:25px;text-align:right;box-sizing:border-box}.el-time-panel__btn{border:none;line-height:28px;padding:0 5px;margin:0 5px;cursor:pointer;background-color:transparent;outline:0;font-size:12px;color:var(--el-text-color-primary)}.el-time-panel__btn.confirm{font-weight:800;color:var(--el-timepicker-active-color,var(--el-color-primary))}.el-descriptions{--el-descriptions-table-border:1px solid var(--el-border-color-lighter);--el-descriptions-item-bordered-label-background:var(--el-fill-color-light);box-sizing:border-box;font-size:var(--el-font-size-base);color:var(--el-text-color-primary)}.el-descriptions__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.el-descriptions__title{color:var(--el-text-color-primary);font-size:16px;font-weight:700}.el-descriptions__body{background-color:var(--el-fill-color-blank)}.el-descriptions__body .el-descriptions__table{border-collapse:collapse;width:100%}.el-descriptions__body .el-descriptions__table .el-descriptions__cell{box-sizing:border-box;text-align:left;font-weight:400;line-height:23px;font-size:14px}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-left{text-align:left}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-center{text-align:center}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-right{text-align:right}.el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{border:var(--el-descriptions-table-border);padding:8px 11px}.el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:12px}.el-descriptions--large{font-size:14px}.el-descriptions--large .el-descriptions__header{margin-bottom:20px}.el-descriptions--large .el-descriptions__header .el-descriptions__title{font-size:16px}.el-descriptions--large .el-descriptions__body .el-descriptions__table .el-descriptions__cell{font-size:14px}.el-descriptions--large .el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{padding:12px 15px}.el-descriptions--large .el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:16px}.el-descriptions--small{font-size:12px}.el-descriptions--small .el-descriptions__header{margin-bottom:12px}.el-descriptions--small .el-descriptions__header .el-descriptions__title{font-size:14px}.el-descriptions--small .el-descriptions__body .el-descriptions__table .el-descriptions__cell{font-size:12px}.el-descriptions--small .el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{padding:4px 7px}.el-descriptions--small .el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:8px}.el-descriptions__label.el-descriptions__cell.is-bordered-label{font-weight:700;color:var(--el-text-color-regular);background:var(--el-descriptions-item-bordered-label-background)}.el-descriptions__label:not(.is-bordered-label){color:var(--el-text-color-primary);margin-right:16px}.el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:6px}.el-descriptions__content.el-descriptions__cell.is-bordered-content{color:var(--el-text-color-primary)}.el-descriptions__content:not(.is-bordered-label){color:var(--el-text-color-regular)}.el-descriptions--large .el-descriptions__label:not(.is-bordered-label){margin-right:16px}.el-descriptions--large .el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:8px}.el-descriptions--small .el-descriptions__label:not(.is-bordered-label){margin-right:12px}.el-descriptions--small .el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:4px}:root{--el-popup-modal-bg-color:var(--el-color-black);--el-popup-modal-opacity:.5}.v-modal-enter{-webkit-animation:v-modal-in var(--el-transition-duration-fast) ease;animation:v-modal-in var(--el-transition-duration-fast) ease}.v-modal-leave{-webkit-animation:v-modal-out var(--el-transition-duration-fast) ease forwards;animation:v-modal-out var(--el-transition-duration-fast) ease forwards}@-webkit-keyframes v-modal-in{0%{opacity:0}}@keyframes v-modal-in{0%{opacity:0}}@-webkit-keyframes v-modal-out{to{opacity:0}}@keyframes v-modal-out{to{opacity:0}}.v-modal{position:fixed;left:0;top:0;width:100%;height:100%;opacity:var(--el-popup-modal-opacity);background:var(--el-popup-modal-bg-color)}.el-popup-parent--hidden{overflow:hidden}.el-dialog{--el-dialog-width:50%;--el-dialog-margin-top:15vh;--el-dialog-bg-color:var(--el-bg-color);--el-dialog-box-shadow:var(--el-box-shadow);--el-dialog-title-font-size:var(--el-font-size-large);--el-dialog-content-font-size:14px;--el-dialog-font-line-height:var(--el-font-line-height-primary);--el-dialog-padding-primary:20px;--el-dialog-border-radius:var(--el-border-radius-small);position:relative;margin:var(--el-dialog-margin-top,15vh) auto 50px;background:var(--el-dialog-bg-color);border-radius:var(--el-dialog-border-radius);box-shadow:var(--el-dialog-box-shadow);box-sizing:border-box;width:var(--el-dialog-width,50%)}.el-dialog:focus{outline:0!important}.el-dialog.is-align-center{margin:auto}.el-dialog.is-fullscreen{--el-dialog-width:100%;--el-dialog-margin-top:0;margin-bottom:0;height:100%;overflow:auto}.el-dialog__wrapper{position:fixed;top:0;right:0;bottom:0;left:0;overflow:auto;margin:0}.el-dialog.is-draggable .el-dialog__header{cursor:move;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-dialog__header{padding:var(--el-dialog-padding-primary);padding-bottom:10px;margin-right:16px}.el-dialog__headerbtn{position:absolute;top:6px;right:0;padding:0;width:54px;height:54px;background:0 0;border:none;outline:0;cursor:pointer;font-size:var(--el-message-close-size,16px)}.el-dialog__headerbtn .el-dialog__close{color:var(--el-color-info);font-size:inherit}.el-dialog__headerbtn:focus .el-dialog__close,.el-dialog__headerbtn:hover .el-dialog__close{color:var(--el-color-primary)}.el-dialog__title{line-height:var(--el-dialog-font-line-height);font-size:var(--el-dialog-title-font-size);color:var(--el-text-color-primary)}.el-dialog__body{padding:calc(var(--el-dialog-padding-primary) + 10px) var(--el-dialog-padding-primary);color:var(--el-text-color-regular);font-size:var(--el-dialog-content-font-size)}.el-dialog__footer{padding:var(--el-dialog-padding-primary);padding-top:10px;text-align:right;box-sizing:border-box}.el-dialog--center{text-align:center}.el-dialog--center .el-dialog__body{text-align:initial;padding:25px calc(var(--el-dialog-padding-primary) + 5px) 30px}.el-dialog--center .el-dialog__footer{text-align:inherit}.el-overlay-dialog{position:fixed;top:0;right:0;bottom:0;left:0;overflow:auto}.dialog-fade-enter-active{-webkit-animation:modal-fade-in var(--el-transition-duration);animation:modal-fade-in var(--el-transition-duration)}.dialog-fade-enter-active .el-overlay-dialog{-webkit-animation:dialog-fade-in var(--el-transition-duration);animation:dialog-fade-in var(--el-transition-duration)}.dialog-fade-leave-active{-webkit-animation:modal-fade-out var(--el-transition-duration);animation:modal-fade-out var(--el-transition-duration)}.dialog-fade-leave-active .el-overlay-dialog{-webkit-animation:dialog-fade-out var(--el-transition-duration);animation:dialog-fade-out var(--el-transition-duration)}@-webkit-keyframes dialog-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@keyframes dialog-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@-webkit-keyframes dialog-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@keyframes dialog-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@-webkit-keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@-webkit-keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}@keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}.el-divider{position:relative}.el-divider--horizontal{display:block;height:1px;width:100%;margin:24px 0;border-top:1px var(--el-border-color) var(--el-border-style)}.el-divider--vertical{display:inline-block;width:1px;height:1em;margin:0 8px;vertical-align:middle;position:relative;border-left:1px var(--el-border-color) var(--el-border-style)}.el-divider__text{position:absolute;background-color:var(--el-bg-color);padding:0 20px;font-weight:500;color:var(--el-text-color-primary);font-size:14px}.el-divider__text.is-left{left:20px;transform:translateY(-50%)}.el-divider__text.is-center{left:50%;transform:translate(-50%) translateY(-50%)}.el-divider__text.is-right{right:20px;transform:translateY(-50%)}.el-drawer{--el-drawer-bg-color:var(--el-dialog-bg-color, var(--el-bg-color));--el-drawer-padding-primary:var(--el-dialog-padding-primary, 20px)}.el-drawer{position:absolute;box-sizing:border-box;background-color:var(--el-drawer-bg-color);display:flex;flex-direction:column;box-shadow:var(--el-box-shadow-dark);overflow:hidden;transition:all var(--el-transition-duration)}.el-drawer .rtl,.el-drawer .ltr,.el-drawer .ttb,.el-drawer .btt{transform:translate(0)}.el-drawer__sr-focus:focus{outline:0!important}.el-drawer__header{align-items:center;color:#72767b;display:flex;margin-bottom:32px;padding:var(--el-drawer-padding-primary);padding-bottom:0}.el-drawer__header>:first-child{flex:1}.el-drawer__title{margin:0;flex:1;line-height:inherit;font-size:1rem}.el-drawer__footer{padding:var(--el-drawer-padding-primary);padding-top:10px;text-align:right}.el-drawer__close-btn{display:inline-flex;border:none;cursor:pointer;font-size:var(--el-font-size-extra-large);color:inherit;background-color:transparent;outline:0}.el-drawer__close-btn:focus i,.el-drawer__close-btn:hover i{color:var(--el-color-primary)}.el-drawer__body{flex:1;padding:var(--el-drawer-padding-primary);overflow:auto}.el-drawer__body>*{box-sizing:border-box}.el-drawer.ltr,.el-drawer.rtl{height:100%;top:0;bottom:0}.el-drawer.btt,.el-drawer.ttb{width:100%;left:0;right:0}.el-drawer.ltr{left:0}.el-drawer.rtl{right:0}.el-drawer.ttb{top:0}.el-drawer.btt{bottom:0}.el-drawer-fade-enter-active,.el-drawer-fade-leave-active{transition:all var(--el-transition-duration)}.el-drawer-fade-enter-active,.el-drawer-fade-enter-from,.el-drawer-fade-enter-to,.el-drawer-fade-leave-active,.el-drawer-fade-leave-from,.el-drawer-fade-leave-to{overflow:hidden!important}.el-drawer-fade-enter-from,.el-drawer-fade-leave-to{opacity:0}.el-drawer-fade-enter-to,.el-drawer-fade-leave-from{opacity:1}.el-drawer-fade-enter-from .rtl,.el-drawer-fade-leave-to .rtl{transform:translate(100%)}.el-drawer-fade-enter-from .ltr,.el-drawer-fade-leave-to .ltr{transform:translate(-100%)}.el-drawer-fade-enter-from .ttb,.el-drawer-fade-leave-to .ttb{transform:translateY(-100%)}.el-drawer-fade-enter-from .btt,.el-drawer-fade-leave-to .btt{transform:translateY(100%)}.el-dropdown{--el-dropdown-menu-box-shadow:var(--el-box-shadow-light);--el-dropdown-menuItem-hover-fill:var(--el-color-primary-light-9);--el-dropdown-menuItem-hover-color:var(--el-color-primary);--el-dropdown-menu-index:10;display:inline-flex;position:relative;color:var(--el-text-color-regular);font-size:var(--el-font-size-base);line-height:1;vertical-align:top}.el-dropdown.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-dropdown__popper{--el-dropdown-menu-box-shadow:var(--el-box-shadow-light);--el-dropdown-menuItem-hover-fill:var(--el-color-primary-light-9);--el-dropdown-menuItem-hover-color:var(--el-color-primary);--el-dropdown-menu-index:10}.el-dropdown__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-dropdown-menu-box-shadow)}.el-dropdown__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-dropdown__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-dropdown__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-dropdown__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-dropdown__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-dropdown__popper .el-dropdown-menu{border:none}.el-dropdown__popper .el-dropdown__popper-selfdefine{outline:0}.el-dropdown__popper .el-scrollbar__bar{z-index:calc(var(--el-dropdown-menu-index) + 1)}.el-dropdown__popper .el-dropdown__list{list-style:none;padding:0;margin:0;box-sizing:border-box}.el-dropdown .el-dropdown__caret-button{padding-left:0;padding-right:0;display:inline-flex;justify-content:center;align-items:center;width:32px;border-left:none}.el-dropdown .el-dropdown__caret-button>span{display:inline-flex}.el-dropdown .el-dropdown__caret-button:before{content:"";position:absolute;display:block;width:1px;top:-1px;bottom:-1px;left:0;background:var(--el-overlay-color-lighter)}.el-dropdown .el-dropdown__caret-button.el-button:before{background:var(--el-border-color);opacity:.5}.el-dropdown .el-dropdown__caret-button .el-dropdown__icon{font-size:inherit;padding-left:0}.el-dropdown .el-dropdown-selfdefine{outline:0}.el-dropdown--large .el-dropdown__caret-button{width:40px}.el-dropdown--small .el-dropdown__caret-button{width:24px}.el-dropdown-menu{position:relative;top:0;left:0;z-index:var(--el-dropdown-menu-index);padding:5px 0;margin:0;background-color:var(--el-bg-color-overlay);border:none;border-radius:var(--el-border-radius-base);box-shadow:none;list-style:none}.el-dropdown-menu__item{display:flex;align-items:center;white-space:nowrap;list-style:none;line-height:22px;padding:5px 16px;margin:0;font-size:var(--el-font-size-base);color:var(--el-text-color-regular);cursor:pointer;outline:0}.el-dropdown-menu__item:not(.is-disabled):focus{background-color:var(--el-dropdown-menuItem-hover-fill);color:var(--el-dropdown-menuItem-hover-color)}.el-dropdown-menu__item i{margin-right:5px}.el-dropdown-menu__item--divided{margin:6px 0;border-top:1px solid var(--el-border-color-lighter)}.el-dropdown-menu__item.is-disabled{cursor:not-allowed;color:var(--el-text-color-disabled)}.el-dropdown-menu--large{padding:7px 0}.el-dropdown-menu--large .el-dropdown-menu__item{padding:7px 20px;line-height:22px;font-size:14px}.el-dropdown-menu--large .el-dropdown-menu__item--divided{margin:8px 0}.el-dropdown-menu--small{padding:3px 0}.el-dropdown-menu--small .el-dropdown-menu__item{padding:2px 12px;line-height:20px;font-size:12px}.el-dropdown-menu--small .el-dropdown-menu__item--divided{margin:4px 0}.el-empty{--el-empty-padding:40px 0;--el-empty-image-width:160px;--el-empty-description-margin-top:20px;--el-empty-bottom-margin-top:20px;--el-empty-fill-color-0:var(--el-color-white);--el-empty-fill-color-1:#fcfcfd;--el-empty-fill-color-2:#f8f9fb;--el-empty-fill-color-3:#f7f8fc;--el-empty-fill-color-4:#eeeff3;--el-empty-fill-color-5:#edeef2;--el-empty-fill-color-6:#e9ebef;--el-empty-fill-color-7:#e5e7e9;--el-empty-fill-color-8:#e0e3e9;--el-empty-fill-color-9:#d5d7de;display:flex;justify-content:center;align-items:center;flex-direction:column;text-align:center;box-sizing:border-box;padding:var(--el-empty-padding)}.el-empty__image{width:var(--el-empty-image-width)}.el-empty__image img{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;width:100%;height:100%;vertical-align:top;-o-object-fit:contain;object-fit:contain}.el-empty__image svg{color:var(--el-svg-monochrome-grey);fill:currentColor;width:100%;height:100%;vertical-align:top}.el-empty__description{margin-top:var(--el-empty-description-margin-top)}.el-empty__description p{margin:0;font-size:var(--el-font-size-base);color:var(--el-text-color-secondary)}.el-empty__bottom{margin-top:var(--el-empty-bottom-margin-top)}.el-footer{--el-footer-padding:0 20px;--el-footer-height:60px;padding:var(--el-footer-padding);box-sizing:border-box;flex-shrink:0;height:var(--el-footer-height)}.el-form{--el-form-label-font-size:var(--el-font-size-base)}.el-form--label-left .el-form-item__label{justify-content:flex-start}.el-form--label-top .el-form-item{display:block}.el-form--label-top .el-form-item .el-form-item__label{display:block;height:auto;text-align:left;margin-bottom:8px;line-height:22px}.el-form--inline .el-form-item{display:inline-flex;vertical-align:middle;margin-right:32px}.el-form--inline.el-form--label-top{display:flex;flex-wrap:wrap}.el-form--inline.el-form--label-top .el-form-item{display:block}.el-form--large.el-form--label-top .el-form-item .el-form-item__label{margin-bottom:12px;line-height:22px}.el-form--default.el-form--label-top .el-form-item .el-form-item__label{margin-bottom:8px;line-height:22px}.el-form--small.el-form--label-top .el-form-item .el-form-item__label{margin-bottom:4px;line-height:20px}.el-form-item{display:flex;--font-size:14px;margin-bottom:18px}.el-form-item .el-form-item{margin-bottom:0}.el-form-item .el-input__validateIcon{display:none}.el-form-item--large{--font-size:14px;--el-form-label-font-size:var(--font-size);margin-bottom:22px}.el-form-item--large .el-form-item__label{height:40px;line-height:40px}.el-form-item--large .el-form-item__content{line-height:40px}.el-form-item--large .el-form-item__error{padding-top:4px}.el-form-item--default{--font-size:14px;--el-form-label-font-size:var(--font-size);margin-bottom:18px}.el-form-item--default .el-form-item__label{height:32px;line-height:32px}.el-form-item--default .el-form-item__content{line-height:32px}.el-form-item--default .el-form-item__error{padding-top:2px}.el-form-item--small{--font-size:12px;--el-form-label-font-size:var(--font-size);margin-bottom:18px}.el-form-item--small .el-form-item__label{height:24px;line-height:24px}.el-form-item--small .el-form-item__content{line-height:24px}.el-form-item--small .el-form-item__error{padding-top:2px}.el-form-item__label-wrap{display:flex}.el-form-item__label{display:inline-flex;justify-content:flex-end;align-items:flex-start;flex:0 0 auto;font-size:var(--el-form-label-font-size);color:var(--el-text-color-regular);height:32px;line-height:32px;padding:0 12px 0 0;box-sizing:border-box}.el-form-item__content{display:flex;flex-wrap:wrap;align-items:center;flex:1;line-height:32px;position:relative;font-size:var(--font-size);min-width:0}.el-form-item__content .el-input-group{vertical-align:top}.el-form-item__error{color:var(--el-color-danger);font-size:12px;line-height:1;padding-top:2px;position:absolute;top:100%;left:0}.el-form-item__error--inline{position:relative;top:auto;left:auto;display:inline-block;margin-left:10px}.el-form-item.is-required:not(.is-no-asterisk).asterisk-left>.el-form-item__label-wrap>.el-form-item__label:before,.el-form-item.is-required:not(.is-no-asterisk).asterisk-left>.el-form-item__label:before{content:"*";color:var(--el-color-danger);margin-right:4px}.el-form-item.is-required:not(.is-no-asterisk).asterisk-right>.el-form-item__label-wrap>.el-form-item__label:after,.el-form-item.is-required:not(.is-no-asterisk).asterisk-right>.el-form-item__label:after{content:"*";color:var(--el-color-danger);margin-left:4px}.el-form-item.is-error .el-select-v2__wrapper,.el-form-item.is-error .el-select-v2__wrapper:focus,.el-form-item.is-error .el-textarea__inner,.el-form-item.is-error .el-textarea__inner:focus{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-form-item.is-error .el-input__wrapper{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-form-item.is-error .el-input-group__append .el-input__wrapper,.el-form-item.is-error .el-input-group__prepend .el-input__wrapper{box-shadow:0 0 0 1px transparent inset}.el-form-item.is-error .el-input__validateIcon{color:var(--el-color-danger)}.el-form-item--feedback .el-input__validateIcon{display:inline-flex}.el-header{--el-header-padding:0 20px;--el-header-height:60px;padding:var(--el-header-padding);box-sizing:border-box;flex-shrink:0;height:var(--el-header-height)}.el-image-viewer__wrapper{position:fixed;top:0;right:0;bottom:0;left:0}.el-image-viewer__btn{position:absolute;z-index:1;display:flex;align-items:center;justify-content:center;border-radius:50%;opacity:.8;cursor:pointer;box-sizing:border-box;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-image-viewer__btn .el-icon{font-size:inherit;cursor:pointer}.el-image-viewer__close{top:40px;right:40px;width:40px;height:40px;font-size:40px}.el-image-viewer__canvas{position:static;width:100%;height:100%;display:flex;justify-content:center;align-items:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-image-viewer__actions{left:50%;bottom:30px;transform:translate(-50%);width:282px;height:44px;padding:0 23px;background-color:var(--el-text-color-regular);border-color:#fff;border-radius:22px}.el-image-viewer__actions__inner{width:100%;height:100%;text-align:justify;cursor:default;font-size:23px;color:#fff;display:flex;align-items:center;justify-content:space-around}.el-image-viewer__prev{top:50%;transform:translateY(-50%);left:40px;width:44px;height:44px;font-size:24px;color:#fff;background-color:var(--el-text-color-regular);border-color:#fff}.el-image-viewer__next{top:50%;transform:translateY(-50%);right:40px;text-indent:2px;width:44px;height:44px;font-size:24px;color:#fff;background-color:var(--el-text-color-regular);border-color:#fff}.el-image-viewer__close{width:44px;height:44px;font-size:24px;color:#fff;background-color:var(--el-text-color-regular);border-color:#fff}.el-image-viewer__mask{position:absolute;width:100%;height:100%;top:0;left:0;opacity:.5;background:#000}.viewer-fade-enter-active{-webkit-animation:viewer-fade-in var(--el-transition-duration);animation:viewer-fade-in var(--el-transition-duration)}.viewer-fade-leave-active{-webkit-animation:viewer-fade-out var(--el-transition-duration);animation:viewer-fade-out var(--el-transition-duration)}@-webkit-keyframes viewer-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@keyframes viewer-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@-webkit-keyframes viewer-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@keyframes viewer-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}.el-image__error,.el-image__inner,.el-image__placeholder,.el-image__wrapper{width:100%;height:100%}.el-image{position:relative;display:inline-block;overflow:hidden}.el-image__inner{vertical-align:top;opacity:1}.el-image__inner.is-loading{opacity:0}.el-image__wrapper{position:absolute;top:0;left:0}.el-image__placeholder{background:var(--el-fill-color-light)}.el-image__error{display:flex;justify-content:center;align-items:center;font-size:14px;background:var(--el-fill-color-light);color:var(--el-text-color-placeholder);vertical-align:middle}.el-image__preview{cursor:pointer}.el-input-number{position:relative;display:inline-flex;width:150px;line-height:30px}.el-input-number .el-input__wrapper{padding-left:42px;padding-right:42px}.el-input-number .el-input__inner{-webkit-appearance:none;-moz-appearance:textfield;text-align:center;line-height:1}.el-input-number .el-input__inner::-webkit-inner-spin-button,.el-input-number .el-input__inner::-webkit-outer-spin-button{margin:0;-webkit-appearance:none}.el-input-number__decrease,.el-input-number__increase{display:flex;justify-content:center;align-items:center;height:auto;position:absolute;z-index:1;top:1px;bottom:1px;width:32px;background:var(--el-fill-color-light);color:var(--el-text-color-regular);cursor:pointer;font-size:13px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-input-number__decrease:hover,.el-input-number__increase:hover{color:var(--el-color-primary)}.el-input-number__decrease:hover~.el-input:not(.is-disabled) .el-input_wrapper,.el-input-number__increase:hover~.el-input:not(.is-disabled) .el-input_wrapper{box-shadow:0 0 0 1px var(--el-input-focus-border-color,var(--el-color-primary)) inset}.el-input-number__decrease.is-disabled,.el-input-number__increase.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-input-number__increase{right:1px;border-radius:0 var(--el-border-radius-base) var(--el-border-radius-base) 0;border-left:var(--el-border)}.el-input-number__decrease{left:1px;border-radius:var(--el-border-radius-base) 0 0 var(--el-border-radius-base);border-right:var(--el-border)}.el-input-number.is-disabled .el-input-number__decrease,.el-input-number.is-disabled .el-input-number__increase{border-color:var(--el-disabled-border-color);color:var(--el-disabled-border-color)}.el-input-number.is-disabled .el-input-number__decrease:hover,.el-input-number.is-disabled .el-input-number__increase:hover{color:var(--el-disabled-border-color);cursor:not-allowed}.el-input-number--large{width:180px;line-height:38px}.el-input-number--large .el-input-number__decrease,.el-input-number--large .el-input-number__increase{width:40px;font-size:14px}.el-input-number--large .el-input__wrapper{padding-left:47px;padding-right:47px}.el-input-number--small{width:120px;line-height:22px}.el-input-number--small .el-input-number__decrease,.el-input-number--small .el-input-number__increase{width:24px;font-size:12px}.el-input-number--small .el-input__wrapper{padding-left:31px;padding-right:31px}.el-input-number--small .el-input-number__decrease [class*=el-icon],.el-input-number--small .el-input-number__increase [class*=el-icon]{transform:scale(.9)}.el-input-number.is-without-controls .el-input__wrapper{padding-left:15px;padding-right:15px}.el-input-number.is-controls-right .el-input__wrapper{padding-left:15px;padding-right:42px}.el-input-number.is-controls-right .el-input-number__decrease,.el-input-number.is-controls-right .el-input-number__increase{--el-input-number-controls-height:15px;height:var(--el-input-number-controls-height);line-height:var(--el-input-number-controls-height)}.el-input-number.is-controls-right .el-input-number__decrease [class*=el-icon],.el-input-number.is-controls-right .el-input-number__increase [class*=el-icon]{transform:scale(.8)}.el-input-number.is-controls-right .el-input-number__increase{bottom:auto;left:auto;border-radius:0 var(--el-border-radius-base) 0 0;border-bottom:var(--el-border)}.el-input-number.is-controls-right .el-input-number__decrease{right:1px;top:auto;left:auto;border-right:none;border-left:var(--el-border);border-radius:0 0 var(--el-border-radius-base) 0}.el-input-number.is-controls-right[class*=large] [class*=decrease],.el-input-number.is-controls-right[class*=large] [class*=increase]{--el-input-number-controls-height:19px}.el-input-number.is-controls-right[class*=small] [class*=decrease],.el-input-number.is-controls-right[class*=small] [class*=increase]{--el-input-number-controls-height:11px}.el-textarea{--el-input-text-color:var(--el-text-color-regular);--el-input-border:var(--el-border);--el-input-hover-border:var(--el-border-color-hover);--el-input-focus-border:var(--el-color-primary);--el-input-transparent-border:0 0 0 1px transparent inset;--el-input-border-color:var(--el-border-color);--el-input-border-radius:var(--el-border-radius-base);--el-input-bg-color:var(--el-fill-color-blank);--el-input-icon-color:var(--el-text-color-placeholder);--el-input-placeholder-color:var(--el-text-color-placeholder);--el-input-hover-border-color:var(--el-border-color-hover);--el-input-clear-hover-color:var(--el-text-color-secondary);--el-input-focus-border-color:var(--el-color-primary)}.el-textarea{position:relative;display:inline-block;width:100%;vertical-align:bottom;font-size:var(--el-font-size-base)}.el-textarea__inner{position:relative;display:block;resize:vertical;padding:5px 11px;line-height:1.5;box-sizing:border-box;width:100%;font-size:inherit;font-family:inherit;color:var(--el-input-text-color,var(--el-text-color-regular));background-color:var(--el-input-bg-color,var(--el-fill-color-blank));background-image:none;-webkit-appearance:none;box-shadow:0 0 0 1px var(--el-input-border-color,var(--el-border-color)) inset;border-radius:var(--el-input-border-radius,var(--el-border-radius-base));transition:var(--el-transition-box-shadow);border:none}.el-textarea__inner::-moz-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-textarea__inner:-ms-input-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-textarea__inner::placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-textarea__inner:hover{box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-textarea__inner:focus{outline:0;box-shadow:0 0 0 1px var(--el-input-focus-border-color) inset}.el-textarea .el-input__count{color:var(--el-color-info);background:var(--el-fill-color-blank);position:absolute;font-size:12px;line-height:14px;bottom:5px;right:10px}.el-textarea.is-disabled .el-textarea__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color);color:var(--el-disabled-text-color);cursor:not-allowed}.el-textarea.is-disabled .el-textarea__inner::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-textarea.is-disabled .el-textarea__inner:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-textarea.is-disabled .el-textarea__inner::placeholder{color:var(--el-text-color-placeholder)}.el-textarea.is-exceed .el-textarea__inner{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-textarea.is-exceed .el-input__count{color:var(--el-color-danger)}.el-input{--el-input-text-color:var(--el-text-color-regular);--el-input-border:var(--el-border);--el-input-hover-border:var(--el-border-color-hover);--el-input-focus-border:var(--el-color-primary);--el-input-transparent-border:0 0 0 1px transparent inset;--el-input-border-color:var(--el-border-color);--el-input-border-radius:var(--el-border-radius-base);--el-input-bg-color:var(--el-fill-color-blank);--el-input-icon-color:var(--el-text-color-placeholder);--el-input-placeholder-color:var(--el-text-color-placeholder);--el-input-hover-border-color:var(--el-border-color-hover);--el-input-clear-hover-color:var(--el-text-color-secondary);--el-input-focus-border-color:var(--el-color-primary)}.el-input{--el-input-height:var(--el-component-size);position:relative;font-size:var(--el-font-size-base);display:inline-flex;width:100%;line-height:var(--el-input-height);box-sizing:border-box;vertical-align:middle}.el-input::-webkit-scrollbar{z-index:11;width:6px}.el-input::-webkit-scrollbar:horizontal{height:6px}.el-input::-webkit-scrollbar-thumb{border-radius:5px;width:6px;background:var(--el-text-color-disabled)}.el-input::-webkit-scrollbar-corner{background:var(--el-fill-color-blank)}.el-input::-webkit-scrollbar-track{background:var(--el-fill-color-blank)}.el-input::-webkit-scrollbar-track-piece{background:var(--el-fill-color-blank);width:6px}.el-input .el-input__clear,.el-input .el-input__password{color:var(--el-input-icon-color);font-size:14px;cursor:pointer}.el-input .el-input__clear:hover,.el-input .el-input__password:hover{color:var(--el-input-clear-hover-color)}.el-input .el-input__count{height:100%;display:inline-flex;align-items:center;color:var(--el-color-info);font-size:12px}.el-input .el-input__count .el-input__count-inner{background:var(--el-fill-color-blank);line-height:initial;display:inline-block;padding-left:8px}.el-input__wrapper{display:inline-flex;flex-grow:1;align-items:center;justify-content:center;padding:1px 11px;background-color:var(--el-input-bg-color,var(--el-fill-color-blank));background-image:none;border-radius:var(--el-input-border-radius,var(--el-border-radius-base));transition:var(--el-transition-box-shadow);transform:translateZ(0);box-shadow:0 0 0 1px var(--el-input-border-color,var(--el-border-color)) inset}.el-input__wrapper:hover{box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-input__wrapper.is-focus{box-shadow:0 0 0 1px var(--el-input-focus-border-color) inset}.el-input__inner{--el-input-inner-height:calc(var(--el-input-height, 32px) - 2px);width:100%;flex-grow:1;-webkit-appearance:none;color:var(--el-input-text-color,var(--el-text-color-regular));font-size:inherit;height:var(--el-input-inner-height);line-height:var(--el-input-inner-height);padding:0;outline:0;border:none;background:0 0;box-sizing:border-box}.el-input__inner:focus{outline:0}.el-input__inner::-moz-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-input__inner:-ms-input-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-input__inner::placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-input__inner[type=password]::-ms-reveal{display:none}.el-input__prefix{display:inline-flex;white-space:nowrap;flex-shrink:0;flex-wrap:nowrap;height:100%;text-align:center;color:var(--el-input-icon-color,var(--el-text-color-placeholder));transition:all var(--el-transition-duration);pointer-events:none}.el-input__prefix-inner{pointer-events:all;display:inline-flex;align-items:center;justify-content:center}.el-input__prefix-inner>:last-child{margin-right:8px}.el-input__prefix-inner>:first-child,.el-input__prefix-inner>:first-child.el-input__icon{margin-left:0}.el-input__suffix{display:inline-flex;white-space:nowrap;flex-shrink:0;flex-wrap:nowrap;height:100%;text-align:center;color:var(--el-input-icon-color,var(--el-text-color-placeholder));transition:all var(--el-transition-duration);pointer-events:none}.el-input__suffix-inner{pointer-events:all;display:inline-flex;align-items:center;justify-content:center}.el-input__suffix-inner>:first-child{margin-left:8px}.el-input .el-input__icon{height:inherit;line-height:inherit;display:flex;justify-content:center;align-items:center;transition:all var(--el-transition-duration);margin-left:8px}.el-input__validateIcon{pointer-events:none}.el-input.is-active .el-input__wrapper{box-shadow:0 0 0 1px var(--el-input-focus-color,) inset}.el-input.is-disabled{cursor:not-allowed}.el-input.is-disabled .el-input__wrapper{background-color:var(--el-disabled-bg-color);box-shadow:0 0 0 1px var(--el-disabled-border-color) inset}.el-input.is-disabled .el-input__inner{color:var(--el-disabled-text-color);-webkit-text-fill-color:var(--el-disabled-text-color);cursor:not-allowed}.el-input.is-disabled .el-input__inner::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-input.is-disabled .el-input__inner:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-input.is-disabled .el-input__inner::placeholder{color:var(--el-text-color-placeholder)}.el-input.is-disabled .el-input__icon{cursor:not-allowed}.el-input.is-exceed .el-input__wrapper{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-input.is-exceed .el-input__suffix .el-input__count{color:var(--el-color-danger)}.el-input--large{--el-input-height:var(--el-component-size-large);font-size:14px}.el-input--large .el-input__wrapper{padding:1px 15px}.el-input--large .el-input__inner{--el-input-inner-height:calc(var(--el-input-height, 40px) - 2px)}.el-input--small{--el-input-height:var(--el-component-size-small);font-size:12px}.el-input--small .el-input__wrapper{padding:1px 7px}.el-input--small .el-input__inner{--el-input-inner-height:calc(var(--el-input-height, 24px) - 2px)}.el-input-group{display:inline-flex;width:100%;align-items:stretch}.el-input-group__append,.el-input-group__prepend{background-color:var(--el-fill-color-light);color:var(--el-color-info);position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:100%;border-radius:var(--el-input-border-radius);padding:0 20px;white-space:nowrap}.el-input-group__append:focus,.el-input-group__prepend:focus{outline:0}.el-input-group__append .el-button,.el-input-group__append .el-select,.el-input-group__prepend .el-button,.el-input-group__prepend .el-select{display:inline-block;margin:0 -20px}.el-input-group__append button.el-button,.el-input-group__append button.el-button:hover,.el-input-group__append div.el-select .el-input__wrapper,.el-input-group__append div.el-select:hover .el-input__wrapper,.el-input-group__prepend button.el-button,.el-input-group__prepend button.el-button:hover,.el-input-group__prepend div.el-select .el-input__wrapper,.el-input-group__prepend div.el-select:hover .el-input__wrapper{border-color:transparent;background-color:transparent;color:inherit}.el-input-group__append .el-button,.el-input-group__append .el-input,.el-input-group__prepend .el-button,.el-input-group__prepend .el-input{font-size:inherit}.el-input-group__prepend{border-right:0;border-top-right-radius:0;border-bottom-right-radius:0;box-shadow:1px 0 0 0 var(--el-input-border-color) inset,0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset}.el-input-group__append{border-left:0;border-top-left-radius:0;border-bottom-left-radius:0;box-shadow:0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset,-1px 0 0 0 var(--el-input-border-color) inset}.el-input-group--prepend>.el-input__wrapper{border-top-left-radius:0;border-bottom-left-radius:0}.el-input-group--prepend .el-input-group__prepend .el-select .el-input .el-input__inner{box-shadow:none!important}.el-input-group--prepend .el-input-group__prepend .el-select .el-input .el-input__wrapper{border-top-right-radius:0;border-bottom-right-radius:0;box-shadow:1px 0 0 0 var(--el-input-border-color) inset,0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset}.el-input-group--prepend .el-input-group__prepend .el-select .el-input.is-focus .el-input__inner{box-shadow:none!important}.el-input-group--prepend .el-input-group__prepend .el-select .el-input.is-focus .el-input__wrapper{box-shadow:1px 0 0 0 var(--el-input-focus-border-color) inset,1px 0 0 0 var(--el-input-focus-border-color),0 1px 0 0 var(--el-input-focus-border-color) inset,0 -1px 0 0 var(--el-input-focus-border-color) inset!important;z-index:2}.el-input-group--prepend .el-input-group__prepend .el-select .el-input.is-focus .el-input__wrapper:focus{outline:0;z-index:2;box-shadow:1px 0 0 0 var(--el-input-focus-border-color) inset,1px 0 0 0 var(--el-input-focus-border-color),0 1px 0 0 var(--el-input-focus-border-color) inset,0 -1px 0 0 var(--el-input-focus-border-color) inset!important}.el-input-group--prepend .el-input-group__prepend .el-select:hover .el-input__inner{box-shadow:none!important}.el-input-group--prepend .el-input-group__prepend .el-select:hover .el-input__wrapper{z-index:1;box-shadow:1px 0 0 0 var(--el-input-hover-border-color) inset,1px 0 0 0 var(--el-input-hover-border-color),0 1px 0 0 var(--el-input-hover-border-color) inset,0 -1px 0 0 var(--el-input-hover-border-color) inset!important}.el-input-group--append>.el-input__wrapper{border-top-right-radius:0;border-bottom-right-radius:0}.el-input-group--append .el-input-group__append .el-select .el-input .el-input__inner{box-shadow:none!important}.el-input-group--append .el-input-group__append .el-select .el-input .el-input__wrapper{border-top-left-radius:0;border-bottom-left-radius:0;box-shadow:0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset,-1px 0 0 0 var(--el-input-border-color) inset}.el-input-group--append .el-input-group__append .el-select .el-input.is-focus .el-input__inner{box-shadow:none!important}.el-input-group--append .el-input-group__append .el-select .el-input.is-focus .el-input__wrapper{z-index:2;box-shadow:-1px 0 0 0 var(--el-input-focus-border-color),-1px 0 0 0 var(--el-input-focus-border-color) inset,0 1px 0 0 var(--el-input-focus-border-color) inset,0 -1px 0 0 var(--el-input-focus-border-color) inset!important}.el-input-group--append .el-input-group__append .el-select:hover .el-input__inner{box-shadow:none!important}.el-input-group--append .el-input-group__append .el-select:hover .el-input__wrapper{z-index:1;box-shadow:-1px 0 0 0 var(--el-input-hover-border-color),-1px 0 0 0 var(--el-input-hover-border-color) inset,0 1px 0 0 var(--el-input-hover-border-color) inset,0 -1px 0 0 var(--el-input-hover-border-color) inset!important}.el-link{--el-link-font-size:var(--el-font-size-base);--el-link-font-weight:var(--el-font-weight-primary);--el-link-text-color:var(--el-text-color-regular);--el-link-hover-text-color:var(--el-color-primary);--el-link-disabled-text-color:var(--el-text-color-placeholder)}.el-link{display:inline-flex;flex-direction:row;align-items:center;justify-content:center;vertical-align:middle;position:relative;text-decoration:none;outline:0;cursor:pointer;padding:0;font-size:var(--el-link-font-size);font-weight:var(--el-link-font-weight);color:var(--el-link-text-color)}.el-link:hover{color:var(--el-link-hover-text-color)}.el-link.is-underline:hover:after{content:"";position:absolute;left:0;right:0;height:0;bottom:0;border-bottom:1px solid var(--el-link-hover-text-color)}.el-link.is-disabled{color:var(--el-link-disabled-text-color);cursor:not-allowed}.el-link [class*=el-icon-]+span{margin-left:5px}.el-link.el-link--default:after{border-color:var(--el-link-hover-text-color)}.el-link__inner{display:inline-flex;justify-content:center;align-items:center}.el-link.el-link--primary{--el-link-text-color:var(--el-color-primary);--el-link-hover-text-color:var(--el-color-primary-light-3);--el-link-disabled-text-color:var(--el-color-primary-light-5)}.el-link.el-link--primary:after{border-color:var(--el-link-text-color)}.el-link.el-link--primary.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--success{--el-link-text-color:var(--el-color-success);--el-link-hover-text-color:var(--el-color-success-light-3);--el-link-disabled-text-color:var(--el-color-success-light-5)}.el-link.el-link--success:after{border-color:var(--el-link-text-color)}.el-link.el-link--success.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--warning{--el-link-text-color:var(--el-color-warning);--el-link-hover-text-color:var(--el-color-warning-light-3);--el-link-disabled-text-color:var(--el-color-warning-light-5)}.el-link.el-link--warning:after{border-color:var(--el-link-text-color)}.el-link.el-link--warning.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--danger{--el-link-text-color:var(--el-color-danger);--el-link-hover-text-color:var(--el-color-danger-light-3);--el-link-disabled-text-color:var(--el-color-danger-light-5)}.el-link.el-link--danger:after{border-color:var(--el-link-text-color)}.el-link.el-link--danger.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--error{--el-link-text-color:var(--el-color-error);--el-link-hover-text-color:var(--el-color-error-light-3);--el-link-disabled-text-color:var(--el-color-error-light-5)}.el-link.el-link--error:after{border-color:var(--el-link-text-color)}.el-link.el-link--error.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--info{--el-link-text-color:var(--el-color-info);--el-link-hover-text-color:var(--el-color-info-light-3);--el-link-disabled-text-color:var(--el-color-info-light-5)}.el-link.el-link--info:after{border-color:var(--el-link-text-color)}.el-link.el-link--info.is-underline:hover:after{border-color:var(--el-link-text-color)}:root{--el-loading-spinner-size:42px;--el-loading-fullscreen-spinner-size:50px}.el-loading-parent--relative{position:relative!important}.el-loading-parent--hidden{overflow:hidden!important}.el-loading-mask{position:absolute;z-index:2000;background-color:var(--el-mask-color);margin:0;top:0;right:0;bottom:0;left:0;transition:opacity var(--el-transition-duration)}.el-loading-mask.is-fullscreen{position:fixed}.el-loading-mask.is-fullscreen .el-loading-spinner{margin-top:calc((0px - var(--el-loading-fullscreen-spinner-size))/ 2)}.el-loading-mask.is-fullscreen .el-loading-spinner .circular{height:var(--el-loading-fullscreen-spinner-size);width:var(--el-loading-fullscreen-spinner-size)}.el-loading-spinner{top:50%;margin-top:calc((0px - var(--el-loading-spinner-size))/ 2);width:100%;text-align:center;position:absolute}.el-loading-spinner .el-loading-text{color:var(--el-color-primary);margin:3px 0;font-size:14px}.el-loading-spinner .circular{display:inline;height:var(--el-loading-spinner-size);width:var(--el-loading-spinner-size);-webkit-animation:loading-rotate 2s linear infinite;animation:loading-rotate 2s linear infinite}.el-loading-spinner .path{-webkit-animation:loading-dash 1.5s ease-in-out infinite;animation:loading-dash 1.5s ease-in-out infinite;stroke-dasharray:90,150;stroke-dashoffset:0;stroke-width:2;stroke:var(--el-color-primary);stroke-linecap:round}.el-loading-spinner i{color:var(--el-color-primary)}.el-loading-fade-enter-from,.el-loading-fade-leave-to{opacity:0}@-webkit-keyframes loading-rotate{to{transform:rotate(360deg)}}@keyframes loading-rotate{to{transform:rotate(360deg)}}@-webkit-keyframes loading-dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-40px}to{stroke-dasharray:90,150;stroke-dashoffset:-120px}}@keyframes loading-dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-40px}to{stroke-dasharray:90,150;stroke-dashoffset:-120px}}.el-main{--el-main-padding:20px;display:block;flex:1;flex-basis:auto;overflow:auto;box-sizing:border-box;padding:var(--el-main-padding)}:root{--el-menu-active-color:var(--el-color-primary);--el-menu-text-color:var(--el-text-color-primary);--el-menu-hover-text-color:var(--el-color-primary);--el-menu-bg-color:var(--el-fill-color-blank);--el-menu-hover-bg-color:var(--el-color-primary-light-9);--el-menu-item-height:56px;--el-menu-sub-item-height:calc(var(--el-menu-item-height) - 6px);--el-menu-horizontal-sub-item-height:36px;--el-menu-item-font-size:var(--el-font-size-base);--el-menu-item-hover-fill:var(--el-color-primary-light-9);--el-menu-border-color:var(--el-border-color);--el-menu-base-level-padding:20px;--el-menu-level-padding:20px;--el-menu-icon-width:24px}.el-menu{border-right:solid 1px var(--el-menu-border-color);list-style:none;position:relative;margin:0;padding-left:0;background-color:var(--el-menu-bg-color);box-sizing:border-box}.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-menu-item,.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-menu-item-group__title,.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-sub-menu__title{white-space:nowrap;padding-left:calc(var(--el-menu-base-level-padding) + var(--el-menu-level) * var(--el-menu-level-padding))}.el-menu--horizontal{display:flex;flex-wrap:nowrap;border-bottom:solid 1px var(--el-menu-border-color);border-right:none}.el-menu--horizontal>.el-menu-item{display:inline-flex;justify-content:center;align-items:center;height:100%;margin:0;border-bottom:2px solid transparent;color:var(--el-menu-text-color)}.el-menu--horizontal>.el-menu-item a,.el-menu--horizontal>.el-menu-item a:hover{color:inherit}.el-menu--horizontal>.el-menu-item:not(.is-disabled):focus,.el-menu--horizontal>.el-menu-item:not(.is-disabled):hover{background-color:#fff}.el-menu--horizontal>.el-sub-menu:focus,.el-menu--horizontal>.el-sub-menu:hover{outline:0}.el-menu--horizontal>.el-sub-menu:hover .el-sub-menu__title{color:var(--el-menu-hover-text-color)}.el-menu--horizontal>.el-sub-menu.is-active .el-sub-menu__title{border-bottom:2px solid var(--el-menu-active-color);color:var(--el-menu-active-color)}.el-menu--horizontal>.el-sub-menu .el-sub-menu__title{height:100%;border-bottom:2px solid transparent;color:var(--el-menu-text-color)}.el-menu--horizontal>.el-sub-menu .el-sub-menu__title:hover{background-color:var(--el-bg-color-overlay)}.el-menu--horizontal .el-menu .el-menu-item,.el-menu--horizontal .el-menu .el-sub-menu__title{background-color:var(--el-menu-bg-color);display:flex;align-items:center;height:var(--el-menu-horizontal-sub-item-height);line-height:var(--el-menu-horizontal-sub-item-height);padding:0 10px;color:var(--el-menu-text-color)}.el-menu--horizontal .el-menu .el-sub-menu__title{padding-right:40px}.el-menu--horizontal .el-menu .el-menu-item.is-active,.el-menu--horizontal .el-menu .el-sub-menu.is-active>.el-sub-menu__title{color:var(--el-menu-active-color)}.el-menu--horizontal .el-menu-item:not(.is-disabled):focus,.el-menu--horizontal .el-menu-item:not(.is-disabled):hover{outline:0;color:var(--el-menu-hover-text-color);background-color:var(--el-menu-hover-bg-color)}.el-menu--horizontal>.el-menu-item.is-active{border-bottom:2px solid var(--el-menu-active-color);color:var(--el-menu-active-color)!important}.el-menu--collapse{width:calc(var(--el-menu-icon-width) + var(--el-menu-base-level-padding) * 2)}.el-menu--collapse>.el-menu-item [class^=el-icon],.el-menu--collapse>.el-menu-item-group>ul>.el-sub-menu>.el-sub-menu__title [class^=el-icon],.el-menu--collapse>.el-sub-menu>.el-sub-menu__title [class^=el-icon]{margin:0;vertical-align:middle;width:var(--el-menu-icon-width);text-align:center}.el-menu--collapse>.el-menu-item .el-sub-menu__icon-arrow,.el-menu--collapse>.el-menu-item-group>ul>.el-sub-menu>.el-sub-menu__title .el-sub-menu__icon-arrow,.el-menu--collapse>.el-sub-menu>.el-sub-menu__title .el-sub-menu__icon-arrow{display:none}.el-menu--collapse>.el-menu-item-group>ul>.el-sub-menu>.el-sub-menu__title>span,.el-menu--collapse>.el-menu-item>span,.el-menu--collapse>.el-sub-menu>.el-sub-menu__title>span{height:0;width:0;overflow:hidden;visibility:hidden;display:inline-block}.el-menu--collapse>.el-menu-item.is-active i{color:inherit}.el-menu--collapse .el-menu .el-sub-menu{min-width:200px}.el-menu--popup{z-index:100;min-width:200px;border:none;padding:5px 0;border-radius:var(--el-border-radius-small);box-shadow:var(--el-box-shadow-light)}.el-menu .el-icon{flex-shrink:0}.el-menu-item{display:flex;align-items:center;height:var(--el-menu-item-height);line-height:var(--el-menu-item-height);font-size:var(--el-menu-item-font-size);color:var(--el-menu-text-color);padding:0 var(--el-menu-base-level-padding);list-style:none;cursor:pointer;position:relative;transition:border-color var(--el-transition-duration),background-color var(--el-transition-duration),color var(--el-transition-duration);box-sizing:border-box;white-space:nowrap}.el-menu-item *{vertical-align:bottom}.el-menu-item i{color:inherit}.el-menu-item:focus,.el-menu-item:hover{outline:0}.el-menu-item:hover{background-color:var(--el-menu-hover-bg-color)}.el-menu-item.is-disabled{opacity:.25;cursor:not-allowed;background:0 0!important}.el-menu-item [class^=el-icon]{margin-right:5px;width:var(--el-menu-icon-width);text-align:center;font-size:18px;vertical-align:middle}.el-menu-item.is-active{color:var(--el-menu-active-color)}.el-menu-item.is-active i{color:inherit}.el-menu-item .el-menu-tooltip__trigger{position:absolute;left:0;top:0;height:100%;width:100%;display:inline-flex;align-items:center;box-sizing:border-box;padding:0 var(--el-menu-base-level-padding)}.el-sub-menu{list-style:none;margin:0;padding-left:0}.el-sub-menu__title{display:flex;align-items:center;height:var(--el-menu-item-height);line-height:var(--el-menu-item-height);font-size:var(--el-menu-item-font-size);color:var(--el-menu-text-color);padding:0 var(--el-menu-base-level-padding);list-style:none;cursor:pointer;position:relative;transition:border-color var(--el-transition-duration),background-color var(--el-transition-duration),color var(--el-transition-duration);box-sizing:border-box;white-space:nowrap;padding-right:calc(var(--el-menu-base-level-padding) + var(--el-menu-icon-width))}.el-sub-menu__title *{vertical-align:bottom}.el-sub-menu__title i{color:inherit}.el-sub-menu__title:focus,.el-sub-menu__title:hover{outline:0}.el-sub-menu__title.is-disabled{opacity:.25;cursor:not-allowed;background:0 0!important}.el-sub-menu__title:hover{background-color:var(--el-menu-hover-bg-color)}.el-sub-menu .el-menu{border:none}.el-sub-menu .el-menu-item{height:var(--el-menu-sub-item-height);line-height:var(--el-menu-sub-item-height)}.el-sub-menu__hide-arrow .el-sub-menu__icon-arrow{display:none!important}.el-sub-menu.is-active .el-sub-menu__title{border-bottom-color:var(--el-menu-active-color)}.el-sub-menu.is-disabled .el-menu-item,.el-sub-menu.is-disabled .el-sub-menu__title{opacity:.25;cursor:not-allowed;background:0 0!important}.el-sub-menu .el-icon{vertical-align:middle;margin-right:5px;width:var(--el-menu-icon-width);text-align:center;font-size:18px}.el-sub-menu .el-icon.el-sub-menu__icon-more{margin-right:0!important}.el-sub-menu .el-sub-menu__icon-arrow{position:absolute;top:50%;right:var(--el-menu-base-level-padding);margin-top:-6px;transition:transform var(--el-transition-duration);font-size:12px;margin-right:0;width:inherit}.el-menu-item-group>ul{padding:0}.el-menu-item-group__title{padding:7px 0 7px var(--el-menu-base-level-padding);line-height:normal;font-size:12px;color:var(--el-text-color-secondary)}.horizontal-collapse-transition .el-sub-menu__title .el-sub-menu__icon-arrow{transition:var(--el-transition-duration-fast);opacity:0}.el-message-box{--el-messagebox-title-color:var(--el-text-color-primary);--el-messagebox-width:420px;--el-messagebox-border-radius:4px;--el-messagebox-font-size:var(--el-font-size-large);--el-messagebox-content-font-size:var(--el-font-size-base);--el-messagebox-content-color:var(--el-text-color-regular);--el-messagebox-error-font-size:12px;--el-messagebox-padding-primary:15px}.el-message-box{display:inline-block;max-width:var(--el-messagebox-width);width:100%;padding-bottom:10px;vertical-align:middle;background-color:var(--el-bg-color);border-radius:var(--el-messagebox-border-radius);border:1px solid var(--el-border-color-lighter);font-size:var(--el-messagebox-font-size);box-shadow:var(--el-box-shadow-light);text-align:left;overflow:hidden;-webkit-backface-visibility:hidden;backface-visibility:hidden;box-sizing:border-box}.el-message-box:focus{outline:0!important}.el-overlay.is-message-box .el-overlay-message-box{text-align:center;position:fixed;top:0;right:0;bottom:0;left:0;padding:16px;overflow:auto}.el-overlay.is-message-box .el-overlay-message-box:after{content:"";display:inline-block;height:100%;width:0;vertical-align:middle}.el-message-box.is-draggable .el-message-box__header{cursor:move;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-message-box__header{position:relative;padding:var(--el-messagebox-padding-primary);padding-bottom:10px}.el-message-box__title{padding-left:0;margin-bottom:0;font-size:var(--el-messagebox-font-size);line-height:1;color:var(--el-messagebox-title-color)}.el-message-box__headerbtn{position:absolute;top:var(--el-messagebox-padding-primary);right:var(--el-messagebox-padding-primary);padding:0;border:none;outline:0;background:0 0;font-size:var(--el-message-close-size,16px);cursor:pointer}.el-message-box__headerbtn .el-message-box__close{color:var(--el-color-info);font-size:inherit}.el-message-box__headerbtn:focus .el-message-box__close,.el-message-box__headerbtn:hover .el-message-box__close{color:var(--el-color-primary)}.el-message-box__content{padding:10px var(--el-messagebox-padding-primary);color:var(--el-messagebox-content-color);font-size:var(--el-messagebox-content-font-size)}.el-message-box__container{position:relative}.el-message-box__input{padding-top:15px}.el-message-box__input div.invalid>input{border-color:var(--el-color-error)}.el-message-box__input div.invalid>input:focus{border-color:var(--el-color-error)}.el-message-box__status{position:absolute;top:50%;transform:translateY(-50%);font-size:24px!important}.el-message-box__status:before{padding-left:1px}.el-message-box__status.el-icon{position:absolute}.el-message-box__status+.el-message-box__message{padding-left:36px;padding-right:12px;word-break:break-word}.el-message-box__status.el-message-box-icon--success{--el-messagebox-color:var(--el-color-success);color:var(--el-messagebox-color)}.el-message-box__status.el-message-box-icon--info{--el-messagebox-color:var(--el-color-info);color:var(--el-messagebox-color)}.el-message-box__status.el-message-box-icon--warning{--el-messagebox-color:var(--el-color-warning);color:var(--el-messagebox-color)}.el-message-box__status.el-message-box-icon--error{--el-messagebox-color:var(--el-color-error);color:var(--el-messagebox-color)}.el-message-box__message{margin:0}.el-message-box__message p{margin:0;line-height:24px}.el-message-box__errormsg{color:var(--el-color-error);font-size:var(--el-messagebox-error-font-size);min-height:18px;margin-top:2px}.el-message-box__btns{padding:5px 15px 0;display:flex;flex-wrap:wrap;justify-content:flex-end;align-items:center}.el-message-box__btns button:nth-child(2){margin-left:10px}.el-message-box__btns-reverse{flex-direction:row-reverse}.el-message-box--center .el-message-box__title{position:relative;display:flex;align-items:center;justify-content:center}.el-message-box--center .el-message-box__status{position:relative;top:auto;padding-right:5px;text-align:center;transform:translateY(-1px)}.el-message-box--center .el-message-box__message{margin-left:0}.el-message-box--center .el-message-box__btns{justify-content:center}.el-message-box--center .el-message-box__content{padding-left:calc(var(--el-messagebox-padding-primary) + 12px);padding-right:calc(var(--el-messagebox-padding-primary) + 12px);text-align:center}.fade-in-linear-enter-active .el-overlay-message-box{-webkit-animation:msgbox-fade-in var(--el-transition-duration);animation:msgbox-fade-in var(--el-transition-duration)}.fade-in-linear-leave-active .el-overlay-message-box{animation:msgbox-fade-in var(--el-transition-duration) reverse}@-webkit-keyframes msgbox-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@keyframes msgbox-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@-webkit-keyframes msgbox-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@keyframes msgbox-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}.el-message{--el-message-bg-color:var(--el-color-info-light-9);--el-message-border-color:var(--el-border-color-lighter);--el-message-padding:15px 19px;--el-message-close-size:16px;--el-message-close-icon-color:var(--el-text-color-placeholder);--el-message-close-hover-color:var(--el-text-color-secondary)}.el-message{width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;max-width:calc(100% - 32px);box-sizing:border-box;border-radius:var(--el-border-radius-base);border-width:var(--el-border-width);border-style:var(--el-border-style);border-color:var(--el-message-border-color);position:fixed;left:50%;top:20px;transform:translate(-50%);background-color:var(--el-message-bg-color);transition:opacity var(--el-transition-duration),transform .4s,top .4s;padding:var(--el-message-padding);display:flex;align-items:center}.el-message.is-center{justify-content:center}.el-message.is-closable .el-message__content{padding-right:31px}.el-message p{margin:0}.el-message--success{--el-message-bg-color:var(--el-color-success-light-9);--el-message-border-color:var(--el-color-success-light-8);--el-message-text-color:var(--el-color-success)}.el-message--success .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--success{color:var(--el-message-text-color)}.el-message--info{--el-message-bg-color:var(--el-color-info-light-9);--el-message-border-color:var(--el-color-info-light-8);--el-message-text-color:var(--el-color-info)}.el-message--info .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--info{color:var(--el-message-text-color)}.el-message--warning{--el-message-bg-color:var(--el-color-warning-light-9);--el-message-border-color:var(--el-color-warning-light-8);--el-message-text-color:var(--el-color-warning)}.el-message--warning .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--warning{color:var(--el-message-text-color)}.el-message--error{--el-message-bg-color:var(--el-color-error-light-9);--el-message-border-color:var(--el-color-error-light-8);--el-message-text-color:var(--el-color-error)}.el-message--error .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--error{color:var(--el-message-text-color)}.el-message__icon{margin-right:10px}.el-message .el-message__badge{position:absolute;top:-8px;right:-8px}.el-message__content{padding:0;font-size:14px;line-height:1}.el-message__content:focus{outline-width:0}.el-message .el-message__closeBtn{position:absolute;top:50%;right:19px;transform:translateY(-50%);cursor:pointer;color:var(--el-message-close-icon-color);font-size:var(--el-message-close-size)}.el-message .el-message__closeBtn:focus{outline-width:0}.el-message .el-message__closeBtn:hover{color:var(--el-message-close-hover-color)}.el-message-fade-enter-from,.el-message-fade-leave-to{opacity:0;transform:translate(-50%,-100%)}.el-notification{--el-notification-width:330px;--el-notification-padding:14px 26px 14px 13px;--el-notification-radius:8px;--el-notification-shadow:var(--el-box-shadow-light);--el-notification-border-color:var(--el-border-color-lighter);--el-notification-icon-size:24px;--el-notification-close-font-size:var(--el-message-close-size, 16px);--el-notification-group-margin-left:13px;--el-notification-group-margin-right:8px;--el-notification-content-font-size:var(--el-font-size-base);--el-notification-content-color:var(--el-text-color-regular);--el-notification-title-font-size:16px;--el-notification-title-color:var(--el-text-color-primary);--el-notification-close-color:var(--el-text-color-secondary);--el-notification-close-hover-color:var(--el-text-color-regular)}.el-notification{display:flex;width:var(--el-notification-width);padding:var(--el-notification-padding);border-radius:var(--el-notification-radius);box-sizing:border-box;border:1px solid var(--el-notification-border-color);position:fixed;background-color:var(--el-bg-color-overlay);box-shadow:var(--el-notification-shadow);transition:opacity var(--el-transition-duration),transform var(--el-transition-duration),left var(--el-transition-duration),right var(--el-transition-duration),top .4s,bottom var(--el-transition-duration);overflow-wrap:anywhere;overflow:hidden;z-index:9999}.el-notification.right{right:16px}.el-notification.left{left:16px}.el-notification__group{margin-left:var(--el-notification-group-margin-left);margin-right:var(--el-notification-group-margin-right)}.el-notification__title{font-weight:700;font-size:var(--el-notification-title-font-size);line-height:var(--el-notification-icon-size);color:var(--el-notification-title-color);margin:0}.el-notification__content{font-size:var(--el-notification-content-font-size);line-height:24px;margin:6px 0 0;color:var(--el-notification-content-color);text-align:justify}.el-notification__content p{margin:0}.el-notification .el-notification__icon{height:var(--el-notification-icon-size);width:var(--el-notification-icon-size);font-size:var(--el-notification-icon-size)}.el-notification .el-notification__closeBtn{position:absolute;top:18px;right:15px;cursor:pointer;color:var(--el-notification-close-color);font-size:var(--el-notification-close-font-size)}.el-notification .el-notification__closeBtn:hover{color:var(--el-notification-close-hover-color)}.el-notification .el-notification--success{--el-notification-icon-color:var(--el-color-success);color:var(--el-notification-icon-color)}.el-notification .el-notification--info{--el-notification-icon-color:var(--el-color-info);color:var(--el-notification-icon-color)}.el-notification .el-notification--warning{--el-notification-icon-color:var(--el-color-warning);color:var(--el-notification-icon-color)}.el-notification .el-notification--error{--el-notification-icon-color:var(--el-color-error);color:var(--el-notification-icon-color)}.el-notification-fade-enter-from.right{right:0;transform:translate(100%)}.el-notification-fade-enter-from.left{left:0;transform:translate(-100%)}.el-notification-fade-leave-to{opacity:0}.el-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;height:100%;background-color:var(--el-overlay-color-lighter);overflow:auto}.el-overlay .el-overlay-root{height:0}.el-page-header.is-contentful .el-page-header__main{border-top:1px solid var(--el-border-color-light);margin-top:16px}.el-page-header__header{display:flex;align-items:center;justify-content:space-between;line-height:24px}.el-page-header__left{display:flex;align-items:center;margin-right:40px;position:relative}.el-page-header__back{display:flex;align-items:center;cursor:pointer}.el-page-header__left .el-divider--vertical{margin:0 16px}.el-page-header__icon{font-size:16px;margin-right:10px;display:flex;align-items:center}.el-page-header__icon .el-icon{font-size:inherit}.el-page-header__title{font-size:14px;font-weight:500}.el-page-header__content{font-size:18px;color:var(--el-text-color-primary)}.el-page-header__breadcrumb{margin-bottom:16px}.el-pagination{--el-pagination-font-size:14px;--el-pagination-bg-color:var(--el-fill-color-blank);--el-pagination-text-color:var(--el-text-color-primary);--el-pagination-border-radius:2px;--el-pagination-button-color:var(--el-text-color-primary);--el-pagination-button-width:32px;--el-pagination-button-height:32px;--el-pagination-button-disabled-color:var(--el-text-color-placeholder);--el-pagination-button-disabled-bg-color:var(--el-fill-color-blank);--el-pagination-button-bg-color:var(--el-fill-color);--el-pagination-hover-color:var(--el-color-primary);--el-pagination-font-size-small:12px;--el-pagination-button-width-small:24px;--el-pagination-button-height-small:24px;--el-pagination-item-gap:16px;white-space:nowrap;color:var(--el-pagination-text-color);font-size:var(--el-pagination-font-size);font-weight:400;display:flex;align-items:center}.el-pagination .el-input__inner{text-align:center;-moz-appearance:textfield}.el-pagination .el-select .el-input{width:128px}.el-pagination button{display:flex;justify-content:center;align-items:center;font-size:var(--el-pagination-font-size);min-width:var(--el-pagination-button-width);height:var(--el-pagination-button-height);line-height:var(--el-pagination-button-height);color:var(--el-pagination-button-color);background:var(--el-pagination-bg-color);padding:0 4px;border:none;border-radius:var(--el-pagination-border-radius);cursor:pointer;text-align:center;box-sizing:border-box}.el-pagination button *{pointer-events:none}.el-pagination button:focus{outline:0}.el-pagination button:hover{color:var(--el-pagination-hover-color)}.el-pagination button.is-active{color:var(--el-pagination-hover-color);cursor:default;font-weight:700}.el-pagination button.is-active.is-disabled{font-weight:700;color:var(--el-text-color-secondary)}.el-pagination button.is-disabled,.el-pagination button:disabled{color:var(--el-pagination-button-disabled-color);background-color:var(--el-pagination-button-disabled-bg-color);cursor:not-allowed}.el-pagination button:focus-visible{outline:1px solid var(--el-pagination-hover-color);outline-offset:-1px}.el-pagination .btn-next .el-icon,.el-pagination .btn-prev .el-icon{display:block;font-size:12px;font-weight:700;width:inherit}.el-pagination>.is-first{margin-left:0!important}.el-pagination>.is-last{margin-right:0!important}.el-pagination .btn-prev{margin-left:var(--el-pagination-item-gap)}.el-pagination__sizes,.el-pagination__total{margin-left:var(--el-pagination-item-gap);font-weight:400;color:var(--el-text-color-regular)}.el-pagination__total[disabled=true]{color:var(--el-text-color-placeholder)}.el-pagination__jump{display:flex;align-items:center;margin-left:var(--el-pagination-item-gap);font-weight:400;color:var(--el-text-color-regular)}.el-pagination__jump[disabled=true]{color:var(--el-text-color-placeholder)}.el-pagination__goto{margin-right:8px}.el-pagination__editor{text-align:center;box-sizing:border-box}.el-pagination__editor.el-input{width:56px}.el-pagination__editor .el-input__inner::-webkit-inner-spin-button,.el-pagination__editor .el-input__inner::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.el-pagination__classifier{margin-left:8px}.el-pagination__rightwrapper{flex:1;display:flex;align-items:center;justify-content:flex-end}.el-pagination.is-background .btn-next,.el-pagination.is-background .btn-prev,.el-pagination.is-background .el-pager li{margin:0 4px;background-color:var(--el-pagination-button-bg-color)}.el-pagination.is-background .btn-next.is-active,.el-pagination.is-background .btn-prev.is-active,.el-pagination.is-background .el-pager li.is-active{background-color:var(--el-color-primary);color:var(--el-color-white)}.el-pagination.is-background .btn-next.is-disabled,.el-pagination.is-background .btn-next:disabled,.el-pagination.is-background .btn-prev.is-disabled,.el-pagination.is-background .btn-prev:disabled,.el-pagination.is-background .el-pager li.is-disabled,.el-pagination.is-background .el-pager li:disabled{color:var(--el-text-color-placeholder);background-color:var(--el-disabled-bg-color)}.el-pagination.is-background .btn-next.is-disabled.is-active,.el-pagination.is-background .btn-next:disabled.is-active,.el-pagination.is-background .btn-prev.is-disabled.is-active,.el-pagination.is-background .btn-prev:disabled.is-active,.el-pagination.is-background .el-pager li.is-disabled.is-active,.el-pagination.is-background .el-pager li:disabled.is-active{color:var(--el-text-color-secondary);background-color:var(--el-fill-color-dark)}.el-pagination.is-background .btn-prev{margin-left:var(--el-pagination-item-gap)}.el-pagination--small .btn-next,.el-pagination--small .btn-prev,.el-pagination--small .el-pager li{height:var(--el-pagination-button-height-small);line-height:var(--el-pagination-button-height-small);font-size:var(--el-pagination-font-size-small);min-width:var(--el-pagination-button-width-small)}.el-pagination--small button,.el-pagination--small span:not([class*=suffix]){font-size:var(--el-pagination-font-size-small)}.el-pagination--small .el-select .el-input{width:100px}.el-pager{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;list-style:none;font-size:0;padding:0;margin:0;display:flex;align-items:center}.el-pager li{display:flex;justify-content:center;align-items:center;font-size:var(--el-pagination-font-size);min-width:var(--el-pagination-button-width);height:var(--el-pagination-button-height);line-height:var(--el-pagination-button-height);color:var(--el-pagination-button-color);background:var(--el-pagination-bg-color);padding:0 4px;border:none;border-radius:var(--el-pagination-border-radius);cursor:pointer;text-align:center;box-sizing:border-box}.el-pager li *{pointer-events:none}.el-pager li:focus{outline:0}.el-pager li:hover{color:var(--el-pagination-hover-color)}.el-pager li.is-active{color:var(--el-pagination-hover-color);cursor:default;font-weight:700}.el-pager li.is-active.is-disabled{font-weight:700;color:var(--el-text-color-secondary)}.el-pager li.is-disabled,.el-pager li:disabled{color:var(--el-pagination-button-disabled-color);background-color:var(--el-pagination-button-disabled-bg-color);cursor:not-allowed}.el-pager li:focus-visible{outline:1px solid var(--el-pagination-hover-color);outline-offset:-1px}.el-popconfirm__main{display:flex;align-items:center}.el-popconfirm__icon{margin-right:5px}.el-popconfirm__action{text-align:right;margin-top:8px}.el-popover{--el-popover-bg-color:var(--el-bg-color-overlay);--el-popover-font-size:var(--el-font-size-base);--el-popover-border-color:var(--el-border-color-lighter);--el-popover-padding:12px;--el-popover-padding-large:18px 20px;--el-popover-title-font-size:16px;--el-popover-title-text-color:var(--el-text-color-primary);--el-popover-border-radius:4px}.el-popover.el-popper{background:var(--el-popover-bg-color);min-width:150px;border-radius:var(--el-popover-border-radius);border:1px solid var(--el-popover-border-color);padding:var(--el-popover-padding);z-index:var(--el-index-popper);color:var(--el-text-color-regular);line-height:1.4;text-align:justify;font-size:var(--el-popover-font-size);box-shadow:var(--el-box-shadow-light);word-break:break-all;box-sizing:border-box}.el-popover.el-popper--plain{padding:var(--el-popover-padding-large)}.el-popover__title{color:var(--el-popover-title-text-color);font-size:var(--el-popover-title-font-size);line-height:1;margin-bottom:12px}.el-popover__reference:focus:hover,.el-popover__reference:focus:not(.focusing){outline-width:0}.el-popover.el-popper.is-dark{--el-popover-bg-color:var(--el-text-color-primary);--el-popover-border-color:var(--el-text-color-primary);--el-popover-title-text-color:var(--el-bg-color);color:var(--el-bg-color)}.el-popover.el-popper:focus,.el-popover.el-popper:focus:active{outline-width:0}.el-progress{position:relative;line-height:1;display:flex;align-items:center}.el-progress__text{font-size:14px;color:var(--el-text-color-regular);margin-left:5px;min-width:50px;line-height:1}.el-progress__text i{vertical-align:middle;display:block}.el-progress--circle,.el-progress--dashboard{display:inline-block}.el-progress--circle .el-progress__text,.el-progress--dashboard .el-progress__text{position:absolute;top:50%;left:0;width:100%;text-align:center;margin:0;transform:translateY(-50%)}.el-progress--circle .el-progress__text i,.el-progress--dashboard .el-progress__text i{vertical-align:middle;display:inline-block}.el-progress--without-text .el-progress__text{display:none}.el-progress--without-text .el-progress-bar{padding-right:0;margin-right:0;display:block}.el-progress--text-inside .el-progress-bar{padding-right:0;margin-right:0}.el-progress.is-success .el-progress-bar__inner{background-color:var(--el-color-success)}.el-progress.is-success .el-progress__text{color:var(--el-color-success)}.el-progress.is-warning .el-progress-bar__inner{background-color:var(--el-color-warning)}.el-progress.is-warning .el-progress__text{color:var(--el-color-warning)}.el-progress.is-exception .el-progress-bar__inner{background-color:var(--el-color-danger)}.el-progress.is-exception .el-progress__text{color:var(--el-color-danger)}.el-progress-bar{flex-grow:1;box-sizing:border-box}.el-progress-bar__outer{height:6px;border-radius:100px;background-color:var(--el-border-color-lighter);overflow:hidden;position:relative;vertical-align:middle}.el-progress-bar__inner{position:absolute;left:0;top:0;height:100%;background-color:var(--el-color-primary);text-align:right;border-radius:100px;line-height:1;white-space:nowrap;transition:width .6s ease}.el-progress-bar__inner:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-progress-bar__inner--indeterminate{transform:translateZ(0);-webkit-animation:indeterminate 3s infinite;animation:indeterminate 3s infinite}.el-progress-bar__inner--striped{background-image:linear-gradient(45deg,rgba(0,0,0,.1) 25%,transparent 25%,transparent 50%,rgba(0,0,0,.1) 50%,rgba(0,0,0,.1) 75%,transparent 75%,transparent);background-size:1.25em 1.25em}.el-progress-bar__inner--striped.el-progress-bar__inner--striped-flow{-webkit-animation:striped-flow 3s linear infinite;animation:striped-flow 3s linear infinite}.el-progress-bar__innerText{display:inline-block;vertical-align:middle;color:#fff;font-size:12px;margin:0 5px}@-webkit-keyframes progress{0%{background-position:0 0}to{background-position:32px 0}}@keyframes progress{0%{background-position:0 0}to{background-position:32px 0}}@-webkit-keyframes indeterminate{0%{left:-100%}to{left:100%}}@keyframes indeterminate{0%{left:-100%}to{left:100%}}@-webkit-keyframes striped-flow{0%{background-position:-100%}to{background-position:100%}}@keyframes striped-flow{0%{background-position:-100%}to{background-position:100%}}.el-radio-button{--el-radio-button-checked-bg-color:var(--el-color-primary);--el-radio-button-checked-text-color:var(--el-color-white);--el-radio-button-checked-border-color:var(--el-color-primary);--el-radio-button-disabled-checked-fill:var(--el-border-color-extra-light)}.el-radio-button{position:relative;display:inline-block;outline:0}.el-radio-button__inner{display:inline-block;line-height:1;white-space:nowrap;vertical-align:middle;background:var(--el-button-bg-color,var(--el-fill-color-blank));border:var(--el-border);font-weight:var(--el-button-font-weight,var(--el-font-weight-primary));border-left:0;color:var(--el-button-text-color,var(--el-text-color-regular));-webkit-appearance:none;text-align:center;box-sizing:border-box;outline:0;margin:0;position:relative;cursor:pointer;transition:var(--el-transition-all);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;padding:8px 15px;font-size:var(--el-font-size-base);border-radius:0}.el-radio-button__inner.is-round{padding:8px 15px}.el-radio-button__inner:hover{color:var(--el-color-primary)}.el-radio-button__inner [class*=el-icon-]{line-height:.9}.el-radio-button__inner [class*=el-icon-]+span{margin-left:5px}.el-radio-button:first-child .el-radio-button__inner{border-left:var(--el-border);border-radius:var(--el-border-radius-base) 0 0 var(--el-border-radius-base);box-shadow:none!important}.el-radio-button__original-radio{opacity:0;outline:0;position:absolute;z-index:-1}.el-radio-button__original-radio:checked+.el-radio-button__inner{color:var(--el-radio-button-checked-text-color,var(--el-color-white));background-color:var(--el-radio-button-checked-bg-color,var(--el-color-primary));border-color:var(--el-radio-button-checked-border-color,var(--el-color-primary));box-shadow:-1px 0 0 0 var(--el-radio-button-checked-border-color,var(--el-color-primary))}.el-radio-button__original-radio:focus-visible+.el-radio-button__inner{border-left:var(--el-border);border-left-color:var(--el-radio-button-checked-border-color,var(--el-color-primary));outline:2px solid var(--el-radio-button-checked-border-color);outline-offset:1px;z-index:2;border-radius:var(--el-border-radius-base);box-shadow:none}.el-radio-button__original-radio:disabled+.el-radio-button__inner{color:var(--el-disabled-text-color);cursor:not-allowed;background-image:none;background-color:var(--el-button-disabled-bg-color,var(--el-fill-color-blank));border-color:var(--el-button-disabled-border-color,var(--el-border-color-light));box-shadow:none}.el-radio-button__original-radio:disabled:checked+.el-radio-button__inner{background-color:var(--el-radio-button-disabled-checked-fill)}.el-radio-button:last-child .el-radio-button__inner{border-radius:0 var(--el-border-radius-base) var(--el-border-radius-base) 0}.el-radio-button:first-child:last-child .el-radio-button__inner{border-radius:var(--el-border-radius-base)}.el-radio-button--large .el-radio-button__inner{padding:12px 19px;font-size:var(--el-font-size-base);border-radius:0}.el-radio-button--large .el-radio-button__inner.is-round{padding:12px 19px}.el-radio-button--small .el-radio-button__inner{padding:5px 11px;font-size:12px;border-radius:0}.el-radio-button--small .el-radio-button__inner.is-round{padding:5px 11px}.el-radio-group{display:inline-flex;align-items:center;flex-wrap:wrap;font-size:0}.el-radio{--el-radio-font-size:var(--el-font-size-base);--el-radio-text-color:var(--el-text-color-regular);--el-radio-font-weight:var(--el-font-weight-primary);--el-radio-input-height:14px;--el-radio-input-width:14px;--el-radio-input-border-radius:var(--el-border-radius-circle);--el-radio-input-bg-color:var(--el-fill-color-blank);--el-radio-input-border:var(--el-border);--el-radio-input-border-color:var(--el-border-color);--el-radio-input-border-color-hover:var(--el-color-primary)}.el-radio{color:var(--el-radio-text-color);font-weight:var(--el-radio-font-weight);position:relative;cursor:pointer;display:inline-flex;align-items:center;white-space:nowrap;outline:0;font-size:var(--el-font-size-base);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;margin-right:32px;height:32px}.el-radio.el-radio--large{height:40px}.el-radio.el-radio--small{height:24px}.el-radio.is-bordered{padding:0 15px 0 9px;border-radius:var(--el-border-radius-base);border:var(--el-border);box-sizing:border-box}.el-radio.is-bordered.is-checked{border-color:var(--el-color-primary)}.el-radio.is-bordered.is-disabled{cursor:not-allowed;border-color:var(--el-border-color-lighter)}.el-radio.is-bordered.el-radio--large{padding:0 19px 0 11px;border-radius:var(--el-border-radius-base)}.el-radio.is-bordered.el-radio--large .el-radio__label{font-size:var(--el-font-size-base)}.el-radio.is-bordered.el-radio--large .el-radio__inner{height:14px;width:14px}.el-radio.is-bordered.el-radio--small{padding:0 11px 0 7px;border-radius:var(--el-border-radius-base)}.el-radio.is-bordered.el-radio--small .el-radio__label{font-size:12px}.el-radio.is-bordered.el-radio--small .el-radio__inner{height:12px;width:12px}.el-radio:last-child{margin-right:0}.el-radio__input{white-space:nowrap;cursor:pointer;outline:0;display:inline-flex;position:relative;vertical-align:middle}.el-radio__input.is-disabled .el-radio__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color);cursor:not-allowed}.el-radio__input.is-disabled .el-radio__inner:after{cursor:not-allowed;background-color:var(--el-disabled-bg-color)}.el-radio__input.is-disabled .el-radio__inner+.el-radio__label{cursor:not-allowed}.el-radio__input.is-disabled.is-checked .el-radio__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color)}.el-radio__input.is-disabled.is-checked .el-radio__inner:after{background-color:var(--el-text-color-placeholder)}.el-radio__input.is-disabled+span.el-radio__label{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-radio__input.is-checked .el-radio__inner{border-color:var(--el-color-primary);background:var(--el-color-primary)}.el-radio__input.is-checked .el-radio__inner:after{transform:translate(-50%,-50%) scale(1)}.el-radio__input.is-checked+.el-radio__label{color:var(--el-color-primary)}.el-radio__input.is-focus .el-radio__inner{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner{border:var(--el-radio-input-border);border-radius:var(--el-radio-input-border-radius);width:var(--el-radio-input-width);height:var(--el-radio-input-height);background-color:var(--el-radio-input-bg-color);position:relative;cursor:pointer;display:inline-block;box-sizing:border-box}.el-radio__inner:hover{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner:after{width:4px;height:4px;border-radius:var(--el-radio-input-border-radius);background-color:var(--el-color-white);content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(0);transition:transform .15s ease-in}.el-radio__original{opacity:0;outline:0;position:absolute;z-index:-1;top:0;left:0;right:0;bottom:0;margin:0}.el-radio__original:focus-visible+.el-radio__inner{outline:2px solid var(--el-radio-input-border-color-hover);outline-offset:1px;border-radius:var(--el-radio-input-border-radius)}.el-radio:focus:not(:focus-visible):not(.is-focus):not(:active):not(.is-disabled) .el-radio__inner{box-shadow:0 0 2px 2px var(--el-radio-input-border-color-hover)}.el-radio__label{font-size:var(--el-radio-font-size);padding-left:8px}.el-radio.el-radio--large .el-radio__label{font-size:14px}.el-radio.el-radio--large .el-radio__inner{width:14px;height:14px}.el-radio.el-radio--small .el-radio__label{font-size:12px}.el-radio.el-radio--small .el-radio__inner{width:12px;height:12px}.el-rate{--el-rate-height:20px;--el-rate-font-size:var(--el-font-size-base);--el-rate-icon-size:18px;--el-rate-icon-margin:6px;--el-rate-void-color:var(--el-border-color-darker);--el-rate-fill-color:#f7ba2a;--el-rate-disabled-void-color:var(--el-fill-color);--el-rate-text-color:var(--el-text-color-primary)}.el-rate{display:inline-flex;align-items:center;height:32px}.el-rate:active,.el-rate:focus{outline:0}.el-rate__item{cursor:pointer;display:inline-block;position:relative;font-size:0;vertical-align:middle;color:var(--el-rate-void-color);line-height:normal}.el-rate .el-rate__icon{position:relative;display:inline-block;font-size:var(--el-rate-icon-size);margin-right:var(--el-rate-icon-margin);transition:var(--el-transition-duration)}.el-rate .el-rate__icon.hover{transform:scale(1.15)}.el-rate .el-rate__icon .path2{position:absolute;left:0;top:0}.el-rate .el-rate__icon.is-active{color:var(--el-rate-fill-color)}.el-rate__decimal{position:absolute;top:0;left:0;display:inline-block;overflow:hidden;color:var(--el-rate-fill-color)}.el-rate__text{font-size:var(--el-rate-font-size);vertical-align:middle;color:var(--el-rate-text-color)}.el-rate--large{height:40px}.el-rate--small{height:24px}.el-rate--small .el-rate__icon{font-size:14px}.el-rate.is-disabled .el-rate__item{cursor:auto;color:var(--el-rate-disabled-void-color)}.el-result{--el-result-padding:40px 30px;--el-result-icon-font-size:64px;--el-result-title-font-size:20px;--el-result-title-margin-top:20px;--el-result-subtitle-margin-top:10px;--el-result-extra-margin-top:30px}.el-result{display:flex;justify-content:center;align-items:center;flex-direction:column;text-align:center;box-sizing:border-box;padding:var(--el-result-padding)}.el-result__icon svg{width:var(--el-result-icon-font-size);height:var(--el-result-icon-font-size)}.el-result__title{margin-top:var(--el-result-title-margin-top)}.el-result__title p{margin:0;font-size:var(--el-result-title-font-size);color:var(--el-text-color-primary);line-height:1.3}.el-result__subtitle{margin-top:var(--el-result-subtitle-margin-top)}.el-result__subtitle p{margin:0;font-size:var(--el-font-size-base);color:var(--el-text-color-regular);line-height:1.3}.el-result__extra{margin-top:var(--el-result-extra-margin-top)}.el-result .icon-primary{--el-result-color:var(--el-color-primary);color:var(--el-result-color)}.el-result .icon-success{--el-result-color:var(--el-color-success);color:var(--el-result-color)}.el-result .icon-warning{--el-result-color:var(--el-color-warning);color:var(--el-result-color)}.el-result .icon-danger{--el-result-color:var(--el-color-danger);color:var(--el-result-color)}.el-result .icon-error{--el-result-color:var(--el-color-error);color:var(--el-result-color)}.el-result .icon-info{--el-result-color:var(--el-color-info);color:var(--el-result-color)}.el-row{display:flex;flex-wrap:wrap;position:relative;box-sizing:border-box}.el-row.is-justify-center{justify-content:center}.el-row.is-justify-end{justify-content:flex-end}.el-row.is-justify-space-between{justify-content:space-between}.el-row.is-justify-space-around{justify-content:space-around}.el-row.is-justify-space-evenly{justify-content:space-evenly}.el-row.is-align-middle{align-items:center}.el-row.is-align-bottom{align-items:flex-end}.el-scrollbar{--el-scrollbar-opacity:.3;--el-scrollbar-bg-color:var(--el-text-color-secondary);--el-scrollbar-hover-opacity:.5;--el-scrollbar-hover-bg-color:var(--el-text-color-secondary)}.el-scrollbar{overflow:hidden;position:relative;height:100%}.el-scrollbar__wrap{overflow:auto;height:100%}.el-scrollbar__wrap--hidden-default{scrollbar-width:none}.el-scrollbar__wrap--hidden-default::-webkit-scrollbar{display:none}.el-scrollbar__thumb{position:relative;display:block;width:0;height:0;cursor:pointer;border-radius:inherit;background-color:var(--el-scrollbar-bg-color,var(--el-text-color-secondary));transition:var(--el-transition-duration) background-color;opacity:var(--el-scrollbar-opacity,.3)}.el-scrollbar__thumb:hover{background-color:var(--el-scrollbar-hover-bg-color,var(--el-text-color-secondary));opacity:var(--el-scrollbar-hover-opacity,.5)}.el-scrollbar__bar{position:absolute;right:2px;bottom:2px;z-index:1;border-radius:4px}.el-scrollbar__bar.is-vertical{width:6px;top:2px}.el-scrollbar__bar.is-vertical>div{width:100%}.el-scrollbar__bar.is-horizontal{height:6px;left:2px}.el-scrollbar__bar.is-horizontal>div{height:100%}.el-scrollbar-fade-enter-active{transition:opacity .34s ease-out}.el-scrollbar-fade-leave-active{transition:opacity .12s ease-out}.el-scrollbar-fade-enter-from,.el-scrollbar-fade-leave-active{opacity:0}.el-select-dropdown{z-index:calc(var(--el-index-top) + 1);border-radius:var(--el-border-radius-base);box-sizing:border-box}.el-select-dropdown .el-scrollbar.is-empty .el-select-dropdown__list{padding:0}.el-select-dropdown__option-item.is-selected:not(.is-multiple).is-disabled{color:var(--el-text-color-disabled)}.el-select-dropdown__option-item.is-selected:not(.is-multiple).is-disabled:after{background-color:var(--el-text-color-disabled)}.el-select-dropdown__option-item:hover:not(.hover){background-color:transparent}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-disabled.is-selected{color:var(--el-text-color-disabled)}.el-select-dropdown__empty{padding:10px 0;margin:0;text-align:center;color:var(--el-text-color-secondary);font-size:var(--el-select-font-size)}.el-select-dropdown__wrap{max-height:274px}.el-select-dropdown__list{list-style:none;margin:6px 0!important;padding:0!important;box-sizing:border-box}.el-select-dropdown__option-item{font-size:var(--el-select-font-size);padding:0 32px 0 20px;position:relative;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--el-text-color-regular);height:34px;line-height:34px;box-sizing:border-box;cursor:pointer}.el-select-dropdown__option-item.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-select-dropdown__option-item.is-disabled:hover{background-color:var(--el-bg-color)}.el-select-dropdown__option-item.is-selected{background-color:var(--el-fill-color-light);font-weight:700}.el-select-dropdown__option-item.is-selected:not(.is-multiple){color:var(--el-color-primary)}.el-select-dropdown__option-item.hover{background-color:var(--el-fill-color-light)!important}.el-select-dropdown__option-item:hover{background-color:var(--el-fill-color-light)}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-selected{color:var(--el-color-primary);background-color:var(--el-bg-color-overlay)}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-selected .el-icon{position:absolute;right:20px;top:0;height:inherit;font-size:12px}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-selected .el-icon svg{height:inherit;vertical-align:middle}.el-select-group{margin:0;padding:0}.el-select-group__wrap{position:relative;list-style:none;margin:0;padding:0}.el-select-group__wrap:not(:last-of-type){padding-bottom:24px}.el-select-group__wrap:not(:last-of-type):after{content:"";position:absolute;display:block;left:20px;right:20px;bottom:12px;height:1px;background:var(--el-border-color-light)}.el-select-group__split-dash{position:absolute;left:20px;right:20px;height:1px;background:var(--el-border-color-light)}.el-select-group__title{padding-left:20px;font-size:12px;color:var(--el-color-info);line-height:30px}.el-select-group .el-select-dropdown__item{padding-left:20px}.el-select-v2{--el-select-border-color-hover:var(--el-border-color-hover);--el-select-disabled-border:var(--el-disabled-border-color);--el-select-font-size:var(--el-font-size-base);--el-select-close-hover-color:var(--el-text-color-secondary);--el-select-input-color:var(--el-text-color-placeholder);--el-select-multiple-input-color:var(--el-text-color-regular);--el-select-input-focus-border-color:var(--el-color-primary);--el-select-input-font-size:14px}.el-select-v2{display:inline-block;position:relative;vertical-align:middle;font-size:14px}.el-select-v2__wrapper{display:flex;align-items:center;flex-wrap:wrap;position:relative;box-sizing:border-box;cursor:pointer;padding:1px 30px 1px 0;border:1px solid var(--el-border-color);border-radius:var(--el-border-radius-base);background-color:var(--el-fill-color-blank);transition:var(--el-transition-duration)}.el-select-v2__wrapper:hover{border-color:var(--el-text-color-placeholder)}.el-select-v2__wrapper.is-filterable{cursor:text}.el-select-v2__wrapper.is-focused{border-color:var(--el-color-primary)}.el-select-v2__wrapper.is-hovering:not(.is-focused){border-color:var(--el-border-color-hover)}.el-select-v2__wrapper.is-disabled{cursor:not-allowed;background-color:var(--el-fill-color-light);color:var(--el-text-color-placeholder);border-color:var(--el-select-disabled-border)}.el-select-v2__wrapper.is-disabled:hover{border-color:var(--el-select-disabled-border)}.el-select-v2__wrapper.is-disabled.is-focus{border-color:var(--el-input-focus-border-color)}.el-select-v2__wrapper.is-disabled .is-transparent{opacity:1;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-select-v2__wrapper.is-disabled .el-select-v2__caret,.el-select-v2__wrapper.is-disabled .el-select-v2__combobox-input{cursor:not-allowed}.el-select-v2__wrapper .el-select-v2__input-wrapper{box-sizing:border-box;position:relative;-webkit-margin-start:12px;margin-inline-start:12px;max-width:100%;overflow:hidden}.el-select-v2__wrapper,.el-select-v2__wrapper .el-select-v2__input-wrapper{line-height:32px}.el-select-v2__wrapper .el-select-v2__input-wrapper input{--el-input-inner-height:calc(var(--el-component-size, 32px) - 8px);height:var(--el-input-inner-height);line-height:var(--el-input-inner-height);min-width:4px;width:100%;background-color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:0 0;border:none;margin:2px 0;outline:0;padding:0}.el-select-v2 .el-select-v2__tags-text{display:inline-block;line-height:normal;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-select-v2__empty{padding:10px 0;margin:0;text-align:center;color:var(--el-text-color-secondary);font-size:14px}.el-select-v2__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-box-shadow-light)}.el-select-v2__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-select-v2__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-select-v2__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-select-v2__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-select-v2__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-select-v2--large .el-select-v2__wrapper .el-select-v2__combobox-input{height:32px}.el-select-v2--large .el-select-v2__caret,.el-select-v2--large .el-select-v2__suffix{height:40px}.el-select-v2--large .el-select-v2__placeholder{font-size:14px;line-height:40px}.el-select-v2--small .el-select-v2__wrapper .el-select-v2__combobox-input{height:16px}.el-select-v2--small .el-select-v2__caret,.el-select-v2--small .el-select-v2__suffix{height:24px}.el-select-v2--small .el-select-v2__placeholder{font-size:12px;line-height:24px}.el-select-v2 .el-select-v2__selection>span{display:inline-block}.el-select-v2:hover .el-select-v2__combobox-input{border-color:var(--el-select-border-color-hover)}.el-select-v2 .el-select__selection-text{text-overflow:ellipsis;display:inline-block;overflow-x:hidden;vertical-align:bottom}.el-select-v2 .el-select-v2__combobox-input{padding-right:35px;display:block;color:var(--el-text-color-regular)}.el-select-v2 .el-select-v2__combobox-input:focus{border-color:var(--el-select-input-focus-border-color)}.el-select-v2__input{border:none;outline:0;padding:0;margin-left:15px;color:var(--el-select-multiple-input-color);font-size:var(--el-select-font-size);-webkit-appearance:none;-moz-appearance:none;appearance:none;height:28px}.el-select-v2__input.is-small{height:14px}.el-select-v2__close{cursor:pointer;position:absolute;top:8px;z-index:var(--el-index-top);right:25px;color:var(--el-select-input-color);line-height:18px;font-size:var(--el-select-input-font-size)}.el-select-v2__close:hover{color:var(--el-select-close-hover-color)}.el-select-v2__suffix{display:inline-flex;position:absolute;right:12px;height:32px;top:50%;transform:translateY(-50%);color:var(--el-input-icon-color,var(--el-text-color-placeholder))}.el-select-v2__suffix .el-input__icon{height:inherit}.el-select-v2__suffix .el-input__icon:not(:first-child){margin-left:8px}.el-select-v2__caret{color:var(--el-select-input-color);font-size:var(--el-select-input-font-size);transition:var(--el-transition-duration);transform:rotate(180deg);cursor:pointer}.el-select-v2__caret.is-reverse{transform:rotate(0)}.el-select-v2__caret.is-show-close{font-size:var(--el-select-font-size);text-align:center;transform:rotate(180deg);border-radius:var(--el-border-radius-circle);color:var(--el-select-input-color);transition:var(--el-transition-color)}.el-select-v2__caret.is-show-close:hover{color:var(--el-select-close-hover-color)}.el-select-v2__caret.el-icon{height:inherit}.el-select-v2__caret.el-icon svg{vertical-align:middle}.el-select-v2__selection{white-space:normal;z-index:var(--el-index-normal);display:flex;align-items:center;flex-wrap:wrap;width:100%}.el-select-v2__input-calculator{left:0;position:absolute;top:0;visibility:hidden;white-space:pre;z-index:999}.el-select-v2__selected-item{line-height:inherit;height:inherit;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;display:flex;flex-wrap:wrap}.el-select-v2__placeholder{position:absolute;top:50%;transform:translateY(-50%);-webkit-margin-start:12px;margin-inline-start:12px;width:calc(100% - 52px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--el-input-text-color,var(--el-text-color-regular))}.el-select-v2__placeholder.is-transparent{color:var(--el-text-color-placeholder)}.el-select-v2 .el-select-v2__selection .el-tag{box-sizing:border-box;border-color:transparent;margin:2px 0 2px 6px;background-color:var(--el-fill-color)}.el-select-v2 .el-select-v2__selection .el-tag .el-icon-close{background-color:var(--el-text-color-placeholder);right:-7px;color:var(--el-color-white)}.el-select-v2 .el-select-v2__selection .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-select-v2 .el-select-v2__selection .el-tag .el-icon-close:before{display:block;transform:translateY(.5px)}.el-select-v2.el-select-v2--small .el-select-v2__selection .el-tag{margin:1px 0 1px 6px;height:18px}.el-select-dropdown{z-index:calc(var(--el-index-top) + 1);border-radius:var(--el-border-radius-base);box-sizing:border-box}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected{color:var(--el-color-primary);background-color:var(--el-bg-color-overlay)}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected.hover{background-color:var(--el-fill-color-light)}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected:after{content:"";position:absolute;top:50%;right:20px;border-top:none;border-right:none;background-repeat:no-repeat;background-position:center;background-color:var(--el-color-primary);-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask-size:100% 100%;-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;-webkit-mask-size:100% 100%;transform:translateY(-50%);width:12px;height:12px}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected.is-disabled:after{background-color:var(--el-text-color-disabled)}.el-select-dropdown .el-select-dropdown__option-item.is-selected:after{content:"";position:absolute;top:50%;right:20px;border-top:none;border-right:none;background-repeat:no-repeat;background-position:center;background-color:var(--el-color-primary);-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask-size:100% 100%;-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;-webkit-mask-size:100% 100%;transform:translateY(-50%);width:12px;height:12px}.el-select-dropdown .el-scrollbar.is-empty .el-select-dropdown__list{padding:0}.el-select-dropdown .el-select-dropdown__item.is-disabled:hover{background-color:unset}.el-select-dropdown .el-select-dropdown__item.is-disabled.selected{color:var(--el-text-color-disabled)}.el-select-dropdown__empty{padding:10px 0;margin:0;text-align:center;color:var(--el-text-color-secondary);font-size:var(--el-select-font-size)}.el-select-dropdown__wrap{max-height:274px}.el-select-dropdown__list{list-style:none;padding:6px 0;margin:0;box-sizing:border-box}.el-select{--el-select-border-color-hover:var(--el-border-color-hover);--el-select-disabled-border:var(--el-disabled-border-color);--el-select-font-size:var(--el-font-size-base);--el-select-close-hover-color:var(--el-text-color-secondary);--el-select-input-color:var(--el-text-color-placeholder);--el-select-multiple-input-color:var(--el-text-color-regular);--el-select-input-focus-border-color:var(--el-color-primary);--el-select-input-font-size:14px}.el-select{display:inline-block;position:relative;vertical-align:middle;line-height:32px}.el-select__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-box-shadow-light)}.el-select__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-select__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-select__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-select__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-select__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-select .el-select-tags-wrapper.has-prefix{margin-left:6px}.el-select--large{line-height:40px}.el-select--large .el-select-tags-wrapper.has-prefix{margin-left:8px}.el-select--small{line-height:24px}.el-select--small .el-select-tags-wrapper.has-prefix{margin-left:4px}.el-select .el-select__tags>span{display:inline-block}.el-select:hover:not(.el-select--disabled) .el-input__wrapper{box-shadow:0 0 0 1px var(--el-select-border-color-hover) inset}.el-select .el-select__tags-text{display:inline-block;line-height:normal;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-select .el-input__wrapper{cursor:pointer}.el-select .el-input__wrapper.is-focus{box-shadow:0 0 0 1px var(--el-select-input-focus-border-color) inset!important}.el-select .el-input__inner{cursor:pointer}.el-select .el-input{display:flex}.el-select .el-input .el-select__caret{color:var(--el-select-input-color);font-size:var(--el-select-input-font-size);transition:transform var(--el-transition-duration);transform:rotate(0);cursor:pointer}.el-select .el-input .el-select__caret.is-reverse{transform:rotate(-180deg)}.el-select .el-input .el-select__caret.is-show-close{font-size:var(--el-select-font-size);text-align:center;transform:rotate(0);border-radius:var(--el-border-radius-circle);color:var(--el-select-input-color);transition:var(--el-transition-color)}.el-select .el-input .el-select__caret.is-show-close:hover{color:var(--el-select-close-hover-color)}.el-select .el-input .el-select__caret.el-icon{position:relative;height:inherit;z-index:2}.el-select .el-input.is-disabled .el-input__wrapper{cursor:not-allowed}.el-select .el-input.is-disabled .el-input__wrapper:hover{box-shadow:0 0 0 1px var(--el-select-disabled-border) inset}.el-select .el-input.is-disabled .el-input__inner,.el-select .el-input.is-disabled .el-select__caret{cursor:not-allowed}.el-select .el-input.is-focus .el-input__wrapper{box-shadow:0 0 0 1px var(--el-select-input-focus-border-color) inset!important}.el-select__input{border:none;outline:0;padding:0;margin-left:15px;color:var(--el-select-multiple-input-color);font-size:var(--el-select-font-size);-webkit-appearance:none;-moz-appearance:none;appearance:none;height:28px;background-color:transparent}.el-select__input.is-disabled{cursor:not-allowed}.el-select__input--iOS{position:absolute;left:0;top:0;z-index:6}.el-select__input.is-small{height:14px}.el-select__close{cursor:pointer;position:absolute;top:8px;z-index:var(--el-index-top);right:25px;color:var(--el-select-input-color);line-height:18px;font-size:var(--el-select-input-font-size)}.el-select__close:hover{color:var(--el-select-close-hover-color)}.el-select__tags{position:absolute;line-height:normal;top:50%;transform:translateY(-50%);white-space:normal;z-index:var(--el-index-normal);display:flex;align-items:center;flex-wrap:wrap;cursor:pointer}.el-select__tags .el-tag{box-sizing:border-box;border-color:transparent;margin:2px 6px 2px 0}.el-select__tags .el-tag:last-child{margin-right:0}.el-select__tags .el-tag .el-icon-close{background-color:var(--el-text-color-placeholder);right:-7px;top:0;color:#fff}.el-select__tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-select__tags .el-tag .el-icon-close:before{display:block;transform:translateY(.5px)}.el-select__tags .el-tag--info{background-color:var(--el-fill-color)}.el-select__tags.is-disabled{cursor:not-allowed}.el-select__collapse-tags{white-space:normal;z-index:var(--el-index-normal);display:flex;align-items:center;flex-wrap:wrap;cursor:pointer}.el-select__collapse-tags .el-tag{box-sizing:border-box;border-color:transparent;margin:2px 6px 2px 0}.el-select__collapse-tags .el-tag:last-child{margin-right:0}.el-select__collapse-tags .el-tag .el-icon-close{background-color:var(--el-text-color-placeholder);right:-7px;top:0;color:#fff}.el-select__collapse-tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-select__collapse-tags .el-tag .el-icon-close:before{display:block;transform:translateY(.5px)}.el-select__collapse-tags .el-tag--info{background-color:var(--el-fill-color)}.el-select__collapse-tag{line-height:inherit;height:inherit;display:flex}.el-skeleton{--el-skeleton-circle-size:var(--el-avatar-size)}.el-skeleton__item{background:var(--el-skeleton-color);display:inline-block;height:16px;border-radius:var(--el-border-radius-base);width:100%}.el-skeleton__circle{border-radius:50%;width:var(--el-skeleton-circle-size);height:var(--el-skeleton-circle-size);line-height:var(--el-skeleton-circle-size)}.el-skeleton__button{height:40px;width:64px;border-radius:4px}.el-skeleton__p{width:100%}.el-skeleton__p.is-last{width:61%}.el-skeleton__p.is-first{width:33%}.el-skeleton__text{width:100%;height:var(--el-font-size-small)}.el-skeleton__caption{height:var(--el-font-size-extra-small)}.el-skeleton__h1{height:var(--el-font-size-extra-large)}.el-skeleton__h3{height:var(--el-font-size-large)}.el-skeleton__h5{height:var(--el-font-size-medium)}.el-skeleton__image{width:unset;display:flex;align-items:center;justify-content:center;border-radius:0}.el-skeleton__image svg{color:var(--el-svg-monochrome-grey);fill:currentColor;width:22%;height:22%}.el-skeleton{--el-skeleton-color:var(--el-fill-color);--el-skeleton-to-color:var(--el-fill-color-darker)}@-webkit-keyframes el-skeleton-loading{0%{background-position:100% 50%}to{background-position:0 50%}}@keyframes el-skeleton-loading{0%{background-position:100% 50%}to{background-position:0 50%}}.el-skeleton{width:100%}.el-skeleton__first-line,.el-skeleton__paragraph{height:16px;margin-top:16px;background:var(--el-skeleton-color)}.el-skeleton.is-animated .el-skeleton__item{background:linear-gradient(90deg,var(--el-skeleton-color) 25%,var(--el-skeleton-to-color) 37%,var(--el-skeleton-color) 63%);background-size:400% 100%;-webkit-animation:el-skeleton-loading 1.4s ease infinite;animation:el-skeleton-loading 1.4s ease infinite}.el-slider{--el-slider-main-bg-color:var(--el-color-primary);--el-slider-runway-bg-color:var(--el-border-color-light);--el-slider-stop-bg-color:var(--el-color-white);--el-slider-disabled-color:var(--el-text-color-placeholder);--el-slider-border-radius:3px;--el-slider-height:6px;--el-slider-button-size:20px;--el-slider-button-wrapper-size:36px;--el-slider-button-wrapper-offset:-15px}.el-slider{width:100%;height:32px;display:flex;align-items:center}.el-slider__runway{flex:1;height:var(--el-slider-height);background-color:var(--el-slider-runway-bg-color);border-radius:var(--el-slider-border-radius);position:relative;cursor:pointer}.el-slider__runway.show-input{margin-right:30px;width:auto}.el-slider__runway.is-disabled{cursor:default}.el-slider__runway.is-disabled .el-slider__bar{background-color:var(--el-slider-disabled-color)}.el-slider__runway.is-disabled .el-slider__button{border-color:var(--el-slider-disabled-color)}.el-slider__runway.is-disabled .el-slider__button-wrapper.hover,.el-slider__runway.is-disabled .el-slider__button-wrapper:hover,.el-slider__runway.is-disabled .el-slider__button-wrapper.dragging{cursor:not-allowed}.el-slider__runway.is-disabled .el-slider__button.dragging,.el-slider__runway.is-disabled .el-slider__button.hover,.el-slider__runway.is-disabled .el-slider__button:hover{transform:scale(1)}.el-slider__runway.is-disabled .el-slider__button.hover,.el-slider__runway.is-disabled .el-slider__button:hover,.el-slider__runway.is-disabled .el-slider__button.dragging{cursor:not-allowed}.el-slider__input{flex-shrink:0;width:130px}.el-slider__bar{height:var(--el-slider-height);background-color:var(--el-slider-main-bg-color);border-top-left-radius:var(--el-slider-border-radius);border-bottom-left-radius:var(--el-slider-border-radius);position:absolute}.el-slider__button-wrapper{height:var(--el-slider-button-wrapper-size);width:var(--el-slider-button-wrapper-size);position:absolute;z-index:1;top:var(--el-slider-button-wrapper-offset);transform:translate(-50%);background-color:transparent;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;line-height:normal;outline:0}.el-slider__button-wrapper:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-slider__button-wrapper.hover,.el-slider__button-wrapper:hover{cursor:-webkit-grab;cursor:grab}.el-slider__button-wrapper.dragging{cursor:-webkit-grabbing;cursor:grabbing}.el-slider__button{display:inline-block;width:var(--el-slider-button-size);height:var(--el-slider-button-size);vertical-align:middle;border:solid 2px var(--el-slider-main-bg-color);background-color:var(--el-color-white);border-radius:50%;box-sizing:border-box;transition:var(--el-transition-duration-fast);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-slider__button.dragging,.el-slider__button.hover,.el-slider__button:hover{transform:scale(1.2)}.el-slider__button.hover,.el-slider__button:hover{cursor:-webkit-grab;cursor:grab}.el-slider__button.dragging{cursor:-webkit-grabbing;cursor:grabbing}.el-slider__stop{position:absolute;height:var(--el-slider-height);width:var(--el-slider-height);border-radius:var(--el-border-radius-circle);background-color:var(--el-slider-stop-bg-color);transform:translate(-50%)}.el-slider__marks{top:0;left:12px;width:18px;height:100%}.el-slider__marks-text{position:absolute;transform:translate(-50%);font-size:14px;color:var(--el-color-info);margin-top:15px;white-space:pre}.el-slider.is-vertical{position:relative;display:inline-flex;width:auto;height:100%;flex:0}.el-slider.is-vertical .el-slider__runway{width:var(--el-slider-height);height:100%;margin:0 16px}.el-slider.is-vertical .el-slider__bar{width:var(--el-slider-height);height:auto;border-radius:0 0 3px 3px}.el-slider.is-vertical .el-slider__button-wrapper{top:auto;left:var(--el-slider-button-wrapper-offset);transform:translateY(50%)}.el-slider.is-vertical .el-slider__stop{transform:translateY(50%)}.el-slider.is-vertical .el-slider__marks-text{margin-top:0;left:15px;transform:translateY(50%)}.el-slider--large{height:40px}.el-slider--small{height:24px}.el-space{display:inline-flex;vertical-align:top}.el-space__item{display:flex;flex-wrap:wrap}.el-space__item>*{flex:1}.el-space--vertical{flex-direction:column}.el-time-spinner{width:100%;white-space:nowrap}.el-spinner{display:inline-block;vertical-align:middle}.el-spinner-inner{-webkit-animation:rotate 2s linear infinite;animation:rotate 2s linear infinite;width:50px;height:50px}.el-spinner-inner .path{stroke:var(--el-border-color-lighter);stroke-linecap:round;-webkit-animation:dash 1.5s ease-in-out infinite;animation:dash 1.5s ease-in-out infinite}@-webkit-keyframes rotate{to{transform:rotate(360deg)}}@keyframes rotate{to{transform:rotate(360deg)}}@-webkit-keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}@keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.el-step{position:relative;flex-shrink:1}.el-step:last-of-type .el-step__line{display:none}.el-step:last-of-type.is-flex{flex-basis:auto!important;flex-shrink:0;flex-grow:0}.el-step:last-of-type .el-step__description,.el-step:last-of-type .el-step__main{padding-right:0}.el-step__head{position:relative;width:100%}.el-step__head.is-process{color:var(--el-text-color-primary);border-color:var(--el-text-color-primary)}.el-step__head.is-wait{color:var(--el-text-color-placeholder);border-color:var(--el-text-color-placeholder)}.el-step__head.is-success{color:var(--el-color-success);border-color:var(--el-color-success)}.el-step__head.is-error{color:var(--el-color-danger);border-color:var(--el-color-danger)}.el-step__head.is-finish{color:var(--el-color-primary);border-color:var(--el-color-primary)}.el-step__icon{position:relative;z-index:1;display:inline-flex;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;box-sizing:border-box;background:var(--el-bg-color);transition:.15s ease-out}.el-step__icon.is-text{border-radius:50%;border:2px solid;border-color:inherit}.el-step__icon.is-icon{width:40px}.el-step__icon-inner{display:inline-block;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;text-align:center;font-weight:700;line-height:1;color:inherit}.el-step__icon-inner[class*=el-icon]:not(.is-status){font-size:25px;font-weight:400}.el-step__icon-inner.is-status{transform:translateY(1px)}.el-step__line{position:absolute;border-color:inherit;background-color:var(--el-text-color-placeholder)}.el-step__line-inner{display:block;border-width:1px;border-style:solid;border-color:inherit;transition:.15s ease-out;box-sizing:border-box;width:0;height:0}.el-step__main{white-space:normal;text-align:left}.el-step__title{font-size:16px;line-height:38px}.el-step__title.is-process{font-weight:700;color:var(--el-text-color-primary)}.el-step__title.is-wait{color:var(--el-text-color-placeholder)}.el-step__title.is-success{color:var(--el-color-success)}.el-step__title.is-error{color:var(--el-color-danger)}.el-step__title.is-finish{color:var(--el-color-primary)}.el-step__description{padding-right:10%;margin-top:-5px;font-size:12px;line-height:20px;font-weight:400}.el-step__description.is-process{color:var(--el-text-color-primary)}.el-step__description.is-wait{color:var(--el-text-color-placeholder)}.el-step__description.is-success{color:var(--el-color-success)}.el-step__description.is-error{color:var(--el-color-danger)}.el-step__description.is-finish{color:var(--el-color-primary)}.el-step.is-horizontal{display:inline-block}.el-step.is-horizontal .el-step__line{height:2px;top:11px;left:0;right:0}.el-step.is-vertical{display:flex}.el-step.is-vertical .el-step__head{flex-grow:0;width:24px}.el-step.is-vertical .el-step__main{padding-left:10px;flex-grow:1}.el-step.is-vertical .el-step__title{line-height:24px;padding-bottom:8px}.el-step.is-vertical .el-step__line{width:2px;top:0;bottom:0;left:11px}.el-step.is-vertical .el-step__icon.is-icon{width:24px}.el-step.is-center .el-step__head,.el-step.is-center .el-step__main{text-align:center}.el-step.is-center .el-step__description{padding-left:20%;padding-right:20%}.el-step.is-center .el-step__line{left:50%;right:-50%}.el-step.is-simple{display:flex;align-items:center}.el-step.is-simple .el-step__head{width:auto;font-size:0;padding-right:10px}.el-step.is-simple .el-step__icon{background:0 0;width:16px;height:16px;font-size:12px}.el-step.is-simple .el-step__icon-inner[class*=el-icon]:not(.is-status){font-size:18px}.el-step.is-simple .el-step__icon-inner.is-status{transform:scale(.8) translateY(1px)}.el-step.is-simple .el-step__main{position:relative;display:flex;align-items:stretch;flex-grow:1}.el-step.is-simple .el-step__title{font-size:16px;line-height:20px}.el-step.is-simple:not(:last-of-type) .el-step__title{max-width:50%;word-break:break-all}.el-step.is-simple .el-step__arrow{flex-grow:1;display:flex;align-items:center;justify-content:center}.el-step.is-simple .el-step__arrow:after,.el-step.is-simple .el-step__arrow:before{content:"";display:inline-block;position:absolute;height:15px;width:1px;background:var(--el-text-color-placeholder)}.el-step.is-simple .el-step__arrow:before{transform:rotate(-45deg) translateY(-4px);transform-origin:0 0}.el-step.is-simple .el-step__arrow:after{transform:rotate(45deg) translateY(4px);transform-origin:100% 100%}.el-step.is-simple:last-of-type .el-step__arrow{display:none}.el-steps{display:flex}.el-steps--simple{padding:13px 8%;border-radius:4px;background:var(--el-fill-color-light)}.el-steps--horizontal{white-space:nowrap}.el-steps--vertical{height:100%;flex-flow:column}.el-switch{--el-switch-on-color:var(--el-color-primary);--el-switch-off-color:var(--el-border-color)}.el-switch{display:inline-flex;align-items:center;position:relative;font-size:14px;line-height:20px;height:32px;vertical-align:middle}.el-switch.is-disabled .el-switch__core,.el-switch.is-disabled .el-switch__label{cursor:not-allowed}.el-switch__label{transition:var(--el-transition-duration-fast);height:20px;display:inline-block;font-size:14px;font-weight:500;cursor:pointer;vertical-align:middle;color:var(--el-text-color-primary)}.el-switch__label.is-active{color:var(--el-color-primary)}.el-switch__label--left{margin-right:10px}.el-switch__label--right{margin-left:10px}.el-switch__label *{line-height:1;font-size:14px;display:inline-block}.el-switch__label .el-icon{height:inherit}.el-switch__label .el-icon svg{vertical-align:middle}.el-switch__input{position:absolute;width:0;height:0;opacity:0;margin:0}.el-switch__input:focus-visible~.el-switch__core{outline:2px solid var(--el-switch-on-color);outline-offset:1px}.el-switch__core{display:inline-flex;position:relative;align-items:center;min-width:40px;height:20px;border:1px solid var(--el-switch-border-color,var(--el-switch-off-color));outline:0;border-radius:10px;box-sizing:border-box;background:var(--el-switch-off-color);cursor:pointer;transition:border-color var(--el-transition-duration),background-color var(--el-transition-duration)}.el-switch__core .el-switch__inner{width:100%;transition:all var(--el-transition-duration);height:16px;display:flex;justify-content:center;align-items:center;overflow:hidden;padding:0 4px 0 18px}.el-switch__core .el-switch__inner .is-icon,.el-switch__core .el-switch__inner .is-text{font-size:12px;color:var(--el-color-white);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-switch__core .el-switch__action{position:absolute;left:1px;border-radius:var(--el-border-radius-circle);transition:all var(--el-transition-duration);width:16px;height:16px;background-color:var(--el-color-white);display:flex;justify-content:center;align-items:center;color:var(--el-switch-off-color)}.el-switch.is-checked .el-switch__core{border-color:var(--el-switch-border-color,var(--el-switch-on-color));background-color:var(--el-switch-on-color)}.el-switch.is-checked .el-switch__core .el-switch__action{left:calc(100% - 17px);color:var(--el-switch-on-color)}.el-switch.is-checked .el-switch__core .el-switch__inner{padding:0 18px 0 4px}.el-switch.is-disabled{opacity:.6}.el-switch--wide .el-switch__label.el-switch__label--left span{left:10px}.el-switch--wide .el-switch__label.el-switch__label--right span{right:10px}.el-switch .label-fade-enter-from,.el-switch .label-fade-leave-active{opacity:0}.el-switch--large{font-size:14px;line-height:24px;height:40px}.el-switch--large .el-switch__label{height:24px;font-size:14px}.el-switch--large .el-switch__label *{font-size:14px}.el-switch--large .el-switch__core{min-width:50px;height:24px;border-radius:12px}.el-switch--large .el-switch__core .el-switch__inner{height:20px;padding:0 6px 0 22px}.el-switch--large .el-switch__core .el-switch__action{width:20px;height:20px}.el-switch--large.is-checked .el-switch__core .el-switch__action{left:calc(100% - 21px)}.el-switch--large.is-checked .el-switch__core .el-switch__inner{padding:0 22px 0 6px}.el-switch--small{font-size:12px;line-height:16px;height:24px}.el-switch--small .el-switch__label{height:16px;font-size:12px}.el-switch--small .el-switch__label *{font-size:12px}.el-switch--small .el-switch__core{min-width:30px;height:16px;border-radius:8px}.el-switch--small .el-switch__core .el-switch__inner{height:12px;padding:0 2px 0 14px}.el-switch--small .el-switch__core .el-switch__action{width:12px;height:12px}.el-switch--small.is-checked .el-switch__core .el-switch__action{left:calc(100% - 13px)}.el-switch--small.is-checked .el-switch__core .el-switch__inner{padding:0 14px 0 2px}.el-table-column--selection .cell{padding-left:14px;padding-right:14px}.el-table-filter{border:solid 1px var(--el-border-color-lighter);border-radius:2px;background-color:#fff;box-shadow:var(--el-box-shadow-light);box-sizing:border-box}.el-table-filter__list{padding:5px 0;margin:0;list-style:none;min-width:100px}.el-table-filter__list-item{line-height:36px;padding:0 10px;cursor:pointer;font-size:var(--el-font-size-base)}.el-table-filter__list-item:hover{background-color:var(--el-color-primary-light-9);color:var(--el-color-primary)}.el-table-filter__list-item.is-active{background-color:var(--el-color-primary);color:#fff}.el-table-filter__content{min-width:100px}.el-table-filter__bottom{border-top:1px solid var(--el-border-color-lighter);padding:8px}.el-table-filter__bottom button{background:0 0;border:none;color:var(--el-text-color-regular);cursor:pointer;font-size:var(--el-font-size-small);padding:0 3px}.el-table-filter__bottom button:hover{color:var(--el-color-primary)}.el-table-filter__bottom button:focus{outline:0}.el-table-filter__bottom button.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-table-filter__wrap{max-height:280px}.el-table-filter__checkbox-group{padding:10px}.el-table-filter__checkbox-group label.el-checkbox{display:flex;align-items:center;margin-right:5px;margin-bottom:12px;margin-left:5px;height:unset}.el-table-filter__checkbox-group .el-checkbox:last-child{margin-bottom:0}.el-table{--el-table-border-color:var(--el-border-color-lighter);--el-table-border:1px solid var(--el-table-border-color);--el-table-text-color:var(--el-text-color-regular);--el-table-header-text-color:var(--el-text-color-secondary);--el-table-row-hover-bg-color:var(--el-fill-color-light);--el-table-current-row-bg-color:var(--el-color-primary-light-9);--el-table-header-bg-color:var(--el-bg-color);--el-table-fixed-box-shadow:var(--el-box-shadow-light);--el-table-bg-color:var(--el-fill-color-blank);--el-table-tr-bg-color:var(--el-fill-color-blank);--el-table-expanded-cell-bg-color:var(--el-fill-color-blank);--el-table-fixed-left-column:inset 10px 0 10px -10px rgba(0, 0, 0, .15);--el-table-fixed-right-column:inset -10px 0 10px -10px rgba(0, 0, 0, .15)}.el-table{position:relative;overflow:hidden;box-sizing:border-box;height:-webkit-fit-content;height:-moz-fit-content;height:fit-content;width:100%;max-width:100%;background-color:var(--el-table-bg-color);font-size:14px;color:var(--el-table-text-color)}.el-table__inner-wrapper{position:relative;display:flex;flex-direction:column;height:100%}.el-table__inner-wrapper:before{left:0;bottom:0;width:100%;height:1px}.el-table.has-footer.el-table--fluid-height tr:last-child td.el-table__cell,.el-table.has-footer.el-table--scrollable-y tr:last-child td.el-table__cell{border-bottom-color:transparent}.el-table__empty-block{position:-webkit-sticky;position:sticky;left:0;min-height:60px;text-align:center;width:100%;display:flex;justify-content:center;align-items:center}.el-table__empty-text{line-height:60px;width:50%;color:var(--el-text-color-secondary)}.el-table__expand-column .cell{padding:0;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-table__expand-icon{position:relative;cursor:pointer;color:var(--el-text-color-regular);font-size:12px;transition:transform var(--el-transition-duration-fast) ease-in-out;height:20px}.el-table__expand-icon--expanded{transform:rotate(90deg)}.el-table__expand-icon>.el-icon{font-size:12px}.el-table__expanded-cell{background-color:var(--el-table-expanded-cell-bg-color)}.el-table__expanded-cell[class*=cell]{padding:20px 50px}.el-table__expanded-cell:hover{background-color:transparent!important}.el-table__placeholder{display:inline-block;width:20px}.el-table__append-wrapper{overflow:hidden}.el-table--fit{border-right:0;border-bottom:0}.el-table--fit .el-table__cell.gutter{border-right-width:1px}.el-table thead{color:var(--el-table-header-text-color);font-weight:500}.el-table thead.is-group th.el-table__cell{background:var(--el-fill-color-light)}.el-table .el-table__cell{padding:8px 0;min-width:0;box-sizing:border-box;text-overflow:ellipsis;vertical-align:middle;position:relative;text-align:left;z-index:1}.el-table .el-table__cell.is-center{text-align:center}.el-table .el-table__cell.is-right{text-align:right}.el-table .el-table__cell.gutter{width:15px;border-right-width:0;border-bottom-width:0;padding:0}.el-table .el-table__cell.is-hidden>*{visibility:hidden}.el-table .cell{box-sizing:border-box;overflow:hidden;text-overflow:ellipsis;white-space:normal;word-break:break-all;line-height:23px;padding:0 12px}.el-table .cell.el-tooltip{white-space:nowrap;min-width:50px}.el-table--large{font-size:var(--el-font-size-base)}.el-table--large .el-table__cell{padding:12px 0}.el-table--large .cell{padding:0 16px}.el-table--default{font-size:14px}.el-table--default .el-table__cell{padding:8px 0}.el-table--default .cell{padding:0 12px}.el-table--small{font-size:12px}.el-table--small .el-table__cell{padding:4px 0}.el-table--small .cell{padding:0 8px}.el-table tr{background-color:var(--el-table-tr-bg-color)}.el-table tr input[type=checkbox]{margin:0}.el-table td.el-table__cell,.el-table th.el-table__cell.is-leaf{border-bottom:var(--el-table-border)}.el-table th.el-table__cell.is-sortable{cursor:pointer}.el-table th.el-table__cell{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:var(--el-table-header-bg-color)}.el-table th.el-table__cell>.cell.highlight{color:var(--el-color-primary)}.el-table th.el-table__cell.required>div:before{display:inline-block;content:"";width:8px;height:8px;border-radius:50%;background:#ff4d51;margin-right:5px;vertical-align:middle}.el-table td.el-table__cell div{box-sizing:border-box}.el-table td.el-table__cell.gutter{width:0}.el-table__footer-wrapper{border-top:var(--el-table-border)}.el-table--border .el-table__inner-wrapper:after,.el-table--border:after,.el-table--border:before,.el-table__inner-wrapper:before{content:"";position:absolute;background-color:var(--el-table-border-color);z-index:3}.el-table--border .el-table__inner-wrapper:after{left:0;top:0;width:100%;height:1px}.el-table--border:before{top:-1px;left:0;width:1px;height:100%}.el-table--border:after{top:-1px;right:0;width:1px;height:100%}.el-table--border .el-table__inner-wrapper{border-right:none;border-bottom:none}.el-table--border .el-table__footer-wrapper{position:relative;flex-shrink:0}.el-table--border .el-table__cell{border-right:var(--el-table-border)}.el-table--border th.el-table__cell.gutter:last-of-type{border-bottom:var(--el-table-border);border-bottom-width:1px}.el-table--border th.el-table__cell{border-bottom:var(--el-table-border)}.el-table--hidden{visibility:hidden}.el-table__body-wrapper,.el-table__footer-wrapper,.el-table__header-wrapper{width:100%}.el-table__body-wrapper tr td.el-table-fixed-column--left,.el-table__body-wrapper tr td.el-table-fixed-column--right,.el-table__body-wrapper tr th.el-table-fixed-column--left,.el-table__body-wrapper tr th.el-table-fixed-column--right,.el-table__footer-wrapper tr td.el-table-fixed-column--left,.el-table__footer-wrapper tr td.el-table-fixed-column--right,.el-table__footer-wrapper tr th.el-table-fixed-column--left,.el-table__footer-wrapper tr th.el-table-fixed-column--right,.el-table__header-wrapper tr td.el-table-fixed-column--left,.el-table__header-wrapper tr td.el-table-fixed-column--right,.el-table__header-wrapper tr th.el-table-fixed-column--left,.el-table__header-wrapper tr th.el-table-fixed-column--right{position:-webkit-sticky!important;position:sticky!important;z-index:2;background:var(--el-bg-color)}.el-table__body-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-last-column:before{content:"";position:absolute;top:0;width:10px;bottom:-1px;overflow-x:hidden;overflow-y:hidden;box-shadow:none;touch-action:none;pointer-events:none}.el-table__body-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-first-column:before{left:-10px}.el-table__body-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-last-column:before{right:-10px;box-shadow:none}.el-table__body-wrapper tr td.el-table__fixed-right-patch,.el-table__body-wrapper tr th.el-table__fixed-right-patch,.el-table__footer-wrapper tr td.el-table__fixed-right-patch,.el-table__footer-wrapper tr th.el-table__fixed-right-patch,.el-table__header-wrapper tr td.el-table__fixed-right-patch,.el-table__header-wrapper tr th.el-table__fixed-right-patch{position:-webkit-sticky!important;position:sticky!important;z-index:2;background:#fff;right:0}.el-table__header-wrapper{flex-shrink:0}.el-table__header-wrapper tr th.el-table-fixed-column--left,.el-table__header-wrapper tr th.el-table-fixed-column--right{background-color:var(--el-table-header-bg-color)}.el-table__body,.el-table__footer,.el-table__header{table-layout:fixed;border-collapse:separate}.el-table__footer-wrapper,.el-table__header-wrapper{overflow:hidden}.el-table__footer-wrapper tbody td.el-table__cell,.el-table__header-wrapper tbody td.el-table__cell{background-color:var(--el-table-row-hover-bg-color);color:var(--el-table-text-color)}.el-table__body-wrapper .el-table-column--selection>.cell,.el-table__header-wrapper .el-table-column--selection>.cell{display:inline-flex;align-items:center;height:23px}.el-table__body-wrapper .el-table-column--selection .el-checkbox,.el-table__header-wrapper .el-table-column--selection .el-checkbox{height:unset}.el-table.is-scrolling-left .el-table-fixed-column--right.is-first-column:before{box-shadow:var(--el-table-fixed-right-column)}.el-table.is-scrolling-left.el-table--border .el-table-fixed-column--left.is-last-column.el-table__cell{border-right:var(--el-table-border)}.el-table.is-scrolling-left th.el-table-fixed-column--left{background-color:var(--el-table-header-bg-color)}.el-table.is-scrolling-right .el-table-fixed-column--left.is-last-column:before{box-shadow:var(--el-table-fixed-left-column)}.el-table.is-scrolling-right .el-table-fixed-column--left.is-last-column.el-table__cell{border-right:none}.el-table.is-scrolling-right th.el-table-fixed-column--right{background-color:var(--el-table-header-bg-color)}.el-table.is-scrolling-middle .el-table-fixed-column--left.is-last-column.el-table__cell{border-right:none}.el-table.is-scrolling-middle .el-table-fixed-column--right.is-first-column:before{box-shadow:var(--el-table-fixed-right-column)}.el-table.is-scrolling-middle .el-table-fixed-column--left.is-last-column:before{box-shadow:var(--el-table-fixed-left-column)}.el-table.is-scrolling-none .el-table-fixed-column--left.is-first-column:before,.el-table.is-scrolling-none .el-table-fixed-column--left.is-last-column:before,.el-table.is-scrolling-none .el-table-fixed-column--right.is-first-column:before,.el-table.is-scrolling-none .el-table-fixed-column--right.is-last-column:before{box-shadow:none}.el-table.is-scrolling-none th.el-table-fixed-column--left,.el-table.is-scrolling-none th.el-table-fixed-column--right{background-color:var(--el-table-header-bg-color)}.el-table__body-wrapper{overflow:hidden;position:relative;flex:1}.el-table__body-wrapper .el-scrollbar__bar{z-index:2}.el-table .caret-wrapper{display:inline-flex;flex-direction:column;align-items:center;height:14px;width:24px;vertical-align:middle;cursor:pointer;overflow:initial;position:relative}.el-table .sort-caret{width:0;height:0;border:solid 5px transparent;position:absolute;left:7px}.el-table .sort-caret.ascending{border-bottom-color:var(--el-text-color-placeholder);top:-5px}.el-table .sort-caret.descending{border-top-color:var(--el-text-color-placeholder);bottom:-3px}.el-table .ascending .sort-caret.ascending{border-bottom-color:var(--el-color-primary)}.el-table .descending .sort-caret.descending{border-top-color:var(--el-color-primary)}.el-table .hidden-columns{visibility:hidden;position:absolute;z-index:-1}.el-table--striped .el-table__body tr.el-table__row--striped td.el-table__cell{background:var(--el-fill-color-lighter)}.el-table--striped .el-table__body tr.el-table__row--striped.current-row td.el-table__cell{background-color:var(--el-table-current-row-bg-color)}.el-table__body tr.hover-row.current-row>td.el-table__cell,.el-table__body tr.hover-row.el-table__row--striped.current-row>td.el-table__cell,.el-table__body tr.hover-row.el-table__row--striped>td.el-table__cell,.el-table__body tr.hover-row>td.el-table__cell{background-color:var(--el-table-row-hover-bg-color)}.el-table__body tr.current-row>td.el-table__cell{background-color:var(--el-table-current-row-bg-color)}.el-table__column-resize-proxy{position:absolute;left:200px;top:0;bottom:0;width:0;border-left:var(--el-table-border);z-index:10}.el-table__column-filter-trigger{display:inline-block;cursor:pointer}.el-table__column-filter-trigger i{color:var(--el-color-info);font-size:14px;vertical-align:middle}.el-table__border-left-patch{top:0;left:0;width:1px;height:100%;z-index:3;position:absolute;background-color:var(--el-table-border-color)}.el-table__border-bottom-patch{left:0;height:1px;z-index:3;position:absolute;background-color:var(--el-table-border-color)}.el-table__border-right-patch{top:0;height:100%;width:1px;z-index:3;position:absolute;background-color:var(--el-table-border-color)}.el-table--enable-row-transition .el-table__body td.el-table__cell{transition:background-color .25s ease}.el-table--enable-row-hover .el-table__body tr:hover>td.el-table__cell{background-color:var(--el-table-row-hover-bg-color)}.el-table [class*=el-table__row--level] .el-table__expand-icon{display:inline-block;width:12px;line-height:12px;height:12px;text-align:center;margin-right:8px}.el-table .el-table.el-table--border .el-table__cell{border-right:var(--el-table-border)}.el-table:not(.el-table--border) .el-table__cell{border-right:none}.el-table:not(.el-table--border)>.el-table__inner-wrapper:after{content:none}.el-table-v2{--el-table-border-color:var(--el-border-color-lighter);--el-table-border:1px solid var(--el-table-border-color);--el-table-text-color:var(--el-text-color-regular);--el-table-header-text-color:var(--el-text-color-secondary);--el-table-row-hover-bg-color:var(--el-fill-color-light);--el-table-current-row-bg-color:var(--el-color-primary-light-9);--el-table-header-bg-color:var(--el-bg-color);--el-table-fixed-box-shadow:var(--el-box-shadow-light);--el-table-bg-color:var(--el-fill-color-blank);--el-table-tr-bg-color:var(--el-fill-color-blank);--el-table-expanded-cell-bg-color:var(--el-fill-color-blank);--el-table-fixed-left-column:inset 10px 0 10px -10px rgba(0, 0, 0, .15);--el-table-fixed-right-column:inset -10px 0 10px -10px rgba(0, 0, 0, .15)}.el-table-v2{font-size:14px}.el-table-v2 *{box-sizing:border-box}.el-table-v2__root{position:relative}.el-table-v2__root:hover .el-table-v2__main .el-virtual-scrollbar{opacity:1}.el-table-v2__main{display:flex;flex-direction:column-reverse;position:absolute;overflow:hidden;top:0;background-color:var(--el-bg-color);left:0}.el-table-v2__main .el-vl__horizontal,.el-table-v2__main .el-vl__vertical{z-index:2}.el-table-v2__left{display:flex;flex-direction:column-reverse;position:absolute;overflow:hidden;top:0;background-color:var(--el-bg-color);left:0;box-shadow:2px 0 4px #0000000f}.el-table-v2__left .el-virtual-scrollbar{opacity:0}.el-table-v2__left .el-vl__horizontal,.el-table-v2__left .el-vl__vertical{z-index:-1}.el-table-v2__right{display:flex;flex-direction:column-reverse;position:absolute;overflow:hidden;top:0;background-color:var(--el-bg-color);right:0;box-shadow:-2px 0 4px #0000000f}.el-table-v2__right .el-virtual-scrollbar{opacity:0}.el-table-v2__right .el-vl__horizontal,.el-table-v2__right .el-vl__vertical{z-index:-1}.el-table-v2__header-row,.el-table-v2__row{-webkit-padding-end:var(--el-table-scrollbar-size);padding-inline-end:var(--el-table-scrollbar-size)}.el-table-v2__header-wrapper{overflow:hidden}.el-table-v2__header{position:relative;overflow:hidden}.el-table-v2__footer{position:absolute;left:0;right:0;bottom:0;overflow:hidden}.el-table-v2__empty{position:absolute;left:0}.el-table-v2__overlay{position:absolute;left:0;right:0;top:0;bottom:0;z-index:9999}.el-table-v2__header-row{display:flex;border-bottom:var(--el-table-border)}.el-table-v2__header-cell{display:flex;align-items:center;padding:0 8px;height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;background-color:var(--el-table-header-bg-color);color:var(--el-table-header-text-color);font-weight:700}.el-table-v2__header-cell.is-align-center{justify-content:center;text-align:center}.el-table-v2__header-cell.is-align-right{justify-content:flex-end;text-align:right}.el-table-v2__header-cell.is-sortable{cursor:pointer}.el-table-v2__header-cell:hover .el-icon{display:block}.el-table-v2__sort-icon{transition:opacity,display var(--el-transition-duration);opacity:.6;display:none}.el-table-v2__sort-icon.is-sorting{display:block;opacity:1}.el-table-v2__row{border-bottom:var(--el-table-border);display:flex;align-items:center;transition:background-color var(--el-transition-duration)}.el-table-v2__row.is-hovered,.el-table-v2__row:hover{background-color:var(--el-table-row-hover-bg-color)}.el-table-v2__row-cell{height:100%;overflow:hidden;display:flex;align-items:center;padding:0 8px}.el-table-v2__row-cell.is-align-center{justify-content:center;text-align:center}.el-table-v2__row-cell.is-align-right{justify-content:flex-end;text-align:right}.el-table-v2__expand-icon{margin:0 4px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-table-v2__expand-icon svg{transition:transform var(--el-transition-duration)}.el-table-v2__expand-icon.is-expanded svg{transform:rotate(90deg)}.el-table-v2:not(.is-dynamic) .el-table-v2__cell-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-table-v2.is-dynamic .el-table-v2__row{overflow:hidden;align-items:stretch}.el-table-v2.is-dynamic .el-table-v2__row .el-table-v2__row-cell{word-break:break-all}.el-tabs{--el-tabs-header-height:40px}.el-tabs__header{padding:0;position:relative;margin:0 0 15px}.el-tabs__active-bar{position:absolute;bottom:0;left:0;height:2px;background-color:var(--el-color-primary);z-index:1;transition:width var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier),transform var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);list-style:none}.el-tabs__new-tab{display:flex;align-items:center;justify-content:center;float:right;border:1px solid var(--el-border-color);height:20px;width:20px;line-height:20px;margin:10px 0 10px 10px;border-radius:3px;text-align:center;font-size:12px;color:var(--el-text-color-primary);cursor:pointer;transition:all .15s}.el-tabs__new-tab .is-icon-plus{height:inherit;width:inherit;transform:scale(.8)}.el-tabs__new-tab .is-icon-plus svg{vertical-align:middle}.el-tabs__new-tab:hover{color:var(--el-color-primary)}.el-tabs__nav-wrap{overflow:hidden;margin-bottom:-1px;position:relative}.el-tabs__nav-wrap:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background-color:var(--el-border-color-light);z-index:var(--el-index-normal)}.el-tabs__nav-wrap.is-scrollable{padding:0 20px;box-sizing:border-box}.el-tabs__nav-scroll{overflow:hidden}.el-tabs__nav-next,.el-tabs__nav-prev{position:absolute;cursor:pointer;line-height:44px;font-size:12px;color:var(--el-text-color-secondary);width:20px;text-align:center}.el-tabs__nav-next{right:0}.el-tabs__nav-prev{left:0}.el-tabs__nav{display:flex;white-space:nowrap;position:relative;transition:transform var(--el-transition-duration);float:left;z-index:calc(var(--el-index-normal) + 1)}.el-tabs__nav.is-stretch{min-width:100%;display:flex}.el-tabs__nav.is-stretch>*{flex:1;text-align:center}.el-tabs__item{padding:0 20px;height:var(--el-tabs-header-height);box-sizing:border-box;display:flex;align-items:center;justify-content:center;list-style:none;font-size:var(--el-font-size-base);font-weight:500;color:var(--el-text-color-primary);position:relative}.el-tabs__item:focus,.el-tabs__item:focus:active{outline:0}.el-tabs__item:focus-visible{box-shadow:0 0 2px 2px var(--el-color-primary) inset;border-radius:3px}.el-tabs__item .is-icon-close{border-radius:50%;text-align:center;transition:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);margin-left:5px}.el-tabs__item .is-icon-close:before{transform:scale(.9);display:inline-block}.el-tabs__item .is-icon-close:hover{background-color:var(--el-text-color-placeholder);color:#fff}.el-tabs__item.is-active{color:var(--el-color-primary)}.el-tabs__item:hover{color:var(--el-color-primary);cursor:pointer}.el-tabs__item.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-tabs__content{overflow:hidden;position:relative}.el-tabs--card>.el-tabs__header{border-bottom:1px solid var(--el-border-color-light);height:var(--el-tabs-header-height)}.el-tabs--card>.el-tabs__header .el-tabs__nav-wrap:after{content:none}.el-tabs--card>.el-tabs__header .el-tabs__nav{border:1px solid var(--el-border-color-light);border-bottom:none;border-radius:4px 4px 0 0;box-sizing:border-box}.el-tabs--card>.el-tabs__header .el-tabs__active-bar{display:none}.el-tabs--card>.el-tabs__header .el-tabs__item .is-icon-close{position:relative;font-size:12px;width:0;height:14px;overflow:hidden;right:-2px;transform-origin:100% 50%}.el-tabs--card>.el-tabs__header .el-tabs__item{border-bottom:1px solid transparent;border-left:1px solid var(--el-border-color-light);transition:color var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier),padding var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier)}.el-tabs--card>.el-tabs__header .el-tabs__item:first-child{border-left:none}.el-tabs--card>.el-tabs__header .el-tabs__item.is-closable:hover{padding-left:13px;padding-right:13px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-closable:hover .is-icon-close{width:14px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active{border-bottom-color:var(--el-bg-color)}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active.is-closable{padding-left:20px;padding-right:20px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active.is-closable .is-icon-close{width:14px}.el-tabs--border-card{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color)}.el-tabs--border-card>.el-tabs__content{padding:15px}.el-tabs--border-card>.el-tabs__header{background-color:var(--el-fill-color-light);border-bottom:1px solid var(--el-border-color-light);margin:0}.el-tabs--border-card>.el-tabs__header .el-tabs__nav-wrap:after{content:none}.el-tabs--border-card>.el-tabs__header .el-tabs__item{transition:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);border:1px solid transparent;margin-top:-1px;color:var(--el-text-color-secondary)}.el-tabs--border-card>.el-tabs__header .el-tabs__item:first-child{margin-left:-1px}.el-tabs--border-card>.el-tabs__header .el-tabs__item+.el-tabs__item{margin-left:-1px}.el-tabs--border-card>.el-tabs__header .el-tabs__item.is-active{color:var(--el-color-primary);background-color:var(--el-bg-color-overlay);border-right-color:var(--el-border-color);border-left-color:var(--el-border-color)}.el-tabs--border-card>.el-tabs__header .el-tabs__item:not(.is-disabled):hover{color:var(--el-color-primary)}.el-tabs--border-card>.el-tabs__header .el-tabs__item.is-disabled{color:var(--el-disabled-text-color)}.el-tabs--border-card>.el-tabs__header .is-scrollable .el-tabs__item:first-child{margin-left:0}.el-tabs--bottom .el-tabs__item.is-bottom:nth-child(2),.el-tabs--bottom .el-tabs__item.is-top:nth-child(2),.el-tabs--top .el-tabs__item.is-bottom:nth-child(2),.el-tabs--top .el-tabs__item.is-top:nth-child(2){padding-left:0}.el-tabs--bottom .el-tabs__item.is-bottom:last-child,.el-tabs--bottom .el-tabs__item.is-top:last-child,.el-tabs--top .el-tabs__item.is-bottom:last-child,.el-tabs--top .el-tabs__item.is-top:last-child{padding-right:0}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2){padding-left:20px}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover{padding-left:13px}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:last-child,.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:last-child,.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:last-child{padding-right:20px}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover{padding-right:13px}.el-tabs--bottom .el-tabs__header.is-bottom{margin-bottom:0;margin-top:10px}.el-tabs--bottom.el-tabs--border-card .el-tabs__header.is-bottom{border-bottom:0;border-top:1px solid var(--el-border-color)}.el-tabs--bottom.el-tabs--border-card .el-tabs__nav-wrap.is-bottom{margin-top:-1px;margin-bottom:0}.el-tabs--bottom.el-tabs--border-card .el-tabs__item.is-bottom:not(.is-active){border:1px solid transparent}.el-tabs--bottom.el-tabs--border-card .el-tabs__item.is-bottom{margin:0 -1px -1px}.el-tabs--left,.el-tabs--right{overflow:hidden}.el-tabs--left .el-tabs__header.is-left,.el-tabs--left .el-tabs__header.is-right,.el-tabs--left .el-tabs__nav-scroll,.el-tabs--left .el-tabs__nav-wrap.is-left,.el-tabs--left .el-tabs__nav-wrap.is-right,.el-tabs--right .el-tabs__header.is-left,.el-tabs--right .el-tabs__header.is-right,.el-tabs--right .el-tabs__nav-scroll,.el-tabs--right .el-tabs__nav-wrap.is-left,.el-tabs--right .el-tabs__nav-wrap.is-right{height:100%}.el-tabs--left .el-tabs__active-bar.is-left,.el-tabs--left .el-tabs__active-bar.is-right,.el-tabs--right .el-tabs__active-bar.is-left,.el-tabs--right .el-tabs__active-bar.is-right{top:0;bottom:auto;width:2px;height:auto}.el-tabs--left .el-tabs__nav-wrap.is-left,.el-tabs--left .el-tabs__nav-wrap.is-right,.el-tabs--right .el-tabs__nav-wrap.is-left,.el-tabs--right .el-tabs__nav-wrap.is-right{margin-bottom:0}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev{height:30px;line-height:30px;width:100%;text-align:center;cursor:pointer}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next i,.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev i,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next i,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev i,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next i,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev i,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next i,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev i{transform:rotate(90deg)}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev{left:auto;top:0}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next{right:auto;bottom:0}.el-tabs--left .el-tabs__nav-wrap.is-left.is-scrollable,.el-tabs--left .el-tabs__nav-wrap.is-right.is-scrollable,.el-tabs--right .el-tabs__nav-wrap.is-left.is-scrollable,.el-tabs--right .el-tabs__nav-wrap.is-right.is-scrollable{padding:30px 0}.el-tabs--left .el-tabs__nav-wrap.is-left:after,.el-tabs--left .el-tabs__nav-wrap.is-right:after,.el-tabs--right .el-tabs__nav-wrap.is-left:after,.el-tabs--right .el-tabs__nav-wrap.is-right:after{height:100%;width:2px;bottom:auto;top:0}.el-tabs--left .el-tabs__nav.is-left,.el-tabs--left .el-tabs__nav.is-right,.el-tabs--right .el-tabs__nav.is-left,.el-tabs--right .el-tabs__nav.is-right{flex-direction:column}.el-tabs--left .el-tabs__item.is-left,.el-tabs--right .el-tabs__item.is-left{justify-content:flex-end}.el-tabs--left .el-tabs__item.is-right,.el-tabs--right .el-tabs__item.is-right{justify-content:flex-start}.el-tabs--left .el-tabs__header.is-left{float:left;margin-bottom:0;margin-right:10px}.el-tabs--left .el-tabs__nav-wrap.is-left{margin-right:-1px}.el-tabs--left .el-tabs__nav-wrap.is-left:after{left:auto;right:0}.el-tabs--left .el-tabs__active-bar.is-left{right:0;left:auto}.el-tabs--left .el-tabs__item.is-left{text-align:right}.el-tabs--left.el-tabs--card .el-tabs__active-bar.is-left{display:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left{border-left:none;border-right:1px solid var(--el-border-color-light);border-bottom:none;border-top:1px solid var(--el-border-color-light);text-align:left}.el-tabs--left.el-tabs--card .el-tabs__item.is-left:first-child{border-right:1px solid var(--el-border-color-light);border-top:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active{border:1px solid var(--el-border-color-light);border-right-color:#fff;border-left:none;border-bottom:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active:first-child{border-top:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active:last-child{border-bottom:none}.el-tabs--left.el-tabs--card .el-tabs__nav{border-radius:4px 0 0 4px;border-bottom:1px solid var(--el-border-color-light);border-right:none}.el-tabs--left.el-tabs--card .el-tabs__new-tab{float:none}.el-tabs--left.el-tabs--border-card .el-tabs__header.is-left{border-right:1px solid var(--el-border-color)}.el-tabs--left.el-tabs--border-card .el-tabs__item.is-left{border:1px solid transparent;margin:-1px 0 -1px -1px}.el-tabs--left.el-tabs--border-card .el-tabs__item.is-left.is-active{border-color:transparent;border-top-color:#d1dbe5;border-bottom-color:#d1dbe5}.el-tabs--right .el-tabs__header.is-right{float:right;margin-bottom:0;margin-left:10px}.el-tabs--right .el-tabs__nav-wrap.is-right{margin-left:-1px}.el-tabs--right .el-tabs__nav-wrap.is-right:after{left:0;right:auto}.el-tabs--right .el-tabs__active-bar.is-right{left:0}.el-tabs--right.el-tabs--card .el-tabs__active-bar.is-right{display:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right{border-bottom:none;border-top:1px solid var(--el-border-color-light)}.el-tabs--right.el-tabs--card .el-tabs__item.is-right:first-child{border-left:1px solid var(--el-border-color-light);border-top:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active{border:1px solid var(--el-border-color-light);border-left-color:#fff;border-right:none;border-bottom:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active:first-child{border-top:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active:last-child{border-bottom:none}.el-tabs--right.el-tabs--card .el-tabs__nav{border-radius:0 4px 4px 0;border-bottom:1px solid var(--el-border-color-light);border-left:none}.el-tabs--right.el-tabs--border-card .el-tabs__header.is-right{border-left:1px solid var(--el-border-color)}.el-tabs--right.el-tabs--border-card .el-tabs__item.is-right{border:1px solid transparent;margin:-1px -1px -1px 0}.el-tabs--right.el-tabs--border-card .el-tabs__item.is-right.is-active{border-color:transparent;border-top-color:#d1dbe5;border-bottom-color:#d1dbe5}.slideInLeft-transition,.slideInRight-transition{display:inline-block}.slideInRight-enter{-webkit-animation:slideInRight-enter var(--el-transition-duration);animation:slideInRight-enter var(--el-transition-duration)}.slideInRight-leave{position:absolute;left:0;right:0;-webkit-animation:slideInRight-leave var(--el-transition-duration);animation:slideInRight-leave var(--el-transition-duration)}.slideInLeft-enter{-webkit-animation:slideInLeft-enter var(--el-transition-duration);animation:slideInLeft-enter var(--el-transition-duration)}.slideInLeft-leave{position:absolute;left:0;right:0;-webkit-animation:slideInLeft-leave var(--el-transition-duration);animation:slideInLeft-leave var(--el-transition-duration)}@-webkit-keyframes slideInRight-enter{0%{opacity:0;transform-origin:0 0;transform:translate(100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@keyframes slideInRight-enter{0%{opacity:0;transform-origin:0 0;transform:translate(100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@-webkit-keyframes slideInRight-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(100%);opacity:0}}@keyframes slideInRight-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(100%);opacity:0}}@-webkit-keyframes slideInLeft-enter{0%{opacity:0;transform-origin:0 0;transform:translate(-100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@keyframes slideInLeft-enter{0%{opacity:0;transform-origin:0 0;transform:translate(-100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@-webkit-keyframes slideInLeft-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(-100%);opacity:0}}@keyframes slideInLeft-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(-100%);opacity:0}}.el-tag{--el-tag-font-size:12px;--el-tag-border-radius:4px;--el-tag-border-radius-rounded:9999px}.el-tag{--el-tag-bg-color:var(--el-color-primary-light-9);--el-tag-border-color:var(--el-color-primary-light-8);--el-tag-hover-color:var(--el-color-primary);--el-tag-text-color:var(--el-color-primary);background-color:var(--el-tag-bg-color);border-color:var(--el-tag-border-color);color:var(--el-tag-text-color);display:inline-flex;justify-content:center;align-items:center;height:24px;padding:0 9px;font-size:var(--el-tag-font-size);line-height:1;border-width:1px;border-style:solid;border-radius:var(--el-tag-border-radius);box-sizing:border-box;white-space:nowrap;--el-icon-size:14px}.el-tag.el-tag--primary{--el-tag-bg-color:var(--el-color-primary-light-9);--el-tag-border-color:var(--el-color-primary-light-8);--el-tag-hover-color:var(--el-color-primary)}.el-tag.el-tag--success{--el-tag-bg-color:var(--el-color-success-light-9);--el-tag-border-color:var(--el-color-success-light-8);--el-tag-hover-color:var(--el-color-success)}.el-tag.el-tag--warning{--el-tag-bg-color:var(--el-color-warning-light-9);--el-tag-border-color:var(--el-color-warning-light-8);--el-tag-hover-color:var(--el-color-warning)}.el-tag.el-tag--danger{--el-tag-bg-color:var(--el-color-danger-light-9);--el-tag-border-color:var(--el-color-danger-light-8);--el-tag-hover-color:var(--el-color-danger)}.el-tag.el-tag--error{--el-tag-bg-color:var(--el-color-error-light-9);--el-tag-border-color:var(--el-color-error-light-8);--el-tag-hover-color:var(--el-color-error)}.el-tag.el-tag--info{--el-tag-bg-color:var(--el-color-info-light-9);--el-tag-border-color:var(--el-color-info-light-8);--el-tag-hover-color:var(--el-color-info)}.el-tag.el-tag--primary{--el-tag-text-color:var(--el-color-primary)}.el-tag.el-tag--success{--el-tag-text-color:var(--el-color-success)}.el-tag.el-tag--warning{--el-tag-text-color:var(--el-color-warning)}.el-tag.el-tag--danger{--el-tag-text-color:var(--el-color-danger)}.el-tag.el-tag--error{--el-tag-text-color:var(--el-color-error)}.el-tag.el-tag--info{--el-tag-text-color:var(--el-color-info)}.el-tag.is-hit{border-color:var(--el-color-primary)}.el-tag.is-round{border-radius:var(--el-tag-border-radius-rounded)}.el-tag .el-tag__close{color:var(--el-tag-text-color)}.el-tag .el-tag__close:hover{color:var(--el-color-white);background-color:var(--el-tag-hover-color)}.el-tag .el-icon{border-radius:50%;cursor:pointer;font-size:calc(var(--el-icon-size) - 2px);height:var(--el-icon-size);width:var(--el-icon-size)}.el-tag .el-tag__close{margin-left:6px}.el-tag--dark{--el-tag-bg-color:var(--el-color-primary);--el-tag-border-color:var(--el-color-primary);--el-tag-hover-color:var(--el-color-primary-light-3);--el-tag-text-color:var(--el-color-white)}.el-tag--dark.el-tag--primary{--el-tag-bg-color:var(--el-color-primary);--el-tag-border-color:var(--el-color-primary);--el-tag-hover-color:var(--el-color-primary-light-3)}.el-tag--dark.el-tag--success{--el-tag-bg-color:var(--el-color-success);--el-tag-border-color:var(--el-color-success);--el-tag-hover-color:var(--el-color-success-light-3)}.el-tag--dark.el-tag--warning{--el-tag-bg-color:var(--el-color-warning);--el-tag-border-color:var(--el-color-warning);--el-tag-hover-color:var(--el-color-warning-light-3)}.el-tag--dark.el-tag--danger{--el-tag-bg-color:var(--el-color-danger);--el-tag-border-color:var(--el-color-danger);--el-tag-hover-color:var(--el-color-danger-light-3)}.el-tag--dark.el-tag--error{--el-tag-bg-color:var(--el-color-error);--el-tag-border-color:var(--el-color-error);--el-tag-hover-color:var(--el-color-error-light-3)}.el-tag--dark.el-tag--info{--el-tag-bg-color:var(--el-color-info);--el-tag-border-color:var(--el-color-info);--el-tag-hover-color:var(--el-color-info-light-3)}.el-tag--dark.el-tag--primary,.el-tag--dark.el-tag--success,.el-tag--dark.el-tag--warning,.el-tag--dark.el-tag--danger,.el-tag--dark.el-tag--error,.el-tag--dark.el-tag--info{--el-tag-text-color:var(--el-color-white)}.el-tag--plain{--el-tag-border-color:var(--el-color-primary-light-5);--el-tag-hover-color:var(--el-color-primary);--el-tag-bg-color:var(--el-fill-color-blank)}.el-tag--plain.el-tag--primary{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-primary-light-5);--el-tag-hover-color:var(--el-color-primary)}.el-tag--plain.el-tag--success{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-success-light-5);--el-tag-hover-color:var(--el-color-success)}.el-tag--plain.el-tag--warning{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-warning-light-5);--el-tag-hover-color:var(--el-color-warning)}.el-tag--plain.el-tag--danger{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-danger-light-5);--el-tag-hover-color:var(--el-color-danger)}.el-tag--plain.el-tag--error{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-error-light-5);--el-tag-hover-color:var(--el-color-error)}.el-tag--plain.el-tag--info{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-info-light-5);--el-tag-hover-color:var(--el-color-info)}.el-tag.is-closable{padding-right:5px}.el-tag--large{padding:0 11px;height:32px;--el-icon-size:16px}.el-tag--large .el-tag__close{margin-left:8px}.el-tag--large.is-closable{padding-right:7px}.el-tag--small{padding:0 7px;height:20px;--el-icon-size:12px}.el-tag--small .el-tag__close{margin-left:4px}.el-tag--small.is-closable{padding-right:3px}.el-tag--small .el-icon-close{transform:scale(.8)}.el-tag.el-tag--primary.is-hit{border-color:var(--el-color-primary)}.el-tag.el-tag--success.is-hit{border-color:var(--el-color-success)}.el-tag.el-tag--warning.is-hit{border-color:var(--el-color-warning)}.el-tag.el-tag--danger.is-hit{border-color:var(--el-color-danger)}.el-tag.el-tag--error.is-hit{border-color:var(--el-color-error)}.el-tag.el-tag--info.is-hit{border-color:var(--el-color-info)}.el-text{--el-text-font-size:var(--el-font-size-base);--el-text-color:var(--el-text-color-regular)}.el-text{align-self:center;margin:0;padding:0;font-size:var(--el-text-font-size);color:var(--el-text-color);word-break:break-all}.el-text.is-truncated{display:inline-block;max-width:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.el-text--large{--el-text-font-size:var(--el-font-size-medium)}.el-text--default{--el-text-font-size:var(--el-font-size-base)}.el-text--small{--el-text-font-size:var(--el-font-size-extra-small)}.el-text.el-text--primary{--el-text-color:var(--el-color-primary)}.el-text.el-text--success{--el-text-color:var(--el-color-success)}.el-text.el-text--warning{--el-text-color:var(--el-color-warning)}.el-text.el-text--danger{--el-text-color:var(--el-color-danger)}.el-text.el-text--error{--el-text-color:var(--el-color-error)}.el-text.el-text--info{--el-text-color:var(--el-color-info)}.el-text>.el-icon{vertical-align:-2px}.time-select{margin:5px 0;min-width:0}.time-select .el-picker-panel__content{max-height:200px;margin:0}.time-select-item{padding:8px 10px;font-size:14px;line-height:20px}.time-select-item.disabled{color:var(--el-datepicker-border-color);cursor:not-allowed}.time-select-item:hover{background-color:var(--el-fill-color-light);font-weight:700;cursor:pointer}.time-select .time-select-item.selected:not(.disabled){color:var(--el-color-primary);font-weight:700}.el-timeline-item{position:relative;padding-bottom:20px}.el-timeline-item__wrapper{position:relative;padding-left:28px;top:-3px}.el-timeline-item__tail{position:absolute;left:4px;height:100%;border-left:2px solid var(--el-timeline-node-color)}.el-timeline-item .el-timeline-item__icon{color:var(--el-color-white);font-size:var(--el-font-size-small)}.el-timeline-item__node{position:absolute;background-color:var(--el-timeline-node-color);border-color:var(--el-timeline-node-color);border-radius:50%;box-sizing:border-box;display:flex;justify-content:center;align-items:center}.el-timeline-item__node--normal{left:-1px;width:var(--el-timeline-node-size-normal);height:var(--el-timeline-node-size-normal)}.el-timeline-item__node--large{left:-2px;width:var(--el-timeline-node-size-large);height:var(--el-timeline-node-size-large)}.el-timeline-item__node.is-hollow{background:var(--el-color-white);border-style:solid;border-width:2px}.el-timeline-item__node--primary{background-color:var(--el-color-primary);border-color:var(--el-color-primary)}.el-timeline-item__node--success{background-color:var(--el-color-success);border-color:var(--el-color-success)}.el-timeline-item__node--warning{background-color:var(--el-color-warning);border-color:var(--el-color-warning)}.el-timeline-item__node--danger{background-color:var(--el-color-danger);border-color:var(--el-color-danger)}.el-timeline-item__node--info{background-color:var(--el-color-info);border-color:var(--el-color-info)}.el-timeline-item__dot{position:absolute;display:flex;justify-content:center;align-items:center}.el-timeline-item__content{color:var(--el-text-color-primary)}.el-timeline-item__timestamp{color:var(--el-text-color-secondary);line-height:1;font-size:var(--el-font-size-small)}.el-timeline-item__timestamp.is-top{margin-bottom:8px;padding-top:4px}.el-timeline-item__timestamp.is-bottom{margin-top:8px}.el-timeline{--el-timeline-node-size-normal:12px;--el-timeline-node-size-large:14px;--el-timeline-node-color:var(--el-border-color-light)}.el-timeline{margin:0;font-size:var(--el-font-size-base);list-style:none}.el-timeline .el-timeline-item:last-child .el-timeline-item__tail{display:none}.el-timeline .el-timeline-item__center{display:flex;align-items:center}.el-timeline .el-timeline-item__center .el-timeline-item__wrapper{width:100%}.el-timeline .el-timeline-item__center .el-timeline-item__tail{top:0}.el-timeline .el-timeline-item__center:first-child .el-timeline-item__tail{height:calc(50% + 10px);top:calc(50% - 10px)}.el-timeline .el-timeline-item__center:last-child .el-timeline-item__tail{display:block;height:calc(50% - 10px)}.el-tooltip-v2__content{--el-tooltip-v2-padding:5px 10px;--el-tooltip-v2-border-radius:4px;--el-tooltip-v2-border-color:var(--el-border-color);border-radius:var(--el-tooltip-v2-border-radius);color:var(--el-color-black);background-color:var(--el-color-white);padding:var(--el-tooltip-v2-padding);border:1px solid var(--el-border-color)}.el-tooltip-v2__arrow{position:absolute;color:var(--el-color-white);width:var(--el-tooltip-v2-arrow-width);height:var(--el-tooltip-v2-arrow-height);pointer-events:none;left:var(--el-tooltip-v2-arrow-x);top:var(--el-tooltip-v2-arrow-y)}.el-tooltip-v2__arrow:before{content:"";width:0;height:0;border:var(--el-tooltip-v2-arrow-border-width) solid transparent;position:absolute}.el-tooltip-v2__arrow:after{content:"";width:0;height:0;border:var(--el-tooltip-v2-arrow-border-width) solid transparent;position:absolute}.el-tooltip-v2__content[data-side^=top] .el-tooltip-v2__arrow{bottom:0}.el-tooltip-v2__content[data-side^=top] .el-tooltip-v2__arrow:before{border-top-color:var(--el-color-white);border-top-width:var(--el-tooltip-v2-arrow-border-width);border-bottom:0;top:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=top] .el-tooltip-v2__arrow:after{border-top-color:var(--el-border-color);border-top-width:var(--el-tooltip-v2-arrow-border-width);border-bottom:0;top:100%;z-index:-1}.el-tooltip-v2__content[data-side^=bottom] .el-tooltip-v2__arrow{top:0}.el-tooltip-v2__content[data-side^=bottom] .el-tooltip-v2__arrow:before{border-bottom-color:var(--el-color-white);border-bottom-width:var(--el-tooltip-v2-arrow-border-width);border-top:0;bottom:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=bottom] .el-tooltip-v2__arrow:after{border-bottom-color:var(--el-border-color);border-bottom-width:var(--el-tooltip-v2-arrow-border-width);border-top:0;bottom:100%;z-index:-1}.el-tooltip-v2__content[data-side^=left] .el-tooltip-v2__arrow{right:0}.el-tooltip-v2__content[data-side^=left] .el-tooltip-v2__arrow:before{border-left-color:var(--el-color-white);border-left-width:var(--el-tooltip-v2-arrow-border-width);border-right:0;left:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=left] .el-tooltip-v2__arrow:after{border-left-color:var(--el-border-color);border-left-width:var(--el-tooltip-v2-arrow-border-width);border-right:0;left:100%;z-index:-1}.el-tooltip-v2__content[data-side^=right] .el-tooltip-v2__arrow{left:0}.el-tooltip-v2__content[data-side^=right] .el-tooltip-v2__arrow:before{border-right-color:var(--el-color-white);border-right-width:var(--el-tooltip-v2-arrow-border-width);border-left:0;right:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=right] .el-tooltip-v2__arrow:after{border-right-color:var(--el-border-color);border-right-width:var(--el-tooltip-v2-arrow-border-width);border-left:0;right:100%;z-index:-1}.el-tooltip-v2__content.is-dark{--el-tooltip-v2-border-color:transparent;background-color:var(--el-color-black);color:var(--el-color-white);border-color:transparent}.el-tooltip-v2__content.is-dark .el-tooltip-v2__arrow{background-color:var(--el-color-black);border-color:transparent}.el-transfer{--el-transfer-border-color:var(--el-border-color-lighter);--el-transfer-border-radius:var(--el-border-radius-base);--el-transfer-panel-width:200px;--el-transfer-panel-header-height:40px;--el-transfer-panel-header-bg-color:var(--el-fill-color-light);--el-transfer-panel-footer-height:40px;--el-transfer-panel-body-height:278px;--el-transfer-item-height:30px;--el-transfer-filter-height:32px}.el-transfer{font-size:var(--el-font-size-base)}.el-transfer__buttons{display:inline-block;vertical-align:middle;padding:0 30px}.el-transfer__button{vertical-align:top}.el-transfer__button:nth-child(2){margin:0 0 0 10px}.el-transfer__button i,.el-transfer__button span{font-size:14px}.el-transfer__button .el-icon+span{margin-left:0}.el-transfer-panel{overflow:hidden;background:var(--el-bg-color-overlay);display:inline-block;text-align:left;vertical-align:middle;width:var(--el-transfer-panel-width);max-height:100%;box-sizing:border-box;position:relative}.el-transfer-panel__body{height:var(--el-transfer-panel-body-height);border-left:1px solid var(--el-transfer-border-color);border-right:1px solid var(--el-transfer-border-color);border-bottom:1px solid var(--el-transfer-border-color);border-bottom-left-radius:var(--el-transfer-border-radius);border-bottom-right-radius:var(--el-transfer-border-radius);overflow:hidden}.el-transfer-panel__body.is-with-footer{border-bottom:none;border-bottom-left-radius:0;border-bottom-right-radius:0}.el-transfer-panel__list{margin:0;padding:6px 0;list-style:none;height:var(--el-transfer-panel-body-height);overflow:auto;box-sizing:border-box}.el-transfer-panel__list.is-filterable{height:calc(100% - var(--el-transfer-filter-height) - 30px);padding-top:0}.el-transfer-panel__item{height:var(--el-transfer-item-height);line-height:var(--el-transfer-item-height);padding-left:15px;display:block!important}.el-transfer-panel__item+.el-transfer-panel__item{margin-left:0}.el-transfer-panel__item.el-checkbox{color:var(--el-text-color-regular)}.el-transfer-panel__item:hover{color:var(--el-color-primary)}.el-transfer-panel__item.el-checkbox .el-checkbox__label{width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;box-sizing:border-box;padding-left:22px;line-height:var(--el-transfer-item-height)}.el-transfer-panel__item .el-checkbox__input{position:absolute;top:8px}.el-transfer-panel__filter{text-align:center;padding:15px;box-sizing:border-box}.el-transfer-panel__filter .el-input__inner{height:var(--el-transfer-filter-height);width:100%;font-size:12px;display:inline-block;box-sizing:border-box;border-radius:calc(var(--el-transfer-filter-height)/ 2)}.el-transfer-panel__filter .el-icon-circle-close{cursor:pointer}.el-transfer-panel .el-transfer-panel__header{display:flex;align-items:center;height:var(--el-transfer-panel-header-height);background:var(--el-transfer-panel-header-bg-color);margin:0;padding-left:15px;border:1px solid var(--el-transfer-border-color);border-top-left-radius:var(--el-transfer-border-radius);border-top-right-radius:var(--el-transfer-border-radius);box-sizing:border-box;color:var(--el-color-black)}.el-transfer-panel .el-transfer-panel__header .el-checkbox{position:relative;display:flex;width:100%;align-items:center}.el-transfer-panel .el-transfer-panel__header .el-checkbox .el-checkbox__label{font-size:16px;color:var(--el-text-color-primary);font-weight:400}.el-transfer-panel .el-transfer-panel__header .el-checkbox .el-checkbox__label span{position:absolute;right:15px;top:50%;transform:translate3d(0,-50%,0);color:var(--el-text-color-secondary);font-size:12px;font-weight:400}.el-transfer-panel .el-transfer-panel__footer{height:var(--el-transfer-panel-footer-height);background:var(--el-bg-color-overlay);margin:0;padding:0;border:1px solid var(--el-transfer-border-color);border-bottom-left-radius:var(--el-transfer-border-radius);border-bottom-right-radius:var(--el-transfer-border-radius)}.el-transfer-panel .el-transfer-panel__footer:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-transfer-panel .el-transfer-panel__footer .el-checkbox{padding-left:20px;color:var(--el-text-color-regular)}.el-transfer-panel .el-transfer-panel__empty{margin:0;height:var(--el-transfer-item-height);line-height:var(--el-transfer-item-height);padding:6px 15px 0;color:var(--el-text-color-secondary);text-align:center}.el-transfer-panel .el-checkbox__label{padding-left:8px}.el-transfer-panel .el-checkbox__inner{height:14px;width:14px;border-radius:3px}.el-transfer-panel .el-checkbox__inner:after{height:6px;width:3px;left:4px}.el-tree{--el-tree-node-hover-bg-color:var(--el-fill-color-light);--el-tree-text-color:var(--el-text-color-regular);--el-tree-expand-icon-color:var(--el-text-color-placeholder)}.el-tree{position:relative;cursor:default;background:var(--el-fill-color-blank);color:var(--el-tree-text-color);font-size:var(--el-font-size-base)}.el-tree__empty-block{position:relative;min-height:60px;text-align:center;width:100%;height:100%}.el-tree__empty-text{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:var(--el-text-color-secondary);font-size:var(--el-font-size-base)}.el-tree__drop-indicator{position:absolute;left:0;right:0;height:1px;background-color:var(--el-color-primary)}.el-tree-node{white-space:nowrap;outline:0}.el-tree-node:focus>.el-tree-node__content{background-color:var(--el-tree-node-hover-bg-color)}.el-tree-node.is-drop-inner>.el-tree-node__content .el-tree-node__label{background-color:var(--el-color-primary);color:#fff}.el-tree-node__content{display:flex;align-items:center;height:26px;cursor:pointer}.el-tree-node__content>.el-tree-node__expand-icon{padding:6px;box-sizing:content-box}.el-tree-node__content>label.el-checkbox{margin-right:8px}.el-tree-node__content:hover{background-color:var(--el-tree-node-hover-bg-color)}.el-tree.is-dragging .el-tree-node__content{cursor:move}.el-tree.is-dragging .el-tree-node__content *{pointer-events:none}.el-tree.is-dragging.is-drop-not-allow .el-tree-node__content{cursor:not-allowed}.el-tree-node__expand-icon{cursor:pointer;color:var(--el-tree-expand-icon-color);font-size:12px;transform:rotate(0);transition:transform var(--el-transition-duration) ease-in-out}.el-tree-node__expand-icon.expanded{transform:rotate(90deg)}.el-tree-node__expand-icon.is-leaf{color:transparent;cursor:default}.el-tree-node__expand-icon.is-hidden{visibility:hidden}.el-tree-node__loading-icon{margin-right:8px;font-size:var(--el-font-size-base);color:var(--el-tree-expand-icon-color)}.el-tree-node>.el-tree-node__children{overflow:hidden;background-color:transparent}.el-tree-node.is-expanded>.el-tree-node__children{display:block}.el-tree--highlight-current .el-tree-node.is-current>.el-tree-node__content{background-color:var(--el-color-primary-light-9)}.el-tree-select{--el-tree-node-hover-bg-color:var(--el-fill-color-light);--el-tree-text-color:var(--el-text-color-regular);--el-tree-expand-icon-color:var(--el-text-color-placeholder)}.el-tree-select__popper .el-tree-node__expand-icon{margin-left:8px}.el-tree-select__popper .el-tree-node.is-checked>.el-tree-node__content .el-select-dropdown__item.selected:after{content:none}.el-tree-select__popper .el-select-dropdown__item{flex:1;background:0 0!important;padding-left:0;height:20px;line-height:20px}.el-upload{--el-upload-dragger-padding-horizontal:40px;--el-upload-dragger-padding-vertical:10px}.el-upload{display:inline-flex;justify-content:center;align-items:center;cursor:pointer;outline:0}.el-upload__input{display:none}.el-upload__tip{font-size:12px;color:var(--el-text-color-regular);margin-top:7px}.el-upload iframe{position:absolute;z-index:-1;top:0;left:0;opacity:0}.el-upload--picture-card{--el-upload-picture-card-size:148px;background-color:var(--el-fill-color-lighter);border:1px dashed var(--el-border-color-darker);border-radius:6px;box-sizing:border-box;width:var(--el-upload-picture-card-size);height:var(--el-upload-picture-card-size);cursor:pointer;vertical-align:top;display:inline-flex;justify-content:center;align-items:center}.el-upload--picture-card i{font-size:28px;color:var(--el-text-color-secondary)}.el-upload--picture-card:hover{border-color:var(--el-color-primary);color:var(--el-color-primary)}.el-upload.is-drag{display:block}.el-upload:focus{border-color:var(--el-color-primary);color:var(--el-color-primary)}.el-upload:focus .el-upload-dragger{border-color:var(--el-color-primary)}.el-upload-dragger{padding:var(--el-upload-dragger-padding-horizontal) var(--el-upload-dragger-padding-vertical);background-color:var(--el-fill-color-blank);border:1px dashed var(--el-border-color);border-radius:6px;box-sizing:border-box;text-align:center;cursor:pointer;position:relative;overflow:hidden}.el-upload-dragger .el-icon--upload{font-size:67px;color:var(--el-text-color-placeholder);margin-bottom:16px;line-height:50px}.el-upload-dragger+.el-upload__tip{text-align:center}.el-upload-dragger~.el-upload__files{border-top:var(--el-border);margin-top:7px;padding-top:5px}.el-upload-dragger .el-upload__text{color:var(--el-text-color-regular);font-size:14px;text-align:center}.el-upload-dragger .el-upload__text em{color:var(--el-color-primary);font-style:normal}.el-upload-dragger:hover{border-color:var(--el-color-primary)}.el-upload-dragger.is-dragover{padding:calc(var(--el-upload-dragger-padding-horizontal) - 1px) calc(var(--el-upload-dragger-padding-vertical) - 1px);background-color:var(--el-color-primary-light-9);border:2px dashed var(--el-color-primary)}.el-upload-list{margin:10px 0 0;padding:0;list-style:none;position:relative}.el-upload-list__item{transition:all .5s cubic-bezier(.55,0,.1,1);font-size:14px;color:var(--el-text-color-regular);margin-bottom:5px;position:relative;box-sizing:border-box;border-radius:4px;width:100%}.el-upload-list__item .el-progress{position:absolute;top:20px;width:100%}.el-upload-list__item .el-progress__text{position:absolute;right:0;top:-13px}.el-upload-list__item .el-progress-bar{margin-right:0;padding-right:0}.el-upload-list__item .el-icon--upload-success{color:var(--el-color-success)}.el-upload-list__item .el-icon--close{display:none;position:absolute;right:5px;top:50%;cursor:pointer;opacity:.75;color:var(--el-text-color-regular);transition:opacity var(--el-transition-duration);transform:translateY(-50%)}.el-upload-list__item .el-icon--close:hover{opacity:1;color:var(--el-color-primary)}.el-upload-list__item .el-icon--close-tip{display:none;position:absolute;top:1px;right:5px;font-size:12px;cursor:pointer;opacity:1;color:var(--el-color-primary);font-style:normal}.el-upload-list__item:hover{background-color:var(--el-fill-color-light)}.el-upload-list__item:hover .el-icon--close{display:inline-flex}.el-upload-list__item:hover .el-progress__text{display:none}.el-upload-list__item .el-upload-list__item-info{display:inline-flex;justify-content:center;flex-direction:column;width:calc(100% - 30px);margin-left:4px}.el-upload-list__item.is-success .el-upload-list__item-status-label{display:inline-flex}.el-upload-list__item.is-success .el-upload-list__item-name:focus,.el-upload-list__item.is-success .el-upload-list__item-name:hover{color:var(--el-color-primary);cursor:pointer}.el-upload-list__item.is-success:focus:not(:hover) .el-icon--close-tip{display:inline-block}.el-upload-list__item.is-success:active,.el-upload-list__item.is-success:not(.focusing):focus{outline-width:0}.el-upload-list__item.is-success:active .el-icon--close-tip,.el-upload-list__item.is-success:not(.focusing):focus .el-icon--close-tip{display:none}.el-upload-list__item.is-success:focus .el-upload-list__item-status-label,.el-upload-list__item.is-success:hover .el-upload-list__item-status-label{display:none;opacity:0}.el-upload-list__item-name{color:var(--el-text-color-regular);display:inline-flex;text-align:center;align-items:center;padding:0 4px;transition:color var(--el-transition-duration);font-size:var(--el-font-size-base)}.el-upload-list__item-name .el-icon{margin-right:6px;color:var(--el-text-color-secondary)}.el-upload-list__item-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-upload-list__item-status-label{position:absolute;right:5px;top:0;line-height:inherit;display:none;height:100%;justify-content:center;align-items:center;transition:opacity var(--el-transition-duration)}.el-upload-list__item-delete{position:absolute;right:10px;top:0;font-size:12px;color:var(--el-text-color-regular);display:none}.el-upload-list__item-delete:hover{color:var(--el-color-primary)}.el-upload-list--picture-card{--el-upload-list-picture-card-size:148px;display:inline-flex;flex-wrap:wrap;margin:0}.el-upload-list--picture-card .el-upload-list__item{overflow:hidden;background-color:var(--el-fill-color-blank);border:1px solid var(--el-border-color);border-radius:6px;box-sizing:border-box;width:var(--el-upload-list-picture-card-size);height:var(--el-upload-list-picture-card-size);margin:0 8px 8px 0;padding:0;display:inline-flex}.el-upload-list--picture-card .el-upload-list__item .el-icon--check,.el-upload-list--picture-card .el-upload-list__item .el-icon--circle-check{color:#fff}.el-upload-list--picture-card .el-upload-list__item .el-icon--close{display:none}.el-upload-list--picture-card .el-upload-list__item:hover .el-upload-list__item-status-label{opacity:0;display:block}.el-upload-list--picture-card .el-upload-list__item:hover .el-progress__text{display:block}.el-upload-list--picture-card .el-upload-list__item .el-upload-list__item-name{display:none}.el-upload-list--picture-card .el-upload-list__item-thumbnail{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.el-upload-list--picture-card .el-upload-list__item-status-label{right:-15px;top:-6px;width:40px;height:24px;background:var(--el-color-success);text-align:center;transform:rotate(45deg)}.el-upload-list--picture-card .el-upload-list__item-status-label i{font-size:12px;margin-top:11px;transform:rotate(-45deg)}.el-upload-list--picture-card .el-upload-list__item-actions{position:absolute;width:100%;height:100%;left:0;top:0;cursor:default;display:inline-flex;justify-content:center;align-items:center;color:#fff;opacity:0;font-size:20px;background-color:var(--el-overlay-color-lighter);transition:opacity var(--el-transition-duration)}.el-upload-list--picture-card .el-upload-list__item-actions span{display:none;cursor:pointer}.el-upload-list--picture-card .el-upload-list__item-actions span+span{margin-left:1rem}.el-upload-list--picture-card .el-upload-list__item-actions .el-upload-list__item-delete{position:static;font-size:inherit;color:inherit}.el-upload-list--picture-card .el-upload-list__item-actions:hover{opacity:1}.el-upload-list--picture-card .el-upload-list__item-actions:hover span{display:inline-flex}.el-upload-list--picture-card .el-progress{top:50%;left:50%;transform:translate(-50%,-50%);bottom:auto;width:126px}.el-upload-list--picture-card .el-progress .el-progress__text{top:50%}.el-upload-list--picture .el-upload-list__item{overflow:hidden;z-index:0;background-color:var(--el-fill-color-blank);border:1px solid var(--el-border-color);border-radius:6px;box-sizing:border-box;margin-top:10px;padding:10px;display:flex;align-items:center}.el-upload-list--picture .el-upload-list__item .el-icon--check,.el-upload-list--picture .el-upload-list__item .el-icon--circle-check{color:#fff}.el-upload-list--picture .el-upload-list__item:hover .el-upload-list__item-status-label{opacity:0;display:inline-flex}.el-upload-list--picture .el-upload-list__item:hover .el-progress__text{display:block}.el-upload-list--picture .el-upload-list__item.is-success .el-upload-list__item-name i{display:none}.el-upload-list--picture .el-upload-list__item .el-icon--close{top:5px;transform:translateY(0)}.el-upload-list--picture .el-upload-list__item-thumbnail{display:inline-flex;justify-content:center;align-items:center;width:70px;height:70px;-o-object-fit:contain;object-fit:contain;position:relative;z-index:1;background-color:var(--el-color-white)}.el-upload-list--picture .el-upload-list__item-status-label{position:absolute;right:-17px;top:-7px;width:46px;height:26px;background:var(--el-color-success);text-align:center;transform:rotate(45deg)}.el-upload-list--picture .el-upload-list__item-status-label i{font-size:12px;margin-top:12px;transform:rotate(-45deg)}.el-upload-list--picture .el-progress{position:relative;top:-7px}.el-upload-cover{position:absolute;left:0;top:0;width:100%;height:100%;overflow:hidden;z-index:10;cursor:default}.el-upload-cover:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-upload-cover img{display:block;width:100%;height:100%}.el-upload-cover__label{right:-15px;top:-6px;width:40px;height:24px;background:var(--el-color-success);text-align:center;transform:rotate(45deg)}.el-upload-cover__label i{font-size:12px;margin-top:11px;transform:rotate(-45deg);color:#fff}.el-upload-cover__progress{display:inline-block;vertical-align:middle;position:static;width:243px}.el-upload-cover__progress+.el-upload__inner{opacity:0}.el-upload-cover__content{position:absolute;top:0;left:0;width:100%;height:100%}.el-upload-cover__interact{position:absolute;bottom:0;left:0;width:100%;height:100%;background-color:var(--el-overlay-color-light);text-align:center}.el-upload-cover__interact .btn{display:inline-block;color:#fff;font-size:14px;cursor:pointer;vertical-align:middle;transition:var(--el-transition-md-fade);margin-top:60px}.el-upload-cover__interact .btn i{margin-top:0}.el-upload-cover__interact .btn span{opacity:0;transition:opacity .15s linear}.el-upload-cover__interact .btn:not(:first-child){margin-left:35px}.el-upload-cover__interact .btn:hover{transform:translateY(-13px)}.el-upload-cover__interact .btn:hover span{opacity:1}.el-upload-cover__interact .btn i{color:#fff;display:block;font-size:24px;line-height:inherit;margin:0 auto 5px}.el-upload-cover__title{position:absolute;bottom:0;left:0;background-color:#fff;height:36px;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:400;text-align:left;padding:0 10px;margin:0;line-height:36px;font-size:14px;color:var(--el-text-color-primary)}.el-upload-cover+.el-upload__inner{opacity:0;position:relative;z-index:1}.el-vl__wrapper{position:relative}.el-vl__wrapper:hover .el-virtual-scrollbar,.el-vl__wrapper.always-on .el-virtual-scrollbar{opacity:1}.el-vl__window{scrollbar-width:none}.el-vl__window::-webkit-scrollbar{display:none}.el-virtual-scrollbar{opacity:0;transition:opacity .34s ease-out}.el-virtual-scrollbar.always-on{opacity:1}.el-vg__wrapper{position:relative}.el-popper{--el-popper-border-radius:var(--el-popover-border-radius, 4px)}.el-popper{position:absolute;border-radius:var(--el-popper-border-radius);padding:5px 11px;z-index:2000;font-size:12px;line-height:20px;min-width:10px;word-wrap:break-word;visibility:visible}.el-popper.is-dark{color:var(--el-bg-color);background:var(--el-text-color-primary);border:1px solid var(--el-text-color-primary)}.el-popper.is-dark .el-popper__arrow:before{border:1px solid var(--el-text-color-primary);background:var(--el-text-color-primary);right:0}.el-popper.is-light{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light)}.el-popper.is-light .el-popper__arrow:before{border:1px solid var(--el-border-color-light);background:var(--el-bg-color-overlay);right:0}.el-popper.is-pure{padding:0}.el-popper__arrow{position:absolute;width:10px;height:10px;z-index:-1}.el-popper__arrow:before{position:absolute;width:10px;height:10px;z-index:-1;content:" ";transform:rotate(45deg);background:var(--el-text-color-primary);box-sizing:border-box}.el-popper[data-popper-placement^=top]>.el-popper__arrow{bottom:-5px}.el-popper[data-popper-placement^=top]>.el-popper__arrow:before{border-bottom-right-radius:2px}.el-popper[data-popper-placement^=bottom]>.el-popper__arrow{top:-5px}.el-popper[data-popper-placement^=bottom]>.el-popper__arrow:before{border-top-left-radius:2px}.el-popper[data-popper-placement^=left]>.el-popper__arrow{right:-5px}.el-popper[data-popper-placement^=left]>.el-popper__arrow:before{border-top-right-radius:2px}.el-popper[data-popper-placement^=right]>.el-popper__arrow{left:-5px}.el-popper[data-popper-placement^=right]>.el-popper__arrow:before{border-bottom-left-radius:2px}.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent!important;border-left-color:transparent!important}.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent!important;border-right-color:transparent!important}.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent!important;border-bottom-color:transparent!important}.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent!important;border-top-color:transparent!important}.el-select-dropdown__item{font-size:var(--el-font-size-base);padding:0 32px 0 20px;position:relative;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--el-text-color-regular);height:34px;line-height:34px;box-sizing:border-box;cursor:pointer}.el-select-dropdown__item.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-select-dropdown__item.hover,.el-select-dropdown__item:hover{background-color:var(--el-fill-color-light)}.el-select-dropdown__item.selected{color:var(--el-color-primary);font-weight:700}.el-statistic{--el-statistic-title-font-weight:400;--el-statistic-title-font-size:var(--el-font-size-extra-small);--el-statistic-title-color:var(--el-text-color-regular);--el-statistic-content-font-weight:400;--el-statistic-content-font-size:var(--el-font-size-extra-large);--el-statistic-content-color:var(--el-text-color-primary)}.el-statistic__head{font-weight:var(--el-statistic-title-font-weight);font-size:var(--el-statistic-title-font-size);color:var(--el-statistic-title-color);line-height:20px;margin-bottom:4px}.el-statistic__content{font-weight:var(--el-statistic-content-font-weight);font-size:var(--el-statistic-content-font-size);color:var(--el-statistic-content-color)}.el-statistic__value{display:inline-block}.el-statistic__prefix{margin-right:4px;display:inline-block}.el-statistic__suffix{margin-left:4px;display:inline-block}.el-button{height:32rem!important;padding:8rem 15rem!important;font-size:14rem!important}.el-input__wrapper{padding:1rem 11rem!important}.el-input{height:32rem!important;font-size:14rem!important}.jt-drawing-row .col-left{font-size:14rem!important}.el-color-picker__trigger{height:32rem!important;padding:4rem!important}.el-radio-button__inner{padding:8rem 15rem!important;font-size:14rem}.el-textarea__inner{padding:5rem 11rem!important;font-size:14rem}.el-input__inner{height:32rem!important;font-size:14rem!important}.jt-drawing-row{display:flex;flex-direction:row;height:40rem;align-items:center}.jt-drawing-row .col-left{display:flex;align-items:center;justify-content:right;width:60rem;font-family:Alimama_ShuHeiTi_Bold;font-weight:700;margin-right:8rem}.jt-drawing-row .col-main{flex:1;display:flex;flex-direction:row}.jt-drawing-row .col-main .el-input--suffix{background-color:#fff0}.jt-drawing-row .col-main .el-input--suffix *{background-color:#fff0;color:#fff}.jt-drawing-row .col-main .el-input-number__decrease,.jt-drawing-row .col-main .el-input-number__increase{background-color:#3489ff;color:#fff}.jt-drawing-dialog{pointer-events:none}.jt-drawing-dialog .el-dialog{pointer-events:auto;position:absolute!important;background:rgba(5,45,155,.7);min-width:280rem;overflow:hidden;margin-top:0rem}.jt-drawing-dialog .el-dialog .el-dialog__header{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZAAAAAyCAIAAAD9fhrKAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDo4NTc1YTY2Yi1hY2U5LTUyNDctODM5MS01MGJjMjM4MDkxMDkiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6RDY4MTUxMzk2RDM1MTFFRDkzM0JDNEQ5N0IwQTIxRjYiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6RDY4MTUxMzg2RDM1MTFFRDkzM0JDNEQ5N0IwQTIxRjYiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6YjZlNTUzODYtMzRjZC02NDQyLWI4OTktODY4YTdiYTNkMzgyIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjg1NzVhNjZiLWFjZTktNTI0Ny04MzkxLTUwYmMyMzgwOTEwOSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Po+VQtwAACdUSURBVHja7H1bluM4kiUMfEjuHpFZtY4+/TGLmQ3MmTMbnf1MdUX6QyIJ2MAAAjC8+JB7ZHZXh7LKQ6IoECSBy2sXFwb4/X/+X2FfEqDv5dh35mXeC+k2CzD/+XfxL72BeVbv04KI7uP6ByD7pZTy6ToMnUTwv3f7rgWG/cNXrhz7AcVtUfOiwP/kOg6mLGRVoq1JUewjsAoLWJQ2RdlTg7CD+y+eJW3MziVU1dfK/wV2LIhXJpQJ/nQhOUFWWxDJRYjnwnfItkB2Z8w/yC7sr9fnXpj8Y/9d27hw/2D4zm/0/4V92EcRtq+bMP9J+AX98UdadxN8oy/D/tXdBeWAvsBQM7/FvwklxzemJ0xyfrflu6JG1T+Hc1mrhKEA/wfTQ9BfAD119x9Ca2R1ZjuEqwdq/Kb7C9vO3oQzZJ9AKdAzqDuoGVC5r3r3j8Gp62XoJaT9g3WBDK3crwwIdfB+mxUmyJP0HXNGAj/uM1zNQWTs8MChMOvJEQYMuDxdepBAQGM7810t2MHIioItnEqwbOx66GBadMSXHHQiCgBHFmDV8h+rJcQPEUaLk+WIFi5YDnyQXPoUs0R+oyTfEWvdkKFaskPYju0t1RLCDrxM/luoHejIm+0qbZ9g6+P2/snOBWDRQVPAggLOgMEBFRh7PoY+DPaJvUIYIvjeb3eG9b39tH6zFoL0Q9eHzVt6A1qOKMdYE7cD+lsBDCtdya7B2QINBEj1YZqMxSAwIKL7J3DVdI0WHbWgY4HdyIp2Z7d+lvreTa+hfHep/M/ZhZS9Gr7pbthqXsmtsdXpepS9MHXTi5xf5XIzX3XXf/tfBkmer2MHkPKdGr0SOckyXGzoO60IYIGBUcEdYFZKSuikFMBLT7pxQprYwXrifAZwtfto3pi9bVEcXVKSVcKtPYT5lSnMlOAaQMKKUobEv2UXF9a7kx4vbkRWnGsxAKxnAIRnrPAtg9FFYM8l93Pg/YA9A31zZCeJfOOBv3znykOv2KG6W/YVpu+xtlHUjlvWXGzu3Dqd6rflx/ZRkH+0vEFofssYCXAbtSNB7O6gxylGfNhRGFFJOdT6jbbFR4jEcHa4EqKrlkOsD2LKs2J9AlGKdVtucv4I9TdQpftrrH88BUSO3QVHI7RaboRWiJW7zy+zoW/jd4Ie0b472y+Q2F+AwHXuXv79f39/GiHr3pCgXQpSxaMeYOx7cxYGBHIKkHIKQhxJ6MOimxQI25jVdWBCy0Up941DSE4JAfKQtUURDcqawrT21YUUnVHkUVoJfByheE0DCGLysIiwkiEX6zwZctkHb3JHofU0ivee7aJx/QoxOTT6b2OVMCmE/0RU0SctOfsqnOz6rS9KszI5Umh2dJHWNjsFXSsw+7nIcCEtKuys2VfILxcWwIf8TdGrI3wxQpQHU/zi5JEjD8HWclhMxX4ecMHgi4ZesOgyBGsZWokCrWD5kPM9otXwbOLK9OphesYiOWvWFA3qddNbivHFc81iq7r8ZrrvJ2Jz/zjuRqnuvQm46rtmsFO0Yaql4w7U4fH5YuJD+JiWsB3Dj9HRYdp0J81LGE7nySMmPZfxflbAemw6wGW42RLMj+bZHEtcL1145NmiPEMWGKmNAwOMkYchZyaenRYiWmgpLx0xcGfXrjwXdMw5xSG/3ZJ/5LKXa0D++I4+R9gKVwwtuVrpNzj6HS7syt/Fuj+E5ghJAAblHeFxG2rhzyWNfgRrZ2HPNDDCVjQm2P4ltPk9kZUfRRmssXRMgzGIhftL7zdCpBuClYxYi02LC7KWwK+JSH4Yj5tEhZiyjLwfBaiq4lSKGonKgzUBK5xdQr5C9wfT/5HCfx5vJhcRkQtYKVrN77BMnjtJPT5pGHK4LCCKHSBidDe/rzQt2S+7CEINL4bBsX7XiNURcTdot5/18NIPXVfiFK8GNB/tGZYhiWBSvt/n8gnN7+9kEccCJSSH4Ai4fsG+stU3BzDI+OEPMS/K7GXgz0foAf6wgVkiYIkJMk2F7/NimBayADDClrZIJDCHLUQBGTdCcKAsPXcKWqODsqABuJPFJApGpx+sskHE20jmINK6KFuAbxvgmR2cCoTE3le5KAoeODNymG7ZKP/IcbdjNrEZTmzVfzMaySEojcE3QeokTnEoYVCFCSxGAT4e3uCU7i/oxMokDCzQKq8MFeTRyv1OquEZoU/pURFgisp1oFhnfiWaxgYCkkEGH8SZMJDi1kBadlvEEcol+x6q4tQ2TwMGw8ClHzF2snu6vN0nFx4mwOUAyILQNNPY4tN1WKUeKDAr/Cj/Cg3QPBnMmhxm4bKoD1PUSML8SmcCZmCmC+dUCwizumlWobYFbEWUs3o8psoXijTeElqsCBeCVE+4wFcEIQsVg9IZNC3hyZhgI7AY1LUVv9KWFJhM/SZioY23iHN1O6bsJGd2lS1VZra/AzY0/HatTsQXG6Vl75MOhoySNjhIHlCzvq6xxMEmVCXH4sSms9wKMmLFeA0bHMxEK9Nl5jehZrEerTM8BUHmaIU5WvHzCvWW06u0NC2pJSZohXJQw3eUXfOZggX1wYMwhn1xU2EfqjZfHYhv1/F9MhGbZjw9xIkrAM0GJG6zoUs5ZhUHRR+PhWCKMGscDDlaNPUUgzcf9+V6IUVLJFSLUSp+ahC3m/9f+v6+UHDoQ9EYCAewWu81rILXyrY4cYMkdHfEyjNNYONMPOLDVd3L1MqVeWGmSqVgiyJ1j2AYptSYtACA2Haz94jN1gOprhSLFbEThhIAErkEIO7TIkOhwPA3+6EQ9cNhUUnEdAvW+0A4SnYdmCiZGhdwHfZCkTMpjlDZD9t8KtlFp+4ATNSuyJjcc1T2KC/rOGQmtIs04uc7uC+0MtxK6GVFFei14VY0QFiEfZipdpiVCajl/RXU1Azi7DaS2HoCRNzlVOmFzTt949XvwlMlKqzoWYnqZIDjZRxvcrkZJiWYkuUwa90NDUi836fn67h2X4dZWHKi+JMANJIMWf1tMphlbj4obTFr7GjokGNSEo95LMIUtgAvfTct2haFERQgYAF6FuMxCDzaoR+rDvQOfIQc+6Af0XaCFPjWYDvV+pEPVmCizfvxv3DqfqgA07sb9sRjARdgfVS/UoLHR31svBBwn/aHa8WPlf8Q07rh1pM6KZBHytXSMB1cx1z+YnQoFYOygQjMhB6RGaZ4ed6jkIRgmuNUihYrWg0erdoxYM7+AlotFAnqZQUxOej+2QNfDa0QK5aOiFZ/gKVp6eGTM9Xjt5UJihpdrYfsFbjKHxWHAAtqStYeyUKv0Zj+dB36DoCcpVHAQd+DV2xaFnz7mEyIZ5AmpeWV2DCQHS8rCcOzDGaZkI7uDmEW6Vl2FBIjI8mU+IxFetgiRZ94n2LUA1Cu5peAm8IjUgA17nnx7qqIXLGXeG0fU9sHYm5eozMNJg9kmldiOsn516qC4TGjS/JgwEQWxYY0iqWqDbVYK2tnpddKJPeCl4O1nbG0TImKmSyOdWJxUuXZ8aFMVp9Ej6/7G3MWUIv4ivFELH7H+UsyIBf0b3qZzt8NmPC1TaiKLlZBZkuDVqjWAcFuxP4pRSseyWJlWNAfjmxQ0ysQTcvFdX6t1OW3fMyxQZ8OhO/YstLtM6xtLEuCAshgEkcDWXbo0KBJMnDDBHIb0M3Xceh7mQwacg0+CEAx1lsDNYN1Xn2nb2/3ZRz70WEWRHaUR4jZaVgY6SU5/KdZRRjSvDH7wUR/wyCQJe/bWI9WQ66oka8RIUMAiD67YDFksV6ira3UD6E+BhLHBDBvIomCE4Ij1vigaFbY3hh/y0+zRLBsH5Ect8nUjo0MZKcTY3NMj4gN8QsTXplrzFgPUhKvQC42p0JVWVobpxjbWiFNWrOVzmkIYhEAZo4EZw1dPhC1R6sLmv8hVAc9c90qPTUTA8r5DbQSVZP/GjF1epXYGSVtaZen4WsHsA4oVbgl0kc6Zv8MUkrrRZiUghSzwqGUJiv8FXuac4NxxKuCWVl4aPe72LlE93mxCIP3aca+uww976xHYMsAUkeeMhMeLkyLYtw1nUyUMAQdmVGIFpPBO0g4R2YchsTXtQ5HYsmngY0JZJxLeDK4WiYgC+fdxvVvwTggMW/7UNmF6aLYjuxYfh+Moj/E5p55rzBy8Ky1MLkwfw85ugh+UrGqaRzBL0V5IhBHNzBUOF6ZFmxhJU5JFHRRM3ChyKV0kUlOLFa0rZogBvpV6joCVWzqDCw3WO4GrcRqtnrScvScvDaMkGIU307AZ2mawIo1awW6/qJ6O+aYjH4WV6+lTNQC9w0w6wvqdHjcBWqerHwECq0MDzS9ZobJYgp3ZoEnSuZBcrPB42iBJlItZM5xfmUhkhZYA7r+Ns3OFzUtNPPIY9YGbHE6sApMvZ1UeafpRrhq2SH049okePiARMLw4lIAL2+CwGAYxSihQxwKTQbbgJ011EZTEmoAcVQxzo7wY4eiFo1gHtIhYh7YAVblTxRYcehAnYwgYJPwM+kzfx/tEsmbvLbpr4oZfuifDeysoer+wvwnDfE3g5u8f2Y6OvPclsyljPKCkkWRoOhyt0DFXZXSGdcXlg+DVqFwsi/IIYw9J7/dGBB0bUfdOppvqEVuTGWiVfesB6ptKwKsq1e1GL3p0jrAsKLWzW9wLmPhASeE35nG9WiqItzmmd/LBLNMQDfRCRPQ+EaZ+rASfYYNLNJbwiwraaEdXnHOCRNpMmBKzYIJT0oIlzWoyvuiHacOdxWCuB4mzMTJW4nOFWLGCF7pYBRzKXD+hWGnAsICPEM6oue9W7w34THCvTHf5SxZx5PbDz5Rsb3bkXrioYd2qz6lnbIYjShoVKmgi9b0acyIp30nSbSGrjL8V8BNIue75mDYkJoCoBDxkSNW5nLvo5UkT/yHcEpO6hwL2K/6b6K/rA6JClDhgYaHVVfABnj1BzlU3XNQkqzcDRBVGYrdCFTgY55pvJYZHSJh0po8oQ5ooPSOlkJLgAp6axDxeumtFZ5uyETWCXwaRyjHgJyzPM4ByglXJ+DSy7stAeIMU4xhIvg5oOEmQp6IghEBhBBCCREjx/wWOgTiJ4pMiq8RaEgTNZz1JW37m6pTnOEMhMGmEWx746PGmkdk2WzAZ2e0HUuUryBUVfAqQS3wF9nbSLDjc4MqlIr7DxjsyOkN1OIIEUppw7Qh82okgSd/yKVfyflNqpufv5Wq7KsPVSJNZh7Z3Kl8TAL3BpMfe/WfuvEbnsAc19ZJ3yOZ4ccPa9bkGBSAyZIjUtBX/3qCSpXRw2yH3lK526Jc+cus3jWNQoJzfmKpH6/IVRAuh1n95CxagkndGI0O6wgiJBHOqnuDV6OK0EzkdlAGupzeBh7lpHRZPLggxqxRAn+AFlV9KgcF8W0sOGhiP96yP9no8djVEJsUoKQPmDHcAqRSllZKQuQ5IPtCJ1JOk5ujcs+XC9A0KU1q9o/VTnWJqFSyqhaxstbQN7ncc6s741ZU1eEbTWbG2nAg7t2kDXp1GrCSYReoh4TbjyYW9jByxNUW4kHP43BfFhqP416H4KhEpOk7Gp+crbROtZpsy7C4a9/d7Pij2dcAzjtSUVIyACiTiTCsCFFXZxX9SSwmvgRgNIrxRwZegXn5CxbAy2teXCjn/IsBNwsMRRxQDUOWaazPGJmom+MqTKe1s6i5FHaHXDAxdjSfZAefbdtjO9sqRHV/qPgudmgjxqmKUNGxMm6CdUcRZrQMc5BiGKENBHQOrbASVWFuSk06vFYWrRYvufc2Euwy2wH3WGEWikZzAxVl0UpkM28i3HVXbcvPoRMrcWc9Kj/+9Dnnwzry5IQ2Zomq+LXyF8KUwZAheZ/mKOMB8PDQORWeiJJBMhWw9D2kwz8UgUthMOtu0MoG4d450TtbaUKpMoWLcS53LHPwsTO332b+g6hkIRTBMpefgcdqq8GCtTsoc/ghcNMApn6FypjgCvIC6mmudjnLKennBCU5ecQjT1k8+ZOW4HWcNmI+Oo9lbFUFstT/WTHxYq4cYTcSt0KZKWIlXytN8zZRFFlDPfe5rBK4LghdVgBmDIuK6pwEJnJraMA7pMnMV+2n9TTQCnG/gT3Ok0+EhFsToUVNzCoHiZidU4LBLJK0bjQrMEkesMIWwEqOKAuqDIbPQoxnT1X2OLVW+O4+WS+ozWxDVvih7zvws5UxyWNTm0kQQjea9oNioudYbpVKfVJ8XF9wR3Uy5TKQMiZrMU9DRClg4335nYYGSgFUmkU546r8Nkxtyaa5ZGUC7Nz96v6t7aIyKbV+lPIn6cDpVgnVw7X2wdzqpetDXylyYdkVOWyl7CiOsl3IyM5mHdVxKnMMrKN4s1wMWik/zc9wn6sFvtKBgQW3S6bjmKI6MlstCUtMJHZJLvZ+jLkLt9Fq+/nBc5N8FrCwkavveGBYbC80+FWutvP4ZCfHt/uEGvPgyB5LUeIr7CqD+QXbKgY3zR+DiQagboasadPs1IfWhmcNfZdoWJlchKkRwu9mqJ6JESfL+9bWHow/btoKBPk+72+BOsYLBd51EHP9CZ6lETMuloBYDIErwyDVprDdPrI5vVgkOWq9P/IIPVjO9semovRogYjtjRW2VSFVWCN+WAwL5mN03BNwNWhFG3RuW03izAwf3SieJoeUWHO6CdU/CWlzOeRDmY0AUGS2We2Cyhx2HHEzR7v8roNoVUrseKxl7KpX+ABgcR4koFQNEsxqznfnuVFCT8x+yNKzZVZk5hd9smb5vDLMLs/dAbnt3v4ldjarkAQFsOEVcbmrWrTL/mS0ye7vk4rPniwNRGqPggihMXrlwI18HDAHKEhd2lAMswtRptvHhgiFNcnpSBIF3EztUOYthk0hbEM/2tCnWukcoK277Ra7e5VEKyVKYbMSMQNaBZ5SM0FoDXp4sjmOM3cw1jTskrqhz4bqDi0RHPepCVVZYIiVM6P8CuPzmuU9y7EVjG8t/MdCad/RCo6hFZ4OCc8PIO8NG5eYdZvUnXIuhPAoWpjJDHXpx76LFwViGJVJrPlIov/e8CE7P9qlVKYg0TCudlDJ8CZNehXwC8Is1liLkGwP02uHmIOsiIlmipCk9HGJIidpYV/AChAkOUiTjIgs711mCYN0lLNIQ1oLlwW3rSTWxNp2URwUoTEqB7VsL1D0lXTkBCE95W37FbsgmOUmbJAsgaK0QebyFFZOByu2hyhKlOGeaKf6ZMRHw4D9C9lEcTE8S06vujcIOKSzeEoZqyqHU0NE+YSDpDmD2WIZ1K5VN/3Q3RNl46tEvXhC2dyXT/FhDasJPznuiE2exakWwywT6H3cab5OktvXN8K+k7Q6Tj4jmvdkyJNGBsnMZz2YFj3Ns7K4YOK5y2BFdxS5vsZM862Hc8gX6JKUQvZcTrCWJXthaQCAz5CJxApZsIciW0YIc7isdKZKVFjLebCT/a6aL6GWGXd3GgXUdJzyPWw0zloNoWa5Fzmgi329t9WxzgUplVwCmOdbqIANf5Dod+gvdtLMBkhhbXzAcy8YoAfKdaUXsUw03a9/CtOPMZsSVD/v5DsNF4NZ3fSHsGJWUn2tpDIHUoRZ0InD8nqJ4J/0pRxjWHjU0d4IHDDDLEN8XJaFJE+m7+WDW8JnYzA7S7fHx/j80/U2zwawHFEywHexqSO22l8ZWjKVyZRzV2omHwYKkSZ9BagkFUe+gg3E7HcpdeISdAWReQIErmQlEnLE3Gya3iMv/MS3x/cR5+1U+BPK3H7I46Z81p6+k/OxQujxd3ghkVsqaxaVB0Eqe2Bo0RHPwndKqqdMgW+yWwwVQoBK1dpQxeynvRq/Ww/qvWCUKOcPA4uqt8FsKwzcGhHG/cv+IGDt+WgSHf3Qz6O6ZEiKiQSVc/1DYByr/D0OPVkZoKmF1YplUAVonjS3ZVkIXOzSXkN3GX1i1Wpa8SQzShYJWkVT4X1Wi8s8k156nhVUlOv1IE+7VxqF0gm5KVEFwGRr1jSgblKqDMtycnTKCYXHrOdiM4dnS9jaaGDbrvcjVqwjRxENh1ruvMIkC01xZXErCMIKVPGWa5q+fpdEW+J0nJyLYK3HJ8I5YRaSt/2D0vVpO25oMCtbpWYTp/hhNPQ4fpMTgLpVfrvcpV7IimXqvE2jTyVmOOxceSQkPB0bhmtheMq83OcF+SoyEH95HbqrAxcshr22YCsSk2XBm4nc1LryoCnQzabO5ihB3gqbwa8piuA1DCqloniZHymP5yCBLpHYqlBUkoqKQn7HjTpCNjdxe07fWSfU2TmJu213e4mn4673I/U5mPm9PtbHODSyYBObqCU2+EbT1uCm/N0Is9zKXfVflzJ/VhqgzczXLR/W9X4HpZUT9RvCXAlVKcBKZTBr7uJiq5we6MWEjdrAljkEdIemamJtXtmW2vDJkPAx3T0Fl0Vpw1MmZ78sVFiyTQ09raZTldghs97Uqzk5CV+vdIfQqu8SjZytiZPKQ9kzdd3bxICGrPFlXIJ7NZtIA4xUlY2YLQ+RZrKCjWud5bfL3sY1Lb4+KPr1arCPkvI0o5qG36IeFS0zmIDOhFrdRbQTrOLm0hhIijjYbDAa1NQh6U0GB7cEsupEGj+mQY55w9+Wd9TlUdFimbKu92FniAPxAUf7YwyrETqJzdiwHCo2UKJMGOgn5XGvlX3XSfl06Ya+q1A2n4evrulCSMsviLstyolWPZBoZTX7QqHHVB1PleCgYZmazospcEGsqeDFslIY85pm05DrRIyFnGno1zDBQf4M2EjP8cCz5fO9G35m+X8BWNXPBkUtrKqB3J7PO0cKraV+050yoda6jncp7Vdni7LPWl7FADC909ChWqR+FR3BFgpZ54QNW1l4q4dn4hKL85TmR5XLjXyS4zMdt41Wpy82PgBYZ6bLb9vfHZTcbLKXPGSyb/uOsmX1UlbCTN4OIGUUTJNSdIh5nZloE4f6RMkF2c2MEal2HhoIha6TmgMZLBJyYmEyh4L05USswqegGjnklzcTs1p3B44/sHiEA5sL11eZelWmqu5/ZK345orxj76gfeiNyYQHw0aWB34/LK3pXFk3jhEomKck6HehFeUyZpLWIe+431XDKAbZza+gZ1vgm9XI7OzCwzjFi9X9BcDZHWZRRA9mY3f/Q/SuzrIJzQcHOg60gv44MLW+qpMsu4lWxpkWytvX8JTaAUGPVjG/diW3ZKbVBPVn1vo+LbNPwWxiwKdxoOmH22pXJtUzVFpIYrcqmEi9YZgDZco+sSRighsgdtOmQyaOQ1yTFFpaSQZtojqvqJiXgmxjdVXBZHSKz9sJBB8gtka2Q2Uwvz2T50S2qnLWULtwTGtbXTMxmdBbu0QHKMF2KpVKYFjrnLEeIafVTSpF4Vg3tPVEbFaHWkuvhu9SvIKdxgzzh8EsNbxg1MiwyYGwgriUV/7yrfNDh8U56lXS6l+i0i+OORjw6ODgkZDwXARQMqN50WsamYokj26yyxNN0gOBVb26mNaTA6JBFn2b5yBaDUP/vGr2KAAqFxfaiqmFuHnSVgXLGBmnL1AfWhJ1CzqKRk2iEgk5LysXXqjhWnEfYGM2S2aPxWxNp222EYxumoVFNYnmgUlBTQ5X3DinJCazTnGr8Gq1N/bE0hNbUiRo3sdC1cYd6G3zOJrZp/6gUIskLWhL+yV8+V1BquGbFNKuz2xiECdpvawZrNp8qv7coL49WLuDlMtH9daa7WCo3PBijWAHiBUbADuFWUcWoajj04aehda78GHgJNONg2nIoNXQPV+GZtNOO3nJuQykGGL1MS1hcayL9UM0L3uJGmn9tc3DdbNJnKHiVQ2F5E0tXdXmKJAxRoQbD+forirjTcECT8RzefV2Ap9jfOin6UWHdI1Thi98qFolHOoDkCRaeYLZt43RRr4GDS2r1S+pAlU3SDTwizALSYanoUOhlFR/iOHJurTkgcGFgsFBZzCLlkxf3vMUo+tk7KnTCw7fRHfRZXh4JBh8XMP6xEtR1lCS2JM6MBphut86ILg1fQxbQGPAS9tI826Xt6GpmTZpHy2fkyQ2SDt5uawmbx2UnXmenQoGdcjn+dmrpyYKrYy5w6pcCXfVQww+1a2ui4fUzUPyT4KPWJH095+HrX2SpSK+6JWtT5EVDnztyXz1sc9VBvER2N0FiLRYks8NBHQ81MJ2eZVy7EKE0i57o0mUn96sDP9sC9yoRusj0JLOVOA7CFXjerq7/9DDM5Dj4euxZQ+wiuG8xrfxtVjX0ryoFiOTkhZtNvRquxwhapqXAxdafpXSgLrfdlIaptb3sBHrVfwB7GLPBH8+dG3oDlUU8ws0ayhWOcuJD1ak5nwAYaOVAx7puzvi44EYP1mlAo49Dzf2Sd2bmKX4hXOaQ6N1NNa/SD+2ltIol7eoD0VUq3cojT3iQcirajqmdvNdmqZpuJKVtHD7oVWNU8nZAHJ6FZp6JSzW9jW+RNvXSdg1oSUtezC/0lhkRfgSNkWXUiNTzeoaIB5F+UcZViM29AIQpa8yYaBuNva+k08XP0Nwo6OCaA032MWi55CfyBT4fLVzbtLHbHuIh0MYwYC13S+6EbXBtk4BqbyYS0pBs2jEKNC8SblJO2eLmyu+PUZfHo65Ho7IPj8N6EvqeTz7YO74PXB8bPbJ0k5fy6jlJS39TxPf6f4iBGzDU7XZazni+BuN9Nn8fLTU4E0Jg1mmQISj15P7J8iaL+X0B+i53oDVvbstNoXWRZTDcY+ilXl1f/8f/+fQo7uJJS60x2kitEJs7mxw6sUm/dwOglrfart41/stHsKU9Xwdu2q0DBUqlNeZbPcktCFurrN4dBvDISzoVmNqFWD726zc/6KWpn/JF+7lLMd16cA85MS2nrWj5KAd8gM78bg+utLy2fuZ0pI4GhkdLM8y4aG6U5sysSHA+cCWfPVCjiZidQXW+og5xI26nuxESFL6uQcPoDobZ1biN7cManQtFVWg8bu+f74OsL1OQftbskcEp5WdczN23ZMpsFS7anythHMT0X9MNDs616NKqo9Qj4ZbQNZSlPJhr4biDq1blYW3B7D+1+vLEOpAXFwfIdWPcMSGhEQ5ZPSC/bOQ/S5C1YLNTo2/CfFKsw4tdJKkZYf2cr3piOuV3O4dXn43PIsvWpH92ESOAhfdf3My3Ofly/7Q5awjEdgw0MRok9bYCusMulyG7skPCDYDt3ZU6MJA5Z1WNk9p/3Tpd5577eeGKertvkTRih0RK1DUQKeaAoV7UAK7T+m6hgWNFAK/wOunw9ODPOtIqZtTqutaLrm0KNQK8hCeOwtSzUnSIncCtX/rVl/U5TdaE0wcwqm0E0h1+V3AD1OOKNF5lbToEHr8rkiGg58PWO1TuM+LgZKNLiMNWo1+hmBDmm3mXLZ/5sVFmhgKvI6DHRDc66hY84zbRXTephmx6kwvbnViJoQWfxQbcJaVcyYchlN949c8wv9UyIbtBz9ugtg2sKGVtG7/VG15aLcyZHcgBeqN1qAn3jH3t3+o4beiQDzYuAxxQ+i6+U20GKVe5O0fOH5HK379fMAqerehVB/TdPcpXCrhonMbXNIBwRZXrSEXUk6r5WOKgNjR+mDjMMidltFAAeu0IutWGcU14WKbaycCaGvZLAH7I0rH0O0Xk/oLkQmOjR5ud/At/wmeePCg6u7/BPWih+fcVAWHRjN090wJv0k1t92B7Aj/Afgtc2kdfwiauJLmBJsCUbVmi6+G+PEFoXv4Qds/cO9MMPV2CzFarmqtKUMNuDiJ/fgQNUMujWiIVZgeKOyA4MuVkqrvx0Glux1dgtPZ5oqAY0/JDZ0bjksHtWRKsF3j3Zw+p3EL/nT+Be2nAB77yfbHLyz50PXBnbykR4ZNTtPhHdGAco3ioofvO/2/UQwlDrx0BviEXjkBTK/QKcwA5ThmUYYs2U0/nN2hqunZZX4mikDlg+HhOcBy67+/TxPiltA1kNvAgstDUsuiVHRa2V/0fWfQSsIBbKrdYFLBDMLyyR01negw48cDJwJnpIttgBON9RK+WpT5E4Kl40s6f2YtQnGyKPyiM8SvukxHi5LLfVWgilTLW304TAQ1+HT5m7z/sHYHl4Dhw3Audflet1Dt1Ra7UV3/1q0FNhq4XvqPf5hDGDb3AGYdsDUEBEVhSArFaLglKhta9e3pIuWBqtQggjSmSN/sgODQPz8NUC5ceuxKzrZAvfEQ3C0Pzj8K4Iv3+/X6VxK4HgG4RgMGJIOCgRo7DAe7vy3GwIHyMZh/9ZIUCJ1N8ACn6k9eDvJPXIJ/onWSZKqgSSrDqc51wtagNL7ZjFZ5XdOEwmPfv1yHo1ZlzMWg+7x8cBUf8DoOmWZfzrHYuMW3UOCGnWo/1sDTcIYPNesvgK9treVsOAQNEotbttctblhmkoF2lpvqQbEotrry9cEz/dLkNp9nsrsOr/p2bSM7ZdNXPZDREdZJgiG/KGlk/yHwe1lgC6dSEHRDh3/YqddNKmoN8bMaf09yPHw+JAwkBbGd2Mx2WwMuT2N/JlqL+66L6Ni5x2FlwKeLHRA8pnyVtz5RwfCEHHTunuNJV+fGI+ULYjc8GZKd9ZufNdTjsXL2AkKopk/HM+e1a4v8OZHzTxjhrfq27OQb63h4SIFyQ4edKcRXuLOSfCwQT/Q+KnAFwbfqLBGPlHN/+39qLAYoHwYscwjDULKZzOVOkiT2YV1DsFlSs0KLxne7LkVS4MXEgg+OgCbzDc83lyPmg0+kJv6ijgH/ncLJv9C0keXi+vk1x0eLIlOVVqcVqKD59M800nf/4ewOlgRZSWv8LSvwoP/TgmDfTT/EhoHWDVDqFzV+O4JZWxqWpjAwGaqrXyYJ3wy56rozcU3cycSZbx+TinmjaT7zt6dLZRJPK85IX4YPvt5mrfVfoBnBA/X9RB8+wjAOrb/0ic6En/7JLh3ELzovPEDpML28eIC2HrsAcNa39VgDjApU/0AtDb5gdwE1gYeYtUDZafkIcbMFDrBMsIn1JjaUlJdiFJsuLVrStQVY86JfOetpMbSuDS4HOqjhbm+3iZ/KYDX7TsJDV4eSZL3f5p+COn8F0ok9XefX68+hd3AcVfBPq1TzK5rEBwI3nOXtBTpJNe+vJJmjih1ruQk3G/GBChr07A0IzrA5UcmAEc2XlP0G1DZF948pEb9bL0OrXi4jwIFLCnWN6e5EK7/rZbBTDh+6gYaivVNSK/VpFMIvw5gvPSb+Jf3i1+vPu9rngHEn7pleBU2I+W3XWV7JvQNyuf7eTa8kw4e4Z/pheJAev+8UiHWepa5/l5OdwbNNoG7/EON3sqG2GFK5JI9hKNOidq8IgctlAHjksUPB5n3KNKansb9eBmhGyFsAobNBzPI3B1dmgD+hDVeHun69/lWZGZ4Zf8RzrW+zYC9p/a7lA1owOFGJZi/HAp1L63e3pMU5LyBITVOvIUmyXFWpbNYaC7WVAcr/L8AA+dSd3OMf2BsAAAAASUVORK5CYII=) no-repeat;background-size:100%;margin-right:0rem;padding:6rem;text-align:center}.jt-drawing-dialog .el-dialog .el-dialog__headerbtn{height:34rem}.jt-drawing-dialog .el-dialog .el-dialog__body{padding:10rem;color:#fff}.jt-drawing-dialog .el-dialog .el-color-picker__trigger{width:120rem}.jt-drawing-dialog .el-dialog .el-body-foot{position:absolute;bottom:8rem;right:8rem;width:calc(100% - 16rem)}.jt-drawing-dialog .el-dialog .el-body-foot .el-button-group{display:flex}.jt-drawing-dialog .el-dialog .el-body-foot .el-button-group .el-button{border:solid 0rem rgb(255,0,0);flex:1}
- `;
- const _hoisted_1$1 = { class: "jt-drawing-dialog" };
- const _hoisted_2$1 = {
- slot: "title",
- class: "header-title"
- };
- const _hoisted_3$1 = { style: { "line-height": "24rem", "font-size": "16rem", "color": "#fff", "font-family": "'Alimama_ShuHeiTi_Bold'" } };
- const _hoisted_4$1 = { class: "odin-dialog__content" };
- const _hoisted_5$1 = { class: "jt-drawing-row" };
- const _hoisted_6$1 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u989C\u8272", -1);
- const _hoisted_7$1 = { class: "col-main" };
- const _hoisted_8$1 = { class: "el-body-foot" };
- const _sfc_main$1 = {
- __name: "CrEditProperty_MilitaryPlot.ce",
- props: {
- params: {
- id: {
- type: String,
- default: () => void 0
- },
- color: {
- type: String,
- default: () => "255,255,0,0.9"
- },
- outlineWidth: {
- type: Number,
- default: () => 0
- },
- outlineColor: {
- type: String,
- default: () => "255,255,0,0.9"
- }
- },
- showDialog: {
- type: Boolean,
- default: () => false
- }
- },
- emits: ["submit", "update:showDialog", "update:params", "remove"],
- setup(__props, { expose: __expose, emit }) {
- const props = __props;
- const language = ref("zh-cn");
- const locale = computed$1(() => language.value === "zh-cn" ? zhCn : en);
- const {
- proxy
- } = getCurrentInstance();
- const predefineColors = ref([
- "#ff4500",
- "#ff8c00",
- "#ffd700",
- "#90ee90",
- "#00ced1",
- "#1e90ff",
- "#c71585",
- "rgba(255, 69, 0, 0.68)",
- "rgb(255, 120, 0)",
- "hsv(51, 100, 98)",
- "hsva(120, 40, 94, 0.5)",
- "hsl(181, 100%, 37%)",
- "hsla(209, 100%, 56%, 0.73)",
- "#c7158577"
- ]);
- const title = ref("\u5C5E\u6027\u7F16\u8F91");
- const dialogVisible = ref(props.showDialog);
- ref(false);
- const color2 = ref(props.params.color);
- const outlineWidth = ref(0);
- const outlineColor = ref(props.params.outlineColor);
- updateParams(props.params);
- function updateParams(params) {
- proxy._params = params;
- switch (params.id) {
- case "DrawStraightArrow":
- title.value = "\u7ED8\u5236\u76F4\u7EBF\u7BAD\u5934";
- break;
- case "DrawAttackArrow":
- title.value = "\u7ED8\u5236\u653B\u51FB\u7BAD\u5934";
- break;
- case "DrawPincerArrow":
- title.value = "\u7ED8\u5236\u94B3\u51FB\u7BAD\u5934";
- break;
- case "DrawGatheringPlace":
- title.value = "\u7ED8\u5236\u96C6\u7ED3\u5730";
- break;
- case "DrawClosedCurve":
- title.value = "\u7ED8\u5236\u95ED\u5408\u66F2\u9762";
- break;
- case "DrawSector":
- title.value = "\u7ED8\u5236\u6247\u5F62";
- break;
- case "DrawBowLine":
- title.value = "\u7ED8\u5236\u5F13\u5F62\u7EBF";
- break;
- case "DrawLune":
- title.value = "\u7ED8\u5236\u5F13\u5F62\u9762";
- break;
- case "DrawCurve":
- title.value = "\u7ED8\u5236\u66F2\u7EBF";
- break;
- case "DrawCurveFlag":
- title.value = "\u7ED8\u5236\u66F2\u7EBF\u65D7\u5E1C";
- break;
- case "DrawRectFlag":
- title.value = "\u7ED8\u5236\u77E9\u5F62\u76F4\u89D2\u65D7\u5E1C";
- break;
- case "DrawTriangleFlag":
- title.value = "\u7ED8\u5236\u4E09\u89D2\u65D7\u5E1C";
- break;
- }
- color2.value = params.color;
- outlineColor.value = params.outlineColor;
- outlineWidth.value = params.outlineWidth;
- }
- __expose({});
- function submit() {
- let outParam = proxy._params;
- outParam.color = color2.value;
- outParam.outlineColor = outlineColor.value;
- outParam.outlineWidth = outlineWidth.value;
- emit("submit", outParam);
- }
- function close() {
- dialogVisible.value = false;
- }
- function remove2() {
- emit("remove", {});
- dialogVisible.value = false;
- }
- function closeDialog() {
- emit("update:showDialog", false);
- }
- function openDialog() {
- updateParams(props.params);
- }
- return (_ctx, _cache) => {
- return openBlock(), createElementBlock("div", _hoisted_1$1, [
- createVNode(unref(ElDialog), {
- modal: false,
- "destroy-on-close": false,
- modelValue: dialogVisible.value,
- "onUpdate:modelValue": _cache[4] || (_cache[4] = ($event) => dialogVisible.value = $event),
- title: title.value,
- style: normalizeStyle({ left: "10rem", background: "rgb(0 44 126 / 68%)", height: "calc(100% - 175rem)", width: "180rem", top: "125rem" }),
- onClose: closeDialog,
- onOpen: openDialog,
- "show-close": false
- }, {
- header: withCtx(() => [
- createElementVNode("div", _hoisted_2$1, [
- createElementVNode("span", _hoisted_3$1, toDisplayString(title.value), 1)
- ])
- ]),
- default: withCtx(() => [
- createElementVNode("div", _hoisted_4$1, [
- createElementVNode("div", _hoisted_5$1, [
- _hoisted_6$1,
- createElementVNode("div", _hoisted_7$1, [
- createVNode(unref(ElConfigProvider), { locale: locale.value }, {
- default: withCtx(() => [
- createVNode(unref(ElColorPicker), {
- modelValue: color2.value,
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => color2.value = $event),
- "show-alpha": "",
- predefine: predefineColors.value,
- label: "12"
- }, null, 8, ["modelValue", "predefine"])
- ]),
- _: 1
- }, 8, ["locale"])
- ])
- ]),
- createElementVNode("div", _hoisted_8$1, [
- createVNode(unref(ElButtonGroup), null, {
- default: withCtx(() => [
- createVNode(unref(ElButton), {
- type: "primary",
- icon: unref(edit_default),
- onClick: _cache[1] || (_cache[1] = ($event) => submit())
- }, {
- default: withCtx(() => [
- createTextVNode("\u4FEE\u6539")
- ]),
- _: 1
- }, 8, ["icon"]),
- createVNode(unref(ElButton), {
- type: "primary",
- style: { "background-color": "rgb(222, 146, 47)" },
- icon: unref(delete_default),
- onClick: _cache[2] || (_cache[2] = ($event) => remove2())
- }, {
- default: withCtx(() => [
- createTextVNode("\u5220\u9664")
- ]),
- _: 1
- }, 8, ["icon"]),
- createVNode(unref(ElButton), {
- type: "primary",
- style: { "background-color": "rgb(126, 128, 135)" },
- icon: unref(close_default),
- onClick: _cache[3] || (_cache[3] = ($event) => close())
- }, {
- default: withCtx(() => [
- createTextVNode("\u5173\u95ED")
- ]),
- _: 1
- }, 8, ["icon"])
- ]),
- _: 1
- })
- ])
- ])
- ]),
- _: 1
- }, 8, ["modelValue", "title", "style"])
- ]);
- };
- }
- };
- var DialogEditProperty$1 = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["styles", [_style_0$1]]]);
- Cesium.Entity.prototype.setParams = function(params) {
- this._params = params;
- };
- Cesium.Entity.prototype.getParams = function() {
- return this._params;
- };
- Cesium.Entity.prototype.setIsEdit = function(isEdit) {
- this._isEdit = isEdit;
- };
- Cesium.Entity.prototype.getIsEdit = function() {
- return this._isEdit;
- };
- class DrawMilitaryPlot {
- constructor(options2) {
- if (!options2.viewer)
- throw new DeveloperError("no options.viewer object!");
- if (!options2.Cesium)
- throw new DeveloperError("no options.Cesium object!");
- this._viewer = options2.viewer;
- this.cesium = options2.Cesium;
- this.drawArr = [];
- this.Draw = "";
- this.edit = new EntityEdit(this._viewer);
- this.edit.activate();
- this.edit.EditEndEntity.addEventListener((result) => {
- if (result.Type) {
- this.handleFirstPosition(result.Type);
- this.edit.DrawExample = this.Draw;
- }
- this._editEntity = result;
- });
- }
- static initEditPropertyParams() {
- return {
- id: void 0,
- color: "rgba(0,255,0,0.75)",
- outlineWidth: 0,
- outlineColor: "rgba(255,255,255,1)"
- };
- }
- editActivate() {
- return this.edit;
- }
- handleFirstPosition(type2) {
- this._viewer.scene.globe.depthTestAgainstTerrain = true;
- switch (type2) {
- case "DrawStraightArrow":
- this.Draw = new MilitaryPlot.DrawStraightArrow({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawAttackArrow":
- this.Draw = new MilitaryPlot.DrawAttackArrow({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawPincerArrow":
- this.Draw = new MilitaryPlot.DrawPincerArrow({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawGatheringPlace":
- this.Draw = new MilitaryPlot.DrawGatheringPlace({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawClosedCurve":
- this.Draw = new MilitaryPlot.DrawClosedCurve({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawSector":
- this.Draw = new MilitaryPlot.DrawSector({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawBowLine":
- this.Draw = new MilitaryPlot.DrawBowLine({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawBowPlane":
- this.Draw = new MilitaryPlot.DrawBowPlane({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawCurve":
- this.Draw = new MilitaryPlot.DrawCurve({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawCurveFlag":
- this.Draw = new MilitaryPlot.DrawCurveFlag({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawRectFlag":
- this.Draw = new MilitaryPlot.DrawRectFlag({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawTriangleFlag":
- this.Draw = new MilitaryPlot.DrawTriangleFlag({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawPoint":
- this.Draw = new MilitaryPlot.DrawPoint({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawPolyline":
- this.Draw = new MilitaryPlot.DrawPolyline({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawPolygon":
- this.Draw = new MilitaryPlot.DrawPolygon({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawRectangle":
- this.Draw = new MilitaryPlot.DrawRectangle({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- case "DrawCircle":
- this.Draw = new MilitaryPlot.DrawCircle({
- viewer: this._viewer,
- Cesium: this.cesium
- });
- break;
- }
- }
- addEntity(data) {
- this.handleFirstPosition(data.type);
- if (this.Draw) {
- let entity = this.Draw.addload(data.position);
- entity._id = data.id;
- return entity;
- }
- }
- }
- Object.assign(DrawMilitaryPlot.prototype, {
- _setMousePointerStyle() {
- document.querySelector("body").style.cursor = "crosshair";
- },
- _setMouseDefaultStyle() {
- document.querySelector("body").style.cursor = "default";
- },
- _registerLeftClickEvent(handler, callChange) {
- let _self = this;
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- _self._lock = true;
- clearTimeout(_self._timer);
- _self._timer = setTimeout(function() {
- if (callChange)
- callChange(event2);
- _self._lock = false;
- }, 200);
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- },
- _registerMouseMoveEvent(handler, callChange) {
- let _self = this;
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (_self._lock === void 0 || _self._lock === false) {
- if (callChange)
- callChange(event2);
- }
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- },
- _registerLeftDownEvent(handler, callChange) {
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (callChange)
- callChange(event2);
- }, Cesium.ScreenSpaceEventType.LEFT_DOWN);
- },
- _registerLeftUpEvent(handler, callChange) {
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (callChange)
- callChange(event2);
- }, Cesium.ScreenSpaceEventType.LEFT_UP);
- },
- _clearEvent(handler) {
- if (!handler)
- return;
- handler.destroy();
- handler = null;
- }
- });
- Object.assign(DrawMilitaryPlot.prototype, {
- _setEntityIsEdit(entity) {
- let _self = this;
- this._closePropertyEditDialog();
- entity.setIsEdit(true);
- this.edit.handlePickEditEntity(entity);
- this._sendShowPropertyDialog(entity);
- let handler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- this._registerLeftClickEvent(handler, function(event2) {
- _self._closePropertyEditDialog();
- let feature2 = _self._viewer.scene.pick(event2.position);
- if (feature2 !== void 0 && feature2.id instanceof Cesium.Entity) {
- let editEntity = feature2.id;
- if (editEntity.Type == "DrawStraightArrow" || editEntity.Type == "DrawAttackArrow" || editEntity.Type == "DrawPincerArrow" || editEntity.Type == "DrawGatheringPlace" || editEntity.Type == "DrawClosedCurve" || editEntity.Type == "DrawSector" || editEntity.Type == "DrawBowLine" || editEntity.Type == "DrawBowPlane" || editEntity.Type == "DrawCurve" || editEntity.Type == "DrawCurveFlag" || editEntity.Type == "DrawRectFlag" || editEntity.Type == "DrawTriangleFlag" || editEntity.Type == "DrawPoint" || editEntity.Type == "DrawPolyline" || editEntity.Type == "DrawPolygon" || editEntity.Type == "DrawRectangle" || editEntity.Type == "DrawCircle") {
- _self._sendShowPropertyDialog(feature2.id);
- }
- }
- });
- },
- _sendShowPropertyDialog(entity) {
- let _self = this;
- let editEntityType = entity.Type;
- if (entity.getIsEdit() === void 0 || entity.getIsEdit() === false || editEntityType === void 0) {
- return;
- }
- let editProperty = entity.getParams();
- if (editProperty !== void 0 && this.onEditProperty !== void 0) {
- editProperty.id = editEntityType;
- _self._openPropertyEditDialog(
- editProperty,
- function(params) {
- _self.updateEditEntityProperty(params);
- },
- function() {
- _self._viewer.entities.remove(entity);
- _self.edit.clearAllEditVertex();
- }
- );
- }
- },
- updateEditEntityProperty: function(params) {
- if (this._editEntity === void 0)
- return;
- if (this._editEntity.getIsEdit() === void 0 || this._editEntity.getIsEdit() === false)
- return;
- let editEntityType = this._editEntity.Type;
- if (editEntityType === void 0)
- return;
- let material = this._editEntity.polygon.material;
- if (material instanceof Cesium.ColorMaterialProperty) {
- let newMaterial = this._materialColorProperty({
- color: params.color
- });
- this._editEntity.polygon.material = newMaterial;
- }
- if (this._editEntity.polyline !== void 0) {
- let newMaterial = this._materialColorProperty({
- color: params.outlineColor
- });
- this._editEntity.polyline.material = newMaterial;
- this._editEntity.polyline.width = parseFloat(params.outlineWidth);
- }
- this._editEntity.setParams(params);
- },
- _materialColorProperty(options2) {
- let mColor = "rgba(0,255,0,1)";
- if (options2 !== void 0 && options2.color !== void 0)
- mColor = options2.color;
- let colorMaterial = new Cesium.ColorMaterialProperty(Cesium.Color.fromCssColorString(mColor));
- colorMaterial._param = {
- color: mColor
- };
- return colorMaterial;
- }
- });
- Object.assign(DrawMilitaryPlot.prototype, {
- drawActivate(type2) {
- this._setMousePointerStyle();
- this.handleFirstPosition(type2);
- this.Draw.startCreate(type2);
- this.Draw.DrawEndEvent.addEventListener((entity, positions, drawType) => {
- this._setMouseDefaultStyle();
- if (entity) {
- let entityParam = DrawMilitaryPlot.initEditPropertyParams();
- entity.setParams(entityParam);
- this._setEntityIsEdit(entity);
- }
- });
- this.drawArr.push(this.Draw);
- return this.Draw;
- },
- clearOne: function() {
- this.Draw.clear();
- },
- clearAll: function() {
- for (var i2 = 0; i2 < this.drawArr.length; i2++) {
- this.drawArr[i2].clear();
- }
- this.edit.deactivate();
- this._closePropertyEditDialog();
- let buttonDiv = document.getElementById("drawButtonDiv");
- if (buttonDiv) {
- document.body.removeChild(buttonDiv);
- }
- }
- });
- Object.assign(DrawMilitaryPlot.prototype, {
- _openPropertyEditDialog: function(params, callEdit, callRemove) {
- this._editPropertyDialogDomId = "dialog-property-dom-militaryplot";
- this._registerDOMPropertyEdit = "dialog-edit-property-militaryplot";
- let PropertyEditComponent = customElements.get(this._registerDOMPropertyEdit);
- if (PropertyEditComponent === void 0) {
- PropertyEditComponent = defineCustomElement(DialogEditProperty$1);
- customElements.define(this._registerDOMPropertyEdit, PropertyEditComponent);
- }
- this._closePropertyEditDialog();
- let dialogPropertyElement = new PropertyEditComponent({
- params
- });
- dialogPropertyElement.id = this._editPropertyDialogDomId;
- dialogPropertyElement.showDialog = true;
- document.body.appendChild(dialogPropertyElement);
- dialogPropertyElement.addEventListener(
- "submit",
- (e) => {
- if (callEdit)
- callEdit(e.detail[0]);
- },
- false
- );
- dialogPropertyElement.addEventListener(
- "remove",
- (e) => {
- if (callRemove)
- callRemove();
- },
- false
- );
- },
- _closePropertyEditDialog() {
- let dom2 = document.getElementById(this._editPropertyDialogDomId);
- if (dom2 !== null && dom2 !== void 0) {
- document.body.removeChild(dom2);
- }
- }
- });
- var _style_0 = `@charset "UTF-8";:root{--el-color-white:#ffffff;--el-color-black:#000000;--el-color-primary-rgb:64,158,255;--el-color-success-rgb:103,194,58;--el-color-warning-rgb:230,162,60;--el-color-danger-rgb:245,108,108;--el-color-error-rgb:245,108,108;--el-color-info-rgb:144,147,153;--el-font-size-extra-large:20px;--el-font-size-large:18px;--el-font-size-medium:16px;--el-font-size-base:14px;--el-font-size-small:13px;--el-font-size-extra-small:12px;--el-font-family:"Helvetica Neue",Helvetica,"PingFang SC","Hiragino Sans GB","Microsoft YaHei","\\5fae\\8f6f\\96c5\\9ed1",Arial,sans-serif;--el-font-weight-primary:500;--el-font-line-height-primary:24px;--el-index-normal:1;--el-index-top:1000;--el-index-popper:2000;--el-border-radius-base:4px;--el-border-radius-small:2px;--el-border-radius-round:20px;--el-border-radius-circle:100%;--el-transition-duration:.3s;--el-transition-duration-fast:.2s;--el-transition-function-ease-in-out-bezier:cubic-bezier(.645, .045, .355, 1);--el-transition-function-fast-bezier:cubic-bezier(.23, 1, .32, 1);--el-transition-all:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);--el-transition-fade:opacity var(--el-transition-duration) var(--el-transition-function-fast-bezier);--el-transition-md-fade:transform var(--el-transition-duration) var(--el-transition-function-fast-bezier),opacity var(--el-transition-duration) var(--el-transition-function-fast-bezier);--el-transition-fade-linear:opacity var(--el-transition-duration-fast) linear;--el-transition-border:border-color var(--el-transition-duration-fast) var(--el-transition-function-ease-in-out-bezier);--el-transition-box-shadow:box-shadow var(--el-transition-duration-fast) var(--el-transition-function-ease-in-out-bezier);--el-transition-color:color var(--el-transition-duration-fast) var(--el-transition-function-ease-in-out-bezier);--el-component-size-large:40px;--el-component-size:32px;--el-component-size-small:24px}:root{color-scheme:light;--el-color-white:#ffffff;--el-color-black:#000000;--el-color-primary:#409eff;--el-color-primary-light-3:#79bbff;--el-color-primary-light-5:#a0cfff;--el-color-primary-light-7:#c6e2ff;--el-color-primary-light-8:#d9ecff;--el-color-primary-light-9:#ecf5ff;--el-color-primary-dark-2:#337ecc;--el-color-success:#67c23a;--el-color-success-light-3:#95d475;--el-color-success-light-5:#b3e19d;--el-color-success-light-7:#d1edc4;--el-color-success-light-8:#e1f3d8;--el-color-success-light-9:#f0f9eb;--el-color-success-dark-2:#529b2e;--el-color-warning:#e6a23c;--el-color-warning-light-3:#eebe77;--el-color-warning-light-5:#f3d19e;--el-color-warning-light-7:#f8e3c5;--el-color-warning-light-8:#faecd8;--el-color-warning-light-9:#fdf6ec;--el-color-warning-dark-2:#b88230;--el-color-danger:#f56c6c;--el-color-danger-light-3:#f89898;--el-color-danger-light-5:#fab6b6;--el-color-danger-light-7:#fcd3d3;--el-color-danger-light-8:#fde2e2;--el-color-danger-light-9:#fef0f0;--el-color-danger-dark-2:#c45656;--el-color-error:#f56c6c;--el-color-error-light-3:#f89898;--el-color-error-light-5:#fab6b6;--el-color-error-light-7:#fcd3d3;--el-color-error-light-8:#fde2e2;--el-color-error-light-9:#fef0f0;--el-color-error-dark-2:#c45656;--el-color-info:#909399;--el-color-info-light-3:#b1b3b8;--el-color-info-light-5:#c8c9cc;--el-color-info-light-7:#dedfe0;--el-color-info-light-8:#e9e9eb;--el-color-info-light-9:#f4f4f5;--el-color-info-dark-2:#73767a;--el-bg-color:#ffffff;--el-bg-color-page:#f2f3f5;--el-bg-color-overlay:#ffffff;--el-text-color-primary:#303133;--el-text-color-regular:#606266;--el-text-color-secondary:#909399;--el-text-color-placeholder:#a8abb2;--el-text-color-disabled:#c0c4cc;--el-border-color:#dcdfe6;--el-border-color-light:#e4e7ed;--el-border-color-lighter:#ebeef5;--el-border-color-extra-light:#f2f6fc;--el-border-color-dark:#d4d7de;--el-border-color-darker:#cdd0d6;--el-fill-color:#f0f2f5;--el-fill-color-light:#f5f7fa;--el-fill-color-lighter:#fafafa;--el-fill-color-extra-light:#fafcff;--el-fill-color-dark:#ebedf0;--el-fill-color-darker:#e6e8eb;--el-fill-color-blank:#ffffff;--el-box-shadow:0px 12px 32px 4px rgba(0, 0, 0, .04),0px 8px 20px rgba(0, 0, 0, .08);--el-box-shadow-light:0px 0px 12px rgba(0, 0, 0, .12);--el-box-shadow-lighter:0px 0px 6px rgba(0, 0, 0, .12);--el-box-shadow-dark:0px 16px 48px 16px rgba(0, 0, 0, .08),0px 12px 32px rgba(0, 0, 0, .12),0px 8px 16px -8px rgba(0, 0, 0, .16);--el-disabled-bg-color:var(--el-fill-color-light);--el-disabled-text-color:var(--el-text-color-placeholder);--el-disabled-border-color:var(--el-border-color-light);--el-overlay-color:rgba(0, 0, 0, .8);--el-overlay-color-light:rgba(0, 0, 0, .7);--el-overlay-color-lighter:rgba(0, 0, 0, .5);--el-mask-color:rgba(255, 255, 255, .9);--el-mask-color-extra-light:rgba(255, 255, 255, .3);--el-border-width:1px;--el-border-style:solid;--el-border-color-hover:var(--el-text-color-disabled);--el-border:var(--el-border-width) var(--el-border-style) var(--el-border-color);--el-svg-monochrome-grey:var(--el-border-color)}.fade-in-linear-enter-active,.fade-in-linear-leave-active{transition:var(--el-transition-fade-linear)}.fade-in-linear-enter-from,.fade-in-linear-leave-to{opacity:0}.el-fade-in-linear-enter-active,.el-fade-in-linear-leave-active{transition:var(--el-transition-fade-linear)}.el-fade-in-linear-enter-from,.el-fade-in-linear-leave-to{opacity:0}.el-fade-in-enter-active,.el-fade-in-leave-active{transition:all var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}.el-fade-in-enter-from,.el-fade-in-leave-active{opacity:0}.el-zoom-in-center-enter-active,.el-zoom-in-center-leave-active{transition:all var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}.el-zoom-in-center-enter-from,.el-zoom-in-center-leave-active{opacity:0;transform:scaleX(0)}.el-zoom-in-top-enter-active,.el-zoom-in-top-leave-active{opacity:1;transform:scaleY(1);transition:var(--el-transition-md-fade);transform-origin:center top}.el-zoom-in-top-enter-active[data-popper-placement^=top],.el-zoom-in-top-leave-active[data-popper-placement^=top]{transform-origin:center bottom}.el-zoom-in-top-enter-from,.el-zoom-in-top-leave-active{opacity:0;transform:scaleY(0)}.el-zoom-in-bottom-enter-active,.el-zoom-in-bottom-leave-active{opacity:1;transform:scaleY(1);transition:var(--el-transition-md-fade);transform-origin:center bottom}.el-zoom-in-bottom-enter-from,.el-zoom-in-bottom-leave-active{opacity:0;transform:scaleY(0)}.el-zoom-in-left-enter-active,.el-zoom-in-left-leave-active{opacity:1;transform:scale(1);transition:var(--el-transition-md-fade);transform-origin:top left}.el-zoom-in-left-enter-from,.el-zoom-in-left-leave-active{opacity:0;transform:scale(.45)}.collapse-transition{transition:var(--el-transition-duration) height ease-in-out,var(--el-transition-duration) padding-top ease-in-out,var(--el-transition-duration) padding-bottom ease-in-out}.el-collapse-transition-enter-active,.el-collapse-transition-leave-active{transition:var(--el-transition-duration) max-height ease-in-out,var(--el-transition-duration) padding-top ease-in-out,var(--el-transition-duration) padding-bottom ease-in-out}.horizontal-collapse-transition{transition:var(--el-transition-duration) width ease-in-out,var(--el-transition-duration) padding-left ease-in-out,var(--el-transition-duration) padding-right ease-in-out}.el-list-enter-active,.el-list-leave-active{transition:all 1s}.el-list-enter-from,.el-list-leave-to{opacity:0;transform:translateY(-30px)}.el-list-leave-active{position:absolute!important}.el-opacity-transition{transition:opacity var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}.el-icon-loading{-webkit-animation:rotating 2s linear infinite;animation:rotating 2s linear infinite}.el-icon--right{margin-left:5px}.el-icon--left{margin-right:5px}@-webkit-keyframes rotating{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes rotating{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.el-icon{--color:inherit;height:1em;width:1em;line-height:1em;display:inline-flex;justify-content:center;align-items:center;position:relative;fill:currentColor;color:var(--color);font-size:inherit}.el-icon.is-loading{-webkit-animation:rotating 2s linear infinite;animation:rotating 2s linear infinite}.el-icon svg{height:1em;width:1em}.el-affix--fixed{position:fixed}.el-alert{--el-alert-padding:8px 16px;--el-alert-border-radius-base:var(--el-border-radius-base);--el-alert-title-font-size:13px;--el-alert-description-font-size:12px;--el-alert-close-font-size:12px;--el-alert-close-customed-font-size:13px;--el-alert-icon-size:16px;--el-alert-icon-large-size:28px;width:100%;padding:var(--el-alert-padding);margin:0;box-sizing:border-box;border-radius:var(--el-alert-border-radius-base);position:relative;background-color:var(--el-color-white);overflow:hidden;opacity:1;display:flex;align-items:center;transition:opacity var(--el-transition-duration-fast)}.el-alert.is-light .el-alert__close-btn{color:var(--el-text-color-placeholder)}.el-alert.is-dark .el-alert__close-btn,.el-alert.is-dark .el-alert__description{color:var(--el-color-white)}.el-alert.is-center{justify-content:center}.el-alert--success{--el-alert-bg-color:var(--el-color-success-light-9)}.el-alert--success.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-success)}.el-alert--success.is-light .el-alert__description{color:var(--el-color-success)}.el-alert--success.is-dark{background-color:var(--el-color-success);color:var(--el-color-white)}.el-alert--info{--el-alert-bg-color:var(--el-color-info-light-9)}.el-alert--info.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-info)}.el-alert--info.is-light .el-alert__description{color:var(--el-color-info)}.el-alert--info.is-dark{background-color:var(--el-color-info);color:var(--el-color-white)}.el-alert--warning{--el-alert-bg-color:var(--el-color-warning-light-9)}.el-alert--warning.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-warning)}.el-alert--warning.is-light .el-alert__description{color:var(--el-color-warning)}.el-alert--warning.is-dark{background-color:var(--el-color-warning);color:var(--el-color-white)}.el-alert--error{--el-alert-bg-color:var(--el-color-error-light-9)}.el-alert--error.is-light{background-color:var(--el-alert-bg-color);color:var(--el-color-error)}.el-alert--error.is-light .el-alert__description{color:var(--el-color-error)}.el-alert--error.is-dark{background-color:var(--el-color-error);color:var(--el-color-white)}.el-alert__content{display:table-cell;padding:0 8px}.el-alert .el-alert__icon{font-size:var(--el-alert-icon-size);width:var(--el-alert-icon-size)}.el-alert .el-alert__icon.is-big{font-size:var(--el-alert-icon-large-size);width:var(--el-alert-icon-large-size)}.el-alert__title{font-size:var(--el-alert-title-font-size);line-height:18px;vertical-align:text-top}.el-alert__title.is-bold{font-weight:700}.el-alert .el-alert__description{font-size:var(--el-alert-description-font-size);margin:5px 0 0}.el-alert .el-alert__close-btn{font-size:var(--el-alert-close-font-size);opacity:1;position:absolute;top:12px;right:15px;cursor:pointer}.el-alert .el-alert__close-btn.is-customed{font-style:normal;font-size:var(--el-alert-close-customed-font-size);top:9px}.el-alert-fade-enter-from,.el-alert-fade-leave-active{opacity:0}.el-aside{overflow:auto;box-sizing:border-box;flex-shrink:0;width:var(--el-aside-width,300px)}.el-autocomplete{position:relative;display:inline-block}.el-autocomplete__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-box-shadow-light)}.el-autocomplete__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-autocomplete__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-autocomplete__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-autocomplete__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-autocomplete__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-autocomplete-suggestion{border-radius:var(--el-border-radius-base);box-sizing:border-box}.el-autocomplete-suggestion__wrap{max-height:280px;padding:10px 0;box-sizing:border-box}.el-autocomplete-suggestion__list{margin:0;padding:0}.el-autocomplete-suggestion li{padding:0 20px;margin:0;line-height:34px;cursor:pointer;color:var(--el-text-color-regular);font-size:var(--el-font-size-base);list-style:none;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.el-autocomplete-suggestion li:hover,.el-autocomplete-suggestion li.highlighted{background-color:var(--el-fill-color-light)}.el-autocomplete-suggestion li.divider{margin-top:6px;border-top:1px solid var(--el-color-black)}.el-autocomplete-suggestion li.divider:last-child{margin-bottom:-6px}.el-autocomplete-suggestion.is-loading li{text-align:center;height:100px;line-height:100px;font-size:20px;color:var(--el-text-color-secondary)}.el-autocomplete-suggestion.is-loading li:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-autocomplete-suggestion.is-loading li:hover{background-color:var(--el-bg-color-overlay)}.el-autocomplete-suggestion.is-loading .el-icon-loading{vertical-align:middle}.el-avatar{--el-avatar-text-color:var(--el-color-white);--el-avatar-bg-color:var(--el-text-color-disabled);--el-avatar-text-size:14px;--el-avatar-icon-size:18px;--el-avatar-border-radius:var(--el-border-radius-base);--el-avatar-size-large:56px;--el-avatar-size-small:24px;--el-avatar-size:40px;display:inline-flex;justify-content:center;align-items:center;box-sizing:border-box;text-align:center;overflow:hidden;color:var(--el-avatar-text-color);background:var(--el-avatar-bg-color);width:var(--el-avatar-size);height:var(--el-avatar-size);font-size:var(--el-avatar-text-size)}.el-avatar>img{display:block;height:100%}.el-avatar--circle{border-radius:50%}.el-avatar--square{border-radius:var(--el-avatar-border-radius)}.el-avatar--icon{font-size:var(--el-avatar-icon-size)}.el-avatar--small{--el-avatar-size:24px}.el-avatar--large{--el-avatar-size:56px}.el-backtop{--el-backtop-bg-color:var(--el-bg-color-overlay);--el-backtop-text-color:var(--el-color-primary);--el-backtop-hover-bg-color:var(--el-border-color-extra-light);position:fixed;background-color:var(--el-backtop-bg-color);width:40px;height:40px;border-radius:50%;color:var(--el-backtop-text-color);display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:var(--el-box-shadow-lighter);cursor:pointer;z-index:5}.el-backtop:hover{background-color:var(--el-backtop-hover-bg-color)}.el-backtop__icon{font-size:20px}.el-badge{--el-badge-bg-color:var(--el-color-danger);--el-badge-radius:10px;--el-badge-font-size:12px;--el-badge-padding:6px;--el-badge-size:18px;position:relative;vertical-align:middle;display:inline-block;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.el-badge__content{background-color:var(--el-badge-bg-color);border-radius:var(--el-badge-radius);color:var(--el-color-white);display:inline-flex;justify-content:center;align-items:center;font-size:var(--el-badge-font-size);height:var(--el-badge-size);padding:0 var(--el-badge-padding);white-space:nowrap;border:1px solid var(--el-bg-color)}.el-badge__content.is-fixed{position:absolute;top:0;right:calc(1px + var(--el-badge-size)/ 2);transform:translateY(-50%) translate(100%);z-index:var(--el-index-normal)}.el-badge__content.is-fixed.is-dot{right:5px}.el-badge__content.is-dot{height:8px;width:8px;padding:0;right:0;border-radius:50%}.el-badge__content--primary{background-color:var(--el-color-primary)}.el-badge__content--success{background-color:var(--el-color-success)}.el-badge__content--warning{background-color:var(--el-color-warning)}.el-badge__content--info{background-color:var(--el-color-info)}.el-badge__content--danger{background-color:var(--el-color-danger)}.el-breadcrumb{font-size:14px;line-height:1}.el-breadcrumb:after,.el-breadcrumb:before{display:table;content:""}.el-breadcrumb:after{clear:both}.el-breadcrumb__separator{margin:0 9px;font-weight:700;color:var(--el-text-color-placeholder)}.el-breadcrumb__separator.el-icon{margin:0 6px;font-weight:400}.el-breadcrumb__separator.el-icon svg{vertical-align:middle}.el-breadcrumb__item{float:left;display:inline-flex;align-items:center}.el-breadcrumb__inner{color:var(--el-text-color-regular)}.el-breadcrumb__inner a,.el-breadcrumb__inner.is-link{font-weight:700;text-decoration:none;transition:var(--el-transition-color);color:var(--el-text-color-primary)}.el-breadcrumb__inner a:hover,.el-breadcrumb__inner.is-link:hover{color:var(--el-color-primary);cursor:pointer}.el-breadcrumb__item:last-child .el-breadcrumb__inner,.el-breadcrumb__item:last-child .el-breadcrumb__inner a,.el-breadcrumb__item:last-child .el-breadcrumb__inner a:hover,.el-breadcrumb__item:last-child .el-breadcrumb__inner:hover{font-weight:400;color:var(--el-text-color-regular);cursor:text}.el-breadcrumb__item:last-child .el-breadcrumb__separator{display:none}.el-button-group{display:inline-block;vertical-align:middle}.el-button-group:after,.el-button-group:before{display:table;content:""}.el-button-group:after{clear:both}.el-button-group>.el-button{float:left;position:relative}.el-button-group>.el-button+.el-button{margin-left:0}.el-button-group>.el-button:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.el-button-group>.el-button:last-child{border-top-left-radius:0;border-bottom-left-radius:0}.el-button-group>.el-button:first-child:last-child{border-top-right-radius:var(--el-border-radius-base);border-bottom-right-radius:var(--el-border-radius-base);border-top-left-radius:var(--el-border-radius-base);border-bottom-left-radius:var(--el-border-radius-base)}.el-button-group>.el-button:first-child:last-child.is-round{border-radius:var(--el-border-radius-round)}.el-button-group>.el-button:first-child:last-child.is-circle{border-radius:50%}.el-button-group>.el-button:not(:first-child):not(:last-child){border-radius:0}.el-button-group>.el-button:not(:last-child){margin-right:-1px}.el-button-group>.el-button:active,.el-button-group>.el-button:focus,.el-button-group>.el-button:hover{z-index:1}.el-button-group>.el-button.is-active{z-index:1}.el-button-group>.el-dropdown>.el-button{border-top-left-radius:0;border-bottom-left-radius:0;border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--primary:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--primary:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--primary:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--success:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--success:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--success:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--warning:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--warning:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--warning:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--danger:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--danger:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--danger:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--info:first-child{border-right-color:var(--el-button-divide-border-color)}.el-button-group .el-button--info:last-child{border-left-color:var(--el-button-divide-border-color)}.el-button-group .el-button--info:not(:first-child):not(:last-child){border-left-color:var(--el-button-divide-border-color);border-right-color:var(--el-button-divide-border-color)}.el-button{--el-button-font-weight:var(--el-font-weight-primary);--el-button-border-color:var(--el-border-color);--el-button-bg-color:var(--el-fill-color-blank);--el-button-text-color:var(--el-text-color-regular);--el-button-disabled-text-color:var(--el-disabled-text-color);--el-button-disabled-bg-color:var(--el-fill-color-blank);--el-button-disabled-border-color:var(--el-border-color-light);--el-button-divide-border-color:rgba(255, 255, 255, .5);--el-button-hover-text-color:var(--el-color-primary);--el-button-hover-bg-color:var(--el-color-primary-light-9);--el-button-hover-border-color:var(--el-color-primary-light-7);--el-button-active-text-color:var(--el-button-hover-text-color);--el-button-active-border-color:var(--el-color-primary);--el-button-active-bg-color:var(--el-button-hover-bg-color);--el-button-outline-color:var(--el-color-primary-light-5);--el-button-hover-link-text-color:var(--el-color-info);--el-button-active-color:var(--el-text-color-primary)}.el-button{display:inline-flex;justify-content:center;align-items:center;line-height:1;height:32px;white-space:nowrap;cursor:pointer;color:var(--el-button-text-color);text-align:center;box-sizing:border-box;outline:0;transition:.1s;font-weight:var(--el-button-font-weight);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;vertical-align:middle;-webkit-appearance:none;background-color:var(--el-button-bg-color);border:var(--el-border);border-color:var(--el-button-border-color);padding:8px 15px;font-size:var(--el-font-size-base);border-radius:var(--el-border-radius-base)}.el-button:focus,.el-button:hover{color:var(--el-button-hover-text-color);border-color:var(--el-button-hover-border-color);background-color:var(--el-button-hover-bg-color);outline:0}.el-button:active{color:var(--el-button-active-text-color);border-color:var(--el-button-active-border-color);background-color:var(--el-button-active-bg-color);outline:0}.el-button:focus-visible{outline:2px solid var(--el-button-outline-color);outline-offset:1px}.el-button>span{display:inline-flex;align-items:center}.el-button+.el-button{margin-left:12px}.el-button.is-round{padding:8px 15px}.el-button::-moz-focus-inner{border:0}.el-button [class*=el-icon]+span{margin-left:6px}.el-button [class*=el-icon] svg{vertical-align:bottom}.el-button.is-plain{--el-button-hover-text-color:var(--el-color-primary);--el-button-hover-bg-color:var(--el-fill-color-blank);--el-button-hover-border-color:var(--el-color-primary)}.el-button.is-active{color:var(--el-button-active-text-color);border-color:var(--el-button-active-border-color);background-color:var(--el-button-active-bg-color);outline:0}.el-button.is-disabled,.el-button.is-disabled:focus,.el-button.is-disabled:hover{color:var(--el-button-disabled-text-color);cursor:not-allowed;background-image:none;background-color:var(--el-button-disabled-bg-color);border-color:var(--el-button-disabled-border-color)}.el-button.is-loading{position:relative;pointer-events:none}.el-button.is-loading:before{z-index:1;pointer-events:none;content:"";position:absolute;left:-1px;top:-1px;right:-1px;bottom:-1px;border-radius:inherit;background-color:var(--el-mask-color-extra-light)}.el-button.is-round{border-radius:var(--el-border-radius-round)}.el-button.is-circle{border-radius:50%;padding:8px}.el-button.is-text{color:var(--el-button-text-color);border:0 solid transparent;background-color:transparent}.el-button.is-text.is-disabled{color:var(--el-button-disabled-text-color);background-color:transparent!important}.el-button.is-text:not(.is-disabled):focus,.el-button.is-text:not(.is-disabled):hover{background-color:var(--el-fill-color-light)}.el-button.is-text:not(.is-disabled):focus-visible{outline:2px solid var(--el-button-outline-color);outline-offset:1px}.el-button.is-text:not(.is-disabled):active{background-color:var(--el-fill-color)}.el-button.is-text:not(.is-disabled).is-has-bg{background-color:var(--el-fill-color-light)}.el-button.is-text:not(.is-disabled).is-has-bg:focus,.el-button.is-text:not(.is-disabled).is-has-bg:hover{background-color:var(--el-fill-color)}.el-button.is-text:not(.is-disabled).is-has-bg:active{background-color:var(--el-fill-color-dark)}.el-button__text--expand{letter-spacing:.3em;margin-right:-.3em}.el-button.is-link{border-color:transparent;color:var(--el-button-text-color);background:0 0;padding:2px;height:auto}.el-button.is-link:focus,.el-button.is-link:hover{color:var(--el-button-hover-link-text-color)}.el-button.is-link.is-disabled{color:var(--el-button-disabled-text-color);background-color:transparent!important;border-color:transparent!important}.el-button.is-link:not(.is-disabled):focus,.el-button.is-link:not(.is-disabled):hover{border-color:transparent;background-color:transparent}.el-button.is-link:not(.is-disabled):active{color:var(--el-button-active-color);border-color:transparent;background-color:transparent}.el-button--text{border-color:transparent;background:0 0;color:var(--el-color-primary);padding-left:0;padding-right:0}.el-button--text.is-disabled{color:var(--el-button-disabled-text-color);background-color:transparent!important;border-color:transparent!important}.el-button--text:not(.is-disabled):focus,.el-button--text:not(.is-disabled):hover{color:var(--el-color-primary-light-3);border-color:transparent;background-color:transparent}.el-button--text:not(.is-disabled):active{color:var(--el-color-primary-dark-2);border-color:transparent;background-color:transparent}.el-button__link--expand{letter-spacing:.3em;margin-right:-.3em}.el-button--primary{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-primary);--el-button-border-color:var(--el-color-primary);--el-button-outline-color:var(--el-color-primary-light-5);--el-button-active-color:var(--el-color-primary-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-primary-light-5);--el-button-hover-bg-color:var(--el-color-primary-light-3);--el-button-hover-border-color:var(--el-color-primary-light-3);--el-button-active-bg-color:var(--el-color-primary-dark-2);--el-button-active-border-color:var(--el-color-primary-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-primary-light-5);--el-button-disabled-border-color:var(--el-color-primary-light-5)}.el-button--primary.is-link,.el-button--primary.is-plain,.el-button--primary.is-text{--el-button-text-color:var(--el-color-primary);--el-button-bg-color:var(--el-color-primary-light-9);--el-button-border-color:var(--el-color-primary-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-primary);--el-button-hover-border-color:var(--el-color-primary);--el-button-active-text-color:var(--el-color-white)}.el-button--primary.is-link.is-disabled,.el-button--primary.is-link.is-disabled:active,.el-button--primary.is-link.is-disabled:focus,.el-button--primary.is-link.is-disabled:hover,.el-button--primary.is-plain.is-disabled,.el-button--primary.is-plain.is-disabled:active,.el-button--primary.is-plain.is-disabled:focus,.el-button--primary.is-plain.is-disabled:hover,.el-button--primary.is-text.is-disabled,.el-button--primary.is-text.is-disabled:active,.el-button--primary.is-text.is-disabled:focus,.el-button--primary.is-text.is-disabled:hover{color:var(--el-color-primary-light-5);background-color:var(--el-color-primary-light-9);border-color:var(--el-color-primary-light-8)}.el-button--success{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-success);--el-button-border-color:var(--el-color-success);--el-button-outline-color:var(--el-color-success-light-5);--el-button-active-color:var(--el-color-success-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-success-light-5);--el-button-hover-bg-color:var(--el-color-success-light-3);--el-button-hover-border-color:var(--el-color-success-light-3);--el-button-active-bg-color:var(--el-color-success-dark-2);--el-button-active-border-color:var(--el-color-success-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-success-light-5);--el-button-disabled-border-color:var(--el-color-success-light-5)}.el-button--success.is-link,.el-button--success.is-plain,.el-button--success.is-text{--el-button-text-color:var(--el-color-success);--el-button-bg-color:var(--el-color-success-light-9);--el-button-border-color:var(--el-color-success-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-success);--el-button-hover-border-color:var(--el-color-success);--el-button-active-text-color:var(--el-color-white)}.el-button--success.is-link.is-disabled,.el-button--success.is-link.is-disabled:active,.el-button--success.is-link.is-disabled:focus,.el-button--success.is-link.is-disabled:hover,.el-button--success.is-plain.is-disabled,.el-button--success.is-plain.is-disabled:active,.el-button--success.is-plain.is-disabled:focus,.el-button--success.is-plain.is-disabled:hover,.el-button--success.is-text.is-disabled,.el-button--success.is-text.is-disabled:active,.el-button--success.is-text.is-disabled:focus,.el-button--success.is-text.is-disabled:hover{color:var(--el-color-success-light-5);background-color:var(--el-color-success-light-9);border-color:var(--el-color-success-light-8)}.el-button--warning{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-warning);--el-button-border-color:var(--el-color-warning);--el-button-outline-color:var(--el-color-warning-light-5);--el-button-active-color:var(--el-color-warning-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-warning-light-5);--el-button-hover-bg-color:var(--el-color-warning-light-3);--el-button-hover-border-color:var(--el-color-warning-light-3);--el-button-active-bg-color:var(--el-color-warning-dark-2);--el-button-active-border-color:var(--el-color-warning-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-warning-light-5);--el-button-disabled-border-color:var(--el-color-warning-light-5)}.el-button--warning.is-link,.el-button--warning.is-plain,.el-button--warning.is-text{--el-button-text-color:var(--el-color-warning);--el-button-bg-color:var(--el-color-warning-light-9);--el-button-border-color:var(--el-color-warning-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-warning);--el-button-hover-border-color:var(--el-color-warning);--el-button-active-text-color:var(--el-color-white)}.el-button--warning.is-link.is-disabled,.el-button--warning.is-link.is-disabled:active,.el-button--warning.is-link.is-disabled:focus,.el-button--warning.is-link.is-disabled:hover,.el-button--warning.is-plain.is-disabled,.el-button--warning.is-plain.is-disabled:active,.el-button--warning.is-plain.is-disabled:focus,.el-button--warning.is-plain.is-disabled:hover,.el-button--warning.is-text.is-disabled,.el-button--warning.is-text.is-disabled:active,.el-button--warning.is-text.is-disabled:focus,.el-button--warning.is-text.is-disabled:hover{color:var(--el-color-warning-light-5);background-color:var(--el-color-warning-light-9);border-color:var(--el-color-warning-light-8)}.el-button--danger{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-danger);--el-button-border-color:var(--el-color-danger);--el-button-outline-color:var(--el-color-danger-light-5);--el-button-active-color:var(--el-color-danger-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-danger-light-5);--el-button-hover-bg-color:var(--el-color-danger-light-3);--el-button-hover-border-color:var(--el-color-danger-light-3);--el-button-active-bg-color:var(--el-color-danger-dark-2);--el-button-active-border-color:var(--el-color-danger-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-danger-light-5);--el-button-disabled-border-color:var(--el-color-danger-light-5)}.el-button--danger.is-link,.el-button--danger.is-plain,.el-button--danger.is-text{--el-button-text-color:var(--el-color-danger);--el-button-bg-color:var(--el-color-danger-light-9);--el-button-border-color:var(--el-color-danger-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-danger);--el-button-hover-border-color:var(--el-color-danger);--el-button-active-text-color:var(--el-color-white)}.el-button--danger.is-link.is-disabled,.el-button--danger.is-link.is-disabled:active,.el-button--danger.is-link.is-disabled:focus,.el-button--danger.is-link.is-disabled:hover,.el-button--danger.is-plain.is-disabled,.el-button--danger.is-plain.is-disabled:active,.el-button--danger.is-plain.is-disabled:focus,.el-button--danger.is-plain.is-disabled:hover,.el-button--danger.is-text.is-disabled,.el-button--danger.is-text.is-disabled:active,.el-button--danger.is-text.is-disabled:focus,.el-button--danger.is-text.is-disabled:hover{color:var(--el-color-danger-light-5);background-color:var(--el-color-danger-light-9);border-color:var(--el-color-danger-light-8)}.el-button--info{--el-button-text-color:var(--el-color-white);--el-button-bg-color:var(--el-color-info);--el-button-border-color:var(--el-color-info);--el-button-outline-color:var(--el-color-info-light-5);--el-button-active-color:var(--el-color-info-dark-2);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-link-text-color:var(--el-color-info-light-5);--el-button-hover-bg-color:var(--el-color-info-light-3);--el-button-hover-border-color:var(--el-color-info-light-3);--el-button-active-bg-color:var(--el-color-info-dark-2);--el-button-active-border-color:var(--el-color-info-dark-2);--el-button-disabled-text-color:var(--el-color-white);--el-button-disabled-bg-color:var(--el-color-info-light-5);--el-button-disabled-border-color:var(--el-color-info-light-5)}.el-button--info.is-link,.el-button--info.is-plain,.el-button--info.is-text{--el-button-text-color:var(--el-color-info);--el-button-bg-color:var(--el-color-info-light-9);--el-button-border-color:var(--el-color-info-light-5);--el-button-hover-text-color:var(--el-color-white);--el-button-hover-bg-color:var(--el-color-info);--el-button-hover-border-color:var(--el-color-info);--el-button-active-text-color:var(--el-color-white)}.el-button--info.is-link.is-disabled,.el-button--info.is-link.is-disabled:active,.el-button--info.is-link.is-disabled:focus,.el-button--info.is-link.is-disabled:hover,.el-button--info.is-plain.is-disabled,.el-button--info.is-plain.is-disabled:active,.el-button--info.is-plain.is-disabled:focus,.el-button--info.is-plain.is-disabled:hover,.el-button--info.is-text.is-disabled,.el-button--info.is-text.is-disabled:active,.el-button--info.is-text.is-disabled:focus,.el-button--info.is-text.is-disabled:hover{color:var(--el-color-info-light-5);background-color:var(--el-color-info-light-9);border-color:var(--el-color-info-light-8)}.el-button--large{--el-button-size:40px;height:var(--el-button-size);padding:12px 19px;font-size:var(--el-font-size-base);border-radius:var(--el-border-radius-base)}.el-button--large [class*=el-icon]+span{margin-left:8px}.el-button--large.is-round{padding:12px 19px}.el-button--large.is-circle{width:var(--el-button-size);padding:12px}.el-button--small{--el-button-size:24px;height:var(--el-button-size);padding:5px 11px;font-size:12px;border-radius:calc(var(--el-border-radius-base) - 1px)}.el-button--small [class*=el-icon]+span{margin-left:4px}.el-button--small.is-round{padding:5px 11px}.el-button--small.is-circle{width:var(--el-button-size);padding:5px}.el-calendar{--el-calendar-border:var(--el-table-border, 1px solid var(--el-border-color-lighter));--el-calendar-header-border-bottom:var(--el-calendar-border);--el-calendar-selected-bg-color:var(--el-color-primary-light-9);--el-calendar-cell-width:85px;background-color:var(--el-fill-color-blank)}.el-calendar__header{display:flex;justify-content:space-between;padding:12px 20px;border-bottom:var(--el-calendar-header-border-bottom)}.el-calendar__title{color:var(--el-text-color);align-self:center}.el-calendar__body{padding:12px 20px 35px}.el-calendar-table{table-layout:fixed;width:100%}.el-calendar-table thead th{padding:12px 0;color:var(--el-text-color-regular);font-weight:400}.el-calendar-table:not(.is-range) td.next,.el-calendar-table:not(.is-range) td.prev{color:var(--el-text-color-placeholder)}.el-calendar-table td{border-bottom:var(--el-calendar-border);border-right:var(--el-calendar-border);vertical-align:top;transition:background-color var(--el-transition-duration-fast) ease}.el-calendar-table td.is-selected{background-color:var(--el-calendar-selected-bg-color)}.el-calendar-table td.is-today{color:var(--el-color-primary)}.el-calendar-table tr:first-child td{border-top:var(--el-calendar-border)}.el-calendar-table tr td:first-child{border-left:var(--el-calendar-border)}.el-calendar-table tr.el-calendar-table__row--hide-border td{border-top:none}.el-calendar-table .el-calendar-day{box-sizing:border-box;padding:8px;height:var(--el-calendar-cell-width)}.el-calendar-table .el-calendar-day:hover{cursor:pointer;background-color:var(--el-calendar-selected-bg-color)}.el-card{--el-card-border-color:var(--el-border-color-light);--el-card-border-radius:4px;--el-card-padding:20px;--el-card-bg-color:var(--el-fill-color-blank)}.el-card{border-radius:var(--el-card-border-radius);border:1px solid var(--el-card-border-color);background-color:var(--el-card-bg-color);overflow:hidden;color:var(--el-text-color-primary);transition:var(--el-transition-duration)}.el-card.is-always-shadow{box-shadow:var(--el-box-shadow-light)}.el-card.is-hover-shadow:focus,.el-card.is-hover-shadow:hover{box-shadow:var(--el-box-shadow-light)}.el-card__header{padding:calc(var(--el-card-padding) - 2px) var(--el-card-padding);border-bottom:1px solid var(--el-card-border-color);box-sizing:border-box}.el-card__body{padding:var(--el-card-padding)}.el-carousel__item{position:absolute;top:0;left:0;width:100%;height:100%;display:inline-block;overflow:hidden;z-index:calc(var(--el-index-normal) - 1)}.el-carousel__item.is-active{z-index:calc(var(--el-index-normal) - 1)}.el-carousel__item.is-animating{transition:transform .4s ease-in-out}.el-carousel__item--card{width:50%;transition:transform .4s ease-in-out}.el-carousel__item--card.is-in-stage{cursor:pointer;z-index:var(--el-index-normal)}.el-carousel__item--card.is-in-stage.is-hover .el-carousel__mask,.el-carousel__item--card.is-in-stage:hover .el-carousel__mask{opacity:.12}.el-carousel__item--card.is-active{z-index:calc(var(--el-index-normal) + 1)}.el-carousel__mask{position:absolute;width:100%;height:100%;top:0;left:0;background-color:var(--el-color-white);opacity:.24;transition:var(--el-transition-duration-fast)}.el-carousel{--el-carousel-arrow-font-size:12px;--el-carousel-arrow-size:36px;--el-carousel-arrow-background:rgba(31, 45, 61, .11);--el-carousel-arrow-hover-background:rgba(31, 45, 61, .23);--el-carousel-indicator-width:30px;--el-carousel-indicator-height:2px;--el-carousel-indicator-padding-horizontal:4px;--el-carousel-indicator-padding-vertical:12px;--el-carousel-indicator-out-color:var(--el-border-color-hover);position:relative}.el-carousel--horizontal{overflow-x:hidden}.el-carousel--vertical{overflow-y:hidden}.el-carousel__container{position:relative;height:300px}.el-carousel__arrow{border:none;outline:0;padding:0;margin:0;height:var(--el-carousel-arrow-size);width:var(--el-carousel-arrow-size);cursor:pointer;transition:var(--el-transition-duration);border-radius:50%;background-color:var(--el-carousel-arrow-background);color:#fff;position:absolute;top:50%;z-index:10;transform:translateY(-50%);text-align:center;font-size:var(--el-carousel-arrow-font-size);display:inline-flex;justify-content:center;align-items:center}.el-carousel__arrow--left{left:16px}.el-carousel__arrow--right{right:16px}.el-carousel__arrow:hover{background-color:var(--el-carousel-arrow-hover-background)}.el-carousel__arrow i{cursor:pointer}.el-carousel__indicators{position:absolute;list-style:none;margin:0;padding:0;z-index:calc(var(--el-index-normal) + 1)}.el-carousel__indicators--horizontal{bottom:0;left:50%;transform:translate(-50%)}.el-carousel__indicators--vertical{right:0;top:50%;transform:translateY(-50%)}.el-carousel__indicators--outside{bottom:calc(var(--el-carousel-indicator-height) + var(--el-carousel-indicator-padding-vertical) * 2);text-align:center;position:static;transform:none}.el-carousel__indicators--outside .el-carousel__indicator:hover button{opacity:.64}.el-carousel__indicators--outside button{background-color:var(--el-carousel-indicator-out-color);opacity:.24}.el-carousel__indicators--labels{left:0;right:0;transform:none;text-align:center}.el-carousel__indicators--labels .el-carousel__button{height:auto;width:auto;padding:2px 18px;font-size:12px;color:#000}.el-carousel__indicators--labels .el-carousel__indicator{padding:6px 4px}.el-carousel__indicator{background-color:transparent;cursor:pointer}.el-carousel__indicator:hover button{opacity:.72}.el-carousel__indicator--horizontal{display:inline-block;padding:var(--el-carousel-indicator-padding-vertical) var(--el-carousel-indicator-padding-horizontal)}.el-carousel__indicator--vertical{padding:var(--el-carousel-indicator-padding-horizontal) var(--el-carousel-indicator-padding-vertical)}.el-carousel__indicator--vertical .el-carousel__button{width:var(--el-carousel-indicator-height);height:calc(var(--el-carousel-indicator-width)/ 2)}.el-carousel__indicator.is-active button{opacity:1}.el-carousel__button{display:block;opacity:.48;width:var(--el-carousel-indicator-width);height:var(--el-carousel-indicator-height);background-color:#fff;border:none;outline:0;padding:0;margin:0;cursor:pointer;transition:var(--el-transition-duration)}.carousel-arrow-left-enter-from,.carousel-arrow-left-leave-active{transform:translateY(-50%) translate(-10px);opacity:0}.carousel-arrow-right-enter-from,.carousel-arrow-right-leave-active{transform:translateY(-50%) translate(10px);opacity:0}.el-cascader-panel{--el-cascader-menu-text-color:var(--el-text-color-regular);--el-cascader-menu-selected-text-color:var(--el-color-primary);--el-cascader-menu-fill:var(--el-bg-color-overlay);--el-cascader-menu-font-size:var(--el-font-size-base);--el-cascader-menu-radius:var(--el-border-radius-base);--el-cascader-menu-border:solid 1px var(--el-border-color-light);--el-cascader-menu-shadow:var(--el-box-shadow-light);--el-cascader-node-background-hover:var(--el-fill-color-light);--el-cascader-node-color-disabled:var(--el-text-color-placeholder);--el-cascader-color-empty:var(--el-text-color-placeholder);--el-cascader-tag-background:var(--el-fill-color)}.el-cascader-panel{display:flex;border-radius:var(--el-cascader-menu-radius);font-size:var(--el-cascader-menu-font-size)}.el-cascader-panel.is-bordered{border:var(--el-cascader-menu-border);border-radius:var(--el-cascader-menu-radius)}.el-cascader-menu{min-width:180px;box-sizing:border-box;color:var(--el-cascader-menu-text-color);border-right:var(--el-cascader-menu-border)}.el-cascader-menu:last-child{border-right:none}.el-cascader-menu:last-child .el-cascader-node{padding-right:20px}.el-cascader-menu__wrap.el-scrollbar__wrap{height:204px}.el-cascader-menu__list{position:relative;min-height:100%;margin:0;padding:6px 0;list-style:none;box-sizing:border-box}.el-cascader-menu__hover-zone{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.el-cascader-menu__empty-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;color:var(--el-cascader-color-empty)}.el-cascader-menu__empty-text .is-loading{margin-right:2px}.el-cascader-node{position:relative;display:flex;align-items:center;padding:0 30px 0 20px;height:34px;line-height:34px;outline:0}.el-cascader-node.is-selectable.in-active-path{color:var(--el-cascader-menu-text-color)}.el-cascader-node.in-active-path,.el-cascader-node.is-active,.el-cascader-node.is-selectable.in-checked-path{color:var(--el-cascader-menu-selected-text-color);font-weight:700}.el-cascader-node:not(.is-disabled){cursor:pointer}.el-cascader-node:not(.is-disabled):focus,.el-cascader-node:not(.is-disabled):hover{background:var(--el-cascader-node-background-hover)}.el-cascader-node.is-disabled{color:var(--el-cascader-node-color-disabled);cursor:not-allowed}.el-cascader-node__prefix{position:absolute;left:10px}.el-cascader-node__postfix{position:absolute;right:10px}.el-cascader-node__label{flex:1;text-align:left;padding:0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.el-cascader-node>.el-checkbox{margin-right:0}.el-cascader-node>.el-radio{margin-right:0}.el-cascader-node>.el-radio .el-radio__label{padding-left:0}.el-cascader{--el-cascader-menu-text-color:var(--el-text-color-regular);--el-cascader-menu-selected-text-color:var(--el-color-primary);--el-cascader-menu-fill:var(--el-bg-color-overlay);--el-cascader-menu-font-size:var(--el-font-size-base);--el-cascader-menu-radius:var(--el-border-radius-base);--el-cascader-menu-border:solid 1px var(--el-border-color-light);--el-cascader-menu-shadow:var(--el-box-shadow-light);--el-cascader-node-background-hover:var(--el-fill-color-light);--el-cascader-node-color-disabled:var(--el-text-color-placeholder);--el-cascader-color-empty:var(--el-text-color-placeholder);--el-cascader-tag-background:var(--el-fill-color);display:inline-block;vertical-align:middle;position:relative;font-size:var(--el-font-size-base);line-height:32px;outline:0}.el-cascader:not(.is-disabled):hover .el-input__wrapper{cursor:pointer;box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-cascader .el-input{display:flex;cursor:pointer}.el-cascader .el-input .el-input__inner{text-overflow:ellipsis;cursor:pointer}.el-cascader .el-input .el-input__suffix-inner .el-icon{height:calc(100% - 2px)}.el-cascader .el-input .el-input__suffix-inner .el-icon svg{vertical-align:middle}.el-cascader .el-input .icon-arrow-down{transition:transform var(--el-transition-duration);font-size:14px}.el-cascader .el-input .icon-arrow-down.is-reverse{transform:rotate(180deg)}.el-cascader .el-input .icon-circle-close:hover{color:var(--el-input-clear-hover-color,var(--el-text-color-secondary))}.el-cascader .el-input.is-focus .el-input__wrapper{box-shadow:0 0 0 1px var(--el-input-focus-border-color,var(--el-color-primary)) inset}.el-cascader--large{font-size:14px;line-height:40px}.el-cascader--small{font-size:12px;line-height:24px}.el-cascader.is-disabled .el-cascader__label{z-index:calc(var(--el-index-normal) + 1);color:var(--el-disabled-text-color)}.el-cascader__dropdown{--el-cascader-menu-text-color:var(--el-text-color-regular);--el-cascader-menu-selected-text-color:var(--el-color-primary);--el-cascader-menu-fill:var(--el-bg-color-overlay);--el-cascader-menu-font-size:var(--el-font-size-base);--el-cascader-menu-radius:var(--el-border-radius-base);--el-cascader-menu-border:solid 1px var(--el-border-color-light);--el-cascader-menu-shadow:var(--el-box-shadow-light);--el-cascader-node-background-hover:var(--el-fill-color-light);--el-cascader-node-color-disabled:var(--el-text-color-placeholder);--el-cascader-color-empty:var(--el-text-color-placeholder);--el-cascader-tag-background:var(--el-fill-color)}.el-cascader__dropdown{font-size:var(--el-cascader-menu-font-size);border-radius:var(--el-cascader-menu-radius)}.el-cascader__dropdown.el-popper{background:var(--el-cascader-menu-fill);border:var(--el-cascader-menu-border);box-shadow:var(--el-cascader-menu-shadow)}.el-cascader__dropdown.el-popper .el-popper__arrow:before{border:var(--el-cascader-menu-border)}.el-cascader__dropdown.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-cascader__dropdown.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-cascader__dropdown.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-cascader__dropdown.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-cascader__dropdown.el-popper{box-shadow:var(--el-cascader-menu-shadow)}.el-cascader__tags{position:absolute;left:0;right:30px;top:50%;transform:translateY(-50%);display:flex;flex-wrap:wrap;line-height:normal;text-align:left;box-sizing:border-box}.el-cascader__tags .el-tag{display:inline-flex;align-items:center;max-width:100%;margin:2px 0 2px 6px;text-overflow:ellipsis;background:var(--el-cascader-tag-background)}.el-cascader__tags .el-tag:not(.is-hit){border-color:transparent}.el-cascader__tags .el-tag>span{flex:1;overflow:hidden;text-overflow:ellipsis}.el-cascader__tags .el-tag .el-icon-close{flex:none;background-color:var(--el-text-color-placeholder);color:var(--el-color-white)}.el-cascader__tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-cascader__collapse-tags{white-space:normal;z-index:var(--el-index-normal)}.el-cascader__collapse-tags .el-tag{display:inline-flex;align-items:center;max-width:100%;margin:2px 0 2px 6px;text-overflow:ellipsis;background:var(--el-fill-color)}.el-cascader__collapse-tags .el-tag:not(.is-hit){border-color:transparent}.el-cascader__collapse-tags .el-tag>span{flex:1;overflow:hidden;text-overflow:ellipsis}.el-cascader__collapse-tags .el-tag .el-icon-close{flex:none;background-color:var(--el-text-color-placeholder);color:var(--el-color-white)}.el-cascader__collapse-tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-cascader__suggestion-panel{border-radius:var(--el-cascader-menu-radius)}.el-cascader__suggestion-list{max-height:204px;margin:0;padding:6px 0;font-size:var(--el-font-size-base);color:var(--el-cascader-menu-text-color);text-align:center}.el-cascader__suggestion-item{display:flex;justify-content:space-between;align-items:center;height:34px;padding:0 15px;text-align:left;outline:0;cursor:pointer}.el-cascader__suggestion-item:focus,.el-cascader__suggestion-item:hover{background:var(--el-cascader-node-background-hover)}.el-cascader__suggestion-item.is-checked{color:var(--el-cascader-menu-selected-text-color);font-weight:700}.el-cascader__suggestion-item>span{margin-right:10px}.el-cascader__empty-text{margin:10px 0;color:var(--el-cascader-color-empty)}.el-cascader__search-input{flex:1;height:24px;min-width:60px;margin:2px 0 2px 11px;padding:0;color:var(--el-cascader-menu-text-color);border:none;outline:0;box-sizing:border-box;background:0 0}.el-cascader__search-input::-moz-placeholder{color:transparent}.el-cascader__search-input:-ms-input-placeholder{color:transparent}.el-cascader__search-input::placeholder{color:transparent}.el-check-tag{background-color:var(--el-color-info-light-9);border-radius:var(--el-border-radius-base);color:var(--el-color-info);cursor:pointer;display:inline-block;font-size:var(--el-font-size-base);line-height:var(--el-font-size-base);padding:7px 15px;transition:var(--el-transition-all);font-weight:700}.el-check-tag:hover{background-color:var(--el-color-info-light-7)}.el-check-tag.is-checked{background-color:var(--el-color-primary-light-8);color:var(--el-color-primary)}.el-check-tag.is-checked:hover{background-color:var(--el-color-primary-light-7)}.el-checkbox-button{--el-checkbox-button-checked-bg-color:var(--el-color-primary);--el-checkbox-button-checked-text-color:var(--el-color-white);--el-checkbox-button-checked-border-color:var(--el-color-primary)}.el-checkbox-button{position:relative;display:inline-block}.el-checkbox-button__inner{display:inline-block;line-height:1;font-weight:var(--el-checkbox-font-weight);white-space:nowrap;vertical-align:middle;cursor:pointer;background:var(--el-button-bg-color,var(--el-fill-color-blank));border:var(--el-border);border-left:0;color:var(--el-button-text-color,var(--el-text-color-regular));-webkit-appearance:none;text-align:center;box-sizing:border-box;outline:0;margin:0;position:relative;transition:var(--el-transition-all);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;padding:8px 15px;font-size:var(--el-font-size-base);border-radius:0}.el-checkbox-button__inner.is-round{padding:8px 15px}.el-checkbox-button__inner:hover{color:var(--el-color-primary)}.el-checkbox-button__inner [class*=el-icon-]{line-height:.9}.el-checkbox-button__inner [class*=el-icon-]+span{margin-left:5px}.el-checkbox-button__original{opacity:0;outline:0;position:absolute;margin:0;z-index:-1}.el-checkbox-button.is-checked .el-checkbox-button__inner{color:var(--el-checkbox-button-checked-text-color);background-color:var(--el-checkbox-button-checked-bg-color);border-color:var(--el-checkbox-button-checked-border-color);box-shadow:-1px 0 0 0 var(--el-color-primary-light-7)}.el-checkbox-button.is-checked:first-child .el-checkbox-button__inner{border-left-color:var(--el-checkbox-button-checked-border-color)}.el-checkbox-button.is-disabled .el-checkbox-button__inner{color:var(--el-disabled-text-color);cursor:not-allowed;background-image:none;background-color:var(--el-button-disabled-bg-color,var(--el-fill-color-blank));border-color:var(--el-button-disabled-border-color,var(--el-border-color-light));box-shadow:none}.el-checkbox-button.is-disabled:first-child .el-checkbox-button__inner{border-left-color:var(--el-button-disabled-border-color,var(--el-border-color-light))}.el-checkbox-button:first-child .el-checkbox-button__inner{border-left:var(--el-border);border-top-left-radius:var(--el-border-radius-base);border-bottom-left-radius:var(--el-border-radius-base);box-shadow:none!important}.el-checkbox-button.is-focus .el-checkbox-button__inner{border-color:var(--el-checkbox-button-checked-border-color)}.el-checkbox-button:last-child .el-checkbox-button__inner{border-top-right-radius:var(--el-border-radius-base);border-bottom-right-radius:var(--el-border-radius-base)}.el-checkbox-button--large .el-checkbox-button__inner{padding:12px 19px;font-size:var(--el-font-size-base);border-radius:0}.el-checkbox-button--large .el-checkbox-button__inner.is-round{padding:12px 19px}.el-checkbox-button--small .el-checkbox-button__inner{padding:5px 11px;font-size:12px;border-radius:0}.el-checkbox-button--small .el-checkbox-button__inner.is-round{padding:5px 11px}.el-checkbox-group{font-size:0;line-height:0}.el-checkbox{--el-checkbox-font-size:14px;--el-checkbox-font-weight:var(--el-font-weight-primary);--el-checkbox-text-color:var(--el-text-color-regular);--el-checkbox-input-height:14px;--el-checkbox-input-width:14px;--el-checkbox-border-radius:var(--el-border-radius-small);--el-checkbox-bg-color:var(--el-fill-color-blank);--el-checkbox-input-border:var(--el-border);--el-checkbox-disabled-border-color:var(--el-border-color);--el-checkbox-disabled-input-fill:var(--el-fill-color-light);--el-checkbox-disabled-icon-color:var(--el-text-color-placeholder);--el-checkbox-disabled-checked-input-fill:var(--el-border-color-extra-light);--el-checkbox-disabled-checked-input-border-color:var(--el-border-color);--el-checkbox-disabled-checked-icon-color:var(--el-text-color-placeholder);--el-checkbox-checked-text-color:var(--el-color-primary);--el-checkbox-checked-input-border-color:var(--el-color-primary);--el-checkbox-checked-bg-color:var(--el-color-primary);--el-checkbox-checked-icon-color:var(--el-color-white);--el-checkbox-input-border-color-hover:var(--el-color-primary)}.el-checkbox{color:var(--el-checkbox-text-color);font-weight:var(--el-checkbox-font-weight);font-size:var(--el-font-size-base);position:relative;cursor:pointer;display:inline-flex;align-items:center;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;margin-right:30px;height:32px}.el-checkbox.is-disabled{cursor:not-allowed}.el-checkbox.is-bordered{padding:0 15px 0 9px;border-radius:var(--el-border-radius-base);border:var(--el-border);box-sizing:border-box}.el-checkbox.is-bordered.is-checked{border-color:var(--el-color-primary)}.el-checkbox.is-bordered.is-disabled{border-color:var(--el-border-color-lighter)}.el-checkbox.is-bordered.el-checkbox--large{padding:0 19px 0 11px;border-radius:var(--el-border-radius-base)}.el-checkbox.is-bordered.el-checkbox--large .el-checkbox__label{font-size:var(--el-font-size-base)}.el-checkbox.is-bordered.el-checkbox--large .el-checkbox__inner{height:14px;width:14px}.el-checkbox.is-bordered.el-checkbox--small{padding:0 11px 0 7px;border-radius:calc(var(--el-border-radius-base) - 1px)}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__label{font-size:12px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__inner{height:12px;width:12px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__inner:after{height:6px;width:2px}.el-checkbox input:focus-visible+.el-checkbox__inner{outline:2px solid var(--el-checkbox-input-border-color-hover);outline-offset:1px;border-radius:var(--el-checkbox-border-radius)}.el-checkbox__input{white-space:nowrap;cursor:pointer;outline:0;display:inline-flex;position:relative}.el-checkbox__input.is-disabled .el-checkbox__inner{background-color:var(--el-checkbox-disabled-input-fill);border-color:var(--el-checkbox-disabled-border-color);cursor:not-allowed}.el-checkbox__input.is-disabled .el-checkbox__inner:after{cursor:not-allowed;border-color:var(--el-checkbox-disabled-icon-color)}.el-checkbox__input.is-disabled.is-checked .el-checkbox__inner{background-color:var(--el-checkbox-disabled-checked-input-fill);border-color:var(--el-checkbox-disabled-checked-input-border-color)}.el-checkbox__input.is-disabled.is-checked .el-checkbox__inner:after{border-color:var(--el-checkbox-disabled-checked-icon-color)}.el-checkbox__input.is-disabled.is-indeterminate .el-checkbox__inner{background-color:var(--el-checkbox-disabled-checked-input-fill);border-color:var(--el-checkbox-disabled-checked-input-border-color)}.el-checkbox__input.is-disabled.is-indeterminate .el-checkbox__inner:before{background-color:var(--el-checkbox-disabled-checked-icon-color);border-color:var(--el-checkbox-disabled-checked-icon-color)}.el-checkbox__input.is-disabled+span.el-checkbox__label{color:var(--el-disabled-text-color);cursor:not-allowed}.el-checkbox__input.is-checked .el-checkbox__inner{background-color:var(--el-checkbox-checked-bg-color);border-color:var(--el-checkbox-checked-input-border-color)}.el-checkbox__input.is-checked .el-checkbox__inner:after{transform:rotate(45deg) scaleY(1)}.el-checkbox__input.is-checked+.el-checkbox__label{color:var(--el-checkbox-checked-text-color)}.el-checkbox__input.is-focus:not(.is-checked) .el-checkbox__original:not(:focus-visible){border-color:var(--el-checkbox-input-border-color-hover)}.el-checkbox__input.is-indeterminate .el-checkbox__inner{background-color:var(--el-checkbox-checked-bg-color);border-color:var(--el-checkbox-checked-input-border-color)}.el-checkbox__input.is-indeterminate .el-checkbox__inner:before{content:"";position:absolute;display:block;background-color:var(--el-checkbox-checked-icon-color);height:2px;transform:scale(.5);left:0;right:0;top:5px}.el-checkbox__input.is-indeterminate .el-checkbox__inner:after{display:none}.el-checkbox__inner{display:inline-block;position:relative;border:var(--el-checkbox-input-border);border-radius:var(--el-checkbox-border-radius);box-sizing:border-box;width:var(--el-checkbox-input-width);height:var(--el-checkbox-input-height);background-color:var(--el-checkbox-bg-color);z-index:var(--el-index-normal);transition:border-color .25s cubic-bezier(.71,-.46,.29,1.46),background-color .25s cubic-bezier(.71,-.46,.29,1.46),outline .25s cubic-bezier(.71,-.46,.29,1.46)}.el-checkbox__inner:hover{border-color:var(--el-checkbox-input-border-color-hover)}.el-checkbox__inner:after{box-sizing:content-box;content:"";border:1px solid var(--el-checkbox-checked-icon-color);border-left:0;border-top:0;height:7px;left:4px;position:absolute;top:1px;transform:rotate(45deg) scaleY(0);width:3px;transition:transform .15s ease-in 50ms;transform-origin:center}.el-checkbox__original{opacity:0;outline:0;position:absolute;margin:0;width:0;height:0;z-index:-1}.el-checkbox__label{display:inline-block;padding-left:8px;line-height:1;font-size:var(--el-checkbox-font-size)}.el-checkbox.el-checkbox--large{height:40px}.el-checkbox.el-checkbox--large .el-checkbox__label{font-size:14px}.el-checkbox.el-checkbox--large .el-checkbox__inner{width:14px;height:14px}.el-checkbox.el-checkbox--small{height:24px}.el-checkbox.el-checkbox--small .el-checkbox__label{font-size:12px}.el-checkbox.el-checkbox--small .el-checkbox__inner{width:12px;height:12px}.el-checkbox.el-checkbox--small .el-checkbox__input.is-indeterminate .el-checkbox__inner:before{top:4px}.el-checkbox.el-checkbox--small .el-checkbox__inner:after{width:2px;height:6px}.el-checkbox:last-of-type{margin-right:0}[class*=el-col-]{box-sizing:border-box}[class*=el-col-].is-guttered{display:block;min-height:1px}.el-col-0,.el-col-0.is-guttered{display:none}.el-col-0{max-width:0%;flex:0 0 0%}.el-col-offset-0{margin-left:0}.el-col-pull-0{position:relative;right:0}.el-col-push-0{position:relative;left:0}.el-col-1{max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-offset-1{margin-left:4.1666666667%}.el-col-pull-1{position:relative;right:4.1666666667%}.el-col-push-1{position:relative;left:4.1666666667%}.el-col-2{max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-offset-2{margin-left:8.3333333333%}.el-col-pull-2{position:relative;right:8.3333333333%}.el-col-push-2{position:relative;left:8.3333333333%}.el-col-3{max-width:12.5%;flex:0 0 12.5%}.el-col-offset-3{margin-left:12.5%}.el-col-pull-3{position:relative;right:12.5%}.el-col-push-3{position:relative;left:12.5%}.el-col-4{max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-offset-4{margin-left:16.6666666667%}.el-col-pull-4{position:relative;right:16.6666666667%}.el-col-push-4{position:relative;left:16.6666666667%}.el-col-5{max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-offset-5{margin-left:20.8333333333%}.el-col-pull-5{position:relative;right:20.8333333333%}.el-col-push-5{position:relative;left:20.8333333333%}.el-col-6{max-width:25%;flex:0 0 25%}.el-col-offset-6{margin-left:25%}.el-col-pull-6{position:relative;right:25%}.el-col-push-6{position:relative;left:25%}.el-col-7{max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-offset-7{margin-left:29.1666666667%}.el-col-pull-7{position:relative;right:29.1666666667%}.el-col-push-7{position:relative;left:29.1666666667%}.el-col-8{max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-offset-8{margin-left:33.3333333333%}.el-col-pull-8{position:relative;right:33.3333333333%}.el-col-push-8{position:relative;left:33.3333333333%}.el-col-9{max-width:37.5%;flex:0 0 37.5%}.el-col-offset-9{margin-left:37.5%}.el-col-pull-9{position:relative;right:37.5%}.el-col-push-9{position:relative;left:37.5%}.el-col-10{max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-offset-10{margin-left:41.6666666667%}.el-col-pull-10{position:relative;right:41.6666666667%}.el-col-push-10{position:relative;left:41.6666666667%}.el-col-11{max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-offset-11{margin-left:45.8333333333%}.el-col-pull-11{position:relative;right:45.8333333333%}.el-col-push-11{position:relative;left:45.8333333333%}.el-col-12{max-width:50%;flex:0 0 50%}.el-col-offset-12{margin-left:50%}.el-col-pull-12{position:relative;right:50%}.el-col-push-12{position:relative;left:50%}.el-col-13{max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-offset-13{margin-left:54.1666666667%}.el-col-pull-13{position:relative;right:54.1666666667%}.el-col-push-13{position:relative;left:54.1666666667%}.el-col-14{max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-offset-14{margin-left:58.3333333333%}.el-col-pull-14{position:relative;right:58.3333333333%}.el-col-push-14{position:relative;left:58.3333333333%}.el-col-15{max-width:62.5%;flex:0 0 62.5%}.el-col-offset-15{margin-left:62.5%}.el-col-pull-15{position:relative;right:62.5%}.el-col-push-15{position:relative;left:62.5%}.el-col-16{max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-offset-16{margin-left:66.6666666667%}.el-col-pull-16{position:relative;right:66.6666666667%}.el-col-push-16{position:relative;left:66.6666666667%}.el-col-17{max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-offset-17{margin-left:70.8333333333%}.el-col-pull-17{position:relative;right:70.8333333333%}.el-col-push-17{position:relative;left:70.8333333333%}.el-col-18{max-width:75%;flex:0 0 75%}.el-col-offset-18{margin-left:75%}.el-col-pull-18{position:relative;right:75%}.el-col-push-18{position:relative;left:75%}.el-col-19{max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-offset-19{margin-left:79.1666666667%}.el-col-pull-19{position:relative;right:79.1666666667%}.el-col-push-19{position:relative;left:79.1666666667%}.el-col-20{max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-offset-20{margin-left:83.3333333333%}.el-col-pull-20{position:relative;right:83.3333333333%}.el-col-push-20{position:relative;left:83.3333333333%}.el-col-21{max-width:87.5%;flex:0 0 87.5%}.el-col-offset-21{margin-left:87.5%}.el-col-pull-21{position:relative;right:87.5%}.el-col-push-21{position:relative;left:87.5%}.el-col-22{max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-offset-22{margin-left:91.6666666667%}.el-col-pull-22{position:relative;right:91.6666666667%}.el-col-push-22{position:relative;left:91.6666666667%}.el-col-23{max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-offset-23{margin-left:95.8333333333%}.el-col-pull-23{position:relative;right:95.8333333333%}.el-col-push-23{position:relative;left:95.8333333333%}.el-col-24{max-width:100%;flex:0 0 100%}.el-col-offset-24{margin-left:100%}.el-col-pull-24{position:relative;right:100%}.el-col-push-24{position:relative;left:100%}@media only screen and (max-width:768px){.el-col-xs-0,.el-col-xs-0.is-guttered{display:none}.el-col-xs-0{max-width:0%;flex:0 0 0%}.el-col-xs-offset-0{margin-left:0}.el-col-xs-pull-0{position:relative;right:0}.el-col-xs-push-0{position:relative;left:0}.el-col-xs-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-xs-offset-1{margin-left:4.1666666667%}.el-col-xs-pull-1{position:relative;right:4.1666666667%}.el-col-xs-push-1{position:relative;left:4.1666666667%}.el-col-xs-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-xs-offset-2{margin-left:8.3333333333%}.el-col-xs-pull-2{position:relative;right:8.3333333333%}.el-col-xs-push-2{position:relative;left:8.3333333333%}.el-col-xs-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-xs-offset-3{margin-left:12.5%}.el-col-xs-pull-3{position:relative;right:12.5%}.el-col-xs-push-3{position:relative;left:12.5%}.el-col-xs-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-xs-offset-4{margin-left:16.6666666667%}.el-col-xs-pull-4{position:relative;right:16.6666666667%}.el-col-xs-push-4{position:relative;left:16.6666666667%}.el-col-xs-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-xs-offset-5{margin-left:20.8333333333%}.el-col-xs-pull-5{position:relative;right:20.8333333333%}.el-col-xs-push-5{position:relative;left:20.8333333333%}.el-col-xs-6{display:block;max-width:25%;flex:0 0 25%}.el-col-xs-offset-6{margin-left:25%}.el-col-xs-pull-6{position:relative;right:25%}.el-col-xs-push-6{position:relative;left:25%}.el-col-xs-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-xs-offset-7{margin-left:29.1666666667%}.el-col-xs-pull-7{position:relative;right:29.1666666667%}.el-col-xs-push-7{position:relative;left:29.1666666667%}.el-col-xs-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-xs-offset-8{margin-left:33.3333333333%}.el-col-xs-pull-8{position:relative;right:33.3333333333%}.el-col-xs-push-8{position:relative;left:33.3333333333%}.el-col-xs-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-xs-offset-9{margin-left:37.5%}.el-col-xs-pull-9{position:relative;right:37.5%}.el-col-xs-push-9{position:relative;left:37.5%}.el-col-xs-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-xs-offset-10{margin-left:41.6666666667%}.el-col-xs-pull-10{position:relative;right:41.6666666667%}.el-col-xs-push-10{position:relative;left:41.6666666667%}.el-col-xs-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-xs-offset-11{margin-left:45.8333333333%}.el-col-xs-pull-11{position:relative;right:45.8333333333%}.el-col-xs-push-11{position:relative;left:45.8333333333%}.el-col-xs-12{display:block;max-width:50%;flex:0 0 50%}.el-col-xs-offset-12{margin-left:50%}.el-col-xs-pull-12{position:relative;right:50%}.el-col-xs-push-12{position:relative;left:50%}.el-col-xs-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-xs-offset-13{margin-left:54.1666666667%}.el-col-xs-pull-13{position:relative;right:54.1666666667%}.el-col-xs-push-13{position:relative;left:54.1666666667%}.el-col-xs-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-xs-offset-14{margin-left:58.3333333333%}.el-col-xs-pull-14{position:relative;right:58.3333333333%}.el-col-xs-push-14{position:relative;left:58.3333333333%}.el-col-xs-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-xs-offset-15{margin-left:62.5%}.el-col-xs-pull-15{position:relative;right:62.5%}.el-col-xs-push-15{position:relative;left:62.5%}.el-col-xs-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-xs-offset-16{margin-left:66.6666666667%}.el-col-xs-pull-16{position:relative;right:66.6666666667%}.el-col-xs-push-16{position:relative;left:66.6666666667%}.el-col-xs-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-xs-offset-17{margin-left:70.8333333333%}.el-col-xs-pull-17{position:relative;right:70.8333333333%}.el-col-xs-push-17{position:relative;left:70.8333333333%}.el-col-xs-18{display:block;max-width:75%;flex:0 0 75%}.el-col-xs-offset-18{margin-left:75%}.el-col-xs-pull-18{position:relative;right:75%}.el-col-xs-push-18{position:relative;left:75%}.el-col-xs-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-xs-offset-19{margin-left:79.1666666667%}.el-col-xs-pull-19{position:relative;right:79.1666666667%}.el-col-xs-push-19{position:relative;left:79.1666666667%}.el-col-xs-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-xs-offset-20{margin-left:83.3333333333%}.el-col-xs-pull-20{position:relative;right:83.3333333333%}.el-col-xs-push-20{position:relative;left:83.3333333333%}.el-col-xs-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-xs-offset-21{margin-left:87.5%}.el-col-xs-pull-21{position:relative;right:87.5%}.el-col-xs-push-21{position:relative;left:87.5%}.el-col-xs-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-xs-offset-22{margin-left:91.6666666667%}.el-col-xs-pull-22{position:relative;right:91.6666666667%}.el-col-xs-push-22{position:relative;left:91.6666666667%}.el-col-xs-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-xs-offset-23{margin-left:95.8333333333%}.el-col-xs-pull-23{position:relative;right:95.8333333333%}.el-col-xs-push-23{position:relative;left:95.8333333333%}.el-col-xs-24{display:block;max-width:100%;flex:0 0 100%}.el-col-xs-offset-24{margin-left:100%}.el-col-xs-pull-24{position:relative;right:100%}.el-col-xs-push-24{position:relative;left:100%}}@media only screen and (min-width:768px){.el-col-sm-0,.el-col-sm-0.is-guttered{display:none}.el-col-sm-0{max-width:0%;flex:0 0 0%}.el-col-sm-offset-0{margin-left:0}.el-col-sm-pull-0{position:relative;right:0}.el-col-sm-push-0{position:relative;left:0}.el-col-sm-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-sm-offset-1{margin-left:4.1666666667%}.el-col-sm-pull-1{position:relative;right:4.1666666667%}.el-col-sm-push-1{position:relative;left:4.1666666667%}.el-col-sm-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-sm-offset-2{margin-left:8.3333333333%}.el-col-sm-pull-2{position:relative;right:8.3333333333%}.el-col-sm-push-2{position:relative;left:8.3333333333%}.el-col-sm-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-sm-offset-3{margin-left:12.5%}.el-col-sm-pull-3{position:relative;right:12.5%}.el-col-sm-push-3{position:relative;left:12.5%}.el-col-sm-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-sm-offset-4{margin-left:16.6666666667%}.el-col-sm-pull-4{position:relative;right:16.6666666667%}.el-col-sm-push-4{position:relative;left:16.6666666667%}.el-col-sm-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-sm-offset-5{margin-left:20.8333333333%}.el-col-sm-pull-5{position:relative;right:20.8333333333%}.el-col-sm-push-5{position:relative;left:20.8333333333%}.el-col-sm-6{display:block;max-width:25%;flex:0 0 25%}.el-col-sm-offset-6{margin-left:25%}.el-col-sm-pull-6{position:relative;right:25%}.el-col-sm-push-6{position:relative;left:25%}.el-col-sm-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-sm-offset-7{margin-left:29.1666666667%}.el-col-sm-pull-7{position:relative;right:29.1666666667%}.el-col-sm-push-7{position:relative;left:29.1666666667%}.el-col-sm-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-sm-offset-8{margin-left:33.3333333333%}.el-col-sm-pull-8{position:relative;right:33.3333333333%}.el-col-sm-push-8{position:relative;left:33.3333333333%}.el-col-sm-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-sm-offset-9{margin-left:37.5%}.el-col-sm-pull-9{position:relative;right:37.5%}.el-col-sm-push-9{position:relative;left:37.5%}.el-col-sm-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-sm-offset-10{margin-left:41.6666666667%}.el-col-sm-pull-10{position:relative;right:41.6666666667%}.el-col-sm-push-10{position:relative;left:41.6666666667%}.el-col-sm-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-sm-offset-11{margin-left:45.8333333333%}.el-col-sm-pull-11{position:relative;right:45.8333333333%}.el-col-sm-push-11{position:relative;left:45.8333333333%}.el-col-sm-12{display:block;max-width:50%;flex:0 0 50%}.el-col-sm-offset-12{margin-left:50%}.el-col-sm-pull-12{position:relative;right:50%}.el-col-sm-push-12{position:relative;left:50%}.el-col-sm-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-sm-offset-13{margin-left:54.1666666667%}.el-col-sm-pull-13{position:relative;right:54.1666666667%}.el-col-sm-push-13{position:relative;left:54.1666666667%}.el-col-sm-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-sm-offset-14{margin-left:58.3333333333%}.el-col-sm-pull-14{position:relative;right:58.3333333333%}.el-col-sm-push-14{position:relative;left:58.3333333333%}.el-col-sm-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-sm-offset-15{margin-left:62.5%}.el-col-sm-pull-15{position:relative;right:62.5%}.el-col-sm-push-15{position:relative;left:62.5%}.el-col-sm-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-sm-offset-16{margin-left:66.6666666667%}.el-col-sm-pull-16{position:relative;right:66.6666666667%}.el-col-sm-push-16{position:relative;left:66.6666666667%}.el-col-sm-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-sm-offset-17{margin-left:70.8333333333%}.el-col-sm-pull-17{position:relative;right:70.8333333333%}.el-col-sm-push-17{position:relative;left:70.8333333333%}.el-col-sm-18{display:block;max-width:75%;flex:0 0 75%}.el-col-sm-offset-18{margin-left:75%}.el-col-sm-pull-18{position:relative;right:75%}.el-col-sm-push-18{position:relative;left:75%}.el-col-sm-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-sm-offset-19{margin-left:79.1666666667%}.el-col-sm-pull-19{position:relative;right:79.1666666667%}.el-col-sm-push-19{position:relative;left:79.1666666667%}.el-col-sm-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-sm-offset-20{margin-left:83.3333333333%}.el-col-sm-pull-20{position:relative;right:83.3333333333%}.el-col-sm-push-20{position:relative;left:83.3333333333%}.el-col-sm-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-sm-offset-21{margin-left:87.5%}.el-col-sm-pull-21{position:relative;right:87.5%}.el-col-sm-push-21{position:relative;left:87.5%}.el-col-sm-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-sm-offset-22{margin-left:91.6666666667%}.el-col-sm-pull-22{position:relative;right:91.6666666667%}.el-col-sm-push-22{position:relative;left:91.6666666667%}.el-col-sm-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-sm-offset-23{margin-left:95.8333333333%}.el-col-sm-pull-23{position:relative;right:95.8333333333%}.el-col-sm-push-23{position:relative;left:95.8333333333%}.el-col-sm-24{display:block;max-width:100%;flex:0 0 100%}.el-col-sm-offset-24{margin-left:100%}.el-col-sm-pull-24{position:relative;right:100%}.el-col-sm-push-24{position:relative;left:100%}}@media only screen and (min-width:992px){.el-col-md-0,.el-col-md-0.is-guttered{display:none}.el-col-md-0{max-width:0%;flex:0 0 0%}.el-col-md-offset-0{margin-left:0}.el-col-md-pull-0{position:relative;right:0}.el-col-md-push-0{position:relative;left:0}.el-col-md-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-md-offset-1{margin-left:4.1666666667%}.el-col-md-pull-1{position:relative;right:4.1666666667%}.el-col-md-push-1{position:relative;left:4.1666666667%}.el-col-md-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-md-offset-2{margin-left:8.3333333333%}.el-col-md-pull-2{position:relative;right:8.3333333333%}.el-col-md-push-2{position:relative;left:8.3333333333%}.el-col-md-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-md-offset-3{margin-left:12.5%}.el-col-md-pull-3{position:relative;right:12.5%}.el-col-md-push-3{position:relative;left:12.5%}.el-col-md-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-md-offset-4{margin-left:16.6666666667%}.el-col-md-pull-4{position:relative;right:16.6666666667%}.el-col-md-push-4{position:relative;left:16.6666666667%}.el-col-md-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-md-offset-5{margin-left:20.8333333333%}.el-col-md-pull-5{position:relative;right:20.8333333333%}.el-col-md-push-5{position:relative;left:20.8333333333%}.el-col-md-6{display:block;max-width:25%;flex:0 0 25%}.el-col-md-offset-6{margin-left:25%}.el-col-md-pull-6{position:relative;right:25%}.el-col-md-push-6{position:relative;left:25%}.el-col-md-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-md-offset-7{margin-left:29.1666666667%}.el-col-md-pull-7{position:relative;right:29.1666666667%}.el-col-md-push-7{position:relative;left:29.1666666667%}.el-col-md-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-md-offset-8{margin-left:33.3333333333%}.el-col-md-pull-8{position:relative;right:33.3333333333%}.el-col-md-push-8{position:relative;left:33.3333333333%}.el-col-md-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-md-offset-9{margin-left:37.5%}.el-col-md-pull-9{position:relative;right:37.5%}.el-col-md-push-9{position:relative;left:37.5%}.el-col-md-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-md-offset-10{margin-left:41.6666666667%}.el-col-md-pull-10{position:relative;right:41.6666666667%}.el-col-md-push-10{position:relative;left:41.6666666667%}.el-col-md-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-md-offset-11{margin-left:45.8333333333%}.el-col-md-pull-11{position:relative;right:45.8333333333%}.el-col-md-push-11{position:relative;left:45.8333333333%}.el-col-md-12{display:block;max-width:50%;flex:0 0 50%}.el-col-md-offset-12{margin-left:50%}.el-col-md-pull-12{position:relative;right:50%}.el-col-md-push-12{position:relative;left:50%}.el-col-md-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-md-offset-13{margin-left:54.1666666667%}.el-col-md-pull-13{position:relative;right:54.1666666667%}.el-col-md-push-13{position:relative;left:54.1666666667%}.el-col-md-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-md-offset-14{margin-left:58.3333333333%}.el-col-md-pull-14{position:relative;right:58.3333333333%}.el-col-md-push-14{position:relative;left:58.3333333333%}.el-col-md-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-md-offset-15{margin-left:62.5%}.el-col-md-pull-15{position:relative;right:62.5%}.el-col-md-push-15{position:relative;left:62.5%}.el-col-md-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-md-offset-16{margin-left:66.6666666667%}.el-col-md-pull-16{position:relative;right:66.6666666667%}.el-col-md-push-16{position:relative;left:66.6666666667%}.el-col-md-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-md-offset-17{margin-left:70.8333333333%}.el-col-md-pull-17{position:relative;right:70.8333333333%}.el-col-md-push-17{position:relative;left:70.8333333333%}.el-col-md-18{display:block;max-width:75%;flex:0 0 75%}.el-col-md-offset-18{margin-left:75%}.el-col-md-pull-18{position:relative;right:75%}.el-col-md-push-18{position:relative;left:75%}.el-col-md-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-md-offset-19{margin-left:79.1666666667%}.el-col-md-pull-19{position:relative;right:79.1666666667%}.el-col-md-push-19{position:relative;left:79.1666666667%}.el-col-md-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-md-offset-20{margin-left:83.3333333333%}.el-col-md-pull-20{position:relative;right:83.3333333333%}.el-col-md-push-20{position:relative;left:83.3333333333%}.el-col-md-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-md-offset-21{margin-left:87.5%}.el-col-md-pull-21{position:relative;right:87.5%}.el-col-md-push-21{position:relative;left:87.5%}.el-col-md-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-md-offset-22{margin-left:91.6666666667%}.el-col-md-pull-22{position:relative;right:91.6666666667%}.el-col-md-push-22{position:relative;left:91.6666666667%}.el-col-md-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-md-offset-23{margin-left:95.8333333333%}.el-col-md-pull-23{position:relative;right:95.8333333333%}.el-col-md-push-23{position:relative;left:95.8333333333%}.el-col-md-24{display:block;max-width:100%;flex:0 0 100%}.el-col-md-offset-24{margin-left:100%}.el-col-md-pull-24{position:relative;right:100%}.el-col-md-push-24{position:relative;left:100%}}@media only screen and (min-width:1200px){.el-col-lg-0,.el-col-lg-0.is-guttered{display:none}.el-col-lg-0{max-width:0%;flex:0 0 0%}.el-col-lg-offset-0{margin-left:0}.el-col-lg-pull-0{position:relative;right:0}.el-col-lg-push-0{position:relative;left:0}.el-col-lg-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-lg-offset-1{margin-left:4.1666666667%}.el-col-lg-pull-1{position:relative;right:4.1666666667%}.el-col-lg-push-1{position:relative;left:4.1666666667%}.el-col-lg-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-lg-offset-2{margin-left:8.3333333333%}.el-col-lg-pull-2{position:relative;right:8.3333333333%}.el-col-lg-push-2{position:relative;left:8.3333333333%}.el-col-lg-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-lg-offset-3{margin-left:12.5%}.el-col-lg-pull-3{position:relative;right:12.5%}.el-col-lg-push-3{position:relative;left:12.5%}.el-col-lg-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-lg-offset-4{margin-left:16.6666666667%}.el-col-lg-pull-4{position:relative;right:16.6666666667%}.el-col-lg-push-4{position:relative;left:16.6666666667%}.el-col-lg-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-lg-offset-5{margin-left:20.8333333333%}.el-col-lg-pull-5{position:relative;right:20.8333333333%}.el-col-lg-push-5{position:relative;left:20.8333333333%}.el-col-lg-6{display:block;max-width:25%;flex:0 0 25%}.el-col-lg-offset-6{margin-left:25%}.el-col-lg-pull-6{position:relative;right:25%}.el-col-lg-push-6{position:relative;left:25%}.el-col-lg-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-lg-offset-7{margin-left:29.1666666667%}.el-col-lg-pull-7{position:relative;right:29.1666666667%}.el-col-lg-push-7{position:relative;left:29.1666666667%}.el-col-lg-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-lg-offset-8{margin-left:33.3333333333%}.el-col-lg-pull-8{position:relative;right:33.3333333333%}.el-col-lg-push-8{position:relative;left:33.3333333333%}.el-col-lg-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-lg-offset-9{margin-left:37.5%}.el-col-lg-pull-9{position:relative;right:37.5%}.el-col-lg-push-9{position:relative;left:37.5%}.el-col-lg-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-lg-offset-10{margin-left:41.6666666667%}.el-col-lg-pull-10{position:relative;right:41.6666666667%}.el-col-lg-push-10{position:relative;left:41.6666666667%}.el-col-lg-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-lg-offset-11{margin-left:45.8333333333%}.el-col-lg-pull-11{position:relative;right:45.8333333333%}.el-col-lg-push-11{position:relative;left:45.8333333333%}.el-col-lg-12{display:block;max-width:50%;flex:0 0 50%}.el-col-lg-offset-12{margin-left:50%}.el-col-lg-pull-12{position:relative;right:50%}.el-col-lg-push-12{position:relative;left:50%}.el-col-lg-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-lg-offset-13{margin-left:54.1666666667%}.el-col-lg-pull-13{position:relative;right:54.1666666667%}.el-col-lg-push-13{position:relative;left:54.1666666667%}.el-col-lg-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-lg-offset-14{margin-left:58.3333333333%}.el-col-lg-pull-14{position:relative;right:58.3333333333%}.el-col-lg-push-14{position:relative;left:58.3333333333%}.el-col-lg-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-lg-offset-15{margin-left:62.5%}.el-col-lg-pull-15{position:relative;right:62.5%}.el-col-lg-push-15{position:relative;left:62.5%}.el-col-lg-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-lg-offset-16{margin-left:66.6666666667%}.el-col-lg-pull-16{position:relative;right:66.6666666667%}.el-col-lg-push-16{position:relative;left:66.6666666667%}.el-col-lg-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-lg-offset-17{margin-left:70.8333333333%}.el-col-lg-pull-17{position:relative;right:70.8333333333%}.el-col-lg-push-17{position:relative;left:70.8333333333%}.el-col-lg-18{display:block;max-width:75%;flex:0 0 75%}.el-col-lg-offset-18{margin-left:75%}.el-col-lg-pull-18{position:relative;right:75%}.el-col-lg-push-18{position:relative;left:75%}.el-col-lg-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-lg-offset-19{margin-left:79.1666666667%}.el-col-lg-pull-19{position:relative;right:79.1666666667%}.el-col-lg-push-19{position:relative;left:79.1666666667%}.el-col-lg-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-lg-offset-20{margin-left:83.3333333333%}.el-col-lg-pull-20{position:relative;right:83.3333333333%}.el-col-lg-push-20{position:relative;left:83.3333333333%}.el-col-lg-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-lg-offset-21{margin-left:87.5%}.el-col-lg-pull-21{position:relative;right:87.5%}.el-col-lg-push-21{position:relative;left:87.5%}.el-col-lg-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-lg-offset-22{margin-left:91.6666666667%}.el-col-lg-pull-22{position:relative;right:91.6666666667%}.el-col-lg-push-22{position:relative;left:91.6666666667%}.el-col-lg-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-lg-offset-23{margin-left:95.8333333333%}.el-col-lg-pull-23{position:relative;right:95.8333333333%}.el-col-lg-push-23{position:relative;left:95.8333333333%}.el-col-lg-24{display:block;max-width:100%;flex:0 0 100%}.el-col-lg-offset-24{margin-left:100%}.el-col-lg-pull-24{position:relative;right:100%}.el-col-lg-push-24{position:relative;left:100%}}@media only screen and (min-width:1920px){.el-col-xl-0,.el-col-xl-0.is-guttered{display:none}.el-col-xl-0{max-width:0%;flex:0 0 0%}.el-col-xl-offset-0{margin-left:0}.el-col-xl-pull-0{position:relative;right:0}.el-col-xl-push-0{position:relative;left:0}.el-col-xl-1{display:block;max-width:4.1666666667%;flex:0 0 4.1666666667%}.el-col-xl-offset-1{margin-left:4.1666666667%}.el-col-xl-pull-1{position:relative;right:4.1666666667%}.el-col-xl-push-1{position:relative;left:4.1666666667%}.el-col-xl-2{display:block;max-width:8.3333333333%;flex:0 0 8.3333333333%}.el-col-xl-offset-2{margin-left:8.3333333333%}.el-col-xl-pull-2{position:relative;right:8.3333333333%}.el-col-xl-push-2{position:relative;left:8.3333333333%}.el-col-xl-3{display:block;max-width:12.5%;flex:0 0 12.5%}.el-col-xl-offset-3{margin-left:12.5%}.el-col-xl-pull-3{position:relative;right:12.5%}.el-col-xl-push-3{position:relative;left:12.5%}.el-col-xl-4{display:block;max-width:16.6666666667%;flex:0 0 16.6666666667%}.el-col-xl-offset-4{margin-left:16.6666666667%}.el-col-xl-pull-4{position:relative;right:16.6666666667%}.el-col-xl-push-4{position:relative;left:16.6666666667%}.el-col-xl-5{display:block;max-width:20.8333333333%;flex:0 0 20.8333333333%}.el-col-xl-offset-5{margin-left:20.8333333333%}.el-col-xl-pull-5{position:relative;right:20.8333333333%}.el-col-xl-push-5{position:relative;left:20.8333333333%}.el-col-xl-6{display:block;max-width:25%;flex:0 0 25%}.el-col-xl-offset-6{margin-left:25%}.el-col-xl-pull-6{position:relative;right:25%}.el-col-xl-push-6{position:relative;left:25%}.el-col-xl-7{display:block;max-width:29.1666666667%;flex:0 0 29.1666666667%}.el-col-xl-offset-7{margin-left:29.1666666667%}.el-col-xl-pull-7{position:relative;right:29.1666666667%}.el-col-xl-push-7{position:relative;left:29.1666666667%}.el-col-xl-8{display:block;max-width:33.3333333333%;flex:0 0 33.3333333333%}.el-col-xl-offset-8{margin-left:33.3333333333%}.el-col-xl-pull-8{position:relative;right:33.3333333333%}.el-col-xl-push-8{position:relative;left:33.3333333333%}.el-col-xl-9{display:block;max-width:37.5%;flex:0 0 37.5%}.el-col-xl-offset-9{margin-left:37.5%}.el-col-xl-pull-9{position:relative;right:37.5%}.el-col-xl-push-9{position:relative;left:37.5%}.el-col-xl-10{display:block;max-width:41.6666666667%;flex:0 0 41.6666666667%}.el-col-xl-offset-10{margin-left:41.6666666667%}.el-col-xl-pull-10{position:relative;right:41.6666666667%}.el-col-xl-push-10{position:relative;left:41.6666666667%}.el-col-xl-11{display:block;max-width:45.8333333333%;flex:0 0 45.8333333333%}.el-col-xl-offset-11{margin-left:45.8333333333%}.el-col-xl-pull-11{position:relative;right:45.8333333333%}.el-col-xl-push-11{position:relative;left:45.8333333333%}.el-col-xl-12{display:block;max-width:50%;flex:0 0 50%}.el-col-xl-offset-12{margin-left:50%}.el-col-xl-pull-12{position:relative;right:50%}.el-col-xl-push-12{position:relative;left:50%}.el-col-xl-13{display:block;max-width:54.1666666667%;flex:0 0 54.1666666667%}.el-col-xl-offset-13{margin-left:54.1666666667%}.el-col-xl-pull-13{position:relative;right:54.1666666667%}.el-col-xl-push-13{position:relative;left:54.1666666667%}.el-col-xl-14{display:block;max-width:58.3333333333%;flex:0 0 58.3333333333%}.el-col-xl-offset-14{margin-left:58.3333333333%}.el-col-xl-pull-14{position:relative;right:58.3333333333%}.el-col-xl-push-14{position:relative;left:58.3333333333%}.el-col-xl-15{display:block;max-width:62.5%;flex:0 0 62.5%}.el-col-xl-offset-15{margin-left:62.5%}.el-col-xl-pull-15{position:relative;right:62.5%}.el-col-xl-push-15{position:relative;left:62.5%}.el-col-xl-16{display:block;max-width:66.6666666667%;flex:0 0 66.6666666667%}.el-col-xl-offset-16{margin-left:66.6666666667%}.el-col-xl-pull-16{position:relative;right:66.6666666667%}.el-col-xl-push-16{position:relative;left:66.6666666667%}.el-col-xl-17{display:block;max-width:70.8333333333%;flex:0 0 70.8333333333%}.el-col-xl-offset-17{margin-left:70.8333333333%}.el-col-xl-pull-17{position:relative;right:70.8333333333%}.el-col-xl-push-17{position:relative;left:70.8333333333%}.el-col-xl-18{display:block;max-width:75%;flex:0 0 75%}.el-col-xl-offset-18{margin-left:75%}.el-col-xl-pull-18{position:relative;right:75%}.el-col-xl-push-18{position:relative;left:75%}.el-col-xl-19{display:block;max-width:79.1666666667%;flex:0 0 79.1666666667%}.el-col-xl-offset-19{margin-left:79.1666666667%}.el-col-xl-pull-19{position:relative;right:79.1666666667%}.el-col-xl-push-19{position:relative;left:79.1666666667%}.el-col-xl-20{display:block;max-width:83.3333333333%;flex:0 0 83.3333333333%}.el-col-xl-offset-20{margin-left:83.3333333333%}.el-col-xl-pull-20{position:relative;right:83.3333333333%}.el-col-xl-push-20{position:relative;left:83.3333333333%}.el-col-xl-21{display:block;max-width:87.5%;flex:0 0 87.5%}.el-col-xl-offset-21{margin-left:87.5%}.el-col-xl-pull-21{position:relative;right:87.5%}.el-col-xl-push-21{position:relative;left:87.5%}.el-col-xl-22{display:block;max-width:91.6666666667%;flex:0 0 91.6666666667%}.el-col-xl-offset-22{margin-left:91.6666666667%}.el-col-xl-pull-22{position:relative;right:91.6666666667%}.el-col-xl-push-22{position:relative;left:91.6666666667%}.el-col-xl-23{display:block;max-width:95.8333333333%;flex:0 0 95.8333333333%}.el-col-xl-offset-23{margin-left:95.8333333333%}.el-col-xl-pull-23{position:relative;right:95.8333333333%}.el-col-xl-push-23{position:relative;left:95.8333333333%}.el-col-xl-24{display:block;max-width:100%;flex:0 0 100%}.el-col-xl-offset-24{margin-left:100%}.el-col-xl-pull-24{position:relative;right:100%}.el-col-xl-push-24{position:relative;left:100%}}.el-collapse{--el-collapse-border-color:var(--el-border-color-lighter);--el-collapse-header-height:48px;--el-collapse-header-bg-color:var(--el-fill-color-blank);--el-collapse-header-text-color:var(--el-text-color-primary);--el-collapse-header-font-size:13px;--el-collapse-content-bg-color:var(--el-fill-color-blank);--el-collapse-content-font-size:13px;--el-collapse-content-text-color:var(--el-text-color-primary);border-top:1px solid var(--el-collapse-border-color);border-bottom:1px solid var(--el-collapse-border-color)}.el-collapse-item.is-disabled .el-collapse-item__header{color:var(--el-text-color-disabled);cursor:not-allowed}.el-collapse-item__header{display:flex;align-items:center;height:var(--el-collapse-header-height);line-height:var(--el-collapse-header-height);background-color:var(--el-collapse-header-bg-color);color:var(--el-collapse-header-text-color);cursor:pointer;border-bottom:1px solid var(--el-collapse-border-color);font-size:var(--el-collapse-header-font-size);font-weight:500;transition:border-bottom-color var(--el-transition-duration);outline:0}.el-collapse-item__arrow{margin:0 8px 0 auto;transition:transform var(--el-transition-duration);font-weight:300}.el-collapse-item__arrow.is-active{transform:rotate(90deg)}.el-collapse-item__header.focusing:focus:not(:hover){color:var(--el-color-primary)}.el-collapse-item__header.is-active{border-bottom-color:transparent}.el-collapse-item__wrap{will-change:height;background-color:var(--el-collapse-content-bg-color);overflow:hidden;box-sizing:border-box;border-bottom:1px solid var(--el-collapse-border-color)}.el-collapse-item__content{padding-bottom:25px;font-size:var(--el-collapse-content-font-size);color:var(--el-collapse-content-text-color);line-height:1.7692307692}.el-collapse-item:last-child{margin-bottom:-1px}.el-color-predefine{display:flex;font-size:12px;margin-top:8px;width:280px}.el-color-predefine__colors{display:flex;flex:1;flex-wrap:wrap}.el-color-predefine__color-selector{margin:0 0 8px 8px;width:20px;height:20px;border-radius:4px;cursor:pointer}.el-color-predefine__color-selector:nth-child(10n+1){margin-left:0}.el-color-predefine__color-selector.selected{box-shadow:0 0 3px 2px var(--el-color-primary)}.el-color-predefine__color-selector>div{display:flex;height:100%;border-radius:3px}.el-color-predefine__color-selector.is-alpha{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAIAAADZF8uwAAAAGUlEQVQYV2M4gwH+YwCGIasIUwhT25BVBADtzYNYrHvv4gAAAABJRU5ErkJggg==)}.el-color-hue-slider{position:relative;box-sizing:border-box;width:280px;height:12px;background-color:red;padding:0 2px;float:right}.el-color-hue-slider__bar{position:relative;background:linear-gradient(to right,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%);height:100%}.el-color-hue-slider__thumb{position:absolute;cursor:pointer;box-sizing:border-box;left:0;top:0;width:4px;height:100%;border-radius:1px;background:#fff;border:1px solid var(--el-border-color-lighter);box-shadow:0 0 2px #0009;z-index:1}.el-color-hue-slider.is-vertical{width:12px;height:180px;padding:2px 0}.el-color-hue-slider.is-vertical .el-color-hue-slider__bar{background:linear-gradient(to bottom,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%)}.el-color-hue-slider.is-vertical .el-color-hue-slider__thumb{left:0;top:0;width:100%;height:4px}.el-color-svpanel{position:relative;width:280px;height:180px}.el-color-svpanel__black,.el-color-svpanel__white{position:absolute;top:0;left:0;right:0;bottom:0}.el-color-svpanel__white{background:linear-gradient(to right,#fff,rgba(255,255,255,0))}.el-color-svpanel__black{background:linear-gradient(to top,#000,rgba(0,0,0,0))}.el-color-svpanel__cursor{position:absolute}.el-color-svpanel__cursor>div{cursor:head;width:4px;height:4px;box-shadow:0 0 0 1.5px #fff,inset 0 0 1px 1px #0000004d,0 0 1px 2px #0006;border-radius:50%;transform:translate(-2px,-2px)}.el-color-alpha-slider{position:relative;box-sizing:border-box;width:280px;height:12px;background-image:linear-gradient(45deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(45deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%);background-size:12px 12px;background-position:0 0,6px 0,6px -6px,0 6px}.el-color-alpha-slider__bar{position:relative;background:linear-gradient(to right,rgba(255,255,255,0) 0,var(--el-bg-color) 100%);height:100%}.el-color-alpha-slider__thumb{position:absolute;cursor:pointer;box-sizing:border-box;left:0;top:0;width:4px;height:100%;border-radius:1px;background:#fff;border:1px solid var(--el-border-color-lighter);box-shadow:0 0 2px #0009;z-index:1}.el-color-alpha-slider.is-vertical{width:20px;height:180px}.el-color-alpha-slider.is-vertical .el-color-alpha-slider__bar{background:linear-gradient(to bottom,rgba(255,255,255,0) 0,#fff 100%)}.el-color-alpha-slider.is-vertical .el-color-alpha-slider__thumb{left:0;top:0;width:100%;height:4px}.el-color-dropdown{width:300px}.el-color-dropdown__main-wrapper{margin-bottom:6px}.el-color-dropdown__main-wrapper:after{content:"";display:table;clear:both}.el-color-dropdown__btns{margin-top:12px;text-align:right}.el-color-dropdown__value{float:left;line-height:26px;font-size:12px;color:#000;width:160px}.el-color-picker{display:inline-block;position:relative;line-height:normal;outline:0}.el-color-picker:hover:not(.is-disabled) .el-color-picker__trigger{border:1px solid var(--el-border-color-hover)}.el-color-picker:focus-visible:not(.is-disabled) .el-color-picker__trigger{outline:2px solid var(--el-color-primary);outline-offset:1px}.el-color-picker.is-disabled .el-color-picker__trigger{cursor:not-allowed}.el-color-picker--large{height:40px}.el-color-picker--large .el-color-picker__trigger{height:40px;width:40px}.el-color-picker--large .el-color-picker__mask{height:38px;width:38px}.el-color-picker--small{height:24px}.el-color-picker--small .el-color-picker__trigger{height:24px;width:24px}.el-color-picker--small .el-color-picker__mask{height:22px;width:22px}.el-color-picker--small .el-color-picker__empty,.el-color-picker--small .el-color-picker__icon{transform:scale(.8)}.el-color-picker__mask{height:30px;width:30px;border-radius:4px;position:absolute;top:1px;left:1px;z-index:1;cursor:not-allowed;background-color:#ffffffb3}.el-color-picker__trigger{display:inline-flex;justify-content:center;align-items:center;box-sizing:border-box;height:32px;width:32px;padding:4px;border:1px solid var(--el-border-color);border-radius:4px;font-size:0;position:relative;cursor:pointer}.el-color-picker__color{position:relative;display:block;box-sizing:border-box;border:1px solid var(--el-text-color-secondary);border-radius:var(--el-border-radius-small);width:100%;height:100%;text-align:center}.el-color-picker__color.is-alpha{background-image:linear-gradient(45deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-a) 25%,var(--el-color-picker-alpha-bg-b) 25%),linear-gradient(45deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%),linear-gradient(135deg,var(--el-color-picker-alpha-bg-b) 75%,var(--el-color-picker-alpha-bg-a) 75%);background-size:12px 12px;background-position:0 0,6px 0,6px -6px,0 6px}.el-color-picker__color-inner{display:inline-flex;justify-content:center;align-items:center;width:100%;height:100%}.el-color-picker .el-color-picker__empty{font-size:12px;color:var(--el-text-color-secondary)}.el-color-picker .el-color-picker__icon{display:inline-flex;justify-content:center;align-items:center;color:#fff;font-size:12px}.el-color-picker__panel{position:absolute;z-index:10;padding:6px;box-sizing:content-box;background-color:#fff;border-radius:var(--el-border-radius-base);box-shadow:var(--el-box-shadow-light)}.el-color-picker__panel.el-popper{border:1px solid var(--el-border-color-lighter)}.el-color-picker,.el-color-picker__panel{--el-color-picker-alpha-bg-a:#ccc;--el-color-picker-alpha-bg-b:transparent}.dark .el-color-picker,.dark .el-color-picker__panel{--el-color-picker-alpha-bg-a:#333333}.el-container{display:flex;flex-direction:row;flex:1;flex-basis:auto;box-sizing:border-box;min-width:0}.el-container.is-vertical{flex-direction:column}.el-date-table{font-size:12px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-date-table.is-week-mode .el-date-table__row:hover .el-date-table-cell{background-color:var(--el-datepicker-inrange-bg-color)}.el-date-table.is-week-mode .el-date-table__row:hover td.available:hover{color:var(--el-datepicker-text-color)}.el-date-table.is-week-mode .el-date-table__row:hover td:first-child .el-date-table-cell{margin-left:5px;border-top-left-radius:15px;border-bottom-left-radius:15px}.el-date-table.is-week-mode .el-date-table__row:hover td:last-child .el-date-table-cell{margin-right:5px;border-top-right-radius:15px;border-bottom-right-radius:15px}.el-date-table.is-week-mode .el-date-table__row.current .el-date-table-cell{background-color:var(--el-datepicker-inrange-bg-color)}.el-date-table td{width:32px;height:30px;padding:4px 0;box-sizing:border-box;text-align:center;cursor:pointer;position:relative}.el-date-table td .el-date-table-cell{height:30px;padding:3px 0;box-sizing:border-box}.el-date-table td .el-date-table-cell .el-date-table-cell__text{width:24px;height:24px;display:block;margin:0 auto;line-height:24px;position:absolute;left:50%;transform:translate(-50%);border-radius:50%}.el-date-table td.next-month,.el-date-table td.prev-month{color:var(--el-datepicker-off-text-color)}.el-date-table td.today{position:relative}.el-date-table td.today .el-date-table-cell__text{color:var(--el-color-primary);font-weight:700}.el-date-table td.today.end-date .el-date-table-cell__text,.el-date-table td.today.start-date .el-date-table-cell__text{color:#fff}.el-date-table td.available:hover{color:var(--el-datepicker-hover-text-color)}.el-date-table td.in-range .el-date-table-cell{background-color:var(--el-datepicker-inrange-bg-color)}.el-date-table td.in-range .el-date-table-cell:hover{background-color:var(--el-datepicker-inrange-hover-bg-color)}.el-date-table td.current:not(.disabled) .el-date-table-cell__text{color:#fff;background-color:var(--el-datepicker-active-color)}.el-date-table td.current:not(.disabled):focus-visible .el-date-table-cell__text{outline:2px solid var(--el-datepicker-active-color);outline-offset:1px}.el-date-table td.end-date .el-date-table-cell,.el-date-table td.start-date .el-date-table-cell{color:#fff}.el-date-table td.end-date .el-date-table-cell__text,.el-date-table td.start-date .el-date-table-cell__text{background-color:var(--el-datepicker-active-color)}.el-date-table td.start-date .el-date-table-cell{margin-left:5px;border-top-left-radius:15px;border-bottom-left-radius:15px}.el-date-table td.end-date .el-date-table-cell{margin-right:5px;border-top-right-radius:15px;border-bottom-right-radius:15px}.el-date-table td.disabled .el-date-table-cell{background-color:var(--el-fill-color-light);opacity:1;cursor:not-allowed;color:var(--el-text-color-placeholder)}.el-date-table td.selected .el-date-table-cell{margin-left:5px;margin-right:5px;background-color:var(--el-datepicker-inrange-bg-color);border-radius:15px}.el-date-table td.selected .el-date-table-cell:hover{background-color:var(--el-datepicker-inrange-hover-bg-color)}.el-date-table td.selected .el-date-table-cell__text{background-color:var(--el-datepicker-active-color);color:#fff;border-radius:15px}.el-date-table td.week{font-size:80%;color:var(--el-datepicker-header-text-color)}.el-date-table td:focus{outline:0}.el-date-table th{padding:5px;color:var(--el-datepicker-header-text-color);font-weight:400;border-bottom:solid 1px var(--el-border-color-lighter)}.el-month-table{font-size:12px;margin:-1px;border-collapse:collapse}.el-month-table td{text-align:center;padding:8px 0;cursor:pointer}.el-month-table td div{height:48px;padding:6px 0;box-sizing:border-box}.el-month-table td.today .cell{color:var(--el-color-primary);font-weight:700}.el-month-table td.today.end-date .cell,.el-month-table td.today.start-date .cell{color:#fff}.el-month-table td.disabled .cell{background-color:var(--el-fill-color-light);cursor:not-allowed;color:var(--el-text-color-placeholder)}.el-month-table td.disabled .cell:hover{color:var(--el-text-color-placeholder)}.el-month-table td .cell{width:60px;height:36px;display:block;line-height:36px;color:var(--el-datepicker-text-color);margin:0 auto;border-radius:18px}.el-month-table td .cell:hover{color:var(--el-datepicker-hover-text-color)}.el-month-table td.in-range div{background-color:var(--el-datepicker-inrange-bg-color)}.el-month-table td.in-range div:hover{background-color:var(--el-datepicker-inrange-hover-bg-color)}.el-month-table td.end-date div,.el-month-table td.start-date div{color:#fff}.el-month-table td.end-date .cell,.el-month-table td.start-date .cell{color:#fff;background-color:var(--el-datepicker-active-color)}.el-month-table td.start-date div{border-top-left-radius:24px;border-bottom-left-radius:24px}.el-month-table td.end-date div{border-top-right-radius:24px;border-bottom-right-radius:24px}.el-month-table td.current:not(.disabled) .cell{color:var(--el-datepicker-active-color)}.el-month-table td:focus-visible{outline:0}.el-month-table td:focus-visible .cell{outline:2px solid var(--el-datepicker-active-color)}.el-year-table{font-size:12px;margin:-1px;border-collapse:collapse}.el-year-table .el-icon{color:var(--el-datepicker-icon-color)}.el-year-table td{text-align:center;padding:20px 3px;cursor:pointer}.el-year-table td.today .cell{color:var(--el-color-primary);font-weight:700}.el-year-table td.disabled .cell{background-color:var(--el-fill-color-light);cursor:not-allowed;color:var(--el-text-color-placeholder)}.el-year-table td.disabled .cell:hover{color:var(--el-text-color-placeholder)}.el-year-table td .cell{width:48px;height:36px;display:block;line-height:36px;color:var(--el-datepicker-text-color);border-radius:18px;margin:0 auto}.el-year-table td .cell:hover{color:var(--el-datepicker-hover-text-color)}.el-year-table td.current:not(.disabled) .cell{color:var(--el-datepicker-active-color)}.el-year-table td:focus-visible{outline:0}.el-year-table td:focus-visible .cell{outline:2px solid var(--el-datepicker-active-color)}.el-time-spinner.has-seconds .el-time-spinner__wrapper{width:33.3%}.el-time-spinner__wrapper{max-height:192px;overflow:auto;display:inline-block;width:50%;vertical-align:top;position:relative}.el-time-spinner__wrapper.el-scrollbar__wrap:not(.el-scrollbar__wrap--hidden-default){padding-bottom:15px}.el-time-spinner__wrapper.is-arrow{box-sizing:border-box;text-align:center;overflow:hidden}.el-time-spinner__wrapper.is-arrow .el-time-spinner__list{transform:translateY(-32px)}.el-time-spinner__wrapper.is-arrow .el-time-spinner__item:hover:not(.is-disabled):not(.is-active){background:var(--el-fill-color-light);cursor:default}.el-time-spinner__arrow{font-size:12px;color:var(--el-text-color-secondary);position:absolute;left:0;width:100%;z-index:var(--el-index-normal);text-align:center;height:30px;line-height:30px;cursor:pointer}.el-time-spinner__arrow:hover{color:var(--el-color-primary)}.el-time-spinner__arrow.arrow-up{top:10px}.el-time-spinner__arrow.arrow-down{bottom:10px}.el-time-spinner__input.el-input{width:70%}.el-time-spinner__input.el-input .el-input__inner{padding:0;text-align:center}.el-time-spinner__list{padding:0;margin:0;list-style:none;text-align:center}.el-time-spinner__list:after,.el-time-spinner__list:before{content:"";display:block;width:100%;height:80px}.el-time-spinner__item{height:32px;line-height:32px;font-size:12px;color:var(--el-text-color-regular)}.el-time-spinner__item:hover:not(.is-disabled):not(.is-active){background:var(--el-fill-color-light);cursor:pointer}.el-time-spinner__item.is-active:not(.is-disabled){color:var(--el-text-color-primary);font-weight:700}.el-time-spinner__item.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-picker__popper{--el-datepicker-border-color:var(--el-disabled-border-color)}.el-picker__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-datepicker-border-color);box-shadow:var(--el-box-shadow-light)}.el-picker__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-datepicker-border-color)}.el-picker__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-picker__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-picker__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-picker__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-date-editor{--el-date-editor-width:220px;--el-date-editor-monthrange-width:300px;--el-date-editor-daterange-width:350px;--el-date-editor-datetimerange-width:400px;--el-input-text-color:var(--el-text-color-regular);--el-input-border:var(--el-border);--el-input-hover-border:var(--el-border-color-hover);--el-input-focus-border:var(--el-color-primary);--el-input-transparent-border:0 0 0 1px transparent inset;--el-input-border-color:var(--el-border-color);--el-input-border-radius:var(--el-border-radius-base);--el-input-bg-color:var(--el-fill-color-blank);--el-input-icon-color:var(--el-text-color-placeholder);--el-input-placeholder-color:var(--el-text-color-placeholder);--el-input-hover-border-color:var(--el-border-color-hover);--el-input-clear-hover-color:var(--el-text-color-secondary);--el-input-focus-border-color:var(--el-color-primary);position:relative;display:inline-block;text-align:left}.el-date-editor.el-input__wrapper{box-shadow:0 0 0 1px var(--el-input-border-color,var(--el-border-color)) inset}.el-date-editor.el-input__wrapper:hover{box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-date-editor.el-input,.el-date-editor.el-input__wrapper{width:var(--el-date-editor-width);height:var(--el-input-height,var(--el-component-size))}.el-date-editor--monthrange{--el-date-editor-width:var(--el-date-editor-monthrange-width)}.el-date-editor--daterange,.el-date-editor--timerange{--el-date-editor-width:var(--el-date-editor-daterange-width)}.el-date-editor--datetimerange{--el-date-editor-width:var(--el-date-editor-datetimerange-width)}.el-date-editor--dates .el-input__wrapper{text-overflow:ellipsis;white-space:nowrap}.el-date-editor .close-icon,.el-date-editor .clear-icon{cursor:pointer}.el-date-editor .clear-icon:hover{color:var(--el-text-color-secondary)}.el-date-editor .el-range__icon{height:inherit;font-size:14px;color:var(--el-text-color-placeholder);float:left}.el-date-editor .el-range__icon svg{vertical-align:middle}.el-date-editor .el-range-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;outline:0;display:inline-block;height:30px;line-height:30px;margin:0;padding:0;width:39%;text-align:center;font-size:var(--el-font-size-base);color:var(--el-text-color-regular);background-color:transparent}.el-date-editor .el-range-input::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-date-editor .el-range-input:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-date-editor .el-range-input::placeholder{color:var(--el-text-color-placeholder)}.el-date-editor .el-range-separator{flex:1;display:inline-flex;justify-content:center;align-items:center;height:100%;padding:0 5px;margin:0;font-size:14px;word-break:keep-all;color:var(--el-text-color-primary)}.el-date-editor .el-range__close-icon{font-size:14px;color:var(--el-text-color-placeholder);height:inherit;width:unset;cursor:pointer}.el-date-editor .el-range__close-icon:hover{color:var(--el-text-color-secondary)}.el-date-editor .el-range__close-icon svg{vertical-align:middle}.el-date-editor .el-range__close-icon--hidden{opacity:0;visibility:hidden}.el-range-editor.el-input__wrapper{display:inline-flex;align-items:center;padding:0 10px}.el-range-editor.is-active,.el-range-editor.is-active:hover{box-shadow:0 0 0 1px var(--el-input-focus-border-color) inset}.el-range-editor--large{line-height:var(--el-component-size-large)}.el-range-editor--large.el-input__wrapper{height:var(--el-component-size-large)}.el-range-editor--large .el-range-separator{line-height:40px;font-size:14px}.el-range-editor--large .el-range-input{height:38px;line-height:38px;font-size:14px}.el-range-editor--small{line-height:var(--el-component-size-small)}.el-range-editor--small.el-input__wrapper{height:var(--el-component-size-small)}.el-range-editor--small .el-range-separator{line-height:24px;font-size:12px}.el-range-editor--small .el-range-input{height:22px;line-height:22px;font-size:12px}.el-range-editor.is-disabled{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color);color:var(--el-disabled-text-color);cursor:not-allowed}.el-range-editor.is-disabled:focus,.el-range-editor.is-disabled:hover{border-color:var(--el-disabled-border-color)}.el-range-editor.is-disabled input{background-color:var(--el-disabled-bg-color);color:var(--el-disabled-text-color);cursor:not-allowed}.el-range-editor.is-disabled input::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-range-editor.is-disabled input:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-range-editor.is-disabled input::placeholder{color:var(--el-text-color-placeholder)}.el-range-editor.is-disabled .el-range-separator{color:var(--el-disabled-text-color)}.el-picker-panel{color:var(--el-text-color-regular);background:var(--el-bg-color-overlay);border-radius:var(--el-border-radius-base);line-height:30px}.el-picker-panel .el-time-panel{margin:5px 0;border:solid 1px var(--el-datepicker-border-color);background-color:var(--el-bg-color-overlay);box-shadow:var(--el-box-shadow-light)}.el-picker-panel__body-wrapper:after,.el-picker-panel__body:after{content:"";display:table;clear:both}.el-picker-panel__content{position:relative;margin:15px}.el-picker-panel__footer{border-top:1px solid var(--el-datepicker-inner-border-color);padding:4px 12px;text-align:right;background-color:var(--el-bg-color-overlay);position:relative;font-size:0}.el-picker-panel__shortcut{display:block;width:100%;border:0;background-color:transparent;line-height:28px;font-size:14px;color:var(--el-datepicker-text-color);padding-left:12px;text-align:left;outline:0;cursor:pointer}.el-picker-panel__shortcut:hover{color:var(--el-datepicker-hover-text-color)}.el-picker-panel__shortcut.active{background-color:#e6f1fe;color:var(--el-datepicker-active-color)}.el-picker-panel__btn{border:1px solid var(--el-fill-color-darker);color:var(--el-text-color-primary);line-height:24px;border-radius:2px;padding:0 20px;cursor:pointer;background-color:transparent;outline:0;font-size:12px}.el-picker-panel__btn[disabled]{color:var(--el-text-color-disabled);cursor:not-allowed}.el-picker-panel__icon-btn{font-size:12px;color:var(--el-datepicker-icon-color);border:0;background:0 0;cursor:pointer;outline:0;margin-top:8px}.el-picker-panel__icon-btn:hover{color:var(--el-datepicker-hover-text-color)}.el-picker-panel__icon-btn:focus-visible{color:var(--el-datepicker-hover-text-color)}.el-picker-panel__icon-btn.is-disabled{color:var(--el-text-color-disabled)}.el-picker-panel__icon-btn.is-disabled:hover{cursor:not-allowed}.el-picker-panel__icon-btn .el-icon{cursor:pointer;font-size:inherit}.el-picker-panel__link-btn{vertical-align:middle}.el-picker-panel [slot=sidebar],.el-picker-panel__sidebar{position:absolute;top:0;bottom:0;width:110px;border-right:1px solid var(--el-datepicker-inner-border-color);box-sizing:border-box;padding-top:6px;background-color:var(--el-bg-color-overlay);overflow:auto}.el-picker-panel [slot=sidebar]+.el-picker-panel__body,.el-picker-panel__sidebar+.el-picker-panel__body{margin-left:110px}.el-date-picker{--el-datepicker-text-color:var(--el-text-color-regular);--el-datepicker-off-text-color:var(--el-text-color-placeholder);--el-datepicker-header-text-color:var(--el-text-color-regular);--el-datepicker-icon-color:var(--el-text-color-primary);--el-datepicker-border-color:var(--el-disabled-border-color);--el-datepicker-inner-border-color:var(--el-border-color-light);--el-datepicker-inrange-bg-color:var(--el-border-color-extra-light);--el-datepicker-inrange-hover-bg-color:var(--el-border-color-extra-light);--el-datepicker-active-color:var(--el-color-primary);--el-datepicker-hover-text-color:var(--el-color-primary)}.el-date-picker{width:322px}.el-date-picker.has-sidebar.has-time{width:434px}.el-date-picker.has-sidebar{width:438px}.el-date-picker.has-time .el-picker-panel__body-wrapper{position:relative}.el-date-picker .el-picker-panel__content{width:292px}.el-date-picker table{table-layout:fixed;width:100%}.el-date-picker__editor-wrap{position:relative;display:table-cell;padding:0 5px}.el-date-picker__time-header{position:relative;border-bottom:1px solid var(--el-datepicker-inner-border-color);font-size:12px;padding:8px 5px 5px;display:table;width:100%;box-sizing:border-box}.el-date-picker__header{margin:12px;text-align:center}.el-date-picker__header--bordered{margin-bottom:0;padding-bottom:12px;border-bottom:solid 1px var(--el-border-color-lighter)}.el-date-picker__header--bordered+.el-picker-panel__content{margin-top:0}.el-date-picker__header-label{font-size:16px;font-weight:500;padding:0 5px;line-height:22px;text-align:center;cursor:pointer;color:var(--el-text-color-regular)}.el-date-picker__header-label:hover{color:var(--el-datepicker-hover-text-color)}.el-date-picker__header-label:focus-visible{outline:0;color:var(--el-datepicker-hover-text-color)}.el-date-picker__header-label.active{color:var(--el-datepicker-active-color)}.el-date-picker__prev-btn{float:left}.el-date-picker__next-btn{float:right}.el-date-picker__time-wrap{padding:10px;text-align:center}.el-date-picker__time-label{float:left;cursor:pointer;line-height:30px;margin-left:10px}.el-date-picker .el-time-panel{position:absolute}.el-date-range-picker{--el-datepicker-text-color:var(--el-text-color-regular);--el-datepicker-off-text-color:var(--el-text-color-placeholder);--el-datepicker-header-text-color:var(--el-text-color-regular);--el-datepicker-icon-color:var(--el-text-color-primary);--el-datepicker-border-color:var(--el-disabled-border-color);--el-datepicker-inner-border-color:var(--el-border-color-light);--el-datepicker-inrange-bg-color:var(--el-border-color-extra-light);--el-datepicker-inrange-hover-bg-color:var(--el-border-color-extra-light);--el-datepicker-active-color:var(--el-color-primary);--el-datepicker-hover-text-color:var(--el-color-primary)}.el-date-range-picker{width:646px}.el-date-range-picker.has-sidebar{width:756px}.el-date-range-picker.has-time .el-picker-panel__body-wrapper{position:relative}.el-date-range-picker table{table-layout:fixed;width:100%}.el-date-range-picker .el-picker-panel__body{min-width:513px}.el-date-range-picker .el-picker-panel__content{margin:0}.el-date-range-picker__header{position:relative;text-align:center;height:28px}.el-date-range-picker__header [class*=arrow-left]{float:left}.el-date-range-picker__header [class*=arrow-right]{float:right}.el-date-range-picker__header div{font-size:16px;font-weight:500;margin-right:50px}.el-date-range-picker__content{float:left;width:50%;box-sizing:border-box;margin:0;padding:16px}.el-date-range-picker__content.is-left{border-right:1px solid var(--el-datepicker-inner-border-color)}.el-date-range-picker__content .el-date-range-picker__header div{margin-left:50px;margin-right:50px}.el-date-range-picker__editors-wrap{box-sizing:border-box;display:table-cell}.el-date-range-picker__editors-wrap.is-right{text-align:right}.el-date-range-picker__time-header{position:relative;border-bottom:1px solid var(--el-datepicker-inner-border-color);font-size:12px;padding:8px 5px 5px;display:table;width:100%;box-sizing:border-box}.el-date-range-picker__time-header>.el-icon-arrow-right{font-size:20px;vertical-align:middle;display:table-cell;color:var(--el-datepicker-icon-color)}.el-date-range-picker__time-picker-wrap{position:relative;display:table-cell;padding:0 5px}.el-date-range-picker__time-picker-wrap .el-picker-panel{position:absolute;top:13px;right:0;z-index:1;background:#fff}.el-date-range-picker__time-picker-wrap .el-time-panel{position:absolute}.el-time-range-picker{width:354px;overflow:visible}.el-time-range-picker__content{position:relative;text-align:center;padding:10px;z-index:1}.el-time-range-picker__cell{box-sizing:border-box;margin:0;padding:4px 7px 7px;width:50%;display:inline-block}.el-time-range-picker__header{margin-bottom:5px;text-align:center;font-size:14px}.el-time-range-picker__body{border-radius:2px;border:1px solid var(--el-datepicker-border-color)}.el-time-panel{border-radius:2px;position:relative;width:180px;left:0;z-index:var(--el-index-top);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;box-sizing:content-box}.el-time-panel__content{font-size:0;position:relative;overflow:hidden}.el-time-panel__content:after,.el-time-panel__content:before{content:"";top:50%;position:absolute;margin-top:-16px;height:32px;z-index:-1;left:0;right:0;box-sizing:border-box;padding-top:6px;text-align:left}.el-time-panel__content:after{left:50%;margin-left:12%;margin-right:12%}.el-time-panel__content:before{padding-left:50%;margin-right:12%;margin-left:12%;border-top:1px solid var(--el-border-color-light);border-bottom:1px solid var(--el-border-color-light)}.el-time-panel__content.has-seconds:after{left:66.6666666667%}.el-time-panel__content.has-seconds:before{padding-left:33.3333333333%}.el-time-panel__footer{border-top:1px solid var(--el-timepicker-inner-border-color,var(--el-border-color-light));padding:4px;height:36px;line-height:25px;text-align:right;box-sizing:border-box}.el-time-panel__btn{border:none;line-height:28px;padding:0 5px;margin:0 5px;cursor:pointer;background-color:transparent;outline:0;font-size:12px;color:var(--el-text-color-primary)}.el-time-panel__btn.confirm{font-weight:800;color:var(--el-timepicker-active-color,var(--el-color-primary))}.el-descriptions{--el-descriptions-table-border:1px solid var(--el-border-color-lighter);--el-descriptions-item-bordered-label-background:var(--el-fill-color-light);box-sizing:border-box;font-size:var(--el-font-size-base);color:var(--el-text-color-primary)}.el-descriptions__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.el-descriptions__title{color:var(--el-text-color-primary);font-size:16px;font-weight:700}.el-descriptions__body{background-color:var(--el-fill-color-blank)}.el-descriptions__body .el-descriptions__table{border-collapse:collapse;width:100%}.el-descriptions__body .el-descriptions__table .el-descriptions__cell{box-sizing:border-box;text-align:left;font-weight:400;line-height:23px;font-size:14px}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-left{text-align:left}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-center{text-align:center}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-right{text-align:right}.el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{border:var(--el-descriptions-table-border);padding:8px 11px}.el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:12px}.el-descriptions--large{font-size:14px}.el-descriptions--large .el-descriptions__header{margin-bottom:20px}.el-descriptions--large .el-descriptions__header .el-descriptions__title{font-size:16px}.el-descriptions--large .el-descriptions__body .el-descriptions__table .el-descriptions__cell{font-size:14px}.el-descriptions--large .el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{padding:12px 15px}.el-descriptions--large .el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:16px}.el-descriptions--small{font-size:12px}.el-descriptions--small .el-descriptions__header{margin-bottom:12px}.el-descriptions--small .el-descriptions__header .el-descriptions__title{font-size:14px}.el-descriptions--small .el-descriptions__body .el-descriptions__table .el-descriptions__cell{font-size:12px}.el-descriptions--small .el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{padding:4px 7px}.el-descriptions--small .el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:8px}.el-descriptions__label.el-descriptions__cell.is-bordered-label{font-weight:700;color:var(--el-text-color-regular);background:var(--el-descriptions-item-bordered-label-background)}.el-descriptions__label:not(.is-bordered-label){color:var(--el-text-color-primary);margin-right:16px}.el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:6px}.el-descriptions__content.el-descriptions__cell.is-bordered-content{color:var(--el-text-color-primary)}.el-descriptions__content:not(.is-bordered-label){color:var(--el-text-color-regular)}.el-descriptions--large .el-descriptions__label:not(.is-bordered-label){margin-right:16px}.el-descriptions--large .el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:8px}.el-descriptions--small .el-descriptions__label:not(.is-bordered-label){margin-right:12px}.el-descriptions--small .el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:4px}:root{--el-popup-modal-bg-color:var(--el-color-black);--el-popup-modal-opacity:.5}.v-modal-enter{-webkit-animation:v-modal-in var(--el-transition-duration-fast) ease;animation:v-modal-in var(--el-transition-duration-fast) ease}.v-modal-leave{-webkit-animation:v-modal-out var(--el-transition-duration-fast) ease forwards;animation:v-modal-out var(--el-transition-duration-fast) ease forwards}@-webkit-keyframes v-modal-in{0%{opacity:0}}@keyframes v-modal-in{0%{opacity:0}}@-webkit-keyframes v-modal-out{to{opacity:0}}@keyframes v-modal-out{to{opacity:0}}.v-modal{position:fixed;left:0;top:0;width:100%;height:100%;opacity:var(--el-popup-modal-opacity);background:var(--el-popup-modal-bg-color)}.el-popup-parent--hidden{overflow:hidden}.el-dialog{--el-dialog-width:50%;--el-dialog-margin-top:15vh;--el-dialog-bg-color:var(--el-bg-color);--el-dialog-box-shadow:var(--el-box-shadow);--el-dialog-title-font-size:var(--el-font-size-large);--el-dialog-content-font-size:14px;--el-dialog-font-line-height:var(--el-font-line-height-primary);--el-dialog-padding-primary:20px;--el-dialog-border-radius:var(--el-border-radius-small);position:relative;margin:var(--el-dialog-margin-top,15vh) auto 50px;background:var(--el-dialog-bg-color);border-radius:var(--el-dialog-border-radius);box-shadow:var(--el-dialog-box-shadow);box-sizing:border-box;width:var(--el-dialog-width,50%)}.el-dialog:focus{outline:0!important}.el-dialog.is-align-center{margin:auto}.el-dialog.is-fullscreen{--el-dialog-width:100%;--el-dialog-margin-top:0;margin-bottom:0;height:100%;overflow:auto}.el-dialog__wrapper{position:fixed;top:0;right:0;bottom:0;left:0;overflow:auto;margin:0}.el-dialog.is-draggable .el-dialog__header{cursor:move;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-dialog__header{padding:var(--el-dialog-padding-primary);padding-bottom:10px;margin-right:16px}.el-dialog__headerbtn{position:absolute;top:6px;right:0;padding:0;width:54px;height:54px;background:0 0;border:none;outline:0;cursor:pointer;font-size:var(--el-message-close-size,16px)}.el-dialog__headerbtn .el-dialog__close{color:var(--el-color-info);font-size:inherit}.el-dialog__headerbtn:focus .el-dialog__close,.el-dialog__headerbtn:hover .el-dialog__close{color:var(--el-color-primary)}.el-dialog__title{line-height:var(--el-dialog-font-line-height);font-size:var(--el-dialog-title-font-size);color:var(--el-text-color-primary)}.el-dialog__body{padding:calc(var(--el-dialog-padding-primary) + 10px) var(--el-dialog-padding-primary);color:var(--el-text-color-regular);font-size:var(--el-dialog-content-font-size)}.el-dialog__footer{padding:var(--el-dialog-padding-primary);padding-top:10px;text-align:right;box-sizing:border-box}.el-dialog--center{text-align:center}.el-dialog--center .el-dialog__body{text-align:initial;padding:25px calc(var(--el-dialog-padding-primary) + 5px) 30px}.el-dialog--center .el-dialog__footer{text-align:inherit}.el-overlay-dialog{position:fixed;top:0;right:0;bottom:0;left:0;overflow:auto}.dialog-fade-enter-active{-webkit-animation:modal-fade-in var(--el-transition-duration);animation:modal-fade-in var(--el-transition-duration)}.dialog-fade-enter-active .el-overlay-dialog{-webkit-animation:dialog-fade-in var(--el-transition-duration);animation:dialog-fade-in var(--el-transition-duration)}.dialog-fade-leave-active{-webkit-animation:modal-fade-out var(--el-transition-duration);animation:modal-fade-out var(--el-transition-duration)}.dialog-fade-leave-active .el-overlay-dialog{-webkit-animation:dialog-fade-out var(--el-transition-duration);animation:dialog-fade-out var(--el-transition-duration)}@-webkit-keyframes dialog-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@keyframes dialog-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@-webkit-keyframes dialog-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@keyframes dialog-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@-webkit-keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@-webkit-keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}@keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}.el-divider{position:relative}.el-divider--horizontal{display:block;height:1px;width:100%;margin:24px 0;border-top:1px var(--el-border-color) var(--el-border-style)}.el-divider--vertical{display:inline-block;width:1px;height:1em;margin:0 8px;vertical-align:middle;position:relative;border-left:1px var(--el-border-color) var(--el-border-style)}.el-divider__text{position:absolute;background-color:var(--el-bg-color);padding:0 20px;font-weight:500;color:var(--el-text-color-primary);font-size:14px}.el-divider__text.is-left{left:20px;transform:translateY(-50%)}.el-divider__text.is-center{left:50%;transform:translate(-50%) translateY(-50%)}.el-divider__text.is-right{right:20px;transform:translateY(-50%)}.el-drawer{--el-drawer-bg-color:var(--el-dialog-bg-color, var(--el-bg-color));--el-drawer-padding-primary:var(--el-dialog-padding-primary, 20px)}.el-drawer{position:absolute;box-sizing:border-box;background-color:var(--el-drawer-bg-color);display:flex;flex-direction:column;box-shadow:var(--el-box-shadow-dark);overflow:hidden;transition:all var(--el-transition-duration)}.el-drawer .rtl,.el-drawer .ltr,.el-drawer .ttb,.el-drawer .btt{transform:translate(0)}.el-drawer__sr-focus:focus{outline:0!important}.el-drawer__header{align-items:center;color:#72767b;display:flex;margin-bottom:32px;padding:var(--el-drawer-padding-primary);padding-bottom:0}.el-drawer__header>:first-child{flex:1}.el-drawer__title{margin:0;flex:1;line-height:inherit;font-size:1rem}.el-drawer__footer{padding:var(--el-drawer-padding-primary);padding-top:10px;text-align:right}.el-drawer__close-btn{display:inline-flex;border:none;cursor:pointer;font-size:var(--el-font-size-extra-large);color:inherit;background-color:transparent;outline:0}.el-drawer__close-btn:focus i,.el-drawer__close-btn:hover i{color:var(--el-color-primary)}.el-drawer__body{flex:1;padding:var(--el-drawer-padding-primary);overflow:auto}.el-drawer__body>*{box-sizing:border-box}.el-drawer.ltr,.el-drawer.rtl{height:100%;top:0;bottom:0}.el-drawer.btt,.el-drawer.ttb{width:100%;left:0;right:0}.el-drawer.ltr{left:0}.el-drawer.rtl{right:0}.el-drawer.ttb{top:0}.el-drawer.btt{bottom:0}.el-drawer-fade-enter-active,.el-drawer-fade-leave-active{transition:all var(--el-transition-duration)}.el-drawer-fade-enter-active,.el-drawer-fade-enter-from,.el-drawer-fade-enter-to,.el-drawer-fade-leave-active,.el-drawer-fade-leave-from,.el-drawer-fade-leave-to{overflow:hidden!important}.el-drawer-fade-enter-from,.el-drawer-fade-leave-to{opacity:0}.el-drawer-fade-enter-to,.el-drawer-fade-leave-from{opacity:1}.el-drawer-fade-enter-from .rtl,.el-drawer-fade-leave-to .rtl{transform:translate(100%)}.el-drawer-fade-enter-from .ltr,.el-drawer-fade-leave-to .ltr{transform:translate(-100%)}.el-drawer-fade-enter-from .ttb,.el-drawer-fade-leave-to .ttb{transform:translateY(-100%)}.el-drawer-fade-enter-from .btt,.el-drawer-fade-leave-to .btt{transform:translateY(100%)}.el-dropdown{--el-dropdown-menu-box-shadow:var(--el-box-shadow-light);--el-dropdown-menuItem-hover-fill:var(--el-color-primary-light-9);--el-dropdown-menuItem-hover-color:var(--el-color-primary);--el-dropdown-menu-index:10;display:inline-flex;position:relative;color:var(--el-text-color-regular);font-size:var(--el-font-size-base);line-height:1;vertical-align:top}.el-dropdown.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-dropdown__popper{--el-dropdown-menu-box-shadow:var(--el-box-shadow-light);--el-dropdown-menuItem-hover-fill:var(--el-color-primary-light-9);--el-dropdown-menuItem-hover-color:var(--el-color-primary);--el-dropdown-menu-index:10}.el-dropdown__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-dropdown-menu-box-shadow)}.el-dropdown__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-dropdown__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-dropdown__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-dropdown__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-dropdown__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-dropdown__popper .el-dropdown-menu{border:none}.el-dropdown__popper .el-dropdown__popper-selfdefine{outline:0}.el-dropdown__popper .el-scrollbar__bar{z-index:calc(var(--el-dropdown-menu-index) + 1)}.el-dropdown__popper .el-dropdown__list{list-style:none;padding:0;margin:0;box-sizing:border-box}.el-dropdown .el-dropdown__caret-button{padding-left:0;padding-right:0;display:inline-flex;justify-content:center;align-items:center;width:32px;border-left:none}.el-dropdown .el-dropdown__caret-button>span{display:inline-flex}.el-dropdown .el-dropdown__caret-button:before{content:"";position:absolute;display:block;width:1px;top:-1px;bottom:-1px;left:0;background:var(--el-overlay-color-lighter)}.el-dropdown .el-dropdown__caret-button.el-button:before{background:var(--el-border-color);opacity:.5}.el-dropdown .el-dropdown__caret-button .el-dropdown__icon{font-size:inherit;padding-left:0}.el-dropdown .el-dropdown-selfdefine{outline:0}.el-dropdown--large .el-dropdown__caret-button{width:40px}.el-dropdown--small .el-dropdown__caret-button{width:24px}.el-dropdown-menu{position:relative;top:0;left:0;z-index:var(--el-dropdown-menu-index);padding:5px 0;margin:0;background-color:var(--el-bg-color-overlay);border:none;border-radius:var(--el-border-radius-base);box-shadow:none;list-style:none}.el-dropdown-menu__item{display:flex;align-items:center;white-space:nowrap;list-style:none;line-height:22px;padding:5px 16px;margin:0;font-size:var(--el-font-size-base);color:var(--el-text-color-regular);cursor:pointer;outline:0}.el-dropdown-menu__item:not(.is-disabled):focus{background-color:var(--el-dropdown-menuItem-hover-fill);color:var(--el-dropdown-menuItem-hover-color)}.el-dropdown-menu__item i{margin-right:5px}.el-dropdown-menu__item--divided{margin:6px 0;border-top:1px solid var(--el-border-color-lighter)}.el-dropdown-menu__item.is-disabled{cursor:not-allowed;color:var(--el-text-color-disabled)}.el-dropdown-menu--large{padding:7px 0}.el-dropdown-menu--large .el-dropdown-menu__item{padding:7px 20px;line-height:22px;font-size:14px}.el-dropdown-menu--large .el-dropdown-menu__item--divided{margin:8px 0}.el-dropdown-menu--small{padding:3px 0}.el-dropdown-menu--small .el-dropdown-menu__item{padding:2px 12px;line-height:20px;font-size:12px}.el-dropdown-menu--small .el-dropdown-menu__item--divided{margin:4px 0}.el-empty{--el-empty-padding:40px 0;--el-empty-image-width:160px;--el-empty-description-margin-top:20px;--el-empty-bottom-margin-top:20px;--el-empty-fill-color-0:var(--el-color-white);--el-empty-fill-color-1:#fcfcfd;--el-empty-fill-color-2:#f8f9fb;--el-empty-fill-color-3:#f7f8fc;--el-empty-fill-color-4:#eeeff3;--el-empty-fill-color-5:#edeef2;--el-empty-fill-color-6:#e9ebef;--el-empty-fill-color-7:#e5e7e9;--el-empty-fill-color-8:#e0e3e9;--el-empty-fill-color-9:#d5d7de;display:flex;justify-content:center;align-items:center;flex-direction:column;text-align:center;box-sizing:border-box;padding:var(--el-empty-padding)}.el-empty__image{width:var(--el-empty-image-width)}.el-empty__image img{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;width:100%;height:100%;vertical-align:top;-o-object-fit:contain;object-fit:contain}.el-empty__image svg{color:var(--el-svg-monochrome-grey);fill:currentColor;width:100%;height:100%;vertical-align:top}.el-empty__description{margin-top:var(--el-empty-description-margin-top)}.el-empty__description p{margin:0;font-size:var(--el-font-size-base);color:var(--el-text-color-secondary)}.el-empty__bottom{margin-top:var(--el-empty-bottom-margin-top)}.el-footer{--el-footer-padding:0 20px;--el-footer-height:60px;padding:var(--el-footer-padding);box-sizing:border-box;flex-shrink:0;height:var(--el-footer-height)}.el-form{--el-form-label-font-size:var(--el-font-size-base)}.el-form--label-left .el-form-item__label{justify-content:flex-start}.el-form--label-top .el-form-item{display:block}.el-form--label-top .el-form-item .el-form-item__label{display:block;height:auto;text-align:left;margin-bottom:8px;line-height:22px}.el-form--inline .el-form-item{display:inline-flex;vertical-align:middle;margin-right:32px}.el-form--inline.el-form--label-top{display:flex;flex-wrap:wrap}.el-form--inline.el-form--label-top .el-form-item{display:block}.el-form--large.el-form--label-top .el-form-item .el-form-item__label{margin-bottom:12px;line-height:22px}.el-form--default.el-form--label-top .el-form-item .el-form-item__label{margin-bottom:8px;line-height:22px}.el-form--small.el-form--label-top .el-form-item .el-form-item__label{margin-bottom:4px;line-height:20px}.el-form-item{display:flex;--font-size:14px;margin-bottom:18px}.el-form-item .el-form-item{margin-bottom:0}.el-form-item .el-input__validateIcon{display:none}.el-form-item--large{--font-size:14px;--el-form-label-font-size:var(--font-size);margin-bottom:22px}.el-form-item--large .el-form-item__label{height:40px;line-height:40px}.el-form-item--large .el-form-item__content{line-height:40px}.el-form-item--large .el-form-item__error{padding-top:4px}.el-form-item--default{--font-size:14px;--el-form-label-font-size:var(--font-size);margin-bottom:18px}.el-form-item--default .el-form-item__label{height:32px;line-height:32px}.el-form-item--default .el-form-item__content{line-height:32px}.el-form-item--default .el-form-item__error{padding-top:2px}.el-form-item--small{--font-size:12px;--el-form-label-font-size:var(--font-size);margin-bottom:18px}.el-form-item--small .el-form-item__label{height:24px;line-height:24px}.el-form-item--small .el-form-item__content{line-height:24px}.el-form-item--small .el-form-item__error{padding-top:2px}.el-form-item__label-wrap{display:flex}.el-form-item__label{display:inline-flex;justify-content:flex-end;align-items:flex-start;flex:0 0 auto;font-size:var(--el-form-label-font-size);color:var(--el-text-color-regular);height:32px;line-height:32px;padding:0 12px 0 0;box-sizing:border-box}.el-form-item__content{display:flex;flex-wrap:wrap;align-items:center;flex:1;line-height:32px;position:relative;font-size:var(--font-size);min-width:0}.el-form-item__content .el-input-group{vertical-align:top}.el-form-item__error{color:var(--el-color-danger);font-size:12px;line-height:1;padding-top:2px;position:absolute;top:100%;left:0}.el-form-item__error--inline{position:relative;top:auto;left:auto;display:inline-block;margin-left:10px}.el-form-item.is-required:not(.is-no-asterisk).asterisk-left>.el-form-item__label-wrap>.el-form-item__label:before,.el-form-item.is-required:not(.is-no-asterisk).asterisk-left>.el-form-item__label:before{content:"*";color:var(--el-color-danger);margin-right:4px}.el-form-item.is-required:not(.is-no-asterisk).asterisk-right>.el-form-item__label-wrap>.el-form-item__label:after,.el-form-item.is-required:not(.is-no-asterisk).asterisk-right>.el-form-item__label:after{content:"*";color:var(--el-color-danger);margin-left:4px}.el-form-item.is-error .el-select-v2__wrapper,.el-form-item.is-error .el-select-v2__wrapper:focus,.el-form-item.is-error .el-textarea__inner,.el-form-item.is-error .el-textarea__inner:focus{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-form-item.is-error .el-input__wrapper{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-form-item.is-error .el-input-group__append .el-input__wrapper,.el-form-item.is-error .el-input-group__prepend .el-input__wrapper{box-shadow:0 0 0 1px transparent inset}.el-form-item.is-error .el-input__validateIcon{color:var(--el-color-danger)}.el-form-item--feedback .el-input__validateIcon{display:inline-flex}.el-header{--el-header-padding:0 20px;--el-header-height:60px;padding:var(--el-header-padding);box-sizing:border-box;flex-shrink:0;height:var(--el-header-height)}.el-image-viewer__wrapper{position:fixed;top:0;right:0;bottom:0;left:0}.el-image-viewer__btn{position:absolute;z-index:1;display:flex;align-items:center;justify-content:center;border-radius:50%;opacity:.8;cursor:pointer;box-sizing:border-box;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-image-viewer__btn .el-icon{font-size:inherit;cursor:pointer}.el-image-viewer__close{top:40px;right:40px;width:40px;height:40px;font-size:40px}.el-image-viewer__canvas{position:static;width:100%;height:100%;display:flex;justify-content:center;align-items:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-image-viewer__actions{left:50%;bottom:30px;transform:translate(-50%);width:282px;height:44px;padding:0 23px;background-color:var(--el-text-color-regular);border-color:#fff;border-radius:22px}.el-image-viewer__actions__inner{width:100%;height:100%;text-align:justify;cursor:default;font-size:23px;color:#fff;display:flex;align-items:center;justify-content:space-around}.el-image-viewer__prev{top:50%;transform:translateY(-50%);left:40px;width:44px;height:44px;font-size:24px;color:#fff;background-color:var(--el-text-color-regular);border-color:#fff}.el-image-viewer__next{top:50%;transform:translateY(-50%);right:40px;text-indent:2px;width:44px;height:44px;font-size:24px;color:#fff;background-color:var(--el-text-color-regular);border-color:#fff}.el-image-viewer__close{width:44px;height:44px;font-size:24px;color:#fff;background-color:var(--el-text-color-regular);border-color:#fff}.el-image-viewer__mask{position:absolute;width:100%;height:100%;top:0;left:0;opacity:.5;background:#000}.viewer-fade-enter-active{-webkit-animation:viewer-fade-in var(--el-transition-duration);animation:viewer-fade-in var(--el-transition-duration)}.viewer-fade-leave-active{-webkit-animation:viewer-fade-out var(--el-transition-duration);animation:viewer-fade-out var(--el-transition-duration)}@-webkit-keyframes viewer-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@keyframes viewer-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@-webkit-keyframes viewer-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@keyframes viewer-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}.el-image__error,.el-image__inner,.el-image__placeholder,.el-image__wrapper{width:100%;height:100%}.el-image{position:relative;display:inline-block;overflow:hidden}.el-image__inner{vertical-align:top;opacity:1}.el-image__inner.is-loading{opacity:0}.el-image__wrapper{position:absolute;top:0;left:0}.el-image__placeholder{background:var(--el-fill-color-light)}.el-image__error{display:flex;justify-content:center;align-items:center;font-size:14px;background:var(--el-fill-color-light);color:var(--el-text-color-placeholder);vertical-align:middle}.el-image__preview{cursor:pointer}.el-input-number{position:relative;display:inline-flex;width:150px;line-height:30px}.el-input-number .el-input__wrapper{padding-left:42px;padding-right:42px}.el-input-number .el-input__inner{-webkit-appearance:none;-moz-appearance:textfield;text-align:center;line-height:1}.el-input-number .el-input__inner::-webkit-inner-spin-button,.el-input-number .el-input__inner::-webkit-outer-spin-button{margin:0;-webkit-appearance:none}.el-input-number__decrease,.el-input-number__increase{display:flex;justify-content:center;align-items:center;height:auto;position:absolute;z-index:1;top:1px;bottom:1px;width:32px;background:var(--el-fill-color-light);color:var(--el-text-color-regular);cursor:pointer;font-size:13px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-input-number__decrease:hover,.el-input-number__increase:hover{color:var(--el-color-primary)}.el-input-number__decrease:hover~.el-input:not(.is-disabled) .el-input_wrapper,.el-input-number__increase:hover~.el-input:not(.is-disabled) .el-input_wrapper{box-shadow:0 0 0 1px var(--el-input-focus-border-color,var(--el-color-primary)) inset}.el-input-number__decrease.is-disabled,.el-input-number__increase.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-input-number__increase{right:1px;border-radius:0 var(--el-border-radius-base) var(--el-border-radius-base) 0;border-left:var(--el-border)}.el-input-number__decrease{left:1px;border-radius:var(--el-border-radius-base) 0 0 var(--el-border-radius-base);border-right:var(--el-border)}.el-input-number.is-disabled .el-input-number__decrease,.el-input-number.is-disabled .el-input-number__increase{border-color:var(--el-disabled-border-color);color:var(--el-disabled-border-color)}.el-input-number.is-disabled .el-input-number__decrease:hover,.el-input-number.is-disabled .el-input-number__increase:hover{color:var(--el-disabled-border-color);cursor:not-allowed}.el-input-number--large{width:180px;line-height:38px}.el-input-number--large .el-input-number__decrease,.el-input-number--large .el-input-number__increase{width:40px;font-size:14px}.el-input-number--large .el-input__wrapper{padding-left:47px;padding-right:47px}.el-input-number--small{width:120px;line-height:22px}.el-input-number--small .el-input-number__decrease,.el-input-number--small .el-input-number__increase{width:24px;font-size:12px}.el-input-number--small .el-input__wrapper{padding-left:31px;padding-right:31px}.el-input-number--small .el-input-number__decrease [class*=el-icon],.el-input-number--small .el-input-number__increase [class*=el-icon]{transform:scale(.9)}.el-input-number.is-without-controls .el-input__wrapper{padding-left:15px;padding-right:15px}.el-input-number.is-controls-right .el-input__wrapper{padding-left:15px;padding-right:42px}.el-input-number.is-controls-right .el-input-number__decrease,.el-input-number.is-controls-right .el-input-number__increase{--el-input-number-controls-height:15px;height:var(--el-input-number-controls-height);line-height:var(--el-input-number-controls-height)}.el-input-number.is-controls-right .el-input-number__decrease [class*=el-icon],.el-input-number.is-controls-right .el-input-number__increase [class*=el-icon]{transform:scale(.8)}.el-input-number.is-controls-right .el-input-number__increase{bottom:auto;left:auto;border-radius:0 var(--el-border-radius-base) 0 0;border-bottom:var(--el-border)}.el-input-number.is-controls-right .el-input-number__decrease{right:1px;top:auto;left:auto;border-right:none;border-left:var(--el-border);border-radius:0 0 var(--el-border-radius-base) 0}.el-input-number.is-controls-right[class*=large] [class*=decrease],.el-input-number.is-controls-right[class*=large] [class*=increase]{--el-input-number-controls-height:19px}.el-input-number.is-controls-right[class*=small] [class*=decrease],.el-input-number.is-controls-right[class*=small] [class*=increase]{--el-input-number-controls-height:11px}.el-textarea{--el-input-text-color:var(--el-text-color-regular);--el-input-border:var(--el-border);--el-input-hover-border:var(--el-border-color-hover);--el-input-focus-border:var(--el-color-primary);--el-input-transparent-border:0 0 0 1px transparent inset;--el-input-border-color:var(--el-border-color);--el-input-border-radius:var(--el-border-radius-base);--el-input-bg-color:var(--el-fill-color-blank);--el-input-icon-color:var(--el-text-color-placeholder);--el-input-placeholder-color:var(--el-text-color-placeholder);--el-input-hover-border-color:var(--el-border-color-hover);--el-input-clear-hover-color:var(--el-text-color-secondary);--el-input-focus-border-color:var(--el-color-primary)}.el-textarea{position:relative;display:inline-block;width:100%;vertical-align:bottom;font-size:var(--el-font-size-base)}.el-textarea__inner{position:relative;display:block;resize:vertical;padding:5px 11px;line-height:1.5;box-sizing:border-box;width:100%;font-size:inherit;font-family:inherit;color:var(--el-input-text-color,var(--el-text-color-regular));background-color:var(--el-input-bg-color,var(--el-fill-color-blank));background-image:none;-webkit-appearance:none;box-shadow:0 0 0 1px var(--el-input-border-color,var(--el-border-color)) inset;border-radius:var(--el-input-border-radius,var(--el-border-radius-base));transition:var(--el-transition-box-shadow);border:none}.el-textarea__inner::-moz-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-textarea__inner:-ms-input-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-textarea__inner::placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-textarea__inner:hover{box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-textarea__inner:focus{outline:0;box-shadow:0 0 0 1px var(--el-input-focus-border-color) inset}.el-textarea .el-input__count{color:var(--el-color-info);background:var(--el-fill-color-blank);position:absolute;font-size:12px;line-height:14px;bottom:5px;right:10px}.el-textarea.is-disabled .el-textarea__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color);color:var(--el-disabled-text-color);cursor:not-allowed}.el-textarea.is-disabled .el-textarea__inner::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-textarea.is-disabled .el-textarea__inner:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-textarea.is-disabled .el-textarea__inner::placeholder{color:var(--el-text-color-placeholder)}.el-textarea.is-exceed .el-textarea__inner{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-textarea.is-exceed .el-input__count{color:var(--el-color-danger)}.el-input{--el-input-text-color:var(--el-text-color-regular);--el-input-border:var(--el-border);--el-input-hover-border:var(--el-border-color-hover);--el-input-focus-border:var(--el-color-primary);--el-input-transparent-border:0 0 0 1px transparent inset;--el-input-border-color:var(--el-border-color);--el-input-border-radius:var(--el-border-radius-base);--el-input-bg-color:var(--el-fill-color-blank);--el-input-icon-color:var(--el-text-color-placeholder);--el-input-placeholder-color:var(--el-text-color-placeholder);--el-input-hover-border-color:var(--el-border-color-hover);--el-input-clear-hover-color:var(--el-text-color-secondary);--el-input-focus-border-color:var(--el-color-primary)}.el-input{--el-input-height:var(--el-component-size);position:relative;font-size:var(--el-font-size-base);display:inline-flex;width:100%;line-height:var(--el-input-height);box-sizing:border-box;vertical-align:middle}.el-input::-webkit-scrollbar{z-index:11;width:6px}.el-input::-webkit-scrollbar:horizontal{height:6px}.el-input::-webkit-scrollbar-thumb{border-radius:5px;width:6px;background:var(--el-text-color-disabled)}.el-input::-webkit-scrollbar-corner{background:var(--el-fill-color-blank)}.el-input::-webkit-scrollbar-track{background:var(--el-fill-color-blank)}.el-input::-webkit-scrollbar-track-piece{background:var(--el-fill-color-blank);width:6px}.el-input .el-input__clear,.el-input .el-input__password{color:var(--el-input-icon-color);font-size:14px;cursor:pointer}.el-input .el-input__clear:hover,.el-input .el-input__password:hover{color:var(--el-input-clear-hover-color)}.el-input .el-input__count{height:100%;display:inline-flex;align-items:center;color:var(--el-color-info);font-size:12px}.el-input .el-input__count .el-input__count-inner{background:var(--el-fill-color-blank);line-height:initial;display:inline-block;padding-left:8px}.el-input__wrapper{display:inline-flex;flex-grow:1;align-items:center;justify-content:center;padding:1px 11px;background-color:var(--el-input-bg-color,var(--el-fill-color-blank));background-image:none;border-radius:var(--el-input-border-radius,var(--el-border-radius-base));transition:var(--el-transition-box-shadow);transform:translateZ(0);box-shadow:0 0 0 1px var(--el-input-border-color,var(--el-border-color)) inset}.el-input__wrapper:hover{box-shadow:0 0 0 1px var(--el-input-hover-border-color) inset}.el-input__wrapper.is-focus{box-shadow:0 0 0 1px var(--el-input-focus-border-color) inset}.el-input__inner{--el-input-inner-height:calc(var(--el-input-height, 32px) - 2px);width:100%;flex-grow:1;-webkit-appearance:none;color:var(--el-input-text-color,var(--el-text-color-regular));font-size:inherit;height:var(--el-input-inner-height);line-height:var(--el-input-inner-height);padding:0;outline:0;border:none;background:0 0;box-sizing:border-box}.el-input__inner:focus{outline:0}.el-input__inner::-moz-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-input__inner:-ms-input-placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-input__inner::placeholder{color:var(--el-input-placeholder-color,var(--el-text-color-placeholder))}.el-input__inner[type=password]::-ms-reveal{display:none}.el-input__prefix{display:inline-flex;white-space:nowrap;flex-shrink:0;flex-wrap:nowrap;height:100%;text-align:center;color:var(--el-input-icon-color,var(--el-text-color-placeholder));transition:all var(--el-transition-duration);pointer-events:none}.el-input__prefix-inner{pointer-events:all;display:inline-flex;align-items:center;justify-content:center}.el-input__prefix-inner>:last-child{margin-right:8px}.el-input__prefix-inner>:first-child,.el-input__prefix-inner>:first-child.el-input__icon{margin-left:0}.el-input__suffix{display:inline-flex;white-space:nowrap;flex-shrink:0;flex-wrap:nowrap;height:100%;text-align:center;color:var(--el-input-icon-color,var(--el-text-color-placeholder));transition:all var(--el-transition-duration);pointer-events:none}.el-input__suffix-inner{pointer-events:all;display:inline-flex;align-items:center;justify-content:center}.el-input__suffix-inner>:first-child{margin-left:8px}.el-input .el-input__icon{height:inherit;line-height:inherit;display:flex;justify-content:center;align-items:center;transition:all var(--el-transition-duration);margin-left:8px}.el-input__validateIcon{pointer-events:none}.el-input.is-active .el-input__wrapper{box-shadow:0 0 0 1px var(--el-input-focus-color,) inset}.el-input.is-disabled{cursor:not-allowed}.el-input.is-disabled .el-input__wrapper{background-color:var(--el-disabled-bg-color);box-shadow:0 0 0 1px var(--el-disabled-border-color) inset}.el-input.is-disabled .el-input__inner{color:var(--el-disabled-text-color);-webkit-text-fill-color:var(--el-disabled-text-color);cursor:not-allowed}.el-input.is-disabled .el-input__inner::-moz-placeholder{color:var(--el-text-color-placeholder)}.el-input.is-disabled .el-input__inner:-ms-input-placeholder{color:var(--el-text-color-placeholder)}.el-input.is-disabled .el-input__inner::placeholder{color:var(--el-text-color-placeholder)}.el-input.is-disabled .el-input__icon{cursor:not-allowed}.el-input.is-exceed .el-input__wrapper{box-shadow:0 0 0 1px var(--el-color-danger) inset}.el-input.is-exceed .el-input__suffix .el-input__count{color:var(--el-color-danger)}.el-input--large{--el-input-height:var(--el-component-size-large);font-size:14px}.el-input--large .el-input__wrapper{padding:1px 15px}.el-input--large .el-input__inner{--el-input-inner-height:calc(var(--el-input-height, 40px) - 2px)}.el-input--small{--el-input-height:var(--el-component-size-small);font-size:12px}.el-input--small .el-input__wrapper{padding:1px 7px}.el-input--small .el-input__inner{--el-input-inner-height:calc(var(--el-input-height, 24px) - 2px)}.el-input-group{display:inline-flex;width:100%;align-items:stretch}.el-input-group__append,.el-input-group__prepend{background-color:var(--el-fill-color-light);color:var(--el-color-info);position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:100%;border-radius:var(--el-input-border-radius);padding:0 20px;white-space:nowrap}.el-input-group__append:focus,.el-input-group__prepend:focus{outline:0}.el-input-group__append .el-button,.el-input-group__append .el-select,.el-input-group__prepend .el-button,.el-input-group__prepend .el-select{display:inline-block;margin:0 -20px}.el-input-group__append button.el-button,.el-input-group__append button.el-button:hover,.el-input-group__append div.el-select .el-input__wrapper,.el-input-group__append div.el-select:hover .el-input__wrapper,.el-input-group__prepend button.el-button,.el-input-group__prepend button.el-button:hover,.el-input-group__prepend div.el-select .el-input__wrapper,.el-input-group__prepend div.el-select:hover .el-input__wrapper{border-color:transparent;background-color:transparent;color:inherit}.el-input-group__append .el-button,.el-input-group__append .el-input,.el-input-group__prepend .el-button,.el-input-group__prepend .el-input{font-size:inherit}.el-input-group__prepend{border-right:0;border-top-right-radius:0;border-bottom-right-radius:0;box-shadow:1px 0 0 0 var(--el-input-border-color) inset,0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset}.el-input-group__append{border-left:0;border-top-left-radius:0;border-bottom-left-radius:0;box-shadow:0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset,-1px 0 0 0 var(--el-input-border-color) inset}.el-input-group--prepend>.el-input__wrapper{border-top-left-radius:0;border-bottom-left-radius:0}.el-input-group--prepend .el-input-group__prepend .el-select .el-input .el-input__inner{box-shadow:none!important}.el-input-group--prepend .el-input-group__prepend .el-select .el-input .el-input__wrapper{border-top-right-radius:0;border-bottom-right-radius:0;box-shadow:1px 0 0 0 var(--el-input-border-color) inset,0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset}.el-input-group--prepend .el-input-group__prepend .el-select .el-input.is-focus .el-input__inner{box-shadow:none!important}.el-input-group--prepend .el-input-group__prepend .el-select .el-input.is-focus .el-input__wrapper{box-shadow:1px 0 0 0 var(--el-input-focus-border-color) inset,1px 0 0 0 var(--el-input-focus-border-color),0 1px 0 0 var(--el-input-focus-border-color) inset,0 -1px 0 0 var(--el-input-focus-border-color) inset!important;z-index:2}.el-input-group--prepend .el-input-group__prepend .el-select .el-input.is-focus .el-input__wrapper:focus{outline:0;z-index:2;box-shadow:1px 0 0 0 var(--el-input-focus-border-color) inset,1px 0 0 0 var(--el-input-focus-border-color),0 1px 0 0 var(--el-input-focus-border-color) inset,0 -1px 0 0 var(--el-input-focus-border-color) inset!important}.el-input-group--prepend .el-input-group__prepend .el-select:hover .el-input__inner{box-shadow:none!important}.el-input-group--prepend .el-input-group__prepend .el-select:hover .el-input__wrapper{z-index:1;box-shadow:1px 0 0 0 var(--el-input-hover-border-color) inset,1px 0 0 0 var(--el-input-hover-border-color),0 1px 0 0 var(--el-input-hover-border-color) inset,0 -1px 0 0 var(--el-input-hover-border-color) inset!important}.el-input-group--append>.el-input__wrapper{border-top-right-radius:0;border-bottom-right-radius:0}.el-input-group--append .el-input-group__append .el-select .el-input .el-input__inner{box-shadow:none!important}.el-input-group--append .el-input-group__append .el-select .el-input .el-input__wrapper{border-top-left-radius:0;border-bottom-left-radius:0;box-shadow:0 1px 0 0 var(--el-input-border-color) inset,0 -1px 0 0 var(--el-input-border-color) inset,-1px 0 0 0 var(--el-input-border-color) inset}.el-input-group--append .el-input-group__append .el-select .el-input.is-focus .el-input__inner{box-shadow:none!important}.el-input-group--append .el-input-group__append .el-select .el-input.is-focus .el-input__wrapper{z-index:2;box-shadow:-1px 0 0 0 var(--el-input-focus-border-color),-1px 0 0 0 var(--el-input-focus-border-color) inset,0 1px 0 0 var(--el-input-focus-border-color) inset,0 -1px 0 0 var(--el-input-focus-border-color) inset!important}.el-input-group--append .el-input-group__append .el-select:hover .el-input__inner{box-shadow:none!important}.el-input-group--append .el-input-group__append .el-select:hover .el-input__wrapper{z-index:1;box-shadow:-1px 0 0 0 var(--el-input-hover-border-color),-1px 0 0 0 var(--el-input-hover-border-color) inset,0 1px 0 0 var(--el-input-hover-border-color) inset,0 -1px 0 0 var(--el-input-hover-border-color) inset!important}.el-link{--el-link-font-size:var(--el-font-size-base);--el-link-font-weight:var(--el-font-weight-primary);--el-link-text-color:var(--el-text-color-regular);--el-link-hover-text-color:var(--el-color-primary);--el-link-disabled-text-color:var(--el-text-color-placeholder)}.el-link{display:inline-flex;flex-direction:row;align-items:center;justify-content:center;vertical-align:middle;position:relative;text-decoration:none;outline:0;cursor:pointer;padding:0;font-size:var(--el-link-font-size);font-weight:var(--el-link-font-weight);color:var(--el-link-text-color)}.el-link:hover{color:var(--el-link-hover-text-color)}.el-link.is-underline:hover:after{content:"";position:absolute;left:0;right:0;height:0;bottom:0;border-bottom:1px solid var(--el-link-hover-text-color)}.el-link.is-disabled{color:var(--el-link-disabled-text-color);cursor:not-allowed}.el-link [class*=el-icon-]+span{margin-left:5px}.el-link.el-link--default:after{border-color:var(--el-link-hover-text-color)}.el-link__inner{display:inline-flex;justify-content:center;align-items:center}.el-link.el-link--primary{--el-link-text-color:var(--el-color-primary);--el-link-hover-text-color:var(--el-color-primary-light-3);--el-link-disabled-text-color:var(--el-color-primary-light-5)}.el-link.el-link--primary:after{border-color:var(--el-link-text-color)}.el-link.el-link--primary.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--success{--el-link-text-color:var(--el-color-success);--el-link-hover-text-color:var(--el-color-success-light-3);--el-link-disabled-text-color:var(--el-color-success-light-5)}.el-link.el-link--success:after{border-color:var(--el-link-text-color)}.el-link.el-link--success.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--warning{--el-link-text-color:var(--el-color-warning);--el-link-hover-text-color:var(--el-color-warning-light-3);--el-link-disabled-text-color:var(--el-color-warning-light-5)}.el-link.el-link--warning:after{border-color:var(--el-link-text-color)}.el-link.el-link--warning.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--danger{--el-link-text-color:var(--el-color-danger);--el-link-hover-text-color:var(--el-color-danger-light-3);--el-link-disabled-text-color:var(--el-color-danger-light-5)}.el-link.el-link--danger:after{border-color:var(--el-link-text-color)}.el-link.el-link--danger.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--error{--el-link-text-color:var(--el-color-error);--el-link-hover-text-color:var(--el-color-error-light-3);--el-link-disabled-text-color:var(--el-color-error-light-5)}.el-link.el-link--error:after{border-color:var(--el-link-text-color)}.el-link.el-link--error.is-underline:hover:after{border-color:var(--el-link-text-color)}.el-link.el-link--info{--el-link-text-color:var(--el-color-info);--el-link-hover-text-color:var(--el-color-info-light-3);--el-link-disabled-text-color:var(--el-color-info-light-5)}.el-link.el-link--info:after{border-color:var(--el-link-text-color)}.el-link.el-link--info.is-underline:hover:after{border-color:var(--el-link-text-color)}:root{--el-loading-spinner-size:42px;--el-loading-fullscreen-spinner-size:50px}.el-loading-parent--relative{position:relative!important}.el-loading-parent--hidden{overflow:hidden!important}.el-loading-mask{position:absolute;z-index:2000;background-color:var(--el-mask-color);margin:0;top:0;right:0;bottom:0;left:0;transition:opacity var(--el-transition-duration)}.el-loading-mask.is-fullscreen{position:fixed}.el-loading-mask.is-fullscreen .el-loading-spinner{margin-top:calc((0px - var(--el-loading-fullscreen-spinner-size))/ 2)}.el-loading-mask.is-fullscreen .el-loading-spinner .circular{height:var(--el-loading-fullscreen-spinner-size);width:var(--el-loading-fullscreen-spinner-size)}.el-loading-spinner{top:50%;margin-top:calc((0px - var(--el-loading-spinner-size))/ 2);width:100%;text-align:center;position:absolute}.el-loading-spinner .el-loading-text{color:var(--el-color-primary);margin:3px 0;font-size:14px}.el-loading-spinner .circular{display:inline;height:var(--el-loading-spinner-size);width:var(--el-loading-spinner-size);-webkit-animation:loading-rotate 2s linear infinite;animation:loading-rotate 2s linear infinite}.el-loading-spinner .path{-webkit-animation:loading-dash 1.5s ease-in-out infinite;animation:loading-dash 1.5s ease-in-out infinite;stroke-dasharray:90,150;stroke-dashoffset:0;stroke-width:2;stroke:var(--el-color-primary);stroke-linecap:round}.el-loading-spinner i{color:var(--el-color-primary)}.el-loading-fade-enter-from,.el-loading-fade-leave-to{opacity:0}@-webkit-keyframes loading-rotate{to{transform:rotate(360deg)}}@keyframes loading-rotate{to{transform:rotate(360deg)}}@-webkit-keyframes loading-dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-40px}to{stroke-dasharray:90,150;stroke-dashoffset:-120px}}@keyframes loading-dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-40px}to{stroke-dasharray:90,150;stroke-dashoffset:-120px}}.el-main{--el-main-padding:20px;display:block;flex:1;flex-basis:auto;overflow:auto;box-sizing:border-box;padding:var(--el-main-padding)}:root{--el-menu-active-color:var(--el-color-primary);--el-menu-text-color:var(--el-text-color-primary);--el-menu-hover-text-color:var(--el-color-primary);--el-menu-bg-color:var(--el-fill-color-blank);--el-menu-hover-bg-color:var(--el-color-primary-light-9);--el-menu-item-height:56px;--el-menu-sub-item-height:calc(var(--el-menu-item-height) - 6px);--el-menu-horizontal-sub-item-height:36px;--el-menu-item-font-size:var(--el-font-size-base);--el-menu-item-hover-fill:var(--el-color-primary-light-9);--el-menu-border-color:var(--el-border-color);--el-menu-base-level-padding:20px;--el-menu-level-padding:20px;--el-menu-icon-width:24px}.el-menu{border-right:solid 1px var(--el-menu-border-color);list-style:none;position:relative;margin:0;padding-left:0;background-color:var(--el-menu-bg-color);box-sizing:border-box}.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-menu-item,.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-menu-item-group__title,.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-sub-menu__title{white-space:nowrap;padding-left:calc(var(--el-menu-base-level-padding) + var(--el-menu-level) * var(--el-menu-level-padding))}.el-menu--horizontal{display:flex;flex-wrap:nowrap;border-bottom:solid 1px var(--el-menu-border-color);border-right:none}.el-menu--horizontal>.el-menu-item{display:inline-flex;justify-content:center;align-items:center;height:100%;margin:0;border-bottom:2px solid transparent;color:var(--el-menu-text-color)}.el-menu--horizontal>.el-menu-item a,.el-menu--horizontal>.el-menu-item a:hover{color:inherit}.el-menu--horizontal>.el-menu-item:not(.is-disabled):focus,.el-menu--horizontal>.el-menu-item:not(.is-disabled):hover{background-color:#fff}.el-menu--horizontal>.el-sub-menu:focus,.el-menu--horizontal>.el-sub-menu:hover{outline:0}.el-menu--horizontal>.el-sub-menu:hover .el-sub-menu__title{color:var(--el-menu-hover-text-color)}.el-menu--horizontal>.el-sub-menu.is-active .el-sub-menu__title{border-bottom:2px solid var(--el-menu-active-color);color:var(--el-menu-active-color)}.el-menu--horizontal>.el-sub-menu .el-sub-menu__title{height:100%;border-bottom:2px solid transparent;color:var(--el-menu-text-color)}.el-menu--horizontal>.el-sub-menu .el-sub-menu__title:hover{background-color:var(--el-bg-color-overlay)}.el-menu--horizontal .el-menu .el-menu-item,.el-menu--horizontal .el-menu .el-sub-menu__title{background-color:var(--el-menu-bg-color);display:flex;align-items:center;height:var(--el-menu-horizontal-sub-item-height);line-height:var(--el-menu-horizontal-sub-item-height);padding:0 10px;color:var(--el-menu-text-color)}.el-menu--horizontal .el-menu .el-sub-menu__title{padding-right:40px}.el-menu--horizontal .el-menu .el-menu-item.is-active,.el-menu--horizontal .el-menu .el-sub-menu.is-active>.el-sub-menu__title{color:var(--el-menu-active-color)}.el-menu--horizontal .el-menu-item:not(.is-disabled):focus,.el-menu--horizontal .el-menu-item:not(.is-disabled):hover{outline:0;color:var(--el-menu-hover-text-color);background-color:var(--el-menu-hover-bg-color)}.el-menu--horizontal>.el-menu-item.is-active{border-bottom:2px solid var(--el-menu-active-color);color:var(--el-menu-active-color)!important}.el-menu--collapse{width:calc(var(--el-menu-icon-width) + var(--el-menu-base-level-padding) * 2)}.el-menu--collapse>.el-menu-item [class^=el-icon],.el-menu--collapse>.el-menu-item-group>ul>.el-sub-menu>.el-sub-menu__title [class^=el-icon],.el-menu--collapse>.el-sub-menu>.el-sub-menu__title [class^=el-icon]{margin:0;vertical-align:middle;width:var(--el-menu-icon-width);text-align:center}.el-menu--collapse>.el-menu-item .el-sub-menu__icon-arrow,.el-menu--collapse>.el-menu-item-group>ul>.el-sub-menu>.el-sub-menu__title .el-sub-menu__icon-arrow,.el-menu--collapse>.el-sub-menu>.el-sub-menu__title .el-sub-menu__icon-arrow{display:none}.el-menu--collapse>.el-menu-item-group>ul>.el-sub-menu>.el-sub-menu__title>span,.el-menu--collapse>.el-menu-item>span,.el-menu--collapse>.el-sub-menu>.el-sub-menu__title>span{height:0;width:0;overflow:hidden;visibility:hidden;display:inline-block}.el-menu--collapse>.el-menu-item.is-active i{color:inherit}.el-menu--collapse .el-menu .el-sub-menu{min-width:200px}.el-menu--popup{z-index:100;min-width:200px;border:none;padding:5px 0;border-radius:var(--el-border-radius-small);box-shadow:var(--el-box-shadow-light)}.el-menu .el-icon{flex-shrink:0}.el-menu-item{display:flex;align-items:center;height:var(--el-menu-item-height);line-height:var(--el-menu-item-height);font-size:var(--el-menu-item-font-size);color:var(--el-menu-text-color);padding:0 var(--el-menu-base-level-padding);list-style:none;cursor:pointer;position:relative;transition:border-color var(--el-transition-duration),background-color var(--el-transition-duration),color var(--el-transition-duration);box-sizing:border-box;white-space:nowrap}.el-menu-item *{vertical-align:bottom}.el-menu-item i{color:inherit}.el-menu-item:focus,.el-menu-item:hover{outline:0}.el-menu-item:hover{background-color:var(--el-menu-hover-bg-color)}.el-menu-item.is-disabled{opacity:.25;cursor:not-allowed;background:0 0!important}.el-menu-item [class^=el-icon]{margin-right:5px;width:var(--el-menu-icon-width);text-align:center;font-size:18px;vertical-align:middle}.el-menu-item.is-active{color:var(--el-menu-active-color)}.el-menu-item.is-active i{color:inherit}.el-menu-item .el-menu-tooltip__trigger{position:absolute;left:0;top:0;height:100%;width:100%;display:inline-flex;align-items:center;box-sizing:border-box;padding:0 var(--el-menu-base-level-padding)}.el-sub-menu{list-style:none;margin:0;padding-left:0}.el-sub-menu__title{display:flex;align-items:center;height:var(--el-menu-item-height);line-height:var(--el-menu-item-height);font-size:var(--el-menu-item-font-size);color:var(--el-menu-text-color);padding:0 var(--el-menu-base-level-padding);list-style:none;cursor:pointer;position:relative;transition:border-color var(--el-transition-duration),background-color var(--el-transition-duration),color var(--el-transition-duration);box-sizing:border-box;white-space:nowrap;padding-right:calc(var(--el-menu-base-level-padding) + var(--el-menu-icon-width))}.el-sub-menu__title *{vertical-align:bottom}.el-sub-menu__title i{color:inherit}.el-sub-menu__title:focus,.el-sub-menu__title:hover{outline:0}.el-sub-menu__title.is-disabled{opacity:.25;cursor:not-allowed;background:0 0!important}.el-sub-menu__title:hover{background-color:var(--el-menu-hover-bg-color)}.el-sub-menu .el-menu{border:none}.el-sub-menu .el-menu-item{height:var(--el-menu-sub-item-height);line-height:var(--el-menu-sub-item-height)}.el-sub-menu__hide-arrow .el-sub-menu__icon-arrow{display:none!important}.el-sub-menu.is-active .el-sub-menu__title{border-bottom-color:var(--el-menu-active-color)}.el-sub-menu.is-disabled .el-menu-item,.el-sub-menu.is-disabled .el-sub-menu__title{opacity:.25;cursor:not-allowed;background:0 0!important}.el-sub-menu .el-icon{vertical-align:middle;margin-right:5px;width:var(--el-menu-icon-width);text-align:center;font-size:18px}.el-sub-menu .el-icon.el-sub-menu__icon-more{margin-right:0!important}.el-sub-menu .el-sub-menu__icon-arrow{position:absolute;top:50%;right:var(--el-menu-base-level-padding);margin-top:-6px;transition:transform var(--el-transition-duration);font-size:12px;margin-right:0;width:inherit}.el-menu-item-group>ul{padding:0}.el-menu-item-group__title{padding:7px 0 7px var(--el-menu-base-level-padding);line-height:normal;font-size:12px;color:var(--el-text-color-secondary)}.horizontal-collapse-transition .el-sub-menu__title .el-sub-menu__icon-arrow{transition:var(--el-transition-duration-fast);opacity:0}.el-message-box{--el-messagebox-title-color:var(--el-text-color-primary);--el-messagebox-width:420px;--el-messagebox-border-radius:4px;--el-messagebox-font-size:var(--el-font-size-large);--el-messagebox-content-font-size:var(--el-font-size-base);--el-messagebox-content-color:var(--el-text-color-regular);--el-messagebox-error-font-size:12px;--el-messagebox-padding-primary:15px}.el-message-box{display:inline-block;max-width:var(--el-messagebox-width);width:100%;padding-bottom:10px;vertical-align:middle;background-color:var(--el-bg-color);border-radius:var(--el-messagebox-border-radius);border:1px solid var(--el-border-color-lighter);font-size:var(--el-messagebox-font-size);box-shadow:var(--el-box-shadow-light);text-align:left;overflow:hidden;-webkit-backface-visibility:hidden;backface-visibility:hidden;box-sizing:border-box}.el-message-box:focus{outline:0!important}.el-overlay.is-message-box .el-overlay-message-box{text-align:center;position:fixed;top:0;right:0;bottom:0;left:0;padding:16px;overflow:auto}.el-overlay.is-message-box .el-overlay-message-box:after{content:"";display:inline-block;height:100%;width:0;vertical-align:middle}.el-message-box.is-draggable .el-message-box__header{cursor:move;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-message-box__header{position:relative;padding:var(--el-messagebox-padding-primary);padding-bottom:10px}.el-message-box__title{padding-left:0;margin-bottom:0;font-size:var(--el-messagebox-font-size);line-height:1;color:var(--el-messagebox-title-color)}.el-message-box__headerbtn{position:absolute;top:var(--el-messagebox-padding-primary);right:var(--el-messagebox-padding-primary);padding:0;border:none;outline:0;background:0 0;font-size:var(--el-message-close-size,16px);cursor:pointer}.el-message-box__headerbtn .el-message-box__close{color:var(--el-color-info);font-size:inherit}.el-message-box__headerbtn:focus .el-message-box__close,.el-message-box__headerbtn:hover .el-message-box__close{color:var(--el-color-primary)}.el-message-box__content{padding:10px var(--el-messagebox-padding-primary);color:var(--el-messagebox-content-color);font-size:var(--el-messagebox-content-font-size)}.el-message-box__container{position:relative}.el-message-box__input{padding-top:15px}.el-message-box__input div.invalid>input{border-color:var(--el-color-error)}.el-message-box__input div.invalid>input:focus{border-color:var(--el-color-error)}.el-message-box__status{position:absolute;top:50%;transform:translateY(-50%);font-size:24px!important}.el-message-box__status:before{padding-left:1px}.el-message-box__status.el-icon{position:absolute}.el-message-box__status+.el-message-box__message{padding-left:36px;padding-right:12px;word-break:break-word}.el-message-box__status.el-message-box-icon--success{--el-messagebox-color:var(--el-color-success);color:var(--el-messagebox-color)}.el-message-box__status.el-message-box-icon--info{--el-messagebox-color:var(--el-color-info);color:var(--el-messagebox-color)}.el-message-box__status.el-message-box-icon--warning{--el-messagebox-color:var(--el-color-warning);color:var(--el-messagebox-color)}.el-message-box__status.el-message-box-icon--error{--el-messagebox-color:var(--el-color-error);color:var(--el-messagebox-color)}.el-message-box__message{margin:0}.el-message-box__message p{margin:0;line-height:24px}.el-message-box__errormsg{color:var(--el-color-error);font-size:var(--el-messagebox-error-font-size);min-height:18px;margin-top:2px}.el-message-box__btns{padding:5px 15px 0;display:flex;flex-wrap:wrap;justify-content:flex-end;align-items:center}.el-message-box__btns button:nth-child(2){margin-left:10px}.el-message-box__btns-reverse{flex-direction:row-reverse}.el-message-box--center .el-message-box__title{position:relative;display:flex;align-items:center;justify-content:center}.el-message-box--center .el-message-box__status{position:relative;top:auto;padding-right:5px;text-align:center;transform:translateY(-1px)}.el-message-box--center .el-message-box__message{margin-left:0}.el-message-box--center .el-message-box__btns{justify-content:center}.el-message-box--center .el-message-box__content{padding-left:calc(var(--el-messagebox-padding-primary) + 12px);padding-right:calc(var(--el-messagebox-padding-primary) + 12px);text-align:center}.fade-in-linear-enter-active .el-overlay-message-box{-webkit-animation:msgbox-fade-in var(--el-transition-duration);animation:msgbox-fade-in var(--el-transition-duration)}.fade-in-linear-leave-active .el-overlay-message-box{animation:msgbox-fade-in var(--el-transition-duration) reverse}@-webkit-keyframes msgbox-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@keyframes msgbox-fade-in{0%{transform:translate3d(0,-20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}@-webkit-keyframes msgbox-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}@keyframes msgbox-fade-out{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(0,-20px,0);opacity:0}}.el-message{--el-message-bg-color:var(--el-color-info-light-9);--el-message-border-color:var(--el-border-color-lighter);--el-message-padding:15px 19px;--el-message-close-size:16px;--el-message-close-icon-color:var(--el-text-color-placeholder);--el-message-close-hover-color:var(--el-text-color-secondary)}.el-message{width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;max-width:calc(100% - 32px);box-sizing:border-box;border-radius:var(--el-border-radius-base);border-width:var(--el-border-width);border-style:var(--el-border-style);border-color:var(--el-message-border-color);position:fixed;left:50%;top:20px;transform:translate(-50%);background-color:var(--el-message-bg-color);transition:opacity var(--el-transition-duration),transform .4s,top .4s;padding:var(--el-message-padding);display:flex;align-items:center}.el-message.is-center{justify-content:center}.el-message.is-closable .el-message__content{padding-right:31px}.el-message p{margin:0}.el-message--success{--el-message-bg-color:var(--el-color-success-light-9);--el-message-border-color:var(--el-color-success-light-8);--el-message-text-color:var(--el-color-success)}.el-message--success .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--success{color:var(--el-message-text-color)}.el-message--info{--el-message-bg-color:var(--el-color-info-light-9);--el-message-border-color:var(--el-color-info-light-8);--el-message-text-color:var(--el-color-info)}.el-message--info .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--info{color:var(--el-message-text-color)}.el-message--warning{--el-message-bg-color:var(--el-color-warning-light-9);--el-message-border-color:var(--el-color-warning-light-8);--el-message-text-color:var(--el-color-warning)}.el-message--warning .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--warning{color:var(--el-message-text-color)}.el-message--error{--el-message-bg-color:var(--el-color-error-light-9);--el-message-border-color:var(--el-color-error-light-8);--el-message-text-color:var(--el-color-error)}.el-message--error .el-message__content{color:var(--el-message-text-color);overflow-wrap:anywhere}.el-message .el-message-icon--error{color:var(--el-message-text-color)}.el-message__icon{margin-right:10px}.el-message .el-message__badge{position:absolute;top:-8px;right:-8px}.el-message__content{padding:0;font-size:14px;line-height:1}.el-message__content:focus{outline-width:0}.el-message .el-message__closeBtn{position:absolute;top:50%;right:19px;transform:translateY(-50%);cursor:pointer;color:var(--el-message-close-icon-color);font-size:var(--el-message-close-size)}.el-message .el-message__closeBtn:focus{outline-width:0}.el-message .el-message__closeBtn:hover{color:var(--el-message-close-hover-color)}.el-message-fade-enter-from,.el-message-fade-leave-to{opacity:0;transform:translate(-50%,-100%)}.el-notification{--el-notification-width:330px;--el-notification-padding:14px 26px 14px 13px;--el-notification-radius:8px;--el-notification-shadow:var(--el-box-shadow-light);--el-notification-border-color:var(--el-border-color-lighter);--el-notification-icon-size:24px;--el-notification-close-font-size:var(--el-message-close-size, 16px);--el-notification-group-margin-left:13px;--el-notification-group-margin-right:8px;--el-notification-content-font-size:var(--el-font-size-base);--el-notification-content-color:var(--el-text-color-regular);--el-notification-title-font-size:16px;--el-notification-title-color:var(--el-text-color-primary);--el-notification-close-color:var(--el-text-color-secondary);--el-notification-close-hover-color:var(--el-text-color-regular)}.el-notification{display:flex;width:var(--el-notification-width);padding:var(--el-notification-padding);border-radius:var(--el-notification-radius);box-sizing:border-box;border:1px solid var(--el-notification-border-color);position:fixed;background-color:var(--el-bg-color-overlay);box-shadow:var(--el-notification-shadow);transition:opacity var(--el-transition-duration),transform var(--el-transition-duration),left var(--el-transition-duration),right var(--el-transition-duration),top .4s,bottom var(--el-transition-duration);overflow-wrap:anywhere;overflow:hidden;z-index:9999}.el-notification.right{right:16px}.el-notification.left{left:16px}.el-notification__group{margin-left:var(--el-notification-group-margin-left);margin-right:var(--el-notification-group-margin-right)}.el-notification__title{font-weight:700;font-size:var(--el-notification-title-font-size);line-height:var(--el-notification-icon-size);color:var(--el-notification-title-color);margin:0}.el-notification__content{font-size:var(--el-notification-content-font-size);line-height:24px;margin:6px 0 0;color:var(--el-notification-content-color);text-align:justify}.el-notification__content p{margin:0}.el-notification .el-notification__icon{height:var(--el-notification-icon-size);width:var(--el-notification-icon-size);font-size:var(--el-notification-icon-size)}.el-notification .el-notification__closeBtn{position:absolute;top:18px;right:15px;cursor:pointer;color:var(--el-notification-close-color);font-size:var(--el-notification-close-font-size)}.el-notification .el-notification__closeBtn:hover{color:var(--el-notification-close-hover-color)}.el-notification .el-notification--success{--el-notification-icon-color:var(--el-color-success);color:var(--el-notification-icon-color)}.el-notification .el-notification--info{--el-notification-icon-color:var(--el-color-info);color:var(--el-notification-icon-color)}.el-notification .el-notification--warning{--el-notification-icon-color:var(--el-color-warning);color:var(--el-notification-icon-color)}.el-notification .el-notification--error{--el-notification-icon-color:var(--el-color-error);color:var(--el-notification-icon-color)}.el-notification-fade-enter-from.right{right:0;transform:translate(100%)}.el-notification-fade-enter-from.left{left:0;transform:translate(-100%)}.el-notification-fade-leave-to{opacity:0}.el-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;height:100%;background-color:var(--el-overlay-color-lighter);overflow:auto}.el-overlay .el-overlay-root{height:0}.el-page-header.is-contentful .el-page-header__main{border-top:1px solid var(--el-border-color-light);margin-top:16px}.el-page-header__header{display:flex;align-items:center;justify-content:space-between;line-height:24px}.el-page-header__left{display:flex;align-items:center;margin-right:40px;position:relative}.el-page-header__back{display:flex;align-items:center;cursor:pointer}.el-page-header__left .el-divider--vertical{margin:0 16px}.el-page-header__icon{font-size:16px;margin-right:10px;display:flex;align-items:center}.el-page-header__icon .el-icon{font-size:inherit}.el-page-header__title{font-size:14px;font-weight:500}.el-page-header__content{font-size:18px;color:var(--el-text-color-primary)}.el-page-header__breadcrumb{margin-bottom:16px}.el-pagination{--el-pagination-font-size:14px;--el-pagination-bg-color:var(--el-fill-color-blank);--el-pagination-text-color:var(--el-text-color-primary);--el-pagination-border-radius:2px;--el-pagination-button-color:var(--el-text-color-primary);--el-pagination-button-width:32px;--el-pagination-button-height:32px;--el-pagination-button-disabled-color:var(--el-text-color-placeholder);--el-pagination-button-disabled-bg-color:var(--el-fill-color-blank);--el-pagination-button-bg-color:var(--el-fill-color);--el-pagination-hover-color:var(--el-color-primary);--el-pagination-font-size-small:12px;--el-pagination-button-width-small:24px;--el-pagination-button-height-small:24px;--el-pagination-item-gap:16px;white-space:nowrap;color:var(--el-pagination-text-color);font-size:var(--el-pagination-font-size);font-weight:400;display:flex;align-items:center}.el-pagination .el-input__inner{text-align:center;-moz-appearance:textfield}.el-pagination .el-select .el-input{width:128px}.el-pagination button{display:flex;justify-content:center;align-items:center;font-size:var(--el-pagination-font-size);min-width:var(--el-pagination-button-width);height:var(--el-pagination-button-height);line-height:var(--el-pagination-button-height);color:var(--el-pagination-button-color);background:var(--el-pagination-bg-color);padding:0 4px;border:none;border-radius:var(--el-pagination-border-radius);cursor:pointer;text-align:center;box-sizing:border-box}.el-pagination button *{pointer-events:none}.el-pagination button:focus{outline:0}.el-pagination button:hover{color:var(--el-pagination-hover-color)}.el-pagination button.is-active{color:var(--el-pagination-hover-color);cursor:default;font-weight:700}.el-pagination button.is-active.is-disabled{font-weight:700;color:var(--el-text-color-secondary)}.el-pagination button.is-disabled,.el-pagination button:disabled{color:var(--el-pagination-button-disabled-color);background-color:var(--el-pagination-button-disabled-bg-color);cursor:not-allowed}.el-pagination button:focus-visible{outline:1px solid var(--el-pagination-hover-color);outline-offset:-1px}.el-pagination .btn-next .el-icon,.el-pagination .btn-prev .el-icon{display:block;font-size:12px;font-weight:700;width:inherit}.el-pagination>.is-first{margin-left:0!important}.el-pagination>.is-last{margin-right:0!important}.el-pagination .btn-prev{margin-left:var(--el-pagination-item-gap)}.el-pagination__sizes,.el-pagination__total{margin-left:var(--el-pagination-item-gap);font-weight:400;color:var(--el-text-color-regular)}.el-pagination__total[disabled=true]{color:var(--el-text-color-placeholder)}.el-pagination__jump{display:flex;align-items:center;margin-left:var(--el-pagination-item-gap);font-weight:400;color:var(--el-text-color-regular)}.el-pagination__jump[disabled=true]{color:var(--el-text-color-placeholder)}.el-pagination__goto{margin-right:8px}.el-pagination__editor{text-align:center;box-sizing:border-box}.el-pagination__editor.el-input{width:56px}.el-pagination__editor .el-input__inner::-webkit-inner-spin-button,.el-pagination__editor .el-input__inner::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.el-pagination__classifier{margin-left:8px}.el-pagination__rightwrapper{flex:1;display:flex;align-items:center;justify-content:flex-end}.el-pagination.is-background .btn-next,.el-pagination.is-background .btn-prev,.el-pagination.is-background .el-pager li{margin:0 4px;background-color:var(--el-pagination-button-bg-color)}.el-pagination.is-background .btn-next.is-active,.el-pagination.is-background .btn-prev.is-active,.el-pagination.is-background .el-pager li.is-active{background-color:var(--el-color-primary);color:var(--el-color-white)}.el-pagination.is-background .btn-next.is-disabled,.el-pagination.is-background .btn-next:disabled,.el-pagination.is-background .btn-prev.is-disabled,.el-pagination.is-background .btn-prev:disabled,.el-pagination.is-background .el-pager li.is-disabled,.el-pagination.is-background .el-pager li:disabled{color:var(--el-text-color-placeholder);background-color:var(--el-disabled-bg-color)}.el-pagination.is-background .btn-next.is-disabled.is-active,.el-pagination.is-background .btn-next:disabled.is-active,.el-pagination.is-background .btn-prev.is-disabled.is-active,.el-pagination.is-background .btn-prev:disabled.is-active,.el-pagination.is-background .el-pager li.is-disabled.is-active,.el-pagination.is-background .el-pager li:disabled.is-active{color:var(--el-text-color-secondary);background-color:var(--el-fill-color-dark)}.el-pagination.is-background .btn-prev{margin-left:var(--el-pagination-item-gap)}.el-pagination--small .btn-next,.el-pagination--small .btn-prev,.el-pagination--small .el-pager li{height:var(--el-pagination-button-height-small);line-height:var(--el-pagination-button-height-small);font-size:var(--el-pagination-font-size-small);min-width:var(--el-pagination-button-width-small)}.el-pagination--small button,.el-pagination--small span:not([class*=suffix]){font-size:var(--el-pagination-font-size-small)}.el-pagination--small .el-select .el-input{width:100px}.el-pager{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;list-style:none;font-size:0;padding:0;margin:0;display:flex;align-items:center}.el-pager li{display:flex;justify-content:center;align-items:center;font-size:var(--el-pagination-font-size);min-width:var(--el-pagination-button-width);height:var(--el-pagination-button-height);line-height:var(--el-pagination-button-height);color:var(--el-pagination-button-color);background:var(--el-pagination-bg-color);padding:0 4px;border:none;border-radius:var(--el-pagination-border-radius);cursor:pointer;text-align:center;box-sizing:border-box}.el-pager li *{pointer-events:none}.el-pager li:focus{outline:0}.el-pager li:hover{color:var(--el-pagination-hover-color)}.el-pager li.is-active{color:var(--el-pagination-hover-color);cursor:default;font-weight:700}.el-pager li.is-active.is-disabled{font-weight:700;color:var(--el-text-color-secondary)}.el-pager li.is-disabled,.el-pager li:disabled{color:var(--el-pagination-button-disabled-color);background-color:var(--el-pagination-button-disabled-bg-color);cursor:not-allowed}.el-pager li:focus-visible{outline:1px solid var(--el-pagination-hover-color);outline-offset:-1px}.el-popconfirm__main{display:flex;align-items:center}.el-popconfirm__icon{margin-right:5px}.el-popconfirm__action{text-align:right;margin-top:8px}.el-popover{--el-popover-bg-color:var(--el-bg-color-overlay);--el-popover-font-size:var(--el-font-size-base);--el-popover-border-color:var(--el-border-color-lighter);--el-popover-padding:12px;--el-popover-padding-large:18px 20px;--el-popover-title-font-size:16px;--el-popover-title-text-color:var(--el-text-color-primary);--el-popover-border-radius:4px}.el-popover.el-popper{background:var(--el-popover-bg-color);min-width:150px;border-radius:var(--el-popover-border-radius);border:1px solid var(--el-popover-border-color);padding:var(--el-popover-padding);z-index:var(--el-index-popper);color:var(--el-text-color-regular);line-height:1.4;text-align:justify;font-size:var(--el-popover-font-size);box-shadow:var(--el-box-shadow-light);word-break:break-all;box-sizing:border-box}.el-popover.el-popper--plain{padding:var(--el-popover-padding-large)}.el-popover__title{color:var(--el-popover-title-text-color);font-size:var(--el-popover-title-font-size);line-height:1;margin-bottom:12px}.el-popover__reference:focus:hover,.el-popover__reference:focus:not(.focusing){outline-width:0}.el-popover.el-popper.is-dark{--el-popover-bg-color:var(--el-text-color-primary);--el-popover-border-color:var(--el-text-color-primary);--el-popover-title-text-color:var(--el-bg-color);color:var(--el-bg-color)}.el-popover.el-popper:focus,.el-popover.el-popper:focus:active{outline-width:0}.el-progress{position:relative;line-height:1;display:flex;align-items:center}.el-progress__text{font-size:14px;color:var(--el-text-color-regular);margin-left:5px;min-width:50px;line-height:1}.el-progress__text i{vertical-align:middle;display:block}.el-progress--circle,.el-progress--dashboard{display:inline-block}.el-progress--circle .el-progress__text,.el-progress--dashboard .el-progress__text{position:absolute;top:50%;left:0;width:100%;text-align:center;margin:0;transform:translateY(-50%)}.el-progress--circle .el-progress__text i,.el-progress--dashboard .el-progress__text i{vertical-align:middle;display:inline-block}.el-progress--without-text .el-progress__text{display:none}.el-progress--without-text .el-progress-bar{padding-right:0;margin-right:0;display:block}.el-progress--text-inside .el-progress-bar{padding-right:0;margin-right:0}.el-progress.is-success .el-progress-bar__inner{background-color:var(--el-color-success)}.el-progress.is-success .el-progress__text{color:var(--el-color-success)}.el-progress.is-warning .el-progress-bar__inner{background-color:var(--el-color-warning)}.el-progress.is-warning .el-progress__text{color:var(--el-color-warning)}.el-progress.is-exception .el-progress-bar__inner{background-color:var(--el-color-danger)}.el-progress.is-exception .el-progress__text{color:var(--el-color-danger)}.el-progress-bar{flex-grow:1;box-sizing:border-box}.el-progress-bar__outer{height:6px;border-radius:100px;background-color:var(--el-border-color-lighter);overflow:hidden;position:relative;vertical-align:middle}.el-progress-bar__inner{position:absolute;left:0;top:0;height:100%;background-color:var(--el-color-primary);text-align:right;border-radius:100px;line-height:1;white-space:nowrap;transition:width .6s ease}.el-progress-bar__inner:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-progress-bar__inner--indeterminate{transform:translateZ(0);-webkit-animation:indeterminate 3s infinite;animation:indeterminate 3s infinite}.el-progress-bar__inner--striped{background-image:linear-gradient(45deg,rgba(0,0,0,.1) 25%,transparent 25%,transparent 50%,rgba(0,0,0,.1) 50%,rgba(0,0,0,.1) 75%,transparent 75%,transparent);background-size:1.25em 1.25em}.el-progress-bar__inner--striped.el-progress-bar__inner--striped-flow{-webkit-animation:striped-flow 3s linear infinite;animation:striped-flow 3s linear infinite}.el-progress-bar__innerText{display:inline-block;vertical-align:middle;color:#fff;font-size:12px;margin:0 5px}@-webkit-keyframes progress{0%{background-position:0 0}to{background-position:32px 0}}@keyframes progress{0%{background-position:0 0}to{background-position:32px 0}}@-webkit-keyframes indeterminate{0%{left:-100%}to{left:100%}}@keyframes indeterminate{0%{left:-100%}to{left:100%}}@-webkit-keyframes striped-flow{0%{background-position:-100%}to{background-position:100%}}@keyframes striped-flow{0%{background-position:-100%}to{background-position:100%}}.el-radio-button{--el-radio-button-checked-bg-color:var(--el-color-primary);--el-radio-button-checked-text-color:var(--el-color-white);--el-radio-button-checked-border-color:var(--el-color-primary);--el-radio-button-disabled-checked-fill:var(--el-border-color-extra-light)}.el-radio-button{position:relative;display:inline-block;outline:0}.el-radio-button__inner{display:inline-block;line-height:1;white-space:nowrap;vertical-align:middle;background:var(--el-button-bg-color,var(--el-fill-color-blank));border:var(--el-border);font-weight:var(--el-button-font-weight,var(--el-font-weight-primary));border-left:0;color:var(--el-button-text-color,var(--el-text-color-regular));-webkit-appearance:none;text-align:center;box-sizing:border-box;outline:0;margin:0;position:relative;cursor:pointer;transition:var(--el-transition-all);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;padding:8px 15px;font-size:var(--el-font-size-base);border-radius:0}.el-radio-button__inner.is-round{padding:8px 15px}.el-radio-button__inner:hover{color:var(--el-color-primary)}.el-radio-button__inner [class*=el-icon-]{line-height:.9}.el-radio-button__inner [class*=el-icon-]+span{margin-left:5px}.el-radio-button:first-child .el-radio-button__inner{border-left:var(--el-border);border-radius:var(--el-border-radius-base) 0 0 var(--el-border-radius-base);box-shadow:none!important}.el-radio-button__original-radio{opacity:0;outline:0;position:absolute;z-index:-1}.el-radio-button__original-radio:checked+.el-radio-button__inner{color:var(--el-radio-button-checked-text-color,var(--el-color-white));background-color:var(--el-radio-button-checked-bg-color,var(--el-color-primary));border-color:var(--el-radio-button-checked-border-color,var(--el-color-primary));box-shadow:-1px 0 0 0 var(--el-radio-button-checked-border-color,var(--el-color-primary))}.el-radio-button__original-radio:focus-visible+.el-radio-button__inner{border-left:var(--el-border);border-left-color:var(--el-radio-button-checked-border-color,var(--el-color-primary));outline:2px solid var(--el-radio-button-checked-border-color);outline-offset:1px;z-index:2;border-radius:var(--el-border-radius-base);box-shadow:none}.el-radio-button__original-radio:disabled+.el-radio-button__inner{color:var(--el-disabled-text-color);cursor:not-allowed;background-image:none;background-color:var(--el-button-disabled-bg-color,var(--el-fill-color-blank));border-color:var(--el-button-disabled-border-color,var(--el-border-color-light));box-shadow:none}.el-radio-button__original-radio:disabled:checked+.el-radio-button__inner{background-color:var(--el-radio-button-disabled-checked-fill)}.el-radio-button:last-child .el-radio-button__inner{border-radius:0 var(--el-border-radius-base) var(--el-border-radius-base) 0}.el-radio-button:first-child:last-child .el-radio-button__inner{border-radius:var(--el-border-radius-base)}.el-radio-button--large .el-radio-button__inner{padding:12px 19px;font-size:var(--el-font-size-base);border-radius:0}.el-radio-button--large .el-radio-button__inner.is-round{padding:12px 19px}.el-radio-button--small .el-radio-button__inner{padding:5px 11px;font-size:12px;border-radius:0}.el-radio-button--small .el-radio-button__inner.is-round{padding:5px 11px}.el-radio-group{display:inline-flex;align-items:center;flex-wrap:wrap;font-size:0}.el-radio{--el-radio-font-size:var(--el-font-size-base);--el-radio-text-color:var(--el-text-color-regular);--el-radio-font-weight:var(--el-font-weight-primary);--el-radio-input-height:14px;--el-radio-input-width:14px;--el-radio-input-border-radius:var(--el-border-radius-circle);--el-radio-input-bg-color:var(--el-fill-color-blank);--el-radio-input-border:var(--el-border);--el-radio-input-border-color:var(--el-border-color);--el-radio-input-border-color-hover:var(--el-color-primary)}.el-radio{color:var(--el-radio-text-color);font-weight:var(--el-radio-font-weight);position:relative;cursor:pointer;display:inline-flex;align-items:center;white-space:nowrap;outline:0;font-size:var(--el-font-size-base);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;margin-right:32px;height:32px}.el-radio.el-radio--large{height:40px}.el-radio.el-radio--small{height:24px}.el-radio.is-bordered{padding:0 15px 0 9px;border-radius:var(--el-border-radius-base);border:var(--el-border);box-sizing:border-box}.el-radio.is-bordered.is-checked{border-color:var(--el-color-primary)}.el-radio.is-bordered.is-disabled{cursor:not-allowed;border-color:var(--el-border-color-lighter)}.el-radio.is-bordered.el-radio--large{padding:0 19px 0 11px;border-radius:var(--el-border-radius-base)}.el-radio.is-bordered.el-radio--large .el-radio__label{font-size:var(--el-font-size-base)}.el-radio.is-bordered.el-radio--large .el-radio__inner{height:14px;width:14px}.el-radio.is-bordered.el-radio--small{padding:0 11px 0 7px;border-radius:var(--el-border-radius-base)}.el-radio.is-bordered.el-radio--small .el-radio__label{font-size:12px}.el-radio.is-bordered.el-radio--small .el-radio__inner{height:12px;width:12px}.el-radio:last-child{margin-right:0}.el-radio__input{white-space:nowrap;cursor:pointer;outline:0;display:inline-flex;position:relative;vertical-align:middle}.el-radio__input.is-disabled .el-radio__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color);cursor:not-allowed}.el-radio__input.is-disabled .el-radio__inner:after{cursor:not-allowed;background-color:var(--el-disabled-bg-color)}.el-radio__input.is-disabled .el-radio__inner+.el-radio__label{cursor:not-allowed}.el-radio__input.is-disabled.is-checked .el-radio__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color)}.el-radio__input.is-disabled.is-checked .el-radio__inner:after{background-color:var(--el-text-color-placeholder)}.el-radio__input.is-disabled+span.el-radio__label{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-radio__input.is-checked .el-radio__inner{border-color:var(--el-color-primary);background:var(--el-color-primary)}.el-radio__input.is-checked .el-radio__inner:after{transform:translate(-50%,-50%) scale(1)}.el-radio__input.is-checked+.el-radio__label{color:var(--el-color-primary)}.el-radio__input.is-focus .el-radio__inner{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner{border:var(--el-radio-input-border);border-radius:var(--el-radio-input-border-radius);width:var(--el-radio-input-width);height:var(--el-radio-input-height);background-color:var(--el-radio-input-bg-color);position:relative;cursor:pointer;display:inline-block;box-sizing:border-box}.el-radio__inner:hover{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner:after{width:4px;height:4px;border-radius:var(--el-radio-input-border-radius);background-color:var(--el-color-white);content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(0);transition:transform .15s ease-in}.el-radio__original{opacity:0;outline:0;position:absolute;z-index:-1;top:0;left:0;right:0;bottom:0;margin:0}.el-radio__original:focus-visible+.el-radio__inner{outline:2px solid var(--el-radio-input-border-color-hover);outline-offset:1px;border-radius:var(--el-radio-input-border-radius)}.el-radio:focus:not(:focus-visible):not(.is-focus):not(:active):not(.is-disabled) .el-radio__inner{box-shadow:0 0 2px 2px var(--el-radio-input-border-color-hover)}.el-radio__label{font-size:var(--el-radio-font-size);padding-left:8px}.el-radio.el-radio--large .el-radio__label{font-size:14px}.el-radio.el-radio--large .el-radio__inner{width:14px;height:14px}.el-radio.el-radio--small .el-radio__label{font-size:12px}.el-radio.el-radio--small .el-radio__inner{width:12px;height:12px}.el-rate{--el-rate-height:20px;--el-rate-font-size:var(--el-font-size-base);--el-rate-icon-size:18px;--el-rate-icon-margin:6px;--el-rate-void-color:var(--el-border-color-darker);--el-rate-fill-color:#f7ba2a;--el-rate-disabled-void-color:var(--el-fill-color);--el-rate-text-color:var(--el-text-color-primary)}.el-rate{display:inline-flex;align-items:center;height:32px}.el-rate:active,.el-rate:focus{outline:0}.el-rate__item{cursor:pointer;display:inline-block;position:relative;font-size:0;vertical-align:middle;color:var(--el-rate-void-color);line-height:normal}.el-rate .el-rate__icon{position:relative;display:inline-block;font-size:var(--el-rate-icon-size);margin-right:var(--el-rate-icon-margin);transition:var(--el-transition-duration)}.el-rate .el-rate__icon.hover{transform:scale(1.15)}.el-rate .el-rate__icon .path2{position:absolute;left:0;top:0}.el-rate .el-rate__icon.is-active{color:var(--el-rate-fill-color)}.el-rate__decimal{position:absolute;top:0;left:0;display:inline-block;overflow:hidden;color:var(--el-rate-fill-color)}.el-rate__text{font-size:var(--el-rate-font-size);vertical-align:middle;color:var(--el-rate-text-color)}.el-rate--large{height:40px}.el-rate--small{height:24px}.el-rate--small .el-rate__icon{font-size:14px}.el-rate.is-disabled .el-rate__item{cursor:auto;color:var(--el-rate-disabled-void-color)}.el-result{--el-result-padding:40px 30px;--el-result-icon-font-size:64px;--el-result-title-font-size:20px;--el-result-title-margin-top:20px;--el-result-subtitle-margin-top:10px;--el-result-extra-margin-top:30px}.el-result{display:flex;justify-content:center;align-items:center;flex-direction:column;text-align:center;box-sizing:border-box;padding:var(--el-result-padding)}.el-result__icon svg{width:var(--el-result-icon-font-size);height:var(--el-result-icon-font-size)}.el-result__title{margin-top:var(--el-result-title-margin-top)}.el-result__title p{margin:0;font-size:var(--el-result-title-font-size);color:var(--el-text-color-primary);line-height:1.3}.el-result__subtitle{margin-top:var(--el-result-subtitle-margin-top)}.el-result__subtitle p{margin:0;font-size:var(--el-font-size-base);color:var(--el-text-color-regular);line-height:1.3}.el-result__extra{margin-top:var(--el-result-extra-margin-top)}.el-result .icon-primary{--el-result-color:var(--el-color-primary);color:var(--el-result-color)}.el-result .icon-success{--el-result-color:var(--el-color-success);color:var(--el-result-color)}.el-result .icon-warning{--el-result-color:var(--el-color-warning);color:var(--el-result-color)}.el-result .icon-danger{--el-result-color:var(--el-color-danger);color:var(--el-result-color)}.el-result .icon-error{--el-result-color:var(--el-color-error);color:var(--el-result-color)}.el-result .icon-info{--el-result-color:var(--el-color-info);color:var(--el-result-color)}.el-row{display:flex;flex-wrap:wrap;position:relative;box-sizing:border-box}.el-row.is-justify-center{justify-content:center}.el-row.is-justify-end{justify-content:flex-end}.el-row.is-justify-space-between{justify-content:space-between}.el-row.is-justify-space-around{justify-content:space-around}.el-row.is-justify-space-evenly{justify-content:space-evenly}.el-row.is-align-middle{align-items:center}.el-row.is-align-bottom{align-items:flex-end}.el-scrollbar{--el-scrollbar-opacity:.3;--el-scrollbar-bg-color:var(--el-text-color-secondary);--el-scrollbar-hover-opacity:.5;--el-scrollbar-hover-bg-color:var(--el-text-color-secondary)}.el-scrollbar{overflow:hidden;position:relative;height:100%}.el-scrollbar__wrap{overflow:auto;height:100%}.el-scrollbar__wrap--hidden-default{scrollbar-width:none}.el-scrollbar__wrap--hidden-default::-webkit-scrollbar{display:none}.el-scrollbar__thumb{position:relative;display:block;width:0;height:0;cursor:pointer;border-radius:inherit;background-color:var(--el-scrollbar-bg-color,var(--el-text-color-secondary));transition:var(--el-transition-duration) background-color;opacity:var(--el-scrollbar-opacity,.3)}.el-scrollbar__thumb:hover{background-color:var(--el-scrollbar-hover-bg-color,var(--el-text-color-secondary));opacity:var(--el-scrollbar-hover-opacity,.5)}.el-scrollbar__bar{position:absolute;right:2px;bottom:2px;z-index:1;border-radius:4px}.el-scrollbar__bar.is-vertical{width:6px;top:2px}.el-scrollbar__bar.is-vertical>div{width:100%}.el-scrollbar__bar.is-horizontal{height:6px;left:2px}.el-scrollbar__bar.is-horizontal>div{height:100%}.el-scrollbar-fade-enter-active{transition:opacity .34s ease-out}.el-scrollbar-fade-leave-active{transition:opacity .12s ease-out}.el-scrollbar-fade-enter-from,.el-scrollbar-fade-leave-active{opacity:0}.el-select-dropdown{z-index:calc(var(--el-index-top) + 1);border-radius:var(--el-border-radius-base);box-sizing:border-box}.el-select-dropdown .el-scrollbar.is-empty .el-select-dropdown__list{padding:0}.el-select-dropdown__option-item.is-selected:not(.is-multiple).is-disabled{color:var(--el-text-color-disabled)}.el-select-dropdown__option-item.is-selected:not(.is-multiple).is-disabled:after{background-color:var(--el-text-color-disabled)}.el-select-dropdown__option-item:hover:not(.hover){background-color:transparent}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-disabled.is-selected{color:var(--el-text-color-disabled)}.el-select-dropdown__empty{padding:10px 0;margin:0;text-align:center;color:var(--el-text-color-secondary);font-size:var(--el-select-font-size)}.el-select-dropdown__wrap{max-height:274px}.el-select-dropdown__list{list-style:none;margin:6px 0!important;padding:0!important;box-sizing:border-box}.el-select-dropdown__option-item{font-size:var(--el-select-font-size);padding:0 32px 0 20px;position:relative;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--el-text-color-regular);height:34px;line-height:34px;box-sizing:border-box;cursor:pointer}.el-select-dropdown__option-item.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-select-dropdown__option-item.is-disabled:hover{background-color:var(--el-bg-color)}.el-select-dropdown__option-item.is-selected{background-color:var(--el-fill-color-light);font-weight:700}.el-select-dropdown__option-item.is-selected:not(.is-multiple){color:var(--el-color-primary)}.el-select-dropdown__option-item.hover{background-color:var(--el-fill-color-light)!important}.el-select-dropdown__option-item:hover{background-color:var(--el-fill-color-light)}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-selected{color:var(--el-color-primary);background-color:var(--el-bg-color-overlay)}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-selected .el-icon{position:absolute;right:20px;top:0;height:inherit;font-size:12px}.el-select-dropdown.is-multiple .el-select-dropdown__option-item.is-selected .el-icon svg{height:inherit;vertical-align:middle}.el-select-group{margin:0;padding:0}.el-select-group__wrap{position:relative;list-style:none;margin:0;padding:0}.el-select-group__wrap:not(:last-of-type){padding-bottom:24px}.el-select-group__wrap:not(:last-of-type):after{content:"";position:absolute;display:block;left:20px;right:20px;bottom:12px;height:1px;background:var(--el-border-color-light)}.el-select-group__split-dash{position:absolute;left:20px;right:20px;height:1px;background:var(--el-border-color-light)}.el-select-group__title{padding-left:20px;font-size:12px;color:var(--el-color-info);line-height:30px}.el-select-group .el-select-dropdown__item{padding-left:20px}.el-select-v2{--el-select-border-color-hover:var(--el-border-color-hover);--el-select-disabled-border:var(--el-disabled-border-color);--el-select-font-size:var(--el-font-size-base);--el-select-close-hover-color:var(--el-text-color-secondary);--el-select-input-color:var(--el-text-color-placeholder);--el-select-multiple-input-color:var(--el-text-color-regular);--el-select-input-focus-border-color:var(--el-color-primary);--el-select-input-font-size:14px}.el-select-v2{display:inline-block;position:relative;vertical-align:middle;font-size:14px}.el-select-v2__wrapper{display:flex;align-items:center;flex-wrap:wrap;position:relative;box-sizing:border-box;cursor:pointer;padding:1px 30px 1px 0;border:1px solid var(--el-border-color);border-radius:var(--el-border-radius-base);background-color:var(--el-fill-color-blank);transition:var(--el-transition-duration)}.el-select-v2__wrapper:hover{border-color:var(--el-text-color-placeholder)}.el-select-v2__wrapper.is-filterable{cursor:text}.el-select-v2__wrapper.is-focused{border-color:var(--el-color-primary)}.el-select-v2__wrapper.is-hovering:not(.is-focused){border-color:var(--el-border-color-hover)}.el-select-v2__wrapper.is-disabled{cursor:not-allowed;background-color:var(--el-fill-color-light);color:var(--el-text-color-placeholder);border-color:var(--el-select-disabled-border)}.el-select-v2__wrapper.is-disabled:hover{border-color:var(--el-select-disabled-border)}.el-select-v2__wrapper.is-disabled.is-focus{border-color:var(--el-input-focus-border-color)}.el-select-v2__wrapper.is-disabled .is-transparent{opacity:1;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-select-v2__wrapper.is-disabled .el-select-v2__caret,.el-select-v2__wrapper.is-disabled .el-select-v2__combobox-input{cursor:not-allowed}.el-select-v2__wrapper .el-select-v2__input-wrapper{box-sizing:border-box;position:relative;-webkit-margin-start:12px;margin-inline-start:12px;max-width:100%;overflow:hidden}.el-select-v2__wrapper,.el-select-v2__wrapper .el-select-v2__input-wrapper{line-height:32px}.el-select-v2__wrapper .el-select-v2__input-wrapper input{--el-input-inner-height:calc(var(--el-component-size, 32px) - 8px);height:var(--el-input-inner-height);line-height:var(--el-input-inner-height);min-width:4px;width:100%;background-color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:0 0;border:none;margin:2px 0;outline:0;padding:0}.el-select-v2 .el-select-v2__tags-text{display:inline-block;line-height:normal;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-select-v2__empty{padding:10px 0;margin:0;text-align:center;color:var(--el-text-color-secondary);font-size:14px}.el-select-v2__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-box-shadow-light)}.el-select-v2__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-select-v2__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-select-v2__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-select-v2__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-select-v2__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-select-v2--large .el-select-v2__wrapper .el-select-v2__combobox-input{height:32px}.el-select-v2--large .el-select-v2__caret,.el-select-v2--large .el-select-v2__suffix{height:40px}.el-select-v2--large .el-select-v2__placeholder{font-size:14px;line-height:40px}.el-select-v2--small .el-select-v2__wrapper .el-select-v2__combobox-input{height:16px}.el-select-v2--small .el-select-v2__caret,.el-select-v2--small .el-select-v2__suffix{height:24px}.el-select-v2--small .el-select-v2__placeholder{font-size:12px;line-height:24px}.el-select-v2 .el-select-v2__selection>span{display:inline-block}.el-select-v2:hover .el-select-v2__combobox-input{border-color:var(--el-select-border-color-hover)}.el-select-v2 .el-select__selection-text{text-overflow:ellipsis;display:inline-block;overflow-x:hidden;vertical-align:bottom}.el-select-v2 .el-select-v2__combobox-input{padding-right:35px;display:block;color:var(--el-text-color-regular)}.el-select-v2 .el-select-v2__combobox-input:focus{border-color:var(--el-select-input-focus-border-color)}.el-select-v2__input{border:none;outline:0;padding:0;margin-left:15px;color:var(--el-select-multiple-input-color);font-size:var(--el-select-font-size);-webkit-appearance:none;-moz-appearance:none;appearance:none;height:28px}.el-select-v2__input.is-small{height:14px}.el-select-v2__close{cursor:pointer;position:absolute;top:8px;z-index:var(--el-index-top);right:25px;color:var(--el-select-input-color);line-height:18px;font-size:var(--el-select-input-font-size)}.el-select-v2__close:hover{color:var(--el-select-close-hover-color)}.el-select-v2__suffix{display:inline-flex;position:absolute;right:12px;height:32px;top:50%;transform:translateY(-50%);color:var(--el-input-icon-color,var(--el-text-color-placeholder))}.el-select-v2__suffix .el-input__icon{height:inherit}.el-select-v2__suffix .el-input__icon:not(:first-child){margin-left:8px}.el-select-v2__caret{color:var(--el-select-input-color);font-size:var(--el-select-input-font-size);transition:var(--el-transition-duration);transform:rotate(180deg);cursor:pointer}.el-select-v2__caret.is-reverse{transform:rotate(0)}.el-select-v2__caret.is-show-close{font-size:var(--el-select-font-size);text-align:center;transform:rotate(180deg);border-radius:var(--el-border-radius-circle);color:var(--el-select-input-color);transition:var(--el-transition-color)}.el-select-v2__caret.is-show-close:hover{color:var(--el-select-close-hover-color)}.el-select-v2__caret.el-icon{height:inherit}.el-select-v2__caret.el-icon svg{vertical-align:middle}.el-select-v2__selection{white-space:normal;z-index:var(--el-index-normal);display:flex;align-items:center;flex-wrap:wrap;width:100%}.el-select-v2__input-calculator{left:0;position:absolute;top:0;visibility:hidden;white-space:pre;z-index:999}.el-select-v2__selected-item{line-height:inherit;height:inherit;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;display:flex;flex-wrap:wrap}.el-select-v2__placeholder{position:absolute;top:50%;transform:translateY(-50%);-webkit-margin-start:12px;margin-inline-start:12px;width:calc(100% - 52px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--el-input-text-color,var(--el-text-color-regular))}.el-select-v2__placeholder.is-transparent{color:var(--el-text-color-placeholder)}.el-select-v2 .el-select-v2__selection .el-tag{box-sizing:border-box;border-color:transparent;margin:2px 0 2px 6px;background-color:var(--el-fill-color)}.el-select-v2 .el-select-v2__selection .el-tag .el-icon-close{background-color:var(--el-text-color-placeholder);right:-7px;color:var(--el-color-white)}.el-select-v2 .el-select-v2__selection .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-select-v2 .el-select-v2__selection .el-tag .el-icon-close:before{display:block;transform:translateY(.5px)}.el-select-v2.el-select-v2--small .el-select-v2__selection .el-tag{margin:1px 0 1px 6px;height:18px}.el-select-dropdown{z-index:calc(var(--el-index-top) + 1);border-radius:var(--el-border-radius-base);box-sizing:border-box}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected{color:var(--el-color-primary);background-color:var(--el-bg-color-overlay)}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected.hover{background-color:var(--el-fill-color-light)}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected:after{content:"";position:absolute;top:50%;right:20px;border-top:none;border-right:none;background-repeat:no-repeat;background-position:center;background-color:var(--el-color-primary);-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask-size:100% 100%;-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;-webkit-mask-size:100% 100%;transform:translateY(-50%);width:12px;height:12px}.el-select-dropdown.is-multiple .el-select-dropdown__item.selected.is-disabled:after{background-color:var(--el-text-color-disabled)}.el-select-dropdown .el-select-dropdown__option-item.is-selected:after{content:"";position:absolute;top:50%;right:20px;border-top:none;border-right:none;background-repeat:no-repeat;background-position:center;background-color:var(--el-color-primary);-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;mask-size:100% 100%;-webkit-mask:url("data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E") no-repeat;-webkit-mask-size:100% 100%;transform:translateY(-50%);width:12px;height:12px}.el-select-dropdown .el-scrollbar.is-empty .el-select-dropdown__list{padding:0}.el-select-dropdown .el-select-dropdown__item.is-disabled:hover{background-color:unset}.el-select-dropdown .el-select-dropdown__item.is-disabled.selected{color:var(--el-text-color-disabled)}.el-select-dropdown__empty{padding:10px 0;margin:0;text-align:center;color:var(--el-text-color-secondary);font-size:var(--el-select-font-size)}.el-select-dropdown__wrap{max-height:274px}.el-select-dropdown__list{list-style:none;padding:6px 0;margin:0;box-sizing:border-box}.el-select{--el-select-border-color-hover:var(--el-border-color-hover);--el-select-disabled-border:var(--el-disabled-border-color);--el-select-font-size:var(--el-font-size-base);--el-select-close-hover-color:var(--el-text-color-secondary);--el-select-input-color:var(--el-text-color-placeholder);--el-select-multiple-input-color:var(--el-text-color-regular);--el-select-input-focus-border-color:var(--el-color-primary);--el-select-input-font-size:14px}.el-select{display:inline-block;position:relative;vertical-align:middle;line-height:32px}.el-select__popper.el-popper{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light);box-shadow:var(--el-box-shadow-light)}.el-select__popper.el-popper .el-popper__arrow:before{border:1px solid var(--el-border-color-light)}.el-select__popper.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent;border-left-color:transparent}.el-select__popper.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent;border-right-color:transparent}.el-select__popper.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent;border-bottom-color:transparent}.el-select__popper.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent;border-top-color:transparent}.el-select .el-select-tags-wrapper.has-prefix{margin-left:6px}.el-select--large{line-height:40px}.el-select--large .el-select-tags-wrapper.has-prefix{margin-left:8px}.el-select--small{line-height:24px}.el-select--small .el-select-tags-wrapper.has-prefix{margin-left:4px}.el-select .el-select__tags>span{display:inline-block}.el-select:hover:not(.el-select--disabled) .el-input__wrapper{box-shadow:0 0 0 1px var(--el-select-border-color-hover) inset}.el-select .el-select__tags-text{display:inline-block;line-height:normal;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-select .el-input__wrapper{cursor:pointer}.el-select .el-input__wrapper.is-focus{box-shadow:0 0 0 1px var(--el-select-input-focus-border-color) inset!important}.el-select .el-input__inner{cursor:pointer}.el-select .el-input{display:flex}.el-select .el-input .el-select__caret{color:var(--el-select-input-color);font-size:var(--el-select-input-font-size);transition:transform var(--el-transition-duration);transform:rotate(0);cursor:pointer}.el-select .el-input .el-select__caret.is-reverse{transform:rotate(-180deg)}.el-select .el-input .el-select__caret.is-show-close{font-size:var(--el-select-font-size);text-align:center;transform:rotate(0);border-radius:var(--el-border-radius-circle);color:var(--el-select-input-color);transition:var(--el-transition-color)}.el-select .el-input .el-select__caret.is-show-close:hover{color:var(--el-select-close-hover-color)}.el-select .el-input .el-select__caret.el-icon{position:relative;height:inherit;z-index:2}.el-select .el-input.is-disabled .el-input__wrapper{cursor:not-allowed}.el-select .el-input.is-disabled .el-input__wrapper:hover{box-shadow:0 0 0 1px var(--el-select-disabled-border) inset}.el-select .el-input.is-disabled .el-input__inner,.el-select .el-input.is-disabled .el-select__caret{cursor:not-allowed}.el-select .el-input.is-focus .el-input__wrapper{box-shadow:0 0 0 1px var(--el-select-input-focus-border-color) inset!important}.el-select__input{border:none;outline:0;padding:0;margin-left:15px;color:var(--el-select-multiple-input-color);font-size:var(--el-select-font-size);-webkit-appearance:none;-moz-appearance:none;appearance:none;height:28px;background-color:transparent}.el-select__input.is-disabled{cursor:not-allowed}.el-select__input--iOS{position:absolute;left:0;top:0;z-index:6}.el-select__input.is-small{height:14px}.el-select__close{cursor:pointer;position:absolute;top:8px;z-index:var(--el-index-top);right:25px;color:var(--el-select-input-color);line-height:18px;font-size:var(--el-select-input-font-size)}.el-select__close:hover{color:var(--el-select-close-hover-color)}.el-select__tags{position:absolute;line-height:normal;top:50%;transform:translateY(-50%);white-space:normal;z-index:var(--el-index-normal);display:flex;align-items:center;flex-wrap:wrap;cursor:pointer}.el-select__tags .el-tag{box-sizing:border-box;border-color:transparent;margin:2px 6px 2px 0}.el-select__tags .el-tag:last-child{margin-right:0}.el-select__tags .el-tag .el-icon-close{background-color:var(--el-text-color-placeholder);right:-7px;top:0;color:#fff}.el-select__tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-select__tags .el-tag .el-icon-close:before{display:block;transform:translateY(.5px)}.el-select__tags .el-tag--info{background-color:var(--el-fill-color)}.el-select__tags.is-disabled{cursor:not-allowed}.el-select__collapse-tags{white-space:normal;z-index:var(--el-index-normal);display:flex;align-items:center;flex-wrap:wrap;cursor:pointer}.el-select__collapse-tags .el-tag{box-sizing:border-box;border-color:transparent;margin:2px 6px 2px 0}.el-select__collapse-tags .el-tag:last-child{margin-right:0}.el-select__collapse-tags .el-tag .el-icon-close{background-color:var(--el-text-color-placeholder);right:-7px;top:0;color:#fff}.el-select__collapse-tags .el-tag .el-icon-close:hover{background-color:var(--el-text-color-secondary)}.el-select__collapse-tags .el-tag .el-icon-close:before{display:block;transform:translateY(.5px)}.el-select__collapse-tags .el-tag--info{background-color:var(--el-fill-color)}.el-select__collapse-tag{line-height:inherit;height:inherit;display:flex}.el-skeleton{--el-skeleton-circle-size:var(--el-avatar-size)}.el-skeleton__item{background:var(--el-skeleton-color);display:inline-block;height:16px;border-radius:var(--el-border-radius-base);width:100%}.el-skeleton__circle{border-radius:50%;width:var(--el-skeleton-circle-size);height:var(--el-skeleton-circle-size);line-height:var(--el-skeleton-circle-size)}.el-skeleton__button{height:40px;width:64px;border-radius:4px}.el-skeleton__p{width:100%}.el-skeleton__p.is-last{width:61%}.el-skeleton__p.is-first{width:33%}.el-skeleton__text{width:100%;height:var(--el-font-size-small)}.el-skeleton__caption{height:var(--el-font-size-extra-small)}.el-skeleton__h1{height:var(--el-font-size-extra-large)}.el-skeleton__h3{height:var(--el-font-size-large)}.el-skeleton__h5{height:var(--el-font-size-medium)}.el-skeleton__image{width:unset;display:flex;align-items:center;justify-content:center;border-radius:0}.el-skeleton__image svg{color:var(--el-svg-monochrome-grey);fill:currentColor;width:22%;height:22%}.el-skeleton{--el-skeleton-color:var(--el-fill-color);--el-skeleton-to-color:var(--el-fill-color-darker)}@-webkit-keyframes el-skeleton-loading{0%{background-position:100% 50%}to{background-position:0 50%}}@keyframes el-skeleton-loading{0%{background-position:100% 50%}to{background-position:0 50%}}.el-skeleton{width:100%}.el-skeleton__first-line,.el-skeleton__paragraph{height:16px;margin-top:16px;background:var(--el-skeleton-color)}.el-skeleton.is-animated .el-skeleton__item{background:linear-gradient(90deg,var(--el-skeleton-color) 25%,var(--el-skeleton-to-color) 37%,var(--el-skeleton-color) 63%);background-size:400% 100%;-webkit-animation:el-skeleton-loading 1.4s ease infinite;animation:el-skeleton-loading 1.4s ease infinite}.el-slider{--el-slider-main-bg-color:var(--el-color-primary);--el-slider-runway-bg-color:var(--el-border-color-light);--el-slider-stop-bg-color:var(--el-color-white);--el-slider-disabled-color:var(--el-text-color-placeholder);--el-slider-border-radius:3px;--el-slider-height:6px;--el-slider-button-size:20px;--el-slider-button-wrapper-size:36px;--el-slider-button-wrapper-offset:-15px}.el-slider{width:100%;height:32px;display:flex;align-items:center}.el-slider__runway{flex:1;height:var(--el-slider-height);background-color:var(--el-slider-runway-bg-color);border-radius:var(--el-slider-border-radius);position:relative;cursor:pointer}.el-slider__runway.show-input{margin-right:30px;width:auto}.el-slider__runway.is-disabled{cursor:default}.el-slider__runway.is-disabled .el-slider__bar{background-color:var(--el-slider-disabled-color)}.el-slider__runway.is-disabled .el-slider__button{border-color:var(--el-slider-disabled-color)}.el-slider__runway.is-disabled .el-slider__button-wrapper.hover,.el-slider__runway.is-disabled .el-slider__button-wrapper:hover,.el-slider__runway.is-disabled .el-slider__button-wrapper.dragging{cursor:not-allowed}.el-slider__runway.is-disabled .el-slider__button.dragging,.el-slider__runway.is-disabled .el-slider__button.hover,.el-slider__runway.is-disabled .el-slider__button:hover{transform:scale(1)}.el-slider__runway.is-disabled .el-slider__button.hover,.el-slider__runway.is-disabled .el-slider__button:hover,.el-slider__runway.is-disabled .el-slider__button.dragging{cursor:not-allowed}.el-slider__input{flex-shrink:0;width:130px}.el-slider__bar{height:var(--el-slider-height);background-color:var(--el-slider-main-bg-color);border-top-left-radius:var(--el-slider-border-radius);border-bottom-left-radius:var(--el-slider-border-radius);position:absolute}.el-slider__button-wrapper{height:var(--el-slider-button-wrapper-size);width:var(--el-slider-button-wrapper-size);position:absolute;z-index:1;top:var(--el-slider-button-wrapper-offset);transform:translate(-50%);background-color:transparent;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;line-height:normal;outline:0}.el-slider__button-wrapper:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-slider__button-wrapper.hover,.el-slider__button-wrapper:hover{cursor:-webkit-grab;cursor:grab}.el-slider__button-wrapper.dragging{cursor:-webkit-grabbing;cursor:grabbing}.el-slider__button{display:inline-block;width:var(--el-slider-button-size);height:var(--el-slider-button-size);vertical-align:middle;border:solid 2px var(--el-slider-main-bg-color);background-color:var(--el-color-white);border-radius:50%;box-sizing:border-box;transition:var(--el-transition-duration-fast);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-slider__button.dragging,.el-slider__button.hover,.el-slider__button:hover{transform:scale(1.2)}.el-slider__button.hover,.el-slider__button:hover{cursor:-webkit-grab;cursor:grab}.el-slider__button.dragging{cursor:-webkit-grabbing;cursor:grabbing}.el-slider__stop{position:absolute;height:var(--el-slider-height);width:var(--el-slider-height);border-radius:var(--el-border-radius-circle);background-color:var(--el-slider-stop-bg-color);transform:translate(-50%)}.el-slider__marks{top:0;left:12px;width:18px;height:100%}.el-slider__marks-text{position:absolute;transform:translate(-50%);font-size:14px;color:var(--el-color-info);margin-top:15px;white-space:pre}.el-slider.is-vertical{position:relative;display:inline-flex;width:auto;height:100%;flex:0}.el-slider.is-vertical .el-slider__runway{width:var(--el-slider-height);height:100%;margin:0 16px}.el-slider.is-vertical .el-slider__bar{width:var(--el-slider-height);height:auto;border-radius:0 0 3px 3px}.el-slider.is-vertical .el-slider__button-wrapper{top:auto;left:var(--el-slider-button-wrapper-offset);transform:translateY(50%)}.el-slider.is-vertical .el-slider__stop{transform:translateY(50%)}.el-slider.is-vertical .el-slider__marks-text{margin-top:0;left:15px;transform:translateY(50%)}.el-slider--large{height:40px}.el-slider--small{height:24px}.el-space{display:inline-flex;vertical-align:top}.el-space__item{display:flex;flex-wrap:wrap}.el-space__item>*{flex:1}.el-space--vertical{flex-direction:column}.el-time-spinner{width:100%;white-space:nowrap}.el-spinner{display:inline-block;vertical-align:middle}.el-spinner-inner{-webkit-animation:rotate 2s linear infinite;animation:rotate 2s linear infinite;width:50px;height:50px}.el-spinner-inner .path{stroke:var(--el-border-color-lighter);stroke-linecap:round;-webkit-animation:dash 1.5s ease-in-out infinite;animation:dash 1.5s ease-in-out infinite}@-webkit-keyframes rotate{to{transform:rotate(360deg)}}@keyframes rotate{to{transform:rotate(360deg)}}@-webkit-keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}@keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.el-step{position:relative;flex-shrink:1}.el-step:last-of-type .el-step__line{display:none}.el-step:last-of-type.is-flex{flex-basis:auto!important;flex-shrink:0;flex-grow:0}.el-step:last-of-type .el-step__description,.el-step:last-of-type .el-step__main{padding-right:0}.el-step__head{position:relative;width:100%}.el-step__head.is-process{color:var(--el-text-color-primary);border-color:var(--el-text-color-primary)}.el-step__head.is-wait{color:var(--el-text-color-placeholder);border-color:var(--el-text-color-placeholder)}.el-step__head.is-success{color:var(--el-color-success);border-color:var(--el-color-success)}.el-step__head.is-error{color:var(--el-color-danger);border-color:var(--el-color-danger)}.el-step__head.is-finish{color:var(--el-color-primary);border-color:var(--el-color-primary)}.el-step__icon{position:relative;z-index:1;display:inline-flex;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;box-sizing:border-box;background:var(--el-bg-color);transition:.15s ease-out}.el-step__icon.is-text{border-radius:50%;border:2px solid;border-color:inherit}.el-step__icon.is-icon{width:40px}.el-step__icon-inner{display:inline-block;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;text-align:center;font-weight:700;line-height:1;color:inherit}.el-step__icon-inner[class*=el-icon]:not(.is-status){font-size:25px;font-weight:400}.el-step__icon-inner.is-status{transform:translateY(1px)}.el-step__line{position:absolute;border-color:inherit;background-color:var(--el-text-color-placeholder)}.el-step__line-inner{display:block;border-width:1px;border-style:solid;border-color:inherit;transition:.15s ease-out;box-sizing:border-box;width:0;height:0}.el-step__main{white-space:normal;text-align:left}.el-step__title{font-size:16px;line-height:38px}.el-step__title.is-process{font-weight:700;color:var(--el-text-color-primary)}.el-step__title.is-wait{color:var(--el-text-color-placeholder)}.el-step__title.is-success{color:var(--el-color-success)}.el-step__title.is-error{color:var(--el-color-danger)}.el-step__title.is-finish{color:var(--el-color-primary)}.el-step__description{padding-right:10%;margin-top:-5px;font-size:12px;line-height:20px;font-weight:400}.el-step__description.is-process{color:var(--el-text-color-primary)}.el-step__description.is-wait{color:var(--el-text-color-placeholder)}.el-step__description.is-success{color:var(--el-color-success)}.el-step__description.is-error{color:var(--el-color-danger)}.el-step__description.is-finish{color:var(--el-color-primary)}.el-step.is-horizontal{display:inline-block}.el-step.is-horizontal .el-step__line{height:2px;top:11px;left:0;right:0}.el-step.is-vertical{display:flex}.el-step.is-vertical .el-step__head{flex-grow:0;width:24px}.el-step.is-vertical .el-step__main{padding-left:10px;flex-grow:1}.el-step.is-vertical .el-step__title{line-height:24px;padding-bottom:8px}.el-step.is-vertical .el-step__line{width:2px;top:0;bottom:0;left:11px}.el-step.is-vertical .el-step__icon.is-icon{width:24px}.el-step.is-center .el-step__head,.el-step.is-center .el-step__main{text-align:center}.el-step.is-center .el-step__description{padding-left:20%;padding-right:20%}.el-step.is-center .el-step__line{left:50%;right:-50%}.el-step.is-simple{display:flex;align-items:center}.el-step.is-simple .el-step__head{width:auto;font-size:0;padding-right:10px}.el-step.is-simple .el-step__icon{background:0 0;width:16px;height:16px;font-size:12px}.el-step.is-simple .el-step__icon-inner[class*=el-icon]:not(.is-status){font-size:18px}.el-step.is-simple .el-step__icon-inner.is-status{transform:scale(.8) translateY(1px)}.el-step.is-simple .el-step__main{position:relative;display:flex;align-items:stretch;flex-grow:1}.el-step.is-simple .el-step__title{font-size:16px;line-height:20px}.el-step.is-simple:not(:last-of-type) .el-step__title{max-width:50%;word-break:break-all}.el-step.is-simple .el-step__arrow{flex-grow:1;display:flex;align-items:center;justify-content:center}.el-step.is-simple .el-step__arrow:after,.el-step.is-simple .el-step__arrow:before{content:"";display:inline-block;position:absolute;height:15px;width:1px;background:var(--el-text-color-placeholder)}.el-step.is-simple .el-step__arrow:before{transform:rotate(-45deg) translateY(-4px);transform-origin:0 0}.el-step.is-simple .el-step__arrow:after{transform:rotate(45deg) translateY(4px);transform-origin:100% 100%}.el-step.is-simple:last-of-type .el-step__arrow{display:none}.el-steps{display:flex}.el-steps--simple{padding:13px 8%;border-radius:4px;background:var(--el-fill-color-light)}.el-steps--horizontal{white-space:nowrap}.el-steps--vertical{height:100%;flex-flow:column}.el-switch{--el-switch-on-color:var(--el-color-primary);--el-switch-off-color:var(--el-border-color)}.el-switch{display:inline-flex;align-items:center;position:relative;font-size:14px;line-height:20px;height:32px;vertical-align:middle}.el-switch.is-disabled .el-switch__core,.el-switch.is-disabled .el-switch__label{cursor:not-allowed}.el-switch__label{transition:var(--el-transition-duration-fast);height:20px;display:inline-block;font-size:14px;font-weight:500;cursor:pointer;vertical-align:middle;color:var(--el-text-color-primary)}.el-switch__label.is-active{color:var(--el-color-primary)}.el-switch__label--left{margin-right:10px}.el-switch__label--right{margin-left:10px}.el-switch__label *{line-height:1;font-size:14px;display:inline-block}.el-switch__label .el-icon{height:inherit}.el-switch__label .el-icon svg{vertical-align:middle}.el-switch__input{position:absolute;width:0;height:0;opacity:0;margin:0}.el-switch__input:focus-visible~.el-switch__core{outline:2px solid var(--el-switch-on-color);outline-offset:1px}.el-switch__core{display:inline-flex;position:relative;align-items:center;min-width:40px;height:20px;border:1px solid var(--el-switch-border-color,var(--el-switch-off-color));outline:0;border-radius:10px;box-sizing:border-box;background:var(--el-switch-off-color);cursor:pointer;transition:border-color var(--el-transition-duration),background-color var(--el-transition-duration)}.el-switch__core .el-switch__inner{width:100%;transition:all var(--el-transition-duration);height:16px;display:flex;justify-content:center;align-items:center;overflow:hidden;padding:0 4px 0 18px}.el-switch__core .el-switch__inner .is-icon,.el-switch__core .el-switch__inner .is-text{font-size:12px;color:var(--el-color-white);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-switch__core .el-switch__action{position:absolute;left:1px;border-radius:var(--el-border-radius-circle);transition:all var(--el-transition-duration);width:16px;height:16px;background-color:var(--el-color-white);display:flex;justify-content:center;align-items:center;color:var(--el-switch-off-color)}.el-switch.is-checked .el-switch__core{border-color:var(--el-switch-border-color,var(--el-switch-on-color));background-color:var(--el-switch-on-color)}.el-switch.is-checked .el-switch__core .el-switch__action{left:calc(100% - 17px);color:var(--el-switch-on-color)}.el-switch.is-checked .el-switch__core .el-switch__inner{padding:0 18px 0 4px}.el-switch.is-disabled{opacity:.6}.el-switch--wide .el-switch__label.el-switch__label--left span{left:10px}.el-switch--wide .el-switch__label.el-switch__label--right span{right:10px}.el-switch .label-fade-enter-from,.el-switch .label-fade-leave-active{opacity:0}.el-switch--large{font-size:14px;line-height:24px;height:40px}.el-switch--large .el-switch__label{height:24px;font-size:14px}.el-switch--large .el-switch__label *{font-size:14px}.el-switch--large .el-switch__core{min-width:50px;height:24px;border-radius:12px}.el-switch--large .el-switch__core .el-switch__inner{height:20px;padding:0 6px 0 22px}.el-switch--large .el-switch__core .el-switch__action{width:20px;height:20px}.el-switch--large.is-checked .el-switch__core .el-switch__action{left:calc(100% - 21px)}.el-switch--large.is-checked .el-switch__core .el-switch__inner{padding:0 22px 0 6px}.el-switch--small{font-size:12px;line-height:16px;height:24px}.el-switch--small .el-switch__label{height:16px;font-size:12px}.el-switch--small .el-switch__label *{font-size:12px}.el-switch--small .el-switch__core{min-width:30px;height:16px;border-radius:8px}.el-switch--small .el-switch__core .el-switch__inner{height:12px;padding:0 2px 0 14px}.el-switch--small .el-switch__core .el-switch__action{width:12px;height:12px}.el-switch--small.is-checked .el-switch__core .el-switch__action{left:calc(100% - 13px)}.el-switch--small.is-checked .el-switch__core .el-switch__inner{padding:0 14px 0 2px}.el-table-column--selection .cell{padding-left:14px;padding-right:14px}.el-table-filter{border:solid 1px var(--el-border-color-lighter);border-radius:2px;background-color:#fff;box-shadow:var(--el-box-shadow-light);box-sizing:border-box}.el-table-filter__list{padding:5px 0;margin:0;list-style:none;min-width:100px}.el-table-filter__list-item{line-height:36px;padding:0 10px;cursor:pointer;font-size:var(--el-font-size-base)}.el-table-filter__list-item:hover{background-color:var(--el-color-primary-light-9);color:var(--el-color-primary)}.el-table-filter__list-item.is-active{background-color:var(--el-color-primary);color:#fff}.el-table-filter__content{min-width:100px}.el-table-filter__bottom{border-top:1px solid var(--el-border-color-lighter);padding:8px}.el-table-filter__bottom button{background:0 0;border:none;color:var(--el-text-color-regular);cursor:pointer;font-size:var(--el-font-size-small);padding:0 3px}.el-table-filter__bottom button:hover{color:var(--el-color-primary)}.el-table-filter__bottom button:focus{outline:0}.el-table-filter__bottom button.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-table-filter__wrap{max-height:280px}.el-table-filter__checkbox-group{padding:10px}.el-table-filter__checkbox-group label.el-checkbox{display:flex;align-items:center;margin-right:5px;margin-bottom:12px;margin-left:5px;height:unset}.el-table-filter__checkbox-group .el-checkbox:last-child{margin-bottom:0}.el-table{--el-table-border-color:var(--el-border-color-lighter);--el-table-border:1px solid var(--el-table-border-color);--el-table-text-color:var(--el-text-color-regular);--el-table-header-text-color:var(--el-text-color-secondary);--el-table-row-hover-bg-color:var(--el-fill-color-light);--el-table-current-row-bg-color:var(--el-color-primary-light-9);--el-table-header-bg-color:var(--el-bg-color);--el-table-fixed-box-shadow:var(--el-box-shadow-light);--el-table-bg-color:var(--el-fill-color-blank);--el-table-tr-bg-color:var(--el-fill-color-blank);--el-table-expanded-cell-bg-color:var(--el-fill-color-blank);--el-table-fixed-left-column:inset 10px 0 10px -10px rgba(0, 0, 0, .15);--el-table-fixed-right-column:inset -10px 0 10px -10px rgba(0, 0, 0, .15)}.el-table{position:relative;overflow:hidden;box-sizing:border-box;height:-webkit-fit-content;height:-moz-fit-content;height:fit-content;width:100%;max-width:100%;background-color:var(--el-table-bg-color);font-size:14px;color:var(--el-table-text-color)}.el-table__inner-wrapper{position:relative;display:flex;flex-direction:column;height:100%}.el-table__inner-wrapper:before{left:0;bottom:0;width:100%;height:1px}.el-table.has-footer.el-table--fluid-height tr:last-child td.el-table__cell,.el-table.has-footer.el-table--scrollable-y tr:last-child td.el-table__cell{border-bottom-color:transparent}.el-table__empty-block{position:-webkit-sticky;position:sticky;left:0;min-height:60px;text-align:center;width:100%;display:flex;justify-content:center;align-items:center}.el-table__empty-text{line-height:60px;width:50%;color:var(--el-text-color-secondary)}.el-table__expand-column .cell{padding:0;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-table__expand-icon{position:relative;cursor:pointer;color:var(--el-text-color-regular);font-size:12px;transition:transform var(--el-transition-duration-fast) ease-in-out;height:20px}.el-table__expand-icon--expanded{transform:rotate(90deg)}.el-table__expand-icon>.el-icon{font-size:12px}.el-table__expanded-cell{background-color:var(--el-table-expanded-cell-bg-color)}.el-table__expanded-cell[class*=cell]{padding:20px 50px}.el-table__expanded-cell:hover{background-color:transparent!important}.el-table__placeholder{display:inline-block;width:20px}.el-table__append-wrapper{overflow:hidden}.el-table--fit{border-right:0;border-bottom:0}.el-table--fit .el-table__cell.gutter{border-right-width:1px}.el-table thead{color:var(--el-table-header-text-color);font-weight:500}.el-table thead.is-group th.el-table__cell{background:var(--el-fill-color-light)}.el-table .el-table__cell{padding:8px 0;min-width:0;box-sizing:border-box;text-overflow:ellipsis;vertical-align:middle;position:relative;text-align:left;z-index:1}.el-table .el-table__cell.is-center{text-align:center}.el-table .el-table__cell.is-right{text-align:right}.el-table .el-table__cell.gutter{width:15px;border-right-width:0;border-bottom-width:0;padding:0}.el-table .el-table__cell.is-hidden>*{visibility:hidden}.el-table .cell{box-sizing:border-box;overflow:hidden;text-overflow:ellipsis;white-space:normal;word-break:break-all;line-height:23px;padding:0 12px}.el-table .cell.el-tooltip{white-space:nowrap;min-width:50px}.el-table--large{font-size:var(--el-font-size-base)}.el-table--large .el-table__cell{padding:12px 0}.el-table--large .cell{padding:0 16px}.el-table--default{font-size:14px}.el-table--default .el-table__cell{padding:8px 0}.el-table--default .cell{padding:0 12px}.el-table--small{font-size:12px}.el-table--small .el-table__cell{padding:4px 0}.el-table--small .cell{padding:0 8px}.el-table tr{background-color:var(--el-table-tr-bg-color)}.el-table tr input[type=checkbox]{margin:0}.el-table td.el-table__cell,.el-table th.el-table__cell.is-leaf{border-bottom:var(--el-table-border)}.el-table th.el-table__cell.is-sortable{cursor:pointer}.el-table th.el-table__cell{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:var(--el-table-header-bg-color)}.el-table th.el-table__cell>.cell.highlight{color:var(--el-color-primary)}.el-table th.el-table__cell.required>div:before{display:inline-block;content:"";width:8px;height:8px;border-radius:50%;background:#ff4d51;margin-right:5px;vertical-align:middle}.el-table td.el-table__cell div{box-sizing:border-box}.el-table td.el-table__cell.gutter{width:0}.el-table__footer-wrapper{border-top:var(--el-table-border)}.el-table--border .el-table__inner-wrapper:after,.el-table--border:after,.el-table--border:before,.el-table__inner-wrapper:before{content:"";position:absolute;background-color:var(--el-table-border-color);z-index:3}.el-table--border .el-table__inner-wrapper:after{left:0;top:0;width:100%;height:1px}.el-table--border:before{top:-1px;left:0;width:1px;height:100%}.el-table--border:after{top:-1px;right:0;width:1px;height:100%}.el-table--border .el-table__inner-wrapper{border-right:none;border-bottom:none}.el-table--border .el-table__footer-wrapper{position:relative;flex-shrink:0}.el-table--border .el-table__cell{border-right:var(--el-table-border)}.el-table--border th.el-table__cell.gutter:last-of-type{border-bottom:var(--el-table-border);border-bottom-width:1px}.el-table--border th.el-table__cell{border-bottom:var(--el-table-border)}.el-table--hidden{visibility:hidden}.el-table__body-wrapper,.el-table__footer-wrapper,.el-table__header-wrapper{width:100%}.el-table__body-wrapper tr td.el-table-fixed-column--left,.el-table__body-wrapper tr td.el-table-fixed-column--right,.el-table__body-wrapper tr th.el-table-fixed-column--left,.el-table__body-wrapper tr th.el-table-fixed-column--right,.el-table__footer-wrapper tr td.el-table-fixed-column--left,.el-table__footer-wrapper tr td.el-table-fixed-column--right,.el-table__footer-wrapper tr th.el-table-fixed-column--left,.el-table__footer-wrapper tr th.el-table-fixed-column--right,.el-table__header-wrapper tr td.el-table-fixed-column--left,.el-table__header-wrapper tr td.el-table-fixed-column--right,.el-table__header-wrapper tr th.el-table-fixed-column--left,.el-table__header-wrapper tr th.el-table-fixed-column--right{position:-webkit-sticky!important;position:sticky!important;z-index:2;background:var(--el-bg-color)}.el-table__body-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-last-column:before{content:"";position:absolute;top:0;width:10px;bottom:-1px;overflow-x:hidden;overflow-y:hidden;box-shadow:none;touch-action:none;pointer-events:none}.el-table__body-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-first-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-first-column:before{left:-10px}.el-table__body-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__body-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__footer-wrapper tr th.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr td.el-table-fixed-column--right.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--left.is-last-column:before,.el-table__header-wrapper tr th.el-table-fixed-column--right.is-last-column:before{right:-10px;box-shadow:none}.el-table__body-wrapper tr td.el-table__fixed-right-patch,.el-table__body-wrapper tr th.el-table__fixed-right-patch,.el-table__footer-wrapper tr td.el-table__fixed-right-patch,.el-table__footer-wrapper tr th.el-table__fixed-right-patch,.el-table__header-wrapper tr td.el-table__fixed-right-patch,.el-table__header-wrapper tr th.el-table__fixed-right-patch{position:-webkit-sticky!important;position:sticky!important;z-index:2;background:#fff;right:0}.el-table__header-wrapper{flex-shrink:0}.el-table__header-wrapper tr th.el-table-fixed-column--left,.el-table__header-wrapper tr th.el-table-fixed-column--right{background-color:var(--el-table-header-bg-color)}.el-table__body,.el-table__footer,.el-table__header{table-layout:fixed;border-collapse:separate}.el-table__footer-wrapper,.el-table__header-wrapper{overflow:hidden}.el-table__footer-wrapper tbody td.el-table__cell,.el-table__header-wrapper tbody td.el-table__cell{background-color:var(--el-table-row-hover-bg-color);color:var(--el-table-text-color)}.el-table__body-wrapper .el-table-column--selection>.cell,.el-table__header-wrapper .el-table-column--selection>.cell{display:inline-flex;align-items:center;height:23px}.el-table__body-wrapper .el-table-column--selection .el-checkbox,.el-table__header-wrapper .el-table-column--selection .el-checkbox{height:unset}.el-table.is-scrolling-left .el-table-fixed-column--right.is-first-column:before{box-shadow:var(--el-table-fixed-right-column)}.el-table.is-scrolling-left.el-table--border .el-table-fixed-column--left.is-last-column.el-table__cell{border-right:var(--el-table-border)}.el-table.is-scrolling-left th.el-table-fixed-column--left{background-color:var(--el-table-header-bg-color)}.el-table.is-scrolling-right .el-table-fixed-column--left.is-last-column:before{box-shadow:var(--el-table-fixed-left-column)}.el-table.is-scrolling-right .el-table-fixed-column--left.is-last-column.el-table__cell{border-right:none}.el-table.is-scrolling-right th.el-table-fixed-column--right{background-color:var(--el-table-header-bg-color)}.el-table.is-scrolling-middle .el-table-fixed-column--left.is-last-column.el-table__cell{border-right:none}.el-table.is-scrolling-middle .el-table-fixed-column--right.is-first-column:before{box-shadow:var(--el-table-fixed-right-column)}.el-table.is-scrolling-middle .el-table-fixed-column--left.is-last-column:before{box-shadow:var(--el-table-fixed-left-column)}.el-table.is-scrolling-none .el-table-fixed-column--left.is-first-column:before,.el-table.is-scrolling-none .el-table-fixed-column--left.is-last-column:before,.el-table.is-scrolling-none .el-table-fixed-column--right.is-first-column:before,.el-table.is-scrolling-none .el-table-fixed-column--right.is-last-column:before{box-shadow:none}.el-table.is-scrolling-none th.el-table-fixed-column--left,.el-table.is-scrolling-none th.el-table-fixed-column--right{background-color:var(--el-table-header-bg-color)}.el-table__body-wrapper{overflow:hidden;position:relative;flex:1}.el-table__body-wrapper .el-scrollbar__bar{z-index:2}.el-table .caret-wrapper{display:inline-flex;flex-direction:column;align-items:center;height:14px;width:24px;vertical-align:middle;cursor:pointer;overflow:initial;position:relative}.el-table .sort-caret{width:0;height:0;border:solid 5px transparent;position:absolute;left:7px}.el-table .sort-caret.ascending{border-bottom-color:var(--el-text-color-placeholder);top:-5px}.el-table .sort-caret.descending{border-top-color:var(--el-text-color-placeholder);bottom:-3px}.el-table .ascending .sort-caret.ascending{border-bottom-color:var(--el-color-primary)}.el-table .descending .sort-caret.descending{border-top-color:var(--el-color-primary)}.el-table .hidden-columns{visibility:hidden;position:absolute;z-index:-1}.el-table--striped .el-table__body tr.el-table__row--striped td.el-table__cell{background:var(--el-fill-color-lighter)}.el-table--striped .el-table__body tr.el-table__row--striped.current-row td.el-table__cell{background-color:var(--el-table-current-row-bg-color)}.el-table__body tr.hover-row.current-row>td.el-table__cell,.el-table__body tr.hover-row.el-table__row--striped.current-row>td.el-table__cell,.el-table__body tr.hover-row.el-table__row--striped>td.el-table__cell,.el-table__body tr.hover-row>td.el-table__cell{background-color:var(--el-table-row-hover-bg-color)}.el-table__body tr.current-row>td.el-table__cell{background-color:var(--el-table-current-row-bg-color)}.el-table__column-resize-proxy{position:absolute;left:200px;top:0;bottom:0;width:0;border-left:var(--el-table-border);z-index:10}.el-table__column-filter-trigger{display:inline-block;cursor:pointer}.el-table__column-filter-trigger i{color:var(--el-color-info);font-size:14px;vertical-align:middle}.el-table__border-left-patch{top:0;left:0;width:1px;height:100%;z-index:3;position:absolute;background-color:var(--el-table-border-color)}.el-table__border-bottom-patch{left:0;height:1px;z-index:3;position:absolute;background-color:var(--el-table-border-color)}.el-table__border-right-patch{top:0;height:100%;width:1px;z-index:3;position:absolute;background-color:var(--el-table-border-color)}.el-table--enable-row-transition .el-table__body td.el-table__cell{transition:background-color .25s ease}.el-table--enable-row-hover .el-table__body tr:hover>td.el-table__cell{background-color:var(--el-table-row-hover-bg-color)}.el-table [class*=el-table__row--level] .el-table__expand-icon{display:inline-block;width:12px;line-height:12px;height:12px;text-align:center;margin-right:8px}.el-table .el-table.el-table--border .el-table__cell{border-right:var(--el-table-border)}.el-table:not(.el-table--border) .el-table__cell{border-right:none}.el-table:not(.el-table--border)>.el-table__inner-wrapper:after{content:none}.el-table-v2{--el-table-border-color:var(--el-border-color-lighter);--el-table-border:1px solid var(--el-table-border-color);--el-table-text-color:var(--el-text-color-regular);--el-table-header-text-color:var(--el-text-color-secondary);--el-table-row-hover-bg-color:var(--el-fill-color-light);--el-table-current-row-bg-color:var(--el-color-primary-light-9);--el-table-header-bg-color:var(--el-bg-color);--el-table-fixed-box-shadow:var(--el-box-shadow-light);--el-table-bg-color:var(--el-fill-color-blank);--el-table-tr-bg-color:var(--el-fill-color-blank);--el-table-expanded-cell-bg-color:var(--el-fill-color-blank);--el-table-fixed-left-column:inset 10px 0 10px -10px rgba(0, 0, 0, .15);--el-table-fixed-right-column:inset -10px 0 10px -10px rgba(0, 0, 0, .15)}.el-table-v2{font-size:14px}.el-table-v2 *{box-sizing:border-box}.el-table-v2__root{position:relative}.el-table-v2__root:hover .el-table-v2__main .el-virtual-scrollbar{opacity:1}.el-table-v2__main{display:flex;flex-direction:column-reverse;position:absolute;overflow:hidden;top:0;background-color:var(--el-bg-color);left:0}.el-table-v2__main .el-vl__horizontal,.el-table-v2__main .el-vl__vertical{z-index:2}.el-table-v2__left{display:flex;flex-direction:column-reverse;position:absolute;overflow:hidden;top:0;background-color:var(--el-bg-color);left:0;box-shadow:2px 0 4px #0000000f}.el-table-v2__left .el-virtual-scrollbar{opacity:0}.el-table-v2__left .el-vl__horizontal,.el-table-v2__left .el-vl__vertical{z-index:-1}.el-table-v2__right{display:flex;flex-direction:column-reverse;position:absolute;overflow:hidden;top:0;background-color:var(--el-bg-color);right:0;box-shadow:-2px 0 4px #0000000f}.el-table-v2__right .el-virtual-scrollbar{opacity:0}.el-table-v2__right .el-vl__horizontal,.el-table-v2__right .el-vl__vertical{z-index:-1}.el-table-v2__header-row,.el-table-v2__row{-webkit-padding-end:var(--el-table-scrollbar-size);padding-inline-end:var(--el-table-scrollbar-size)}.el-table-v2__header-wrapper{overflow:hidden}.el-table-v2__header{position:relative;overflow:hidden}.el-table-v2__footer{position:absolute;left:0;right:0;bottom:0;overflow:hidden}.el-table-v2__empty{position:absolute;left:0}.el-table-v2__overlay{position:absolute;left:0;right:0;top:0;bottom:0;z-index:9999}.el-table-v2__header-row{display:flex;border-bottom:var(--el-table-border)}.el-table-v2__header-cell{display:flex;align-items:center;padding:0 8px;height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;background-color:var(--el-table-header-bg-color);color:var(--el-table-header-text-color);font-weight:700}.el-table-v2__header-cell.is-align-center{justify-content:center;text-align:center}.el-table-v2__header-cell.is-align-right{justify-content:flex-end;text-align:right}.el-table-v2__header-cell.is-sortable{cursor:pointer}.el-table-v2__header-cell:hover .el-icon{display:block}.el-table-v2__sort-icon{transition:opacity,display var(--el-transition-duration);opacity:.6;display:none}.el-table-v2__sort-icon.is-sorting{display:block;opacity:1}.el-table-v2__row{border-bottom:var(--el-table-border);display:flex;align-items:center;transition:background-color var(--el-transition-duration)}.el-table-v2__row.is-hovered,.el-table-v2__row:hover{background-color:var(--el-table-row-hover-bg-color)}.el-table-v2__row-cell{height:100%;overflow:hidden;display:flex;align-items:center;padding:0 8px}.el-table-v2__row-cell.is-align-center{justify-content:center;text-align:center}.el-table-v2__row-cell.is-align-right{justify-content:flex-end;text-align:right}.el-table-v2__expand-icon{margin:0 4px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-table-v2__expand-icon svg{transition:transform var(--el-transition-duration)}.el-table-v2__expand-icon.is-expanded svg{transform:rotate(90deg)}.el-table-v2:not(.is-dynamic) .el-table-v2__cell-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-table-v2.is-dynamic .el-table-v2__row{overflow:hidden;align-items:stretch}.el-table-v2.is-dynamic .el-table-v2__row .el-table-v2__row-cell{word-break:break-all}.el-tabs{--el-tabs-header-height:40px}.el-tabs__header{padding:0;position:relative;margin:0 0 15px}.el-tabs__active-bar{position:absolute;bottom:0;left:0;height:2px;background-color:var(--el-color-primary);z-index:1;transition:width var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier),transform var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);list-style:none}.el-tabs__new-tab{display:flex;align-items:center;justify-content:center;float:right;border:1px solid var(--el-border-color);height:20px;width:20px;line-height:20px;margin:10px 0 10px 10px;border-radius:3px;text-align:center;font-size:12px;color:var(--el-text-color-primary);cursor:pointer;transition:all .15s}.el-tabs__new-tab .is-icon-plus{height:inherit;width:inherit;transform:scale(.8)}.el-tabs__new-tab .is-icon-plus svg{vertical-align:middle}.el-tabs__new-tab:hover{color:var(--el-color-primary)}.el-tabs__nav-wrap{overflow:hidden;margin-bottom:-1px;position:relative}.el-tabs__nav-wrap:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background-color:var(--el-border-color-light);z-index:var(--el-index-normal)}.el-tabs__nav-wrap.is-scrollable{padding:0 20px;box-sizing:border-box}.el-tabs__nav-scroll{overflow:hidden}.el-tabs__nav-next,.el-tabs__nav-prev{position:absolute;cursor:pointer;line-height:44px;font-size:12px;color:var(--el-text-color-secondary);width:20px;text-align:center}.el-tabs__nav-next{right:0}.el-tabs__nav-prev{left:0}.el-tabs__nav{display:flex;white-space:nowrap;position:relative;transition:transform var(--el-transition-duration);float:left;z-index:calc(var(--el-index-normal) + 1)}.el-tabs__nav.is-stretch{min-width:100%;display:flex}.el-tabs__nav.is-stretch>*{flex:1;text-align:center}.el-tabs__item{padding:0 20px;height:var(--el-tabs-header-height);box-sizing:border-box;display:flex;align-items:center;justify-content:center;list-style:none;font-size:var(--el-font-size-base);font-weight:500;color:var(--el-text-color-primary);position:relative}.el-tabs__item:focus,.el-tabs__item:focus:active{outline:0}.el-tabs__item:focus-visible{box-shadow:0 0 2px 2px var(--el-color-primary) inset;border-radius:3px}.el-tabs__item .is-icon-close{border-radius:50%;text-align:center;transition:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);margin-left:5px}.el-tabs__item .is-icon-close:before{transform:scale(.9);display:inline-block}.el-tabs__item .is-icon-close:hover{background-color:var(--el-text-color-placeholder);color:#fff}.el-tabs__item.is-active{color:var(--el-color-primary)}.el-tabs__item:hover{color:var(--el-color-primary);cursor:pointer}.el-tabs__item.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-tabs__content{overflow:hidden;position:relative}.el-tabs--card>.el-tabs__header{border-bottom:1px solid var(--el-border-color-light);height:var(--el-tabs-header-height)}.el-tabs--card>.el-tabs__header .el-tabs__nav-wrap:after{content:none}.el-tabs--card>.el-tabs__header .el-tabs__nav{border:1px solid var(--el-border-color-light);border-bottom:none;border-radius:4px 4px 0 0;box-sizing:border-box}.el-tabs--card>.el-tabs__header .el-tabs__active-bar{display:none}.el-tabs--card>.el-tabs__header .el-tabs__item .is-icon-close{position:relative;font-size:12px;width:0;height:14px;overflow:hidden;right:-2px;transform-origin:100% 50%}.el-tabs--card>.el-tabs__header .el-tabs__item{border-bottom:1px solid transparent;border-left:1px solid var(--el-border-color-light);transition:color var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier),padding var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier)}.el-tabs--card>.el-tabs__header .el-tabs__item:first-child{border-left:none}.el-tabs--card>.el-tabs__header .el-tabs__item.is-closable:hover{padding-left:13px;padding-right:13px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-closable:hover .is-icon-close{width:14px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active{border-bottom-color:var(--el-bg-color)}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active.is-closable{padding-left:20px;padding-right:20px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active.is-closable .is-icon-close{width:14px}.el-tabs--border-card{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color)}.el-tabs--border-card>.el-tabs__content{padding:15px}.el-tabs--border-card>.el-tabs__header{background-color:var(--el-fill-color-light);border-bottom:1px solid var(--el-border-color-light);margin:0}.el-tabs--border-card>.el-tabs__header .el-tabs__nav-wrap:after{content:none}.el-tabs--border-card>.el-tabs__header .el-tabs__item{transition:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);border:1px solid transparent;margin-top:-1px;color:var(--el-text-color-secondary)}.el-tabs--border-card>.el-tabs__header .el-tabs__item:first-child{margin-left:-1px}.el-tabs--border-card>.el-tabs__header .el-tabs__item+.el-tabs__item{margin-left:-1px}.el-tabs--border-card>.el-tabs__header .el-tabs__item.is-active{color:var(--el-color-primary);background-color:var(--el-bg-color-overlay);border-right-color:var(--el-border-color);border-left-color:var(--el-border-color)}.el-tabs--border-card>.el-tabs__header .el-tabs__item:not(.is-disabled):hover{color:var(--el-color-primary)}.el-tabs--border-card>.el-tabs__header .el-tabs__item.is-disabled{color:var(--el-disabled-text-color)}.el-tabs--border-card>.el-tabs__header .is-scrollable .el-tabs__item:first-child{margin-left:0}.el-tabs--bottom .el-tabs__item.is-bottom:nth-child(2),.el-tabs--bottom .el-tabs__item.is-top:nth-child(2),.el-tabs--top .el-tabs__item.is-bottom:nth-child(2),.el-tabs--top .el-tabs__item.is-top:nth-child(2){padding-left:0}.el-tabs--bottom .el-tabs__item.is-bottom:last-child,.el-tabs--bottom .el-tabs__item.is-top:last-child,.el-tabs--top .el-tabs__item.is-bottom:last-child,.el-tabs--top .el-tabs__item.is-top:last-child{padding-right:0}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2){padding-left:20px}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2):not(.is-active).is-closable:hover{padding-left:13px}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:last-child,.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:last-child,.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:last-child{padding-right:20px}.el-tabs--bottom .el-tabs--left>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--bottom .el-tabs--right>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--left>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top .el-tabs--right>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover,.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:last-child:not(.is-active).is-closable:hover{padding-right:13px}.el-tabs--bottom .el-tabs__header.is-bottom{margin-bottom:0;margin-top:10px}.el-tabs--bottom.el-tabs--border-card .el-tabs__header.is-bottom{border-bottom:0;border-top:1px solid var(--el-border-color)}.el-tabs--bottom.el-tabs--border-card .el-tabs__nav-wrap.is-bottom{margin-top:-1px;margin-bottom:0}.el-tabs--bottom.el-tabs--border-card .el-tabs__item.is-bottom:not(.is-active){border:1px solid transparent}.el-tabs--bottom.el-tabs--border-card .el-tabs__item.is-bottom{margin:0 -1px -1px}.el-tabs--left,.el-tabs--right{overflow:hidden}.el-tabs--left .el-tabs__header.is-left,.el-tabs--left .el-tabs__header.is-right,.el-tabs--left .el-tabs__nav-scroll,.el-tabs--left .el-tabs__nav-wrap.is-left,.el-tabs--left .el-tabs__nav-wrap.is-right,.el-tabs--right .el-tabs__header.is-left,.el-tabs--right .el-tabs__header.is-right,.el-tabs--right .el-tabs__nav-scroll,.el-tabs--right .el-tabs__nav-wrap.is-left,.el-tabs--right .el-tabs__nav-wrap.is-right{height:100%}.el-tabs--left .el-tabs__active-bar.is-left,.el-tabs--left .el-tabs__active-bar.is-right,.el-tabs--right .el-tabs__active-bar.is-left,.el-tabs--right .el-tabs__active-bar.is-right{top:0;bottom:auto;width:2px;height:auto}.el-tabs--left .el-tabs__nav-wrap.is-left,.el-tabs--left .el-tabs__nav-wrap.is-right,.el-tabs--right .el-tabs__nav-wrap.is-left,.el-tabs--right .el-tabs__nav-wrap.is-right{margin-bottom:0}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev{height:30px;line-height:30px;width:100%;text-align:center;cursor:pointer}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next i,.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev i,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next i,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev i,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next i,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev i,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next i,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev i{transform:rotate(90deg)}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev{left:auto;top:0}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next{right:auto;bottom:0}.el-tabs--left .el-tabs__nav-wrap.is-left.is-scrollable,.el-tabs--left .el-tabs__nav-wrap.is-right.is-scrollable,.el-tabs--right .el-tabs__nav-wrap.is-left.is-scrollable,.el-tabs--right .el-tabs__nav-wrap.is-right.is-scrollable{padding:30px 0}.el-tabs--left .el-tabs__nav-wrap.is-left:after,.el-tabs--left .el-tabs__nav-wrap.is-right:after,.el-tabs--right .el-tabs__nav-wrap.is-left:after,.el-tabs--right .el-tabs__nav-wrap.is-right:after{height:100%;width:2px;bottom:auto;top:0}.el-tabs--left .el-tabs__nav.is-left,.el-tabs--left .el-tabs__nav.is-right,.el-tabs--right .el-tabs__nav.is-left,.el-tabs--right .el-tabs__nav.is-right{flex-direction:column}.el-tabs--left .el-tabs__item.is-left,.el-tabs--right .el-tabs__item.is-left{justify-content:flex-end}.el-tabs--left .el-tabs__item.is-right,.el-tabs--right .el-tabs__item.is-right{justify-content:flex-start}.el-tabs--left .el-tabs__header.is-left{float:left;margin-bottom:0;margin-right:10px}.el-tabs--left .el-tabs__nav-wrap.is-left{margin-right:-1px}.el-tabs--left .el-tabs__nav-wrap.is-left:after{left:auto;right:0}.el-tabs--left .el-tabs__active-bar.is-left{right:0;left:auto}.el-tabs--left .el-tabs__item.is-left{text-align:right}.el-tabs--left.el-tabs--card .el-tabs__active-bar.is-left{display:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left{border-left:none;border-right:1px solid var(--el-border-color-light);border-bottom:none;border-top:1px solid var(--el-border-color-light);text-align:left}.el-tabs--left.el-tabs--card .el-tabs__item.is-left:first-child{border-right:1px solid var(--el-border-color-light);border-top:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active{border:1px solid var(--el-border-color-light);border-right-color:#fff;border-left:none;border-bottom:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active:first-child{border-top:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active:last-child{border-bottom:none}.el-tabs--left.el-tabs--card .el-tabs__nav{border-radius:4px 0 0 4px;border-bottom:1px solid var(--el-border-color-light);border-right:none}.el-tabs--left.el-tabs--card .el-tabs__new-tab{float:none}.el-tabs--left.el-tabs--border-card .el-tabs__header.is-left{border-right:1px solid var(--el-border-color)}.el-tabs--left.el-tabs--border-card .el-tabs__item.is-left{border:1px solid transparent;margin:-1px 0 -1px -1px}.el-tabs--left.el-tabs--border-card .el-tabs__item.is-left.is-active{border-color:transparent;border-top-color:#d1dbe5;border-bottom-color:#d1dbe5}.el-tabs--right .el-tabs__header.is-right{float:right;margin-bottom:0;margin-left:10px}.el-tabs--right .el-tabs__nav-wrap.is-right{margin-left:-1px}.el-tabs--right .el-tabs__nav-wrap.is-right:after{left:0;right:auto}.el-tabs--right .el-tabs__active-bar.is-right{left:0}.el-tabs--right.el-tabs--card .el-tabs__active-bar.is-right{display:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right{border-bottom:none;border-top:1px solid var(--el-border-color-light)}.el-tabs--right.el-tabs--card .el-tabs__item.is-right:first-child{border-left:1px solid var(--el-border-color-light);border-top:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active{border:1px solid var(--el-border-color-light);border-left-color:#fff;border-right:none;border-bottom:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active:first-child{border-top:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active:last-child{border-bottom:none}.el-tabs--right.el-tabs--card .el-tabs__nav{border-radius:0 4px 4px 0;border-bottom:1px solid var(--el-border-color-light);border-left:none}.el-tabs--right.el-tabs--border-card .el-tabs__header.is-right{border-left:1px solid var(--el-border-color)}.el-tabs--right.el-tabs--border-card .el-tabs__item.is-right{border:1px solid transparent;margin:-1px -1px -1px 0}.el-tabs--right.el-tabs--border-card .el-tabs__item.is-right.is-active{border-color:transparent;border-top-color:#d1dbe5;border-bottom-color:#d1dbe5}.slideInLeft-transition,.slideInRight-transition{display:inline-block}.slideInRight-enter{-webkit-animation:slideInRight-enter var(--el-transition-duration);animation:slideInRight-enter var(--el-transition-duration)}.slideInRight-leave{position:absolute;left:0;right:0;-webkit-animation:slideInRight-leave var(--el-transition-duration);animation:slideInRight-leave var(--el-transition-duration)}.slideInLeft-enter{-webkit-animation:slideInLeft-enter var(--el-transition-duration);animation:slideInLeft-enter var(--el-transition-duration)}.slideInLeft-leave{position:absolute;left:0;right:0;-webkit-animation:slideInLeft-leave var(--el-transition-duration);animation:slideInLeft-leave var(--el-transition-duration)}@-webkit-keyframes slideInRight-enter{0%{opacity:0;transform-origin:0 0;transform:translate(100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@keyframes slideInRight-enter{0%{opacity:0;transform-origin:0 0;transform:translate(100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@-webkit-keyframes slideInRight-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(100%);opacity:0}}@keyframes slideInRight-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(100%);opacity:0}}@-webkit-keyframes slideInLeft-enter{0%{opacity:0;transform-origin:0 0;transform:translate(-100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@keyframes slideInLeft-enter{0%{opacity:0;transform-origin:0 0;transform:translate(-100%)}to{opacity:1;transform-origin:0 0;transform:translate(0)}}@-webkit-keyframes slideInLeft-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(-100%);opacity:0}}@keyframes slideInLeft-leave{0%{transform-origin:0 0;transform:translate(0);opacity:1}to{transform-origin:0 0;transform:translate(-100%);opacity:0}}.el-tag{--el-tag-font-size:12px;--el-tag-border-radius:4px;--el-tag-border-radius-rounded:9999px}.el-tag{--el-tag-bg-color:var(--el-color-primary-light-9);--el-tag-border-color:var(--el-color-primary-light-8);--el-tag-hover-color:var(--el-color-primary);--el-tag-text-color:var(--el-color-primary);background-color:var(--el-tag-bg-color);border-color:var(--el-tag-border-color);color:var(--el-tag-text-color);display:inline-flex;justify-content:center;align-items:center;height:24px;padding:0 9px;font-size:var(--el-tag-font-size);line-height:1;border-width:1px;border-style:solid;border-radius:var(--el-tag-border-radius);box-sizing:border-box;white-space:nowrap;--el-icon-size:14px}.el-tag.el-tag--primary{--el-tag-bg-color:var(--el-color-primary-light-9);--el-tag-border-color:var(--el-color-primary-light-8);--el-tag-hover-color:var(--el-color-primary)}.el-tag.el-tag--success{--el-tag-bg-color:var(--el-color-success-light-9);--el-tag-border-color:var(--el-color-success-light-8);--el-tag-hover-color:var(--el-color-success)}.el-tag.el-tag--warning{--el-tag-bg-color:var(--el-color-warning-light-9);--el-tag-border-color:var(--el-color-warning-light-8);--el-tag-hover-color:var(--el-color-warning)}.el-tag.el-tag--danger{--el-tag-bg-color:var(--el-color-danger-light-9);--el-tag-border-color:var(--el-color-danger-light-8);--el-tag-hover-color:var(--el-color-danger)}.el-tag.el-tag--error{--el-tag-bg-color:var(--el-color-error-light-9);--el-tag-border-color:var(--el-color-error-light-8);--el-tag-hover-color:var(--el-color-error)}.el-tag.el-tag--info{--el-tag-bg-color:var(--el-color-info-light-9);--el-tag-border-color:var(--el-color-info-light-8);--el-tag-hover-color:var(--el-color-info)}.el-tag.el-tag--primary{--el-tag-text-color:var(--el-color-primary)}.el-tag.el-tag--success{--el-tag-text-color:var(--el-color-success)}.el-tag.el-tag--warning{--el-tag-text-color:var(--el-color-warning)}.el-tag.el-tag--danger{--el-tag-text-color:var(--el-color-danger)}.el-tag.el-tag--error{--el-tag-text-color:var(--el-color-error)}.el-tag.el-tag--info{--el-tag-text-color:var(--el-color-info)}.el-tag.is-hit{border-color:var(--el-color-primary)}.el-tag.is-round{border-radius:var(--el-tag-border-radius-rounded)}.el-tag .el-tag__close{color:var(--el-tag-text-color)}.el-tag .el-tag__close:hover{color:var(--el-color-white);background-color:var(--el-tag-hover-color)}.el-tag .el-icon{border-radius:50%;cursor:pointer;font-size:calc(var(--el-icon-size) - 2px);height:var(--el-icon-size);width:var(--el-icon-size)}.el-tag .el-tag__close{margin-left:6px}.el-tag--dark{--el-tag-bg-color:var(--el-color-primary);--el-tag-border-color:var(--el-color-primary);--el-tag-hover-color:var(--el-color-primary-light-3);--el-tag-text-color:var(--el-color-white)}.el-tag--dark.el-tag--primary{--el-tag-bg-color:var(--el-color-primary);--el-tag-border-color:var(--el-color-primary);--el-tag-hover-color:var(--el-color-primary-light-3)}.el-tag--dark.el-tag--success{--el-tag-bg-color:var(--el-color-success);--el-tag-border-color:var(--el-color-success);--el-tag-hover-color:var(--el-color-success-light-3)}.el-tag--dark.el-tag--warning{--el-tag-bg-color:var(--el-color-warning);--el-tag-border-color:var(--el-color-warning);--el-tag-hover-color:var(--el-color-warning-light-3)}.el-tag--dark.el-tag--danger{--el-tag-bg-color:var(--el-color-danger);--el-tag-border-color:var(--el-color-danger);--el-tag-hover-color:var(--el-color-danger-light-3)}.el-tag--dark.el-tag--error{--el-tag-bg-color:var(--el-color-error);--el-tag-border-color:var(--el-color-error);--el-tag-hover-color:var(--el-color-error-light-3)}.el-tag--dark.el-tag--info{--el-tag-bg-color:var(--el-color-info);--el-tag-border-color:var(--el-color-info);--el-tag-hover-color:var(--el-color-info-light-3)}.el-tag--dark.el-tag--primary,.el-tag--dark.el-tag--success,.el-tag--dark.el-tag--warning,.el-tag--dark.el-tag--danger,.el-tag--dark.el-tag--error,.el-tag--dark.el-tag--info{--el-tag-text-color:var(--el-color-white)}.el-tag--plain{--el-tag-border-color:var(--el-color-primary-light-5);--el-tag-hover-color:var(--el-color-primary);--el-tag-bg-color:var(--el-fill-color-blank)}.el-tag--plain.el-tag--primary{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-primary-light-5);--el-tag-hover-color:var(--el-color-primary)}.el-tag--plain.el-tag--success{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-success-light-5);--el-tag-hover-color:var(--el-color-success)}.el-tag--plain.el-tag--warning{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-warning-light-5);--el-tag-hover-color:var(--el-color-warning)}.el-tag--plain.el-tag--danger{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-danger-light-5);--el-tag-hover-color:var(--el-color-danger)}.el-tag--plain.el-tag--error{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-error-light-5);--el-tag-hover-color:var(--el-color-error)}.el-tag--plain.el-tag--info{--el-tag-bg-color:var(--el-fill-color-blank);--el-tag-border-color:var(--el-color-info-light-5);--el-tag-hover-color:var(--el-color-info)}.el-tag.is-closable{padding-right:5px}.el-tag--large{padding:0 11px;height:32px;--el-icon-size:16px}.el-tag--large .el-tag__close{margin-left:8px}.el-tag--large.is-closable{padding-right:7px}.el-tag--small{padding:0 7px;height:20px;--el-icon-size:12px}.el-tag--small .el-tag__close{margin-left:4px}.el-tag--small.is-closable{padding-right:3px}.el-tag--small .el-icon-close{transform:scale(.8)}.el-tag.el-tag--primary.is-hit{border-color:var(--el-color-primary)}.el-tag.el-tag--success.is-hit{border-color:var(--el-color-success)}.el-tag.el-tag--warning.is-hit{border-color:var(--el-color-warning)}.el-tag.el-tag--danger.is-hit{border-color:var(--el-color-danger)}.el-tag.el-tag--error.is-hit{border-color:var(--el-color-error)}.el-tag.el-tag--info.is-hit{border-color:var(--el-color-info)}.el-text{--el-text-font-size:var(--el-font-size-base);--el-text-color:var(--el-text-color-regular)}.el-text{align-self:center;margin:0;padding:0;font-size:var(--el-text-font-size);color:var(--el-text-color);word-break:break-all}.el-text.is-truncated{display:inline-block;max-width:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.el-text--large{--el-text-font-size:var(--el-font-size-medium)}.el-text--default{--el-text-font-size:var(--el-font-size-base)}.el-text--small{--el-text-font-size:var(--el-font-size-extra-small)}.el-text.el-text--primary{--el-text-color:var(--el-color-primary)}.el-text.el-text--success{--el-text-color:var(--el-color-success)}.el-text.el-text--warning{--el-text-color:var(--el-color-warning)}.el-text.el-text--danger{--el-text-color:var(--el-color-danger)}.el-text.el-text--error{--el-text-color:var(--el-color-error)}.el-text.el-text--info{--el-text-color:var(--el-color-info)}.el-text>.el-icon{vertical-align:-2px}.time-select{margin:5px 0;min-width:0}.time-select .el-picker-panel__content{max-height:200px;margin:0}.time-select-item{padding:8px 10px;font-size:14px;line-height:20px}.time-select-item.disabled{color:var(--el-datepicker-border-color);cursor:not-allowed}.time-select-item:hover{background-color:var(--el-fill-color-light);font-weight:700;cursor:pointer}.time-select .time-select-item.selected:not(.disabled){color:var(--el-color-primary);font-weight:700}.el-timeline-item{position:relative;padding-bottom:20px}.el-timeline-item__wrapper{position:relative;padding-left:28px;top:-3px}.el-timeline-item__tail{position:absolute;left:4px;height:100%;border-left:2px solid var(--el-timeline-node-color)}.el-timeline-item .el-timeline-item__icon{color:var(--el-color-white);font-size:var(--el-font-size-small)}.el-timeline-item__node{position:absolute;background-color:var(--el-timeline-node-color);border-color:var(--el-timeline-node-color);border-radius:50%;box-sizing:border-box;display:flex;justify-content:center;align-items:center}.el-timeline-item__node--normal{left:-1px;width:var(--el-timeline-node-size-normal);height:var(--el-timeline-node-size-normal)}.el-timeline-item__node--large{left:-2px;width:var(--el-timeline-node-size-large);height:var(--el-timeline-node-size-large)}.el-timeline-item__node.is-hollow{background:var(--el-color-white);border-style:solid;border-width:2px}.el-timeline-item__node--primary{background-color:var(--el-color-primary);border-color:var(--el-color-primary)}.el-timeline-item__node--success{background-color:var(--el-color-success);border-color:var(--el-color-success)}.el-timeline-item__node--warning{background-color:var(--el-color-warning);border-color:var(--el-color-warning)}.el-timeline-item__node--danger{background-color:var(--el-color-danger);border-color:var(--el-color-danger)}.el-timeline-item__node--info{background-color:var(--el-color-info);border-color:var(--el-color-info)}.el-timeline-item__dot{position:absolute;display:flex;justify-content:center;align-items:center}.el-timeline-item__content{color:var(--el-text-color-primary)}.el-timeline-item__timestamp{color:var(--el-text-color-secondary);line-height:1;font-size:var(--el-font-size-small)}.el-timeline-item__timestamp.is-top{margin-bottom:8px;padding-top:4px}.el-timeline-item__timestamp.is-bottom{margin-top:8px}.el-timeline{--el-timeline-node-size-normal:12px;--el-timeline-node-size-large:14px;--el-timeline-node-color:var(--el-border-color-light)}.el-timeline{margin:0;font-size:var(--el-font-size-base);list-style:none}.el-timeline .el-timeline-item:last-child .el-timeline-item__tail{display:none}.el-timeline .el-timeline-item__center{display:flex;align-items:center}.el-timeline .el-timeline-item__center .el-timeline-item__wrapper{width:100%}.el-timeline .el-timeline-item__center .el-timeline-item__tail{top:0}.el-timeline .el-timeline-item__center:first-child .el-timeline-item__tail{height:calc(50% + 10px);top:calc(50% - 10px)}.el-timeline .el-timeline-item__center:last-child .el-timeline-item__tail{display:block;height:calc(50% - 10px)}.el-tooltip-v2__content{--el-tooltip-v2-padding:5px 10px;--el-tooltip-v2-border-radius:4px;--el-tooltip-v2-border-color:var(--el-border-color);border-radius:var(--el-tooltip-v2-border-radius);color:var(--el-color-black);background-color:var(--el-color-white);padding:var(--el-tooltip-v2-padding);border:1px solid var(--el-border-color)}.el-tooltip-v2__arrow{position:absolute;color:var(--el-color-white);width:var(--el-tooltip-v2-arrow-width);height:var(--el-tooltip-v2-arrow-height);pointer-events:none;left:var(--el-tooltip-v2-arrow-x);top:var(--el-tooltip-v2-arrow-y)}.el-tooltip-v2__arrow:before{content:"";width:0;height:0;border:var(--el-tooltip-v2-arrow-border-width) solid transparent;position:absolute}.el-tooltip-v2__arrow:after{content:"";width:0;height:0;border:var(--el-tooltip-v2-arrow-border-width) solid transparent;position:absolute}.el-tooltip-v2__content[data-side^=top] .el-tooltip-v2__arrow{bottom:0}.el-tooltip-v2__content[data-side^=top] .el-tooltip-v2__arrow:before{border-top-color:var(--el-color-white);border-top-width:var(--el-tooltip-v2-arrow-border-width);border-bottom:0;top:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=top] .el-tooltip-v2__arrow:after{border-top-color:var(--el-border-color);border-top-width:var(--el-tooltip-v2-arrow-border-width);border-bottom:0;top:100%;z-index:-1}.el-tooltip-v2__content[data-side^=bottom] .el-tooltip-v2__arrow{top:0}.el-tooltip-v2__content[data-side^=bottom] .el-tooltip-v2__arrow:before{border-bottom-color:var(--el-color-white);border-bottom-width:var(--el-tooltip-v2-arrow-border-width);border-top:0;bottom:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=bottom] .el-tooltip-v2__arrow:after{border-bottom-color:var(--el-border-color);border-bottom-width:var(--el-tooltip-v2-arrow-border-width);border-top:0;bottom:100%;z-index:-1}.el-tooltip-v2__content[data-side^=left] .el-tooltip-v2__arrow{right:0}.el-tooltip-v2__content[data-side^=left] .el-tooltip-v2__arrow:before{border-left-color:var(--el-color-white);border-left-width:var(--el-tooltip-v2-arrow-border-width);border-right:0;left:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=left] .el-tooltip-v2__arrow:after{border-left-color:var(--el-border-color);border-left-width:var(--el-tooltip-v2-arrow-border-width);border-right:0;left:100%;z-index:-1}.el-tooltip-v2__content[data-side^=right] .el-tooltip-v2__arrow{left:0}.el-tooltip-v2__content[data-side^=right] .el-tooltip-v2__arrow:before{border-right-color:var(--el-color-white);border-right-width:var(--el-tooltip-v2-arrow-border-width);border-left:0;right:calc(100% - 1px)}.el-tooltip-v2__content[data-side^=right] .el-tooltip-v2__arrow:after{border-right-color:var(--el-border-color);border-right-width:var(--el-tooltip-v2-arrow-border-width);border-left:0;right:100%;z-index:-1}.el-tooltip-v2__content.is-dark{--el-tooltip-v2-border-color:transparent;background-color:var(--el-color-black);color:var(--el-color-white);border-color:transparent}.el-tooltip-v2__content.is-dark .el-tooltip-v2__arrow{background-color:var(--el-color-black);border-color:transparent}.el-transfer{--el-transfer-border-color:var(--el-border-color-lighter);--el-transfer-border-radius:var(--el-border-radius-base);--el-transfer-panel-width:200px;--el-transfer-panel-header-height:40px;--el-transfer-panel-header-bg-color:var(--el-fill-color-light);--el-transfer-panel-footer-height:40px;--el-transfer-panel-body-height:278px;--el-transfer-item-height:30px;--el-transfer-filter-height:32px}.el-transfer{font-size:var(--el-font-size-base)}.el-transfer__buttons{display:inline-block;vertical-align:middle;padding:0 30px}.el-transfer__button{vertical-align:top}.el-transfer__button:nth-child(2){margin:0 0 0 10px}.el-transfer__button i,.el-transfer__button span{font-size:14px}.el-transfer__button .el-icon+span{margin-left:0}.el-transfer-panel{overflow:hidden;background:var(--el-bg-color-overlay);display:inline-block;text-align:left;vertical-align:middle;width:var(--el-transfer-panel-width);max-height:100%;box-sizing:border-box;position:relative}.el-transfer-panel__body{height:var(--el-transfer-panel-body-height);border-left:1px solid var(--el-transfer-border-color);border-right:1px solid var(--el-transfer-border-color);border-bottom:1px solid var(--el-transfer-border-color);border-bottom-left-radius:var(--el-transfer-border-radius);border-bottom-right-radius:var(--el-transfer-border-radius);overflow:hidden}.el-transfer-panel__body.is-with-footer{border-bottom:none;border-bottom-left-radius:0;border-bottom-right-radius:0}.el-transfer-panel__list{margin:0;padding:6px 0;list-style:none;height:var(--el-transfer-panel-body-height);overflow:auto;box-sizing:border-box}.el-transfer-panel__list.is-filterable{height:calc(100% - var(--el-transfer-filter-height) - 30px);padding-top:0}.el-transfer-panel__item{height:var(--el-transfer-item-height);line-height:var(--el-transfer-item-height);padding-left:15px;display:block!important}.el-transfer-panel__item+.el-transfer-panel__item{margin-left:0}.el-transfer-panel__item.el-checkbox{color:var(--el-text-color-regular)}.el-transfer-panel__item:hover{color:var(--el-color-primary)}.el-transfer-panel__item.el-checkbox .el-checkbox__label{width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;box-sizing:border-box;padding-left:22px;line-height:var(--el-transfer-item-height)}.el-transfer-panel__item .el-checkbox__input{position:absolute;top:8px}.el-transfer-panel__filter{text-align:center;padding:15px;box-sizing:border-box}.el-transfer-panel__filter .el-input__inner{height:var(--el-transfer-filter-height);width:100%;font-size:12px;display:inline-block;box-sizing:border-box;border-radius:calc(var(--el-transfer-filter-height)/ 2)}.el-transfer-panel__filter .el-icon-circle-close{cursor:pointer}.el-transfer-panel .el-transfer-panel__header{display:flex;align-items:center;height:var(--el-transfer-panel-header-height);background:var(--el-transfer-panel-header-bg-color);margin:0;padding-left:15px;border:1px solid var(--el-transfer-border-color);border-top-left-radius:var(--el-transfer-border-radius);border-top-right-radius:var(--el-transfer-border-radius);box-sizing:border-box;color:var(--el-color-black)}.el-transfer-panel .el-transfer-panel__header .el-checkbox{position:relative;display:flex;width:100%;align-items:center}.el-transfer-panel .el-transfer-panel__header .el-checkbox .el-checkbox__label{font-size:16px;color:var(--el-text-color-primary);font-weight:400}.el-transfer-panel .el-transfer-panel__header .el-checkbox .el-checkbox__label span{position:absolute;right:15px;top:50%;transform:translate3d(0,-50%,0);color:var(--el-text-color-secondary);font-size:12px;font-weight:400}.el-transfer-panel .el-transfer-panel__footer{height:var(--el-transfer-panel-footer-height);background:var(--el-bg-color-overlay);margin:0;padding:0;border:1px solid var(--el-transfer-border-color);border-bottom-left-radius:var(--el-transfer-border-radius);border-bottom-right-radius:var(--el-transfer-border-radius)}.el-transfer-panel .el-transfer-panel__footer:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-transfer-panel .el-transfer-panel__footer .el-checkbox{padding-left:20px;color:var(--el-text-color-regular)}.el-transfer-panel .el-transfer-panel__empty{margin:0;height:var(--el-transfer-item-height);line-height:var(--el-transfer-item-height);padding:6px 15px 0;color:var(--el-text-color-secondary);text-align:center}.el-transfer-panel .el-checkbox__label{padding-left:8px}.el-transfer-panel .el-checkbox__inner{height:14px;width:14px;border-radius:3px}.el-transfer-panel .el-checkbox__inner:after{height:6px;width:3px;left:4px}.el-tree{--el-tree-node-hover-bg-color:var(--el-fill-color-light);--el-tree-text-color:var(--el-text-color-regular);--el-tree-expand-icon-color:var(--el-text-color-placeholder)}.el-tree{position:relative;cursor:default;background:var(--el-fill-color-blank);color:var(--el-tree-text-color);font-size:var(--el-font-size-base)}.el-tree__empty-block{position:relative;min-height:60px;text-align:center;width:100%;height:100%}.el-tree__empty-text{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:var(--el-text-color-secondary);font-size:var(--el-font-size-base)}.el-tree__drop-indicator{position:absolute;left:0;right:0;height:1px;background-color:var(--el-color-primary)}.el-tree-node{white-space:nowrap;outline:0}.el-tree-node:focus>.el-tree-node__content{background-color:var(--el-tree-node-hover-bg-color)}.el-tree-node.is-drop-inner>.el-tree-node__content .el-tree-node__label{background-color:var(--el-color-primary);color:#fff}.el-tree-node__content{display:flex;align-items:center;height:26px;cursor:pointer}.el-tree-node__content>.el-tree-node__expand-icon{padding:6px;box-sizing:content-box}.el-tree-node__content>label.el-checkbox{margin-right:8px}.el-tree-node__content:hover{background-color:var(--el-tree-node-hover-bg-color)}.el-tree.is-dragging .el-tree-node__content{cursor:move}.el-tree.is-dragging .el-tree-node__content *{pointer-events:none}.el-tree.is-dragging.is-drop-not-allow .el-tree-node__content{cursor:not-allowed}.el-tree-node__expand-icon{cursor:pointer;color:var(--el-tree-expand-icon-color);font-size:12px;transform:rotate(0);transition:transform var(--el-transition-duration) ease-in-out}.el-tree-node__expand-icon.expanded{transform:rotate(90deg)}.el-tree-node__expand-icon.is-leaf{color:transparent;cursor:default}.el-tree-node__expand-icon.is-hidden{visibility:hidden}.el-tree-node__loading-icon{margin-right:8px;font-size:var(--el-font-size-base);color:var(--el-tree-expand-icon-color)}.el-tree-node>.el-tree-node__children{overflow:hidden;background-color:transparent}.el-tree-node.is-expanded>.el-tree-node__children{display:block}.el-tree--highlight-current .el-tree-node.is-current>.el-tree-node__content{background-color:var(--el-color-primary-light-9)}.el-tree-select{--el-tree-node-hover-bg-color:var(--el-fill-color-light);--el-tree-text-color:var(--el-text-color-regular);--el-tree-expand-icon-color:var(--el-text-color-placeholder)}.el-tree-select__popper .el-tree-node__expand-icon{margin-left:8px}.el-tree-select__popper .el-tree-node.is-checked>.el-tree-node__content .el-select-dropdown__item.selected:after{content:none}.el-tree-select__popper .el-select-dropdown__item{flex:1;background:0 0!important;padding-left:0;height:20px;line-height:20px}.el-upload{--el-upload-dragger-padding-horizontal:40px;--el-upload-dragger-padding-vertical:10px}.el-upload{display:inline-flex;justify-content:center;align-items:center;cursor:pointer;outline:0}.el-upload__input{display:none}.el-upload__tip{font-size:12px;color:var(--el-text-color-regular);margin-top:7px}.el-upload iframe{position:absolute;z-index:-1;top:0;left:0;opacity:0}.el-upload--picture-card{--el-upload-picture-card-size:148px;background-color:var(--el-fill-color-lighter);border:1px dashed var(--el-border-color-darker);border-radius:6px;box-sizing:border-box;width:var(--el-upload-picture-card-size);height:var(--el-upload-picture-card-size);cursor:pointer;vertical-align:top;display:inline-flex;justify-content:center;align-items:center}.el-upload--picture-card i{font-size:28px;color:var(--el-text-color-secondary)}.el-upload--picture-card:hover{border-color:var(--el-color-primary);color:var(--el-color-primary)}.el-upload.is-drag{display:block}.el-upload:focus{border-color:var(--el-color-primary);color:var(--el-color-primary)}.el-upload:focus .el-upload-dragger{border-color:var(--el-color-primary)}.el-upload-dragger{padding:var(--el-upload-dragger-padding-horizontal) var(--el-upload-dragger-padding-vertical);background-color:var(--el-fill-color-blank);border:1px dashed var(--el-border-color);border-radius:6px;box-sizing:border-box;text-align:center;cursor:pointer;position:relative;overflow:hidden}.el-upload-dragger .el-icon--upload{font-size:67px;color:var(--el-text-color-placeholder);margin-bottom:16px;line-height:50px}.el-upload-dragger+.el-upload__tip{text-align:center}.el-upload-dragger~.el-upload__files{border-top:var(--el-border);margin-top:7px;padding-top:5px}.el-upload-dragger .el-upload__text{color:var(--el-text-color-regular);font-size:14px;text-align:center}.el-upload-dragger .el-upload__text em{color:var(--el-color-primary);font-style:normal}.el-upload-dragger:hover{border-color:var(--el-color-primary)}.el-upload-dragger.is-dragover{padding:calc(var(--el-upload-dragger-padding-horizontal) - 1px) calc(var(--el-upload-dragger-padding-vertical) - 1px);background-color:var(--el-color-primary-light-9);border:2px dashed var(--el-color-primary)}.el-upload-list{margin:10px 0 0;padding:0;list-style:none;position:relative}.el-upload-list__item{transition:all .5s cubic-bezier(.55,0,.1,1);font-size:14px;color:var(--el-text-color-regular);margin-bottom:5px;position:relative;box-sizing:border-box;border-radius:4px;width:100%}.el-upload-list__item .el-progress{position:absolute;top:20px;width:100%}.el-upload-list__item .el-progress__text{position:absolute;right:0;top:-13px}.el-upload-list__item .el-progress-bar{margin-right:0;padding-right:0}.el-upload-list__item .el-icon--upload-success{color:var(--el-color-success)}.el-upload-list__item .el-icon--close{display:none;position:absolute;right:5px;top:50%;cursor:pointer;opacity:.75;color:var(--el-text-color-regular);transition:opacity var(--el-transition-duration);transform:translateY(-50%)}.el-upload-list__item .el-icon--close:hover{opacity:1;color:var(--el-color-primary)}.el-upload-list__item .el-icon--close-tip{display:none;position:absolute;top:1px;right:5px;font-size:12px;cursor:pointer;opacity:1;color:var(--el-color-primary);font-style:normal}.el-upload-list__item:hover{background-color:var(--el-fill-color-light)}.el-upload-list__item:hover .el-icon--close{display:inline-flex}.el-upload-list__item:hover .el-progress__text{display:none}.el-upload-list__item .el-upload-list__item-info{display:inline-flex;justify-content:center;flex-direction:column;width:calc(100% - 30px);margin-left:4px}.el-upload-list__item.is-success .el-upload-list__item-status-label{display:inline-flex}.el-upload-list__item.is-success .el-upload-list__item-name:focus,.el-upload-list__item.is-success .el-upload-list__item-name:hover{color:var(--el-color-primary);cursor:pointer}.el-upload-list__item.is-success:focus:not(:hover) .el-icon--close-tip{display:inline-block}.el-upload-list__item.is-success:active,.el-upload-list__item.is-success:not(.focusing):focus{outline-width:0}.el-upload-list__item.is-success:active .el-icon--close-tip,.el-upload-list__item.is-success:not(.focusing):focus .el-icon--close-tip{display:none}.el-upload-list__item.is-success:focus .el-upload-list__item-status-label,.el-upload-list__item.is-success:hover .el-upload-list__item-status-label{display:none;opacity:0}.el-upload-list__item-name{color:var(--el-text-color-regular);display:inline-flex;text-align:center;align-items:center;padding:0 4px;transition:color var(--el-transition-duration);font-size:var(--el-font-size-base)}.el-upload-list__item-name .el-icon{margin-right:6px;color:var(--el-text-color-secondary)}.el-upload-list__item-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-upload-list__item-status-label{position:absolute;right:5px;top:0;line-height:inherit;display:none;height:100%;justify-content:center;align-items:center;transition:opacity var(--el-transition-duration)}.el-upload-list__item-delete{position:absolute;right:10px;top:0;font-size:12px;color:var(--el-text-color-regular);display:none}.el-upload-list__item-delete:hover{color:var(--el-color-primary)}.el-upload-list--picture-card{--el-upload-list-picture-card-size:148px;display:inline-flex;flex-wrap:wrap;margin:0}.el-upload-list--picture-card .el-upload-list__item{overflow:hidden;background-color:var(--el-fill-color-blank);border:1px solid var(--el-border-color);border-radius:6px;box-sizing:border-box;width:var(--el-upload-list-picture-card-size);height:var(--el-upload-list-picture-card-size);margin:0 8px 8px 0;padding:0;display:inline-flex}.el-upload-list--picture-card .el-upload-list__item .el-icon--check,.el-upload-list--picture-card .el-upload-list__item .el-icon--circle-check{color:#fff}.el-upload-list--picture-card .el-upload-list__item .el-icon--close{display:none}.el-upload-list--picture-card .el-upload-list__item:hover .el-upload-list__item-status-label{opacity:0;display:block}.el-upload-list--picture-card .el-upload-list__item:hover .el-progress__text{display:block}.el-upload-list--picture-card .el-upload-list__item .el-upload-list__item-name{display:none}.el-upload-list--picture-card .el-upload-list__item-thumbnail{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.el-upload-list--picture-card .el-upload-list__item-status-label{right:-15px;top:-6px;width:40px;height:24px;background:var(--el-color-success);text-align:center;transform:rotate(45deg)}.el-upload-list--picture-card .el-upload-list__item-status-label i{font-size:12px;margin-top:11px;transform:rotate(-45deg)}.el-upload-list--picture-card .el-upload-list__item-actions{position:absolute;width:100%;height:100%;left:0;top:0;cursor:default;display:inline-flex;justify-content:center;align-items:center;color:#fff;opacity:0;font-size:20px;background-color:var(--el-overlay-color-lighter);transition:opacity var(--el-transition-duration)}.el-upload-list--picture-card .el-upload-list__item-actions span{display:none;cursor:pointer}.el-upload-list--picture-card .el-upload-list__item-actions span+span{margin-left:1rem}.el-upload-list--picture-card .el-upload-list__item-actions .el-upload-list__item-delete{position:static;font-size:inherit;color:inherit}.el-upload-list--picture-card .el-upload-list__item-actions:hover{opacity:1}.el-upload-list--picture-card .el-upload-list__item-actions:hover span{display:inline-flex}.el-upload-list--picture-card .el-progress{top:50%;left:50%;transform:translate(-50%,-50%);bottom:auto;width:126px}.el-upload-list--picture-card .el-progress .el-progress__text{top:50%}.el-upload-list--picture .el-upload-list__item{overflow:hidden;z-index:0;background-color:var(--el-fill-color-blank);border:1px solid var(--el-border-color);border-radius:6px;box-sizing:border-box;margin-top:10px;padding:10px;display:flex;align-items:center}.el-upload-list--picture .el-upload-list__item .el-icon--check,.el-upload-list--picture .el-upload-list__item .el-icon--circle-check{color:#fff}.el-upload-list--picture .el-upload-list__item:hover .el-upload-list__item-status-label{opacity:0;display:inline-flex}.el-upload-list--picture .el-upload-list__item:hover .el-progress__text{display:block}.el-upload-list--picture .el-upload-list__item.is-success .el-upload-list__item-name i{display:none}.el-upload-list--picture .el-upload-list__item .el-icon--close{top:5px;transform:translateY(0)}.el-upload-list--picture .el-upload-list__item-thumbnail{display:inline-flex;justify-content:center;align-items:center;width:70px;height:70px;-o-object-fit:contain;object-fit:contain;position:relative;z-index:1;background-color:var(--el-color-white)}.el-upload-list--picture .el-upload-list__item-status-label{position:absolute;right:-17px;top:-7px;width:46px;height:26px;background:var(--el-color-success);text-align:center;transform:rotate(45deg)}.el-upload-list--picture .el-upload-list__item-status-label i{font-size:12px;margin-top:12px;transform:rotate(-45deg)}.el-upload-list--picture .el-progress{position:relative;top:-7px}.el-upload-cover{position:absolute;left:0;top:0;width:100%;height:100%;overflow:hidden;z-index:10;cursor:default}.el-upload-cover:after{display:inline-block;content:"";height:100%;vertical-align:middle}.el-upload-cover img{display:block;width:100%;height:100%}.el-upload-cover__label{right:-15px;top:-6px;width:40px;height:24px;background:var(--el-color-success);text-align:center;transform:rotate(45deg)}.el-upload-cover__label i{font-size:12px;margin-top:11px;transform:rotate(-45deg);color:#fff}.el-upload-cover__progress{display:inline-block;vertical-align:middle;position:static;width:243px}.el-upload-cover__progress+.el-upload__inner{opacity:0}.el-upload-cover__content{position:absolute;top:0;left:0;width:100%;height:100%}.el-upload-cover__interact{position:absolute;bottom:0;left:0;width:100%;height:100%;background-color:var(--el-overlay-color-light);text-align:center}.el-upload-cover__interact .btn{display:inline-block;color:#fff;font-size:14px;cursor:pointer;vertical-align:middle;transition:var(--el-transition-md-fade);margin-top:60px}.el-upload-cover__interact .btn i{margin-top:0}.el-upload-cover__interact .btn span{opacity:0;transition:opacity .15s linear}.el-upload-cover__interact .btn:not(:first-child){margin-left:35px}.el-upload-cover__interact .btn:hover{transform:translateY(-13px)}.el-upload-cover__interact .btn:hover span{opacity:1}.el-upload-cover__interact .btn i{color:#fff;display:block;font-size:24px;line-height:inherit;margin:0 auto 5px}.el-upload-cover__title{position:absolute;bottom:0;left:0;background-color:#fff;height:36px;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:400;text-align:left;padding:0 10px;margin:0;line-height:36px;font-size:14px;color:var(--el-text-color-primary)}.el-upload-cover+.el-upload__inner{opacity:0;position:relative;z-index:1}.el-vl__wrapper{position:relative}.el-vl__wrapper:hover .el-virtual-scrollbar,.el-vl__wrapper.always-on .el-virtual-scrollbar{opacity:1}.el-vl__window{scrollbar-width:none}.el-vl__window::-webkit-scrollbar{display:none}.el-virtual-scrollbar{opacity:0;transition:opacity .34s ease-out}.el-virtual-scrollbar.always-on{opacity:1}.el-vg__wrapper{position:relative}.el-popper{--el-popper-border-radius:var(--el-popover-border-radius, 4px)}.el-popper{position:absolute;border-radius:var(--el-popper-border-radius);padding:5px 11px;z-index:2000;font-size:12px;line-height:20px;min-width:10px;word-wrap:break-word;visibility:visible}.el-popper.is-dark{color:var(--el-bg-color);background:var(--el-text-color-primary);border:1px solid var(--el-text-color-primary)}.el-popper.is-dark .el-popper__arrow:before{border:1px solid var(--el-text-color-primary);background:var(--el-text-color-primary);right:0}.el-popper.is-light{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color-light)}.el-popper.is-light .el-popper__arrow:before{border:1px solid var(--el-border-color-light);background:var(--el-bg-color-overlay);right:0}.el-popper.is-pure{padding:0}.el-popper__arrow{position:absolute;width:10px;height:10px;z-index:-1}.el-popper__arrow:before{position:absolute;width:10px;height:10px;z-index:-1;content:" ";transform:rotate(45deg);background:var(--el-text-color-primary);box-sizing:border-box}.el-popper[data-popper-placement^=top]>.el-popper__arrow{bottom:-5px}.el-popper[data-popper-placement^=top]>.el-popper__arrow:before{border-bottom-right-radius:2px}.el-popper[data-popper-placement^=bottom]>.el-popper__arrow{top:-5px}.el-popper[data-popper-placement^=bottom]>.el-popper__arrow:before{border-top-left-radius:2px}.el-popper[data-popper-placement^=left]>.el-popper__arrow{right:-5px}.el-popper[data-popper-placement^=left]>.el-popper__arrow:before{border-top-right-radius:2px}.el-popper[data-popper-placement^=right]>.el-popper__arrow{left:-5px}.el-popper[data-popper-placement^=right]>.el-popper__arrow:before{border-bottom-left-radius:2px}.el-popper[data-popper-placement^=top] .el-popper__arrow:before{border-top-color:transparent!important;border-left-color:transparent!important}.el-popper[data-popper-placement^=bottom] .el-popper__arrow:before{border-bottom-color:transparent!important;border-right-color:transparent!important}.el-popper[data-popper-placement^=left] .el-popper__arrow:before{border-left-color:transparent!important;border-bottom-color:transparent!important}.el-popper[data-popper-placement^=right] .el-popper__arrow:before{border-right-color:transparent!important;border-top-color:transparent!important}.el-select-dropdown__item{font-size:var(--el-font-size-base);padding:0 32px 0 20px;position:relative;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--el-text-color-regular);height:34px;line-height:34px;box-sizing:border-box;cursor:pointer}.el-select-dropdown__item.is-disabled{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-select-dropdown__item.hover,.el-select-dropdown__item:hover{background-color:var(--el-fill-color-light)}.el-select-dropdown__item.selected{color:var(--el-color-primary);font-weight:700}.el-statistic{--el-statistic-title-font-weight:400;--el-statistic-title-font-size:var(--el-font-size-extra-small);--el-statistic-title-color:var(--el-text-color-regular);--el-statistic-content-font-weight:400;--el-statistic-content-font-size:var(--el-font-size-extra-large);--el-statistic-content-color:var(--el-text-color-primary)}.el-statistic__head{font-weight:var(--el-statistic-title-font-weight);font-size:var(--el-statistic-title-font-size);color:var(--el-statistic-title-color);line-height:20px;margin-bottom:4px}.el-statistic__content{font-weight:var(--el-statistic-content-font-weight);font-size:var(--el-statistic-content-font-size);color:var(--el-statistic-content-color)}.el-statistic__value{display:inline-block}.el-statistic__prefix{margin-right:4px;display:inline-block}.el-statistic__suffix{margin-left:4px;display:inline-block}.el-button{height:32rem!important;padding:8rem 15rem!important;font-size:14rem!important}.el-input__wrapper{padding:1rem 11rem!important}.el-input{height:32rem!important;font-size:14rem!important}.el-input-number{line-height:30rem!important;width:150rem}.el-input-number__decrease,.el-input-number__increase{top:1rem!important;bottom:1rem!important;width:32rem!important;font-size:13rem!important;background-color:#409eff}.jt-drawing-row .col-left{font-size:14rem!important}.el-color-picker__trigger{height:32rem!important;padding:4rem!important}.el-radio-button__inner{padding:8rem 15rem!important;font-size:14rem}.el-textarea__inner{padding:5rem 11rem!important;font-size:14rem}.el-input__inner{height:32rem!important;font-size:14rem!important}.el-scrollbar{color:#fff!important;background-color:#052d73!important;overflow:visible!important}.jt-drawing-row{display:flex;flex-direction:row;height:40rem;align-items:center}.jt-drawing-row .col-left{display:flex;align-items:center;justify-content:right;width:60rem;font-family:Alimama_ShuHeiTi_Bold;font-weight:700;margin-right:8rem}.jt-drawing-row .col-main{flex:1;display:flex;flex-direction:row}.jt-drawing-row .col-main .el-input--suffix{background-color:#fff0}.jt-drawing-row .col-main .el-input--suffix *{background-color:#fff0;color:#fff}.jt-drawing-row .col-main .el-input-number__decrease,.jt-drawing-row .col-main .el-input-number__increase{background-color:#409eff;color:#fff}.jt-drawing-dialog{pointer-events:none}.jt-drawing-dialog .el-dialog{pointer-events:auto;position:absolute!important;background:rgba(5,45,155,.7);min-width:280rem;overflow:hidden;left:10rem;background:rgba(0,44,126,.68);height:calc(100% - 175rem);width:180rem;top:125rem;margin-top:0rem}.jt-drawing-dialog .el-dialog .el-dialog__header{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZAAAAAyCAIAAAD9fhrKAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDo4NTc1YTY2Yi1hY2U5LTUyNDctODM5MS01MGJjMjM4MDkxMDkiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6RDY4MTUxMzk2RDM1MTFFRDkzM0JDNEQ5N0IwQTIxRjYiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6RDY4MTUxMzg2RDM1MTFFRDkzM0JDNEQ5N0IwQTIxRjYiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6YjZlNTUzODYtMzRjZC02NDQyLWI4OTktODY4YTdiYTNkMzgyIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjg1NzVhNjZiLWFjZTktNTI0Ny04MzkxLTUwYmMyMzgwOTEwOSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Po+VQtwAACdUSURBVHja7H1bluM4kiUMfEjuHpFZtY4+/TGLmQ3MmTMbnf1MdUX6QyIJ2MAAAjC8+JB7ZHZXh7LKQ6IoECSBy2sXFwb4/X/+X2FfEqDv5dh35mXeC+k2CzD/+XfxL72BeVbv04KI7uP6ByD7pZTy6ToMnUTwv3f7rgWG/cNXrhz7AcVtUfOiwP/kOg6mLGRVoq1JUewjsAoLWJQ2RdlTg7CD+y+eJW3MziVU1dfK/wV2LIhXJpQJ/nQhOUFWWxDJRYjnwnfItkB2Z8w/yC7sr9fnXpj8Y/9d27hw/2D4zm/0/4V92EcRtq+bMP9J+AX98UdadxN8oy/D/tXdBeWAvsBQM7/FvwklxzemJ0xyfrflu6JG1T+Hc1mrhKEA/wfTQ9BfAD119x9Ca2R1ZjuEqwdq/Kb7C9vO3oQzZJ9AKdAzqDuoGVC5r3r3j8Gp62XoJaT9g3WBDK3crwwIdfB+mxUmyJP0HXNGAj/uM1zNQWTs8MChMOvJEQYMuDxdepBAQGM7810t2MHIioItnEqwbOx66GBadMSXHHQiCgBHFmDV8h+rJcQPEUaLk+WIFi5YDnyQXPoUs0R+oyTfEWvdkKFaskPYju0t1RLCDrxM/luoHejIm+0qbZ9g6+P2/snOBWDRQVPAggLOgMEBFRh7PoY+DPaJvUIYIvjeb3eG9b39tH6zFoL0Q9eHzVt6A1qOKMdYE7cD+lsBDCtdya7B2QINBEj1YZqMxSAwIKL7J3DVdI0WHbWgY4HdyIp2Z7d+lvreTa+hfHep/M/ZhZS9Gr7pbthqXsmtsdXpepS9MHXTi5xf5XIzX3XXf/tfBkmer2MHkPKdGr0SOckyXGzoO60IYIGBUcEdYFZKSuikFMBLT7pxQprYwXrifAZwtfto3pi9bVEcXVKSVcKtPYT5lSnMlOAaQMKKUobEv2UXF9a7kx4vbkRWnGsxAKxnAIRnrPAtg9FFYM8l93Pg/YA9A31zZCeJfOOBv3znykOv2KG6W/YVpu+xtlHUjlvWXGzu3Dqd6rflx/ZRkH+0vEFofssYCXAbtSNB7O6gxylGfNhRGFFJOdT6jbbFR4jEcHa4EqKrlkOsD2LKs2J9AlGKdVtucv4I9TdQpftrrH88BUSO3QVHI7RaboRWiJW7zy+zoW/jd4Ie0b472y+Q2F+AwHXuXv79f39/GiHr3pCgXQpSxaMeYOx7cxYGBHIKkHIKQhxJ6MOimxQI25jVdWBCy0Up941DSE4JAfKQtUURDcqawrT21YUUnVHkUVoJfByheE0DCGLysIiwkiEX6zwZctkHb3JHofU0ivee7aJx/QoxOTT6b2OVMCmE/0RU0SctOfsqnOz6rS9KszI5Umh2dJHWNjsFXSsw+7nIcCEtKuys2VfILxcWwIf8TdGrI3wxQpQHU/zi5JEjD8HWclhMxX4ecMHgi4ZesOgyBGsZWokCrWD5kPM9otXwbOLK9OphesYiOWvWFA3qddNbivHFc81iq7r8ZrrvJ2Jz/zjuRqnuvQm46rtmsFO0Yaql4w7U4fH5YuJD+JiWsB3Dj9HRYdp0J81LGE7nySMmPZfxflbAemw6wGW42RLMj+bZHEtcL1145NmiPEMWGKmNAwOMkYchZyaenRYiWmgpLx0xcGfXrjwXdMw5xSG/3ZJ/5LKXa0D++I4+R9gKVwwtuVrpNzj6HS7syt/Fuj+E5ghJAAblHeFxG2rhzyWNfgRrZ2HPNDDCVjQm2P4ltPk9kZUfRRmssXRMgzGIhftL7zdCpBuClYxYi02LC7KWwK+JSH4Yj5tEhZiyjLwfBaiq4lSKGonKgzUBK5xdQr5C9wfT/5HCfx5vJhcRkQtYKVrN77BMnjtJPT5pGHK4LCCKHSBidDe/rzQt2S+7CEINL4bBsX7XiNURcTdot5/18NIPXVfiFK8GNB/tGZYhiWBSvt/n8gnN7+9kEccCJSSH4Ai4fsG+stU3BzDI+OEPMS/K7GXgz0foAf6wgVkiYIkJMk2F7/NimBayADDClrZIJDCHLUQBGTdCcKAsPXcKWqODsqABuJPFJApGpx+sskHE20jmINK6KFuAbxvgmR2cCoTE3le5KAoeODNymG7ZKP/IcbdjNrEZTmzVfzMaySEojcE3QeokTnEoYVCFCSxGAT4e3uCU7i/oxMokDCzQKq8MFeTRyv1OquEZoU/pURFgisp1oFhnfiWaxgYCkkEGH8SZMJDi1kBadlvEEcol+x6q4tQ2TwMGw8ClHzF2snu6vN0nFx4mwOUAyILQNNPY4tN1WKUeKDAr/Cj/Cg3QPBnMmhxm4bKoD1PUSML8SmcCZmCmC+dUCwizumlWobYFbEWUs3o8psoXijTeElqsCBeCVE+4wFcEIQsVg9IZNC3hyZhgI7AY1LUVv9KWFJhM/SZioY23iHN1O6bsJGd2lS1VZra/AzY0/HatTsQXG6Vl75MOhoySNjhIHlCzvq6xxMEmVCXH4sSms9wKMmLFeA0bHMxEK9Nl5jehZrEerTM8BUHmaIU5WvHzCvWW06u0NC2pJSZohXJQw3eUXfOZggX1wYMwhn1xU2EfqjZfHYhv1/F9MhGbZjw9xIkrAM0GJG6zoUs5ZhUHRR+PhWCKMGscDDlaNPUUgzcf9+V6IUVLJFSLUSp+ahC3m/9f+v6+UHDoQ9EYCAewWu81rILXyrY4cYMkdHfEyjNNYONMPOLDVd3L1MqVeWGmSqVgiyJ1j2AYptSYtACA2Haz94jN1gOprhSLFbEThhIAErkEIO7TIkOhwPA3+6EQ9cNhUUnEdAvW+0A4SnYdmCiZGhdwHfZCkTMpjlDZD9t8KtlFp+4ATNSuyJjcc1T2KC/rOGQmtIs04uc7uC+0MtxK6GVFFei14VY0QFiEfZipdpiVCajl/RXU1Azi7DaS2HoCRNzlVOmFzTt949XvwlMlKqzoWYnqZIDjZRxvcrkZJiWYkuUwa90NDUi836fn67h2X4dZWHKi+JMANJIMWf1tMphlbj4obTFr7GjokGNSEo95LMIUtgAvfTct2haFERQgYAF6FuMxCDzaoR+rDvQOfIQc+6Af0XaCFPjWYDvV+pEPVmCizfvxv3DqfqgA07sb9sRjARdgfVS/UoLHR31svBBwn/aHa8WPlf8Q07rh1pM6KZBHytXSMB1cx1z+YnQoFYOygQjMhB6RGaZ4ed6jkIRgmuNUihYrWg0erdoxYM7+AlotFAnqZQUxOej+2QNfDa0QK5aOiFZ/gKVp6eGTM9Xjt5UJihpdrYfsFbjKHxWHAAtqStYeyUKv0Zj+dB36DoCcpVHAQd+DV2xaFnz7mEyIZ5AmpeWV2DCQHS8rCcOzDGaZkI7uDmEW6Vl2FBIjI8mU+IxFetgiRZ94n2LUA1Cu5peAm8IjUgA17nnx7qqIXLGXeG0fU9sHYm5eozMNJg9kmldiOsn516qC4TGjS/JgwEQWxYY0iqWqDbVYK2tnpddKJPeCl4O1nbG0TImKmSyOdWJxUuXZ8aFMVp9Ej6/7G3MWUIv4ivFELH7H+UsyIBf0b3qZzt8NmPC1TaiKLlZBZkuDVqjWAcFuxP4pRSseyWJlWNAfjmxQ0ysQTcvFdX6t1OW3fMyxQZ8OhO/YstLtM6xtLEuCAshgEkcDWXbo0KBJMnDDBHIb0M3Xceh7mQwacg0+CEAx1lsDNYN1Xn2nb2/3ZRz70WEWRHaUR4jZaVgY6SU5/KdZRRjSvDH7wUR/wyCQJe/bWI9WQ66oka8RIUMAiD67YDFksV6ira3UD6E+BhLHBDBvIomCE4Ij1vigaFbY3hh/y0+zRLBsH5Ect8nUjo0MZKcTY3NMj4gN8QsTXplrzFgPUhKvQC42p0JVWVobpxjbWiFNWrOVzmkIYhEAZo4EZw1dPhC1R6sLmv8hVAc9c90qPTUTA8r5DbQSVZP/GjF1epXYGSVtaZen4WsHsA4oVbgl0kc6Zv8MUkrrRZiUghSzwqGUJiv8FXuac4NxxKuCWVl4aPe72LlE93mxCIP3aca+uww976xHYMsAUkeeMhMeLkyLYtw1nUyUMAQdmVGIFpPBO0g4R2YchsTXtQ5HYsmngY0JZJxLeDK4WiYgC+fdxvVvwTggMW/7UNmF6aLYjuxYfh+Moj/E5p55rzBy8Ky1MLkwfw85ugh+UrGqaRzBL0V5IhBHNzBUOF6ZFmxhJU5JFHRRM3ChyKV0kUlOLFa0rZogBvpV6joCVWzqDCw3WO4GrcRqtnrScvScvDaMkGIU307AZ2mawIo1awW6/qJ6O+aYjH4WV6+lTNQC9w0w6wvqdHjcBWqerHwECq0MDzS9ZobJYgp3ZoEnSuZBcrPB42iBJlItZM5xfmUhkhZYA7r+Ns3OFzUtNPPIY9YGbHE6sApMvZ1UeafpRrhq2SH049okePiARMLw4lIAL2+CwGAYxSihQxwKTQbbgJ011EZTEmoAcVQxzo7wY4eiFo1gHtIhYh7YAVblTxRYcehAnYwgYJPwM+kzfx/tEsmbvLbpr4oZfuifDeysoer+wvwnDfE3g5u8f2Y6OvPclsyljPKCkkWRoOhyt0DFXZXSGdcXlg+DVqFwsi/IIYw9J7/dGBB0bUfdOppvqEVuTGWiVfesB6ptKwKsq1e1GL3p0jrAsKLWzW9wLmPhASeE35nG9WiqItzmmd/LBLNMQDfRCRPQ+EaZ+rASfYYNLNJbwiwraaEdXnHOCRNpMmBKzYIJT0oIlzWoyvuiHacOdxWCuB4mzMTJW4nOFWLGCF7pYBRzKXD+hWGnAsICPEM6oue9W7w34THCvTHf5SxZx5PbDz5Rsb3bkXrioYd2qz6lnbIYjShoVKmgi9b0acyIp30nSbSGrjL8V8BNIue75mDYkJoCoBDxkSNW5nLvo5UkT/yHcEpO6hwL2K/6b6K/rA6JClDhgYaHVVfABnj1BzlU3XNQkqzcDRBVGYrdCFTgY55pvJYZHSJh0po8oQ5ooPSOlkJLgAp6axDxeumtFZ5uyETWCXwaRyjHgJyzPM4ByglXJ+DSy7stAeIMU4xhIvg5oOEmQp6IghEBhBBCCREjx/wWOgTiJ4pMiq8RaEgTNZz1JW37m6pTnOEMhMGmEWx746PGmkdk2WzAZ2e0HUuUryBUVfAqQS3wF9nbSLDjc4MqlIr7DxjsyOkN1OIIEUppw7Qh82okgSd/yKVfyflNqpufv5Wq7KsPVSJNZh7Z3Kl8TAL3BpMfe/WfuvEbnsAc19ZJ3yOZ4ccPa9bkGBSAyZIjUtBX/3qCSpXRw2yH3lK526Jc+cus3jWNQoJzfmKpH6/IVRAuh1n95CxagkndGI0O6wgiJBHOqnuDV6OK0EzkdlAGupzeBh7lpHRZPLggxqxRAn+AFlV9KgcF8W0sOGhiP96yP9no8djVEJsUoKQPmDHcAqRSllZKQuQ5IPtCJ1JOk5ujcs+XC9A0KU1q9o/VTnWJqFSyqhaxstbQN7ncc6s741ZU1eEbTWbG2nAg7t2kDXp1GrCSYReoh4TbjyYW9jByxNUW4kHP43BfFhqP416H4KhEpOk7Gp+crbROtZpsy7C4a9/d7Pij2dcAzjtSUVIyACiTiTCsCFFXZxX9SSwmvgRgNIrxRwZegXn5CxbAy2teXCjn/IsBNwsMRRxQDUOWaazPGJmom+MqTKe1s6i5FHaHXDAxdjSfZAefbdtjO9sqRHV/qPgudmgjxqmKUNGxMm6CdUcRZrQMc5BiGKENBHQOrbASVWFuSk06vFYWrRYvufc2Euwy2wH3WGEWikZzAxVl0UpkM28i3HVXbcvPoRMrcWc9Kj/+9Dnnwzry5IQ2Zomq+LXyF8KUwZAheZ/mKOMB8PDQORWeiJJBMhWw9D2kwz8UgUthMOtu0MoG4d450TtbaUKpMoWLcS53LHPwsTO332b+g6hkIRTBMpefgcdqq8GCtTsoc/ghcNMApn6FypjgCvIC6mmudjnLKennBCU5ecQjT1k8+ZOW4HWcNmI+Oo9lbFUFstT/WTHxYq4cYTcSt0KZKWIlXytN8zZRFFlDPfe5rBK4LghdVgBmDIuK6pwEJnJraMA7pMnMV+2n9TTQCnG/gT3Ok0+EhFsToUVNzCoHiZidU4LBLJK0bjQrMEkesMIWwEqOKAuqDIbPQoxnT1X2OLVW+O4+WS+ozWxDVvih7zvws5UxyWNTm0kQQjea9oNioudYbpVKfVJ8XF9wR3Uy5TKQMiZrMU9DRClg4335nYYGSgFUmkU546r8Nkxtyaa5ZGUC7Nz96v6t7aIyKbV+lPIn6cDpVgnVw7X2wdzqpetDXylyYdkVOWyl7CiOsl3IyM5mHdVxKnMMrKN4s1wMWik/zc9wn6sFvtKBgQW3S6bjmKI6MlstCUtMJHZJLvZ+jLkLt9Fq+/nBc5N8FrCwkavveGBYbC80+FWutvP4ZCfHt/uEGvPgyB5LUeIr7CqD+QXbKgY3zR+DiQagboasadPs1IfWhmcNfZdoWJlchKkRwu9mqJ6JESfL+9bWHow/btoKBPk+72+BOsYLBd51EHP9CZ6lETMuloBYDIErwyDVprDdPrI5vVgkOWq9P/IIPVjO9semovRogYjtjRW2VSFVWCN+WAwL5mN03BNwNWhFG3RuW03izAwf3SieJoeUWHO6CdU/CWlzOeRDmY0AUGS2We2Cyhx2HHEzR7v8roNoVUrseKxl7KpX+ABgcR4koFQNEsxqznfnuVFCT8x+yNKzZVZk5hd9smb5vDLMLs/dAbnt3v4ldjarkAQFsOEVcbmrWrTL/mS0ye7vk4rPniwNRGqPggihMXrlwI18HDAHKEhd2lAMswtRptvHhgiFNcnpSBIF3EztUOYthk0hbEM/2tCnWukcoK277Ra7e5VEKyVKYbMSMQNaBZ5SM0FoDXp4sjmOM3cw1jTskrqhz4bqDi0RHPepCVVZYIiVM6P8CuPzmuU9y7EVjG8t/MdCad/RCo6hFZ4OCc8PIO8NG5eYdZvUnXIuhPAoWpjJDHXpx76LFwViGJVJrPlIov/e8CE7P9qlVKYg0TCudlDJ8CZNehXwC8Is1liLkGwP02uHmIOsiIlmipCk9HGJIidpYV/AChAkOUiTjIgs711mCYN0lLNIQ1oLlwW3rSTWxNp2URwUoTEqB7VsL1D0lXTkBCE95W37FbsgmOUmbJAsgaK0QebyFFZOByu2hyhKlOGeaKf6ZMRHw4D9C9lEcTE8S06vujcIOKSzeEoZqyqHU0NE+YSDpDmD2WIZ1K5VN/3Q3RNl46tEvXhC2dyXT/FhDasJPznuiE2exakWwywT6H3cab5OktvXN8K+k7Q6Tj4jmvdkyJNGBsnMZz2YFj3Ns7K4YOK5y2BFdxS5vsZM862Hc8gX6JKUQvZcTrCWJXthaQCAz5CJxApZsIciW0YIc7isdKZKVFjLebCT/a6aL6GWGXd3GgXUdJzyPWw0zloNoWa5Fzmgi329t9WxzgUplVwCmOdbqIANf5Dod+gvdtLMBkhhbXzAcy8YoAfKdaUXsUw03a9/CtOPMZsSVD/v5DsNF4NZ3fSHsGJWUn2tpDIHUoRZ0InD8nqJ4J/0pRxjWHjU0d4IHDDDLEN8XJaFJE+m7+WDW8JnYzA7S7fHx/j80/U2zwawHFEywHexqSO22l8ZWjKVyZRzV2omHwYKkSZ9BagkFUe+gg3E7HcpdeISdAWReQIErmQlEnLE3Gya3iMv/MS3x/cR5+1U+BPK3H7I46Z81p6+k/OxQujxd3ghkVsqaxaVB0Eqe2Bo0RHPwndKqqdMgW+yWwwVQoBK1dpQxeynvRq/Ww/qvWCUKOcPA4uqt8FsKwzcGhHG/cv+IGDt+WgSHf3Qz6O6ZEiKiQSVc/1DYByr/D0OPVkZoKmF1YplUAVonjS3ZVkIXOzSXkN3GX1i1Wpa8SQzShYJWkVT4X1Wi8s8k156nhVUlOv1IE+7VxqF0gm5KVEFwGRr1jSgblKqDMtycnTKCYXHrOdiM4dnS9jaaGDbrvcjVqwjRxENh1ruvMIkC01xZXErCMIKVPGWa5q+fpdEW+J0nJyLYK3HJ8I5YRaSt/2D0vVpO25oMCtbpWYTp/hhNPQ4fpMTgLpVfrvcpV7IimXqvE2jTyVmOOxceSQkPB0bhmtheMq83OcF+SoyEH95HbqrAxcshr22YCsSk2XBm4nc1LryoCnQzabO5ihB3gqbwa8piuA1DCqloniZHymP5yCBLpHYqlBUkoqKQn7HjTpCNjdxe07fWSfU2TmJu213e4mn4673I/U5mPm9PtbHODSyYBObqCU2+EbT1uCm/N0Is9zKXfVflzJ/VhqgzczXLR/W9X4HpZUT9RvCXAlVKcBKZTBr7uJiq5we6MWEjdrAljkEdIemamJtXtmW2vDJkPAx3T0Fl0Vpw1MmZ78sVFiyTQ09raZTldghs97Uqzk5CV+vdIfQqu8SjZytiZPKQ9kzdd3bxICGrPFlXIJ7NZtIA4xUlY2YLQ+RZrKCjWud5bfL3sY1Lb4+KPr1arCPkvI0o5qG36IeFS0zmIDOhFrdRbQTrOLm0hhIijjYbDAa1NQh6U0GB7cEsupEGj+mQY55w9+Wd9TlUdFimbKu92FniAPxAUf7YwyrETqJzdiwHCo2UKJMGOgn5XGvlX3XSfl06Ya+q1A2n4evrulCSMsviLstyolWPZBoZTX7QqHHVB1PleCgYZmazospcEGsqeDFslIY85pm05DrRIyFnGno1zDBQf4M2EjP8cCz5fO9G35m+X8BWNXPBkUtrKqB3J7PO0cKraV+050yoda6jncp7Vdni7LPWl7FADC909ChWqR+FR3BFgpZ54QNW1l4q4dn4hKL85TmR5XLjXyS4zMdt41Wpy82PgBYZ6bLb9vfHZTcbLKXPGSyb/uOsmX1UlbCTN4OIGUUTJNSdIh5nZloE4f6RMkF2c2MEal2HhoIha6TmgMZLBJyYmEyh4L05USswqegGjnklzcTs1p3B44/sHiEA5sL11eZelWmqu5/ZK345orxj76gfeiNyYQHw0aWB34/LK3pXFk3jhEomKck6HehFeUyZpLWIe+431XDKAbZza+gZ1vgm9XI7OzCwzjFi9X9BcDZHWZRRA9mY3f/Q/SuzrIJzQcHOg60gv44MLW+qpMsu4lWxpkWytvX8JTaAUGPVjG/diW3ZKbVBPVn1vo+LbNPwWxiwKdxoOmH22pXJtUzVFpIYrcqmEi9YZgDZco+sSRighsgdtOmQyaOQ1yTFFpaSQZtojqvqJiXgmxjdVXBZHSKz9sJBB8gtka2Q2Uwvz2T50S2qnLWULtwTGtbXTMxmdBbu0QHKMF2KpVKYFjrnLEeIafVTSpF4Vg3tPVEbFaHWkuvhu9SvIKdxgzzh8EsNbxg1MiwyYGwgriUV/7yrfNDh8U56lXS6l+i0i+OORjw6ODgkZDwXARQMqN50WsamYokj26yyxNN0gOBVb26mNaTA6JBFn2b5yBaDUP/vGr2KAAqFxfaiqmFuHnSVgXLGBmnL1AfWhJ1CzqKRk2iEgk5LysXXqjhWnEfYGM2S2aPxWxNp222EYxumoVFNYnmgUlBTQ5X3DinJCazTnGr8Gq1N/bE0hNbUiRo3sdC1cYd6G3zOJrZp/6gUIskLWhL+yV8+V1BquGbFNKuz2xiECdpvawZrNp8qv7coL49WLuDlMtH9daa7WCo3PBijWAHiBUbADuFWUcWoajj04aehda78GHgJNONg2nIoNXQPV+GZtNOO3nJuQykGGL1MS1hcayL9UM0L3uJGmn9tc3DdbNJnKHiVQ2F5E0tXdXmKJAxRoQbD+forirjTcECT8RzefV2Ap9jfOin6UWHdI1Thi98qFolHOoDkCRaeYLZt43RRr4GDS2r1S+pAlU3SDTwizALSYanoUOhlFR/iOHJurTkgcGFgsFBZzCLlkxf3vMUo+tk7KnTCw7fRHfRZXh4JBh8XMP6xEtR1lCS2JM6MBphut86ILg1fQxbQGPAS9tI826Xt6GpmTZpHy2fkyQ2SDt5uawmbx2UnXmenQoGdcjn+dmrpyYKrYy5w6pcCXfVQww+1a2ui4fUzUPyT4KPWJH095+HrX2SpSK+6JWtT5EVDnztyXz1sc9VBvER2N0FiLRYks8NBHQ81MJ2eZVy7EKE0i57o0mUn96sDP9sC9yoRusj0JLOVOA7CFXjerq7/9DDM5Dj4euxZQ+wiuG8xrfxtVjX0ryoFiOTkhZtNvRquxwhapqXAxdafpXSgLrfdlIaptb3sBHrVfwB7GLPBH8+dG3oDlUU8ws0ayhWOcuJD1ak5nwAYaOVAx7puzvi44EYP1mlAo49Dzf2Sd2bmKX4hXOaQ6N1NNa/SD+2ltIol7eoD0VUq3cojT3iQcirajqmdvNdmqZpuJKVtHD7oVWNU8nZAHJ6FZp6JSzW9jW+RNvXSdg1oSUtezC/0lhkRfgSNkWXUiNTzeoaIB5F+UcZViM29AIQpa8yYaBuNva+k08XP0Nwo6OCaA032MWi55CfyBT4fLVzbtLHbHuIh0MYwYC13S+6EbXBtk4BqbyYS0pBs2jEKNC8SblJO2eLmyu+PUZfHo65Ho7IPj8N6EvqeTz7YO74PXB8bPbJ0k5fy6jlJS39TxPf6f4iBGzDU7XZazni+BuN9Nn8fLTU4E0Jg1mmQISj15P7J8iaL+X0B+i53oDVvbstNoXWRZTDcY+ilXl1f/8f/+fQo7uJJS60x2kitEJs7mxw6sUm/dwOglrfart41/stHsKU9Xwdu2q0DBUqlNeZbPcktCFurrN4dBvDISzoVmNqFWD726zc/6KWpn/JF+7lLMd16cA85MS2nrWj5KAd8gM78bg+utLy2fuZ0pI4GhkdLM8y4aG6U5sysSHA+cCWfPVCjiZidQXW+og5xI26nuxESFL6uQcPoDobZ1biN7cManQtFVWg8bu+f74OsL1OQftbskcEp5WdczN23ZMpsFS7anythHMT0X9MNDs616NKqo9Qj4ZbQNZSlPJhr4biDq1blYW3B7D+1+vLEOpAXFwfIdWPcMSGhEQ5ZPSC/bOQ/S5C1YLNTo2/CfFKsw4tdJKkZYf2cr3piOuV3O4dXn43PIsvWpH92ESOAhfdf3My3Ofly/7Q5awjEdgw0MRok9bYCusMulyG7skPCDYDt3ZU6MJA5Z1WNk9p/3Tpd5577eeGKertvkTRih0RK1DUQKeaAoV7UAK7T+m6hgWNFAK/wOunw9ODPOtIqZtTqutaLrm0KNQK8hCeOwtSzUnSIncCtX/rVl/U5TdaE0wcwqm0E0h1+V3AD1OOKNF5lbToEHr8rkiGg58PWO1TuM+LgZKNLiMNWo1+hmBDmm3mXLZ/5sVFmhgKvI6DHRDc66hY84zbRXTephmx6kwvbnViJoQWfxQbcJaVcyYchlN949c8wv9UyIbtBz9ugtg2sKGVtG7/VG15aLcyZHcgBeqN1qAn3jH3t3+o4beiQDzYuAxxQ+i6+U20GKVe5O0fOH5HK379fMAqerehVB/TdPcpXCrhonMbXNIBwRZXrSEXUk6r5WOKgNjR+mDjMMidltFAAeu0IutWGcU14WKbaycCaGvZLAH7I0rH0O0Xk/oLkQmOjR5ud/At/wmeePCg6u7/BPWih+fcVAWHRjN090wJv0k1t92B7Aj/Afgtc2kdfwiauJLmBJsCUbVmi6+G+PEFoXv4Qds/cO9MMPV2CzFarmqtKUMNuDiJ/fgQNUMujWiIVZgeKOyA4MuVkqrvx0Glux1dgtPZ5oqAY0/JDZ0bjksHtWRKsF3j3Zw+p3EL/nT+Be2nAB77yfbHLyz50PXBnbykR4ZNTtPhHdGAco3ioofvO/2/UQwlDrx0BviEXjkBTK/QKcwA5ThmUYYs2U0/nN2hqunZZX4mikDlg+HhOcBy67+/TxPiltA1kNvAgstDUsuiVHRa2V/0fWfQSsIBbKrdYFLBDMLyyR01negw48cDJwJnpIttgBON9RK+WpT5E4Kl40s6f2YtQnGyKPyiM8SvukxHi5LLfVWgilTLW304TAQ1+HT5m7z/sHYHl4Dhw3Audflet1Dt1Ra7UV3/1q0FNhq4XvqPf5hDGDb3AGYdsDUEBEVhSArFaLglKhta9e3pIuWBqtQggjSmSN/sgODQPz8NUC5ceuxKzrZAvfEQ3C0Pzj8K4Iv3+/X6VxK4HgG4RgMGJIOCgRo7DAe7vy3GwIHyMZh/9ZIUCJ1N8ACn6k9eDvJPXIJ/onWSZKqgSSrDqc51wtagNL7ZjFZ5XdOEwmPfv1yHo1ZlzMWg+7x8cBUf8DoOmWZfzrHYuMW3UOCGnWo/1sDTcIYPNesvgK9treVsOAQNEotbttctblhmkoF2lpvqQbEotrry9cEz/dLkNp9nsrsOr/p2bSM7ZdNXPZDREdZJgiG/KGlk/yHwe1lgC6dSEHRDh3/YqddNKmoN8bMaf09yPHw+JAwkBbGd2Mx2WwMuT2N/JlqL+66L6Ni5x2FlwKeLHRA8pnyVtz5RwfCEHHTunuNJV+fGI+ULYjc8GZKd9ZufNdTjsXL2AkKopk/HM+e1a4v8OZHzTxjhrfq27OQb63h4SIFyQ4edKcRXuLOSfCwQT/Q+KnAFwbfqLBGPlHN/+39qLAYoHwYscwjDULKZzOVOkiT2YV1DsFlSs0KLxne7LkVS4MXEgg+OgCbzDc83lyPmg0+kJv6ijgH/ncLJv9C0keXi+vk1x0eLIlOVVqcVqKD59M800nf/4ewOlgRZSWv8LSvwoP/TgmDfTT/EhoHWDVDqFzV+O4JZWxqWpjAwGaqrXyYJ3wy56rozcU3cycSZbx+TinmjaT7zt6dLZRJPK85IX4YPvt5mrfVfoBnBA/X9RB8+wjAOrb/0ic6En/7JLh3ELzovPEDpML28eIC2HrsAcNa39VgDjApU/0AtDb5gdwE1gYeYtUDZafkIcbMFDrBMsIn1JjaUlJdiFJsuLVrStQVY86JfOetpMbSuDS4HOqjhbm+3iZ/KYDX7TsJDV4eSZL3f5p+COn8F0ok9XefX68+hd3AcVfBPq1TzK5rEBwI3nOXtBTpJNe+vJJmjih1ruQk3G/GBChr07A0IzrA5UcmAEc2XlP0G1DZF948pEb9bL0OrXi4jwIFLCnWN6e5EK7/rZbBTDh+6gYaivVNSK/VpFMIvw5gvPSb+Jf3i1+vPu9rngHEn7pleBU2I+W3XWV7JvQNyuf7eTa8kw4e4Z/pheJAev+8UiHWepa5/l5OdwbNNoG7/EON3sqG2GFK5JI9hKNOidq8IgctlAHjksUPB5n3KNKansb9eBmhGyFsAobNBzPI3B1dmgD+hDVeHun69/lWZGZ4Zf8RzrW+zYC9p/a7lA1owOFGJZi/HAp1L63e3pMU5LyBITVOvIUmyXFWpbNYaC7WVAcr/L8AA+dSd3OMf2BsAAAAASUVORK5CYII=) no-repeat;background-size:100%;margin-right:0rem;padding:6rem;text-align:center}.jt-drawing-dialog .el-dialog .el-dialog__headerbtn{height:34rem}.jt-drawing-dialog .el-dialog .content{height:calc(100% - 120rem);width:92%;overflow-y:auto;padding:5rem 0 0;position:absolute}.jt-drawing-dialog .el-dialog .el-collapse{--el-collapse-border-color: rgb(0 44 126 / 0%);--el-collapse-header-text-color: #ffffff;--el-collapse-header-font-size: 13rem;--el-collapse-content-bg-color: rgb(0 44 126 / 0%);--el-collapse-content-font-size: 13rem;--el-collapse-content-text-color: rgb(216 240 255);--el-collapse-header-height: 40rem;--el-collapse-header-bg-color: rgb(30 130 255)}.jt-drawing-dialog .el-dialog .el-collapse .el-collapse-item__header{background-color:#409eff;border-bottom:2px solid rgb(22,90,190)}.jt-drawing-dialog .el-dialog .el-collapse .el-collapse-item__content{padding:10rem}.jt-drawing-dialog .el-dialog .el-dialog__body{padding:10rem;color:#fff}.jt-drawing-dialog .el-dialog .el-color-picker__trigger{width:120rem}.jt-drawing-dialog .el-dialog .el-body-foot{position:absolute;bottom:8rem;right:8rem;width:calc(100% - 16rem)}.jt-drawing-dialog .el-dialog .el-body-foot .el-button-group{display:flex}.jt-drawing-dialog .el-dialog .el-body-foot .el-button-group .el-button{border:solid 0rem rgb(255,0,0);flex:1}
- `;
- const _hoisted_1 = { class: "jt-drawing-dialog" };
- const _hoisted_2 = {
- slot: "title",
- class: "header-title"
- };
- const _hoisted_3 = { style: { "line-height": "24rem", "font-size": "16rem", "color": "#fff", "font-family": "'Alimama_ShuHeiTi_Bold'" } };
- const _hoisted_4 = { class: "content" };
- const _hoisted_5 = {
- class: "jt-drawing-row",
- style: { "height": "60rem" }
- };
- const _hoisted_6 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u5185\u5BB9", -1);
- const _hoisted_7 = { class: "col-main" };
- const _hoisted_8 = { class: "jt-drawing-row" };
- const _hoisted_9 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u5B57\u4F53", -1);
- const _hoisted_10 = { class: "col-main" };
- const _hoisted_11 = { class: "jt-drawing-row" };
- const _hoisted_12 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u5B57\u4F53\u5927\u5C0F", -1);
- const _hoisted_13 = { class: "col-main" };
- const _hoisted_14 = { class: "jt-drawing-row" };
- const _hoisted_15 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u662F\u5426\u52A0\u7C97", -1);
- const _hoisted_16 = { class: "col-main" };
- const _hoisted_17 = { class: "jt-drawing-row" };
- const _hoisted_18 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u662F\u5426\u659C\u4F53", -1);
- const _hoisted_19 = { class: "col-main" };
- const _hoisted_20 = { class: "jt-drawing-row" };
- const _hoisted_21 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u989C\u8272", -1);
- const _hoisted_22 = { class: "col-main" };
- const _hoisted_23 = { class: "jt-drawing-row" };
- const _hoisted_24 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u662F\u5426\u8FB9\u6846", -1);
- const _hoisted_25 = { class: "col-main" };
- const _hoisted_26 = { class: "jt-drawing-row" };
- const _hoisted_27 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u8FB9\u6846\u989C\u8272", -1);
- const _hoisted_28 = { class: "col-main" };
- const _hoisted_29 = { class: "jt-drawing-row" };
- const _hoisted_30 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u8FB9\u6846\u5BBD\u5EA6", -1);
- const _hoisted_31 = { class: "col-main" };
- const _hoisted_32 = { class: "jt-drawing-row" };
- const _hoisted_33 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u662F\u5426\u80CC\u666F", -1);
- const _hoisted_34 = { class: "col-main" };
- const _hoisted_35 = { class: "jt-drawing-row" };
- const _hoisted_36 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u80CC\u666F\u989C\u8272", -1);
- const _hoisted_37 = { class: "col-main" };
- const _hoisted_38 = { class: "jt-drawing-row" };
- const _hoisted_39 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u80CC\u666F\u5185\u8FB9\u8DDD", -1);
- const _hoisted_40 = { class: "col-main" };
- const _hoisted_41 = { class: "jt-drawing-row" };
- const _hoisted_42 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u6A2A\u5411\u504F\u79FB\u50CF\u7D20", -1);
- const _hoisted_43 = { class: "col-main" };
- const _hoisted_44 = { class: "jt-drawing-row" };
- const _hoisted_45 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u7EB5\u5411\u504F\u79FB\u50CF\u7D20", -1);
- const _hoisted_46 = { class: "col-main" };
- const _hoisted_47 = { class: "jt-drawing-row" };
- const _hoisted_48 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u50CF\u7D20\u5927\u5C0F", -1);
- const _hoisted_49 = { class: "col-main" };
- const _hoisted_50 = { class: "jt-drawing-row" };
- const _hoisted_51 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u989C\u8272", -1);
- const _hoisted_52 = { class: "col-main" };
- const _hoisted_53 = { class: "jt-drawing-row" };
- const _hoisted_54 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u662F\u5426\u8FB9\u6846", -1);
- const _hoisted_55 = { class: "col-main" };
- const _hoisted_56 = { class: "jt-drawing-row" };
- const _hoisted_57 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u8FB9\u6846\u989C\u8272", -1);
- const _hoisted_58 = { class: "col-main" };
- const _hoisted_59 = { class: "jt-drawing-row" };
- const _hoisted_60 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u8FB9\u6846\u5BBD\u5EA6", -1);
- const _hoisted_61 = { class: "col-main" };
- const _hoisted_62 = {
- class: "jt-drawing-row",
- style: { "height": "60rem" }
- };
- const _hoisted_63 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u56FE\u6807", -1);
- const _hoisted_64 = { class: "col-main" };
- const _hoisted_65 = { class: "jt-drawing-row" };
- const _hoisted_66 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u5927\u5C0F\u6BD4\u4F8B", -1);
- const _hoisted_67 = { class: "col-main" };
- const _hoisted_68 = {
- class: "jt-drawing-row",
- style: { "height": "60rem" }
- };
- const _hoisted_69 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u6A21\u578B\u8DEF\u5F84", -1);
- const _hoisted_70 = { class: "col-main" };
- const _hoisted_71 = { class: "jt-drawing-row" };
- const _hoisted_72 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u900F\u660E\u5EA6", -1);
- const _hoisted_73 = { class: "col-main" };
- const _hoisted_74 = { class: "jt-drawing-row" };
- const _hoisted_75 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u6700\u5C0F\u50CF\u7D20\u5927\u5C0F", -1);
- const _hoisted_76 = { class: "col-main" };
- const _hoisted_77 = { class: "jt-drawing-row" };
- const _hoisted_78 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u662F\u5426\u8FB9\u6846", -1);
- const _hoisted_79 = { class: "col-main" };
- const _hoisted_80 = { class: "jt-drawing-row" };
- const _hoisted_81 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u8FB9\u6846\u989C\u8272", -1);
- const _hoisted_82 = { class: "col-main" };
- const _hoisted_83 = { class: "jt-drawing-row" };
- const _hoisted_84 = /* @__PURE__ */ createElementVNode("div", { class: "col-left" }, "\u8FB9\u6846\u5BBD\u5EA6", -1);
- const _hoisted_85 = { class: "col-main" };
- const _hoisted_86 = { class: "el-body-foot" };
- const _sfc_main = {
- __name: "CrEditProperty_Point.ce",
- props: {
- params: {
- id: {
- type: String,
- default: () => void 0
- },
- text: {
- type: String,
- default: () => ""
- },
- font: {
- type: String,
- default: () => ""
- },
- fontSize: {
- type: Number,
- default: () => 24
- },
- color: {
- type: String,
- default: () => "255,255,0,0.9"
- }
- },
- showDialog: {
- type: Boolean,
- default: () => false
- }
- },
- emits: ["submit", "update:showDialog", "update:params", "remove"],
- setup(__props, { emit }) {
- const props = __props;
- const language = ref("zh-cn");
- const locale = computed$1(() => language.value === "zh-cn" ? zhCn : en);
- const {
- proxy
- } = getCurrentInstance();
- const predefineColors = ref([
- "#ff4500",
- "#ff8c00",
- "#ffd700",
- "#90ee90",
- "#00ced1",
- "#1e90ff",
- "#c71585",
- "rgba(255, 69, 0, 0.68)",
- "rgb(255, 120, 0)",
- "hsv(51, 100, 98)",
- "hsva(120, 40, 94, 0.5)",
- "hsl(181, 100%, 37%)",
- "hsla(209, 100%, 56%, 0.73)",
- "#c7158577"
- ]);
- const selectOptionsFont = [
- {
- value: "Helvetica",
- label: "\u9ED8\u8BA4\u5B57\u4F53"
- },
- {
- value: "Microsoft YaHei",
- label: "\u5FAE\u8F6F\u96C5\u9ED1"
- },
- {
- value: "\u5B8B\u4F53",
- label: "\u5B8B\u4F53"
- },
- {
- value: "\u6977\u4F53",
- label: "\u6977\u4F53"
- },
- {
- value: "\u96B6\u4E66",
- label: "\u96B6\u4E66"
- },
- {
- value: "\u9ED1\u4F53",
- label: "\u9ED1\u4F53"
- }
- ];
- const activeNames = ref(["1"]);
- const title = ref("\u5C5E\u6027\u7F16\u8F91");
- const dialogVisible = ref(props.showDialog);
- const isShowLabelStyle = ref(false);
- const isShowPointStyle = ref(false);
- const isShowBillboardStyle = ref(false);
- const isShowModelStyle = ref(false);
- const label2 = ref({
- content: "",
- font: "",
- fontSize: 0,
- bolder: false,
- italic: false,
- fillColor: "",
- showOutline: false,
- outlineColor: "",
- outlineWidth: 0,
- showBackground: false,
- backgroundColor: "",
- backgroundPadding: 0,
- pixelOffsetX: 0,
- pixelOffsetY: 0
- });
- const point2 = ref({
- color: "",
- pixelSize: 10,
- showOutline: false,
- outlineColor: "",
- outlineWidth: 0
- });
- const billboard = ref({
- imgUrl: "",
- alpha: 1,
- scale: 1
- });
- const model = ref({
- url: "",
- alpha: 1,
- showSilhouette: false,
- silhouetteSize: 0,
- silhouetteColor: "rgba(255,255,255,1)",
- minimumPixelSize: 1,
- maximumScale: 1,
- heading: 0,
- pitch: 0,
- roll: 0
- });
- updateParams(props.params);
- function updateParams(params) {
- proxy._params = params;
- _setShowControls(false);
- if (params.id === DrawPoint.DrawType.Label) {
- title.value = "\u6587\u5B57\u7F16\u8F91";
- activeNames.value = ["\u6807\u6CE8\u6837\u5F0F"];
- isShowLabelStyle.value = true;
- label2.value.content = params.label.text;
- label2.value.font = params.label.font;
- label2.value.fontSize = params.label.fontSize;
- label2.value.fillColor = params.label.fillColor;
- label2.value.showOutline = params.label.showOutline;
- label2.value.outlineColor = params.label.outlineColor;
- label2.value.outlineWidth = params.label.outlineWidth;
- label2.value.showBackground = params.label.showBackground;
- label2.value.backgroundColor = params.label.backgroundColor;
- label2.value.backgroundPadding = params.label.backgroundPadding;
- label2.value.pixelOffsetX = params.label.pixelOffsetX;
- label2.value.pixelOffsetY = params.label.pixelOffsetY;
- } else if (params.id === DrawPoint.DrawType.Point) {
- title.value = "\u70B9\u7F16\u8F91";
- activeNames.value = ["\u70B9\u6837\u5F0F"];
- isShowPointStyle.value = true;
- point2.value.color = params.point.color;
- point2.value.pixelSize = params.point.pixelSize;
- point2.value.showOutline = params.point.showOutline;
- point2.value.outlineColor = params.point.outlineColor;
- point2.value.outlineWidth = params.point.outlineWidth;
- } else if (params.id === DrawPoint.DrawType.Point2Label) {
- title.value = "\u70B9\u53CA\u6587\u5B57\u7F16\u8F91";
- activeNames.value = ["\u70B9\u6837\u5F0F", "\u6807\u6CE8\u6837\u5F0F"];
- isShowPointStyle.value = true;
- isShowLabelStyle.value = true;
- point2.value.color = params.point.color;
- point2.value.pixelSize = params.point.pixelSize;
- point2.value.showOutline = params.point.showOutline;
- point2.value.outlineColor = params.point.outlineColor;
- point2.value.outlineWidth = params.point.outlineWidth;
- label2.value.content = params.label.text;
- label2.value.font = params.label.font;
- label2.value.fontSize = params.label.fontSize;
- label2.value.fillColor = params.label.fillColor;
- label2.value.showOutline = params.label.showOutline;
- label2.value.outlineColor = params.label.outlineColor;
- label2.value.outlineWidth = params.label.outlineWidth;
- label2.value.showBackground = params.label.showBackground;
- label2.value.backgroundColor = params.label.backgroundColor;
- label2.value.backgroundPadding = params.label.backgroundPadding;
- label2.value.pixelOffsetX = params.label.pixelOffsetX;
- label2.value.pixelOffsetY = params.label.pixelOffsetY;
- } else if (params.id === DrawPoint.DrawType.Billboard) {
- title.value = "\u5E7F\u544A\u724C\u7F16\u8F91";
- activeNames.value = ["\u56FE\u7247\u6837\u5F0F"];
- isShowBillboardStyle.value = true;
- billboard.value.imgUrl = params.billboard.imgUrl;
- billboard.value.alpha = params.billboard.alpha;
- billboard.value.scale = params.billboard.scale;
- } else if (params.id === DrawPoint.DrawType.Billboard2Label) {
- title.value = "\u5E7F\u544A\u724C\u53CA\u6587\u5B57\u5706\u7F16\u8F91";
- activeNames.value = ["\u56FE\u7247\u6837\u5F0F", "\u6807\u6CE8\u6837\u5F0F"];
- isShowBillboardStyle.value = true;
- isShowLabelStyle.value = true;
- billboard.value.imgUrl = params.billboard.imgUrl;
- billboard.value.alpha = params.billboard.alpha;
- billboard.value.scale = params.billboard.scale;
- label2.value.content = params.label.text;
- label2.value.font = params.label.font;
- label2.value.fontSize = params.label.fontSize;
- label2.value.fillColor = params.label.fillColor;
- label2.value.showOutline = params.label.showOutline;
- label2.value.outlineColor = params.label.outlineColor;
- label2.value.outlineWidth = params.label.outlineWidth;
- label2.value.showBackground = params.label.showBackground;
- label2.value.backgroundColor = params.label.backgroundColor;
- label2.value.backgroundPadding = params.label.backgroundPadding;
- label2.value.pixelOffsetX = params.label.pixelOffsetX;
- label2.value.pixelOffsetY = params.label.pixelOffsetY;
- } else if (params.id === DrawPoint.DrawType.Model) {
- title.value = "\u5C0F\u6A21\u578B\u7F16\u8F91";
- activeNames.value = ["\u5C0F\u6A21\u578B\u6837\u5F0F"];
- isShowModelStyle.value = true;
- model.value.url = params.model.url;
- model.value.alpha = params.model.alpha;
- model.value.showSilhouette = params.model.showSilhouette;
- model.value.silhouetteColor = params.model.silhouetteColor;
- model.value.silhouetteSize = params.model.silhouetteSize;
- model.value.minimumPixelSize = params.model.minimumPixelSize;
- model.value.maximumScale = params.model.maximumScale;
- model.value.heading = params.model.heading;
- model.value.pitch = params.model.pitch;
- model.value.roll = params.model.roll;
- }
- }
- function _setShowControls(isShow) {
- isShowLabelStyle.value = isShow;
- isShowPointStyle.value = isShow;
- isShowBillboardStyle.value = isShow;
- isShowModelStyle.value = isShow;
- }
- function submit() {
- let outParam = proxy._params;
- outParam = {
- id: outParam.id,
- label: {
- text: label2.value.content,
- font: label2.value.font,
- fontSize: label2.value.fontSize,
- bolder: label2.value.bolder,
- italic: label2.value.italic,
- fillColor: label2.value.fillColor,
- showOutline: label2.value.showOutline,
- outlineWidth: label2.value.outlineWidth,
- outlineColor: label2.value.outlineColor,
- showBackground: label2.value.showBackground,
- backgroundColor: label2.value.backgroundColor,
- backgroundPadding: label2.value.backgroundPadding,
- pixelOffsetX: label2.value.pixelOffsetX,
- pixelOffsetY: label2.value.pixelOffsetY
- },
- point: {
- color: point2.value.color,
- pixelSize: point2.value.pixelSize,
- showOutline: point2.value.showOutline,
- outlineWidth: point2.value.outlineWidth,
- outlineColor: point2.value.outlineColor
- },
- billboard: {
- imgUrl: billboard.value.imgUrl,
- alpha: billboard.value.alpha,
- scale: billboard.value.scale
- },
- model: {
- url: model.value.url,
- alpha: model.value.alpha,
- showSilhouette: model.value.showSilhouette,
- silhouetteColor: model.value.silhouetteColor,
- silhouetteSize: model.value.silhouetteSize,
- minimumPixelSize: model.value.minimumPixelSize,
- maximumScale: model.value.maximumScale,
- heading: model.value.heading,
- pitch: model.value.pitch,
- roll: model.value.roll
- }
- };
- emit("submit", outParam);
- }
- function close() {
- dialogVisible.value = false;
- }
- function remove2() {
- emit("remove", {});
- dialogVisible.value = false;
- }
- function closeDialog() {
- emit("update:showDialog", false);
- }
- function openDialog() {
- updateParams(props.params);
- }
- return (_ctx, _cache) => {
- const _component_el_scrollbar = resolveComponent("el-scrollbar");
- return openBlock(), createElementBlock("div", _hoisted_1, [
- createVNode(unref(ElDialog), {
- modal: false,
- "destroy-on-close": false,
- modelValue: dialogVisible.value,
- "onUpdate:modelValue": _cache[31] || (_cache[31] = ($event) => dialogVisible.value = $event),
- title: title.value,
- onClose: closeDialog,
- onOpen: openDialog,
- "show-close": false
- }, {
- header: withCtx(() => [
- createElementVNode("div", _hoisted_2, [
- createElementVNode("span", _hoisted_3, toDisplayString(title.value), 1)
- ])
- ]),
- default: withCtx(() => [
- createVNode(_component_el_scrollbar, null, {
- default: withCtx(() => [
- createElementVNode("div", _hoisted_4, [
- createVNode(unref(ElCollapse), {
- modelValue: activeNames.value,
- "onUpdate:modelValue": _cache[27] || (_cache[27] = ($event) => activeNames.value = $event)
- }, {
- default: withCtx(() => [
- withDirectives(createVNode(unref(ElCollapseItem), { name: "\u6807\u6CE8\u6837\u5F0F" }, {
- title: withCtx(() => [
- createVNode(unref(ElIcon), { style: { "padding": "10rem" } }, {
- default: withCtx(() => [
- createVNode(unref(setting_default))
- ]),
- _: 1
- }),
- createTextVNode("\u6807\u6CE8\u6837\u5F0F ")
- ]),
- default: withCtx(() => [
- createElementVNode("div", _hoisted_5, [
- _hoisted_6,
- createElementVNode("div", _hoisted_7, [
- createVNode(unref(ElInput), {
- modelValue: label2.value.content,
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => label2.value.content = $event),
- placeholder: "\u8F93\u5165\u663E\u793A\u7684\u6587\u5B57\u5185\u5BB9",
- clearable: "",
- type: "textarea",
- rows: 2
- }, null, 8, ["modelValue"])
- ])
- ]),
- createElementVNode("div", _hoisted_8, [
- _hoisted_9,
- createElementVNode("div", _hoisted_10, [
- createVNode(unref(ElSelect), {
- modelValue: label2.value.font,
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => label2.value.font = $event),
- placeholder: "\u8BF7\u9009\u62E9"
- }, {
- default: withCtx(() => [
- (openBlock(), createElementBlock(Fragment, null, renderList(selectOptionsFont, (item) => {
- return createVNode(unref(ElOption), {
- key: item.value,
- label: item.label,
- value: item.value
- }, null, 8, ["label", "value"]);
- }), 64))
- ]),
- _: 1
- }, 8, ["modelValue"])
- ])
- ]),
- createElementVNode("div", _hoisted_11, [
- _hoisted_12,
- createElementVNode("div", _hoisted_13, [
- createVNode(unref(ElInputNumber), {
- modelValue: label2.value.fontSize,
- "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => label2.value.fontSize = $event),
- min: 0,
- max: 100
- }, null, 8, ["modelValue"])
- ])
- ]),
- createElementVNode("div", _hoisted_14, [
- _hoisted_15,
- createElementVNode("div", _hoisted_16, [
- createVNode(unref(ElSwitch), {
- modelValue: label2.value.bolder,
- "onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => label2.value.bolder = $event)
- }, null, 8, ["modelValue"])
- ])
- ]),
- createElementVNode("div", _hoisted_17, [
- _hoisted_18,
- createElementVNode("div", _hoisted_19, [
- createVNode(unref(ElSwitch), {
- modelValue: label2.value.italic,
- "onUpdate:modelValue": _cache[4] || (_cache[4] = ($event) => label2.value.italic = $event)
- }, null, 8, ["modelValue"])
- ])
- ]),
- createElementVNode("div", _hoisted_20, [
- _hoisted_21,
- createElementVNode("div", _hoisted_22, [
- createVNode(unref(ElConfigProvider), { locale: locale.value }, {
- default: withCtx(() => [
- createVNode(unref(ElColorPicker), {
- modelValue: label2.value.fillColor,
- "onUpdate:modelValue": _cache[5] || (_cache[5] = ($event) => label2.value.fillColor = $event),
- "show-alpha": "",
- predefine: predefineColors.value,
- label: "12"
- }, null, 8, ["modelValue", "predefine"])
- ]),
- _: 1
- }, 8, ["locale"])
- ])
- ]),
- createElementVNode("div", _hoisted_23, [
- _hoisted_24,
- createElementVNode("div", _hoisted_25, [
- createVNode(unref(ElSwitch), {
- modelValue: label2.value.showOutline,
- "onUpdate:modelValue": _cache[6] || (_cache[6] = ($event) => label2.value.showOutline = $event)
- }, null, 8, ["modelValue"])
- ])
- ]),
- withDirectives(createElementVNode("div", _hoisted_26, [
- _hoisted_27,
- createElementVNode("div", _hoisted_28, [
- createVNode(unref(ElConfigProvider), { locale: locale.value }, {
- default: withCtx(() => [
- createVNode(unref(ElColorPicker), {
- modelValue: label2.value.outlineColor,
- "onUpdate:modelValue": _cache[7] || (_cache[7] = ($event) => label2.value.outlineColor = $event),
- "show-alpha": "",
- predefine: predefineColors.value,
- label: "12"
- }, null, 8, ["modelValue", "predefine"])
- ]),
- _: 1
- }, 8, ["locale"])
- ])
- ], 512), [
- [vShow, label2.value.showOutline]
- ]),
- withDirectives(createElementVNode("div", _hoisted_29, [
- _hoisted_30,
- createElementVNode("div", _hoisted_31, [
- createVNode(unref(ElInputNumber), {
- modelValue: label2.value.outlineWidth,
- "onUpdate:modelValue": _cache[8] || (_cache[8] = ($event) => label2.value.outlineWidth = $event),
- min: 0,
- max: 100
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, label2.value.showOutline]
- ]),
- createElementVNode("div", _hoisted_32, [
- _hoisted_33,
- createElementVNode("div", _hoisted_34, [
- createVNode(unref(ElSwitch), {
- modelValue: label2.value.showBackground,
- "onUpdate:modelValue": _cache[9] || (_cache[9] = ($event) => label2.value.showBackground = $event)
- }, null, 8, ["modelValue"])
- ])
- ]),
- withDirectives(createElementVNode("div", _hoisted_35, [
- _hoisted_36,
- createElementVNode("div", _hoisted_37, [
- createVNode(unref(ElConfigProvider), { locale: locale.value }, {
- default: withCtx(() => [
- createVNode(unref(ElColorPicker), {
- modelValue: label2.value.backgroundColor,
- "onUpdate:modelValue": _cache[10] || (_cache[10] = ($event) => label2.value.backgroundColor = $event),
- "show-alpha": "",
- predefine: predefineColors.value,
- label: "12"
- }, null, 8, ["modelValue", "predefine"])
- ]),
- _: 1
- }, 8, ["locale"])
- ])
- ], 512), [
- [vShow, label2.value.showBackground]
- ]),
- withDirectives(createElementVNode("div", _hoisted_38, [
- _hoisted_39,
- createElementVNode("div", _hoisted_40, [
- createVNode(unref(ElInputNumber), {
- modelValue: label2.value.backgroundPadding,
- "onUpdate:modelValue": _cache[11] || (_cache[11] = ($event) => label2.value.backgroundPadding = $event),
- min: -100,
- max: 100
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, label2.value.showBackground]
- ]),
- createElementVNode("div", _hoisted_41, [
- _hoisted_42,
- createElementVNode("div", _hoisted_43, [
- createVNode(unref(ElInputNumber), {
- modelValue: label2.value.pixelOffsetX,
- "onUpdate:modelValue": _cache[12] || (_cache[12] = ($event) => label2.value.pixelOffsetX = $event),
- min: -100,
- max: 100
- }, null, 8, ["modelValue"])
- ])
- ]),
- createElementVNode("div", _hoisted_44, [
- _hoisted_45,
- createElementVNode("div", _hoisted_46, [
- createVNode(unref(ElInputNumber), {
- modelValue: label2.value.pixelOffsetY,
- "onUpdate:modelValue": _cache[13] || (_cache[13] = ($event) => label2.value.pixelOffsetY = $event),
- min: -100,
- max: 100
- }, null, 8, ["modelValue"])
- ])
- ])
- ]),
- _: 1
- }, 512), [
- [vShow, isShowLabelStyle.value]
- ]),
- withDirectives(createVNode(unref(ElCollapseItem), { name: "\u70B9\u6837\u5F0F" }, {
- title: withCtx(() => [
- createVNode(unref(ElIcon), { style: { "padding": "10rem" } }, {
- default: withCtx(() => [
- createVNode(unref(setting_default))
- ]),
- _: 1
- }),
- createTextVNode("\u70B9\u6837\u5F0F ")
- ]),
- default: withCtx(() => [
- createElementVNode("div", _hoisted_47, [
- _hoisted_48,
- createElementVNode("div", _hoisted_49, [
- createVNode(unref(ElInputNumber), {
- modelValue: point2.value.pixelSize,
- "onUpdate:modelValue": _cache[14] || (_cache[14] = ($event) => point2.value.pixelSize = $event),
- min: 0,
- max: 100
- }, null, 8, ["modelValue"])
- ])
- ]),
- createElementVNode("div", _hoisted_50, [
- _hoisted_51,
- createElementVNode("div", _hoisted_52, [
- createVNode(unref(ElConfigProvider), { locale: locale.value }, {
- default: withCtx(() => [
- createVNode(unref(ElColorPicker), {
- modelValue: point2.value.color,
- "onUpdate:modelValue": _cache[15] || (_cache[15] = ($event) => point2.value.color = $event),
- "show-alpha": "",
- predefine: predefineColors.value,
- label: "12"
- }, null, 8, ["modelValue", "predefine"])
- ]),
- _: 1
- }, 8, ["locale"])
- ])
- ]),
- createElementVNode("div", _hoisted_53, [
- _hoisted_54,
- createElementVNode("div", _hoisted_55, [
- createVNode(unref(ElSwitch), {
- modelValue: point2.value.showOutline,
- "onUpdate:modelValue": _cache[16] || (_cache[16] = ($event) => point2.value.showOutline = $event)
- }, null, 8, ["modelValue"])
- ])
- ]),
- withDirectives(createElementVNode("div", _hoisted_56, [
- _hoisted_57,
- createElementVNode("div", _hoisted_58, [
- createVNode(unref(ElConfigProvider), { locale: locale.value }, {
- default: withCtx(() => [
- createVNode(unref(ElColorPicker), {
- modelValue: point2.value.outlineColor,
- "onUpdate:modelValue": _cache[17] || (_cache[17] = ($event) => point2.value.outlineColor = $event),
- "show-alpha": "",
- predefine: predefineColors.value,
- label: "12"
- }, null, 8, ["modelValue", "predefine"])
- ]),
- _: 1
- }, 8, ["locale"])
- ])
- ], 512), [
- [vShow, point2.value.showOutline]
- ]),
- withDirectives(createElementVNode("div", _hoisted_59, [
- _hoisted_60,
- createElementVNode("div", _hoisted_61, [
- createVNode(unref(ElInputNumber), {
- modelValue: point2.value.outlineWidth,
- "onUpdate:modelValue": _cache[18] || (_cache[18] = ($event) => point2.value.outlineWidth = $event),
- min: 0,
- max: 100
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, point2.value.showOutline]
- ])
- ]),
- _: 1
- }, 512), [
- [vShow, isShowPointStyle.value]
- ]),
- withDirectives(createVNode(unref(ElCollapseItem), { name: "\u56FE\u7247\u6837\u5F0F" }, {
- title: withCtx(() => [
- createVNode(unref(ElIcon), { style: { "padding": "10rem" } }, {
- default: withCtx(() => [
- createVNode(unref(setting_default))
- ]),
- _: 1
- }),
- createTextVNode("\u56FE\u7247\u6837\u5F0F ")
- ]),
- default: withCtx(() => [
- createElementVNode("div", _hoisted_62, [
- _hoisted_63,
- createElementVNode("div", _hoisted_64, [
- createVNode(unref(ElInput), {
- modelValue: billboard.value.imgUrl,
- "onUpdate:modelValue": _cache[19] || (_cache[19] = ($event) => billboard.value.imgUrl = $event),
- placeholder: "\u8F93\u5165\u56FE\u6807\u8DEF\u5F84",
- clearable: "",
- type: "textarea",
- rows: 2
- }, null, 8, ["modelValue"])
- ])
- ]),
- createElementVNode("div", _hoisted_65, [
- _hoisted_66,
- createElementVNode("div", _hoisted_67, [
- createVNode(unref(ElInputNumber), {
- modelValue: billboard.value.scale,
- "onUpdate:modelValue": _cache[20] || (_cache[20] = ($event) => billboard.value.scale = $event),
- min: 1,
- max: 100
- }, null, 8, ["modelValue"])
- ])
- ])
- ]),
- _: 1
- }, 512), [
- [vShow, isShowBillboardStyle.value]
- ]),
- withDirectives(createVNode(unref(ElCollapseItem), { name: "\u5C0F\u6A21\u578B\u6837\u5F0F" }, {
- title: withCtx(() => [
- createVNode(unref(ElIcon), { style: { "padding": "10rem" } }, {
- default: withCtx(() => [
- createVNode(unref(setting_default))
- ]),
- _: 1
- }),
- createTextVNode("\u5C0F\u6A21\u578B\u6837\u5F0F ")
- ]),
- default: withCtx(() => [
- createElementVNode("div", _hoisted_68, [
- _hoisted_69,
- createElementVNode("div", _hoisted_70, [
- createVNode(unref(ElInput), {
- modelValue: model.value.url,
- "onUpdate:modelValue": _cache[21] || (_cache[21] = ($event) => model.value.url = $event),
- placeholder: "\u8F93\u5165\u6A21\u578B\u8DEF\u5F84",
- clearable: "",
- type: "textarea",
- rows: 2
- }, null, 8, ["modelValue"])
- ])
- ]),
- createElementVNode("div", _hoisted_71, [
- _hoisted_72,
- createElementVNode("div", _hoisted_73, [
- createVNode(unref(ElInputNumber), {
- modelValue: model.value.alpha,
- "onUpdate:modelValue": _cache[22] || (_cache[22] = ($event) => model.value.alpha = $event),
- step: 0.1,
- min: 0,
- max: 1
- }, null, 8, ["modelValue"])
- ])
- ]),
- createElementVNode("div", _hoisted_74, [
- _hoisted_75,
- createElementVNode("div", _hoisted_76, [
- createVNode(unref(ElInputNumber), {
- modelValue: model.value.minimumPixelSize,
- "onUpdate:modelValue": _cache[23] || (_cache[23] = ($event) => model.value.minimumPixelSize = $event),
- step: 1,
- min: 0,
- max: 2e4
- }, null, 8, ["modelValue"])
- ])
- ]),
- createElementVNode("div", _hoisted_77, [
- _hoisted_78,
- createElementVNode("div", _hoisted_79, [
- createVNode(unref(ElSwitch), {
- modelValue: model.value.showSilhouette,
- "onUpdate:modelValue": _cache[24] || (_cache[24] = ($event) => model.value.showSilhouette = $event)
- }, null, 8, ["modelValue"])
- ])
- ]),
- withDirectives(createElementVNode("div", _hoisted_80, [
- _hoisted_81,
- createElementVNode("div", _hoisted_82, [
- createVNode(unref(ElConfigProvider), { locale: locale.value }, {
- default: withCtx(() => [
- createVNode(unref(ElColorPicker), {
- modelValue: model.value.silhouetteColor,
- "onUpdate:modelValue": _cache[25] || (_cache[25] = ($event) => model.value.silhouetteColor = $event),
- "show-alpha": "",
- predefine: predefineColors.value,
- label: "12"
- }, null, 8, ["modelValue", "predefine"])
- ]),
- _: 1
- }, 8, ["locale"])
- ])
- ], 512), [
- [vShow, model.value.showSilhouette]
- ]),
- withDirectives(createElementVNode("div", _hoisted_83, [
- _hoisted_84,
- createElementVNode("div", _hoisted_85, [
- createVNode(unref(ElInputNumber), {
- modelValue: model.value.silhouetteSize,
- "onUpdate:modelValue": _cache[26] || (_cache[26] = ($event) => model.value.silhouetteSize = $event),
- step: 1,
- min: 0,
- max: 100
- }, null, 8, ["modelValue"])
- ])
- ], 512), [
- [vShow, model.value.showSilhouette]
- ])
- ]),
- _: 1
- }, 512), [
- [vShow, isShowModelStyle.value]
- ])
- ]),
- _: 1
- }, 8, ["modelValue"])
- ]),
- createElementVNode("div", _hoisted_86, [
- createVNode(unref(ElButtonGroup), null, {
- default: withCtx(() => [
- createVNode(unref(ElButton), {
- type: "primary",
- icon: unref(edit_default),
- onClick: _cache[28] || (_cache[28] = ($event) => submit())
- }, {
- default: withCtx(() => [
- createTextVNode("\u4FEE\u6539")
- ]),
- _: 1
- }, 8, ["icon"]),
- createVNode(unref(ElButton), {
- type: "primary",
- style: { "background-color": "rgb(222, 146, 47)" },
- icon: unref(delete_default),
- onClick: _cache[29] || (_cache[29] = ($event) => remove2())
- }, {
- default: withCtx(() => [
- createTextVNode("\u5220\u9664")
- ]),
- _: 1
- }, 8, ["icon"]),
- createVNode(unref(ElButton), {
- type: "primary",
- style: { "background-color": "rgb(126, 128, 135)" },
- icon: unref(close_default),
- onClick: _cache[30] || (_cache[30] = ($event) => close())
- }, {
- default: withCtx(() => [
- createTextVNode("\u5173\u95ED")
- ]),
- _: 1
- }, 8, ["icon"])
- ]),
- _: 1
- })
- ])
- ]),
- _: 1
- })
- ]),
- _: 1
- }, 8, ["modelValue", "title"])
- ]);
- };
- }
- };
- var DialogEditProperty = /* @__PURE__ */ _export_sfc(_sfc_main, [["styles", [_style_0]]]);
- Cesium.Entity.prototype.setParams = function(params) {
- this._params = params;
- };
- Cesium.Entity.prototype.getParams = function() {
- return this._params;
- };
- Cesium.Entity.prototype.setEntityType = function(entityType) {
- this._entityType = entityType;
- };
- Cesium.Entity.prototype.getEntityType = function(entityType) {
- return this._entityType;
- };
- Cesium.Entity.prototype.setIsEdit = function(isEdit) {
- this._isEdit = isEdit;
- };
- Cesium.Entity.prototype.getIsEdit = function() {
- return this._isEdit;
- };
- class DrawPoint {
- constructor(viewer2) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- this._viewer = viewer2;
- this._viewer.scene.globe.depthTestAgainstTerrain = true;
- this._viewer.cesiumWidget.screenSpaceEventHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);
- this._entities = [];
- this._pointObject = new PointObject(viewer2);
- }
- static initEditPropertyParams() {
- return {
- id: void 0,
- label: {
- text: "\u91D1\u7530CIM\u4E09\u7EF4\u57FA\u7840\u5E73\u53F0",
- font: "Helvetica",
- fontSize: 24,
- bolder: false,
- italic: false,
- fillColor: "rgba(0,255,0,0.75)",
- showOutline: false,
- outlineWidth: 0,
- outlineColor: "rgba(255,255,255,1)",
- showBackground: false,
- backgroundPadding: 0,
- backgroundColor: "rgba(255,255,255,1)",
- pixelOffsetX: 0,
- pixelOffsetY: 0
- },
- point: {
- color: "rgba(0,255,0,0.75)",
- pixelSize: 10,
- showOutline: false,
- outlineWidth: 0,
- outlineColor: "rgba(255,255,255,1)"
- },
- billboard: {
- imgUrl: "jt3dSDK/imgs/point/point3.png",
- alpha: 1,
- scale: 1
- },
- model: {
- url: "jt3dSDK/gltf/pyramid.glb",
- alpha: 1,
- showSilhouette: false,
- silhouetteColor: "rgba(255,255,255,1)",
- silhouetteSize: 0,
- minimumPixelSize: 128,
- maximumScale: 2e4,
- heading: 0,
- pitch: 0,
- roll: 0
- }
- };
- }
- _cartesian3ToGeo(position2) {
- let g = Cesium.Ellipsoid.WGS84.cartesianToCartographic(position2);
- return {
- longitude: Cesium.Math.toDegrees(g.longitude),
- latitude: Cesium.Math.toDegrees(g.latitude),
- height: g.height
- };
- }
- _arcToDegree(arc) {
- return arc / Math.PI * 180;
- }
- _getScreenClickPositionAndHeight(screenPoint) {
- var lng = void 0, lat = void 0, height2 = void 0;
- var ray = this._viewer.scene.camera.getPickRay(screenPoint);
- var position2 = this._viewer.scene.globe.pick(ray, this._viewer.scene);
- var cartographic = Cesium.Ellipsoid.WGS84.cartesianToCartographic(position2);
- var feature2 = this._viewer.scene.pick(screenPoint);
- if (feature2 == void 0) {
- lng = this._arcToDegree(cartographic.longitude);
- lat = this._arcToDegree(cartographic.latitude);
- height2 = cartographic.height;
- } else {
- var cartesian = this._viewer.scene.pickPosition(screenPoint);
- if (Cesium.defined(cartesian)) {
- var cartographic = Cesium.Cartographic.fromCartesian(cartesian);
- lng = this._arcToDegree(cartographic.longitude);
- lat = this._arcToDegree(cartographic.latitude);
- height2 = cartographic.height;
- }
- }
- return {
- lng,
- lat,
- height: height2
- };
- }
- _transfromFromScreenPoint(screenPosition) {
- let location = this._getScreenClickPositionAndHeight(screenPosition);
- var cartesian = Cesium.Cartesian3.fromDegrees(location.lng, location.lat, location.height);
- return {
- gLocation: location,
- sLocation: cartesian
- };
- }
- }
- Object.assign(DrawPoint.prototype, {
- _setMousePointerStyle() {
- document.querySelector("body").style.cursor = "crosshair";
- },
- _setMouseDefaultStyle() {
- document.querySelector("body").style.cursor = "default";
- },
- _registerLeftClickEvent(handler, callChange) {
- let _self = this;
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- _self._lock = true;
- clearTimeout(_self._timer);
- _self._timer = setTimeout(function() {
- if (callChange)
- callChange(event2);
- _self._lock = false;
- }, 200);
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- },
- _registerMouseMoveEvent(handler, callChange) {
- let _self = this;
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (_self._lock === void 0 || _self._lock === false) {
- if (callChange)
- callChange(event2);
- }
- }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- },
- _registerLeftDownEvent(handler, callChange) {
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (callChange)
- callChange(event2);
- }, Cesium.ScreenSpaceEventType.LEFT_DOWN);
- },
- _registerLeftUpEvent(handler, callChange) {
- if (!handler)
- return;
- handler.setInputAction(function(event2) {
- if (callChange)
- callChange(event2);
- }, Cesium.ScreenSpaceEventType.LEFT_UP);
- },
- _clearEvent(handler) {
- if (!handler)
- return;
- handler.destroy();
- handler = null;
- }
- });
- Object.assign(DrawPoint.prototype, {
- draw: function(type2, options2) {
- let _self = this;
- _self._unActivateEdit();
- this._drawEventHandler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- this._drawType = type2;
- switch (type2) {
- case DrawPoint.DrawType.Model:
- _self._sketchDrawModel(_self._drawEventHandler, options2);
- break;
- case DrawPoint.DrawType.Label:
- _self._sketchDrawLabel(_self._drawEventHandler, options2);
- break;
- case DrawPoint.DrawType.Point:
- _self._sketchDrawPoint(_self._drawEventHandler, options2);
- break;
- case DrawPoint.DrawType.Point2Label:
- _self._sketchDrawPoint2Label(_self._drawEventHandler, options2);
- break;
- case DrawPoint.DrawType.Billboard:
- _self._sketchDrawBillboard(_self._drawEventHandler, options2);
- break;
- case DrawPoint.DrawType.Billboard2Label:
- _self._sketchDrawBillboard2Label(_self._drawEventHandler, options2);
- break;
- }
- },
- clearAll() {
- for (var i2 = 0; i2 < this._entities.length; i2++) {
- var getById = viewer.entities.getById(this._entities[i2]);
- if (getById) {
- this._viewer.entities.remove(getById);
- }
- }
- this._closePropertyEditDialog();
- },
- _sketchDrawLabel(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- let entityParam = DrawPoint.initEditPropertyParams();
- entityParam.label.font = entityParam.label.fontSize + "px " + entityParam.label.font;
- entityParam.label.pixelOffset = {
- x: entityParam.label.pixelOffsetX,
- y: entityParam.label.pixelOffsetY
- };
- _self._pointObject.addLabel(loc2.sLocation, {
- label: entityParam.label
- }).then((entity) => {
- _self._viewer.entities.add(entity);
- _self._entities.push(entity.id);
- entityParam = DrawPoint.initEditPropertyParams();
- _self._drawEntity = entity;
- _self._drawEntity.setParams(entityParam);
- _self._drawEntity.setEntityType(DrawPoint.DrawType.Label);
- _self._setEntityIsEdit(_self._drawEntity);
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(loc2.sLocation, loc2.gLocation);
- });
- });
- },
- _sketchDrawPoint(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- let entityParam = DrawPoint.initEditPropertyParams();
- _self._pointObject.addPoint(loc2.sLocation, {
- point: entityParam.point
- }).then((entity) => {
- _self._viewer.entities.add(entity);
- _self._entities.push(entity.id);
- entityParam = DrawPoint.initEditPropertyParams();
- _self._drawEntity = entity;
- _self._drawEntity.setParams(entityParam);
- _self._drawEntity.setEntityType(DrawPoint.DrawType.Point);
- _self._setEntityIsEdit(_self._drawEntity);
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(loc2.sLocation, loc2.gLocation);
- });
- });
- },
- _sketchDrawPoint2Label(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- let entityParam = DrawPoint.initEditPropertyParams();
- entityParam.label.font = entityParam.label.fontSize + "px " + entityParam.label.font;
- entityParam.label.pixelOffset = {
- x: entityParam.label.pixelOffsetX,
- y: entityParam.label.pixelOffsetY - 10
- };
- _self._pointObject.addPoint(loc2.sLocation, {
- point: entityParam.point,
- label: entityParam.label
- }).then((entity) => {
- _self._viewer.entities.add(entity);
- _self._entities.push(entity.id);
- entityParam = DrawPoint.initEditPropertyParams();
- entityParam.label.pixelOffsetY = -10;
- _self._drawEntity = entity;
- _self._drawEntity.setParams(entityParam);
- _self._drawEntity.setEntityType(DrawPoint.DrawType.Point2Label);
- _self._setEntityIsEdit(_self._drawEntity);
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(loc2.sLocation, loc2.gLocation);
- });
- });
- },
- _sketchDrawBillboard(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- let entityParam = DrawPoint.initEditPropertyParams();
- _self._pointObject.addBillboard(loc2.sLocation, {
- billboard: entityParam.billboard
- }).then((entity) => {
- _self._viewer.entities.add(entity);
- _self._entities.push(entity.id);
- entityParam = DrawPoint.initEditPropertyParams();
- entityParam.label.pixelOffsetY = -50;
- _self._drawEntity = entity;
- _self._drawEntity.setParams(entityParam);
- _self._drawEntity.setEntityType(DrawPoint.DrawType.Billboard);
- _self._setEntityIsEdit(_self._drawEntity);
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(loc2.sLocation, loc2.gLocation);
- });
- });
- },
- _sketchDrawBillboard2Label(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- let entityParam = DrawPoint.initEditPropertyParams();
- entityParam.label.font = entityParam.label.fontSize + "px " + entityParam.label.font;
- entityParam.label.pixelOffset = {
- x: entityParam.label.pixelOffsetX,
- y: entityParam.label.pixelOffsetY - 50
- };
- _self._pointObject.addBillboard(loc2.sLocation, {
- billboard: entityParam.billboard,
- label: entityParam.label
- }).then((entity) => {
- _self._viewer.entities.add(entity);
- _self._entities.push(entity.id);
- entityParam = DrawPoint.initEditPropertyParams();
- _self._drawEntity = entity;
- _self._drawEntity.setParams(entityParam);
- _self._drawEntity.setEntityType(DrawPoint.DrawType.Billboard2Label);
- _self._setEntityIsEdit(_self._drawEntity);
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(loc2.sLocation, loc2.gLocation);
- });
- });
- },
- _sketchDrawModel(handler, options2) {
- let _self = this;
- this._registerLeftClickEvent(handler, function(event2) {
- let loc2 = _self._transfromFromScreenPoint(event2.position);
- if (!Cesium.defined(loc2.sLocation))
- return;
- let entityParam = DrawPoint.initEditPropertyParams();
- _self._pointObject.addModel(loc2.sLocation, {
- model: entityParam.model
- }).then((entity) => {
- _self._viewer.entities.add(entity);
- _self._entities.push(entity.id);
- entityParam = DrawPoint.initEditPropertyParams();
- _self._drawEntity = entity;
- _self._drawEntity.setParams(entityParam);
- _self._drawEntity.setEntityType(DrawPoint.DrawType.Model);
- _self._setEntityIsEdit(_self._drawEntity);
- _self._clearEvent(handler);
- if (options2.onComplete)
- options2.onComplete(loc2.sLocation, loc2.gLocation);
- });
- });
- },
- updateEditEntityProperty: function(params) {
- if (this._editEntity === void 0)
- return;
- if (this._editEntity.getIsEdit() === void 0 || this._editEntity.getIsEdit() === false)
- return;
- let editEntityType = this._editEntity.getEntityType();
- if (editEntityType === void 0)
- return;
- if (editEntityType === DrawPoint.DrawType.Label) {
- this._updateLabelProperty(params);
- } else if (editEntityType === DrawPoint.DrawType.Point) {
- this._updatePointProperty(params);
- } else if (editEntityType === DrawPoint.DrawType.Point2Label) {
- this._updatePoint2LabelProperty(params);
- } else if (editEntityType === DrawPoint.DrawType.Billboard) {
- this._updateBillboardProperty(params);
- } else if (editEntityType === DrawPoint.DrawType.Billboard2Label) {
- this._updateBillboard2LabelProperty(params);
- } else if (editEntityType === DrawPoint.DrawType.Model) {
- this._updateModelProperty(params);
- }
- },
- _updateLabelProperty(params) {
- let label2 = params.label;
- this._editEntity.label.text = label2.text;
- let font = "";
- if (label2.italic) {
- font += "italic ";
- }
- if (label2.bolder) {
- font += " bolder ";
- }
- font += label2.fontSize + "px " + label2.font;
- this._editEntity.label.font = font;
- this._editEntity.label.fillColor = Cesium.Color.fromCssColorString(label2.fillColor);
- this._editEntity.label.outlineColor = Cesium.Color.fromCssColorString(label2.outlineColor);
- this._editEntity.label.outlineWidth = parseFloat(label2.outlineWidth);
- this._editEntity.label.showBackground = label2.showBackground;
- this._editEntity.label.backgroundColor = Cesium.Color.fromCssColorString(label2.backgroundColor);
- this._editEntity.label.backgroundPadding = new Cesium.Cartesian2(parseFloat(label2.backgroundPadding), parseFloat(label2.backgroundPadding));
- this._editEntity.label.pixelOffset = new Cesium.Cartesian2(parseFloat(label2.pixelOffsetX), parseFloat(label2.pixelOffsetY));
- this._editEntity.setParams(params);
- },
- _updatePointProperty(params) {
- let point2 = params.point;
- this._editEntity.point.color = Cesium.Color.fromCssColorString(point2.color);
- this._editEntity.point.pixelSize = parseFloat(point2.pixelSize);
- this._editEntity.point.outlineColor = Cesium.Color.fromCssColorString(point2.outlineColor);
- this._editEntity.point.outlineWidth = parseFloat(point2.outlineWidth);
- this._editEntity.setParams(params);
- },
- _updatePoint2LabelProperty(params) {
- let label2 = params.label;
- this._editEntity.label.text = label2.text;
- let font = "";
- if (label2.italic) {
- font += "italic ";
- }
- if (label2.bolder) {
- font += " bolder ";
- }
- font += label2.fontSize + "px " + label2.font;
- this._editEntity.label.font = font;
- this._editEntity.label.fillColor = Cesium.Color.fromCssColorString(label2.fillColor);
- this._editEntity.label.outlineColor = Cesium.Color.fromCssColorString(label2.outlineColor);
- this._editEntity.label.outlineWidth = parseFloat(label2.outlineWidth);
- this._editEntity.label.showBackground = label2.showBackground;
- this._editEntity.label.backgroundColor = Cesium.Color.fromCssColorString(label2.backgroundColor);
- this._editEntity.label.backgroundPadding = new Cesium.Cartesian2(parseFloat(label2.backgroundPadding), parseFloat(label2.backgroundPadding));
- let point2 = params.point;
- this._editEntity.point.color = Cesium.Color.fromCssColorString(point2.color);
- this._editEntity.point.pixelSize = parseFloat(point2.pixelSize);
- this._editEntity.point.outlineColor = Cesium.Color.fromCssColorString(point2.outlineColor);
- this._editEntity.point.outlineWidth = parseFloat(point2.outlineWidth);
- this._editEntity.setParams(params);
- },
- _updateBillboardProperty(params) {
- let billboard = params.billboard;
- this._editEntity.billboard.image = billboard.imgUrl;
- this._editEntity.billboard.scale = billboard.scale;
- this._editEntity.setParams(params);
- },
- _updateBillboard2LabelProperty(params) {
- let label2 = params.label;
- this._editEntity.label.text = label2.text;
- let font = "";
- if (label2.italic) {
- font += "italic ";
- }
- if (label2.bolder) {
- font += " bolder ";
- }
- font += label2.fontSize + "px " + label2.font;
- this._editEntity.label.font = font;
- this._editEntity.label.fillColor = Cesium.Color.fromCssColorString(label2.fillColor);
- this._editEntity.label.outlineColor = Cesium.Color.fromCssColorString(label2.outlineColor);
- this._editEntity.label.outlineWidth = parseFloat(label2.outlineWidth);
- this._editEntity.label.showBackground = label2.showBackground;
- this._editEntity.label.backgroundColor = Cesium.Color.fromCssColorString(label2.backgroundColor);
- this._editEntity.label.backgroundPadding = new Cesium.Cartesian2(parseFloat(label2.backgroundPadding), parseFloat(label2.backgroundPadding));
- this._editEntity.label.pixelOffset = new Cesium.Cartesian2(parseFloat(label2.pixelOffsetX), parseFloat(label2.pixelOffsetY));
- let billboard = params.billboard;
- this._editEntity.billboard.image = billboard.imgUrl;
- this._editEntity.billboard.scale = billboard.scale;
- this._editEntity.setParams(params);
- }
- });
- Object.assign(DrawPoint.prototype, {
- _setEntityIsEdit(entity) {
- let _self = this;
- this._unActivateEdit();
- entity.setIsEdit(true);
- this._sendShowPropertyDialog(entity);
- let handler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- this._registerLeftClickEvent(handler, function(event2) {
- _self._unActivateEdit();
- let feature2 = _self._viewer.scene.pick(event2.position);
- if (feature2 !== void 0 && feature2.id instanceof Cesium.Entity) {
- let editEntityType = feature2.id.getEntityType();
- if (editEntityType === DrawPoint.DrawType.Label || editEntityType === DrawPoint.DrawType.Point || editEntityType === DrawPoint.DrawType.Point2Label || editEntityType === DrawPoint.DrawType.Billboard || editEntityType === DrawPoint.DrawType.Billboard2Label || editEntityType === DrawPoint.DrawType.Model) {
- feature2.id.setIsEdit(true);
- _self._sendShowPropertyDialog(feature2.id);
- }
- }
- });
- this._registerMouseMoveEvent(handler, function(event2) {
- let toolTip = "\u5355\u51FB\u4FEE\u6539\u5C5E\u6027\uFF0C\u5355\u51FB\u62D6\u52A8\u4FEE\u6539\u4F4D\u7F6E";
- let feature2 = _self._viewer.scene.pick(event2.endPosition);
- if (feature2 !== void 0 && feature2.id instanceof Cesium.Entity) {
- let editEntityType = feature2.id.getEntityType();
- if (editEntityType === DrawPoint.DrawType.Label || editEntityType === DrawPoint.DrawType.Point || editEntityType === DrawPoint.DrawType.Point2Label || editEntityType === DrawPoint.DrawType.Billboard || editEntityType === DrawPoint.DrawType.Billboard2Label || editEntityType === DrawPoint.DrawType.Model) {
- if (feature2.id.getIsEdit()) {
- toolTip = "\u5355\u51FB\u4FEE\u6539\u5C5E\u6027\uFF0C\u5355\u51FB\u62D6\u52A8\u4FEE\u6539\u4F4D\u7F6E";
- CreateRemindertip(toolTip, event2.endPosition, true);
- } else {
- toolTip = "\u5355\u51FB\u4FEE\u6539\u5C5E\u6027";
- CreateRemindertip(toolTip, event2.endPosition, true);
- }
- }
- } else {
- CreateRemindertip(toolTip, event2.endPosition, false);
- }
- });
- },
- _unActivateEdit: function() {
- if (this._sketchEditHandler != void 0) {
- this._sketchEditHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_DOWN);
- this._sketchEditHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_UP);
- this._sketchEditHandler.removeInputAction(Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- }
- this._editEntity = void 0;
- for (var i2 = 0; i2 < this._entities.length; i2++) {
- var getById = this._viewer.entities.getById(this._entities[i2]);
- if (getById) {
- getById.setIsEdit(false);
- }
- }
- this._closePropertyEditDialog();
- },
- _sendShowPropertyDialog(entity) {
- let _self = this;
- let editEntityType = entity.getEntityType();
- if (entity.getIsEdit() === void 0 || entity.getIsEdit() === false || editEntityType === void 0) {
- this._unActivateEdit();
- return;
- }
- let editProperty = entity.getParams();
- if (editProperty !== void 0 && this.onEditProperty !== void 0) {
- editProperty.id = editEntityType;
- _self._openPropertyEditDialog(
- editProperty,
- function(params) {
- _self.updateEditEntityProperty(params);
- },
- function() {
- _self._viewer.entities.remove(entity);
- _self._editEntity = void 0;
- }
- );
- }
- this._activeteNormalEdit(entity);
- },
- _activeteNormalEdit: function(editEntity) {
- let _self = this;
- editEntity.getEntityType();
- this._editEntity = editEntity;
- if (this._sketchEditHandler === void 0) {
- this._sketchEditHandler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- }
- this._registerLeftDownEvent(this._sketchEditHandler, function(event2) {
- const pickInfo = _self._viewer.scene.pick(event2.position);
- if (!pickInfo) {
- return;
- }
- _self._viewer.scene.screenSpaceCameraController.enableRotate = false;
- _self._registerMouseMoveEvent(_self._sketchEditHandler, function(event3) {
- const position2 = event3.endPosition;
- const cartesian = _self._viewer.scene.globe.pick(_self._viewer.camera.getPickRay(position2), _self._viewer.scene);
- const selectedEntity = _self._editEntity;
- if (!selectedEntity) {
- return false;
- }
- selectedEntity.position = cartesian;
- });
- _self._registerLeftUpEvent(_self._sketchEditHandler, function(event3) {
- _self._sketchEditHandler.removeInputAction(Cesium.ScreenSpaceEventType.MOUSE_MOVE);
- _self._sketchEditHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_UP);
- _self._viewer.scene.screenSpaceCameraController.enableRotate = true;
- });
- });
- },
- _updateModelProperty(params) {
- let model = params.model;
- this._editEntity.model.uri = model.url;
- this._editEntity.model.color = Cesium.Color.WHITE.withAlpha(model.alpha);
- this._editEntity.model.minimumPixelSize = model.minimumPixelSize;
- this._editEntity.model.maximumScale = model.maximumScale;
- this._editEntity.model.silhouetteSize = model.silhouetteSize;
- this._editEntity.model.silhouetteColor = new Cesium.Color.fromCssColorString(model.silhouetteColor);
- var heading = Cesium.Math.toRadians(model.heading);
- var pitch = model.pitch;
- var roll = model.roll;
- new Cesium.HeadingPitchRoll(heading, pitch, roll);
- this._editEntity.setParams(params);
- }
- });
- Object.assign(DrawPoint.prototype, {
- _openPropertyEditDialog: function(params, callEdit, callRemove) {
- this._editPropertyDialogDomId = "dialog-property-dom-point";
- this._registerDOMPropertyEdit = "dialog-edit-property-point";
- let PropertyEditComponent = customElements.get(this._registerDOMPropertyEdit);
- if (PropertyEditComponent === void 0) {
- PropertyEditComponent = defineCustomElement(DialogEditProperty);
- customElements.define(this._registerDOMPropertyEdit, PropertyEditComponent);
- }
- this._closePropertyEditDialog();
- let dialogPropertyElement = new PropertyEditComponent({
- params
- });
- dialogPropertyElement.id = this._editPropertyDialogDomId;
- dialogPropertyElement.showDialog = true;
- document.body.appendChild(dialogPropertyElement);
- dialogPropertyElement.addEventListener(
- "submit",
- (e) => {
- if (callEdit)
- callEdit(e.detail[0]);
- },
- false
- );
- dialogPropertyElement.addEventListener(
- "remove",
- (e) => {
- if (callRemove)
- callRemove();
- },
- false
- );
- },
- _closePropertyEditDialog() {
- let dom2 = document.getElementById(this._editPropertyDialogDomId);
- if (dom2 !== null && dom2 !== void 0) {
- document.body.removeChild(dom2);
- }
- }
- });
- DrawPoint.DrawType = Object.freeze({
- Model: "model",
- Label: "label",
- Point: "point",
- Point2Label: "point2Label",
- Billboard: "billboard",
- Billboard2Label: "billboard2Label"
- });
- var MultiFieldAdaptWindow$1 = "";
- class MultiFieldAdaptWindow {
- constructor(viewer2, position2, title, properties, offsetHeight) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!position2)
- throw new Cesium.DeveloperError("no position object!");
- this.viewer = viewer2;
- this.position = position2;
- this.offsetHeight = offsetHeight;
- if (position2 instanceof Cesium.Cartesian3) {
- this.position = position2;
- } else {
- this.position = Cesium.Cartesian3.fromDegrees(position2[0], position2[1], position2[2] || 0);
- }
- if (document.getElementsByClassName("MultiField-popup").length > 0) {
- document.getElementsByClassName("MultiField-popup")[0].remove();
- viewer2.entities.remove(viewer2.entities.getById("MultiFieldPopupPoint"));
- }
- this.id = "popup_" + getGuid();
- this.popupDiv = document.createElement("div");
- this.popupDiv.classList.add("MultiField-popup");
- this.popupDiv.id = this.id;
- this.viewer.container.append(this.popupDiv);
- this.popupDiv.innerHTML = this._createHtml(title, properties);
- this.viewer.scene.postRender.addEventListener(this.postRender, this);
- this.initPoint();
- document.getElementsByClassName("leaflet-popup-close-button")[0].onclick = () => {
- this.close();
- };
- }
- postRender() {
- this.viewer.scene.canvas.height;
- const windowPosition = new Cesium.Cartesian2();
- Cesium.SceneTransforms.wgs84ToWindowCoordinates(
- this.viewer.scene,
- this.position,
- windowPosition
- );
- let elWidth = this.popupDiv.offsetWidth;
- let elHeight = this.popupDiv.offsetHeight;
- if (!!this.offsetHeight) {
- elHeight += this.offsetHeight;
- }
- this.popupDiv.style.left = windowPosition.x - elWidth / 2 + "px";
- this.popupDiv.style.top = windowPosition.y - elHeight + "px";
- const camerPosition = this.viewer.camera.position;
- let height2 = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(camerPosition).height;
- height2 += this.viewer.scene.globe.ellipsoid.maximumRadius;
- if (!(Cesium.Cartesian3.distance(camerPosition, this.position) > height2) && this.viewer.camera.positionCartographic.height < 5e7) {
- this.popupDiv.style.display = "block";
- } else {
- this.popupDiv.style.display = "none";
- }
- }
- _createHtml(header, content) {
- let html = `
- <div class="MultiField-popup-header">
- ` + header + `
- <span class="leaflet-popup-close-button">\xD7</span>
- </div>
- <div class="MultiField-popup-content">
- ` + this._createTable(content) + `
- </div>
- <div class="MultiField-popup-tip">
- </div>
- `;
- return html;
- }
- _createTable(content) {
- let html = '<table class="table-popup">';
- for (let key in content) {
- html += `<tr><td class="title-popup">${key}</td>
- <td class="value-popup">${content[key]}</td></tr>`;
- }
- html += "</table>";
- return html;
- }
- initPoint() {
- this.billboard = new Cesium.Entity({
- id: "MultiFieldPopupPoint",
- name: "popupPoint",
- position: this.position,
- billboard: {
- image: "jt3dSDK/imgs/point/point.png",
- horizontalOrigin: Cesium.HorizontalOrigin.center,
- verticalOrigin: Cesium.VerticalOrigin.bottom,
- scale: 1,
- pixelOffset: new Cesium.Cartesian2(0, 0),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- }
- });
- this.viewer.entities.add(this.billboard);
- }
- }
- Object.assign(MultiFieldAdaptWindow.prototype, {
- close() {
- this.popupDiv.remove();
- this.viewer.scene.postRender.removeEventListener(this.postRender, this);
- this.viewer.entities.remove(this.billboard);
- }
- });
- var win;
- if (typeof window !== "undefined") {
- win = window;
- } else if (typeof commonjsGlobal !== "undefined") {
- win = commonjsGlobal;
- } else if (typeof self !== "undefined") {
- win = self;
- } else {
- win = {};
- }
- var window_1 = win;
- var __viteBrowserExternal = {};
- var __viteBrowserExternal$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
- __proto__: null,
- "default": __viteBrowserExternal
- }, Symbol.toStringTag, { value: "Module" }));
- var require$$0 = /* @__PURE__ */ getAugmentedNamespace(__viteBrowserExternal$1);
- var topLevel = typeof commonjsGlobal !== "undefined" ? commonjsGlobal : typeof window !== "undefined" ? window : {};
- var minDoc = require$$0;
- var doccy;
- if (typeof document !== "undefined") {
- doccy = document;
- } else {
- doccy = topLevel["__GLOBAL_DOCUMENT_CACHE@4"];
- if (!doccy) {
- doccy = topLevel["__GLOBAL_DOCUMENT_CACHE@4"] = minDoc;
- }
- }
- var document_1 = doccy;
- var keycode$1 = { exports: {} };
- (function(module2, exports2) {
- function keyCode(searchInput) {
- if (searchInput && "object" === typeof searchInput) {
- var hasKeyCode = searchInput.which || searchInput.keyCode || searchInput.charCode;
- if (hasKeyCode)
- searchInput = hasKeyCode;
- }
- if ("number" === typeof searchInput)
- return names2[searchInput];
- var search = String(searchInput);
- var foundNamedKey = codes[search.toLowerCase()];
- if (foundNamedKey)
- return foundNamedKey;
- var foundNamedKey = aliases[search.toLowerCase()];
- if (foundNamedKey)
- return foundNamedKey;
- if (search.length === 1)
- return search.charCodeAt(0);
- return void 0;
- }
- keyCode.isEventKey = function isEventKey(event2, nameOrCode) {
- if (event2 && "object" === typeof event2) {
- var keyCode2 = event2.which || event2.keyCode || event2.charCode;
- if (keyCode2 === null || keyCode2 === void 0) {
- return false;
- }
- if (typeof nameOrCode === "string") {
- var foundNamedKey = codes[nameOrCode.toLowerCase()];
- if (foundNamedKey) {
- return foundNamedKey === keyCode2;
- }
- var foundNamedKey = aliases[nameOrCode.toLowerCase()];
- if (foundNamedKey) {
- return foundNamedKey === keyCode2;
- }
- } else if (typeof nameOrCode === "number") {
- return nameOrCode === keyCode2;
- }
- return false;
- }
- };
- exports2 = module2.exports = keyCode;
- var codes = exports2.code = exports2.codes = {
- "backspace": 8,
- "tab": 9,
- "enter": 13,
- "shift": 16,
- "ctrl": 17,
- "alt": 18,
- "pause/break": 19,
- "caps lock": 20,
- "esc": 27,
- "space": 32,
- "page up": 33,
- "page down": 34,
- "end": 35,
- "home": 36,
- "left": 37,
- "up": 38,
- "right": 39,
- "down": 40,
- "insert": 45,
- "delete": 46,
- "command": 91,
- "left command": 91,
- "right command": 93,
- "numpad *": 106,
- "numpad +": 107,
- "numpad -": 109,
- "numpad .": 110,
- "numpad /": 111,
- "num lock": 144,
- "scroll lock": 145,
- "my computer": 182,
- "my calculator": 183,
- ";": 186,
- "=": 187,
- ",": 188,
- "-": 189,
- ".": 190,
- "/": 191,
- "`": 192,
- "[": 219,
- "\\": 220,
- "]": 221,
- "'": 222
- };
- var aliases = exports2.aliases = {
- "windows": 91,
- "\u21E7": 16,
- "\u2325": 18,
- "\u2303": 17,
- "\u2318": 91,
- "ctl": 17,
- "control": 17,
- "option": 18,
- "pause": 19,
- "break": 19,
- "caps": 20,
- "return": 13,
- "escape": 27,
- "spc": 32,
- "spacebar": 32,
- "pgup": 33,
- "pgdn": 34,
- "ins": 45,
- "del": 46,
- "cmd": 91
- };
- /*!
- * Programatically add the following
- */
- for (i2 = 97; i2 < 123; i2++)
- codes[String.fromCharCode(i2)] = i2 - 32;
- for (var i2 = 48; i2 < 58; i2++)
- codes[i2 - 48] = i2;
- for (i2 = 1; i2 < 13; i2++)
- codes["f" + i2] = i2 + 111;
- for (i2 = 0; i2 < 10; i2++)
- codes["numpad " + i2] = i2 + 96;
- var names2 = exports2.names = exports2.title = {};
- for (i2 in codes)
- names2[codes[i2]] = i2;
- for (var alias in aliases) {
- codes[alias] = aliases[alias];
- }
- })(keycode$1, keycode$1.exports);
- var keycode = keycode$1.exports;
- var tuple = SafeParseTuple;
- function SafeParseTuple(obj, reviver) {
- var json;
- var error = null;
- try {
- json = JSON.parse(obj, reviver);
- } catch (err) {
- error = err;
- }
- return [error, json];
- }
- var lib = { exports: {} };
- function _extends$2() {
- _extends$2 = Object.assign ? Object.assign.bind() : function(target) {
- for (var i2 = 1; i2 < arguments.length; i2++) {
- var source = arguments[i2];
- for (var key in source) {
- if (Object.prototype.hasOwnProperty.call(source, key)) {
- target[key] = source[key];
- }
- }
- }
- return target;
- };
- return _extends$2.apply(this, arguments);
- }
- var _extends$3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
- __proto__: null,
- "default": _extends$2
- }, Symbol.toStringTag, { value: "Module" }));
- var require$$1 = /* @__PURE__ */ getAugmentedNamespace(_extends$3);
- var isFunction_1 = isFunction$1;
- var toString$2 = Object.prototype.toString;
- function isFunction$1(fn2) {
- if (!fn2) {
- return false;
- }
- var string = toString$2.call(fn2);
- return string === "[object Function]" || typeof fn2 === "function" && string !== "[object RegExp]" || typeof window !== "undefined" && (fn2 === window.setTimeout || fn2 === window.alert || fn2 === window.confirm || fn2 === window.prompt);
- }
- var window$3 = window_1;
- var httpResponseHandler = function httpResponseHandler2(callback2, decodeResponseBody) {
- if (decodeResponseBody === void 0) {
- decodeResponseBody = false;
- }
- return function(err, response, responseBody) {
- if (err) {
- callback2(err);
- return;
- }
- if (response.statusCode >= 400 && response.statusCode <= 599) {
- var cause = responseBody;
- if (decodeResponseBody) {
- if (window$3.TextDecoder) {
- var charset = getCharset(response.headers && response.headers["content-type"]);
- try {
- cause = new TextDecoder(charset).decode(responseBody);
- } catch (e) {
- }
- } else {
- cause = String.fromCharCode.apply(null, new Uint8Array(responseBody));
- }
- }
- callback2({
- cause
- });
- return;
- }
- callback2(null, responseBody);
- };
- };
- function getCharset(contentTypeHeader) {
- if (contentTypeHeader === void 0) {
- contentTypeHeader = "";
- }
- return contentTypeHeader.toLowerCase().split(";").reduce(function(charset, contentType) {
- var _contentType$split = contentType.split("="), type2 = _contentType$split[0], value = _contentType$split[1];
- if (type2.trim() === "charset") {
- return value.trim();
- }
- return charset;
- }, "utf-8");
- }
- var httpHandler = httpResponseHandler;
- var window$2 = window_1;
- var _extends$1 = require$$1;
- var isFunction = isFunction_1;
- createXHR.httpHandler = httpHandler;
- /**
- * @license
- * slighly modified parse-headers 2.0.2 <https://github.com/kesla/parse-headers/>
- * Copyright (c) 2014 David Björklund
- * Available under the MIT license
- * <https://github.com/kesla/parse-headers/blob/master/LICENCE>
- */
- var parseHeaders = function parseHeaders2(headers) {
- var result = {};
- if (!headers) {
- return result;
- }
- headers.trim().split("\n").forEach(function(row) {
- var index2 = row.indexOf(":");
- var key = row.slice(0, index2).trim().toLowerCase();
- var value = row.slice(index2 + 1).trim();
- if (typeof result[key] === "undefined") {
- result[key] = value;
- } else if (Array.isArray(result[key])) {
- result[key].push(value);
- } else {
- result[key] = [result[key], value];
- }
- });
- return result;
- };
- lib.exports = createXHR;
- lib.exports.default = createXHR;
- createXHR.XMLHttpRequest = window$2.XMLHttpRequest || noop$2;
- createXHR.XDomainRequest = "withCredentials" in new createXHR.XMLHttpRequest() ? createXHR.XMLHttpRequest : window$2.XDomainRequest;
- forEachArray(["get", "put", "post", "patch", "head", "delete"], function(method) {
- createXHR[method === "delete" ? "del" : method] = function(uri, options2, callback2) {
- options2 = initParams(uri, options2, callback2);
- options2.method = method.toUpperCase();
- return _createXHR(options2);
- };
- });
- function forEachArray(array, iterator) {
- for (var i2 = 0; i2 < array.length; i2++) {
- iterator(array[i2]);
- }
- }
- function isEmpty(obj) {
- for (var i2 in obj) {
- if (obj.hasOwnProperty(i2))
- return false;
- }
- return true;
- }
- function initParams(uri, options2, callback2) {
- var params = uri;
- if (isFunction(options2)) {
- callback2 = options2;
- if (typeof uri === "string") {
- params = {
- uri
- };
- }
- } else {
- params = _extends$1({}, options2, {
- uri
- });
- }
- params.callback = callback2;
- return params;
- }
- function createXHR(uri, options2, callback2) {
- options2 = initParams(uri, options2, callback2);
- return _createXHR(options2);
- }
- function _createXHR(options2) {
- if (typeof options2.callback === "undefined") {
- throw new Error("callback argument missing");
- }
- var called = false;
- var callback2 = function cbOnce(err, response, body2) {
- if (!called) {
- called = true;
- options2.callback(err, response, body2);
- }
- };
- function readystatechange() {
- if (xhr.readyState === 4) {
- setTimeout(loadFunc, 0);
- }
- }
- function getBody() {
- var body2 = void 0;
- if (xhr.response) {
- body2 = xhr.response;
- } else {
- body2 = xhr.responseText || getXml(xhr);
- }
- if (isJson) {
- try {
- body2 = JSON.parse(body2);
- } catch (e) {
- }
- }
- return body2;
- }
- function errorFunc(evt) {
- clearTimeout(timeoutTimer);
- if (!(evt instanceof Error)) {
- evt = new Error("" + (evt || "Unknown XMLHttpRequest Error"));
- }
- evt.statusCode = 0;
- return callback2(evt, failureResponse);
- }
- function loadFunc() {
- if (aborted)
- return;
- var status;
- clearTimeout(timeoutTimer);
- if (options2.useXDR && xhr.status === void 0) {
- status = 200;
- } else {
- status = xhr.status === 1223 ? 204 : xhr.status;
- }
- var response = failureResponse;
- var err = null;
- if (status !== 0) {
- response = {
- body: getBody(),
- statusCode: status,
- method,
- headers: {},
- url: uri,
- rawRequest: xhr
- };
- if (xhr.getAllResponseHeaders) {
- response.headers = parseHeaders(xhr.getAllResponseHeaders());
- }
- } else {
- err = new Error("Internal XMLHttpRequest Error");
- }
- return callback2(err, response, response.body);
- }
- var xhr = options2.xhr || null;
- if (!xhr) {
- if (options2.cors || options2.useXDR) {
- xhr = new createXHR.XDomainRequest();
- } else {
- xhr = new createXHR.XMLHttpRequest();
- }
- }
- var key;
- var aborted;
- var uri = xhr.url = options2.uri || options2.url;
- var method = xhr.method = options2.method || "GET";
- var body = options2.body || options2.data;
- var headers = xhr.headers = options2.headers || {};
- var sync = !!options2.sync;
- var isJson = false;
- var timeoutTimer;
- var failureResponse = {
- body: void 0,
- headers: {},
- statusCode: 0,
- method,
- url: uri,
- rawRequest: xhr
- };
- if ("json" in options2 && options2.json !== false) {
- isJson = true;
- headers["accept"] || headers["Accept"] || (headers["Accept"] = "application/json");
- if (method !== "GET" && method !== "HEAD") {
- headers["content-type"] || headers["Content-Type"] || (headers["Content-Type"] = "application/json");
- body = JSON.stringify(options2.json === true ? body : options2.json);
- }
- }
- xhr.onreadystatechange = readystatechange;
- xhr.onload = loadFunc;
- xhr.onerror = errorFunc;
- xhr.onprogress = function() {
- };
- xhr.onabort = function() {
- aborted = true;
- };
- xhr.ontimeout = errorFunc;
- xhr.open(method, uri, !sync, options2.username, options2.password);
- if (!sync) {
- xhr.withCredentials = !!options2.withCredentials;
- }
- if (!sync && options2.timeout > 0) {
- timeoutTimer = setTimeout(function() {
- if (aborted)
- return;
- aborted = true;
- xhr.abort("timeout");
- var e = new Error("XMLHttpRequest timeout");
- e.code = "ETIMEDOUT";
- errorFunc(e);
- }, options2.timeout);
- }
- if (xhr.setRequestHeader) {
- for (key in headers) {
- if (headers.hasOwnProperty(key)) {
- xhr.setRequestHeader(key, headers[key]);
- }
- }
- } else if (options2.headers && !isEmpty(options2.headers)) {
- throw new Error("Headers cannot be set on an XDomainRequest object");
- }
- if ("responseType" in options2) {
- xhr.responseType = options2.responseType;
- }
- if ("beforeSend" in options2 && typeof options2.beforeSend === "function") {
- options2.beforeSend(xhr);
- }
- xhr.send(body || null);
- return xhr;
- }
- function getXml(xhr) {
- try {
- if (xhr.responseType === "document") {
- return xhr.responseXML;
- }
- var firefoxBugTakenEffect = xhr.responseXML && xhr.responseXML.documentElement.nodeName === "parsererror";
- if (xhr.responseType === "" && !firefoxBugTakenEffect) {
- return xhr.responseXML;
- }
- } catch (e) {
- }
- return null;
- }
- function noop$2() {
- }
- var XHR = lib.exports;
- var browserIndex = { exports: {} };
- var document$1 = document_1;
- var _objCreate = Object.create || function() {
- function F() {
- }
- return function(o) {
- if (arguments.length !== 1) {
- throw new Error("Object.create shim only accepts one parameter.");
- }
- F.prototype = o;
- return new F();
- };
- }();
- function ParsingError(errorData, message) {
- this.name = "ParsingError";
- this.code = errorData.code;
- this.message = message || errorData.message;
- }
- ParsingError.prototype = _objCreate(Error.prototype);
- ParsingError.prototype.constructor = ParsingError;
- ParsingError.Errors = {
- BadSignature: {
- code: 0,
- message: "Malformed WebVTT signature."
- },
- BadTimeStamp: {
- code: 1,
- message: "Malformed time stamp."
- }
- };
- function parseTimeStamp(input) {
- function computeSeconds(h2, m2, s, f) {
- return (h2 | 0) * 3600 + (m2 | 0) * 60 + (s | 0) + (f | 0) / 1e3;
- }
- var m = input.match(/^(\d+):(\d{1,2})(:\d{1,2})?\.(\d{3})/);
- if (!m) {
- return null;
- }
- if (m[3]) {
- return computeSeconds(m[1], m[2], m[3].replace(":", ""), m[4]);
- } else if (m[1] > 59) {
- return computeSeconds(m[1], m[2], 0, m[4]);
- } else {
- return computeSeconds(0, m[1], m[2], m[4]);
- }
- }
- function Settings() {
- this.values = _objCreate(null);
- }
- Settings.prototype = {
- set: function(k, v) {
- if (!this.get(k) && v !== "") {
- this.values[k] = v;
- }
- },
- get: function(k, dflt, defaultKey) {
- if (defaultKey) {
- return this.has(k) ? this.values[k] : dflt[defaultKey];
- }
- return this.has(k) ? this.values[k] : dflt;
- },
- has: function(k) {
- return k in this.values;
- },
- alt: function(k, v, a) {
- for (var n = 0; n < a.length; ++n) {
- if (v === a[n]) {
- this.set(k, v);
- break;
- }
- }
- },
- integer: function(k, v) {
- if (/^-?\d+$/.test(v)) {
- this.set(k, parseInt(v, 10));
- }
- },
- percent: function(k, v) {
- if (v.match(/^([\d]{1,3})(\.[\d]*)?%$/)) {
- v = parseFloat(v);
- if (v >= 0 && v <= 100) {
- this.set(k, v);
- return true;
- }
- }
- return false;
- }
- };
- function parseOptions(input, callback2, keyValueDelim, groupDelim) {
- var groups = groupDelim ? input.split(groupDelim) : [input];
- for (var i2 in groups) {
- if (typeof groups[i2] !== "string") {
- continue;
- }
- var kv = groups[i2].split(keyValueDelim);
- if (kv.length !== 2) {
- continue;
- }
- var k = kv[0].trim();
- var v = kv[1].trim();
- callback2(k, v);
- }
- }
- function parseCue(input, cue, regionList) {
- var oInput = input;
- function consumeTimeStamp() {
- var ts3 = parseTimeStamp(input);
- if (ts3 === null) {
- throw new ParsingError(
- ParsingError.Errors.BadTimeStamp,
- "Malformed timestamp: " + oInput
- );
- }
- input = input.replace(/^[^\sa-zA-Z-]+/, "");
- return ts3;
- }
- function consumeCueSettings(input2, cue2) {
- var settings = new Settings();
- parseOptions(input2, function(k, v) {
- switch (k) {
- case "region":
- for (var i2 = regionList.length - 1; i2 >= 0; i2--) {
- if (regionList[i2].id === v) {
- settings.set(k, regionList[i2].region);
- break;
- }
- }
- break;
- case "vertical":
- settings.alt(k, v, ["rl", "lr"]);
- break;
- case "line":
- var vals = v.split(","), vals0 = vals[0];
- settings.integer(k, vals0);
- settings.percent(k, vals0) ? settings.set("snapToLines", false) : null;
- settings.alt(k, vals0, ["auto"]);
- if (vals.length === 2) {
- settings.alt("lineAlign", vals[1], ["start", "center", "end"]);
- }
- break;
- case "position":
- vals = v.split(",");
- settings.percent(k, vals[0]);
- if (vals.length === 2) {
- settings.alt("positionAlign", vals[1], ["start", "center", "end"]);
- }
- break;
- case "size":
- settings.percent(k, v);
- break;
- case "align":
- settings.alt(k, v, ["start", "center", "end", "left", "right"]);
- break;
- }
- }, /:/, /\s/);
- cue2.region = settings.get("region", null);
- cue2.vertical = settings.get("vertical", "");
- try {
- cue2.line = settings.get("line", "auto");
- } catch (e) {
- }
- cue2.lineAlign = settings.get("lineAlign", "start");
- cue2.snapToLines = settings.get("snapToLines", true);
- cue2.size = settings.get("size", 100);
- try {
- cue2.align = settings.get("align", "center");
- } catch (e) {
- cue2.align = settings.get("align", "middle");
- }
- try {
- cue2.position = settings.get("position", "auto");
- } catch (e) {
- cue2.position = settings.get("position", {
- start: 0,
- left: 0,
- center: 50,
- middle: 50,
- end: 100,
- right: 100
- }, cue2.align);
- }
- cue2.positionAlign = settings.get("positionAlign", {
- start: "start",
- left: "start",
- center: "center",
- middle: "center",
- end: "end",
- right: "end"
- }, cue2.align);
- }
- function skipWhitespace() {
- input = input.replace(/^\s+/, "");
- }
- skipWhitespace();
- cue.startTime = consumeTimeStamp();
- skipWhitespace();
- if (input.substr(0, 3) !== "-->") {
- throw new ParsingError(
- ParsingError.Errors.BadTimeStamp,
- "Malformed time stamp (time stamps must be separated by '-->'): " + oInput
- );
- }
- input = input.substr(3);
- skipWhitespace();
- cue.endTime = consumeTimeStamp();
- skipWhitespace();
- consumeCueSettings(input, cue);
- }
- var TEXTAREA_ELEMENT = document$1.createElement && document$1.createElement("textarea");
- var TAG_NAME = {
- c: "span",
- i: "i",
- b: "b",
- u: "u",
- ruby: "ruby",
- rt: "rt",
- v: "span",
- lang: "span"
- };
- var DEFAULT_COLOR_CLASS = {
- white: "rgba(255,255,255,1)",
- lime: "rgba(0,255,0,1)",
- cyan: "rgba(0,255,255,1)",
- red: "rgba(255,0,0,1)",
- yellow: "rgba(255,255,0,1)",
- magenta: "rgba(255,0,255,1)",
- blue: "rgba(0,0,255,1)",
- black: "rgba(0,0,0,1)"
- };
- var TAG_ANNOTATION = {
- v: "title",
- lang: "lang"
- };
- var NEEDS_PARENT = {
- rt: "ruby"
- };
- function parseContent(window2, input) {
- function nextToken() {
- if (!input) {
- return null;
- }
- function consume(result) {
- input = input.substr(result.length);
- return result;
- }
- var m2 = input.match(/^([^<]*)(<[^>]*>?)?/);
- return consume(m2[1] ? m2[1] : m2[2]);
- }
- function unescape2(s) {
- TEXTAREA_ELEMENT.innerHTML = s;
- s = TEXTAREA_ELEMENT.textContent;
- TEXTAREA_ELEMENT.textContent = "";
- return s;
- }
- function shouldAdd(current2, element) {
- return !NEEDS_PARENT[element.localName] || NEEDS_PARENT[element.localName] === current2.localName;
- }
- function createElement(type2, annotation) {
- var tagName = TAG_NAME[type2];
- if (!tagName) {
- return null;
- }
- var element = window2.document.createElement(tagName);
- var name = TAG_ANNOTATION[type2];
- if (name && annotation) {
- element[name] = annotation.trim();
- }
- return element;
- }
- var rootDiv = window2.document.createElement("div"), current = rootDiv, t2, tagStack = [];
- while ((t2 = nextToken()) !== null) {
- if (t2[0] === "<") {
- if (t2[1] === "/") {
- if (tagStack.length && tagStack[tagStack.length - 1] === t2.substr(2).replace(">", "")) {
- tagStack.pop();
- current = current.parentNode;
- }
- continue;
- }
- var ts3 = parseTimeStamp(t2.substr(1, t2.length - 2));
- var node;
- if (ts3) {
- node = window2.document.createProcessingInstruction("timestamp", ts3);
- current.appendChild(node);
- continue;
- }
- var m = t2.match(/^<([^.\s/0-9>]+)(\.[^\s\\>]+)?([^>\\]+)?(\\?)>?$/);
- if (!m) {
- continue;
- }
- node = createElement(m[1], m[3]);
- if (!node) {
- continue;
- }
- if (!shouldAdd(current, node)) {
- continue;
- }
- if (m[2]) {
- var classes = m[2].split(".");
- classes.forEach(function(cl) {
- var bgColor = /^bg_/.test(cl);
- var colorName = bgColor ? cl.slice(3) : cl;
- if (DEFAULT_COLOR_CLASS.hasOwnProperty(colorName)) {
- var propName = bgColor ? "background-color" : "color";
- var propValue = DEFAULT_COLOR_CLASS[colorName];
- node.style[propName] = propValue;
- }
- });
- node.className = classes.join(" ");
- }
- tagStack.push(m[1]);
- current.appendChild(node);
- current = node;
- continue;
- }
- current.appendChild(window2.document.createTextNode(unescape2(t2)));
- }
- return rootDiv;
- }
- var strongRTLRanges = [
- [1470, 1470],
- [1472, 1472],
- [1475, 1475],
- [1478, 1478],
- [1488, 1514],
- [1520, 1524],
- [1544, 1544],
- [1547, 1547],
- [1549, 1549],
- [1563, 1563],
- [1566, 1610],
- [1645, 1647],
- [1649, 1749],
- [1765, 1766],
- [1774, 1775],
- [1786, 1805],
- [1807, 1808],
- [1810, 1839],
- [1869, 1957],
- [1969, 1969],
- [1984, 2026],
- [2036, 2037],
- [2042, 2042],
- [2048, 2069],
- [2074, 2074],
- [2084, 2084],
- [2088, 2088],
- [2096, 2110],
- [2112, 2136],
- [2142, 2142],
- [2208, 2208],
- [2210, 2220],
- [8207, 8207],
- [64285, 64285],
- [64287, 64296],
- [64298, 64310],
- [64312, 64316],
- [64318, 64318],
- [64320, 64321],
- [64323, 64324],
- [64326, 64449],
- [64467, 64829],
- [64848, 64911],
- [64914, 64967],
- [65008, 65020],
- [65136, 65140],
- [65142, 65276],
- [67584, 67589],
- [67592, 67592],
- [67594, 67637],
- [67639, 67640],
- [67644, 67644],
- [67647, 67669],
- [67671, 67679],
- [67840, 67867],
- [67872, 67897],
- [67903, 67903],
- [67968, 68023],
- [68030, 68031],
- [68096, 68096],
- [68112, 68115],
- [68117, 68119],
- [68121, 68147],
- [68160, 68167],
- [68176, 68184],
- [68192, 68223],
- [68352, 68405],
- [68416, 68437],
- [68440, 68466],
- [68472, 68479],
- [68608, 68680],
- [126464, 126467],
- [126469, 126495],
- [126497, 126498],
- [126500, 126500],
- [126503, 126503],
- [126505, 126514],
- [126516, 126519],
- [126521, 126521],
- [126523, 126523],
- [126530, 126530],
- [126535, 126535],
- [126537, 126537],
- [126539, 126539],
- [126541, 126543],
- [126545, 126546],
- [126548, 126548],
- [126551, 126551],
- [126553, 126553],
- [126555, 126555],
- [126557, 126557],
- [126559, 126559],
- [126561, 126562],
- [126564, 126564],
- [126567, 126570],
- [126572, 126578],
- [126580, 126583],
- [126585, 126588],
- [126590, 126590],
- [126592, 126601],
- [126603, 126619],
- [126625, 126627],
- [126629, 126633],
- [126635, 126651],
- [1114109, 1114109]
- ];
- function isStrongRTLChar(charCode) {
- for (var i2 = 0; i2 < strongRTLRanges.length; i2++) {
- var currentRange = strongRTLRanges[i2];
- if (charCode >= currentRange[0] && charCode <= currentRange[1]) {
- return true;
- }
- }
- return false;
- }
- function determineBidi(cueDiv) {
- var nodeStack = [], text = "", charCode;
- if (!cueDiv || !cueDiv.childNodes) {
- return "ltr";
- }
- function pushNodes(nodeStack2, node) {
- for (var i3 = node.childNodes.length - 1; i3 >= 0; i3--) {
- nodeStack2.push(node.childNodes[i3]);
- }
- }
- function nextTextNode(nodeStack2) {
- if (!nodeStack2 || !nodeStack2.length) {
- return null;
- }
- var node = nodeStack2.pop(), text2 = node.textContent || node.innerText;
- if (text2) {
- var m = text2.match(/^.*(\n|\r)/);
- if (m) {
- nodeStack2.length = 0;
- return m[0];
- }
- return text2;
- }
- if (node.tagName === "ruby") {
- return nextTextNode(nodeStack2);
- }
- if (node.childNodes) {
- pushNodes(nodeStack2, node);
- return nextTextNode(nodeStack2);
- }
- }
- pushNodes(nodeStack, cueDiv);
- while (text = nextTextNode(nodeStack)) {
- for (var i2 = 0; i2 < text.length; i2++) {
- charCode = text.charCodeAt(i2);
- if (isStrongRTLChar(charCode)) {
- return "rtl";
- }
- }
- }
- return "ltr";
- }
- function computeLinePos(cue) {
- if (typeof cue.line === "number" && (cue.snapToLines || cue.line >= 0 && cue.line <= 100)) {
- return cue.line;
- }
- if (!cue.track || !cue.track.textTrackList || !cue.track.textTrackList.mediaElement) {
- return -1;
- }
- var track = cue.track, trackList = track.textTrackList, count = 0;
- for (var i2 = 0; i2 < trackList.length && trackList[i2] !== track; i2++) {
- if (trackList[i2].mode === "showing") {
- count++;
- }
- }
- return ++count * -1;
- }
- function StyleBox() {
- }
- StyleBox.prototype.applyStyles = function(styles, div) {
- div = div || this.div;
- for (var prop in styles) {
- if (styles.hasOwnProperty(prop)) {
- div.style[prop] = styles[prop];
- }
- }
- };
- StyleBox.prototype.formatStyle = function(val, unit) {
- return val === 0 ? 0 : val + unit;
- };
- function CueStyleBox(window2, cue, styleOptions) {
- StyleBox.call(this);
- this.cue = cue;
- this.cueDiv = parseContent(window2, cue.text);
- var styles = {
- color: "rgba(255, 255, 255, 1)",
- backgroundColor: "rgba(0, 0, 0, 0.8)",
- position: "relative",
- left: 0,
- right: 0,
- top: 0,
- bottom: 0,
- display: "inline",
- writingMode: cue.vertical === "" ? "horizontal-tb" : cue.vertical === "lr" ? "vertical-lr" : "vertical-rl",
- unicodeBidi: "plaintext"
- };
- this.applyStyles(styles, this.cueDiv);
- this.div = window2.document.createElement("div");
- styles = {
- direction: determineBidi(this.cueDiv),
- writingMode: cue.vertical === "" ? "horizontal-tb" : cue.vertical === "lr" ? "vertical-lr" : "vertical-rl",
- unicodeBidi: "plaintext",
- textAlign: cue.align === "middle" ? "center" : cue.align,
- font: styleOptions.font,
- whiteSpace: "pre-line",
- position: "absolute"
- };
- this.applyStyles(styles);
- this.div.appendChild(this.cueDiv);
- var textPos = 0;
- switch (cue.positionAlign) {
- case "start":
- textPos = cue.position;
- break;
- case "center":
- textPos = cue.position - cue.size / 2;
- break;
- case "end":
- textPos = cue.position - cue.size;
- break;
- }
- if (cue.vertical === "") {
- this.applyStyles({
- left: this.formatStyle(textPos, "%"),
- width: this.formatStyle(cue.size, "%")
- });
- } else {
- this.applyStyles({
- top: this.formatStyle(textPos, "%"),
- height: this.formatStyle(cue.size, "%")
- });
- }
- this.move = function(box) {
- this.applyStyles({
- top: this.formatStyle(box.top, "px"),
- bottom: this.formatStyle(box.bottom, "px"),
- left: this.formatStyle(box.left, "px"),
- right: this.formatStyle(box.right, "px"),
- height: this.formatStyle(box.height, "px"),
- width: this.formatStyle(box.width, "px")
- });
- };
- }
- CueStyleBox.prototype = _objCreate(StyleBox.prototype);
- CueStyleBox.prototype.constructor = CueStyleBox;
- function BoxPosition(obj) {
- var lh, height2, width2, top;
- if (obj.div) {
- height2 = obj.div.offsetHeight;
- width2 = obj.div.offsetWidth;
- top = obj.div.offsetTop;
- var rects = (rects = obj.div.childNodes) && (rects = rects[0]) && rects.getClientRects && rects.getClientRects();
- obj = obj.div.getBoundingClientRect();
- lh = rects ? Math.max(rects[0] && rects[0].height || 0, obj.height / rects.length) : 0;
- }
- this.left = obj.left;
- this.right = obj.right;
- this.top = obj.top || top;
- this.height = obj.height || height2;
- this.bottom = obj.bottom || top + (obj.height || height2);
- this.width = obj.width || width2;
- this.lineHeight = lh !== void 0 ? lh : obj.lineHeight;
- }
- BoxPosition.prototype.move = function(axis, toMove) {
- toMove = toMove !== void 0 ? toMove : this.lineHeight;
- switch (axis) {
- case "+x":
- this.left += toMove;
- this.right += toMove;
- break;
- case "-x":
- this.left -= toMove;
- this.right -= toMove;
- break;
- case "+y":
- this.top += toMove;
- this.bottom += toMove;
- break;
- case "-y":
- this.top -= toMove;
- this.bottom -= toMove;
- break;
- }
- };
- BoxPosition.prototype.overlaps = function(b2) {
- return this.left < b2.right && this.right > b2.left && this.top < b2.bottom && this.bottom > b2.top;
- };
- BoxPosition.prototype.overlapsAny = function(boxes) {
- for (var i2 = 0; i2 < boxes.length; i2++) {
- if (this.overlaps(boxes[i2])) {
- return true;
- }
- }
- return false;
- };
- BoxPosition.prototype.within = function(container) {
- return this.top >= container.top && this.bottom <= container.bottom && this.left >= container.left && this.right <= container.right;
- };
- BoxPosition.prototype.overlapsOppositeAxis = function(container, axis) {
- switch (axis) {
- case "+x":
- return this.left < container.left;
- case "-x":
- return this.right > container.right;
- case "+y":
- return this.top < container.top;
- case "-y":
- return this.bottom > container.bottom;
- }
- };
- BoxPosition.prototype.intersectPercentage = function(b2) {
- var x = Math.max(0, Math.min(this.right, b2.right) - Math.max(this.left, b2.left)), y = Math.max(0, Math.min(this.bottom, b2.bottom) - Math.max(this.top, b2.top)), intersectArea = x * y;
- return intersectArea / (this.height * this.width);
- };
- BoxPosition.prototype.toCSSCompatValues = function(reference) {
- return {
- top: this.top - reference.top,
- bottom: reference.bottom - this.bottom,
- left: this.left - reference.left,
- right: reference.right - this.right,
- height: this.height,
- width: this.width
- };
- };
- BoxPosition.getSimpleBoxPosition = function(obj) {
- var height2 = obj.div ? obj.div.offsetHeight : obj.tagName ? obj.offsetHeight : 0;
- var width2 = obj.div ? obj.div.offsetWidth : obj.tagName ? obj.offsetWidth : 0;
- var top = obj.div ? obj.div.offsetTop : obj.tagName ? obj.offsetTop : 0;
- obj = obj.div ? obj.div.getBoundingClientRect() : obj.tagName ? obj.getBoundingClientRect() : obj;
- var ret = {
- left: obj.left,
- right: obj.right,
- top: obj.top || top,
- height: obj.height || height2,
- bottom: obj.bottom || top + (obj.height || height2),
- width: obj.width || width2
- };
- return ret;
- };
- function moveBoxToLinePosition(window2, styleBox, containerBox, boxPositions) {
- function findBestPosition(b, axis2) {
- var bestPosition2, specifiedPosition = new BoxPosition(b), percentage = 1;
- for (var i2 = 0; i2 < axis2.length; i2++) {
- while (b.overlapsOppositeAxis(containerBox, axis2[i2]) || b.within(containerBox) && b.overlapsAny(boxPositions)) {
- b.move(axis2[i2]);
- }
- if (b.within(containerBox)) {
- return b;
- }
- var p = b.intersectPercentage(containerBox);
- if (percentage > p) {
- bestPosition2 = new BoxPosition(b);
- percentage = p;
- }
- b = new BoxPosition(specifiedPosition);
- }
- return bestPosition2 || specifiedPosition;
- }
- var boxPosition = new BoxPosition(styleBox), cue = styleBox.cue, linePos = computeLinePos(cue), axis = [];
- if (cue.snapToLines) {
- var size;
- switch (cue.vertical) {
- case "":
- axis = ["+y", "-y"];
- size = "height";
- break;
- case "rl":
- axis = ["+x", "-x"];
- size = "width";
- break;
- case "lr":
- axis = ["-x", "+x"];
- size = "width";
- break;
- }
- var step = boxPosition.lineHeight, position2 = step * Math.round(linePos), maxPosition = containerBox[size] + step, initialAxis = axis[0];
- if (Math.abs(position2) > maxPosition) {
- position2 = position2 < 0 ? -1 : 1;
- position2 *= Math.ceil(maxPosition / step) * step;
- }
- if (linePos < 0) {
- position2 += cue.vertical === "" ? containerBox.height : containerBox.width;
- axis = axis.reverse();
- }
- boxPosition.move(initialAxis, position2);
- } else {
- var calculatedPercentage = boxPosition.lineHeight / containerBox.height * 100;
- switch (cue.lineAlign) {
- case "center":
- linePos -= calculatedPercentage / 2;
- break;
- case "end":
- linePos -= calculatedPercentage;
- break;
- }
- switch (cue.vertical) {
- case "":
- styleBox.applyStyles({
- top: styleBox.formatStyle(linePos, "%")
- });
- break;
- case "rl":
- styleBox.applyStyles({
- left: styleBox.formatStyle(linePos, "%")
- });
- break;
- case "lr":
- styleBox.applyStyles({
- right: styleBox.formatStyle(linePos, "%")
- });
- break;
- }
- axis = ["+y", "-x", "+x", "-y"];
- boxPosition = new BoxPosition(styleBox);
- }
- var bestPosition = findBestPosition(boxPosition, axis);
- styleBox.move(bestPosition.toCSSCompatValues(containerBox));
- }
- function WebVTT$1() {
- }
- WebVTT$1.StringDecoder = function() {
- return {
- decode: function(data) {
- if (!data) {
- return "";
- }
- if (typeof data !== "string") {
- throw new Error("Error - expected string data.");
- }
- return decodeURIComponent(encodeURIComponent(data));
- }
- };
- };
- WebVTT$1.convertCueToDOMTree = function(window2, cuetext) {
- if (!window2 || !cuetext) {
- return null;
- }
- return parseContent(window2, cuetext);
- };
- var FONT_SIZE_PERCENT = 0.05;
- var FONT_STYLE = "sans-serif";
- var CUE_BACKGROUND_PADDING = "1.5%";
- WebVTT$1.processCues = function(window2, cues, overlay) {
- if (!window2 || !cues || !overlay) {
- return null;
- }
- while (overlay.firstChild) {
- overlay.removeChild(overlay.firstChild);
- }
- var paddedOverlay = window2.document.createElement("div");
- paddedOverlay.style.position = "absolute";
- paddedOverlay.style.left = "0";
- paddedOverlay.style.right = "0";
- paddedOverlay.style.top = "0";
- paddedOverlay.style.bottom = "0";
- paddedOverlay.style.margin = CUE_BACKGROUND_PADDING;
- overlay.appendChild(paddedOverlay);
- function shouldCompute(cues2) {
- for (var i3 = 0; i3 < cues2.length; i3++) {
- if (cues2[i3].hasBeenReset || !cues2[i3].displayState) {
- return true;
- }
- }
- return false;
- }
- if (!shouldCompute(cues)) {
- for (var i2 = 0; i2 < cues.length; i2++) {
- paddedOverlay.appendChild(cues[i2].displayState);
- }
- return;
- }
- var boxPositions = [], containerBox = BoxPosition.getSimpleBoxPosition(paddedOverlay), fontSize = Math.round(containerBox.height * FONT_SIZE_PERCENT * 100) / 100;
- var styleOptions = {
- font: fontSize + "px " + FONT_STYLE
- };
- (function() {
- var styleBox, cue;
- for (var i3 = 0; i3 < cues.length; i3++) {
- cue = cues[i3];
- styleBox = new CueStyleBox(window2, cue, styleOptions);
- paddedOverlay.appendChild(styleBox.div);
- moveBoxToLinePosition(window2, styleBox, containerBox, boxPositions);
- cue.displayState = styleBox.div;
- boxPositions.push(BoxPosition.getSimpleBoxPosition(styleBox));
- }
- })();
- };
- WebVTT$1.Parser = function(window2, vttjs2, decoder) {
- if (!decoder) {
- decoder = vttjs2;
- vttjs2 = {};
- }
- if (!vttjs2) {
- vttjs2 = {};
- }
- this.window = window2;
- this.vttjs = vttjs2;
- this.state = "INITIAL";
- this.buffer = "";
- this.decoder = decoder || new TextDecoder("utf8");
- this.regionList = [];
- };
- WebVTT$1.Parser.prototype = {
- reportOrThrowError: function(e) {
- if (e instanceof ParsingError) {
- this.onparsingerror && this.onparsingerror(e);
- } else {
- throw e;
- }
- },
- parse: function(data) {
- var self2 = this;
- if (data) {
- self2.buffer += self2.decoder.decode(data, { stream: true });
- }
- function collectNextLine() {
- var buffer = self2.buffer;
- var pos = 0;
- while (pos < buffer.length && buffer[pos] !== "\r" && buffer[pos] !== "\n") {
- ++pos;
- }
- var line2 = buffer.substr(0, pos);
- if (buffer[pos] === "\r") {
- ++pos;
- }
- if (buffer[pos] === "\n") {
- ++pos;
- }
- self2.buffer = buffer.substr(pos);
- return line2;
- }
- function parseRegion(input) {
- var settings = new Settings();
- parseOptions(input, function(k, v) {
- switch (k) {
- case "id":
- settings.set(k, v);
- break;
- case "width":
- settings.percent(k, v);
- break;
- case "lines":
- settings.integer(k, v);
- break;
- case "regionanchor":
- case "viewportanchor":
- var xy = v.split(",");
- if (xy.length !== 2) {
- break;
- }
- var anchor = new Settings();
- anchor.percent("x", xy[0]);
- anchor.percent("y", xy[1]);
- if (!anchor.has("x") || !anchor.has("y")) {
- break;
- }
- settings.set(k + "X", anchor.get("x"));
- settings.set(k + "Y", anchor.get("y"));
- break;
- case "scroll":
- settings.alt(k, v, ["up"]);
- break;
- }
- }, /=/, /\s/);
- if (settings.has("id")) {
- var region = new (self2.vttjs.VTTRegion || self2.window.VTTRegion)();
- region.width = settings.get("width", 100);
- region.lines = settings.get("lines", 3);
- region.regionAnchorX = settings.get("regionanchorX", 0);
- region.regionAnchorY = settings.get("regionanchorY", 100);
- region.viewportAnchorX = settings.get("viewportanchorX", 0);
- region.viewportAnchorY = settings.get("viewportanchorY", 100);
- region.scroll = settings.get("scroll", "");
- self2.onregion && self2.onregion(region);
- self2.regionList.push({
- id: settings.get("id"),
- region
- });
- }
- }
- function parseTimestampMap(input) {
- var settings = new Settings();
- parseOptions(input, function(k, v) {
- switch (k) {
- case "MPEGT":
- settings.integer(k + "S", v);
- break;
- case "LOCA":
- settings.set(k + "L", parseTimeStamp(v));
- break;
- }
- }, /[^\d]:/, /,/);
- self2.ontimestampmap && self2.ontimestampmap({
- "MPEGTS": settings.get("MPEGTS"),
- "LOCAL": settings.get("LOCAL")
- });
- }
- function parseHeader(input) {
- if (input.match(/X-TIMESTAMP-MAP/)) {
- parseOptions(input, function(k, v) {
- switch (k) {
- case "X-TIMESTAMP-MAP":
- parseTimestampMap(v);
- break;
- }
- }, /=/);
- } else {
- parseOptions(input, function(k, v) {
- switch (k) {
- case "Region":
- parseRegion(v);
- break;
- }
- }, /:/);
- }
- }
- try {
- var line;
- if (self2.state === "INITIAL") {
- if (!/\r\n|\n/.test(self2.buffer)) {
- return this;
- }
- line = collectNextLine();
- var m = line.match(/^WEBVTT([ \t].*)?$/);
- if (!m || !m[0]) {
- throw new ParsingError(ParsingError.Errors.BadSignature);
- }
- self2.state = "HEADER";
- }
- var alreadyCollectedLine = false;
- while (self2.buffer) {
- if (!/\r\n|\n/.test(self2.buffer)) {
- return this;
- }
- if (!alreadyCollectedLine) {
- line = collectNextLine();
- } else {
- alreadyCollectedLine = false;
- }
- switch (self2.state) {
- case "HEADER":
- if (/:/.test(line)) {
- parseHeader(line);
- } else if (!line) {
- self2.state = "ID";
- }
- continue;
- case "NOTE":
- if (!line) {
- self2.state = "ID";
- }
- continue;
- case "ID":
- if (/^NOTE($|[ \t])/.test(line)) {
- self2.state = "NOTE";
- break;
- }
- if (!line) {
- continue;
- }
- self2.cue = new (self2.vttjs.VTTCue || self2.window.VTTCue)(0, 0, "");
- try {
- self2.cue.align = "center";
- } catch (e) {
- self2.cue.align = "middle";
- }
- self2.state = "CUE";
- if (line.indexOf("-->") === -1) {
- self2.cue.id = line;
- continue;
- }
- case "CUE":
- try {
- parseCue(line, self2.cue, self2.regionList);
- } catch (e) {
- self2.reportOrThrowError(e);
- self2.cue = null;
- self2.state = "BADCUE";
- continue;
- }
- self2.state = "CUETEXT";
- continue;
- case "CUETEXT":
- var hasSubstring = line.indexOf("-->") !== -1;
- if (!line || hasSubstring && (alreadyCollectedLine = true)) {
- self2.oncue && self2.oncue(self2.cue);
- self2.cue = null;
- self2.state = "ID";
- continue;
- }
- if (self2.cue.text) {
- self2.cue.text += "\n";
- }
- self2.cue.text += line.replace(/\u2028/g, "\n").replace(/u2029/g, "\n");
- continue;
- case "BADCUE":
- if (!line) {
- self2.state = "ID";
- }
- continue;
- }
- }
- } catch (e) {
- self2.reportOrThrowError(e);
- if (self2.state === "CUETEXT" && self2.cue && self2.oncue) {
- self2.oncue(self2.cue);
- }
- self2.cue = null;
- self2.state = self2.state === "INITIAL" ? "BADWEBVTT" : "BADCUE";
- }
- return this;
- },
- flush: function() {
- var self2 = this;
- try {
- self2.buffer += self2.decoder.decode();
- if (self2.cue || self2.state === "HEADER") {
- self2.buffer += "\n\n";
- self2.parse();
- }
- if (self2.state === "INITIAL") {
- throw new ParsingError(ParsingError.Errors.BadSignature);
- }
- } catch (e) {
- self2.reportOrThrowError(e);
- }
- self2.onflush && self2.onflush();
- return this;
- }
- };
- var vtt$1 = WebVTT$1;
- var autoKeyword = "auto";
- var directionSetting = {
- "": 1,
- "lr": 1,
- "rl": 1
- };
- var alignSetting = {
- "start": 1,
- "center": 1,
- "end": 1,
- "left": 1,
- "right": 1,
- "auto": 1,
- "line-left": 1,
- "line-right": 1
- };
- function findDirectionSetting(value) {
- if (typeof value !== "string") {
- return false;
- }
- var dir = directionSetting[value.toLowerCase()];
- return dir ? value.toLowerCase() : false;
- }
- function findAlignSetting(value) {
- if (typeof value !== "string") {
- return false;
- }
- var align = alignSetting[value.toLowerCase()];
- return align ? value.toLowerCase() : false;
- }
- function VTTCue(startTime, endTime, text) {
- this.hasBeenReset = false;
- var _id = "";
- var _pauseOnExit = false;
- var _startTime = startTime;
- var _endTime = endTime;
- var _text = text;
- var _region = null;
- var _vertical = "";
- var _snapToLines = true;
- var _line = "auto";
- var _lineAlign = "start";
- var _position = "auto";
- var _positionAlign = "auto";
- var _size = 100;
- var _align = "center";
- Object.defineProperties(this, {
- "id": {
- enumerable: true,
- get: function() {
- return _id;
- },
- set: function(value) {
- _id = "" + value;
- }
- },
- "pauseOnExit": {
- enumerable: true,
- get: function() {
- return _pauseOnExit;
- },
- set: function(value) {
- _pauseOnExit = !!value;
- }
- },
- "startTime": {
- enumerable: true,
- get: function() {
- return _startTime;
- },
- set: function(value) {
- if (typeof value !== "number") {
- throw new TypeError("Start time must be set to a number.");
- }
- _startTime = value;
- this.hasBeenReset = true;
- }
- },
- "endTime": {
- enumerable: true,
- get: function() {
- return _endTime;
- },
- set: function(value) {
- if (typeof value !== "number") {
- throw new TypeError("End time must be set to a number.");
- }
- _endTime = value;
- this.hasBeenReset = true;
- }
- },
- "text": {
- enumerable: true,
- get: function() {
- return _text;
- },
- set: function(value) {
- _text = "" + value;
- this.hasBeenReset = true;
- }
- },
- "region": {
- enumerable: true,
- get: function() {
- return _region;
- },
- set: function(value) {
- _region = value;
- this.hasBeenReset = true;
- }
- },
- "vertical": {
- enumerable: true,
- get: function() {
- return _vertical;
- },
- set: function(value) {
- var setting = findDirectionSetting(value);
- if (setting === false) {
- throw new SyntaxError("Vertical: an invalid or illegal direction string was specified.");
- }
- _vertical = setting;
- this.hasBeenReset = true;
- }
- },
- "snapToLines": {
- enumerable: true,
- get: function() {
- return _snapToLines;
- },
- set: function(value) {
- _snapToLines = !!value;
- this.hasBeenReset = true;
- }
- },
- "line": {
- enumerable: true,
- get: function() {
- return _line;
- },
- set: function(value) {
- if (typeof value !== "number" && value !== autoKeyword) {
- throw new SyntaxError("Line: an invalid number or illegal string was specified.");
- }
- _line = value;
- this.hasBeenReset = true;
- }
- },
- "lineAlign": {
- enumerable: true,
- get: function() {
- return _lineAlign;
- },
- set: function(value) {
- var setting = findAlignSetting(value);
- if (!setting) {
- console.warn("lineAlign: an invalid or illegal string was specified.");
- } else {
- _lineAlign = setting;
- this.hasBeenReset = true;
- }
- }
- },
- "position": {
- enumerable: true,
- get: function() {
- return _position;
- },
- set: function(value) {
- if (value < 0 || value > 100) {
- throw new Error("Position must be between 0 and 100.");
- }
- _position = value;
- this.hasBeenReset = true;
- }
- },
- "positionAlign": {
- enumerable: true,
- get: function() {
- return _positionAlign;
- },
- set: function(value) {
- var setting = findAlignSetting(value);
- if (!setting) {
- console.warn("positionAlign: an invalid or illegal string was specified.");
- } else {
- _positionAlign = setting;
- this.hasBeenReset = true;
- }
- }
- },
- "size": {
- enumerable: true,
- get: function() {
- return _size;
- },
- set: function(value) {
- if (value < 0 || value > 100) {
- throw new Error("Size must be between 0 and 100.");
- }
- _size = value;
- this.hasBeenReset = true;
- }
- },
- "align": {
- enumerable: true,
- get: function() {
- return _align;
- },
- set: function(value) {
- var setting = findAlignSetting(value);
- if (!setting) {
- throw new SyntaxError("align: an invalid or illegal alignment string was specified.");
- }
- _align = setting;
- this.hasBeenReset = true;
- }
- }
- });
- this.displayState = void 0;
- }
- VTTCue.prototype.getCueAsHTML = function() {
- return WebVTT.convertCueToDOMTree(window, this.text);
- };
- var vttcue = VTTCue;
- var scrollSetting = {
- "": true,
- "up": true
- };
- function findScrollSetting(value) {
- if (typeof value !== "string") {
- return false;
- }
- var scroll = scrollSetting[value.toLowerCase()];
- return scroll ? value.toLowerCase() : false;
- }
- function isValidPercentValue(value) {
- return typeof value === "number" && (value >= 0 && value <= 100);
- }
- function VTTRegion() {
- var _width = 100;
- var _lines = 3;
- var _regionAnchorX = 0;
- var _regionAnchorY = 100;
- var _viewportAnchorX = 0;
- var _viewportAnchorY = 100;
- var _scroll = "";
- Object.defineProperties(this, {
- "width": {
- enumerable: true,
- get: function() {
- return _width;
- },
- set: function(value) {
- if (!isValidPercentValue(value)) {
- throw new Error("Width must be between 0 and 100.");
- }
- _width = value;
- }
- },
- "lines": {
- enumerable: true,
- get: function() {
- return _lines;
- },
- set: function(value) {
- if (typeof value !== "number") {
- throw new TypeError("Lines must be set to a number.");
- }
- _lines = value;
- }
- },
- "regionAnchorY": {
- enumerable: true,
- get: function() {
- return _regionAnchorY;
- },
- set: function(value) {
- if (!isValidPercentValue(value)) {
- throw new Error("RegionAnchorX must be between 0 and 100.");
- }
- _regionAnchorY = value;
- }
- },
- "regionAnchorX": {
- enumerable: true,
- get: function() {
- return _regionAnchorX;
- },
- set: function(value) {
- if (!isValidPercentValue(value)) {
- throw new Error("RegionAnchorY must be between 0 and 100.");
- }
- _regionAnchorX = value;
- }
- },
- "viewportAnchorY": {
- enumerable: true,
- get: function() {
- return _viewportAnchorY;
- },
- set: function(value) {
- if (!isValidPercentValue(value)) {
- throw new Error("ViewportAnchorY must be between 0 and 100.");
- }
- _viewportAnchorY = value;
- }
- },
- "viewportAnchorX": {
- enumerable: true,
- get: function() {
- return _viewportAnchorX;
- },
- set: function(value) {
- if (!isValidPercentValue(value)) {
- throw new Error("ViewportAnchorX must be between 0 and 100.");
- }
- _viewportAnchorX = value;
- }
- },
- "scroll": {
- enumerable: true,
- get: function() {
- return _scroll;
- },
- set: function(value) {
- var setting = findScrollSetting(value);
- if (setting === false) {
- console.warn("Scroll: an invalid or illegal string was specified.");
- } else {
- _scroll = setting;
- }
- }
- }
- });
- }
- var vttregion = VTTRegion;
- var window$1 = window_1;
- var vttjs = browserIndex.exports = {
- WebVTT: vtt$1,
- VTTCue: vttcue,
- VTTRegion: vttregion
- };
- window$1.vttjs = vttjs;
- window$1.WebVTT = vttjs.WebVTT;
- var cueShim = vttjs.VTTCue;
- var regionShim = vttjs.VTTRegion;
- var nativeVTTCue = window$1.VTTCue;
- var nativeVTTRegion = window$1.VTTRegion;
- vttjs.shim = function() {
- window$1.VTTCue = cueShim;
- window$1.VTTRegion = regionShim;
- };
- vttjs.restore = function() {
- window$1.VTTCue = nativeVTTCue;
- window$1.VTTRegion = nativeVTTRegion;
- };
- if (!window$1.VTTCue) {
- vttjs.shim();
- }
- var vtt = browserIndex.exports;
- var urlToolkit = { exports: {} };
- (function(module2, exports2) {
- (function(root2) {
- var URL_REGEX = /^(?=((?:[a-zA-Z0-9+\-.]+:)?))\1(?=((?:\/\/[^\/?#]*)?))\2(?=((?:(?:[^?#\/]*\/)*[^;?#\/]*)?))\3((?:;[^?#]*)?)(\?[^#]*)?(#[^]*)?$/;
- var FIRST_SEGMENT_REGEX = /^(?=([^\/?#]*))\1([^]*)$/;
- var SLASH_DOT_REGEX = /(?:\/|^)\.(?=\/)/g;
- var SLASH_DOT_DOT_REGEX = /(?:\/|^)\.\.\/(?!\.\.\/)[^\/]*(?=\/)/g;
- var URLToolkit2 = {
- buildAbsoluteURL: function(baseURL, relativeURL, opts) {
- opts = opts || {};
- baseURL = baseURL.trim();
- relativeURL = relativeURL.trim();
- if (!relativeURL) {
- if (!opts.alwaysNormalize) {
- return baseURL;
- }
- var basePartsForNormalise = URLToolkit2.parseURL(baseURL);
- if (!basePartsForNormalise) {
- throw new Error("Error trying to parse base URL.");
- }
- basePartsForNormalise.path = URLToolkit2.normalizePath(
- basePartsForNormalise.path
- );
- return URLToolkit2.buildURLFromParts(basePartsForNormalise);
- }
- var relativeParts = URLToolkit2.parseURL(relativeURL);
- if (!relativeParts) {
- throw new Error("Error trying to parse relative URL.");
- }
- if (relativeParts.scheme) {
- if (!opts.alwaysNormalize) {
- return relativeURL;
- }
- relativeParts.path = URLToolkit2.normalizePath(relativeParts.path);
- return URLToolkit2.buildURLFromParts(relativeParts);
- }
- var baseParts = URLToolkit2.parseURL(baseURL);
- if (!baseParts) {
- throw new Error("Error trying to parse base URL.");
- }
- if (!baseParts.netLoc && baseParts.path && baseParts.path[0] !== "/") {
- var pathParts = FIRST_SEGMENT_REGEX.exec(baseParts.path);
- baseParts.netLoc = pathParts[1];
- baseParts.path = pathParts[2];
- }
- if (baseParts.netLoc && !baseParts.path) {
- baseParts.path = "/";
- }
- var builtParts = {
- scheme: baseParts.scheme,
- netLoc: relativeParts.netLoc,
- path: null,
- params: relativeParts.params,
- query: relativeParts.query,
- fragment: relativeParts.fragment
- };
- if (!relativeParts.netLoc) {
- builtParts.netLoc = baseParts.netLoc;
- if (relativeParts.path[0] !== "/") {
- if (!relativeParts.path) {
- builtParts.path = baseParts.path;
- if (!relativeParts.params) {
- builtParts.params = baseParts.params;
- if (!relativeParts.query) {
- builtParts.query = baseParts.query;
- }
- }
- } else {
- var baseURLPath = baseParts.path;
- var newPath = baseURLPath.substring(0, baseURLPath.lastIndexOf("/") + 1) + relativeParts.path;
- builtParts.path = URLToolkit2.normalizePath(newPath);
- }
- }
- }
- if (builtParts.path === null) {
- builtParts.path = opts.alwaysNormalize ? URLToolkit2.normalizePath(relativeParts.path) : relativeParts.path;
- }
- return URLToolkit2.buildURLFromParts(builtParts);
- },
- parseURL: function(url) {
- var parts = URL_REGEX.exec(url);
- if (!parts) {
- return null;
- }
- return {
- scheme: parts[1] || "",
- netLoc: parts[2] || "",
- path: parts[3] || "",
- params: parts[4] || "",
- query: parts[5] || "",
- fragment: parts[6] || ""
- };
- },
- normalizePath: function(path) {
- path = path.split("").reverse().join("").replace(SLASH_DOT_REGEX, "");
- while (path.length !== (path = path.replace(SLASH_DOT_DOT_REGEX, "")).length) {
- }
- return path.split("").reverse().join("");
- },
- buildURLFromParts: function(parts) {
- return parts.scheme + parts.netLoc + parts.path + parts.params + parts.query + parts.fragment;
- }
- };
- module2.exports = URLToolkit2;
- })();
- })(urlToolkit);
- var URLToolkit = urlToolkit.exports;
- var DEFAULT_LOCATION$2 = "http://example.com";
- var resolveUrl$4 = function resolveUrl(baseUrl, relativeUrl) {
- if (/^[a-z]+:/i.test(relativeUrl)) {
- return relativeUrl;
- }
- if (/^data:/.test(baseUrl)) {
- baseUrl = window_1.location && window_1.location.href || "";
- }
- var nativeURL = typeof window_1.URL === "function";
- var protocolLess = /^\/\//.test(baseUrl);
- var removeLocation = !window_1.location && !/\/\//i.test(baseUrl);
- if (nativeURL) {
- baseUrl = new window_1.URL(baseUrl, window_1.location || DEFAULT_LOCATION$2);
- } else if (!/\/\//i.test(baseUrl)) {
- baseUrl = URLToolkit.buildAbsoluteURL(window_1.location && window_1.location.href || "", baseUrl);
- }
- if (nativeURL) {
- var newUrl = new URL(relativeUrl, baseUrl);
- if (removeLocation) {
- return newUrl.href.slice(DEFAULT_LOCATION$2.length);
- } else if (protocolLess) {
- return newUrl.href.slice(newUrl.protocol.length);
- }
- return newUrl.href;
- }
- return URLToolkit.buildAbsoluteURL(baseUrl, relativeUrl);
- };
- var Stream$1 = /* @__PURE__ */ function() {
- function Stream2() {
- this.listeners = {};
- }
- var _proto = Stream2.prototype;
- _proto.on = function on3(type2, listener) {
- if (!this.listeners[type2]) {
- this.listeners[type2] = [];
- }
- this.listeners[type2].push(listener);
- };
- _proto.off = function off2(type2, listener) {
- if (!this.listeners[type2]) {
- return false;
- }
- var index2 = this.listeners[type2].indexOf(listener);
- this.listeners[type2] = this.listeners[type2].slice(0);
- this.listeners[type2].splice(index2, 1);
- return index2 > -1;
- };
- _proto.trigger = function trigger2(type2) {
- var callbacks = this.listeners[type2];
- if (!callbacks) {
- return;
- }
- if (arguments.length === 2) {
- var length = callbacks.length;
- for (var i2 = 0; i2 < length; ++i2) {
- callbacks[i2].call(this, arguments[1]);
- }
- } else {
- var args = Array.prototype.slice.call(arguments, 1);
- var _length = callbacks.length;
- for (var _i = 0; _i < _length; ++_i) {
- callbacks[_i].apply(this, args);
- }
- }
- };
- _proto.dispose = function dispose() {
- this.listeners = {};
- };
- _proto.pipe = function pipe(destination2) {
- this.on("data", function(data) {
- destination2.push(data);
- });
- };
- return Stream2;
- }();
- var atob$2 = function atob(s) {
- return window_1.atob ? window_1.atob(s) : Buffer.from(s, "base64").toString("binary");
- };
- function decodeB64ToUint8Array$2(b64Text) {
- var decodedString = atob$2(b64Text);
- var array = new Uint8Array(decodedString.length);
- for (var i2 = 0; i2 < decodedString.length; i2++) {
- array[i2] = decodedString.charCodeAt(i2);
- }
- return array;
- }
- /*! @name m3u8-parser @version 6.1.0 @license Apache-2.0 */
- class LineStream$1 extends Stream$1 {
- constructor() {
- super();
- this.buffer = "";
- }
- push(data) {
- let nextNewline;
- this.buffer += data;
- nextNewline = this.buffer.indexOf("\n");
- for (; nextNewline > -1; nextNewline = this.buffer.indexOf("\n")) {
- this.trigger("data", this.buffer.substring(0, nextNewline));
- this.buffer = this.buffer.substring(nextNewline + 1);
- }
- }
- }
- const TAB$1 = String.fromCharCode(9);
- const parseByterange$1 = function(byterangeString) {
- const match = /([0-9.]*)?@?([0-9.]*)?/.exec(byterangeString || "");
- const result = {};
- if (match[1]) {
- result.length = parseInt(match[1], 10);
- }
- if (match[2]) {
- result.offset = parseInt(match[2], 10);
- }
- return result;
- };
- const attributeSeparator$1 = function() {
- const key = "[^=]*";
- const value = '"[^"]*"|[^,]*';
- const keyvalue = "(?:" + key + ")=(?:" + value + ")";
- return new RegExp("(?:^|,)(" + keyvalue + ")");
- };
- const parseAttributes$3 = function(attributes) {
- const result = {};
- if (!attributes) {
- return result;
- }
- const attrs = attributes.split(attributeSeparator$1());
- let i2 = attrs.length;
- let attr;
- while (i2--) {
- if (attrs[i2] === "") {
- continue;
- }
- attr = /([^=]*)=(.*)/.exec(attrs[i2]).slice(1);
- attr[0] = attr[0].replace(/^\s+|\s+$/g, "");
- attr[1] = attr[1].replace(/^\s+|\s+$/g, "");
- attr[1] = attr[1].replace(/^['"](.*)['"]$/g, "$1");
- result[attr[0]] = attr[1];
- }
- return result;
- };
- class ParseStream$1 extends Stream$1 {
- constructor() {
- super();
- this.customParsers = [];
- this.tagMappers = [];
- }
- push(line) {
- let match;
- let event2;
- line = line.trim();
- if (line.length === 0) {
- return;
- }
- if (line[0] !== "#") {
- this.trigger("data", {
- type: "uri",
- uri: line
- });
- return;
- }
- const newLines = this.tagMappers.reduce((acc, mapper) => {
- const mappedLine = mapper(line);
- if (mappedLine === line) {
- return acc;
- }
- return acc.concat([mappedLine]);
- }, [line]);
- newLines.forEach((newLine) => {
- for (let i2 = 0; i2 < this.customParsers.length; i2++) {
- if (this.customParsers[i2].call(this, newLine)) {
- return;
- }
- }
- if (newLine.indexOf("#EXT") !== 0) {
- this.trigger("data", {
- type: "comment",
- text: newLine.slice(1)
- });
- return;
- }
- newLine = newLine.replace("\r", "");
- match = /^#EXTM3U/.exec(newLine);
- if (match) {
- this.trigger("data", {
- type: "tag",
- tagType: "m3u"
- });
- return;
- }
- match = /^#EXTINF:([0-9\.]*)?,?(.*)?$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "inf"
- };
- if (match[1]) {
- event2.duration = parseFloat(match[1]);
- }
- if (match[2]) {
- event2.title = match[2];
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-TARGETDURATION:([0-9.]*)?/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "targetduration"
- };
- if (match[1]) {
- event2.duration = parseInt(match[1], 10);
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-VERSION:([0-9.]*)?/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "version"
- };
- if (match[1]) {
- event2.version = parseInt(match[1], 10);
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-MEDIA-SEQUENCE:(\-?[0-9.]*)?/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "media-sequence"
- };
- if (match[1]) {
- event2.number = parseInt(match[1], 10);
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-DISCONTINUITY-SEQUENCE:(\-?[0-9.]*)?/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "discontinuity-sequence"
- };
- if (match[1]) {
- event2.number = parseInt(match[1], 10);
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-PLAYLIST-TYPE:(.*)?$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "playlist-type"
- };
- if (match[1]) {
- event2.playlistType = match[1];
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-BYTERANGE:(.*)?$/.exec(newLine);
- if (match) {
- event2 = _extends$2(parseByterange$1(match[1]), {
- type: "tag",
- tagType: "byterange"
- });
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-ALLOW-CACHE:(YES|NO)?/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "allow-cache"
- };
- if (match[1]) {
- event2.allowed = !/NO/.test(match[1]);
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-MAP:(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "map"
- };
- if (match[1]) {
- const attributes = parseAttributes$3(match[1]);
- if (attributes.URI) {
- event2.uri = attributes.URI;
- }
- if (attributes.BYTERANGE) {
- event2.byterange = parseByterange$1(attributes.BYTERANGE);
- }
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-STREAM-INF:(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "stream-inf"
- };
- if (match[1]) {
- event2.attributes = parseAttributes$3(match[1]);
- if (event2.attributes.RESOLUTION) {
- const split2 = event2.attributes.RESOLUTION.split("x");
- const resolution = {};
- if (split2[0]) {
- resolution.width = parseInt(split2[0], 10);
- }
- if (split2[1]) {
- resolution.height = parseInt(split2[1], 10);
- }
- event2.attributes.RESOLUTION = resolution;
- }
- if (event2.attributes.BANDWIDTH) {
- event2.attributes.BANDWIDTH = parseInt(event2.attributes.BANDWIDTH, 10);
- }
- if (event2.attributes["FRAME-RATE"]) {
- event2.attributes["FRAME-RATE"] = parseFloat(event2.attributes["FRAME-RATE"]);
- }
- if (event2.attributes["PROGRAM-ID"]) {
- event2.attributes["PROGRAM-ID"] = parseInt(event2.attributes["PROGRAM-ID"], 10);
- }
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-MEDIA:(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "media"
- };
- if (match[1]) {
- event2.attributes = parseAttributes$3(match[1]);
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-ENDLIST/.exec(newLine);
- if (match) {
- this.trigger("data", {
- type: "tag",
- tagType: "endlist"
- });
- return;
- }
- match = /^#EXT-X-DISCONTINUITY/.exec(newLine);
- if (match) {
- this.trigger("data", {
- type: "tag",
- tagType: "discontinuity"
- });
- return;
- }
- match = /^#EXT-X-PROGRAM-DATE-TIME:(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "program-date-time"
- };
- if (match[1]) {
- event2.dateTimeString = match[1];
- event2.dateTimeObject = new Date(match[1]);
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-KEY:(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "key"
- };
- if (match[1]) {
- event2.attributes = parseAttributes$3(match[1]);
- if (event2.attributes.IV) {
- if (event2.attributes.IV.substring(0, 2).toLowerCase() === "0x") {
- event2.attributes.IV = event2.attributes.IV.substring(2);
- }
- event2.attributes.IV = event2.attributes.IV.match(/.{8}/g);
- event2.attributes.IV[0] = parseInt(event2.attributes.IV[0], 16);
- event2.attributes.IV[1] = parseInt(event2.attributes.IV[1], 16);
- event2.attributes.IV[2] = parseInt(event2.attributes.IV[2], 16);
- event2.attributes.IV[3] = parseInt(event2.attributes.IV[3], 16);
- event2.attributes.IV = new Uint32Array(event2.attributes.IV);
- }
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-START:(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "start"
- };
- if (match[1]) {
- event2.attributes = parseAttributes$3(match[1]);
- event2.attributes["TIME-OFFSET"] = parseFloat(event2.attributes["TIME-OFFSET"]);
- event2.attributes.PRECISE = /YES/.test(event2.attributes.PRECISE);
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-CUE-OUT-CONT:(.*)?$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "cue-out-cont"
- };
- if (match[1]) {
- event2.data = match[1];
- } else {
- event2.data = "";
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-CUE-OUT:(.*)?$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "cue-out"
- };
- if (match[1]) {
- event2.data = match[1];
- } else {
- event2.data = "";
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-CUE-IN:(.*)?$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "cue-in"
- };
- if (match[1]) {
- event2.data = match[1];
- } else {
- event2.data = "";
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-SKIP:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "skip"
- };
- event2.attributes = parseAttributes$3(match[1]);
- if (event2.attributes.hasOwnProperty("SKIPPED-SEGMENTS")) {
- event2.attributes["SKIPPED-SEGMENTS"] = parseInt(event2.attributes["SKIPPED-SEGMENTS"], 10);
- }
- if (event2.attributes.hasOwnProperty("RECENTLY-REMOVED-DATERANGES")) {
- event2.attributes["RECENTLY-REMOVED-DATERANGES"] = event2.attributes["RECENTLY-REMOVED-DATERANGES"].split(TAB$1);
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-PART:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "part"
- };
- event2.attributes = parseAttributes$3(match[1]);
- ["DURATION"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = parseFloat(event2.attributes[key]);
- }
- });
- ["INDEPENDENT", "GAP"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = /YES/.test(event2.attributes[key]);
- }
- });
- if (event2.attributes.hasOwnProperty("BYTERANGE")) {
- event2.attributes.byterange = parseByterange$1(event2.attributes.BYTERANGE);
- }
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-SERVER-CONTROL:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "server-control"
- };
- event2.attributes = parseAttributes$3(match[1]);
- ["CAN-SKIP-UNTIL", "PART-HOLD-BACK", "HOLD-BACK"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = parseFloat(event2.attributes[key]);
- }
- });
- ["CAN-SKIP-DATERANGES", "CAN-BLOCK-RELOAD"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = /YES/.test(event2.attributes[key]);
- }
- });
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-PART-INF:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "part-inf"
- };
- event2.attributes = parseAttributes$3(match[1]);
- ["PART-TARGET"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = parseFloat(event2.attributes[key]);
- }
- });
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-PRELOAD-HINT:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "preload-hint"
- };
- event2.attributes = parseAttributes$3(match[1]);
- ["BYTERANGE-START", "BYTERANGE-LENGTH"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = parseInt(event2.attributes[key], 10);
- const subkey = key === "BYTERANGE-LENGTH" ? "length" : "offset";
- event2.attributes.byterange = event2.attributes.byterange || {};
- event2.attributes.byterange[subkey] = event2.attributes[key];
- delete event2.attributes[key];
- }
- });
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-RENDITION-REPORT:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "rendition-report"
- };
- event2.attributes = parseAttributes$3(match[1]);
- ["LAST-MSN", "LAST-PART"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = parseInt(event2.attributes[key], 10);
- }
- });
- this.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-DATERANGE:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "daterange"
- };
- event2.attributes = parseAttributes$3(match[1]);
- ["ID", "CLASS"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = String(event2.attributes[key]);
- }
- });
- ["START-DATE", "END-DATE"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = new Date(event2.attributes[key]);
- }
- });
- ["DURATION", "PLANNED-DURATION"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = parseFloat(event2.attributes[key]);
- }
- });
- ["END-ON-NEXT"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = /YES/i.test(event2.attributes[key]);
- }
- });
- ["SCTE35-CMD", " SCTE35-OUT", "SCTE35-IN"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = event2.attributes[key].toString(16);
- }
- });
- const clientAttributePattern = /^X-([A-Z]+-)+[A-Z]+$/;
- for (const key in event2.attributes) {
- if (!clientAttributePattern.test(key)) {
- continue;
- }
- const isHexaDecimal = /[0-9A-Fa-f]{6}/g.test(event2.attributes[key]);
- const isDecimalFloating = /^\d+(\.\d+)?$/.test(event2.attributes[key]);
- event2.attributes[key] = isHexaDecimal ? event2.attributes[key].toString(16) : isDecimalFloating ? parseFloat(event2.attributes[key]) : String(event2.attributes[key]);
- }
- this.trigger("data", event2);
- return;
- }
- this.trigger("data", {
- type: "tag",
- data: newLine.slice(4)
- });
- });
- }
- addParser({
- expression,
- customType,
- dataParser,
- segment
- }) {
- if (typeof dataParser !== "function") {
- dataParser = (line) => line;
- }
- this.customParsers.push((line) => {
- const match = expression.exec(line);
- if (match) {
- this.trigger("data", {
- type: "custom",
- data: dataParser(line),
- customType,
- segment
- });
- return true;
- }
- });
- }
- addTagMapper({
- expression,
- map
- }) {
- const mapFn = (line) => {
- if (expression.test(line)) {
- return map(line);
- }
- return line;
- };
- this.tagMappers.push(mapFn);
- }
- }
- const camelCase$1 = (str) => str.toLowerCase().replace(/-(\w)/g, (a) => a[1].toUpperCase());
- const camelCaseKeys$1 = function(attributes) {
- const result = {};
- Object.keys(attributes).forEach(function(key) {
- result[camelCase$1(key)] = attributes[key];
- });
- return result;
- };
- const setHoldBack$1 = function(manifest) {
- const {
- serverControl,
- targetDuration,
- partTargetDuration
- } = manifest;
- if (!serverControl) {
- return;
- }
- const tag = "#EXT-X-SERVER-CONTROL";
- const hb = "holdBack";
- const phb = "partHoldBack";
- const minTargetDuration = targetDuration && targetDuration * 3;
- const minPartDuration = partTargetDuration && partTargetDuration * 2;
- if (targetDuration && !serverControl.hasOwnProperty(hb)) {
- serverControl[hb] = minTargetDuration;
- this.trigger("info", {
- message: `${tag} defaulting HOLD-BACK to targetDuration * 3 (${minTargetDuration}).`
- });
- }
- if (minTargetDuration && serverControl[hb] < minTargetDuration) {
- this.trigger("warn", {
- message: `${tag} clamping HOLD-BACK (${serverControl[hb]}) to targetDuration * 3 (${minTargetDuration})`
- });
- serverControl[hb] = minTargetDuration;
- }
- if (partTargetDuration && !serverControl.hasOwnProperty(phb)) {
- serverControl[phb] = partTargetDuration * 3;
- this.trigger("info", {
- message: `${tag} defaulting PART-HOLD-BACK to partTargetDuration * 3 (${serverControl[phb]}).`
- });
- }
- if (partTargetDuration && serverControl[phb] < minPartDuration) {
- this.trigger("warn", {
- message: `${tag} clamping PART-HOLD-BACK (${serverControl[phb]}) to partTargetDuration * 2 (${minPartDuration}).`
- });
- serverControl[phb] = minPartDuration;
- }
- };
- class Parser$1 extends Stream$1 {
- constructor() {
- super();
- this.lineStream = new LineStream$1();
- this.parseStream = new ParseStream$1();
- this.lineStream.pipe(this.parseStream);
- const self2 = this;
- const uris = [];
- let currentUri = {};
- let currentMap;
- let key;
- let hasParts = false;
- const noop2 = function() {
- };
- const defaultMediaGroups = {
- "AUDIO": {},
- "VIDEO": {},
- "CLOSED-CAPTIONS": {},
- "SUBTITLES": {}
- };
- const widevineUuid = "urn:uuid:edef8ba9-79d6-4ace-a3c8-27dcd51d21ed";
- let currentTimeline = 0;
- this.manifest = {
- allowCache: true,
- discontinuityStarts: [],
- segments: []
- };
- let lastByterangeEnd = 0;
- let lastPartByterangeEnd = 0;
- const daterangeTags = {};
- this.on("end", () => {
- if (currentUri.uri || !currentUri.parts && !currentUri.preloadHints) {
- return;
- }
- if (!currentUri.map && currentMap) {
- currentUri.map = currentMap;
- }
- if (!currentUri.key && key) {
- currentUri.key = key;
- }
- if (!currentUri.timeline && typeof currentTimeline === "number") {
- currentUri.timeline = currentTimeline;
- }
- this.manifest.preloadSegment = currentUri;
- });
- this.parseStream.on("data", function(entry) {
- let mediaGroup;
- let rendition;
- ({
- tag() {
- ({
- version() {
- if (entry.version) {
- this.manifest.version = entry.version;
- }
- },
- "allow-cache"() {
- this.manifest.allowCache = entry.allowed;
- if (!("allowed" in entry)) {
- this.trigger("info", {
- message: "defaulting allowCache to YES"
- });
- this.manifest.allowCache = true;
- }
- },
- byterange() {
- const byterange = {};
- if ("length" in entry) {
- currentUri.byterange = byterange;
- byterange.length = entry.length;
- if (!("offset" in entry)) {
- entry.offset = lastByterangeEnd;
- }
- }
- if ("offset" in entry) {
- currentUri.byterange = byterange;
- byterange.offset = entry.offset;
- }
- lastByterangeEnd = byterange.offset + byterange.length;
- },
- endlist() {
- this.manifest.endList = true;
- },
- inf() {
- if (!("mediaSequence" in this.manifest)) {
- this.manifest.mediaSequence = 0;
- this.trigger("info", {
- message: "defaulting media sequence to zero"
- });
- }
- if (!("discontinuitySequence" in this.manifest)) {
- this.manifest.discontinuitySequence = 0;
- this.trigger("info", {
- message: "defaulting discontinuity sequence to zero"
- });
- }
- if (entry.duration > 0) {
- currentUri.duration = entry.duration;
- }
- if (entry.duration === 0) {
- currentUri.duration = 0.01;
- this.trigger("info", {
- message: "updating zero segment duration to a small value"
- });
- }
- this.manifest.segments = uris;
- },
- key() {
- if (!entry.attributes) {
- this.trigger("warn", {
- message: "ignoring key declaration without attribute list"
- });
- return;
- }
- if (entry.attributes.METHOD === "NONE") {
- key = null;
- return;
- }
- if (!entry.attributes.URI) {
- this.trigger("warn", {
- message: "ignoring key declaration without URI"
- });
- return;
- }
- if (entry.attributes.KEYFORMAT === "com.apple.streamingkeydelivery") {
- this.manifest.contentProtection = this.manifest.contentProtection || {};
- this.manifest.contentProtection["com.apple.fps.1_0"] = {
- attributes: entry.attributes
- };
- return;
- }
- if (entry.attributes.KEYFORMAT === "com.microsoft.playready") {
- this.manifest.contentProtection = this.manifest.contentProtection || {};
- this.manifest.contentProtection["com.microsoft.playready"] = {
- uri: entry.attributes.URI
- };
- return;
- }
- if (entry.attributes.KEYFORMAT === widevineUuid) {
- const VALID_METHODS = ["SAMPLE-AES", "SAMPLE-AES-CTR", "SAMPLE-AES-CENC"];
- if (VALID_METHODS.indexOf(entry.attributes.METHOD) === -1) {
- this.trigger("warn", {
- message: "invalid key method provided for Widevine"
- });
- return;
- }
- if (entry.attributes.METHOD === "SAMPLE-AES-CENC") {
- this.trigger("warn", {
- message: "SAMPLE-AES-CENC is deprecated, please use SAMPLE-AES-CTR instead"
- });
- }
- if (entry.attributes.URI.substring(0, 23) !== "data:text/plain;base64,") {
- this.trigger("warn", {
- message: "invalid key URI provided for Widevine"
- });
- return;
- }
- if (!(entry.attributes.KEYID && entry.attributes.KEYID.substring(0, 2) === "0x")) {
- this.trigger("warn", {
- message: "invalid key ID provided for Widevine"
- });
- return;
- }
- this.manifest.contentProtection = this.manifest.contentProtection || {};
- this.manifest.contentProtection["com.widevine.alpha"] = {
- attributes: {
- schemeIdUri: entry.attributes.KEYFORMAT,
- keyId: entry.attributes.KEYID.substring(2)
- },
- pssh: decodeB64ToUint8Array$2(entry.attributes.URI.split(",")[1])
- };
- return;
- }
- if (!entry.attributes.METHOD) {
- this.trigger("warn", {
- message: "defaulting key method to AES-128"
- });
- }
- key = {
- method: entry.attributes.METHOD || "AES-128",
- uri: entry.attributes.URI
- };
- if (typeof entry.attributes.IV !== "undefined") {
- key.iv = entry.attributes.IV;
- }
- },
- "media-sequence"() {
- if (!isFinite(entry.number)) {
- this.trigger("warn", {
- message: "ignoring invalid media sequence: " + entry.number
- });
- return;
- }
- this.manifest.mediaSequence = entry.number;
- },
- "discontinuity-sequence"() {
- if (!isFinite(entry.number)) {
- this.trigger("warn", {
- message: "ignoring invalid discontinuity sequence: " + entry.number
- });
- return;
- }
- this.manifest.discontinuitySequence = entry.number;
- currentTimeline = entry.number;
- },
- "playlist-type"() {
- if (!/VOD|EVENT/.test(entry.playlistType)) {
- this.trigger("warn", {
- message: "ignoring unknown playlist type: " + entry.playlist
- });
- return;
- }
- this.manifest.playlistType = entry.playlistType;
- },
- map() {
- currentMap = {};
- if (entry.uri) {
- currentMap.uri = entry.uri;
- }
- if (entry.byterange) {
- currentMap.byterange = entry.byterange;
- }
- if (key) {
- currentMap.key = key;
- }
- },
- "stream-inf"() {
- this.manifest.playlists = uris;
- this.manifest.mediaGroups = this.manifest.mediaGroups || defaultMediaGroups;
- if (!entry.attributes) {
- this.trigger("warn", {
- message: "ignoring empty stream-inf attributes"
- });
- return;
- }
- if (!currentUri.attributes) {
- currentUri.attributes = {};
- }
- _extends$2(currentUri.attributes, entry.attributes);
- },
- media() {
- this.manifest.mediaGroups = this.manifest.mediaGroups || defaultMediaGroups;
- if (!(entry.attributes && entry.attributes.TYPE && entry.attributes["GROUP-ID"] && entry.attributes.NAME)) {
- this.trigger("warn", {
- message: "ignoring incomplete or missing media group"
- });
- return;
- }
- const mediaGroupType = this.manifest.mediaGroups[entry.attributes.TYPE];
- mediaGroupType[entry.attributes["GROUP-ID"]] = mediaGroupType[entry.attributes["GROUP-ID"]] || {};
- mediaGroup = mediaGroupType[entry.attributes["GROUP-ID"]];
- rendition = {
- default: /yes/i.test(entry.attributes.DEFAULT)
- };
- if (rendition.default) {
- rendition.autoselect = true;
- } else {
- rendition.autoselect = /yes/i.test(entry.attributes.AUTOSELECT);
- }
- if (entry.attributes.LANGUAGE) {
- rendition.language = entry.attributes.LANGUAGE;
- }
- if (entry.attributes.URI) {
- rendition.uri = entry.attributes.URI;
- }
- if (entry.attributes["INSTREAM-ID"]) {
- rendition.instreamId = entry.attributes["INSTREAM-ID"];
- }
- if (entry.attributes.CHARACTERISTICS) {
- rendition.characteristics = entry.attributes.CHARACTERISTICS;
- }
- if (entry.attributes.FORCED) {
- rendition.forced = /yes/i.test(entry.attributes.FORCED);
- }
- mediaGroup[entry.attributes.NAME] = rendition;
- },
- discontinuity() {
- currentTimeline += 1;
- currentUri.discontinuity = true;
- this.manifest.discontinuityStarts.push(uris.length);
- },
- "program-date-time"() {
- if (typeof this.manifest.dateTimeString === "undefined") {
- this.manifest.dateTimeString = entry.dateTimeString;
- this.manifest.dateTimeObject = entry.dateTimeObject;
- }
- currentUri.dateTimeString = entry.dateTimeString;
- currentUri.dateTimeObject = entry.dateTimeObject;
- },
- targetduration() {
- if (!isFinite(entry.duration) || entry.duration < 0) {
- this.trigger("warn", {
- message: "ignoring invalid target duration: " + entry.duration
- });
- return;
- }
- this.manifest.targetDuration = entry.duration;
- setHoldBack$1.call(this, this.manifest);
- },
- start() {
- if (!entry.attributes || isNaN(entry.attributes["TIME-OFFSET"])) {
- this.trigger("warn", {
- message: "ignoring start declaration without appropriate attribute list"
- });
- return;
- }
- this.manifest.start = {
- timeOffset: entry.attributes["TIME-OFFSET"],
- precise: entry.attributes.PRECISE
- };
- },
- "cue-out"() {
- currentUri.cueOut = entry.data;
- },
- "cue-out-cont"() {
- currentUri.cueOutCont = entry.data;
- },
- "cue-in"() {
- currentUri.cueIn = entry.data;
- },
- "skip"() {
- this.manifest.skip = camelCaseKeys$1(entry.attributes);
- this.warnOnMissingAttributes_("#EXT-X-SKIP", entry.attributes, ["SKIPPED-SEGMENTS"]);
- },
- "part"() {
- hasParts = true;
- const segmentIndex = this.manifest.segments.length;
- const part = camelCaseKeys$1(entry.attributes);
- currentUri.parts = currentUri.parts || [];
- currentUri.parts.push(part);
- if (part.byterange) {
- if (!part.byterange.hasOwnProperty("offset")) {
- part.byterange.offset = lastPartByterangeEnd;
- }
- lastPartByterangeEnd = part.byterange.offset + part.byterange.length;
- }
- const partIndex = currentUri.parts.length - 1;
- this.warnOnMissingAttributes_(`#EXT-X-PART #${partIndex} for segment #${segmentIndex}`, entry.attributes, ["URI", "DURATION"]);
- if (this.manifest.renditionReports) {
- this.manifest.renditionReports.forEach((r2, i2) => {
- if (!r2.hasOwnProperty("lastPart")) {
- this.trigger("warn", {
- message: `#EXT-X-RENDITION-REPORT #${i2} lacks required attribute(s): LAST-PART`
- });
- }
- });
- }
- },
- "server-control"() {
- const attrs = this.manifest.serverControl = camelCaseKeys$1(entry.attributes);
- if (!attrs.hasOwnProperty("canBlockReload")) {
- attrs.canBlockReload = false;
- this.trigger("info", {
- message: "#EXT-X-SERVER-CONTROL defaulting CAN-BLOCK-RELOAD to false"
- });
- }
- setHoldBack$1.call(this, this.manifest);
- if (attrs.canSkipDateranges && !attrs.hasOwnProperty("canSkipUntil")) {
- this.trigger("warn", {
- message: "#EXT-X-SERVER-CONTROL lacks required attribute CAN-SKIP-UNTIL which is required when CAN-SKIP-DATERANGES is set"
- });
- }
- },
- "preload-hint"() {
- const segmentIndex = this.manifest.segments.length;
- const hint = camelCaseKeys$1(entry.attributes);
- const isPart = hint.type && hint.type === "PART";
- currentUri.preloadHints = currentUri.preloadHints || [];
- currentUri.preloadHints.push(hint);
- if (hint.byterange) {
- if (!hint.byterange.hasOwnProperty("offset")) {
- hint.byterange.offset = isPart ? lastPartByterangeEnd : 0;
- if (isPart) {
- lastPartByterangeEnd = hint.byterange.offset + hint.byterange.length;
- }
- }
- }
- const index2 = currentUri.preloadHints.length - 1;
- this.warnOnMissingAttributes_(`#EXT-X-PRELOAD-HINT #${index2} for segment #${segmentIndex}`, entry.attributes, ["TYPE", "URI"]);
- if (!hint.type) {
- return;
- }
- for (let i2 = 0; i2 < currentUri.preloadHints.length - 1; i2++) {
- const otherHint = currentUri.preloadHints[i2];
- if (!otherHint.type) {
- continue;
- }
- if (otherHint.type === hint.type) {
- this.trigger("warn", {
- message: `#EXT-X-PRELOAD-HINT #${index2} for segment #${segmentIndex} has the same TYPE ${hint.type} as preload hint #${i2}`
- });
- }
- }
- },
- "rendition-report"() {
- const report = camelCaseKeys$1(entry.attributes);
- this.manifest.renditionReports = this.manifest.renditionReports || [];
- this.manifest.renditionReports.push(report);
- const index2 = this.manifest.renditionReports.length - 1;
- const required = ["LAST-MSN", "URI"];
- if (hasParts) {
- required.push("LAST-PART");
- }
- this.warnOnMissingAttributes_(`#EXT-X-RENDITION-REPORT #${index2}`, entry.attributes, required);
- },
- "part-inf"() {
- this.manifest.partInf = camelCaseKeys$1(entry.attributes);
- this.warnOnMissingAttributes_("#EXT-X-PART-INF", entry.attributes, ["PART-TARGET"]);
- if (this.manifest.partInf.partTarget) {
- this.manifest.partTargetDuration = this.manifest.partInf.partTarget;
- }
- setHoldBack$1.call(this, this.manifest);
- },
- "daterange"() {
- this.manifest.daterange = this.manifest.daterange || [];
- this.manifest.daterange.push(camelCaseKeys$1(entry.attributes));
- const index2 = this.manifest.daterange.length - 1;
- this.warnOnMissingAttributes_(`#EXT-X-DATERANGE #${index2}`, entry.attributes, ["ID", "START-DATE"]);
- const daterange = this.manifest.daterange[index2];
- if (daterange.endDate && daterange.startDate && new Date(daterange.endDate) < new Date(daterange.startDate)) {
- this.trigger("warn", {
- message: "EXT-X-DATERANGE END-DATE must be equal to or later than the value of the START-DATE"
- });
- }
- if (daterange.duration && daterange.duration < 0) {
- this.trigger("warn", {
- message: "EXT-X-DATERANGE DURATION must not be negative"
- });
- }
- if (daterange.plannedDuration && daterange.plannedDuration < 0) {
- this.trigger("warn", {
- message: "EXT-X-DATERANGE PLANNED-DURATION must not be negative"
- });
- }
- const endOnNextYes = !!daterange.endOnNext;
- if (endOnNextYes && !daterange.class) {
- this.trigger("warn", {
- message: "EXT-X-DATERANGE with an END-ON-NEXT=YES attribute must have a CLASS attribute"
- });
- }
- if (endOnNextYes && (daterange.duration || daterange.endDate)) {
- this.trigger("warn", {
- message: "EXT-X-DATERANGE with an END-ON-NEXT=YES attribute must not contain DURATION or END-DATE attributes"
- });
- }
- if (daterange.duration && daterange.endDate) {
- const startDate = daterange.startDate;
- const newDateInSeconds = startDate.setSeconds(startDate.getSeconds() + daterange.duration);
- this.manifest.daterange[index2].endDate = new Date(newDateInSeconds);
- }
- if (daterange && !this.manifest.dateTimeString) {
- this.trigger("warn", {
- message: "A playlist with EXT-X-DATERANGE tag must contain atleast one EXT-X-PROGRAM-DATE-TIME tag"
- });
- }
- if (!daterangeTags[daterange.id]) {
- daterangeTags[daterange.id] = daterange;
- } else {
- for (const attribute in daterangeTags[daterange.id]) {
- if (daterangeTags[daterange.id][attribute] !== daterange[attribute]) {
- this.trigger("warn", {
- message: "EXT-X-DATERANGE tags with the same ID in a playlist must have the same attributes and same attribute values"
- });
- break;
- }
- }
- }
- }
- }[entry.tagType] || noop2).call(self2);
- },
- uri() {
- currentUri.uri = entry.uri;
- uris.push(currentUri);
- if (this.manifest.targetDuration && !("duration" in currentUri)) {
- this.trigger("warn", {
- message: "defaulting segment duration to the target duration"
- });
- currentUri.duration = this.manifest.targetDuration;
- }
- if (key) {
- currentUri.key = key;
- }
- currentUri.timeline = currentTimeline;
- if (currentMap) {
- currentUri.map = currentMap;
- }
- lastPartByterangeEnd = 0;
- currentUri = {};
- },
- comment() {
- },
- custom() {
- if (entry.segment) {
- currentUri.custom = currentUri.custom || {};
- currentUri.custom[entry.customType] = entry.data;
- } else {
- this.manifest.custom = this.manifest.custom || {};
- this.manifest.custom[entry.customType] = entry.data;
- }
- }
- })[entry.type].call(self2);
- });
- }
- warnOnMissingAttributes_(identifier, attributes, required) {
- const missing = [];
- required.forEach(function(key) {
- if (!attributes.hasOwnProperty(key)) {
- missing.push(key);
- }
- });
- if (missing.length) {
- this.trigger("warn", {
- message: `${identifier} lacks required attribute(s): ${missing.join(", ")}`
- });
- }
- }
- push(chunk) {
- this.lineStream.push(chunk);
- }
- end() {
- this.lineStream.push("\n");
- this.trigger("end");
- }
- addParser(options2) {
- this.parseStream.addParser(options2);
- }
- addTagMapper(options2) {
- this.parseStream.addTagMapper(options2);
- }
- }
- var regexs$1 = {
- mp4: /^(av0?1|avc0?[1234]|vp0?9|flac|opus|mp3|mp4a|mp4v|stpp.ttml.im1t)/,
- webm: /^(vp0?[89]|av0?1|opus|vorbis)/,
- ogg: /^(vp0?[89]|theora|flac|opus|vorbis)/,
- video: /^(av0?1|avc0?[1234]|vp0?[89]|hvc1|hev1|theora|mp4v)/,
- audio: /^(mp4a|flac|vorbis|opus|ac-[34]|ec-3|alac|mp3|speex|aac)/,
- text: /^(stpp.ttml.im1t)/,
- muxerVideo: /^(avc0?1)/,
- muxerAudio: /^(mp4a)/,
- muxerText: /a^/
- };
- var mediaTypes$1 = ["video", "audio", "text"];
- var upperMediaTypes$1 = ["Video", "Audio", "Text"];
- var translateLegacyCodec$1 = function translateLegacyCodec(codec) {
- if (!codec) {
- return codec;
- }
- return codec.replace(/avc1\.(\d+)\.(\d+)/i, function(orig, profile, avcLevel) {
- var profileHex = ("00" + Number(profile).toString(16)).slice(-2);
- var avcLevelHex = ("00" + Number(avcLevel).toString(16)).slice(-2);
- return "avc1." + profileHex + "00" + avcLevelHex;
- });
- };
- var parseCodecs$1 = function parseCodecs(codecString) {
- if (codecString === void 0) {
- codecString = "";
- }
- var codecs = codecString.split(",");
- var result = [];
- codecs.forEach(function(codec) {
- codec = codec.trim();
- var codecType;
- mediaTypes$1.forEach(function(name) {
- var match = regexs$1[name].exec(codec.toLowerCase());
- if (!match || match.length <= 1) {
- return;
- }
- codecType = name;
- var type2 = codec.substring(0, match[1].length);
- var details = codec.replace(type2, "");
- result.push({
- type: type2,
- details,
- mediaType: name
- });
- });
- if (!codecType) {
- result.push({
- type: codec,
- details: "",
- mediaType: "unknown"
- });
- }
- });
- return result;
- };
- var codecsFromDefault$1 = function codecsFromDefault(master, audioGroupId) {
- if (!master.mediaGroups.AUDIO || !audioGroupId) {
- return null;
- }
- var audioGroup = master.mediaGroups.AUDIO[audioGroupId];
- if (!audioGroup) {
- return null;
- }
- for (var name in audioGroup) {
- var audioType = audioGroup[name];
- if (audioType.default && audioType.playlists) {
- return parseCodecs$1(audioType.playlists[0].attributes.CODECS);
- }
- }
- return null;
- };
- var isAudioCodec$1 = function isAudioCodec(codec) {
- if (codec === void 0) {
- codec = "";
- }
- return regexs$1.audio.test(codec.trim().toLowerCase());
- };
- var isTextCodec$1 = function isTextCodec(codec) {
- if (codec === void 0) {
- codec = "";
- }
- return regexs$1.text.test(codec.trim().toLowerCase());
- };
- var getMimeForCodec$1 = function getMimeForCodec(codecString) {
- if (!codecString || typeof codecString !== "string") {
- return;
- }
- var codecs = codecString.toLowerCase().split(",").map(function(c) {
- return translateLegacyCodec$1(c.trim());
- });
- var type2 = "video";
- if (codecs.length === 1 && isAudioCodec$1(codecs[0])) {
- type2 = "audio";
- } else if (codecs.length === 1 && isTextCodec$1(codecs[0])) {
- type2 = "application";
- }
- var container = "mp4";
- if (codecs.every(function(c) {
- return regexs$1.mp4.test(c);
- })) {
- container = "mp4";
- } else if (codecs.every(function(c) {
- return regexs$1.webm.test(c);
- })) {
- container = "webm";
- } else if (codecs.every(function(c) {
- return regexs$1.ogg.test(c);
- })) {
- container = "ogg";
- }
- return type2 + "/" + container + ';codecs="' + codecString + '"';
- };
- var browserSupportsCodec$1 = function browserSupportsCodec(codecString) {
- if (codecString === void 0) {
- codecString = "";
- }
- return window_1.MediaSource && window_1.MediaSource.isTypeSupported && window_1.MediaSource.isTypeSupported(getMimeForCodec$1(codecString)) || false;
- };
- var muxerSupportsCodec$1 = function muxerSupportsCodec(codecString) {
- if (codecString === void 0) {
- codecString = "";
- }
- return codecString.toLowerCase().split(",").every(function(codec) {
- codec = codec.trim();
- for (var i2 = 0; i2 < upperMediaTypes$1.length; i2++) {
- var type2 = upperMediaTypes$1[i2];
- if (regexs$1["muxer" + type2].test(codec)) {
- return true;
- }
- }
- return false;
- });
- };
- var DEFAULT_AUDIO_CODEC$1 = "mp4a.40.2";
- var DEFAULT_VIDEO_CODEC$1 = "avc1.4d400d";
- var MPEGURL_REGEX$1 = /^(audio|video|application)\/(x-|vnd\.apple\.)?mpegurl/i;
- var DASH_REGEX$1 = /^application\/dash\+xml/i;
- var simpleTypeFromSourceType$1 = function simpleTypeFromSourceType(type2) {
- if (MPEGURL_REGEX$1.test(type2)) {
- return "hls";
- }
- if (DASH_REGEX$1.test(type2)) {
- return "dash";
- }
- if (type2 === "application/vnd.videojs.vhs+json") {
- return "vhs-json";
- }
- return null;
- };
- var countBits$1 = function countBits(x) {
- return x.toString(2).length;
- };
- var countBytes$1 = function countBytes(x) {
- return Math.ceil(countBits$1(x) / 8);
- };
- var isArrayBufferView$1 = function isArrayBufferView(obj) {
- if (ArrayBuffer.isView === "function") {
- return ArrayBuffer.isView(obj);
- }
- return obj && obj.buffer instanceof ArrayBuffer;
- };
- var isTypedArray$1 = function isTypedArray(obj) {
- return isArrayBufferView$1(obj);
- };
- var toUint8$1 = function toUint8(bytes) {
- if (bytes instanceof Uint8Array) {
- return bytes;
- }
- if (!Array.isArray(bytes) && !isTypedArray$1(bytes) && !(bytes instanceof ArrayBuffer)) {
- if (typeof bytes !== "number" || typeof bytes === "number" && bytes !== bytes) {
- bytes = 0;
- } else {
- bytes = [bytes];
- }
- }
- return new Uint8Array(bytes && bytes.buffer || bytes, bytes && bytes.byteOffset || 0, bytes && bytes.byteLength || 0);
- };
- var BigInt$1 = window_1.BigInt || Number;
- var BYTE_TABLE$1 = [BigInt$1("0x1"), BigInt$1("0x100"), BigInt$1("0x10000"), BigInt$1("0x1000000"), BigInt$1("0x100000000"), BigInt$1("0x10000000000"), BigInt$1("0x1000000000000"), BigInt$1("0x100000000000000"), BigInt$1("0x10000000000000000")];
- (function() {
- var a = new Uint16Array([65484]);
- var b = new Uint8Array(a.buffer, a.byteOffset, a.byteLength);
- if (b[0] === 255) {
- return "big";
- }
- if (b[0] === 204) {
- return "little";
- }
- return "unknown";
- })();
- var bytesToNumber$1 = function bytesToNumber(bytes, _temp) {
- var _ref = _temp === void 0 ? {} : _temp, _ref$signed = _ref.signed, signed = _ref$signed === void 0 ? false : _ref$signed, _ref$le = _ref.le, le = _ref$le === void 0 ? false : _ref$le;
- bytes = toUint8$1(bytes);
- var fn2 = le ? "reduce" : "reduceRight";
- var obj = bytes[fn2] ? bytes[fn2] : Array.prototype[fn2];
- var number = obj.call(bytes, function(total, byte, i2) {
- var exponent = le ? i2 : Math.abs(i2 + 1 - bytes.length);
- return total + BigInt$1(byte) * BYTE_TABLE$1[exponent];
- }, BigInt$1(0));
- if (signed) {
- var max2 = BYTE_TABLE$1[bytes.length] / BigInt$1(2) - BigInt$1(1);
- number = BigInt$1(number);
- if (number > max2) {
- number -= max2;
- number -= max2;
- number -= BigInt$1(2);
- }
- }
- return Number(number);
- };
- var numberToBytes$1 = function numberToBytes(number, _temp2) {
- var _ref2 = _temp2 === void 0 ? {} : _temp2, _ref2$le = _ref2.le, le = _ref2$le === void 0 ? false : _ref2$le;
- if (typeof number !== "bigint" && typeof number !== "number" || typeof number === "number" && number !== number) {
- number = 0;
- }
- number = BigInt$1(number);
- var byteCount = countBytes$1(number);
- var bytes = new Uint8Array(new ArrayBuffer(byteCount));
- for (var i2 = 0; i2 < byteCount; i2++) {
- var byteIndex = le ? i2 : Math.abs(i2 + 1 - bytes.length);
- bytes[byteIndex] = Number(number / BYTE_TABLE$1[i2] & BigInt$1(255));
- if (number < 0) {
- bytes[byteIndex] = Math.abs(~bytes[byteIndex]);
- bytes[byteIndex] -= i2 === 0 ? 1 : 2;
- }
- }
- return bytes;
- };
- var stringToBytes$1 = function stringToBytes(string, stringIsBytes) {
- if (typeof string !== "string" && string && typeof string.toString === "function") {
- string = string.toString();
- }
- if (typeof string !== "string") {
- return new Uint8Array();
- }
- if (!stringIsBytes) {
- string = unescape(encodeURIComponent(string));
- }
- var view = new Uint8Array(string.length);
- for (var i2 = 0; i2 < string.length; i2++) {
- view[i2] = string.charCodeAt(i2);
- }
- return view;
- };
- var concatTypedArrays$1 = function concatTypedArrays() {
- for (var _len = arguments.length, buffers = new Array(_len), _key = 0; _key < _len; _key++) {
- buffers[_key] = arguments[_key];
- }
- buffers = buffers.filter(function(b) {
- return b && (b.byteLength || b.length) && typeof b !== "string";
- });
- if (buffers.length <= 1) {
- return toUint8$1(buffers[0]);
- }
- var totalLen = buffers.reduce(function(total, buf, i2) {
- return total + (buf.byteLength || buf.length);
- }, 0);
- var tempBuffer = new Uint8Array(totalLen);
- var offset = 0;
- buffers.forEach(function(buf) {
- buf = toUint8$1(buf);
- tempBuffer.set(buf, offset);
- offset += buf.byteLength;
- });
- return tempBuffer;
- };
- var bytesMatch$1 = function bytesMatch(a, b, _temp3) {
- var _ref3 = _temp3 === void 0 ? {} : _temp3, _ref3$offset = _ref3.offset, offset = _ref3$offset === void 0 ? 0 : _ref3$offset, _ref3$mask = _ref3.mask, mask = _ref3$mask === void 0 ? [] : _ref3$mask;
- a = toUint8$1(a);
- b = toUint8$1(b);
- var fn2 = b.every ? b.every : Array.prototype.every;
- return b.length && a.length - offset >= b.length && fn2.call(b, function(bByte, i2) {
- var aByte = mask[i2] ? mask[i2] & a[offset + i2] : a[offset + i2];
- return bByte === aByte;
- });
- };
- var DEFAULT_LOCATION$1 = "http://example.com";
- var resolveUrl$3 = function resolveUrl2(baseUrl, relativeUrl) {
- if (/^[a-z]+:/i.test(relativeUrl)) {
- return relativeUrl;
- }
- if (/^data:/.test(baseUrl)) {
- baseUrl = window_1.location && window_1.location.href || "";
- }
- var nativeURL = typeof window_1.URL === "function";
- var protocolLess = /^\/\//.test(baseUrl);
- var removeLocation = !window_1.location && !/\/\//i.test(baseUrl);
- if (nativeURL) {
- baseUrl = new window_1.URL(baseUrl, window_1.location || DEFAULT_LOCATION$1);
- } else if (!/\/\//i.test(baseUrl)) {
- baseUrl = URLToolkit.buildAbsoluteURL(window_1.location && window_1.location.href || "", baseUrl);
- }
- if (nativeURL) {
- var newUrl = new URL(relativeUrl, baseUrl);
- if (removeLocation) {
- return newUrl.href.slice(DEFAULT_LOCATION$1.length);
- } else if (protocolLess) {
- return newUrl.href.slice(newUrl.protocol.length);
- }
- return newUrl.href;
- }
- return URLToolkit.buildAbsoluteURL(baseUrl, relativeUrl);
- };
- var forEachMediaGroup$3 = function forEachMediaGroup(master, groups, callback2) {
- groups.forEach(function(mediaType) {
- for (var groupKey in master.mediaGroups[mediaType]) {
- for (var labelKey in master.mediaGroups[mediaType][groupKey]) {
- var mediaProperties = master.mediaGroups[mediaType][groupKey][labelKey];
- callback2(mediaProperties, mediaType, groupKey, labelKey);
- }
- }
- });
- };
- var atob$1 = function atob2(s) {
- return window_1.atob ? window_1.atob(s) : Buffer.from(s, "base64").toString("binary");
- };
- function decodeB64ToUint8Array$1(b64Text) {
- var decodedString = atob$1(b64Text);
- var array = new Uint8Array(decodedString.length);
- for (var i2 = 0; i2 < decodedString.length; i2++) {
- array[i2] = decodedString.charCodeAt(i2);
- }
- return array;
- }
- var dom$1 = {};
- var conventions$2 = {};
- function find$1(list, predicate, ac) {
- if (ac === void 0) {
- ac = Array.prototype;
- }
- if (list && typeof ac.find === "function") {
- return ac.find.call(list, predicate);
- }
- for (var i2 = 0; i2 < list.length; i2++) {
- if (Object.prototype.hasOwnProperty.call(list, i2)) {
- var item = list[i2];
- if (predicate.call(void 0, item, i2, list)) {
- return item;
- }
- }
- }
- }
- function freeze(object, oc) {
- if (oc === void 0) {
- oc = Object;
- }
- return oc && typeof oc.freeze === "function" ? oc.freeze(object) : object;
- }
- function assign$1(target, source) {
- if (target === null || typeof target !== "object") {
- throw new TypeError("target is not an object");
- }
- for (var key in source) {
- if (Object.prototype.hasOwnProperty.call(source, key)) {
- target[key] = source[key];
- }
- }
- return target;
- }
- var MIME_TYPE = freeze({
- HTML: "text/html",
- isHTML: function(value) {
- return value === MIME_TYPE.HTML;
- },
- XML_APPLICATION: "application/xml",
- XML_TEXT: "text/xml",
- XML_XHTML_APPLICATION: "application/xhtml+xml",
- XML_SVG_IMAGE: "image/svg+xml"
- });
- var NAMESPACE$3 = freeze({
- HTML: "http://www.w3.org/1999/xhtml",
- isHTML: function(uri) {
- return uri === NAMESPACE$3.HTML;
- },
- SVG: "http://www.w3.org/2000/svg",
- XML: "http://www.w3.org/XML/1998/namespace",
- XMLNS: "http://www.w3.org/2000/xmlns/"
- });
- conventions$2.assign = assign$1;
- conventions$2.find = find$1;
- conventions$2.freeze = freeze;
- conventions$2.MIME_TYPE = MIME_TYPE;
- conventions$2.NAMESPACE = NAMESPACE$3;
- var conventions$1 = conventions$2;
- var find = conventions$1.find;
- var NAMESPACE$2 = conventions$1.NAMESPACE;
- function notEmptyString(input) {
- return input !== "";
- }
- function splitOnASCIIWhitespace(input) {
- return input ? input.split(/[\t\n\f\r ]+/).filter(notEmptyString) : [];
- }
- function orderedSetReducer(current, element) {
- if (!current.hasOwnProperty(element)) {
- current[element] = true;
- }
- return current;
- }
- function toOrderedSet(input) {
- if (!input)
- return [];
- var list = splitOnASCIIWhitespace(input);
- return Object.keys(list.reduce(orderedSetReducer, {}));
- }
- function arrayIncludes(list) {
- return function(element) {
- return list && list.indexOf(element) !== -1;
- };
- }
- function copy(src, dest) {
- for (var p in src) {
- if (Object.prototype.hasOwnProperty.call(src, p)) {
- dest[p] = src[p];
- }
- }
- }
- function _extends(Class, Super) {
- var pt2 = Class.prototype;
- if (!(pt2 instanceof Super)) {
- let t2 = function() {
- };
- t2.prototype = Super.prototype;
- t2 = new t2();
- copy(pt2, t2);
- Class.prototype = pt2 = t2;
- }
- if (pt2.constructor != Class) {
- if (typeof Class != "function") {
- console.error("unknown Class:" + Class);
- }
- pt2.constructor = Class;
- }
- }
- var NodeType = {};
- var ELEMENT_NODE = NodeType.ELEMENT_NODE = 1;
- var ATTRIBUTE_NODE = NodeType.ATTRIBUTE_NODE = 2;
- var TEXT_NODE = NodeType.TEXT_NODE = 3;
- var CDATA_SECTION_NODE = NodeType.CDATA_SECTION_NODE = 4;
- var ENTITY_REFERENCE_NODE = NodeType.ENTITY_REFERENCE_NODE = 5;
- var ENTITY_NODE = NodeType.ENTITY_NODE = 6;
- var PROCESSING_INSTRUCTION_NODE = NodeType.PROCESSING_INSTRUCTION_NODE = 7;
- var COMMENT_NODE = NodeType.COMMENT_NODE = 8;
- var DOCUMENT_NODE = NodeType.DOCUMENT_NODE = 9;
- var DOCUMENT_TYPE_NODE = NodeType.DOCUMENT_TYPE_NODE = 10;
- var DOCUMENT_FRAGMENT_NODE = NodeType.DOCUMENT_FRAGMENT_NODE = 11;
- var NOTATION_NODE = NodeType.NOTATION_NODE = 12;
- var ExceptionCode = {};
- var ExceptionMessage = {};
- ExceptionCode.INDEX_SIZE_ERR = (ExceptionMessage[1] = "Index size error", 1);
- ExceptionCode.DOMSTRING_SIZE_ERR = (ExceptionMessage[2] = "DOMString size error", 2);
- var HIERARCHY_REQUEST_ERR = ExceptionCode.HIERARCHY_REQUEST_ERR = (ExceptionMessage[3] = "Hierarchy request error", 3);
- ExceptionCode.WRONG_DOCUMENT_ERR = (ExceptionMessage[4] = "Wrong document", 4);
- ExceptionCode.INVALID_CHARACTER_ERR = (ExceptionMessage[5] = "Invalid character", 5);
- ExceptionCode.NO_DATA_ALLOWED_ERR = (ExceptionMessage[6] = "No data allowed", 6);
- ExceptionCode.NO_MODIFICATION_ALLOWED_ERR = (ExceptionMessage[7] = "No modification allowed", 7);
- var NOT_FOUND_ERR = ExceptionCode.NOT_FOUND_ERR = (ExceptionMessage[8] = "Not found", 8);
- ExceptionCode.NOT_SUPPORTED_ERR = (ExceptionMessage[9] = "Not supported", 9);
- var INUSE_ATTRIBUTE_ERR = ExceptionCode.INUSE_ATTRIBUTE_ERR = (ExceptionMessage[10] = "Attribute in use", 10);
- ExceptionCode.INVALID_STATE_ERR = (ExceptionMessage[11] = "Invalid state", 11);
- ExceptionCode.SYNTAX_ERR = (ExceptionMessage[12] = "Syntax error", 12);
- ExceptionCode.INVALID_MODIFICATION_ERR = (ExceptionMessage[13] = "Invalid modification", 13);
- ExceptionCode.NAMESPACE_ERR = (ExceptionMessage[14] = "Invalid namespace", 14);
- ExceptionCode.INVALID_ACCESS_ERR = (ExceptionMessage[15] = "Invalid access", 15);
- function DOMException(code, message) {
- if (message instanceof Error) {
- var error = message;
- } else {
- error = this;
- Error.call(this, ExceptionMessage[code]);
- this.message = ExceptionMessage[code];
- if (Error.captureStackTrace)
- Error.captureStackTrace(this, DOMException);
- }
- error.code = code;
- if (message)
- this.message = this.message + ": " + message;
- return error;
- }
- DOMException.prototype = Error.prototype;
- copy(ExceptionCode, DOMException);
- function NodeList() {
- }
- NodeList.prototype = {
- length: 0,
- item: function(index2) {
- return this[index2] || null;
- },
- toString: function(isHTML, nodeFilter) {
- for (var buf = [], i2 = 0; i2 < this.length; i2++) {
- serializeToString(this[i2], buf, isHTML, nodeFilter);
- }
- return buf.join("");
- },
- filter: function(predicate) {
- return Array.prototype.filter.call(this, predicate);
- },
- indexOf: function(item) {
- return Array.prototype.indexOf.call(this, item);
- }
- };
- function LiveNodeList(node, refresh) {
- this._node = node;
- this._refresh = refresh;
- _updateLiveList(this);
- }
- function _updateLiveList(list) {
- var inc = list._node._inc || list._node.ownerDocument._inc;
- if (list._inc != inc) {
- var ls = list._refresh(list._node);
- __set__(list, "length", ls.length);
- copy(ls, list);
- list._inc = inc;
- }
- }
- LiveNodeList.prototype.item = function(i2) {
- _updateLiveList(this);
- return this[i2];
- };
- _extends(LiveNodeList, NodeList);
- function NamedNodeMap() {
- }
- function _findNodeIndex(list, node) {
- var i2 = list.length;
- while (i2--) {
- if (list[i2] === node) {
- return i2;
- }
- }
- }
- function _addNamedNode(el, list, newAttr, oldAttr) {
- if (oldAttr) {
- list[_findNodeIndex(list, oldAttr)] = newAttr;
- } else {
- list[list.length++] = newAttr;
- }
- if (el) {
- newAttr.ownerElement = el;
- var doc = el.ownerDocument;
- if (doc) {
- oldAttr && _onRemoveAttribute(doc, el, oldAttr);
- _onAddAttribute(doc, el, newAttr);
- }
- }
- }
- function _removeNamedNode(el, list, attr) {
- var i2 = _findNodeIndex(list, attr);
- if (i2 >= 0) {
- var lastIndex = list.length - 1;
- while (i2 < lastIndex) {
- list[i2] = list[++i2];
- }
- list.length = lastIndex;
- if (el) {
- var doc = el.ownerDocument;
- if (doc) {
- _onRemoveAttribute(doc, el, attr);
- attr.ownerElement = null;
- }
- }
- } else {
- throw new DOMException(NOT_FOUND_ERR, new Error(el.tagName + "@" + attr));
- }
- }
- NamedNodeMap.prototype = {
- length: 0,
- item: NodeList.prototype.item,
- getNamedItem: function(key) {
- var i2 = this.length;
- while (i2--) {
- var attr = this[i2];
- if (attr.nodeName == key) {
- return attr;
- }
- }
- },
- setNamedItem: function(attr) {
- var el = attr.ownerElement;
- if (el && el != this._ownerElement) {
- throw new DOMException(INUSE_ATTRIBUTE_ERR);
- }
- var oldAttr = this.getNamedItem(attr.nodeName);
- _addNamedNode(this._ownerElement, this, attr, oldAttr);
- return oldAttr;
- },
- setNamedItemNS: function(attr) {
- var el = attr.ownerElement, oldAttr;
- if (el && el != this._ownerElement) {
- throw new DOMException(INUSE_ATTRIBUTE_ERR);
- }
- oldAttr = this.getNamedItemNS(attr.namespaceURI, attr.localName);
- _addNamedNode(this._ownerElement, this, attr, oldAttr);
- return oldAttr;
- },
- removeNamedItem: function(key) {
- var attr = this.getNamedItem(key);
- _removeNamedNode(this._ownerElement, this, attr);
- return attr;
- },
- removeNamedItemNS: function(namespaceURI, localName) {
- var attr = this.getNamedItemNS(namespaceURI, localName);
- _removeNamedNode(this._ownerElement, this, attr);
- return attr;
- },
- getNamedItemNS: function(namespaceURI, localName) {
- var i2 = this.length;
- while (i2--) {
- var node = this[i2];
- if (node.localName == localName && node.namespaceURI == namespaceURI) {
- return node;
- }
- }
- return null;
- }
- };
- function DOMImplementation$1() {
- }
- DOMImplementation$1.prototype = {
- hasFeature: function(feature2, version2) {
- return true;
- },
- createDocument: function(namespaceURI, qualifiedName, doctype) {
- var doc = new Document();
- doc.implementation = this;
- doc.childNodes = new NodeList();
- doc.doctype = doctype || null;
- if (doctype) {
- doc.appendChild(doctype);
- }
- if (qualifiedName) {
- var root2 = doc.createElementNS(namespaceURI, qualifiedName);
- doc.appendChild(root2);
- }
- return doc;
- },
- createDocumentType: function(qualifiedName, publicId, systemId) {
- var node = new DocumentType();
- node.name = qualifiedName;
- node.nodeName = qualifiedName;
- node.publicId = publicId || "";
- node.systemId = systemId || "";
- return node;
- }
- };
- function Node() {
- }
- Node.prototype = {
- firstChild: null,
- lastChild: null,
- previousSibling: null,
- nextSibling: null,
- attributes: null,
- parentNode: null,
- childNodes: null,
- ownerDocument: null,
- nodeValue: null,
- namespaceURI: null,
- prefix: null,
- localName: null,
- insertBefore: function(newChild, refChild) {
- return _insertBefore(this, newChild, refChild);
- },
- replaceChild: function(newChild, oldChild) {
- _insertBefore(this, newChild, oldChild, assertPreReplacementValidityInDocument);
- if (oldChild) {
- this.removeChild(oldChild);
- }
- },
- removeChild: function(oldChild) {
- return _removeChild(this, oldChild);
- },
- appendChild: function(newChild) {
- return this.insertBefore(newChild, null);
- },
- hasChildNodes: function() {
- return this.firstChild != null;
- },
- cloneNode: function(deep) {
- return cloneNode(this.ownerDocument || this, this, deep);
- },
- normalize: function() {
- var child = this.firstChild;
- while (child) {
- var next = child.nextSibling;
- if (next && next.nodeType == TEXT_NODE && child.nodeType == TEXT_NODE) {
- this.removeChild(next);
- child.appendData(next.data);
- } else {
- child.normalize();
- child = next;
- }
- }
- },
- isSupported: function(feature2, version2) {
- return this.ownerDocument.implementation.hasFeature(feature2, version2);
- },
- hasAttributes: function() {
- return this.attributes.length > 0;
- },
- lookupPrefix: function(namespaceURI) {
- var el = this;
- while (el) {
- var map = el._nsMap;
- if (map) {
- for (var n in map) {
- if (Object.prototype.hasOwnProperty.call(map, n) && map[n] === namespaceURI) {
- return n;
- }
- }
- }
- el = el.nodeType == ATTRIBUTE_NODE ? el.ownerDocument : el.parentNode;
- }
- return null;
- },
- lookupNamespaceURI: function(prefix) {
- var el = this;
- while (el) {
- var map = el._nsMap;
- if (map) {
- if (Object.prototype.hasOwnProperty.call(map, prefix)) {
- return map[prefix];
- }
- }
- el = el.nodeType == ATTRIBUTE_NODE ? el.ownerDocument : el.parentNode;
- }
- return null;
- },
- isDefaultNamespace: function(namespaceURI) {
- var prefix = this.lookupPrefix(namespaceURI);
- return prefix == null;
- }
- };
- function _xmlEncoder(c) {
- return c == "<" && "<" || c == ">" && ">" || c == "&" && "&" || c == '"' && """ || "&#" + c.charCodeAt() + ";";
- }
- copy(NodeType, Node);
- copy(NodeType, Node.prototype);
- function _visitNode(node, callback2) {
- if (callback2(node)) {
- return true;
- }
- if (node = node.firstChild) {
- do {
- if (_visitNode(node, callback2)) {
- return true;
- }
- } while (node = node.nextSibling);
- }
- }
- function Document() {
- this.ownerDocument = this;
- }
- function _onAddAttribute(doc, el, newAttr) {
- doc && doc._inc++;
- var ns = newAttr.namespaceURI;
- if (ns === NAMESPACE$2.XMLNS) {
- el._nsMap[newAttr.prefix ? newAttr.localName : ""] = newAttr.value;
- }
- }
- function _onRemoveAttribute(doc, el, newAttr, remove2) {
- doc && doc._inc++;
- var ns = newAttr.namespaceURI;
- if (ns === NAMESPACE$2.XMLNS) {
- delete el._nsMap[newAttr.prefix ? newAttr.localName : ""];
- }
- }
- function _onUpdateChild(doc, el, newChild) {
- if (doc && doc._inc) {
- doc._inc++;
- var cs = el.childNodes;
- if (newChild) {
- cs[cs.length++] = newChild;
- } else {
- var child = el.firstChild;
- var i2 = 0;
- while (child) {
- cs[i2++] = child;
- child = child.nextSibling;
- }
- cs.length = i2;
- delete cs[cs.length];
- }
- }
- }
- function _removeChild(parentNode, child) {
- var previous = child.previousSibling;
- var next = child.nextSibling;
- if (previous) {
- previous.nextSibling = next;
- } else {
- parentNode.firstChild = next;
- }
- if (next) {
- next.previousSibling = previous;
- } else {
- parentNode.lastChild = previous;
- }
- child.parentNode = null;
- child.previousSibling = null;
- child.nextSibling = null;
- _onUpdateChild(parentNode.ownerDocument, parentNode);
- return child;
- }
- function hasValidParentNodeType(node) {
- return node && (node.nodeType === Node.DOCUMENT_NODE || node.nodeType === Node.DOCUMENT_FRAGMENT_NODE || node.nodeType === Node.ELEMENT_NODE);
- }
- function hasInsertableNodeType(node) {
- return node && (isElementNode(node) || isTextNode$2(node) || isDocTypeNode(node) || node.nodeType === Node.DOCUMENT_FRAGMENT_NODE || node.nodeType === Node.COMMENT_NODE || node.nodeType === Node.PROCESSING_INSTRUCTION_NODE);
- }
- function isDocTypeNode(node) {
- return node && node.nodeType === Node.DOCUMENT_TYPE_NODE;
- }
- function isElementNode(node) {
- return node && node.nodeType === Node.ELEMENT_NODE;
- }
- function isTextNode$2(node) {
- return node && node.nodeType === Node.TEXT_NODE;
- }
- function isElementInsertionPossible(doc, child) {
- var parentChildNodes = doc.childNodes || [];
- if (find(parentChildNodes, isElementNode) || isDocTypeNode(child)) {
- return false;
- }
- var docTypeNode = find(parentChildNodes, isDocTypeNode);
- return !(child && docTypeNode && parentChildNodes.indexOf(docTypeNode) > parentChildNodes.indexOf(child));
- }
- function isElementReplacementPossible(doc, child) {
- var parentChildNodes = doc.childNodes || [];
- function hasElementChildThatIsNotChild(node) {
- return isElementNode(node) && node !== child;
- }
- if (find(parentChildNodes, hasElementChildThatIsNotChild)) {
- return false;
- }
- var docTypeNode = find(parentChildNodes, isDocTypeNode);
- return !(child && docTypeNode && parentChildNodes.indexOf(docTypeNode) > parentChildNodes.indexOf(child));
- }
- function assertPreInsertionValidity1to5(parent, node, child) {
- if (!hasValidParentNodeType(parent)) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "Unexpected parent node type " + parent.nodeType);
- }
- if (child && child.parentNode !== parent) {
- throw new DOMException(NOT_FOUND_ERR, "child not in parent");
- }
- if (!hasInsertableNodeType(node) || isDocTypeNode(node) && parent.nodeType !== Node.DOCUMENT_NODE) {
- throw new DOMException(
- HIERARCHY_REQUEST_ERR,
- "Unexpected node type " + node.nodeType + " for parent node type " + parent.nodeType
- );
- }
- }
- function assertPreInsertionValidityInDocument(parent, node, child) {
- var parentChildNodes = parent.childNodes || [];
- var nodeChildNodes = node.childNodes || [];
- if (node.nodeType === Node.DOCUMENT_FRAGMENT_NODE) {
- var nodeChildElements = nodeChildNodes.filter(isElementNode);
- if (nodeChildElements.length > 1 || find(nodeChildNodes, isTextNode$2)) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "More than one element or text in fragment");
- }
- if (nodeChildElements.length === 1 && !isElementInsertionPossible(parent, child)) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "Element in fragment can not be inserted before doctype");
- }
- }
- if (isElementNode(node)) {
- if (!isElementInsertionPossible(parent, child)) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "Only one element can be added and only after doctype");
- }
- }
- if (isDocTypeNode(node)) {
- if (find(parentChildNodes, isDocTypeNode)) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "Only one doctype is allowed");
- }
- var parentElementChild = find(parentChildNodes, isElementNode);
- if (child && parentChildNodes.indexOf(parentElementChild) < parentChildNodes.indexOf(child)) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "Doctype can only be inserted before an element");
- }
- if (!child && parentElementChild) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "Doctype can not be appended since element is present");
- }
- }
- }
- function assertPreReplacementValidityInDocument(parent, node, child) {
- var parentChildNodes = parent.childNodes || [];
- var nodeChildNodes = node.childNodes || [];
- if (node.nodeType === Node.DOCUMENT_FRAGMENT_NODE) {
- var nodeChildElements = nodeChildNodes.filter(isElementNode);
- if (nodeChildElements.length > 1 || find(nodeChildNodes, isTextNode$2)) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "More than one element or text in fragment");
- }
- if (nodeChildElements.length === 1 && !isElementReplacementPossible(parent, child)) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "Element in fragment can not be inserted before doctype");
- }
- }
- if (isElementNode(node)) {
- if (!isElementReplacementPossible(parent, child)) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "Only one element can be added and only after doctype");
- }
- }
- if (isDocTypeNode(node)) {
- let hasDoctypeChildThatIsNotChild = function(node2) {
- return isDocTypeNode(node2) && node2 !== child;
- };
- if (find(parentChildNodes, hasDoctypeChildThatIsNotChild)) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "Only one doctype is allowed");
- }
- var parentElementChild = find(parentChildNodes, isElementNode);
- if (child && parentChildNodes.indexOf(parentElementChild) < parentChildNodes.indexOf(child)) {
- throw new DOMException(HIERARCHY_REQUEST_ERR, "Doctype can only be inserted before an element");
- }
- }
- }
- function _insertBefore(parent, node, child, _inDocumentAssertion) {
- assertPreInsertionValidity1to5(parent, node, child);
- if (parent.nodeType === Node.DOCUMENT_NODE) {
- (_inDocumentAssertion || assertPreInsertionValidityInDocument)(parent, node, child);
- }
- var cp = node.parentNode;
- if (cp) {
- cp.removeChild(node);
- }
- if (node.nodeType === DOCUMENT_FRAGMENT_NODE) {
- var newFirst = node.firstChild;
- if (newFirst == null) {
- return node;
- }
- var newLast = node.lastChild;
- } else {
- newFirst = newLast = node;
- }
- var pre = child ? child.previousSibling : parent.lastChild;
- newFirst.previousSibling = pre;
- newLast.nextSibling = child;
- if (pre) {
- pre.nextSibling = newFirst;
- } else {
- parent.firstChild = newFirst;
- }
- if (child == null) {
- parent.lastChild = newLast;
- } else {
- child.previousSibling = newLast;
- }
- do {
- newFirst.parentNode = parent;
- } while (newFirst !== newLast && (newFirst = newFirst.nextSibling));
- _onUpdateChild(parent.ownerDocument || parent, parent);
- if (node.nodeType == DOCUMENT_FRAGMENT_NODE) {
- node.firstChild = node.lastChild = null;
- }
- return node;
- }
- function _appendSingleChild(parentNode, newChild) {
- if (newChild.parentNode) {
- newChild.parentNode.removeChild(newChild);
- }
- newChild.parentNode = parentNode;
- newChild.previousSibling = parentNode.lastChild;
- newChild.nextSibling = null;
- if (newChild.previousSibling) {
- newChild.previousSibling.nextSibling = newChild;
- } else {
- parentNode.firstChild = newChild;
- }
- parentNode.lastChild = newChild;
- _onUpdateChild(parentNode.ownerDocument, parentNode, newChild);
- return newChild;
- }
- Document.prototype = {
- nodeName: "#document",
- nodeType: DOCUMENT_NODE,
- doctype: null,
- documentElement: null,
- _inc: 1,
- insertBefore: function(newChild, refChild) {
- if (newChild.nodeType == DOCUMENT_FRAGMENT_NODE) {
- var child = newChild.firstChild;
- while (child) {
- var next = child.nextSibling;
- this.insertBefore(child, refChild);
- child = next;
- }
- return newChild;
- }
- _insertBefore(this, newChild, refChild);
- newChild.ownerDocument = this;
- if (this.documentElement === null && newChild.nodeType === ELEMENT_NODE) {
- this.documentElement = newChild;
- }
- return newChild;
- },
- removeChild: function(oldChild) {
- if (this.documentElement == oldChild) {
- this.documentElement = null;
- }
- return _removeChild(this, oldChild);
- },
- replaceChild: function(newChild, oldChild) {
- _insertBefore(this, newChild, oldChild, assertPreReplacementValidityInDocument);
- newChild.ownerDocument = this;
- if (oldChild) {
- this.removeChild(oldChild);
- }
- if (isElementNode(newChild)) {
- this.documentElement = newChild;
- }
- },
- importNode: function(importedNode, deep) {
- return importNode(this, importedNode, deep);
- },
- getElementById: function(id) {
- var rtv = null;
- _visitNode(this.documentElement, function(node) {
- if (node.nodeType == ELEMENT_NODE) {
- if (node.getAttribute("id") == id) {
- rtv = node;
- return true;
- }
- }
- });
- return rtv;
- },
- getElementsByClassName: function(classNames) {
- var classNamesSet = toOrderedSet(classNames);
- return new LiveNodeList(this, function(base2) {
- var ls = [];
- if (classNamesSet.length > 0) {
- _visitNode(base2.documentElement, function(node) {
- if (node !== base2 && node.nodeType === ELEMENT_NODE) {
- var nodeClassNames = node.getAttribute("class");
- if (nodeClassNames) {
- var matches = classNames === nodeClassNames;
- if (!matches) {
- var nodeClassNamesSet = toOrderedSet(nodeClassNames);
- matches = classNamesSet.every(arrayIncludes(nodeClassNamesSet));
- }
- if (matches) {
- ls.push(node);
- }
- }
- }
- });
- }
- return ls;
- });
- },
- createElement: function(tagName) {
- var node = new Element$1();
- node.ownerDocument = this;
- node.nodeName = tagName;
- node.tagName = tagName;
- node.localName = tagName;
- node.childNodes = new NodeList();
- var attrs = node.attributes = new NamedNodeMap();
- attrs._ownerElement = node;
- return node;
- },
- createDocumentFragment: function() {
- var node = new DocumentFragment();
- node.ownerDocument = this;
- node.childNodes = new NodeList();
- return node;
- },
- createTextNode: function(data) {
- var node = new Text();
- node.ownerDocument = this;
- node.appendData(data);
- return node;
- },
- createComment: function(data) {
- var node = new Comment();
- node.ownerDocument = this;
- node.appendData(data);
- return node;
- },
- createCDATASection: function(data) {
- var node = new CDATASection();
- node.ownerDocument = this;
- node.appendData(data);
- return node;
- },
- createProcessingInstruction: function(target, data) {
- var node = new ProcessingInstruction();
- node.ownerDocument = this;
- node.tagName = node.target = target;
- node.nodeValue = node.data = data;
- return node;
- },
- createAttribute: function(name) {
- var node = new Attr();
- node.ownerDocument = this;
- node.name = name;
- node.nodeName = name;
- node.localName = name;
- node.specified = true;
- return node;
- },
- createEntityReference: function(name) {
- var node = new EntityReference();
- node.ownerDocument = this;
- node.nodeName = name;
- return node;
- },
- createElementNS: function(namespaceURI, qualifiedName) {
- var node = new Element$1();
- var pl = qualifiedName.split(":");
- var attrs = node.attributes = new NamedNodeMap();
- node.childNodes = new NodeList();
- node.ownerDocument = this;
- node.nodeName = qualifiedName;
- node.tagName = qualifiedName;
- node.namespaceURI = namespaceURI;
- if (pl.length == 2) {
- node.prefix = pl[0];
- node.localName = pl[1];
- } else {
- node.localName = qualifiedName;
- }
- attrs._ownerElement = node;
- return node;
- },
- createAttributeNS: function(namespaceURI, qualifiedName) {
- var node = new Attr();
- var pl = qualifiedName.split(":");
- node.ownerDocument = this;
- node.nodeName = qualifiedName;
- node.name = qualifiedName;
- node.namespaceURI = namespaceURI;
- node.specified = true;
- if (pl.length == 2) {
- node.prefix = pl[0];
- node.localName = pl[1];
- } else {
- node.localName = qualifiedName;
- }
- return node;
- }
- };
- _extends(Document, Node);
- function Element$1() {
- this._nsMap = {};
- }
- Element$1.prototype = {
- nodeType: ELEMENT_NODE,
- hasAttribute: function(name) {
- return this.getAttributeNode(name) != null;
- },
- getAttribute: function(name) {
- var attr = this.getAttributeNode(name);
- return attr && attr.value || "";
- },
- getAttributeNode: function(name) {
- return this.attributes.getNamedItem(name);
- },
- setAttribute: function(name, value) {
- var attr = this.ownerDocument.createAttribute(name);
- attr.value = attr.nodeValue = "" + value;
- this.setAttributeNode(attr);
- },
- removeAttribute: function(name) {
- var attr = this.getAttributeNode(name);
- attr && this.removeAttributeNode(attr);
- },
- appendChild: function(newChild) {
- if (newChild.nodeType === DOCUMENT_FRAGMENT_NODE) {
- return this.insertBefore(newChild, null);
- } else {
- return _appendSingleChild(this, newChild);
- }
- },
- setAttributeNode: function(newAttr) {
- return this.attributes.setNamedItem(newAttr);
- },
- setAttributeNodeNS: function(newAttr) {
- return this.attributes.setNamedItemNS(newAttr);
- },
- removeAttributeNode: function(oldAttr) {
- return this.attributes.removeNamedItem(oldAttr.nodeName);
- },
- removeAttributeNS: function(namespaceURI, localName) {
- var old = this.getAttributeNodeNS(namespaceURI, localName);
- old && this.removeAttributeNode(old);
- },
- hasAttributeNS: function(namespaceURI, localName) {
- return this.getAttributeNodeNS(namespaceURI, localName) != null;
- },
- getAttributeNS: function(namespaceURI, localName) {
- var attr = this.getAttributeNodeNS(namespaceURI, localName);
- return attr && attr.value || "";
- },
- setAttributeNS: function(namespaceURI, qualifiedName, value) {
- var attr = this.ownerDocument.createAttributeNS(namespaceURI, qualifiedName);
- attr.value = attr.nodeValue = "" + value;
- this.setAttributeNode(attr);
- },
- getAttributeNodeNS: function(namespaceURI, localName) {
- return this.attributes.getNamedItemNS(namespaceURI, localName);
- },
- getElementsByTagName: function(tagName) {
- return new LiveNodeList(this, function(base2) {
- var ls = [];
- _visitNode(base2, function(node) {
- if (node !== base2 && node.nodeType == ELEMENT_NODE && (tagName === "*" || node.tagName == tagName)) {
- ls.push(node);
- }
- });
- return ls;
- });
- },
- getElementsByTagNameNS: function(namespaceURI, localName) {
- return new LiveNodeList(this, function(base2) {
- var ls = [];
- _visitNode(base2, function(node) {
- if (node !== base2 && node.nodeType === ELEMENT_NODE && (namespaceURI === "*" || node.namespaceURI === namespaceURI) && (localName === "*" || node.localName == localName)) {
- ls.push(node);
- }
- });
- return ls;
- });
- }
- };
- Document.prototype.getElementsByTagName = Element$1.prototype.getElementsByTagName;
- Document.prototype.getElementsByTagNameNS = Element$1.prototype.getElementsByTagNameNS;
- _extends(Element$1, Node);
- function Attr() {
- }
- Attr.prototype.nodeType = ATTRIBUTE_NODE;
- _extends(Attr, Node);
- function CharacterData() {
- }
- CharacterData.prototype = {
- data: "",
- substringData: function(offset, count) {
- return this.data.substring(offset, offset + count);
- },
- appendData: function(text) {
- text = this.data + text;
- this.nodeValue = this.data = text;
- this.length = text.length;
- },
- insertData: function(offset, text) {
- this.replaceData(offset, 0, text);
- },
- appendChild: function(newChild) {
- throw new Error(ExceptionMessage[HIERARCHY_REQUEST_ERR]);
- },
- deleteData: function(offset, count) {
- this.replaceData(offset, count, "");
- },
- replaceData: function(offset, count, text) {
- var start2 = this.data.substring(0, offset);
- var end = this.data.substring(offset + count);
- text = start2 + text + end;
- this.nodeValue = this.data = text;
- this.length = text.length;
- }
- };
- _extends(CharacterData, Node);
- function Text() {
- }
- Text.prototype = {
- nodeName: "#text",
- nodeType: TEXT_NODE,
- splitText: function(offset) {
- var text = this.data;
- var newText = text.substring(offset);
- text = text.substring(0, offset);
- this.data = this.nodeValue = text;
- this.length = text.length;
- var newNode = this.ownerDocument.createTextNode(newText);
- if (this.parentNode) {
- this.parentNode.insertBefore(newNode, this.nextSibling);
- }
- return newNode;
- }
- };
- _extends(Text, CharacterData);
- function Comment() {
- }
- Comment.prototype = {
- nodeName: "#comment",
- nodeType: COMMENT_NODE
- };
- _extends(Comment, CharacterData);
- function CDATASection() {
- }
- CDATASection.prototype = {
- nodeName: "#cdata-section",
- nodeType: CDATA_SECTION_NODE
- };
- _extends(CDATASection, CharacterData);
- function DocumentType() {
- }
- DocumentType.prototype.nodeType = DOCUMENT_TYPE_NODE;
- _extends(DocumentType, Node);
- function Notation() {
- }
- Notation.prototype.nodeType = NOTATION_NODE;
- _extends(Notation, Node);
- function Entity() {
- }
- Entity.prototype.nodeType = ENTITY_NODE;
- _extends(Entity, Node);
- function EntityReference() {
- }
- EntityReference.prototype.nodeType = ENTITY_REFERENCE_NODE;
- _extends(EntityReference, Node);
- function DocumentFragment() {
- }
- DocumentFragment.prototype.nodeName = "#document-fragment";
- DocumentFragment.prototype.nodeType = DOCUMENT_FRAGMENT_NODE;
- _extends(DocumentFragment, Node);
- function ProcessingInstruction() {
- }
- ProcessingInstruction.prototype.nodeType = PROCESSING_INSTRUCTION_NODE;
- _extends(ProcessingInstruction, Node);
- function XMLSerializer() {
- }
- XMLSerializer.prototype.serializeToString = function(node, isHtml, nodeFilter) {
- return nodeSerializeToString.call(node, isHtml, nodeFilter);
- };
- Node.prototype.toString = nodeSerializeToString;
- function nodeSerializeToString(isHtml, nodeFilter) {
- var buf = [];
- var refNode = this.nodeType == 9 && this.documentElement || this;
- var prefix = refNode.prefix;
- var uri = refNode.namespaceURI;
- if (uri && prefix == null) {
- var prefix = refNode.lookupPrefix(uri);
- if (prefix == null) {
- var visibleNamespaces = [
- { namespace: uri, prefix: null }
- ];
- }
- }
- serializeToString(this, buf, isHtml, nodeFilter, visibleNamespaces);
- return buf.join("");
- }
- function needNamespaceDefine(node, isHTML, visibleNamespaces) {
- var prefix = node.prefix || "";
- var uri = node.namespaceURI;
- if (!uri) {
- return false;
- }
- if (prefix === "xml" && uri === NAMESPACE$2.XML || uri === NAMESPACE$2.XMLNS) {
- return false;
- }
- var i2 = visibleNamespaces.length;
- while (i2--) {
- var ns = visibleNamespaces[i2];
- if (ns.prefix === prefix) {
- return ns.namespace !== uri;
- }
- }
- return true;
- }
- function addSerializedAttribute(buf, qualifiedName, value) {
- buf.push(" ", qualifiedName, '="', value.replace(/[<>&"\t\n\r]/g, _xmlEncoder), '"');
- }
- function serializeToString(node, buf, isHTML, nodeFilter, visibleNamespaces) {
- if (!visibleNamespaces) {
- visibleNamespaces = [];
- }
- if (nodeFilter) {
- node = nodeFilter(node);
- if (node) {
- if (typeof node == "string") {
- buf.push(node);
- return;
- }
- } else {
- return;
- }
- }
- switch (node.nodeType) {
- case ELEMENT_NODE:
- var attrs = node.attributes;
- var len = attrs.length;
- var child = node.firstChild;
- var nodeName = node.tagName;
- isHTML = NAMESPACE$2.isHTML(node.namespaceURI) || isHTML;
- var prefixedNodeName = nodeName;
- if (!isHTML && !node.prefix && node.namespaceURI) {
- var defaultNS;
- for (var ai = 0; ai < attrs.length; ai++) {
- if (attrs.item(ai).name === "xmlns") {
- defaultNS = attrs.item(ai).value;
- break;
- }
- }
- if (!defaultNS) {
- for (var nsi = visibleNamespaces.length - 1; nsi >= 0; nsi--) {
- var namespace = visibleNamespaces[nsi];
- if (namespace.prefix === "" && namespace.namespace === node.namespaceURI) {
- defaultNS = namespace.namespace;
- break;
- }
- }
- }
- if (defaultNS !== node.namespaceURI) {
- for (var nsi = visibleNamespaces.length - 1; nsi >= 0; nsi--) {
- var namespace = visibleNamespaces[nsi];
- if (namespace.namespace === node.namespaceURI) {
- if (namespace.prefix) {
- prefixedNodeName = namespace.prefix + ":" + nodeName;
- }
- break;
- }
- }
- }
- }
- buf.push("<", prefixedNodeName);
- for (var i2 = 0; i2 < len; i2++) {
- var attr = attrs.item(i2);
- if (attr.prefix == "xmlns") {
- visibleNamespaces.push({ prefix: attr.localName, namespace: attr.value });
- } else if (attr.nodeName == "xmlns") {
- visibleNamespaces.push({ prefix: "", namespace: attr.value });
- }
- }
- for (var i2 = 0; i2 < len; i2++) {
- var attr = attrs.item(i2);
- if (needNamespaceDefine(attr, isHTML, visibleNamespaces)) {
- var prefix = attr.prefix || "";
- var uri = attr.namespaceURI;
- addSerializedAttribute(buf, prefix ? "xmlns:" + prefix : "xmlns", uri);
- visibleNamespaces.push({ prefix, namespace: uri });
- }
- serializeToString(attr, buf, isHTML, nodeFilter, visibleNamespaces);
- }
- if (nodeName === prefixedNodeName && needNamespaceDefine(node, isHTML, visibleNamespaces)) {
- var prefix = node.prefix || "";
- var uri = node.namespaceURI;
- addSerializedAttribute(buf, prefix ? "xmlns:" + prefix : "xmlns", uri);
- visibleNamespaces.push({ prefix, namespace: uri });
- }
- if (child || isHTML && !/^(?:meta|link|img|br|hr|input)$/i.test(nodeName)) {
- buf.push(">");
- if (isHTML && /^script$/i.test(nodeName)) {
- while (child) {
- if (child.data) {
- buf.push(child.data);
- } else {
- serializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces.slice());
- }
- child = child.nextSibling;
- }
- } else {
- while (child) {
- serializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces.slice());
- child = child.nextSibling;
- }
- }
- buf.push("</", prefixedNodeName, ">");
- } else {
- buf.push("/>");
- }
- return;
- case DOCUMENT_NODE:
- case DOCUMENT_FRAGMENT_NODE:
- var child = node.firstChild;
- while (child) {
- serializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces.slice());
- child = child.nextSibling;
- }
- return;
- case ATTRIBUTE_NODE:
- return addSerializedAttribute(buf, node.name, node.value);
- case TEXT_NODE:
- return buf.push(
- node.data.replace(/[<&>]/g, _xmlEncoder)
- );
- case CDATA_SECTION_NODE:
- return buf.push("<![CDATA[", node.data, "]]>");
- case COMMENT_NODE:
- return buf.push("<!--", node.data, "-->");
- case DOCUMENT_TYPE_NODE:
- var pubid = node.publicId;
- var sysid = node.systemId;
- buf.push("<!DOCTYPE ", node.name);
- if (pubid) {
- buf.push(" PUBLIC ", pubid);
- if (sysid && sysid != ".") {
- buf.push(" ", sysid);
- }
- buf.push(">");
- } else if (sysid && sysid != ".") {
- buf.push(" SYSTEM ", sysid, ">");
- } else {
- var sub = node.internalSubset;
- if (sub) {
- buf.push(" [", sub, "]");
- }
- buf.push(">");
- }
- return;
- case PROCESSING_INSTRUCTION_NODE:
- return buf.push("<?", node.target, " ", node.data, "?>");
- case ENTITY_REFERENCE_NODE:
- return buf.push("&", node.nodeName, ";");
- default:
- buf.push("??", node.nodeName);
- }
- }
- function importNode(doc, node, deep) {
- var node2;
- switch (node.nodeType) {
- case ELEMENT_NODE:
- node2 = node.cloneNode(false);
- node2.ownerDocument = doc;
- case DOCUMENT_FRAGMENT_NODE:
- break;
- case ATTRIBUTE_NODE:
- deep = true;
- break;
- }
- if (!node2) {
- node2 = node.cloneNode(false);
- }
- node2.ownerDocument = doc;
- node2.parentNode = null;
- if (deep) {
- var child = node.firstChild;
- while (child) {
- node2.appendChild(importNode(doc, child, deep));
- child = child.nextSibling;
- }
- }
- return node2;
- }
- function cloneNode(doc, node, deep) {
- var node2 = new node.constructor();
- for (var n in node) {
- if (Object.prototype.hasOwnProperty.call(node, n)) {
- var v = node[n];
- if (typeof v != "object") {
- if (v != node2[n]) {
- node2[n] = v;
- }
- }
- }
- }
- if (node.childNodes) {
- node2.childNodes = new NodeList();
- }
- node2.ownerDocument = doc;
- switch (node2.nodeType) {
- case ELEMENT_NODE:
- var attrs = node.attributes;
- var attrs2 = node2.attributes = new NamedNodeMap();
- var len = attrs.length;
- attrs2._ownerElement = node2;
- for (var i2 = 0; i2 < len; i2++) {
- node2.setAttributeNode(cloneNode(doc, attrs.item(i2), true));
- }
- break;
- case ATTRIBUTE_NODE:
- deep = true;
- }
- if (deep) {
- var child = node.firstChild;
- while (child) {
- node2.appendChild(cloneNode(doc, child, deep));
- child = child.nextSibling;
- }
- }
- return node2;
- }
- function __set__(object, key, value) {
- object[key] = value;
- }
- try {
- if (Object.defineProperty) {
- let getTextContent = function(node) {
- switch (node.nodeType) {
- case ELEMENT_NODE:
- case DOCUMENT_FRAGMENT_NODE:
- var buf = [];
- node = node.firstChild;
- while (node) {
- if (node.nodeType !== 7 && node.nodeType !== 8) {
- buf.push(getTextContent(node));
- }
- node = node.nextSibling;
- }
- return buf.join("");
- default:
- return node.nodeValue;
- }
- };
- Object.defineProperty(LiveNodeList.prototype, "length", {
- get: function() {
- _updateLiveList(this);
- return this.$$length;
- }
- });
- Object.defineProperty(Node.prototype, "textContent", {
- get: function() {
- return getTextContent(this);
- },
- set: function(data) {
- switch (this.nodeType) {
- case ELEMENT_NODE:
- case DOCUMENT_FRAGMENT_NODE:
- while (this.firstChild) {
- this.removeChild(this.firstChild);
- }
- if (data || String(data)) {
- this.appendChild(this.ownerDocument.createTextNode(data));
- }
- break;
- default:
- this.data = data;
- this.value = data;
- this.nodeValue = data;
- }
- }
- });
- __set__ = function(object, key, value) {
- object["$$" + key] = value;
- };
- }
- } catch (e) {
- }
- dom$1.DocumentType = DocumentType;
- dom$1.DOMException = DOMException;
- dom$1.DOMImplementation = DOMImplementation$1;
- dom$1.Element = Element$1;
- dom$1.Node = Node;
- dom$1.NodeList = NodeList;
- dom$1.XMLSerializer = XMLSerializer;
- var domParser = {};
- var entities$1 = {};
- (function(exports2) {
- var freeze2 = conventions$2.freeze;
- exports2.XML_ENTITIES = freeze2({ amp: "&", apos: "'", gt: ">", lt: "<", quot: '"' });
- exports2.HTML_ENTITIES = freeze2({
- lt: "<",
- gt: ">",
- amp: "&",
- quot: '"',
- apos: "'",
- Agrave: "\xC0",
- Aacute: "\xC1",
- Acirc: "\xC2",
- Atilde: "\xC3",
- Auml: "\xC4",
- Aring: "\xC5",
- AElig: "\xC6",
- Ccedil: "\xC7",
- Egrave: "\xC8",
- Eacute: "\xC9",
- Ecirc: "\xCA",
- Euml: "\xCB",
- Igrave: "\xCC",
- Iacute: "\xCD",
- Icirc: "\xCE",
- Iuml: "\xCF",
- ETH: "\xD0",
- Ntilde: "\xD1",
- Ograve: "\xD2",
- Oacute: "\xD3",
- Ocirc: "\xD4",
- Otilde: "\xD5",
- Ouml: "\xD6",
- Oslash: "\xD8",
- Ugrave: "\xD9",
- Uacute: "\xDA",
- Ucirc: "\xDB",
- Uuml: "\xDC",
- Yacute: "\xDD",
- THORN: "\xDE",
- szlig: "\xDF",
- agrave: "\xE0",
- aacute: "\xE1",
- acirc: "\xE2",
- atilde: "\xE3",
- auml: "\xE4",
- aring: "\xE5",
- aelig: "\xE6",
- ccedil: "\xE7",
- egrave: "\xE8",
- eacute: "\xE9",
- ecirc: "\xEA",
- euml: "\xEB",
- igrave: "\xEC",
- iacute: "\xED",
- icirc: "\xEE",
- iuml: "\xEF",
- eth: "\xF0",
- ntilde: "\xF1",
- ograve: "\xF2",
- oacute: "\xF3",
- ocirc: "\xF4",
- otilde: "\xF5",
- ouml: "\xF6",
- oslash: "\xF8",
- ugrave: "\xF9",
- uacute: "\xFA",
- ucirc: "\xFB",
- uuml: "\xFC",
- yacute: "\xFD",
- thorn: "\xFE",
- yuml: "\xFF",
- nbsp: "\xA0",
- iexcl: "\xA1",
- cent: "\xA2",
- pound: "\xA3",
- curren: "\xA4",
- yen: "\xA5",
- brvbar: "\xA6",
- sect: "\xA7",
- uml: "\xA8",
- copy: "\xA9",
- ordf: "\xAA",
- laquo: "\xAB",
- not: "\xAC",
- shy: "\xAD\xAD",
- reg: "\xAE",
- macr: "\xAF",
- deg: "\xB0",
- plusmn: "\xB1",
- sup2: "\xB2",
- sup3: "\xB3",
- acute: "\xB4",
- micro: "\xB5",
- para: "\xB6",
- middot: "\xB7",
- cedil: "\xB8",
- sup1: "\xB9",
- ordm: "\xBA",
- raquo: "\xBB",
- frac14: "\xBC",
- frac12: "\xBD",
- frac34: "\xBE",
- iquest: "\xBF",
- times: "\xD7",
- divide: "\xF7",
- forall: "\u2200",
- part: "\u2202",
- exist: "\u2203",
- empty: "\u2205",
- nabla: "\u2207",
- isin: "\u2208",
- notin: "\u2209",
- ni: "\u220B",
- prod: "\u220F",
- sum: "\u2211",
- minus: "\u2212",
- lowast: "\u2217",
- radic: "\u221A",
- prop: "\u221D",
- infin: "\u221E",
- ang: "\u2220",
- and: "\u2227",
- or: "\u2228",
- cap: "\u2229",
- cup: "\u222A",
- "int": "\u222B",
- there4: "\u2234",
- sim: "\u223C",
- cong: "\u2245",
- asymp: "\u2248",
- ne: "\u2260",
- equiv: "\u2261",
- le: "\u2264",
- ge: "\u2265",
- sub: "\u2282",
- sup: "\u2283",
- nsub: "\u2284",
- sube: "\u2286",
- supe: "\u2287",
- oplus: "\u2295",
- otimes: "\u2297",
- perp: "\u22A5",
- sdot: "\u22C5",
- Alpha: "\u0391",
- Beta: "\u0392",
- Gamma: "\u0393",
- Delta: "\u0394",
- Epsilon: "\u0395",
- Zeta: "\u0396",
- Eta: "\u0397",
- Theta: "\u0398",
- Iota: "\u0399",
- Kappa: "\u039A",
- Lambda: "\u039B",
- Mu: "\u039C",
- Nu: "\u039D",
- Xi: "\u039E",
- Omicron: "\u039F",
- Pi: "\u03A0",
- Rho: "\u03A1",
- Sigma: "\u03A3",
- Tau: "\u03A4",
- Upsilon: "\u03A5",
- Phi: "\u03A6",
- Chi: "\u03A7",
- Psi: "\u03A8",
- Omega: "\u03A9",
- alpha: "\u03B1",
- beta: "\u03B2",
- gamma: "\u03B3",
- delta: "\u03B4",
- epsilon: "\u03B5",
- zeta: "\u03B6",
- eta: "\u03B7",
- theta: "\u03B8",
- iota: "\u03B9",
- kappa: "\u03BA",
- lambda: "\u03BB",
- mu: "\u03BC",
- nu: "\u03BD",
- xi: "\u03BE",
- omicron: "\u03BF",
- pi: "\u03C0",
- rho: "\u03C1",
- sigmaf: "\u03C2",
- sigma: "\u03C3",
- tau: "\u03C4",
- upsilon: "\u03C5",
- phi: "\u03C6",
- chi: "\u03C7",
- psi: "\u03C8",
- omega: "\u03C9",
- thetasym: "\u03D1",
- upsih: "\u03D2",
- piv: "\u03D6",
- OElig: "\u0152",
- oelig: "\u0153",
- Scaron: "\u0160",
- scaron: "\u0161",
- Yuml: "\u0178",
- fnof: "\u0192",
- circ: "\u02C6",
- tilde: "\u02DC",
- ensp: "\u2002",
- emsp: "\u2003",
- thinsp: "\u2009",
- zwnj: "\u200C",
- zwj: "\u200D",
- lrm: "\u200E",
- rlm: "\u200F",
- ndash: "\u2013",
- mdash: "\u2014",
- lsquo: "\u2018",
- rsquo: "\u2019",
- sbquo: "\u201A",
- ldquo: "\u201C",
- rdquo: "\u201D",
- bdquo: "\u201E",
- dagger: "\u2020",
- Dagger: "\u2021",
- bull: "\u2022",
- hellip: "\u2026",
- permil: "\u2030",
- prime: "\u2032",
- Prime: "\u2033",
- lsaquo: "\u2039",
- rsaquo: "\u203A",
- oline: "\u203E",
- euro: "\u20AC",
- trade: "\u2122",
- larr: "\u2190",
- uarr: "\u2191",
- rarr: "\u2192",
- darr: "\u2193",
- harr: "\u2194",
- crarr: "\u21B5",
- lceil: "\u2308",
- rceil: "\u2309",
- lfloor: "\u230A",
- rfloor: "\u230B",
- loz: "\u25CA",
- spades: "\u2660",
- clubs: "\u2663",
- hearts: "\u2665",
- diams: "\u2666"
- });
- exports2.entityMap = exports2.HTML_ENTITIES;
- })(entities$1);
- var sax$1 = {};
- var NAMESPACE$1 = conventions$2.NAMESPACE;
- var nameStartChar = /[A-Z_a-z\xC0-\xD6\xD8-\xF6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD]/;
- var nameChar = new RegExp("[\\-\\.0-9" + nameStartChar.source.slice(1, -1) + "\\u00B7\\u0300-\\u036F\\u203F-\\u2040]");
- var tagNamePattern = new RegExp("^" + nameStartChar.source + nameChar.source + "*(?::" + nameStartChar.source + nameChar.source + "*)?$");
- var S_TAG = 0;
- var S_ATTR = 1;
- var S_ATTR_SPACE = 2;
- var S_EQ = 3;
- var S_ATTR_NOQUOT_VALUE = 4;
- var S_ATTR_END = 5;
- var S_TAG_SPACE = 6;
- var S_TAG_CLOSE = 7;
- function ParseError$1(message, locator) {
- this.message = message;
- this.locator = locator;
- if (Error.captureStackTrace)
- Error.captureStackTrace(this, ParseError$1);
- }
- ParseError$1.prototype = new Error();
- ParseError$1.prototype.name = ParseError$1.name;
- function XMLReader$1() {
- }
- XMLReader$1.prototype = {
- parse: function(source, defaultNSMap, entityMap) {
- var domBuilder = this.domBuilder;
- domBuilder.startDocument();
- _copy(defaultNSMap, defaultNSMap = {});
- parse$2(
- source,
- defaultNSMap,
- entityMap,
- domBuilder,
- this.errorHandler
- );
- domBuilder.endDocument();
- }
- };
- function parse$2(source, defaultNSMapCopy, entityMap, domBuilder, errorHandler) {
- function fixedFromCharCode(code) {
- if (code > 65535) {
- code -= 65536;
- var surrogate1 = 55296 + (code >> 10), surrogate2 = 56320 + (code & 1023);
- return String.fromCharCode(surrogate1, surrogate2);
- } else {
- return String.fromCharCode(code);
- }
- }
- function entityReplacer(a2) {
- var k = a2.slice(1, -1);
- if (Object.hasOwnProperty.call(entityMap, k)) {
- return entityMap[k];
- } else if (k.charAt(0) === "#") {
- return fixedFromCharCode(parseInt(k.substr(1).replace("x", "0x")));
- } else {
- errorHandler.error("entity not found:" + a2);
- return a2;
- }
- }
- function appendText(end2) {
- if (end2 > start2) {
- var xt2 = source.substring(start2, end2).replace(/&#?\w+;/g, entityReplacer);
- locator && position2(start2);
- domBuilder.characters(xt2, 0, end2 - start2);
- start2 = end2;
- }
- }
- function position2(p, m) {
- while (p >= lineEnd && (m = linePattern.exec(source))) {
- lineStart = m.index;
- lineEnd = lineStart + m[0].length;
- locator.lineNumber++;
- }
- locator.columnNumber = p - lineStart + 1;
- }
- var lineStart = 0;
- var lineEnd = 0;
- var linePattern = /.*(?:\r\n?|\n)|.*$/g;
- var locator = domBuilder.locator;
- var parseStack = [{ currentNSMap: defaultNSMapCopy }];
- var closeMap = {};
- var start2 = 0;
- while (true) {
- try {
- var tagStart = source.indexOf("<", start2);
- if (tagStart < 0) {
- if (!source.substr(start2).match(/^\s*$/)) {
- var doc = domBuilder.doc;
- var text = doc.createTextNode(source.substr(start2));
- doc.appendChild(text);
- domBuilder.currentElement = text;
- }
- return;
- }
- if (tagStart > start2) {
- appendText(tagStart);
- }
- switch (source.charAt(tagStart + 1)) {
- case "/":
- var end = source.indexOf(">", tagStart + 3);
- var tagName = source.substring(tagStart + 2, end).replace(/[ \t\n\r]+$/g, "");
- var config = parseStack.pop();
- if (end < 0) {
- tagName = source.substring(tagStart + 2).replace(/[\s<].*/, "");
- errorHandler.error("end tag name: " + tagName + " is not complete:" + config.tagName);
- end = tagStart + 1 + tagName.length;
- } else if (tagName.match(/\s</)) {
- tagName = tagName.replace(/[\s<].*/, "");
- errorHandler.error("end tag name: " + tagName + " maybe not complete");
- end = tagStart + 1 + tagName.length;
- }
- var localNSMap = config.localNSMap;
- var endMatch = config.tagName == tagName;
- var endIgnoreCaseMach = endMatch || config.tagName && config.tagName.toLowerCase() == tagName.toLowerCase();
- if (endIgnoreCaseMach) {
- domBuilder.endElement(config.uri, config.localName, tagName);
- if (localNSMap) {
- for (var prefix in localNSMap) {
- if (Object.prototype.hasOwnProperty.call(localNSMap, prefix)) {
- domBuilder.endPrefixMapping(prefix);
- }
- }
- }
- if (!endMatch) {
- errorHandler.fatalError("end tag name: " + tagName + " is not match the current start tagName:" + config.tagName);
- }
- } else {
- parseStack.push(config);
- }
- end++;
- break;
- case "?":
- locator && position2(tagStart);
- end = parseInstruction(source, tagStart, domBuilder);
- break;
- case "!":
- locator && position2(tagStart);
- end = parseDCC(source, tagStart, domBuilder, errorHandler);
- break;
- default:
- locator && position2(tagStart);
- var el = new ElementAttributes();
- var currentNSMap = parseStack[parseStack.length - 1].currentNSMap;
- var end = parseElementStartPart(source, tagStart, el, currentNSMap, entityReplacer, errorHandler);
- var len = el.length;
- if (!el.closed && fixSelfClosed(source, end, el.tagName, closeMap)) {
- el.closed = true;
- if (!entityMap.nbsp) {
- errorHandler.warning("unclosed xml attribute");
- }
- }
- if (locator && len) {
- var locator2 = copyLocator(locator, {});
- for (var i2 = 0; i2 < len; i2++) {
- var a = el[i2];
- position2(a.offset);
- a.locator = copyLocator(locator, {});
- }
- domBuilder.locator = locator2;
- if (appendElement$1(el, domBuilder, currentNSMap)) {
- parseStack.push(el);
- }
- domBuilder.locator = locator;
- } else {
- if (appendElement$1(el, domBuilder, currentNSMap)) {
- parseStack.push(el);
- }
- }
- if (NAMESPACE$1.isHTML(el.uri) && !el.closed) {
- end = parseHtmlSpecialContent(source, end, el.tagName, entityReplacer, domBuilder);
- } else {
- end++;
- }
- }
- } catch (e) {
- if (e instanceof ParseError$1) {
- throw e;
- }
- errorHandler.error("element parse error: " + e);
- end = -1;
- }
- if (end > start2) {
- start2 = end;
- } else {
- appendText(Math.max(tagStart, start2) + 1);
- }
- }
- }
- function copyLocator(f, t2) {
- t2.lineNumber = f.lineNumber;
- t2.columnNumber = f.columnNumber;
- return t2;
- }
- function parseElementStartPart(source, start2, el, currentNSMap, entityReplacer, errorHandler) {
- function addAttribute(qname, value2, startIndex) {
- if (el.attributeNames.hasOwnProperty(qname)) {
- errorHandler.fatalError("Attribute " + qname + " redefined");
- }
- el.addValue(
- qname,
- value2.replace(/[\t\n\r]/g, " ").replace(/&#?\w+;/g, entityReplacer),
- startIndex
- );
- }
- var attrName;
- var value;
- var p = ++start2;
- var s = S_TAG;
- while (true) {
- var c = source.charAt(p);
- switch (c) {
- case "=":
- if (s === S_ATTR) {
- attrName = source.slice(start2, p);
- s = S_EQ;
- } else if (s === S_ATTR_SPACE) {
- s = S_EQ;
- } else {
- throw new Error("attribute equal must after attrName");
- }
- break;
- case "'":
- case '"':
- if (s === S_EQ || s === S_ATTR) {
- if (s === S_ATTR) {
- errorHandler.warning('attribute value must after "="');
- attrName = source.slice(start2, p);
- }
- start2 = p + 1;
- p = source.indexOf(c, start2);
- if (p > 0) {
- value = source.slice(start2, p);
- addAttribute(attrName, value, start2 - 1);
- s = S_ATTR_END;
- } else {
- throw new Error("attribute value no end '" + c + "' match");
- }
- } else if (s == S_ATTR_NOQUOT_VALUE) {
- value = source.slice(start2, p);
- addAttribute(attrName, value, start2);
- errorHandler.warning('attribute "' + attrName + '" missed start quot(' + c + ")!!");
- start2 = p + 1;
- s = S_ATTR_END;
- } else {
- throw new Error('attribute value must after "="');
- }
- break;
- case "/":
- switch (s) {
- case S_TAG:
- el.setTagName(source.slice(start2, p));
- case S_ATTR_END:
- case S_TAG_SPACE:
- case S_TAG_CLOSE:
- s = S_TAG_CLOSE;
- el.closed = true;
- case S_ATTR_NOQUOT_VALUE:
- case S_ATTR:
- break;
- case S_ATTR_SPACE:
- el.closed = true;
- break;
- default:
- throw new Error("attribute invalid close char('/')");
- }
- break;
- case "":
- errorHandler.error("unexpected end of input");
- if (s == S_TAG) {
- el.setTagName(source.slice(start2, p));
- }
- return p;
- case ">":
- switch (s) {
- case S_TAG:
- el.setTagName(source.slice(start2, p));
- case S_ATTR_END:
- case S_TAG_SPACE:
- case S_TAG_CLOSE:
- break;
- case S_ATTR_NOQUOT_VALUE:
- case S_ATTR:
- value = source.slice(start2, p);
- if (value.slice(-1) === "/") {
- el.closed = true;
- value = value.slice(0, -1);
- }
- case S_ATTR_SPACE:
- if (s === S_ATTR_SPACE) {
- value = attrName;
- }
- if (s == S_ATTR_NOQUOT_VALUE) {
- errorHandler.warning('attribute "' + value + '" missed quot(")!');
- addAttribute(attrName, value, start2);
- } else {
- if (!NAMESPACE$1.isHTML(currentNSMap[""]) || !value.match(/^(?:disabled|checked|selected)$/i)) {
- errorHandler.warning('attribute "' + value + '" missed value!! "' + value + '" instead!!');
- }
- addAttribute(value, value, start2);
- }
- break;
- case S_EQ:
- throw new Error("attribute value missed!!");
- }
- return p;
- case "\x80":
- c = " ";
- default:
- if (c <= " ") {
- switch (s) {
- case S_TAG:
- el.setTagName(source.slice(start2, p));
- s = S_TAG_SPACE;
- break;
- case S_ATTR:
- attrName = source.slice(start2, p);
- s = S_ATTR_SPACE;
- break;
- case S_ATTR_NOQUOT_VALUE:
- var value = source.slice(start2, p);
- errorHandler.warning('attribute "' + value + '" missed quot(")!!');
- addAttribute(attrName, value, start2);
- case S_ATTR_END:
- s = S_TAG_SPACE;
- break;
- }
- } else {
- switch (s) {
- case S_ATTR_SPACE:
- el.tagName;
- if (!NAMESPACE$1.isHTML(currentNSMap[""]) || !attrName.match(/^(?:disabled|checked|selected)$/i)) {
- errorHandler.warning('attribute "' + attrName + '" missed value!! "' + attrName + '" instead2!!');
- }
- addAttribute(attrName, attrName, start2);
- start2 = p;
- s = S_ATTR;
- break;
- case S_ATTR_END:
- errorHandler.warning('attribute space is required"' + attrName + '"!!');
- case S_TAG_SPACE:
- s = S_ATTR;
- start2 = p;
- break;
- case S_EQ:
- s = S_ATTR_NOQUOT_VALUE;
- start2 = p;
- break;
- case S_TAG_CLOSE:
- throw new Error("elements closed character '/' and '>' must be connected to");
- }
- }
- }
- p++;
- }
- }
- function appendElement$1(el, domBuilder, currentNSMap) {
- var tagName = el.tagName;
- var localNSMap = null;
- var i2 = el.length;
- while (i2--) {
- var a = el[i2];
- var qName = a.qName;
- var value = a.value;
- var nsp = qName.indexOf(":");
- if (nsp > 0) {
- var prefix = a.prefix = qName.slice(0, nsp);
- var localName = qName.slice(nsp + 1);
- var nsPrefix = prefix === "xmlns" && localName;
- } else {
- localName = qName;
- prefix = null;
- nsPrefix = qName === "xmlns" && "";
- }
- a.localName = localName;
- if (nsPrefix !== false) {
- if (localNSMap == null) {
- localNSMap = {};
- _copy(currentNSMap, currentNSMap = {});
- }
- currentNSMap[nsPrefix] = localNSMap[nsPrefix] = value;
- a.uri = NAMESPACE$1.XMLNS;
- domBuilder.startPrefixMapping(nsPrefix, value);
- }
- }
- var i2 = el.length;
- while (i2--) {
- a = el[i2];
- var prefix = a.prefix;
- if (prefix) {
- if (prefix === "xml") {
- a.uri = NAMESPACE$1.XML;
- }
- if (prefix !== "xmlns") {
- a.uri = currentNSMap[prefix || ""];
- }
- }
- }
- var nsp = tagName.indexOf(":");
- if (nsp > 0) {
- prefix = el.prefix = tagName.slice(0, nsp);
- localName = el.localName = tagName.slice(nsp + 1);
- } else {
- prefix = null;
- localName = el.localName = tagName;
- }
- var ns = el.uri = currentNSMap[prefix || ""];
- domBuilder.startElement(ns, localName, tagName, el);
- if (el.closed) {
- domBuilder.endElement(ns, localName, tagName);
- if (localNSMap) {
- for (prefix in localNSMap) {
- if (Object.prototype.hasOwnProperty.call(localNSMap, prefix)) {
- domBuilder.endPrefixMapping(prefix);
- }
- }
- }
- } else {
- el.currentNSMap = currentNSMap;
- el.localNSMap = localNSMap;
- return true;
- }
- }
- function parseHtmlSpecialContent(source, elStartEnd, tagName, entityReplacer, domBuilder) {
- if (/^(?:script|textarea)$/i.test(tagName)) {
- var elEndStart = source.indexOf("</" + tagName + ">", elStartEnd);
- var text = source.substring(elStartEnd + 1, elEndStart);
- if (/[&<]/.test(text)) {
- if (/^script$/i.test(tagName)) {
- domBuilder.characters(text, 0, text.length);
- return elEndStart;
- }
- text = text.replace(/&#?\w+;/g, entityReplacer);
- domBuilder.characters(text, 0, text.length);
- return elEndStart;
- }
- }
- return elStartEnd + 1;
- }
- function fixSelfClosed(source, elStartEnd, tagName, closeMap) {
- var pos = closeMap[tagName];
- if (pos == null) {
- pos = source.lastIndexOf("</" + tagName + ">");
- if (pos < elStartEnd) {
- pos = source.lastIndexOf("</" + tagName);
- }
- closeMap[tagName] = pos;
- }
- return pos < elStartEnd;
- }
- function _copy(source, target) {
- for (var n in source) {
- if (Object.prototype.hasOwnProperty.call(source, n)) {
- target[n] = source[n];
- }
- }
- }
- function parseDCC(source, start2, domBuilder, errorHandler) {
- var next = source.charAt(start2 + 2);
- switch (next) {
- case "-":
- if (source.charAt(start2 + 3) === "-") {
- var end = source.indexOf("-->", start2 + 4);
- if (end > start2) {
- domBuilder.comment(source, start2 + 4, end - start2 - 4);
- return end + 3;
- } else {
- errorHandler.error("Unclosed comment");
- return -1;
- }
- } else {
- return -1;
- }
- default:
- if (source.substr(start2 + 3, 6) == "CDATA[") {
- var end = source.indexOf("]]>", start2 + 9);
- domBuilder.startCDATA();
- domBuilder.characters(source, start2 + 9, end - start2 - 9);
- domBuilder.endCDATA();
- return end + 3;
- }
- var matchs = split(source, start2);
- var len = matchs.length;
- if (len > 1 && /!doctype/i.test(matchs[0][0])) {
- var name = matchs[1][0];
- var pubid = false;
- var sysid = false;
- if (len > 3) {
- if (/^public$/i.test(matchs[2][0])) {
- pubid = matchs[3][0];
- sysid = len > 4 && matchs[4][0];
- } else if (/^system$/i.test(matchs[2][0])) {
- sysid = matchs[3][0];
- }
- }
- var lastMatch = matchs[len - 1];
- domBuilder.startDTD(name, pubid, sysid);
- domBuilder.endDTD();
- return lastMatch.index + lastMatch[0].length;
- }
- }
- return -1;
- }
- function parseInstruction(source, start2, domBuilder) {
- var end = source.indexOf("?>", start2);
- if (end) {
- var match = source.substring(start2, end).match(/^<\?(\S*)\s*([\s\S]*?)\s*$/);
- if (match) {
- match[0].length;
- domBuilder.processingInstruction(match[1], match[2]);
- return end + 2;
- } else {
- return -1;
- }
- }
- return -1;
- }
- function ElementAttributes() {
- this.attributeNames = {};
- }
- ElementAttributes.prototype = {
- setTagName: function(tagName) {
- if (!tagNamePattern.test(tagName)) {
- throw new Error("invalid tagName:" + tagName);
- }
- this.tagName = tagName;
- },
- addValue: function(qName, value, offset) {
- if (!tagNamePattern.test(qName)) {
- throw new Error("invalid attribute:" + qName);
- }
- this.attributeNames[qName] = this.length;
- this[this.length++] = { qName, value, offset };
- },
- length: 0,
- getLocalName: function(i2) {
- return this[i2].localName;
- },
- getLocator: function(i2) {
- return this[i2].locator;
- },
- getQName: function(i2) {
- return this[i2].qName;
- },
- getURI: function(i2) {
- return this[i2].uri;
- },
- getValue: function(i2) {
- return this[i2].value;
- }
- };
- function split(source, start2) {
- var match;
- var buf = [];
- var reg = /'[^']+'|"[^"]+"|[^\s<>\/=]+=?|(\/?\s*>|<)/g;
- reg.lastIndex = start2;
- reg.exec(source);
- while (match = reg.exec(source)) {
- buf.push(match);
- if (match[1])
- return buf;
- }
- }
- sax$1.XMLReader = XMLReader$1;
- sax$1.ParseError = ParseError$1;
- var conventions = conventions$2;
- var dom = dom$1;
- var entities = entities$1;
- var sax = sax$1;
- var DOMImplementation = dom.DOMImplementation;
- var NAMESPACE = conventions.NAMESPACE;
- var ParseError = sax.ParseError;
- var XMLReader = sax.XMLReader;
- function normalizeLineEndings(input) {
- return input.replace(/\r[\n\u0085]/g, "\n").replace(/[\r\u0085\u2028]/g, "\n");
- }
- function DOMParser$1(options2) {
- this.options = options2 || { locator: {} };
- }
- DOMParser$1.prototype.parseFromString = function(source, mimeType) {
- var options2 = this.options;
- var sax2 = new XMLReader();
- var domBuilder = options2.domBuilder || new DOMHandler();
- var errorHandler = options2.errorHandler;
- var locator = options2.locator;
- var defaultNSMap = options2.xmlns || {};
- var isHTML = /\/x?html?$/.test(mimeType);
- var entityMap = isHTML ? entities.HTML_ENTITIES : entities.XML_ENTITIES;
- if (locator) {
- domBuilder.setDocumentLocator(locator);
- }
- sax2.errorHandler = buildErrorHandler(errorHandler, domBuilder, locator);
- sax2.domBuilder = options2.domBuilder || domBuilder;
- if (isHTML) {
- defaultNSMap[""] = NAMESPACE.HTML;
- }
- defaultNSMap.xml = defaultNSMap.xml || NAMESPACE.XML;
- var normalize = options2.normalizeLineEndings || normalizeLineEndings;
- if (source && typeof source === "string") {
- sax2.parse(
- normalize(source),
- defaultNSMap,
- entityMap
- );
- } else {
- sax2.errorHandler.error("invalid doc source");
- }
- return domBuilder.doc;
- };
- function buildErrorHandler(errorImpl, domBuilder, locator) {
- if (!errorImpl) {
- if (domBuilder instanceof DOMHandler) {
- return domBuilder;
- }
- errorImpl = domBuilder;
- }
- var errorHandler = {};
- var isCallback = errorImpl instanceof Function;
- locator = locator || {};
- function build(key) {
- var fn2 = errorImpl[key];
- if (!fn2 && isCallback) {
- fn2 = errorImpl.length == 2 ? function(msg) {
- errorImpl(key, msg);
- } : errorImpl;
- }
- errorHandler[key] = fn2 && function(msg) {
- fn2("[xmldom " + key + "] " + msg + _locator(locator));
- } || function() {
- };
- }
- build("warning");
- build("error");
- build("fatalError");
- return errorHandler;
- }
- function DOMHandler() {
- this.cdata = false;
- }
- function position(locator, node) {
- node.lineNumber = locator.lineNumber;
- node.columnNumber = locator.columnNumber;
- }
- DOMHandler.prototype = {
- startDocument: function() {
- this.doc = new DOMImplementation().createDocument(null, null, null);
- if (this.locator) {
- this.doc.documentURI = this.locator.systemId;
- }
- },
- startElement: function(namespaceURI, localName, qName, attrs) {
- var doc = this.doc;
- var el = doc.createElementNS(namespaceURI, qName || localName);
- var len = attrs.length;
- appendElement(this, el);
- this.currentElement = el;
- this.locator && position(this.locator, el);
- for (var i2 = 0; i2 < len; i2++) {
- var namespaceURI = attrs.getURI(i2);
- var value = attrs.getValue(i2);
- var qName = attrs.getQName(i2);
- var attr = doc.createAttributeNS(namespaceURI, qName);
- this.locator && position(attrs.getLocator(i2), attr);
- attr.value = attr.nodeValue = value;
- el.setAttributeNode(attr);
- }
- },
- endElement: function(namespaceURI, localName, qName) {
- var current = this.currentElement;
- current.tagName;
- this.currentElement = current.parentNode;
- },
- startPrefixMapping: function(prefix, uri) {
- },
- endPrefixMapping: function(prefix) {
- },
- processingInstruction: function(target, data) {
- var ins = this.doc.createProcessingInstruction(target, data);
- this.locator && position(this.locator, ins);
- appendElement(this, ins);
- },
- ignorableWhitespace: function(ch, start2, length) {
- },
- characters: function(chars, start2, length) {
- chars = _toString.apply(this, arguments);
- if (chars) {
- if (this.cdata) {
- var charNode = this.doc.createCDATASection(chars);
- } else {
- var charNode = this.doc.createTextNode(chars);
- }
- if (this.currentElement) {
- this.currentElement.appendChild(charNode);
- } else if (/^\s*$/.test(chars)) {
- this.doc.appendChild(charNode);
- }
- this.locator && position(this.locator, charNode);
- }
- },
- skippedEntity: function(name) {
- },
- endDocument: function() {
- this.doc.normalize();
- },
- setDocumentLocator: function(locator) {
- if (this.locator = locator) {
- locator.lineNumber = 0;
- }
- },
- comment: function(chars, start2, length) {
- chars = _toString.apply(this, arguments);
- var comm = this.doc.createComment(chars);
- this.locator && position(this.locator, comm);
- appendElement(this, comm);
- },
- startCDATA: function() {
- this.cdata = true;
- },
- endCDATA: function() {
- this.cdata = false;
- },
- startDTD: function(name, publicId, systemId) {
- var impl = this.doc.implementation;
- if (impl && impl.createDocumentType) {
- var dt2 = impl.createDocumentType(name, publicId, systemId);
- this.locator && position(this.locator, dt2);
- appendElement(this, dt2);
- this.doc.doctype = dt2;
- }
- },
- warning: function(error) {
- console.warn("[xmldom warning] " + error, _locator(this.locator));
- },
- error: function(error) {
- console.error("[xmldom error] " + error, _locator(this.locator));
- },
- fatalError: function(error) {
- throw new ParseError(error, this.locator);
- }
- };
- function _locator(l) {
- if (l) {
- return "\n@" + (l.systemId || "") + "#[line:" + l.lineNumber + ",col:" + l.columnNumber + "]";
- }
- }
- function _toString(chars, start2, length) {
- if (typeof chars == "string") {
- return chars.substr(start2, length);
- } else {
- if (chars.length >= start2 + length || start2) {
- return new java.lang.String(chars, start2, length) + "";
- }
- return chars;
- }
- }
- "endDTD,startEntity,endEntity,attributeDecl,elementDecl,externalEntityDecl,internalEntityDecl,resolveEntity,getExternalSubset,notationDecl,unparsedEntityDecl".replace(/\w+/g, function(key) {
- DOMHandler.prototype[key] = function() {
- return null;
- };
- });
- function appendElement(hander, node) {
- if (!hander.currentElement) {
- hander.doc.appendChild(node);
- } else {
- hander.currentElement.appendChild(node);
- }
- }
- domParser.__DOMHandler = DOMHandler;
- domParser.normalizeLineEndings = normalizeLineEndings;
- domParser.DOMParser = DOMParser$1;
- var DOMParser = domParser.DOMParser;
- /*! @name mpd-parser @version 1.1.1 @license Apache-2.0 */
- const isObject$3 = (obj) => {
- return !!obj && typeof obj === "object";
- };
- const merge$3 = (...objects) => {
- return objects.reduce((result, source) => {
- if (typeof source !== "object") {
- return result;
- }
- Object.keys(source).forEach((key) => {
- if (Array.isArray(result[key]) && Array.isArray(source[key])) {
- result[key] = result[key].concat(source[key]);
- } else if (isObject$3(result[key]) && isObject$3(source[key])) {
- result[key] = merge$3(result[key], source[key]);
- } else {
- result[key] = source[key];
- }
- });
- return result;
- }, {});
- };
- const values$1 = (o) => Object.keys(o).map((k) => o[k]);
- const range$1 = (start2, end) => {
- const result = [];
- for (let i2 = start2; i2 < end; i2++) {
- result.push(i2);
- }
- return result;
- };
- const flatten$1 = (lists) => lists.reduce((x, y) => x.concat(y), []);
- const from$1 = (list) => {
- if (!list.length) {
- return [];
- }
- const result = [];
- for (let i2 = 0; i2 < list.length; i2++) {
- result.push(list[i2]);
- }
- return result;
- };
- const findIndexes$1 = (l, key) => l.reduce((a, e, i2) => {
- if (e[key]) {
- a.push(i2);
- }
- return a;
- }, []);
- const union$1 = (lists, keyFunction) => {
- return values$1(lists.reduce((acc, list) => {
- list.forEach((el) => {
- acc[keyFunction(el)] = el;
- });
- return acc;
- }, {}));
- };
- var errors$1 = {
- INVALID_NUMBER_OF_PERIOD: "INVALID_NUMBER_OF_PERIOD",
- DASH_EMPTY_MANIFEST: "DASH_EMPTY_MANIFEST",
- DASH_INVALID_XML: "DASH_INVALID_XML",
- NO_BASE_URL: "NO_BASE_URL",
- MISSING_SEGMENT_INFORMATION: "MISSING_SEGMENT_INFORMATION",
- SEGMENT_TIME_UNSPECIFIED: "SEGMENT_TIME_UNSPECIFIED",
- UNSUPPORTED_UTC_TIMING_SCHEME: "UNSUPPORTED_UTC_TIMING_SCHEME"
- };
- const urlTypeToSegment$1 = ({
- baseUrl = "",
- source = "",
- range: range3 = "",
- indexRange = ""
- }) => {
- const segment = {
- uri: source,
- resolvedUri: resolveUrl$3(baseUrl || "", source)
- };
- if (range3 || indexRange) {
- const rangeStr = range3 ? range3 : indexRange;
- const ranges = rangeStr.split("-");
- let startRange = window_1.BigInt ? window_1.BigInt(ranges[0]) : parseInt(ranges[0], 10);
- let endRange = window_1.BigInt ? window_1.BigInt(ranges[1]) : parseInt(ranges[1], 10);
- if (startRange < Number.MAX_SAFE_INTEGER && typeof startRange === "bigint") {
- startRange = Number(startRange);
- }
- if (endRange < Number.MAX_SAFE_INTEGER && typeof endRange === "bigint") {
- endRange = Number(endRange);
- }
- let length;
- if (typeof endRange === "bigint" || typeof startRange === "bigint") {
- length = window_1.BigInt(endRange) - window_1.BigInt(startRange) + window_1.BigInt(1);
- } else {
- length = endRange - startRange + 1;
- }
- if (typeof length === "bigint" && length < Number.MAX_SAFE_INTEGER) {
- length = Number(length);
- }
- segment.byterange = {
- length,
- offset: startRange
- };
- }
- return segment;
- };
- const byteRangeToString$1 = (byterange) => {
- let endRange;
- if (typeof byterange.offset === "bigint" || typeof byterange.length === "bigint") {
- endRange = window_1.BigInt(byterange.offset) + window_1.BigInt(byterange.length) - window_1.BigInt(1);
- } else {
- endRange = byterange.offset + byterange.length - 1;
- }
- return `${byterange.offset}-${endRange}`;
- };
- const parseEndNumber$1 = (endNumber) => {
- if (endNumber && typeof endNumber !== "number") {
- endNumber = parseInt(endNumber, 10);
- }
- if (isNaN(endNumber)) {
- return null;
- }
- return endNumber;
- };
- const segmentRange$1 = {
- static(attributes) {
- const {
- duration: duration5,
- timescale: timescale2 = 1,
- sourceDuration,
- periodDuration
- } = attributes;
- const endNumber = parseEndNumber$1(attributes.endNumber);
- const segmentDuration = duration5 / timescale2;
- if (typeof endNumber === "number") {
- return {
- start: 0,
- end: endNumber
- };
- }
- if (typeof periodDuration === "number") {
- return {
- start: 0,
- end: periodDuration / segmentDuration
- };
- }
- return {
- start: 0,
- end: sourceDuration / segmentDuration
- };
- },
- dynamic(attributes) {
- const {
- NOW,
- clientOffset,
- availabilityStartTime: availabilityStartTime2,
- timescale: timescale2 = 1,
- duration: duration5,
- periodStart = 0,
- minimumUpdatePeriod: minimumUpdatePeriod2 = 0,
- timeShiftBufferDepth: timeShiftBufferDepth2 = Infinity
- } = attributes;
- const endNumber = parseEndNumber$1(attributes.endNumber);
- const now2 = (NOW + clientOffset) / 1e3;
- const periodStartWC = availabilityStartTime2 + periodStart;
- const periodEndWC = now2 + minimumUpdatePeriod2;
- const periodDuration = periodEndWC - periodStartWC;
- const segmentCount = Math.ceil(periodDuration * timescale2 / duration5);
- const availableStart = Math.floor((now2 - periodStartWC - timeShiftBufferDepth2) * timescale2 / duration5);
- const availableEnd = Math.floor((now2 - periodStartWC) * timescale2 / duration5);
- return {
- start: Math.max(0, availableStart),
- end: typeof endNumber === "number" ? endNumber : Math.min(segmentCount, availableEnd)
- };
- }
- };
- const toSegments$1 = (attributes) => (number) => {
- const {
- duration: duration5,
- timescale: timescale2 = 1,
- periodStart,
- startNumber: startNumber2 = 1
- } = attributes;
- return {
- number: startNumber2 + number,
- duration: duration5 / timescale2,
- timeline: periodStart,
- time: number * duration5
- };
- };
- const parseByDuration$1 = (attributes) => {
- const {
- type: type2,
- duration: duration5,
- timescale: timescale2 = 1,
- periodDuration,
- sourceDuration
- } = attributes;
- const {
- start: start2,
- end
- } = segmentRange$1[type2](attributes);
- const segments = range$1(start2, end).map(toSegments$1(attributes));
- if (type2 === "static") {
- const index2 = segments.length - 1;
- const sectionDuration = typeof periodDuration === "number" ? periodDuration : sourceDuration;
- segments[index2].duration = sectionDuration - duration5 / timescale2 * index2;
- }
- return segments;
- };
- const segmentsFromBase$1 = (attributes) => {
- const {
- baseUrl,
- initialization = {},
- sourceDuration,
- indexRange = "",
- periodStart,
- presentationTime,
- number = 0,
- duration: duration5
- } = attributes;
- if (!baseUrl) {
- throw new Error(errors$1.NO_BASE_URL);
- }
- const initSegment = urlTypeToSegment$1({
- baseUrl,
- source: initialization.sourceURL,
- range: initialization.range
- });
- const segment = urlTypeToSegment$1({
- baseUrl,
- source: baseUrl,
- indexRange
- });
- segment.map = initSegment;
- if (duration5) {
- const segmentTimeInfo = parseByDuration$1(attributes);
- if (segmentTimeInfo.length) {
- segment.duration = segmentTimeInfo[0].duration;
- segment.timeline = segmentTimeInfo[0].timeline;
- }
- } else if (sourceDuration) {
- segment.duration = sourceDuration;
- segment.timeline = periodStart;
- }
- segment.presentationTime = presentationTime || periodStart;
- segment.number = number;
- return [segment];
- };
- const addSidxSegmentsToPlaylist$1$1 = (playlist, sidx, baseUrl) => {
- const initSegment = playlist.sidx.map ? playlist.sidx.map : null;
- const sourceDuration = playlist.sidx.duration;
- const timeline = playlist.timeline || 0;
- const sidxByteRange = playlist.sidx.byterange;
- const sidxEnd = sidxByteRange.offset + sidxByteRange.length;
- const timescale2 = sidx.timescale;
- const mediaReferences = sidx.references.filter((r2) => r2.referenceType !== 1);
- const segments = [];
- const type2 = playlist.endList ? "static" : "dynamic";
- const periodStart = playlist.sidx.timeline;
- let presentationTime = periodStart;
- let number = playlist.mediaSequence || 0;
- let startIndex;
- if (typeof sidx.firstOffset === "bigint") {
- startIndex = window_1.BigInt(sidxEnd) + sidx.firstOffset;
- } else {
- startIndex = sidxEnd + sidx.firstOffset;
- }
- for (let i2 = 0; i2 < mediaReferences.length; i2++) {
- const reference = sidx.references[i2];
- const size = reference.referencedSize;
- const duration5 = reference.subsegmentDuration;
- let endIndex;
- if (typeof startIndex === "bigint") {
- endIndex = startIndex + window_1.BigInt(size) - window_1.BigInt(1);
- } else {
- endIndex = startIndex + size - 1;
- }
- const indexRange = `${startIndex}-${endIndex}`;
- const attributes = {
- baseUrl,
- timescale: timescale2,
- timeline,
- periodStart,
- presentationTime,
- number,
- duration: duration5,
- sourceDuration,
- indexRange,
- type: type2
- };
- const segment = segmentsFromBase$1(attributes)[0];
- if (initSegment) {
- segment.map = initSegment;
- }
- segments.push(segment);
- if (typeof startIndex === "bigint") {
- startIndex += window_1.BigInt(size);
- } else {
- startIndex += size;
- }
- presentationTime += duration5 / timescale2;
- number++;
- }
- playlist.segments = segments;
- return playlist;
- };
- const SUPPORTED_MEDIA_TYPES$1 = ["AUDIO", "SUBTITLES"];
- const TIME_FUDGE$1 = 1 / 60;
- const getUniqueTimelineStarts$1 = (timelineStarts) => {
- return union$1(timelineStarts, ({
- timeline
- }) => timeline).sort((a, b) => a.timeline > b.timeline ? 1 : -1);
- };
- const findPlaylistWithName$1 = (playlists, name) => {
- for (let i2 = 0; i2 < playlists.length; i2++) {
- if (playlists[i2].attributes.NAME === name) {
- return playlists[i2];
- }
- }
- return null;
- };
- const getMediaGroupPlaylists$1 = (manifest) => {
- let mediaGroupPlaylists = [];
- forEachMediaGroup$3(manifest, SUPPORTED_MEDIA_TYPES$1, (properties, type2, group, label2) => {
- mediaGroupPlaylists = mediaGroupPlaylists.concat(properties.playlists || []);
- });
- return mediaGroupPlaylists;
- };
- const updateMediaSequenceForPlaylist$1 = ({
- playlist,
- mediaSequence
- }) => {
- playlist.mediaSequence = mediaSequence;
- playlist.segments.forEach((segment, index2) => {
- segment.number = playlist.mediaSequence + index2;
- });
- };
- const updateSequenceNumbers$1 = ({
- oldPlaylists,
- newPlaylists,
- timelineStarts
- }) => {
- newPlaylists.forEach((playlist) => {
- playlist.discontinuitySequence = timelineStarts.findIndex(function({
- timeline
- }) {
- return timeline === playlist.timeline;
- });
- const oldPlaylist = findPlaylistWithName$1(oldPlaylists, playlist.attributes.NAME);
- if (!oldPlaylist) {
- return;
- }
- if (playlist.sidx) {
- return;
- }
- const firstNewSegment = playlist.segments[0];
- const oldMatchingSegmentIndex = oldPlaylist.segments.findIndex(function(oldSegment) {
- return Math.abs(oldSegment.presentationTime - firstNewSegment.presentationTime) < TIME_FUDGE$1;
- });
- if (oldMatchingSegmentIndex === -1) {
- updateMediaSequenceForPlaylist$1({
- playlist,
- mediaSequence: oldPlaylist.mediaSequence + oldPlaylist.segments.length
- });
- playlist.segments[0].discontinuity = true;
- playlist.discontinuityStarts.unshift(0);
- if (!oldPlaylist.segments.length && playlist.timeline > oldPlaylist.timeline || oldPlaylist.segments.length && playlist.timeline > oldPlaylist.segments[oldPlaylist.segments.length - 1].timeline) {
- playlist.discontinuitySequence--;
- }
- return;
- }
- const oldMatchingSegment = oldPlaylist.segments[oldMatchingSegmentIndex];
- if (oldMatchingSegment.discontinuity && !firstNewSegment.discontinuity) {
- firstNewSegment.discontinuity = true;
- playlist.discontinuityStarts.unshift(0);
- playlist.discontinuitySequence--;
- }
- updateMediaSequenceForPlaylist$1({
- playlist,
- mediaSequence: oldPlaylist.segments[oldMatchingSegmentIndex].number
- });
- });
- };
- const positionManifestOnTimeline$1 = ({
- oldManifest,
- newManifest
- }) => {
- const oldPlaylists = oldManifest.playlists.concat(getMediaGroupPlaylists$1(oldManifest));
- const newPlaylists = newManifest.playlists.concat(getMediaGroupPlaylists$1(newManifest));
- newManifest.timelineStarts = getUniqueTimelineStarts$1([oldManifest.timelineStarts, newManifest.timelineStarts]);
- updateSequenceNumbers$1({
- oldPlaylists,
- newPlaylists,
- timelineStarts: newManifest.timelineStarts
- });
- return newManifest;
- };
- const generateSidxKey$1 = (sidx) => sidx && sidx.uri + "-" + byteRangeToString$1(sidx.byterange);
- const mergeDiscontiguousPlaylists$1 = (playlists) => {
- const mergedPlaylists = values$1(playlists.reduce((acc, playlist) => {
- const name = playlist.attributes.id + (playlist.attributes.lang || "");
- if (!acc[name]) {
- acc[name] = playlist;
- acc[name].attributes.timelineStarts = [];
- } else {
- if (playlist.segments) {
- if (playlist.segments[0]) {
- playlist.segments[0].discontinuity = true;
- }
- acc[name].segments.push(...playlist.segments);
- }
- if (playlist.attributes.contentProtection) {
- acc[name].attributes.contentProtection = playlist.attributes.contentProtection;
- }
- }
- acc[name].attributes.timelineStarts.push({
- start: playlist.attributes.periodStart,
- timeline: playlist.attributes.periodStart
- });
- return acc;
- }, {}));
- return mergedPlaylists.map((playlist) => {
- playlist.discontinuityStarts = findIndexes$1(playlist.segments || [], "discontinuity");
- return playlist;
- });
- };
- const addSidxSegmentsToPlaylist$2 = (playlist, sidxMapping) => {
- const sidxKey = generateSidxKey$1(playlist.sidx);
- const sidxMatch = sidxKey && sidxMapping[sidxKey] && sidxMapping[sidxKey].sidx;
- if (sidxMatch) {
- addSidxSegmentsToPlaylist$1$1(playlist, sidxMatch, playlist.sidx.resolvedUri);
- }
- return playlist;
- };
- const addSidxSegmentsToPlaylists$1 = (playlists, sidxMapping = {}) => {
- if (!Object.keys(sidxMapping).length) {
- return playlists;
- }
- for (const i2 in playlists) {
- playlists[i2] = addSidxSegmentsToPlaylist$2(playlists[i2], sidxMapping);
- }
- return playlists;
- };
- const formatAudioPlaylist$1 = ({
- attributes,
- segments,
- sidx,
- mediaSequence,
- discontinuitySequence,
- discontinuityStarts
- }, isAudioOnly3) => {
- const playlist = {
- attributes: {
- NAME: attributes.id,
- BANDWIDTH: attributes.bandwidth,
- CODECS: attributes.codecs,
- ["PROGRAM-ID"]: 1
- },
- uri: "",
- endList: attributes.type === "static",
- timeline: attributes.periodStart,
- resolvedUri: "",
- targetDuration: attributes.duration,
- discontinuitySequence,
- discontinuityStarts,
- timelineStarts: attributes.timelineStarts,
- mediaSequence,
- segments
- };
- if (attributes.contentProtection) {
- playlist.contentProtection = attributes.contentProtection;
- }
- if (sidx) {
- playlist.sidx = sidx;
- }
- if (isAudioOnly3) {
- playlist.attributes.AUDIO = "audio";
- playlist.attributes.SUBTITLES = "subs";
- }
- return playlist;
- };
- const formatVttPlaylist$1 = ({
- attributes,
- segments,
- mediaSequence,
- discontinuityStarts,
- discontinuitySequence
- }) => {
- if (typeof segments === "undefined") {
- segments = [{
- uri: attributes.baseUrl,
- timeline: attributes.periodStart,
- resolvedUri: attributes.baseUrl || "",
- duration: attributes.sourceDuration,
- number: 0
- }];
- attributes.duration = attributes.sourceDuration;
- }
- const m3u8Attributes = {
- NAME: attributes.id,
- BANDWIDTH: attributes.bandwidth,
- ["PROGRAM-ID"]: 1
- };
- if (attributes.codecs) {
- m3u8Attributes.CODECS = attributes.codecs;
- }
- return {
- attributes: m3u8Attributes,
- uri: "",
- endList: attributes.type === "static",
- timeline: attributes.periodStart,
- resolvedUri: attributes.baseUrl || "",
- targetDuration: attributes.duration,
- timelineStarts: attributes.timelineStarts,
- discontinuityStarts,
- discontinuitySequence,
- mediaSequence,
- segments
- };
- };
- const organizeAudioPlaylists$1 = (playlists, sidxMapping = {}, isAudioOnly3 = false) => {
- let mainPlaylist;
- const formattedPlaylists = playlists.reduce((a, playlist) => {
- const role = playlist.attributes.role && playlist.attributes.role.value || "";
- const language = playlist.attributes.lang || "";
- let label2 = playlist.attributes.label || "main";
- if (language && !playlist.attributes.label) {
- const roleLabel = role ? ` (${role})` : "";
- label2 = `${playlist.attributes.lang}${roleLabel}`;
- }
- if (!a[label2]) {
- a[label2] = {
- language,
- autoselect: true,
- default: role === "main",
- playlists: [],
- uri: ""
- };
- }
- const formatted = addSidxSegmentsToPlaylist$2(formatAudioPlaylist$1(playlist, isAudioOnly3), sidxMapping);
- a[label2].playlists.push(formatted);
- if (typeof mainPlaylist === "undefined" && role === "main") {
- mainPlaylist = playlist;
- mainPlaylist.default = true;
- }
- return a;
- }, {});
- if (!mainPlaylist) {
- const firstLabel = Object.keys(formattedPlaylists)[0];
- formattedPlaylists[firstLabel].default = true;
- }
- return formattedPlaylists;
- };
- const organizeVttPlaylists$1 = (playlists, sidxMapping = {}) => {
- return playlists.reduce((a, playlist) => {
- const label2 = playlist.attributes.label || playlist.attributes.lang || "text";
- if (!a[label2]) {
- a[label2] = {
- language: label2,
- default: false,
- autoselect: false,
- playlists: [],
- uri: ""
- };
- }
- a[label2].playlists.push(addSidxSegmentsToPlaylist$2(formatVttPlaylist$1(playlist), sidxMapping));
- return a;
- }, {});
- };
- const organizeCaptionServices$1 = (captionServices) => captionServices.reduce((svcObj, svc) => {
- if (!svc) {
- return svcObj;
- }
- svc.forEach((service) => {
- const {
- channel,
- language
- } = service;
- svcObj[language] = {
- autoselect: false,
- default: false,
- instreamId: channel,
- language
- };
- if (service.hasOwnProperty("aspectRatio")) {
- svcObj[language].aspectRatio = service.aspectRatio;
- }
- if (service.hasOwnProperty("easyReader")) {
- svcObj[language].easyReader = service.easyReader;
- }
- if (service.hasOwnProperty("3D")) {
- svcObj[language]["3D"] = service["3D"];
- }
- });
- return svcObj;
- }, {});
- const formatVideoPlaylist$1 = ({
- attributes,
- segments,
- sidx,
- discontinuityStarts
- }) => {
- const playlist = {
- attributes: {
- NAME: attributes.id,
- AUDIO: "audio",
- SUBTITLES: "subs",
- RESOLUTION: {
- width: attributes.width,
- height: attributes.height
- },
- CODECS: attributes.codecs,
- BANDWIDTH: attributes.bandwidth,
- ["PROGRAM-ID"]: 1
- },
- uri: "",
- endList: attributes.type === "static",
- timeline: attributes.periodStart,
- resolvedUri: "",
- targetDuration: attributes.duration,
- discontinuityStarts,
- timelineStarts: attributes.timelineStarts,
- segments
- };
- if (attributes.frameRate) {
- playlist.attributes["FRAME-RATE"] = attributes.frameRate;
- }
- if (attributes.contentProtection) {
- playlist.contentProtection = attributes.contentProtection;
- }
- if (sidx) {
- playlist.sidx = sidx;
- }
- return playlist;
- };
- const videoOnly$1 = ({
- attributes
- }) => attributes.mimeType === "video/mp4" || attributes.mimeType === "video/webm" || attributes.contentType === "video";
- const audioOnly$1 = ({
- attributes
- }) => attributes.mimeType === "audio/mp4" || attributes.mimeType === "audio/webm" || attributes.contentType === "audio";
- const vttOnly$1 = ({
- attributes
- }) => attributes.mimeType === "text/vtt" || attributes.contentType === "text";
- const addMediaSequenceValues$1 = (playlists, timelineStarts) => {
- playlists.forEach((playlist) => {
- playlist.mediaSequence = 0;
- playlist.discontinuitySequence = timelineStarts.findIndex(function({
- timeline
- }) {
- return timeline === playlist.timeline;
- });
- if (!playlist.segments) {
- return;
- }
- playlist.segments.forEach((segment, index2) => {
- segment.number = index2;
- });
- });
- };
- const flattenMediaGroupPlaylists$1 = (mediaGroupObject) => {
- if (!mediaGroupObject) {
- return [];
- }
- return Object.keys(mediaGroupObject).reduce((acc, label2) => {
- const labelContents = mediaGroupObject[label2];
- return acc.concat(labelContents.playlists);
- }, []);
- };
- const toM3u8$1 = ({
- dashPlaylists,
- locations,
- sidxMapping = {},
- previousManifest,
- eventStream
- }) => {
- if (!dashPlaylists.length) {
- return {};
- }
- const {
- sourceDuration: duration5,
- type: type2,
- suggestedPresentationDelay: suggestedPresentationDelay2,
- minimumUpdatePeriod: minimumUpdatePeriod2
- } = dashPlaylists[0].attributes;
- const videoPlaylists = mergeDiscontiguousPlaylists$1(dashPlaylists.filter(videoOnly$1)).map(formatVideoPlaylist$1);
- const audioPlaylists = mergeDiscontiguousPlaylists$1(dashPlaylists.filter(audioOnly$1));
- const vttPlaylists = mergeDiscontiguousPlaylists$1(dashPlaylists.filter(vttOnly$1));
- const captions = dashPlaylists.map((playlist) => playlist.attributes.captionServices).filter(Boolean);
- const manifest = {
- allowCache: true,
- discontinuityStarts: [],
- segments: [],
- endList: true,
- mediaGroups: {
- AUDIO: {},
- VIDEO: {},
- ["CLOSED-CAPTIONS"]: {},
- SUBTITLES: {}
- },
- uri: "",
- duration: duration5,
- playlists: addSidxSegmentsToPlaylists$1(videoPlaylists, sidxMapping)
- };
- if (minimumUpdatePeriod2 >= 0) {
- manifest.minimumUpdatePeriod = minimumUpdatePeriod2 * 1e3;
- }
- if (locations) {
- manifest.locations = locations;
- }
- if (type2 === "dynamic") {
- manifest.suggestedPresentationDelay = suggestedPresentationDelay2;
- }
- if (eventStream && eventStream.length > 0) {
- manifest.eventStream = eventStream;
- }
- const isAudioOnly3 = manifest.playlists.length === 0;
- const organizedAudioGroup = audioPlaylists.length ? organizeAudioPlaylists$1(audioPlaylists, sidxMapping, isAudioOnly3) : null;
- const organizedVttGroup = vttPlaylists.length ? organizeVttPlaylists$1(vttPlaylists, sidxMapping) : null;
- const formattedPlaylists = videoPlaylists.concat(flattenMediaGroupPlaylists$1(organizedAudioGroup), flattenMediaGroupPlaylists$1(organizedVttGroup));
- const playlistTimelineStarts = formattedPlaylists.map(({
- timelineStarts
- }) => timelineStarts);
- manifest.timelineStarts = getUniqueTimelineStarts$1(playlistTimelineStarts);
- addMediaSequenceValues$1(formattedPlaylists, manifest.timelineStarts);
- if (organizedAudioGroup) {
- manifest.mediaGroups.AUDIO.audio = organizedAudioGroup;
- }
- if (organizedVttGroup) {
- manifest.mediaGroups.SUBTITLES.subs = organizedVttGroup;
- }
- if (captions.length) {
- manifest.mediaGroups["CLOSED-CAPTIONS"].cc = organizeCaptionServices$1(captions);
- }
- if (previousManifest) {
- return positionManifestOnTimeline$1({
- oldManifest: previousManifest,
- newManifest: manifest
- });
- }
- return manifest;
- };
- const getLiveRValue$1 = (attributes, time, duration5) => {
- const {
- NOW,
- clientOffset,
- availabilityStartTime: availabilityStartTime2,
- timescale: timescale2 = 1,
- periodStart = 0,
- minimumUpdatePeriod: minimumUpdatePeriod2 = 0
- } = attributes;
- const now2 = (NOW + clientOffset) / 1e3;
- const periodStartWC = availabilityStartTime2 + periodStart;
- const periodEndWC = now2 + minimumUpdatePeriod2;
- const periodDuration = periodEndWC - periodStartWC;
- return Math.ceil((periodDuration * timescale2 - time) / duration5);
- };
- const parseByTimeline$1 = (attributes, segmentTimeline) => {
- const {
- type: type2,
- minimumUpdatePeriod: minimumUpdatePeriod2 = 0,
- media = "",
- sourceDuration,
- timescale: timescale2 = 1,
- startNumber: startNumber2 = 1,
- periodStart: timeline
- } = attributes;
- const segments = [];
- let time = -1;
- for (let sIndex = 0; sIndex < segmentTimeline.length; sIndex++) {
- const S = segmentTimeline[sIndex];
- const duration5 = S.d;
- const repeat = S.r || 0;
- const segmentTime = S.t || 0;
- if (time < 0) {
- time = segmentTime;
- }
- if (segmentTime && segmentTime > time) {
- time = segmentTime;
- }
- let count;
- if (repeat < 0) {
- const nextS = sIndex + 1;
- if (nextS === segmentTimeline.length) {
- if (type2 === "dynamic" && minimumUpdatePeriod2 > 0 && media.indexOf("$Number$") > 0) {
- count = getLiveRValue$1(attributes, time, duration5);
- } else {
- count = (sourceDuration * timescale2 - time) / duration5;
- }
- } else {
- count = (segmentTimeline[nextS].t - time) / duration5;
- }
- } else {
- count = repeat + 1;
- }
- const end = startNumber2 + segments.length + count;
- let number = startNumber2 + segments.length;
- while (number < end) {
- segments.push({
- number,
- duration: duration5 / timescale2,
- time,
- timeline
- });
- time += duration5;
- number++;
- }
- }
- return segments;
- };
- const identifierPattern$1 = /\$([A-z]*)(?:(%0)([0-9]+)d)?\$/g;
- const identifierReplacement$1 = (values3) => (match, identifier, format, width2) => {
- if (match === "$$") {
- return "$";
- }
- if (typeof values3[identifier] === "undefined") {
- return match;
- }
- const value = "" + values3[identifier];
- if (identifier === "RepresentationID") {
- return value;
- }
- if (!format) {
- width2 = 1;
- } else {
- width2 = parseInt(width2, 10);
- }
- if (value.length >= width2) {
- return value;
- }
- return `${new Array(width2 - value.length + 1).join("0")}${value}`;
- };
- const constructTemplateUrl$1 = (url, values3) => url.replace(identifierPattern$1, identifierReplacement$1(values3));
- const parseTemplateInfo$1 = (attributes, segmentTimeline) => {
- if (!attributes.duration && !segmentTimeline) {
- return [{
- number: attributes.startNumber || 1,
- duration: attributes.sourceDuration,
- time: 0,
- timeline: attributes.periodStart
- }];
- }
- if (attributes.duration) {
- return parseByDuration$1(attributes);
- }
- return parseByTimeline$1(attributes, segmentTimeline);
- };
- const segmentsFromTemplate$1 = (attributes, segmentTimeline) => {
- const templateValues = {
- RepresentationID: attributes.id,
- Bandwidth: attributes.bandwidth || 0
- };
- const {
- initialization = {
- sourceURL: "",
- range: ""
- }
- } = attributes;
- const mapSegment = urlTypeToSegment$1({
- baseUrl: attributes.baseUrl,
- source: constructTemplateUrl$1(initialization.sourceURL, templateValues),
- range: initialization.range
- });
- const segments = parseTemplateInfo$1(attributes, segmentTimeline);
- return segments.map((segment) => {
- templateValues.Number = segment.number;
- templateValues.Time = segment.time;
- const uri = constructTemplateUrl$1(attributes.media || "", templateValues);
- const timescale2 = attributes.timescale || 1;
- const presentationTimeOffset2 = attributes.presentationTimeOffset || 0;
- const presentationTime = attributes.periodStart + (segment.time - presentationTimeOffset2) / timescale2;
- const map = {
- uri,
- timeline: segment.timeline,
- duration: segment.duration,
- resolvedUri: resolveUrl$3(attributes.baseUrl || "", uri),
- map: mapSegment,
- number: segment.number,
- presentationTime
- };
- return map;
- });
- };
- const SegmentURLToSegmentObject$1 = (attributes, segmentUrl) => {
- const {
- baseUrl,
- initialization = {}
- } = attributes;
- const initSegment = urlTypeToSegment$1({
- baseUrl,
- source: initialization.sourceURL,
- range: initialization.range
- });
- const segment = urlTypeToSegment$1({
- baseUrl,
- source: segmentUrl.media,
- range: segmentUrl.mediaRange
- });
- segment.map = initSegment;
- return segment;
- };
- const segmentsFromList$1 = (attributes, segmentTimeline) => {
- const {
- duration: duration5,
- segmentUrls = [],
- periodStart
- } = attributes;
- if (!duration5 && !segmentTimeline || duration5 && segmentTimeline) {
- throw new Error(errors$1.SEGMENT_TIME_UNSPECIFIED);
- }
- const segmentUrlMap = segmentUrls.map((segmentUrlObject) => SegmentURLToSegmentObject$1(attributes, segmentUrlObject));
- let segmentTimeInfo;
- if (duration5) {
- segmentTimeInfo = parseByDuration$1(attributes);
- }
- if (segmentTimeline) {
- segmentTimeInfo = parseByTimeline$1(attributes, segmentTimeline);
- }
- const segments = segmentTimeInfo.map((segmentTime, index2) => {
- if (segmentUrlMap[index2]) {
- const segment = segmentUrlMap[index2];
- const timescale2 = attributes.timescale || 1;
- const presentationTimeOffset2 = attributes.presentationTimeOffset || 0;
- segment.timeline = segmentTime.timeline;
- segment.duration = segmentTime.duration;
- segment.number = segmentTime.number;
- segment.presentationTime = periodStart + (segmentTime.time - presentationTimeOffset2) / timescale2;
- return segment;
- }
- }).filter((segment) => segment);
- return segments;
- };
- const generateSegments$1 = ({
- attributes,
- segmentInfo
- }) => {
- let segmentAttributes;
- let segmentsFn;
- if (segmentInfo.template) {
- segmentsFn = segmentsFromTemplate$1;
- segmentAttributes = merge$3(attributes, segmentInfo.template);
- } else if (segmentInfo.base) {
- segmentsFn = segmentsFromBase$1;
- segmentAttributes = merge$3(attributes, segmentInfo.base);
- } else if (segmentInfo.list) {
- segmentsFn = segmentsFromList$1;
- segmentAttributes = merge$3(attributes, segmentInfo.list);
- }
- const segmentsInfo = {
- attributes
- };
- if (!segmentsFn) {
- return segmentsInfo;
- }
- const segments = segmentsFn(segmentAttributes, segmentInfo.segmentTimeline);
- if (segmentAttributes.duration) {
- const {
- duration: duration5,
- timescale: timescale2 = 1
- } = segmentAttributes;
- segmentAttributes.duration = duration5 / timescale2;
- } else if (segments.length) {
- segmentAttributes.duration = segments.reduce((max2, segment) => {
- return Math.max(max2, Math.ceil(segment.duration));
- }, 0);
- } else {
- segmentAttributes.duration = 0;
- }
- segmentsInfo.attributes = segmentAttributes;
- segmentsInfo.segments = segments;
- if (segmentInfo.base && segmentAttributes.indexRange) {
- segmentsInfo.sidx = segments[0];
- segmentsInfo.segments = [];
- }
- return segmentsInfo;
- };
- const toPlaylists$1 = (representations) => representations.map(generateSegments$1);
- const findChildren$1 = (element, name) => from$1(element.childNodes).filter(({
- tagName
- }) => tagName === name);
- const getContent$1 = (element) => element.textContent.trim();
- const parseDivisionValue$1 = (value) => {
- return parseFloat(value.split("/").reduce((prev, current) => prev / current));
- };
- const parseDuration$1 = (str) => {
- const SECONDS_IN_YEAR = 365 * 24 * 60 * 60;
- const SECONDS_IN_MONTH = 30 * 24 * 60 * 60;
- const SECONDS_IN_DAY = 24 * 60 * 60;
- const SECONDS_IN_HOUR = 60 * 60;
- const SECONDS_IN_MIN = 60;
- const durationRegex = /P(?:(\d*)Y)?(?:(\d*)M)?(?:(\d*)D)?(?:T(?:(\d*)H)?(?:(\d*)M)?(?:([\d.]*)S)?)?/;
- const match = durationRegex.exec(str);
- if (!match) {
- return 0;
- }
- const [year, month, day, hour, minute, second] = match.slice(1);
- return parseFloat(year || 0) * SECONDS_IN_YEAR + parseFloat(month || 0) * SECONDS_IN_MONTH + parseFloat(day || 0) * SECONDS_IN_DAY + parseFloat(hour || 0) * SECONDS_IN_HOUR + parseFloat(minute || 0) * SECONDS_IN_MIN + parseFloat(second || 0);
- };
- const parseDate$1 = (str) => {
- const dateRegex = /^\d+-\d+-\d+T\d+:\d+:\d+(\.\d+)?$/;
- if (dateRegex.test(str)) {
- str += "Z";
- }
- return Date.parse(str);
- };
- const parsers$1 = {
- mediaPresentationDuration(value) {
- return parseDuration$1(value);
- },
- availabilityStartTime(value) {
- return parseDate$1(value) / 1e3;
- },
- minimumUpdatePeriod(value) {
- return parseDuration$1(value);
- },
- suggestedPresentationDelay(value) {
- return parseDuration$1(value);
- },
- type(value) {
- return value;
- },
- timeShiftBufferDepth(value) {
- return parseDuration$1(value);
- },
- start(value) {
- return parseDuration$1(value);
- },
- width(value) {
- return parseInt(value, 10);
- },
- height(value) {
- return parseInt(value, 10);
- },
- bandwidth(value) {
- return parseInt(value, 10);
- },
- frameRate(value) {
- return parseDivisionValue$1(value);
- },
- startNumber(value) {
- return parseInt(value, 10);
- },
- timescale(value) {
- return parseInt(value, 10);
- },
- presentationTimeOffset(value) {
- return parseInt(value, 10);
- },
- duration(value) {
- const parsedValue = parseInt(value, 10);
- if (isNaN(parsedValue)) {
- return parseDuration$1(value);
- }
- return parsedValue;
- },
- d(value) {
- return parseInt(value, 10);
- },
- t(value) {
- return parseInt(value, 10);
- },
- r(value) {
- return parseInt(value, 10);
- },
- presentationTime(value) {
- return parseInt(value, 10);
- },
- DEFAULT(value) {
- return value;
- }
- };
- const parseAttributes$2 = (el) => {
- if (!(el && el.attributes)) {
- return {};
- }
- return from$1(el.attributes).reduce((a, e) => {
- const parseFn = parsers$1[e.name] || parsers$1.DEFAULT;
- a[e.name] = parseFn(e.value);
- return a;
- }, {});
- };
- const keySystemsMap$1 = {
- "urn:uuid:1077efec-c0b2-4d02-ace3-3c1e52e2fb4b": "org.w3.clearkey",
- "urn:uuid:edef8ba9-79d6-4ace-a3c8-27dcd51d21ed": "com.widevine.alpha",
- "urn:uuid:9a04f079-9840-4286-ab92-e65be0885f95": "com.microsoft.playready",
- "urn:uuid:f239e769-efa3-4850-9c16-a903c6932efb": "com.adobe.primetime"
- };
- const buildBaseUrls$1 = (referenceUrls, baseUrlElements) => {
- if (!baseUrlElements.length) {
- return referenceUrls;
- }
- return flatten$1(referenceUrls.map(function(reference) {
- return baseUrlElements.map(function(baseUrlElement) {
- return resolveUrl$3(reference, getContent$1(baseUrlElement));
- });
- }));
- };
- const getSegmentInformation$1 = (adaptationSet) => {
- const segmentTemplate = findChildren$1(adaptationSet, "SegmentTemplate")[0];
- const segmentList = findChildren$1(adaptationSet, "SegmentList")[0];
- const segmentUrls = segmentList && findChildren$1(segmentList, "SegmentURL").map((s) => merge$3({
- tag: "SegmentURL"
- }, parseAttributes$2(s)));
- const segmentBase = findChildren$1(adaptationSet, "SegmentBase")[0];
- const segmentTimelineParentNode = segmentList || segmentTemplate;
- const segmentTimeline = segmentTimelineParentNode && findChildren$1(segmentTimelineParentNode, "SegmentTimeline")[0];
- const segmentInitializationParentNode = segmentList || segmentBase || segmentTemplate;
- const segmentInitialization = segmentInitializationParentNode && findChildren$1(segmentInitializationParentNode, "Initialization")[0];
- const template = segmentTemplate && parseAttributes$2(segmentTemplate);
- if (template && segmentInitialization) {
- template.initialization = segmentInitialization && parseAttributes$2(segmentInitialization);
- } else if (template && template.initialization) {
- template.initialization = {
- sourceURL: template.initialization
- };
- }
- const segmentInfo = {
- template,
- segmentTimeline: segmentTimeline && findChildren$1(segmentTimeline, "S").map((s) => parseAttributes$2(s)),
- list: segmentList && merge$3(parseAttributes$2(segmentList), {
- segmentUrls,
- initialization: parseAttributes$2(segmentInitialization)
- }),
- base: segmentBase && merge$3(parseAttributes$2(segmentBase), {
- initialization: parseAttributes$2(segmentInitialization)
- })
- };
- Object.keys(segmentInfo).forEach((key) => {
- if (!segmentInfo[key]) {
- delete segmentInfo[key];
- }
- });
- return segmentInfo;
- };
- const inheritBaseUrls$1 = (adaptationSetAttributes, adaptationSetBaseUrls, adaptationSetSegmentInfo) => (representation) => {
- const repBaseUrlElements = findChildren$1(representation, "BaseURL");
- const repBaseUrls = buildBaseUrls$1(adaptationSetBaseUrls, repBaseUrlElements);
- const attributes = merge$3(adaptationSetAttributes, parseAttributes$2(representation));
- const representationSegmentInfo = getSegmentInformation$1(representation);
- return repBaseUrls.map((baseUrl) => {
- return {
- segmentInfo: merge$3(adaptationSetSegmentInfo, representationSegmentInfo),
- attributes: merge$3(attributes, {
- baseUrl
- })
- };
- });
- };
- const generateKeySystemInformation$1 = (contentProtectionNodes) => {
- return contentProtectionNodes.reduce((acc, node) => {
- const attributes = parseAttributes$2(node);
- if (attributes.schemeIdUri) {
- attributes.schemeIdUri = attributes.schemeIdUri.toLowerCase();
- }
- const keySystem = keySystemsMap$1[attributes.schemeIdUri];
- if (keySystem) {
- acc[keySystem] = {
- attributes
- };
- const psshNode = findChildren$1(node, "cenc:pssh")[0];
- if (psshNode) {
- const pssh = getContent$1(psshNode);
- acc[keySystem].pssh = pssh && decodeB64ToUint8Array$1(pssh);
- }
- }
- return acc;
- }, {});
- };
- const parseCaptionServiceMetadata$1 = (service) => {
- if (service.schemeIdUri === "urn:scte:dash:cc:cea-608:2015") {
- const values3 = typeof service.value !== "string" ? [] : service.value.split(";");
- return values3.map((value) => {
- let channel;
- let language;
- language = value;
- if (/^CC\d=/.test(value)) {
- [channel, language] = value.split("=");
- } else if (/^CC\d$/.test(value)) {
- channel = value;
- }
- return {
- channel,
- language
- };
- });
- } else if (service.schemeIdUri === "urn:scte:dash:cc:cea-708:2015") {
- const values3 = typeof service.value !== "string" ? [] : service.value.split(";");
- return values3.map((value) => {
- const flags = {
- "channel": void 0,
- "language": void 0,
- "aspectRatio": 1,
- "easyReader": 0,
- "3D": 0
- };
- if (/=/.test(value)) {
- const [channel, opts = ""] = value.split("=");
- flags.channel = channel;
- flags.language = value;
- opts.split(",").forEach((opt) => {
- const [name, val] = opt.split(":");
- if (name === "lang") {
- flags.language = val;
- } else if (name === "er") {
- flags.easyReader = Number(val);
- } else if (name === "war") {
- flags.aspectRatio = Number(val);
- } else if (name === "3D") {
- flags["3D"] = Number(val);
- }
- });
- } else {
- flags.language = value;
- }
- if (flags.channel) {
- flags.channel = "SERVICE" + flags.channel;
- }
- return flags;
- });
- }
- };
- const toEventStream = (period) => {
- return flatten$1(findChildren$1(period.node, "EventStream").map((eventStream) => {
- const eventStreamAttributes = parseAttributes$2(eventStream);
- const schemeIdUri = eventStreamAttributes.schemeIdUri;
- return findChildren$1(eventStream, "Event").map((event2) => {
- const eventAttributes = parseAttributes$2(event2);
- const presentationTime = eventAttributes.presentationTime || 0;
- const timescale2 = eventStreamAttributes.timescale || 1;
- const duration5 = eventAttributes.duration || 0;
- const start2 = presentationTime / timescale2 + period.attributes.start;
- return {
- schemeIdUri,
- value: eventStreamAttributes.value,
- id: eventAttributes.id,
- start: start2,
- end: start2 + duration5 / timescale2,
- messageData: getContent$1(event2) || eventAttributes.messageData,
- contentEncoding: eventStreamAttributes.contentEncoding,
- presentationTimeOffset: eventStreamAttributes.presentationTimeOffset || 0
- };
- });
- }));
- };
- const toRepresentations$1 = (periodAttributes, periodBaseUrls, periodSegmentInfo) => (adaptationSet) => {
- const adaptationSetAttributes = parseAttributes$2(adaptationSet);
- const adaptationSetBaseUrls = buildBaseUrls$1(periodBaseUrls, findChildren$1(adaptationSet, "BaseURL"));
- const role = findChildren$1(adaptationSet, "Role")[0];
- const roleAttributes = {
- role: parseAttributes$2(role)
- };
- let attrs = merge$3(periodAttributes, adaptationSetAttributes, roleAttributes);
- const accessibility = findChildren$1(adaptationSet, "Accessibility")[0];
- const captionServices = parseCaptionServiceMetadata$1(parseAttributes$2(accessibility));
- if (captionServices) {
- attrs = merge$3(attrs, {
- captionServices
- });
- }
- const label2 = findChildren$1(adaptationSet, "Label")[0];
- if (label2 && label2.childNodes.length) {
- const labelVal = label2.childNodes[0].nodeValue.trim();
- attrs = merge$3(attrs, {
- label: labelVal
- });
- }
- const contentProtection = generateKeySystemInformation$1(findChildren$1(adaptationSet, "ContentProtection"));
- if (Object.keys(contentProtection).length) {
- attrs = merge$3(attrs, {
- contentProtection
- });
- }
- const segmentInfo = getSegmentInformation$1(adaptationSet);
- const representations = findChildren$1(adaptationSet, "Representation");
- const adaptationSetSegmentInfo = merge$3(periodSegmentInfo, segmentInfo);
- return flatten$1(representations.map(inheritBaseUrls$1(attrs, adaptationSetBaseUrls, adaptationSetSegmentInfo)));
- };
- const toAdaptationSets$1 = (mpdAttributes, mpdBaseUrls) => (period, index2) => {
- const periodBaseUrls = buildBaseUrls$1(mpdBaseUrls, findChildren$1(period.node, "BaseURL"));
- const periodAttributes = merge$3(mpdAttributes, {
- periodStart: period.attributes.start
- });
- if (typeof period.attributes.duration === "number") {
- periodAttributes.periodDuration = period.attributes.duration;
- }
- const adaptationSets = findChildren$1(period.node, "AdaptationSet");
- const periodSegmentInfo = getSegmentInformation$1(period.node);
- return flatten$1(adaptationSets.map(toRepresentations$1(periodAttributes, periodBaseUrls, periodSegmentInfo)));
- };
- const getPeriodStart$1 = ({
- attributes,
- priorPeriodAttributes,
- mpdType
- }) => {
- if (typeof attributes.start === "number") {
- return attributes.start;
- }
- if (priorPeriodAttributes && typeof priorPeriodAttributes.start === "number" && typeof priorPeriodAttributes.duration === "number") {
- return priorPeriodAttributes.start + priorPeriodAttributes.duration;
- }
- if (!priorPeriodAttributes && mpdType === "static") {
- return 0;
- }
- return null;
- };
- const inheritAttributes$1 = (mpd, options2 = {}) => {
- const {
- manifestUri = "",
- NOW = Date.now(),
- clientOffset = 0
- } = options2;
- const periodNodes = findChildren$1(mpd, "Period");
- if (!periodNodes.length) {
- throw new Error(errors$1.INVALID_NUMBER_OF_PERIOD);
- }
- const locations = findChildren$1(mpd, "Location");
- const mpdAttributes = parseAttributes$2(mpd);
- const mpdBaseUrls = buildBaseUrls$1([manifestUri], findChildren$1(mpd, "BaseURL"));
- mpdAttributes.type = mpdAttributes.type || "static";
- mpdAttributes.sourceDuration = mpdAttributes.mediaPresentationDuration || 0;
- mpdAttributes.NOW = NOW;
- mpdAttributes.clientOffset = clientOffset;
- if (locations.length) {
- mpdAttributes.locations = locations.map(getContent$1);
- }
- const periods = [];
- periodNodes.forEach((node, index2) => {
- const attributes = parseAttributes$2(node);
- const priorPeriod = periods[index2 - 1];
- attributes.start = getPeriodStart$1({
- attributes,
- priorPeriodAttributes: priorPeriod ? priorPeriod.attributes : null,
- mpdType: mpdAttributes.type
- });
- periods.push({
- node,
- attributes
- });
- });
- return {
- locations: mpdAttributes.locations,
- representationInfo: flatten$1(periods.map(toAdaptationSets$1(mpdAttributes, mpdBaseUrls))),
- eventStream: flatten$1(periods.map(toEventStream))
- };
- };
- const stringToMpdXml$1 = (manifestString) => {
- if (manifestString === "") {
- throw new Error(errors$1.DASH_EMPTY_MANIFEST);
- }
- const parser2 = new DOMParser();
- let xml;
- let mpd;
- try {
- xml = parser2.parseFromString(manifestString, "application/xml");
- mpd = xml && xml.documentElement.tagName === "MPD" ? xml.documentElement : null;
- } catch (e) {
- }
- if (!mpd || mpd && mpd.getElementsByTagName("parsererror").length > 0) {
- throw new Error(errors$1.DASH_INVALID_XML);
- }
- return mpd;
- };
- const parseUTCTimingScheme$1 = (mpd) => {
- const UTCTimingNode = findChildren$1(mpd, "UTCTiming")[0];
- if (!UTCTimingNode) {
- return null;
- }
- const attributes = parseAttributes$2(UTCTimingNode);
- switch (attributes.schemeIdUri) {
- case "urn:mpeg:dash:utc:http-head:2014":
- case "urn:mpeg:dash:utc:http-head:2012":
- attributes.method = "HEAD";
- break;
- case "urn:mpeg:dash:utc:http-xsdate:2014":
- case "urn:mpeg:dash:utc:http-iso:2014":
- case "urn:mpeg:dash:utc:http-xsdate:2012":
- case "urn:mpeg:dash:utc:http-iso:2012":
- attributes.method = "GET";
- break;
- case "urn:mpeg:dash:utc:direct:2014":
- case "urn:mpeg:dash:utc:direct:2012":
- attributes.method = "DIRECT";
- attributes.value = Date.parse(attributes.value);
- break;
- case "urn:mpeg:dash:utc:http-ntp:2014":
- case "urn:mpeg:dash:utc:ntp:2014":
- case "urn:mpeg:dash:utc:sntp:2014":
- default:
- throw new Error(errors$1.UNSUPPORTED_UTC_TIMING_SCHEME);
- }
- return attributes;
- };
- const parse$1 = (manifestString, options2 = {}) => {
- const parsedManifestInfo = inheritAttributes$1(stringToMpdXml$1(manifestString), options2);
- const playlists = toPlaylists$1(parsedManifestInfo.representationInfo);
- return toM3u8$1({
- dashPlaylists: playlists,
- locations: parsedManifestInfo.locations,
- sidxMapping: options2.sidxMapping,
- previousManifest: options2.previousManifest,
- eventStream: parsedManifestInfo.eventStream
- });
- };
- const parseUTCTiming$1 = (manifestString) => parseUTCTimingScheme$1(stringToMpdXml$1(manifestString));
- var MAX_UINT32$1 = Math.pow(2, 32);
- var getUint64$3 = function(uint8) {
- var dv = new DataView(uint8.buffer, uint8.byteOffset, uint8.byteLength);
- var value;
- if (dv.getBigUint64) {
- value = dv.getBigUint64(0);
- if (value < Number.MAX_SAFE_INTEGER) {
- return Number(value);
- }
- return value;
- }
- return dv.getUint32(0) * MAX_UINT32$1 + dv.getUint32(4);
- };
- var numbers$1 = {
- getUint64: getUint64$3,
- MAX_UINT32: MAX_UINT32$1
- };
- var getUint64$2 = numbers$1.getUint64;
- var parseSidx$1 = function(data) {
- var view = new DataView(data.buffer, data.byteOffset, data.byteLength), result = {
- version: data[0],
- flags: new Uint8Array(data.subarray(1, 4)),
- references: [],
- referenceId: view.getUint32(4),
- timescale: view.getUint32(8)
- }, i2 = 12;
- if (result.version === 0) {
- result.earliestPresentationTime = view.getUint32(i2);
- result.firstOffset = view.getUint32(i2 + 4);
- i2 += 8;
- } else {
- result.earliestPresentationTime = getUint64$2(data.subarray(i2));
- result.firstOffset = getUint64$2(data.subarray(i2 + 8));
- i2 += 16;
- }
- i2 += 2;
- var referenceCount = view.getUint16(i2);
- i2 += 2;
- for (; referenceCount > 0; i2 += 12, referenceCount--) {
- result.references.push({
- referenceType: (data[i2] & 128) >>> 7,
- referencedSize: view.getUint32(i2) & 2147483647,
- subsegmentDuration: view.getUint32(i2 + 4),
- startsWithSap: !!(data[i2 + 8] & 128),
- sapType: (data[i2 + 8] & 112) >>> 4,
- sapDeltaTime: view.getUint32(i2 + 8) & 268435455
- });
- }
- return result;
- };
- var parseSidx_1$1 = parseSidx$1;
- var ID3$1 = toUint8$1([73, 68, 51]);
- var getId3Size$1 = function getId3Size(bytes, offset) {
- if (offset === void 0) {
- offset = 0;
- }
- bytes = toUint8$1(bytes);
- var flags = bytes[offset + 5];
- var returnSize = bytes[offset + 6] << 21 | bytes[offset + 7] << 14 | bytes[offset + 8] << 7 | bytes[offset + 9];
- var footerPresent = (flags & 16) >> 4;
- if (footerPresent) {
- return returnSize + 20;
- }
- return returnSize + 10;
- };
- var getId3Offset$1 = function getId3Offset(bytes, offset) {
- if (offset === void 0) {
- offset = 0;
- }
- bytes = toUint8$1(bytes);
- if (bytes.length - offset < 10 || !bytesMatch$1(bytes, ID3$1, {
- offset
- })) {
- return offset;
- }
- offset += getId3Size$1(bytes, offset);
- return getId3Offset(bytes, offset);
- };
- var normalizePath$3 = function normalizePath(path) {
- if (typeof path === "string") {
- return stringToBytes$1(path);
- }
- if (typeof path === "number") {
- return path;
- }
- return path;
- };
- var normalizePaths$3 = function normalizePaths(paths) {
- if (!Array.isArray(paths)) {
- return [normalizePath$3(paths)];
- }
- return paths.map(function(p) {
- return normalizePath$3(p);
- });
- };
- var findBox$1 = function findBox(bytes, paths, complete) {
- if (complete === void 0) {
- complete = false;
- }
- paths = normalizePaths$3(paths);
- bytes = toUint8$1(bytes);
- var results = [];
- if (!paths.length) {
- return results;
- }
- var i2 = 0;
- while (i2 < bytes.length) {
- var size = (bytes[i2] << 24 | bytes[i2 + 1] << 16 | bytes[i2 + 2] << 8 | bytes[i2 + 3]) >>> 0;
- var type2 = bytes.subarray(i2 + 4, i2 + 8);
- if (size === 0) {
- break;
- }
- var end = i2 + size;
- if (end > bytes.length) {
- if (complete) {
- break;
- }
- end = bytes.length;
- }
- var data = bytes.subarray(i2 + 8, end);
- if (bytesMatch$1(type2, paths[0])) {
- if (paths.length === 1) {
- results.push(data);
- } else {
- results.push.apply(results, findBox(data, paths.slice(1), complete));
- }
- }
- i2 = end;
- }
- return results;
- };
- var EBML_TAGS$1 = {
- EBML: toUint8$1([26, 69, 223, 163]),
- DocType: toUint8$1([66, 130]),
- Segment: toUint8$1([24, 83, 128, 103]),
- SegmentInfo: toUint8$1([21, 73, 169, 102]),
- Tracks: toUint8$1([22, 84, 174, 107]),
- Track: toUint8$1([174]),
- TrackNumber: toUint8$1([215]),
- DefaultDuration: toUint8$1([35, 227, 131]),
- TrackEntry: toUint8$1([174]),
- TrackType: toUint8$1([131]),
- FlagDefault: toUint8$1([136]),
- CodecID: toUint8$1([134]),
- CodecPrivate: toUint8$1([99, 162]),
- VideoTrack: toUint8$1([224]),
- AudioTrack: toUint8$1([225]),
- Cluster: toUint8$1([31, 67, 182, 117]),
- Timestamp: toUint8$1([231]),
- TimestampScale: toUint8$1([42, 215, 177]),
- BlockGroup: toUint8$1([160]),
- BlockDuration: toUint8$1([155]),
- Block: toUint8$1([161]),
- SimpleBlock: toUint8$1([163])
- };
- var LENGTH_TABLE$1 = [128, 64, 32, 16, 8, 4, 2, 1];
- var getLength$1 = function getLength(byte) {
- var len = 1;
- for (var i2 = 0; i2 < LENGTH_TABLE$1.length; i2++) {
- if (byte & LENGTH_TABLE$1[i2]) {
- break;
- }
- len++;
- }
- return len;
- };
- var getvint$1 = function getvint(bytes, offset, removeLength, signed) {
- if (removeLength === void 0) {
- removeLength = true;
- }
- if (signed === void 0) {
- signed = false;
- }
- var length = getLength$1(bytes[offset]);
- var valueBytes = bytes.subarray(offset, offset + length);
- if (removeLength) {
- valueBytes = Array.prototype.slice.call(bytes, offset, offset + length);
- valueBytes[0] ^= LENGTH_TABLE$1[length - 1];
- }
- return {
- length,
- value: bytesToNumber$1(valueBytes, {
- signed
- }),
- bytes: valueBytes
- };
- };
- var normalizePath$2 = function normalizePath2(path) {
- if (typeof path === "string") {
- return path.match(/.{1,2}/g).map(function(p) {
- return normalizePath2(p);
- });
- }
- if (typeof path === "number") {
- return numberToBytes$1(path);
- }
- return path;
- };
- var normalizePaths$2 = function normalizePaths2(paths) {
- if (!Array.isArray(paths)) {
- return [normalizePath$2(paths)];
- }
- return paths.map(function(p) {
- return normalizePath$2(p);
- });
- };
- var getInfinityDataSize$1 = function getInfinityDataSize(id, bytes, offset) {
- if (offset >= bytes.length) {
- return bytes.length;
- }
- var innerid = getvint$1(bytes, offset, false);
- if (bytesMatch$1(id.bytes, innerid.bytes)) {
- return offset;
- }
- var dataHeader = getvint$1(bytes, offset + innerid.length);
- return getInfinityDataSize(id, bytes, offset + dataHeader.length + dataHeader.value + innerid.length);
- };
- var findEbml$1 = function findEbml(bytes, paths) {
- paths = normalizePaths$2(paths);
- bytes = toUint8$1(bytes);
- var results = [];
- if (!paths.length) {
- return results;
- }
- var i2 = 0;
- while (i2 < bytes.length) {
- var id = getvint$1(bytes, i2, false);
- var dataHeader = getvint$1(bytes, i2 + id.length);
- var dataStart = i2 + id.length + dataHeader.length;
- if (dataHeader.value === 127) {
- dataHeader.value = getInfinityDataSize$1(id, bytes, dataStart);
- if (dataHeader.value !== bytes.length) {
- dataHeader.value -= dataStart;
- }
- }
- var dataEnd = dataStart + dataHeader.value > bytes.length ? bytes.length : dataStart + dataHeader.value;
- var data = bytes.subarray(dataStart, dataEnd);
- if (bytesMatch$1(paths[0], id.bytes)) {
- if (paths.length === 1) {
- results.push(data);
- } else {
- results = results.concat(findEbml(data, paths.slice(1)));
- }
- }
- var totalLength = id.length + dataHeader.length + data.length;
- i2 += totalLength;
- }
- return results;
- };
- var NAL_TYPE_ONE$1 = toUint8$1([0, 0, 0, 1]);
- var NAL_TYPE_TWO$1 = toUint8$1([0, 0, 1]);
- var EMULATION_PREVENTION$1 = toUint8$1([0, 0, 3]);
- var discardEmulationPreventionBytes$1 = function discardEmulationPreventionBytes(bytes) {
- var positions = [];
- var i2 = 1;
- while (i2 < bytes.length - 2) {
- if (bytesMatch$1(bytes.subarray(i2, i2 + 3), EMULATION_PREVENTION$1)) {
- positions.push(i2 + 2);
- i2++;
- }
- i2++;
- }
- if (positions.length === 0) {
- return bytes;
- }
- var newLength = bytes.length - positions.length;
- var newData = new Uint8Array(newLength);
- var sourceIndex = 0;
- for (i2 = 0; i2 < newLength; sourceIndex++, i2++) {
- if (sourceIndex === positions[0]) {
- sourceIndex++;
- positions.shift();
- }
- newData[i2] = bytes[sourceIndex];
- }
- return newData;
- };
- var findNal$1 = function findNal(bytes, dataType, types, nalLimit) {
- if (nalLimit === void 0) {
- nalLimit = Infinity;
- }
- bytes = toUint8$1(bytes);
- types = [].concat(types);
- var i2 = 0;
- var nalStart;
- var nalsFound = 0;
- while (i2 < bytes.length && (nalsFound < nalLimit || nalStart)) {
- var nalOffset = void 0;
- if (bytesMatch$1(bytes.subarray(i2), NAL_TYPE_ONE$1)) {
- nalOffset = 4;
- } else if (bytesMatch$1(bytes.subarray(i2), NAL_TYPE_TWO$1)) {
- nalOffset = 3;
- }
- if (!nalOffset) {
- i2++;
- continue;
- }
- nalsFound++;
- if (nalStart) {
- return discardEmulationPreventionBytes$1(bytes.subarray(nalStart, i2));
- }
- var nalType = void 0;
- if (dataType === "h264") {
- nalType = bytes[i2 + nalOffset] & 31;
- } else if (dataType === "h265") {
- nalType = bytes[i2 + nalOffset] >> 1 & 63;
- }
- if (types.indexOf(nalType) !== -1) {
- nalStart = i2 + nalOffset;
- }
- i2 += nalOffset + (dataType === "h264" ? 1 : 2);
- }
- return bytes.subarray(0, 0);
- };
- var findH264Nal$1 = function findH264Nal(bytes, type2, nalLimit) {
- return findNal$1(bytes, "h264", type2, nalLimit);
- };
- var findH265Nal$1 = function findH265Nal(bytes, type2, nalLimit) {
- return findNal$1(bytes, "h265", type2, nalLimit);
- };
- var CONSTANTS$1 = {
- "webm": toUint8$1([119, 101, 98, 109]),
- "matroska": toUint8$1([109, 97, 116, 114, 111, 115, 107, 97]),
- "flac": toUint8$1([102, 76, 97, 67]),
- "ogg": toUint8$1([79, 103, 103, 83]),
- "ac3": toUint8$1([11, 119]),
- "riff": toUint8$1([82, 73, 70, 70]),
- "avi": toUint8$1([65, 86, 73]),
- "wav": toUint8$1([87, 65, 86, 69]),
- "3gp": toUint8$1([102, 116, 121, 112, 51, 103]),
- "mp4": toUint8$1([102, 116, 121, 112]),
- "fmp4": toUint8$1([115, 116, 121, 112]),
- "mov": toUint8$1([102, 116, 121, 112, 113, 116]),
- "moov": toUint8$1([109, 111, 111, 118]),
- "moof": toUint8$1([109, 111, 111, 102])
- };
- var _isLikely$1 = {
- aac: function aac(bytes) {
- var offset = getId3Offset$1(bytes);
- return bytesMatch$1(bytes, [255, 16], {
- offset,
- mask: [255, 22]
- });
- },
- mp3: function mp3(bytes) {
- var offset = getId3Offset$1(bytes);
- return bytesMatch$1(bytes, [255, 2], {
- offset,
- mask: [255, 6]
- });
- },
- webm: function webm(bytes) {
- var docType = findEbml$1(bytes, [EBML_TAGS$1.EBML, EBML_TAGS$1.DocType])[0];
- return bytesMatch$1(docType, CONSTANTS$1.webm);
- },
- mkv: function mkv(bytes) {
- var docType = findEbml$1(bytes, [EBML_TAGS$1.EBML, EBML_TAGS$1.DocType])[0];
- return bytesMatch$1(docType, CONSTANTS$1.matroska);
- },
- mp4: function mp4(bytes) {
- if (_isLikely$1["3gp"](bytes) || _isLikely$1.mov(bytes)) {
- return false;
- }
- if (bytesMatch$1(bytes, CONSTANTS$1.mp4, {
- offset: 4
- }) || bytesMatch$1(bytes, CONSTANTS$1.fmp4, {
- offset: 4
- })) {
- return true;
- }
- if (bytesMatch$1(bytes, CONSTANTS$1.moof, {
- offset: 4
- }) || bytesMatch$1(bytes, CONSTANTS$1.moov, {
- offset: 4
- })) {
- return true;
- }
- },
- mov: function mov(bytes) {
- return bytesMatch$1(bytes, CONSTANTS$1.mov, {
- offset: 4
- });
- },
- "3gp": function gp(bytes) {
- return bytesMatch$1(bytes, CONSTANTS$1["3gp"], {
- offset: 4
- });
- },
- ac3: function ac3(bytes) {
- var offset = getId3Offset$1(bytes);
- return bytesMatch$1(bytes, CONSTANTS$1.ac3, {
- offset
- });
- },
- ts: function ts(bytes) {
- if (bytes.length < 189 && bytes.length >= 1) {
- return bytes[0] === 71;
- }
- var i2 = 0;
- while (i2 + 188 < bytes.length && i2 < 188) {
- if (bytes[i2] === 71 && bytes[i2 + 188] === 71) {
- return true;
- }
- i2 += 1;
- }
- return false;
- },
- flac: function flac(bytes) {
- var offset = getId3Offset$1(bytes);
- return bytesMatch$1(bytes, CONSTANTS$1.flac, {
- offset
- });
- },
- ogg: function ogg(bytes) {
- return bytesMatch$1(bytes, CONSTANTS$1.ogg);
- },
- avi: function avi(bytes) {
- return bytesMatch$1(bytes, CONSTANTS$1.riff) && bytesMatch$1(bytes, CONSTANTS$1.avi, {
- offset: 8
- });
- },
- wav: function wav(bytes) {
- return bytesMatch$1(bytes, CONSTANTS$1.riff) && bytesMatch$1(bytes, CONSTANTS$1.wav, {
- offset: 8
- });
- },
- "h264": function h264(bytes) {
- return findH264Nal$1(bytes, 7, 3).length;
- },
- "h265": function h265(bytes) {
- return findH265Nal$1(bytes, [32, 33], 3).length;
- }
- };
- var isLikelyTypes$1 = Object.keys(_isLikely$1).filter(function(t2) {
- return t2 !== "ts" && t2 !== "h264" && t2 !== "h265";
- }).concat(["ts", "h264", "h265"]);
- isLikelyTypes$1.forEach(function(type2) {
- var isLikelyFn = _isLikely$1[type2];
- _isLikely$1[type2] = function(bytes) {
- return isLikelyFn(toUint8$1(bytes));
- };
- });
- var isLikely$1 = _isLikely$1;
- var detectContainerForBytes$1 = function detectContainerForBytes(bytes) {
- bytes = toUint8$1(bytes);
- for (var i2 = 0; i2 < isLikelyTypes$1.length; i2++) {
- var type2 = isLikelyTypes$1[i2];
- if (isLikely$1[type2](bytes)) {
- return type2;
- }
- }
- return "";
- };
- var isLikelyFmp4MediaSegment$1 = function isLikelyFmp4MediaSegment(bytes) {
- return findBox$1(bytes, ["moof"]).length > 0;
- };
- var ONE_SECOND_IN_TS$1 = 9e4, secondsToVideoTs$1, secondsToAudioTs$1, videoTsToSeconds$1, audioTsToSeconds$1, audioTsToVideoTs$1, videoTsToAudioTs$1, metadataTsToSeconds$1;
- secondsToVideoTs$1 = function(seconds) {
- return seconds * ONE_SECOND_IN_TS$1;
- };
- secondsToAudioTs$1 = function(seconds, sampleRate) {
- return seconds * sampleRate;
- };
- videoTsToSeconds$1 = function(timestamp) {
- return timestamp / ONE_SECOND_IN_TS$1;
- };
- audioTsToSeconds$1 = function(timestamp, sampleRate) {
- return timestamp / sampleRate;
- };
- audioTsToVideoTs$1 = function(timestamp, sampleRate) {
- return secondsToVideoTs$1(audioTsToSeconds$1(timestamp, sampleRate));
- };
- videoTsToAudioTs$1 = function(timestamp, sampleRate) {
- return secondsToAudioTs$1(videoTsToSeconds$1(timestamp), sampleRate);
- };
- metadataTsToSeconds$1 = function(timestamp, timelineStartPts, keepOriginalTimestamps) {
- return videoTsToSeconds$1(keepOriginalTimestamps ? timestamp : timestamp - timelineStartPts);
- };
- var clock$1 = {
- ONE_SECOND_IN_TS: ONE_SECOND_IN_TS$1,
- secondsToVideoTs: secondsToVideoTs$1,
- secondsToAudioTs: secondsToAudioTs$1,
- videoTsToSeconds: videoTsToSeconds$1,
- audioTsToSeconds: audioTsToSeconds$1,
- audioTsToVideoTs: audioTsToVideoTs$1,
- videoTsToAudioTs: videoTsToAudioTs$1,
- metadataTsToSeconds: metadataTsToSeconds$1
- };
- /**
- * @license
- * Video.js 8.3.0 <http://videojs.com/>
- * Copyright Brightcove, Inc. <https://www.brightcove.com/>
- * Available under Apache License Version 2.0
- * <https://github.com/videojs/video.js/blob/main/LICENSE>
- *
- * Includes vtt.js <https://github.com/mozilla/vtt.js>
- * Available under Apache License Version 2.0
- * <https://github.com/mozilla/vtt.js/blob/main/LICENSE>
- */
- var version$6$1 = "8.3.0";
- const hooks_$1 = {};
- const hooks$1 = function(type2, fn2) {
- hooks_$1[type2] = hooks_$1[type2] || [];
- if (fn2) {
- hooks_$1[type2] = hooks_$1[type2].concat(fn2);
- }
- return hooks_$1[type2];
- };
- const hook$1 = function(type2, fn2) {
- hooks$1(type2, fn2);
- };
- const removeHook$1 = function(type2, fn2) {
- const index2 = hooks$1(type2).indexOf(fn2);
- if (index2 <= -1) {
- return false;
- }
- hooks_$1[type2] = hooks_$1[type2].slice();
- hooks_$1[type2].splice(index2, 1);
- return true;
- };
- const hookOnce$1 = function(type2, fn2) {
- hooks$1(type2, [].concat(fn2).map((original) => {
- const wrapper = (...args) => {
- removeHook$1(type2, wrapper);
- return original(...args);
- };
- return wrapper;
- }));
- };
- const FullscreenApi$1 = {
- prefixed: true
- };
- const apiMap$1 = [
- ["requestFullscreen", "exitFullscreen", "fullscreenElement", "fullscreenEnabled", "fullscreenchange", "fullscreenerror", "fullscreen"],
- ["webkitRequestFullscreen", "webkitExitFullscreen", "webkitFullscreenElement", "webkitFullscreenEnabled", "webkitfullscreenchange", "webkitfullscreenerror", "-webkit-full-screen"],
- ["mozRequestFullScreen", "mozCancelFullScreen", "mozFullScreenElement", "mozFullScreenEnabled", "mozfullscreenchange", "mozfullscreenerror", "-moz-full-screen"],
- ["msRequestFullscreen", "msExitFullscreen", "msFullscreenElement", "msFullscreenEnabled", "MSFullscreenChange", "MSFullscreenError", "-ms-fullscreen"]
- ];
- const specApi$1 = apiMap$1[0];
- let browserApi$1;
- for (let i2 = 0; i2 < apiMap$1.length; i2++) {
- if (apiMap$1[i2][1] in document_1) {
- browserApi$1 = apiMap$1[i2];
- break;
- }
- }
- if (browserApi$1) {
- for (let i2 = 0; i2 < browserApi$1.length; i2++) {
- FullscreenApi$1[specApi$1[i2]] = browserApi$1[i2];
- }
- FullscreenApi$1.prefixed = browserApi$1[0] !== specApi$1[0];
- }
- let history$1 = [];
- const LogByTypeFactory$1 = (name, log2) => (type2, level, args) => {
- const lvl = log2.levels[level];
- const lvlRegExp = new RegExp(`^(${lvl})$`);
- if (type2 !== "log") {
- args.unshift(type2.toUpperCase() + ":");
- }
- args.unshift(name + ":");
- if (history$1) {
- history$1.push([].concat(args));
- const splice2 = history$1.length - 1e3;
- history$1.splice(0, splice2 > 0 ? splice2 : 0);
- }
- if (!window_1.console) {
- return;
- }
- let fn2 = window_1.console[type2];
- if (!fn2 && type2 === "debug") {
- fn2 = window_1.console.info || window_1.console.log;
- }
- if (!fn2 || !lvl || !lvlRegExp.test(type2)) {
- return;
- }
- fn2[Array.isArray(args) ? "apply" : "call"](window_1.console, args);
- };
- function createLogger$1$1(name) {
- let level = "info";
- let logByType;
- const log2 = function(...args) {
- logByType("log", level, args);
- };
- logByType = LogByTypeFactory$1(name, log2);
- log2.createLogger = (subname) => createLogger$1$1(name + ": " + subname);
- log2.levels = {
- all: "debug|log|warn|error",
- off: "",
- debug: "debug|log|warn|error",
- info: "log|warn|error",
- warn: "warn|error",
- error: "error",
- DEFAULT: level
- };
- log2.level = (lvl) => {
- if (typeof lvl === "string") {
- if (!log2.levels.hasOwnProperty(lvl)) {
- throw new Error(`"${lvl}" in not a valid log level`);
- }
- level = lvl;
- }
- return level;
- };
- log2.history = () => history$1 ? [].concat(history$1) : [];
- log2.history.filter = (fname) => {
- return (history$1 || []).filter((historyItem) => {
- return new RegExp(`.*${fname}.*`).test(historyItem[0]);
- });
- };
- log2.history.clear = () => {
- if (history$1) {
- history$1.length = 0;
- }
- };
- log2.history.disable = () => {
- if (history$1 !== null) {
- history$1.length = 0;
- history$1 = null;
- }
- };
- log2.history.enable = () => {
- if (history$1 === null) {
- history$1 = [];
- }
- };
- log2.error = (...args) => logByType("error", level, args);
- log2.warn = (...args) => logByType("warn", level, args);
- log2.debug = (...args) => logByType("debug", level, args);
- return log2;
- }
- const log$1$1 = createLogger$1$1("VIDEOJS");
- const createLogger$2 = log$1$1.createLogger;
- const toString$1 = Object.prototype.toString;
- const keys$1 = function(object) {
- return isObject$2(object) ? Object.keys(object) : [];
- };
- function each$1(object, fn2) {
- keys$1(object).forEach((key) => fn2(object[key], key));
- }
- function reduce$1(object, fn2, initial = 0) {
- return keys$1(object).reduce((accum, key) => fn2(accum, object[key], key), initial);
- }
- function isObject$2(value) {
- return !!value && typeof value === "object";
- }
- function isPlain$1(value) {
- return isObject$2(value) && toString$1.call(value) === "[object Object]" && value.constructor === Object;
- }
- function merge$1(...sources) {
- const result = {};
- sources.forEach((source) => {
- if (!source) {
- return;
- }
- each$1(source, (value, key) => {
- if (!isPlain$1(value)) {
- result[key] = value;
- return;
- }
- if (!isPlain$1(result[key])) {
- result[key] = {};
- }
- result[key] = merge$1(result[key], value);
- });
- });
- return result;
- }
- function defineLazyProperty$1(obj, key, getValue2, setter = true) {
- const set4 = (value) => Object.defineProperty(obj, key, {
- value,
- enumerable: true,
- writable: true
- });
- const options2 = {
- configurable: true,
- enumerable: true,
- get() {
- const value = getValue2();
- set4(value);
- return value;
- }
- };
- if (setter) {
- options2.set = set4;
- }
- return Object.defineProperty(obj, key, options2);
- }
- var Obj = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- each: each$1,
- reduce: reduce$1,
- isObject: isObject$2,
- isPlain: isPlain$1,
- merge: merge$1,
- defineLazyProperty: defineLazyProperty$1
- });
- let IS_IPOD$1 = false;
- let IOS_VERSION$1 = null;
- let IS_ANDROID$1 = false;
- let ANDROID_VERSION$1;
- let IS_FIREFOX$1 = false;
- let IS_EDGE$1 = false;
- let IS_CHROMIUM = false;
- let IS_CHROME$1 = false;
- let CHROMIUM_VERSION = null;
- let CHROME_VERSION$1 = null;
- let IE_VERSION$1 = null;
- let IS_SAFARI$1 = false;
- let IS_WINDOWS$1 = false;
- let IS_IPAD$1 = false;
- let IS_IPHONE$1 = false;
- const TOUCH_ENABLED$1 = Boolean(isReal$1() && ("ontouchstart" in window_1 || window_1.navigator.maxTouchPoints || window_1.DocumentTouch && window_1.document instanceof window_1.DocumentTouch));
- const UAD = window_1.navigator && window_1.navigator.userAgentData;
- if (UAD) {
- IS_ANDROID$1 = UAD.platform === "Android";
- IS_EDGE$1 = Boolean(UAD.brands.find((b) => b.brand === "Microsoft Edge"));
- IS_CHROMIUM = Boolean(UAD.brands.find((b) => b.brand === "Chromium"));
- IS_CHROME$1 = !IS_EDGE$1 && IS_CHROMIUM;
- CHROMIUM_VERSION = CHROME_VERSION$1 = (UAD.brands.find((b) => b.brand === "Chromium") || {}).version || null;
- IS_WINDOWS$1 = UAD.platform === "Windows";
- }
- if (!IS_CHROMIUM) {
- const USER_AGENT2 = window_1.navigator && window_1.navigator.userAgent || "";
- IS_IPOD$1 = /iPod/i.test(USER_AGENT2);
- IOS_VERSION$1 = function() {
- const match = USER_AGENT2.match(/OS (\d+)_/i);
- if (match && match[1]) {
- return match[1];
- }
- return null;
- }();
- IS_ANDROID$1 = /Android/i.test(USER_AGENT2);
- ANDROID_VERSION$1 = function() {
- const match = USER_AGENT2.match(/Android (\d+)(?:\.(\d+))?(?:\.(\d+))*/i);
- if (!match) {
- return null;
- }
- const major = match[1] && parseFloat(match[1]);
- const minor = match[2] && parseFloat(match[2]);
- if (major && minor) {
- return parseFloat(match[1] + "." + match[2]);
- } else if (major) {
- return major;
- }
- return null;
- }();
- IS_FIREFOX$1 = /Firefox/i.test(USER_AGENT2);
- IS_EDGE$1 = /Edg/i.test(USER_AGENT2);
- IS_CHROMIUM = /Chrome/i.test(USER_AGENT2) || /CriOS/i.test(USER_AGENT2);
- IS_CHROME$1 = !IS_EDGE$1 && IS_CHROMIUM;
- CHROMIUM_VERSION = CHROME_VERSION$1 = function() {
- const match = USER_AGENT2.match(/(Chrome|CriOS)\/(\d+)/);
- if (match && match[2]) {
- return parseFloat(match[2]);
- }
- return null;
- }();
- IE_VERSION$1 = function() {
- const result = /MSIE\s(\d+)\.\d/.exec(USER_AGENT2);
- let version2 = result && parseFloat(result[1]);
- if (!version2 && /Trident\/7.0/i.test(USER_AGENT2) && /rv:11.0/.test(USER_AGENT2)) {
- version2 = 11;
- }
- return version2;
- }();
- IS_SAFARI$1 = /Safari/i.test(USER_AGENT2) && !IS_CHROME$1 && !IS_ANDROID$1 && !IS_EDGE$1;
- IS_WINDOWS$1 = /Windows/i.test(USER_AGENT2);
- IS_IPAD$1 = /iPad/i.test(USER_AGENT2) || IS_SAFARI$1 && TOUCH_ENABLED$1 && !/iPhone/i.test(USER_AGENT2);
- IS_IPHONE$1 = /iPhone/i.test(USER_AGENT2) && !IS_IPAD$1;
- }
- const IS_IOS$1 = IS_IPHONE$1 || IS_IPAD$1 || IS_IPOD$1;
- const IS_ANY_SAFARI$1 = (IS_SAFARI$1 || IS_IOS$1) && !IS_CHROME$1;
- var browser$1 = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- get IS_IPOD() {
- return IS_IPOD$1;
- },
- get IOS_VERSION() {
- return IOS_VERSION$1;
- },
- get IS_ANDROID() {
- return IS_ANDROID$1;
- },
- get ANDROID_VERSION() {
- return ANDROID_VERSION$1;
- },
- get IS_FIREFOX() {
- return IS_FIREFOX$1;
- },
- get IS_EDGE() {
- return IS_EDGE$1;
- },
- get IS_CHROMIUM() {
- return IS_CHROMIUM;
- },
- get IS_CHROME() {
- return IS_CHROME$1;
- },
- get CHROMIUM_VERSION() {
- return CHROMIUM_VERSION;
- },
- get CHROME_VERSION() {
- return CHROME_VERSION$1;
- },
- get IE_VERSION() {
- return IE_VERSION$1;
- },
- get IS_SAFARI() {
- return IS_SAFARI$1;
- },
- get IS_WINDOWS() {
- return IS_WINDOWS$1;
- },
- get IS_IPAD() {
- return IS_IPAD$1;
- },
- get IS_IPHONE() {
- return IS_IPHONE$1;
- },
- TOUCH_ENABLED: TOUCH_ENABLED$1,
- IS_IOS: IS_IOS$1,
- IS_ANY_SAFARI: IS_ANY_SAFARI$1
- });
- function isNonBlankString$1(str) {
- return typeof str === "string" && Boolean(str.trim());
- }
- function throwIfWhitespace$1(str) {
- if (str.indexOf(" ") >= 0) {
- throw new Error("class has illegal whitespace characters");
- }
- }
- function isReal$1() {
- return document_1 === window_1.document;
- }
- function isEl$1(value) {
- return isObject$2(value) && value.nodeType === 1;
- }
- function isInFrame$1() {
- try {
- return window_1.parent !== window_1.self;
- } catch (x) {
- return true;
- }
- }
- function createQuerier$1(method) {
- return function(selector, context) {
- if (!isNonBlankString$1(selector)) {
- return document_1[method](null);
- }
- if (isNonBlankString$1(context)) {
- context = document_1.querySelector(context);
- }
- const ctx = isEl$1(context) ? context : document_1;
- return ctx[method] && ctx[method](selector);
- };
- }
- function createEl$1(tagName = "div", properties = {}, attributes = {}, content) {
- const el = document_1.createElement(tagName);
- Object.getOwnPropertyNames(properties).forEach(function(propName) {
- const val = properties[propName];
- if (propName === "textContent") {
- textContent$1(el, val);
- } else if (el[propName] !== val || propName === "tabIndex") {
- el[propName] = val;
- }
- });
- Object.getOwnPropertyNames(attributes).forEach(function(attrName) {
- el.setAttribute(attrName, attributes[attrName]);
- });
- if (content) {
- appendContent$1(el, content);
- }
- return el;
- }
- function textContent$1(el, text) {
- if (typeof el.textContent === "undefined") {
- el.innerText = text;
- } else {
- el.textContent = text;
- }
- return el;
- }
- function prependTo$1(child, parent) {
- if (parent.firstChild) {
- parent.insertBefore(child, parent.firstChild);
- } else {
- parent.appendChild(child);
- }
- }
- function hasClass$1(element, classToCheck) {
- throwIfWhitespace$1(classToCheck);
- return element.classList.contains(classToCheck);
- }
- function addClass$1(element, ...classesToAdd) {
- element.classList.add(...classesToAdd.reduce((prev, current) => prev.concat(current.split(/\s+/)), []));
- return element;
- }
- function removeClass$1(element, ...classesToRemove) {
- if (!element) {
- log$1$1.warn("removeClass was called with an element that doesn't exist");
- return null;
- }
- element.classList.remove(...classesToRemove.reduce((prev, current) => prev.concat(current.split(/\s+/)), []));
- return element;
- }
- function toggleClass$1(element, classToToggle, predicate) {
- if (typeof predicate === "function") {
- predicate = predicate(element, classToToggle);
- }
- if (typeof predicate !== "boolean") {
- predicate = void 0;
- }
- classToToggle.split(/\s+/).forEach((className) => element.classList.toggle(className, predicate));
- return element;
- }
- function setAttributes$1(el, attributes) {
- Object.getOwnPropertyNames(attributes).forEach(function(attrName) {
- const attrValue = attributes[attrName];
- if (attrValue === null || typeof attrValue === "undefined" || attrValue === false) {
- el.removeAttribute(attrName);
- } else {
- el.setAttribute(attrName, attrValue === true ? "" : attrValue);
- }
- });
- }
- function getAttributes$1(tag) {
- const obj = {};
- const knownBooleans = ",autoplay,controls,playsinline,loop,muted,default,defaultMuted,";
- if (tag && tag.attributes && tag.attributes.length > 0) {
- const attrs = tag.attributes;
- for (let i2 = attrs.length - 1; i2 >= 0; i2--) {
- const attrName = attrs[i2].name;
- let attrVal = attrs[i2].value;
- if (typeof tag[attrName] === "boolean" || knownBooleans.indexOf("," + attrName + ",") !== -1) {
- attrVal = attrVal !== null ? true : false;
- }
- obj[attrName] = attrVal;
- }
- }
- return obj;
- }
- function getAttribute$1(el, attribute) {
- return el.getAttribute(attribute);
- }
- function setAttribute$1(el, attribute, value) {
- el.setAttribute(attribute, value);
- }
- function removeAttribute$1(el, attribute) {
- el.removeAttribute(attribute);
- }
- function blockTextSelection$1() {
- document_1.body.focus();
- document_1.onselectstart = function() {
- return false;
- };
- }
- function unblockTextSelection$1() {
- document_1.onselectstart = function() {
- return true;
- };
- }
- function getBoundingClientRect$1(el) {
- if (el && el.getBoundingClientRect && el.parentNode) {
- const rect = el.getBoundingClientRect();
- const result = {};
- ["bottom", "height", "left", "right", "top", "width"].forEach((k) => {
- if (rect[k] !== void 0) {
- result[k] = rect[k];
- }
- });
- if (!result.height) {
- result.height = parseFloat(computedStyle$1(el, "height"));
- }
- if (!result.width) {
- result.width = parseFloat(computedStyle$1(el, "width"));
- }
- return result;
- }
- }
- function findPosition$1(el) {
- if (!el || el && !el.offsetParent) {
- return {
- left: 0,
- top: 0,
- width: 0,
- height: 0
- };
- }
- const width2 = el.offsetWidth;
- const height2 = el.offsetHeight;
- let left = 0;
- let top = 0;
- while (el.offsetParent && el !== document_1[FullscreenApi$1.fullscreenElement]) {
- left += el.offsetLeft;
- top += el.offsetTop;
- el = el.offsetParent;
- }
- return {
- left,
- top,
- width: width2,
- height: height2
- };
- }
- function getPointerPosition$1(el, event2) {
- const translated = {
- x: 0,
- y: 0
- };
- if (IS_IOS$1) {
- let item = el;
- while (item && item.nodeName.toLowerCase() !== "html") {
- const transform3 = computedStyle$1(item, "transform");
- if (/^matrix/.test(transform3)) {
- const values3 = transform3.slice(7, -1).split(/,\s/).map(Number);
- translated.x += values3[4];
- translated.y += values3[5];
- } else if (/^matrix3d/.test(transform3)) {
- const values3 = transform3.slice(9, -1).split(/,\s/).map(Number);
- translated.x += values3[12];
- translated.y += values3[13];
- }
- item = item.parentNode;
- }
- }
- const position2 = {};
- const boxTarget = findPosition$1(event2.target);
- const box = findPosition$1(el);
- const boxW = box.width;
- const boxH = box.height;
- let offsetY = event2.offsetY - (box.top - boxTarget.top);
- let offsetX = event2.offsetX - (box.left - boxTarget.left);
- if (event2.changedTouches) {
- offsetX = event2.changedTouches[0].pageX - box.left;
- offsetY = event2.changedTouches[0].pageY + box.top;
- if (IS_IOS$1) {
- offsetX -= translated.x;
- offsetY -= translated.y;
- }
- }
- position2.y = 1 - Math.max(0, Math.min(1, offsetY / boxH));
- position2.x = Math.max(0, Math.min(1, offsetX / boxW));
- return position2;
- }
- function isTextNode$1(value) {
- return isObject$2(value) && value.nodeType === 3;
- }
- function emptyEl$1(el) {
- while (el.firstChild) {
- el.removeChild(el.firstChild);
- }
- return el;
- }
- function normalizeContent$1(content) {
- if (typeof content === "function") {
- content = content();
- }
- return (Array.isArray(content) ? content : [content]).map((value) => {
- if (typeof value === "function") {
- value = value();
- }
- if (isEl$1(value) || isTextNode$1(value)) {
- return value;
- }
- if (typeof value === "string" && /\S/.test(value)) {
- return document_1.createTextNode(value);
- }
- }).filter((value) => value);
- }
- function appendContent$1(el, content) {
- normalizeContent$1(content).forEach((node) => el.appendChild(node));
- return el;
- }
- function insertContent$1(el, content) {
- return appendContent$1(emptyEl$1(el), content);
- }
- function isSingleLeftClick$1(event2) {
- if (event2.button === void 0 && event2.buttons === void 0) {
- return true;
- }
- if (event2.button === 0 && event2.buttons === void 0) {
- return true;
- }
- if (event2.type === "mouseup" && event2.button === 0 && event2.buttons === 0) {
- return true;
- }
- if (event2.button !== 0 || event2.buttons !== 1) {
- return false;
- }
- return true;
- }
- const $$1 = createQuerier$1("querySelector");
- const $$$1 = createQuerier$1("querySelectorAll");
- function computedStyle$1(el, prop) {
- if (!el || !prop) {
- return "";
- }
- if (typeof window_1.getComputedStyle === "function") {
- let computedStyleValue;
- try {
- computedStyleValue = window_1.getComputedStyle(el);
- } catch (e) {
- return "";
- }
- return computedStyleValue ? computedStyleValue.getPropertyValue(prop) || computedStyleValue[prop] : "";
- }
- return "";
- }
- var Dom$2 = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- isReal: isReal$1,
- isEl: isEl$1,
- isInFrame: isInFrame$1,
- createEl: createEl$1,
- textContent: textContent$1,
- prependTo: prependTo$1,
- hasClass: hasClass$1,
- addClass: addClass$1,
- removeClass: removeClass$1,
- toggleClass: toggleClass$1,
- setAttributes: setAttributes$1,
- getAttributes: getAttributes$1,
- getAttribute: getAttribute$1,
- setAttribute: setAttribute$1,
- removeAttribute: removeAttribute$1,
- blockTextSelection: blockTextSelection$1,
- unblockTextSelection: unblockTextSelection$1,
- getBoundingClientRect: getBoundingClientRect$1,
- findPosition: findPosition$1,
- getPointerPosition: getPointerPosition$1,
- isTextNode: isTextNode$1,
- emptyEl: emptyEl$1,
- normalizeContent: normalizeContent$1,
- appendContent: appendContent$1,
- insertContent: insertContent$1,
- isSingleLeftClick: isSingleLeftClick$1,
- $: $$1,
- $$: $$$1,
- computedStyle: computedStyle$1
- });
- let _windowLoaded$1 = false;
- let videojs$1$1;
- const autoSetup$1 = function() {
- if (videojs$1$1.options.autoSetup === false) {
- return;
- }
- const vids = Array.prototype.slice.call(document_1.getElementsByTagName("video"));
- const audios = Array.prototype.slice.call(document_1.getElementsByTagName("audio"));
- const divs = Array.prototype.slice.call(document_1.getElementsByTagName("video-js"));
- const mediaEls = vids.concat(audios, divs);
- if (mediaEls && mediaEls.length > 0) {
- for (let i2 = 0, e = mediaEls.length; i2 < e; i2++) {
- const mediaEl = mediaEls[i2];
- if (mediaEl && mediaEl.getAttribute) {
- if (mediaEl.player === void 0) {
- const options2 = mediaEl.getAttribute("data-setup");
- if (options2 !== null) {
- videojs$1$1(mediaEl);
- }
- }
- } else {
- autoSetupTimeout$1(1);
- break;
- }
- }
- } else if (!_windowLoaded$1) {
- autoSetupTimeout$1(1);
- }
- };
- function autoSetupTimeout$1(wait, vjs) {
- if (!isReal$1()) {
- return;
- }
- if (vjs) {
- videojs$1$1 = vjs;
- }
- window_1.setTimeout(autoSetup$1, wait);
- }
- function setWindowLoaded$1() {
- _windowLoaded$1 = true;
- window_1.removeEventListener("load", setWindowLoaded$1);
- }
- if (isReal$1()) {
- if (document_1.readyState === "complete") {
- setWindowLoaded$1();
- } else {
- window_1.addEventListener("load", setWindowLoaded$1);
- }
- }
- const createStyleElement$1 = function(className) {
- const style = document_1.createElement("style");
- style.className = className;
- return style;
- };
- const setTextContent$1 = function(el, content) {
- if (el.styleSheet) {
- el.styleSheet.cssText = content;
- } else {
- el.textContent = content;
- }
- };
- var DomData$1 = /* @__PURE__ */ new WeakMap();
- const _initialGuid$1 = 3;
- let _guid$1 = _initialGuid$1;
- function newGUID$1() {
- return _guid$1++;
- }
- function _cleanUpEvents$1(elem, type2) {
- if (!DomData$1.has(elem)) {
- return;
- }
- const data = DomData$1.get(elem);
- if (data.handlers[type2].length === 0) {
- delete data.handlers[type2];
- if (elem.removeEventListener) {
- elem.removeEventListener(type2, data.dispatcher, false);
- } else if (elem.detachEvent) {
- elem.detachEvent("on" + type2, data.dispatcher);
- }
- }
- if (Object.getOwnPropertyNames(data.handlers).length <= 0) {
- delete data.handlers;
- delete data.dispatcher;
- delete data.disabled;
- }
- if (Object.getOwnPropertyNames(data).length === 0) {
- DomData$1.delete(elem);
- }
- }
- function _handleMultipleEvents$1(fn2, elem, types, callback2) {
- types.forEach(function(type2) {
- fn2(elem, type2, callback2);
- });
- }
- function fixEvent$1(event2) {
- if (event2.fixed_) {
- return event2;
- }
- function returnTrue() {
- return true;
- }
- function returnFalse() {
- return false;
- }
- if (!event2 || !event2.isPropagationStopped || !event2.isImmediatePropagationStopped) {
- const old = event2 || window_1.event;
- event2 = {};
- for (const key in old) {
- if (key !== "layerX" && key !== "layerY" && key !== "keyLocation" && key !== "webkitMovementX" && key !== "webkitMovementY" && key !== "path") {
- if (!(key === "returnValue" && old.preventDefault)) {
- event2[key] = old[key];
- }
- }
- }
- if (!event2.target) {
- event2.target = event2.srcElement || document_1;
- }
- if (!event2.relatedTarget) {
- event2.relatedTarget = event2.fromElement === event2.target ? event2.toElement : event2.fromElement;
- }
- event2.preventDefault = function() {
- if (old.preventDefault) {
- old.preventDefault();
- }
- event2.returnValue = false;
- old.returnValue = false;
- event2.defaultPrevented = true;
- };
- event2.defaultPrevented = false;
- event2.stopPropagation = function() {
- if (old.stopPropagation) {
- old.stopPropagation();
- }
- event2.cancelBubble = true;
- old.cancelBubble = true;
- event2.isPropagationStopped = returnTrue;
- };
- event2.isPropagationStopped = returnFalse;
- event2.stopImmediatePropagation = function() {
- if (old.stopImmediatePropagation) {
- old.stopImmediatePropagation();
- }
- event2.isImmediatePropagationStopped = returnTrue;
- event2.stopPropagation();
- };
- event2.isImmediatePropagationStopped = returnFalse;
- if (event2.clientX !== null && event2.clientX !== void 0) {
- const doc = document_1.documentElement;
- const body = document_1.body;
- event2.pageX = event2.clientX + (doc && doc.scrollLeft || body && body.scrollLeft || 0) - (doc && doc.clientLeft || body && body.clientLeft || 0);
- event2.pageY = event2.clientY + (doc && doc.scrollTop || body && body.scrollTop || 0) - (doc && doc.clientTop || body && body.clientTop || 0);
- }
- event2.which = event2.charCode || event2.keyCode;
- if (event2.button !== null && event2.button !== void 0) {
- event2.button = event2.button & 1 ? 0 : event2.button & 4 ? 1 : event2.button & 2 ? 2 : 0;
- }
- }
- event2.fixed_ = true;
- return event2;
- }
- let _supportsPassive$1;
- const supportsPassive$1 = function() {
- if (typeof _supportsPassive$1 !== "boolean") {
- _supportsPassive$1 = false;
- try {
- const opts = Object.defineProperty({}, "passive", {
- get() {
- _supportsPassive$1 = true;
- }
- });
- window_1.addEventListener("test", null, opts);
- window_1.removeEventListener("test", null, opts);
- } catch (e) {
- }
- }
- return _supportsPassive$1;
- };
- const passiveEvents$1 = ["touchstart", "touchmove"];
- function on$1(elem, type2, fn2) {
- if (Array.isArray(type2)) {
- return _handleMultipleEvents$1(on$1, elem, type2, fn2);
- }
- if (!DomData$1.has(elem)) {
- DomData$1.set(elem, {});
- }
- const data = DomData$1.get(elem);
- if (!data.handlers) {
- data.handlers = {};
- }
- if (!data.handlers[type2]) {
- data.handlers[type2] = [];
- }
- if (!fn2.guid) {
- fn2.guid = newGUID$1();
- }
- data.handlers[type2].push(fn2);
- if (!data.dispatcher) {
- data.disabled = false;
- data.dispatcher = function(event2, hash) {
- if (data.disabled) {
- return;
- }
- event2 = fixEvent$1(event2);
- const handlers = data.handlers[event2.type];
- if (handlers) {
- const handlersCopy = handlers.slice(0);
- for (let m = 0, n = handlersCopy.length; m < n; m++) {
- if (event2.isImmediatePropagationStopped()) {
- break;
- } else {
- try {
- handlersCopy[m].call(elem, event2, hash);
- } catch (e) {
- log$1$1.error(e);
- }
- }
- }
- }
- };
- }
- if (data.handlers[type2].length === 1) {
- if (elem.addEventListener) {
- let options2 = false;
- if (supportsPassive$1() && passiveEvents$1.indexOf(type2) > -1) {
- options2 = {
- passive: true
- };
- }
- elem.addEventListener(type2, data.dispatcher, options2);
- } else if (elem.attachEvent) {
- elem.attachEvent("on" + type2, data.dispatcher);
- }
- }
- }
- function off$1(elem, type2, fn2) {
- if (!DomData$1.has(elem)) {
- return;
- }
- const data = DomData$1.get(elem);
- if (!data.handlers) {
- return;
- }
- if (Array.isArray(type2)) {
- return _handleMultipleEvents$1(off$1, elem, type2, fn2);
- }
- const removeType = function(el, t2) {
- data.handlers[t2] = [];
- _cleanUpEvents$1(el, t2);
- };
- if (type2 === void 0) {
- for (const t2 in data.handlers) {
- if (Object.prototype.hasOwnProperty.call(data.handlers || {}, t2)) {
- removeType(elem, t2);
- }
- }
- return;
- }
- const handlers = data.handlers[type2];
- if (!handlers) {
- return;
- }
- if (!fn2) {
- removeType(elem, type2);
- return;
- }
- if (fn2.guid) {
- for (let n = 0; n < handlers.length; n++) {
- if (handlers[n].guid === fn2.guid) {
- handlers.splice(n--, 1);
- }
- }
- }
- _cleanUpEvents$1(elem, type2);
- }
- function trigger$1(elem, event2, hash) {
- const elemData = DomData$1.has(elem) ? DomData$1.get(elem) : {};
- const parent = elem.parentNode || elem.ownerDocument;
- if (typeof event2 === "string") {
- event2 = {
- type: event2,
- target: elem
- };
- } else if (!event2.target) {
- event2.target = elem;
- }
- event2 = fixEvent$1(event2);
- if (elemData.dispatcher) {
- elemData.dispatcher.call(elem, event2, hash);
- }
- if (parent && !event2.isPropagationStopped() && event2.bubbles === true) {
- trigger$1.call(null, parent, event2, hash);
- } else if (!parent && !event2.defaultPrevented && event2.target && event2.target[event2.type]) {
- if (!DomData$1.has(event2.target)) {
- DomData$1.set(event2.target, {});
- }
- const targetData = DomData$1.get(event2.target);
- if (event2.target[event2.type]) {
- targetData.disabled = true;
- if (typeof event2.target[event2.type] === "function") {
- event2.target[event2.type]();
- }
- targetData.disabled = false;
- }
- }
- return !event2.defaultPrevented;
- }
- function one$1(elem, type2, fn2) {
- if (Array.isArray(type2)) {
- return _handleMultipleEvents$1(one$1, elem, type2, fn2);
- }
- const func = function() {
- off$1(elem, type2, func);
- fn2.apply(this, arguments);
- };
- func.guid = fn2.guid = fn2.guid || newGUID$1();
- on$1(elem, type2, func);
- }
- function any$1(elem, type2, fn2) {
- const func = function() {
- off$1(elem, type2, func);
- fn2.apply(this, arguments);
- };
- func.guid = fn2.guid = fn2.guid || newGUID$1();
- on$1(elem, type2, func);
- }
- var Events$1 = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- fixEvent: fixEvent$1,
- on: on$1,
- off: off$1,
- trigger: trigger$1,
- one: one$1,
- any: any$1
- });
- const UPDATE_REFRESH_INTERVAL$1 = 30;
- const bind_ = function(context, fn2, uid) {
- if (!fn2.guid) {
- fn2.guid = newGUID$1();
- }
- const bound = fn2.bind(context);
- bound.guid = uid ? uid + "_" + fn2.guid : fn2.guid;
- return bound;
- };
- const throttle$1 = function(fn2, wait) {
- let last = window_1.performance.now();
- const throttled = function(...args) {
- const now2 = window_1.performance.now();
- if (now2 - last >= wait) {
- fn2(...args);
- last = now2;
- }
- };
- return throttled;
- };
- const debounce$1 = function(func, wait, immediate, context = window_1) {
- let timeout;
- const cancel = () => {
- context.clearTimeout(timeout);
- timeout = null;
- };
- const debounced = function() {
- const self2 = this;
- const args = arguments;
- let later = function() {
- timeout = null;
- later = null;
- if (!immediate) {
- func.apply(self2, args);
- }
- };
- if (!timeout && immediate) {
- func.apply(self2, args);
- }
- context.clearTimeout(timeout);
- timeout = context.setTimeout(later, wait);
- };
- debounced.cancel = cancel;
- return debounced;
- };
- var Fn = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- UPDATE_REFRESH_INTERVAL: UPDATE_REFRESH_INTERVAL$1,
- bind_,
- throttle: throttle$1,
- debounce: debounce$1
- });
- let EVENT_MAP$1;
- class EventTarget$2$1 {
- on(type2, fn2) {
- const ael = this.addEventListener;
- this.addEventListener = () => {
- };
- on$1(this, type2, fn2);
- this.addEventListener = ael;
- }
- off(type2, fn2) {
- off$1(this, type2, fn2);
- }
- one(type2, fn2) {
- const ael = this.addEventListener;
- this.addEventListener = () => {
- };
- one$1(this, type2, fn2);
- this.addEventListener = ael;
- }
- any(type2, fn2) {
- const ael = this.addEventListener;
- this.addEventListener = () => {
- };
- any$1(this, type2, fn2);
- this.addEventListener = ael;
- }
- trigger(event2) {
- const type2 = event2.type || event2;
- if (typeof event2 === "string") {
- event2 = {
- type: type2
- };
- }
- event2 = fixEvent$1(event2);
- if (this.allowedEvents_[type2] && this["on" + type2]) {
- this["on" + type2](event2);
- }
- trigger$1(this, event2);
- }
- queueTrigger(event2) {
- if (!EVENT_MAP$1) {
- EVENT_MAP$1 = /* @__PURE__ */ new Map();
- }
- const type2 = event2.type || event2;
- let map = EVENT_MAP$1.get(this);
- if (!map) {
- map = /* @__PURE__ */ new Map();
- EVENT_MAP$1.set(this, map);
- }
- const oldTimeout = map.get(type2);
- map.delete(type2);
- window_1.clearTimeout(oldTimeout);
- const timeout = window_1.setTimeout(() => {
- map.delete(type2);
- if (map.size === 0) {
- map = null;
- EVENT_MAP$1.delete(this);
- }
- this.trigger(event2);
- }, 0);
- map.set(type2, timeout);
- }
- }
- EventTarget$2$1.prototype.allowedEvents_ = {};
- EventTarget$2$1.prototype.addEventListener = EventTarget$2$1.prototype.on;
- EventTarget$2$1.prototype.removeEventListener = EventTarget$2$1.prototype.off;
- EventTarget$2$1.prototype.dispatchEvent = EventTarget$2$1.prototype.trigger;
- const objName$1 = (obj) => {
- if (typeof obj.name === "function") {
- return obj.name();
- }
- if (typeof obj.name === "string") {
- return obj.name;
- }
- if (obj.name_) {
- return obj.name_;
- }
- if (obj.constructor && obj.constructor.name) {
- return obj.constructor.name;
- }
- return typeof obj;
- };
- const isEvented$1 = (object) => object instanceof EventTarget$2$1 || !!object.eventBusEl_ && ["on", "one", "off", "trigger"].every((k) => typeof object[k] === "function");
- const addEventedCallback$1 = (target, callback2) => {
- if (isEvented$1(target)) {
- callback2();
- } else {
- if (!target.eventedCallbacks) {
- target.eventedCallbacks = [];
- }
- target.eventedCallbacks.push(callback2);
- }
- };
- const isValidEventType$1 = (type2) => typeof type2 === "string" && /\S/.test(type2) || Array.isArray(type2) && !!type2.length;
- const validateTarget$1 = (target, obj, fnName) => {
- if (!target || !target.nodeName && !isEvented$1(target)) {
- throw new Error(`Invalid target for ${objName$1(obj)}#${fnName}; must be a DOM node or evented object.`);
- }
- };
- const validateEventType$1 = (type2, obj, fnName) => {
- if (!isValidEventType$1(type2)) {
- throw new Error(`Invalid event type for ${objName$1(obj)}#${fnName}; must be a non-empty string or array.`);
- }
- };
- const validateListener$1 = (listener, obj, fnName) => {
- if (typeof listener !== "function") {
- throw new Error(`Invalid listener for ${objName$1(obj)}#${fnName}; must be a function.`);
- }
- };
- const normalizeListenArgs$1 = (self2, args, fnName) => {
- const isTargetingSelf = args.length < 3 || args[0] === self2 || args[0] === self2.eventBusEl_;
- let target;
- let type2;
- let listener;
- if (isTargetingSelf) {
- target = self2.eventBusEl_;
- if (args.length >= 3) {
- args.shift();
- }
- [type2, listener] = args;
- } else {
- [target, type2, listener] = args;
- }
- validateTarget$1(target, self2, fnName);
- validateEventType$1(type2, self2, fnName);
- validateListener$1(listener, self2, fnName);
- listener = bind_(self2, listener);
- return {
- isTargetingSelf,
- target,
- type: type2,
- listener
- };
- };
- const listen$1 = (target, method, type2, listener) => {
- validateTarget$1(target, target, method);
- if (target.nodeName) {
- Events$1[method](target, type2, listener);
- } else {
- target[method](type2, listener);
- }
- };
- const EventedMixin$1 = {
- on(...args) {
- const {
- isTargetingSelf,
- target,
- type: type2,
- listener
- } = normalizeListenArgs$1(this, args, "on");
- listen$1(target, "on", type2, listener);
- if (!isTargetingSelf) {
- const removeListenerOnDispose = () => this.off(target, type2, listener);
- removeListenerOnDispose.guid = listener.guid;
- const removeRemoverOnTargetDispose = () => this.off("dispose", removeListenerOnDispose);
- removeRemoverOnTargetDispose.guid = listener.guid;
- listen$1(this, "on", "dispose", removeListenerOnDispose);
- listen$1(target, "on", "dispose", removeRemoverOnTargetDispose);
- }
- },
- one(...args) {
- const {
- isTargetingSelf,
- target,
- type: type2,
- listener
- } = normalizeListenArgs$1(this, args, "one");
- if (isTargetingSelf) {
- listen$1(target, "one", type2, listener);
- } else {
- const wrapper = (...largs) => {
- this.off(target, type2, wrapper);
- listener.apply(null, largs);
- };
- wrapper.guid = listener.guid;
- listen$1(target, "one", type2, wrapper);
- }
- },
- any(...args) {
- const {
- isTargetingSelf,
- target,
- type: type2,
- listener
- } = normalizeListenArgs$1(this, args, "any");
- if (isTargetingSelf) {
- listen$1(target, "any", type2, listener);
- } else {
- const wrapper = (...largs) => {
- this.off(target, type2, wrapper);
- listener.apply(null, largs);
- };
- wrapper.guid = listener.guid;
- listen$1(target, "any", type2, wrapper);
- }
- },
- off(targetOrType, typeOrListener, listener) {
- if (!targetOrType || isValidEventType$1(targetOrType)) {
- off$1(this.eventBusEl_, targetOrType, typeOrListener);
- } else {
- const target = targetOrType;
- const type2 = typeOrListener;
- validateTarget$1(target, this, "off");
- validateEventType$1(type2, this, "off");
- validateListener$1(listener, this, "off");
- listener = bind_(this, listener);
- this.off("dispose", listener);
- if (target.nodeName) {
- off$1(target, type2, listener);
- off$1(target, "dispose", listener);
- } else if (isEvented$1(target)) {
- target.off(type2, listener);
- target.off("dispose", listener);
- }
- }
- },
- trigger(event2, hash) {
- validateTarget$1(this.eventBusEl_, this, "trigger");
- const type2 = event2 && typeof event2 !== "string" ? event2.type : event2;
- if (!isValidEventType$1(type2)) {
- throw new Error(`Invalid event type for ${objName$1(this)}#trigger; must be a non-empty string or object with a type key that has a non-empty value.`);
- }
- return trigger$1(this.eventBusEl_, event2, hash);
- }
- };
- function evented$1(target, options2 = {}) {
- const {
- eventBusKey
- } = options2;
- if (eventBusKey) {
- if (!target[eventBusKey].nodeName) {
- throw new Error(`The eventBusKey "${eventBusKey}" does not refer to an element.`);
- }
- target.eventBusEl_ = target[eventBusKey];
- } else {
- target.eventBusEl_ = createEl$1("span", {
- className: "vjs-event-bus"
- });
- }
- Object.assign(target, EventedMixin$1);
- if (target.eventedCallbacks) {
- target.eventedCallbacks.forEach((callback2) => {
- callback2();
- });
- }
- target.on("dispose", () => {
- target.off();
- [target, target.el_, target.eventBusEl_].forEach(function(val) {
- if (val && DomData$1.has(val)) {
- DomData$1.delete(val);
- }
- });
- window_1.setTimeout(() => {
- target.eventBusEl_ = null;
- }, 0);
- });
- return target;
- }
- const StatefulMixin$1 = {
- state: {},
- setState(stateUpdates) {
- if (typeof stateUpdates === "function") {
- stateUpdates = stateUpdates();
- }
- let changes;
- each$1(stateUpdates, (value, key) => {
- if (this.state[key] !== value) {
- changes = changes || {};
- changes[key] = {
- from: this.state[key],
- to: value
- };
- }
- this.state[key] = value;
- });
- if (changes && isEvented$1(this)) {
- this.trigger({
- changes,
- type: "statechanged"
- });
- }
- return changes;
- }
- };
- function stateful$1(target, defaultState) {
- Object.assign(target, StatefulMixin$1);
- target.state = Object.assign({}, target.state, defaultState);
- if (typeof target.handleStateChanged === "function" && isEvented$1(target)) {
- target.on("statechanged", target.handleStateChanged);
- }
- return target;
- }
- const toLowerCase$1 = function(string) {
- if (typeof string !== "string") {
- return string;
- }
- return string.replace(/./, (w) => w.toLowerCase());
- };
- const toTitleCase$1$1 = function(string) {
- if (typeof string !== "string") {
- return string;
- }
- return string.replace(/./, (w) => w.toUpperCase());
- };
- const titleCaseEquals$1 = function(str1, str2) {
- return toTitleCase$1$1(str1) === toTitleCase$1$1(str2);
- };
- var Str = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- toLowerCase: toLowerCase$1,
- toTitleCase: toTitleCase$1$1,
- titleCaseEquals: titleCaseEquals$1
- });
- class Component$1$1 {
- constructor(player, options2, ready) {
- if (!player && this.play) {
- this.player_ = player = this;
- } else {
- this.player_ = player;
- }
- this.isDisposed_ = false;
- this.parentComponent_ = null;
- this.options_ = merge$1({}, this.options_);
- options2 = this.options_ = merge$1(this.options_, options2);
- this.id_ = options2.id || options2.el && options2.el.id;
- if (!this.id_) {
- const id = player && player.id && player.id() || "no_player";
- this.id_ = `${id}_component_${newGUID$1()}`;
- }
- this.name_ = options2.name || null;
- if (options2.el) {
- this.el_ = options2.el;
- } else if (options2.createEl !== false) {
- this.el_ = this.createEl();
- }
- if (options2.className && this.el_) {
- options2.className.split(" ").forEach((c) => this.addClass(c));
- }
- ["on", "off", "one", "any", "trigger"].forEach((fn2) => {
- this[fn2] = void 0;
- });
- if (options2.evented !== false) {
- evented$1(this, {
- eventBusKey: this.el_ ? "el_" : null
- });
- this.handleLanguagechange = this.handleLanguagechange.bind(this);
- this.on(this.player_, "languagechange", this.handleLanguagechange);
- }
- stateful$1(this, this.constructor.defaultState);
- this.children_ = [];
- this.childIndex_ = {};
- this.childNameIndex_ = {};
- this.setTimeoutIds_ = /* @__PURE__ */ new Set();
- this.setIntervalIds_ = /* @__PURE__ */ new Set();
- this.rafIds_ = /* @__PURE__ */ new Set();
- this.namedRafs_ = /* @__PURE__ */ new Map();
- this.clearingTimersOnDispose_ = false;
- if (options2.initChildren !== false) {
- this.initChildren();
- }
- this.ready(ready);
- if (options2.reportTouchActivity !== false) {
- this.enableTouchActivity();
- }
- }
- on(type2, fn2) {
- }
- off(type2, fn2) {
- }
- one(type2, fn2) {
- }
- any(type2, fn2) {
- }
- trigger(event2) {
- }
- dispose(options2 = {}) {
- if (this.isDisposed_) {
- return;
- }
- if (this.readyQueue_) {
- this.readyQueue_.length = 0;
- }
- this.trigger({
- type: "dispose",
- bubbles: false
- });
- this.isDisposed_ = true;
- if (this.children_) {
- for (let i2 = this.children_.length - 1; i2 >= 0; i2--) {
- if (this.children_[i2].dispose) {
- this.children_[i2].dispose();
- }
- }
- }
- this.children_ = null;
- this.childIndex_ = null;
- this.childNameIndex_ = null;
- this.parentComponent_ = null;
- if (this.el_) {
- if (this.el_.parentNode) {
- if (options2.restoreEl) {
- this.el_.parentNode.replaceChild(options2.restoreEl, this.el_);
- } else {
- this.el_.parentNode.removeChild(this.el_);
- }
- }
- this.el_ = null;
- }
- this.player_ = null;
- }
- isDisposed() {
- return Boolean(this.isDisposed_);
- }
- player() {
- return this.player_;
- }
- options(obj) {
- if (!obj) {
- return this.options_;
- }
- this.options_ = merge$1(this.options_, obj);
- return this.options_;
- }
- el() {
- return this.el_;
- }
- createEl(tagName, properties, attributes) {
- return createEl$1(tagName, properties, attributes);
- }
- localize(string, tokens, defaultValue2 = string) {
- const code = this.player_.language && this.player_.language();
- const languages = this.player_.languages && this.player_.languages();
- const language = languages && languages[code];
- const primaryCode = code && code.split("-")[0];
- const primaryLang = languages && languages[primaryCode];
- let localizedString = defaultValue2;
- if (language && language[string]) {
- localizedString = language[string];
- } else if (primaryLang && primaryLang[string]) {
- localizedString = primaryLang[string];
- }
- if (tokens) {
- localizedString = localizedString.replace(/\{(\d+)\}/g, function(match, index2) {
- const value = tokens[index2 - 1];
- let ret = value;
- if (typeof value === "undefined") {
- ret = match;
- }
- return ret;
- });
- }
- return localizedString;
- }
- handleLanguagechange() {
- }
- contentEl() {
- return this.contentEl_ || this.el_;
- }
- id() {
- return this.id_;
- }
- name() {
- return this.name_;
- }
- children() {
- return this.children_;
- }
- getChildById(id) {
- return this.childIndex_[id];
- }
- getChild(name) {
- if (!name) {
- return;
- }
- return this.childNameIndex_[name];
- }
- getDescendant(...names2) {
- names2 = names2.reduce((acc, n) => acc.concat(n), []);
- let currentChild = this;
- for (let i2 = 0; i2 < names2.length; i2++) {
- currentChild = currentChild.getChild(names2[i2]);
- if (!currentChild || !currentChild.getChild) {
- return;
- }
- }
- return currentChild;
- }
- addChild(child, options2 = {}, index2 = this.children_.length) {
- let component;
- let componentName;
- if (typeof child === "string") {
- componentName = toTitleCase$1$1(child);
- const componentClassName = options2.componentClass || componentName;
- options2.name = componentName;
- const ComponentClass = Component$1$1.getComponent(componentClassName);
- if (!ComponentClass) {
- throw new Error(`Component ${componentClassName} does not exist`);
- }
- if (typeof ComponentClass !== "function") {
- return null;
- }
- component = new ComponentClass(this.player_ || this, options2);
- } else {
- component = child;
- }
- if (component.parentComponent_) {
- component.parentComponent_.removeChild(component);
- }
- this.children_.splice(index2, 0, component);
- component.parentComponent_ = this;
- if (typeof component.id === "function") {
- this.childIndex_[component.id()] = component;
- }
- componentName = componentName || component.name && toTitleCase$1$1(component.name());
- if (componentName) {
- this.childNameIndex_[componentName] = component;
- this.childNameIndex_[toLowerCase$1(componentName)] = component;
- }
- if (typeof component.el === "function" && component.el()) {
- let refNode = null;
- if (this.children_[index2 + 1]) {
- if (this.children_[index2 + 1].el_) {
- refNode = this.children_[index2 + 1].el_;
- } else if (isEl$1(this.children_[index2 + 1])) {
- refNode = this.children_[index2 + 1];
- }
- }
- this.contentEl().insertBefore(component.el(), refNode);
- }
- return component;
- }
- removeChild(component) {
- if (typeof component === "string") {
- component = this.getChild(component);
- }
- if (!component || !this.children_) {
- return;
- }
- let childFound = false;
- for (let i2 = this.children_.length - 1; i2 >= 0; i2--) {
- if (this.children_[i2] === component) {
- childFound = true;
- this.children_.splice(i2, 1);
- break;
- }
- }
- if (!childFound) {
- return;
- }
- component.parentComponent_ = null;
- this.childIndex_[component.id()] = null;
- this.childNameIndex_[toTitleCase$1$1(component.name())] = null;
- this.childNameIndex_[toLowerCase$1(component.name())] = null;
- const compEl = component.el();
- if (compEl && compEl.parentNode === this.contentEl()) {
- this.contentEl().removeChild(component.el());
- }
- }
- initChildren() {
- const children = this.options_.children;
- if (children) {
- const parentOptions = this.options_;
- const handleAdd = (child) => {
- const name = child.name;
- let opts = child.opts;
- if (parentOptions[name] !== void 0) {
- opts = parentOptions[name];
- }
- if (opts === false) {
- return;
- }
- if (opts === true) {
- opts = {};
- }
- opts.playerOptions = this.options_.playerOptions;
- const newChild = this.addChild(name, opts);
- if (newChild) {
- this[name] = newChild;
- }
- };
- let workingChildren;
- const Tech2 = Component$1$1.getComponent("Tech");
- if (Array.isArray(children)) {
- workingChildren = children;
- } else {
- workingChildren = Object.keys(children);
- }
- workingChildren.concat(Object.keys(this.options_).filter(function(child) {
- return !workingChildren.some(function(wchild) {
- if (typeof wchild === "string") {
- return child === wchild;
- }
- return child === wchild.name;
- });
- })).map((child) => {
- let name;
- let opts;
- if (typeof child === "string") {
- name = child;
- opts = children[name] || this.options_[name] || {};
- } else {
- name = child.name;
- opts = child;
- }
- return {
- name,
- opts
- };
- }).filter((child) => {
- const c = Component$1$1.getComponent(child.opts.componentClass || toTitleCase$1$1(child.name));
- return c && !Tech2.isTech(c);
- }).forEach(handleAdd);
- }
- }
- buildCSSClass() {
- return "";
- }
- ready(fn2, sync = false) {
- if (!fn2) {
- return;
- }
- if (!this.isReady_) {
- this.readyQueue_ = this.readyQueue_ || [];
- this.readyQueue_.push(fn2);
- return;
- }
- if (sync) {
- fn2.call(this);
- } else {
- this.setTimeout(fn2, 1);
- }
- }
- triggerReady() {
- this.isReady_ = true;
- this.setTimeout(function() {
- const readyQueue = this.readyQueue_;
- this.readyQueue_ = [];
- if (readyQueue && readyQueue.length > 0) {
- readyQueue.forEach(function(fn2) {
- fn2.call(this);
- }, this);
- }
- this.trigger("ready");
- }, 1);
- }
- $(selector, context) {
- return $$1(selector, context || this.contentEl());
- }
- $$(selector, context) {
- return $$$1(selector, context || this.contentEl());
- }
- hasClass(classToCheck) {
- return hasClass$1(this.el_, classToCheck);
- }
- addClass(...classesToAdd) {
- addClass$1(this.el_, ...classesToAdd);
- }
- removeClass(...classesToRemove) {
- removeClass$1(this.el_, ...classesToRemove);
- }
- toggleClass(classToToggle, predicate) {
- toggleClass$1(this.el_, classToToggle, predicate);
- }
- show() {
- this.removeClass("vjs-hidden");
- }
- hide() {
- this.addClass("vjs-hidden");
- }
- lockShowing() {
- this.addClass("vjs-lock-showing");
- }
- unlockShowing() {
- this.removeClass("vjs-lock-showing");
- }
- getAttribute(attribute) {
- return getAttribute$1(this.el_, attribute);
- }
- setAttribute(attribute, value) {
- setAttribute$1(this.el_, attribute, value);
- }
- removeAttribute(attribute) {
- removeAttribute$1(this.el_, attribute);
- }
- width(num, skipListeners) {
- return this.dimension("width", num, skipListeners);
- }
- height(num, skipListeners) {
- return this.dimension("height", num, skipListeners);
- }
- dimensions(width2, height2) {
- this.width(width2, true);
- this.height(height2);
- }
- dimension(widthOrHeight, num, skipListeners) {
- if (num !== void 0) {
- if (num === null || num !== num) {
- num = 0;
- }
- if (("" + num).indexOf("%") !== -1 || ("" + num).indexOf("px") !== -1) {
- this.el_.style[widthOrHeight] = num;
- } else if (num === "auto") {
- this.el_.style[widthOrHeight] = "";
- } else {
- this.el_.style[widthOrHeight] = num + "px";
- }
- if (!skipListeners) {
- this.trigger("componentresize");
- }
- return;
- }
- if (!this.el_) {
- return 0;
- }
- const val = this.el_.style[widthOrHeight];
- const pxIndex = val.indexOf("px");
- if (pxIndex !== -1) {
- return parseInt(val.slice(0, pxIndex), 10);
- }
- return parseInt(this.el_["offset" + toTitleCase$1$1(widthOrHeight)], 10);
- }
- currentDimension(widthOrHeight) {
- let computedWidthOrHeight = 0;
- if (widthOrHeight !== "width" && widthOrHeight !== "height") {
- throw new Error("currentDimension only accepts width or height value");
- }
- computedWidthOrHeight = computedStyle$1(this.el_, widthOrHeight);
- computedWidthOrHeight = parseFloat(computedWidthOrHeight);
- if (computedWidthOrHeight === 0 || isNaN(computedWidthOrHeight)) {
- const rule = `offset${toTitleCase$1$1(widthOrHeight)}`;
- computedWidthOrHeight = this.el_[rule];
- }
- return computedWidthOrHeight;
- }
- currentDimensions() {
- return {
- width: this.currentDimension("width"),
- height: this.currentDimension("height")
- };
- }
- currentWidth() {
- return this.currentDimension("width");
- }
- currentHeight() {
- return this.currentDimension("height");
- }
- focus() {
- this.el_.focus();
- }
- blur() {
- this.el_.blur();
- }
- handleKeyDown(event2) {
- if (this.player_) {
- if (!keycode.isEventKey(event2, "Tab")) {
- event2.stopPropagation();
- }
- this.player_.handleKeyDown(event2);
- }
- }
- handleKeyPress(event2) {
- this.handleKeyDown(event2);
- }
- emitTapEvents() {
- let touchStart = 0;
- let firstTouch = null;
- const tapMovementThreshold = 10;
- const touchTimeThreshold = 200;
- let couldBeTap;
- this.on("touchstart", function(event2) {
- if (event2.touches.length === 1) {
- firstTouch = {
- pageX: event2.touches[0].pageX,
- pageY: event2.touches[0].pageY
- };
- touchStart = window_1.performance.now();
- couldBeTap = true;
- }
- });
- this.on("touchmove", function(event2) {
- if (event2.touches.length > 1) {
- couldBeTap = false;
- } else if (firstTouch) {
- const xdiff = event2.touches[0].pageX - firstTouch.pageX;
- const ydiff = event2.touches[0].pageY - firstTouch.pageY;
- const touchDistance = Math.sqrt(xdiff * xdiff + ydiff * ydiff);
- if (touchDistance > tapMovementThreshold) {
- couldBeTap = false;
- }
- }
- });
- const noTap = function() {
- couldBeTap = false;
- };
- this.on("touchleave", noTap);
- this.on("touchcancel", noTap);
- this.on("touchend", function(event2) {
- firstTouch = null;
- if (couldBeTap === true) {
- const touchTime = window_1.performance.now() - touchStart;
- if (touchTime < touchTimeThreshold) {
- event2.preventDefault();
- this.trigger("tap");
- }
- }
- });
- }
- enableTouchActivity() {
- if (!this.player() || !this.player().reportUserActivity) {
- return;
- }
- const report = bind_(this.player(), this.player().reportUserActivity);
- let touchHolding;
- this.on("touchstart", function() {
- report();
- this.clearInterval(touchHolding);
- touchHolding = this.setInterval(report, 250);
- });
- const touchEnd = function(event2) {
- report();
- this.clearInterval(touchHolding);
- };
- this.on("touchmove", report);
- this.on("touchend", touchEnd);
- this.on("touchcancel", touchEnd);
- }
- setTimeout(fn2, timeout) {
- var timeoutId;
- fn2 = bind_(this, fn2);
- this.clearTimersOnDispose_();
- timeoutId = window_1.setTimeout(() => {
- if (this.setTimeoutIds_.has(timeoutId)) {
- this.setTimeoutIds_.delete(timeoutId);
- }
- fn2();
- }, timeout);
- this.setTimeoutIds_.add(timeoutId);
- return timeoutId;
- }
- clearTimeout(timeoutId) {
- if (this.setTimeoutIds_.has(timeoutId)) {
- this.setTimeoutIds_.delete(timeoutId);
- window_1.clearTimeout(timeoutId);
- }
- return timeoutId;
- }
- setInterval(fn2, interval) {
- fn2 = bind_(this, fn2);
- this.clearTimersOnDispose_();
- const intervalId = window_1.setInterval(fn2, interval);
- this.setIntervalIds_.add(intervalId);
- return intervalId;
- }
- clearInterval(intervalId) {
- if (this.setIntervalIds_.has(intervalId)) {
- this.setIntervalIds_.delete(intervalId);
- window_1.clearInterval(intervalId);
- }
- return intervalId;
- }
- requestAnimationFrame(fn2) {
- this.clearTimersOnDispose_();
- var id;
- fn2 = bind_(this, fn2);
- id = window_1.requestAnimationFrame(() => {
- if (this.rafIds_.has(id)) {
- this.rafIds_.delete(id);
- }
- fn2();
- });
- this.rafIds_.add(id);
- return id;
- }
- requestNamedAnimationFrame(name, fn2) {
- if (this.namedRafs_.has(name)) {
- return;
- }
- this.clearTimersOnDispose_();
- fn2 = bind_(this, fn2);
- const id = this.requestAnimationFrame(() => {
- fn2();
- if (this.namedRafs_.has(name)) {
- this.namedRafs_.delete(name);
- }
- });
- this.namedRafs_.set(name, id);
- return name;
- }
- cancelNamedAnimationFrame(name) {
- if (!this.namedRafs_.has(name)) {
- return;
- }
- this.cancelAnimationFrame(this.namedRafs_.get(name));
- this.namedRafs_.delete(name);
- }
- cancelAnimationFrame(id) {
- if (this.rafIds_.has(id)) {
- this.rafIds_.delete(id);
- window_1.cancelAnimationFrame(id);
- }
- return id;
- }
- clearTimersOnDispose_() {
- if (this.clearingTimersOnDispose_) {
- return;
- }
- this.clearingTimersOnDispose_ = true;
- this.one("dispose", () => {
- [["namedRafs_", "cancelNamedAnimationFrame"], ["rafIds_", "cancelAnimationFrame"], ["setTimeoutIds_", "clearTimeout"], ["setIntervalIds_", "clearInterval"]].forEach(([idName, cancelName]) => {
- this[idName].forEach((val, key) => this[cancelName](key));
- });
- this.clearingTimersOnDispose_ = false;
- });
- }
- static registerComponent(name, ComponentToRegister) {
- if (typeof name !== "string" || !name) {
- throw new Error(`Illegal component name, "${name}"; must be a non-empty string.`);
- }
- const Tech2 = Component$1$1.getComponent("Tech");
- const isTech = Tech2 && Tech2.isTech(ComponentToRegister);
- const isComp = Component$1$1 === ComponentToRegister || Component$1$1.prototype.isPrototypeOf(ComponentToRegister.prototype);
- if (isTech || !isComp) {
- let reason;
- if (isTech) {
- reason = "techs must be registered using Tech.registerTech()";
- } else {
- reason = "must be a Component subclass";
- }
- throw new Error(`Illegal component, "${name}"; ${reason}.`);
- }
- name = toTitleCase$1$1(name);
- if (!Component$1$1.components_) {
- Component$1$1.components_ = {};
- }
- const Player2 = Component$1$1.getComponent("Player");
- if (name === "Player" && Player2 && Player2.players) {
- const players = Player2.players;
- const playerNames = Object.keys(players);
- if (players && playerNames.length > 0 && playerNames.map((pname) => players[pname]).every(Boolean)) {
- throw new Error("Can not register Player component after player has been created.");
- }
- }
- Component$1$1.components_[name] = ComponentToRegister;
- Component$1$1.components_[toLowerCase$1(name)] = ComponentToRegister;
- return ComponentToRegister;
- }
- static getComponent(name) {
- if (!name || !Component$1$1.components_) {
- return;
- }
- return Component$1$1.components_[name];
- }
- }
- Component$1$1.registerComponent("Component", Component$1$1);
- function rangeCheck$1(fnName, index2, maxIndex) {
- if (typeof index2 !== "number" || index2 < 0 || index2 > maxIndex) {
- throw new Error(`Failed to execute '${fnName}' on 'TimeRanges': The index provided (${index2}) is non-numeric or out of bounds (0-${maxIndex}).`);
- }
- }
- function getRange$1(fnName, valueIndex, ranges, rangeIndex) {
- rangeCheck$1(fnName, rangeIndex, ranges.length - 1);
- return ranges[rangeIndex][valueIndex];
- }
- function createTimeRangesObj$1(ranges) {
- let timeRangesObj;
- if (ranges === void 0 || ranges.length === 0) {
- timeRangesObj = {
- length: 0,
- start() {
- throw new Error("This TimeRanges object is empty");
- },
- end() {
- throw new Error("This TimeRanges object is empty");
- }
- };
- } else {
- timeRangesObj = {
- length: ranges.length,
- start: getRange$1.bind(null, "start", 0, ranges),
- end: getRange$1.bind(null, "end", 1, ranges)
- };
- }
- if (window_1.Symbol && window_1.Symbol.iterator) {
- timeRangesObj[window_1.Symbol.iterator] = () => (ranges || []).values();
- }
- return timeRangesObj;
- }
- function createTimeRanges$1(start2, end) {
- if (Array.isArray(start2)) {
- return createTimeRangesObj$1(start2);
- } else if (start2 === void 0 || end === void 0) {
- return createTimeRangesObj$1();
- }
- return createTimeRangesObj$1([[start2, end]]);
- }
- const defaultImplementation$1 = function(seconds, guide) {
- seconds = seconds < 0 ? 0 : seconds;
- let s = Math.floor(seconds % 60);
- let m = Math.floor(seconds / 60 % 60);
- let h2 = Math.floor(seconds / 3600);
- const gm = Math.floor(guide / 60 % 60);
- const gh = Math.floor(guide / 3600);
- if (isNaN(seconds) || seconds === Infinity) {
- h2 = m = s = "-";
- }
- h2 = h2 > 0 || gh > 0 ? h2 + ":" : "";
- m = ((h2 || gm >= 10) && m < 10 ? "0" + m : m) + ":";
- s = s < 10 ? "0" + s : s;
- return h2 + m + s;
- };
- let implementation$1 = defaultImplementation$1;
- function setFormatTime$1(customImplementation) {
- implementation$1 = customImplementation;
- }
- function resetFormatTime$1() {
- implementation$1 = defaultImplementation$1;
- }
- function formatTime$1(seconds, guide = seconds) {
- return implementation$1(seconds, guide);
- }
- var Time = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- createTimeRanges: createTimeRanges$1,
- createTimeRange: createTimeRanges$1,
- setFormatTime: setFormatTime$1,
- resetFormatTime: resetFormatTime$1,
- formatTime: formatTime$1
- });
- function bufferedPercent$1(buffered, duration5) {
- let bufferedDuration = 0;
- let start2;
- let end;
- if (!duration5) {
- return 0;
- }
- if (!buffered || !buffered.length) {
- buffered = createTimeRanges$1(0, 0);
- }
- for (let i2 = 0; i2 < buffered.length; i2++) {
- start2 = buffered.start(i2);
- end = buffered.end(i2);
- if (end > duration5) {
- end = duration5;
- }
- bufferedDuration += end - start2;
- }
- return bufferedDuration / duration5;
- }
- function MediaError$1(value) {
- if (value instanceof MediaError$1) {
- return value;
- }
- if (typeof value === "number") {
- this.code = value;
- } else if (typeof value === "string") {
- this.message = value;
- } else if (isObject$2(value)) {
- if (typeof value.code === "number") {
- this.code = value.code;
- }
- Object.assign(this, value);
- }
- if (!this.message) {
- this.message = MediaError$1.defaultMessages[this.code] || "";
- }
- }
- MediaError$1.prototype.code = 0;
- MediaError$1.prototype.message = "";
- MediaError$1.prototype.status = null;
- MediaError$1.errorTypes = ["MEDIA_ERR_CUSTOM", "MEDIA_ERR_ABORTED", "MEDIA_ERR_NETWORK", "MEDIA_ERR_DECODE", "MEDIA_ERR_SRC_NOT_SUPPORTED", "MEDIA_ERR_ENCRYPTED"];
- MediaError$1.defaultMessages = {
- 1: "You aborted the media playback",
- 2: "A network error caused the media download to fail part-way.",
- 3: "The media playback was aborted due to a corruption problem or because the media used features your browser did not support.",
- 4: "The media could not be loaded, either because the server or network failed or because the format is not supported.",
- 5: "The media is encrypted and we do not have the keys to decrypt it."
- };
- for (let errNum = 0; errNum < MediaError$1.errorTypes.length; errNum++) {
- MediaError$1[MediaError$1.errorTypes[errNum]] = errNum;
- MediaError$1.prototype[MediaError$1.errorTypes[errNum]] = errNum;
- }
- function isPromise$1(value) {
- return value !== void 0 && value !== null && typeof value.then === "function";
- }
- function silencePromise$1(value) {
- if (isPromise$1(value)) {
- value.then(null, (e) => {
- });
- }
- }
- const trackToJson_$1 = function(track) {
- const ret = ["kind", "label", "language", "id", "inBandMetadataTrackDispatchType", "mode", "src"].reduce((acc, prop, i2) => {
- if (track[prop]) {
- acc[prop] = track[prop];
- }
- return acc;
- }, {
- cues: track.cues && Array.prototype.map.call(track.cues, function(cue) {
- return {
- startTime: cue.startTime,
- endTime: cue.endTime,
- text: cue.text,
- id: cue.id
- };
- })
- });
- return ret;
- };
- const textTracksToJson$1 = function(tech) {
- const trackEls = tech.$$("track");
- const trackObjs = Array.prototype.map.call(trackEls, (t2) => t2.track);
- const tracks = Array.prototype.map.call(trackEls, function(trackEl) {
- const json = trackToJson_$1(trackEl.track);
- if (trackEl.src) {
- json.src = trackEl.src;
- }
- return json;
- });
- return tracks.concat(Array.prototype.filter.call(tech.textTracks(), function(track) {
- return trackObjs.indexOf(track) === -1;
- }).map(trackToJson_$1));
- };
- const jsonToTextTracks$1 = function(json, tech) {
- json.forEach(function(track) {
- const addedTrack = tech.addRemoteTextTrack(track).track;
- if (!track.src && track.cues) {
- track.cues.forEach((cue) => addedTrack.addCue(cue));
- }
- });
- return tech.textTracks();
- };
- var textTrackConverter$1 = {
- textTracksToJson: textTracksToJson$1,
- jsonToTextTracks: jsonToTextTracks$1,
- trackToJson_: trackToJson_$1
- };
- const MODAL_CLASS_NAME$1 = "vjs-modal-dialog";
- class ModalDialog$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.handleKeyDown_ = (e) => this.handleKeyDown(e);
- this.close_ = (e) => this.close(e);
- this.opened_ = this.hasBeenOpened_ = this.hasBeenFilled_ = false;
- this.closeable(!this.options_.uncloseable);
- this.content(this.options_.content);
- this.contentEl_ = createEl$1("div", {
- className: `${MODAL_CLASS_NAME$1}-content`
- }, {
- role: "document"
- });
- this.descEl_ = createEl$1("p", {
- className: `${MODAL_CLASS_NAME$1}-description vjs-control-text`,
- id: this.el().getAttribute("aria-describedby")
- });
- textContent$1(this.descEl_, this.description());
- this.el_.appendChild(this.descEl_);
- this.el_.appendChild(this.contentEl_);
- }
- createEl() {
- return super.createEl("div", {
- className: this.buildCSSClass(),
- tabIndex: -1
- }, {
- "aria-describedby": `${this.id()}_description`,
- "aria-hidden": "true",
- "aria-label": this.label(),
- "role": "dialog"
- });
- }
- dispose() {
- this.contentEl_ = null;
- this.descEl_ = null;
- this.previouslyActiveEl_ = null;
- super.dispose();
- }
- buildCSSClass() {
- return `${MODAL_CLASS_NAME$1} vjs-hidden ${super.buildCSSClass()}`;
- }
- label() {
- return this.localize(this.options_.label || "Modal Window");
- }
- description() {
- let desc = this.options_.description || this.localize("This is a modal window.");
- if (this.closeable()) {
- desc += " " + this.localize("This modal can be closed by pressing the Escape key or activating the close button.");
- }
- return desc;
- }
- open() {
- if (!this.opened_) {
- const player = this.player();
- this.trigger("beforemodalopen");
- this.opened_ = true;
- if (this.options_.fillAlways || !this.hasBeenOpened_ && !this.hasBeenFilled_) {
- this.fill();
- }
- this.wasPlaying_ = !player.paused();
- if (this.options_.pauseOnOpen && this.wasPlaying_) {
- player.pause();
- }
- this.on("keydown", this.handleKeyDown_);
- this.hadControls_ = player.controls();
- player.controls(false);
- this.show();
- this.conditionalFocus_();
- this.el().setAttribute("aria-hidden", "false");
- this.trigger("modalopen");
- this.hasBeenOpened_ = true;
- }
- }
- opened(value) {
- if (typeof value === "boolean") {
- this[value ? "open" : "close"]();
- }
- return this.opened_;
- }
- close() {
- if (!this.opened_) {
- return;
- }
- const player = this.player();
- this.trigger("beforemodalclose");
- this.opened_ = false;
- if (this.wasPlaying_ && this.options_.pauseOnOpen) {
- player.play();
- }
- this.off("keydown", this.handleKeyDown_);
- if (this.hadControls_) {
- player.controls(true);
- }
- this.hide();
- this.el().setAttribute("aria-hidden", "true");
- this.trigger("modalclose");
- this.conditionalBlur_();
- if (this.options_.temporary) {
- this.dispose();
- }
- }
- closeable(value) {
- if (typeof value === "boolean") {
- const closeable = this.closeable_ = !!value;
- let close = this.getChild("closeButton");
- if (closeable && !close) {
- const temp = this.contentEl_;
- this.contentEl_ = this.el_;
- close = this.addChild("closeButton", {
- controlText: "Close Modal Dialog"
- });
- this.contentEl_ = temp;
- this.on(close, "close", this.close_);
- }
- if (!closeable && close) {
- this.off(close, "close", this.close_);
- this.removeChild(close);
- close.dispose();
- }
- }
- return this.closeable_;
- }
- fill() {
- this.fillWith(this.content());
- }
- fillWith(content) {
- const contentEl = this.contentEl();
- const parentEl = contentEl.parentNode;
- const nextSiblingEl = contentEl.nextSibling;
- this.trigger("beforemodalfill");
- this.hasBeenFilled_ = true;
- parentEl.removeChild(contentEl);
- this.empty();
- insertContent$1(contentEl, content);
- this.trigger("modalfill");
- if (nextSiblingEl) {
- parentEl.insertBefore(contentEl, nextSiblingEl);
- } else {
- parentEl.appendChild(contentEl);
- }
- const closeButton = this.getChild("closeButton");
- if (closeButton) {
- parentEl.appendChild(closeButton.el_);
- }
- }
- empty() {
- this.trigger("beforemodalempty");
- emptyEl$1(this.contentEl());
- this.trigger("modalempty");
- }
- content(value) {
- if (typeof value !== "undefined") {
- this.content_ = value;
- }
- return this.content_;
- }
- conditionalFocus_() {
- const activeEl = document_1.activeElement;
- const playerEl = this.player_.el_;
- this.previouslyActiveEl_ = null;
- if (playerEl.contains(activeEl) || playerEl === activeEl) {
- this.previouslyActiveEl_ = activeEl;
- this.focus();
- }
- }
- conditionalBlur_() {
- if (this.previouslyActiveEl_) {
- this.previouslyActiveEl_.focus();
- this.previouslyActiveEl_ = null;
- }
- }
- handleKeyDown(event2) {
- event2.stopPropagation();
- if (keycode.isEventKey(event2, "Escape") && this.closeable()) {
- event2.preventDefault();
- this.close();
- return;
- }
- if (!keycode.isEventKey(event2, "Tab")) {
- return;
- }
- const focusableEls = this.focusableEls_();
- const activeEl = this.el_.querySelector(":focus");
- let focusIndex;
- for (let i2 = 0; i2 < focusableEls.length; i2++) {
- if (activeEl === focusableEls[i2]) {
- focusIndex = i2;
- break;
- }
- }
- if (document_1.activeElement === this.el_) {
- focusIndex = 0;
- }
- if (event2.shiftKey && focusIndex === 0) {
- focusableEls[focusableEls.length - 1].focus();
- event2.preventDefault();
- } else if (!event2.shiftKey && focusIndex === focusableEls.length - 1) {
- focusableEls[0].focus();
- event2.preventDefault();
- }
- }
- focusableEls_() {
- const allChildren = this.el_.querySelectorAll("*");
- return Array.prototype.filter.call(allChildren, (child) => {
- return (child instanceof window_1.HTMLAnchorElement || child instanceof window_1.HTMLAreaElement) && child.hasAttribute("href") || (child instanceof window_1.HTMLInputElement || child instanceof window_1.HTMLSelectElement || child instanceof window_1.HTMLTextAreaElement || child instanceof window_1.HTMLButtonElement) && !child.hasAttribute("disabled") || child instanceof window_1.HTMLIFrameElement || child instanceof window_1.HTMLObjectElement || child instanceof window_1.HTMLEmbedElement || child.hasAttribute("tabindex") && child.getAttribute("tabindex") !== -1 || child.hasAttribute("contenteditable");
- });
- }
- }
- ModalDialog$1.prototype.options_ = {
- pauseOnOpen: true,
- temporary: true
- };
- Component$1$1.registerComponent("ModalDialog", ModalDialog$1);
- class TrackList$1 extends EventTarget$2$1 {
- constructor(tracks = []) {
- super();
- this.tracks_ = [];
- Object.defineProperty(this, "length", {
- get() {
- return this.tracks_.length;
- }
- });
- for (let i2 = 0; i2 < tracks.length; i2++) {
- this.addTrack(tracks[i2]);
- }
- }
- addTrack(track) {
- const index2 = this.tracks_.length;
- if (!("" + index2 in this)) {
- Object.defineProperty(this, index2, {
- get() {
- return this.tracks_[index2];
- }
- });
- }
- if (this.tracks_.indexOf(track) === -1) {
- this.tracks_.push(track);
- this.trigger({
- track,
- type: "addtrack",
- target: this
- });
- }
- track.labelchange_ = () => {
- this.trigger({
- track,
- type: "labelchange",
- target: this
- });
- };
- if (isEvented$1(track)) {
- track.addEventListener("labelchange", track.labelchange_);
- }
- }
- removeTrack(rtrack) {
- let track;
- for (let i2 = 0, l = this.length; i2 < l; i2++) {
- if (this[i2] === rtrack) {
- track = this[i2];
- if (track.off) {
- track.off();
- }
- this.tracks_.splice(i2, 1);
- break;
- }
- }
- if (!track) {
- return;
- }
- this.trigger({
- track,
- type: "removetrack",
- target: this
- });
- }
- getTrackById(id) {
- let result = null;
- for (let i2 = 0, l = this.length; i2 < l; i2++) {
- const track = this[i2];
- if (track.id === id) {
- result = track;
- break;
- }
- }
- return result;
- }
- }
- TrackList$1.prototype.allowedEvents_ = {
- change: "change",
- addtrack: "addtrack",
- removetrack: "removetrack",
- labelchange: "labelchange"
- };
- for (const event2 in TrackList$1.prototype.allowedEvents_) {
- TrackList$1.prototype["on" + event2] = null;
- }
- const disableOthers$1$1 = function(list, track) {
- for (let i2 = 0; i2 < list.length; i2++) {
- if (!Object.keys(list[i2]).length || track.id === list[i2].id) {
- continue;
- }
- list[i2].enabled = false;
- }
- };
- class AudioTrackList$1 extends TrackList$1 {
- constructor(tracks = []) {
- for (let i2 = tracks.length - 1; i2 >= 0; i2--) {
- if (tracks[i2].enabled) {
- disableOthers$1$1(tracks, tracks[i2]);
- break;
- }
- }
- super(tracks);
- this.changing_ = false;
- }
- addTrack(track) {
- if (track.enabled) {
- disableOthers$1$1(this, track);
- }
- super.addTrack(track);
- if (!track.addEventListener) {
- return;
- }
- track.enabledChange_ = () => {
- if (this.changing_) {
- return;
- }
- this.changing_ = true;
- disableOthers$1$1(this, track);
- this.changing_ = false;
- this.trigger("change");
- };
- track.addEventListener("enabledchange", track.enabledChange_);
- }
- removeTrack(rtrack) {
- super.removeTrack(rtrack);
- if (rtrack.removeEventListener && rtrack.enabledChange_) {
- rtrack.removeEventListener("enabledchange", rtrack.enabledChange_);
- rtrack.enabledChange_ = null;
- }
- }
- }
- const disableOthers$2 = function(list, track) {
- for (let i2 = 0; i2 < list.length; i2++) {
- if (!Object.keys(list[i2]).length || track.id === list[i2].id) {
- continue;
- }
- list[i2].selected = false;
- }
- };
- class VideoTrackList$1 extends TrackList$1 {
- constructor(tracks = []) {
- for (let i2 = tracks.length - 1; i2 >= 0; i2--) {
- if (tracks[i2].selected) {
- disableOthers$2(tracks, tracks[i2]);
- break;
- }
- }
- super(tracks);
- this.changing_ = false;
- Object.defineProperty(this, "selectedIndex", {
- get() {
- for (let i2 = 0; i2 < this.length; i2++) {
- if (this[i2].selected) {
- return i2;
- }
- }
- return -1;
- },
- set() {
- }
- });
- }
- addTrack(track) {
- if (track.selected) {
- disableOthers$2(this, track);
- }
- super.addTrack(track);
- if (!track.addEventListener) {
- return;
- }
- track.selectedChange_ = () => {
- if (this.changing_) {
- return;
- }
- this.changing_ = true;
- disableOthers$2(this, track);
- this.changing_ = false;
- this.trigger("change");
- };
- track.addEventListener("selectedchange", track.selectedChange_);
- }
- removeTrack(rtrack) {
- super.removeTrack(rtrack);
- if (rtrack.removeEventListener && rtrack.selectedChange_) {
- rtrack.removeEventListener("selectedchange", rtrack.selectedChange_);
- rtrack.selectedChange_ = null;
- }
- }
- }
- class TextTrackList$1 extends TrackList$1 {
- addTrack(track) {
- super.addTrack(track);
- if (!this.queueChange_) {
- this.queueChange_ = () => this.queueTrigger("change");
- }
- if (!this.triggerSelectedlanguagechange) {
- this.triggerSelectedlanguagechange_ = () => this.trigger("selectedlanguagechange");
- }
- track.addEventListener("modechange", this.queueChange_);
- const nonLanguageTextTrackKind = ["metadata", "chapters"];
- if (nonLanguageTextTrackKind.indexOf(track.kind) === -1) {
- track.addEventListener("modechange", this.triggerSelectedlanguagechange_);
- }
- }
- removeTrack(rtrack) {
- super.removeTrack(rtrack);
- if (rtrack.removeEventListener) {
- if (this.queueChange_) {
- rtrack.removeEventListener("modechange", this.queueChange_);
- }
- if (this.selectedlanguagechange_) {
- rtrack.removeEventListener("modechange", this.triggerSelectedlanguagechange_);
- }
- }
- }
- }
- class HtmlTrackElementList$1 {
- constructor(trackElements = []) {
- this.trackElements_ = [];
- Object.defineProperty(this, "length", {
- get() {
- return this.trackElements_.length;
- }
- });
- for (let i2 = 0, length = trackElements.length; i2 < length; i2++) {
- this.addTrackElement_(trackElements[i2]);
- }
- }
- addTrackElement_(trackElement) {
- const index2 = this.trackElements_.length;
- if (!("" + index2 in this)) {
- Object.defineProperty(this, index2, {
- get() {
- return this.trackElements_[index2];
- }
- });
- }
- if (this.trackElements_.indexOf(trackElement) === -1) {
- this.trackElements_.push(trackElement);
- }
- }
- getTrackElementByTrack_(track) {
- let trackElement_;
- for (let i2 = 0, length = this.trackElements_.length; i2 < length; i2++) {
- if (track === this.trackElements_[i2].track) {
- trackElement_ = this.trackElements_[i2];
- break;
- }
- }
- return trackElement_;
- }
- removeTrackElement_(trackElement) {
- for (let i2 = 0, length = this.trackElements_.length; i2 < length; i2++) {
- if (trackElement === this.trackElements_[i2]) {
- if (this.trackElements_[i2].track && typeof this.trackElements_[i2].track.off === "function") {
- this.trackElements_[i2].track.off();
- }
- if (typeof this.trackElements_[i2].off === "function") {
- this.trackElements_[i2].off();
- }
- this.trackElements_.splice(i2, 1);
- break;
- }
- }
- }
- }
- class TextTrackCueList$1 {
- constructor(cues) {
- TextTrackCueList$1.prototype.setCues_.call(this, cues);
- Object.defineProperty(this, "length", {
- get() {
- return this.length_;
- }
- });
- }
- setCues_(cues) {
- const oldLength = this.length || 0;
- let i2 = 0;
- const l = cues.length;
- this.cues_ = cues;
- this.length_ = cues.length;
- const defineProp = function(index2) {
- if (!("" + index2 in this)) {
- Object.defineProperty(this, "" + index2, {
- get() {
- return this.cues_[index2];
- }
- });
- }
- };
- if (oldLength < l) {
- i2 = oldLength;
- for (; i2 < l; i2++) {
- defineProp.call(this, i2);
- }
- }
- }
- getCueById(id) {
- let result = null;
- for (let i2 = 0, l = this.length; i2 < l; i2++) {
- const cue = this[i2];
- if (cue.id === id) {
- result = cue;
- break;
- }
- }
- return result;
- }
- }
- const VideoTrackKind$1 = {
- alternative: "alternative",
- captions: "captions",
- main: "main",
- sign: "sign",
- subtitles: "subtitles",
- commentary: "commentary"
- };
- const AudioTrackKind$1 = {
- "alternative": "alternative",
- "descriptions": "descriptions",
- "main": "main",
- "main-desc": "main-desc",
- "translation": "translation",
- "commentary": "commentary"
- };
- const TextTrackKind$1 = {
- subtitles: "subtitles",
- captions: "captions",
- descriptions: "descriptions",
- chapters: "chapters",
- metadata: "metadata"
- };
- const TextTrackMode$1 = {
- disabled: "disabled",
- hidden: "hidden",
- showing: "showing"
- };
- class Track$1 extends EventTarget$2$1 {
- constructor(options2 = {}) {
- super();
- const trackProps = {
- id: options2.id || "vjs_track_" + newGUID$1(),
- kind: options2.kind || "",
- language: options2.language || ""
- };
- let label2 = options2.label || "";
- for (const key in trackProps) {
- Object.defineProperty(this, key, {
- get() {
- return trackProps[key];
- },
- set() {
- }
- });
- }
- Object.defineProperty(this, "label", {
- get() {
- return label2;
- },
- set(newLabel) {
- if (newLabel !== label2) {
- label2 = newLabel;
- this.trigger("labelchange");
- }
- }
- });
- }
- }
- const parseUrl$1 = function(url) {
- const props = ["protocol", "hostname", "port", "pathname", "search", "hash", "host"];
- const a = document_1.createElement("a");
- a.href = url;
- const details = {};
- for (let i2 = 0; i2 < props.length; i2++) {
- details[props[i2]] = a[props[i2]];
- }
- if (details.protocol === "http:") {
- details.host = details.host.replace(/:80$/, "");
- }
- if (details.protocol === "https:") {
- details.host = details.host.replace(/:443$/, "");
- }
- if (!details.protocol) {
- details.protocol = window_1.location.protocol;
- }
- if (!details.host) {
- details.host = window_1.location.host;
- }
- return details;
- };
- const getAbsoluteURL$1 = function(url) {
- if (!url.match(/^https?:\/\//)) {
- const a = document_1.createElement("a");
- a.href = url;
- url = a.href;
- }
- return url;
- };
- const getFileExtension$1 = function(path) {
- if (typeof path === "string") {
- const splitPathRe = /^(\/?)([\s\S]*?)((?:\.{1,2}|[^\/]+?)(\.([^\.\/\?]+)))(?:[\/]*|[\?].*)$/;
- const pathParts = splitPathRe.exec(path);
- if (pathParts) {
- return pathParts.pop().toLowerCase();
- }
- }
- return "";
- };
- const isCrossOrigin$1 = function(url, winLoc = window_1.location) {
- const urlInfo = parseUrl$1(url);
- const srcProtocol = urlInfo.protocol === ":" ? winLoc.protocol : urlInfo.protocol;
- const crossOrigin = srcProtocol + urlInfo.host !== winLoc.protocol + winLoc.host;
- return crossOrigin;
- };
- var Url$2 = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- parseUrl: parseUrl$1,
- getAbsoluteURL: getAbsoluteURL$1,
- getFileExtension: getFileExtension$1,
- isCrossOrigin: isCrossOrigin$1
- });
- const parseCues$1 = function(srcContent, track) {
- const parser2 = new window_1.WebVTT.Parser(window_1, window_1.vttjs, window_1.WebVTT.StringDecoder());
- const errors2 = [];
- parser2.oncue = function(cue) {
- track.addCue(cue);
- };
- parser2.onparsingerror = function(error) {
- errors2.push(error);
- };
- parser2.onflush = function() {
- track.trigger({
- type: "loadeddata",
- target: track
- });
- };
- parser2.parse(srcContent);
- if (errors2.length > 0) {
- if (window_1.console && window_1.console.groupCollapsed) {
- window_1.console.groupCollapsed(`Text Track parsing errors for ${track.src}`);
- }
- errors2.forEach((error) => log$1$1.error(error));
- if (window_1.console && window_1.console.groupEnd) {
- window_1.console.groupEnd();
- }
- }
- parser2.flush();
- };
- const loadTrack$1 = function(src, track) {
- const opts = {
- uri: src
- };
- const crossOrigin = isCrossOrigin$1(src);
- if (crossOrigin) {
- opts.cors = crossOrigin;
- }
- const withCredentials = track.tech_.crossOrigin() === "use-credentials";
- if (withCredentials) {
- opts.withCredentials = withCredentials;
- }
- XHR(opts, bind_(this, function(err, response, responseBody) {
- if (err) {
- return log$1$1.error(err, response);
- }
- track.loaded_ = true;
- if (typeof window_1.WebVTT !== "function") {
- if (track.tech_) {
- track.tech_.any(["vttjsloaded", "vttjserror"], (event2) => {
- if (event2.type === "vttjserror") {
- log$1$1.error(`vttjs failed to load, stopping trying to process ${track.src}`);
- return;
- }
- return parseCues$1(responseBody, track);
- });
- }
- } else {
- parseCues$1(responseBody, track);
- }
- }));
- };
- class TextTrack$1 extends Track$1 {
- constructor(options2 = {}) {
- if (!options2.tech) {
- throw new Error("A tech was not provided.");
- }
- const settings = merge$1(options2, {
- kind: TextTrackKind$1[options2.kind] || "subtitles",
- language: options2.language || options2.srclang || ""
- });
- let mode = TextTrackMode$1[settings.mode] || "disabled";
- const default_ = settings.default;
- if (settings.kind === "metadata" || settings.kind === "chapters") {
- mode = "hidden";
- }
- super(settings);
- this.tech_ = settings.tech;
- this.cues_ = [];
- this.activeCues_ = [];
- this.preload_ = this.tech_.preloadTextTracks !== false;
- const cues = new TextTrackCueList$1(this.cues_);
- const activeCues = new TextTrackCueList$1(this.activeCues_);
- let changed = false;
- this.timeupdateHandler = bind_(this, function(event2 = {}) {
- if (this.tech_.isDisposed()) {
- return;
- }
- if (!this.tech_.isReady_) {
- if (event2.type !== "timeupdate") {
- this.rvf_ = this.tech_.requestVideoFrameCallback(this.timeupdateHandler);
- }
- return;
- }
- this.activeCues = this.activeCues;
- if (changed) {
- this.trigger("cuechange");
- changed = false;
- }
- if (event2.type !== "timeupdate") {
- this.rvf_ = this.tech_.requestVideoFrameCallback(this.timeupdateHandler);
- }
- });
- const disposeHandler = () => {
- this.stopTracking();
- };
- this.tech_.one("dispose", disposeHandler);
- if (mode !== "disabled") {
- this.startTracking();
- }
- Object.defineProperties(this, {
- default: {
- get() {
- return default_;
- },
- set() {
- }
- },
- mode: {
- get() {
- return mode;
- },
- set(newMode) {
- if (!TextTrackMode$1[newMode]) {
- return;
- }
- if (mode === newMode) {
- return;
- }
- mode = newMode;
- if (!this.preload_ && mode !== "disabled" && this.cues.length === 0) {
- loadTrack$1(this.src, this);
- }
- this.stopTracking();
- if (mode !== "disabled") {
- this.startTracking();
- }
- this.trigger("modechange");
- }
- },
- cues: {
- get() {
- if (!this.loaded_) {
- return null;
- }
- return cues;
- },
- set() {
- }
- },
- activeCues: {
- get() {
- if (!this.loaded_) {
- return null;
- }
- if (this.cues.length === 0) {
- return activeCues;
- }
- const ct2 = this.tech_.currentTime();
- const active = [];
- for (let i2 = 0, l = this.cues.length; i2 < l; i2++) {
- const cue = this.cues[i2];
- if (cue.startTime <= ct2 && cue.endTime >= ct2) {
- active.push(cue);
- }
- }
- changed = false;
- if (active.length !== this.activeCues_.length) {
- changed = true;
- } else {
- for (let i2 = 0; i2 < active.length; i2++) {
- if (this.activeCues_.indexOf(active[i2]) === -1) {
- changed = true;
- }
- }
- }
- this.activeCues_ = active;
- activeCues.setCues_(this.activeCues_);
- return activeCues;
- },
- set() {
- }
- }
- });
- if (settings.src) {
- this.src = settings.src;
- if (!this.preload_) {
- this.loaded_ = true;
- }
- if (this.preload_ || settings.kind !== "subtitles" && settings.kind !== "captions") {
- loadTrack$1(this.src, this);
- }
- } else {
- this.loaded_ = true;
- }
- }
- startTracking() {
- this.rvf_ = this.tech_.requestVideoFrameCallback(this.timeupdateHandler);
- this.tech_.on("timeupdate", this.timeupdateHandler);
- }
- stopTracking() {
- if (this.rvf_) {
- this.tech_.cancelVideoFrameCallback(this.rvf_);
- this.rvf_ = void 0;
- }
- this.tech_.off("timeupdate", this.timeupdateHandler);
- }
- addCue(originalCue) {
- let cue = originalCue;
- if (window_1.vttjs && !(originalCue instanceof window_1.vttjs.VTTCue)) {
- cue = new window_1.vttjs.VTTCue(originalCue.startTime, originalCue.endTime, originalCue.text);
- for (const prop in originalCue) {
- if (!(prop in cue)) {
- cue[prop] = originalCue[prop];
- }
- }
- cue.id = originalCue.id;
- cue.originalCue_ = originalCue;
- }
- const tracks = this.tech_.textTracks();
- for (let i2 = 0; i2 < tracks.length; i2++) {
- if (tracks[i2] !== this) {
- tracks[i2].removeCue(cue);
- }
- }
- this.cues_.push(cue);
- this.cues.setCues_(this.cues_);
- }
- removeCue(removeCue) {
- let i2 = this.cues_.length;
- while (i2--) {
- const cue = this.cues_[i2];
- if (cue === removeCue || cue.originalCue_ && cue.originalCue_ === removeCue) {
- this.cues_.splice(i2, 1);
- this.cues.setCues_(this.cues_);
- break;
- }
- }
- }
- }
- TextTrack$1.prototype.allowedEvents_ = {
- cuechange: "cuechange"
- };
- class AudioTrack$1 extends Track$1 {
- constructor(options2 = {}) {
- const settings = merge$1(options2, {
- kind: AudioTrackKind$1[options2.kind] || ""
- });
- super(settings);
- let enabled = false;
- Object.defineProperty(this, "enabled", {
- get() {
- return enabled;
- },
- set(newEnabled) {
- if (typeof newEnabled !== "boolean" || newEnabled === enabled) {
- return;
- }
- enabled = newEnabled;
- this.trigger("enabledchange");
- }
- });
- if (settings.enabled) {
- this.enabled = settings.enabled;
- }
- this.loaded_ = true;
- }
- }
- class VideoTrack$1 extends Track$1 {
- constructor(options2 = {}) {
- const settings = merge$1(options2, {
- kind: VideoTrackKind$1[options2.kind] || ""
- });
- super(settings);
- let selected = false;
- Object.defineProperty(this, "selected", {
- get() {
- return selected;
- },
- set(newSelected) {
- if (typeof newSelected !== "boolean" || newSelected === selected) {
- return;
- }
- selected = newSelected;
- this.trigger("selectedchange");
- }
- });
- if (settings.selected) {
- this.selected = settings.selected;
- }
- }
- }
- class HTMLTrackElement$1 extends EventTarget$2$1 {
- constructor(options2 = {}) {
- super();
- let readyState;
- const track = new TextTrack$1(options2);
- this.kind = track.kind;
- this.src = track.src;
- this.srclang = track.language;
- this.label = track.label;
- this.default = track.default;
- Object.defineProperties(this, {
- readyState: {
- get() {
- return readyState;
- }
- },
- track: {
- get() {
- return track;
- }
- }
- });
- readyState = HTMLTrackElement$1.NONE;
- track.addEventListener("loadeddata", () => {
- readyState = HTMLTrackElement$1.LOADED;
- this.trigger({
- type: "load",
- target: this
- });
- });
- }
- }
- HTMLTrackElement$1.prototype.allowedEvents_ = {
- load: "load"
- };
- HTMLTrackElement$1.NONE = 0;
- HTMLTrackElement$1.LOADING = 1;
- HTMLTrackElement$1.LOADED = 2;
- HTMLTrackElement$1.ERROR = 3;
- const NORMAL$1 = {
- audio: {
- ListClass: AudioTrackList$1,
- TrackClass: AudioTrack$1,
- capitalName: "Audio"
- },
- video: {
- ListClass: VideoTrackList$1,
- TrackClass: VideoTrack$1,
- capitalName: "Video"
- },
- text: {
- ListClass: TextTrackList$1,
- TrackClass: TextTrack$1,
- capitalName: "Text"
- }
- };
- Object.keys(NORMAL$1).forEach(function(type2) {
- NORMAL$1[type2].getterName = `${type2}Tracks`;
- NORMAL$1[type2].privateName = `${type2}Tracks_`;
- });
- const REMOTE$1 = {
- remoteText: {
- ListClass: TextTrackList$1,
- TrackClass: TextTrack$1,
- capitalName: "RemoteText",
- getterName: "remoteTextTracks",
- privateName: "remoteTextTracks_"
- },
- remoteTextEl: {
- ListClass: HtmlTrackElementList$1,
- TrackClass: HTMLTrackElement$1,
- capitalName: "RemoteTextTrackEls",
- getterName: "remoteTextTrackEls",
- privateName: "remoteTextTrackEls_"
- }
- };
- const ALL$1 = Object.assign({}, NORMAL$1, REMOTE$1);
- REMOTE$1.names = Object.keys(REMOTE$1);
- NORMAL$1.names = Object.keys(NORMAL$1);
- ALL$1.names = [].concat(REMOTE$1.names).concat(NORMAL$1.names);
- function createTrackHelper$1(self2, kind, label2, language, options2 = {}) {
- const tracks = self2.textTracks();
- options2.kind = kind;
- if (label2) {
- options2.label = label2;
- }
- if (language) {
- options2.language = language;
- }
- options2.tech = self2;
- const track = new ALL$1.text.TrackClass(options2);
- tracks.addTrack(track);
- return track;
- }
- class Tech$2 extends Component$1$1 {
- constructor(options2 = {}, ready = function() {
- }) {
- options2.reportTouchActivity = false;
- super(null, options2, ready);
- this.onDurationChange_ = (e) => this.onDurationChange(e);
- this.trackProgress_ = (e) => this.trackProgress(e);
- this.trackCurrentTime_ = (e) => this.trackCurrentTime(e);
- this.stopTrackingCurrentTime_ = (e) => this.stopTrackingCurrentTime(e);
- this.disposeSourceHandler_ = (e) => this.disposeSourceHandler(e);
- this.queuedHanders_ = /* @__PURE__ */ new Set();
- this.hasStarted_ = false;
- this.on("playing", function() {
- this.hasStarted_ = true;
- });
- this.on("loadstart", function() {
- this.hasStarted_ = false;
- });
- ALL$1.names.forEach((name) => {
- const props = ALL$1[name];
- if (options2 && options2[props.getterName]) {
- this[props.privateName] = options2[props.getterName];
- }
- });
- if (!this.featuresProgressEvents) {
- this.manualProgressOn();
- }
- if (!this.featuresTimeupdateEvents) {
- this.manualTimeUpdatesOn();
- }
- ["Text", "Audio", "Video"].forEach((track) => {
- if (options2[`native${track}Tracks`] === false) {
- this[`featuresNative${track}Tracks`] = false;
- }
- });
- if (options2.nativeCaptions === false || options2.nativeTextTracks === false) {
- this.featuresNativeTextTracks = false;
- } else if (options2.nativeCaptions === true || options2.nativeTextTracks === true) {
- this.featuresNativeTextTracks = true;
- }
- if (!this.featuresNativeTextTracks) {
- this.emulateTextTracks();
- }
- this.preloadTextTracks = options2.preloadTextTracks !== false;
- this.autoRemoteTextTracks_ = new ALL$1.text.ListClass();
- this.initTrackListeners();
- if (!options2.nativeControlsForTouch) {
- this.emitTapEvents();
- }
- if (this.constructor) {
- this.name_ = this.constructor.name || "Unknown Tech";
- }
- }
- triggerSourceset(src) {
- if (!this.isReady_) {
- this.one("ready", () => this.setTimeout(() => this.triggerSourceset(src), 1));
- }
- this.trigger({
- src,
- type: "sourceset"
- });
- }
- manualProgressOn() {
- this.on("durationchange", this.onDurationChange_);
- this.manualProgress = true;
- this.one("ready", this.trackProgress_);
- }
- manualProgressOff() {
- this.manualProgress = false;
- this.stopTrackingProgress();
- this.off("durationchange", this.onDurationChange_);
- }
- trackProgress(event2) {
- this.stopTrackingProgress();
- this.progressInterval = this.setInterval(bind_(this, function() {
- const numBufferedPercent = this.bufferedPercent();
- if (this.bufferedPercent_ !== numBufferedPercent) {
- this.trigger("progress");
- }
- this.bufferedPercent_ = numBufferedPercent;
- if (numBufferedPercent === 1) {
- this.stopTrackingProgress();
- }
- }), 500);
- }
- onDurationChange(event2) {
- this.duration_ = this.duration();
- }
- buffered() {
- return createTimeRanges$1(0, 0);
- }
- bufferedPercent() {
- return bufferedPercent$1(this.buffered(), this.duration_);
- }
- stopTrackingProgress() {
- this.clearInterval(this.progressInterval);
- }
- manualTimeUpdatesOn() {
- this.manualTimeUpdates = true;
- this.on("play", this.trackCurrentTime_);
- this.on("pause", this.stopTrackingCurrentTime_);
- }
- manualTimeUpdatesOff() {
- this.manualTimeUpdates = false;
- this.stopTrackingCurrentTime();
- this.off("play", this.trackCurrentTime_);
- this.off("pause", this.stopTrackingCurrentTime_);
- }
- trackCurrentTime() {
- if (this.currentTimeInterval) {
- this.stopTrackingCurrentTime();
- }
- this.currentTimeInterval = this.setInterval(function() {
- this.trigger({
- type: "timeupdate",
- target: this,
- manuallyTriggered: true
- });
- }, 250);
- }
- stopTrackingCurrentTime() {
- this.clearInterval(this.currentTimeInterval);
- this.trigger({
- type: "timeupdate",
- target: this,
- manuallyTriggered: true
- });
- }
- dispose() {
- this.clearTracks(NORMAL$1.names);
- if (this.manualProgress) {
- this.manualProgressOff();
- }
- if (this.manualTimeUpdates) {
- this.manualTimeUpdatesOff();
- }
- super.dispose();
- }
- clearTracks(types) {
- types = [].concat(types);
- types.forEach((type2) => {
- const list = this[`${type2}Tracks`]() || [];
- let i2 = list.length;
- while (i2--) {
- const track = list[i2];
- if (type2 === "text") {
- this.removeRemoteTextTrack(track);
- }
- list.removeTrack(track);
- }
- });
- }
- cleanupAutoTextTracks() {
- const list = this.autoRemoteTextTracks_ || [];
- let i2 = list.length;
- while (i2--) {
- const track = list[i2];
- this.removeRemoteTextTrack(track);
- }
- }
- reset() {
- }
- crossOrigin() {
- }
- setCrossOrigin() {
- }
- error(err) {
- if (err !== void 0) {
- this.error_ = new MediaError$1(err);
- this.trigger("error");
- }
- return this.error_;
- }
- played() {
- if (this.hasStarted_) {
- return createTimeRanges$1(0, 0);
- }
- return createTimeRanges$1();
- }
- play() {
- }
- setScrubbing(_isScrubbing) {
- }
- scrubbing() {
- }
- setCurrentTime(_seconds) {
- if (this.manualTimeUpdates) {
- this.trigger({
- type: "timeupdate",
- target: this,
- manuallyTriggered: true
- });
- }
- }
- initTrackListeners() {
- NORMAL$1.names.forEach((name) => {
- const props = NORMAL$1[name];
- const trackListChanges = () => {
- this.trigger(`${name}trackchange`);
- };
- const tracks = this[props.getterName]();
- tracks.addEventListener("removetrack", trackListChanges);
- tracks.addEventListener("addtrack", trackListChanges);
- this.on("dispose", () => {
- tracks.removeEventListener("removetrack", trackListChanges);
- tracks.removeEventListener("addtrack", trackListChanges);
- });
- });
- }
- addWebVttScript_() {
- if (window_1.WebVTT) {
- return;
- }
- if (document_1.body.contains(this.el())) {
- if (!this.options_["vtt.js"] && isPlain$1(vtt) && Object.keys(vtt).length > 0) {
- this.trigger("vttjsloaded");
- return;
- }
- const script = document_1.createElement("script");
- script.src = this.options_["vtt.js"] || "https://vjs.zencdn.net/vttjs/0.14.1/vtt.min.js";
- script.onload = () => {
- this.trigger("vttjsloaded");
- };
- script.onerror = () => {
- this.trigger("vttjserror");
- };
- this.on("dispose", () => {
- script.onload = null;
- script.onerror = null;
- });
- window_1.WebVTT = true;
- this.el().parentNode.appendChild(script);
- } else {
- this.ready(this.addWebVttScript_);
- }
- }
- emulateTextTracks() {
- const tracks = this.textTracks();
- const remoteTracks = this.remoteTextTracks();
- const handleAddTrack = (e) => tracks.addTrack(e.track);
- const handleRemoveTrack = (e) => tracks.removeTrack(e.track);
- remoteTracks.on("addtrack", handleAddTrack);
- remoteTracks.on("removetrack", handleRemoveTrack);
- this.addWebVttScript_();
- const updateDisplay = () => this.trigger("texttrackchange");
- const textTracksChanges = () => {
- updateDisplay();
- for (let i2 = 0; i2 < tracks.length; i2++) {
- const track = tracks[i2];
- track.removeEventListener("cuechange", updateDisplay);
- if (track.mode === "showing") {
- track.addEventListener("cuechange", updateDisplay);
- }
- }
- };
- textTracksChanges();
- tracks.addEventListener("change", textTracksChanges);
- tracks.addEventListener("addtrack", textTracksChanges);
- tracks.addEventListener("removetrack", textTracksChanges);
- this.on("dispose", function() {
- remoteTracks.off("addtrack", handleAddTrack);
- remoteTracks.off("removetrack", handleRemoveTrack);
- tracks.removeEventListener("change", textTracksChanges);
- tracks.removeEventListener("addtrack", textTracksChanges);
- tracks.removeEventListener("removetrack", textTracksChanges);
- for (let i2 = 0; i2 < tracks.length; i2++) {
- const track = tracks[i2];
- track.removeEventListener("cuechange", updateDisplay);
- }
- });
- }
- addTextTrack(kind, label2, language) {
- if (!kind) {
- throw new Error("TextTrack kind is required but was not provided");
- }
- return createTrackHelper$1(this, kind, label2, language);
- }
- createRemoteTextTrack(options2) {
- const track = merge$1(options2, {
- tech: this
- });
- return new REMOTE$1.remoteTextEl.TrackClass(track);
- }
- addRemoteTextTrack(options2 = {}, manualCleanup) {
- const htmlTrackElement = this.createRemoteTextTrack(options2);
- if (typeof manualCleanup !== "boolean") {
- manualCleanup = false;
- }
- this.remoteTextTrackEls().addTrackElement_(htmlTrackElement);
- this.remoteTextTracks().addTrack(htmlTrackElement.track);
- if (manualCleanup === false) {
- this.ready(() => this.autoRemoteTextTracks_.addTrack(htmlTrackElement.track));
- }
- return htmlTrackElement;
- }
- removeRemoteTextTrack(track) {
- const trackElement = this.remoteTextTrackEls().getTrackElementByTrack_(track);
- this.remoteTextTrackEls().removeTrackElement_(trackElement);
- this.remoteTextTracks().removeTrack(track);
- this.autoRemoteTextTracks_.removeTrack(track);
- }
- getVideoPlaybackQuality() {
- return {};
- }
- requestPictureInPicture() {
- return Promise.reject();
- }
- disablePictureInPicture() {
- return true;
- }
- setDisablePictureInPicture() {
- }
- requestVideoFrameCallback(cb) {
- const id = newGUID$1();
- if (!this.isReady_ || this.paused()) {
- this.queuedHanders_.add(id);
- this.one("playing", () => {
- if (this.queuedHanders_.has(id)) {
- this.queuedHanders_.delete(id);
- cb();
- }
- });
- } else {
- this.requestNamedAnimationFrame(id, cb);
- }
- return id;
- }
- cancelVideoFrameCallback(id) {
- if (this.queuedHanders_.has(id)) {
- this.queuedHanders_.delete(id);
- } else {
- this.cancelNamedAnimationFrame(id);
- }
- }
- setPoster() {
- }
- playsinline() {
- }
- setPlaysinline() {
- }
- overrideNativeAudioTracks(override) {
- }
- overrideNativeVideoTracks(override) {
- }
- canPlayType(_type) {
- return "";
- }
- static canPlayType(_type) {
- return "";
- }
- static canPlaySource(srcObj, options2) {
- return Tech$2.canPlayType(srcObj.type);
- }
- static isTech(component) {
- return component.prototype instanceof Tech$2 || component instanceof Tech$2 || component === Tech$2;
- }
- static registerTech(name, tech) {
- if (!Tech$2.techs_) {
- Tech$2.techs_ = {};
- }
- if (!Tech$2.isTech(tech)) {
- throw new Error(`Tech ${name} must be a Tech`);
- }
- if (!Tech$2.canPlayType) {
- throw new Error("Techs must have a static canPlayType method on them");
- }
- if (!Tech$2.canPlaySource) {
- throw new Error("Techs must have a static canPlaySource method on them");
- }
- name = toTitleCase$1$1(name);
- Tech$2.techs_[name] = tech;
- Tech$2.techs_[toLowerCase$1(name)] = tech;
- if (name !== "Tech") {
- Tech$2.defaultTechOrder_.push(name);
- }
- return tech;
- }
- static getTech(name) {
- if (!name) {
- return;
- }
- if (Tech$2.techs_ && Tech$2.techs_[name]) {
- return Tech$2.techs_[name];
- }
- name = toTitleCase$1$1(name);
- if (window_1 && window_1.videojs && window_1.videojs[name]) {
- log$1$1.warn(`The ${name} tech was added to the videojs object when it should be registered using videojs.registerTech(name, tech)`);
- return window_1.videojs[name];
- }
- }
- }
- ALL$1.names.forEach(function(name) {
- const props = ALL$1[name];
- Tech$2.prototype[props.getterName] = function() {
- this[props.privateName] = this[props.privateName] || new props.ListClass();
- return this[props.privateName];
- };
- });
- Tech$2.prototype.featuresVolumeControl = true;
- Tech$2.prototype.featuresMuteControl = true;
- Tech$2.prototype.featuresFullscreenResize = false;
- Tech$2.prototype.featuresPlaybackRate = false;
- Tech$2.prototype.featuresProgressEvents = false;
- Tech$2.prototype.featuresSourceset = false;
- Tech$2.prototype.featuresTimeupdateEvents = false;
- Tech$2.prototype.featuresNativeTextTracks = false;
- Tech$2.prototype.featuresVideoFrameCallback = false;
- Tech$2.withSourceHandlers = function(_Tech) {
- _Tech.registerSourceHandler = function(handler, index2) {
- let handlers = _Tech.sourceHandlers;
- if (!handlers) {
- handlers = _Tech.sourceHandlers = [];
- }
- if (index2 === void 0) {
- index2 = handlers.length;
- }
- handlers.splice(index2, 0, handler);
- };
- _Tech.canPlayType = function(type2) {
- const handlers = _Tech.sourceHandlers || [];
- let can;
- for (let i2 = 0; i2 < handlers.length; i2++) {
- can = handlers[i2].canPlayType(type2);
- if (can) {
- return can;
- }
- }
- return "";
- };
- _Tech.selectSourceHandler = function(source, options2) {
- const handlers = _Tech.sourceHandlers || [];
- let can;
- for (let i2 = 0; i2 < handlers.length; i2++) {
- can = handlers[i2].canHandleSource(source, options2);
- if (can) {
- return handlers[i2];
- }
- }
- return null;
- };
- _Tech.canPlaySource = function(srcObj, options2) {
- const sh = _Tech.selectSourceHandler(srcObj, options2);
- if (sh) {
- return sh.canHandleSource(srcObj, options2);
- }
- return "";
- };
- const deferrable = ["seekable", "seeking", "duration"];
- deferrable.forEach(function(fnName) {
- const originalFn = this[fnName];
- if (typeof originalFn !== "function") {
- return;
- }
- this[fnName] = function() {
- if (this.sourceHandler_ && this.sourceHandler_[fnName]) {
- return this.sourceHandler_[fnName].apply(this.sourceHandler_, arguments);
- }
- return originalFn.apply(this, arguments);
- };
- }, _Tech.prototype);
- _Tech.prototype.setSource = function(source) {
- let sh = _Tech.selectSourceHandler(source, this.options_);
- if (!sh) {
- if (_Tech.nativeSourceHandler) {
- sh = _Tech.nativeSourceHandler;
- } else {
- log$1$1.error("No source handler found for the current source.");
- }
- }
- this.disposeSourceHandler();
- this.off("dispose", this.disposeSourceHandler_);
- if (sh !== _Tech.nativeSourceHandler) {
- this.currentSource_ = source;
- }
- this.sourceHandler_ = sh.handleSource(source, this, this.options_);
- this.one("dispose", this.disposeSourceHandler_);
- };
- _Tech.prototype.disposeSourceHandler = function() {
- if (this.currentSource_) {
- this.clearTracks(["audio", "video"]);
- this.currentSource_ = null;
- }
- this.cleanupAutoTextTracks();
- if (this.sourceHandler_) {
- if (this.sourceHandler_.dispose) {
- this.sourceHandler_.dispose();
- }
- this.sourceHandler_ = null;
- }
- };
- };
- Component$1$1.registerComponent("Tech", Tech$2);
- Tech$2.registerTech("Tech", Tech$2);
- Tech$2.defaultTechOrder_ = [];
- const middlewares$1 = {};
- const middlewareInstances$1 = {};
- const TERMINATOR$1 = {};
- function use$1(type2, middleware) {
- middlewares$1[type2] = middlewares$1[type2] || [];
- middlewares$1[type2].push(middleware);
- }
- function setSource$1(player, src, next) {
- player.setTimeout(() => setSourceHelper$1(src, middlewares$1[src.type], next, player), 1);
- }
- function setTech$1(middleware, tech) {
- middleware.forEach((mw) => mw.setTech && mw.setTech(tech));
- }
- function get$1(middleware, tech, method) {
- return middleware.reduceRight(middlewareIterator$1(method), tech[method]());
- }
- function set$1(middleware, tech, method, arg) {
- return tech[method](middleware.reduce(middlewareIterator$1(method), arg));
- }
- function mediate$1(middleware, tech, method, arg = null) {
- const callMethod = "call" + toTitleCase$1$1(method);
- const middlewareValue = middleware.reduce(middlewareIterator$1(callMethod), arg);
- const terminated = middlewareValue === TERMINATOR$1;
- const returnValue = terminated ? null : tech[method](middlewareValue);
- executeRight$1(middleware, method, returnValue, terminated);
- return returnValue;
- }
- const allowedGetters$1 = {
- buffered: 1,
- currentTime: 1,
- duration: 1,
- muted: 1,
- played: 1,
- paused: 1,
- seekable: 1,
- volume: 1,
- ended: 1
- };
- const allowedSetters$1 = {
- setCurrentTime: 1,
- setMuted: 1,
- setVolume: 1
- };
- const allowedMediators$1 = {
- play: 1,
- pause: 1
- };
- function middlewareIterator$1(method) {
- return (value, mw) => {
- if (value === TERMINATOR$1) {
- return TERMINATOR$1;
- }
- if (mw[method]) {
- return mw[method](value);
- }
- return value;
- };
- }
- function executeRight$1(mws, method, value, terminated) {
- for (let i2 = mws.length - 1; i2 >= 0; i2--) {
- const mw = mws[i2];
- if (mw[method]) {
- mw[method](terminated, value);
- }
- }
- }
- function clearCacheForPlayer$1(player) {
- middlewareInstances$1[player.id()] = null;
- }
- function getOrCreateFactory$1(player, mwFactory) {
- const mws = middlewareInstances$1[player.id()];
- let mw = null;
- if (mws === void 0 || mws === null) {
- mw = mwFactory(player);
- middlewareInstances$1[player.id()] = [[mwFactory, mw]];
- return mw;
- }
- for (let i2 = 0; i2 < mws.length; i2++) {
- const [mwf, mwi] = mws[i2];
- if (mwf !== mwFactory) {
- continue;
- }
- mw = mwi;
- }
- if (mw === null) {
- mw = mwFactory(player);
- mws.push([mwFactory, mw]);
- }
- return mw;
- }
- function setSourceHelper$1(src = {}, middleware = [], next, player, acc = [], lastRun = false) {
- const [mwFactory, ...mwrest] = middleware;
- if (typeof mwFactory === "string") {
- setSourceHelper$1(src, middlewares$1[mwFactory], next, player, acc, lastRun);
- } else if (mwFactory) {
- const mw = getOrCreateFactory$1(player, mwFactory);
- if (!mw.setSource) {
- acc.push(mw);
- return setSourceHelper$1(src, mwrest, next, player, acc, lastRun);
- }
- mw.setSource(Object.assign({}, src), function(err, _src) {
- if (err) {
- return setSourceHelper$1(src, mwrest, next, player, acc, lastRun);
- }
- acc.push(mw);
- setSourceHelper$1(_src, src.type === _src.type ? mwrest : middlewares$1[_src.type], next, player, acc, lastRun);
- });
- } else if (mwrest.length) {
- setSourceHelper$1(src, mwrest, next, player, acc, lastRun);
- } else if (lastRun) {
- next(src, acc);
- } else {
- setSourceHelper$1(src, middlewares$1["*"], next, player, acc, true);
- }
- }
- const MimetypesKind$1 = {
- opus: "video/ogg",
- ogv: "video/ogg",
- mp4: "video/mp4",
- mov: "video/mp4",
- m4v: "video/mp4",
- mkv: "video/x-matroska",
- m4a: "audio/mp4",
- mp3: "audio/mpeg",
- aac: "audio/aac",
- caf: "audio/x-caf",
- flac: "audio/flac",
- oga: "audio/ogg",
- wav: "audio/wav",
- m3u8: "application/x-mpegURL",
- mpd: "application/dash+xml",
- jpg: "image/jpeg",
- jpeg: "image/jpeg",
- gif: "image/gif",
- png: "image/png",
- svg: "image/svg+xml",
- webp: "image/webp"
- };
- const getMimetype$1 = function(src = "") {
- const ext = getFileExtension$1(src);
- const mimetype = MimetypesKind$1[ext.toLowerCase()];
- return mimetype || "";
- };
- const findMimetype$1 = (player, src) => {
- if (!src) {
- return "";
- }
- if (player.cache_.source.src === src && player.cache_.source.type) {
- return player.cache_.source.type;
- }
- const matchingSources = player.cache_.sources.filter((s) => s.src === src);
- if (matchingSources.length) {
- return matchingSources[0].type;
- }
- const sources = player.$$("source");
- for (let i2 = 0; i2 < sources.length; i2++) {
- const s = sources[i2];
- if (s.type && s.src && s.src === src) {
- return s.type;
- }
- }
- return getMimetype$1(src);
- };
- const filterSource$1 = function(src) {
- if (Array.isArray(src)) {
- let newsrc = [];
- src.forEach(function(srcobj) {
- srcobj = filterSource$1(srcobj);
- if (Array.isArray(srcobj)) {
- newsrc = newsrc.concat(srcobj);
- } else if (isObject$2(srcobj)) {
- newsrc.push(srcobj);
- }
- });
- src = newsrc;
- } else if (typeof src === "string" && src.trim()) {
- src = [fixSource$1({
- src
- })];
- } else if (isObject$2(src) && typeof src.src === "string" && src.src && src.src.trim()) {
- src = [fixSource$1(src)];
- } else {
- src = [];
- }
- return src;
- };
- function fixSource$1(src) {
- if (!src.type) {
- const mimetype = getMimetype$1(src.src);
- if (mimetype) {
- src.type = mimetype;
- }
- }
- return src;
- }
- class MediaLoader$1 extends Component$1$1 {
- constructor(player, options2, ready) {
- const options_ = merge$1({
- createEl: false
- }, options2);
- super(player, options_, ready);
- if (!options2.playerOptions.sources || options2.playerOptions.sources.length === 0) {
- for (let i2 = 0, j = options2.playerOptions.techOrder; i2 < j.length; i2++) {
- const techName = toTitleCase$1$1(j[i2]);
- let tech = Tech$2.getTech(techName);
- if (!techName) {
- tech = Component$1$1.getComponent(techName);
- }
- if (tech && tech.isSupported()) {
- player.loadTech_(techName);
- break;
- }
- }
- } else {
- player.src(options2.playerOptions.sources);
- }
- }
- }
- Component$1$1.registerComponent("MediaLoader", MediaLoader$1);
- class ClickableComponent$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- if (this.options_.controlText) {
- this.controlText(this.options_.controlText);
- }
- this.handleMouseOver_ = (e) => this.handleMouseOver(e);
- this.handleMouseOut_ = (e) => this.handleMouseOut(e);
- this.handleClick_ = (e) => this.handleClick(e);
- this.handleKeyDown_ = (e) => this.handleKeyDown(e);
- this.emitTapEvents();
- this.enable();
- }
- createEl(tag = "div", props = {}, attributes = {}) {
- props = Object.assign({
- className: this.buildCSSClass(),
- tabIndex: 0
- }, props);
- if (tag === "button") {
- log$1$1.error(`Creating a ClickableComponent with an HTML element of ${tag} is not supported; use a Button instead.`);
- }
- attributes = Object.assign({
- role: "button"
- }, attributes);
- this.tabIndex_ = props.tabIndex;
- const el = createEl$1(tag, props, attributes);
- el.appendChild(createEl$1("span", {
- className: "vjs-icon-placeholder"
- }, {
- "aria-hidden": true
- }));
- this.createControlTextEl(el);
- return el;
- }
- dispose() {
- this.controlTextEl_ = null;
- super.dispose();
- }
- createControlTextEl(el) {
- this.controlTextEl_ = createEl$1("span", {
- className: "vjs-control-text"
- }, {
- "aria-live": "polite"
- });
- if (el) {
- el.appendChild(this.controlTextEl_);
- }
- this.controlText(this.controlText_, el);
- return this.controlTextEl_;
- }
- controlText(text, el = this.el()) {
- if (text === void 0) {
- return this.controlText_ || "Need Text";
- }
- const localizedText = this.localize(text);
- this.controlText_ = text;
- textContent$1(this.controlTextEl_, localizedText);
- if (!this.nonIconControl && !this.player_.options_.noUITitleAttributes) {
- el.setAttribute("title", localizedText);
- }
- }
- buildCSSClass() {
- return `vjs-control vjs-button ${super.buildCSSClass()}`;
- }
- enable() {
- if (!this.enabled_) {
- this.enabled_ = true;
- this.removeClass("vjs-disabled");
- this.el_.setAttribute("aria-disabled", "false");
- if (typeof this.tabIndex_ !== "undefined") {
- this.el_.setAttribute("tabIndex", this.tabIndex_);
- }
- this.on(["tap", "click"], this.handleClick_);
- this.on("keydown", this.handleKeyDown_);
- }
- }
- disable() {
- this.enabled_ = false;
- this.addClass("vjs-disabled");
- this.el_.setAttribute("aria-disabled", "true");
- if (typeof this.tabIndex_ !== "undefined") {
- this.el_.removeAttribute("tabIndex");
- }
- this.off("mouseover", this.handleMouseOver_);
- this.off("mouseout", this.handleMouseOut_);
- this.off(["tap", "click"], this.handleClick_);
- this.off("keydown", this.handleKeyDown_);
- }
- handleLanguagechange() {
- this.controlText(this.controlText_);
- }
- handleClick(event2) {
- if (this.options_.clickHandler) {
- this.options_.clickHandler.call(this, arguments);
- }
- }
- handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Space") || keycode.isEventKey(event2, "Enter")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.trigger("click");
- } else {
- super.handleKeyDown(event2);
- }
- }
- }
- Component$1$1.registerComponent("ClickableComponent", ClickableComponent$1);
- class PosterImage$1 extends ClickableComponent$1 {
- constructor(player, options2) {
- super(player, options2);
- this.update();
- this.update_ = (e) => this.update(e);
- player.on("posterchange", this.update_);
- }
- dispose() {
- this.player().off("posterchange", this.update_);
- super.dispose();
- }
- createEl() {
- return createEl$1("div", {
- className: "vjs-poster"
- });
- }
- crossOrigin(value) {
- if (typeof value === "undefined") {
- if (this.$("img")) {
- return this.$("img").crossOrigin;
- } else if (this.player_.tech_ && this.player_.tech_.isReady_) {
- return this.player_.crossOrigin();
- }
- return this.player_.options_.crossOrigin || this.player_.options_.crossorigin || null;
- }
- if (value !== null && value !== "anonymous" && value !== "use-credentials") {
- this.player_.log.warn(`crossOrigin must be null, "anonymous" or "use-credentials", given "${value}"`);
- return;
- }
- if (this.$("img")) {
- this.$("img").crossOrigin = value;
- }
- return;
- }
- update(event2) {
- const url = this.player().poster();
- this.setSrc(url);
- if (url) {
- this.show();
- } else {
- this.hide();
- }
- }
- setSrc(url) {
- if (!url) {
- this.el_.textContent = "";
- return;
- }
- if (!this.$("img")) {
- this.el_.appendChild(createEl$1("picture", {
- className: "vjs-poster",
- tabIndex: -1
- }, {}, createEl$1("img", {
- loading: "lazy",
- crossOrigin: this.crossOrigin()
- }, {
- alt: ""
- })));
- }
- this.$("img").src = url;
- }
- handleClick(event2) {
- if (!this.player_.controls()) {
- return;
- }
- if (this.player_.tech(true)) {
- this.player_.tech(true).focus();
- }
- if (this.player_.paused()) {
- silencePromise$1(this.player_.play());
- } else {
- this.player_.pause();
- }
- }
- }
- PosterImage$1.prototype.crossorigin = PosterImage$1.prototype.crossOrigin;
- Component$1$1.registerComponent("PosterImage", PosterImage$1);
- const darkGray$1 = "#222";
- const lightGray$1 = "#ccc";
- const fontMap$1 = {
- monospace: "monospace",
- sansSerif: "sans-serif",
- serif: "serif",
- monospaceSansSerif: '"Andale Mono", "Lucida Console", monospace',
- monospaceSerif: '"Courier New", monospace',
- proportionalSansSerif: "sans-serif",
- proportionalSerif: "serif",
- casual: '"Comic Sans MS", Impact, fantasy',
- script: '"Monotype Corsiva", cursive',
- smallcaps: '"Andale Mono", "Lucida Console", monospace, sans-serif'
- };
- function constructColor$1(color2, opacity) {
- let hex;
- if (color2.length === 4) {
- hex = color2[1] + color2[1] + color2[2] + color2[2] + color2[3] + color2[3];
- } else if (color2.length === 7) {
- hex = color2.slice(1);
- } else {
- throw new Error("Invalid color code provided, " + color2 + "; must be formatted as e.g. #f0e or #f604e2.");
- }
- return "rgba(" + parseInt(hex.slice(0, 2), 16) + "," + parseInt(hex.slice(2, 4), 16) + "," + parseInt(hex.slice(4, 6), 16) + "," + opacity + ")";
- }
- function tryUpdateStyle$1(el, style, rule) {
- try {
- el.style[style] = rule;
- } catch (e) {
- return;
- }
- }
- class TextTrackDisplay$1 extends Component$1$1 {
- constructor(player, options2, ready) {
- super(player, options2, ready);
- const updateDisplayHandler = (e) => this.updateDisplay(e);
- player.on("loadstart", (e) => this.toggleDisplay(e));
- player.on("texttrackchange", updateDisplayHandler);
- player.on("loadedmetadata", (e) => this.preselectTrack(e));
- player.ready(bind_(this, function() {
- if (player.tech_ && player.tech_.featuresNativeTextTracks) {
- this.hide();
- return;
- }
- player.on("fullscreenchange", updateDisplayHandler);
- player.on("playerresize", updateDisplayHandler);
- const screenOrientation = window_1.screen.orientation || window_1;
- const changeOrientationEvent = window_1.screen.orientation ? "change" : "orientationchange";
- screenOrientation.addEventListener(changeOrientationEvent, updateDisplayHandler);
- player.on("dispose", () => screenOrientation.removeEventListener(changeOrientationEvent, updateDisplayHandler));
- const tracks = this.options_.playerOptions.tracks || [];
- for (let i2 = 0; i2 < tracks.length; i2++) {
- this.player_.addRemoteTextTrack(tracks[i2], true);
- }
- this.preselectTrack();
- }));
- }
- preselectTrack() {
- const modes = {
- captions: 1,
- subtitles: 1
- };
- const trackList = this.player_.textTracks();
- const userPref = this.player_.cache_.selectedLanguage;
- let firstDesc;
- let firstCaptions;
- let preferredTrack;
- for (let i2 = 0; i2 < trackList.length; i2++) {
- const track = trackList[i2];
- if (userPref && userPref.enabled && userPref.language && userPref.language === track.language && track.kind in modes) {
- if (track.kind === userPref.kind) {
- preferredTrack = track;
- } else if (!preferredTrack) {
- preferredTrack = track;
- }
- } else if (userPref && !userPref.enabled) {
- preferredTrack = null;
- firstDesc = null;
- firstCaptions = null;
- } else if (track.default) {
- if (track.kind === "descriptions" && !firstDesc) {
- firstDesc = track;
- } else if (track.kind in modes && !firstCaptions) {
- firstCaptions = track;
- }
- }
- }
- if (preferredTrack) {
- preferredTrack.mode = "showing";
- } else if (firstCaptions) {
- firstCaptions.mode = "showing";
- } else if (firstDesc) {
- firstDesc.mode = "showing";
- }
- }
- toggleDisplay() {
- if (this.player_.tech_ && this.player_.tech_.featuresNativeTextTracks) {
- this.hide();
- } else {
- this.show();
- }
- }
- createEl() {
- return super.createEl("div", {
- className: "vjs-text-track-display"
- }, {
- "translate": "yes",
- "aria-live": "off",
- "aria-atomic": "true"
- });
- }
- clearDisplay() {
- if (typeof window_1.WebVTT === "function") {
- window_1.WebVTT.processCues(window_1, [], this.el_);
- }
- }
- updateDisplay() {
- const tracks = this.player_.textTracks();
- const allowMultipleShowingTracks = this.options_.allowMultipleShowingTracks;
- this.clearDisplay();
- if (allowMultipleShowingTracks) {
- const showingTracks = [];
- for (let i3 = 0; i3 < tracks.length; ++i3) {
- const track = tracks[i3];
- if (track.mode !== "showing") {
- continue;
- }
- showingTracks.push(track);
- }
- this.updateForTrack(showingTracks);
- return;
- }
- let descriptionsTrack = null;
- let captionsSubtitlesTrack = null;
- let i2 = tracks.length;
- while (i2--) {
- const track = tracks[i2];
- if (track.mode === "showing") {
- if (track.kind === "descriptions") {
- descriptionsTrack = track;
- } else {
- captionsSubtitlesTrack = track;
- }
- }
- }
- if (captionsSubtitlesTrack) {
- if (this.getAttribute("aria-live") !== "off") {
- this.setAttribute("aria-live", "off");
- }
- this.updateForTrack(captionsSubtitlesTrack);
- } else if (descriptionsTrack) {
- if (this.getAttribute("aria-live") !== "assertive") {
- this.setAttribute("aria-live", "assertive");
- }
- this.updateForTrack(descriptionsTrack);
- }
- }
- updateDisplayState(track) {
- const overrides = this.player_.textTrackSettings.getValues();
- const cues = track.activeCues;
- let i2 = cues.length;
- while (i2--) {
- const cue = cues[i2];
- if (!cue) {
- continue;
- }
- const cueDiv = cue.displayState;
- if (overrides.color) {
- cueDiv.firstChild.style.color = overrides.color;
- }
- if (overrides.textOpacity) {
- tryUpdateStyle$1(cueDiv.firstChild, "color", constructColor$1(overrides.color || "#fff", overrides.textOpacity));
- }
- if (overrides.backgroundColor) {
- cueDiv.firstChild.style.backgroundColor = overrides.backgroundColor;
- }
- if (overrides.backgroundOpacity) {
- tryUpdateStyle$1(cueDiv.firstChild, "backgroundColor", constructColor$1(overrides.backgroundColor || "#000", overrides.backgroundOpacity));
- }
- if (overrides.windowColor) {
- if (overrides.windowOpacity) {
- tryUpdateStyle$1(cueDiv, "backgroundColor", constructColor$1(overrides.windowColor, overrides.windowOpacity));
- } else {
- cueDiv.style.backgroundColor = overrides.windowColor;
- }
- }
- if (overrides.edgeStyle) {
- if (overrides.edgeStyle === "dropshadow") {
- cueDiv.firstChild.style.textShadow = `2px 2px 3px ${darkGray$1}, 2px 2px 4px ${darkGray$1}, 2px 2px 5px ${darkGray$1}`;
- } else if (overrides.edgeStyle === "raised") {
- cueDiv.firstChild.style.textShadow = `1px 1px ${darkGray$1}, 2px 2px ${darkGray$1}, 3px 3px ${darkGray$1}`;
- } else if (overrides.edgeStyle === "depressed") {
- cueDiv.firstChild.style.textShadow = `1px 1px ${lightGray$1}, 0 1px ${lightGray$1}, -1px -1px ${darkGray$1}, 0 -1px ${darkGray$1}`;
- } else if (overrides.edgeStyle === "uniform") {
- cueDiv.firstChild.style.textShadow = `0 0 4px ${darkGray$1}, 0 0 4px ${darkGray$1}, 0 0 4px ${darkGray$1}, 0 0 4px ${darkGray$1}`;
- }
- }
- if (overrides.fontPercent && overrides.fontPercent !== 1) {
- const fontSize = window_1.parseFloat(cueDiv.style.fontSize);
- cueDiv.style.fontSize = fontSize * overrides.fontPercent + "px";
- cueDiv.style.height = "auto";
- cueDiv.style.top = "auto";
- }
- if (overrides.fontFamily && overrides.fontFamily !== "default") {
- if (overrides.fontFamily === "small-caps") {
- cueDiv.firstChild.style.fontVariant = "small-caps";
- } else {
- cueDiv.firstChild.style.fontFamily = fontMap$1[overrides.fontFamily];
- }
- }
- }
- }
- updateForTrack(tracks) {
- if (!Array.isArray(tracks)) {
- tracks = [tracks];
- }
- if (typeof window_1.WebVTT !== "function" || tracks.every((track) => {
- return !track.activeCues;
- })) {
- return;
- }
- const cues = [];
- for (let i2 = 0; i2 < tracks.length; ++i2) {
- const track = tracks[i2];
- for (let j = 0; j < track.activeCues.length; ++j) {
- cues.push(track.activeCues[j]);
- }
- }
- window_1.WebVTT.processCues(window_1, cues, this.el_);
- for (let i2 = 0; i2 < tracks.length; ++i2) {
- const track = tracks[i2];
- for (let j = 0; j < track.activeCues.length; ++j) {
- const cueEl = track.activeCues[j].displayState;
- addClass$1(cueEl, "vjs-text-track-cue", "vjs-text-track-cue-" + (track.language ? track.language : i2));
- if (track.language) {
- setAttribute$1(cueEl, "lang", track.language);
- }
- }
- if (this.player_.textTrackSettings) {
- this.updateDisplayState(track);
- }
- }
- }
- }
- Component$1$1.registerComponent("TextTrackDisplay", TextTrackDisplay$1);
- class LoadingSpinner$1 extends Component$1$1 {
- createEl() {
- const isAudio = this.player_.isAudio();
- const playerType = this.localize(isAudio ? "Audio Player" : "Video Player");
- const controlText = createEl$1("span", {
- className: "vjs-control-text",
- textContent: this.localize("{1} is loading.", [playerType])
- });
- const el = super.createEl("div", {
- className: "vjs-loading-spinner",
- dir: "ltr"
- });
- el.appendChild(controlText);
- return el;
- }
- handleLanguagechange() {
- this.$(".vjs-control-text").textContent = this.localize("{1} is loading.", [this.player_.isAudio() ? "Audio Player" : "Video Player"]);
- }
- }
- Component$1$1.registerComponent("LoadingSpinner", LoadingSpinner$1);
- class Button$1 extends ClickableComponent$1 {
- createEl(tag, props = {}, attributes = {}) {
- tag = "button";
- props = Object.assign({
- className: this.buildCSSClass()
- }, props);
- attributes = Object.assign({
- type: "button"
- }, attributes);
- const el = createEl$1(tag, props, attributes);
- el.appendChild(createEl$1("span", {
- className: "vjs-icon-placeholder"
- }, {
- "aria-hidden": true
- }));
- this.createControlTextEl(el);
- return el;
- }
- addChild(child, options2 = {}) {
- const className = this.constructor.name;
- log$1$1.warn(`Adding an actionable (user controllable) child to a Button (${className}) is not supported; use a ClickableComponent instead.`);
- return Component$1$1.prototype.addChild.call(this, child, options2);
- }
- enable() {
- super.enable();
- this.el_.removeAttribute("disabled");
- }
- disable() {
- super.disable();
- this.el_.setAttribute("disabled", "disabled");
- }
- handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Space") || keycode.isEventKey(event2, "Enter")) {
- event2.stopPropagation();
- return;
- }
- super.handleKeyDown(event2);
- }
- }
- Component$1$1.registerComponent("Button", Button$1);
- class BigPlayButton$1 extends Button$1 {
- constructor(player, options2) {
- super(player, options2);
- this.mouseused_ = false;
- this.on("mousedown", (e) => this.handleMouseDown(e));
- }
- buildCSSClass() {
- return "vjs-big-play-button";
- }
- handleClick(event2) {
- const playPromise = this.player_.play();
- if (this.mouseused_ && event2.clientX && event2.clientY) {
- silencePromise$1(playPromise);
- if (this.player_.tech(true)) {
- this.player_.tech(true).focus();
- }
- return;
- }
- const cb = this.player_.getChild("controlBar");
- const playToggle = cb && cb.getChild("playToggle");
- if (!playToggle) {
- this.player_.tech(true).focus();
- return;
- }
- const playFocus = () => playToggle.focus();
- if (isPromise$1(playPromise)) {
- playPromise.then(playFocus, () => {
- });
- } else {
- this.setTimeout(playFocus, 1);
- }
- }
- handleKeyDown(event2) {
- this.mouseused_ = false;
- super.handleKeyDown(event2);
- }
- handleMouseDown(event2) {
- this.mouseused_ = true;
- }
- }
- BigPlayButton$1.prototype.controlText_ = "Play Video";
- Component$1$1.registerComponent("BigPlayButton", BigPlayButton$1);
- class CloseButton$1 extends Button$1 {
- constructor(player, options2) {
- super(player, options2);
- this.controlText(options2 && options2.controlText || this.localize("Close"));
- }
- buildCSSClass() {
- return `vjs-close-button ${super.buildCSSClass()}`;
- }
- handleClick(event2) {
- this.trigger({
- type: "close",
- bubbles: false
- });
- }
- handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Esc")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.trigger("click");
- } else {
- super.handleKeyDown(event2);
- }
- }
- }
- Component$1$1.registerComponent("CloseButton", CloseButton$1);
- class PlayToggle$1 extends Button$1 {
- constructor(player, options2 = {}) {
- super(player, options2);
- options2.replay = options2.replay === void 0 || options2.replay;
- this.on(player, "play", (e) => this.handlePlay(e));
- this.on(player, "pause", (e) => this.handlePause(e));
- if (options2.replay) {
- this.on(player, "ended", (e) => this.handleEnded(e));
- }
- }
- buildCSSClass() {
- return `vjs-play-control ${super.buildCSSClass()}`;
- }
- handleClick(event2) {
- if (this.player_.paused()) {
- silencePromise$1(this.player_.play());
- } else {
- this.player_.pause();
- }
- }
- handleSeeked(event2) {
- this.removeClass("vjs-ended");
- if (this.player_.paused()) {
- this.handlePause(event2);
- } else {
- this.handlePlay(event2);
- }
- }
- handlePlay(event2) {
- this.removeClass("vjs-ended", "vjs-paused");
- this.addClass("vjs-playing");
- this.controlText("Pause");
- }
- handlePause(event2) {
- this.removeClass("vjs-playing");
- this.addClass("vjs-paused");
- this.controlText("Play");
- }
- handleEnded(event2) {
- this.removeClass("vjs-playing");
- this.addClass("vjs-ended");
- this.controlText("Replay");
- this.one(this.player_, "seeked", (e) => this.handleSeeked(e));
- }
- }
- PlayToggle$1.prototype.controlText_ = "Play";
- Component$1$1.registerComponent("PlayToggle", PlayToggle$1);
- class TimeDisplay$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.on(player, ["timeupdate", "ended"], (e) => this.updateContent(e));
- this.updateTextNode_();
- }
- createEl() {
- const className = this.buildCSSClass();
- const el = super.createEl("div", {
- className: `${className} vjs-time-control vjs-control`
- });
- const span = createEl$1("span", {
- className: "vjs-control-text",
- textContent: `${this.localize(this.labelText_)}\xA0`
- }, {
- role: "presentation"
- });
- el.appendChild(span);
- this.contentEl_ = createEl$1("span", {
- className: `${className}-display`
- }, {
- role: "presentation"
- });
- el.appendChild(this.contentEl_);
- return el;
- }
- dispose() {
- this.contentEl_ = null;
- this.textNode_ = null;
- super.dispose();
- }
- updateTextNode_(time = 0) {
- time = formatTime$1(time);
- if (this.formattedTime_ === time) {
- return;
- }
- this.formattedTime_ = time;
- this.requestNamedAnimationFrame("TimeDisplay#updateTextNode_", () => {
- if (!this.contentEl_) {
- return;
- }
- let oldNode = this.textNode_;
- if (oldNode && this.contentEl_.firstChild !== oldNode) {
- oldNode = null;
- log$1$1.warn("TimeDisplay#updateTextnode_: Prevented replacement of text node element since it was no longer a child of this node. Appending a new node instead.");
- }
- this.textNode_ = document_1.createTextNode(this.formattedTime_);
- if (!this.textNode_) {
- return;
- }
- if (oldNode) {
- this.contentEl_.replaceChild(this.textNode_, oldNode);
- } else {
- this.contentEl_.appendChild(this.textNode_);
- }
- });
- }
- updateContent(event2) {
- }
- }
- TimeDisplay$1.prototype.labelText_ = "Time";
- TimeDisplay$1.prototype.controlText_ = "Time";
- Component$1$1.registerComponent("TimeDisplay", TimeDisplay$1);
- class CurrentTimeDisplay$1 extends TimeDisplay$1 {
- buildCSSClass() {
- return "vjs-current-time";
- }
- updateContent(event2) {
- let time;
- if (this.player_.ended()) {
- time = this.player_.duration();
- } else {
- time = this.player_.scrubbing() ? this.player_.getCache().currentTime : this.player_.currentTime();
- }
- this.updateTextNode_(time);
- }
- }
- CurrentTimeDisplay$1.prototype.labelText_ = "Current Time";
- CurrentTimeDisplay$1.prototype.controlText_ = "Current Time";
- Component$1$1.registerComponent("CurrentTimeDisplay", CurrentTimeDisplay$1);
- class DurationDisplay$1 extends TimeDisplay$1 {
- constructor(player, options2) {
- super(player, options2);
- const updateContent = (e) => this.updateContent(e);
- this.on(player, "durationchange", updateContent);
- this.on(player, "loadstart", updateContent);
- this.on(player, "loadedmetadata", updateContent);
- }
- buildCSSClass() {
- return "vjs-duration";
- }
- updateContent(event2) {
- const duration5 = this.player_.duration();
- this.updateTextNode_(duration5);
- }
- }
- DurationDisplay$1.prototype.labelText_ = "Duration";
- DurationDisplay$1.prototype.controlText_ = "Duration";
- Component$1$1.registerComponent("DurationDisplay", DurationDisplay$1);
- class TimeDivider$1 extends Component$1$1 {
- createEl() {
- const el = super.createEl("div", {
- className: "vjs-time-control vjs-time-divider"
- }, {
- "aria-hidden": true
- });
- const div = super.createEl("div");
- const span = super.createEl("span", {
- textContent: "/"
- });
- div.appendChild(span);
- el.appendChild(div);
- return el;
- }
- }
- Component$1$1.registerComponent("TimeDivider", TimeDivider$1);
- class RemainingTimeDisplay$1 extends TimeDisplay$1 {
- constructor(player, options2) {
- super(player, options2);
- this.on(player, "durationchange", (e) => this.updateContent(e));
- }
- buildCSSClass() {
- return "vjs-remaining-time";
- }
- createEl() {
- const el = super.createEl();
- if (this.options_.displayNegative !== false) {
- el.insertBefore(createEl$1("span", {}, {
- "aria-hidden": true
- }, "-"), this.contentEl_);
- }
- return el;
- }
- updateContent(event2) {
- if (typeof this.player_.duration() !== "number") {
- return;
- }
- let time;
- if (this.player_.ended()) {
- time = 0;
- } else if (this.player_.remainingTimeDisplay) {
- time = this.player_.remainingTimeDisplay();
- } else {
- time = this.player_.remainingTime();
- }
- this.updateTextNode_(time);
- }
- }
- RemainingTimeDisplay$1.prototype.labelText_ = "Remaining Time";
- RemainingTimeDisplay$1.prototype.controlText_ = "Remaining Time";
- Component$1$1.registerComponent("RemainingTimeDisplay", RemainingTimeDisplay$1);
- class LiveDisplay$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.updateShowing();
- this.on(this.player(), "durationchange", (e) => this.updateShowing(e));
- }
- createEl() {
- const el = super.createEl("div", {
- className: "vjs-live-control vjs-control"
- });
- this.contentEl_ = createEl$1("div", {
- className: "vjs-live-display"
- }, {
- "aria-live": "off"
- });
- this.contentEl_.appendChild(createEl$1("span", {
- className: "vjs-control-text",
- textContent: `${this.localize("Stream Type")}\xA0`
- }));
- this.contentEl_.appendChild(document_1.createTextNode(this.localize("LIVE")));
- el.appendChild(this.contentEl_);
- return el;
- }
- dispose() {
- this.contentEl_ = null;
- super.dispose();
- }
- updateShowing(event2) {
- if (this.player().duration() === Infinity) {
- this.show();
- } else {
- this.hide();
- }
- }
- }
- Component$1$1.registerComponent("LiveDisplay", LiveDisplay$1);
- class SeekToLive$1 extends Button$1 {
- constructor(player, options2) {
- super(player, options2);
- this.updateLiveEdgeStatus();
- if (this.player_.liveTracker) {
- this.updateLiveEdgeStatusHandler_ = (e) => this.updateLiveEdgeStatus(e);
- this.on(this.player_.liveTracker, "liveedgechange", this.updateLiveEdgeStatusHandler_);
- }
- }
- createEl() {
- const el = super.createEl("button", {
- className: "vjs-seek-to-live-control vjs-control"
- });
- this.textEl_ = createEl$1("span", {
- className: "vjs-seek-to-live-text",
- textContent: this.localize("LIVE")
- }, {
- "aria-hidden": "true"
- });
- el.appendChild(this.textEl_);
- return el;
- }
- updateLiveEdgeStatus() {
- if (!this.player_.liveTracker || this.player_.liveTracker.atLiveEdge()) {
- this.setAttribute("aria-disabled", true);
- this.addClass("vjs-at-live-edge");
- this.controlText("Seek to live, currently playing live");
- } else {
- this.setAttribute("aria-disabled", false);
- this.removeClass("vjs-at-live-edge");
- this.controlText("Seek to live, currently behind live");
- }
- }
- handleClick() {
- this.player_.liveTracker.seekToLiveEdge();
- }
- dispose() {
- if (this.player_.liveTracker) {
- this.off(this.player_.liveTracker, "liveedgechange", this.updateLiveEdgeStatusHandler_);
- }
- this.textEl_ = null;
- super.dispose();
- }
- }
- SeekToLive$1.prototype.controlText_ = "Seek to live, currently playing live";
- Component$1$1.registerComponent("SeekToLive", SeekToLive$1);
- function clamp$1(number, min2, max2) {
- number = Number(number);
- return Math.min(max2, Math.max(min2, isNaN(number) ? min2 : number));
- }
- var Num = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- clamp: clamp$1
- });
- class Slider$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.handleMouseDown_ = (e) => this.handleMouseDown(e);
- this.handleMouseUp_ = (e) => this.handleMouseUp(e);
- this.handleKeyDown_ = (e) => this.handleKeyDown(e);
- this.handleClick_ = (e) => this.handleClick(e);
- this.handleMouseMove_ = (e) => this.handleMouseMove(e);
- this.update_ = (e) => this.update(e);
- this.bar = this.getChild(this.options_.barName);
- this.vertical(!!this.options_.vertical);
- this.enable();
- }
- enabled() {
- return this.enabled_;
- }
- enable() {
- if (this.enabled()) {
- return;
- }
- this.on("mousedown", this.handleMouseDown_);
- this.on("touchstart", this.handleMouseDown_);
- this.on("keydown", this.handleKeyDown_);
- this.on("click", this.handleClick_);
- this.on(this.player_, "controlsvisible", this.update);
- if (this.playerEvent) {
- this.on(this.player_, this.playerEvent, this.update);
- }
- this.removeClass("disabled");
- this.setAttribute("tabindex", 0);
- this.enabled_ = true;
- }
- disable() {
- if (!this.enabled()) {
- return;
- }
- const doc = this.bar.el_.ownerDocument;
- this.off("mousedown", this.handleMouseDown_);
- this.off("touchstart", this.handleMouseDown_);
- this.off("keydown", this.handleKeyDown_);
- this.off("click", this.handleClick_);
- this.off(this.player_, "controlsvisible", this.update_);
- this.off(doc, "mousemove", this.handleMouseMove_);
- this.off(doc, "mouseup", this.handleMouseUp_);
- this.off(doc, "touchmove", this.handleMouseMove_);
- this.off(doc, "touchend", this.handleMouseUp_);
- this.removeAttribute("tabindex");
- this.addClass("disabled");
- if (this.playerEvent) {
- this.off(this.player_, this.playerEvent, this.update);
- }
- this.enabled_ = false;
- }
- createEl(type2, props = {}, attributes = {}) {
- props.className = props.className + " vjs-slider";
- props = Object.assign({
- tabIndex: 0
- }, props);
- attributes = Object.assign({
- "role": "slider",
- "aria-valuenow": 0,
- "aria-valuemin": 0,
- "aria-valuemax": 100
- }, attributes);
- return super.createEl(type2, props, attributes);
- }
- handleMouseDown(event2) {
- const doc = this.bar.el_.ownerDocument;
- if (event2.type === "mousedown") {
- event2.preventDefault();
- }
- if (event2.type === "touchstart" && !IS_CHROME$1) {
- event2.preventDefault();
- }
- blockTextSelection$1();
- this.addClass("vjs-sliding");
- this.trigger("slideractive");
- this.on(doc, "mousemove", this.handleMouseMove_);
- this.on(doc, "mouseup", this.handleMouseUp_);
- this.on(doc, "touchmove", this.handleMouseMove_);
- this.on(doc, "touchend", this.handleMouseUp_);
- this.handleMouseMove(event2, true);
- }
- handleMouseMove(event2) {
- }
- handleMouseUp(event2) {
- const doc = this.bar.el_.ownerDocument;
- unblockTextSelection$1();
- this.removeClass("vjs-sliding");
- this.trigger("sliderinactive");
- this.off(doc, "mousemove", this.handleMouseMove_);
- this.off(doc, "mouseup", this.handleMouseUp_);
- this.off(doc, "touchmove", this.handleMouseMove_);
- this.off(doc, "touchend", this.handleMouseUp_);
- this.update();
- }
- update() {
- if (!this.el_ || !this.bar) {
- return;
- }
- const progress = this.getProgress();
- if (progress === this.progress_) {
- return progress;
- }
- this.progress_ = progress;
- this.requestNamedAnimationFrame("Slider#update", () => {
- const sizeKey = this.vertical() ? "height" : "width";
- this.bar.el().style[sizeKey] = (progress * 100).toFixed(2) + "%";
- });
- return progress;
- }
- getProgress() {
- return Number(clamp$1(this.getPercent(), 0, 1).toFixed(4));
- }
- calculateDistance(event2) {
- const position2 = getPointerPosition$1(this.el_, event2);
- if (this.vertical()) {
- return position2.y;
- }
- return position2.x;
- }
- handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Left") || keycode.isEventKey(event2, "Down")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.stepBack();
- } else if (keycode.isEventKey(event2, "Right") || keycode.isEventKey(event2, "Up")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.stepForward();
- } else {
- super.handleKeyDown(event2);
- }
- }
- handleClick(event2) {
- event2.stopPropagation();
- event2.preventDefault();
- }
- vertical(bool) {
- if (bool === void 0) {
- return this.vertical_ || false;
- }
- this.vertical_ = !!bool;
- if (this.vertical_) {
- this.addClass("vjs-slider-vertical");
- } else {
- this.addClass("vjs-slider-horizontal");
- }
- }
- }
- Component$1$1.registerComponent("Slider", Slider$1);
- const percentify$1 = (time, end) => clamp$1(time / end * 100, 0, 100).toFixed(2) + "%";
- class LoadProgressBar$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.partEls_ = [];
- this.on(player, "progress", (e) => this.update(e));
- }
- createEl() {
- const el = super.createEl("div", {
- className: "vjs-load-progress"
- });
- const wrapper = createEl$1("span", {
- className: "vjs-control-text"
- });
- const loadedText = createEl$1("span", {
- textContent: this.localize("Loaded")
- });
- const separator = document_1.createTextNode(": ");
- this.percentageEl_ = createEl$1("span", {
- className: "vjs-control-text-loaded-percentage",
- textContent: "0%"
- });
- el.appendChild(wrapper);
- wrapper.appendChild(loadedText);
- wrapper.appendChild(separator);
- wrapper.appendChild(this.percentageEl_);
- return el;
- }
- dispose() {
- this.partEls_ = null;
- this.percentageEl_ = null;
- super.dispose();
- }
- update(event2) {
- this.requestNamedAnimationFrame("LoadProgressBar#update", () => {
- const liveTracker = this.player_.liveTracker;
- const buffered = this.player_.buffered();
- const duration5 = liveTracker && liveTracker.isLive() ? liveTracker.seekableEnd() : this.player_.duration();
- const bufferedEnd = this.player_.bufferedEnd();
- const children = this.partEls_;
- const percent = percentify$1(bufferedEnd, duration5);
- if (this.percent_ !== percent) {
- this.el_.style.width = percent;
- textContent$1(this.percentageEl_, percent);
- this.percent_ = percent;
- }
- for (let i2 = 0; i2 < buffered.length; i2++) {
- const start2 = buffered.start(i2);
- const end = buffered.end(i2);
- let part = children[i2];
- if (!part) {
- part = this.el_.appendChild(createEl$1());
- children[i2] = part;
- }
- if (part.dataset.start === start2 && part.dataset.end === end) {
- continue;
- }
- part.dataset.start = start2;
- part.dataset.end = end;
- part.style.left = percentify$1(start2, bufferedEnd);
- part.style.width = percentify$1(end - start2, bufferedEnd);
- }
- for (let i2 = children.length; i2 > buffered.length; i2--) {
- this.el_.removeChild(children[i2 - 1]);
- }
- children.length = buffered.length;
- });
- }
- }
- Component$1$1.registerComponent("LoadProgressBar", LoadProgressBar$1);
- class TimeTooltip$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.update = throttle$1(bind_(this, this.update), UPDATE_REFRESH_INTERVAL$1);
- }
- createEl() {
- return super.createEl("div", {
- className: "vjs-time-tooltip"
- }, {
- "aria-hidden": "true"
- });
- }
- update(seekBarRect, seekBarPoint, content) {
- const tooltipRect = findPosition$1(this.el_);
- const playerRect = getBoundingClientRect$1(this.player_.el());
- const seekBarPointPx = seekBarRect.width * seekBarPoint;
- if (!playerRect || !tooltipRect) {
- return;
- }
- const spaceLeftOfPoint = seekBarRect.left - playerRect.left + seekBarPointPx;
- const spaceRightOfPoint = seekBarRect.width - seekBarPointPx + (playerRect.right - seekBarRect.right);
- let pullTooltipBy = tooltipRect.width / 2;
- if (spaceLeftOfPoint < pullTooltipBy) {
- pullTooltipBy += pullTooltipBy - spaceLeftOfPoint;
- } else if (spaceRightOfPoint < pullTooltipBy) {
- pullTooltipBy = spaceRightOfPoint;
- }
- if (pullTooltipBy < 0) {
- pullTooltipBy = 0;
- } else if (pullTooltipBy > tooltipRect.width) {
- pullTooltipBy = tooltipRect.width;
- }
- pullTooltipBy = Math.round(pullTooltipBy);
- this.el_.style.right = `-${pullTooltipBy}px`;
- this.write(content);
- }
- write(content) {
- textContent$1(this.el_, content);
- }
- updateTime(seekBarRect, seekBarPoint, time, cb) {
- this.requestNamedAnimationFrame("TimeTooltip#updateTime", () => {
- let content;
- const duration5 = this.player_.duration();
- if (this.player_.liveTracker && this.player_.liveTracker.isLive()) {
- const liveWindow = this.player_.liveTracker.liveWindow();
- const secondsBehind = liveWindow - seekBarPoint * liveWindow;
- content = (secondsBehind < 1 ? "" : "-") + formatTime$1(secondsBehind, liveWindow);
- } else {
- content = formatTime$1(time, duration5);
- }
- this.update(seekBarRect, seekBarPoint, content);
- if (cb) {
- cb();
- }
- });
- }
- }
- Component$1$1.registerComponent("TimeTooltip", TimeTooltip$1);
- class PlayProgressBar$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.update = throttle$1(bind_(this, this.update), UPDATE_REFRESH_INTERVAL$1);
- }
- createEl() {
- return super.createEl("div", {
- className: "vjs-play-progress vjs-slider-bar"
- }, {
- "aria-hidden": "true"
- });
- }
- update(seekBarRect, seekBarPoint) {
- const timeTooltip = this.getChild("timeTooltip");
- if (!timeTooltip) {
- return;
- }
- const time = this.player_.scrubbing() ? this.player_.getCache().currentTime : this.player_.currentTime();
- timeTooltip.updateTime(seekBarRect, seekBarPoint, time);
- }
- }
- PlayProgressBar$1.prototype.options_ = {
- children: []
- };
- if (!IS_IOS$1 && !IS_ANDROID$1) {
- PlayProgressBar$1.prototype.options_.children.push("timeTooltip");
- }
- Component$1$1.registerComponent("PlayProgressBar", PlayProgressBar$1);
- class MouseTimeDisplay$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.update = throttle$1(bind_(this, this.update), UPDATE_REFRESH_INTERVAL$1);
- }
- createEl() {
- return super.createEl("div", {
- className: "vjs-mouse-display"
- });
- }
- update(seekBarRect, seekBarPoint) {
- const time = seekBarPoint * this.player_.duration();
- this.getChild("timeTooltip").updateTime(seekBarRect, seekBarPoint, time, () => {
- this.el_.style.left = `${seekBarRect.width * seekBarPoint}px`;
- });
- }
- }
- MouseTimeDisplay$1.prototype.options_ = {
- children: ["timeTooltip"]
- };
- Component$1$1.registerComponent("MouseTimeDisplay", MouseTimeDisplay$1);
- const STEP_SECONDS$1 = 5;
- const PAGE_KEY_MULTIPLIER$1 = 12;
- class SeekBar$1 extends Slider$1 {
- constructor(player, options2) {
- super(player, options2);
- this.setEventHandlers_();
- }
- setEventHandlers_() {
- this.update_ = bind_(this, this.update);
- this.update = throttle$1(this.update_, UPDATE_REFRESH_INTERVAL$1);
- this.on(this.player_, ["ended", "durationchange", "timeupdate"], this.update);
- if (this.player_.liveTracker) {
- this.on(this.player_.liveTracker, "liveedgechange", this.update);
- }
- this.updateInterval = null;
- this.enableIntervalHandler_ = (e) => this.enableInterval_(e);
- this.disableIntervalHandler_ = (e) => this.disableInterval_(e);
- this.on(this.player_, ["playing"], this.enableIntervalHandler_);
- this.on(this.player_, ["ended", "pause", "waiting"], this.disableIntervalHandler_);
- if ("hidden" in document_1 && "visibilityState" in document_1) {
- this.on(document_1, "visibilitychange", this.toggleVisibility_);
- }
- }
- toggleVisibility_(e) {
- if (document_1.visibilityState === "hidden") {
- this.cancelNamedAnimationFrame("SeekBar#update");
- this.cancelNamedAnimationFrame("Slider#update");
- this.disableInterval_(e);
- } else {
- if (!this.player_.ended() && !this.player_.paused()) {
- this.enableInterval_();
- }
- this.update();
- }
- }
- enableInterval_() {
- if (this.updateInterval) {
- return;
- }
- this.updateInterval = this.setInterval(this.update, UPDATE_REFRESH_INTERVAL$1);
- }
- disableInterval_(e) {
- if (this.player_.liveTracker && this.player_.liveTracker.isLive() && e && e.type !== "ended") {
- return;
- }
- if (!this.updateInterval) {
- return;
- }
- this.clearInterval(this.updateInterval);
- this.updateInterval = null;
- }
- createEl() {
- return super.createEl("div", {
- className: "vjs-progress-holder"
- }, {
- "aria-label": this.localize("Progress Bar")
- });
- }
- update(event2) {
- if (document_1.visibilityState === "hidden") {
- return;
- }
- const percent = super.update();
- this.requestNamedAnimationFrame("SeekBar#update", () => {
- const currentTime = this.player_.ended() ? this.player_.duration() : this.getCurrentTime_();
- const liveTracker = this.player_.liveTracker;
- let duration5 = this.player_.duration();
- if (liveTracker && liveTracker.isLive()) {
- duration5 = this.player_.liveTracker.liveCurrentTime();
- }
- if (this.percent_ !== percent) {
- this.el_.setAttribute("aria-valuenow", (percent * 100).toFixed(2));
- this.percent_ = percent;
- }
- if (this.currentTime_ !== currentTime || this.duration_ !== duration5) {
- this.el_.setAttribute("aria-valuetext", this.localize("progress bar timing: currentTime={1} duration={2}", [formatTime$1(currentTime, duration5), formatTime$1(duration5, duration5)], "{1} of {2}"));
- this.currentTime_ = currentTime;
- this.duration_ = duration5;
- }
- if (this.bar) {
- this.bar.update(getBoundingClientRect$1(this.el()), this.getProgress());
- }
- });
- return percent;
- }
- userSeek_(ct2) {
- if (this.player_.liveTracker && this.player_.liveTracker.isLive()) {
- this.player_.liveTracker.nextSeekedFromUser();
- }
- this.player_.currentTime(ct2);
- }
- getCurrentTime_() {
- return this.player_.scrubbing() ? this.player_.getCache().currentTime : this.player_.currentTime();
- }
- getPercent() {
- const currentTime = this.getCurrentTime_();
- let percent;
- const liveTracker = this.player_.liveTracker;
- if (liveTracker && liveTracker.isLive()) {
- percent = (currentTime - liveTracker.seekableStart()) / liveTracker.liveWindow();
- if (liveTracker.atLiveEdge()) {
- percent = 1;
- }
- } else {
- percent = currentTime / this.player_.duration();
- }
- return percent;
- }
- handleMouseDown(event2) {
- if (!isSingleLeftClick$1(event2)) {
- return;
- }
- event2.stopPropagation();
- this.videoWasPlaying = !this.player_.paused();
- this.player_.pause();
- super.handleMouseDown(event2);
- }
- handleMouseMove(event2, mouseDown = false) {
- if (!isSingleLeftClick$1(event2)) {
- return;
- }
- if (!mouseDown && !this.player_.scrubbing()) {
- this.player_.scrubbing(true);
- }
- let newTime;
- const distance2 = this.calculateDistance(event2);
- const liveTracker = this.player_.liveTracker;
- if (!liveTracker || !liveTracker.isLive()) {
- newTime = distance2 * this.player_.duration();
- if (newTime === this.player_.duration()) {
- newTime = newTime - 0.1;
- }
- } else {
- if (distance2 >= 0.99) {
- liveTracker.seekToLiveEdge();
- return;
- }
- const seekableStart = liveTracker.seekableStart();
- const seekableEnd = liveTracker.liveCurrentTime();
- newTime = seekableStart + distance2 * liveTracker.liveWindow();
- if (newTime >= seekableEnd) {
- newTime = seekableEnd;
- }
- if (newTime <= seekableStart) {
- newTime = seekableStart + 0.1;
- }
- if (newTime === Infinity) {
- return;
- }
- }
- this.userSeek_(newTime);
- }
- enable() {
- super.enable();
- const mouseTimeDisplay = this.getChild("mouseTimeDisplay");
- if (!mouseTimeDisplay) {
- return;
- }
- mouseTimeDisplay.show();
- }
- disable() {
- super.disable();
- const mouseTimeDisplay = this.getChild("mouseTimeDisplay");
- if (!mouseTimeDisplay) {
- return;
- }
- mouseTimeDisplay.hide();
- }
- handleMouseUp(event2) {
- super.handleMouseUp(event2);
- if (event2) {
- event2.stopPropagation();
- }
- this.player_.scrubbing(false);
- this.player_.trigger({
- type: "timeupdate",
- target: this,
- manuallyTriggered: true
- });
- if (this.videoWasPlaying) {
- silencePromise$1(this.player_.play());
- } else {
- this.update_();
- }
- }
- stepForward() {
- this.userSeek_(this.player_.currentTime() + STEP_SECONDS$1);
- }
- stepBack() {
- this.userSeek_(this.player_.currentTime() - STEP_SECONDS$1);
- }
- handleAction(event2) {
- if (this.player_.paused()) {
- this.player_.play();
- } else {
- this.player_.pause();
- }
- }
- handleKeyDown(event2) {
- const liveTracker = this.player_.liveTracker;
- if (keycode.isEventKey(event2, "Space") || keycode.isEventKey(event2, "Enter")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.handleAction(event2);
- } else if (keycode.isEventKey(event2, "Home")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.userSeek_(0);
- } else if (keycode.isEventKey(event2, "End")) {
- event2.preventDefault();
- event2.stopPropagation();
- if (liveTracker && liveTracker.isLive()) {
- this.userSeek_(liveTracker.liveCurrentTime());
- } else {
- this.userSeek_(this.player_.duration());
- }
- } else if (/^[0-9]$/.test(keycode(event2))) {
- event2.preventDefault();
- event2.stopPropagation();
- const gotoFraction = (keycode.codes[keycode(event2)] - keycode.codes["0"]) * 10 / 100;
- if (liveTracker && liveTracker.isLive()) {
- this.userSeek_(liveTracker.seekableStart() + liveTracker.liveWindow() * gotoFraction);
- } else {
- this.userSeek_(this.player_.duration() * gotoFraction);
- }
- } else if (keycode.isEventKey(event2, "PgDn")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.userSeek_(this.player_.currentTime() - STEP_SECONDS$1 * PAGE_KEY_MULTIPLIER$1);
- } else if (keycode.isEventKey(event2, "PgUp")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.userSeek_(this.player_.currentTime() + STEP_SECONDS$1 * PAGE_KEY_MULTIPLIER$1);
- } else {
- super.handleKeyDown(event2);
- }
- }
- dispose() {
- this.disableInterval_();
- this.off(this.player_, ["ended", "durationchange", "timeupdate"], this.update);
- if (this.player_.liveTracker) {
- this.off(this.player_.liveTracker, "liveedgechange", this.update);
- }
- this.off(this.player_, ["playing"], this.enableIntervalHandler_);
- this.off(this.player_, ["ended", "pause", "waiting"], this.disableIntervalHandler_);
- if ("hidden" in document_1 && "visibilityState" in document_1) {
- this.off(document_1, "visibilitychange", this.toggleVisibility_);
- }
- super.dispose();
- }
- }
- SeekBar$1.prototype.options_ = {
- children: ["loadProgressBar", "playProgressBar"],
- barName: "playProgressBar"
- };
- if (!IS_IOS$1 && !IS_ANDROID$1) {
- SeekBar$1.prototype.options_.children.splice(1, 0, "mouseTimeDisplay");
- }
- Component$1$1.registerComponent("SeekBar", SeekBar$1);
- class ProgressControl$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.handleMouseMove = throttle$1(bind_(this, this.handleMouseMove), UPDATE_REFRESH_INTERVAL$1);
- this.throttledHandleMouseSeek = throttle$1(bind_(this, this.handleMouseSeek), UPDATE_REFRESH_INTERVAL$1);
- this.handleMouseUpHandler_ = (e) => this.handleMouseUp(e);
- this.handleMouseDownHandler_ = (e) => this.handleMouseDown(e);
- this.enable();
- }
- createEl() {
- return super.createEl("div", {
- className: "vjs-progress-control vjs-control"
- });
- }
- handleMouseMove(event2) {
- const seekBar = this.getChild("seekBar");
- if (!seekBar) {
- return;
- }
- const playProgressBar = seekBar.getChild("playProgressBar");
- const mouseTimeDisplay = seekBar.getChild("mouseTimeDisplay");
- if (!playProgressBar && !mouseTimeDisplay) {
- return;
- }
- const seekBarEl = seekBar.el();
- const seekBarRect = findPosition$1(seekBarEl);
- let seekBarPoint = getPointerPosition$1(seekBarEl, event2).x;
- seekBarPoint = clamp$1(seekBarPoint, 0, 1);
- if (mouseTimeDisplay) {
- mouseTimeDisplay.update(seekBarRect, seekBarPoint);
- }
- if (playProgressBar) {
- playProgressBar.update(seekBarRect, seekBar.getProgress());
- }
- }
- handleMouseSeek(event2) {
- const seekBar = this.getChild("seekBar");
- if (seekBar) {
- seekBar.handleMouseMove(event2);
- }
- }
- enabled() {
- return this.enabled_;
- }
- disable() {
- this.children().forEach((child) => child.disable && child.disable());
- if (!this.enabled()) {
- return;
- }
- this.off(["mousedown", "touchstart"], this.handleMouseDownHandler_);
- this.off(this.el_, "mousemove", this.handleMouseMove);
- this.removeListenersAddedOnMousedownAndTouchstart();
- this.addClass("disabled");
- this.enabled_ = false;
- if (this.player_.scrubbing()) {
- const seekBar = this.getChild("seekBar");
- this.player_.scrubbing(false);
- if (seekBar.videoWasPlaying) {
- silencePromise$1(this.player_.play());
- }
- }
- }
- enable() {
- this.children().forEach((child) => child.enable && child.enable());
- if (this.enabled()) {
- return;
- }
- this.on(["mousedown", "touchstart"], this.handleMouseDownHandler_);
- this.on(this.el_, "mousemove", this.handleMouseMove);
- this.removeClass("disabled");
- this.enabled_ = true;
- }
- removeListenersAddedOnMousedownAndTouchstart() {
- const doc = this.el_.ownerDocument;
- this.off(doc, "mousemove", this.throttledHandleMouseSeek);
- this.off(doc, "touchmove", this.throttledHandleMouseSeek);
- this.off(doc, "mouseup", this.handleMouseUpHandler_);
- this.off(doc, "touchend", this.handleMouseUpHandler_);
- }
- handleMouseDown(event2) {
- const doc = this.el_.ownerDocument;
- const seekBar = this.getChild("seekBar");
- if (seekBar) {
- seekBar.handleMouseDown(event2);
- }
- this.on(doc, "mousemove", this.throttledHandleMouseSeek);
- this.on(doc, "touchmove", this.throttledHandleMouseSeek);
- this.on(doc, "mouseup", this.handleMouseUpHandler_);
- this.on(doc, "touchend", this.handleMouseUpHandler_);
- }
- handleMouseUp(event2) {
- const seekBar = this.getChild("seekBar");
- if (seekBar) {
- seekBar.handleMouseUp(event2);
- }
- this.removeListenersAddedOnMousedownAndTouchstart();
- }
- }
- ProgressControl$1.prototype.options_ = {
- children: ["seekBar"]
- };
- Component$1$1.registerComponent("ProgressControl", ProgressControl$1);
- class PictureInPictureToggle$1 extends Button$1 {
- constructor(player, options2) {
- super(player, options2);
- this.on(player, ["enterpictureinpicture", "leavepictureinpicture"], (e) => this.handlePictureInPictureChange(e));
- this.on(player, ["disablepictureinpicturechanged", "loadedmetadata"], (e) => this.handlePictureInPictureEnabledChange(e));
- this.on(player, ["loadedmetadata", "audioonlymodechange", "audiopostermodechange"], () => {
- const isSourceAudio = player.currentType().substring(0, 5) === "audio";
- if (isSourceAudio || player.audioPosterMode() || player.audioOnlyMode()) {
- if (player.isInPictureInPicture()) {
- player.exitPictureInPicture();
- }
- this.hide();
- } else {
- this.show();
- }
- });
- this.disable();
- }
- buildCSSClass() {
- return `vjs-picture-in-picture-control ${super.buildCSSClass()}`;
- }
- handlePictureInPictureEnabledChange() {
- if (document_1.pictureInPictureEnabled && this.player_.disablePictureInPicture() === false || this.player_.options_.enableDocumentPictureInPicture && "documentPictureInPicture" in window_1) {
- this.enable();
- } else {
- this.disable();
- }
- }
- handlePictureInPictureChange(event2) {
- if (this.player_.isInPictureInPicture()) {
- this.controlText("Exit Picture-in-Picture");
- } else {
- this.controlText("Picture-in-Picture");
- }
- this.handlePictureInPictureEnabledChange();
- }
- handleClick(event2) {
- if (!this.player_.isInPictureInPicture()) {
- this.player_.requestPictureInPicture();
- } else {
- this.player_.exitPictureInPicture();
- }
- }
- }
- PictureInPictureToggle$1.prototype.controlText_ = "Picture-in-Picture";
- Component$1$1.registerComponent("PictureInPictureToggle", PictureInPictureToggle$1);
- class FullscreenToggle$1 extends Button$1 {
- constructor(player, options2) {
- super(player, options2);
- this.on(player, "fullscreenchange", (e) => this.handleFullscreenChange(e));
- if (document_1[player.fsApi_.fullscreenEnabled] === false) {
- this.disable();
- }
- }
- buildCSSClass() {
- return `vjs-fullscreen-control ${super.buildCSSClass()}`;
- }
- handleFullscreenChange(event2) {
- if (this.player_.isFullscreen()) {
- this.controlText("Exit Fullscreen");
- } else {
- this.controlText("Fullscreen");
- }
- }
- handleClick(event2) {
- if (!this.player_.isFullscreen()) {
- this.player_.requestFullscreen();
- } else {
- this.player_.exitFullscreen();
- }
- }
- }
- FullscreenToggle$1.prototype.controlText_ = "Fullscreen";
- Component$1$1.registerComponent("FullscreenToggle", FullscreenToggle$1);
- const checkVolumeSupport$1 = function(self2, player) {
- if (player.tech_ && !player.tech_.featuresVolumeControl) {
- self2.addClass("vjs-hidden");
- }
- self2.on(player, "loadstart", function() {
- if (!player.tech_.featuresVolumeControl) {
- self2.addClass("vjs-hidden");
- } else {
- self2.removeClass("vjs-hidden");
- }
- });
- };
- class VolumeLevel$1 extends Component$1$1 {
- createEl() {
- const el = super.createEl("div", {
- className: "vjs-volume-level"
- });
- el.appendChild(super.createEl("span", {
- className: "vjs-control-text"
- }));
- return el;
- }
- }
- Component$1$1.registerComponent("VolumeLevel", VolumeLevel$1);
- class VolumeLevelTooltip$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.update = throttle$1(bind_(this, this.update), UPDATE_REFRESH_INTERVAL$1);
- }
- createEl() {
- return super.createEl("div", {
- className: "vjs-volume-tooltip"
- }, {
- "aria-hidden": "true"
- });
- }
- update(rangeBarRect, rangeBarPoint, vertical, content) {
- if (!vertical) {
- const tooltipRect = getBoundingClientRect$1(this.el_);
- const playerRect = getBoundingClientRect$1(this.player_.el());
- const volumeBarPointPx = rangeBarRect.width * rangeBarPoint;
- if (!playerRect || !tooltipRect) {
- return;
- }
- const spaceLeftOfPoint = rangeBarRect.left - playerRect.left + volumeBarPointPx;
- const spaceRightOfPoint = rangeBarRect.width - volumeBarPointPx + (playerRect.right - rangeBarRect.right);
- let pullTooltipBy = tooltipRect.width / 2;
- if (spaceLeftOfPoint < pullTooltipBy) {
- pullTooltipBy += pullTooltipBy - spaceLeftOfPoint;
- } else if (spaceRightOfPoint < pullTooltipBy) {
- pullTooltipBy = spaceRightOfPoint;
- }
- if (pullTooltipBy < 0) {
- pullTooltipBy = 0;
- } else if (pullTooltipBy > tooltipRect.width) {
- pullTooltipBy = tooltipRect.width;
- }
- this.el_.style.right = `-${pullTooltipBy}px`;
- }
- this.write(`${content}%`);
- }
- write(content) {
- textContent$1(this.el_, content);
- }
- updateVolume(rangeBarRect, rangeBarPoint, vertical, volume, cb) {
- this.requestNamedAnimationFrame("VolumeLevelTooltip#updateVolume", () => {
- this.update(rangeBarRect, rangeBarPoint, vertical, volume.toFixed(0));
- if (cb) {
- cb();
- }
- });
- }
- }
- Component$1$1.registerComponent("VolumeLevelTooltip", VolumeLevelTooltip$1);
- class MouseVolumeLevelDisplay$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.update = throttle$1(bind_(this, this.update), UPDATE_REFRESH_INTERVAL$1);
- }
- createEl() {
- return super.createEl("div", {
- className: "vjs-mouse-display"
- });
- }
- update(rangeBarRect, rangeBarPoint, vertical) {
- const volume = 100 * rangeBarPoint;
- this.getChild("volumeLevelTooltip").updateVolume(rangeBarRect, rangeBarPoint, vertical, volume, () => {
- if (vertical) {
- this.el_.style.bottom = `${rangeBarRect.height * rangeBarPoint}px`;
- } else {
- this.el_.style.left = `${rangeBarRect.width * rangeBarPoint}px`;
- }
- });
- }
- }
- MouseVolumeLevelDisplay$1.prototype.options_ = {
- children: ["volumeLevelTooltip"]
- };
- Component$1$1.registerComponent("MouseVolumeLevelDisplay", MouseVolumeLevelDisplay$1);
- class VolumeBar$1 extends Slider$1 {
- constructor(player, options2) {
- super(player, options2);
- this.on("slideractive", (e) => this.updateLastVolume_(e));
- this.on(player, "volumechange", (e) => this.updateARIAAttributes(e));
- player.ready(() => this.updateARIAAttributes());
- }
- createEl() {
- return super.createEl("div", {
- className: "vjs-volume-bar vjs-slider-bar"
- }, {
- "aria-label": this.localize("Volume Level"),
- "aria-live": "polite"
- });
- }
- handleMouseDown(event2) {
- if (!isSingleLeftClick$1(event2)) {
- return;
- }
- super.handleMouseDown(event2);
- }
- handleMouseMove(event2) {
- const mouseVolumeLevelDisplay = this.getChild("mouseVolumeLevelDisplay");
- if (mouseVolumeLevelDisplay) {
- const volumeBarEl = this.el();
- const volumeBarRect = getBoundingClientRect$1(volumeBarEl);
- const vertical = this.vertical();
- let volumeBarPoint = getPointerPosition$1(volumeBarEl, event2);
- volumeBarPoint = vertical ? volumeBarPoint.y : volumeBarPoint.x;
- volumeBarPoint = clamp$1(volumeBarPoint, 0, 1);
- mouseVolumeLevelDisplay.update(volumeBarRect, volumeBarPoint, vertical);
- }
- if (!isSingleLeftClick$1(event2)) {
- return;
- }
- this.checkMuted();
- this.player_.volume(this.calculateDistance(event2));
- }
- checkMuted() {
- if (this.player_.muted()) {
- this.player_.muted(false);
- }
- }
- getPercent() {
- if (this.player_.muted()) {
- return 0;
- }
- return this.player_.volume();
- }
- stepForward() {
- this.checkMuted();
- this.player_.volume(this.player_.volume() + 0.1);
- }
- stepBack() {
- this.checkMuted();
- this.player_.volume(this.player_.volume() - 0.1);
- }
- updateARIAAttributes(event2) {
- const ariaValue = this.player_.muted() ? 0 : this.volumeAsPercentage_();
- this.el_.setAttribute("aria-valuenow", ariaValue);
- this.el_.setAttribute("aria-valuetext", ariaValue + "%");
- }
- volumeAsPercentage_() {
- return Math.round(this.player_.volume() * 100);
- }
- updateLastVolume_() {
- const volumeBeforeDrag = this.player_.volume();
- this.one("sliderinactive", () => {
- if (this.player_.volume() === 0) {
- this.player_.lastVolume_(volumeBeforeDrag);
- }
- });
- }
- }
- VolumeBar$1.prototype.options_ = {
- children: ["volumeLevel"],
- barName: "volumeLevel"
- };
- if (!IS_IOS$1 && !IS_ANDROID$1) {
- VolumeBar$1.prototype.options_.children.splice(0, 0, "mouseVolumeLevelDisplay");
- }
- VolumeBar$1.prototype.playerEvent = "volumechange";
- Component$1$1.registerComponent("VolumeBar", VolumeBar$1);
- class VolumeControl$1 extends Component$1$1 {
- constructor(player, options2 = {}) {
- options2.vertical = options2.vertical || false;
- if (typeof options2.volumeBar === "undefined" || isPlain$1(options2.volumeBar)) {
- options2.volumeBar = options2.volumeBar || {};
- options2.volumeBar.vertical = options2.vertical;
- }
- super(player, options2);
- checkVolumeSupport$1(this, player);
- this.throttledHandleMouseMove = throttle$1(bind_(this, this.handleMouseMove), UPDATE_REFRESH_INTERVAL$1);
- this.handleMouseUpHandler_ = (e) => this.handleMouseUp(e);
- this.on("mousedown", (e) => this.handleMouseDown(e));
- this.on("touchstart", (e) => this.handleMouseDown(e));
- this.on("mousemove", (e) => this.handleMouseMove(e));
- this.on(this.volumeBar, ["focus", "slideractive"], () => {
- this.volumeBar.addClass("vjs-slider-active");
- this.addClass("vjs-slider-active");
- this.trigger("slideractive");
- });
- this.on(this.volumeBar, ["blur", "sliderinactive"], () => {
- this.volumeBar.removeClass("vjs-slider-active");
- this.removeClass("vjs-slider-active");
- this.trigger("sliderinactive");
- });
- }
- createEl() {
- let orientationClass = "vjs-volume-horizontal";
- if (this.options_.vertical) {
- orientationClass = "vjs-volume-vertical";
- }
- return super.createEl("div", {
- className: `vjs-volume-control vjs-control ${orientationClass}`
- });
- }
- handleMouseDown(event2) {
- const doc = this.el_.ownerDocument;
- this.on(doc, "mousemove", this.throttledHandleMouseMove);
- this.on(doc, "touchmove", this.throttledHandleMouseMove);
- this.on(doc, "mouseup", this.handleMouseUpHandler_);
- this.on(doc, "touchend", this.handleMouseUpHandler_);
- }
- handleMouseUp(event2) {
- const doc = this.el_.ownerDocument;
- this.off(doc, "mousemove", this.throttledHandleMouseMove);
- this.off(doc, "touchmove", this.throttledHandleMouseMove);
- this.off(doc, "mouseup", this.handleMouseUpHandler_);
- this.off(doc, "touchend", this.handleMouseUpHandler_);
- }
- handleMouseMove(event2) {
- this.volumeBar.handleMouseMove(event2);
- }
- }
- VolumeControl$1.prototype.options_ = {
- children: ["volumeBar"]
- };
- Component$1$1.registerComponent("VolumeControl", VolumeControl$1);
- const checkMuteSupport$1 = function(self2, player) {
- if (player.tech_ && !player.tech_.featuresMuteControl) {
- self2.addClass("vjs-hidden");
- }
- self2.on(player, "loadstart", function() {
- if (!player.tech_.featuresMuteControl) {
- self2.addClass("vjs-hidden");
- } else {
- self2.removeClass("vjs-hidden");
- }
- });
- };
- class MuteToggle$1 extends Button$1 {
- constructor(player, options2) {
- super(player, options2);
- checkMuteSupport$1(this, player);
- this.on(player, ["loadstart", "volumechange"], (e) => this.update(e));
- }
- buildCSSClass() {
- return `vjs-mute-control ${super.buildCSSClass()}`;
- }
- handleClick(event2) {
- const vol = this.player_.volume();
- const lastVolume = this.player_.lastVolume_();
- if (vol === 0) {
- const volumeToSet = lastVolume < 0.1 ? 0.1 : lastVolume;
- this.player_.volume(volumeToSet);
- this.player_.muted(false);
- } else {
- this.player_.muted(this.player_.muted() ? false : true);
- }
- }
- update(event2) {
- this.updateIcon_();
- this.updateControlText_();
- }
- updateIcon_() {
- const vol = this.player_.volume();
- let level = 3;
- if (IS_IOS$1 && this.player_.tech_ && this.player_.tech_.el_) {
- this.player_.muted(this.player_.tech_.el_.muted);
- }
- if (vol === 0 || this.player_.muted()) {
- level = 0;
- } else if (vol < 0.33) {
- level = 1;
- } else if (vol < 0.67) {
- level = 2;
- }
- removeClass$1(this.el_, [0, 1, 2, 3].reduce((str, i2) => str + `${i2 ? " " : ""}vjs-vol-${i2}`, ""));
- addClass$1(this.el_, `vjs-vol-${level}`);
- }
- updateControlText_() {
- const soundOff = this.player_.muted() || this.player_.volume() === 0;
- const text = soundOff ? "Unmute" : "Mute";
- if (this.controlText() !== text) {
- this.controlText(text);
- }
- }
- }
- MuteToggle$1.prototype.controlText_ = "Mute";
- Component$1$1.registerComponent("MuteToggle", MuteToggle$1);
- class VolumePanel$1 extends Component$1$1 {
- constructor(player, options2 = {}) {
- if (typeof options2.inline !== "undefined") {
- options2.inline = options2.inline;
- } else {
- options2.inline = true;
- }
- if (typeof options2.volumeControl === "undefined" || isPlain$1(options2.volumeControl)) {
- options2.volumeControl = options2.volumeControl || {};
- options2.volumeControl.vertical = !options2.inline;
- }
- super(player, options2);
- this.handleKeyPressHandler_ = (e) => this.handleKeyPress(e);
- this.on(player, ["loadstart"], (e) => this.volumePanelState_(e));
- this.on(this.muteToggle, "keyup", (e) => this.handleKeyPress(e));
- this.on(this.volumeControl, "keyup", (e) => this.handleVolumeControlKeyUp(e));
- this.on("keydown", (e) => this.handleKeyPress(e));
- this.on("mouseover", (e) => this.handleMouseOver(e));
- this.on("mouseout", (e) => this.handleMouseOut(e));
- this.on(this.volumeControl, ["slideractive"], this.sliderActive_);
- this.on(this.volumeControl, ["sliderinactive"], this.sliderInactive_);
- }
- sliderActive_() {
- this.addClass("vjs-slider-active");
- }
- sliderInactive_() {
- this.removeClass("vjs-slider-active");
- }
- volumePanelState_() {
- if (this.volumeControl.hasClass("vjs-hidden") && this.muteToggle.hasClass("vjs-hidden")) {
- this.addClass("vjs-hidden");
- }
- if (this.volumeControl.hasClass("vjs-hidden") && !this.muteToggle.hasClass("vjs-hidden")) {
- this.addClass("vjs-mute-toggle-only");
- }
- }
- createEl() {
- let orientationClass = "vjs-volume-panel-horizontal";
- if (!this.options_.inline) {
- orientationClass = "vjs-volume-panel-vertical";
- }
- return super.createEl("div", {
- className: `vjs-volume-panel vjs-control ${orientationClass}`
- });
- }
- dispose() {
- this.handleMouseOut();
- super.dispose();
- }
- handleVolumeControlKeyUp(event2) {
- if (keycode.isEventKey(event2, "Esc")) {
- this.muteToggle.focus();
- }
- }
- handleMouseOver(event2) {
- this.addClass("vjs-hover");
- on$1(document_1, "keyup", this.handleKeyPressHandler_);
- }
- handleMouseOut(event2) {
- this.removeClass("vjs-hover");
- off$1(document_1, "keyup", this.handleKeyPressHandler_);
- }
- handleKeyPress(event2) {
- if (keycode.isEventKey(event2, "Esc")) {
- this.handleMouseOut();
- }
- }
- }
- VolumePanel$1.prototype.options_ = {
- children: ["muteToggle", "volumeControl"]
- };
- Component$1$1.registerComponent("VolumePanel", VolumePanel$1);
- class SkipForward extends Button$1 {
- constructor(player, options2) {
- super(player, options2);
- this.validOptions = [5, 10, 30];
- this.skipTime = this.getSkipForwardTime();
- if (this.skipTime && this.validOptions.includes(this.skipTime)) {
- this.controlText(this.localize("Skip forward {1} seconds", [this.skipTime]));
- this.show();
- } else {
- this.hide();
- }
- }
- getSkipForwardTime() {
- const playerOptions = this.options_.playerOptions;
- return playerOptions.controlBar && playerOptions.controlBar.skipButtons && playerOptions.controlBar.skipButtons.forward;
- }
- buildCSSClass() {
- return `vjs-skip-forward-${this.getSkipForwardTime()} ${super.buildCSSClass()}`;
- }
- handleClick(event2) {
- const currentVideoTime = this.player_.currentTime();
- const liveTracker = this.player_.liveTracker;
- const duration5 = liveTracker && liveTracker.isLive() ? liveTracker.seekableEnd() : this.player_.duration();
- let newTime;
- if (currentVideoTime + this.skipTime <= duration5) {
- newTime = currentVideoTime + this.skipTime;
- } else {
- newTime = duration5;
- }
- this.player_.currentTime(newTime);
- }
- handleLanguagechange() {
- this.controlText(this.localize("Skip forward {1} seconds", [this.skipTime]));
- }
- }
- Component$1$1.registerComponent("SkipForward", SkipForward);
- class SkipBackward extends Button$1 {
- constructor(player, options2) {
- super(player, options2);
- this.validOptions = [5, 10, 30];
- this.skipTime = this.getSkipBackwardTime();
- if (this.skipTime && this.validOptions.includes(this.skipTime)) {
- this.controlText(this.localize("Skip backward {1} seconds", [this.skipTime]));
- this.show();
- } else {
- this.hide();
- }
- }
- getSkipBackwardTime() {
- const playerOptions = this.options_.playerOptions;
- return playerOptions.controlBar && playerOptions.controlBar.skipButtons && playerOptions.controlBar.skipButtons.backward;
- }
- buildCSSClass() {
- return `vjs-skip-backward-${this.getSkipBackwardTime()} ${super.buildCSSClass()}`;
- }
- handleClick(event2) {
- const currentVideoTime = this.player_.currentTime();
- const liveTracker = this.player_.liveTracker;
- const seekableStart = liveTracker && liveTracker.isLive() && liveTracker.seekableStart();
- let newTime;
- if (seekableStart && currentVideoTime - this.skipTime <= seekableStart) {
- newTime = seekableStart;
- } else if (currentVideoTime >= this.skipTime) {
- newTime = currentVideoTime - this.skipTime;
- } else {
- newTime = 0;
- }
- this.player_.currentTime(newTime);
- }
- handleLanguagechange() {
- this.controlText(this.localize("Skip backward {1} seconds", [this.skipTime]));
- }
- }
- SkipBackward.prototype.controlText_ = "Skip Backward";
- Component$1$1.registerComponent("SkipBackward", SkipBackward);
- class Menu$1 extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- if (options2) {
- this.menuButton_ = options2.menuButton;
- }
- this.focusedChild_ = -1;
- this.on("keydown", (e) => this.handleKeyDown(e));
- this.boundHandleBlur_ = (e) => this.handleBlur(e);
- this.boundHandleTapClick_ = (e) => this.handleTapClick(e);
- }
- addEventListenerForItem(component) {
- if (!(component instanceof Component$1$1)) {
- return;
- }
- this.on(component, "blur", this.boundHandleBlur_);
- this.on(component, ["tap", "click"], this.boundHandleTapClick_);
- }
- removeEventListenerForItem(component) {
- if (!(component instanceof Component$1$1)) {
- return;
- }
- this.off(component, "blur", this.boundHandleBlur_);
- this.off(component, ["tap", "click"], this.boundHandleTapClick_);
- }
- removeChild(component) {
- if (typeof component === "string") {
- component = this.getChild(component);
- }
- this.removeEventListenerForItem(component);
- super.removeChild(component);
- }
- addItem(component) {
- const childComponent = this.addChild(component);
- if (childComponent) {
- this.addEventListenerForItem(childComponent);
- }
- }
- createEl() {
- const contentElType = this.options_.contentElType || "ul";
- this.contentEl_ = createEl$1(contentElType, {
- className: "vjs-menu-content"
- });
- this.contentEl_.setAttribute("role", "menu");
- const el = super.createEl("div", {
- append: this.contentEl_,
- className: "vjs-menu"
- });
- el.appendChild(this.contentEl_);
- on$1(el, "click", function(event2) {
- event2.preventDefault();
- event2.stopImmediatePropagation();
- });
- return el;
- }
- dispose() {
- this.contentEl_ = null;
- this.boundHandleBlur_ = null;
- this.boundHandleTapClick_ = null;
- super.dispose();
- }
- handleBlur(event2) {
- const relatedTarget = event2.relatedTarget || document_1.activeElement;
- if (!this.children().some((element) => {
- return element.el() === relatedTarget;
- })) {
- const btn = this.menuButton_;
- if (btn && btn.buttonPressed_ && relatedTarget !== btn.el().firstChild) {
- btn.unpressButton();
- }
- }
- }
- handleTapClick(event2) {
- if (this.menuButton_) {
- this.menuButton_.unpressButton();
- const childComponents = this.children();
- if (!Array.isArray(childComponents)) {
- return;
- }
- const foundComponent = childComponents.filter((component) => component.el() === event2.target)[0];
- if (!foundComponent) {
- return;
- }
- if (foundComponent.name() !== "CaptionSettingsMenuItem") {
- this.menuButton_.focus();
- }
- }
- }
- handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Left") || keycode.isEventKey(event2, "Down")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.stepForward();
- } else if (keycode.isEventKey(event2, "Right") || keycode.isEventKey(event2, "Up")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.stepBack();
- }
- }
- stepForward() {
- let stepChild = 0;
- if (this.focusedChild_ !== void 0) {
- stepChild = this.focusedChild_ + 1;
- }
- this.focus(stepChild);
- }
- stepBack() {
- let stepChild = 0;
- if (this.focusedChild_ !== void 0) {
- stepChild = this.focusedChild_ - 1;
- }
- this.focus(stepChild);
- }
- focus(item = 0) {
- const children = this.children().slice();
- const haveTitle = children.length && children[0].hasClass("vjs-menu-title");
- if (haveTitle) {
- children.shift();
- }
- if (children.length > 0) {
- if (item < 0) {
- item = 0;
- } else if (item >= children.length) {
- item = children.length - 1;
- }
- this.focusedChild_ = item;
- children[item].el_.focus();
- }
- }
- }
- Component$1$1.registerComponent("Menu", Menu$1);
- class MenuButton$1 extends Component$1$1 {
- constructor(player, options2 = {}) {
- super(player, options2);
- this.menuButton_ = new Button$1(player, options2);
- this.menuButton_.controlText(this.controlText_);
- this.menuButton_.el_.setAttribute("aria-haspopup", "true");
- const buttonClass = Button$1.prototype.buildCSSClass();
- this.menuButton_.el_.className = this.buildCSSClass() + " " + buttonClass;
- this.menuButton_.removeClass("vjs-control");
- this.addChild(this.menuButton_);
- this.update();
- this.enabled_ = true;
- const handleClick = (e) => this.handleClick(e);
- this.handleMenuKeyUp_ = (e) => this.handleMenuKeyUp(e);
- this.on(this.menuButton_, "tap", handleClick);
- this.on(this.menuButton_, "click", handleClick);
- this.on(this.menuButton_, "keydown", (e) => this.handleKeyDown(e));
- this.on(this.menuButton_, "mouseenter", () => {
- this.addClass("vjs-hover");
- this.menu.show();
- on$1(document_1, "keyup", this.handleMenuKeyUp_);
- });
- this.on("mouseleave", (e) => this.handleMouseLeave(e));
- this.on("keydown", (e) => this.handleSubmenuKeyDown(e));
- }
- update() {
- const menu = this.createMenu();
- if (this.menu) {
- this.menu.dispose();
- this.removeChild(this.menu);
- }
- this.menu = menu;
- this.addChild(menu);
- this.buttonPressed_ = false;
- this.menuButton_.el_.setAttribute("aria-expanded", "false");
- if (this.items && this.items.length <= this.hideThreshold_) {
- this.hide();
- this.menu.contentEl_.removeAttribute("role");
- } else {
- this.show();
- this.menu.contentEl_.setAttribute("role", "menu");
- }
- }
- createMenu() {
- const menu = new Menu$1(this.player_, {
- menuButton: this
- });
- this.hideThreshold_ = 0;
- if (this.options_.title) {
- const titleEl = createEl$1("li", {
- className: "vjs-menu-title",
- textContent: toTitleCase$1$1(this.options_.title),
- tabIndex: -1
- });
- const titleComponent = new Component$1$1(this.player_, {
- el: titleEl
- });
- menu.addItem(titleComponent);
- }
- this.items = this.createItems();
- if (this.items) {
- for (let i2 = 0; i2 < this.items.length; i2++) {
- menu.addItem(this.items[i2]);
- }
- }
- return menu;
- }
- createItems() {
- }
- createEl() {
- return super.createEl("div", {
- className: this.buildWrapperCSSClass()
- }, {});
- }
- buildWrapperCSSClass() {
- let menuButtonClass = "vjs-menu-button";
- if (this.options_.inline === true) {
- menuButtonClass += "-inline";
- } else {
- menuButtonClass += "-popup";
- }
- const buttonClass = Button$1.prototype.buildCSSClass();
- return `vjs-menu-button ${menuButtonClass} ${buttonClass} ${super.buildCSSClass()}`;
- }
- buildCSSClass() {
- let menuButtonClass = "vjs-menu-button";
- if (this.options_.inline === true) {
- menuButtonClass += "-inline";
- } else {
- menuButtonClass += "-popup";
- }
- return `vjs-menu-button ${menuButtonClass} ${super.buildCSSClass()}`;
- }
- controlText(text, el = this.menuButton_.el()) {
- return this.menuButton_.controlText(text, el);
- }
- dispose() {
- this.handleMouseLeave();
- super.dispose();
- }
- handleClick(event2) {
- if (this.buttonPressed_) {
- this.unpressButton();
- } else {
- this.pressButton();
- }
- }
- handleMouseLeave(event2) {
- this.removeClass("vjs-hover");
- off$1(document_1, "keyup", this.handleMenuKeyUp_);
- }
- focus() {
- this.menuButton_.focus();
- }
- blur() {
- this.menuButton_.blur();
- }
- handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Esc") || keycode.isEventKey(event2, "Tab")) {
- if (this.buttonPressed_) {
- this.unpressButton();
- }
- if (!keycode.isEventKey(event2, "Tab")) {
- event2.preventDefault();
- this.menuButton_.focus();
- }
- } else if (keycode.isEventKey(event2, "Up") || keycode.isEventKey(event2, "Down")) {
- if (!this.buttonPressed_) {
- event2.preventDefault();
- this.pressButton();
- }
- }
- }
- handleMenuKeyUp(event2) {
- if (keycode.isEventKey(event2, "Esc") || keycode.isEventKey(event2, "Tab")) {
- this.removeClass("vjs-hover");
- }
- }
- handleSubmenuKeyPress(event2) {
- this.handleSubmenuKeyDown(event2);
- }
- handleSubmenuKeyDown(event2) {
- if (keycode.isEventKey(event2, "Esc") || keycode.isEventKey(event2, "Tab")) {
- if (this.buttonPressed_) {
- this.unpressButton();
- }
- if (!keycode.isEventKey(event2, "Tab")) {
- event2.preventDefault();
- this.menuButton_.focus();
- }
- }
- }
- pressButton() {
- if (this.enabled_) {
- this.buttonPressed_ = true;
- this.menu.show();
- this.menu.lockShowing();
- this.menuButton_.el_.setAttribute("aria-expanded", "true");
- if (IS_IOS$1 && isInFrame$1()) {
- return;
- }
- this.menu.focus();
- }
- }
- unpressButton() {
- if (this.enabled_) {
- this.buttonPressed_ = false;
- this.menu.unlockShowing();
- this.menu.hide();
- this.menuButton_.el_.setAttribute("aria-expanded", "false");
- }
- }
- disable() {
- this.unpressButton();
- this.enabled_ = false;
- this.addClass("vjs-disabled");
- this.menuButton_.disable();
- }
- enable() {
- this.enabled_ = true;
- this.removeClass("vjs-disabled");
- this.menuButton_.enable();
- }
- }
- Component$1$1.registerComponent("MenuButton", MenuButton$1);
- class TrackButton$1 extends MenuButton$1 {
- constructor(player, options2) {
- const tracks = options2.tracks;
- super(player, options2);
- if (this.items.length <= 1) {
- this.hide();
- }
- if (!tracks) {
- return;
- }
- const updateHandler = bind_(this, this.update);
- tracks.addEventListener("removetrack", updateHandler);
- tracks.addEventListener("addtrack", updateHandler);
- tracks.addEventListener("labelchange", updateHandler);
- this.player_.on("ready", updateHandler);
- this.player_.on("dispose", function() {
- tracks.removeEventListener("removetrack", updateHandler);
- tracks.removeEventListener("addtrack", updateHandler);
- tracks.removeEventListener("labelchange", updateHandler);
- });
- }
- }
- Component$1$1.registerComponent("TrackButton", TrackButton$1);
- const MenuKeys$1 = ["Tab", "Esc", "Up", "Down", "Right", "Left"];
- class MenuItem$1 extends ClickableComponent$1 {
- constructor(player, options2) {
- super(player, options2);
- this.selectable = options2.selectable;
- this.isSelected_ = options2.selected || false;
- this.multiSelectable = options2.multiSelectable;
- this.selected(this.isSelected_);
- if (this.selectable) {
- if (this.multiSelectable) {
- this.el_.setAttribute("role", "menuitemcheckbox");
- } else {
- this.el_.setAttribute("role", "menuitemradio");
- }
- } else {
- this.el_.setAttribute("role", "menuitem");
- }
- }
- createEl(type2, props, attrs) {
- this.nonIconControl = true;
- const el = super.createEl("li", Object.assign({
- className: "vjs-menu-item",
- tabIndex: -1
- }, props), attrs);
- el.replaceChild(createEl$1("span", {
- className: "vjs-menu-item-text",
- textContent: this.localize(this.options_.label)
- }), el.querySelector(".vjs-icon-placeholder"));
- return el;
- }
- handleKeyDown(event2) {
- if (!MenuKeys$1.some((key) => keycode.isEventKey(event2, key))) {
- super.handleKeyDown(event2);
- }
- }
- handleClick(event2) {
- this.selected(true);
- }
- selected(selected) {
- if (this.selectable) {
- if (selected) {
- this.addClass("vjs-selected");
- this.el_.setAttribute("aria-checked", "true");
- this.controlText(", selected");
- this.isSelected_ = true;
- } else {
- this.removeClass("vjs-selected");
- this.el_.setAttribute("aria-checked", "false");
- this.controlText("");
- this.isSelected_ = false;
- }
- }
- }
- }
- Component$1$1.registerComponent("MenuItem", MenuItem$1);
- class TextTrackMenuItem$1 extends MenuItem$1 {
- constructor(player, options2) {
- const track = options2.track;
- const tracks = player.textTracks();
- options2.label = track.label || track.language || "Unknown";
- options2.selected = track.mode === "showing";
- super(player, options2);
- this.track = track;
- this.kinds = (options2.kinds || [options2.kind || this.track.kind]).filter(Boolean);
- const changeHandler = (...args) => {
- this.handleTracksChange.apply(this, args);
- };
- const selectedLanguageChangeHandler = (...args) => {
- this.handleSelectedLanguageChange.apply(this, args);
- };
- player.on(["loadstart", "texttrackchange"], changeHandler);
- tracks.addEventListener("change", changeHandler);
- tracks.addEventListener("selectedlanguagechange", selectedLanguageChangeHandler);
- this.on("dispose", function() {
- player.off(["loadstart", "texttrackchange"], changeHandler);
- tracks.removeEventListener("change", changeHandler);
- tracks.removeEventListener("selectedlanguagechange", selectedLanguageChangeHandler);
- });
- if (tracks.onchange === void 0) {
- let event2;
- this.on(["tap", "click"], function() {
- if (typeof window_1.Event !== "object") {
- try {
- event2 = new window_1.Event("change");
- } catch (err) {
- }
- }
- if (!event2) {
- event2 = document_1.createEvent("Event");
- event2.initEvent("change", true, true);
- }
- tracks.dispatchEvent(event2);
- });
- }
- this.handleTracksChange();
- }
- handleClick(event2) {
- const referenceTrack = this.track;
- const tracks = this.player_.textTracks();
- super.handleClick(event2);
- if (!tracks) {
- return;
- }
- for (let i2 = 0; i2 < tracks.length; i2++) {
- const track = tracks[i2];
- if (this.kinds.indexOf(track.kind) === -1) {
- continue;
- }
- if (track === referenceTrack) {
- if (track.mode !== "showing") {
- track.mode = "showing";
- }
- } else if (track.mode !== "disabled") {
- track.mode = "disabled";
- }
- }
- }
- handleTracksChange(event2) {
- const shouldBeSelected = this.track.mode === "showing";
- if (shouldBeSelected !== this.isSelected_) {
- this.selected(shouldBeSelected);
- }
- }
- handleSelectedLanguageChange(event2) {
- if (this.track.mode === "showing") {
- const selectedLanguage = this.player_.cache_.selectedLanguage;
- if (selectedLanguage && selectedLanguage.enabled && selectedLanguage.language === this.track.language && selectedLanguage.kind !== this.track.kind) {
- return;
- }
- this.player_.cache_.selectedLanguage = {
- enabled: true,
- language: this.track.language,
- kind: this.track.kind
- };
- }
- }
- dispose() {
- this.track = null;
- super.dispose();
- }
- }
- Component$1$1.registerComponent("TextTrackMenuItem", TextTrackMenuItem$1);
- class OffTextTrackMenuItem$1 extends TextTrackMenuItem$1 {
- constructor(player, options2) {
- options2.track = {
- player,
- kind: options2.kind,
- kinds: options2.kinds,
- default: false,
- mode: "disabled"
- };
- if (!options2.kinds) {
- options2.kinds = [options2.kind];
- }
- if (options2.label) {
- options2.track.label = options2.label;
- } else {
- options2.track.label = options2.kinds.join(" and ") + " off";
- }
- options2.selectable = true;
- options2.multiSelectable = false;
- super(player, options2);
- }
- handleTracksChange(event2) {
- const tracks = this.player().textTracks();
- let shouldBeSelected = true;
- for (let i2 = 0, l = tracks.length; i2 < l; i2++) {
- const track = tracks[i2];
- if (this.options_.kinds.indexOf(track.kind) > -1 && track.mode === "showing") {
- shouldBeSelected = false;
- break;
- }
- }
- if (shouldBeSelected !== this.isSelected_) {
- this.selected(shouldBeSelected);
- }
- }
- handleSelectedLanguageChange(event2) {
- const tracks = this.player().textTracks();
- let allHidden = true;
- for (let i2 = 0, l = tracks.length; i2 < l; i2++) {
- const track = tracks[i2];
- if (["captions", "descriptions", "subtitles"].indexOf(track.kind) > -1 && track.mode === "showing") {
- allHidden = false;
- break;
- }
- }
- if (allHidden) {
- this.player_.cache_.selectedLanguage = {
- enabled: false
- };
- }
- }
- handleLanguagechange() {
- this.$(".vjs-menu-item-text").textContent = this.player_.localize(this.options_.label);
- super.handleLanguagechange();
- }
- }
- Component$1$1.registerComponent("OffTextTrackMenuItem", OffTextTrackMenuItem$1);
- class TextTrackButton$1 extends TrackButton$1 {
- constructor(player, options2 = {}) {
- options2.tracks = player.textTracks();
- super(player, options2);
- }
- createItems(items = [], TrackMenuItem = TextTrackMenuItem$1) {
- let label2;
- if (this.label_) {
- label2 = `${this.label_} off`;
- }
- items.push(new OffTextTrackMenuItem$1(this.player_, {
- kinds: this.kinds_,
- kind: this.kind_,
- label: label2
- }));
- this.hideThreshold_ += 1;
- const tracks = this.player_.textTracks();
- if (!Array.isArray(this.kinds_)) {
- this.kinds_ = [this.kind_];
- }
- for (let i2 = 0; i2 < tracks.length; i2++) {
- const track = tracks[i2];
- if (this.kinds_.indexOf(track.kind) > -1) {
- const item = new TrackMenuItem(this.player_, {
- track,
- kinds: this.kinds_,
- kind: this.kind_,
- selectable: true,
- multiSelectable: false
- });
- item.addClass(`vjs-${track.kind}-menu-item`);
- items.push(item);
- }
- }
- return items;
- }
- }
- Component$1$1.registerComponent("TextTrackButton", TextTrackButton$1);
- class ChaptersTrackMenuItem$1 extends MenuItem$1 {
- constructor(player, options2) {
- const track = options2.track;
- const cue = options2.cue;
- const currentTime = player.currentTime();
- options2.selectable = true;
- options2.multiSelectable = false;
- options2.label = cue.text;
- options2.selected = cue.startTime <= currentTime && currentTime < cue.endTime;
- super(player, options2);
- this.track = track;
- this.cue = cue;
- }
- handleClick(event2) {
- super.handleClick();
- this.player_.currentTime(this.cue.startTime);
- }
- }
- Component$1$1.registerComponent("ChaptersTrackMenuItem", ChaptersTrackMenuItem$1);
- class ChaptersButton$1 extends TextTrackButton$1 {
- constructor(player, options2, ready) {
- super(player, options2, ready);
- this.selectCurrentItem_ = () => {
- this.items.forEach((item) => {
- item.selected(this.track_.activeCues[0] === item.cue);
- });
- };
- }
- buildCSSClass() {
- return `vjs-chapters-button ${super.buildCSSClass()}`;
- }
- buildWrapperCSSClass() {
- return `vjs-chapters-button ${super.buildWrapperCSSClass()}`;
- }
- update(event2) {
- if (event2 && event2.track && event2.track.kind !== "chapters") {
- return;
- }
- const track = this.findChaptersTrack();
- if (track !== this.track_) {
- this.setTrack(track);
- super.update();
- } else if (!this.items || track && track.cues && track.cues.length !== this.items.length) {
- super.update();
- }
- }
- setTrack(track) {
- if (this.track_ === track) {
- return;
- }
- if (!this.updateHandler_) {
- this.updateHandler_ = this.update.bind(this);
- }
- if (this.track_) {
- const remoteTextTrackEl = this.player_.remoteTextTrackEls().getTrackElementByTrack_(this.track_);
- if (remoteTextTrackEl) {
- remoteTextTrackEl.removeEventListener("load", this.updateHandler_);
- }
- this.track_.removeEventListener("cuechange", this.selectCurrentItem_);
- this.track_ = null;
- }
- this.track_ = track;
- if (this.track_) {
- this.track_.mode = "hidden";
- const remoteTextTrackEl = this.player_.remoteTextTrackEls().getTrackElementByTrack_(this.track_);
- if (remoteTextTrackEl) {
- remoteTextTrackEl.addEventListener("load", this.updateHandler_);
- }
- this.track_.addEventListener("cuechange", this.selectCurrentItem_);
- }
- }
- findChaptersTrack() {
- const tracks = this.player_.textTracks() || [];
- for (let i2 = tracks.length - 1; i2 >= 0; i2--) {
- const track = tracks[i2];
- if (track.kind === this.kind_) {
- return track;
- }
- }
- }
- getMenuCaption() {
- if (this.track_ && this.track_.label) {
- return this.track_.label;
- }
- return this.localize(toTitleCase$1$1(this.kind_));
- }
- createMenu() {
- this.options_.title = this.getMenuCaption();
- return super.createMenu();
- }
- createItems() {
- const items = [];
- if (!this.track_) {
- return items;
- }
- const cues = this.track_.cues;
- if (!cues) {
- return items;
- }
- for (let i2 = 0, l = cues.length; i2 < l; i2++) {
- const cue = cues[i2];
- const mi = new ChaptersTrackMenuItem$1(this.player_, {
- track: this.track_,
- cue
- });
- items.push(mi);
- }
- return items;
- }
- }
- ChaptersButton$1.prototype.kind_ = "chapters";
- ChaptersButton$1.prototype.controlText_ = "Chapters";
- Component$1$1.registerComponent("ChaptersButton", ChaptersButton$1);
- class DescriptionsButton$1 extends TextTrackButton$1 {
- constructor(player, options2, ready) {
- super(player, options2, ready);
- const tracks = player.textTracks();
- const changeHandler = bind_(this, this.handleTracksChange);
- tracks.addEventListener("change", changeHandler);
- this.on("dispose", function() {
- tracks.removeEventListener("change", changeHandler);
- });
- }
- handleTracksChange(event2) {
- const tracks = this.player().textTracks();
- let disabled = false;
- for (let i2 = 0, l = tracks.length; i2 < l; i2++) {
- const track = tracks[i2];
- if (track.kind !== this.kind_ && track.mode === "showing") {
- disabled = true;
- break;
- }
- }
- if (disabled) {
- this.disable();
- } else {
- this.enable();
- }
- }
- buildCSSClass() {
- return `vjs-descriptions-button ${super.buildCSSClass()}`;
- }
- buildWrapperCSSClass() {
- return `vjs-descriptions-button ${super.buildWrapperCSSClass()}`;
- }
- }
- DescriptionsButton$1.prototype.kind_ = "descriptions";
- DescriptionsButton$1.prototype.controlText_ = "Descriptions";
- Component$1$1.registerComponent("DescriptionsButton", DescriptionsButton$1);
- class SubtitlesButton$1 extends TextTrackButton$1 {
- constructor(player, options2, ready) {
- super(player, options2, ready);
- }
- buildCSSClass() {
- return `vjs-subtitles-button ${super.buildCSSClass()}`;
- }
- buildWrapperCSSClass() {
- return `vjs-subtitles-button ${super.buildWrapperCSSClass()}`;
- }
- }
- SubtitlesButton$1.prototype.kind_ = "subtitles";
- SubtitlesButton$1.prototype.controlText_ = "Subtitles";
- Component$1$1.registerComponent("SubtitlesButton", SubtitlesButton$1);
- class CaptionSettingsMenuItem$1 extends TextTrackMenuItem$1 {
- constructor(player, options2) {
- options2.track = {
- player,
- kind: options2.kind,
- label: options2.kind + " settings",
- selectable: false,
- default: false,
- mode: "disabled"
- };
- options2.selectable = false;
- options2.name = "CaptionSettingsMenuItem";
- super(player, options2);
- this.addClass("vjs-texttrack-settings");
- this.controlText(", opens " + options2.kind + " settings dialog");
- }
- handleClick(event2) {
- this.player().getChild("textTrackSettings").open();
- }
- handleLanguagechange() {
- this.$(".vjs-menu-item-text").textContent = this.player_.localize(this.options_.kind + " settings");
- super.handleLanguagechange();
- }
- }
- Component$1$1.registerComponent("CaptionSettingsMenuItem", CaptionSettingsMenuItem$1);
- class CaptionsButton$1 extends TextTrackButton$1 {
- constructor(player, options2, ready) {
- super(player, options2, ready);
- }
- buildCSSClass() {
- return `vjs-captions-button ${super.buildCSSClass()}`;
- }
- buildWrapperCSSClass() {
- return `vjs-captions-button ${super.buildWrapperCSSClass()}`;
- }
- createItems() {
- const items = [];
- if (!(this.player().tech_ && this.player().tech_.featuresNativeTextTracks) && this.player().getChild("textTrackSettings")) {
- items.push(new CaptionSettingsMenuItem$1(this.player_, {
- kind: this.kind_
- }));
- this.hideThreshold_ += 1;
- }
- return super.createItems(items);
- }
- }
- CaptionsButton$1.prototype.kind_ = "captions";
- CaptionsButton$1.prototype.controlText_ = "Captions";
- Component$1$1.registerComponent("CaptionsButton", CaptionsButton$1);
- class SubsCapsMenuItem$1 extends TextTrackMenuItem$1 {
- createEl(type2, props, attrs) {
- const el = super.createEl(type2, props, attrs);
- const parentSpan = el.querySelector(".vjs-menu-item-text");
- if (this.options_.track.kind === "captions") {
- parentSpan.appendChild(createEl$1("span", {
- className: "vjs-icon-placeholder"
- }, {
- "aria-hidden": true
- }));
- parentSpan.appendChild(createEl$1("span", {
- className: "vjs-control-text",
- textContent: ` ${this.localize("Captions")}`
- }));
- }
- return el;
- }
- }
- Component$1$1.registerComponent("SubsCapsMenuItem", SubsCapsMenuItem$1);
- class SubsCapsButton$1 extends TextTrackButton$1 {
- constructor(player, options2 = {}) {
- super(player, options2);
- this.label_ = "subtitles";
- if (["en", "en-us", "en-ca", "fr-ca"].indexOf(this.player_.language_) > -1) {
- this.label_ = "captions";
- }
- this.menuButton_.controlText(toTitleCase$1$1(this.label_));
- }
- buildCSSClass() {
- return `vjs-subs-caps-button ${super.buildCSSClass()}`;
- }
- buildWrapperCSSClass() {
- return `vjs-subs-caps-button ${super.buildWrapperCSSClass()}`;
- }
- createItems() {
- let items = [];
- if (!(this.player().tech_ && this.player().tech_.featuresNativeTextTracks) && this.player().getChild("textTrackSettings")) {
- items.push(new CaptionSettingsMenuItem$1(this.player_, {
- kind: this.label_
- }));
- this.hideThreshold_ += 1;
- }
- items = super.createItems(items, SubsCapsMenuItem$1);
- return items;
- }
- }
- SubsCapsButton$1.prototype.kinds_ = ["captions", "subtitles"];
- SubsCapsButton$1.prototype.controlText_ = "Subtitles";
- Component$1$1.registerComponent("SubsCapsButton", SubsCapsButton$1);
- class AudioTrackMenuItem$1 extends MenuItem$1 {
- constructor(player, options2) {
- const track = options2.track;
- const tracks = player.audioTracks();
- options2.label = track.label || track.language || "Unknown";
- options2.selected = track.enabled;
- super(player, options2);
- this.track = track;
- this.addClass(`vjs-${track.kind}-menu-item`);
- const changeHandler = (...args) => {
- this.handleTracksChange.apply(this, args);
- };
- tracks.addEventListener("change", changeHandler);
- this.on("dispose", () => {
- tracks.removeEventListener("change", changeHandler);
- });
- }
- createEl(type2, props, attrs) {
- const el = super.createEl(type2, props, attrs);
- const parentSpan = el.querySelector(".vjs-menu-item-text");
- if (this.options_.track.kind === "main-desc") {
- parentSpan.appendChild(createEl$1("span", {
- className: "vjs-icon-placeholder"
- }, {
- "aria-hidden": true
- }));
- parentSpan.appendChild(createEl$1("span", {
- className: "vjs-control-text",
- textContent: " " + this.localize("Descriptions")
- }));
- }
- return el;
- }
- handleClick(event2) {
- super.handleClick(event2);
- this.track.enabled = true;
- if (this.player_.tech_.featuresNativeAudioTracks) {
- const tracks = this.player_.audioTracks();
- for (let i2 = 0; i2 < tracks.length; i2++) {
- const track = tracks[i2];
- if (track === this.track) {
- continue;
- }
- track.enabled = track === this.track;
- }
- }
- }
- handleTracksChange(event2) {
- this.selected(this.track.enabled);
- }
- }
- Component$1$1.registerComponent("AudioTrackMenuItem", AudioTrackMenuItem$1);
- class AudioTrackButton$1 extends TrackButton$1 {
- constructor(player, options2 = {}) {
- options2.tracks = player.audioTracks();
- super(player, options2);
- }
- buildCSSClass() {
- return `vjs-audio-button ${super.buildCSSClass()}`;
- }
- buildWrapperCSSClass() {
- return `vjs-audio-button ${super.buildWrapperCSSClass()}`;
- }
- createItems(items = []) {
- this.hideThreshold_ = 1;
- const tracks = this.player_.audioTracks();
- for (let i2 = 0; i2 < tracks.length; i2++) {
- const track = tracks[i2];
- items.push(new AudioTrackMenuItem$1(this.player_, {
- track,
- selectable: true,
- multiSelectable: false
- }));
- }
- return items;
- }
- }
- AudioTrackButton$1.prototype.controlText_ = "Audio Track";
- Component$1$1.registerComponent("AudioTrackButton", AudioTrackButton$1);
- class PlaybackRateMenuItem$1 extends MenuItem$1 {
- constructor(player, options2) {
- const label2 = options2.rate;
- const rate = parseFloat(label2, 10);
- options2.label = label2;
- options2.selected = rate === player.playbackRate();
- options2.selectable = true;
- options2.multiSelectable = false;
- super(player, options2);
- this.label = label2;
- this.rate = rate;
- this.on(player, "ratechange", (e) => this.update(e));
- }
- handleClick(event2) {
- super.handleClick();
- this.player().playbackRate(this.rate);
- }
- update(event2) {
- this.selected(this.player().playbackRate() === this.rate);
- }
- }
- PlaybackRateMenuItem$1.prototype.contentElType = "button";
- Component$1$1.registerComponent("PlaybackRateMenuItem", PlaybackRateMenuItem$1);
- class PlaybackRateMenuButton$1 extends MenuButton$1 {
- constructor(player, options2) {
- super(player, options2);
- this.menuButton_.el_.setAttribute("aria-describedby", this.labelElId_);
- this.updateVisibility();
- this.updateLabel();
- this.on(player, "loadstart", (e) => this.updateVisibility(e));
- this.on(player, "ratechange", (e) => this.updateLabel(e));
- this.on(player, "playbackrateschange", (e) => this.handlePlaybackRateschange(e));
- }
- createEl() {
- const el = super.createEl();
- this.labelElId_ = "vjs-playback-rate-value-label-" + this.id_;
- this.labelEl_ = createEl$1("div", {
- className: "vjs-playback-rate-value",
- id: this.labelElId_,
- textContent: "1x"
- });
- el.appendChild(this.labelEl_);
- return el;
- }
- dispose() {
- this.labelEl_ = null;
- super.dispose();
- }
- buildCSSClass() {
- return `vjs-playback-rate ${super.buildCSSClass()}`;
- }
- buildWrapperCSSClass() {
- return `vjs-playback-rate ${super.buildWrapperCSSClass()}`;
- }
- createItems() {
- const rates = this.playbackRates();
- const items = [];
- for (let i2 = rates.length - 1; i2 >= 0; i2--) {
- items.push(new PlaybackRateMenuItem$1(this.player(), {
- rate: rates[i2] + "x"
- }));
- }
- return items;
- }
- handlePlaybackRateschange(event2) {
- this.update();
- }
- playbackRates() {
- const player = this.player();
- return player.playbackRates && player.playbackRates() || [];
- }
- playbackRateSupported() {
- return this.player().tech_ && this.player().tech_.featuresPlaybackRate && this.playbackRates() && this.playbackRates().length > 0;
- }
- updateVisibility(event2) {
- if (this.playbackRateSupported()) {
- this.removeClass("vjs-hidden");
- } else {
- this.addClass("vjs-hidden");
- }
- }
- updateLabel(event2) {
- if (this.playbackRateSupported()) {
- this.labelEl_.textContent = this.player().playbackRate() + "x";
- }
- }
- }
- PlaybackRateMenuButton$1.prototype.controlText_ = "Playback Rate";
- Component$1$1.registerComponent("PlaybackRateMenuButton", PlaybackRateMenuButton$1);
- class Spacer$1 extends Component$1$1 {
- buildCSSClass() {
- return `vjs-spacer ${super.buildCSSClass()}`;
- }
- createEl(tag = "div", props = {}, attributes = {}) {
- if (!props.className) {
- props.className = this.buildCSSClass();
- }
- return super.createEl(tag, props, attributes);
- }
- }
- Component$1$1.registerComponent("Spacer", Spacer$1);
- class CustomControlSpacer$1 extends Spacer$1 {
- buildCSSClass() {
- return `vjs-custom-control-spacer ${super.buildCSSClass()}`;
- }
- createEl() {
- return super.createEl("div", {
- className: this.buildCSSClass(),
- textContent: "\xA0"
- });
- }
- }
- Component$1$1.registerComponent("CustomControlSpacer", CustomControlSpacer$1);
- class ControlBar$1 extends Component$1$1 {
- createEl() {
- return super.createEl("div", {
- className: "vjs-control-bar",
- dir: "ltr"
- });
- }
- }
- ControlBar$1.prototype.options_ = {
- children: ["playToggle", "skipBackward", "skipForward", "volumePanel", "currentTimeDisplay", "timeDivider", "durationDisplay", "progressControl", "liveDisplay", "seekToLive", "remainingTimeDisplay", "customControlSpacer", "playbackRateMenuButton", "chaptersButton", "descriptionsButton", "subsCapsButton", "audioTrackButton", "fullscreenToggle"]
- };
- if ("exitPictureInPicture" in document_1) {
- ControlBar$1.prototype.options_.children.splice(ControlBar$1.prototype.options_.children.length - 1, 0, "pictureInPictureToggle");
- }
- Component$1$1.registerComponent("ControlBar", ControlBar$1);
- class ErrorDisplay$1 extends ModalDialog$1 {
- constructor(player, options2) {
- super(player, options2);
- this.on(player, "error", (e) => this.open(e));
- }
- buildCSSClass() {
- return `vjs-error-display ${super.buildCSSClass()}`;
- }
- content() {
- const error = this.player().error();
- return error ? this.localize(error.message) : "";
- }
- }
- ErrorDisplay$1.prototype.options_ = Object.assign({}, ModalDialog$1.prototype.options_, {
- pauseOnOpen: false,
- fillAlways: true,
- temporary: false,
- uncloseable: true
- });
- Component$1$1.registerComponent("ErrorDisplay", ErrorDisplay$1);
- const LOCAL_STORAGE_KEY$1$1 = "vjs-text-track-settings";
- const COLOR_BLACK$1 = ["#000", "Black"];
- const COLOR_BLUE$1 = ["#00F", "Blue"];
- const COLOR_CYAN$1 = ["#0FF", "Cyan"];
- const COLOR_GREEN$1 = ["#0F0", "Green"];
- const COLOR_MAGENTA$1 = ["#F0F", "Magenta"];
- const COLOR_RED$1 = ["#F00", "Red"];
- const COLOR_WHITE$1 = ["#FFF", "White"];
- const COLOR_YELLOW$1 = ["#FF0", "Yellow"];
- const OPACITY_OPAQUE$1 = ["1", "Opaque"];
- const OPACITY_SEMI$1 = ["0.5", "Semi-Transparent"];
- const OPACITY_TRANS$1 = ["0", "Transparent"];
- const selectConfigs$1 = {
- backgroundColor: {
- selector: ".vjs-bg-color > select",
- id: "captions-background-color-%s",
- label: "Color",
- options: [COLOR_BLACK$1, COLOR_WHITE$1, COLOR_RED$1, COLOR_GREEN$1, COLOR_BLUE$1, COLOR_YELLOW$1, COLOR_MAGENTA$1, COLOR_CYAN$1]
- },
- backgroundOpacity: {
- selector: ".vjs-bg-opacity > select",
- id: "captions-background-opacity-%s",
- label: "Opacity",
- options: [OPACITY_OPAQUE$1, OPACITY_SEMI$1, OPACITY_TRANS$1]
- },
- color: {
- selector: ".vjs-text-color > select",
- id: "captions-foreground-color-%s",
- label: "Color",
- options: [COLOR_WHITE$1, COLOR_BLACK$1, COLOR_RED$1, COLOR_GREEN$1, COLOR_BLUE$1, COLOR_YELLOW$1, COLOR_MAGENTA$1, COLOR_CYAN$1]
- },
- edgeStyle: {
- selector: ".vjs-edge-style > select",
- id: "%s",
- label: "Text Edge Style",
- options: [["none", "None"], ["raised", "Raised"], ["depressed", "Depressed"], ["uniform", "Uniform"], ["dropshadow", "Dropshadow"]]
- },
- fontFamily: {
- selector: ".vjs-font-family > select",
- id: "captions-font-family-%s",
- label: "Font Family",
- options: [["proportionalSansSerif", "Proportional Sans-Serif"], ["monospaceSansSerif", "Monospace Sans-Serif"], ["proportionalSerif", "Proportional Serif"], ["monospaceSerif", "Monospace Serif"], ["casual", "Casual"], ["script", "Script"], ["small-caps", "Small Caps"]]
- },
- fontPercent: {
- selector: ".vjs-font-percent > select",
- id: "captions-font-size-%s",
- label: "Font Size",
- options: [["0.50", "50%"], ["0.75", "75%"], ["1.00", "100%"], ["1.25", "125%"], ["1.50", "150%"], ["1.75", "175%"], ["2.00", "200%"], ["3.00", "300%"], ["4.00", "400%"]],
- default: 2,
- parser: (v) => v === "1.00" ? null : Number(v)
- },
- textOpacity: {
- selector: ".vjs-text-opacity > select",
- id: "captions-foreground-opacity-%s",
- label: "Opacity",
- options: [OPACITY_OPAQUE$1, OPACITY_SEMI$1]
- },
- windowColor: {
- selector: ".vjs-window-color > select",
- id: "captions-window-color-%s",
- label: "Color"
- },
- windowOpacity: {
- selector: ".vjs-window-opacity > select",
- id: "captions-window-opacity-%s",
- label: "Opacity",
- options: [OPACITY_TRANS$1, OPACITY_SEMI$1, OPACITY_OPAQUE$1]
- }
- };
- selectConfigs$1.windowColor.options = selectConfigs$1.backgroundColor.options;
- function parseOptionValue$1(value, parser2) {
- if (parser2) {
- value = parser2(value);
- }
- if (value && value !== "none") {
- return value;
- }
- }
- function getSelectedOptionValue$1(el, parser2) {
- const value = el.options[el.options.selectedIndex].value;
- return parseOptionValue$1(value, parser2);
- }
- function setSelectedOption$1(el, value, parser2) {
- if (!value) {
- return;
- }
- for (let i2 = 0; i2 < el.options.length; i2++) {
- if (parseOptionValue$1(el.options[i2].value, parser2) === value) {
- el.selectedIndex = i2;
- break;
- }
- }
- }
- class TextTrackSettings$1 extends ModalDialog$1 {
- constructor(player, options2) {
- options2.temporary = false;
- super(player, options2);
- this.updateDisplay = this.updateDisplay.bind(this);
- this.fill();
- this.hasBeenOpened_ = this.hasBeenFilled_ = true;
- this.endDialog = createEl$1("p", {
- className: "vjs-control-text",
- textContent: this.localize("End of dialog window.")
- });
- this.el().appendChild(this.endDialog);
- this.setDefaults();
- if (options2.persistTextTrackSettings === void 0) {
- this.options_.persistTextTrackSettings = this.options_.playerOptions.persistTextTrackSettings;
- }
- this.on(this.$(".vjs-done-button"), "click", () => {
- this.saveSettings();
- this.close();
- });
- this.on(this.$(".vjs-default-button"), "click", () => {
- this.setDefaults();
- this.updateDisplay();
- });
- each$1(selectConfigs$1, (config) => {
- this.on(this.$(config.selector), "change", this.updateDisplay);
- });
- if (this.options_.persistTextTrackSettings) {
- this.restoreSettings();
- }
- }
- dispose() {
- this.endDialog = null;
- super.dispose();
- }
- createElSelect_(key, legendId = "", type2 = "label") {
- const config = selectConfigs$1[key];
- const id = config.id.replace("%s", this.id_);
- const selectLabelledbyIds = [legendId, id].join(" ").trim();
- return [`<${type2} id="${id}" class="${type2 === "label" ? "vjs-label" : ""}">`, this.localize(config.label), `</${type2}>`, `<select aria-labelledby="${selectLabelledbyIds}">`].concat(config.options.map((o) => {
- const optionId = id + "-" + o[1].replace(/\W+/g, "");
- return [`<option id="${optionId}" value="${o[0]}" `, `aria-labelledby="${selectLabelledbyIds} ${optionId}">`, this.localize(o[1]), "</option>"].join("");
- })).concat("</select>").join("");
- }
- createElFgColor_() {
- const legendId = `captions-text-legend-${this.id_}`;
- return ['<fieldset class="vjs-fg vjs-track-setting">', `<legend id="${legendId}">`, this.localize("Text"), "</legend>", '<span class="vjs-text-color">', this.createElSelect_("color", legendId), "</span>", '<span class="vjs-text-opacity vjs-opacity">', this.createElSelect_("textOpacity", legendId), "</span>", "</fieldset>"].join("");
- }
- createElBgColor_() {
- const legendId = `captions-background-${this.id_}`;
- return ['<fieldset class="vjs-bg vjs-track-setting">', `<legend id="${legendId}">`, this.localize("Text Background"), "</legend>", '<span class="vjs-bg-color">', this.createElSelect_("backgroundColor", legendId), "</span>", '<span class="vjs-bg-opacity vjs-opacity">', this.createElSelect_("backgroundOpacity", legendId), "</span>", "</fieldset>"].join("");
- }
- createElWinColor_() {
- const legendId = `captions-window-${this.id_}`;
- return ['<fieldset class="vjs-window vjs-track-setting">', `<legend id="${legendId}">`, this.localize("Caption Area Background"), "</legend>", '<span class="vjs-window-color">', this.createElSelect_("windowColor", legendId), "</span>", '<span class="vjs-window-opacity vjs-opacity">', this.createElSelect_("windowOpacity", legendId), "</span>", "</fieldset>"].join("");
- }
- createElColors_() {
- return createEl$1("div", {
- className: "vjs-track-settings-colors",
- innerHTML: [this.createElFgColor_(), this.createElBgColor_(), this.createElWinColor_()].join("")
- });
- }
- createElFont_() {
- return createEl$1("div", {
- className: "vjs-track-settings-font",
- innerHTML: ['<fieldset class="vjs-font-percent vjs-track-setting">', this.createElSelect_("fontPercent", "", "legend"), "</fieldset>", '<fieldset class="vjs-edge-style vjs-track-setting">', this.createElSelect_("edgeStyle", "", "legend"), "</fieldset>", '<fieldset class="vjs-font-family vjs-track-setting">', this.createElSelect_("fontFamily", "", "legend"), "</fieldset>"].join("")
- });
- }
- createElControls_() {
- const defaultsDescription = this.localize("restore all settings to the default values");
- return createEl$1("div", {
- className: "vjs-track-settings-controls",
- innerHTML: [`<button type="button" class="vjs-default-button" title="${defaultsDescription}">`, this.localize("Reset"), `<span class="vjs-control-text"> ${defaultsDescription}</span>`, "</button>", `<button type="button" class="vjs-done-button">${this.localize("Done")}</button>`].join("")
- });
- }
- content() {
- return [this.createElColors_(), this.createElFont_(), this.createElControls_()];
- }
- label() {
- return this.localize("Caption Settings Dialog");
- }
- description() {
- return this.localize("Beginning of dialog window. Escape will cancel and close the window.");
- }
- buildCSSClass() {
- return super.buildCSSClass() + " vjs-text-track-settings";
- }
- getValues() {
- return reduce$1(selectConfigs$1, (accum, config, key) => {
- const value = getSelectedOptionValue$1(this.$(config.selector), config.parser);
- if (value !== void 0) {
- accum[key] = value;
- }
- return accum;
- }, {});
- }
- setValues(values3) {
- each$1(selectConfigs$1, (config, key) => {
- setSelectedOption$1(this.$(config.selector), values3[key], config.parser);
- });
- }
- setDefaults() {
- each$1(selectConfigs$1, (config) => {
- const index2 = config.hasOwnProperty("default") ? config.default : 0;
- this.$(config.selector).selectedIndex = index2;
- });
- }
- restoreSettings() {
- let values3;
- try {
- values3 = JSON.parse(window_1.localStorage.getItem(LOCAL_STORAGE_KEY$1$1));
- } catch (err) {
- log$1$1.warn(err);
- }
- if (values3) {
- this.setValues(values3);
- }
- }
- saveSettings() {
- if (!this.options_.persistTextTrackSettings) {
- return;
- }
- const values3 = this.getValues();
- try {
- if (Object.keys(values3).length) {
- window_1.localStorage.setItem(LOCAL_STORAGE_KEY$1$1, JSON.stringify(values3));
- } else {
- window_1.localStorage.removeItem(LOCAL_STORAGE_KEY$1$1);
- }
- } catch (err) {
- log$1$1.warn(err);
- }
- }
- updateDisplay() {
- const ttDisplay = this.player_.getChild("textTrackDisplay");
- if (ttDisplay) {
- ttDisplay.updateDisplay();
- }
- }
- conditionalBlur_() {
- this.previouslyActiveEl_ = null;
- const cb = this.player_.controlBar;
- const subsCapsBtn = cb && cb.subsCapsButton;
- const ccBtn = cb && cb.captionsButton;
- if (subsCapsBtn) {
- subsCapsBtn.focus();
- } else if (ccBtn) {
- ccBtn.focus();
- }
- }
- handleLanguagechange() {
- this.fill();
- }
- }
- Component$1$1.registerComponent("TextTrackSettings", TextTrackSettings$1);
- class ResizeManager$1 extends Component$1$1 {
- constructor(player, options2) {
- let RESIZE_OBSERVER_AVAILABLE = options2.ResizeObserver || window_1.ResizeObserver;
- if (options2.ResizeObserver === null) {
- RESIZE_OBSERVER_AVAILABLE = false;
- }
- const options_ = merge$1({
- createEl: !RESIZE_OBSERVER_AVAILABLE,
- reportTouchActivity: false
- }, options2);
- super(player, options_);
- this.ResizeObserver = options2.ResizeObserver || window_1.ResizeObserver;
- this.loadListener_ = null;
- this.resizeObserver_ = null;
- this.debouncedHandler_ = debounce$1(() => {
- this.resizeHandler();
- }, 100, false, this);
- if (RESIZE_OBSERVER_AVAILABLE) {
- this.resizeObserver_ = new this.ResizeObserver(this.debouncedHandler_);
- this.resizeObserver_.observe(player.el());
- } else {
- this.loadListener_ = () => {
- if (!this.el_ || !this.el_.contentWindow) {
- return;
- }
- const debouncedHandler_ = this.debouncedHandler_;
- let unloadListener_ = this.unloadListener_ = function() {
- off$1(this, "resize", debouncedHandler_);
- off$1(this, "unload", unloadListener_);
- unloadListener_ = null;
- };
- on$1(this.el_.contentWindow, "unload", unloadListener_);
- on$1(this.el_.contentWindow, "resize", debouncedHandler_);
- };
- this.one("load", this.loadListener_);
- }
- }
- createEl() {
- return super.createEl("iframe", {
- className: "vjs-resize-manager",
- tabIndex: -1,
- title: this.localize("No content")
- }, {
- "aria-hidden": "true"
- });
- }
- resizeHandler() {
- if (!this.player_ || !this.player_.trigger) {
- return;
- }
- this.player_.trigger("playerresize");
- }
- dispose() {
- if (this.debouncedHandler_) {
- this.debouncedHandler_.cancel();
- }
- if (this.resizeObserver_) {
- if (this.player_.el()) {
- this.resizeObserver_.unobserve(this.player_.el());
- }
- this.resizeObserver_.disconnect();
- }
- if (this.loadListener_) {
- this.off("load", this.loadListener_);
- }
- if (this.el_ && this.el_.contentWindow && this.unloadListener_) {
- this.unloadListener_.call(this.el_.contentWindow);
- }
- this.ResizeObserver = null;
- this.resizeObserver = null;
- this.debouncedHandler_ = null;
- this.loadListener_ = null;
- super.dispose();
- }
- }
- Component$1$1.registerComponent("ResizeManager", ResizeManager$1);
- const defaults$2 = {
- trackingThreshold: 20,
- liveTolerance: 15
- };
- class LiveTracker$1 extends Component$1$1 {
- constructor(player, options2) {
- const options_ = merge$1(defaults$2, options2, {
- createEl: false
- });
- super(player, options_);
- this.trackLiveHandler_ = () => this.trackLive_();
- this.handlePlay_ = (e) => this.handlePlay(e);
- this.handleFirstTimeupdate_ = (e) => this.handleFirstTimeupdate(e);
- this.handleSeeked_ = (e) => this.handleSeeked(e);
- this.seekToLiveEdge_ = (e) => this.seekToLiveEdge(e);
- this.reset_();
- this.on(this.player_, "durationchange", (e) => this.handleDurationchange(e));
- this.on(this.player_, "canplay", () => this.toggleTracking());
- }
- trackLive_() {
- const seekable3 = this.player_.seekable();
- if (!seekable3 || !seekable3.length) {
- return;
- }
- const newTime = Number(window_1.performance.now().toFixed(4));
- const deltaTime = this.lastTime_ === -1 ? 0 : (newTime - this.lastTime_) / 1e3;
- this.lastTime_ = newTime;
- this.pastSeekEnd_ = this.pastSeekEnd() + deltaTime;
- const liveCurrentTime = this.liveCurrentTime();
- const currentTime = this.player_.currentTime();
- let isBehind = this.player_.paused() || this.seekedBehindLive_ || Math.abs(liveCurrentTime - currentTime) > this.options_.liveTolerance;
- if (!this.timeupdateSeen_ || liveCurrentTime === Infinity) {
- isBehind = false;
- }
- if (isBehind !== this.behindLiveEdge_) {
- this.behindLiveEdge_ = isBehind;
- this.trigger("liveedgechange");
- }
- }
- handleDurationchange() {
- this.toggleTracking();
- }
- toggleTracking() {
- if (this.player_.duration() === Infinity && this.liveWindow() >= this.options_.trackingThreshold) {
- if (this.player_.options_.liveui) {
- this.player_.addClass("vjs-liveui");
- }
- this.startTracking();
- } else {
- this.player_.removeClass("vjs-liveui");
- this.stopTracking();
- }
- }
- startTracking() {
- if (this.isTracking()) {
- return;
- }
- if (!this.timeupdateSeen_) {
- this.timeupdateSeen_ = this.player_.hasStarted();
- }
- this.trackingInterval_ = this.setInterval(this.trackLiveHandler_, UPDATE_REFRESH_INTERVAL$1);
- this.trackLive_();
- this.on(this.player_, ["play", "pause"], this.trackLiveHandler_);
- if (!this.timeupdateSeen_) {
- this.one(this.player_, "play", this.handlePlay_);
- this.one(this.player_, "timeupdate", this.handleFirstTimeupdate_);
- } else {
- this.on(this.player_, "seeked", this.handleSeeked_);
- }
- }
- handleFirstTimeupdate() {
- this.timeupdateSeen_ = true;
- this.on(this.player_, "seeked", this.handleSeeked_);
- }
- handleSeeked() {
- const timeDiff = Math.abs(this.liveCurrentTime() - this.player_.currentTime());
- this.seekedBehindLive_ = this.nextSeekedFromUser_ && timeDiff > 2;
- this.nextSeekedFromUser_ = false;
- this.trackLive_();
- }
- handlePlay() {
- this.one(this.player_, "timeupdate", this.seekToLiveEdge_);
- }
- reset_() {
- this.lastTime_ = -1;
- this.pastSeekEnd_ = 0;
- this.lastSeekEnd_ = -1;
- this.behindLiveEdge_ = true;
- this.timeupdateSeen_ = false;
- this.seekedBehindLive_ = false;
- this.nextSeekedFromUser_ = false;
- this.clearInterval(this.trackingInterval_);
- this.trackingInterval_ = null;
- this.off(this.player_, ["play", "pause"], this.trackLiveHandler_);
- this.off(this.player_, "seeked", this.handleSeeked_);
- this.off(this.player_, "play", this.handlePlay_);
- this.off(this.player_, "timeupdate", this.handleFirstTimeupdate_);
- this.off(this.player_, "timeupdate", this.seekToLiveEdge_);
- }
- nextSeekedFromUser() {
- this.nextSeekedFromUser_ = true;
- }
- stopTracking() {
- if (!this.isTracking()) {
- return;
- }
- this.reset_();
- this.trigger("liveedgechange");
- }
- seekableEnd() {
- const seekable3 = this.player_.seekable();
- const seekableEnds = [];
- let i2 = seekable3 ? seekable3.length : 0;
- while (i2--) {
- seekableEnds.push(seekable3.end(i2));
- }
- return seekableEnds.length ? seekableEnds.sort()[seekableEnds.length - 1] : Infinity;
- }
- seekableStart() {
- const seekable3 = this.player_.seekable();
- const seekableStarts = [];
- let i2 = seekable3 ? seekable3.length : 0;
- while (i2--) {
- seekableStarts.push(seekable3.start(i2));
- }
- return seekableStarts.length ? seekableStarts.sort()[0] : 0;
- }
- liveWindow() {
- const liveCurrentTime = this.liveCurrentTime();
- if (liveCurrentTime === Infinity) {
- return 0;
- }
- return liveCurrentTime - this.seekableStart();
- }
- isLive() {
- return this.isTracking();
- }
- atLiveEdge() {
- return !this.behindLiveEdge();
- }
- liveCurrentTime() {
- return this.pastSeekEnd() + this.seekableEnd();
- }
- pastSeekEnd() {
- const seekableEnd = this.seekableEnd();
- if (this.lastSeekEnd_ !== -1 && seekableEnd !== this.lastSeekEnd_) {
- this.pastSeekEnd_ = 0;
- }
- this.lastSeekEnd_ = seekableEnd;
- return this.pastSeekEnd_;
- }
- behindLiveEdge() {
- return this.behindLiveEdge_;
- }
- isTracking() {
- return typeof this.trackingInterval_ === "number";
- }
- seekToLiveEdge() {
- this.seekedBehindLive_ = false;
- if (this.atLiveEdge()) {
- return;
- }
- this.nextSeekedFromUser_ = false;
- this.player_.currentTime(this.liveCurrentTime());
- }
- dispose() {
- this.stopTracking();
- super.dispose();
- }
- }
- Component$1$1.registerComponent("LiveTracker", LiveTracker$1);
- class TitleBar extends Component$1$1 {
- constructor(player, options2) {
- super(player, options2);
- this.on("statechanged", (e) => this.updateDom_());
- this.updateDom_();
- }
- createEl() {
- this.els = {
- title: createEl$1("div", {
- className: "vjs-title-bar-title",
- id: `vjs-title-bar-title-${newGUID$1()}`
- }),
- description: createEl$1("div", {
- className: "vjs-title-bar-description",
- id: `vjs-title-bar-description-${newGUID$1()}`
- })
- };
- return createEl$1("div", {
- className: "vjs-title-bar"
- }, {}, Object.values(this.els));
- }
- updateDom_() {
- const tech = this.player_.tech_;
- const techEl = tech && tech.el_;
- const techAriaAttrs = {
- title: "aria-labelledby",
- description: "aria-describedby"
- };
- ["title", "description"].forEach((k) => {
- const value = this.state[k];
- const el = this.els[k];
- const techAriaAttr = techAriaAttrs[k];
- emptyEl$1(el);
- if (value) {
- textContent$1(el, value);
- }
- if (techEl) {
- techEl.removeAttribute(techAriaAttr);
- if (value) {
- techEl.setAttribute(techAriaAttr, el.id);
- }
- }
- });
- if (this.state.title || this.state.description) {
- this.show();
- } else {
- this.hide();
- }
- }
- update(options2) {
- this.setState(options2);
- }
- dispose() {
- const tech = this.player_.tech_;
- const techEl = tech && tech.el_;
- if (techEl) {
- techEl.removeAttribute("aria-labelledby");
- techEl.removeAttribute("aria-describedby");
- }
- super.dispose();
- this.els = null;
- }
- }
- Component$1$1.registerComponent("TitleBar", TitleBar);
- const sourcesetLoad$1 = (tech) => {
- const el = tech.el();
- if (el.hasAttribute("src")) {
- tech.triggerSourceset(el.src);
- return true;
- }
- const sources = tech.$$("source");
- const srcUrls = [];
- let src = "";
- if (!sources.length) {
- return false;
- }
- for (let i2 = 0; i2 < sources.length; i2++) {
- const url = sources[i2].src;
- if (url && srcUrls.indexOf(url) === -1) {
- srcUrls.push(url);
- }
- }
- if (!srcUrls.length) {
- return false;
- }
- if (srcUrls.length === 1) {
- src = srcUrls[0];
- }
- tech.triggerSourceset(src);
- return true;
- };
- const innerHTMLDescriptorPolyfill$1 = Object.defineProperty({}, "innerHTML", {
- get() {
- return this.cloneNode(true).innerHTML;
- },
- set(v) {
- const dummy = document_1.createElement(this.nodeName.toLowerCase());
- dummy.innerHTML = v;
- const docFrag = document_1.createDocumentFragment();
- while (dummy.childNodes.length) {
- docFrag.appendChild(dummy.childNodes[0]);
- }
- this.innerText = "";
- window_1.Element.prototype.appendChild.call(this, docFrag);
- return this.innerHTML;
- }
- });
- const getDescriptor$1 = (priority, prop) => {
- let descriptor = {};
- for (let i2 = 0; i2 < priority.length; i2++) {
- descriptor = Object.getOwnPropertyDescriptor(priority[i2], prop);
- if (descriptor && descriptor.set && descriptor.get) {
- break;
- }
- }
- descriptor.enumerable = true;
- descriptor.configurable = true;
- return descriptor;
- };
- const getInnerHTMLDescriptor$1 = (tech) => getDescriptor$1([tech.el(), window_1.HTMLMediaElement.prototype, window_1.Element.prototype, innerHTMLDescriptorPolyfill$1], "innerHTML");
- const firstSourceWatch$1 = function(tech) {
- const el = tech.el();
- if (el.resetSourceWatch_) {
- return;
- }
- const old = {};
- const innerDescriptor = getInnerHTMLDescriptor$1(tech);
- const appendWrapper = (appendFn) => (...args) => {
- const retval = appendFn.apply(el, args);
- sourcesetLoad$1(tech);
- return retval;
- };
- ["append", "appendChild", "insertAdjacentHTML"].forEach((k) => {
- if (!el[k]) {
- return;
- }
- old[k] = el[k];
- el[k] = appendWrapper(old[k]);
- });
- Object.defineProperty(el, "innerHTML", merge$1(innerDescriptor, {
- set: appendWrapper(innerDescriptor.set)
- }));
- el.resetSourceWatch_ = () => {
- el.resetSourceWatch_ = null;
- Object.keys(old).forEach((k) => {
- el[k] = old[k];
- });
- Object.defineProperty(el, "innerHTML", innerDescriptor);
- };
- tech.one("sourceset", el.resetSourceWatch_);
- };
- const srcDescriptorPolyfill$1 = Object.defineProperty({}, "src", {
- get() {
- if (this.hasAttribute("src")) {
- return getAbsoluteURL$1(window_1.Element.prototype.getAttribute.call(this, "src"));
- }
- return "";
- },
- set(v) {
- window_1.Element.prototype.setAttribute.call(this, "src", v);
- return v;
- }
- });
- const getSrcDescriptor$1 = (tech) => getDescriptor$1([tech.el(), window_1.HTMLMediaElement.prototype, srcDescriptorPolyfill$1], "src");
- const setupSourceset$1 = function(tech) {
- if (!tech.featuresSourceset) {
- return;
- }
- const el = tech.el();
- if (el.resetSourceset_) {
- return;
- }
- const srcDescriptor = getSrcDescriptor$1(tech);
- const oldSetAttribute = el.setAttribute;
- const oldLoad = el.load;
- Object.defineProperty(el, "src", merge$1(srcDescriptor, {
- set: (v) => {
- const retval = srcDescriptor.set.call(el, v);
- tech.triggerSourceset(el.src);
- return retval;
- }
- }));
- el.setAttribute = (n, v) => {
- const retval = oldSetAttribute.call(el, n, v);
- if (/src/i.test(n)) {
- tech.triggerSourceset(el.src);
- }
- return retval;
- };
- el.load = () => {
- const retval = oldLoad.call(el);
- if (!sourcesetLoad$1(tech)) {
- tech.triggerSourceset("");
- firstSourceWatch$1(tech);
- }
- return retval;
- };
- if (el.currentSrc) {
- tech.triggerSourceset(el.currentSrc);
- } else if (!sourcesetLoad$1(tech)) {
- firstSourceWatch$1(tech);
- }
- el.resetSourceset_ = () => {
- el.resetSourceset_ = null;
- el.load = oldLoad;
- el.setAttribute = oldSetAttribute;
- Object.defineProperty(el, "src", srcDescriptor);
- if (el.resetSourceWatch_) {
- el.resetSourceWatch_();
- }
- };
- };
- class Html5$2 extends Tech$2 {
- constructor(options2, ready) {
- super(options2, ready);
- const source = options2.source;
- let crossoriginTracks = false;
- this.featuresVideoFrameCallback = this.featuresVideoFrameCallback && this.el_.tagName === "VIDEO";
- if (source && (this.el_.currentSrc !== source.src || options2.tag && options2.tag.initNetworkState_ === 3)) {
- this.setSource(source);
- } else {
- this.handleLateInit_(this.el_);
- }
- if (options2.enableSourceset) {
- this.setupSourcesetHandling_();
- }
- this.isScrubbing_ = false;
- if (this.el_.hasChildNodes()) {
- const nodes = this.el_.childNodes;
- let nodesLength = nodes.length;
- const removeNodes = [];
- while (nodesLength--) {
- const node = nodes[nodesLength];
- const nodeName = node.nodeName.toLowerCase();
- if (nodeName === "track") {
- if (!this.featuresNativeTextTracks) {
- removeNodes.push(node);
- } else {
- this.remoteTextTrackEls().addTrackElement_(node);
- this.remoteTextTracks().addTrack(node.track);
- this.textTracks().addTrack(node.track);
- if (!crossoriginTracks && !this.el_.hasAttribute("crossorigin") && isCrossOrigin$1(node.src)) {
- crossoriginTracks = true;
- }
- }
- }
- }
- for (let i2 = 0; i2 < removeNodes.length; i2++) {
- this.el_.removeChild(removeNodes[i2]);
- }
- }
- this.proxyNativeTracks_();
- if (this.featuresNativeTextTracks && crossoriginTracks) {
- log$1$1.warn("Text Tracks are being loaded from another origin but the crossorigin attribute isn't used.\nThis may prevent text tracks from loading.");
- }
- this.restoreMetadataTracksInIOSNativePlayer_();
- if ((TOUCH_ENABLED$1 || IS_IPHONE$1) && options2.nativeControlsForTouch === true) {
- this.setControls(true);
- }
- this.proxyWebkitFullscreen_();
- this.triggerReady();
- }
- dispose() {
- if (this.el_ && this.el_.resetSourceset_) {
- this.el_.resetSourceset_();
- }
- Html5$2.disposeMediaElement(this.el_);
- this.options_ = null;
- super.dispose();
- }
- setupSourcesetHandling_() {
- setupSourceset$1(this);
- }
- restoreMetadataTracksInIOSNativePlayer_() {
- const textTracks = this.textTracks();
- let metadataTracksPreFullscreenState;
- const takeMetadataTrackSnapshot = () => {
- metadataTracksPreFullscreenState = [];
- for (let i2 = 0; i2 < textTracks.length; i2++) {
- const track = textTracks[i2];
- if (track.kind === "metadata") {
- metadataTracksPreFullscreenState.push({
- track,
- storedMode: track.mode
- });
- }
- }
- };
- takeMetadataTrackSnapshot();
- textTracks.addEventListener("change", takeMetadataTrackSnapshot);
- this.on("dispose", () => textTracks.removeEventListener("change", takeMetadataTrackSnapshot));
- const restoreTrackMode = () => {
- for (let i2 = 0; i2 < metadataTracksPreFullscreenState.length; i2++) {
- const storedTrack = metadataTracksPreFullscreenState[i2];
- if (storedTrack.track.mode === "disabled" && storedTrack.track.mode !== storedTrack.storedMode) {
- storedTrack.track.mode = storedTrack.storedMode;
- }
- }
- textTracks.removeEventListener("change", restoreTrackMode);
- };
- this.on("webkitbeginfullscreen", () => {
- textTracks.removeEventListener("change", takeMetadataTrackSnapshot);
- textTracks.removeEventListener("change", restoreTrackMode);
- textTracks.addEventListener("change", restoreTrackMode);
- });
- this.on("webkitendfullscreen", () => {
- textTracks.removeEventListener("change", takeMetadataTrackSnapshot);
- textTracks.addEventListener("change", takeMetadataTrackSnapshot);
- textTracks.removeEventListener("change", restoreTrackMode);
- });
- }
- overrideNative_(type2, override) {
- if (override !== this[`featuresNative${type2}Tracks`]) {
- return;
- }
- const lowerCaseType = type2.toLowerCase();
- if (this[`${lowerCaseType}TracksListeners_`]) {
- Object.keys(this[`${lowerCaseType}TracksListeners_`]).forEach((eventName) => {
- const elTracks = this.el()[`${lowerCaseType}Tracks`];
- elTracks.removeEventListener(eventName, this[`${lowerCaseType}TracksListeners_`][eventName]);
- });
- }
- this[`featuresNative${type2}Tracks`] = !override;
- this[`${lowerCaseType}TracksListeners_`] = null;
- this.proxyNativeTracksForType_(lowerCaseType);
- }
- overrideNativeAudioTracks(override) {
- this.overrideNative_("Audio", override);
- }
- overrideNativeVideoTracks(override) {
- this.overrideNative_("Video", override);
- }
- proxyNativeTracksForType_(name) {
- const props = NORMAL$1[name];
- const elTracks = this.el()[props.getterName];
- const techTracks = this[props.getterName]();
- if (!this[`featuresNative${props.capitalName}Tracks`] || !elTracks || !elTracks.addEventListener) {
- return;
- }
- const listeners = {
- change: (e) => {
- const event2 = {
- type: "change",
- target: techTracks,
- currentTarget: techTracks,
- srcElement: techTracks
- };
- techTracks.trigger(event2);
- if (name === "text") {
- this[REMOTE$1.remoteText.getterName]().trigger(event2);
- }
- },
- addtrack(e) {
- techTracks.addTrack(e.track);
- },
- removetrack(e) {
- techTracks.removeTrack(e.track);
- }
- };
- const removeOldTracks = function() {
- const removeTracks = [];
- for (let i2 = 0; i2 < techTracks.length; i2++) {
- let found = false;
- for (let j = 0; j < elTracks.length; j++) {
- if (elTracks[j] === techTracks[i2]) {
- found = true;
- break;
- }
- }
- if (!found) {
- removeTracks.push(techTracks[i2]);
- }
- }
- while (removeTracks.length) {
- techTracks.removeTrack(removeTracks.shift());
- }
- };
- this[props.getterName + "Listeners_"] = listeners;
- Object.keys(listeners).forEach((eventName) => {
- const listener = listeners[eventName];
- elTracks.addEventListener(eventName, listener);
- this.on("dispose", (e) => elTracks.removeEventListener(eventName, listener));
- });
- this.on("loadstart", removeOldTracks);
- this.on("dispose", (e) => this.off("loadstart", removeOldTracks));
- }
- proxyNativeTracks_() {
- NORMAL$1.names.forEach((name) => {
- this.proxyNativeTracksForType_(name);
- });
- }
- createEl() {
- let el = this.options_.tag;
- if (!el || !(this.options_.playerElIngest || this.movingMediaElementInDOM)) {
- if (el) {
- const clone = el.cloneNode(true);
- if (el.parentNode) {
- el.parentNode.insertBefore(clone, el);
- }
- Html5$2.disposeMediaElement(el);
- el = clone;
- } else {
- el = document_1.createElement("video");
- const tagAttributes = this.options_.tag && getAttributes$1(this.options_.tag);
- const attributes = merge$1({}, tagAttributes);
- if (!TOUCH_ENABLED$1 || this.options_.nativeControlsForTouch !== true) {
- delete attributes.controls;
- }
- setAttributes$1(el, Object.assign(attributes, {
- id: this.options_.techId,
- class: "vjs-tech"
- }));
- }
- el.playerId = this.options_.playerId;
- }
- if (typeof this.options_.preload !== "undefined") {
- setAttribute$1(el, "preload", this.options_.preload);
- }
- if (this.options_.disablePictureInPicture !== void 0) {
- el.disablePictureInPicture = this.options_.disablePictureInPicture;
- }
- const settingsAttrs = ["loop", "muted", "playsinline", "autoplay"];
- for (let i2 = 0; i2 < settingsAttrs.length; i2++) {
- const attr = settingsAttrs[i2];
- const value = this.options_[attr];
- if (typeof value !== "undefined") {
- if (value) {
- setAttribute$1(el, attr, attr);
- } else {
- removeAttribute$1(el, attr);
- }
- el[attr] = value;
- }
- }
- return el;
- }
- handleLateInit_(el) {
- if (el.networkState === 0 || el.networkState === 3) {
- return;
- }
- if (el.readyState === 0) {
- let loadstartFired = false;
- const setLoadstartFired = function() {
- loadstartFired = true;
- };
- this.on("loadstart", setLoadstartFired);
- const triggerLoadstart = function() {
- if (!loadstartFired) {
- this.trigger("loadstart");
- }
- };
- this.on("loadedmetadata", triggerLoadstart);
- this.ready(function() {
- this.off("loadstart", setLoadstartFired);
- this.off("loadedmetadata", triggerLoadstart);
- if (!loadstartFired) {
- this.trigger("loadstart");
- }
- });
- return;
- }
- const eventsToTrigger = ["loadstart"];
- eventsToTrigger.push("loadedmetadata");
- if (el.readyState >= 2) {
- eventsToTrigger.push("loadeddata");
- }
- if (el.readyState >= 3) {
- eventsToTrigger.push("canplay");
- }
- if (el.readyState >= 4) {
- eventsToTrigger.push("canplaythrough");
- }
- this.ready(function() {
- eventsToTrigger.forEach(function(type2) {
- this.trigger(type2);
- }, this);
- });
- }
- setScrubbing(isScrubbing) {
- this.isScrubbing_ = isScrubbing;
- }
- scrubbing() {
- return this.isScrubbing_;
- }
- setCurrentTime(seconds) {
- try {
- if (this.isScrubbing_ && this.el_.fastSeek && IS_ANY_SAFARI$1) {
- this.el_.fastSeek(seconds);
- } else {
- this.el_.currentTime = seconds;
- }
- } catch (e) {
- log$1$1(e, "Video is not ready. (Video.js)");
- }
- }
- duration() {
- if (this.el_.duration === Infinity && IS_ANDROID$1 && IS_CHROME$1 && this.el_.currentTime === 0) {
- const checkProgress = () => {
- if (this.el_.currentTime > 0) {
- if (this.el_.duration === Infinity) {
- this.trigger("durationchange");
- }
- this.off("timeupdate", checkProgress);
- }
- };
- this.on("timeupdate", checkProgress);
- return NaN;
- }
- return this.el_.duration || NaN;
- }
- width() {
- return this.el_.offsetWidth;
- }
- height() {
- return this.el_.offsetHeight;
- }
- proxyWebkitFullscreen_() {
- if (!("webkitDisplayingFullscreen" in this.el_)) {
- return;
- }
- const endFn = function() {
- this.trigger("fullscreenchange", {
- isFullscreen: false
- });
- if (this.el_.controls && !this.options_.nativeControlsForTouch && this.controls()) {
- this.el_.controls = false;
- }
- };
- const beginFn = function() {
- if ("webkitPresentationMode" in this.el_ && this.el_.webkitPresentationMode !== "picture-in-picture") {
- this.one("webkitendfullscreen", endFn);
- this.trigger("fullscreenchange", {
- isFullscreen: true,
- nativeIOSFullscreen: true
- });
- }
- };
- this.on("webkitbeginfullscreen", beginFn);
- this.on("dispose", () => {
- this.off("webkitbeginfullscreen", beginFn);
- this.off("webkitendfullscreen", endFn);
- });
- }
- supportsFullScreen() {
- return typeof this.el_.webkitEnterFullScreen === "function";
- }
- enterFullScreen() {
- const video = this.el_;
- if (video.paused && video.networkState <= video.HAVE_METADATA) {
- silencePromise$1(this.el_.play());
- this.setTimeout(function() {
- video.pause();
- try {
- video.webkitEnterFullScreen();
- } catch (e) {
- this.trigger("fullscreenerror", e);
- }
- }, 0);
- } else {
- try {
- video.webkitEnterFullScreen();
- } catch (e) {
- this.trigger("fullscreenerror", e);
- }
- }
- }
- exitFullScreen() {
- if (!this.el_.webkitDisplayingFullscreen) {
- this.trigger("fullscreenerror", new Error("The video is not fullscreen"));
- return;
- }
- this.el_.webkitExitFullScreen();
- }
- requestPictureInPicture() {
- return this.el_.requestPictureInPicture();
- }
- requestVideoFrameCallback(cb) {
- if (this.featuresVideoFrameCallback && !this.el_.webkitKeys) {
- return this.el_.requestVideoFrameCallback(cb);
- }
- return super.requestVideoFrameCallback(cb);
- }
- cancelVideoFrameCallback(id) {
- if (this.featuresVideoFrameCallback && !this.el_.webkitKeys) {
- this.el_.cancelVideoFrameCallback(id);
- } else {
- super.cancelVideoFrameCallback(id);
- }
- }
- src(src) {
- if (src === void 0) {
- return this.el_.src;
- }
- this.setSrc(src);
- }
- reset() {
- Html5$2.resetMediaElement(this.el_);
- }
- currentSrc() {
- if (this.currentSource_) {
- return this.currentSource_.src;
- }
- return this.el_.currentSrc;
- }
- setControls(val) {
- this.el_.controls = !!val;
- }
- addTextTrack(kind, label2, language) {
- if (!this.featuresNativeTextTracks) {
- return super.addTextTrack(kind, label2, language);
- }
- return this.el_.addTextTrack(kind, label2, language);
- }
- createRemoteTextTrack(options2) {
- if (!this.featuresNativeTextTracks) {
- return super.createRemoteTextTrack(options2);
- }
- const htmlTrackElement = document_1.createElement("track");
- if (options2.kind) {
- htmlTrackElement.kind = options2.kind;
- }
- if (options2.label) {
- htmlTrackElement.label = options2.label;
- }
- if (options2.language || options2.srclang) {
- htmlTrackElement.srclang = options2.language || options2.srclang;
- }
- if (options2.default) {
- htmlTrackElement.default = options2.default;
- }
- if (options2.id) {
- htmlTrackElement.id = options2.id;
- }
- if (options2.src) {
- htmlTrackElement.src = options2.src;
- }
- return htmlTrackElement;
- }
- addRemoteTextTrack(options2, manualCleanup) {
- const htmlTrackElement = super.addRemoteTextTrack(options2, manualCleanup);
- if (this.featuresNativeTextTracks) {
- this.el().appendChild(htmlTrackElement);
- }
- return htmlTrackElement;
- }
- removeRemoteTextTrack(track) {
- super.removeRemoteTextTrack(track);
- if (this.featuresNativeTextTracks) {
- const tracks = this.$$("track");
- let i2 = tracks.length;
- while (i2--) {
- if (track === tracks[i2] || track === tracks[i2].track) {
- this.el().removeChild(tracks[i2]);
- }
- }
- }
- }
- getVideoPlaybackQuality() {
- if (typeof this.el().getVideoPlaybackQuality === "function") {
- return this.el().getVideoPlaybackQuality();
- }
- const videoPlaybackQuality = {};
- if (typeof this.el().webkitDroppedFrameCount !== "undefined" && typeof this.el().webkitDecodedFrameCount !== "undefined") {
- videoPlaybackQuality.droppedVideoFrames = this.el().webkitDroppedFrameCount;
- videoPlaybackQuality.totalVideoFrames = this.el().webkitDecodedFrameCount;
- }
- if (window_1.performance) {
- videoPlaybackQuality.creationTime = window_1.performance.now();
- }
- return videoPlaybackQuality;
- }
- }
- defineLazyProperty$1(Html5$2, "TEST_VID", function() {
- if (!isReal$1()) {
- return;
- }
- const video = document_1.createElement("video");
- const track = document_1.createElement("track");
- track.kind = "captions";
- track.srclang = "en";
- track.label = "English";
- video.appendChild(track);
- return video;
- });
- Html5$2.isSupported = function() {
- try {
- Html5$2.TEST_VID.volume = 0.5;
- } catch (e) {
- return false;
- }
- return !!(Html5$2.TEST_VID && Html5$2.TEST_VID.canPlayType);
- };
- Html5$2.canPlayType = function(type2) {
- return Html5$2.TEST_VID.canPlayType(type2);
- };
- Html5$2.canPlaySource = function(srcObj, options2) {
- return Html5$2.canPlayType(srcObj.type);
- };
- Html5$2.canControlVolume = function() {
- try {
- const volume = Html5$2.TEST_VID.volume;
- Html5$2.TEST_VID.volume = volume / 2 + 0.1;
- const canControl = volume !== Html5$2.TEST_VID.volume;
- if (canControl && IS_IOS$1) {
- window_1.setTimeout(() => {
- if (Html5$2 && Html5$2.prototype) {
- Html5$2.prototype.featuresVolumeControl = volume !== Html5$2.TEST_VID.volume;
- }
- });
- return false;
- }
- return canControl;
- } catch (e) {
- return false;
- }
- };
- Html5$2.canMuteVolume = function() {
- try {
- const muted = Html5$2.TEST_VID.muted;
- Html5$2.TEST_VID.muted = !muted;
- if (Html5$2.TEST_VID.muted) {
- setAttribute$1(Html5$2.TEST_VID, "muted", "muted");
- } else {
- removeAttribute$1(Html5$2.TEST_VID, "muted", "muted");
- }
- return muted !== Html5$2.TEST_VID.muted;
- } catch (e) {
- return false;
- }
- };
- Html5$2.canControlPlaybackRate = function() {
- if (IS_ANDROID$1 && IS_CHROME$1 && CHROME_VERSION$1 < 58) {
- return false;
- }
- try {
- const playbackRate = Html5$2.TEST_VID.playbackRate;
- Html5$2.TEST_VID.playbackRate = playbackRate / 2 + 0.1;
- return playbackRate !== Html5$2.TEST_VID.playbackRate;
- } catch (e) {
- return false;
- }
- };
- Html5$2.canOverrideAttributes = function() {
- try {
- const noop2 = () => {
- };
- Object.defineProperty(document_1.createElement("video"), "src", {
- get: noop2,
- set: noop2
- });
- Object.defineProperty(document_1.createElement("audio"), "src", {
- get: noop2,
- set: noop2
- });
- Object.defineProperty(document_1.createElement("video"), "innerHTML", {
- get: noop2,
- set: noop2
- });
- Object.defineProperty(document_1.createElement("audio"), "innerHTML", {
- get: noop2,
- set: noop2
- });
- } catch (e) {
- return false;
- }
- return true;
- };
- Html5$2.supportsNativeTextTracks = function() {
- return IS_ANY_SAFARI$1 || IS_IOS$1 && IS_CHROME$1;
- };
- Html5$2.supportsNativeVideoTracks = function() {
- return !!(Html5$2.TEST_VID && Html5$2.TEST_VID.videoTracks);
- };
- Html5$2.supportsNativeAudioTracks = function() {
- return !!(Html5$2.TEST_VID && Html5$2.TEST_VID.audioTracks);
- };
- Html5$2.Events = ["loadstart", "suspend", "abort", "error", "emptied", "stalled", "loadedmetadata", "loadeddata", "canplay", "canplaythrough", "playing", "waiting", "seeking", "seeked", "ended", "durationchange", "timeupdate", "progress", "play", "pause", "ratechange", "resize", "volumechange"];
- [["featuresMuteControl", "canMuteVolume"], ["featuresPlaybackRate", "canControlPlaybackRate"], ["featuresSourceset", "canOverrideAttributes"], ["featuresNativeTextTracks", "supportsNativeTextTracks"], ["featuresNativeVideoTracks", "supportsNativeVideoTracks"], ["featuresNativeAudioTracks", "supportsNativeAudioTracks"]].forEach(function([key, fn2]) {
- defineLazyProperty$1(Html5$2.prototype, key, () => Html5$2[fn2](), true);
- });
- Html5$2.prototype.featuresVolumeControl = Html5$2.canControlVolume();
- Html5$2.prototype.movingMediaElementInDOM = !IS_IOS$1;
- Html5$2.prototype.featuresFullscreenResize = true;
- Html5$2.prototype.featuresProgressEvents = true;
- Html5$2.prototype.featuresTimeupdateEvents = true;
- Html5$2.prototype.featuresVideoFrameCallback = !!(Html5$2.TEST_VID && Html5$2.TEST_VID.requestVideoFrameCallback);
- Html5$2.disposeMediaElement = function(el) {
- if (!el) {
- return;
- }
- if (el.parentNode) {
- el.parentNode.removeChild(el);
- }
- while (el.hasChildNodes()) {
- el.removeChild(el.firstChild);
- }
- el.removeAttribute("src");
- if (typeof el.load === "function") {
- (function() {
- try {
- el.load();
- } catch (e) {
- }
- })();
- }
- };
- Html5$2.resetMediaElement = function(el) {
- if (!el) {
- return;
- }
- const sources = el.querySelectorAll("source");
- let i2 = sources.length;
- while (i2--) {
- el.removeChild(sources[i2]);
- }
- el.removeAttribute("src");
- if (typeof el.load === "function") {
- (function() {
- try {
- el.load();
- } catch (e) {
- }
- })();
- }
- };
- [
- "muted",
- "defaultMuted",
- "autoplay",
- "controls",
- "loop",
- "playsinline"
- ].forEach(function(prop) {
- Html5$2.prototype[prop] = function() {
- return this.el_[prop] || this.el_.hasAttribute(prop);
- };
- });
- [
- "muted",
- "defaultMuted",
- "autoplay",
- "loop",
- "playsinline"
- ].forEach(function(prop) {
- Html5$2.prototype["set" + toTitleCase$1$1(prop)] = function(v) {
- this.el_[prop] = v;
- if (v) {
- this.el_.setAttribute(prop, prop);
- } else {
- this.el_.removeAttribute(prop);
- }
- };
- });
- [
- "paused",
- "currentTime",
- "buffered",
- "volume",
- "poster",
- "preload",
- "error",
- "seeking",
- "seekable",
- "ended",
- "playbackRate",
- "defaultPlaybackRate",
- "disablePictureInPicture",
- "played",
- "networkState",
- "readyState",
- "videoWidth",
- "videoHeight",
- "crossOrigin"
- ].forEach(function(prop) {
- Html5$2.prototype[prop] = function() {
- return this.el_[prop];
- };
- });
- [
- "volume",
- "src",
- "poster",
- "preload",
- "playbackRate",
- "defaultPlaybackRate",
- "disablePictureInPicture",
- "crossOrigin"
- ].forEach(function(prop) {
- Html5$2.prototype["set" + toTitleCase$1$1(prop)] = function(v) {
- this.el_[prop] = v;
- };
- });
- [
- "pause",
- "load",
- "play"
- ].forEach(function(prop) {
- Html5$2.prototype[prop] = function() {
- return this.el_[prop]();
- };
- });
- Tech$2.withSourceHandlers(Html5$2);
- Html5$2.nativeSourceHandler = {};
- Html5$2.nativeSourceHandler.canPlayType = function(type2) {
- try {
- return Html5$2.TEST_VID.canPlayType(type2);
- } catch (e) {
- return "";
- }
- };
- Html5$2.nativeSourceHandler.canHandleSource = function(source, options2) {
- if (source.type) {
- return Html5$2.nativeSourceHandler.canPlayType(source.type);
- } else if (source.src) {
- const ext = getFileExtension$1(source.src);
- return Html5$2.nativeSourceHandler.canPlayType(`video/${ext}`);
- }
- return "";
- };
- Html5$2.nativeSourceHandler.handleSource = function(source, tech, options2) {
- tech.setSrc(source.src);
- };
- Html5$2.nativeSourceHandler.dispose = function() {
- };
- Html5$2.registerSourceHandler(Html5$2.nativeSourceHandler);
- Tech$2.registerTech("Html5", Html5$2);
- const TECH_EVENTS_RETRIGGER$1 = [
- "progress",
- "abort",
- "suspend",
- "emptied",
- "stalled",
- "loadedmetadata",
- "loadeddata",
- "timeupdate",
- "resize",
- "volumechange",
- "texttrackchange"
- ];
- const TECH_EVENTS_QUEUE$1 = {
- canplay: "CanPlay",
- canplaythrough: "CanPlayThrough",
- playing: "Playing",
- seeked: "Seeked"
- };
- const BREAKPOINT_ORDER$1 = ["tiny", "xsmall", "small", "medium", "large", "xlarge", "huge"];
- const BREAKPOINT_CLASSES$1 = {};
- BREAKPOINT_ORDER$1.forEach((k) => {
- const v = k.charAt(0) === "x" ? `x-${k.substring(1)}` : k;
- BREAKPOINT_CLASSES$1[k] = `vjs-layout-${v}`;
- });
- const DEFAULT_BREAKPOINTS$1 = {
- tiny: 210,
- xsmall: 320,
- small: 425,
- medium: 768,
- large: 1440,
- xlarge: 2560,
- huge: Infinity
- };
- class Player$1 extends Component$1$1 {
- constructor(tag, options2, ready) {
- tag.id = tag.id || options2.id || `vjs_video_${newGUID$1()}`;
- options2 = Object.assign(Player$1.getTagSettings(tag), options2);
- options2.initChildren = false;
- options2.createEl = false;
- options2.evented = false;
- options2.reportTouchActivity = false;
- if (!options2.language) {
- const closest = tag.closest("[lang]");
- if (closest) {
- options2.language = closest.getAttribute("lang");
- }
- }
- super(null, options2, ready);
- this.boundDocumentFullscreenChange_ = (e) => this.documentFullscreenChange_(e);
- this.boundFullWindowOnEscKey_ = (e) => this.fullWindowOnEscKey(e);
- this.boundUpdateStyleEl_ = (e) => this.updateStyleEl_(e);
- this.boundApplyInitTime_ = (e) => this.applyInitTime_(e);
- this.boundUpdateCurrentBreakpoint_ = (e) => this.updateCurrentBreakpoint_(e);
- this.boundHandleTechClick_ = (e) => this.handleTechClick_(e);
- this.boundHandleTechDoubleClick_ = (e) => this.handleTechDoubleClick_(e);
- this.boundHandleTechTouchStart_ = (e) => this.handleTechTouchStart_(e);
- this.boundHandleTechTouchMove_ = (e) => this.handleTechTouchMove_(e);
- this.boundHandleTechTouchEnd_ = (e) => this.handleTechTouchEnd_(e);
- this.boundHandleTechTap_ = (e) => this.handleTechTap_(e);
- this.isFullscreen_ = false;
- this.log = createLogger$2(this.id_);
- this.fsApi_ = FullscreenApi$1;
- this.isPosterFromTech_ = false;
- this.queuedCallbacks_ = [];
- this.isReady_ = false;
- this.hasStarted_ = false;
- this.userActive_ = false;
- this.debugEnabled_ = false;
- this.audioOnlyMode_ = false;
- this.audioPosterMode_ = false;
- this.audioOnlyCache_ = {
- playerHeight: null,
- hiddenChildren: []
- };
- if (!this.options_ || !this.options_.techOrder || !this.options_.techOrder.length) {
- throw new Error("No techOrder specified. Did you overwrite videojs.options instead of just changing the properties you want to override?");
- }
- this.tag = tag;
- this.tagAttributes = tag && getAttributes$1(tag);
- this.language(this.options_.language);
- if (options2.languages) {
- const languagesToLower = {};
- Object.getOwnPropertyNames(options2.languages).forEach(function(name) {
- languagesToLower[name.toLowerCase()] = options2.languages[name];
- });
- this.languages_ = languagesToLower;
- } else {
- this.languages_ = Player$1.prototype.options_.languages;
- }
- this.resetCache_();
- this.poster_ = options2.poster || "";
- this.controls_ = !!options2.controls;
- tag.controls = false;
- tag.removeAttribute("controls");
- this.changingSrc_ = false;
- this.playCallbacks_ = [];
- this.playTerminatedQueue_ = [];
- if (tag.hasAttribute("autoplay")) {
- this.autoplay(true);
- } else {
- this.autoplay(this.options_.autoplay);
- }
- if (options2.plugins) {
- Object.keys(options2.plugins).forEach((name) => {
- if (typeof this[name] !== "function") {
- throw new Error(`plugin "${name}" does not exist`);
- }
- });
- }
- this.scrubbing_ = false;
- this.el_ = this.createEl();
- evented$1(this, {
- eventBusKey: "el_"
- });
- if (this.fsApi_.requestFullscreen) {
- on$1(document_1, this.fsApi_.fullscreenchange, this.boundDocumentFullscreenChange_);
- this.on(this.fsApi_.fullscreenchange, this.boundDocumentFullscreenChange_);
- }
- if (this.fluid_) {
- this.on(["playerreset", "resize"], this.boundUpdateStyleEl_);
- }
- const playerOptionsCopy = merge$1(this.options_);
- if (options2.plugins) {
- Object.keys(options2.plugins).forEach((name) => {
- this[name](options2.plugins[name]);
- });
- }
- if (options2.debug) {
- this.debug(true);
- }
- this.options_.playerOptions = playerOptionsCopy;
- this.middleware_ = [];
- this.playbackRates(options2.playbackRates);
- this.initChildren();
- this.isAudio(tag.nodeName.toLowerCase() === "audio");
- if (this.controls()) {
- this.addClass("vjs-controls-enabled");
- } else {
- this.addClass("vjs-controls-disabled");
- }
- this.el_.setAttribute("role", "region");
- if (this.isAudio()) {
- this.el_.setAttribute("aria-label", this.localize("Audio Player"));
- } else {
- this.el_.setAttribute("aria-label", this.localize("Video Player"));
- }
- if (this.isAudio()) {
- this.addClass("vjs-audio");
- }
- if (TOUCH_ENABLED$1) {
- this.addClass("vjs-touch-enabled");
- }
- if (!IS_IOS$1) {
- this.addClass("vjs-workinghover");
- }
- Player$1.players[this.id_] = this;
- const majorVersion = version$6$1.split(".")[0];
- this.addClass(`vjs-v${majorVersion}`);
- this.userActive(true);
- this.reportUserActivity();
- this.one("play", (e) => this.listenForUserActivity_(e));
- this.on("keydown", (e) => this.handleKeyDown(e));
- this.on("languagechange", (e) => this.handleLanguagechange(e));
- this.breakpoints(this.options_.breakpoints);
- this.responsive(this.options_.responsive);
- this.on("ready", () => {
- this.audioPosterMode(this.options_.audioPosterMode);
- this.audioOnlyMode(this.options_.audioOnlyMode);
- });
- }
- dispose() {
- this.trigger("dispose");
- this.off("dispose");
- off$1(document_1, this.fsApi_.fullscreenchange, this.boundDocumentFullscreenChange_);
- off$1(document_1, "keydown", this.boundFullWindowOnEscKey_);
- if (this.styleEl_ && this.styleEl_.parentNode) {
- this.styleEl_.parentNode.removeChild(this.styleEl_);
- this.styleEl_ = null;
- }
- Player$1.players[this.id_] = null;
- if (this.tag && this.tag.player) {
- this.tag.player = null;
- }
- if (this.el_ && this.el_.player) {
- this.el_.player = null;
- }
- if (this.tech_) {
- this.tech_.dispose();
- this.isPosterFromTech_ = false;
- this.poster_ = "";
- }
- if (this.playerElIngest_) {
- this.playerElIngest_ = null;
- }
- if (this.tag) {
- this.tag = null;
- }
- clearCacheForPlayer$1(this);
- ALL$1.names.forEach((name) => {
- const props = ALL$1[name];
- const list = this[props.getterName]();
- if (list && list.off) {
- list.off();
- }
- });
- super.dispose({
- restoreEl: this.options_.restoreEl
- });
- }
- createEl() {
- let tag = this.tag;
- let el;
- let playerElIngest = this.playerElIngest_ = tag.parentNode && tag.parentNode.hasAttribute && tag.parentNode.hasAttribute("data-vjs-player");
- const divEmbed = this.tag.tagName.toLowerCase() === "video-js";
- if (playerElIngest) {
- el = this.el_ = tag.parentNode;
- } else if (!divEmbed) {
- el = this.el_ = super.createEl("div");
- }
- const attrs = getAttributes$1(tag);
- if (divEmbed) {
- el = this.el_ = tag;
- tag = this.tag = document_1.createElement("video");
- while (el.children.length) {
- tag.appendChild(el.firstChild);
- }
- if (!hasClass$1(el, "video-js")) {
- addClass$1(el, "video-js");
- }
- el.appendChild(tag);
- playerElIngest = this.playerElIngest_ = el;
- Object.keys(el).forEach((k) => {
- try {
- tag[k] = el[k];
- } catch (e) {
- }
- });
- }
- tag.setAttribute("tabindex", "-1");
- attrs.tabindex = "-1";
- if (IS_CHROME$1 && IS_WINDOWS$1) {
- tag.setAttribute("role", "application");
- attrs.role = "application";
- }
- tag.removeAttribute("width");
- tag.removeAttribute("height");
- if ("width" in attrs) {
- delete attrs.width;
- }
- if ("height" in attrs) {
- delete attrs.height;
- }
- Object.getOwnPropertyNames(attrs).forEach(function(attr) {
- if (!(divEmbed && attr === "class")) {
- el.setAttribute(attr, attrs[attr]);
- }
- if (divEmbed) {
- tag.setAttribute(attr, attrs[attr]);
- }
- });
- tag.playerId = tag.id;
- tag.id += "_html5_api";
- tag.className = "vjs-tech";
- tag.player = el.player = this;
- this.addClass("vjs-paused");
- if (window_1.VIDEOJS_NO_DYNAMIC_STYLE !== true) {
- this.styleEl_ = createStyleElement$1("vjs-styles-dimensions");
- const defaultsStyleEl = $$1(".vjs-styles-defaults");
- const head = $$1("head");
- head.insertBefore(this.styleEl_, defaultsStyleEl ? defaultsStyleEl.nextSibling : head.firstChild);
- }
- this.fill_ = false;
- this.fluid_ = false;
- this.width(this.options_.width);
- this.height(this.options_.height);
- this.fill(this.options_.fill);
- this.fluid(this.options_.fluid);
- this.aspectRatio(this.options_.aspectRatio);
- this.crossOrigin(this.options_.crossOrigin || this.options_.crossorigin);
- const links = tag.getElementsByTagName("a");
- for (let i2 = 0; i2 < links.length; i2++) {
- const linkEl = links.item(i2);
- addClass$1(linkEl, "vjs-hidden");
- linkEl.setAttribute("hidden", "hidden");
- }
- tag.initNetworkState_ = tag.networkState;
- if (tag.parentNode && !playerElIngest) {
- tag.parentNode.insertBefore(el, tag);
- }
- prependTo$1(tag, el);
- this.children_.unshift(tag);
- this.el_.setAttribute("lang", this.language_);
- this.el_.setAttribute("translate", "no");
- this.el_ = el;
- return el;
- }
- crossOrigin(value) {
- if (typeof value === "undefined") {
- return this.techGet_("crossOrigin");
- }
- if (value !== null && value !== "anonymous" && value !== "use-credentials") {
- log$1$1.warn(`crossOrigin must be null, "anonymous" or "use-credentials", given "${value}"`);
- return;
- }
- this.techCall_("setCrossOrigin", value);
- if (this.posterImage) {
- this.posterImage.crossOrigin(value);
- }
- return;
- }
- width(value) {
- return this.dimension("width", value);
- }
- height(value) {
- return this.dimension("height", value);
- }
- dimension(dimension, value) {
- const privDimension = dimension + "_";
- if (value === void 0) {
- return this[privDimension] || 0;
- }
- if (value === "" || value === "auto") {
- this[privDimension] = void 0;
- this.updateStyleEl_();
- return;
- }
- const parsedVal = parseFloat(value);
- if (isNaN(parsedVal)) {
- log$1$1.error(`Improper value "${value}" supplied for for ${dimension}`);
- return;
- }
- this[privDimension] = parsedVal;
- this.updateStyleEl_();
- }
- fluid(bool) {
- if (bool === void 0) {
- return !!this.fluid_;
- }
- this.fluid_ = !!bool;
- if (isEvented$1(this)) {
- this.off(["playerreset", "resize"], this.boundUpdateStyleEl_);
- }
- if (bool) {
- this.addClass("vjs-fluid");
- this.fill(false);
- addEventedCallback$1(this, () => {
- this.on(["playerreset", "resize"], this.boundUpdateStyleEl_);
- });
- } else {
- this.removeClass("vjs-fluid");
- }
- this.updateStyleEl_();
- }
- fill(bool) {
- if (bool === void 0) {
- return !!this.fill_;
- }
- this.fill_ = !!bool;
- if (bool) {
- this.addClass("vjs-fill");
- this.fluid(false);
- } else {
- this.removeClass("vjs-fill");
- }
- }
- aspectRatio(ratio) {
- if (ratio === void 0) {
- return this.aspectRatio_;
- }
- if (!/^\d+\:\d+$/.test(ratio)) {
- throw new Error("Improper value supplied for aspect ratio. The format should be width:height, for example 16:9.");
- }
- this.aspectRatio_ = ratio;
- this.fluid(true);
- this.updateStyleEl_();
- }
- updateStyleEl_() {
- if (window_1.VIDEOJS_NO_DYNAMIC_STYLE === true) {
- const width3 = typeof this.width_ === "number" ? this.width_ : this.options_.width;
- const height3 = typeof this.height_ === "number" ? this.height_ : this.options_.height;
- const techEl = this.tech_ && this.tech_.el();
- if (techEl) {
- if (width3 >= 0) {
- techEl.width = width3;
- }
- if (height3 >= 0) {
- techEl.height = height3;
- }
- }
- return;
- }
- let width2;
- let height2;
- let aspectRatio;
- let idClass;
- if (this.aspectRatio_ !== void 0 && this.aspectRatio_ !== "auto") {
- aspectRatio = this.aspectRatio_;
- } else if (this.videoWidth() > 0) {
- aspectRatio = this.videoWidth() + ":" + this.videoHeight();
- } else {
- aspectRatio = "16:9";
- }
- const ratioParts = aspectRatio.split(":");
- const ratioMultiplier = ratioParts[1] / ratioParts[0];
- if (this.width_ !== void 0) {
- width2 = this.width_;
- } else if (this.height_ !== void 0) {
- width2 = this.height_ / ratioMultiplier;
- } else {
- width2 = this.videoWidth() || 300;
- }
- if (this.height_ !== void 0) {
- height2 = this.height_;
- } else {
- height2 = width2 * ratioMultiplier;
- }
- if (/^[^a-zA-Z]/.test(this.id())) {
- idClass = "dimensions-" + this.id();
- } else {
- idClass = this.id() + "-dimensions";
- }
- this.addClass(idClass);
- setTextContent$1(this.styleEl_, `
- .${idClass} {
- width: ${width2}px;
- height: ${height2}px;
- }
- .${idClass}.vjs-fluid:not(.vjs-audio-only-mode) {
- padding-top: ${ratioMultiplier * 100}%;
- }
- `);
- }
- loadTech_(techName, source) {
- if (this.tech_) {
- this.unloadTech_();
- }
- const titleTechName = toTitleCase$1$1(techName);
- const camelTechName = techName.charAt(0).toLowerCase() + techName.slice(1);
- if (titleTechName !== "Html5" && this.tag) {
- Tech$2.getTech("Html5").disposeMediaElement(this.tag);
- this.tag.player = null;
- this.tag = null;
- }
- this.techName_ = titleTechName;
- this.isReady_ = false;
- let autoplay = this.autoplay();
- if (typeof this.autoplay() === "string" || this.autoplay() === true && this.options_.normalizeAutoplay) {
- autoplay = false;
- }
- const techOptions = {
- source,
- autoplay,
- "nativeControlsForTouch": this.options_.nativeControlsForTouch,
- "playerId": this.id(),
- "techId": `${this.id()}_${camelTechName}_api`,
- "playsinline": this.options_.playsinline,
- "preload": this.options_.preload,
- "loop": this.options_.loop,
- "disablePictureInPicture": this.options_.disablePictureInPicture,
- "muted": this.options_.muted,
- "poster": this.poster(),
- "language": this.language(),
- "playerElIngest": this.playerElIngest_ || false,
- "vtt.js": this.options_["vtt.js"],
- "canOverridePoster": !!this.options_.techCanOverridePoster,
- "enableSourceset": this.options_.enableSourceset
- };
- ALL$1.names.forEach((name) => {
- const props = ALL$1[name];
- techOptions[props.getterName] = this[props.privateName];
- });
- Object.assign(techOptions, this.options_[titleTechName]);
- Object.assign(techOptions, this.options_[camelTechName]);
- Object.assign(techOptions, this.options_[techName.toLowerCase()]);
- if (this.tag) {
- techOptions.tag = this.tag;
- }
- if (source && source.src === this.cache_.src && this.cache_.currentTime > 0) {
- techOptions.startTime = this.cache_.currentTime;
- }
- const TechClass = Tech$2.getTech(techName);
- if (!TechClass) {
- throw new Error(`No Tech named '${titleTechName}' exists! '${titleTechName}' should be registered using videojs.registerTech()'`);
- }
- this.tech_ = new TechClass(techOptions);
- this.tech_.ready(bind_(this, this.handleTechReady_), true);
- textTrackConverter$1.jsonToTextTracks(this.textTracksJson_ || [], this.tech_);
- TECH_EVENTS_RETRIGGER$1.forEach((event2) => {
- this.on(this.tech_, event2, (e) => this[`handleTech${toTitleCase$1$1(event2)}_`](e));
- });
- Object.keys(TECH_EVENTS_QUEUE$1).forEach((event2) => {
- this.on(this.tech_, event2, (eventObj) => {
- if (this.tech_.playbackRate() === 0 && this.tech_.seeking()) {
- this.queuedCallbacks_.push({
- callback: this[`handleTech${TECH_EVENTS_QUEUE$1[event2]}_`].bind(this),
- event: eventObj
- });
- return;
- }
- this[`handleTech${TECH_EVENTS_QUEUE$1[event2]}_`](eventObj);
- });
- });
- this.on(this.tech_, "loadstart", (e) => this.handleTechLoadStart_(e));
- this.on(this.tech_, "sourceset", (e) => this.handleTechSourceset_(e));
- this.on(this.tech_, "waiting", (e) => this.handleTechWaiting_(e));
- this.on(this.tech_, "ended", (e) => this.handleTechEnded_(e));
- this.on(this.tech_, "seeking", (e) => this.handleTechSeeking_(e));
- this.on(this.tech_, "play", (e) => this.handleTechPlay_(e));
- this.on(this.tech_, "pause", (e) => this.handleTechPause_(e));
- this.on(this.tech_, "durationchange", (e) => this.handleTechDurationChange_(e));
- this.on(this.tech_, "fullscreenchange", (e, data) => this.handleTechFullscreenChange_(e, data));
- this.on(this.tech_, "fullscreenerror", (e, err) => this.handleTechFullscreenError_(e, err));
- this.on(this.tech_, "enterpictureinpicture", (e) => this.handleTechEnterPictureInPicture_(e));
- this.on(this.tech_, "leavepictureinpicture", (e) => this.handleTechLeavePictureInPicture_(e));
- this.on(this.tech_, "error", (e) => this.handleTechError_(e));
- this.on(this.tech_, "posterchange", (e) => this.handleTechPosterChange_(e));
- this.on(this.tech_, "textdata", (e) => this.handleTechTextData_(e));
- this.on(this.tech_, "ratechange", (e) => this.handleTechRateChange_(e));
- this.on(this.tech_, "loadedmetadata", this.boundUpdateStyleEl_);
- this.usingNativeControls(this.techGet_("controls"));
- if (this.controls() && !this.usingNativeControls()) {
- this.addTechControlsListeners_();
- }
- if (this.tech_.el().parentNode !== this.el() && (titleTechName !== "Html5" || !this.tag)) {
- prependTo$1(this.tech_.el(), this.el());
- }
- if (this.tag) {
- this.tag.player = null;
- this.tag = null;
- }
- }
- unloadTech_() {
- ALL$1.names.forEach((name) => {
- const props = ALL$1[name];
- this[props.privateName] = this[props.getterName]();
- });
- this.textTracksJson_ = textTrackConverter$1.textTracksToJson(this.tech_);
- this.isReady_ = false;
- this.tech_.dispose();
- this.tech_ = false;
- if (this.isPosterFromTech_) {
- this.poster_ = "";
- this.trigger("posterchange");
- }
- this.isPosterFromTech_ = false;
- }
- tech(safety) {
- if (safety === void 0) {
- log$1$1.warn("Using the tech directly can be dangerous. I hope you know what you're doing.\nSee https://github.com/videojs/video.js/issues/2617 for more info.\n");
- }
- return this.tech_;
- }
- addTechControlsListeners_() {
- this.removeTechControlsListeners_();
- this.on(this.tech_, "click", this.boundHandleTechClick_);
- this.on(this.tech_, "dblclick", this.boundHandleTechDoubleClick_);
- this.on(this.tech_, "touchstart", this.boundHandleTechTouchStart_);
- this.on(this.tech_, "touchmove", this.boundHandleTechTouchMove_);
- this.on(this.tech_, "touchend", this.boundHandleTechTouchEnd_);
- this.on(this.tech_, "tap", this.boundHandleTechTap_);
- }
- removeTechControlsListeners_() {
- this.off(this.tech_, "tap", this.boundHandleTechTap_);
- this.off(this.tech_, "touchstart", this.boundHandleTechTouchStart_);
- this.off(this.tech_, "touchmove", this.boundHandleTechTouchMove_);
- this.off(this.tech_, "touchend", this.boundHandleTechTouchEnd_);
- this.off(this.tech_, "click", this.boundHandleTechClick_);
- this.off(this.tech_, "dblclick", this.boundHandleTechDoubleClick_);
- }
- handleTechReady_() {
- this.triggerReady();
- if (this.cache_.volume) {
- this.techCall_("setVolume", this.cache_.volume);
- }
- this.handleTechPosterChange_();
- this.handleTechDurationChange_();
- }
- handleTechLoadStart_() {
- this.removeClass("vjs-ended", "vjs-seeking");
- this.error(null);
- this.handleTechDurationChange_();
- if (!this.paused()) {
- this.trigger("loadstart");
- } else {
- this.hasStarted(false);
- this.trigger("loadstart");
- }
- this.manualAutoplay_(this.autoplay() === true && this.options_.normalizeAutoplay ? "play" : this.autoplay());
- }
- manualAutoplay_(type2) {
- if (!this.tech_ || typeof type2 !== "string") {
- return;
- }
- const resolveMuted = () => {
- const previouslyMuted = this.muted();
- this.muted(true);
- const restoreMuted = () => {
- this.muted(previouslyMuted);
- };
- this.playTerminatedQueue_.push(restoreMuted);
- const mutedPromise = this.play();
- if (!isPromise$1(mutedPromise)) {
- return;
- }
- return mutedPromise.catch((err) => {
- restoreMuted();
- throw new Error(`Rejection at manualAutoplay. Restoring muted value. ${err ? err : ""}`);
- });
- };
- let promise;
- if (type2 === "any" && !this.muted()) {
- promise = this.play();
- if (isPromise$1(promise)) {
- promise = promise.catch(resolveMuted);
- }
- } else if (type2 === "muted" && !this.muted()) {
- promise = resolveMuted();
- } else {
- promise = this.play();
- }
- if (!isPromise$1(promise)) {
- return;
- }
- return promise.then(() => {
- this.trigger({
- type: "autoplay-success",
- autoplay: type2
- });
- }).catch(() => {
- this.trigger({
- type: "autoplay-failure",
- autoplay: type2
- });
- });
- }
- updateSourceCaches_(srcObj = "") {
- let src = srcObj;
- let type2 = "";
- if (typeof src !== "string") {
- src = srcObj.src;
- type2 = srcObj.type;
- }
- this.cache_.source = this.cache_.source || {};
- this.cache_.sources = this.cache_.sources || [];
- if (src && !type2) {
- type2 = findMimetype$1(this, src);
- }
- this.cache_.source = merge$1({}, srcObj, {
- src,
- type: type2
- });
- const matchingSources = this.cache_.sources.filter((s) => s.src && s.src === src);
- const sourceElSources = [];
- const sourceEls = this.$$("source");
- const matchingSourceEls = [];
- for (let i2 = 0; i2 < sourceEls.length; i2++) {
- const sourceObj = getAttributes$1(sourceEls[i2]);
- sourceElSources.push(sourceObj);
- if (sourceObj.src && sourceObj.src === src) {
- matchingSourceEls.push(sourceObj.src);
- }
- }
- if (matchingSourceEls.length && !matchingSources.length) {
- this.cache_.sources = sourceElSources;
- } else if (!matchingSources.length) {
- this.cache_.sources = [this.cache_.source];
- }
- this.cache_.src = src;
- }
- handleTechSourceset_(event2) {
- if (!this.changingSrc_) {
- let updateSourceCaches = (src) => this.updateSourceCaches_(src);
- const playerSrc = this.currentSource().src;
- const eventSrc = event2.src;
- if (playerSrc && !/^blob:/.test(playerSrc) && /^blob:/.test(eventSrc)) {
- if (!this.lastSource_ || this.lastSource_.tech !== eventSrc && this.lastSource_.player !== playerSrc) {
- updateSourceCaches = () => {
- };
- }
- }
- updateSourceCaches(eventSrc);
- if (!event2.src) {
- this.tech_.any(["sourceset", "loadstart"], (e) => {
- if (e.type === "sourceset") {
- return;
- }
- const techSrc = this.techGet("currentSrc");
- this.lastSource_.tech = techSrc;
- this.updateSourceCaches_(techSrc);
- });
- }
- }
- this.lastSource_ = {
- player: this.currentSource().src,
- tech: event2.src
- };
- this.trigger({
- src: event2.src,
- type: "sourceset"
- });
- }
- hasStarted(request) {
- if (request === void 0) {
- return this.hasStarted_;
- }
- if (request === this.hasStarted_) {
- return;
- }
- this.hasStarted_ = request;
- if (this.hasStarted_) {
- this.addClass("vjs-has-started");
- } else {
- this.removeClass("vjs-has-started");
- }
- }
- handleTechPlay_() {
- this.removeClass("vjs-ended", "vjs-paused");
- this.addClass("vjs-playing");
- this.hasStarted(true);
- this.trigger("play");
- }
- handleTechRateChange_() {
- if (this.tech_.playbackRate() > 0 && this.cache_.lastPlaybackRate === 0) {
- this.queuedCallbacks_.forEach((queued) => queued.callback(queued.event));
- this.queuedCallbacks_ = [];
- }
- this.cache_.lastPlaybackRate = this.tech_.playbackRate();
- this.trigger("ratechange");
- }
- handleTechWaiting_() {
- this.addClass("vjs-waiting");
- this.trigger("waiting");
- const timeWhenWaiting = this.currentTime();
- const timeUpdateListener = () => {
- if (timeWhenWaiting !== this.currentTime()) {
- this.removeClass("vjs-waiting");
- this.off("timeupdate", timeUpdateListener);
- }
- };
- this.on("timeupdate", timeUpdateListener);
- }
- handleTechCanPlay_() {
- this.removeClass("vjs-waiting");
- this.trigger("canplay");
- }
- handleTechCanPlayThrough_() {
- this.removeClass("vjs-waiting");
- this.trigger("canplaythrough");
- }
- handleTechPlaying_() {
- this.removeClass("vjs-waiting");
- this.trigger("playing");
- }
- handleTechSeeking_() {
- this.addClass("vjs-seeking");
- this.trigger("seeking");
- }
- handleTechSeeked_() {
- this.removeClass("vjs-seeking", "vjs-ended");
- this.trigger("seeked");
- }
- handleTechPause_() {
- this.removeClass("vjs-playing");
- this.addClass("vjs-paused");
- this.trigger("pause");
- }
- handleTechEnded_() {
- this.addClass("vjs-ended");
- this.removeClass("vjs-waiting");
- if (this.options_.loop) {
- this.currentTime(0);
- this.play();
- } else if (!this.paused()) {
- this.pause();
- }
- this.trigger("ended");
- }
- handleTechDurationChange_() {
- this.duration(this.techGet_("duration"));
- }
- handleTechClick_(event2) {
- if (!this.controls_) {
- return;
- }
- if (this.options_ === void 0 || this.options_.userActions === void 0 || this.options_.userActions.click === void 0 || this.options_.userActions.click !== false) {
- if (this.options_ !== void 0 && this.options_.userActions !== void 0 && typeof this.options_.userActions.click === "function") {
- this.options_.userActions.click.call(this, event2);
- } else if (this.paused()) {
- silencePromise$1(this.play());
- } else {
- this.pause();
- }
- }
- }
- handleTechDoubleClick_(event2) {
- if (!this.controls_) {
- return;
- }
- const inAllowedEls = Array.prototype.some.call(this.$$(".vjs-control-bar, .vjs-modal-dialog"), (el) => el.contains(event2.target));
- if (!inAllowedEls) {
- if (this.options_ === void 0 || this.options_.userActions === void 0 || this.options_.userActions.doubleClick === void 0 || this.options_.userActions.doubleClick !== false) {
- if (this.options_ !== void 0 && this.options_.userActions !== void 0 && typeof this.options_.userActions.doubleClick === "function") {
- this.options_.userActions.doubleClick.call(this, event2);
- } else if (this.isFullscreen()) {
- this.exitFullscreen();
- } else {
- this.requestFullscreen();
- }
- }
- }
- }
- handleTechTap_() {
- this.userActive(!this.userActive());
- }
- handleTechTouchStart_() {
- this.userWasActive = this.userActive();
- }
- handleTechTouchMove_() {
- if (this.userWasActive) {
- this.reportUserActivity();
- }
- }
- handleTechTouchEnd_(event2) {
- if (event2.cancelable) {
- event2.preventDefault();
- }
- }
- toggleFullscreenClass_() {
- if (this.isFullscreen()) {
- this.addClass("vjs-fullscreen");
- } else {
- this.removeClass("vjs-fullscreen");
- }
- }
- documentFullscreenChange_(e) {
- const targetPlayer = e.target.player;
- if (targetPlayer && targetPlayer !== this) {
- return;
- }
- const el = this.el();
- let isFs = document_1[this.fsApi_.fullscreenElement] === el;
- if (!isFs && el.matches) {
- isFs = el.matches(":" + this.fsApi_.fullscreen);
- } else if (!isFs && el.msMatchesSelector) {
- isFs = el.msMatchesSelector(":" + this.fsApi_.fullscreen);
- }
- this.isFullscreen(isFs);
- }
- handleTechFullscreenChange_(event2, data) {
- if (data) {
- if (data.nativeIOSFullscreen) {
- this.addClass("vjs-ios-native-fs");
- this.tech_.one("webkitendfullscreen", () => {
- this.removeClass("vjs-ios-native-fs");
- });
- }
- this.isFullscreen(data.isFullscreen);
- }
- }
- handleTechFullscreenError_(event2, err) {
- this.trigger("fullscreenerror", err);
- }
- togglePictureInPictureClass_() {
- if (this.isInPictureInPicture()) {
- this.addClass("vjs-picture-in-picture");
- } else {
- this.removeClass("vjs-picture-in-picture");
- }
- }
- handleTechEnterPictureInPicture_(event2) {
- this.isInPictureInPicture(true);
- }
- handleTechLeavePictureInPicture_(event2) {
- this.isInPictureInPicture(false);
- }
- handleTechError_() {
- const error = this.tech_.error();
- this.error(error);
- }
- handleTechTextData_() {
- let data = null;
- if (arguments.length > 1) {
- data = arguments[1];
- }
- this.trigger("textdata", data);
- }
- getCache() {
- return this.cache_;
- }
- resetCache_() {
- this.cache_ = {
- currentTime: 0,
- initTime: 0,
- inactivityTimeout: this.options_.inactivityTimeout,
- duration: NaN,
- lastVolume: 1,
- lastPlaybackRate: this.defaultPlaybackRate(),
- media: null,
- src: "",
- source: {},
- sources: [],
- playbackRates: [],
- volume: 1
- };
- }
- techCall_(method, arg) {
- this.ready(function() {
- if (method in allowedSetters$1) {
- return set$1(this.middleware_, this.tech_, method, arg);
- } else if (method in allowedMediators$1) {
- return mediate$1(this.middleware_, this.tech_, method, arg);
- }
- try {
- if (this.tech_) {
- this.tech_[method](arg);
- }
- } catch (e) {
- log$1$1(e);
- throw e;
- }
- }, true);
- }
- techGet_(method) {
- if (!this.tech_ || !this.tech_.isReady_) {
- return;
- }
- if (method in allowedGetters$1) {
- return get$1(this.middleware_, this.tech_, method);
- } else if (method in allowedMediators$1) {
- return mediate$1(this.middleware_, this.tech_, method);
- }
- try {
- return this.tech_[method]();
- } catch (e) {
- if (this.tech_[method] === void 0) {
- log$1$1(`Video.js: ${method} method not defined for ${this.techName_} playback technology.`, e);
- throw e;
- }
- if (e.name === "TypeError") {
- log$1$1(`Video.js: ${method} unavailable on ${this.techName_} playback technology element.`, e);
- this.tech_.isReady_ = false;
- throw e;
- }
- log$1$1(e);
- throw e;
- }
- }
- play() {
- return new Promise((resolve2) => {
- this.play_(resolve2);
- });
- }
- play_(callback2 = silencePromise$1) {
- this.playCallbacks_.push(callback2);
- const isSrcReady = Boolean(!this.changingSrc_ && (this.src() || this.currentSrc()));
- const isSafariOrIOS = Boolean(IS_ANY_SAFARI$1 || IS_IOS$1);
- if (this.waitToPlay_) {
- this.off(["ready", "loadstart"], this.waitToPlay_);
- this.waitToPlay_ = null;
- }
- if (!this.isReady_ || !isSrcReady) {
- this.waitToPlay_ = (e) => {
- this.play_();
- };
- this.one(["ready", "loadstart"], this.waitToPlay_);
- if (!isSrcReady && isSafariOrIOS) {
- this.load();
- }
- return;
- }
- const val = this.techGet_("play");
- const isNativeReplay = isSafariOrIOS && this.hasClass("vjs-ended");
- if (isNativeReplay) {
- this.resetProgressBar_();
- }
- if (val === null) {
- this.runPlayTerminatedQueue_();
- } else {
- this.runPlayCallbacks_(val);
- }
- }
- runPlayTerminatedQueue_() {
- const queue = this.playTerminatedQueue_.slice(0);
- this.playTerminatedQueue_ = [];
- queue.forEach(function(q2) {
- q2();
- });
- }
- runPlayCallbacks_(val) {
- const callbacks = this.playCallbacks_.slice(0);
- this.playCallbacks_ = [];
- this.playTerminatedQueue_ = [];
- callbacks.forEach(function(cb) {
- cb(val);
- });
- }
- pause() {
- this.techCall_("pause");
- }
- paused() {
- return this.techGet_("paused") === false ? false : true;
- }
- played() {
- return this.techGet_("played") || createTimeRanges$1(0, 0);
- }
- scrubbing(isScrubbing) {
- if (typeof isScrubbing === "undefined") {
- return this.scrubbing_;
- }
- this.scrubbing_ = !!isScrubbing;
- this.techCall_("setScrubbing", this.scrubbing_);
- if (isScrubbing) {
- this.addClass("vjs-scrubbing");
- } else {
- this.removeClass("vjs-scrubbing");
- }
- }
- currentTime(seconds) {
- if (typeof seconds !== "undefined") {
- if (seconds < 0) {
- seconds = 0;
- }
- if (!this.isReady_ || this.changingSrc_ || !this.tech_ || !this.tech_.isReady_) {
- this.cache_.initTime = seconds;
- this.off("canplay", this.boundApplyInitTime_);
- this.one("canplay", this.boundApplyInitTime_);
- return;
- }
- this.techCall_("setCurrentTime", seconds);
- this.cache_.initTime = 0;
- return;
- }
- this.cache_.currentTime = this.techGet_("currentTime") || 0;
- return this.cache_.currentTime;
- }
- applyInitTime_() {
- this.currentTime(this.cache_.initTime);
- }
- duration(seconds) {
- if (seconds === void 0) {
- return this.cache_.duration !== void 0 ? this.cache_.duration : NaN;
- }
- seconds = parseFloat(seconds);
- if (seconds < 0) {
- seconds = Infinity;
- }
- if (seconds !== this.cache_.duration) {
- this.cache_.duration = seconds;
- if (seconds === Infinity) {
- this.addClass("vjs-live");
- } else {
- this.removeClass("vjs-live");
- }
- if (!isNaN(seconds)) {
- this.trigger("durationchange");
- }
- }
- }
- remainingTime() {
- return this.duration() - this.currentTime();
- }
- remainingTimeDisplay() {
- return Math.floor(this.duration()) - Math.floor(this.currentTime());
- }
- buffered() {
- let buffered = this.techGet_("buffered");
- if (!buffered || !buffered.length) {
- buffered = createTimeRanges$1(0, 0);
- }
- return buffered;
- }
- bufferedPercent() {
- return bufferedPercent$1(this.buffered(), this.duration());
- }
- bufferedEnd() {
- const buffered = this.buffered();
- const duration5 = this.duration();
- let end = buffered.end(buffered.length - 1);
- if (end > duration5) {
- end = duration5;
- }
- return end;
- }
- volume(percentAsDecimal) {
- let vol;
- if (percentAsDecimal !== void 0) {
- vol = Math.max(0, Math.min(1, parseFloat(percentAsDecimal)));
- this.cache_.volume = vol;
- this.techCall_("setVolume", vol);
- if (vol > 0) {
- this.lastVolume_(vol);
- }
- return;
- }
- vol = parseFloat(this.techGet_("volume"));
- return isNaN(vol) ? 1 : vol;
- }
- muted(muted) {
- if (muted !== void 0) {
- this.techCall_("setMuted", muted);
- return;
- }
- return this.techGet_("muted") || false;
- }
- defaultMuted(defaultMuted) {
- if (defaultMuted !== void 0) {
- return this.techCall_("setDefaultMuted", defaultMuted);
- }
- return this.techGet_("defaultMuted") || false;
- }
- lastVolume_(percentAsDecimal) {
- if (percentAsDecimal !== void 0 && percentAsDecimal !== 0) {
- this.cache_.lastVolume = percentAsDecimal;
- return;
- }
- return this.cache_.lastVolume;
- }
- supportsFullScreen() {
- return this.techGet_("supportsFullScreen") || false;
- }
- isFullscreen(isFS) {
- if (isFS !== void 0) {
- const oldValue = this.isFullscreen_;
- this.isFullscreen_ = Boolean(isFS);
- if (this.isFullscreen_ !== oldValue && this.fsApi_.prefixed) {
- this.trigger("fullscreenchange");
- }
- this.toggleFullscreenClass_();
- return;
- }
- return this.isFullscreen_;
- }
- requestFullscreen(fullscreenOptions) {
- if (this.isInPictureInPicture()) {
- this.exitPictureInPicture();
- }
- const self2 = this;
- return new Promise((resolve2, reject2) => {
- function offHandler() {
- self2.off("fullscreenerror", errorHandler);
- self2.off("fullscreenchange", changeHandler);
- }
- function changeHandler() {
- offHandler();
- resolve2();
- }
- function errorHandler(e, err) {
- offHandler();
- reject2(err);
- }
- self2.one("fullscreenchange", changeHandler);
- self2.one("fullscreenerror", errorHandler);
- const promise = self2.requestFullscreenHelper_(fullscreenOptions);
- if (promise) {
- promise.then(offHandler, offHandler);
- promise.then(resolve2, reject2);
- }
- });
- }
- requestFullscreenHelper_(fullscreenOptions) {
- let fsOptions;
- if (!this.fsApi_.prefixed) {
- fsOptions = this.options_.fullscreen && this.options_.fullscreen.options || {};
- if (fullscreenOptions !== void 0) {
- fsOptions = fullscreenOptions;
- }
- }
- if (this.fsApi_.requestFullscreen) {
- const promise = this.el_[this.fsApi_.requestFullscreen](fsOptions);
- if (promise) {
- promise.then(() => this.isFullscreen(true), () => this.isFullscreen(false));
- }
- return promise;
- } else if (this.tech_.supportsFullScreen() && !this.options_.preferFullWindow === true) {
- this.techCall_("enterFullScreen");
- } else {
- this.enterFullWindow();
- }
- }
- exitFullscreen() {
- const self2 = this;
- return new Promise((resolve2, reject2) => {
- function offHandler() {
- self2.off("fullscreenerror", errorHandler);
- self2.off("fullscreenchange", changeHandler);
- }
- function changeHandler() {
- offHandler();
- resolve2();
- }
- function errorHandler(e, err) {
- offHandler();
- reject2(err);
- }
- self2.one("fullscreenchange", changeHandler);
- self2.one("fullscreenerror", errorHandler);
- const promise = self2.exitFullscreenHelper_();
- if (promise) {
- promise.then(offHandler, offHandler);
- promise.then(resolve2, reject2);
- }
- });
- }
- exitFullscreenHelper_() {
- if (this.fsApi_.requestFullscreen) {
- const promise = document_1[this.fsApi_.exitFullscreen]();
- if (promise) {
- silencePromise$1(promise.then(() => this.isFullscreen(false)));
- }
- return promise;
- } else if (this.tech_.supportsFullScreen() && !this.options_.preferFullWindow === true) {
- this.techCall_("exitFullScreen");
- } else {
- this.exitFullWindow();
- }
- }
- enterFullWindow() {
- this.isFullscreen(true);
- this.isFullWindow = true;
- this.docOrigOverflow = document_1.documentElement.style.overflow;
- on$1(document_1, "keydown", this.boundFullWindowOnEscKey_);
- document_1.documentElement.style.overflow = "hidden";
- addClass$1(document_1.body, "vjs-full-window");
- this.trigger("enterFullWindow");
- }
- fullWindowOnEscKey(event2) {
- if (keycode.isEventKey(event2, "Esc")) {
- if (this.isFullscreen() === true) {
- if (!this.isFullWindow) {
- this.exitFullscreen();
- } else {
- this.exitFullWindow();
- }
- }
- }
- }
- exitFullWindow() {
- this.isFullscreen(false);
- this.isFullWindow = false;
- off$1(document_1, "keydown", this.boundFullWindowOnEscKey_);
- document_1.documentElement.style.overflow = this.docOrigOverflow;
- removeClass$1(document_1.body, "vjs-full-window");
- this.trigger("exitFullWindow");
- }
- disablePictureInPicture(value) {
- if (value === void 0) {
- return this.techGet_("disablePictureInPicture");
- }
- this.techCall_("setDisablePictureInPicture", value);
- this.options_.disablePictureInPicture = value;
- this.trigger("disablepictureinpicturechanged");
- }
- isInPictureInPicture(isPiP) {
- if (isPiP !== void 0) {
- this.isInPictureInPicture_ = !!isPiP;
- this.togglePictureInPictureClass_();
- return;
- }
- return !!this.isInPictureInPicture_;
- }
- requestPictureInPicture() {
- if (this.options_.enableDocumentPictureInPicture && window_1.documentPictureInPicture) {
- const pipContainer = document_1.createElement(this.el().tagName);
- pipContainer.classList = this.el().classList;
- pipContainer.classList.add("vjs-pip-container");
- if (this.posterImage) {
- pipContainer.appendChild(this.posterImage.el().cloneNode(true));
- }
- if (this.titleBar) {
- pipContainer.appendChild(this.titleBar.el().cloneNode(true));
- }
- pipContainer.appendChild(createEl$1("p", {
- className: "vjs-pip-text"
- }, {}, this.localize("Playing in picture-in-picture")));
- return window_1.documentPictureInPicture.requestWindow({
- initialAspectRatio: this.videoWidth() / this.videoHeight(),
- copyStyleSheets: true
- }).then((pipWindow) => {
- this.el_.parentNode.insertBefore(pipContainer, this.el_);
- pipWindow.document.body.append(this.el_);
- pipWindow.document.body.classList.add("vjs-pip-window");
- this.player_.isInPictureInPicture(true);
- this.player_.trigger("enterpictureinpicture");
- pipWindow.addEventListener("unload", (event2) => {
- const pipVideo = event2.target.querySelector(".video-js");
- pipContainer.replaceWith(pipVideo);
- this.player_.isInPictureInPicture(false);
- this.player_.trigger("leavepictureinpicture");
- });
- return pipWindow;
- });
- }
- if ("pictureInPictureEnabled" in document_1 && this.disablePictureInPicture() === false) {
- return this.techGet_("requestPictureInPicture");
- }
- return Promise.reject("No PiP mode is available");
- }
- exitPictureInPicture() {
- if (window_1.documentPictureInPicture && window_1.documentPictureInPicture.window) {
- window_1.documentPictureInPicture.window.close();
- return Promise.resolve();
- }
- if ("pictureInPictureEnabled" in document_1) {
- return document_1.exitPictureInPicture();
- }
- }
- handleKeyDown(event2) {
- const {
- userActions
- } = this.options_;
- if (!userActions || !userActions.hotkeys) {
- return;
- }
- const excludeElement = (el) => {
- const tagName = el.tagName.toLowerCase();
- if (el.isContentEditable) {
- return true;
- }
- const allowedInputTypes = ["button", "checkbox", "hidden", "radio", "reset", "submit"];
- if (tagName === "input") {
- return allowedInputTypes.indexOf(el.type) === -1;
- }
- const excludedTags = ["textarea"];
- return excludedTags.indexOf(tagName) !== -1;
- };
- if (excludeElement(this.el_.ownerDocument.activeElement)) {
- return;
- }
- if (typeof userActions.hotkeys === "function") {
- userActions.hotkeys.call(this, event2);
- } else {
- this.handleHotkeys(event2);
- }
- }
- handleHotkeys(event2) {
- const hotkeys = this.options_.userActions ? this.options_.userActions.hotkeys : {};
- const {
- fullscreenKey = (keydownEvent) => keycode.isEventKey(keydownEvent, "f"),
- muteKey = (keydownEvent) => keycode.isEventKey(keydownEvent, "m"),
- playPauseKey = (keydownEvent) => keycode.isEventKey(keydownEvent, "k") || keycode.isEventKey(keydownEvent, "Space")
- } = hotkeys;
- if (fullscreenKey.call(this, event2)) {
- event2.preventDefault();
- event2.stopPropagation();
- const FSToggle = Component$1$1.getComponent("FullscreenToggle");
- if (document_1[this.fsApi_.fullscreenEnabled] !== false) {
- FSToggle.prototype.handleClick.call(this, event2);
- }
- } else if (muteKey.call(this, event2)) {
- event2.preventDefault();
- event2.stopPropagation();
- const MuteToggle2 = Component$1$1.getComponent("MuteToggle");
- MuteToggle2.prototype.handleClick.call(this, event2);
- } else if (playPauseKey.call(this, event2)) {
- event2.preventDefault();
- event2.stopPropagation();
- const PlayToggle2 = Component$1$1.getComponent("PlayToggle");
- PlayToggle2.prototype.handleClick.call(this, event2);
- }
- }
- canPlayType(type2) {
- let can;
- for (let i2 = 0, j = this.options_.techOrder; i2 < j.length; i2++) {
- const techName = j[i2];
- let tech = Tech$2.getTech(techName);
- if (!tech) {
- tech = Component$1$1.getComponent(techName);
- }
- if (!tech) {
- log$1$1.error(`The "${techName}" tech is undefined. Skipped browser support check for that tech.`);
- continue;
- }
- if (tech.isSupported()) {
- can = tech.canPlayType(type2);
- if (can) {
- return can;
- }
- }
- }
- return "";
- }
- selectSource(sources) {
- const techs = this.options_.techOrder.map((techName) => {
- return [techName, Tech$2.getTech(techName)];
- }).filter(([techName, tech]) => {
- if (tech) {
- return tech.isSupported();
- }
- log$1$1.error(`The "${techName}" tech is undefined. Skipped browser support check for that tech.`);
- return false;
- });
- const findFirstPassingTechSourcePair = function(outerArray, innerArray, tester) {
- let found;
- outerArray.some((outerChoice) => {
- return innerArray.some((innerChoice) => {
- found = tester(outerChoice, innerChoice);
- if (found) {
- return true;
- }
- });
- });
- return found;
- };
- let foundSourceAndTech;
- const flip = (fn2) => (a, b) => fn2(b, a);
- const finder = ([techName, tech], source) => {
- if (tech.canPlaySource(source, this.options_[techName.toLowerCase()])) {
- return {
- source,
- tech: techName
- };
- }
- };
- if (this.options_.sourceOrder) {
- foundSourceAndTech = findFirstPassingTechSourcePair(sources, techs, flip(finder));
- } else {
- foundSourceAndTech = findFirstPassingTechSourcePair(techs, sources, finder);
- }
- return foundSourceAndTech || false;
- }
- handleSrc_(source, isRetry) {
- if (typeof source === "undefined") {
- return this.cache_.src || "";
- }
- if (this.resetRetryOnError_) {
- this.resetRetryOnError_();
- }
- const sources = filterSource$1(source);
- if (!sources.length) {
- this.setTimeout(function() {
- this.error({
- code: 4,
- message: this.options_.notSupportedMessage
- });
- }, 0);
- return;
- }
- this.changingSrc_ = true;
- if (!isRetry) {
- this.cache_.sources = sources;
- }
- this.updateSourceCaches_(sources[0]);
- setSource$1(this, sources[0], (middlewareSource, mws) => {
- this.middleware_ = mws;
- if (!isRetry) {
- this.cache_.sources = sources;
- }
- this.updateSourceCaches_(middlewareSource);
- const err = this.src_(middlewareSource);
- if (err) {
- if (sources.length > 1) {
- return this.handleSrc_(sources.slice(1));
- }
- this.changingSrc_ = false;
- this.setTimeout(function() {
- this.error({
- code: 4,
- message: this.options_.notSupportedMessage
- });
- }, 0);
- this.triggerReady();
- return;
- }
- setTech$1(mws, this.tech_);
- });
- if (sources.length > 1) {
- const retry = () => {
- this.error(null);
- this.handleSrc_(sources.slice(1), true);
- };
- const stopListeningForErrors = () => {
- this.off("error", retry);
- };
- this.one("error", retry);
- this.one("playing", stopListeningForErrors);
- this.resetRetryOnError_ = () => {
- this.off("error", retry);
- this.off("playing", stopListeningForErrors);
- };
- }
- }
- src(source) {
- return this.handleSrc_(source, false);
- }
- src_(source) {
- const sourceTech = this.selectSource([source]);
- if (!sourceTech) {
- return true;
- }
- if (!titleCaseEquals$1(sourceTech.tech, this.techName_)) {
- this.changingSrc_ = true;
- this.loadTech_(sourceTech.tech, sourceTech.source);
- this.tech_.ready(() => {
- this.changingSrc_ = false;
- });
- return false;
- }
- this.ready(function() {
- if (this.tech_.constructor.prototype.hasOwnProperty("setSource")) {
- this.techCall_("setSource", source);
- } else {
- this.techCall_("src", source.src);
- }
- this.changingSrc_ = false;
- }, true);
- return false;
- }
- load() {
- this.techCall_("load");
- }
- reset() {
- if (this.paused()) {
- this.doReset_();
- } else {
- const playPromise = this.play();
- silencePromise$1(playPromise.then(() => this.doReset_()));
- }
- }
- doReset_() {
- if (this.tech_) {
- this.tech_.clearTracks("text");
- }
- this.resetCache_();
- this.poster("");
- this.loadTech_(this.options_.techOrder[0], null);
- this.techCall_("reset");
- this.resetControlBarUI_();
- if (isEvented$1(this)) {
- this.trigger("playerreset");
- }
- }
- resetControlBarUI_() {
- this.resetProgressBar_();
- this.resetPlaybackRate_();
- this.resetVolumeBar_();
- }
- resetProgressBar_() {
- this.currentTime(0);
- const {
- currentTimeDisplay,
- durationDisplay,
- progressControl,
- remainingTimeDisplay
- } = this.controlBar || {};
- const {
- seekBar
- } = progressControl || {};
- if (currentTimeDisplay) {
- currentTimeDisplay.updateContent();
- }
- if (durationDisplay) {
- durationDisplay.updateContent();
- }
- if (remainingTimeDisplay) {
- remainingTimeDisplay.updateContent();
- }
- if (seekBar) {
- seekBar.update();
- if (seekBar.loadProgressBar) {
- seekBar.loadProgressBar.update();
- }
- }
- }
- resetPlaybackRate_() {
- this.playbackRate(this.defaultPlaybackRate());
- this.handleTechRateChange_();
- }
- resetVolumeBar_() {
- this.volume(1);
- this.trigger("volumechange");
- }
- currentSources() {
- const source = this.currentSource();
- const sources = [];
- if (Object.keys(source).length !== 0) {
- sources.push(source);
- }
- return this.cache_.sources || sources;
- }
- currentSource() {
- return this.cache_.source || {};
- }
- currentSrc() {
- return this.currentSource() && this.currentSource().src || "";
- }
- currentType() {
- return this.currentSource() && this.currentSource().type || "";
- }
- preload(value) {
- if (value !== void 0) {
- this.techCall_("setPreload", value);
- this.options_.preload = value;
- return;
- }
- return this.techGet_("preload");
- }
- autoplay(value) {
- if (value === void 0) {
- return this.options_.autoplay || false;
- }
- let techAutoplay;
- if (typeof value === "string" && /(any|play|muted)/.test(value) || value === true && this.options_.normalizeAutoplay) {
- this.options_.autoplay = value;
- this.manualAutoplay_(typeof value === "string" ? value : "play");
- techAutoplay = false;
- } else if (!value) {
- this.options_.autoplay = false;
- } else {
- this.options_.autoplay = true;
- }
- techAutoplay = typeof techAutoplay === "undefined" ? this.options_.autoplay : techAutoplay;
- if (this.tech_) {
- this.techCall_("setAutoplay", techAutoplay);
- }
- }
- playsinline(value) {
- if (value !== void 0) {
- this.techCall_("setPlaysinline", value);
- this.options_.playsinline = value;
- return this;
- }
- return this.techGet_("playsinline");
- }
- loop(value) {
- if (value !== void 0) {
- this.techCall_("setLoop", value);
- this.options_.loop = value;
- return;
- }
- return this.techGet_("loop");
- }
- poster(src) {
- if (src === void 0) {
- return this.poster_;
- }
- if (!src) {
- src = "";
- }
- if (src === this.poster_) {
- return;
- }
- this.poster_ = src;
- this.techCall_("setPoster", src);
- this.isPosterFromTech_ = false;
- this.trigger("posterchange");
- }
- handleTechPosterChange_() {
- if ((!this.poster_ || this.options_.techCanOverridePoster) && this.tech_ && this.tech_.poster) {
- const newPoster = this.tech_.poster() || "";
- if (newPoster !== this.poster_) {
- this.poster_ = newPoster;
- this.isPosterFromTech_ = true;
- this.trigger("posterchange");
- }
- }
- }
- controls(bool) {
- if (bool === void 0) {
- return !!this.controls_;
- }
- bool = !!bool;
- if (this.controls_ === bool) {
- return;
- }
- this.controls_ = bool;
- if (this.usingNativeControls()) {
- this.techCall_("setControls", bool);
- }
- if (this.controls_) {
- this.removeClass("vjs-controls-disabled");
- this.addClass("vjs-controls-enabled");
- this.trigger("controlsenabled");
- if (!this.usingNativeControls()) {
- this.addTechControlsListeners_();
- }
- } else {
- this.removeClass("vjs-controls-enabled");
- this.addClass("vjs-controls-disabled");
- this.trigger("controlsdisabled");
- if (!this.usingNativeControls()) {
- this.removeTechControlsListeners_();
- }
- }
- }
- usingNativeControls(bool) {
- if (bool === void 0) {
- return !!this.usingNativeControls_;
- }
- bool = !!bool;
- if (this.usingNativeControls_ === bool) {
- return;
- }
- this.usingNativeControls_ = bool;
- if (this.usingNativeControls_) {
- this.addClass("vjs-using-native-controls");
- this.trigger("usingnativecontrols");
- } else {
- this.removeClass("vjs-using-native-controls");
- this.trigger("usingcustomcontrols");
- }
- }
- error(err) {
- if (err === void 0) {
- return this.error_ || null;
- }
- hooks$1("beforeerror").forEach((hookFunction) => {
- const newErr = hookFunction(this, err);
- if (!(isObject$2(newErr) && !Array.isArray(newErr) || typeof newErr === "string" || typeof newErr === "number" || newErr === null)) {
- this.log.error("please return a value that MediaError expects in beforeerror hooks");
- return;
- }
- err = newErr;
- });
- if (this.options_.suppressNotSupportedError && err && err.code === 4) {
- const triggerSuppressedError = function() {
- this.error(err);
- };
- this.options_.suppressNotSupportedError = false;
- this.any(["click", "touchstart"], triggerSuppressedError);
- this.one("loadstart", function() {
- this.off(["click", "touchstart"], triggerSuppressedError);
- });
- return;
- }
- if (err === null) {
- this.error_ = err;
- this.removeClass("vjs-error");
- if (this.errorDisplay) {
- this.errorDisplay.close();
- }
- return;
- }
- this.error_ = new MediaError$1(err);
- this.addClass("vjs-error");
- log$1$1.error(`(CODE:${this.error_.code} ${MediaError$1.errorTypes[this.error_.code]})`, this.error_.message, this.error_);
- this.trigger("error");
- hooks$1("error").forEach((hookFunction) => hookFunction(this, this.error_));
- return;
- }
- reportUserActivity(event2) {
- this.userActivity_ = true;
- }
- userActive(bool) {
- if (bool === void 0) {
- return this.userActive_;
- }
- bool = !!bool;
- if (bool === this.userActive_) {
- return;
- }
- this.userActive_ = bool;
- if (this.userActive_) {
- this.userActivity_ = true;
- this.removeClass("vjs-user-inactive");
- this.addClass("vjs-user-active");
- this.trigger("useractive");
- return;
- }
- if (this.tech_) {
- this.tech_.one("mousemove", function(e) {
- e.stopPropagation();
- e.preventDefault();
- });
- }
- this.userActivity_ = false;
- this.removeClass("vjs-user-active");
- this.addClass("vjs-user-inactive");
- this.trigger("userinactive");
- }
- listenForUserActivity_() {
- let mouseInProgress;
- let lastMoveX;
- let lastMoveY;
- const handleActivity = bind_(this, this.reportUserActivity);
- const handleMouseMove = function(e) {
- if (e.screenX !== lastMoveX || e.screenY !== lastMoveY) {
- lastMoveX = e.screenX;
- lastMoveY = e.screenY;
- handleActivity();
- }
- };
- const handleMouseDown = function() {
- handleActivity();
- this.clearInterval(mouseInProgress);
- mouseInProgress = this.setInterval(handleActivity, 250);
- };
- const handleMouseUpAndMouseLeave = function(event2) {
- handleActivity();
- this.clearInterval(mouseInProgress);
- };
- this.on("mousedown", handleMouseDown);
- this.on("mousemove", handleMouseMove);
- this.on("mouseup", handleMouseUpAndMouseLeave);
- this.on("mouseleave", handleMouseUpAndMouseLeave);
- const controlBar = this.getChild("controlBar");
- if (controlBar && !IS_IOS$1 && !IS_ANDROID$1) {
- controlBar.on("mouseenter", function(event2) {
- if (this.player().options_.inactivityTimeout !== 0) {
- this.player().cache_.inactivityTimeout = this.player().options_.inactivityTimeout;
- }
- this.player().options_.inactivityTimeout = 0;
- });
- controlBar.on("mouseleave", function(event2) {
- this.player().options_.inactivityTimeout = this.player().cache_.inactivityTimeout;
- });
- }
- this.on("keydown", handleActivity);
- this.on("keyup", handleActivity);
- let inactivityTimeout;
- this.setInterval(function() {
- if (!this.userActivity_) {
- return;
- }
- this.userActivity_ = false;
- this.userActive(true);
- this.clearTimeout(inactivityTimeout);
- const timeout = this.options_.inactivityTimeout;
- if (timeout <= 0) {
- return;
- }
- inactivityTimeout = this.setTimeout(function() {
- if (!this.userActivity_) {
- this.userActive(false);
- }
- }, timeout);
- }, 250);
- }
- playbackRate(rate) {
- if (rate !== void 0) {
- this.techCall_("setPlaybackRate", rate);
- return;
- }
- if (this.tech_ && this.tech_.featuresPlaybackRate) {
- return this.cache_.lastPlaybackRate || this.techGet_("playbackRate");
- }
- return 1;
- }
- defaultPlaybackRate(rate) {
- if (rate !== void 0) {
- return this.techCall_("setDefaultPlaybackRate", rate);
- }
- if (this.tech_ && this.tech_.featuresPlaybackRate) {
- return this.techGet_("defaultPlaybackRate");
- }
- return 1;
- }
- isAudio(bool) {
- if (bool !== void 0) {
- this.isAudio_ = !!bool;
- return;
- }
- return !!this.isAudio_;
- }
- enableAudioOnlyUI_() {
- this.addClass("vjs-audio-only-mode");
- const playerChildren = this.children();
- const controlBar = this.getChild("ControlBar");
- const controlBarHeight = controlBar && controlBar.currentHeight();
- playerChildren.forEach((child) => {
- if (child === controlBar) {
- return;
- }
- if (child.el_ && !child.hasClass("vjs-hidden")) {
- child.hide();
- this.audioOnlyCache_.hiddenChildren.push(child);
- }
- });
- this.audioOnlyCache_.playerHeight = this.currentHeight();
- this.height(controlBarHeight);
- this.trigger("audioonlymodechange");
- }
- disableAudioOnlyUI_() {
- this.removeClass("vjs-audio-only-mode");
- this.audioOnlyCache_.hiddenChildren.forEach((child) => child.show());
- this.height(this.audioOnlyCache_.playerHeight);
- this.trigger("audioonlymodechange");
- }
- audioOnlyMode(value) {
- if (typeof value !== "boolean" || value === this.audioOnlyMode_) {
- return this.audioOnlyMode_;
- }
- this.audioOnlyMode_ = value;
- if (value) {
- const exitPromises = [];
- if (this.isInPictureInPicture()) {
- exitPromises.push(this.exitPictureInPicture());
- }
- if (this.isFullscreen()) {
- exitPromises.push(this.exitFullscreen());
- }
- if (this.audioPosterMode()) {
- exitPromises.push(this.audioPosterMode(false));
- }
- return Promise.all(exitPromises).then(() => this.enableAudioOnlyUI_());
- }
- return Promise.resolve().then(() => this.disableAudioOnlyUI_());
- }
- enablePosterModeUI_() {
- const tech = this.tech_ && this.tech_;
- tech.hide();
- this.addClass("vjs-audio-poster-mode");
- this.trigger("audiopostermodechange");
- }
- disablePosterModeUI_() {
- const tech = this.tech_ && this.tech_;
- tech.show();
- this.removeClass("vjs-audio-poster-mode");
- this.trigger("audiopostermodechange");
- }
- audioPosterMode(value) {
- if (typeof value !== "boolean" || value === this.audioPosterMode_) {
- return this.audioPosterMode_;
- }
- this.audioPosterMode_ = value;
- if (value) {
- if (this.audioOnlyMode()) {
- const audioOnlyModePromise = this.audioOnlyMode(false);
- return audioOnlyModePromise.then(() => {
- this.enablePosterModeUI_();
- });
- }
- return Promise.resolve().then(() => {
- this.enablePosterModeUI_();
- });
- }
- return Promise.resolve().then(() => {
- this.disablePosterModeUI_();
- });
- }
- addTextTrack(kind, label2, language) {
- if (this.tech_) {
- return this.tech_.addTextTrack(kind, label2, language);
- }
- }
- addRemoteTextTrack(options2, manualCleanup) {
- if (this.tech_) {
- return this.tech_.addRemoteTextTrack(options2, manualCleanup);
- }
- }
- removeRemoteTextTrack(obj = {}) {
- let {
- track
- } = obj;
- if (!track) {
- track = obj;
- }
- if (this.tech_) {
- return this.tech_.removeRemoteTextTrack(track);
- }
- }
- getVideoPlaybackQuality() {
- return this.techGet_("getVideoPlaybackQuality");
- }
- videoWidth() {
- return this.tech_ && this.tech_.videoWidth && this.tech_.videoWidth() || 0;
- }
- videoHeight() {
- return this.tech_ && this.tech_.videoHeight && this.tech_.videoHeight() || 0;
- }
- language(code) {
- if (code === void 0) {
- return this.language_;
- }
- if (this.language_ !== String(code).toLowerCase()) {
- this.language_ = String(code).toLowerCase();
- if (isEvented$1(this)) {
- this.trigger("languagechange");
- }
- }
- }
- languages() {
- return merge$1(Player$1.prototype.options_.languages, this.languages_);
- }
- toJSON() {
- const options2 = merge$1(this.options_);
- const tracks = options2.tracks;
- options2.tracks = [];
- for (let i2 = 0; i2 < tracks.length; i2++) {
- let track = tracks[i2];
- track = merge$1(track);
- track.player = void 0;
- options2.tracks[i2] = track;
- }
- return options2;
- }
- createModal(content, options2) {
- options2 = options2 || {};
- options2.content = content || "";
- const modal = new ModalDialog$1(this, options2);
- this.addChild(modal);
- modal.on("dispose", () => {
- this.removeChild(modal);
- });
- modal.open();
- return modal;
- }
- updateCurrentBreakpoint_() {
- if (!this.responsive()) {
- return;
- }
- const currentBreakpoint = this.currentBreakpoint();
- const currentWidth = this.currentWidth();
- for (let i2 = 0; i2 < BREAKPOINT_ORDER$1.length; i2++) {
- const candidateBreakpoint = BREAKPOINT_ORDER$1[i2];
- const maxWidth = this.breakpoints_[candidateBreakpoint];
- if (currentWidth <= maxWidth) {
- if (currentBreakpoint === candidateBreakpoint) {
- return;
- }
- if (currentBreakpoint) {
- this.removeClass(BREAKPOINT_CLASSES$1[currentBreakpoint]);
- }
- this.addClass(BREAKPOINT_CLASSES$1[candidateBreakpoint]);
- this.breakpoint_ = candidateBreakpoint;
- break;
- }
- }
- }
- removeCurrentBreakpoint_() {
- const className = this.currentBreakpointClass();
- this.breakpoint_ = "";
- if (className) {
- this.removeClass(className);
- }
- }
- breakpoints(breakpoints) {
- if (breakpoints === void 0) {
- return Object.assign(this.breakpoints_);
- }
- this.breakpoint_ = "";
- this.breakpoints_ = Object.assign({}, DEFAULT_BREAKPOINTS$1, breakpoints);
- this.updateCurrentBreakpoint_();
- return Object.assign(this.breakpoints_);
- }
- responsive(value) {
- if (value === void 0) {
- return this.responsive_;
- }
- value = Boolean(value);
- const current = this.responsive_;
- if (value === current) {
- return;
- }
- this.responsive_ = value;
- if (value) {
- this.on("playerresize", this.boundUpdateCurrentBreakpoint_);
- this.updateCurrentBreakpoint_();
- } else {
- this.off("playerresize", this.boundUpdateCurrentBreakpoint_);
- this.removeCurrentBreakpoint_();
- }
- return value;
- }
- currentBreakpoint() {
- return this.breakpoint_;
- }
- currentBreakpointClass() {
- return BREAKPOINT_CLASSES$1[this.breakpoint_] || "";
- }
- loadMedia(media, ready) {
- if (!media || typeof media !== "object") {
- return;
- }
- this.reset();
- this.cache_.media = merge$1(media);
- const {
- artist,
- artwork,
- description,
- poster,
- src,
- textTracks,
- title
- } = this.cache_.media;
- if (!artwork && poster) {
- this.cache_.media.artwork = [{
- src: poster,
- type: getMimetype$1(poster)
- }];
- }
- if (src) {
- this.src(src);
- }
- if (poster) {
- this.poster(poster);
- }
- if (Array.isArray(textTracks)) {
- textTracks.forEach((tt2) => this.addRemoteTextTrack(tt2, false));
- }
- if (this.titleBar) {
- this.titleBar.update({
- title,
- description: description || artist || ""
- });
- }
- this.ready(ready);
- }
- getMedia() {
- if (!this.cache_.media) {
- const poster = this.poster();
- const src = this.currentSources();
- const textTracks = Array.prototype.map.call(this.remoteTextTracks(), (tt2) => ({
- kind: tt2.kind,
- label: tt2.label,
- language: tt2.language,
- src: tt2.src
- }));
- const media = {
- src,
- textTracks
- };
- if (poster) {
- media.poster = poster;
- media.artwork = [{
- src: media.poster,
- type: getMimetype$1(media.poster)
- }];
- }
- return media;
- }
- return merge$1(this.cache_.media);
- }
- static getTagSettings(tag) {
- const baseOptions = {
- sources: [],
- tracks: []
- };
- const tagOptions = getAttributes$1(tag);
- const dataSetup = tagOptions["data-setup"];
- if (hasClass$1(tag, "vjs-fill")) {
- tagOptions.fill = true;
- }
- if (hasClass$1(tag, "vjs-fluid")) {
- tagOptions.fluid = true;
- }
- if (dataSetup !== null) {
- const [err, data] = tuple(dataSetup || "{}");
- if (err) {
- log$1$1.error(err);
- }
- Object.assign(tagOptions, data);
- }
- Object.assign(baseOptions, tagOptions);
- if (tag.hasChildNodes()) {
- const children = tag.childNodes;
- for (let i2 = 0, j = children.length; i2 < j; i2++) {
- const child = children[i2];
- const childName = child.nodeName.toLowerCase();
- if (childName === "source") {
- baseOptions.sources.push(getAttributes$1(child));
- } else if (childName === "track") {
- baseOptions.tracks.push(getAttributes$1(child));
- }
- }
- }
- return baseOptions;
- }
- debug(enabled) {
- if (enabled === void 0) {
- return this.debugEnabled_;
- }
- if (enabled) {
- this.trigger("debugon");
- this.previousLogLevel_ = this.log.level;
- this.log.level("debug");
- this.debugEnabled_ = true;
- } else {
- this.trigger("debugoff");
- this.log.level(this.previousLogLevel_);
- this.previousLogLevel_ = void 0;
- this.debugEnabled_ = false;
- }
- }
- playbackRates(newRates) {
- if (newRates === void 0) {
- return this.cache_.playbackRates;
- }
- if (!Array.isArray(newRates)) {
- return;
- }
- if (!newRates.every((rate) => typeof rate === "number")) {
- return;
- }
- this.cache_.playbackRates = newRates;
- this.trigger("playbackrateschange");
- }
- }
- ALL$1.names.forEach(function(name) {
- const props = ALL$1[name];
- Player$1.prototype[props.getterName] = function() {
- if (this.tech_) {
- return this.tech_[props.getterName]();
- }
- this[props.privateName] = this[props.privateName] || new props.ListClass();
- return this[props.privateName];
- };
- });
- Player$1.prototype.crossorigin = Player$1.prototype.crossOrigin;
- Player$1.players = {};
- const navigator$3 = window_1.navigator;
- Player$1.prototype.options_ = {
- techOrder: Tech$2.defaultTechOrder_,
- html5: {},
- enableSourceset: true,
- inactivityTimeout: 2e3,
- playbackRates: [],
- liveui: false,
- children: ["mediaLoader", "posterImage", "titleBar", "textTrackDisplay", "loadingSpinner", "bigPlayButton", "liveTracker", "controlBar", "errorDisplay", "textTrackSettings", "resizeManager"],
- language: navigator$3 && (navigator$3.languages && navigator$3.languages[0] || navigator$3.userLanguage || navigator$3.language) || "en",
- languages: {},
- notSupportedMessage: "No compatible source was found for this media.",
- normalizeAutoplay: false,
- fullscreen: {
- options: {
- navigationUI: "hide"
- }
- },
- breakpoints: {},
- responsive: false,
- audioOnlyMode: false,
- audioPosterMode: false
- };
- [
- "ended",
- "seeking",
- "seekable",
- "networkState",
- "readyState"
- ].forEach(function(fn2) {
- Player$1.prototype[fn2] = function() {
- return this.techGet_(fn2);
- };
- });
- TECH_EVENTS_RETRIGGER$1.forEach(function(event2) {
- Player$1.prototype[`handleTech${toTitleCase$1$1(event2)}_`] = function() {
- return this.trigger(event2);
- };
- });
- Component$1$1.registerComponent("Player", Player$1);
- const BASE_PLUGIN_NAME$1 = "plugin";
- const PLUGIN_CACHE_KEY$1 = "activePlugins_";
- const pluginStorage$1 = {};
- const pluginExists$1 = (name) => pluginStorage$1.hasOwnProperty(name);
- const getPlugin$1 = (name) => pluginExists$1(name) ? pluginStorage$1[name] : void 0;
- const markPluginAsActive$1 = (player, name) => {
- player[PLUGIN_CACHE_KEY$1] = player[PLUGIN_CACHE_KEY$1] || {};
- player[PLUGIN_CACHE_KEY$1][name] = true;
- };
- const triggerSetupEvent$1 = (player, hash, before) => {
- const eventName = (before ? "before" : "") + "pluginsetup";
- player.trigger(eventName, hash);
- player.trigger(eventName + ":" + hash.name, hash);
- };
- const createBasicPlugin$1 = function(name, plugin) {
- const basicPluginWrapper = function() {
- triggerSetupEvent$1(this, {
- name,
- plugin,
- instance: null
- }, true);
- const instance = plugin.apply(this, arguments);
- markPluginAsActive$1(this, name);
- triggerSetupEvent$1(this, {
- name,
- plugin,
- instance
- });
- return instance;
- };
- Object.keys(plugin).forEach(function(prop) {
- basicPluginWrapper[prop] = plugin[prop];
- });
- return basicPluginWrapper;
- };
- const createPluginFactory$1 = (name, PluginSubClass) => {
- PluginSubClass.prototype.name = name;
- return function(...args) {
- triggerSetupEvent$1(this, {
- name,
- plugin: PluginSubClass,
- instance: null
- }, true);
- const instance = new PluginSubClass(...[this, ...args]);
- this[name] = () => instance;
- triggerSetupEvent$1(this, instance.getEventHash());
- return instance;
- };
- };
- class Plugin$1 {
- constructor(player) {
- if (this.constructor === Plugin$1) {
- throw new Error("Plugin must be sub-classed; not directly instantiated.");
- }
- this.player = player;
- if (!this.log) {
- this.log = this.player.log.createLogger(this.name);
- }
- evented$1(this);
- delete this.trigger;
- stateful$1(this, this.constructor.defaultState);
- markPluginAsActive$1(player, this.name);
- this.dispose = this.dispose.bind(this);
- player.on("dispose", this.dispose);
- }
- version() {
- return this.constructor.VERSION;
- }
- getEventHash(hash = {}) {
- hash.name = this.name;
- hash.plugin = this.constructor;
- hash.instance = this;
- return hash;
- }
- trigger(event2, hash = {}) {
- return trigger$1(this.eventBusEl_, event2, this.getEventHash(hash));
- }
- handleStateChanged(e) {
- }
- dispose() {
- const {
- name,
- player
- } = this;
- this.trigger("dispose");
- this.off();
- player.off("dispose", this.dispose);
- player[PLUGIN_CACHE_KEY$1][name] = false;
- this.player = this.state = null;
- player[name] = createPluginFactory$1(name, pluginStorage$1[name]);
- }
- static isBasic(plugin) {
- const p = typeof plugin === "string" ? getPlugin$1(plugin) : plugin;
- return typeof p === "function" && !Plugin$1.prototype.isPrototypeOf(p.prototype);
- }
- static registerPlugin(name, plugin) {
- if (typeof name !== "string") {
- throw new Error(`Illegal plugin name, "${name}", must be a string, was ${typeof name}.`);
- }
- if (pluginExists$1(name)) {
- log$1$1.warn(`A plugin named "${name}" already exists. You may want to avoid re-registering plugins!`);
- } else if (Player$1.prototype.hasOwnProperty(name)) {
- throw new Error(`Illegal plugin name, "${name}", cannot share a name with an existing player method!`);
- }
- if (typeof plugin !== "function") {
- throw new Error(`Illegal plugin for "${name}", must be a function, was ${typeof plugin}.`);
- }
- pluginStorage$1[name] = plugin;
- if (name !== BASE_PLUGIN_NAME$1) {
- if (Plugin$1.isBasic(plugin)) {
- Player$1.prototype[name] = createBasicPlugin$1(name, plugin);
- } else {
- Player$1.prototype[name] = createPluginFactory$1(name, plugin);
- }
- }
- return plugin;
- }
- static deregisterPlugin(name) {
- if (name === BASE_PLUGIN_NAME$1) {
- throw new Error("Cannot de-register base plugin.");
- }
- if (pluginExists$1(name)) {
- delete pluginStorage$1[name];
- delete Player$1.prototype[name];
- }
- }
- static getPlugins(names2 = Object.keys(pluginStorage$1)) {
- let result;
- names2.forEach((name) => {
- const plugin = getPlugin$1(name);
- if (plugin) {
- result = result || {};
- result[name] = plugin;
- }
- });
- return result;
- }
- static getPluginVersion(name) {
- const plugin = getPlugin$1(name);
- return plugin && plugin.VERSION || "";
- }
- }
- Plugin$1.getPlugin = getPlugin$1;
- Plugin$1.BASE_PLUGIN_NAME = BASE_PLUGIN_NAME$1;
- Plugin$1.registerPlugin(BASE_PLUGIN_NAME$1, Plugin$1);
- Player$1.prototype.usingPlugin = function(name) {
- return !!this[PLUGIN_CACHE_KEY$1] && this[PLUGIN_CACHE_KEY$1][name] === true;
- };
- Player$1.prototype.hasPlugin = function(name) {
- return !!pluginExists$1(name);
- };
- function deprecate(message, fn2) {
- let warned = false;
- return function(...args) {
- if (!warned) {
- log$1$1.warn(message);
- }
- warned = true;
- return fn2.apply(this, args);
- };
- }
- function deprecateForMajor(major, oldName, newName, fn2) {
- return deprecate(`${oldName} is deprecated and will be removed in ${major}.0; please use ${newName} instead.`, fn2);
- }
- const normalizeId$1 = (id) => id.indexOf("#") === 0 ? id.slice(1) : id;
- function videojs$2(id, options2, ready) {
- let player = videojs$2.getPlayer(id);
- if (player) {
- if (options2) {
- log$1$1.warn(`Player "${id}" is already initialised. Options will not be applied.`);
- }
- if (ready) {
- player.ready(ready);
- }
- return player;
- }
- const el = typeof id === "string" ? $$1("#" + normalizeId$1(id)) : id;
- if (!isEl$1(el)) {
- throw new TypeError("The element or ID supplied is not valid. (videojs)");
- }
- if (!el.ownerDocument.defaultView || !el.ownerDocument.body.contains(el)) {
- log$1$1.warn("The element supplied is not included in the DOM");
- }
- options2 = options2 || {};
- if (options2.restoreEl === true) {
- options2.restoreEl = (el.parentNode && el.parentNode.hasAttribute("data-vjs-player") ? el.parentNode : el).cloneNode(true);
- }
- hooks$1("beforesetup").forEach((hookFunction) => {
- const opts = hookFunction(el, merge$1(options2));
- if (!isObject$2(opts) || Array.isArray(opts)) {
- log$1$1.error("please return an object in beforesetup hooks");
- return;
- }
- options2 = merge$1(options2, opts);
- });
- const PlayerComponent = Component$1$1.getComponent("Player");
- player = new PlayerComponent(el, options2, ready);
- hooks$1("setup").forEach((hookFunction) => hookFunction(player));
- return player;
- }
- videojs$2.hooks_ = hooks_$1;
- videojs$2.hooks = hooks$1;
- videojs$2.hook = hook$1;
- videojs$2.hookOnce = hookOnce$1;
- videojs$2.removeHook = removeHook$1;
- if (window_1.VIDEOJS_NO_DYNAMIC_STYLE !== true && isReal$1()) {
- let style = $$1(".vjs-styles-defaults");
- if (!style) {
- style = createStyleElement$1("vjs-styles-defaults");
- const head = $$1("head");
- if (head) {
- head.insertBefore(style, head.firstChild);
- }
- setTextContent$1(style, `
- .video-js {
- width: 300px;
- height: 150px;
- }
- .vjs-fluid:not(.vjs-audio-only-mode) {
- padding-top: 56.25%
- }
- `);
- }
- }
- autoSetupTimeout$1(1, videojs$2);
- videojs$2.VERSION = version$6$1;
- videojs$2.options = Player$1.prototype.options_;
- videojs$2.getPlayers = () => Player$1.players;
- videojs$2.getPlayer = (id) => {
- const players = Player$1.players;
- let tag;
- if (typeof id === "string") {
- const nId = normalizeId$1(id);
- const player = players[nId];
- if (player) {
- return player;
- }
- tag = $$1("#" + nId);
- } else {
- tag = id;
- }
- if (isEl$1(tag)) {
- const {
- player,
- playerId
- } = tag;
- if (player || players[playerId]) {
- return player || players[playerId];
- }
- }
- };
- videojs$2.getAllPlayers = () => Object.keys(Player$1.players).map((k) => Player$1.players[k]).filter(Boolean);
- videojs$2.players = Player$1.players;
- videojs$2.getComponent = Component$1$1.getComponent;
- videojs$2.registerComponent = (name, comp) => {
- if (Tech$2.isTech(comp)) {
- log$1$1.warn(`The ${name} tech was registered as a component. It should instead be registered using videojs.registerTech(name, tech)`);
- }
- Component$1$1.registerComponent.call(Component$1$1, name, comp);
- };
- videojs$2.getTech = Tech$2.getTech;
- videojs$2.registerTech = Tech$2.registerTech;
- videojs$2.use = use$1;
- Object.defineProperty(videojs$2, "middleware", {
- value: {},
- writeable: false,
- enumerable: true
- });
- Object.defineProperty(videojs$2.middleware, "TERMINATOR", {
- value: TERMINATOR$1,
- writeable: false,
- enumerable: true
- });
- videojs$2.browser = browser$1;
- videojs$2.obj = Obj;
- videojs$2.mergeOptions = deprecateForMajor(9, "videojs.mergeOptions", "videojs.obj.merge", merge$1);
- videojs$2.defineLazyProperty = deprecateForMajor(9, "videojs.defineLazyProperty", "videojs.obj.defineLazyProperty", defineLazyProperty$1);
- videojs$2.bind = deprecateForMajor(9, "videojs.bind", "native Function.prototype.bind", bind_);
- videojs$2.registerPlugin = Plugin$1.registerPlugin;
- videojs$2.deregisterPlugin = Plugin$1.deregisterPlugin;
- videojs$2.plugin = (name, plugin) => {
- log$1$1.warn("videojs.plugin() is deprecated; use videojs.registerPlugin() instead");
- return Plugin$1.registerPlugin(name, plugin);
- };
- videojs$2.getPlugins = Plugin$1.getPlugins;
- videojs$2.getPlugin = Plugin$1.getPlugin;
- videojs$2.getPluginVersion = Plugin$1.getPluginVersion;
- videojs$2.addLanguage = function(code, data) {
- code = ("" + code).toLowerCase();
- videojs$2.options.languages = merge$1(videojs$2.options.languages, {
- [code]: data
- });
- return videojs$2.options.languages[code];
- };
- videojs$2.log = log$1$1;
- videojs$2.createLogger = createLogger$2;
- videojs$2.time = Time;
- videojs$2.createTimeRange = deprecateForMajor(9, "videojs.createTimeRange", "videojs.time.createTimeRanges", createTimeRanges$1);
- videojs$2.createTimeRanges = deprecateForMajor(9, "videojs.createTimeRanges", "videojs.time.createTimeRanges", createTimeRanges$1);
- videojs$2.formatTime = deprecateForMajor(9, "videojs.formatTime", "videojs.time.formatTime", formatTime$1);
- videojs$2.setFormatTime = deprecateForMajor(9, "videojs.setFormatTime", "videojs.time.setFormatTime", setFormatTime$1);
- videojs$2.resetFormatTime = deprecateForMajor(9, "videojs.resetFormatTime", "videojs.time.resetFormatTime", resetFormatTime$1);
- videojs$2.parseUrl = deprecateForMajor(9, "videojs.parseUrl", "videojs.url.parseUrl", parseUrl$1);
- videojs$2.isCrossOrigin = deprecateForMajor(9, "videojs.isCrossOrigin", "videojs.url.isCrossOrigin", isCrossOrigin$1);
- videojs$2.EventTarget = EventTarget$2$1;
- videojs$2.any = any$1;
- videojs$2.on = on$1;
- videojs$2.one = one$1;
- videojs$2.off = off$1;
- videojs$2.trigger = trigger$1;
- videojs$2.xhr = XHR;
- videojs$2.TextTrack = TextTrack$1;
- videojs$2.AudioTrack = AudioTrack$1;
- videojs$2.VideoTrack = VideoTrack$1;
- ["isEl", "isTextNode", "createEl", "hasClass", "addClass", "removeClass", "toggleClass", "setAttributes", "getAttributes", "emptyEl", "appendContent", "insertContent"].forEach((k) => {
- videojs$2[k] = function() {
- log$1$1.warn(`videojs.${k}() is deprecated; use videojs.dom.${k}() instead`);
- return Dom$2[k].apply(null, arguments);
- };
- });
- videojs$2.computedStyle = deprecateForMajor(9, "videojs.computedStyle", "videojs.dom.computedStyle", computedStyle$1);
- videojs$2.dom = Dom$2;
- videojs$2.fn = Fn;
- videojs$2.num = Num;
- videojs$2.str = Str;
- videojs$2.url = Url$2;
- /*! @name videojs-contrib-quality-levels @version 3.0.0 @license Apache-2.0 */
- class QualityLevel {
- constructor(representation) {
- let level = this;
- level.id = representation.id;
- level.label = level.id;
- level.width = representation.width;
- level.height = representation.height;
- level.bitrate = representation.bandwidth;
- level.frameRate = representation.frameRate;
- level.enabled_ = representation.enabled;
- Object.defineProperty(level, "enabled", {
- get() {
- return level.enabled_();
- },
- set(enable) {
- level.enabled_(enable);
- }
- });
- return level;
- }
- }
- class QualityLevelList extends videojs$2.EventTarget {
- constructor() {
- super();
- let list = this;
- list.levels_ = [];
- list.selectedIndex_ = -1;
- Object.defineProperty(list, "selectedIndex", {
- get() {
- return list.selectedIndex_;
- }
- });
- Object.defineProperty(list, "length", {
- get() {
- return list.levels_.length;
- }
- });
- return list;
- }
- addQualityLevel(representation) {
- let qualityLevel = this.getQualityLevelById(representation.id);
- if (qualityLevel) {
- return qualityLevel;
- }
- const index2 = this.levels_.length;
- qualityLevel = new QualityLevel(representation);
- if (!("" + index2 in this)) {
- Object.defineProperty(this, index2, {
- get() {
- return this.levels_[index2];
- }
- });
- }
- this.levels_.push(qualityLevel);
- this.trigger({
- qualityLevel,
- type: "addqualitylevel"
- });
- return qualityLevel;
- }
- removeQualityLevel(qualityLevel) {
- let removed = null;
- for (let i2 = 0, l = this.length; i2 < l; i2++) {
- if (this[i2] === qualityLevel) {
- removed = this.levels_.splice(i2, 1)[0];
- if (this.selectedIndex_ === i2) {
- this.selectedIndex_ = -1;
- } else if (this.selectedIndex_ > i2) {
- this.selectedIndex_--;
- }
- break;
- }
- }
- if (removed) {
- this.trigger({
- qualityLevel,
- type: "removequalitylevel"
- });
- }
- return removed;
- }
- getQualityLevelById(id) {
- for (let i2 = 0, l = this.length; i2 < l; i2++) {
- const level = this[i2];
- if (level.id === id) {
- return level;
- }
- }
- return null;
- }
- dispose() {
- this.selectedIndex_ = -1;
- this.levels_.length = 0;
- }
- }
- QualityLevelList.prototype.allowedEvents_ = {
- change: "change",
- addqualitylevel: "addqualitylevel",
- removequalitylevel: "removequalitylevel"
- };
- for (const event2 in QualityLevelList.prototype.allowedEvents_) {
- QualityLevelList.prototype["on" + event2] = null;
- }
- var version$5$1 = "3.0.0";
- const registerPlugin$1 = videojs$2.registerPlugin || videojs$2.plugin;
- const initPlugin$1 = function(player, options2) {
- const originalPluginFn = player.qualityLevels;
- const qualityLevelList = new QualityLevelList();
- const disposeHandler = function() {
- qualityLevelList.dispose();
- player.qualityLevels = originalPluginFn;
- player.off("dispose", disposeHandler);
- };
- player.on("dispose", disposeHandler);
- player.qualityLevels = () => qualityLevelList;
- player.qualityLevels.VERSION = version$5$1;
- return qualityLevelList;
- };
- const qualityLevels = function(options2) {
- return initPlugin$1(this, videojs$2.mergeOptions({}, options2));
- };
- registerPlugin$1("qualityLevels", qualityLevels);
- qualityLevels.VERSION = version$5$1;
- /*! @name @videojs/http-streaming @version 3.0.2 @license Apache-2.0 */
- const resolveUrl$2 = resolveUrl$4;
- const resolveManifestRedirect$1 = (url, req) => {
- if (req && req.responseURL && url !== req.responseURL) {
- return req.responseURL;
- }
- return url;
- };
- const logger$1 = (source) => {
- if (videojs$2.log.debug) {
- return videojs$2.log.debug.bind(videojs$2, "VHS:", `${source} >`);
- }
- return function() {
- };
- };
- function merge$2(...args) {
- const context = videojs$2.obj || videojs$2;
- const fn2 = context.merge || context.mergeOptions;
- return fn2.apply(context, args);
- }
- function createTimeRanges$2(...args) {
- const context = videojs$2.time || videojs$2;
- const fn2 = context.createTimeRanges || context.createTimeRanges;
- return fn2.apply(context, args);
- }
- const TIME_FUDGE_FACTOR$1 = 1 / 30;
- const SAFE_TIME_DELTA$1 = TIME_FUDGE_FACTOR$1 * 3;
- const filterRanges$1 = function(timeRanges, predicate) {
- const results = [];
- let i2;
- if (timeRanges && timeRanges.length) {
- for (i2 = 0; i2 < timeRanges.length; i2++) {
- if (predicate(timeRanges.start(i2), timeRanges.end(i2))) {
- results.push([timeRanges.start(i2), timeRanges.end(i2)]);
- }
- }
- }
- return createTimeRanges$2(results);
- };
- const findRange$1 = function(buffered, time) {
- return filterRanges$1(buffered, function(start2, end) {
- return start2 - SAFE_TIME_DELTA$1 <= time && end + SAFE_TIME_DELTA$1 >= time;
- });
- };
- const findNextRange$1 = function(timeRanges, time) {
- return filterRanges$1(timeRanges, function(start2) {
- return start2 - TIME_FUDGE_FACTOR$1 >= time;
- });
- };
- const findGaps$1 = function(buffered) {
- if (buffered.length < 2) {
- return createTimeRanges$2();
- }
- const ranges = [];
- for (let i2 = 1; i2 < buffered.length; i2++) {
- const start2 = buffered.end(i2 - 1);
- const end = buffered.start(i2);
- ranges.push([start2, end]);
- }
- return createTimeRanges$2(ranges);
- };
- const bufferIntersection$1 = function(bufferA, bufferB) {
- let start2 = null;
- let end = null;
- let arity = 0;
- const extents = [];
- const ranges = [];
- if (!bufferA || !bufferA.length || !bufferB || !bufferB.length) {
- return createTimeRanges$2();
- }
- let count = bufferA.length;
- while (count--) {
- extents.push({
- time: bufferA.start(count),
- type: "start"
- });
- extents.push({
- time: bufferA.end(count),
- type: "end"
- });
- }
- count = bufferB.length;
- while (count--) {
- extents.push({
- time: bufferB.start(count),
- type: "start"
- });
- extents.push({
- time: bufferB.end(count),
- type: "end"
- });
- }
- extents.sort(function(a, b) {
- return a.time - b.time;
- });
- for (count = 0; count < extents.length; count++) {
- if (extents[count].type === "start") {
- arity++;
- if (arity === 2) {
- start2 = extents[count].time;
- }
- } else if (extents[count].type === "end") {
- arity--;
- if (arity === 1) {
- end = extents[count].time;
- }
- }
- if (start2 !== null && end !== null) {
- ranges.push([start2, end]);
- start2 = null;
- end = null;
- }
- }
- return createTimeRanges$2(ranges);
- };
- const printableRange$1 = (range3) => {
- const strArr = [];
- if (!range3 || !range3.length) {
- return "";
- }
- for (let i2 = 0; i2 < range3.length; i2++) {
- strArr.push(range3.start(i2) + " => " + range3.end(i2));
- }
- return strArr.join(", ");
- };
- const timeUntilRebuffer$1 = function(buffered, currentTime, playbackRate = 1) {
- const bufferedEnd = buffered.length ? buffered.end(buffered.length - 1) : 0;
- return (bufferedEnd - currentTime) / playbackRate;
- };
- const timeRangesToArray$1 = (timeRanges) => {
- const timeRangesList = [];
- for (let i2 = 0; i2 < timeRanges.length; i2++) {
- timeRangesList.push({
- start: timeRanges.start(i2),
- end: timeRanges.end(i2)
- });
- }
- return timeRangesList;
- };
- const isRangeDifferent$1 = function(a, b) {
- if (a === b) {
- return false;
- }
- if (!a && b || !b && a) {
- return true;
- }
- if (a.length !== b.length) {
- return true;
- }
- for (let i2 = 0; i2 < a.length; i2++) {
- if (a.start(i2) !== b.start(i2) || a.end(i2) !== b.end(i2)) {
- return true;
- }
- }
- return false;
- };
- const lastBufferedEnd$1 = function(a) {
- if (!a || !a.length || !a.end) {
- return;
- }
- return a.end(a.length - 1);
- };
- const timeAheadOf$1 = function(range3, startTime) {
- let time = 0;
- if (!range3 || !range3.length) {
- return time;
- }
- for (let i2 = 0; i2 < range3.length; i2++) {
- const start2 = range3.start(i2);
- const end = range3.end(i2);
- if (startTime > end) {
- continue;
- }
- if (startTime > start2 && startTime <= end) {
- time += end - startTime;
- continue;
- }
- time += end - start2;
- }
- return time;
- };
- const segmentDurationWithParts$1 = (playlist, segment) => {
- if (!segment.preload) {
- return segment.duration;
- }
- let result = 0;
- (segment.parts || []).forEach(function(p) {
- result += p.duration;
- });
- (segment.preloadHints || []).forEach(function(p) {
- if (p.type === "PART") {
- result += playlist.partTargetDuration;
- }
- });
- return result;
- };
- const getPartsAndSegments$1 = (playlist) => (playlist.segments || []).reduce((acc, segment, si) => {
- if (segment.parts) {
- segment.parts.forEach(function(part, pi) {
- acc.push({
- duration: part.duration,
- segmentIndex: si,
- partIndex: pi,
- part,
- segment
- });
- });
- } else {
- acc.push({
- duration: segment.duration,
- segmentIndex: si,
- partIndex: null,
- segment,
- part: null
- });
- }
- return acc;
- }, []);
- const getLastParts$1 = (media) => {
- const lastSegment = media.segments && media.segments.length && media.segments[media.segments.length - 1];
- return lastSegment && lastSegment.parts || [];
- };
- const getKnownPartCount$1 = ({
- preloadSegment
- }) => {
- if (!preloadSegment) {
- return;
- }
- const {
- parts,
- preloadHints
- } = preloadSegment;
- let partCount = (preloadHints || []).reduce((count, hint) => count + (hint.type === "PART" ? 1 : 0), 0);
- partCount += parts && parts.length ? parts.length : 0;
- return partCount;
- };
- const liveEdgeDelay$1 = (main, media) => {
- if (media.endList) {
- return 0;
- }
- if (main && main.suggestedPresentationDelay) {
- return main.suggestedPresentationDelay;
- }
- const hasParts = getLastParts$1(media).length > 0;
- if (hasParts && media.serverControl && media.serverControl.partHoldBack) {
- return media.serverControl.partHoldBack;
- } else if (hasParts && media.partTargetDuration) {
- return media.partTargetDuration * 3;
- } else if (media.serverControl && media.serverControl.holdBack) {
- return media.serverControl.holdBack;
- } else if (media.targetDuration) {
- return media.targetDuration * 3;
- }
- return 0;
- };
- const backwardDuration$1 = function(playlist, endSequence) {
- let result = 0;
- let i2 = endSequence - playlist.mediaSequence;
- let segment = playlist.segments[i2];
- if (segment) {
- if (typeof segment.start !== "undefined") {
- return {
- result: segment.start,
- precise: true
- };
- }
- if (typeof segment.end !== "undefined") {
- return {
- result: segment.end - segment.duration,
- precise: true
- };
- }
- }
- while (i2--) {
- segment = playlist.segments[i2];
- if (typeof segment.end !== "undefined") {
- return {
- result: result + segment.end,
- precise: true
- };
- }
- result += segmentDurationWithParts$1(playlist, segment);
- if (typeof segment.start !== "undefined") {
- return {
- result: result + segment.start,
- precise: true
- };
- }
- }
- return {
- result,
- precise: false
- };
- };
- const forwardDuration$1 = function(playlist, endSequence) {
- let result = 0;
- let segment;
- let i2 = endSequence - playlist.mediaSequence;
- for (; i2 < playlist.segments.length; i2++) {
- segment = playlist.segments[i2];
- if (typeof segment.start !== "undefined") {
- return {
- result: segment.start - result,
- precise: true
- };
- }
- result += segmentDurationWithParts$1(playlist, segment);
- if (typeof segment.end !== "undefined") {
- return {
- result: segment.end - result,
- precise: true
- };
- }
- }
- return {
- result: -1,
- precise: false
- };
- };
- const intervalDuration$1 = function(playlist, endSequence, expired) {
- if (typeof endSequence === "undefined") {
- endSequence = playlist.mediaSequence + playlist.segments.length;
- }
- if (endSequence < playlist.mediaSequence) {
- return 0;
- }
- const backward = backwardDuration$1(playlist, endSequence);
- if (backward.precise) {
- return backward.result;
- }
- const forward = forwardDuration$1(playlist, endSequence);
- if (forward.precise) {
- return forward.result;
- }
- return backward.result + expired;
- };
- const duration$1 = function(playlist, endSequence, expired) {
- if (!playlist) {
- return 0;
- }
- if (typeof expired !== "number") {
- expired = 0;
- }
- if (typeof endSequence === "undefined") {
- if (playlist.totalDuration) {
- return playlist.totalDuration;
- }
- if (!playlist.endList) {
- return window_1.Infinity;
- }
- }
- return intervalDuration$1(playlist, endSequence, expired);
- };
- const sumDurations$1 = function({
- defaultDuration,
- durationList,
- startIndex,
- endIndex
- }) {
- let durations = 0;
- if (startIndex > endIndex) {
- [startIndex, endIndex] = [endIndex, startIndex];
- }
- if (startIndex < 0) {
- for (let i2 = startIndex; i2 < Math.min(0, endIndex); i2++) {
- durations += defaultDuration;
- }
- startIndex = 0;
- }
- for (let i2 = startIndex; i2 < endIndex; i2++) {
- durations += durationList[i2].duration;
- }
- return durations;
- };
- const playlistEnd$1 = function(playlist, expired, useSafeLiveEnd, liveEdgePadding) {
- if (!playlist || !playlist.segments) {
- return null;
- }
- if (playlist.endList) {
- return duration$1(playlist);
- }
- if (expired === null) {
- return null;
- }
- expired = expired || 0;
- let lastSegmentEndTime = intervalDuration$1(playlist, playlist.mediaSequence + playlist.segments.length, expired);
- if (useSafeLiveEnd) {
- liveEdgePadding = typeof liveEdgePadding === "number" ? liveEdgePadding : liveEdgeDelay$1(null, playlist);
- lastSegmentEndTime -= liveEdgePadding;
- }
- return Math.max(0, lastSegmentEndTime);
- };
- const seekable$1 = function(playlist, expired, liveEdgePadding) {
- const useSafeLiveEnd = true;
- const seekableStart = expired || 0;
- const seekableEnd = playlistEnd$1(playlist, expired, useSafeLiveEnd, liveEdgePadding);
- if (seekableEnd === null) {
- return createTimeRanges$2();
- }
- return createTimeRanges$2(seekableStart, seekableEnd);
- };
- const getMediaInfoForTime$1 = function({
- playlist,
- currentTime,
- startingSegmentIndex,
- startingPartIndex,
- startTime,
- exactManifestTimings
- }) {
- let time = currentTime - startTime;
- const partsAndSegments = getPartsAndSegments$1(playlist);
- let startIndex = 0;
- for (let i2 = 0; i2 < partsAndSegments.length; i2++) {
- const partAndSegment = partsAndSegments[i2];
- if (startingSegmentIndex !== partAndSegment.segmentIndex) {
- continue;
- }
- if (typeof startingPartIndex === "number" && typeof partAndSegment.partIndex === "number" && startingPartIndex !== partAndSegment.partIndex) {
- continue;
- }
- startIndex = i2;
- break;
- }
- if (time < 0) {
- if (startIndex > 0) {
- for (let i2 = startIndex - 1; i2 >= 0; i2--) {
- const partAndSegment = partsAndSegments[i2];
- time += partAndSegment.duration;
- if (exactManifestTimings) {
- if (time < 0) {
- continue;
- }
- } else if (time + TIME_FUDGE_FACTOR$1 <= 0) {
- continue;
- }
- return {
- partIndex: partAndSegment.partIndex,
- segmentIndex: partAndSegment.segmentIndex,
- startTime: startTime - sumDurations$1({
- defaultDuration: playlist.targetDuration,
- durationList: partsAndSegments,
- startIndex,
- endIndex: i2
- })
- };
- }
- }
- return {
- partIndex: partsAndSegments[0] && partsAndSegments[0].partIndex || null,
- segmentIndex: partsAndSegments[0] && partsAndSegments[0].segmentIndex || 0,
- startTime: currentTime
- };
- }
- if (startIndex < 0) {
- for (let i2 = startIndex; i2 < 0; i2++) {
- time -= playlist.targetDuration;
- if (time < 0) {
- return {
- partIndex: partsAndSegments[0] && partsAndSegments[0].partIndex || null,
- segmentIndex: partsAndSegments[0] && partsAndSegments[0].segmentIndex || 0,
- startTime: currentTime
- };
- }
- }
- startIndex = 0;
- }
- for (let i2 = startIndex; i2 < partsAndSegments.length; i2++) {
- const partAndSegment = partsAndSegments[i2];
- time -= partAndSegment.duration;
- if (exactManifestTimings) {
- if (time > 0) {
- continue;
- }
- } else if (time - TIME_FUDGE_FACTOR$1 >= 0) {
- continue;
- }
- return {
- partIndex: partAndSegment.partIndex,
- segmentIndex: partAndSegment.segmentIndex,
- startTime: startTime + sumDurations$1({
- defaultDuration: playlist.targetDuration,
- durationList: partsAndSegments,
- startIndex,
- endIndex: i2
- })
- };
- }
- return {
- segmentIndex: partsAndSegments[partsAndSegments.length - 1].segmentIndex,
- partIndex: partsAndSegments[partsAndSegments.length - 1].partIndex,
- startTime: currentTime
- };
- };
- const isExcluded = function(playlist) {
- return playlist.excludeUntil && playlist.excludeUntil > Date.now();
- };
- const isIncompatible$1 = function(playlist) {
- return playlist.excludeUntil && playlist.excludeUntil === Infinity;
- };
- const isEnabled$1 = function(playlist) {
- const excluded = isExcluded(playlist);
- return !playlist.disabled && !excluded;
- };
- const isDisabled$1 = function(playlist) {
- return playlist.disabled;
- };
- const isAes$1 = function(media) {
- for (let i2 = 0; i2 < media.segments.length; i2++) {
- if (media.segments[i2].key) {
- return true;
- }
- }
- return false;
- };
- const hasAttribute$1 = function(attr, playlist) {
- return playlist.attributes && playlist.attributes[attr];
- };
- const estimateSegmentRequestTime$1 = function(segmentDuration, bandwidth2, playlist, bytesReceived = 0) {
- if (!hasAttribute$1("BANDWIDTH", playlist)) {
- return NaN;
- }
- const size = segmentDuration * playlist.attributes.BANDWIDTH;
- return (size - bytesReceived * 8) / bandwidth2;
- };
- const isLowestEnabledRendition$1 = (main, media) => {
- if (main.playlists.length === 1) {
- return true;
- }
- const currentBandwidth = media.attributes.BANDWIDTH || Number.MAX_VALUE;
- return main.playlists.filter((playlist) => {
- if (!isEnabled$1(playlist)) {
- return false;
- }
- return (playlist.attributes.BANDWIDTH || 0) < currentBandwidth;
- }).length === 0;
- };
- const playlistMatch$1 = (a, b) => {
- if (!a && !b || !a && b || a && !b) {
- return false;
- }
- if (a === b) {
- return true;
- }
- if (a.id && b.id && a.id === b.id) {
- return true;
- }
- if (a.resolvedUri && b.resolvedUri && a.resolvedUri === b.resolvedUri) {
- return true;
- }
- if (a.uri && b.uri && a.uri === b.uri) {
- return true;
- }
- return false;
- };
- const someAudioVariant$1 = function(main, callback2) {
- const AUDIO5 = main && main.mediaGroups && main.mediaGroups.AUDIO || {};
- let found = false;
- for (const groupName in AUDIO5) {
- for (const label2 in AUDIO5[groupName]) {
- found = callback2(AUDIO5[groupName][label2]);
- if (found) {
- break;
- }
- }
- if (found) {
- break;
- }
- }
- return !!found;
- };
- const isAudioOnly$1 = (main) => {
- if (!main || !main.playlists || !main.playlists.length) {
- const found = someAudioVariant$1(main, (variant) => variant.playlists && variant.playlists.length || variant.uri);
- return found;
- }
- for (let i2 = 0; i2 < main.playlists.length; i2++) {
- const playlist = main.playlists[i2];
- const CODECS = playlist.attributes && playlist.attributes.CODECS;
- if (CODECS && CODECS.split(",").every((c) => isAudioCodec$1(c))) {
- continue;
- }
- const found = someAudioVariant$1(main, (variant) => playlistMatch$1(playlist, variant));
- if (found) {
- continue;
- }
- return false;
- }
- return true;
- };
- var Playlist$1 = {
- liveEdgeDelay: liveEdgeDelay$1,
- duration: duration$1,
- seekable: seekable$1,
- getMediaInfoForTime: getMediaInfoForTime$1,
- isEnabled: isEnabled$1,
- isDisabled: isDisabled$1,
- isExcluded,
- isIncompatible: isIncompatible$1,
- playlistEnd: playlistEnd$1,
- isAes: isAes$1,
- hasAttribute: hasAttribute$1,
- estimateSegmentRequestTime: estimateSegmentRequestTime$1,
- isLowestEnabledRendition: isLowestEnabledRendition$1,
- isAudioOnly: isAudioOnly$1,
- playlistMatch: playlistMatch$1,
- segmentDurationWithParts: segmentDurationWithParts$1
- };
- const {
- log: log$2
- } = videojs$2;
- const createPlaylistID$1 = (index2, uri) => {
- return `${index2}-${uri}`;
- };
- const groupID$1 = (type2, group, label2) => {
- return `placeholder-uri-${type2}-${group}-${label2}`;
- };
- const parseManifest$1 = ({
- onwarn,
- oninfo,
- manifestString,
- customTagParsers = [],
- customTagMappers = [],
- llhls
- }) => {
- const parser2 = new Parser$1();
- if (onwarn) {
- parser2.on("warn", onwarn);
- }
- if (oninfo) {
- parser2.on("info", oninfo);
- }
- customTagParsers.forEach((customParser) => parser2.addParser(customParser));
- customTagMappers.forEach((mapper) => parser2.addTagMapper(mapper));
- parser2.push(manifestString);
- parser2.end();
- const manifest = parser2.manifest;
- if (!llhls) {
- ["preloadSegment", "skip", "serverControl", "renditionReports", "partInf", "partTargetDuration"].forEach(function(k) {
- if (manifest.hasOwnProperty(k)) {
- delete manifest[k];
- }
- });
- if (manifest.segments) {
- manifest.segments.forEach(function(segment) {
- ["parts", "preloadHints"].forEach(function(k) {
- if (segment.hasOwnProperty(k)) {
- delete segment[k];
- }
- });
- });
- }
- }
- if (!manifest.targetDuration) {
- let targetDuration = 10;
- if (manifest.segments && manifest.segments.length) {
- targetDuration = manifest.segments.reduce((acc, s) => Math.max(acc, s.duration), 0);
- }
- if (onwarn) {
- onwarn(`manifest has no targetDuration defaulting to ${targetDuration}`);
- }
- manifest.targetDuration = targetDuration;
- }
- const parts = getLastParts$1(manifest);
- if (parts.length && !manifest.partTargetDuration) {
- const partTargetDuration = parts.reduce((acc, p) => Math.max(acc, p.duration), 0);
- if (onwarn) {
- onwarn(`manifest has no partTargetDuration defaulting to ${partTargetDuration}`);
- log$2.error("LL-HLS manifest has parts but lacks required #EXT-X-PART-INF:PART-TARGET value. See https://datatracker.ietf.org/doc/html/draft-pantos-hls-rfc8216bis-09#section-4.4.3.7. Playback is not guaranteed.");
- }
- manifest.partTargetDuration = partTargetDuration;
- }
- return manifest;
- };
- const forEachMediaGroup$2 = (main, callback2) => {
- if (!main.mediaGroups) {
- return;
- }
- ["AUDIO", "SUBTITLES"].forEach((mediaType) => {
- if (!main.mediaGroups[mediaType]) {
- return;
- }
- for (const groupKey in main.mediaGroups[mediaType]) {
- for (const labelKey in main.mediaGroups[mediaType][groupKey]) {
- const mediaProperties = main.mediaGroups[mediaType][groupKey][labelKey];
- callback2(mediaProperties, mediaType, groupKey, labelKey);
- }
- }
- });
- };
- const setupMediaPlaylist$1 = ({
- playlist,
- uri,
- id
- }) => {
- playlist.id = id;
- playlist.playlistErrors_ = 0;
- if (uri) {
- playlist.uri = uri;
- }
- playlist.attributes = playlist.attributes || {};
- };
- const setupMediaPlaylists$1 = (main) => {
- let i2 = main.playlists.length;
- while (i2--) {
- const playlist = main.playlists[i2];
- setupMediaPlaylist$1({
- playlist,
- id: createPlaylistID$1(i2, playlist.uri)
- });
- playlist.resolvedUri = resolveUrl$2(main.uri, playlist.uri);
- main.playlists[playlist.id] = playlist;
- main.playlists[playlist.uri] = playlist;
- if (!playlist.attributes.BANDWIDTH) {
- log$2.warn("Invalid playlist STREAM-INF detected. Missing BANDWIDTH attribute.");
- }
- }
- };
- const resolveMediaGroupUris$1 = (main) => {
- forEachMediaGroup$2(main, (properties) => {
- if (properties.uri) {
- properties.resolvedUri = resolveUrl$2(main.uri, properties.uri);
- }
- });
- };
- const mainForMedia = (media, uri) => {
- const id = createPlaylistID$1(0, uri);
- const main = {
- mediaGroups: {
- "AUDIO": {},
- "VIDEO": {},
- "CLOSED-CAPTIONS": {},
- "SUBTITLES": {}
- },
- uri: window_1.location.href,
- resolvedUri: window_1.location.href,
- playlists: [{
- uri,
- id,
- resolvedUri: uri,
- attributes: {}
- }]
- };
- main.playlists[id] = main.playlists[0];
- main.playlists[uri] = main.playlists[0];
- return main;
- };
- const addPropertiesToMain = (main, uri, createGroupID = groupID$1) => {
- main.uri = uri;
- for (let i2 = 0; i2 < main.playlists.length; i2++) {
- if (!main.playlists[i2].uri) {
- const phonyUri = `placeholder-uri-${i2}`;
- main.playlists[i2].uri = phonyUri;
- }
- }
- const audioOnlyMain = isAudioOnly$1(main);
- forEachMediaGroup$2(main, (properties, mediaType, groupKey, labelKey) => {
- if (!properties.playlists || !properties.playlists.length) {
- if (audioOnlyMain && mediaType === "AUDIO" && !properties.uri) {
- for (let i2 = 0; i2 < main.playlists.length; i2++) {
- const p = main.playlists[i2];
- if (p.attributes && p.attributes.AUDIO && p.attributes.AUDIO === groupKey) {
- return;
- }
- }
- }
- properties.playlists = [_extends$2({}, properties)];
- }
- properties.playlists.forEach(function(p, i2) {
- const groupId = createGroupID(mediaType, groupKey, labelKey, p);
- const id = createPlaylistID$1(i2, groupId);
- if (p.uri) {
- p.resolvedUri = p.resolvedUri || resolveUrl$2(main.uri, p.uri);
- } else {
- p.uri = i2 === 0 ? groupId : id;
- p.resolvedUri = p.uri;
- }
- p.id = p.id || id;
- p.attributes = p.attributes || {};
- main.playlists[p.id] = p;
- main.playlists[p.uri] = p;
- });
- });
- setupMediaPlaylists$1(main);
- resolveMediaGroupUris$1(main);
- };
- const {
- EventTarget: EventTarget$1$1
- } = videojs$2;
- const addLLHLSQueryDirectives$1 = (uri, media) => {
- if (media.endList || !media.serverControl) {
- return uri;
- }
- const parameters = {};
- if (media.serverControl.canBlockReload) {
- const {
- preloadSegment
- } = media;
- let nextMSN = media.mediaSequence + media.segments.length;
- if (preloadSegment) {
- const parts = preloadSegment.parts || [];
- const nextPart = getKnownPartCount$1(media) - 1;
- if (nextPart > -1 && nextPart !== parts.length - 1) {
- parameters._HLS_part = nextPart;
- }
- if (nextPart > -1 || parts.length) {
- nextMSN--;
- }
- }
- parameters._HLS_msn = nextMSN;
- }
- if (media.serverControl && media.serverControl.canSkipUntil) {
- parameters._HLS_skip = media.serverControl.canSkipDateranges ? "v2" : "YES";
- }
- if (Object.keys(parameters).length) {
- const parsedUri = new window_1.URL(uri);
- ["_HLS_skip", "_HLS_msn", "_HLS_part"].forEach(function(name) {
- if (!parameters.hasOwnProperty(name)) {
- return;
- }
- parsedUri.searchParams.set(name, parameters[name]);
- });
- uri = parsedUri.toString();
- }
- return uri;
- };
- const updateSegment$1 = (a, b) => {
- if (!a) {
- return b;
- }
- const result = merge$2(a, b);
- if (a.preloadHints && !b.preloadHints) {
- delete result.preloadHints;
- }
- if (a.parts && !b.parts) {
- delete result.parts;
- } else if (a.parts && b.parts) {
- for (let i2 = 0; i2 < b.parts.length; i2++) {
- if (a.parts && a.parts[i2]) {
- result.parts[i2] = merge$2(a.parts[i2], b.parts[i2]);
- }
- }
- }
- if (!a.skipped && b.skipped) {
- result.skipped = false;
- }
- if (a.preload && !b.preload) {
- result.preload = false;
- }
- return result;
- };
- const updateSegments$1 = (original, update, offset) => {
- const oldSegments = original.slice();
- const newSegments = update.slice();
- offset = offset || 0;
- const result = [];
- let currentMap;
- for (let newIndex = 0; newIndex < newSegments.length; newIndex++) {
- const oldSegment = oldSegments[newIndex + offset];
- const newSegment = newSegments[newIndex];
- if (oldSegment) {
- currentMap = oldSegment.map || currentMap;
- result.push(updateSegment$1(oldSegment, newSegment));
- } else {
- if (currentMap && !newSegment.map) {
- newSegment.map = currentMap;
- }
- result.push(newSegment);
- }
- }
- return result;
- };
- const resolveSegmentUris$1 = (segment, baseUri) => {
- if (!segment.resolvedUri && segment.uri) {
- segment.resolvedUri = resolveUrl$2(baseUri, segment.uri);
- }
- if (segment.key && !segment.key.resolvedUri) {
- segment.key.resolvedUri = resolveUrl$2(baseUri, segment.key.uri);
- }
- if (segment.map && !segment.map.resolvedUri) {
- segment.map.resolvedUri = resolveUrl$2(baseUri, segment.map.uri);
- }
- if (segment.map && segment.map.key && !segment.map.key.resolvedUri) {
- segment.map.key.resolvedUri = resolveUrl$2(baseUri, segment.map.key.uri);
- }
- if (segment.parts && segment.parts.length) {
- segment.parts.forEach((p) => {
- if (p.resolvedUri) {
- return;
- }
- p.resolvedUri = resolveUrl$2(baseUri, p.uri);
- });
- }
- if (segment.preloadHints && segment.preloadHints.length) {
- segment.preloadHints.forEach((p) => {
- if (p.resolvedUri) {
- return;
- }
- p.resolvedUri = resolveUrl$2(baseUri, p.uri);
- });
- }
- };
- const getAllSegments$1 = function(media) {
- const segments = media.segments || [];
- const preloadSegment = media.preloadSegment;
- if (preloadSegment && preloadSegment.parts && preloadSegment.parts.length) {
- if (preloadSegment.preloadHints) {
- for (let i2 = 0; i2 < preloadSegment.preloadHints.length; i2++) {
- if (preloadSegment.preloadHints[i2].type === "MAP") {
- return segments;
- }
- }
- }
- preloadSegment.duration = media.targetDuration;
- preloadSegment.preload = true;
- segments.push(preloadSegment);
- }
- return segments;
- };
- const isPlaylistUnchanged$1 = (a, b) => a === b || a.segments && b.segments && a.segments.length === b.segments.length && a.endList === b.endList && a.mediaSequence === b.mediaSequence && a.preloadSegment === b.preloadSegment;
- const updateMain$1 = (main, newMedia, unchangedCheck = isPlaylistUnchanged$1) => {
- const result = merge$2(main, {});
- const oldMedia = result.playlists[newMedia.id];
- if (!oldMedia) {
- return null;
- }
- if (unchangedCheck(oldMedia, newMedia)) {
- return null;
- }
- newMedia.segments = getAllSegments$1(newMedia);
- const mergedPlaylist = merge$2(oldMedia, newMedia);
- if (mergedPlaylist.preloadSegment && !newMedia.preloadSegment) {
- delete mergedPlaylist.preloadSegment;
- }
- if (oldMedia.segments) {
- if (newMedia.skip) {
- newMedia.segments = newMedia.segments || [];
- for (let i2 = 0; i2 < newMedia.skip.skippedSegments; i2++) {
- newMedia.segments.unshift({
- skipped: true
- });
- }
- }
- mergedPlaylist.segments = updateSegments$1(oldMedia.segments, newMedia.segments, newMedia.mediaSequence - oldMedia.mediaSequence);
- }
- mergedPlaylist.segments.forEach((segment) => {
- resolveSegmentUris$1(segment, mergedPlaylist.resolvedUri);
- });
- for (let i2 = 0; i2 < result.playlists.length; i2++) {
- if (result.playlists[i2].id === newMedia.id) {
- result.playlists[i2] = mergedPlaylist;
- }
- }
- result.playlists[newMedia.id] = mergedPlaylist;
- result.playlists[newMedia.uri] = mergedPlaylist;
- forEachMediaGroup$2(main, (properties, mediaType, groupKey, labelKey) => {
- if (!properties.playlists) {
- return;
- }
- for (let i2 = 0; i2 < properties.playlists.length; i2++) {
- if (newMedia.id === properties.playlists[i2].id) {
- properties.playlists[i2] = mergedPlaylist;
- }
- }
- });
- return result;
- };
- const refreshDelay$1 = (media, update) => {
- const segments = media.segments || [];
- const lastSegment = segments[segments.length - 1];
- const lastPart = lastSegment && lastSegment.parts && lastSegment.parts[lastSegment.parts.length - 1];
- const lastDuration = lastPart && lastPart.duration || lastSegment && lastSegment.duration;
- if (update && lastDuration) {
- return lastDuration * 1e3;
- }
- return (media.partTargetDuration || media.targetDuration || 10) * 500;
- };
- class PlaylistLoader$1 extends EventTarget$1$1 {
- constructor(src, vhs, options2 = {}) {
- super();
- if (!src) {
- throw new Error("A non-empty playlist URL or object is required");
- }
- this.logger_ = logger$1("PlaylistLoader");
- const {
- withCredentials = false
- } = options2;
- this.src = src;
- this.vhs_ = vhs;
- this.withCredentials = withCredentials;
- const vhsOptions = vhs.options_;
- this.customTagParsers = vhsOptions && vhsOptions.customTagParsers || [];
- this.customTagMappers = vhsOptions && vhsOptions.customTagMappers || [];
- this.llhls = vhsOptions && vhsOptions.llhls;
- this.state = "HAVE_NOTHING";
- this.handleMediaupdatetimeout_ = this.handleMediaupdatetimeout_.bind(this);
- this.on("mediaupdatetimeout", this.handleMediaupdatetimeout_);
- }
- handleMediaupdatetimeout_() {
- if (this.state !== "HAVE_METADATA") {
- return;
- }
- const media = this.media();
- let uri = resolveUrl$2(this.main.uri, media.uri);
- if (this.llhls) {
- uri = addLLHLSQueryDirectives$1(uri, media);
- }
- this.state = "HAVE_CURRENT_METADATA";
- this.request = this.vhs_.xhr({
- uri,
- withCredentials: this.withCredentials
- }, (error, req) => {
- if (!this.request) {
- return;
- }
- if (error) {
- return this.playlistRequestError(this.request, this.media(), "HAVE_METADATA");
- }
- this.haveMetadata({
- playlistString: this.request.responseText,
- url: this.media().uri,
- id: this.media().id
- });
- });
- }
- playlistRequestError(xhr, playlist, startingState) {
- const {
- uri,
- id
- } = playlist;
- this.request = null;
- if (startingState) {
- this.state = startingState;
- }
- this.error = {
- playlist: this.main.playlists[id],
- status: xhr.status,
- message: `HLS playlist request error at URL: ${uri}.`,
- responseText: xhr.responseText,
- code: xhr.status >= 500 ? 4 : 2
- };
- this.trigger("error");
- }
- parseManifest_({
- url,
- manifestString
- }) {
- return parseManifest$1({
- onwarn: ({
- message
- }) => this.logger_(`m3u8-parser warn for ${url}: ${message}`),
- oninfo: ({
- message
- }) => this.logger_(`m3u8-parser info for ${url}: ${message}`),
- manifestString,
- customTagParsers: this.customTagParsers,
- customTagMappers: this.customTagMappers,
- llhls: this.llhls
- });
- }
- haveMetadata({
- playlistString,
- playlistObject,
- url,
- id
- }) {
- this.request = null;
- this.state = "HAVE_METADATA";
- const playlist = playlistObject || this.parseManifest_({
- url,
- manifestString: playlistString
- });
- playlist.lastRequest = Date.now();
- setupMediaPlaylist$1({
- playlist,
- uri: url,
- id
- });
- const update = updateMain$1(this.main, playlist);
- this.targetDuration = playlist.partTargetDuration || playlist.targetDuration;
- this.pendingMedia_ = null;
- if (update) {
- this.main = update;
- this.media_ = this.main.playlists[id];
- } else {
- this.trigger("playlistunchanged");
- }
- this.updateMediaUpdateTimeout_(refreshDelay$1(this.media(), !!update));
- this.trigger("loadedplaylist");
- }
- dispose() {
- this.trigger("dispose");
- this.stopRequest();
- window_1.clearTimeout(this.mediaUpdateTimeout);
- window_1.clearTimeout(this.finalRenditionTimeout);
- this.off();
- }
- stopRequest() {
- if (this.request) {
- const oldRequest = this.request;
- this.request = null;
- oldRequest.onreadystatechange = null;
- oldRequest.abort();
- }
- }
- media(playlist, shouldDelay) {
- if (!playlist) {
- return this.media_;
- }
- if (this.state === "HAVE_NOTHING") {
- throw new Error("Cannot switch media playlist from " + this.state);
- }
- if (typeof playlist === "string") {
- if (!this.main.playlists[playlist]) {
- throw new Error("Unknown playlist URI: " + playlist);
- }
- playlist = this.main.playlists[playlist];
- }
- window_1.clearTimeout(this.finalRenditionTimeout);
- if (shouldDelay) {
- const delay = (playlist.partTargetDuration || playlist.targetDuration) / 2 * 1e3 || 5 * 1e3;
- this.finalRenditionTimeout = window_1.setTimeout(this.media.bind(this, playlist, false), delay);
- return;
- }
- const startingState = this.state;
- const mediaChange = !this.media_ || playlist.id !== this.media_.id;
- const mainPlaylistRef = this.main.playlists[playlist.id];
- if (mainPlaylistRef && mainPlaylistRef.endList || playlist.endList && playlist.segments.length) {
- if (this.request) {
- this.request.onreadystatechange = null;
- this.request.abort();
- this.request = null;
- }
- this.state = "HAVE_METADATA";
- this.media_ = playlist;
- if (mediaChange) {
- this.trigger("mediachanging");
- if (startingState === "HAVE_MAIN_MANIFEST") {
- this.trigger("loadedmetadata");
- } else {
- this.trigger("mediachange");
- }
- }
- return;
- }
- this.updateMediaUpdateTimeout_(refreshDelay$1(playlist, true));
- if (!mediaChange) {
- return;
- }
- this.state = "SWITCHING_MEDIA";
- if (this.request) {
- if (playlist.resolvedUri === this.request.url) {
- return;
- }
- this.request.onreadystatechange = null;
- this.request.abort();
- this.request = null;
- }
- if (this.media_) {
- this.trigger("mediachanging");
- }
- this.pendingMedia_ = playlist;
- this.request = this.vhs_.xhr({
- uri: playlist.resolvedUri,
- withCredentials: this.withCredentials
- }, (error, req) => {
- if (!this.request) {
- return;
- }
- playlist.lastRequest = Date.now();
- playlist.resolvedUri = resolveManifestRedirect$1(playlist.resolvedUri, req);
- if (error) {
- return this.playlistRequestError(this.request, playlist, startingState);
- }
- this.haveMetadata({
- playlistString: req.responseText,
- url: playlist.uri,
- id: playlist.id
- });
- if (startingState === "HAVE_MAIN_MANIFEST") {
- this.trigger("loadedmetadata");
- } else {
- this.trigger("mediachange");
- }
- });
- }
- pause() {
- if (this.mediaUpdateTimeout) {
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- }
- this.stopRequest();
- if (this.state === "HAVE_NOTHING") {
- this.started = false;
- }
- if (this.state === "SWITCHING_MEDIA") {
- if (this.media_) {
- this.state = "HAVE_METADATA";
- } else {
- this.state = "HAVE_MAIN_MANIFEST";
- }
- } else if (this.state === "HAVE_CURRENT_METADATA") {
- this.state = "HAVE_METADATA";
- }
- }
- load(shouldDelay) {
- if (this.mediaUpdateTimeout) {
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- }
- const media = this.media();
- if (shouldDelay) {
- const delay = media ? (media.partTargetDuration || media.targetDuration) / 2 * 1e3 : 5 * 1e3;
- this.mediaUpdateTimeout = window_1.setTimeout(() => {
- this.mediaUpdateTimeout = null;
- this.load();
- }, delay);
- return;
- }
- if (!this.started) {
- this.start();
- return;
- }
- if (media && !media.endList) {
- this.trigger("mediaupdatetimeout");
- } else {
- this.trigger("loadedplaylist");
- }
- }
- updateMediaUpdateTimeout_(delay) {
- if (this.mediaUpdateTimeout) {
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- }
- if (!this.media() || this.media().endList) {
- return;
- }
- this.mediaUpdateTimeout = window_1.setTimeout(() => {
- this.mediaUpdateTimeout = null;
- this.trigger("mediaupdatetimeout");
- this.updateMediaUpdateTimeout_(delay);
- }, delay);
- }
- start() {
- this.started = true;
- if (typeof this.src === "object") {
- if (!this.src.uri) {
- this.src.uri = window_1.location.href;
- }
- this.src.resolvedUri = this.src.uri;
- setTimeout(() => {
- this.setupInitialPlaylist(this.src);
- }, 0);
- return;
- }
- this.request = this.vhs_.xhr({
- uri: this.src,
- withCredentials: this.withCredentials
- }, (error, req) => {
- if (!this.request) {
- return;
- }
- this.request = null;
- if (error) {
- this.error = {
- status: req.status,
- message: `HLS playlist request error at URL: ${this.src}.`,
- responseText: req.responseText,
- code: 2
- };
- if (this.state === "HAVE_NOTHING") {
- this.started = false;
- }
- return this.trigger("error");
- }
- this.src = resolveManifestRedirect$1(this.src, req);
- const manifest = this.parseManifest_({
- manifestString: req.responseText,
- url: this.src
- });
- this.setupInitialPlaylist(manifest);
- });
- }
- srcUri() {
- return typeof this.src === "string" ? this.src : this.src.uri;
- }
- setupInitialPlaylist(manifest) {
- this.state = "HAVE_MAIN_MANIFEST";
- if (manifest.playlists) {
- this.main = manifest;
- addPropertiesToMain(this.main, this.srcUri());
- manifest.playlists.forEach((playlist) => {
- playlist.segments = getAllSegments$1(playlist);
- playlist.segments.forEach((segment) => {
- resolveSegmentUris$1(segment, playlist.resolvedUri);
- });
- });
- this.trigger("loadedplaylist");
- if (!this.request) {
- this.media(this.main.playlists[0]);
- }
- return;
- }
- const uri = this.srcUri() || window_1.location.href;
- this.main = mainForMedia(manifest, uri);
- this.haveMetadata({
- playlistObject: manifest,
- url: uri,
- id: this.main.playlists[0].id
- });
- this.trigger("loadedmetadata");
- }
- }
- const {
- xhr: videojsXHR$1
- } = videojs$2;
- const callbackWrapper$1 = function(request, error, response, callback2) {
- const reqResponse = request.responseType === "arraybuffer" ? request.response : request.responseText;
- if (!error && reqResponse) {
- request.responseTime = Date.now();
- request.roundTripTime = request.responseTime - request.requestTime;
- request.bytesReceived = reqResponse.byteLength || reqResponse.length;
- if (!request.bandwidth) {
- request.bandwidth = Math.floor(request.bytesReceived / request.roundTripTime * 8 * 1e3);
- }
- }
- if (response.headers) {
- request.responseHeaders = response.headers;
- }
- if (error && error.code === "ETIMEDOUT") {
- request.timedout = true;
- }
- if (!error && !request.aborted && response.statusCode !== 200 && response.statusCode !== 206 && response.statusCode !== 0) {
- error = new Error("XHR Failed with a response of: " + (request && (reqResponse || request.responseText)));
- }
- callback2(error, request);
- };
- const xhrFactory$1 = function() {
- const xhr = function XhrFunction(options2, callback2) {
- options2 = merge$2({
- timeout: 45e3
- }, options2);
- const beforeRequest = XhrFunction.beforeRequest || videojs$2.Vhs.xhr.beforeRequest;
- if (beforeRequest && typeof beforeRequest === "function") {
- const newOptions = beforeRequest(options2);
- if (newOptions) {
- options2 = newOptions;
- }
- }
- const xhrMethod = videojs$2.Vhs.xhr.original === true ? videojsXHR$1 : videojs$2.Vhs.xhr;
- const request = xhrMethod(options2, function(error, response) {
- return callbackWrapper$1(request, error, response, callback2);
- });
- const originalAbort = request.abort;
- request.abort = function() {
- request.aborted = true;
- return originalAbort.apply(request, arguments);
- };
- request.uri = options2.uri;
- request.requestTime = Date.now();
- return request;
- };
- xhr.original = true;
- return xhr;
- };
- const byterangeStr$1 = function(byterange) {
- let byterangeEnd;
- const byterangeStart = byterange.offset;
- if (typeof byterange.offset === "bigint" || typeof byterange.length === "bigint") {
- byterangeEnd = window_1.BigInt(byterange.offset) + window_1.BigInt(byterange.length) - window_1.BigInt(1);
- } else {
- byterangeEnd = byterange.offset + byterange.length - 1;
- }
- return "bytes=" + byterangeStart + "-" + byterangeEnd;
- };
- const segmentXhrHeaders$1 = function(segment) {
- const headers = {};
- if (segment.byterange) {
- headers.Range = byterangeStr$1(segment.byterange);
- }
- return headers;
- };
- const textRange$1 = function(range3, i2) {
- return range3.start(i2) + "-" + range3.end(i2);
- };
- const formatHexString$1 = function(e, i2) {
- const value = e.toString(16);
- return "00".substring(0, 2 - value.length) + value + (i2 % 2 ? " " : "");
- };
- const formatAsciiString$1 = function(e) {
- if (e >= 32 && e < 126) {
- return String.fromCharCode(e);
- }
- return ".";
- };
- const createTransferableMessage$1 = function(message) {
- const transferable = {};
- Object.keys(message).forEach((key) => {
- const value = message[key];
- if (isArrayBufferView$1(value)) {
- transferable[key] = {
- bytes: value.buffer,
- byteOffset: value.byteOffset,
- byteLength: value.byteLength
- };
- } else {
- transferable[key] = value;
- }
- });
- return transferable;
- };
- const initSegmentId$1 = function(initSegment) {
- const byterange = initSegment.byterange || {
- length: Infinity,
- offset: 0
- };
- return [byterange.length, byterange.offset, initSegment.resolvedUri].join(",");
- };
- const segmentKeyId$1 = function(key) {
- return key.resolvedUri;
- };
- const hexDump$1 = (data) => {
- const bytes = Array.prototype.slice.call(data);
- const step = 16;
- let result = "";
- let hex;
- let ascii;
- for (let j = 0; j < bytes.length / step; j++) {
- hex = bytes.slice(j * step, j * step + step).map(formatHexString$1).join("");
- ascii = bytes.slice(j * step, j * step + step).map(formatAsciiString$1).join("");
- result += hex + " " + ascii + "\n";
- }
- return result;
- };
- const tagDump$1 = ({
- bytes
- }) => hexDump$1(bytes);
- const textRanges$1 = (ranges) => {
- let result = "";
- let i2;
- for (i2 = 0; i2 < ranges.length; i2++) {
- result += textRange$1(ranges, i2) + " ";
- }
- return result;
- };
- var utils$1 = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- createTransferableMessage: createTransferableMessage$1,
- initSegmentId: initSegmentId$1,
- segmentKeyId: segmentKeyId$1,
- hexDump: hexDump$1,
- tagDump: tagDump$1,
- textRanges: textRanges$1
- });
- const SEGMENT_END_FUDGE_PERCENT$1 = 0.25;
- const playerTimeToProgramTime$1 = (playerTime, segment) => {
- if (!segment.dateTimeObject) {
- return null;
- }
- const transmuxerPrependedSeconds = segment.videoTimingInfo.transmuxerPrependedSeconds;
- const transmuxedStart = segment.videoTimingInfo.transmuxedPresentationStart;
- const startOfSegment = transmuxedStart + transmuxerPrependedSeconds;
- const offsetFromSegmentStart = playerTime - startOfSegment;
- return new Date(segment.dateTimeObject.getTime() + offsetFromSegmentStart * 1e3);
- };
- const originalSegmentVideoDuration$1 = (videoTimingInfo) => {
- return videoTimingInfo.transmuxedPresentationEnd - videoTimingInfo.transmuxedPresentationStart - videoTimingInfo.transmuxerPrependedSeconds;
- };
- const findSegmentForProgramTime$1 = (programTime, playlist) => {
- let dateTimeObject;
- try {
- dateTimeObject = new Date(programTime);
- } catch (e) {
- return null;
- }
- if (!playlist || !playlist.segments || playlist.segments.length === 0) {
- return null;
- }
- let segment = playlist.segments[0];
- if (dateTimeObject < segment.dateTimeObject) {
- return null;
- }
- for (let i2 = 0; i2 < playlist.segments.length - 1; i2++) {
- segment = playlist.segments[i2];
- const nextSegmentStart = playlist.segments[i2 + 1].dateTimeObject;
- if (dateTimeObject < nextSegmentStart) {
- break;
- }
- }
- const lastSegment = playlist.segments[playlist.segments.length - 1];
- const lastSegmentStart = lastSegment.dateTimeObject;
- const lastSegmentDuration = lastSegment.videoTimingInfo ? originalSegmentVideoDuration$1(lastSegment.videoTimingInfo) : lastSegment.duration + lastSegment.duration * SEGMENT_END_FUDGE_PERCENT$1;
- const lastSegmentEnd = new Date(lastSegmentStart.getTime() + lastSegmentDuration * 1e3);
- if (dateTimeObject > lastSegmentEnd) {
- return null;
- }
- if (dateTimeObject > lastSegmentStart) {
- segment = lastSegment;
- }
- return {
- segment,
- estimatedStart: segment.videoTimingInfo ? segment.videoTimingInfo.transmuxedPresentationStart : Playlist$1.duration(playlist, playlist.mediaSequence + playlist.segments.indexOf(segment)),
- type: segment.videoTimingInfo ? "accurate" : "estimate"
- };
- };
- const findSegmentForPlayerTime$1 = (time, playlist) => {
- if (!playlist || !playlist.segments || playlist.segments.length === 0) {
- return null;
- }
- let segmentEnd = 0;
- let segment;
- for (let i2 = 0; i2 < playlist.segments.length; i2++) {
- segment = playlist.segments[i2];
- segmentEnd = segment.videoTimingInfo ? segment.videoTimingInfo.transmuxedPresentationEnd : segmentEnd + segment.duration;
- if (time <= segmentEnd) {
- break;
- }
- }
- const lastSegment = playlist.segments[playlist.segments.length - 1];
- if (lastSegment.videoTimingInfo && lastSegment.videoTimingInfo.transmuxedPresentationEnd < time) {
- return null;
- }
- if (time > segmentEnd) {
- if (time > segmentEnd + lastSegment.duration * SEGMENT_END_FUDGE_PERCENT$1) {
- return null;
- }
- segment = lastSegment;
- }
- return {
- segment,
- estimatedStart: segment.videoTimingInfo ? segment.videoTimingInfo.transmuxedPresentationStart : segmentEnd - segment.duration,
- type: segment.videoTimingInfo ? "accurate" : "estimate"
- };
- };
- const getOffsetFromTimestamp$1 = (comparisonTimeStamp, programTime) => {
- let segmentDateTime;
- let programDateTime;
- try {
- segmentDateTime = new Date(comparisonTimeStamp);
- programDateTime = new Date(programTime);
- } catch (e) {
- }
- const segmentTimeEpoch = segmentDateTime.getTime();
- const programTimeEpoch = programDateTime.getTime();
- return (programTimeEpoch - segmentTimeEpoch) / 1e3;
- };
- const verifyProgramDateTimeTags$1 = (playlist) => {
- if (!playlist.segments || playlist.segments.length === 0) {
- return false;
- }
- for (let i2 = 0; i2 < playlist.segments.length; i2++) {
- const segment = playlist.segments[i2];
- if (!segment.dateTimeObject) {
- return false;
- }
- }
- return true;
- };
- const getProgramTime$1 = ({
- playlist,
- time = void 0,
- callback: callback2
- }) => {
- if (!callback2) {
- throw new Error("getProgramTime: callback must be provided");
- }
- if (!playlist || time === void 0) {
- return callback2({
- message: "getProgramTime: playlist and time must be provided"
- });
- }
- const matchedSegment = findSegmentForPlayerTime$1(time, playlist);
- if (!matchedSegment) {
- return callback2({
- message: "valid programTime was not found"
- });
- }
- if (matchedSegment.type === "estimate") {
- return callback2({
- message: "Accurate programTime could not be determined. Please seek to e.seekTime and try again",
- seekTime: matchedSegment.estimatedStart
- });
- }
- const programTimeObject = {
- mediaSeconds: time
- };
- const programTime = playerTimeToProgramTime$1(time, matchedSegment.segment);
- if (programTime) {
- programTimeObject.programDateTime = programTime.toISOString();
- }
- return callback2(null, programTimeObject);
- };
- const seekToProgramTime$1 = ({
- programTime,
- playlist,
- retryCount = 2,
- seekTo,
- pauseAfterSeek = true,
- tech,
- callback: callback2
- }) => {
- if (!callback2) {
- throw new Error("seekToProgramTime: callback must be provided");
- }
- if (typeof programTime === "undefined" || !playlist || !seekTo) {
- return callback2({
- message: "seekToProgramTime: programTime, seekTo and playlist must be provided"
- });
- }
- if (!playlist.endList && !tech.hasStarted_) {
- return callback2({
- message: "player must be playing a live stream to start buffering"
- });
- }
- if (!verifyProgramDateTimeTags$1(playlist)) {
- return callback2({
- message: "programDateTime tags must be provided in the manifest " + playlist.resolvedUri
- });
- }
- const matchedSegment = findSegmentForProgramTime$1(programTime, playlist);
- if (!matchedSegment) {
- return callback2({
- message: `${programTime} was not found in the stream`
- });
- }
- const segment = matchedSegment.segment;
- const mediaOffset = getOffsetFromTimestamp$1(segment.dateTimeObject, programTime);
- if (matchedSegment.type === "estimate") {
- if (retryCount === 0) {
- return callback2({
- message: `${programTime} is not buffered yet. Try again`
- });
- }
- seekTo(matchedSegment.estimatedStart + mediaOffset);
- tech.one("seeked", () => {
- seekToProgramTime$1({
- programTime,
- playlist,
- retryCount: retryCount - 1,
- seekTo,
- pauseAfterSeek,
- tech,
- callback: callback2
- });
- });
- return;
- }
- const seekToTime = segment.start + mediaOffset;
- const seekedCallback = () => {
- return callback2(null, tech.currentTime());
- };
- tech.one("seeked", seekedCallback);
- if (pauseAfterSeek) {
- tech.pause();
- }
- seekTo(seekToTime);
- };
- const callbackOnCompleted$1 = (request, cb) => {
- if (request.readyState === 4) {
- return cb();
- }
- return;
- };
- const containerRequest$1 = (uri, xhr, cb) => {
- let bytes = [];
- let id3Offset;
- let finished = false;
- const endRequestAndCallback = function(err, req, type2, _bytes) {
- req.abort();
- finished = true;
- return cb(err, req, type2, _bytes);
- };
- const progressListener = function(error, request2) {
- if (finished) {
- return;
- }
- if (error) {
- return endRequestAndCallback(error, request2, "", bytes);
- }
- const newPart = request2.responseText.substring(bytes && bytes.byteLength || 0, request2.responseText.length);
- bytes = concatTypedArrays$1(bytes, stringToBytes$1(newPart, true));
- id3Offset = id3Offset || getId3Offset$1(bytes);
- if (bytes.length < 10 || id3Offset && bytes.length < id3Offset + 2) {
- return callbackOnCompleted$1(request2, () => endRequestAndCallback(error, request2, "", bytes));
- }
- const type2 = detectContainerForBytes$1(bytes);
- if (type2 === "ts" && bytes.length < 188) {
- return callbackOnCompleted$1(request2, () => endRequestAndCallback(error, request2, "", bytes));
- }
- if (!type2 && bytes.length < 376) {
- return callbackOnCompleted$1(request2, () => endRequestAndCallback(error, request2, "", bytes));
- }
- return endRequestAndCallback(null, request2, type2, bytes);
- };
- const options2 = {
- uri,
- beforeSend(request2) {
- request2.overrideMimeType("text/plain; charset=x-user-defined");
- request2.addEventListener("progress", function({
- total,
- loaded
- }) {
- return callbackWrapper$1(request2, null, {
- statusCode: request2.status
- }, progressListener);
- });
- }
- };
- const request = xhr(options2, function(error, response) {
- return callbackWrapper$1(request, error, response, progressListener);
- });
- return request;
- };
- const {
- EventTarget: EventTarget$3
- } = videojs$2;
- const dashPlaylistUnchanged$1 = function(a, b) {
- if (!isPlaylistUnchanged$1(a, b)) {
- return false;
- }
- if (a.sidx && b.sidx && (a.sidx.offset !== b.sidx.offset || a.sidx.length !== b.sidx.length)) {
- return false;
- } else if (!a.sidx && b.sidx || a.sidx && !b.sidx) {
- return false;
- }
- if (a.segments && !b.segments || !a.segments && b.segments) {
- return false;
- }
- if (!a.segments && !b.segments) {
- return true;
- }
- for (let i2 = 0; i2 < a.segments.length; i2++) {
- const aSegment = a.segments[i2];
- const bSegment = b.segments[i2];
- if (aSegment.uri !== bSegment.uri) {
- return false;
- }
- if (!aSegment.byterange && !bSegment.byterange) {
- continue;
- }
- const aByterange = aSegment.byterange;
- const bByterange = bSegment.byterange;
- if (aByterange && !bByterange || !aByterange && bByterange) {
- return false;
- }
- if (aByterange.offset !== bByterange.offset || aByterange.length !== bByterange.length) {
- return false;
- }
- }
- return true;
- };
- const dashGroupId$1 = (type2, group, label2, playlist) => {
- const playlistId = playlist.attributes.NAME || label2;
- return `placeholder-uri-${type2}-${group}-${playlistId}`;
- };
- const parseMainXml = ({
- mainXml,
- srcUrl,
- clientOffset,
- sidxMapping,
- previousManifest
- }) => {
- const manifest = parse$1(mainXml, {
- manifestUri: srcUrl,
- clientOffset,
- sidxMapping,
- previousManifest
- });
- addPropertiesToMain(manifest, srcUrl, dashGroupId$1);
- return manifest;
- };
- const removeOldMediaGroupLabels$1 = (update, newMain) => {
- forEachMediaGroup$2(update, (properties, type2, group, label2) => {
- if (!(label2 in newMain.mediaGroups[type2][group])) {
- delete update.mediaGroups[type2][group][label2];
- }
- });
- };
- const updateMain = (oldMain, newMain, sidxMapping) => {
- let noChanges = true;
- let update = merge$2(oldMain, {
- duration: newMain.duration,
- minimumUpdatePeriod: newMain.minimumUpdatePeriod,
- timelineStarts: newMain.timelineStarts
- });
- for (let i2 = 0; i2 < newMain.playlists.length; i2++) {
- const playlist = newMain.playlists[i2];
- if (playlist.sidx) {
- const sidxKey = generateSidxKey$1(playlist.sidx);
- if (sidxMapping && sidxMapping[sidxKey] && sidxMapping[sidxKey].sidx) {
- addSidxSegmentsToPlaylist$1$1(playlist, sidxMapping[sidxKey].sidx, playlist.sidx.resolvedUri);
- }
- }
- const playlistUpdate = updateMain$1(update, playlist, dashPlaylistUnchanged$1);
- if (playlistUpdate) {
- update = playlistUpdate;
- noChanges = false;
- }
- }
- forEachMediaGroup$2(newMain, (properties, type2, group, label2) => {
- if (properties.playlists && properties.playlists.length) {
- const id = properties.playlists[0].id;
- const playlistUpdate = updateMain$1(update, properties.playlists[0], dashPlaylistUnchanged$1);
- if (playlistUpdate) {
- update = playlistUpdate;
- if (!(label2 in update.mediaGroups[type2][group])) {
- update.mediaGroups[type2][group][label2] = properties;
- }
- update.mediaGroups[type2][group][label2].playlists[0] = update.playlists[id];
- noChanges = false;
- }
- }
- });
- removeOldMediaGroupLabels$1(update, newMain);
- if (newMain.minimumUpdatePeriod !== oldMain.minimumUpdatePeriod) {
- noChanges = false;
- }
- if (noChanges) {
- return null;
- }
- return update;
- };
- const equivalentSidx$1 = (a, b) => {
- const neitherMap = Boolean(!a.map && !b.map);
- const equivalentMap = neitherMap || Boolean(a.map && b.map && a.map.byterange.offset === b.map.byterange.offset && a.map.byterange.length === b.map.byterange.length);
- return equivalentMap && a.uri === b.uri && a.byterange.offset === b.byterange.offset && a.byterange.length === b.byterange.length;
- };
- const compareSidxEntry$1 = (playlists, oldSidxMapping) => {
- const newSidxMapping = {};
- for (const id in playlists) {
- const playlist = playlists[id];
- const currentSidxInfo = playlist.sidx;
- if (currentSidxInfo) {
- const key = generateSidxKey$1(currentSidxInfo);
- if (!oldSidxMapping[key]) {
- break;
- }
- const savedSidxInfo = oldSidxMapping[key].sidxInfo;
- if (equivalentSidx$1(savedSidxInfo, currentSidxInfo)) {
- newSidxMapping[key] = oldSidxMapping[key];
- }
- }
- }
- return newSidxMapping;
- };
- const filterChangedSidxMappings$1 = (main, oldSidxMapping) => {
- const videoSidx = compareSidxEntry$1(main.playlists, oldSidxMapping);
- let mediaGroupSidx = videoSidx;
- forEachMediaGroup$2(main, (properties, mediaType, groupKey, labelKey) => {
- if (properties.playlists && properties.playlists.length) {
- const playlists = properties.playlists;
- mediaGroupSidx = merge$2(mediaGroupSidx, compareSidxEntry$1(playlists, oldSidxMapping));
- }
- });
- return mediaGroupSidx;
- };
- class DashPlaylistLoader$1 extends EventTarget$3 {
- constructor(srcUrlOrPlaylist, vhs, options2 = {}, mainPlaylistLoader) {
- super();
- this.mainPlaylistLoader_ = mainPlaylistLoader || this;
- if (!mainPlaylistLoader) {
- this.isMain_ = true;
- }
- const {
- withCredentials = false
- } = options2;
- this.vhs_ = vhs;
- this.withCredentials = withCredentials;
- if (!srcUrlOrPlaylist) {
- throw new Error("A non-empty playlist URL or object is required");
- }
- this.on("minimumUpdatePeriod", () => {
- this.refreshXml_();
- });
- this.on("mediaupdatetimeout", () => {
- this.refreshMedia_(this.media().id);
- });
- this.state = "HAVE_NOTHING";
- this.loadedPlaylists_ = {};
- this.logger_ = logger$1("DashPlaylistLoader");
- if (this.isMain_) {
- this.mainPlaylistLoader_.srcUrl = srcUrlOrPlaylist;
- this.mainPlaylistLoader_.sidxMapping_ = {};
- } else {
- this.childPlaylist_ = srcUrlOrPlaylist;
- }
- }
- requestErrored_(err, request, startingState) {
- if (!this.request) {
- return true;
- }
- this.request = null;
- if (err) {
- this.error = typeof err === "object" && !(err instanceof Error) ? err : {
- status: request.status,
- message: "DASH request error at URL: " + request.uri,
- response: request.response,
- code: 2
- };
- if (startingState) {
- this.state = startingState;
- }
- this.trigger("error");
- return true;
- }
- }
- addSidxSegments_(playlist, startingState, cb) {
- const sidxKey = playlist.sidx && generateSidxKey$1(playlist.sidx);
- if (!playlist.sidx || !sidxKey || this.mainPlaylistLoader_.sidxMapping_[sidxKey]) {
- this.mediaRequest_ = window_1.setTimeout(() => cb(false), 0);
- return;
- }
- const uri = resolveManifestRedirect$1(playlist.sidx.resolvedUri);
- const fin = (err, request) => {
- if (this.requestErrored_(err, request, startingState)) {
- return;
- }
- const sidxMapping = this.mainPlaylistLoader_.sidxMapping_;
- let sidx;
- try {
- sidx = parseSidx_1$1(toUint8$1(request.response).subarray(8));
- } catch (e) {
- this.requestErrored_(e, request, startingState);
- return;
- }
- sidxMapping[sidxKey] = {
- sidxInfo: playlist.sidx,
- sidx
- };
- addSidxSegmentsToPlaylist$1$1(playlist, sidx, playlist.sidx.resolvedUri);
- return cb(true);
- };
- this.request = containerRequest$1(uri, this.vhs_.xhr, (err, request, container, bytes) => {
- if (err) {
- return fin(err, request);
- }
- if (!container || container !== "mp4") {
- return fin({
- status: request.status,
- message: `Unsupported ${container || "unknown"} container type for sidx segment at URL: ${uri}`,
- response: "",
- playlist,
- internal: true,
- playlistExclusionDuration: Infinity,
- code: 2
- }, request);
- }
- const {
- offset,
- length
- } = playlist.sidx.byterange;
- if (bytes.length >= length + offset) {
- return fin(err, {
- response: bytes.subarray(offset, offset + length),
- status: request.status,
- uri: request.uri
- });
- }
- this.request = this.vhs_.xhr({
- uri,
- responseType: "arraybuffer",
- headers: segmentXhrHeaders$1({
- byterange: playlist.sidx.byterange
- })
- }, fin);
- });
- }
- dispose() {
- this.trigger("dispose");
- this.stopRequest();
- this.loadedPlaylists_ = {};
- window_1.clearTimeout(this.minimumUpdatePeriodTimeout_);
- window_1.clearTimeout(this.mediaRequest_);
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- this.mediaRequest_ = null;
- this.minimumUpdatePeriodTimeout_ = null;
- if (this.mainPlaylistLoader_.createMupOnMedia_) {
- this.off("loadedmetadata", this.mainPlaylistLoader_.createMupOnMedia_);
- this.mainPlaylistLoader_.createMupOnMedia_ = null;
- }
- this.off();
- }
- hasPendingRequest() {
- return this.request || this.mediaRequest_;
- }
- stopRequest() {
- if (this.request) {
- const oldRequest = this.request;
- this.request = null;
- oldRequest.onreadystatechange = null;
- oldRequest.abort();
- }
- }
- media(playlist) {
- if (!playlist) {
- return this.media_;
- }
- if (this.state === "HAVE_NOTHING") {
- throw new Error("Cannot switch media playlist from " + this.state);
- }
- const startingState = this.state;
- if (typeof playlist === "string") {
- if (!this.mainPlaylistLoader_.main.playlists[playlist]) {
- throw new Error("Unknown playlist URI: " + playlist);
- }
- playlist = this.mainPlaylistLoader_.main.playlists[playlist];
- }
- const mediaChange = !this.media_ || playlist.id !== this.media_.id;
- if (mediaChange && this.loadedPlaylists_[playlist.id] && this.loadedPlaylists_[playlist.id].endList) {
- this.state = "HAVE_METADATA";
- this.media_ = playlist;
- if (mediaChange) {
- this.trigger("mediachanging");
- this.trigger("mediachange");
- }
- return;
- }
- if (!mediaChange) {
- return;
- }
- if (this.media_) {
- this.trigger("mediachanging");
- }
- this.addSidxSegments_(playlist, startingState, (sidxChanged) => {
- this.haveMetadata({
- startingState,
- playlist
- });
- });
- }
- haveMetadata({
- startingState,
- playlist
- }) {
- this.state = "HAVE_METADATA";
- this.loadedPlaylists_[playlist.id] = playlist;
- this.mediaRequest_ = null;
- this.refreshMedia_(playlist.id);
- if (startingState === "HAVE_MAIN_MANIFEST") {
- this.trigger("loadedmetadata");
- } else {
- this.trigger("mediachange");
- }
- }
- pause() {
- if (this.mainPlaylistLoader_.createMupOnMedia_) {
- this.off("loadedmetadata", this.mainPlaylistLoader_.createMupOnMedia_);
- this.mainPlaylistLoader_.createMupOnMedia_ = null;
- }
- this.stopRequest();
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- if (this.isMain_) {
- window_1.clearTimeout(this.mainPlaylistLoader_.minimumUpdatePeriodTimeout_);
- this.mainPlaylistLoader_.minimumUpdatePeriodTimeout_ = null;
- }
- if (this.state === "HAVE_NOTHING") {
- this.started = false;
- }
- }
- load(isFinalRendition) {
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- const media = this.media();
- if (isFinalRendition) {
- const delay = media ? media.targetDuration / 2 * 1e3 : 5 * 1e3;
- this.mediaUpdateTimeout = window_1.setTimeout(() => this.load(), delay);
- return;
- }
- if (!this.started) {
- this.start();
- return;
- }
- if (media && !media.endList) {
- if (this.isMain_ && !this.minimumUpdatePeriodTimeout_) {
- this.trigger("minimumUpdatePeriod");
- this.updateMinimumUpdatePeriodTimeout_();
- }
- this.trigger("mediaupdatetimeout");
- } else {
- this.trigger("loadedplaylist");
- }
- }
- start() {
- this.started = true;
- if (!this.isMain_) {
- this.mediaRequest_ = window_1.setTimeout(() => this.haveMain_(), 0);
- return;
- }
- this.requestMain_((req, mainChanged) => {
- this.haveMain_();
- if (!this.hasPendingRequest() && !this.media_) {
- this.media(this.mainPlaylistLoader_.main.playlists[0]);
- }
- });
- }
- requestMain_(cb) {
- this.request = this.vhs_.xhr({
- uri: this.mainPlaylistLoader_.srcUrl,
- withCredentials: this.withCredentials
- }, (error, req) => {
- if (this.requestErrored_(error, req)) {
- if (this.state === "HAVE_NOTHING") {
- this.started = false;
- }
- return;
- }
- const mainChanged = req.responseText !== this.mainPlaylistLoader_.mainXml_;
- this.mainPlaylistLoader_.mainXml_ = req.responseText;
- if (req.responseHeaders && req.responseHeaders.date) {
- this.mainLoaded_ = Date.parse(req.responseHeaders.date);
- } else {
- this.mainLoaded_ = Date.now();
- }
- this.mainPlaylistLoader_.srcUrl = resolveManifestRedirect$1(this.mainPlaylistLoader_.srcUrl, req);
- if (mainChanged) {
- this.handleMain_();
- this.syncClientServerClock_(() => {
- return cb(req, mainChanged);
- });
- return;
- }
- return cb(req, mainChanged);
- });
- }
- syncClientServerClock_(done) {
- const utcTiming = parseUTCTiming$1(this.mainPlaylistLoader_.mainXml_);
- if (utcTiming === null) {
- this.mainPlaylistLoader_.clientOffset_ = this.mainLoaded_ - Date.now();
- return done();
- }
- if (utcTiming.method === "DIRECT") {
- this.mainPlaylistLoader_.clientOffset_ = utcTiming.value - Date.now();
- return done();
- }
- this.request = this.vhs_.xhr({
- uri: resolveUrl$2(this.mainPlaylistLoader_.srcUrl, utcTiming.value),
- method: utcTiming.method,
- withCredentials: this.withCredentials
- }, (error, req) => {
- if (!this.request) {
- return;
- }
- if (error) {
- this.mainPlaylistLoader_.clientOffset_ = this.mainLoaded_ - Date.now();
- return done();
- }
- let serverTime;
- if (utcTiming.method === "HEAD") {
- if (!req.responseHeaders || !req.responseHeaders.date) {
- serverTime = this.mainLoaded_;
- } else {
- serverTime = Date.parse(req.responseHeaders.date);
- }
- } else {
- serverTime = Date.parse(req.responseText);
- }
- this.mainPlaylistLoader_.clientOffset_ = serverTime - Date.now();
- done();
- });
- }
- haveMain_() {
- this.state = "HAVE_MAIN_MANIFEST";
- if (this.isMain_) {
- this.trigger("loadedplaylist");
- } else if (!this.media_) {
- this.media(this.childPlaylist_);
- }
- }
- handleMain_() {
- this.mediaRequest_ = null;
- const oldMain = this.mainPlaylistLoader_.main;
- let newMain = parseMainXml({
- mainXml: this.mainPlaylistLoader_.mainXml_,
- srcUrl: this.mainPlaylistLoader_.srcUrl,
- clientOffset: this.mainPlaylistLoader_.clientOffset_,
- sidxMapping: this.mainPlaylistLoader_.sidxMapping_,
- previousManifest: oldMain
- });
- if (oldMain) {
- newMain = updateMain(oldMain, newMain, this.mainPlaylistLoader_.sidxMapping_);
- }
- this.mainPlaylistLoader_.main = newMain ? newMain : oldMain;
- const location = this.mainPlaylistLoader_.main.locations && this.mainPlaylistLoader_.main.locations[0];
- if (location && location !== this.mainPlaylistLoader_.srcUrl) {
- this.mainPlaylistLoader_.srcUrl = location;
- }
- if (!oldMain || newMain && newMain.minimumUpdatePeriod !== oldMain.minimumUpdatePeriod) {
- this.updateMinimumUpdatePeriodTimeout_();
- }
- return Boolean(newMain);
- }
- updateMinimumUpdatePeriodTimeout_() {
- const mpl = this.mainPlaylistLoader_;
- if (mpl.createMupOnMedia_) {
- mpl.off("loadedmetadata", mpl.createMupOnMedia_);
- mpl.createMupOnMedia_ = null;
- }
- if (mpl.minimumUpdatePeriodTimeout_) {
- window_1.clearTimeout(mpl.minimumUpdatePeriodTimeout_);
- mpl.minimumUpdatePeriodTimeout_ = null;
- }
- let mup = mpl.main && mpl.main.minimumUpdatePeriod;
- if (mup === 0) {
- if (mpl.media()) {
- mup = mpl.media().targetDuration * 1e3;
- } else {
- mpl.createMupOnMedia_ = mpl.updateMinimumUpdatePeriodTimeout_;
- mpl.one("loadedmetadata", mpl.createMupOnMedia_);
- }
- }
- if (typeof mup !== "number" || mup <= 0) {
- if (mup < 0) {
- this.logger_(`found invalid minimumUpdatePeriod of ${mup}, not setting a timeout`);
- }
- return;
- }
- this.createMUPTimeout_(mup);
- }
- createMUPTimeout_(mup) {
- const mpl = this.mainPlaylistLoader_;
- mpl.minimumUpdatePeriodTimeout_ = window_1.setTimeout(() => {
- mpl.minimumUpdatePeriodTimeout_ = null;
- mpl.trigger("minimumUpdatePeriod");
- mpl.createMUPTimeout_(mup);
- }, mup);
- }
- refreshXml_() {
- this.requestMain_((req, mainChanged) => {
- if (!mainChanged) {
- return;
- }
- if (this.media_) {
- this.media_ = this.mainPlaylistLoader_.main.playlists[this.media_.id];
- }
- this.mainPlaylistLoader_.sidxMapping_ = filterChangedSidxMappings$1(this.mainPlaylistLoader_.main, this.mainPlaylistLoader_.sidxMapping_);
- this.addSidxSegments_(this.media(), this.state, (sidxChanged) => {
- this.refreshMedia_(this.media().id);
- });
- });
- }
- refreshMedia_(mediaID) {
- if (!mediaID) {
- throw new Error("refreshMedia_ must take a media id");
- }
- if (this.media_ && this.isMain_) {
- this.handleMain_();
- }
- const playlists = this.mainPlaylistLoader_.main.playlists;
- const mediaChanged = !this.media_ || this.media_ !== playlists[mediaID];
- if (mediaChanged) {
- this.media_ = playlists[mediaID];
- } else {
- this.trigger("playlistunchanged");
- }
- if (!this.mediaUpdateTimeout) {
- const createMediaUpdateTimeout = () => {
- if (this.media().endList) {
- return;
- }
- this.mediaUpdateTimeout = window_1.setTimeout(() => {
- this.trigger("mediaupdatetimeout");
- createMediaUpdateTimeout();
- }, refreshDelay$1(this.media(), Boolean(mediaChanged)));
- };
- createMediaUpdateTimeout();
- }
- this.trigger("loadedplaylist");
- }
- }
- var Config$1 = {
- GOAL_BUFFER_LENGTH: 30,
- MAX_GOAL_BUFFER_LENGTH: 60,
- BACK_BUFFER_LENGTH: 30,
- GOAL_BUFFER_LENGTH_RATE: 1,
- INITIAL_BANDWIDTH: 4194304,
- BANDWIDTH_VARIANCE: 1.2,
- BUFFER_LOW_WATER_LINE: 0,
- MAX_BUFFER_LOW_WATER_LINE: 30,
- EXPERIMENTAL_MAX_BUFFER_LOW_WATER_LINE: 16,
- BUFFER_LOW_WATER_LINE_RATE: 1,
- BUFFER_HIGH_WATER_LINE: 30
- };
- const stringToArrayBuffer$1 = (string) => {
- const view = new Uint8Array(new ArrayBuffer(string.length));
- for (let i2 = 0; i2 < string.length; i2++) {
- view[i2] = string.charCodeAt(i2);
- }
- return view.buffer;
- };
- const browserWorkerPolyFill$1 = function(workerObj) {
- workerObj.on = workerObj.addEventListener;
- workerObj.off = workerObj.removeEventListener;
- return workerObj;
- };
- const createObjectURL$1 = function(str) {
- try {
- return URL.createObjectURL(new Blob([str], {
- type: "application/javascript"
- }));
- } catch (e) {
- const blob = new BlobBuilder();
- blob.append(str);
- return URL.createObjectURL(blob.getBlob());
- }
- };
- const factory$1 = function(code) {
- return function() {
- const objectUrl = createObjectURL$1(code);
- const worker = browserWorkerPolyFill$1(new Worker(objectUrl));
- worker.objURL = objectUrl;
- const terminate = worker.terminate;
- worker.on = worker.addEventListener;
- worker.off = worker.removeEventListener;
- worker.terminate = function() {
- URL.revokeObjectURL(objectUrl);
- return terminate.call(this);
- };
- return worker;
- };
- };
- const transform$1 = function(code) {
- return `var browserWorkerPolyFill = ${browserWorkerPolyFill$1.toString()};
- browserWorkerPolyFill(self);
- ` + code;
- };
- const getWorkerString$1 = function(fn2) {
- return fn2.toString().replace(/^function.+?{/, "").slice(0, -1);
- };
- const workerCode$1$1 = transform$1(getWorkerString$1(function() {
- var commonjsGlobal2 = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
- var Stream$8 = function() {
- this.init = function() {
- var listeners = {};
- this.on = function(type3, listener) {
- if (!listeners[type3]) {
- listeners[type3] = [];
- }
- listeners[type3] = listeners[type3].concat(listener);
- };
- this.off = function(type3, listener) {
- var index2;
- if (!listeners[type3]) {
- return false;
- }
- index2 = listeners[type3].indexOf(listener);
- listeners[type3] = listeners[type3].slice();
- listeners[type3].splice(index2, 1);
- return index2 > -1;
- };
- this.trigger = function(type3) {
- var callbacks, i2, length, args;
- callbacks = listeners[type3];
- if (!callbacks) {
- return;
- }
- if (arguments.length === 2) {
- length = callbacks.length;
- for (i2 = 0; i2 < length; ++i2) {
- callbacks[i2].call(this, arguments[1]);
- }
- } else {
- args = [];
- i2 = arguments.length;
- for (i2 = 1; i2 < arguments.length; ++i2) {
- args.push(arguments[i2]);
- }
- length = callbacks.length;
- for (i2 = 0; i2 < length; ++i2) {
- callbacks[i2].apply(this, args);
- }
- }
- };
- this.dispose = function() {
- listeners = {};
- };
- };
- };
- Stream$8.prototype.pipe = function(destination2) {
- this.on("data", function(data) {
- destination2.push(data);
- });
- this.on("done", function(flushSource) {
- destination2.flush(flushSource);
- });
- this.on("partialdone", function(flushSource) {
- destination2.partialFlush(flushSource);
- });
- this.on("endedtimeline", function(flushSource) {
- destination2.endTimeline(flushSource);
- });
- this.on("reset", function(flushSource) {
- destination2.reset(flushSource);
- });
- return destination2;
- };
- Stream$8.prototype.push = function(data) {
- this.trigger("data", data);
- };
- Stream$8.prototype.flush = function(flushSource) {
- this.trigger("done", flushSource);
- };
- Stream$8.prototype.partialFlush = function(flushSource) {
- this.trigger("partialdone", flushSource);
- };
- Stream$8.prototype.endTimeline = function(flushSource) {
- this.trigger("endedtimeline", flushSource);
- };
- Stream$8.prototype.reset = function(flushSource) {
- this.trigger("reset", flushSource);
- };
- var stream = Stream$8;
- var MAX_UINT32$12 = Math.pow(2, 32);
- var getUint64$32 = function(uint8) {
- var dv = new DataView(uint8.buffer, uint8.byteOffset, uint8.byteLength);
- var value;
- if (dv.getBigUint64) {
- value = dv.getBigUint64(0);
- if (value < Number.MAX_SAFE_INTEGER) {
- return Number(value);
- }
- return value;
- }
- return dv.getUint32(0) * MAX_UINT32$12 + dv.getUint32(4);
- };
- var numbers2 = {
- getUint64: getUint64$32,
- MAX_UINT32: MAX_UINT32$12
- };
- var MAX_UINT322 = numbers2.MAX_UINT32;
- var box, dinf, esds, ftyp, mdat, mfhd, minf, moof, moov, mvex, mvhd, trak, tkhd, mdia, mdhd, hdlr, sdtp, stbl, stsd, traf, trex, trun$1, types, MAJOR_BRAND, MINOR_VERSION, AVC1_BRAND, VIDEO_HDLR, AUDIO_HDLR, HDLR_TYPES, VMHD, SMHD, DREF, STCO, STSC, STSZ, STTS;
- (function() {
- var i2;
- types = {
- avc1: [],
- avcC: [],
- btrt: [],
- dinf: [],
- dref: [],
- esds: [],
- ftyp: [],
- hdlr: [],
- mdat: [],
- mdhd: [],
- mdia: [],
- mfhd: [],
- minf: [],
- moof: [],
- moov: [],
- mp4a: [],
- mvex: [],
- mvhd: [],
- pasp: [],
- sdtp: [],
- smhd: [],
- stbl: [],
- stco: [],
- stsc: [],
- stsd: [],
- stsz: [],
- stts: [],
- styp: [],
- tfdt: [],
- tfhd: [],
- traf: [],
- trak: [],
- trun: [],
- trex: [],
- tkhd: [],
- vmhd: []
- };
- if (typeof Uint8Array === "undefined") {
- return;
- }
- for (i2 in types) {
- if (types.hasOwnProperty(i2)) {
- types[i2] = [i2.charCodeAt(0), i2.charCodeAt(1), i2.charCodeAt(2), i2.charCodeAt(3)];
- }
- }
- MAJOR_BRAND = new Uint8Array(["i".charCodeAt(0), "s".charCodeAt(0), "o".charCodeAt(0), "m".charCodeAt(0)]);
- AVC1_BRAND = new Uint8Array(["a".charCodeAt(0), "v".charCodeAt(0), "c".charCodeAt(0), "1".charCodeAt(0)]);
- MINOR_VERSION = new Uint8Array([0, 0, 0, 1]);
- VIDEO_HDLR = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 118,
- 105,
- 100,
- 101,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 86,
- 105,
- 100,
- 101,
- 111,
- 72,
- 97,
- 110,
- 100,
- 108,
- 101,
- 114,
- 0
- ]);
- AUDIO_HDLR = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 115,
- 111,
- 117,
- 110,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 83,
- 111,
- 117,
- 110,
- 100,
- 72,
- 97,
- 110,
- 100,
- 108,
- 101,
- 114,
- 0
- ]);
- HDLR_TYPES = {
- video: VIDEO_HDLR,
- audio: AUDIO_HDLR
- };
- DREF = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 12,
- 117,
- 114,
- 108,
- 32,
- 0,
- 0,
- 0,
- 1
- ]);
- SMHD = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- STCO = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- STSC = STCO;
- STSZ = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- STTS = STCO;
- VMHD = new Uint8Array([
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- })();
- box = function(type3) {
- var payload = [], size = 0, i2, result, view;
- for (i2 = 1; i2 < arguments.length; i2++) {
- payload.push(arguments[i2]);
- }
- i2 = payload.length;
- while (i2--) {
- size += payload[i2].byteLength;
- }
- result = new Uint8Array(size + 8);
- view = new DataView(result.buffer, result.byteOffset, result.byteLength);
- view.setUint32(0, result.byteLength);
- result.set(type3, 4);
- for (i2 = 0, size = 8; i2 < payload.length; i2++) {
- result.set(payload[i2], size);
- size += payload[i2].byteLength;
- }
- return result;
- };
- dinf = function() {
- return box(types.dinf, box(types.dref, DREF));
- };
- esds = function(track) {
- return box(types.esds, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 3,
- 25,
- 0,
- 0,
- 0,
- 4,
- 17,
- 64,
- 21,
- 0,
- 6,
- 0,
- 0,
- 0,
- 218,
- 192,
- 0,
- 0,
- 218,
- 192,
- 5,
- 2,
- track.audioobjecttype << 3 | track.samplingfrequencyindex >>> 1,
- track.samplingfrequencyindex << 7 | track.channelcount << 3,
- 6,
- 1,
- 2
- ]));
- };
- ftyp = function() {
- return box(types.ftyp, MAJOR_BRAND, MINOR_VERSION, MAJOR_BRAND, AVC1_BRAND);
- };
- hdlr = function(type3) {
- return box(types.hdlr, HDLR_TYPES[type3]);
- };
- mdat = function(data) {
- return box(types.mdat, data);
- };
- mdhd = function(track) {
- var result = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 2,
- 0,
- 0,
- 0,
- 3,
- 0,
- 1,
- 95,
- 144,
- track.duration >>> 24 & 255,
- track.duration >>> 16 & 255,
- track.duration >>> 8 & 255,
- track.duration & 255,
- 85,
- 196,
- 0,
- 0
- ]);
- if (track.samplerate) {
- result[12] = track.samplerate >>> 24 & 255;
- result[13] = track.samplerate >>> 16 & 255;
- result[14] = track.samplerate >>> 8 & 255;
- result[15] = track.samplerate & 255;
- }
- return box(types.mdhd, result);
- };
- mdia = function(track) {
- return box(types.mdia, mdhd(track), hdlr(track.type), minf(track));
- };
- mfhd = function(sequenceNumber) {
- return box(types.mfhd, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- (sequenceNumber & 4278190080) >> 24,
- (sequenceNumber & 16711680) >> 16,
- (sequenceNumber & 65280) >> 8,
- sequenceNumber & 255
- ]));
- };
- minf = function(track) {
- return box(types.minf, track.type === "video" ? box(types.vmhd, VMHD) : box(types.smhd, SMHD), dinf(), stbl(track));
- };
- moof = function(sequenceNumber, tracks) {
- var trackFragments = [], i2 = tracks.length;
- while (i2--) {
- trackFragments[i2] = traf(tracks[i2]);
- }
- return box.apply(null, [types.moof, mfhd(sequenceNumber)].concat(trackFragments));
- };
- moov = function(tracks) {
- var i2 = tracks.length, boxes = [];
- while (i2--) {
- boxes[i2] = trak(tracks[i2]);
- }
- return box.apply(null, [types.moov, mvhd(4294967295)].concat(boxes).concat(mvex(tracks)));
- };
- mvex = function(tracks) {
- var i2 = tracks.length, boxes = [];
- while (i2--) {
- boxes[i2] = trex(tracks[i2]);
- }
- return box.apply(null, [types.mvex].concat(boxes));
- };
- mvhd = function(duration5) {
- var bytes = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 2,
- 0,
- 1,
- 95,
- 144,
- (duration5 & 4278190080) >> 24,
- (duration5 & 16711680) >> 16,
- (duration5 & 65280) >> 8,
- duration5 & 255,
- 0,
- 1,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 64,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 255,
- 255,
- 255,
- 255
- ]);
- return box(types.mvhd, bytes);
- };
- sdtp = function(track) {
- var samples = track.samples || [], bytes = new Uint8Array(4 + samples.length), flags, i2;
- for (i2 = 0; i2 < samples.length; i2++) {
- flags = samples[i2].flags;
- bytes[i2 + 4] = flags.dependsOn << 4 | flags.isDependedOn << 2 | flags.hasRedundancy;
- }
- return box(types.sdtp, bytes);
- };
- stbl = function(track) {
- return box(types.stbl, stsd(track), box(types.stts, STTS), box(types.stsc, STSC), box(types.stsz, STSZ), box(types.stco, STCO));
- };
- (function() {
- var videoSample, audioSample;
- stsd = function(track) {
- return box(types.stsd, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1
- ]), track.type === "video" ? videoSample(track) : audioSample(track));
- };
- videoSample = function(track) {
- var sps = track.sps || [], pps = track.pps || [], sequenceParameterSets = [], pictureParameterSets = [], i2, avc1Box;
- for (i2 = 0; i2 < sps.length; i2++) {
- sequenceParameterSets.push((sps[i2].byteLength & 65280) >>> 8);
- sequenceParameterSets.push(sps[i2].byteLength & 255);
- sequenceParameterSets = sequenceParameterSets.concat(Array.prototype.slice.call(sps[i2]));
- }
- for (i2 = 0; i2 < pps.length; i2++) {
- pictureParameterSets.push((pps[i2].byteLength & 65280) >>> 8);
- pictureParameterSets.push(pps[i2].byteLength & 255);
- pictureParameterSets = pictureParameterSets.concat(Array.prototype.slice.call(pps[i2]));
- }
- avc1Box = [types.avc1, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- (track.width & 65280) >> 8,
- track.width & 255,
- (track.height & 65280) >> 8,
- track.height & 255,
- 0,
- 72,
- 0,
- 0,
- 0,
- 72,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 19,
- 118,
- 105,
- 100,
- 101,
- 111,
- 106,
- 115,
- 45,
- 99,
- 111,
- 110,
- 116,
- 114,
- 105,
- 98,
- 45,
- 104,
- 108,
- 115,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 24,
- 17,
- 17
- ]), box(types.avcC, new Uint8Array([
- 1,
- track.profileIdc,
- track.profileCompatibility,
- track.levelIdc,
- 255
- ].concat(
- [sps.length],
- sequenceParameterSets,
- [pps.length],
- pictureParameterSets
- ))), box(types.btrt, new Uint8Array([
- 0,
- 28,
- 156,
- 128,
- 0,
- 45,
- 198,
- 192,
- 0,
- 45,
- 198,
- 192
- ]))];
- if (track.sarRatio) {
- var hSpacing = track.sarRatio[0], vSpacing = track.sarRatio[1];
- avc1Box.push(box(types.pasp, new Uint8Array([(hSpacing & 4278190080) >> 24, (hSpacing & 16711680) >> 16, (hSpacing & 65280) >> 8, hSpacing & 255, (vSpacing & 4278190080) >> 24, (vSpacing & 16711680) >> 16, (vSpacing & 65280) >> 8, vSpacing & 255])));
- }
- return box.apply(null, avc1Box);
- };
- audioSample = function(track) {
- return box(types.mp4a, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- (track.channelcount & 65280) >> 8,
- track.channelcount & 255,
- (track.samplesize & 65280) >> 8,
- track.samplesize & 255,
- 0,
- 0,
- 0,
- 0,
- (track.samplerate & 65280) >> 8,
- track.samplerate & 255,
- 0,
- 0
- ]), esds(track));
- };
- })();
- tkhd = function(track) {
- var result = new Uint8Array([
- 0,
- 0,
- 0,
- 7,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- (track.id & 4278190080) >> 24,
- (track.id & 16711680) >> 16,
- (track.id & 65280) >> 8,
- track.id & 255,
- 0,
- 0,
- 0,
- 0,
- (track.duration & 4278190080) >> 24,
- (track.duration & 16711680) >> 16,
- (track.duration & 65280) >> 8,
- track.duration & 255,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 64,
- 0,
- 0,
- 0,
- (track.width & 65280) >> 8,
- track.width & 255,
- 0,
- 0,
- (track.height & 65280) >> 8,
- track.height & 255,
- 0,
- 0
- ]);
- return box(types.tkhd, result);
- };
- traf = function(track) {
- var trackFragmentHeader, trackFragmentDecodeTime, trackFragmentRun, sampleDependencyTable, dataOffset, upperWordBaseMediaDecodeTime, lowerWordBaseMediaDecodeTime;
- trackFragmentHeader = box(types.tfhd, new Uint8Array([
- 0,
- 0,
- 0,
- 58,
- (track.id & 4278190080) >> 24,
- (track.id & 16711680) >> 16,
- (track.id & 65280) >> 8,
- track.id & 255,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]));
- upperWordBaseMediaDecodeTime = Math.floor(track.baseMediaDecodeTime / MAX_UINT322);
- lowerWordBaseMediaDecodeTime = Math.floor(track.baseMediaDecodeTime % MAX_UINT322);
- trackFragmentDecodeTime = box(types.tfdt, new Uint8Array([
- 1,
- 0,
- 0,
- 0,
- upperWordBaseMediaDecodeTime >>> 24 & 255,
- upperWordBaseMediaDecodeTime >>> 16 & 255,
- upperWordBaseMediaDecodeTime >>> 8 & 255,
- upperWordBaseMediaDecodeTime & 255,
- lowerWordBaseMediaDecodeTime >>> 24 & 255,
- lowerWordBaseMediaDecodeTime >>> 16 & 255,
- lowerWordBaseMediaDecodeTime >>> 8 & 255,
- lowerWordBaseMediaDecodeTime & 255
- ]));
- dataOffset = 32 + 20 + 8 + 16 + 8 + 8;
- if (track.type === "audio") {
- trackFragmentRun = trun$1(track, dataOffset);
- return box(types.traf, trackFragmentHeader, trackFragmentDecodeTime, trackFragmentRun);
- }
- sampleDependencyTable = sdtp(track);
- trackFragmentRun = trun$1(track, sampleDependencyTable.length + dataOffset);
- return box(types.traf, trackFragmentHeader, trackFragmentDecodeTime, trackFragmentRun, sampleDependencyTable);
- };
- trak = function(track) {
- track.duration = track.duration || 4294967295;
- return box(types.trak, tkhd(track), mdia(track));
- };
- trex = function(track) {
- var result = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- (track.id & 4278190080) >> 24,
- (track.id & 16711680) >> 16,
- (track.id & 65280) >> 8,
- track.id & 255,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 1
- ]);
- if (track.type !== "video") {
- result[result.length - 1] = 0;
- }
- return box(types.trex, result);
- };
- (function() {
- var audioTrun, videoTrun, trunHeader;
- trunHeader = function(samples, offset) {
- var durationPresent = 0, sizePresent = 0, flagsPresent = 0, compositionTimeOffset = 0;
- if (samples.length) {
- if (samples[0].duration !== void 0) {
- durationPresent = 1;
- }
- if (samples[0].size !== void 0) {
- sizePresent = 2;
- }
- if (samples[0].flags !== void 0) {
- flagsPresent = 4;
- }
- if (samples[0].compositionTimeOffset !== void 0) {
- compositionTimeOffset = 8;
- }
- }
- return [
- 0,
- 0,
- durationPresent | sizePresent | flagsPresent | compositionTimeOffset,
- 1,
- (samples.length & 4278190080) >>> 24,
- (samples.length & 16711680) >>> 16,
- (samples.length & 65280) >>> 8,
- samples.length & 255,
- (offset & 4278190080) >>> 24,
- (offset & 16711680) >>> 16,
- (offset & 65280) >>> 8,
- offset & 255
- ];
- };
- videoTrun = function(track, offset) {
- var bytesOffest, bytes, header, samples, sample, i2;
- samples = track.samples || [];
- offset += 8 + 12 + 16 * samples.length;
- header = trunHeader(samples, offset);
- bytes = new Uint8Array(header.length + samples.length * 16);
- bytes.set(header);
- bytesOffest = header.length;
- for (i2 = 0; i2 < samples.length; i2++) {
- sample = samples[i2];
- bytes[bytesOffest++] = (sample.duration & 4278190080) >>> 24;
- bytes[bytesOffest++] = (sample.duration & 16711680) >>> 16;
- bytes[bytesOffest++] = (sample.duration & 65280) >>> 8;
- bytes[bytesOffest++] = sample.duration & 255;
- bytes[bytesOffest++] = (sample.size & 4278190080) >>> 24;
- bytes[bytesOffest++] = (sample.size & 16711680) >>> 16;
- bytes[bytesOffest++] = (sample.size & 65280) >>> 8;
- bytes[bytesOffest++] = sample.size & 255;
- bytes[bytesOffest++] = sample.flags.isLeading << 2 | sample.flags.dependsOn;
- bytes[bytesOffest++] = sample.flags.isDependedOn << 6 | sample.flags.hasRedundancy << 4 | sample.flags.paddingValue << 1 | sample.flags.isNonSyncSample;
- bytes[bytesOffest++] = sample.flags.degradationPriority & 240 << 8;
- bytes[bytesOffest++] = sample.flags.degradationPriority & 15;
- bytes[bytesOffest++] = (sample.compositionTimeOffset & 4278190080) >>> 24;
- bytes[bytesOffest++] = (sample.compositionTimeOffset & 16711680) >>> 16;
- bytes[bytesOffest++] = (sample.compositionTimeOffset & 65280) >>> 8;
- bytes[bytesOffest++] = sample.compositionTimeOffset & 255;
- }
- return box(types.trun, bytes);
- };
- audioTrun = function(track, offset) {
- var bytes, bytesOffest, header, samples, sample, i2;
- samples = track.samples || [];
- offset += 8 + 12 + 8 * samples.length;
- header = trunHeader(samples, offset);
- bytes = new Uint8Array(header.length + samples.length * 8);
- bytes.set(header);
- bytesOffest = header.length;
- for (i2 = 0; i2 < samples.length; i2++) {
- sample = samples[i2];
- bytes[bytesOffest++] = (sample.duration & 4278190080) >>> 24;
- bytes[bytesOffest++] = (sample.duration & 16711680) >>> 16;
- bytes[bytesOffest++] = (sample.duration & 65280) >>> 8;
- bytes[bytesOffest++] = sample.duration & 255;
- bytes[bytesOffest++] = (sample.size & 4278190080) >>> 24;
- bytes[bytesOffest++] = (sample.size & 16711680) >>> 16;
- bytes[bytesOffest++] = (sample.size & 65280) >>> 8;
- bytes[bytesOffest++] = sample.size & 255;
- }
- return box(types.trun, bytes);
- };
- trun$1 = function(track, offset) {
- if (track.type === "audio") {
- return audioTrun(track, offset);
- }
- return videoTrun(track, offset);
- };
- })();
- var mp4Generator = {
- ftyp,
- mdat,
- moof,
- moov,
- initSegment: function(tracks) {
- var fileType = ftyp(), movie = moov(tracks), result;
- result = new Uint8Array(fileType.byteLength + movie.byteLength);
- result.set(fileType);
- result.set(movie, fileType.byteLength);
- return result;
- }
- };
- var groupNalsIntoFrames = function(nalUnits) {
- var i2, currentNal, currentFrame = [], frames = [];
- frames.byteLength = 0;
- frames.nalCount = 0;
- frames.duration = 0;
- currentFrame.byteLength = 0;
- for (i2 = 0; i2 < nalUnits.length; i2++) {
- currentNal = nalUnits[i2];
- if (currentNal.nalUnitType === "access_unit_delimiter_rbsp") {
- if (currentFrame.length) {
- currentFrame.duration = currentNal.dts - currentFrame.dts;
- frames.byteLength += currentFrame.byteLength;
- frames.nalCount += currentFrame.length;
- frames.duration += currentFrame.duration;
- frames.push(currentFrame);
- }
- currentFrame = [currentNal];
- currentFrame.byteLength = currentNal.data.byteLength;
- currentFrame.pts = currentNal.pts;
- currentFrame.dts = currentNal.dts;
- } else {
- if (currentNal.nalUnitType === "slice_layer_without_partitioning_rbsp_idr") {
- currentFrame.keyFrame = true;
- }
- currentFrame.duration = currentNal.dts - currentFrame.dts;
- currentFrame.byteLength += currentNal.data.byteLength;
- currentFrame.push(currentNal);
- }
- }
- if (frames.length && (!currentFrame.duration || currentFrame.duration <= 0)) {
- currentFrame.duration = frames[frames.length - 1].duration;
- }
- frames.byteLength += currentFrame.byteLength;
- frames.nalCount += currentFrame.length;
- frames.duration += currentFrame.duration;
- frames.push(currentFrame);
- return frames;
- };
- var groupFramesIntoGops = function(frames) {
- var i2, currentFrame, currentGop = [], gops = [];
- currentGop.byteLength = 0;
- currentGop.nalCount = 0;
- currentGop.duration = 0;
- currentGop.pts = frames[0].pts;
- currentGop.dts = frames[0].dts;
- gops.byteLength = 0;
- gops.nalCount = 0;
- gops.duration = 0;
- gops.pts = frames[0].pts;
- gops.dts = frames[0].dts;
- for (i2 = 0; i2 < frames.length; i2++) {
- currentFrame = frames[i2];
- if (currentFrame.keyFrame) {
- if (currentGop.length) {
- gops.push(currentGop);
- gops.byteLength += currentGop.byteLength;
- gops.nalCount += currentGop.nalCount;
- gops.duration += currentGop.duration;
- }
- currentGop = [currentFrame];
- currentGop.nalCount = currentFrame.length;
- currentGop.byteLength = currentFrame.byteLength;
- currentGop.pts = currentFrame.pts;
- currentGop.dts = currentFrame.dts;
- currentGop.duration = currentFrame.duration;
- } else {
- currentGop.duration += currentFrame.duration;
- currentGop.nalCount += currentFrame.length;
- currentGop.byteLength += currentFrame.byteLength;
- currentGop.push(currentFrame);
- }
- }
- if (gops.length && currentGop.duration <= 0) {
- currentGop.duration = gops[gops.length - 1].duration;
- }
- gops.byteLength += currentGop.byteLength;
- gops.nalCount += currentGop.nalCount;
- gops.duration += currentGop.duration;
- gops.push(currentGop);
- return gops;
- };
- var extendFirstKeyFrame = function(gops) {
- var currentGop;
- if (!gops[0][0].keyFrame && gops.length > 1) {
- currentGop = gops.shift();
- gops.byteLength -= currentGop.byteLength;
- gops.nalCount -= currentGop.nalCount;
- gops[0][0].dts = currentGop.dts;
- gops[0][0].pts = currentGop.pts;
- gops[0][0].duration += currentGop.duration;
- }
- return gops;
- };
- var createDefaultSample = function() {
- return {
- size: 0,
- flags: {
- isLeading: 0,
- dependsOn: 1,
- isDependedOn: 0,
- hasRedundancy: 0,
- degradationPriority: 0,
- isNonSyncSample: 1
- }
- };
- };
- var sampleForFrame = function(frame, dataOffset) {
- var sample = createDefaultSample();
- sample.dataOffset = dataOffset;
- sample.compositionTimeOffset = frame.pts - frame.dts;
- sample.duration = frame.duration;
- sample.size = 4 * frame.length;
- sample.size += frame.byteLength;
- if (frame.keyFrame) {
- sample.flags.dependsOn = 2;
- sample.flags.isNonSyncSample = 0;
- }
- return sample;
- };
- var generateSampleTable$1 = function(gops, baseDataOffset) {
- var h2, i2, sample, currentGop, currentFrame, dataOffset = baseDataOffset || 0, samples = [];
- for (h2 = 0; h2 < gops.length; h2++) {
- currentGop = gops[h2];
- for (i2 = 0; i2 < currentGop.length; i2++) {
- currentFrame = currentGop[i2];
- sample = sampleForFrame(currentFrame, dataOffset);
- dataOffset += sample.size;
- samples.push(sample);
- }
- }
- return samples;
- };
- var concatenateNalData = function(gops) {
- var h2, i2, j, currentGop, currentFrame, currentNal, dataOffset = 0, nalsByteLength = gops.byteLength, numberOfNals = gops.nalCount, totalByteLength = nalsByteLength + 4 * numberOfNals, data = new Uint8Array(totalByteLength), view = new DataView(data.buffer);
- for (h2 = 0; h2 < gops.length; h2++) {
- currentGop = gops[h2];
- for (i2 = 0; i2 < currentGop.length; i2++) {
- currentFrame = currentGop[i2];
- for (j = 0; j < currentFrame.length; j++) {
- currentNal = currentFrame[j];
- view.setUint32(dataOffset, currentNal.data.byteLength);
- dataOffset += 4;
- data.set(currentNal.data, dataOffset);
- dataOffset += currentNal.data.byteLength;
- }
- }
- }
- return data;
- };
- var generateSampleTableForFrame = function(frame, baseDataOffset) {
- var sample, dataOffset = baseDataOffset || 0, samples = [];
- sample = sampleForFrame(frame, dataOffset);
- samples.push(sample);
- return samples;
- };
- var concatenateNalDataForFrame = function(frame) {
- var i2, currentNal, dataOffset = 0, nalsByteLength = frame.byteLength, numberOfNals = frame.length, totalByteLength = nalsByteLength + 4 * numberOfNals, data = new Uint8Array(totalByteLength), view = new DataView(data.buffer);
- for (i2 = 0; i2 < frame.length; i2++) {
- currentNal = frame[i2];
- view.setUint32(dataOffset, currentNal.data.byteLength);
- dataOffset += 4;
- data.set(currentNal.data, dataOffset);
- dataOffset += currentNal.data.byteLength;
- }
- return data;
- };
- var frameUtils$1 = {
- groupNalsIntoFrames,
- groupFramesIntoGops,
- extendFirstKeyFrame,
- generateSampleTable: generateSampleTable$1,
- concatenateNalData,
- generateSampleTableForFrame,
- concatenateNalDataForFrame
- };
- var highPrefix = [33, 16, 5, 32, 164, 27];
- var lowPrefix = [33, 65, 108, 84, 1, 2, 4, 8, 168, 2, 4, 8, 17, 191, 252];
- var zeroFill = function(count) {
- var a = [];
- while (count--) {
- a.push(0);
- }
- return a;
- };
- var makeTable = function(metaTable) {
- return Object.keys(metaTable).reduce(function(obj, key) {
- obj[key] = new Uint8Array(metaTable[key].reduce(function(arr, part) {
- return arr.concat(part);
- }, []));
- return obj;
- }, {});
- };
- var silence;
- var silence_1 = function() {
- if (!silence) {
- var coneOfSilence2 = {
- 96e3: [highPrefix, [227, 64], zeroFill(154), [56]],
- 88200: [highPrefix, [231], zeroFill(170), [56]],
- 64e3: [highPrefix, [248, 192], zeroFill(240), [56]],
- 48e3: [highPrefix, [255, 192], zeroFill(268), [55, 148, 128], zeroFill(54), [112]],
- 44100: [highPrefix, [255, 192], zeroFill(268), [55, 163, 128], zeroFill(84), [112]],
- 32e3: [highPrefix, [255, 192], zeroFill(268), [55, 234], zeroFill(226), [112]],
- 24e3: [highPrefix, [255, 192], zeroFill(268), [55, 255, 128], zeroFill(268), [111, 112], zeroFill(126), [224]],
- 16e3: [highPrefix, [255, 192], zeroFill(268), [55, 255, 128], zeroFill(268), [111, 255], zeroFill(269), [223, 108], zeroFill(195), [1, 192]],
- 12e3: [lowPrefix, zeroFill(268), [3, 127, 248], zeroFill(268), [6, 255, 240], zeroFill(268), [13, 255, 224], zeroFill(268), [27, 253, 128], zeroFill(259), [56]],
- 11025: [lowPrefix, zeroFill(268), [3, 127, 248], zeroFill(268), [6, 255, 240], zeroFill(268), [13, 255, 224], zeroFill(268), [27, 255, 192], zeroFill(268), [55, 175, 128], zeroFill(108), [112]],
- 8e3: [lowPrefix, zeroFill(268), [3, 121, 16], zeroFill(47), [7]]
- };
- silence = makeTable(coneOfSilence2);
- }
- return silence;
- };
- var ONE_SECOND_IN_TS$4 = 9e4, secondsToVideoTs2, secondsToAudioTs2, videoTsToSeconds2, audioTsToSeconds2, audioTsToVideoTs2, videoTsToAudioTs2, metadataTsToSeconds2;
- secondsToVideoTs2 = function(seconds) {
- return seconds * ONE_SECOND_IN_TS$4;
- };
- secondsToAudioTs2 = function(seconds, sampleRate) {
- return seconds * sampleRate;
- };
- videoTsToSeconds2 = function(timestamp) {
- return timestamp / ONE_SECOND_IN_TS$4;
- };
- audioTsToSeconds2 = function(timestamp, sampleRate) {
- return timestamp / sampleRate;
- };
- audioTsToVideoTs2 = function(timestamp, sampleRate) {
- return secondsToVideoTs2(audioTsToSeconds2(timestamp, sampleRate));
- };
- videoTsToAudioTs2 = function(timestamp, sampleRate) {
- return secondsToAudioTs2(videoTsToSeconds2(timestamp), sampleRate);
- };
- metadataTsToSeconds2 = function(timestamp, timelineStartPts, keepOriginalTimestamps) {
- return videoTsToSeconds2(keepOriginalTimestamps ? timestamp : timestamp - timelineStartPts);
- };
- var clock$2 = {
- ONE_SECOND_IN_TS: ONE_SECOND_IN_TS$4,
- secondsToVideoTs: secondsToVideoTs2,
- secondsToAudioTs: secondsToAudioTs2,
- videoTsToSeconds: videoTsToSeconds2,
- audioTsToSeconds: audioTsToSeconds2,
- audioTsToVideoTs: audioTsToVideoTs2,
- videoTsToAudioTs: videoTsToAudioTs2,
- metadataTsToSeconds: metadataTsToSeconds2
- };
- var coneOfSilence = silence_1;
- var clock$12 = clock$2;
- var sumFrameByteLengths = function(array) {
- var i2, currentObj, sum = 0;
- for (i2 = 0; i2 < array.length; i2++) {
- currentObj = array[i2];
- sum += currentObj.data.byteLength;
- }
- return sum;
- };
- var prefixWithSilence = function(track, frames, audioAppendStartTs, videoBaseMediaDecodeTime) {
- var baseMediaDecodeTimeTs, frameDuration = 0, audioGapDuration = 0, audioFillFrameCount = 0, audioFillDuration = 0, silentFrame, i2, firstFrame;
- if (!frames.length) {
- return;
- }
- baseMediaDecodeTimeTs = clock$12.audioTsToVideoTs(track.baseMediaDecodeTime, track.samplerate);
- frameDuration = Math.ceil(clock$12.ONE_SECOND_IN_TS / (track.samplerate / 1024));
- if (audioAppendStartTs && videoBaseMediaDecodeTime) {
- audioGapDuration = baseMediaDecodeTimeTs - Math.max(audioAppendStartTs, videoBaseMediaDecodeTime);
- audioFillFrameCount = Math.floor(audioGapDuration / frameDuration);
- audioFillDuration = audioFillFrameCount * frameDuration;
- }
- if (audioFillFrameCount < 1 || audioFillDuration > clock$12.ONE_SECOND_IN_TS / 2) {
- return;
- }
- silentFrame = coneOfSilence()[track.samplerate];
- if (!silentFrame) {
- silentFrame = frames[0].data;
- }
- for (i2 = 0; i2 < audioFillFrameCount; i2++) {
- firstFrame = frames[0];
- frames.splice(0, 0, {
- data: silentFrame,
- dts: firstFrame.dts - frameDuration,
- pts: firstFrame.pts - frameDuration
- });
- }
- track.baseMediaDecodeTime -= Math.floor(clock$12.videoTsToAudioTs(audioFillDuration, track.samplerate));
- return audioFillDuration;
- };
- var trimAdtsFramesByEarliestDts = function(adtsFrames, track, earliestAllowedDts) {
- if (track.minSegmentDts >= earliestAllowedDts) {
- return adtsFrames;
- }
- track.minSegmentDts = Infinity;
- return adtsFrames.filter(function(currentFrame) {
- if (currentFrame.dts >= earliestAllowedDts) {
- track.minSegmentDts = Math.min(track.minSegmentDts, currentFrame.dts);
- track.minSegmentPts = track.minSegmentDts;
- return true;
- }
- return false;
- });
- };
- var generateSampleTable = function(frames) {
- var i2, currentFrame, samples = [];
- for (i2 = 0; i2 < frames.length; i2++) {
- currentFrame = frames[i2];
- samples.push({
- size: currentFrame.data.byteLength,
- duration: 1024
- });
- }
- return samples;
- };
- var concatenateFrameData = function(frames) {
- var i2, currentFrame, dataOffset = 0, data = new Uint8Array(sumFrameByteLengths(frames));
- for (i2 = 0; i2 < frames.length; i2++) {
- currentFrame = frames[i2];
- data.set(currentFrame.data, dataOffset);
- dataOffset += currentFrame.data.byteLength;
- }
- return data;
- };
- var audioFrameUtils$1 = {
- prefixWithSilence,
- trimAdtsFramesByEarliestDts,
- generateSampleTable,
- concatenateFrameData
- };
- var ONE_SECOND_IN_TS$3 = clock$2.ONE_SECOND_IN_TS;
- var collectDtsInfo = function(track, data) {
- if (typeof data.pts === "number") {
- if (track.timelineStartInfo.pts === void 0) {
- track.timelineStartInfo.pts = data.pts;
- }
- if (track.minSegmentPts === void 0) {
- track.minSegmentPts = data.pts;
- } else {
- track.minSegmentPts = Math.min(track.minSegmentPts, data.pts);
- }
- if (track.maxSegmentPts === void 0) {
- track.maxSegmentPts = data.pts;
- } else {
- track.maxSegmentPts = Math.max(track.maxSegmentPts, data.pts);
- }
- }
- if (typeof data.dts === "number") {
- if (track.timelineStartInfo.dts === void 0) {
- track.timelineStartInfo.dts = data.dts;
- }
- if (track.minSegmentDts === void 0) {
- track.minSegmentDts = data.dts;
- } else {
- track.minSegmentDts = Math.min(track.minSegmentDts, data.dts);
- }
- if (track.maxSegmentDts === void 0) {
- track.maxSegmentDts = data.dts;
- } else {
- track.maxSegmentDts = Math.max(track.maxSegmentDts, data.dts);
- }
- }
- };
- var clearDtsInfo = function(track) {
- delete track.minSegmentDts;
- delete track.maxSegmentDts;
- delete track.minSegmentPts;
- delete track.maxSegmentPts;
- };
- var calculateTrackBaseMediaDecodeTime = function(track, keepOriginalTimestamps) {
- var baseMediaDecodeTime, scale, minSegmentDts = track.minSegmentDts;
- if (!keepOriginalTimestamps) {
- minSegmentDts -= track.timelineStartInfo.dts;
- }
- baseMediaDecodeTime = track.timelineStartInfo.baseMediaDecodeTime;
- baseMediaDecodeTime += minSegmentDts;
- baseMediaDecodeTime = Math.max(0, baseMediaDecodeTime);
- if (track.type === "audio") {
- scale = track.samplerate / ONE_SECOND_IN_TS$3;
- baseMediaDecodeTime *= scale;
- baseMediaDecodeTime = Math.floor(baseMediaDecodeTime);
- }
- return baseMediaDecodeTime;
- };
- var trackDecodeInfo$1 = {
- clearDtsInfo,
- calculateTrackBaseMediaDecodeTime,
- collectDtsInfo
- };
- var USER_DATA_REGISTERED_ITU_T_T35 = 4, RBSP_TRAILING_BITS = 128;
- var parseSei = function(bytes) {
- var i2 = 0, result = {
- payloadType: -1,
- payloadSize: 0
- }, payloadType = 0, payloadSize = 0;
- while (i2 < bytes.byteLength) {
- if (bytes[i2] === RBSP_TRAILING_BITS) {
- break;
- }
- while (bytes[i2] === 255) {
- payloadType += 255;
- i2++;
- }
- payloadType += bytes[i2++];
- while (bytes[i2] === 255) {
- payloadSize += 255;
- i2++;
- }
- payloadSize += bytes[i2++];
- if (!result.payload && payloadType === USER_DATA_REGISTERED_ITU_T_T35) {
- var userIdentifier = String.fromCharCode(bytes[i2 + 3], bytes[i2 + 4], bytes[i2 + 5], bytes[i2 + 6]);
- if (userIdentifier === "GA94") {
- result.payloadType = payloadType;
- result.payloadSize = payloadSize;
- result.payload = bytes.subarray(i2, i2 + payloadSize);
- break;
- } else {
- result.payload = void 0;
- }
- }
- i2 += payloadSize;
- payloadType = 0;
- payloadSize = 0;
- }
- return result;
- };
- var parseUserData = function(sei) {
- if (sei.payload[0] !== 181) {
- return null;
- }
- if ((sei.payload[1] << 8 | sei.payload[2]) !== 49) {
- return null;
- }
- if (String.fromCharCode(sei.payload[3], sei.payload[4], sei.payload[5], sei.payload[6]) !== "GA94") {
- return null;
- }
- if (sei.payload[7] !== 3) {
- return null;
- }
- return sei.payload.subarray(8, sei.payload.length - 1);
- };
- var parseCaptionPackets = function(pts, userData) {
- var results = [], i2, count, offset, data;
- if (!(userData[0] & 64)) {
- return results;
- }
- count = userData[0] & 31;
- for (i2 = 0; i2 < count; i2++) {
- offset = i2 * 3;
- data = {
- type: userData[offset + 2] & 3,
- pts
- };
- if (userData[offset + 2] & 4) {
- data.ccData = userData[offset + 3] << 8 | userData[offset + 4];
- results.push(data);
- }
- }
- return results;
- };
- var discardEmulationPreventionBytes$12 = function(data) {
- var length = data.byteLength, emulationPreventionBytesPositions = [], i2 = 1, newLength, newData;
- while (i2 < length - 2) {
- if (data[i2] === 0 && data[i2 + 1] === 0 && data[i2 + 2] === 3) {
- emulationPreventionBytesPositions.push(i2 + 2);
- i2 += 2;
- } else {
- i2++;
- }
- }
- if (emulationPreventionBytesPositions.length === 0) {
- return data;
- }
- newLength = length - emulationPreventionBytesPositions.length;
- newData = new Uint8Array(newLength);
- var sourceIndex = 0;
- for (i2 = 0; i2 < newLength; sourceIndex++, i2++) {
- if (sourceIndex === emulationPreventionBytesPositions[0]) {
- sourceIndex++;
- emulationPreventionBytesPositions.shift();
- }
- newData[i2] = data[sourceIndex];
- }
- return newData;
- };
- var captionPacketParser = {
- parseSei,
- parseUserData,
- parseCaptionPackets,
- discardEmulationPreventionBytes: discardEmulationPreventionBytes$12,
- USER_DATA_REGISTERED_ITU_T_T35
- };
- var Stream$7 = stream;
- var cea708Parser = captionPacketParser;
- var CaptionStream$2 = function(options2) {
- options2 = options2 || {};
- CaptionStream$2.prototype.init.call(this);
- this.parse708captions_ = typeof options2.parse708captions === "boolean" ? options2.parse708captions : true;
- this.captionPackets_ = [];
- this.ccStreams_ = [
- new Cea608Stream(0, 0),
- new Cea608Stream(0, 1),
- new Cea608Stream(1, 0),
- new Cea608Stream(1, 1)
- ];
- if (this.parse708captions_) {
- this.cc708Stream_ = new Cea708Stream({
- captionServices: options2.captionServices
- });
- }
- this.reset();
- this.ccStreams_.forEach(function(cc) {
- cc.on("data", this.trigger.bind(this, "data"));
- cc.on("partialdone", this.trigger.bind(this, "partialdone"));
- cc.on("done", this.trigger.bind(this, "done"));
- }, this);
- if (this.parse708captions_) {
- this.cc708Stream_.on("data", this.trigger.bind(this, "data"));
- this.cc708Stream_.on("partialdone", this.trigger.bind(this, "partialdone"));
- this.cc708Stream_.on("done", this.trigger.bind(this, "done"));
- }
- };
- CaptionStream$2.prototype = new Stream$7();
- CaptionStream$2.prototype.push = function(event2) {
- var sei, userData, newCaptionPackets;
- if (event2.nalUnitType !== "sei_rbsp") {
- return;
- }
- sei = cea708Parser.parseSei(event2.escapedRBSP);
- if (!sei.payload) {
- return;
- }
- if (sei.payloadType !== cea708Parser.USER_DATA_REGISTERED_ITU_T_T35) {
- return;
- }
- userData = cea708Parser.parseUserData(sei);
- if (!userData) {
- return;
- }
- if (event2.dts < this.latestDts_) {
- this.ignoreNextEqualDts_ = true;
- return;
- } else if (event2.dts === this.latestDts_ && this.ignoreNextEqualDts_) {
- this.numSameDts_--;
- if (!this.numSameDts_) {
- this.ignoreNextEqualDts_ = false;
- }
- return;
- }
- newCaptionPackets = cea708Parser.parseCaptionPackets(event2.pts, userData);
- this.captionPackets_ = this.captionPackets_.concat(newCaptionPackets);
- if (this.latestDts_ !== event2.dts) {
- this.numSameDts_ = 0;
- }
- this.numSameDts_++;
- this.latestDts_ = event2.dts;
- };
- CaptionStream$2.prototype.flushCCStreams = function(flushType) {
- this.ccStreams_.forEach(function(cc) {
- return flushType === "flush" ? cc.flush() : cc.partialFlush();
- }, this);
- };
- CaptionStream$2.prototype.flushStream = function(flushType) {
- if (!this.captionPackets_.length) {
- this.flushCCStreams(flushType);
- return;
- }
- this.captionPackets_.forEach(function(elem, idx) {
- elem.presortIndex = idx;
- });
- this.captionPackets_.sort(function(a, b) {
- if (a.pts === b.pts) {
- return a.presortIndex - b.presortIndex;
- }
- return a.pts - b.pts;
- });
- this.captionPackets_.forEach(function(packet) {
- if (packet.type < 2) {
- this.dispatchCea608Packet(packet);
- } else {
- this.dispatchCea708Packet(packet);
- }
- }, this);
- this.captionPackets_.length = 0;
- this.flushCCStreams(flushType);
- };
- CaptionStream$2.prototype.flush = function() {
- return this.flushStream("flush");
- };
- CaptionStream$2.prototype.partialFlush = function() {
- return this.flushStream("partialFlush");
- };
- CaptionStream$2.prototype.reset = function() {
- this.latestDts_ = null;
- this.ignoreNextEqualDts_ = false;
- this.numSameDts_ = 0;
- this.activeCea608Channel_ = [null, null];
- this.ccStreams_.forEach(function(ccStream) {
- ccStream.reset();
- });
- };
- CaptionStream$2.prototype.dispatchCea608Packet = function(packet) {
- if (this.setsTextOrXDSActive(packet)) {
- this.activeCea608Channel_[packet.type] = null;
- } else if (this.setsChannel1Active(packet)) {
- this.activeCea608Channel_[packet.type] = 0;
- } else if (this.setsChannel2Active(packet)) {
- this.activeCea608Channel_[packet.type] = 1;
- }
- if (this.activeCea608Channel_[packet.type] === null) {
- return;
- }
- this.ccStreams_[(packet.type << 1) + this.activeCea608Channel_[packet.type]].push(packet);
- };
- CaptionStream$2.prototype.setsChannel1Active = function(packet) {
- return (packet.ccData & 30720) === 4096;
- };
- CaptionStream$2.prototype.setsChannel2Active = function(packet) {
- return (packet.ccData & 30720) === 6144;
- };
- CaptionStream$2.prototype.setsTextOrXDSActive = function(packet) {
- return (packet.ccData & 28928) === 256 || (packet.ccData & 30974) === 4138 || (packet.ccData & 30974) === 6186;
- };
- CaptionStream$2.prototype.dispatchCea708Packet = function(packet) {
- if (this.parse708captions_) {
- this.cc708Stream_.push(packet);
- }
- };
- var CHARACTER_TRANSLATION_708 = {
- 127: 9834,
- 4128: 32,
- 4129: 160,
- 4133: 8230,
- 4138: 352,
- 4140: 338,
- 4144: 9608,
- 4145: 8216,
- 4146: 8217,
- 4147: 8220,
- 4148: 8221,
- 4149: 8226,
- 4153: 8482,
- 4154: 353,
- 4156: 339,
- 4157: 8480,
- 4159: 376,
- 4214: 8539,
- 4215: 8540,
- 4216: 8541,
- 4217: 8542,
- 4218: 9168,
- 4219: 9124,
- 4220: 9123,
- 4221: 9135,
- 4222: 9126,
- 4223: 9121,
- 4256: 12600
- };
- var get708CharFromCode = function(code) {
- var newCode = CHARACTER_TRANSLATION_708[code] || code;
- if (code & 4096 && code === newCode) {
- return "";
- }
- return String.fromCharCode(newCode);
- };
- var within708TextBlock = function(b) {
- return 32 <= b && b <= 127 || 160 <= b && b <= 255;
- };
- var Cea708Window = function(windowNum) {
- this.windowNum = windowNum;
- this.reset();
- };
- Cea708Window.prototype.reset = function() {
- this.clearText();
- this.pendingNewLine = false;
- this.winAttr = {};
- this.penAttr = {};
- this.penLoc = {};
- this.penColor = {};
- this.visible = 0;
- this.rowLock = 0;
- this.columnLock = 0;
- this.priority = 0;
- this.relativePositioning = 0;
- this.anchorVertical = 0;
- this.anchorHorizontal = 0;
- this.anchorPoint = 0;
- this.rowCount = 1;
- this.virtualRowCount = this.rowCount + 1;
- this.columnCount = 41;
- this.windowStyle = 0;
- this.penStyle = 0;
- };
- Cea708Window.prototype.getText = function() {
- return this.rows.join("\n");
- };
- Cea708Window.prototype.clearText = function() {
- this.rows = [""];
- this.rowIdx = 0;
- };
- Cea708Window.prototype.newLine = function(pts) {
- if (this.rows.length >= this.virtualRowCount && typeof this.beforeRowOverflow === "function") {
- this.beforeRowOverflow(pts);
- }
- if (this.rows.length > 0) {
- this.rows.push("");
- this.rowIdx++;
- }
- while (this.rows.length > this.virtualRowCount) {
- this.rows.shift();
- this.rowIdx--;
- }
- };
- Cea708Window.prototype.isEmpty = function() {
- if (this.rows.length === 0) {
- return true;
- } else if (this.rows.length === 1) {
- return this.rows[0] === "";
- }
- return false;
- };
- Cea708Window.prototype.addText = function(text) {
- this.rows[this.rowIdx] += text;
- };
- Cea708Window.prototype.backspace = function() {
- if (!this.isEmpty()) {
- var row = this.rows[this.rowIdx];
- this.rows[this.rowIdx] = row.substr(0, row.length - 1);
- }
- };
- var Cea708Service = function(serviceNum, encoding, stream2) {
- this.serviceNum = serviceNum;
- this.text = "";
- this.currentWindow = new Cea708Window(-1);
- this.windows = [];
- this.stream = stream2;
- if (typeof encoding === "string") {
- this.createTextDecoder(encoding);
- }
- };
- Cea708Service.prototype.init = function(pts, beforeRowOverflow) {
- this.startPts = pts;
- for (var win3 = 0; win3 < 8; win3++) {
- this.windows[win3] = new Cea708Window(win3);
- if (typeof beforeRowOverflow === "function") {
- this.windows[win3].beforeRowOverflow = beforeRowOverflow;
- }
- }
- };
- Cea708Service.prototype.setCurrentWindow = function(windowNum) {
- this.currentWindow = this.windows[windowNum];
- };
- Cea708Service.prototype.createTextDecoder = function(encoding) {
- if (typeof TextDecoder === "undefined") {
- this.stream.trigger("log", {
- level: "warn",
- message: "The `encoding` option is unsupported without TextDecoder support"
- });
- } else {
- try {
- this.textDecoder_ = new TextDecoder(encoding);
- } catch (error) {
- this.stream.trigger("log", {
- level: "warn",
- message: "TextDecoder could not be created with " + encoding + " encoding. " + error
- });
- }
- }
- };
- var Cea708Stream = function(options2) {
- options2 = options2 || {};
- Cea708Stream.prototype.init.call(this);
- var self2 = this;
- var captionServices = options2.captionServices || {};
- var captionServiceEncodings = {};
- var serviceProps;
- Object.keys(captionServices).forEach((serviceName) => {
- serviceProps = captionServices[serviceName];
- if (/^SERVICE/.test(serviceName)) {
- captionServiceEncodings[serviceName] = serviceProps.encoding;
- }
- });
- this.serviceEncodings = captionServiceEncodings;
- this.current708Packet = null;
- this.services = {};
- this.push = function(packet) {
- if (packet.type === 3) {
- self2.new708Packet();
- self2.add708Bytes(packet);
- } else {
- if (self2.current708Packet === null) {
- self2.new708Packet();
- }
- self2.add708Bytes(packet);
- }
- };
- };
- Cea708Stream.prototype = new Stream$7();
- Cea708Stream.prototype.new708Packet = function() {
- if (this.current708Packet !== null) {
- this.push708Packet();
- }
- this.current708Packet = {
- data: [],
- ptsVals: []
- };
- };
- Cea708Stream.prototype.add708Bytes = function(packet) {
- var data = packet.ccData;
- var byte0 = data >>> 8;
- var byte1 = data & 255;
- this.current708Packet.ptsVals.push(packet.pts);
- this.current708Packet.data.push(byte0);
- this.current708Packet.data.push(byte1);
- };
- Cea708Stream.prototype.push708Packet = function() {
- var packet708 = this.current708Packet;
- var packetData = packet708.data;
- var serviceNum = null;
- var blockSize = null;
- var i2 = 0;
- var b = packetData[i2++];
- packet708.seq = b >> 6;
- packet708.sizeCode = b & 63;
- for (; i2 < packetData.length; i2++) {
- b = packetData[i2++];
- serviceNum = b >> 5;
- blockSize = b & 31;
- if (serviceNum === 7 && blockSize > 0) {
- b = packetData[i2++];
- serviceNum = b;
- }
- this.pushServiceBlock(serviceNum, i2, blockSize);
- if (blockSize > 0) {
- i2 += blockSize - 1;
- }
- }
- };
- Cea708Stream.prototype.pushServiceBlock = function(serviceNum, start2, size) {
- var b;
- var i2 = start2;
- var packetData = this.current708Packet.data;
- var service = this.services[serviceNum];
- if (!service) {
- service = this.initService(serviceNum, i2);
- }
- for (; i2 < start2 + size && i2 < packetData.length; i2++) {
- b = packetData[i2];
- if (within708TextBlock(b)) {
- i2 = this.handleText(i2, service);
- } else if (b === 24) {
- i2 = this.multiByteCharacter(i2, service);
- } else if (b === 16) {
- i2 = this.extendedCommands(i2, service);
- } else if (128 <= b && b <= 135) {
- i2 = this.setCurrentWindow(i2, service);
- } else if (152 <= b && b <= 159) {
- i2 = this.defineWindow(i2, service);
- } else if (b === 136) {
- i2 = this.clearWindows(i2, service);
- } else if (b === 140) {
- i2 = this.deleteWindows(i2, service);
- } else if (b === 137) {
- i2 = this.displayWindows(i2, service);
- } else if (b === 138) {
- i2 = this.hideWindows(i2, service);
- } else if (b === 139) {
- i2 = this.toggleWindows(i2, service);
- } else if (b === 151) {
- i2 = this.setWindowAttributes(i2, service);
- } else if (b === 144) {
- i2 = this.setPenAttributes(i2, service);
- } else if (b === 145) {
- i2 = this.setPenColor(i2, service);
- } else if (b === 146) {
- i2 = this.setPenLocation(i2, service);
- } else if (b === 143) {
- service = this.reset(i2, service);
- } else if (b === 8) {
- service.currentWindow.backspace();
- } else if (b === 12) {
- service.currentWindow.clearText();
- } else if (b === 13) {
- service.currentWindow.pendingNewLine = true;
- } else if (b === 14) {
- service.currentWindow.clearText();
- } else if (b === 141) {
- i2++;
- } else
- ;
- }
- };
- Cea708Stream.prototype.extendedCommands = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- if (within708TextBlock(b)) {
- i2 = this.handleText(i2, service, {
- isExtended: true
- });
- }
- return i2;
- };
- Cea708Stream.prototype.getPts = function(byteIndex) {
- return this.current708Packet.ptsVals[Math.floor(byteIndex / 2)];
- };
- Cea708Stream.prototype.initService = function(serviceNum, i2) {
- var serviceName = "SERVICE" + serviceNum;
- var self2 = this;
- var serviceName;
- var encoding;
- if (serviceName in this.serviceEncodings) {
- encoding = this.serviceEncodings[serviceName];
- }
- this.services[serviceNum] = new Cea708Service(serviceNum, encoding, self2);
- this.services[serviceNum].init(this.getPts(i2), function(pts) {
- self2.flushDisplayed(pts, self2.services[serviceNum]);
- });
- return this.services[serviceNum];
- };
- Cea708Stream.prototype.handleText = function(i2, service, options2) {
- var isExtended = options2 && options2.isExtended;
- var isMultiByte = options2 && options2.isMultiByte;
- var packetData = this.current708Packet.data;
- var extended = isExtended ? 4096 : 0;
- var currentByte = packetData[i2];
- var nextByte = packetData[i2 + 1];
- var win3 = service.currentWindow;
- var char;
- var charCodeArray;
- if (service.textDecoder_ && !isExtended) {
- if (isMultiByte) {
- charCodeArray = [currentByte, nextByte];
- i2++;
- } else {
- charCodeArray = [currentByte];
- }
- char = service.textDecoder_.decode(new Uint8Array(charCodeArray));
- } else {
- char = get708CharFromCode(extended | currentByte);
- }
- if (win3.pendingNewLine && !win3.isEmpty()) {
- win3.newLine(this.getPts(i2));
- }
- win3.pendingNewLine = false;
- win3.addText(char);
- return i2;
- };
- Cea708Stream.prototype.multiByteCharacter = function(i2, service) {
- var packetData = this.current708Packet.data;
- var firstByte = packetData[i2 + 1];
- var secondByte = packetData[i2 + 2];
- if (within708TextBlock(firstByte) && within708TextBlock(secondByte)) {
- i2 = this.handleText(++i2, service, {
- isMultiByte: true
- });
- }
- return i2;
- };
- Cea708Stream.prototype.setCurrentWindow = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var windowNum = b & 7;
- service.setCurrentWindow(windowNum);
- return i2;
- };
- Cea708Stream.prototype.defineWindow = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var windowNum = b & 7;
- service.setCurrentWindow(windowNum);
- var win3 = service.currentWindow;
- b = packetData[++i2];
- win3.visible = (b & 32) >> 5;
- win3.rowLock = (b & 16) >> 4;
- win3.columnLock = (b & 8) >> 3;
- win3.priority = b & 7;
- b = packetData[++i2];
- win3.relativePositioning = (b & 128) >> 7;
- win3.anchorVertical = b & 127;
- b = packetData[++i2];
- win3.anchorHorizontal = b;
- b = packetData[++i2];
- win3.anchorPoint = (b & 240) >> 4;
- win3.rowCount = b & 15;
- b = packetData[++i2];
- win3.columnCount = b & 63;
- b = packetData[++i2];
- win3.windowStyle = (b & 56) >> 3;
- win3.penStyle = b & 7;
- win3.virtualRowCount = win3.rowCount + 1;
- return i2;
- };
- Cea708Stream.prototype.setWindowAttributes = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var winAttr = service.currentWindow.winAttr;
- b = packetData[++i2];
- winAttr.fillOpacity = (b & 192) >> 6;
- winAttr.fillRed = (b & 48) >> 4;
- winAttr.fillGreen = (b & 12) >> 2;
- winAttr.fillBlue = b & 3;
- b = packetData[++i2];
- winAttr.borderType = (b & 192) >> 6;
- winAttr.borderRed = (b & 48) >> 4;
- winAttr.borderGreen = (b & 12) >> 2;
- winAttr.borderBlue = b & 3;
- b = packetData[++i2];
- winAttr.borderType += (b & 128) >> 5;
- winAttr.wordWrap = (b & 64) >> 6;
- winAttr.printDirection = (b & 48) >> 4;
- winAttr.scrollDirection = (b & 12) >> 2;
- winAttr.justify = b & 3;
- b = packetData[++i2];
- winAttr.effectSpeed = (b & 240) >> 4;
- winAttr.effectDirection = (b & 12) >> 2;
- winAttr.displayEffect = b & 3;
- return i2;
- };
- Cea708Stream.prototype.flushDisplayed = function(pts, service) {
- var displayedText = [];
- for (var winId = 0; winId < 8; winId++) {
- if (service.windows[winId].visible && !service.windows[winId].isEmpty()) {
- displayedText.push(service.windows[winId].getText());
- }
- }
- service.endPts = pts;
- service.text = displayedText.join("\n\n");
- this.pushCaption(service);
- service.startPts = pts;
- };
- Cea708Stream.prototype.pushCaption = function(service) {
- if (service.text !== "") {
- this.trigger("data", {
- startPts: service.startPts,
- endPts: service.endPts,
- text: service.text,
- stream: "cc708_" + service.serviceNum
- });
- service.text = "";
- service.startPts = service.endPts;
- }
- };
- Cea708Stream.prototype.displayWindows = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- for (var winId = 0; winId < 8; winId++) {
- if (b & 1 << winId) {
- service.windows[winId].visible = 1;
- }
- }
- return i2;
- };
- Cea708Stream.prototype.hideWindows = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- for (var winId = 0; winId < 8; winId++) {
- if (b & 1 << winId) {
- service.windows[winId].visible = 0;
- }
- }
- return i2;
- };
- Cea708Stream.prototype.toggleWindows = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- for (var winId = 0; winId < 8; winId++) {
- if (b & 1 << winId) {
- service.windows[winId].visible ^= 1;
- }
- }
- return i2;
- };
- Cea708Stream.prototype.clearWindows = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- for (var winId = 0; winId < 8; winId++) {
- if (b & 1 << winId) {
- service.windows[winId].clearText();
- }
- }
- return i2;
- };
- Cea708Stream.prototype.deleteWindows = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- for (var winId = 0; winId < 8; winId++) {
- if (b & 1 << winId) {
- service.windows[winId].reset();
- }
- }
- return i2;
- };
- Cea708Stream.prototype.setPenAttributes = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var penAttr = service.currentWindow.penAttr;
- b = packetData[++i2];
- penAttr.textTag = (b & 240) >> 4;
- penAttr.offset = (b & 12) >> 2;
- penAttr.penSize = b & 3;
- b = packetData[++i2];
- penAttr.italics = (b & 128) >> 7;
- penAttr.underline = (b & 64) >> 6;
- penAttr.edgeType = (b & 56) >> 3;
- penAttr.fontStyle = b & 7;
- return i2;
- };
- Cea708Stream.prototype.setPenColor = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var penColor = service.currentWindow.penColor;
- b = packetData[++i2];
- penColor.fgOpacity = (b & 192) >> 6;
- penColor.fgRed = (b & 48) >> 4;
- penColor.fgGreen = (b & 12) >> 2;
- penColor.fgBlue = b & 3;
- b = packetData[++i2];
- penColor.bgOpacity = (b & 192) >> 6;
- penColor.bgRed = (b & 48) >> 4;
- penColor.bgGreen = (b & 12) >> 2;
- penColor.bgBlue = b & 3;
- b = packetData[++i2];
- penColor.edgeRed = (b & 48) >> 4;
- penColor.edgeGreen = (b & 12) >> 2;
- penColor.edgeBlue = b & 3;
- return i2;
- };
- Cea708Stream.prototype.setPenLocation = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var penLoc = service.currentWindow.penLoc;
- service.currentWindow.pendingNewLine = true;
- b = packetData[++i2];
- penLoc.row = b & 15;
- b = packetData[++i2];
- penLoc.column = b & 63;
- return i2;
- };
- Cea708Stream.prototype.reset = function(i2, service) {
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- return this.initService(service.serviceNum, i2);
- };
- var CHARACTER_TRANSLATION = {
- 42: 225,
- 92: 233,
- 94: 237,
- 95: 243,
- 96: 250,
- 123: 231,
- 124: 247,
- 125: 209,
- 126: 241,
- 127: 9608,
- 304: 174,
- 305: 176,
- 306: 189,
- 307: 191,
- 308: 8482,
- 309: 162,
- 310: 163,
- 311: 9834,
- 312: 224,
- 313: 160,
- 314: 232,
- 315: 226,
- 316: 234,
- 317: 238,
- 318: 244,
- 319: 251,
- 544: 193,
- 545: 201,
- 546: 211,
- 547: 218,
- 548: 220,
- 549: 252,
- 550: 8216,
- 551: 161,
- 552: 42,
- 553: 39,
- 554: 8212,
- 555: 169,
- 556: 8480,
- 557: 8226,
- 558: 8220,
- 559: 8221,
- 560: 192,
- 561: 194,
- 562: 199,
- 563: 200,
- 564: 202,
- 565: 203,
- 566: 235,
- 567: 206,
- 568: 207,
- 569: 239,
- 570: 212,
- 571: 217,
- 572: 249,
- 573: 219,
- 574: 171,
- 575: 187,
- 800: 195,
- 801: 227,
- 802: 205,
- 803: 204,
- 804: 236,
- 805: 210,
- 806: 242,
- 807: 213,
- 808: 245,
- 809: 123,
- 810: 125,
- 811: 92,
- 812: 94,
- 813: 95,
- 814: 124,
- 815: 126,
- 816: 196,
- 817: 228,
- 818: 214,
- 819: 246,
- 820: 223,
- 821: 165,
- 822: 164,
- 823: 9474,
- 824: 197,
- 825: 229,
- 826: 216,
- 827: 248,
- 828: 9484,
- 829: 9488,
- 830: 9492,
- 831: 9496
- };
- var getCharFromCode = function(code) {
- if (code === null) {
- return "";
- }
- code = CHARACTER_TRANSLATION[code] || code;
- return String.fromCharCode(code);
- };
- var BOTTOM_ROW = 14;
- var ROWS = [4352, 4384, 4608, 4640, 5376, 5408, 5632, 5664, 5888, 5920, 4096, 4864, 4896, 5120, 5152];
- var createDisplayBuffer = function() {
- var result = [], i2 = BOTTOM_ROW + 1;
- while (i2--) {
- result.push("");
- }
- return result;
- };
- var Cea608Stream = function(field, dataChannel) {
- Cea608Stream.prototype.init.call(this);
- this.field_ = field || 0;
- this.dataChannel_ = dataChannel || 0;
- this.name_ = "CC" + ((this.field_ << 1 | this.dataChannel_) + 1);
- this.setConstants();
- this.reset();
- this.push = function(packet) {
- var data, swap, char0, char1, text;
- data = packet.ccData & 32639;
- if (data === this.lastControlCode_) {
- this.lastControlCode_ = null;
- return;
- }
- if ((data & 61440) === 4096) {
- this.lastControlCode_ = data;
- } else if (data !== this.PADDING_) {
- this.lastControlCode_ = null;
- }
- char0 = data >>> 8;
- char1 = data & 255;
- if (data === this.PADDING_) {
- return;
- } else if (data === this.RESUME_CAPTION_LOADING_) {
- this.mode_ = "popOn";
- } else if (data === this.END_OF_CAPTION_) {
- this.mode_ = "popOn";
- this.clearFormatting(packet.pts);
- this.flushDisplayed(packet.pts);
- swap = this.displayed_;
- this.displayed_ = this.nonDisplayed_;
- this.nonDisplayed_ = swap;
- this.startPts_ = packet.pts;
- } else if (data === this.ROLL_UP_2_ROWS_) {
- this.rollUpRows_ = 2;
- this.setRollUp(packet.pts);
- } else if (data === this.ROLL_UP_3_ROWS_) {
- this.rollUpRows_ = 3;
- this.setRollUp(packet.pts);
- } else if (data === this.ROLL_UP_4_ROWS_) {
- this.rollUpRows_ = 4;
- this.setRollUp(packet.pts);
- } else if (data === this.CARRIAGE_RETURN_) {
- this.clearFormatting(packet.pts);
- this.flushDisplayed(packet.pts);
- this.shiftRowsUp_();
- this.startPts_ = packet.pts;
- } else if (data === this.BACKSPACE_) {
- if (this.mode_ === "popOn") {
- this.nonDisplayed_[this.row_] = this.nonDisplayed_[this.row_].slice(0, -1);
- } else {
- this.displayed_[this.row_] = this.displayed_[this.row_].slice(0, -1);
- }
- } else if (data === this.ERASE_DISPLAYED_MEMORY_) {
- this.flushDisplayed(packet.pts);
- this.displayed_ = createDisplayBuffer();
- } else if (data === this.ERASE_NON_DISPLAYED_MEMORY_) {
- this.nonDisplayed_ = createDisplayBuffer();
- } else if (data === this.RESUME_DIRECT_CAPTIONING_) {
- if (this.mode_ !== "paintOn") {
- this.flushDisplayed(packet.pts);
- this.displayed_ = createDisplayBuffer();
- }
- this.mode_ = "paintOn";
- this.startPts_ = packet.pts;
- } else if (this.isSpecialCharacter(char0, char1)) {
- char0 = (char0 & 3) << 8;
- text = getCharFromCode(char0 | char1);
- this[this.mode_](packet.pts, text);
- this.column_++;
- } else if (this.isExtCharacter(char0, char1)) {
- if (this.mode_ === "popOn") {
- this.nonDisplayed_[this.row_] = this.nonDisplayed_[this.row_].slice(0, -1);
- } else {
- this.displayed_[this.row_] = this.displayed_[this.row_].slice(0, -1);
- }
- char0 = (char0 & 3) << 8;
- text = getCharFromCode(char0 | char1);
- this[this.mode_](packet.pts, text);
- this.column_++;
- } else if (this.isMidRowCode(char0, char1)) {
- this.clearFormatting(packet.pts);
- this[this.mode_](packet.pts, " ");
- this.column_++;
- if ((char1 & 14) === 14) {
- this.addFormatting(packet.pts, ["i"]);
- }
- if ((char1 & 1) === 1) {
- this.addFormatting(packet.pts, ["u"]);
- }
- } else if (this.isOffsetControlCode(char0, char1)) {
- this.column_ += char1 & 3;
- } else if (this.isPAC(char0, char1)) {
- var row = ROWS.indexOf(data & 7968);
- if (this.mode_ === "rollUp") {
- if (row - this.rollUpRows_ + 1 < 0) {
- row = this.rollUpRows_ - 1;
- }
- this.setRollUp(packet.pts, row);
- }
- if (row !== this.row_) {
- this.clearFormatting(packet.pts);
- this.row_ = row;
- }
- if (char1 & 1 && this.formatting_.indexOf("u") === -1) {
- this.addFormatting(packet.pts, ["u"]);
- }
- if ((data & 16) === 16) {
- this.column_ = ((data & 14) >> 1) * 4;
- }
- if (this.isColorPAC(char1)) {
- if ((char1 & 14) === 14) {
- this.addFormatting(packet.pts, ["i"]);
- }
- }
- } else if (this.isNormalChar(char0)) {
- if (char1 === 0) {
- char1 = null;
- }
- text = getCharFromCode(char0);
- text += getCharFromCode(char1);
- this[this.mode_](packet.pts, text);
- this.column_ += text.length;
- }
- };
- };
- Cea608Stream.prototype = new Stream$7();
- Cea608Stream.prototype.flushDisplayed = function(pts) {
- var content = this.displayed_.map(function(row, index2) {
- try {
- return row.trim();
- } catch (e) {
- this.trigger("log", {
- level: "warn",
- message: "Skipping a malformed 608 caption at index " + index2 + "."
- });
- return "";
- }
- }, this).join("\n").replace(/^\n+|\n+$/g, "");
- if (content.length) {
- this.trigger("data", {
- startPts: this.startPts_,
- endPts: pts,
- text: content,
- stream: this.name_
- });
- }
- };
- Cea608Stream.prototype.reset = function() {
- this.mode_ = "popOn";
- this.topRow_ = 0;
- this.startPts_ = 0;
- this.displayed_ = createDisplayBuffer();
- this.nonDisplayed_ = createDisplayBuffer();
- this.lastControlCode_ = null;
- this.column_ = 0;
- this.row_ = BOTTOM_ROW;
- this.rollUpRows_ = 2;
- this.formatting_ = [];
- };
- Cea608Stream.prototype.setConstants = function() {
- if (this.dataChannel_ === 0) {
- this.BASE_ = 16;
- this.EXT_ = 17;
- this.CONTROL_ = (20 | this.field_) << 8;
- this.OFFSET_ = 23;
- } else if (this.dataChannel_ === 1) {
- this.BASE_ = 24;
- this.EXT_ = 25;
- this.CONTROL_ = (28 | this.field_) << 8;
- this.OFFSET_ = 31;
- }
- this.PADDING_ = 0;
- this.RESUME_CAPTION_LOADING_ = this.CONTROL_ | 32;
- this.END_OF_CAPTION_ = this.CONTROL_ | 47;
- this.ROLL_UP_2_ROWS_ = this.CONTROL_ | 37;
- this.ROLL_UP_3_ROWS_ = this.CONTROL_ | 38;
- this.ROLL_UP_4_ROWS_ = this.CONTROL_ | 39;
- this.CARRIAGE_RETURN_ = this.CONTROL_ | 45;
- this.RESUME_DIRECT_CAPTIONING_ = this.CONTROL_ | 41;
- this.BACKSPACE_ = this.CONTROL_ | 33;
- this.ERASE_DISPLAYED_MEMORY_ = this.CONTROL_ | 44;
- this.ERASE_NON_DISPLAYED_MEMORY_ = this.CONTROL_ | 46;
- };
- Cea608Stream.prototype.isSpecialCharacter = function(char0, char1) {
- return char0 === this.EXT_ && char1 >= 48 && char1 <= 63;
- };
- Cea608Stream.prototype.isExtCharacter = function(char0, char1) {
- return (char0 === this.EXT_ + 1 || char0 === this.EXT_ + 2) && char1 >= 32 && char1 <= 63;
- };
- Cea608Stream.prototype.isMidRowCode = function(char0, char1) {
- return char0 === this.EXT_ && char1 >= 32 && char1 <= 47;
- };
- Cea608Stream.prototype.isOffsetControlCode = function(char0, char1) {
- return char0 === this.OFFSET_ && char1 >= 33 && char1 <= 35;
- };
- Cea608Stream.prototype.isPAC = function(char0, char1) {
- return char0 >= this.BASE_ && char0 < this.BASE_ + 8 && char1 >= 64 && char1 <= 127;
- };
- Cea608Stream.prototype.isColorPAC = function(char1) {
- return char1 >= 64 && char1 <= 79 || char1 >= 96 && char1 <= 127;
- };
- Cea608Stream.prototype.isNormalChar = function(char) {
- return char >= 32 && char <= 127;
- };
- Cea608Stream.prototype.setRollUp = function(pts, newBaseRow) {
- if (this.mode_ !== "rollUp") {
- this.row_ = BOTTOM_ROW;
- this.mode_ = "rollUp";
- this.flushDisplayed(pts);
- this.nonDisplayed_ = createDisplayBuffer();
- this.displayed_ = createDisplayBuffer();
- }
- if (newBaseRow !== void 0 && newBaseRow !== this.row_) {
- for (var i2 = 0; i2 < this.rollUpRows_; i2++) {
- this.displayed_[newBaseRow - i2] = this.displayed_[this.row_ - i2];
- this.displayed_[this.row_ - i2] = "";
- }
- }
- if (newBaseRow === void 0) {
- newBaseRow = this.row_;
- }
- this.topRow_ = newBaseRow - this.rollUpRows_ + 1;
- };
- Cea608Stream.prototype.addFormatting = function(pts, format) {
- this.formatting_ = this.formatting_.concat(format);
- var text = format.reduce(function(text2, format2) {
- return text2 + "<" + format2 + ">";
- }, "");
- this[this.mode_](pts, text);
- };
- Cea608Stream.prototype.clearFormatting = function(pts) {
- if (!this.formatting_.length) {
- return;
- }
- var text = this.formatting_.reverse().reduce(function(text2, format) {
- return text2 + "</" + format + ">";
- }, "");
- this.formatting_ = [];
- this[this.mode_](pts, text);
- };
- Cea608Stream.prototype.popOn = function(pts, text) {
- var baseRow = this.nonDisplayed_[this.row_];
- baseRow += text;
- this.nonDisplayed_[this.row_] = baseRow;
- };
- Cea608Stream.prototype.rollUp = function(pts, text) {
- var baseRow = this.displayed_[this.row_];
- baseRow += text;
- this.displayed_[this.row_] = baseRow;
- };
- Cea608Stream.prototype.shiftRowsUp_ = function() {
- var i2;
- for (i2 = 0; i2 < this.topRow_; i2++) {
- this.displayed_[i2] = "";
- }
- for (i2 = this.row_ + 1; i2 < BOTTOM_ROW + 1; i2++) {
- this.displayed_[i2] = "";
- }
- for (i2 = this.topRow_; i2 < this.row_; i2++) {
- this.displayed_[i2] = this.displayed_[i2 + 1];
- }
- this.displayed_[this.row_] = "";
- };
- Cea608Stream.prototype.paintOn = function(pts, text) {
- var baseRow = this.displayed_[this.row_];
- baseRow += text;
- this.displayed_[this.row_] = baseRow;
- };
- var captionStream = {
- CaptionStream: CaptionStream$2,
- Cea608Stream,
- Cea708Stream
- };
- var streamTypes = {
- H264_STREAM_TYPE: 27,
- ADTS_STREAM_TYPE: 15,
- METADATA_STREAM_TYPE: 21
- };
- var Stream$6 = stream;
- var MAX_TS = 8589934592;
- var RO_THRESH = 4294967296;
- var TYPE_SHARED = "shared";
- var handleRollover$1 = function(value, reference) {
- var direction = 1;
- if (value > reference) {
- direction = -1;
- }
- while (Math.abs(reference - value) > RO_THRESH) {
- value += direction * MAX_TS;
- }
- return value;
- };
- var TimestampRolloverStream$1 = function(type3) {
- var lastDTS, referenceDTS;
- TimestampRolloverStream$1.prototype.init.call(this);
- this.type_ = type3 || TYPE_SHARED;
- this.push = function(data) {
- if (this.type_ !== TYPE_SHARED && data.type !== this.type_) {
- return;
- }
- if (referenceDTS === void 0) {
- referenceDTS = data.dts;
- }
- data.dts = handleRollover$1(data.dts, referenceDTS);
- data.pts = handleRollover$1(data.pts, referenceDTS);
- lastDTS = data.dts;
- this.trigger("data", data);
- };
- this.flush = function() {
- referenceDTS = lastDTS;
- this.trigger("done");
- };
- this.endTimeline = function() {
- this.flush();
- this.trigger("endedtimeline");
- };
- this.discontinuity = function() {
- referenceDTS = void 0;
- lastDTS = void 0;
- };
- this.reset = function() {
- this.discontinuity();
- this.trigger("reset");
- };
- };
- TimestampRolloverStream$1.prototype = new Stream$6();
- var timestampRolloverStream = {
- TimestampRolloverStream: TimestampRolloverStream$1,
- handleRollover: handleRollover$1
- };
- var typedArrayIndexOf$1 = (typedArray2, element, fromIndex) => {
- if (!typedArray2) {
- return -1;
- }
- var currentIndex = fromIndex;
- for (; currentIndex < typedArray2.length; currentIndex++) {
- if (typedArray2[currentIndex] === element) {
- return currentIndex;
- }
- }
- return -1;
- };
- var typedArray = {
- typedArrayIndexOf: typedArrayIndexOf$1
- };
- var typedArrayIndexOf = typedArray.typedArrayIndexOf, textEncodingDescriptionByte = {
- Iso88591: 0,
- Utf16: 1,
- Utf16be: 2,
- Utf8: 3
- }, percentEncode$1 = function(bytes, start2, end) {
- var i2, result = "";
- for (i2 = start2; i2 < end; i2++) {
- result += "%" + ("00" + bytes[i2].toString(16)).slice(-2);
- }
- return result;
- }, parseUtf8 = function(bytes, start2, end) {
- return decodeURIComponent(percentEncode$1(bytes, start2, end));
- }, parseIso88591$1 = function(bytes, start2, end) {
- return unescape(percentEncode$1(bytes, start2, end));
- }, parseSyncSafeInteger$1 = function(data) {
- return data[0] << 21 | data[1] << 14 | data[2] << 7 | data[3];
- }, frameParsers = {
- "APIC": function(frame) {
- var i2 = 1, mimeTypeEndIndex, descriptionEndIndex, LINK_MIME_TYPE = "-->";
- if (frame.data[0] !== textEncodingDescriptionByte.Utf8) {
- return;
- }
- mimeTypeEndIndex = typedArrayIndexOf(frame.data, 0, i2);
- if (mimeTypeEndIndex < 0) {
- return;
- }
- frame.mimeType = parseIso88591$1(frame.data, i2, mimeTypeEndIndex);
- i2 = mimeTypeEndIndex + 1;
- frame.pictureType = frame.data[i2];
- i2++;
- descriptionEndIndex = typedArrayIndexOf(frame.data, 0, i2);
- if (descriptionEndIndex < 0) {
- return;
- }
- frame.description = parseUtf8(frame.data, i2, descriptionEndIndex);
- i2 = descriptionEndIndex + 1;
- if (frame.mimeType === LINK_MIME_TYPE) {
- frame.url = parseIso88591$1(frame.data, i2, frame.data.length);
- } else {
- frame.pictureData = frame.data.subarray(i2, frame.data.length);
- }
- },
- "T*": function(frame) {
- if (frame.data[0] !== textEncodingDescriptionByte.Utf8) {
- return;
- }
- frame.value = parseUtf8(frame.data, 1, frame.data.length).replace(/\0*$/, "");
- frame.values = frame.value.split("\0");
- },
- "TXXX": function(frame) {
- var descriptionEndIndex;
- if (frame.data[0] !== textEncodingDescriptionByte.Utf8) {
- return;
- }
- descriptionEndIndex = typedArrayIndexOf(frame.data, 0, 1);
- if (descriptionEndIndex === -1) {
- return;
- }
- frame.description = parseUtf8(frame.data, 1, descriptionEndIndex);
- frame.value = parseUtf8(frame.data, descriptionEndIndex + 1, frame.data.length).replace(/\0*$/, "");
- frame.data = frame.value;
- },
- "W*": function(frame) {
- frame.url = parseIso88591$1(frame.data, 0, frame.data.length).replace(/\0.*$/, "");
- },
- "WXXX": function(frame) {
- var descriptionEndIndex;
- if (frame.data[0] !== textEncodingDescriptionByte.Utf8) {
- return;
- }
- descriptionEndIndex = typedArrayIndexOf(frame.data, 0, 1);
- if (descriptionEndIndex === -1) {
- return;
- }
- frame.description = parseUtf8(frame.data, 1, descriptionEndIndex);
- frame.url = parseIso88591$1(frame.data, descriptionEndIndex + 1, frame.data.length).replace(/\0.*$/, "");
- },
- "PRIV": function(frame) {
- var i2;
- for (i2 = 0; i2 < frame.data.length; i2++) {
- if (frame.data[i2] === 0) {
- frame.owner = parseIso88591$1(frame.data, 0, i2);
- break;
- }
- }
- frame.privateData = frame.data.subarray(i2 + 1);
- frame.data = frame.privateData;
- }
- };
- var parseId3Frames$1 = function(data) {
- var frameSize, frameHeader, frameStart = 10, tagSize = 0, frames = [];
- if (data.length < 10 || data[0] !== "I".charCodeAt(0) || data[1] !== "D".charCodeAt(0) || data[2] !== "3".charCodeAt(0)) {
- return;
- }
- tagSize = parseSyncSafeInteger$1(data.subarray(6, 10));
- tagSize += 10;
- var hasExtendedHeader = data[5] & 64;
- if (hasExtendedHeader) {
- frameStart += 4;
- frameStart += parseSyncSafeInteger$1(data.subarray(10, 14));
- tagSize -= parseSyncSafeInteger$1(data.subarray(16, 20));
- }
- do {
- frameSize = parseSyncSafeInteger$1(data.subarray(frameStart + 4, frameStart + 8));
- if (frameSize < 1) {
- break;
- }
- frameHeader = String.fromCharCode(data[frameStart], data[frameStart + 1], data[frameStart + 2], data[frameStart + 3]);
- var frame = {
- id: frameHeader,
- data: data.subarray(frameStart + 10, frameStart + frameSize + 10)
- };
- frame.key = frame.id;
- if (frameParsers[frame.id]) {
- frameParsers[frame.id](frame);
- } else if (frame.id[0] === "T") {
- frameParsers["T*"](frame);
- } else if (frame.id[0] === "W") {
- frameParsers["W*"](frame);
- }
- frames.push(frame);
- frameStart += 10;
- frameStart += frameSize;
- } while (frameStart < tagSize);
- return frames;
- };
- var parseId3 = {
- parseId3Frames: parseId3Frames$1,
- parseSyncSafeInteger: parseSyncSafeInteger$1,
- frameParsers
- };
- var Stream$5 = stream, StreamTypes$3 = streamTypes, id3 = parseId3, MetadataStream;
- MetadataStream = function(options2) {
- var settings = {
- descriptor: options2 && options2.descriptor
- }, tagSize = 0, buffer = [], bufferSize = 0, i2;
- MetadataStream.prototype.init.call(this);
- this.dispatchType = StreamTypes$3.METADATA_STREAM_TYPE.toString(16);
- if (settings.descriptor) {
- for (i2 = 0; i2 < settings.descriptor.length; i2++) {
- this.dispatchType += ("00" + settings.descriptor[i2].toString(16)).slice(-2);
- }
- }
- this.push = function(chunk) {
- var tag, frameStart, frameSize, frame, i3, frameHeader;
- if (chunk.type !== "timed-metadata") {
- return;
- }
- if (chunk.dataAlignmentIndicator) {
- bufferSize = 0;
- buffer.length = 0;
- }
- if (buffer.length === 0 && (chunk.data.length < 10 || chunk.data[0] !== "I".charCodeAt(0) || chunk.data[1] !== "D".charCodeAt(0) || chunk.data[2] !== "3".charCodeAt(0))) {
- this.trigger("log", {
- level: "warn",
- message: "Skipping unrecognized metadata packet"
- });
- return;
- }
- buffer.push(chunk);
- bufferSize += chunk.data.byteLength;
- if (buffer.length === 1) {
- tagSize = id3.parseSyncSafeInteger(chunk.data.subarray(6, 10));
- tagSize += 10;
- }
- if (bufferSize < tagSize) {
- return;
- }
- tag = {
- data: new Uint8Array(tagSize),
- frames: [],
- pts: buffer[0].pts,
- dts: buffer[0].dts
- };
- for (i3 = 0; i3 < tagSize; ) {
- tag.data.set(buffer[0].data.subarray(0, tagSize - i3), i3);
- i3 += buffer[0].data.byteLength;
- bufferSize -= buffer[0].data.byteLength;
- buffer.shift();
- }
- frameStart = 10;
- if (tag.data[5] & 64) {
- frameStart += 4;
- frameStart += id3.parseSyncSafeInteger(tag.data.subarray(10, 14));
- tagSize -= id3.parseSyncSafeInteger(tag.data.subarray(16, 20));
- }
- do {
- frameSize = id3.parseSyncSafeInteger(tag.data.subarray(frameStart + 4, frameStart + 8));
- if (frameSize < 1) {
- this.trigger("log", {
- level: "warn",
- message: "Malformed ID3 frame encountered. Skipping remaining metadata parsing."
- });
- break;
- }
- frameHeader = String.fromCharCode(tag.data[frameStart], tag.data[frameStart + 1], tag.data[frameStart + 2], tag.data[frameStart + 3]);
- frame = {
- id: frameHeader,
- data: tag.data.subarray(frameStart + 10, frameStart + frameSize + 10)
- };
- frame.key = frame.id;
- if (id3.frameParsers[frame.id]) {
- id3.frameParsers[frame.id](frame);
- } else if (frame.id[0] === "T") {
- id3.frameParsers["T*"](frame);
- } else if (frame.id[0] === "W") {
- id3.frameParsers["W*"](frame);
- }
- if (frame.owner === "com.apple.streaming.transportStreamTimestamp") {
- var d2 = frame.data, size = (d2[3] & 1) << 30 | d2[4] << 22 | d2[5] << 14 | d2[6] << 6 | d2[7] >>> 2;
- size *= 4;
- size += d2[7] & 3;
- frame.timeStamp = size;
- if (tag.pts === void 0 && tag.dts === void 0) {
- tag.pts = frame.timeStamp;
- tag.dts = frame.timeStamp;
- }
- this.trigger("timestamp", frame);
- }
- tag.frames.push(frame);
- frameStart += 10;
- frameStart += frameSize;
- } while (frameStart < tagSize);
- this.trigger("data", tag);
- };
- };
- MetadataStream.prototype = new Stream$5();
- var metadataStream = MetadataStream;
- var Stream$4 = stream, CaptionStream$1 = captionStream, StreamTypes$2 = streamTypes, TimestampRolloverStream = timestampRolloverStream.TimestampRolloverStream;
- var TransportPacketStream, TransportParseStream, ElementaryStream;
- var MP2T_PACKET_LENGTH$1 = 188, SYNC_BYTE$1 = 71;
- TransportPacketStream = function() {
- var buffer = new Uint8Array(MP2T_PACKET_LENGTH$1), bytesInBuffer = 0;
- TransportPacketStream.prototype.init.call(this);
- this.push = function(bytes) {
- var startIndex = 0, endIndex = MP2T_PACKET_LENGTH$1, everything;
- if (bytesInBuffer) {
- everything = new Uint8Array(bytes.byteLength + bytesInBuffer);
- everything.set(buffer.subarray(0, bytesInBuffer));
- everything.set(bytes, bytesInBuffer);
- bytesInBuffer = 0;
- } else {
- everything = bytes;
- }
- while (endIndex < everything.byteLength) {
- if (everything[startIndex] === SYNC_BYTE$1 && everything[endIndex] === SYNC_BYTE$1) {
- this.trigger("data", everything.subarray(startIndex, endIndex));
- startIndex += MP2T_PACKET_LENGTH$1;
- endIndex += MP2T_PACKET_LENGTH$1;
- continue;
- }
- startIndex++;
- endIndex++;
- }
- if (startIndex < everything.byteLength) {
- buffer.set(everything.subarray(startIndex), 0);
- bytesInBuffer = everything.byteLength - startIndex;
- }
- };
- this.flush = function() {
- if (bytesInBuffer === MP2T_PACKET_LENGTH$1 && buffer[0] === SYNC_BYTE$1) {
- this.trigger("data", buffer);
- bytesInBuffer = 0;
- }
- this.trigger("done");
- };
- this.endTimeline = function() {
- this.flush();
- this.trigger("endedtimeline");
- };
- this.reset = function() {
- bytesInBuffer = 0;
- this.trigger("reset");
- };
- };
- TransportPacketStream.prototype = new Stream$4();
- TransportParseStream = function() {
- var parsePsi, parsePat2, parsePmt2, self2;
- TransportParseStream.prototype.init.call(this);
- self2 = this;
- this.packetsWaitingForPmt = [];
- this.programMapTable = void 0;
- parsePsi = function(payload, psi) {
- var offset = 0;
- if (psi.payloadUnitStartIndicator) {
- offset += payload[offset] + 1;
- }
- if (psi.type === "pat") {
- parsePat2(payload.subarray(offset), psi);
- } else {
- parsePmt2(payload.subarray(offset), psi);
- }
- };
- parsePat2 = function(payload, pat) {
- pat.section_number = payload[7];
- pat.last_section_number = payload[8];
- self2.pmtPid = (payload[10] & 31) << 8 | payload[11];
- pat.pmtPid = self2.pmtPid;
- };
- parsePmt2 = function(payload, pmt) {
- var sectionLength, tableEnd, programInfoLength, offset;
- if (!(payload[5] & 1)) {
- return;
- }
- self2.programMapTable = {
- video: null,
- audio: null,
- "timed-metadata": {}
- };
- sectionLength = (payload[1] & 15) << 8 | payload[2];
- tableEnd = 3 + sectionLength - 4;
- programInfoLength = (payload[10] & 15) << 8 | payload[11];
- offset = 12 + programInfoLength;
- while (offset < tableEnd) {
- var streamType = payload[offset];
- var pid = (payload[offset + 1] & 31) << 8 | payload[offset + 2];
- if (streamType === StreamTypes$2.H264_STREAM_TYPE && self2.programMapTable.video === null) {
- self2.programMapTable.video = pid;
- } else if (streamType === StreamTypes$2.ADTS_STREAM_TYPE && self2.programMapTable.audio === null) {
- self2.programMapTable.audio = pid;
- } else if (streamType === StreamTypes$2.METADATA_STREAM_TYPE) {
- self2.programMapTable["timed-metadata"][pid] = streamType;
- }
- offset += ((payload[offset + 3] & 15) << 8 | payload[offset + 4]) + 5;
- }
- pmt.programMapTable = self2.programMapTable;
- };
- this.push = function(packet) {
- var result = {}, offset = 4;
- result.payloadUnitStartIndicator = !!(packet[1] & 64);
- result.pid = packet[1] & 31;
- result.pid <<= 8;
- result.pid |= packet[2];
- if ((packet[3] & 48) >>> 4 > 1) {
- offset += packet[offset] + 1;
- }
- if (result.pid === 0) {
- result.type = "pat";
- parsePsi(packet.subarray(offset), result);
- this.trigger("data", result);
- } else if (result.pid === this.pmtPid) {
- result.type = "pmt";
- parsePsi(packet.subarray(offset), result);
- this.trigger("data", result);
- while (this.packetsWaitingForPmt.length) {
- this.processPes_.apply(this, this.packetsWaitingForPmt.shift());
- }
- } else if (this.programMapTable === void 0) {
- this.packetsWaitingForPmt.push([packet, offset, result]);
- } else {
- this.processPes_(packet, offset, result);
- }
- };
- this.processPes_ = function(packet, offset, result) {
- if (result.pid === this.programMapTable.video) {
- result.streamType = StreamTypes$2.H264_STREAM_TYPE;
- } else if (result.pid === this.programMapTable.audio) {
- result.streamType = StreamTypes$2.ADTS_STREAM_TYPE;
- } else {
- result.streamType = this.programMapTable["timed-metadata"][result.pid];
- }
- result.type = "pes";
- result.data = packet.subarray(offset);
- this.trigger("data", result);
- };
- };
- TransportParseStream.prototype = new Stream$4();
- TransportParseStream.STREAM_TYPES = {
- h264: 27,
- adts: 15
- };
- ElementaryStream = function() {
- var self2 = this, segmentHadPmt = false, video = {
- data: [],
- size: 0
- }, audio = {
- data: [],
- size: 0
- }, timedMetadata = {
- data: [],
- size: 0
- }, programMapTable, parsePes = function(payload, pes) {
- var ptsDtsFlags;
- const startPrefix = payload[0] << 16 | payload[1] << 8 | payload[2];
- pes.data = new Uint8Array();
- if (startPrefix !== 1) {
- return;
- }
- pes.packetLength = 6 + (payload[4] << 8 | payload[5]);
- pes.dataAlignmentIndicator = (payload[6] & 4) !== 0;
- ptsDtsFlags = payload[7];
- if (ptsDtsFlags & 192) {
- pes.pts = (payload[9] & 14) << 27 | (payload[10] & 255) << 20 | (payload[11] & 254) << 12 | (payload[12] & 255) << 5 | (payload[13] & 254) >>> 3;
- pes.pts *= 4;
- pes.pts += (payload[13] & 6) >>> 1;
- pes.dts = pes.pts;
- if (ptsDtsFlags & 64) {
- pes.dts = (payload[14] & 14) << 27 | (payload[15] & 255) << 20 | (payload[16] & 254) << 12 | (payload[17] & 255) << 5 | (payload[18] & 254) >>> 3;
- pes.dts *= 4;
- pes.dts += (payload[18] & 6) >>> 1;
- }
- }
- pes.data = payload.subarray(9 + payload[8]);
- }, flushStream = function(stream2, type3, forceFlush) {
- var packetData = new Uint8Array(stream2.size), event2 = {
- type: type3
- }, i2 = 0, offset = 0, packetFlushable = false, fragment;
- if (!stream2.data.length || stream2.size < 9) {
- return;
- }
- event2.trackId = stream2.data[0].pid;
- for (i2 = 0; i2 < stream2.data.length; i2++) {
- fragment = stream2.data[i2];
- packetData.set(fragment.data, offset);
- offset += fragment.data.byteLength;
- }
- parsePes(packetData, event2);
- packetFlushable = type3 === "video" || event2.packetLength <= stream2.size;
- if (forceFlush || packetFlushable) {
- stream2.size = 0;
- stream2.data.length = 0;
- }
- if (packetFlushable) {
- self2.trigger("data", event2);
- }
- };
- ElementaryStream.prototype.init.call(this);
- this.push = function(data) {
- ({
- pat: function() {
- },
- pes: function() {
- var stream2, streamType;
- switch (data.streamType) {
- case StreamTypes$2.H264_STREAM_TYPE:
- stream2 = video;
- streamType = "video";
- break;
- case StreamTypes$2.ADTS_STREAM_TYPE:
- stream2 = audio;
- streamType = "audio";
- break;
- case StreamTypes$2.METADATA_STREAM_TYPE:
- stream2 = timedMetadata;
- streamType = "timed-metadata";
- break;
- default:
- return;
- }
- if (data.payloadUnitStartIndicator) {
- flushStream(stream2, streamType, true);
- }
- stream2.data.push(data);
- stream2.size += data.data.byteLength;
- },
- pmt: function() {
- var event2 = {
- type: "metadata",
- tracks: []
- };
- programMapTable = data.programMapTable;
- if (programMapTable.video !== null) {
- event2.tracks.push({
- timelineStartInfo: {
- baseMediaDecodeTime: 0
- },
- id: +programMapTable.video,
- codec: "avc",
- type: "video"
- });
- }
- if (programMapTable.audio !== null) {
- event2.tracks.push({
- timelineStartInfo: {
- baseMediaDecodeTime: 0
- },
- id: +programMapTable.audio,
- codec: "adts",
- type: "audio"
- });
- }
- segmentHadPmt = true;
- self2.trigger("data", event2);
- }
- })[data.type]();
- };
- this.reset = function() {
- video.size = 0;
- video.data.length = 0;
- audio.size = 0;
- audio.data.length = 0;
- this.trigger("reset");
- };
- this.flushStreams_ = function() {
- flushStream(video, "video");
- flushStream(audio, "audio");
- flushStream(timedMetadata, "timed-metadata");
- };
- this.flush = function() {
- if (!segmentHadPmt && programMapTable) {
- var pmt = {
- type: "metadata",
- tracks: []
- };
- if (programMapTable.video !== null) {
- pmt.tracks.push({
- timelineStartInfo: {
- baseMediaDecodeTime: 0
- },
- id: +programMapTable.video,
- codec: "avc",
- type: "video"
- });
- }
- if (programMapTable.audio !== null) {
- pmt.tracks.push({
- timelineStartInfo: {
- baseMediaDecodeTime: 0
- },
- id: +programMapTable.audio,
- codec: "adts",
- type: "audio"
- });
- }
- self2.trigger("data", pmt);
- }
- segmentHadPmt = false;
- this.flushStreams_();
- this.trigger("done");
- };
- };
- ElementaryStream.prototype = new Stream$4();
- var m2ts$1 = {
- PAT_PID: 0,
- MP2T_PACKET_LENGTH: MP2T_PACKET_LENGTH$1,
- TransportPacketStream,
- TransportParseStream,
- ElementaryStream,
- TimestampRolloverStream,
- CaptionStream: CaptionStream$1.CaptionStream,
- Cea608Stream: CaptionStream$1.Cea608Stream,
- Cea708Stream: CaptionStream$1.Cea708Stream,
- MetadataStream: metadataStream
- };
- for (var type2 in StreamTypes$2) {
- if (StreamTypes$2.hasOwnProperty(type2)) {
- m2ts$1[type2] = StreamTypes$2[type2];
- }
- }
- var m2ts_1 = m2ts$1;
- var Stream$3 = stream;
- var ONE_SECOND_IN_TS$2 = clock$2.ONE_SECOND_IN_TS;
- var AdtsStream$1;
- var ADTS_SAMPLING_FREQUENCIES$1 = [96e3, 88200, 64e3, 48e3, 44100, 32e3, 24e3, 22050, 16e3, 12e3, 11025, 8e3, 7350];
- AdtsStream$1 = function(handlePartialSegments) {
- var buffer, frameNum = 0;
- AdtsStream$1.prototype.init.call(this);
- this.skipWarn_ = function(start2, end) {
- this.trigger("log", {
- level: "warn",
- message: `adts skiping bytes ${start2} to ${end} in frame ${frameNum} outside syncword`
- });
- };
- this.push = function(packet) {
- var i2 = 0, frameLength, protectionSkipBytes, oldBuffer, sampleCount, adtsFrameDuration;
- if (!handlePartialSegments) {
- frameNum = 0;
- }
- if (packet.type !== "audio") {
- return;
- }
- if (buffer && buffer.length) {
- oldBuffer = buffer;
- buffer = new Uint8Array(oldBuffer.byteLength + packet.data.byteLength);
- buffer.set(oldBuffer);
- buffer.set(packet.data, oldBuffer.byteLength);
- } else {
- buffer = packet.data;
- }
- var skip;
- while (i2 + 7 < buffer.length) {
- if (buffer[i2] !== 255 || (buffer[i2 + 1] & 246) !== 240) {
- if (typeof skip !== "number") {
- skip = i2;
- }
- i2++;
- continue;
- }
- if (typeof skip === "number") {
- this.skipWarn_(skip, i2);
- skip = null;
- }
- protectionSkipBytes = (~buffer[i2 + 1] & 1) * 2;
- frameLength = (buffer[i2 + 3] & 3) << 11 | buffer[i2 + 4] << 3 | (buffer[i2 + 5] & 224) >> 5;
- sampleCount = ((buffer[i2 + 6] & 3) + 1) * 1024;
- adtsFrameDuration = sampleCount * ONE_SECOND_IN_TS$2 / ADTS_SAMPLING_FREQUENCIES$1[(buffer[i2 + 2] & 60) >>> 2];
- if (buffer.byteLength - i2 < frameLength) {
- break;
- }
- this.trigger("data", {
- pts: packet.pts + frameNum * adtsFrameDuration,
- dts: packet.dts + frameNum * adtsFrameDuration,
- sampleCount,
- audioobjecttype: (buffer[i2 + 2] >>> 6 & 3) + 1,
- channelcount: (buffer[i2 + 2] & 1) << 2 | (buffer[i2 + 3] & 192) >>> 6,
- samplerate: ADTS_SAMPLING_FREQUENCIES$1[(buffer[i2 + 2] & 60) >>> 2],
- samplingfrequencyindex: (buffer[i2 + 2] & 60) >>> 2,
- samplesize: 16,
- data: buffer.subarray(i2 + 7 + protectionSkipBytes, i2 + frameLength)
- });
- frameNum++;
- i2 += frameLength;
- }
- if (typeof skip === "number") {
- this.skipWarn_(skip, i2);
- skip = null;
- }
- buffer = buffer.subarray(i2);
- };
- this.flush = function() {
- frameNum = 0;
- this.trigger("done");
- };
- this.reset = function() {
- buffer = void 0;
- this.trigger("reset");
- };
- this.endTimeline = function() {
- buffer = void 0;
- this.trigger("endedtimeline");
- };
- };
- AdtsStream$1.prototype = new Stream$3();
- var adts = AdtsStream$1;
- var ExpGolomb$1;
- ExpGolomb$1 = function(workingData) {
- var workingBytesAvailable = workingData.byteLength, workingWord = 0, workingBitsAvailable = 0;
- this.length = function() {
- return 8 * workingBytesAvailable;
- };
- this.bitsAvailable = function() {
- return 8 * workingBytesAvailable + workingBitsAvailable;
- };
- this.loadWord = function() {
- var position2 = workingData.byteLength - workingBytesAvailable, workingBytes = new Uint8Array(4), availableBytes = Math.min(4, workingBytesAvailable);
- if (availableBytes === 0) {
- throw new Error("no bytes available");
- }
- workingBytes.set(workingData.subarray(position2, position2 + availableBytes));
- workingWord = new DataView(workingBytes.buffer).getUint32(0);
- workingBitsAvailable = availableBytes * 8;
- workingBytesAvailable -= availableBytes;
- };
- this.skipBits = function(count) {
- var skipBytes;
- if (workingBitsAvailable > count) {
- workingWord <<= count;
- workingBitsAvailable -= count;
- } else {
- count -= workingBitsAvailable;
- skipBytes = Math.floor(count / 8);
- count -= skipBytes * 8;
- workingBytesAvailable -= skipBytes;
- this.loadWord();
- workingWord <<= count;
- workingBitsAvailable -= count;
- }
- };
- this.readBits = function(size) {
- var bits = Math.min(workingBitsAvailable, size), valu = workingWord >>> 32 - bits;
- workingBitsAvailable -= bits;
- if (workingBitsAvailable > 0) {
- workingWord <<= bits;
- } else if (workingBytesAvailable > 0) {
- this.loadWord();
- }
- bits = size - bits;
- if (bits > 0) {
- return valu << bits | this.readBits(bits);
- }
- return valu;
- };
- this.skipLeadingZeros = function() {
- var leadingZeroCount;
- for (leadingZeroCount = 0; leadingZeroCount < workingBitsAvailable; ++leadingZeroCount) {
- if ((workingWord & 2147483648 >>> leadingZeroCount) !== 0) {
- workingWord <<= leadingZeroCount;
- workingBitsAvailable -= leadingZeroCount;
- return leadingZeroCount;
- }
- }
- this.loadWord();
- return leadingZeroCount + this.skipLeadingZeros();
- };
- this.skipUnsignedExpGolomb = function() {
- this.skipBits(1 + this.skipLeadingZeros());
- };
- this.skipExpGolomb = function() {
- this.skipBits(1 + this.skipLeadingZeros());
- };
- this.readUnsignedExpGolomb = function() {
- var clz = this.skipLeadingZeros();
- return this.readBits(clz + 1) - 1;
- };
- this.readExpGolomb = function() {
- var valu = this.readUnsignedExpGolomb();
- if (1 & valu) {
- return 1 + valu >>> 1;
- }
- return -1 * (valu >>> 1);
- };
- this.readBoolean = function() {
- return this.readBits(1) === 1;
- };
- this.readUnsignedByte = function() {
- return this.readBits(8);
- };
- this.loadWord();
- };
- var expGolomb = ExpGolomb$1;
- var Stream$2 = stream;
- var ExpGolomb = expGolomb;
- var H264Stream$1, NalByteStream;
- var PROFILES_WITH_OPTIONAL_SPS_DATA;
- NalByteStream = function() {
- var syncPoint = 0, i2, buffer;
- NalByteStream.prototype.init.call(this);
- this.push = function(data) {
- var swapBuffer;
- if (!buffer) {
- buffer = data.data;
- } else {
- swapBuffer = new Uint8Array(buffer.byteLength + data.data.byteLength);
- swapBuffer.set(buffer);
- swapBuffer.set(data.data, buffer.byteLength);
- buffer = swapBuffer;
- }
- var len = buffer.byteLength;
- for (; syncPoint < len - 3; syncPoint++) {
- if (buffer[syncPoint + 2] === 1) {
- i2 = syncPoint + 5;
- break;
- }
- }
- while (i2 < len) {
- switch (buffer[i2]) {
- case 0:
- if (buffer[i2 - 1] !== 0) {
- i2 += 2;
- break;
- } else if (buffer[i2 - 2] !== 0) {
- i2++;
- break;
- }
- if (syncPoint + 3 !== i2 - 2) {
- this.trigger("data", buffer.subarray(syncPoint + 3, i2 - 2));
- }
- do {
- i2++;
- } while (buffer[i2] !== 1 && i2 < len);
- syncPoint = i2 - 2;
- i2 += 3;
- break;
- case 1:
- if (buffer[i2 - 1] !== 0 || buffer[i2 - 2] !== 0) {
- i2 += 3;
- break;
- }
- this.trigger("data", buffer.subarray(syncPoint + 3, i2 - 2));
- syncPoint = i2 - 2;
- i2 += 3;
- break;
- default:
- i2 += 3;
- break;
- }
- }
- buffer = buffer.subarray(syncPoint);
- i2 -= syncPoint;
- syncPoint = 0;
- };
- this.reset = function() {
- buffer = null;
- syncPoint = 0;
- this.trigger("reset");
- };
- this.flush = function() {
- if (buffer && buffer.byteLength > 3) {
- this.trigger("data", buffer.subarray(syncPoint + 3));
- }
- buffer = null;
- syncPoint = 0;
- this.trigger("done");
- };
- this.endTimeline = function() {
- this.flush();
- this.trigger("endedtimeline");
- };
- };
- NalByteStream.prototype = new Stream$2();
- PROFILES_WITH_OPTIONAL_SPS_DATA = {
- 100: true,
- 110: true,
- 122: true,
- 244: true,
- 44: true,
- 83: true,
- 86: true,
- 118: true,
- 128: true,
- 138: true,
- 139: true,
- 134: true
- };
- H264Stream$1 = function() {
- var nalByteStream = new NalByteStream(), self2, trackId, currentPts, currentDts, discardEmulationPreventionBytes5, readSequenceParameterSet, skipScalingList;
- H264Stream$1.prototype.init.call(this);
- self2 = this;
- this.push = function(packet) {
- if (packet.type !== "video") {
- return;
- }
- trackId = packet.trackId;
- currentPts = packet.pts;
- currentDts = packet.dts;
- nalByteStream.push(packet);
- };
- nalByteStream.on("data", function(data) {
- var event2 = {
- trackId,
- pts: currentPts,
- dts: currentDts,
- data,
- nalUnitTypeCode: data[0] & 31
- };
- switch (event2.nalUnitTypeCode) {
- case 5:
- event2.nalUnitType = "slice_layer_without_partitioning_rbsp_idr";
- break;
- case 6:
- event2.nalUnitType = "sei_rbsp";
- event2.escapedRBSP = discardEmulationPreventionBytes5(data.subarray(1));
- break;
- case 7:
- event2.nalUnitType = "seq_parameter_set_rbsp";
- event2.escapedRBSP = discardEmulationPreventionBytes5(data.subarray(1));
- event2.config = readSequenceParameterSet(event2.escapedRBSP);
- break;
- case 8:
- event2.nalUnitType = "pic_parameter_set_rbsp";
- break;
- case 9:
- event2.nalUnitType = "access_unit_delimiter_rbsp";
- break;
- }
- self2.trigger("data", event2);
- });
- nalByteStream.on("done", function() {
- self2.trigger("done");
- });
- nalByteStream.on("partialdone", function() {
- self2.trigger("partialdone");
- });
- nalByteStream.on("reset", function() {
- self2.trigger("reset");
- });
- nalByteStream.on("endedtimeline", function() {
- self2.trigger("endedtimeline");
- });
- this.flush = function() {
- nalByteStream.flush();
- };
- this.partialFlush = function() {
- nalByteStream.partialFlush();
- };
- this.reset = function() {
- nalByteStream.reset();
- };
- this.endTimeline = function() {
- nalByteStream.endTimeline();
- };
- skipScalingList = function(count, expGolombDecoder) {
- var lastScale = 8, nextScale = 8, j, deltaScale;
- for (j = 0; j < count; j++) {
- if (nextScale !== 0) {
- deltaScale = expGolombDecoder.readExpGolomb();
- nextScale = (lastScale + deltaScale + 256) % 256;
- }
- lastScale = nextScale === 0 ? lastScale : nextScale;
- }
- };
- discardEmulationPreventionBytes5 = function(data) {
- var length = data.byteLength, emulationPreventionBytesPositions = [], i2 = 1, newLength, newData;
- while (i2 < length - 2) {
- if (data[i2] === 0 && data[i2 + 1] === 0 && data[i2 + 2] === 3) {
- emulationPreventionBytesPositions.push(i2 + 2);
- i2 += 2;
- } else {
- i2++;
- }
- }
- if (emulationPreventionBytesPositions.length === 0) {
- return data;
- }
- newLength = length - emulationPreventionBytesPositions.length;
- newData = new Uint8Array(newLength);
- var sourceIndex = 0;
- for (i2 = 0; i2 < newLength; sourceIndex++, i2++) {
- if (sourceIndex === emulationPreventionBytesPositions[0]) {
- sourceIndex++;
- emulationPreventionBytesPositions.shift();
- }
- newData[i2] = data[sourceIndex];
- }
- return newData;
- };
- readSequenceParameterSet = function(data) {
- var frameCropLeftOffset = 0, frameCropRightOffset = 0, frameCropTopOffset = 0, frameCropBottomOffset = 0, expGolombDecoder, profileIdc, levelIdc, profileCompatibility, chromaFormatIdc, picOrderCntType, numRefFramesInPicOrderCntCycle, picWidthInMbsMinus1, picHeightInMapUnitsMinus1, frameMbsOnlyFlag, scalingListCount, sarRatio = [1, 1], aspectRatioIdc, i2;
- expGolombDecoder = new ExpGolomb(data);
- profileIdc = expGolombDecoder.readUnsignedByte();
- profileCompatibility = expGolombDecoder.readUnsignedByte();
- levelIdc = expGolombDecoder.readUnsignedByte();
- expGolombDecoder.skipUnsignedExpGolomb();
- if (PROFILES_WITH_OPTIONAL_SPS_DATA[profileIdc]) {
- chromaFormatIdc = expGolombDecoder.readUnsignedExpGolomb();
- if (chromaFormatIdc === 3) {
- expGolombDecoder.skipBits(1);
- }
- expGolombDecoder.skipUnsignedExpGolomb();
- expGolombDecoder.skipUnsignedExpGolomb();
- expGolombDecoder.skipBits(1);
- if (expGolombDecoder.readBoolean()) {
- scalingListCount = chromaFormatIdc !== 3 ? 8 : 12;
- for (i2 = 0; i2 < scalingListCount; i2++) {
- if (expGolombDecoder.readBoolean()) {
- if (i2 < 6) {
- skipScalingList(16, expGolombDecoder);
- } else {
- skipScalingList(64, expGolombDecoder);
- }
- }
- }
- }
- }
- expGolombDecoder.skipUnsignedExpGolomb();
- picOrderCntType = expGolombDecoder.readUnsignedExpGolomb();
- if (picOrderCntType === 0) {
- expGolombDecoder.readUnsignedExpGolomb();
- } else if (picOrderCntType === 1) {
- expGolombDecoder.skipBits(1);
- expGolombDecoder.skipExpGolomb();
- expGolombDecoder.skipExpGolomb();
- numRefFramesInPicOrderCntCycle = expGolombDecoder.readUnsignedExpGolomb();
- for (i2 = 0; i2 < numRefFramesInPicOrderCntCycle; i2++) {
- expGolombDecoder.skipExpGolomb();
- }
- }
- expGolombDecoder.skipUnsignedExpGolomb();
- expGolombDecoder.skipBits(1);
- picWidthInMbsMinus1 = expGolombDecoder.readUnsignedExpGolomb();
- picHeightInMapUnitsMinus1 = expGolombDecoder.readUnsignedExpGolomb();
- frameMbsOnlyFlag = expGolombDecoder.readBits(1);
- if (frameMbsOnlyFlag === 0) {
- expGolombDecoder.skipBits(1);
- }
- expGolombDecoder.skipBits(1);
- if (expGolombDecoder.readBoolean()) {
- frameCropLeftOffset = expGolombDecoder.readUnsignedExpGolomb();
- frameCropRightOffset = expGolombDecoder.readUnsignedExpGolomb();
- frameCropTopOffset = expGolombDecoder.readUnsignedExpGolomb();
- frameCropBottomOffset = expGolombDecoder.readUnsignedExpGolomb();
- }
- if (expGolombDecoder.readBoolean()) {
- if (expGolombDecoder.readBoolean()) {
- aspectRatioIdc = expGolombDecoder.readUnsignedByte();
- switch (aspectRatioIdc) {
- case 1:
- sarRatio = [1, 1];
- break;
- case 2:
- sarRatio = [12, 11];
- break;
- case 3:
- sarRatio = [10, 11];
- break;
- case 4:
- sarRatio = [16, 11];
- break;
- case 5:
- sarRatio = [40, 33];
- break;
- case 6:
- sarRatio = [24, 11];
- break;
- case 7:
- sarRatio = [20, 11];
- break;
- case 8:
- sarRatio = [32, 11];
- break;
- case 9:
- sarRatio = [80, 33];
- break;
- case 10:
- sarRatio = [18, 11];
- break;
- case 11:
- sarRatio = [15, 11];
- break;
- case 12:
- sarRatio = [64, 33];
- break;
- case 13:
- sarRatio = [160, 99];
- break;
- case 14:
- sarRatio = [4, 3];
- break;
- case 15:
- sarRatio = [3, 2];
- break;
- case 16:
- sarRatio = [2, 1];
- break;
- case 255: {
- sarRatio = [expGolombDecoder.readUnsignedByte() << 8 | expGolombDecoder.readUnsignedByte(), expGolombDecoder.readUnsignedByte() << 8 | expGolombDecoder.readUnsignedByte()];
- break;
- }
- }
- if (sarRatio) {
- sarRatio[0] / sarRatio[1];
- }
- }
- }
- return {
- profileIdc,
- levelIdc,
- profileCompatibility,
- width: (picWidthInMbsMinus1 + 1) * 16 - frameCropLeftOffset * 2 - frameCropRightOffset * 2,
- height: (2 - frameMbsOnlyFlag) * (picHeightInMapUnitsMinus1 + 1) * 16 - frameCropTopOffset * 2 - frameCropBottomOffset * 2,
- sarRatio
- };
- };
- };
- H264Stream$1.prototype = new Stream$2();
- var h2643 = {
- H264Stream: H264Stream$1,
- NalByteStream
- };
- var ADTS_SAMPLING_FREQUENCIES = [96e3, 88200, 64e3, 48e3, 44100, 32e3, 24e3, 22050, 16e3, 12e3, 11025, 8e3, 7350];
- var parseId3TagSize = function(header, byteIndex) {
- var returnSize = header[byteIndex + 6] << 21 | header[byteIndex + 7] << 14 | header[byteIndex + 8] << 7 | header[byteIndex + 9], flags = header[byteIndex + 5], footerPresent = (flags & 16) >> 4;
- returnSize = returnSize >= 0 ? returnSize : 0;
- if (footerPresent) {
- return returnSize + 20;
- }
- return returnSize + 10;
- };
- var getId3Offset4 = function(data, offset) {
- if (data.length - offset < 10 || data[offset] !== "I".charCodeAt(0) || data[offset + 1] !== "D".charCodeAt(0) || data[offset + 2] !== "3".charCodeAt(0)) {
- return offset;
- }
- offset += parseId3TagSize(data, offset);
- return getId3Offset4(data, offset);
- };
- var isLikelyAacData$1 = function(data) {
- var offset = getId3Offset4(data, 0);
- return data.length >= offset + 2 && (data[offset] & 255) === 255 && (data[offset + 1] & 240) === 240 && (data[offset + 1] & 22) === 16;
- };
- var parseSyncSafeInteger = function(data) {
- return data[0] << 21 | data[1] << 14 | data[2] << 7 | data[3];
- };
- var percentEncode = function(bytes, start2, end) {
- var i2, result = "";
- for (i2 = start2; i2 < end; i2++) {
- result += "%" + ("00" + bytes[i2].toString(16)).slice(-2);
- }
- return result;
- };
- var parseIso88591 = function(bytes, start2, end) {
- return unescape(percentEncode(bytes, start2, end));
- };
- var parseAdtsSize = function(header, byteIndex) {
- var lowThree = (header[byteIndex + 5] & 224) >> 5, middle = header[byteIndex + 4] << 3, highTwo = header[byteIndex + 3] & 3 << 11;
- return highTwo | middle | lowThree;
- };
- var parseType$4 = function(header, byteIndex) {
- if (header[byteIndex] === "I".charCodeAt(0) && header[byteIndex + 1] === "D".charCodeAt(0) && header[byteIndex + 2] === "3".charCodeAt(0)) {
- return "timed-metadata";
- } else if (header[byteIndex] & true && (header[byteIndex + 1] & 240) === 240) {
- return "audio";
- }
- return null;
- };
- var parseSampleRate = function(packet) {
- var i2 = 0;
- while (i2 + 5 < packet.length) {
- if (packet[i2] !== 255 || (packet[i2 + 1] & 246) !== 240) {
- i2++;
- continue;
- }
- return ADTS_SAMPLING_FREQUENCIES[(packet[i2 + 2] & 60) >>> 2];
- }
- return null;
- };
- var parseAacTimestamp = function(packet) {
- var frameStart, frameSize, frame, frameHeader;
- frameStart = 10;
- if (packet[5] & 64) {
- frameStart += 4;
- frameStart += parseSyncSafeInteger(packet.subarray(10, 14));
- }
- do {
- frameSize = parseSyncSafeInteger(packet.subarray(frameStart + 4, frameStart + 8));
- if (frameSize < 1) {
- return null;
- }
- frameHeader = String.fromCharCode(packet[frameStart], packet[frameStart + 1], packet[frameStart + 2], packet[frameStart + 3]);
- if (frameHeader === "PRIV") {
- frame = packet.subarray(frameStart + 10, frameStart + frameSize + 10);
- for (var i2 = 0; i2 < frame.byteLength; i2++) {
- if (frame[i2] === 0) {
- var owner = parseIso88591(frame, 0, i2);
- if (owner === "com.apple.streaming.transportStreamTimestamp") {
- var d2 = frame.subarray(i2 + 1);
- var size = (d2[3] & 1) << 30 | d2[4] << 22 | d2[5] << 14 | d2[6] << 6 | d2[7] >>> 2;
- size *= 4;
- size += d2[7] & 3;
- return size;
- }
- break;
- }
- }
- }
- frameStart += 10;
- frameStart += frameSize;
- } while (frameStart < packet.byteLength);
- return null;
- };
- var utils2 = {
- isLikelyAacData: isLikelyAacData$1,
- parseId3TagSize,
- parseAdtsSize,
- parseType: parseType$4,
- parseSampleRate,
- parseAacTimestamp
- };
- var Stream$12 = stream;
- var aacUtils = utils2;
- var AacStream$1;
- AacStream$1 = function() {
- var everything = new Uint8Array(), timeStamp = 0;
- AacStream$1.prototype.init.call(this);
- this.setTimestamp = function(timestamp) {
- timeStamp = timestamp;
- };
- this.push = function(bytes) {
- var frameSize = 0, byteIndex = 0, bytesLeft, chunk, packet, tempLength;
- if (everything.length) {
- tempLength = everything.length;
- everything = new Uint8Array(bytes.byteLength + tempLength);
- everything.set(everything.subarray(0, tempLength));
- everything.set(bytes, tempLength);
- } else {
- everything = bytes;
- }
- while (everything.length - byteIndex >= 3) {
- if (everything[byteIndex] === "I".charCodeAt(0) && everything[byteIndex + 1] === "D".charCodeAt(0) && everything[byteIndex + 2] === "3".charCodeAt(0)) {
- if (everything.length - byteIndex < 10) {
- break;
- }
- frameSize = aacUtils.parseId3TagSize(everything, byteIndex);
- if (byteIndex + frameSize > everything.length) {
- break;
- }
- chunk = {
- type: "timed-metadata",
- data: everything.subarray(byteIndex, byteIndex + frameSize)
- };
- this.trigger("data", chunk);
- byteIndex += frameSize;
- continue;
- } else if ((everything[byteIndex] & 255) === 255 && (everything[byteIndex + 1] & 240) === 240) {
- if (everything.length - byteIndex < 7) {
- break;
- }
- frameSize = aacUtils.parseAdtsSize(everything, byteIndex);
- if (byteIndex + frameSize > everything.length) {
- break;
- }
- packet = {
- type: "audio",
- data: everything.subarray(byteIndex, byteIndex + frameSize),
- pts: timeStamp,
- dts: timeStamp
- };
- this.trigger("data", packet);
- byteIndex += frameSize;
- continue;
- }
- byteIndex++;
- }
- bytesLeft = everything.length - byteIndex;
- if (bytesLeft > 0) {
- everything = everything.subarray(byteIndex);
- } else {
- everything = new Uint8Array();
- }
- };
- this.reset = function() {
- everything = new Uint8Array();
- this.trigger("reset");
- };
- this.endTimeline = function() {
- everything = new Uint8Array();
- this.trigger("endedtimeline");
- };
- };
- AacStream$1.prototype = new Stream$12();
- var aac3 = AacStream$1;
- var AUDIO_PROPERTIES$1 = ["audioobjecttype", "channelcount", "samplerate", "samplingfrequencyindex", "samplesize"];
- var audioProperties = AUDIO_PROPERTIES$1;
- var VIDEO_PROPERTIES$1 = ["width", "height", "profileIdc", "levelIdc", "profileCompatibility", "sarRatio"];
- var videoProperties = VIDEO_PROPERTIES$1;
- var Stream2 = stream;
- var mp43 = mp4Generator;
- var frameUtils = frameUtils$1;
- var audioFrameUtils = audioFrameUtils$1;
- var trackDecodeInfo = trackDecodeInfo$1;
- var m2ts = m2ts_1;
- var clock2 = clock$2;
- var AdtsStream = adts;
- var H264Stream = h2643.H264Stream;
- var AacStream = aac3;
- var isLikelyAacData = utils2.isLikelyAacData;
- var ONE_SECOND_IN_TS$12 = clock$2.ONE_SECOND_IN_TS;
- var AUDIO_PROPERTIES = audioProperties;
- var VIDEO_PROPERTIES = videoProperties;
- var VideoSegmentStream, AudioSegmentStream, Transmuxer, CoalesceStream;
- var retriggerForStream = function(key, event2) {
- event2.stream = key;
- this.trigger("log", event2);
- };
- var addPipelineLogRetriggers = function(transmuxer2, pipeline) {
- var keys3 = Object.keys(pipeline);
- for (var i2 = 0; i2 < keys3.length; i2++) {
- var key = keys3[i2];
- if (key === "headOfPipeline" || !pipeline[key].on) {
- continue;
- }
- pipeline[key].on("log", retriggerForStream.bind(transmuxer2, key));
- }
- };
- var arrayEquals = function(a, b) {
- var i2;
- if (a.length !== b.length) {
- return false;
- }
- for (i2 = 0; i2 < a.length; i2++) {
- if (a[i2] !== b[i2]) {
- return false;
- }
- }
- return true;
- };
- var generateSegmentTimingInfo = function(baseMediaDecodeTime, startDts, startPts, endDts, endPts, prependedContentDuration) {
- var ptsOffsetFromDts = startPts - startDts, decodeDuration = endDts - startDts, presentationDuration = endPts - startPts;
- return {
- start: {
- dts: baseMediaDecodeTime,
- pts: baseMediaDecodeTime + ptsOffsetFromDts
- },
- end: {
- dts: baseMediaDecodeTime + decodeDuration,
- pts: baseMediaDecodeTime + presentationDuration
- },
- prependedContentDuration,
- baseMediaDecodeTime
- };
- };
- AudioSegmentStream = function(track, options2) {
- var adtsFrames = [], sequenceNumber, earliestAllowedDts = 0, audioAppendStartTs = 0, videoBaseMediaDecodeTime = Infinity;
- options2 = options2 || {};
- sequenceNumber = options2.firstSequenceNumber || 0;
- AudioSegmentStream.prototype.init.call(this);
- this.push = function(data) {
- trackDecodeInfo.collectDtsInfo(track, data);
- if (track) {
- AUDIO_PROPERTIES.forEach(function(prop) {
- track[prop] = data[prop];
- });
- }
- adtsFrames.push(data);
- };
- this.setEarliestDts = function(earliestDts) {
- earliestAllowedDts = earliestDts;
- };
- this.setVideoBaseMediaDecodeTime = function(baseMediaDecodeTime) {
- videoBaseMediaDecodeTime = baseMediaDecodeTime;
- };
- this.setAudioAppendStart = function(timestamp) {
- audioAppendStartTs = timestamp;
- };
- this.flush = function() {
- var frames, moof2, mdat2, boxes, frameDuration, segmentDuration, videoClockCyclesOfSilencePrefixed;
- if (adtsFrames.length === 0) {
- this.trigger("done", "AudioSegmentStream");
- return;
- }
- frames = audioFrameUtils.trimAdtsFramesByEarliestDts(adtsFrames, track, earliestAllowedDts);
- track.baseMediaDecodeTime = trackDecodeInfo.calculateTrackBaseMediaDecodeTime(track, options2.keepOriginalTimestamps);
- videoClockCyclesOfSilencePrefixed = audioFrameUtils.prefixWithSilence(track, frames, audioAppendStartTs, videoBaseMediaDecodeTime);
- track.samples = audioFrameUtils.generateSampleTable(frames);
- mdat2 = mp43.mdat(audioFrameUtils.concatenateFrameData(frames));
- adtsFrames = [];
- moof2 = mp43.moof(sequenceNumber, [track]);
- boxes = new Uint8Array(moof2.byteLength + mdat2.byteLength);
- sequenceNumber++;
- boxes.set(moof2);
- boxes.set(mdat2, moof2.byteLength);
- trackDecodeInfo.clearDtsInfo(track);
- frameDuration = Math.ceil(ONE_SECOND_IN_TS$12 * 1024 / track.samplerate);
- if (frames.length) {
- segmentDuration = frames.length * frameDuration;
- this.trigger("segmentTimingInfo", generateSegmentTimingInfo(
- clock2.audioTsToVideoTs(track.baseMediaDecodeTime, track.samplerate),
- frames[0].dts,
- frames[0].pts,
- frames[0].dts + segmentDuration,
- frames[0].pts + segmentDuration,
- videoClockCyclesOfSilencePrefixed || 0
- ));
- this.trigger("timingInfo", {
- start: frames[0].pts,
- end: frames[0].pts + segmentDuration
- });
- }
- this.trigger("data", {
- track,
- boxes
- });
- this.trigger("done", "AudioSegmentStream");
- };
- this.reset = function() {
- trackDecodeInfo.clearDtsInfo(track);
- adtsFrames = [];
- this.trigger("reset");
- };
- };
- AudioSegmentStream.prototype = new Stream2();
- VideoSegmentStream = function(track, options2) {
- var sequenceNumber, nalUnits = [], gopsToAlignWith = [], config, pps;
- options2 = options2 || {};
- sequenceNumber = options2.firstSequenceNumber || 0;
- VideoSegmentStream.prototype.init.call(this);
- delete track.minPTS;
- this.gopCache_ = [];
- this.push = function(nalUnit) {
- trackDecodeInfo.collectDtsInfo(track, nalUnit);
- if (nalUnit.nalUnitType === "seq_parameter_set_rbsp" && !config) {
- config = nalUnit.config;
- track.sps = [nalUnit.data];
- VIDEO_PROPERTIES.forEach(function(prop) {
- track[prop] = config[prop];
- }, this);
- }
- if (nalUnit.nalUnitType === "pic_parameter_set_rbsp" && !pps) {
- pps = nalUnit.data;
- track.pps = [nalUnit.data];
- }
- nalUnits.push(nalUnit);
- };
- this.flush = function() {
- var frames, gopForFusion, gops, moof2, mdat2, boxes, prependedContentDuration = 0, firstGop, lastGop;
- while (nalUnits.length) {
- if (nalUnits[0].nalUnitType === "access_unit_delimiter_rbsp") {
- break;
- }
- nalUnits.shift();
- }
- if (nalUnits.length === 0) {
- this.resetStream_();
- this.trigger("done", "VideoSegmentStream");
- return;
- }
- frames = frameUtils.groupNalsIntoFrames(nalUnits);
- gops = frameUtils.groupFramesIntoGops(frames);
- if (!gops[0][0].keyFrame) {
- gopForFusion = this.getGopForFusion_(nalUnits[0], track);
- if (gopForFusion) {
- prependedContentDuration = gopForFusion.duration;
- gops.unshift(gopForFusion);
- gops.byteLength += gopForFusion.byteLength;
- gops.nalCount += gopForFusion.nalCount;
- gops.pts = gopForFusion.pts;
- gops.dts = gopForFusion.dts;
- gops.duration += gopForFusion.duration;
- } else {
- gops = frameUtils.extendFirstKeyFrame(gops);
- }
- }
- if (gopsToAlignWith.length) {
- var alignedGops;
- if (options2.alignGopsAtEnd) {
- alignedGops = this.alignGopsAtEnd_(gops);
- } else {
- alignedGops = this.alignGopsAtStart_(gops);
- }
- if (!alignedGops) {
- this.gopCache_.unshift({
- gop: gops.pop(),
- pps: track.pps,
- sps: track.sps
- });
- this.gopCache_.length = Math.min(6, this.gopCache_.length);
- nalUnits = [];
- this.resetStream_();
- this.trigger("done", "VideoSegmentStream");
- return;
- }
- trackDecodeInfo.clearDtsInfo(track);
- gops = alignedGops;
- }
- trackDecodeInfo.collectDtsInfo(track, gops);
- track.samples = frameUtils.generateSampleTable(gops);
- mdat2 = mp43.mdat(frameUtils.concatenateNalData(gops));
- track.baseMediaDecodeTime = trackDecodeInfo.calculateTrackBaseMediaDecodeTime(track, options2.keepOriginalTimestamps);
- this.trigger("processedGopsInfo", gops.map(function(gop) {
- return {
- pts: gop.pts,
- dts: gop.dts,
- byteLength: gop.byteLength
- };
- }));
- firstGop = gops[0];
- lastGop = gops[gops.length - 1];
- this.trigger("segmentTimingInfo", generateSegmentTimingInfo(track.baseMediaDecodeTime, firstGop.dts, firstGop.pts, lastGop.dts + lastGop.duration, lastGop.pts + lastGop.duration, prependedContentDuration));
- this.trigger("timingInfo", {
- start: gops[0].pts,
- end: gops[gops.length - 1].pts + gops[gops.length - 1].duration
- });
- this.gopCache_.unshift({
- gop: gops.pop(),
- pps: track.pps,
- sps: track.sps
- });
- this.gopCache_.length = Math.min(6, this.gopCache_.length);
- nalUnits = [];
- this.trigger("baseMediaDecodeTime", track.baseMediaDecodeTime);
- this.trigger("timelineStartInfo", track.timelineStartInfo);
- moof2 = mp43.moof(sequenceNumber, [track]);
- boxes = new Uint8Array(moof2.byteLength + mdat2.byteLength);
- sequenceNumber++;
- boxes.set(moof2);
- boxes.set(mdat2, moof2.byteLength);
- this.trigger("data", {
- track,
- boxes
- });
- this.resetStream_();
- this.trigger("done", "VideoSegmentStream");
- };
- this.reset = function() {
- this.resetStream_();
- nalUnits = [];
- this.gopCache_.length = 0;
- gopsToAlignWith.length = 0;
- this.trigger("reset");
- };
- this.resetStream_ = function() {
- trackDecodeInfo.clearDtsInfo(track);
- config = void 0;
- pps = void 0;
- };
- this.getGopForFusion_ = function(nalUnit) {
- var halfSecond = 45e3, allowableOverlap = 1e4, nearestDistance = Infinity, dtsDistance, nearestGopObj, currentGop, currentGopObj, i2;
- for (i2 = 0; i2 < this.gopCache_.length; i2++) {
- currentGopObj = this.gopCache_[i2];
- currentGop = currentGopObj.gop;
- if (!(track.pps && arrayEquals(track.pps[0], currentGopObj.pps[0])) || !(track.sps && arrayEquals(track.sps[0], currentGopObj.sps[0]))) {
- continue;
- }
- if (currentGop.dts < track.timelineStartInfo.dts) {
- continue;
- }
- dtsDistance = nalUnit.dts - currentGop.dts - currentGop.duration;
- if (dtsDistance >= -allowableOverlap && dtsDistance <= halfSecond) {
- if (!nearestGopObj || nearestDistance > dtsDistance) {
- nearestGopObj = currentGopObj;
- nearestDistance = dtsDistance;
- }
- }
- }
- if (nearestGopObj) {
- return nearestGopObj.gop;
- }
- return null;
- };
- this.alignGopsAtStart_ = function(gops) {
- var alignIndex, gopIndex, align, gop, byteLength, nalCount, duration5, alignedGops;
- byteLength = gops.byteLength;
- nalCount = gops.nalCount;
- duration5 = gops.duration;
- alignIndex = gopIndex = 0;
- while (alignIndex < gopsToAlignWith.length && gopIndex < gops.length) {
- align = gopsToAlignWith[alignIndex];
- gop = gops[gopIndex];
- if (align.pts === gop.pts) {
- break;
- }
- if (gop.pts > align.pts) {
- alignIndex++;
- continue;
- }
- gopIndex++;
- byteLength -= gop.byteLength;
- nalCount -= gop.nalCount;
- duration5 -= gop.duration;
- }
- if (gopIndex === 0) {
- return gops;
- }
- if (gopIndex === gops.length) {
- return null;
- }
- alignedGops = gops.slice(gopIndex);
- alignedGops.byteLength = byteLength;
- alignedGops.duration = duration5;
- alignedGops.nalCount = nalCount;
- alignedGops.pts = alignedGops[0].pts;
- alignedGops.dts = alignedGops[0].dts;
- return alignedGops;
- };
- this.alignGopsAtEnd_ = function(gops) {
- var alignIndex, gopIndex, align, gop, alignEndIndex, matchFound;
- alignIndex = gopsToAlignWith.length - 1;
- gopIndex = gops.length - 1;
- alignEndIndex = null;
- matchFound = false;
- while (alignIndex >= 0 && gopIndex >= 0) {
- align = gopsToAlignWith[alignIndex];
- gop = gops[gopIndex];
- if (align.pts === gop.pts) {
- matchFound = true;
- break;
- }
- if (align.pts > gop.pts) {
- alignIndex--;
- continue;
- }
- if (alignIndex === gopsToAlignWith.length - 1) {
- alignEndIndex = gopIndex;
- }
- gopIndex--;
- }
- if (!matchFound && alignEndIndex === null) {
- return null;
- }
- var trimIndex;
- if (matchFound) {
- trimIndex = gopIndex;
- } else {
- trimIndex = alignEndIndex;
- }
- if (trimIndex === 0) {
- return gops;
- }
- var alignedGops = gops.slice(trimIndex);
- var metadata = alignedGops.reduce(function(total, gop2) {
- total.byteLength += gop2.byteLength;
- total.duration += gop2.duration;
- total.nalCount += gop2.nalCount;
- return total;
- }, {
- byteLength: 0,
- duration: 0,
- nalCount: 0
- });
- alignedGops.byteLength = metadata.byteLength;
- alignedGops.duration = metadata.duration;
- alignedGops.nalCount = metadata.nalCount;
- alignedGops.pts = alignedGops[0].pts;
- alignedGops.dts = alignedGops[0].dts;
- return alignedGops;
- };
- this.alignGopsWith = function(newGopsToAlignWith) {
- gopsToAlignWith = newGopsToAlignWith;
- };
- };
- VideoSegmentStream.prototype = new Stream2();
- CoalesceStream = function(options2, metadataStream2) {
- this.numberOfTracks = 0;
- this.metadataStream = metadataStream2;
- options2 = options2 || {};
- if (typeof options2.remux !== "undefined") {
- this.remuxTracks = !!options2.remux;
- } else {
- this.remuxTracks = true;
- }
- if (typeof options2.keepOriginalTimestamps === "boolean") {
- this.keepOriginalTimestamps = options2.keepOriginalTimestamps;
- } else {
- this.keepOriginalTimestamps = false;
- }
- this.pendingTracks = [];
- this.videoTrack = null;
- this.pendingBoxes = [];
- this.pendingCaptions = [];
- this.pendingMetadata = [];
- this.pendingBytes = 0;
- this.emittedTracks = 0;
- CoalesceStream.prototype.init.call(this);
- this.push = function(output) {
- if (output.text) {
- return this.pendingCaptions.push(output);
- }
- if (output.frames) {
- return this.pendingMetadata.push(output);
- }
- this.pendingTracks.push(output.track);
- this.pendingBytes += output.boxes.byteLength;
- if (output.track.type === "video") {
- this.videoTrack = output.track;
- this.pendingBoxes.push(output.boxes);
- }
- if (output.track.type === "audio") {
- this.audioTrack = output.track;
- this.pendingBoxes.unshift(output.boxes);
- }
- };
- };
- CoalesceStream.prototype = new Stream2();
- CoalesceStream.prototype.flush = function(flushSource) {
- var offset = 0, event2 = {
- captions: [],
- captionStreams: {},
- metadata: [],
- info: {}
- }, caption, id32, initSegment, timelineStartPts = 0, i2;
- if (this.pendingTracks.length < this.numberOfTracks) {
- if (flushSource !== "VideoSegmentStream" && flushSource !== "AudioSegmentStream") {
- return;
- } else if (this.remuxTracks) {
- return;
- } else if (this.pendingTracks.length === 0) {
- this.emittedTracks++;
- if (this.emittedTracks >= this.numberOfTracks) {
- this.trigger("done");
- this.emittedTracks = 0;
- }
- return;
- }
- }
- if (this.videoTrack) {
- timelineStartPts = this.videoTrack.timelineStartInfo.pts;
- VIDEO_PROPERTIES.forEach(function(prop) {
- event2.info[prop] = this.videoTrack[prop];
- }, this);
- } else if (this.audioTrack) {
- timelineStartPts = this.audioTrack.timelineStartInfo.pts;
- AUDIO_PROPERTIES.forEach(function(prop) {
- event2.info[prop] = this.audioTrack[prop];
- }, this);
- }
- if (this.videoTrack || this.audioTrack) {
- if (this.pendingTracks.length === 1) {
- event2.type = this.pendingTracks[0].type;
- } else {
- event2.type = "combined";
- }
- this.emittedTracks += this.pendingTracks.length;
- initSegment = mp43.initSegment(this.pendingTracks);
- event2.initSegment = new Uint8Array(initSegment.byteLength);
- event2.initSegment.set(initSegment);
- event2.data = new Uint8Array(this.pendingBytes);
- for (i2 = 0; i2 < this.pendingBoxes.length; i2++) {
- event2.data.set(this.pendingBoxes[i2], offset);
- offset += this.pendingBoxes[i2].byteLength;
- }
- for (i2 = 0; i2 < this.pendingCaptions.length; i2++) {
- caption = this.pendingCaptions[i2];
- caption.startTime = clock2.metadataTsToSeconds(caption.startPts, timelineStartPts, this.keepOriginalTimestamps);
- caption.endTime = clock2.metadataTsToSeconds(caption.endPts, timelineStartPts, this.keepOriginalTimestamps);
- event2.captionStreams[caption.stream] = true;
- event2.captions.push(caption);
- }
- for (i2 = 0; i2 < this.pendingMetadata.length; i2++) {
- id32 = this.pendingMetadata[i2];
- id32.cueTime = clock2.metadataTsToSeconds(id32.pts, timelineStartPts, this.keepOriginalTimestamps);
- event2.metadata.push(id32);
- }
- event2.metadata.dispatchType = this.metadataStream.dispatchType;
- this.pendingTracks.length = 0;
- this.videoTrack = null;
- this.pendingBoxes.length = 0;
- this.pendingCaptions.length = 0;
- this.pendingBytes = 0;
- this.pendingMetadata.length = 0;
- this.trigger("data", event2);
- for (i2 = 0; i2 < event2.captions.length; i2++) {
- caption = event2.captions[i2];
- this.trigger("caption", caption);
- }
- for (i2 = 0; i2 < event2.metadata.length; i2++) {
- id32 = event2.metadata[i2];
- this.trigger("id3Frame", id32);
- }
- }
- if (this.emittedTracks >= this.numberOfTracks) {
- this.trigger("done");
- this.emittedTracks = 0;
- }
- };
- CoalesceStream.prototype.setRemux = function(val) {
- this.remuxTracks = val;
- };
- Transmuxer = function(options2) {
- var self2 = this, hasFlushed = true, videoTrack, audioTrack;
- Transmuxer.prototype.init.call(this);
- options2 = options2 || {};
- this.baseMediaDecodeTime = options2.baseMediaDecodeTime || 0;
- this.transmuxPipeline_ = {};
- this.setupAacPipeline = function() {
- var pipeline = {};
- this.transmuxPipeline_ = pipeline;
- pipeline.type = "aac";
- pipeline.metadataStream = new m2ts.MetadataStream();
- pipeline.aacStream = new AacStream();
- pipeline.audioTimestampRolloverStream = new m2ts.TimestampRolloverStream("audio");
- pipeline.timedMetadataTimestampRolloverStream = new m2ts.TimestampRolloverStream("timed-metadata");
- pipeline.adtsStream = new AdtsStream();
- pipeline.coalesceStream = new CoalesceStream(options2, pipeline.metadataStream);
- pipeline.headOfPipeline = pipeline.aacStream;
- pipeline.aacStream.pipe(pipeline.audioTimestampRolloverStream).pipe(pipeline.adtsStream);
- pipeline.aacStream.pipe(pipeline.timedMetadataTimestampRolloverStream).pipe(pipeline.metadataStream).pipe(pipeline.coalesceStream);
- pipeline.metadataStream.on("timestamp", function(frame) {
- pipeline.aacStream.setTimestamp(frame.timeStamp);
- });
- pipeline.aacStream.on("data", function(data) {
- if (data.type !== "timed-metadata" && data.type !== "audio" || pipeline.audioSegmentStream) {
- return;
- }
- audioTrack = audioTrack || {
- timelineStartInfo: {
- baseMediaDecodeTime: self2.baseMediaDecodeTime
- },
- codec: "adts",
- type: "audio"
- };
- pipeline.coalesceStream.numberOfTracks++;
- pipeline.audioSegmentStream = new AudioSegmentStream(audioTrack, options2);
- pipeline.audioSegmentStream.on("log", self2.getLogTrigger_("audioSegmentStream"));
- pipeline.audioSegmentStream.on("timingInfo", self2.trigger.bind(self2, "audioTimingInfo"));
- pipeline.adtsStream.pipe(pipeline.audioSegmentStream).pipe(pipeline.coalesceStream);
- self2.trigger("trackinfo", {
- hasAudio: !!audioTrack,
- hasVideo: !!videoTrack
- });
- });
- pipeline.coalesceStream.on("data", this.trigger.bind(this, "data"));
- pipeline.coalesceStream.on("done", this.trigger.bind(this, "done"));
- addPipelineLogRetriggers(this, pipeline);
- };
- this.setupTsPipeline = function() {
- var pipeline = {};
- this.transmuxPipeline_ = pipeline;
- pipeline.type = "ts";
- pipeline.metadataStream = new m2ts.MetadataStream();
- pipeline.packetStream = new m2ts.TransportPacketStream();
- pipeline.parseStream = new m2ts.TransportParseStream();
- pipeline.elementaryStream = new m2ts.ElementaryStream();
- pipeline.timestampRolloverStream = new m2ts.TimestampRolloverStream();
- pipeline.adtsStream = new AdtsStream();
- pipeline.h264Stream = new H264Stream();
- pipeline.captionStream = new m2ts.CaptionStream(options2);
- pipeline.coalesceStream = new CoalesceStream(options2, pipeline.metadataStream);
- pipeline.headOfPipeline = pipeline.packetStream;
- pipeline.packetStream.pipe(pipeline.parseStream).pipe(pipeline.elementaryStream).pipe(pipeline.timestampRolloverStream);
- pipeline.timestampRolloverStream.pipe(pipeline.h264Stream);
- pipeline.timestampRolloverStream.pipe(pipeline.adtsStream);
- pipeline.timestampRolloverStream.pipe(pipeline.metadataStream).pipe(pipeline.coalesceStream);
- pipeline.h264Stream.pipe(pipeline.captionStream).pipe(pipeline.coalesceStream);
- pipeline.elementaryStream.on("data", function(data) {
- var i2;
- if (data.type === "metadata") {
- i2 = data.tracks.length;
- while (i2--) {
- if (!videoTrack && data.tracks[i2].type === "video") {
- videoTrack = data.tracks[i2];
- videoTrack.timelineStartInfo.baseMediaDecodeTime = self2.baseMediaDecodeTime;
- } else if (!audioTrack && data.tracks[i2].type === "audio") {
- audioTrack = data.tracks[i2];
- audioTrack.timelineStartInfo.baseMediaDecodeTime = self2.baseMediaDecodeTime;
- }
- }
- if (videoTrack && !pipeline.videoSegmentStream) {
- pipeline.coalesceStream.numberOfTracks++;
- pipeline.videoSegmentStream = new VideoSegmentStream(videoTrack, options2);
- pipeline.videoSegmentStream.on("log", self2.getLogTrigger_("videoSegmentStream"));
- pipeline.videoSegmentStream.on("timelineStartInfo", function(timelineStartInfo) {
- if (audioTrack && !options2.keepOriginalTimestamps) {
- audioTrack.timelineStartInfo = timelineStartInfo;
- pipeline.audioSegmentStream.setEarliestDts(timelineStartInfo.dts - self2.baseMediaDecodeTime);
- }
- });
- pipeline.videoSegmentStream.on("processedGopsInfo", self2.trigger.bind(self2, "gopInfo"));
- pipeline.videoSegmentStream.on("segmentTimingInfo", self2.trigger.bind(self2, "videoSegmentTimingInfo"));
- pipeline.videoSegmentStream.on("baseMediaDecodeTime", function(baseMediaDecodeTime) {
- if (audioTrack) {
- pipeline.audioSegmentStream.setVideoBaseMediaDecodeTime(baseMediaDecodeTime);
- }
- });
- pipeline.videoSegmentStream.on("timingInfo", self2.trigger.bind(self2, "videoTimingInfo"));
- pipeline.h264Stream.pipe(pipeline.videoSegmentStream).pipe(pipeline.coalesceStream);
- }
- if (audioTrack && !pipeline.audioSegmentStream) {
- pipeline.coalesceStream.numberOfTracks++;
- pipeline.audioSegmentStream = new AudioSegmentStream(audioTrack, options2);
- pipeline.audioSegmentStream.on("log", self2.getLogTrigger_("audioSegmentStream"));
- pipeline.audioSegmentStream.on("timingInfo", self2.trigger.bind(self2, "audioTimingInfo"));
- pipeline.audioSegmentStream.on("segmentTimingInfo", self2.trigger.bind(self2, "audioSegmentTimingInfo"));
- pipeline.adtsStream.pipe(pipeline.audioSegmentStream).pipe(pipeline.coalesceStream);
- }
- self2.trigger("trackinfo", {
- hasAudio: !!audioTrack,
- hasVideo: !!videoTrack
- });
- }
- });
- pipeline.coalesceStream.on("data", this.trigger.bind(this, "data"));
- pipeline.coalesceStream.on("id3Frame", function(id3Frame) {
- id3Frame.dispatchType = pipeline.metadataStream.dispatchType;
- self2.trigger("id3Frame", id3Frame);
- });
- pipeline.coalesceStream.on("caption", this.trigger.bind(this, "caption"));
- pipeline.coalesceStream.on("done", this.trigger.bind(this, "done"));
- addPipelineLogRetriggers(this, pipeline);
- };
- this.setBaseMediaDecodeTime = function(baseMediaDecodeTime) {
- var pipeline = this.transmuxPipeline_;
- if (!options2.keepOriginalTimestamps) {
- this.baseMediaDecodeTime = baseMediaDecodeTime;
- }
- if (audioTrack) {
- audioTrack.timelineStartInfo.dts = void 0;
- audioTrack.timelineStartInfo.pts = void 0;
- trackDecodeInfo.clearDtsInfo(audioTrack);
- if (pipeline.audioTimestampRolloverStream) {
- pipeline.audioTimestampRolloverStream.discontinuity();
- }
- }
- if (videoTrack) {
- if (pipeline.videoSegmentStream) {
- pipeline.videoSegmentStream.gopCache_ = [];
- }
- videoTrack.timelineStartInfo.dts = void 0;
- videoTrack.timelineStartInfo.pts = void 0;
- trackDecodeInfo.clearDtsInfo(videoTrack);
- pipeline.captionStream.reset();
- }
- if (pipeline.timestampRolloverStream) {
- pipeline.timestampRolloverStream.discontinuity();
- }
- };
- this.setAudioAppendStart = function(timestamp) {
- if (audioTrack) {
- this.transmuxPipeline_.audioSegmentStream.setAudioAppendStart(timestamp);
- }
- };
- this.setRemux = function(val) {
- var pipeline = this.transmuxPipeline_;
- options2.remux = val;
- if (pipeline && pipeline.coalesceStream) {
- pipeline.coalesceStream.setRemux(val);
- }
- };
- this.alignGopsWith = function(gopsToAlignWith) {
- if (videoTrack && this.transmuxPipeline_.videoSegmentStream) {
- this.transmuxPipeline_.videoSegmentStream.alignGopsWith(gopsToAlignWith);
- }
- };
- this.getLogTrigger_ = function(key) {
- var self3 = this;
- return function(event2) {
- event2.stream = key;
- self3.trigger("log", event2);
- };
- };
- this.push = function(data) {
- if (hasFlushed) {
- var isAac = isLikelyAacData(data);
- if (isAac && this.transmuxPipeline_.type !== "aac") {
- this.setupAacPipeline();
- } else if (!isAac && this.transmuxPipeline_.type !== "ts") {
- this.setupTsPipeline();
- }
- hasFlushed = false;
- }
- this.transmuxPipeline_.headOfPipeline.push(data);
- };
- this.flush = function() {
- hasFlushed = true;
- this.transmuxPipeline_.headOfPipeline.flush();
- };
- this.endTimeline = function() {
- this.transmuxPipeline_.headOfPipeline.endTimeline();
- };
- this.reset = function() {
- if (this.transmuxPipeline_.headOfPipeline) {
- this.transmuxPipeline_.headOfPipeline.reset();
- }
- };
- this.resetCaptions = function() {
- if (this.transmuxPipeline_.captionStream) {
- this.transmuxPipeline_.captionStream.reset();
- }
- };
- };
- Transmuxer.prototype = new Stream2();
- var transmuxer = {
- Transmuxer,
- VideoSegmentStream,
- AudioSegmentStream,
- AUDIO_PROPERTIES,
- VIDEO_PROPERTIES,
- generateSegmentTimingInfo
- };
- var toUnsigned$3 = function(value) {
- return value >>> 0;
- };
- var toHexString$1 = function(value) {
- return ("00" + value.toString(16)).slice(-2);
- };
- var bin = {
- toUnsigned: toUnsigned$3,
- toHexString: toHexString$1
- };
- var parseType$3 = function(buffer) {
- var result = "";
- result += String.fromCharCode(buffer[0]);
- result += String.fromCharCode(buffer[1]);
- result += String.fromCharCode(buffer[2]);
- result += String.fromCharCode(buffer[3]);
- return result;
- };
- var parseType_1 = parseType$3;
- var toUnsigned$2 = bin.toUnsigned;
- var parseType$2 = parseType_1;
- var findBox$2 = function(data, path) {
- var results = [], i2, size, type3, end, subresults;
- if (!path.length) {
- return null;
- }
- for (i2 = 0; i2 < data.byteLength; ) {
- size = toUnsigned$2(data[i2] << 24 | data[i2 + 1] << 16 | data[i2 + 2] << 8 | data[i2 + 3]);
- type3 = parseType$2(data.subarray(i2 + 4, i2 + 8));
- end = size > 1 ? i2 + size : data.byteLength;
- if (type3 === path[0]) {
- if (path.length === 1) {
- results.push(data.subarray(i2 + 8, end));
- } else {
- subresults = findBox$2(data.subarray(i2 + 8, end), path.slice(1));
- if (subresults.length) {
- results = results.concat(subresults);
- }
- }
- }
- i2 = end;
- }
- return results;
- };
- var findBox_1 = findBox$2;
- var toUnsigned$1 = bin.toUnsigned;
- var getUint64$22 = numbers2.getUint64;
- var tfdt = function(data) {
- var result = {
- version: data[0],
- flags: new Uint8Array(data.subarray(1, 4))
- };
- if (result.version === 1) {
- result.baseMediaDecodeTime = getUint64$22(data.subarray(4));
- } else {
- result.baseMediaDecodeTime = toUnsigned$1(data[4] << 24 | data[5] << 16 | data[6] << 8 | data[7]);
- }
- return result;
- };
- var parseTfdt$2 = tfdt;
- var parseSampleFlags$1 = function(flags) {
- return {
- isLeading: (flags[0] & 12) >>> 2,
- dependsOn: flags[0] & 3,
- isDependedOn: (flags[1] & 192) >>> 6,
- hasRedundancy: (flags[1] & 48) >>> 4,
- paddingValue: (flags[1] & 14) >>> 1,
- isNonSyncSample: flags[1] & 1,
- degradationPriority: flags[2] << 8 | flags[3]
- };
- };
- var parseSampleFlags_1 = parseSampleFlags$1;
- var parseSampleFlags = parseSampleFlags_1;
- var trun = function(data) {
- var result = {
- version: data[0],
- flags: new Uint8Array(data.subarray(1, 4)),
- samples: []
- }, view = new DataView(data.buffer, data.byteOffset, data.byteLength), dataOffsetPresent = result.flags[2] & 1, firstSampleFlagsPresent = result.flags[2] & 4, sampleDurationPresent = result.flags[1] & 1, sampleSizePresent = result.flags[1] & 2, sampleFlagsPresent = result.flags[1] & 4, sampleCompositionTimeOffsetPresent = result.flags[1] & 8, sampleCount = view.getUint32(4), offset = 8, sample;
- if (dataOffsetPresent) {
- result.dataOffset = view.getInt32(offset);
- offset += 4;
- }
- if (firstSampleFlagsPresent && sampleCount) {
- sample = {
- flags: parseSampleFlags(data.subarray(offset, offset + 4))
- };
- offset += 4;
- if (sampleDurationPresent) {
- sample.duration = view.getUint32(offset);
- offset += 4;
- }
- if (sampleSizePresent) {
- sample.size = view.getUint32(offset);
- offset += 4;
- }
- if (sampleCompositionTimeOffsetPresent) {
- if (result.version === 1) {
- sample.compositionTimeOffset = view.getInt32(offset);
- } else {
- sample.compositionTimeOffset = view.getUint32(offset);
- }
- offset += 4;
- }
- result.samples.push(sample);
- sampleCount--;
- }
- while (sampleCount--) {
- sample = {};
- if (sampleDurationPresent) {
- sample.duration = view.getUint32(offset);
- offset += 4;
- }
- if (sampleSizePresent) {
- sample.size = view.getUint32(offset);
- offset += 4;
- }
- if (sampleFlagsPresent) {
- sample.flags = parseSampleFlags(data.subarray(offset, offset + 4));
- offset += 4;
- }
- if (sampleCompositionTimeOffsetPresent) {
- if (result.version === 1) {
- sample.compositionTimeOffset = view.getInt32(offset);
- } else {
- sample.compositionTimeOffset = view.getUint32(offset);
- }
- offset += 4;
- }
- result.samples.push(sample);
- }
- return result;
- };
- var parseTrun$2 = trun;
- var tfhd = function(data) {
- var view = new DataView(data.buffer, data.byteOffset, data.byteLength), result = {
- version: data[0],
- flags: new Uint8Array(data.subarray(1, 4)),
- trackId: view.getUint32(4)
- }, baseDataOffsetPresent = result.flags[2] & 1, sampleDescriptionIndexPresent = result.flags[2] & 2, defaultSampleDurationPresent = result.flags[2] & 8, defaultSampleSizePresent = result.flags[2] & 16, defaultSampleFlagsPresent = result.flags[2] & 32, durationIsEmpty = result.flags[0] & 65536, defaultBaseIsMoof = result.flags[0] & 131072, i2;
- i2 = 8;
- if (baseDataOffsetPresent) {
- i2 += 4;
- result.baseDataOffset = view.getUint32(12);
- i2 += 4;
- }
- if (sampleDescriptionIndexPresent) {
- result.sampleDescriptionIndex = view.getUint32(i2);
- i2 += 4;
- }
- if (defaultSampleDurationPresent) {
- result.defaultSampleDuration = view.getUint32(i2);
- i2 += 4;
- }
- if (defaultSampleSizePresent) {
- result.defaultSampleSize = view.getUint32(i2);
- i2 += 4;
- }
- if (defaultSampleFlagsPresent) {
- result.defaultSampleFlags = view.getUint32(i2);
- }
- if (durationIsEmpty) {
- result.durationIsEmpty = true;
- }
- if (!baseDataOffsetPresent && defaultBaseIsMoof) {
- result.baseDataOffsetIsMoof = true;
- }
- return result;
- };
- var parseTfhd$2 = tfhd;
- var win2;
- if (typeof window !== "undefined") {
- win2 = window;
- } else if (typeof commonjsGlobal2 !== "undefined") {
- win2 = commonjsGlobal2;
- } else if (typeof self !== "undefined") {
- win2 = self;
- } else {
- win2 = {};
- }
- var window_12 = win2;
- var discardEmulationPreventionBytes4 = captionPacketParser.discardEmulationPreventionBytes;
- var CaptionStream = captionStream.CaptionStream;
- var findBox$12 = findBox_1;
- var parseTfdt$1 = parseTfdt$2;
- var parseTrun$1 = parseTrun$2;
- var parseTfhd$1 = parseTfhd$2;
- var window$22 = window_12;
- var mapToSample = function(offset, samples) {
- var approximateOffset = offset;
- for (var i2 = 0; i2 < samples.length; i2++) {
- var sample = samples[i2];
- if (approximateOffset < sample.size) {
- return sample;
- }
- approximateOffset -= sample.size;
- }
- return null;
- };
- var findSeiNals = function(avcStream, samples, trackId) {
- var avcView = new DataView(avcStream.buffer, avcStream.byteOffset, avcStream.byteLength), result = {
- logs: [],
- seiNals: []
- }, seiNal, i2, length, lastMatchedSample;
- for (i2 = 0; i2 + 4 < avcStream.length; i2 += length) {
- length = avcView.getUint32(i2);
- i2 += 4;
- if (length <= 0) {
- continue;
- }
- switch (avcStream[i2] & 31) {
- case 6:
- var data = avcStream.subarray(i2 + 1, i2 + 1 + length);
- var matchingSample = mapToSample(i2, samples);
- seiNal = {
- nalUnitType: "sei_rbsp",
- size: length,
- data,
- escapedRBSP: discardEmulationPreventionBytes4(data),
- trackId
- };
- if (matchingSample) {
- seiNal.pts = matchingSample.pts;
- seiNal.dts = matchingSample.dts;
- lastMatchedSample = matchingSample;
- } else if (lastMatchedSample) {
- seiNal.pts = lastMatchedSample.pts;
- seiNal.dts = lastMatchedSample.dts;
- } else {
- result.logs.push({
- level: "warn",
- message: "We've encountered a nal unit without data at " + i2 + " for trackId " + trackId + ". See mux.js#223."
- });
- break;
- }
- result.seiNals.push(seiNal);
- break;
- }
- }
- return result;
- };
- var parseSamples = function(truns, baseMediaDecodeTime, tfhd2) {
- var currentDts = baseMediaDecodeTime;
- var defaultSampleDuration = tfhd2.defaultSampleDuration || 0;
- var defaultSampleSize = tfhd2.defaultSampleSize || 0;
- var trackId = tfhd2.trackId;
- var allSamples = [];
- truns.forEach(function(trun2) {
- var trackRun = parseTrun$1(trun2);
- var samples = trackRun.samples;
- samples.forEach(function(sample) {
- if (sample.duration === void 0) {
- sample.duration = defaultSampleDuration;
- }
- if (sample.size === void 0) {
- sample.size = defaultSampleSize;
- }
- sample.trackId = trackId;
- sample.dts = currentDts;
- if (sample.compositionTimeOffset === void 0) {
- sample.compositionTimeOffset = 0;
- }
- if (typeof currentDts === "bigint") {
- sample.pts = currentDts + window$22.BigInt(sample.compositionTimeOffset);
- currentDts += window$22.BigInt(sample.duration);
- } else {
- sample.pts = currentDts + sample.compositionTimeOffset;
- currentDts += sample.duration;
- }
- });
- allSamples = allSamples.concat(samples);
- });
- return allSamples;
- };
- var parseCaptionNals = function(segment, videoTrackId) {
- var trafs = findBox$12(segment, ["moof", "traf"]);
- var mdats = findBox$12(segment, ["mdat"]);
- var captionNals = {};
- var mdatTrafPairs = [];
- mdats.forEach(function(mdat2, index2) {
- var matchingTraf = trafs[index2];
- mdatTrafPairs.push({
- mdat: mdat2,
- traf: matchingTraf
- });
- });
- mdatTrafPairs.forEach(function(pair) {
- var mdat2 = pair.mdat;
- var traf2 = pair.traf;
- var tfhd2 = findBox$12(traf2, ["tfhd"]);
- var headerInfo = parseTfhd$1(tfhd2[0]);
- var trackId = headerInfo.trackId;
- var tfdt2 = findBox$12(traf2, ["tfdt"]);
- var baseMediaDecodeTime = tfdt2.length > 0 ? parseTfdt$1(tfdt2[0]).baseMediaDecodeTime : 0;
- var truns = findBox$12(traf2, ["trun"]);
- var samples;
- var result;
- if (videoTrackId === trackId && truns.length > 0) {
- samples = parseSamples(truns, baseMediaDecodeTime, headerInfo);
- result = findSeiNals(mdat2, samples, trackId);
- if (!captionNals[trackId]) {
- captionNals[trackId] = {
- seiNals: [],
- logs: []
- };
- }
- captionNals[trackId].seiNals = captionNals[trackId].seiNals.concat(result.seiNals);
- captionNals[trackId].logs = captionNals[trackId].logs.concat(result.logs);
- }
- });
- return captionNals;
- };
- var parseEmbeddedCaptions = function(segment, trackId, timescale3) {
- var captionNals;
- if (trackId === null) {
- return null;
- }
- captionNals = parseCaptionNals(segment, trackId);
- var trackNals = captionNals[trackId] || {};
- return {
- seiNals: trackNals.seiNals,
- logs: trackNals.logs,
- timescale: timescale3
- };
- };
- var CaptionParser = function() {
- var isInitialized = false;
- var captionStream2;
- var segmentCache;
- var trackId;
- var timescale3;
- var parsedCaptions;
- var parsingPartial;
- this.isInitialized = function() {
- return isInitialized;
- };
- this.init = function(options2) {
- captionStream2 = new CaptionStream();
- isInitialized = true;
- parsingPartial = options2 ? options2.isPartial : false;
- captionStream2.on("data", function(event2) {
- event2.startTime = event2.startPts / timescale3;
- event2.endTime = event2.endPts / timescale3;
- parsedCaptions.captions.push(event2);
- parsedCaptions.captionStreams[event2.stream] = true;
- });
- captionStream2.on("log", function(log2) {
- parsedCaptions.logs.push(log2);
- });
- };
- this.isNewInit = function(videoTrackIds, timescales) {
- if (videoTrackIds && videoTrackIds.length === 0 || timescales && typeof timescales === "object" && Object.keys(timescales).length === 0) {
- return false;
- }
- return trackId !== videoTrackIds[0] || timescale3 !== timescales[trackId];
- };
- this.parse = function(segment, videoTrackIds, timescales) {
- var parsedData;
- if (!this.isInitialized()) {
- return null;
- } else if (!videoTrackIds || !timescales) {
- return null;
- } else if (this.isNewInit(videoTrackIds, timescales)) {
- trackId = videoTrackIds[0];
- timescale3 = timescales[trackId];
- } else if (trackId === null || !timescale3) {
- segmentCache.push(segment);
- return null;
- }
- while (segmentCache.length > 0) {
- var cachedSegment = segmentCache.shift();
- this.parse(cachedSegment, videoTrackIds, timescales);
- }
- parsedData = parseEmbeddedCaptions(segment, trackId, timescale3);
- if (parsedData && parsedData.logs) {
- parsedCaptions.logs = parsedCaptions.logs.concat(parsedData.logs);
- }
- if (parsedData === null || !parsedData.seiNals) {
- if (parsedCaptions.logs.length) {
- return {
- logs: parsedCaptions.logs,
- captions: [],
- captionStreams: []
- };
- }
- return null;
- }
- this.pushNals(parsedData.seiNals);
- this.flushStream();
- return parsedCaptions;
- };
- this.pushNals = function(nals) {
- if (!this.isInitialized() || !nals || nals.length === 0) {
- return null;
- }
- nals.forEach(function(nal) {
- captionStream2.push(nal);
- });
- };
- this.flushStream = function() {
- if (!this.isInitialized()) {
- return null;
- }
- if (!parsingPartial) {
- captionStream2.flush();
- } else {
- captionStream2.partialFlush();
- }
- };
- this.clearParsedCaptions = function() {
- parsedCaptions.captions = [];
- parsedCaptions.captionStreams = {};
- parsedCaptions.logs = [];
- };
- this.resetCaptionStream = function() {
- if (!this.isInitialized()) {
- return null;
- }
- captionStream2.reset();
- };
- this.clearAllCaptions = function() {
- this.clearParsedCaptions();
- this.resetCaptionStream();
- };
- this.reset = function() {
- segmentCache = [];
- trackId = null;
- timescale3 = null;
- if (!parsedCaptions) {
- parsedCaptions = {
- captions: [],
- captionStreams: {},
- logs: []
- };
- } else {
- this.clearParsedCaptions();
- }
- this.resetCaptionStream();
- };
- this.reset();
- };
- var captionParser = CaptionParser;
- var uint8ToCString$1 = function(data) {
- var index2 = 0;
- var curChar = String.fromCharCode(data[index2]);
- var retString = "";
- while (curChar !== "\0") {
- retString += curChar;
- index2++;
- curChar = String.fromCharCode(data[index2]);
- }
- retString += curChar;
- return retString;
- };
- var string = {
- uint8ToCString: uint8ToCString$1
- };
- var uint8ToCString = string.uint8ToCString;
- var getUint64$12 = numbers2.getUint64;
- var parseEmsgBox = function(boxData) {
- var offset = 4;
- var version2 = boxData[0];
- var scheme_id_uri, value, timescale3, presentation_time, presentation_time_delta, event_duration, id, message_data;
- if (version2 === 0) {
- scheme_id_uri = uint8ToCString(boxData.subarray(offset));
- offset += scheme_id_uri.length;
- value = uint8ToCString(boxData.subarray(offset));
- offset += value.length;
- var dv = new DataView(boxData.buffer);
- timescale3 = dv.getUint32(offset);
- offset += 4;
- presentation_time_delta = dv.getUint32(offset);
- offset += 4;
- event_duration = dv.getUint32(offset);
- offset += 4;
- id = dv.getUint32(offset);
- offset += 4;
- } else if (version2 === 1) {
- var dv = new DataView(boxData.buffer);
- timescale3 = dv.getUint32(offset);
- offset += 4;
- presentation_time = getUint64$12(boxData.subarray(offset));
- offset += 8;
- event_duration = dv.getUint32(offset);
- offset += 4;
- id = dv.getUint32(offset);
- offset += 4;
- scheme_id_uri = uint8ToCString(boxData.subarray(offset));
- offset += scheme_id_uri.length;
- value = uint8ToCString(boxData.subarray(offset));
- offset += value.length;
- }
- message_data = new Uint8Array(boxData.subarray(offset, boxData.byteLength));
- var emsgBox = {
- scheme_id_uri,
- value,
- timescale: timescale3 ? timescale3 : 1,
- presentation_time,
- presentation_time_delta,
- event_duration,
- id,
- message_data
- };
- return isValidEmsgBox(version2, emsgBox) ? emsgBox : void 0;
- };
- var scaleTime = function(presentationTime, timescale3, timeDelta, offset) {
- return presentationTime || presentationTime === 0 ? presentationTime / timescale3 : offset + timeDelta / timescale3;
- };
- var isValidEmsgBox = function(version2, emsg2) {
- var hasScheme = emsg2.scheme_id_uri !== "\0";
- var isValidV0Box = version2 === 0 && isDefined(emsg2.presentation_time_delta) && hasScheme;
- var isValidV1Box = version2 === 1 && isDefined(emsg2.presentation_time) && hasScheme;
- return !(version2 > 1) && isValidV0Box || isValidV1Box;
- };
- var isDefined = function(data) {
- return data !== void 0 || data !== null;
- };
- var emsg$1 = {
- parseEmsgBox,
- scaleTime
- };
- var toUnsigned = bin.toUnsigned;
- var toHexString = bin.toHexString;
- var findBox4 = findBox_1;
- var parseType$1 = parseType_1;
- var emsg = emsg$1;
- var parseTfhd = parseTfhd$2;
- var parseTrun = parseTrun$2;
- var parseTfdt = parseTfdt$2;
- var getUint642 = numbers2.getUint64;
- var timescale2, startTime, compositionStartTime, getVideoTrackIds, getTracks, getTimescaleFromMediaHeader, getEmsgID3;
- var window$12 = window_12;
- var parseId3Frames = parseId3.parseId3Frames;
- timescale2 = function(init) {
- var result = {}, traks = findBox4(init, ["moov", "trak"]);
- return traks.reduce(function(result2, trak2) {
- var tkhd2, version2, index2, id, mdhd2;
- tkhd2 = findBox4(trak2, ["tkhd"])[0];
- if (!tkhd2) {
- return null;
- }
- version2 = tkhd2[0];
- index2 = version2 === 0 ? 12 : 20;
- id = toUnsigned(tkhd2[index2] << 24 | tkhd2[index2 + 1] << 16 | tkhd2[index2 + 2] << 8 | tkhd2[index2 + 3]);
- mdhd2 = findBox4(trak2, ["mdia", "mdhd"])[0];
- if (!mdhd2) {
- return null;
- }
- version2 = mdhd2[0];
- index2 = version2 === 0 ? 12 : 20;
- result2[id] = toUnsigned(mdhd2[index2] << 24 | mdhd2[index2 + 1] << 16 | mdhd2[index2 + 2] << 8 | mdhd2[index2 + 3]);
- return result2;
- }, result);
- };
- startTime = function(timescale3, fragment) {
- var trafs;
- trafs = findBox4(fragment, ["moof", "traf"]);
- var lowestTime = trafs.reduce(function(acc, traf2) {
- var tfhd2 = findBox4(traf2, ["tfhd"])[0];
- var id = toUnsigned(tfhd2[4] << 24 | tfhd2[5] << 16 | tfhd2[6] << 8 | tfhd2[7]);
- var scale = timescale3[id] || 9e4;
- var tfdt2 = findBox4(traf2, ["tfdt"])[0];
- var dv = new DataView(tfdt2.buffer, tfdt2.byteOffset, tfdt2.byteLength);
- var baseTime;
- if (tfdt2[0] === 1) {
- baseTime = getUint642(tfdt2.subarray(4, 12));
- } else {
- baseTime = dv.getUint32(4);
- }
- let seconds;
- if (typeof baseTime === "bigint") {
- seconds = baseTime / window$12.BigInt(scale);
- } else if (typeof baseTime === "number" && !isNaN(baseTime)) {
- seconds = baseTime / scale;
- }
- if (seconds < Number.MAX_SAFE_INTEGER) {
- seconds = Number(seconds);
- }
- if (seconds < acc) {
- acc = seconds;
- }
- return acc;
- }, Infinity);
- return typeof lowestTime === "bigint" || isFinite(lowestTime) ? lowestTime : 0;
- };
- compositionStartTime = function(timescales, fragment) {
- var trafBoxes = findBox4(fragment, ["moof", "traf"]);
- var baseMediaDecodeTime = 0;
- var compositionTimeOffset = 0;
- var trackId;
- if (trafBoxes && trafBoxes.length) {
- var tfhd2 = findBox4(trafBoxes[0], ["tfhd"])[0];
- var trun2 = findBox4(trafBoxes[0], ["trun"])[0];
- var tfdt2 = findBox4(trafBoxes[0], ["tfdt"])[0];
- if (tfhd2) {
- var parsedTfhd = parseTfhd(tfhd2);
- trackId = parsedTfhd.trackId;
- }
- if (tfdt2) {
- var parsedTfdt = parseTfdt(tfdt2);
- baseMediaDecodeTime = parsedTfdt.baseMediaDecodeTime;
- }
- if (trun2) {
- var parsedTrun = parseTrun(trun2);
- if (parsedTrun.samples && parsedTrun.samples.length) {
- compositionTimeOffset = parsedTrun.samples[0].compositionTimeOffset || 0;
- }
- }
- }
- var timescale3 = timescales[trackId] || 9e4;
- if (typeof baseMediaDecodeTime === "bigint") {
- compositionTimeOffset = window$12.BigInt(compositionTimeOffset);
- timescale3 = window$12.BigInt(timescale3);
- }
- var result = (baseMediaDecodeTime + compositionTimeOffset) / timescale3;
- if (typeof result === "bigint" && result < Number.MAX_SAFE_INTEGER) {
- result = Number(result);
- }
- return result;
- };
- getVideoTrackIds = function(init) {
- var traks = findBox4(init, ["moov", "trak"]);
- var videoTrackIds = [];
- traks.forEach(function(trak2) {
- var hdlrs = findBox4(trak2, ["mdia", "hdlr"]);
- var tkhds = findBox4(trak2, ["tkhd"]);
- hdlrs.forEach(function(hdlr2, index2) {
- var handlerType = parseType$1(hdlr2.subarray(8, 12));
- var tkhd2 = tkhds[index2];
- var view;
- var version2;
- var trackId;
- if (handlerType === "vide") {
- view = new DataView(tkhd2.buffer, tkhd2.byteOffset, tkhd2.byteLength);
- version2 = view.getUint8(0);
- trackId = version2 === 0 ? view.getUint32(12) : view.getUint32(20);
- videoTrackIds.push(trackId);
- }
- });
- });
- return videoTrackIds;
- };
- getTimescaleFromMediaHeader = function(mdhd2) {
- var version2 = mdhd2[0];
- var index2 = version2 === 0 ? 12 : 20;
- return toUnsigned(mdhd2[index2] << 24 | mdhd2[index2 + 1] << 16 | mdhd2[index2 + 2] << 8 | mdhd2[index2 + 3]);
- };
- getTracks = function(init) {
- var traks = findBox4(init, ["moov", "trak"]);
- var tracks = [];
- traks.forEach(function(trak2) {
- var track = {};
- var tkhd2 = findBox4(trak2, ["tkhd"])[0];
- var view, tkhdVersion;
- if (tkhd2) {
- view = new DataView(tkhd2.buffer, tkhd2.byteOffset, tkhd2.byteLength);
- tkhdVersion = view.getUint8(0);
- track.id = tkhdVersion === 0 ? view.getUint32(12) : view.getUint32(20);
- }
- var hdlr2 = findBox4(trak2, ["mdia", "hdlr"])[0];
- if (hdlr2) {
- var type3 = parseType$1(hdlr2.subarray(8, 12));
- if (type3 === "vide") {
- track.type = "video";
- } else if (type3 === "soun") {
- track.type = "audio";
- } else {
- track.type = type3;
- }
- }
- var stsd2 = findBox4(trak2, ["mdia", "minf", "stbl", "stsd"])[0];
- if (stsd2) {
- var sampleDescriptions = stsd2.subarray(8);
- track.codec = parseType$1(sampleDescriptions.subarray(4, 8));
- var codecBox = findBox4(sampleDescriptions, [track.codec])[0];
- var codecConfig, codecConfigType;
- if (codecBox) {
- if (/^[asm]vc[1-9]$/i.test(track.codec)) {
- codecConfig = codecBox.subarray(78);
- codecConfigType = parseType$1(codecConfig.subarray(4, 8));
- if (codecConfigType === "avcC" && codecConfig.length > 11) {
- track.codec += ".";
- track.codec += toHexString(codecConfig[9]);
- track.codec += toHexString(codecConfig[10]);
- track.codec += toHexString(codecConfig[11]);
- } else {
- track.codec = "avc1.4d400d";
- }
- } else if (/^mp4[a,v]$/i.test(track.codec)) {
- codecConfig = codecBox.subarray(28);
- codecConfigType = parseType$1(codecConfig.subarray(4, 8));
- if (codecConfigType === "esds" && codecConfig.length > 20 && codecConfig[19] !== 0) {
- track.codec += "." + toHexString(codecConfig[19]);
- track.codec += "." + toHexString(codecConfig[20] >>> 2 & 63).replace(/^0/, "");
- } else {
- track.codec = "mp4a.40.2";
- }
- } else {
- track.codec = track.codec.toLowerCase();
- }
- }
- }
- var mdhd2 = findBox4(trak2, ["mdia", "mdhd"])[0];
- if (mdhd2) {
- track.timescale = getTimescaleFromMediaHeader(mdhd2);
- }
- tracks.push(track);
- });
- return tracks;
- };
- getEmsgID3 = function(segmentData, offset = 0) {
- var emsgBoxes = findBox4(segmentData, ["emsg"]);
- return emsgBoxes.map((data) => {
- var parsedBox = emsg.parseEmsgBox(new Uint8Array(data));
- var parsedId3Frames = parseId3Frames(parsedBox.message_data);
- return {
- cueTime: emsg.scaleTime(parsedBox.presentation_time, parsedBox.timescale, parsedBox.presentation_time_delta, offset),
- duration: emsg.scaleTime(parsedBox.event_duration, parsedBox.timescale),
- frames: parsedId3Frames
- };
- });
- };
- var probe$2 = {
- findBox: findBox4,
- parseType: parseType$1,
- timescale: timescale2,
- startTime,
- compositionStartTime,
- videoTrackIds: getVideoTrackIds,
- tracks: getTracks,
- getTimescaleFromMediaHeader,
- getEmsgID3
- };
- var StreamTypes$1 = streamTypes;
- var parsePid = function(packet) {
- var pid = packet[1] & 31;
- pid <<= 8;
- pid |= packet[2];
- return pid;
- };
- var parsePayloadUnitStartIndicator = function(packet) {
- return !!(packet[1] & 64);
- };
- var parseAdaptionField = function(packet) {
- var offset = 0;
- if ((packet[3] & 48) >>> 4 > 1) {
- offset += packet[4] + 1;
- }
- return offset;
- };
- var parseType = function(packet, pmtPid) {
- var pid = parsePid(packet);
- if (pid === 0) {
- return "pat";
- } else if (pid === pmtPid) {
- return "pmt";
- } else if (pmtPid) {
- return "pes";
- }
- return null;
- };
- var parsePat = function(packet) {
- var pusi = parsePayloadUnitStartIndicator(packet);
- var offset = 4 + parseAdaptionField(packet);
- if (pusi) {
- offset += packet[offset] + 1;
- }
- return (packet[offset + 10] & 31) << 8 | packet[offset + 11];
- };
- var parsePmt = function(packet) {
- var programMapTable = {};
- var pusi = parsePayloadUnitStartIndicator(packet);
- var payloadOffset = 4 + parseAdaptionField(packet);
- if (pusi) {
- payloadOffset += packet[payloadOffset] + 1;
- }
- if (!(packet[payloadOffset + 5] & 1)) {
- return;
- }
- var sectionLength, tableEnd, programInfoLength;
- sectionLength = (packet[payloadOffset + 1] & 15) << 8 | packet[payloadOffset + 2];
- tableEnd = 3 + sectionLength - 4;
- programInfoLength = (packet[payloadOffset + 10] & 15) << 8 | packet[payloadOffset + 11];
- var offset = 12 + programInfoLength;
- while (offset < tableEnd) {
- var i2 = payloadOffset + offset;
- programMapTable[(packet[i2 + 1] & 31) << 8 | packet[i2 + 2]] = packet[i2];
- offset += ((packet[i2 + 3] & 15) << 8 | packet[i2 + 4]) + 5;
- }
- return programMapTable;
- };
- var parsePesType = function(packet, programMapTable) {
- var pid = parsePid(packet);
- var type3 = programMapTable[pid];
- switch (type3) {
- case StreamTypes$1.H264_STREAM_TYPE:
- return "video";
- case StreamTypes$1.ADTS_STREAM_TYPE:
- return "audio";
- case StreamTypes$1.METADATA_STREAM_TYPE:
- return "timed-metadata";
- default:
- return null;
- }
- };
- var parsePesTime = function(packet) {
- var pusi = parsePayloadUnitStartIndicator(packet);
- if (!pusi) {
- return null;
- }
- var offset = 4 + parseAdaptionField(packet);
- if (offset >= packet.byteLength) {
- return null;
- }
- var pes = null;
- var ptsDtsFlags;
- ptsDtsFlags = packet[offset + 7];
- if (ptsDtsFlags & 192) {
- pes = {};
- pes.pts = (packet[offset + 9] & 14) << 27 | (packet[offset + 10] & 255) << 20 | (packet[offset + 11] & 254) << 12 | (packet[offset + 12] & 255) << 5 | (packet[offset + 13] & 254) >>> 3;
- pes.pts *= 4;
- pes.pts += (packet[offset + 13] & 6) >>> 1;
- pes.dts = pes.pts;
- if (ptsDtsFlags & 64) {
- pes.dts = (packet[offset + 14] & 14) << 27 | (packet[offset + 15] & 255) << 20 | (packet[offset + 16] & 254) << 12 | (packet[offset + 17] & 255) << 5 | (packet[offset + 18] & 254) >>> 3;
- pes.dts *= 4;
- pes.dts += (packet[offset + 18] & 6) >>> 1;
- }
- }
- return pes;
- };
- var parseNalUnitType = function(type3) {
- switch (type3) {
- case 5:
- return "slice_layer_without_partitioning_rbsp_idr";
- case 6:
- return "sei_rbsp";
- case 7:
- return "seq_parameter_set_rbsp";
- case 8:
- return "pic_parameter_set_rbsp";
- case 9:
- return "access_unit_delimiter_rbsp";
- default:
- return null;
- }
- };
- var videoPacketContainsKeyFrame = function(packet) {
- var offset = 4 + parseAdaptionField(packet);
- var frameBuffer = packet.subarray(offset);
- var frameI = 0;
- var frameSyncPoint = 0;
- var foundKeyFrame = false;
- var nalType;
- for (; frameSyncPoint < frameBuffer.byteLength - 3; frameSyncPoint++) {
- if (frameBuffer[frameSyncPoint + 2] === 1) {
- frameI = frameSyncPoint + 5;
- break;
- }
- }
- while (frameI < frameBuffer.byteLength) {
- switch (frameBuffer[frameI]) {
- case 0:
- if (frameBuffer[frameI - 1] !== 0) {
- frameI += 2;
- break;
- } else if (frameBuffer[frameI - 2] !== 0) {
- frameI++;
- break;
- }
- if (frameSyncPoint + 3 !== frameI - 2) {
- nalType = parseNalUnitType(frameBuffer[frameSyncPoint + 3] & 31);
- if (nalType === "slice_layer_without_partitioning_rbsp_idr") {
- foundKeyFrame = true;
- }
- }
- do {
- frameI++;
- } while (frameBuffer[frameI] !== 1 && frameI < frameBuffer.length);
- frameSyncPoint = frameI - 2;
- frameI += 3;
- break;
- case 1:
- if (frameBuffer[frameI - 1] !== 0 || frameBuffer[frameI - 2] !== 0) {
- frameI += 3;
- break;
- }
- nalType = parseNalUnitType(frameBuffer[frameSyncPoint + 3] & 31);
- if (nalType === "slice_layer_without_partitioning_rbsp_idr") {
- foundKeyFrame = true;
- }
- frameSyncPoint = frameI - 2;
- frameI += 3;
- break;
- default:
- frameI += 3;
- break;
- }
- }
- frameBuffer = frameBuffer.subarray(frameSyncPoint);
- frameI -= frameSyncPoint;
- frameSyncPoint = 0;
- if (frameBuffer && frameBuffer.byteLength > 3) {
- nalType = parseNalUnitType(frameBuffer[frameSyncPoint + 3] & 31);
- if (nalType === "slice_layer_without_partitioning_rbsp_idr") {
- foundKeyFrame = true;
- }
- }
- return foundKeyFrame;
- };
- var probe$1 = {
- parseType,
- parsePat,
- parsePmt,
- parsePayloadUnitStartIndicator,
- parsePesType,
- parsePesTime,
- videoPacketContainsKeyFrame
- };
- var StreamTypes = streamTypes;
- var handleRollover = timestampRolloverStream.handleRollover;
- var probe = {};
- probe.ts = probe$1;
- probe.aac = utils2;
- var ONE_SECOND_IN_TS2 = clock$2.ONE_SECOND_IN_TS;
- var MP2T_PACKET_LENGTH = 188, SYNC_BYTE = 71;
- var parsePsi_ = function(bytes, pmt) {
- var startIndex = 0, endIndex = MP2T_PACKET_LENGTH, packet, type3;
- while (endIndex < bytes.byteLength) {
- if (bytes[startIndex] === SYNC_BYTE && bytes[endIndex] === SYNC_BYTE) {
- packet = bytes.subarray(startIndex, endIndex);
- type3 = probe.ts.parseType(packet, pmt.pid);
- switch (type3) {
- case "pat":
- pmt.pid = probe.ts.parsePat(packet);
- break;
- case "pmt":
- var table = probe.ts.parsePmt(packet);
- pmt.table = pmt.table || {};
- Object.keys(table).forEach(function(key) {
- pmt.table[key] = table[key];
- });
- break;
- }
- startIndex += MP2T_PACKET_LENGTH;
- endIndex += MP2T_PACKET_LENGTH;
- continue;
- }
- startIndex++;
- endIndex++;
- }
- };
- var parseAudioPes_ = function(bytes, pmt, result) {
- var startIndex = 0, endIndex = MP2T_PACKET_LENGTH, packet, type3, pesType, pusi, parsed;
- var endLoop = false;
- while (endIndex <= bytes.byteLength) {
- if (bytes[startIndex] === SYNC_BYTE && (bytes[endIndex] === SYNC_BYTE || endIndex === bytes.byteLength)) {
- packet = bytes.subarray(startIndex, endIndex);
- type3 = probe.ts.parseType(packet, pmt.pid);
- switch (type3) {
- case "pes":
- pesType = probe.ts.parsePesType(packet, pmt.table);
- pusi = probe.ts.parsePayloadUnitStartIndicator(packet);
- if (pesType === "audio" && pusi) {
- parsed = probe.ts.parsePesTime(packet);
- if (parsed) {
- parsed.type = "audio";
- result.audio.push(parsed);
- endLoop = true;
- }
- }
- break;
- }
- if (endLoop) {
- break;
- }
- startIndex += MP2T_PACKET_LENGTH;
- endIndex += MP2T_PACKET_LENGTH;
- continue;
- }
- startIndex++;
- endIndex++;
- }
- endIndex = bytes.byteLength;
- startIndex = endIndex - MP2T_PACKET_LENGTH;
- endLoop = false;
- while (startIndex >= 0) {
- if (bytes[startIndex] === SYNC_BYTE && (bytes[endIndex] === SYNC_BYTE || endIndex === bytes.byteLength)) {
- packet = bytes.subarray(startIndex, endIndex);
- type3 = probe.ts.parseType(packet, pmt.pid);
- switch (type3) {
- case "pes":
- pesType = probe.ts.parsePesType(packet, pmt.table);
- pusi = probe.ts.parsePayloadUnitStartIndicator(packet);
- if (pesType === "audio" && pusi) {
- parsed = probe.ts.parsePesTime(packet);
- if (parsed) {
- parsed.type = "audio";
- result.audio.push(parsed);
- endLoop = true;
- }
- }
- break;
- }
- if (endLoop) {
- break;
- }
- startIndex -= MP2T_PACKET_LENGTH;
- endIndex -= MP2T_PACKET_LENGTH;
- continue;
- }
- startIndex--;
- endIndex--;
- }
- };
- var parseVideoPes_ = function(bytes, pmt, result) {
- var startIndex = 0, endIndex = MP2T_PACKET_LENGTH, packet, type3, pesType, pusi, parsed, frame, i2, pes;
- var endLoop = false;
- var currentFrame = {
- data: [],
- size: 0
- };
- while (endIndex < bytes.byteLength) {
- if (bytes[startIndex] === SYNC_BYTE && bytes[endIndex] === SYNC_BYTE) {
- packet = bytes.subarray(startIndex, endIndex);
- type3 = probe.ts.parseType(packet, pmt.pid);
- switch (type3) {
- case "pes":
- pesType = probe.ts.parsePesType(packet, pmt.table);
- pusi = probe.ts.parsePayloadUnitStartIndicator(packet);
- if (pesType === "video") {
- if (pusi && !endLoop) {
- parsed = probe.ts.parsePesTime(packet);
- if (parsed) {
- parsed.type = "video";
- result.video.push(parsed);
- endLoop = true;
- }
- }
- if (!result.firstKeyFrame) {
- if (pusi) {
- if (currentFrame.size !== 0) {
- frame = new Uint8Array(currentFrame.size);
- i2 = 0;
- while (currentFrame.data.length) {
- pes = currentFrame.data.shift();
- frame.set(pes, i2);
- i2 += pes.byteLength;
- }
- if (probe.ts.videoPacketContainsKeyFrame(frame)) {
- var firstKeyFrame = probe.ts.parsePesTime(frame);
- if (firstKeyFrame) {
- result.firstKeyFrame = firstKeyFrame;
- result.firstKeyFrame.type = "video";
- } else {
- console.warn("Failed to extract PTS/DTS from PES at first keyframe. This could be an unusual TS segment, or else mux.js did not parse your TS segment correctly. If you know your TS segments do contain PTS/DTS on keyframes please file a bug report! You can try ffprobe to double check for yourself.");
- }
- }
- currentFrame.size = 0;
- }
- }
- currentFrame.data.push(packet);
- currentFrame.size += packet.byteLength;
- }
- }
- break;
- }
- if (endLoop && result.firstKeyFrame) {
- break;
- }
- startIndex += MP2T_PACKET_LENGTH;
- endIndex += MP2T_PACKET_LENGTH;
- continue;
- }
- startIndex++;
- endIndex++;
- }
- endIndex = bytes.byteLength;
- startIndex = endIndex - MP2T_PACKET_LENGTH;
- endLoop = false;
- while (startIndex >= 0) {
- if (bytes[startIndex] === SYNC_BYTE && bytes[endIndex] === SYNC_BYTE) {
- packet = bytes.subarray(startIndex, endIndex);
- type3 = probe.ts.parseType(packet, pmt.pid);
- switch (type3) {
- case "pes":
- pesType = probe.ts.parsePesType(packet, pmt.table);
- pusi = probe.ts.parsePayloadUnitStartIndicator(packet);
- if (pesType === "video" && pusi) {
- parsed = probe.ts.parsePesTime(packet);
- if (parsed) {
- parsed.type = "video";
- result.video.push(parsed);
- endLoop = true;
- }
- }
- break;
- }
- if (endLoop) {
- break;
- }
- startIndex -= MP2T_PACKET_LENGTH;
- endIndex -= MP2T_PACKET_LENGTH;
- continue;
- }
- startIndex--;
- endIndex--;
- }
- };
- var adjustTimestamp_ = function(segmentInfo, baseTimestamp) {
- if (segmentInfo.audio && segmentInfo.audio.length) {
- var audioBaseTimestamp = baseTimestamp;
- if (typeof audioBaseTimestamp === "undefined" || isNaN(audioBaseTimestamp)) {
- audioBaseTimestamp = segmentInfo.audio[0].dts;
- }
- segmentInfo.audio.forEach(function(info) {
- info.dts = handleRollover(info.dts, audioBaseTimestamp);
- info.pts = handleRollover(info.pts, audioBaseTimestamp);
- info.dtsTime = info.dts / ONE_SECOND_IN_TS2;
- info.ptsTime = info.pts / ONE_SECOND_IN_TS2;
- });
- }
- if (segmentInfo.video && segmentInfo.video.length) {
- var videoBaseTimestamp = baseTimestamp;
- if (typeof videoBaseTimestamp === "undefined" || isNaN(videoBaseTimestamp)) {
- videoBaseTimestamp = segmentInfo.video[0].dts;
- }
- segmentInfo.video.forEach(function(info) {
- info.dts = handleRollover(info.dts, videoBaseTimestamp);
- info.pts = handleRollover(info.pts, videoBaseTimestamp);
- info.dtsTime = info.dts / ONE_SECOND_IN_TS2;
- info.ptsTime = info.pts / ONE_SECOND_IN_TS2;
- });
- if (segmentInfo.firstKeyFrame) {
- var frame = segmentInfo.firstKeyFrame;
- frame.dts = handleRollover(frame.dts, videoBaseTimestamp);
- frame.pts = handleRollover(frame.pts, videoBaseTimestamp);
- frame.dtsTime = frame.dts / ONE_SECOND_IN_TS2;
- frame.ptsTime = frame.pts / ONE_SECOND_IN_TS2;
- }
- }
- };
- var inspectAac_ = function(bytes) {
- var endLoop = false, audioCount = 0, sampleRate = null, timestamp = null, frameSize = 0, byteIndex = 0, packet;
- while (bytes.length - byteIndex >= 3) {
- var type3 = probe.aac.parseType(bytes, byteIndex);
- switch (type3) {
- case "timed-metadata":
- if (bytes.length - byteIndex < 10) {
- endLoop = true;
- break;
- }
- frameSize = probe.aac.parseId3TagSize(bytes, byteIndex);
- if (frameSize > bytes.length) {
- endLoop = true;
- break;
- }
- if (timestamp === null) {
- packet = bytes.subarray(byteIndex, byteIndex + frameSize);
- timestamp = probe.aac.parseAacTimestamp(packet);
- }
- byteIndex += frameSize;
- break;
- case "audio":
- if (bytes.length - byteIndex < 7) {
- endLoop = true;
- break;
- }
- frameSize = probe.aac.parseAdtsSize(bytes, byteIndex);
- if (frameSize > bytes.length) {
- endLoop = true;
- break;
- }
- if (sampleRate === null) {
- packet = bytes.subarray(byteIndex, byteIndex + frameSize);
- sampleRate = probe.aac.parseSampleRate(packet);
- }
- audioCount++;
- byteIndex += frameSize;
- break;
- default:
- byteIndex++;
- break;
- }
- if (endLoop) {
- return null;
- }
- }
- if (sampleRate === null || timestamp === null) {
- return null;
- }
- var audioTimescale = ONE_SECOND_IN_TS2 / sampleRate;
- var result = {
- audio: [{
- type: "audio",
- dts: timestamp,
- pts: timestamp
- }, {
- type: "audio",
- dts: timestamp + audioCount * 1024 * audioTimescale,
- pts: timestamp + audioCount * 1024 * audioTimescale
- }]
- };
- return result;
- };
- var inspectTs_ = function(bytes) {
- var pmt = {
- pid: null,
- table: null
- };
- var result = {};
- parsePsi_(bytes, pmt);
- for (var pid in pmt.table) {
- if (pmt.table.hasOwnProperty(pid)) {
- var type3 = pmt.table[pid];
- switch (type3) {
- case StreamTypes.H264_STREAM_TYPE:
- result.video = [];
- parseVideoPes_(bytes, pmt, result);
- if (result.video.length === 0) {
- delete result.video;
- }
- break;
- case StreamTypes.ADTS_STREAM_TYPE:
- result.audio = [];
- parseAudioPes_(bytes, pmt, result);
- if (result.audio.length === 0) {
- delete result.audio;
- }
- break;
- }
- }
- }
- return result;
- };
- var inspect = function(bytes, baseTimestamp) {
- var isAacData = probe.aac.isLikelyAacData(bytes);
- var result;
- if (isAacData) {
- result = inspectAac_(bytes);
- } else {
- result = inspectTs_(bytes);
- }
- if (!result || !result.audio && !result.video) {
- return null;
- }
- adjustTimestamp_(result, baseTimestamp);
- return result;
- };
- var tsInspector = {
- inspect,
- parseAudioPes_
- };
- const wireTransmuxerEvents = function(self2, transmuxer2) {
- transmuxer2.on("data", function(segment) {
- const initArray = segment.initSegment;
- segment.initSegment = {
- data: initArray.buffer,
- byteOffset: initArray.byteOffset,
- byteLength: initArray.byteLength
- };
- const typedArray2 = segment.data;
- segment.data = typedArray2.buffer;
- self2.postMessage({
- action: "data",
- segment,
- byteOffset: typedArray2.byteOffset,
- byteLength: typedArray2.byteLength
- }, [segment.data]);
- });
- transmuxer2.on("done", function(data) {
- self2.postMessage({
- action: "done"
- });
- });
- transmuxer2.on("gopInfo", function(gopInfo) {
- self2.postMessage({
- action: "gopInfo",
- gopInfo
- });
- });
- transmuxer2.on("videoSegmentTimingInfo", function(timingInfo) {
- const videoSegmentTimingInfo = {
- start: {
- decode: clock$2.videoTsToSeconds(timingInfo.start.dts),
- presentation: clock$2.videoTsToSeconds(timingInfo.start.pts)
- },
- end: {
- decode: clock$2.videoTsToSeconds(timingInfo.end.dts),
- presentation: clock$2.videoTsToSeconds(timingInfo.end.pts)
- },
- baseMediaDecodeTime: clock$2.videoTsToSeconds(timingInfo.baseMediaDecodeTime)
- };
- if (timingInfo.prependedContentDuration) {
- videoSegmentTimingInfo.prependedContentDuration = clock$2.videoTsToSeconds(timingInfo.prependedContentDuration);
- }
- self2.postMessage({
- action: "videoSegmentTimingInfo",
- videoSegmentTimingInfo
- });
- });
- transmuxer2.on("audioSegmentTimingInfo", function(timingInfo) {
- const audioSegmentTimingInfo = {
- start: {
- decode: clock$2.videoTsToSeconds(timingInfo.start.dts),
- presentation: clock$2.videoTsToSeconds(timingInfo.start.pts)
- },
- end: {
- decode: clock$2.videoTsToSeconds(timingInfo.end.dts),
- presentation: clock$2.videoTsToSeconds(timingInfo.end.pts)
- },
- baseMediaDecodeTime: clock$2.videoTsToSeconds(timingInfo.baseMediaDecodeTime)
- };
- if (timingInfo.prependedContentDuration) {
- audioSegmentTimingInfo.prependedContentDuration = clock$2.videoTsToSeconds(timingInfo.prependedContentDuration);
- }
- self2.postMessage({
- action: "audioSegmentTimingInfo",
- audioSegmentTimingInfo
- });
- });
- transmuxer2.on("id3Frame", function(id3Frame) {
- self2.postMessage({
- action: "id3Frame",
- id3Frame
- });
- });
- transmuxer2.on("caption", function(caption) {
- self2.postMessage({
- action: "caption",
- caption
- });
- });
- transmuxer2.on("trackinfo", function(trackInfo) {
- self2.postMessage({
- action: "trackinfo",
- trackInfo
- });
- });
- transmuxer2.on("audioTimingInfo", function(audioTimingInfo) {
- self2.postMessage({
- action: "audioTimingInfo",
- audioTimingInfo: {
- start: clock$2.videoTsToSeconds(audioTimingInfo.start),
- end: clock$2.videoTsToSeconds(audioTimingInfo.end)
- }
- });
- });
- transmuxer2.on("videoTimingInfo", function(videoTimingInfo) {
- self2.postMessage({
- action: "videoTimingInfo",
- videoTimingInfo: {
- start: clock$2.videoTsToSeconds(videoTimingInfo.start),
- end: clock$2.videoTsToSeconds(videoTimingInfo.end)
- }
- });
- });
- transmuxer2.on("log", function(log2) {
- self2.postMessage({
- action: "log",
- log: log2
- });
- });
- };
- class MessageHandlers {
- constructor(self2, options2) {
- this.options = options2 || {};
- this.self = self2;
- this.init();
- }
- init() {
- if (this.transmuxer) {
- this.transmuxer.dispose();
- }
- this.transmuxer = new transmuxer.Transmuxer(this.options);
- wireTransmuxerEvents(this.self, this.transmuxer);
- }
- pushMp4Captions(data) {
- if (!this.captionParser) {
- this.captionParser = new captionParser();
- this.captionParser.init();
- }
- const segment = new Uint8Array(data.data, data.byteOffset, data.byteLength);
- const parsed = this.captionParser.parse(segment, data.trackIds, data.timescales);
- this.self.postMessage({
- action: "mp4Captions",
- captions: parsed && parsed.captions || [],
- logs: parsed && parsed.logs || [],
- data: segment.buffer
- }, [segment.buffer]);
- }
- probeMp4StartTime({
- timescales,
- data
- }) {
- const startTime2 = probe$2.startTime(timescales, data);
- this.self.postMessage({
- action: "probeMp4StartTime",
- startTime: startTime2,
- data
- }, [data.buffer]);
- }
- probeMp4Tracks({
- data
- }) {
- const tracks = probe$2.tracks(data);
- this.self.postMessage({
- action: "probeMp4Tracks",
- tracks,
- data
- }, [data.buffer]);
- }
- probeTs({
- data,
- baseStartTime
- }) {
- const tsStartTime = typeof baseStartTime === "number" && !isNaN(baseStartTime) ? baseStartTime * clock$2.ONE_SECOND_IN_TS : void 0;
- const timeInfo = tsInspector.inspect(data, tsStartTime);
- let result = null;
- if (timeInfo) {
- result = {
- hasVideo: timeInfo.video && timeInfo.video.length === 2 || false,
- hasAudio: timeInfo.audio && timeInfo.audio.length === 2 || false
- };
- if (result.hasVideo) {
- result.videoStart = timeInfo.video[0].ptsTime;
- }
- if (result.hasAudio) {
- result.audioStart = timeInfo.audio[0].ptsTime;
- }
- }
- this.self.postMessage({
- action: "probeTs",
- result,
- data
- }, [data.buffer]);
- }
- clearAllMp4Captions() {
- if (this.captionParser) {
- this.captionParser.clearAllCaptions();
- }
- }
- clearParsedMp4Captions() {
- if (this.captionParser) {
- this.captionParser.clearParsedCaptions();
- }
- }
- push(data) {
- const segment = new Uint8Array(data.data, data.byteOffset, data.byteLength);
- this.transmuxer.push(segment);
- }
- reset() {
- this.transmuxer.reset();
- }
- setTimestampOffset(data) {
- const timestampOffset2 = data.timestampOffset || 0;
- this.transmuxer.setBaseMediaDecodeTime(Math.round(clock$2.secondsToVideoTs(timestampOffset2)));
- }
- setAudioAppendStart(data) {
- this.transmuxer.setAudioAppendStart(Math.ceil(clock$2.secondsToVideoTs(data.appendStart)));
- }
- setRemux(data) {
- this.transmuxer.setRemux(data.remux);
- }
- flush(data) {
- this.transmuxer.flush();
- self.postMessage({
- action: "done",
- type: "transmuxed"
- });
- }
- endTimeline() {
- this.transmuxer.endTimeline();
- self.postMessage({
- action: "endedtimeline",
- type: "transmuxed"
- });
- }
- alignGopsWith(data) {
- this.transmuxer.alignGopsWith(data.gopsToAlignWith.slice());
- }
- }
- self.onmessage = function(event2) {
- if (event2.data.action === "init" && event2.data.options) {
- this.messageHandlers = new MessageHandlers(self, event2.data.options);
- return;
- }
- if (!this.messageHandlers) {
- this.messageHandlers = new MessageHandlers(self);
- }
- if (event2.data && event2.data.action && event2.data.action !== "init") {
- if (this.messageHandlers[event2.data.action]) {
- this.messageHandlers[event2.data.action](event2.data);
- }
- }
- };
- }));
- var TransmuxWorker$1 = factory$1(workerCode$1$1);
- const handleData_$1 = (event2, transmuxedData, callback2) => {
- const {
- type: type2,
- initSegment,
- captions,
- captionStreams,
- metadata,
- videoFrameDtsTime,
- videoFramePtsTime
- } = event2.data.segment;
- transmuxedData.buffer.push({
- captions,
- captionStreams,
- metadata
- });
- const boxes = event2.data.segment.boxes || {
- data: event2.data.segment.data
- };
- const result = {
- type: type2,
- data: new Uint8Array(boxes.data, boxes.data.byteOffset, boxes.data.byteLength),
- initSegment: new Uint8Array(initSegment.data, initSegment.byteOffset, initSegment.byteLength)
- };
- if (typeof videoFrameDtsTime !== "undefined") {
- result.videoFrameDtsTime = videoFrameDtsTime;
- }
- if (typeof videoFramePtsTime !== "undefined") {
- result.videoFramePtsTime = videoFramePtsTime;
- }
- callback2(result);
- };
- const handleDone_$1 = ({
- transmuxedData,
- callback: callback2
- }) => {
- transmuxedData.buffer = [];
- callback2(transmuxedData);
- };
- const handleGopInfo_$1 = (event2, transmuxedData) => {
- transmuxedData.gopInfo = event2.data.gopInfo;
- };
- const processTransmux$1 = (options2) => {
- const {
- transmuxer,
- bytes,
- audioAppendStart,
- gopsToAlignWith,
- remux,
- onData,
- onTrackInfo,
- onAudioTimingInfo,
- onVideoTimingInfo,
- onVideoSegmentTimingInfo,
- onAudioSegmentTimingInfo,
- onId3,
- onCaptions,
- onDone,
- onEndedTimeline,
- onTransmuxerLog,
- isEndOfTimeline
- } = options2;
- const transmuxedData = {
- buffer: []
- };
- let waitForEndedTimelineEvent = isEndOfTimeline;
- const handleMessage = (event2) => {
- if (transmuxer.currentTransmux !== options2) {
- return;
- }
- if (event2.data.action === "data") {
- handleData_$1(event2, transmuxedData, onData);
- }
- if (event2.data.action === "trackinfo") {
- onTrackInfo(event2.data.trackInfo);
- }
- if (event2.data.action === "gopInfo") {
- handleGopInfo_$1(event2, transmuxedData);
- }
- if (event2.data.action === "audioTimingInfo") {
- onAudioTimingInfo(event2.data.audioTimingInfo);
- }
- if (event2.data.action === "videoTimingInfo") {
- onVideoTimingInfo(event2.data.videoTimingInfo);
- }
- if (event2.data.action === "videoSegmentTimingInfo") {
- onVideoSegmentTimingInfo(event2.data.videoSegmentTimingInfo);
- }
- if (event2.data.action === "audioSegmentTimingInfo") {
- onAudioSegmentTimingInfo(event2.data.audioSegmentTimingInfo);
- }
- if (event2.data.action === "id3Frame") {
- onId3([event2.data.id3Frame], event2.data.id3Frame.dispatchType);
- }
- if (event2.data.action === "caption") {
- onCaptions(event2.data.caption);
- }
- if (event2.data.action === "endedtimeline") {
- waitForEndedTimelineEvent = false;
- onEndedTimeline();
- }
- if (event2.data.action === "log") {
- onTransmuxerLog(event2.data.log);
- }
- if (event2.data.type !== "transmuxed") {
- return;
- }
- if (waitForEndedTimelineEvent) {
- return;
- }
- transmuxer.onmessage = null;
- handleDone_$1({
- transmuxedData,
- callback: onDone
- });
- dequeue$1(transmuxer);
- };
- transmuxer.onmessage = handleMessage;
- if (audioAppendStart) {
- transmuxer.postMessage({
- action: "setAudioAppendStart",
- appendStart: audioAppendStart
- });
- }
- if (Array.isArray(gopsToAlignWith)) {
- transmuxer.postMessage({
- action: "alignGopsWith",
- gopsToAlignWith
- });
- }
- if (typeof remux !== "undefined") {
- transmuxer.postMessage({
- action: "setRemux",
- remux
- });
- }
- if (bytes.byteLength) {
- const buffer = bytes instanceof ArrayBuffer ? bytes : bytes.buffer;
- const byteOffset = bytes instanceof ArrayBuffer ? 0 : bytes.byteOffset;
- transmuxer.postMessage({
- action: "push",
- data: buffer,
- byteOffset,
- byteLength: bytes.byteLength
- }, [buffer]);
- }
- if (isEndOfTimeline) {
- transmuxer.postMessage({
- action: "endTimeline"
- });
- }
- transmuxer.postMessage({
- action: "flush"
- });
- };
- const dequeue$1 = (transmuxer) => {
- transmuxer.currentTransmux = null;
- if (transmuxer.transmuxQueue.length) {
- transmuxer.currentTransmux = transmuxer.transmuxQueue.shift();
- if (typeof transmuxer.currentTransmux === "function") {
- transmuxer.currentTransmux();
- } else {
- processTransmux$1(transmuxer.currentTransmux);
- }
- }
- };
- const processAction$1 = (transmuxer, action) => {
- transmuxer.postMessage({
- action
- });
- dequeue$1(transmuxer);
- };
- const enqueueAction$1 = (action, transmuxer) => {
- if (!transmuxer.currentTransmux) {
- transmuxer.currentTransmux = action;
- processAction$1(transmuxer, action);
- return;
- }
- transmuxer.transmuxQueue.push(processAction$1.bind(null, transmuxer, action));
- };
- const reset$1 = (transmuxer) => {
- enqueueAction$1("reset", transmuxer);
- };
- const endTimeline$1 = (transmuxer) => {
- enqueueAction$1("endTimeline", transmuxer);
- };
- const transmux$1 = (options2) => {
- if (!options2.transmuxer.currentTransmux) {
- options2.transmuxer.currentTransmux = options2;
- processTransmux$1(options2);
- return;
- }
- options2.transmuxer.transmuxQueue.push(options2);
- };
- const createTransmuxer$1 = (options2) => {
- const transmuxer = new TransmuxWorker$1();
- transmuxer.currentTransmux = null;
- transmuxer.transmuxQueue = [];
- const term = transmuxer.terminate;
- transmuxer.terminate = () => {
- transmuxer.currentTransmux = null;
- transmuxer.transmuxQueue.length = 0;
- return term.call(transmuxer);
- };
- transmuxer.postMessage({
- action: "init",
- options: options2
- });
- return transmuxer;
- };
- var segmentTransmuxer$1 = {
- reset: reset$1,
- endTimeline: endTimeline$1,
- transmux: transmux$1,
- createTransmuxer: createTransmuxer$1
- };
- const workerCallback$1 = function(options2) {
- const transmuxer = options2.transmuxer;
- const endAction = options2.endAction || options2.action;
- const callback2 = options2.callback;
- const message = _extends$2({}, options2, {
- endAction: null,
- transmuxer: null,
- callback: null
- });
- const listenForEndEvent = (event2) => {
- if (event2.data.action !== endAction) {
- return;
- }
- transmuxer.removeEventListener("message", listenForEndEvent);
- if (event2.data.data) {
- event2.data.data = new Uint8Array(event2.data.data, options2.byteOffset || 0, options2.byteLength || event2.data.data.byteLength);
- if (options2.data) {
- options2.data = event2.data.data;
- }
- }
- callback2(event2.data);
- };
- transmuxer.addEventListener("message", listenForEndEvent);
- if (options2.data) {
- const isArrayBuffer = options2.data instanceof ArrayBuffer;
- message.byteOffset = isArrayBuffer ? 0 : options2.data.byteOffset;
- message.byteLength = options2.data.byteLength;
- const transfers = [isArrayBuffer ? options2.data : options2.data.buffer];
- transmuxer.postMessage(message, transfers);
- } else {
- transmuxer.postMessage(message);
- }
- };
- const REQUEST_ERRORS$1 = {
- FAILURE: 2,
- TIMEOUT: -101,
- ABORTED: -102
- };
- const abortAll$1 = (activeXhrs) => {
- activeXhrs.forEach((xhr) => {
- xhr.abort();
- });
- };
- const getRequestStats$1 = (request) => {
- return {
- bandwidth: request.bandwidth,
- bytesReceived: request.bytesReceived || 0,
- roundTripTime: request.roundTripTime || 0
- };
- };
- const getProgressStats$1 = (progressEvent) => {
- const request = progressEvent.target;
- const roundTripTime = Date.now() - request.requestTime;
- const stats = {
- bandwidth: Infinity,
- bytesReceived: 0,
- roundTripTime: roundTripTime || 0
- };
- stats.bytesReceived = progressEvent.loaded;
- stats.bandwidth = Math.floor(stats.bytesReceived / stats.roundTripTime * 8 * 1e3);
- return stats;
- };
- const handleErrors$1 = (error, request) => {
- if (request.timedout) {
- return {
- status: request.status,
- message: "HLS request timed-out at URL: " + request.uri,
- code: REQUEST_ERRORS$1.TIMEOUT,
- xhr: request
- };
- }
- if (request.aborted) {
- return {
- status: request.status,
- message: "HLS request aborted at URL: " + request.uri,
- code: REQUEST_ERRORS$1.ABORTED,
- xhr: request
- };
- }
- if (error) {
- return {
- status: request.status,
- message: "HLS request errored at URL: " + request.uri,
- code: REQUEST_ERRORS$1.FAILURE,
- xhr: request
- };
- }
- if (request.responseType === "arraybuffer" && request.response.byteLength === 0) {
- return {
- status: request.status,
- message: "Empty HLS response at URL: " + request.uri,
- code: REQUEST_ERRORS$1.FAILURE,
- xhr: request
- };
- }
- return null;
- };
- const handleKeyResponse$1 = (segment, objects, finishProcessingFn) => (error, request) => {
- const response = request.response;
- const errorObj = handleErrors$1(error, request);
- if (errorObj) {
- return finishProcessingFn(errorObj, segment);
- }
- if (response.byteLength !== 16) {
- return finishProcessingFn({
- status: request.status,
- message: "Invalid HLS key at URL: " + request.uri,
- code: REQUEST_ERRORS$1.FAILURE,
- xhr: request
- }, segment);
- }
- const view = new DataView(response);
- const bytes = new Uint32Array([view.getUint32(0), view.getUint32(4), view.getUint32(8), view.getUint32(12)]);
- for (let i2 = 0; i2 < objects.length; i2++) {
- objects[i2].bytes = bytes;
- }
- return finishProcessingFn(null, segment);
- };
- const parseInitSegment$1 = (segment, callback2) => {
- const type2 = detectContainerForBytes$1(segment.map.bytes);
- if (type2 !== "mp4") {
- const uri = segment.map.resolvedUri || segment.map.uri;
- return callback2({
- internal: true,
- message: `Found unsupported ${type2 || "unknown"} container for initialization segment at URL: ${uri}`,
- code: REQUEST_ERRORS$1.FAILURE
- });
- }
- workerCallback$1({
- action: "probeMp4Tracks",
- data: segment.map.bytes,
- transmuxer: segment.transmuxer,
- callback: ({
- tracks,
- data
- }) => {
- segment.map.bytes = data;
- tracks.forEach(function(track) {
- segment.map.tracks = segment.map.tracks || {};
- if (segment.map.tracks[track.type]) {
- return;
- }
- segment.map.tracks[track.type] = track;
- if (typeof track.id === "number" && track.timescale) {
- segment.map.timescales = segment.map.timescales || {};
- segment.map.timescales[track.id] = track.timescale;
- }
- });
- return callback2(null);
- }
- });
- };
- const handleInitSegmentResponse$1 = ({
- segment,
- finishProcessingFn
- }) => (error, request) => {
- const errorObj = handleErrors$1(error, request);
- if (errorObj) {
- return finishProcessingFn(errorObj, segment);
- }
- const bytes = new Uint8Array(request.response);
- if (segment.map.key) {
- segment.map.encryptedBytes = bytes;
- return finishProcessingFn(null, segment);
- }
- segment.map.bytes = bytes;
- parseInitSegment$1(segment, function(parseError) {
- if (parseError) {
- parseError.xhr = request;
- parseError.status = request.status;
- return finishProcessingFn(parseError, segment);
- }
- finishProcessingFn(null, segment);
- });
- };
- const handleSegmentResponse$1 = ({
- segment,
- finishProcessingFn,
- responseType
- }) => (error, request) => {
- const errorObj = handleErrors$1(error, request);
- if (errorObj) {
- return finishProcessingFn(errorObj, segment);
- }
- const newBytes = responseType === "arraybuffer" || !request.responseText ? request.response : stringToArrayBuffer$1(request.responseText.substring(segment.lastReachedChar || 0));
- segment.stats = getRequestStats$1(request);
- if (segment.key) {
- segment.encryptedBytes = new Uint8Array(newBytes);
- } else {
- segment.bytes = new Uint8Array(newBytes);
- }
- return finishProcessingFn(null, segment);
- };
- const transmuxAndNotify$1 = ({
- segment,
- bytes,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- }) => {
- const fmp4Tracks = segment.map && segment.map.tracks || {};
- const isMuxed3 = Boolean(fmp4Tracks.audio && fmp4Tracks.video);
- let audioStartFn = timingInfoFn.bind(null, segment, "audio", "start");
- const audioEndFn = timingInfoFn.bind(null, segment, "audio", "end");
- let videoStartFn = timingInfoFn.bind(null, segment, "video", "start");
- const videoEndFn = timingInfoFn.bind(null, segment, "video", "end");
- const finish = () => transmux$1({
- bytes,
- transmuxer: segment.transmuxer,
- audioAppendStart: segment.audioAppendStart,
- gopsToAlignWith: segment.gopsToAlignWith,
- remux: isMuxed3,
- onData: (result) => {
- result.type = result.type === "combined" ? "video" : result.type;
- dataFn(segment, result);
- },
- onTrackInfo: (trackInfo) => {
- if (trackInfoFn) {
- if (isMuxed3) {
- trackInfo.isMuxed = true;
- }
- trackInfoFn(segment, trackInfo);
- }
- },
- onAudioTimingInfo: (audioTimingInfo) => {
- if (audioStartFn && typeof audioTimingInfo.start !== "undefined") {
- audioStartFn(audioTimingInfo.start);
- audioStartFn = null;
- }
- if (audioEndFn && typeof audioTimingInfo.end !== "undefined") {
- audioEndFn(audioTimingInfo.end);
- }
- },
- onVideoTimingInfo: (videoTimingInfo) => {
- if (videoStartFn && typeof videoTimingInfo.start !== "undefined") {
- videoStartFn(videoTimingInfo.start);
- videoStartFn = null;
- }
- if (videoEndFn && typeof videoTimingInfo.end !== "undefined") {
- videoEndFn(videoTimingInfo.end);
- }
- },
- onVideoSegmentTimingInfo: (videoSegmentTimingInfo) => {
- videoSegmentTimingInfoFn(videoSegmentTimingInfo);
- },
- onAudioSegmentTimingInfo: (audioSegmentTimingInfo) => {
- audioSegmentTimingInfoFn(audioSegmentTimingInfo);
- },
- onId3: (id3Frames, dispatchType) => {
- id3Fn(segment, id3Frames, dispatchType);
- },
- onCaptions: (captions) => {
- captionsFn(segment, [captions]);
- },
- isEndOfTimeline,
- onEndedTimeline: () => {
- endedTimelineFn();
- },
- onTransmuxerLog,
- onDone: (result) => {
- if (!doneFn) {
- return;
- }
- result.type = result.type === "combined" ? "video" : result.type;
- doneFn(null, segment, result);
- }
- });
- workerCallback$1({
- action: "probeTs",
- transmuxer: segment.transmuxer,
- data: bytes,
- baseStartTime: segment.baseStartTime,
- callback: (data) => {
- segment.bytes = bytes = data.data;
- const probeResult = data.result;
- if (probeResult) {
- trackInfoFn(segment, {
- hasAudio: probeResult.hasAudio,
- hasVideo: probeResult.hasVideo,
- isMuxed: isMuxed3
- });
- trackInfoFn = null;
- if (probeResult.hasAudio && !isMuxed3) {
- audioStartFn(probeResult.audioStart);
- }
- if (probeResult.hasVideo) {
- videoStartFn(probeResult.videoStart);
- }
- audioStartFn = null;
- videoStartFn = null;
- }
- finish();
- }
- });
- };
- const handleSegmentBytes$1 = ({
- segment,
- bytes,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- }) => {
- let bytesAsUint8Array = new Uint8Array(bytes);
- if (isLikelyFmp4MediaSegment$1(bytesAsUint8Array)) {
- segment.isFmp4 = true;
- const {
- tracks
- } = segment.map;
- const trackInfo = {
- isFmp4: true,
- hasVideo: !!tracks.video,
- hasAudio: !!tracks.audio
- };
- if (tracks.audio && tracks.audio.codec && tracks.audio.codec !== "enca") {
- trackInfo.audioCodec = tracks.audio.codec;
- }
- if (tracks.video && tracks.video.codec && tracks.video.codec !== "encv") {
- trackInfo.videoCodec = tracks.video.codec;
- }
- if (tracks.video && tracks.audio) {
- trackInfo.isMuxed = true;
- }
- trackInfoFn(segment, trackInfo);
- const finishLoading = (captions) => {
- dataFn(segment, {
- data: bytesAsUint8Array,
- type: trackInfo.hasAudio && !trackInfo.isMuxed ? "audio" : "video"
- });
- if (captions && captions.length) {
- captionsFn(segment, captions);
- }
- doneFn(null, segment, {});
- };
- workerCallback$1({
- action: "probeMp4StartTime",
- timescales: segment.map.timescales,
- data: bytesAsUint8Array,
- transmuxer: segment.transmuxer,
- callback: ({
- data,
- startTime
- }) => {
- bytes = data.buffer;
- segment.bytes = bytesAsUint8Array = data;
- if (trackInfo.hasAudio && !trackInfo.isMuxed) {
- timingInfoFn(segment, "audio", "start", startTime);
- }
- if (trackInfo.hasVideo) {
- timingInfoFn(segment, "video", "start", startTime);
- }
- if (!tracks.video || !data.byteLength || !segment.transmuxer) {
- finishLoading();
- return;
- }
- workerCallback$1({
- action: "pushMp4Captions",
- endAction: "mp4Captions",
- transmuxer: segment.transmuxer,
- data: bytesAsUint8Array,
- timescales: segment.map.timescales,
- trackIds: [tracks.video.id],
- callback: (message) => {
- bytes = message.data.buffer;
- segment.bytes = bytesAsUint8Array = message.data;
- message.logs.forEach(function(log2) {
- onTransmuxerLog(merge$2(log2, {
- stream: "mp4CaptionParser"
- }));
- });
- finishLoading(message.captions);
- }
- });
- }
- });
- return;
- }
- if (!segment.transmuxer) {
- doneFn(null, segment, {});
- return;
- }
- if (typeof segment.container === "undefined") {
- segment.container = detectContainerForBytes$1(bytesAsUint8Array);
- }
- if (segment.container !== "ts" && segment.container !== "aac") {
- trackInfoFn(segment, {
- hasAudio: false,
- hasVideo: false
- });
- doneFn(null, segment, {});
- return;
- }
- transmuxAndNotify$1({
- segment,
- bytes,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- });
- };
- const decrypt$1 = function({
- id,
- key,
- encryptedBytes,
- decryptionWorker
- }, callback2) {
- const decryptionHandler = (event2) => {
- if (event2.data.source === id) {
- decryptionWorker.removeEventListener("message", decryptionHandler);
- const decrypted = event2.data.decrypted;
- callback2(new Uint8Array(decrypted.bytes, decrypted.byteOffset, decrypted.byteLength));
- }
- };
- decryptionWorker.addEventListener("message", decryptionHandler);
- let keyBytes;
- if (key.bytes.slice) {
- keyBytes = key.bytes.slice();
- } else {
- keyBytes = new Uint32Array(Array.prototype.slice.call(key.bytes));
- }
- decryptionWorker.postMessage(createTransferableMessage$1({
- source: id,
- encrypted: encryptedBytes,
- key: keyBytes,
- iv: key.iv
- }), [encryptedBytes.buffer, keyBytes.buffer]);
- };
- const decryptSegment$1 = ({
- decryptionWorker,
- segment,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- }) => {
- decrypt$1({
- id: segment.requestId,
- key: segment.key,
- encryptedBytes: segment.encryptedBytes,
- decryptionWorker
- }, (decryptedBytes) => {
- segment.bytes = decryptedBytes;
- handleSegmentBytes$1({
- segment,
- bytes: segment.bytes,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- });
- });
- };
- const waitForCompletion$1 = ({
- activeXhrs,
- decryptionWorker,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- }) => {
- let count = 0;
- let didError = false;
- return (error, segment) => {
- if (didError) {
- return;
- }
- if (error) {
- didError = true;
- abortAll$1(activeXhrs);
- return doneFn(error, segment);
- }
- count += 1;
- if (count === activeXhrs.length) {
- const segmentFinish = function() {
- if (segment.encryptedBytes) {
- return decryptSegment$1({
- decryptionWorker,
- segment,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- });
- }
- handleSegmentBytes$1({
- segment,
- bytes: segment.bytes,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- });
- };
- segment.endOfAllRequests = Date.now();
- if (segment.map && segment.map.encryptedBytes && !segment.map.bytes) {
- return decrypt$1({
- decryptionWorker,
- id: segment.requestId + "-init",
- encryptedBytes: segment.map.encryptedBytes,
- key: segment.map.key
- }, (decryptedBytes) => {
- segment.map.bytes = decryptedBytes;
- parseInitSegment$1(segment, (parseError) => {
- if (parseError) {
- abortAll$1(activeXhrs);
- return doneFn(parseError, segment);
- }
- segmentFinish();
- });
- });
- }
- segmentFinish();
- }
- };
- };
- const handleLoadEnd$1 = ({
- loadendState,
- abortFn
- }) => (event2) => {
- const request = event2.target;
- if (request.aborted && abortFn && !loadendState.calledAbortFn) {
- abortFn();
- loadendState.calledAbortFn = true;
- }
- };
- const handleProgress$1 = ({
- segment,
- progressFn,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn
- }) => (event2) => {
- const request = event2.target;
- if (request.aborted) {
- return;
- }
- segment.stats = merge$2(segment.stats, getProgressStats$1(event2));
- if (!segment.stats.firstBytesReceivedAt && segment.stats.bytesReceived) {
- segment.stats.firstBytesReceivedAt = Date.now();
- }
- return progressFn(event2, segment);
- };
- const mediaSegmentRequest$1 = ({
- xhr,
- xhrOptions,
- decryptionWorker,
- segment,
- abortFn,
- progressFn,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- }) => {
- const activeXhrs = [];
- const finishProcessingFn = waitForCompletion$1({
- activeXhrs,
- decryptionWorker,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- });
- if (segment.key && !segment.key.bytes) {
- const objects = [segment.key];
- if (segment.map && !segment.map.bytes && segment.map.key && segment.map.key.resolvedUri === segment.key.resolvedUri) {
- objects.push(segment.map.key);
- }
- const keyRequestOptions = merge$2(xhrOptions, {
- uri: segment.key.resolvedUri,
- responseType: "arraybuffer"
- });
- const keyRequestCallback = handleKeyResponse$1(segment, objects, finishProcessingFn);
- const keyXhr = xhr(keyRequestOptions, keyRequestCallback);
- activeXhrs.push(keyXhr);
- }
- if (segment.map && !segment.map.bytes) {
- const differentMapKey = segment.map.key && (!segment.key || segment.key.resolvedUri !== segment.map.key.resolvedUri);
- if (differentMapKey) {
- const mapKeyRequestOptions = merge$2(xhrOptions, {
- uri: segment.map.key.resolvedUri,
- responseType: "arraybuffer"
- });
- const mapKeyRequestCallback = handleKeyResponse$1(segment, [segment.map.key], finishProcessingFn);
- const mapKeyXhr = xhr(mapKeyRequestOptions, mapKeyRequestCallback);
- activeXhrs.push(mapKeyXhr);
- }
- const initSegmentOptions = merge$2(xhrOptions, {
- uri: segment.map.resolvedUri,
- responseType: "arraybuffer",
- headers: segmentXhrHeaders$1(segment.map)
- });
- const initSegmentRequestCallback = handleInitSegmentResponse$1({
- segment,
- finishProcessingFn
- });
- const initSegmentXhr = xhr(initSegmentOptions, initSegmentRequestCallback);
- activeXhrs.push(initSegmentXhr);
- }
- const segmentRequestOptions = merge$2(xhrOptions, {
- uri: segment.part && segment.part.resolvedUri || segment.resolvedUri,
- responseType: "arraybuffer",
- headers: segmentXhrHeaders$1(segment)
- });
- const segmentRequestCallback = handleSegmentResponse$1({
- segment,
- finishProcessingFn,
- responseType: segmentRequestOptions.responseType
- });
- const segmentXhr = xhr(segmentRequestOptions, segmentRequestCallback);
- segmentXhr.addEventListener("progress", handleProgress$1({
- segment,
- progressFn,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn
- }));
- activeXhrs.push(segmentXhr);
- const loadendState = {};
- activeXhrs.forEach((activeXhr) => {
- activeXhr.addEventListener("loadend", handleLoadEnd$1({
- loadendState,
- abortFn
- }));
- });
- return () => abortAll$1(activeXhrs);
- };
- const logFn$1$1 = logger$1("CodecUtils");
- const getCodecs$1 = function(media) {
- const mediaAttributes = media.attributes || {};
- if (mediaAttributes.CODECS) {
- return parseCodecs$1(mediaAttributes.CODECS);
- }
- };
- const isMaat$1 = (main, media) => {
- const mediaAttributes = media.attributes || {};
- return main && main.mediaGroups && main.mediaGroups.AUDIO && mediaAttributes.AUDIO && main.mediaGroups.AUDIO[mediaAttributes.AUDIO];
- };
- const isMuxed$1 = (main, media) => {
- if (!isMaat$1(main, media)) {
- return true;
- }
- const mediaAttributes = media.attributes || {};
- const audioGroup = main.mediaGroups.AUDIO[mediaAttributes.AUDIO];
- for (const groupId in audioGroup) {
- if (!audioGroup[groupId].uri && !audioGroup[groupId].playlists) {
- return true;
- }
- }
- return false;
- };
- const unwrapCodecList$1 = function(codecList) {
- const codecs = {};
- codecList.forEach(({
- mediaType,
- type: type2,
- details
- }) => {
- codecs[mediaType] = codecs[mediaType] || [];
- codecs[mediaType].push(translateLegacyCodec$1(`${type2}${details}`));
- });
- Object.keys(codecs).forEach(function(mediaType) {
- if (codecs[mediaType].length > 1) {
- logFn$1$1(`multiple ${mediaType} codecs found as attributes: ${codecs[mediaType].join(", ")}. Setting playlist codecs to null so that we wait for mux.js to probe segments for real codecs.`);
- codecs[mediaType] = null;
- return;
- }
- codecs[mediaType] = codecs[mediaType][0];
- });
- return codecs;
- };
- const codecCount$1 = function(codecObj) {
- let count = 0;
- if (codecObj.audio) {
- count++;
- }
- if (codecObj.video) {
- count++;
- }
- return count;
- };
- const codecsForPlaylist$1 = function(main, media) {
- const mediaAttributes = media.attributes || {};
- const codecInfo = unwrapCodecList$1(getCodecs$1(media) || []);
- if (isMaat$1(main, media) && !codecInfo.audio) {
- if (!isMuxed$1(main, media)) {
- const defaultCodecs = unwrapCodecList$1(codecsFromDefault$1(main, mediaAttributes.AUDIO) || []);
- if (defaultCodecs.audio) {
- codecInfo.audio = defaultCodecs.audio;
- }
- }
- }
- return codecInfo;
- };
- const logFn$2 = logger$1("PlaylistSelector");
- const representationToString$1 = function(representation) {
- if (!representation || !representation.playlist) {
- return;
- }
- const playlist = representation.playlist;
- return JSON.stringify({
- id: playlist.id,
- bandwidth: representation.bandwidth,
- width: representation.width,
- height: representation.height,
- codecs: playlist.attributes && playlist.attributes.CODECS || ""
- });
- };
- const safeGetComputedStyle$1 = function(el, property) {
- if (!el) {
- return "";
- }
- const result = window_1.getComputedStyle(el);
- if (!result) {
- return "";
- }
- return result[property];
- };
- const stableSort$1 = function(array, sortFn) {
- const newArray = array.slice();
- array.sort(function(left, right) {
- const cmp = sortFn(left, right);
- if (cmp === 0) {
- return newArray.indexOf(left) - newArray.indexOf(right);
- }
- return cmp;
- });
- };
- const comparePlaylistBandwidth$1 = function(left, right) {
- let leftBandwidth;
- let rightBandwidth;
- if (left.attributes.BANDWIDTH) {
- leftBandwidth = left.attributes.BANDWIDTH;
- }
- leftBandwidth = leftBandwidth || window_1.Number.MAX_VALUE;
- if (right.attributes.BANDWIDTH) {
- rightBandwidth = right.attributes.BANDWIDTH;
- }
- rightBandwidth = rightBandwidth || window_1.Number.MAX_VALUE;
- return leftBandwidth - rightBandwidth;
- };
- const comparePlaylistResolution$1 = function(left, right) {
- let leftWidth;
- let rightWidth;
- if (left.attributes.RESOLUTION && left.attributes.RESOLUTION.width) {
- leftWidth = left.attributes.RESOLUTION.width;
- }
- leftWidth = leftWidth || window_1.Number.MAX_VALUE;
- if (right.attributes.RESOLUTION && right.attributes.RESOLUTION.width) {
- rightWidth = right.attributes.RESOLUTION.width;
- }
- rightWidth = rightWidth || window_1.Number.MAX_VALUE;
- if (leftWidth === rightWidth && left.attributes.BANDWIDTH && right.attributes.BANDWIDTH) {
- return left.attributes.BANDWIDTH - right.attributes.BANDWIDTH;
- }
- return leftWidth - rightWidth;
- };
- let simpleSelector$1 = function(main, playerBandwidth, playerWidth, playerHeight, limitRenditionByPlayerDimensions, playlistController) {
- if (!main) {
- return;
- }
- const options2 = {
- bandwidth: playerBandwidth,
- width: playerWidth,
- height: playerHeight,
- limitRenditionByPlayerDimensions
- };
- let playlists = main.playlists;
- if (Playlist$1.isAudioOnly(main)) {
- playlists = playlistController.getAudioTrackPlaylists_();
- options2.audioOnly = true;
- }
- let sortedPlaylistReps = playlists.map((playlist) => {
- let bandwidth2;
- const width2 = playlist.attributes && playlist.attributes.RESOLUTION && playlist.attributes.RESOLUTION.width;
- const height2 = playlist.attributes && playlist.attributes.RESOLUTION && playlist.attributes.RESOLUTION.height;
- bandwidth2 = playlist.attributes && playlist.attributes.BANDWIDTH;
- bandwidth2 = bandwidth2 || window_1.Number.MAX_VALUE;
- return {
- bandwidth: bandwidth2,
- width: width2,
- height: height2,
- playlist
- };
- });
- stableSort$1(sortedPlaylistReps, (left, right) => left.bandwidth - right.bandwidth);
- sortedPlaylistReps = sortedPlaylistReps.filter((rep2) => !Playlist$1.isIncompatible(rep2.playlist));
- let enabledPlaylistReps = sortedPlaylistReps.filter((rep2) => Playlist$1.isEnabled(rep2.playlist));
- if (!enabledPlaylistReps.length) {
- enabledPlaylistReps = sortedPlaylistReps.filter((rep2) => !Playlist$1.isDisabled(rep2.playlist));
- }
- const bandwidthPlaylistReps = enabledPlaylistReps.filter((rep2) => rep2.bandwidth * Config$1.BANDWIDTH_VARIANCE < playerBandwidth);
- let highestRemainingBandwidthRep = bandwidthPlaylistReps[bandwidthPlaylistReps.length - 1];
- const bandwidthBestRep = bandwidthPlaylistReps.filter((rep2) => rep2.bandwidth === highestRemainingBandwidthRep.bandwidth)[0];
- if (limitRenditionByPlayerDimensions === false) {
- const chosenRep2 = bandwidthBestRep || enabledPlaylistReps[0] || sortedPlaylistReps[0];
- if (chosenRep2 && chosenRep2.playlist) {
- let type2 = "sortedPlaylistReps";
- if (bandwidthBestRep) {
- type2 = "bandwidthBestRep";
- }
- if (enabledPlaylistReps[0]) {
- type2 = "enabledPlaylistReps";
- }
- logFn$2(`choosing ${representationToString$1(chosenRep2)} using ${type2} with options`, options2);
- return chosenRep2.playlist;
- }
- logFn$2("could not choose a playlist with options", options2);
- return null;
- }
- const haveResolution = bandwidthPlaylistReps.filter((rep2) => rep2.width && rep2.height);
- stableSort$1(haveResolution, (left, right) => left.width - right.width);
- const resolutionBestRepList = haveResolution.filter((rep2) => rep2.width === playerWidth && rep2.height === playerHeight);
- highestRemainingBandwidthRep = resolutionBestRepList[resolutionBestRepList.length - 1];
- const resolutionBestRep = resolutionBestRepList.filter((rep2) => rep2.bandwidth === highestRemainingBandwidthRep.bandwidth)[0];
- let resolutionPlusOneList;
- let resolutionPlusOneSmallest;
- let resolutionPlusOneRep;
- if (!resolutionBestRep) {
- resolutionPlusOneList = haveResolution.filter((rep2) => rep2.width > playerWidth || rep2.height > playerHeight);
- resolutionPlusOneSmallest = resolutionPlusOneList.filter((rep2) => rep2.width === resolutionPlusOneList[0].width && rep2.height === resolutionPlusOneList[0].height);
- highestRemainingBandwidthRep = resolutionPlusOneSmallest[resolutionPlusOneSmallest.length - 1];
- resolutionPlusOneRep = resolutionPlusOneSmallest.filter((rep2) => rep2.bandwidth === highestRemainingBandwidthRep.bandwidth)[0];
- }
- let leastPixelDiffRep;
- if (playlistController.leastPixelDiffSelector) {
- const leastPixelDiffList = haveResolution.map((rep2) => {
- rep2.pixelDiff = Math.abs(rep2.width - playerWidth) + Math.abs(rep2.height - playerHeight);
- return rep2;
- });
- stableSort$1(leastPixelDiffList, (left, right) => {
- if (left.pixelDiff === right.pixelDiff) {
- return right.bandwidth - left.bandwidth;
- }
- return left.pixelDiff - right.pixelDiff;
- });
- leastPixelDiffRep = leastPixelDiffList[0];
- }
- const chosenRep = leastPixelDiffRep || resolutionPlusOneRep || resolutionBestRep || bandwidthBestRep || enabledPlaylistReps[0] || sortedPlaylistReps[0];
- if (chosenRep && chosenRep.playlist) {
- let type2 = "sortedPlaylistReps";
- if (leastPixelDiffRep) {
- type2 = "leastPixelDiffRep";
- } else if (resolutionPlusOneRep) {
- type2 = "resolutionPlusOneRep";
- } else if (resolutionBestRep) {
- type2 = "resolutionBestRep";
- } else if (bandwidthBestRep) {
- type2 = "bandwidthBestRep";
- } else if (enabledPlaylistReps[0]) {
- type2 = "enabledPlaylistReps";
- }
- logFn$2(`choosing ${representationToString$1(chosenRep)} using ${type2} with options`, options2);
- return chosenRep.playlist;
- }
- logFn$2("could not choose a playlist with options", options2);
- return null;
- };
- const lastBandwidthSelector$1 = function() {
- const pixelRatio = this.useDevicePixelRatio ? window_1.devicePixelRatio || 1 : 1;
- return simpleSelector$1(this.playlists.main, this.systemBandwidth, parseInt(safeGetComputedStyle$1(this.tech_.el(), "width"), 10) * pixelRatio, parseInt(safeGetComputedStyle$1(this.tech_.el(), "height"), 10) * pixelRatio, this.limitRenditionByPlayerDimensions, this.playlistController_);
- };
- const movingAverageBandwidthSelector$1 = function(decay) {
- let average = -1;
- let lastSystemBandwidth = -1;
- if (decay < 0 || decay > 1) {
- throw new Error("Moving average bandwidth decay must be between 0 and 1.");
- }
- return function() {
- const pixelRatio = this.useDevicePixelRatio ? window_1.devicePixelRatio || 1 : 1;
- if (average < 0) {
- average = this.systemBandwidth;
- lastSystemBandwidth = this.systemBandwidth;
- }
- if (this.systemBandwidth > 0 && this.systemBandwidth !== lastSystemBandwidth) {
- average = decay * this.systemBandwidth + (1 - decay) * average;
- lastSystemBandwidth = this.systemBandwidth;
- }
- return simpleSelector$1(this.playlists.main, average, parseInt(safeGetComputedStyle$1(this.tech_.el(), "width"), 10) * pixelRatio, parseInt(safeGetComputedStyle$1(this.tech_.el(), "height"), 10) * pixelRatio, this.limitRenditionByPlayerDimensions, this.playlistController_);
- };
- };
- const minRebufferMaxBandwidthSelector$1 = function(settings) {
- const {
- main,
- currentTime,
- bandwidth: bandwidth2,
- duration: duration5,
- segmentDuration,
- timeUntilRebuffer: timeUntilRebuffer3,
- currentTimeline,
- syncController
- } = settings;
- const compatiblePlaylists = main.playlists.filter((playlist) => !Playlist$1.isIncompatible(playlist));
- let enabledPlaylists = compatiblePlaylists.filter(Playlist$1.isEnabled);
- if (!enabledPlaylists.length) {
- enabledPlaylists = compatiblePlaylists.filter((playlist) => !Playlist$1.isDisabled(playlist));
- }
- const bandwidthPlaylists = enabledPlaylists.filter(Playlist$1.hasAttribute.bind(null, "BANDWIDTH"));
- const rebufferingEstimates = bandwidthPlaylists.map((playlist) => {
- const syncPoint = syncController.getSyncPoint(playlist, duration5, currentTimeline, currentTime);
- const numRequests = syncPoint ? 1 : 2;
- const requestTimeEstimate = Playlist$1.estimateSegmentRequestTime(segmentDuration, bandwidth2, playlist);
- const rebufferingImpact = requestTimeEstimate * numRequests - timeUntilRebuffer3;
- return {
- playlist,
- rebufferingImpact
- };
- });
- const noRebufferingPlaylists = rebufferingEstimates.filter((estimate) => estimate.rebufferingImpact <= 0);
- stableSort$1(noRebufferingPlaylists, (a, b) => comparePlaylistBandwidth$1(b.playlist, a.playlist));
- if (noRebufferingPlaylists.length) {
- return noRebufferingPlaylists[0];
- }
- stableSort$1(rebufferingEstimates, (a, b) => a.rebufferingImpact - b.rebufferingImpact);
- return rebufferingEstimates[0] || null;
- };
- const lowestBitrateCompatibleVariantSelector$1 = function() {
- const playlists = this.playlists.main.playlists.filter(Playlist$1.isEnabled);
- stableSort$1(playlists, (a, b) => comparePlaylistBandwidth$1(a, b));
- const playlistsWithVideo = playlists.filter((playlist) => !!codecsForPlaylist$1(this.playlists.main, playlist).video);
- return playlistsWithVideo[0] || null;
- };
- const concatSegments$1 = (segmentObj) => {
- let offset = 0;
- let tempBuffer;
- if (segmentObj.bytes) {
- tempBuffer = new Uint8Array(segmentObj.bytes);
- segmentObj.segments.forEach((segment) => {
- tempBuffer.set(segment, offset);
- offset += segment.byteLength;
- });
- }
- return tempBuffer;
- };
- const createCaptionsTrackIfNotExists$1 = function(inbandTextTracks, tech, captionStream) {
- if (!inbandTextTracks[captionStream]) {
- tech.trigger({
- type: "usage",
- name: "vhs-608"
- });
- let instreamId = captionStream;
- if (/^cc708_/.test(captionStream)) {
- instreamId = "SERVICE" + captionStream.split("_")[1];
- }
- const track = tech.textTracks().getTrackById(instreamId);
- if (track) {
- inbandTextTracks[captionStream] = track;
- } else {
- const captionServices = tech.options_.vhs && tech.options_.vhs.captionServices || {};
- let label2 = captionStream;
- let language = captionStream;
- let def = false;
- const captionService = captionServices[instreamId];
- if (captionService) {
- label2 = captionService.label;
- language = captionService.language;
- def = captionService.default;
- }
- inbandTextTracks[captionStream] = tech.addRemoteTextTrack({
- kind: "captions",
- id: instreamId,
- default: def,
- label: label2,
- language
- }, false).track;
- }
- }
- };
- const addCaptionData$1 = function({
- inbandTextTracks,
- captionArray,
- timestampOffset: timestampOffset2
- }) {
- if (!captionArray) {
- return;
- }
- const Cue = window_1.WebKitDataCue || window_1.VTTCue;
- captionArray.forEach((caption) => {
- const track = caption.stream;
- inbandTextTracks[track].addCue(new Cue(caption.startTime + timestampOffset2, caption.endTime + timestampOffset2, caption.text));
- });
- };
- const deprecateOldCue$1 = function(cue) {
- Object.defineProperties(cue.frame, {
- id: {
- get() {
- videojs$2.log.warn("cue.frame.id is deprecated. Use cue.value.key instead.");
- return cue.value.key;
- }
- },
- value: {
- get() {
- videojs$2.log.warn("cue.frame.value is deprecated. Use cue.value.data instead.");
- return cue.value.data;
- }
- },
- privateData: {
- get() {
- videojs$2.log.warn("cue.frame.privateData is deprecated. Use cue.value.data instead.");
- return cue.value.data;
- }
- }
- });
- };
- const addMetadata$1 = ({
- inbandTextTracks,
- metadataArray,
- timestampOffset: timestampOffset2,
- videoDuration
- }) => {
- if (!metadataArray) {
- return;
- }
- const Cue = window_1.WebKitDataCue || window_1.VTTCue;
- const metadataTrack = inbandTextTracks.metadataTrack_;
- if (!metadataTrack) {
- return;
- }
- metadataArray.forEach((metadata) => {
- const time = metadata.cueTime + timestampOffset2;
- if (typeof time !== "number" || window_1.isNaN(time) || time < 0 || !(time < Infinity)) {
- return;
- }
- metadata.frames.forEach((frame) => {
- const cue = new Cue(time, time, frame.value || frame.url || frame.data || "");
- cue.frame = frame;
- cue.value = frame;
- deprecateOldCue$1(cue);
- metadataTrack.addCue(cue);
- });
- });
- if (!metadataTrack.cues || !metadataTrack.cues.length) {
- return;
- }
- const cues = metadataTrack.cues;
- const cuesArray = [];
- for (let i2 = 0; i2 < cues.length; i2++) {
- if (cues[i2]) {
- cuesArray.push(cues[i2]);
- }
- }
- const cuesGroupedByStartTime = cuesArray.reduce((obj, cue) => {
- const timeSlot = obj[cue.startTime] || [];
- timeSlot.push(cue);
- obj[cue.startTime] = timeSlot;
- return obj;
- }, {});
- const sortedStartTimes = Object.keys(cuesGroupedByStartTime).sort((a, b) => Number(a) - Number(b));
- sortedStartTimes.forEach((startTime, idx) => {
- const cueGroup = cuesGroupedByStartTime[startTime];
- const nextTime = Number(sortedStartTimes[idx + 1]) || videoDuration;
- cueGroup.forEach((cue) => {
- cue.endTime = nextTime;
- });
- });
- };
- const createMetadataTrackIfNotExists$1 = (inbandTextTracks, dispatchType, tech) => {
- if (inbandTextTracks.metadataTrack_) {
- return;
- }
- inbandTextTracks.metadataTrack_ = tech.addRemoteTextTrack({
- kind: "metadata",
- label: "Timed Metadata"
- }, false).track;
- inbandTextTracks.metadataTrack_.inBandMetadataTrackDispatchType = dispatchType;
- };
- const removeCuesFromTrack$1 = function(start2, end, track) {
- let i2;
- let cue;
- if (!track) {
- return;
- }
- if (!track.cues) {
- return;
- }
- i2 = track.cues.length;
- while (i2--) {
- cue = track.cues[i2];
- if (cue.startTime >= start2 && cue.endTime <= end) {
- track.removeCue(cue);
- }
- }
- };
- const removeDuplicateCuesFromTrack$1 = function(track) {
- const cues = track.cues;
- if (!cues) {
- return;
- }
- for (let i2 = 0; i2 < cues.length; i2++) {
- const duplicates = [];
- let occurrences = 0;
- for (let j = 0; j < cues.length; j++) {
- if (cues[i2].startTime === cues[j].startTime && cues[i2].endTime === cues[j].endTime && cues[i2].text === cues[j].text) {
- occurrences++;
- if (occurrences > 1) {
- duplicates.push(cues[j]);
- }
- }
- }
- if (duplicates.length) {
- duplicates.forEach((dupe) => track.removeCue(dupe));
- }
- }
- };
- const gopsSafeToAlignWith$1 = (buffer, currentTime, mapping) => {
- if (typeof currentTime === "undefined" || currentTime === null || !buffer.length) {
- return [];
- }
- const currentTimePts = Math.ceil((currentTime - mapping + 3) * clock$1.ONE_SECOND_IN_TS);
- let i2;
- for (i2 = 0; i2 < buffer.length; i2++) {
- if (buffer[i2].pts > currentTimePts) {
- break;
- }
- }
- return buffer.slice(i2);
- };
- const updateGopBuffer$1 = (buffer, gops, replace) => {
- if (!gops.length) {
- return buffer;
- }
- if (replace) {
- return gops.slice();
- }
- const start2 = gops[0].pts;
- let i2 = 0;
- for (i2; i2 < buffer.length; i2++) {
- if (buffer[i2].pts >= start2) {
- break;
- }
- }
- return buffer.slice(0, i2).concat(gops);
- };
- const removeGopBuffer$1 = (buffer, start2, end, mapping) => {
- const startPts = Math.ceil((start2 - mapping) * clock$1.ONE_SECOND_IN_TS);
- const endPts = Math.ceil((end - mapping) * clock$1.ONE_SECOND_IN_TS);
- const updatedBuffer = buffer.slice();
- let i2 = buffer.length;
- while (i2--) {
- if (buffer[i2].pts <= endPts) {
- break;
- }
- }
- if (i2 === -1) {
- return updatedBuffer;
- }
- let j = i2 + 1;
- while (j--) {
- if (buffer[j].pts <= startPts) {
- break;
- }
- }
- j = Math.max(j, 0);
- updatedBuffer.splice(j, i2 - j + 1);
- return updatedBuffer;
- };
- const shallowEqual$1 = function(a, b) {
- if (!a && !b || !a && b || a && !b) {
- return false;
- }
- if (a === b) {
- return true;
- }
- const akeys = Object.keys(a).sort();
- const bkeys = Object.keys(b).sort();
- if (akeys.length !== bkeys.length) {
- return false;
- }
- for (let i2 = 0; i2 < akeys.length; i2++) {
- const key = akeys[i2];
- if (key !== bkeys[i2]) {
- return false;
- }
- if (a[key] !== b[key]) {
- return false;
- }
- }
- return true;
- };
- const QUOTA_EXCEEDED_ERR$1 = 22;
- const getSyncSegmentCandidate$1 = function(currentTimeline, segments, targetTime) {
- segments = segments || [];
- const timelineSegments = [];
- let time = 0;
- for (let i2 = 0; i2 < segments.length; i2++) {
- const segment = segments[i2];
- if (currentTimeline === segment.timeline) {
- timelineSegments.push(i2);
- time += segment.duration;
- if (time > targetTime) {
- return i2;
- }
- }
- }
- if (timelineSegments.length === 0) {
- return 0;
- }
- return timelineSegments[timelineSegments.length - 1];
- };
- const MIN_BACK_BUFFER$1 = 1;
- const CHECK_BUFFER_DELAY$1 = 500;
- const finite$1 = (num) => typeof num === "number" && isFinite(num);
- const MIN_SEGMENT_DURATION_TO_SAVE_STATS$1 = 1 / 60;
- const illegalMediaSwitch$1 = (loaderType, startingMedia, trackInfo) => {
- if (loaderType !== "main" || !startingMedia || !trackInfo) {
- return null;
- }
- if (!trackInfo.hasAudio && !trackInfo.hasVideo) {
- return "Neither audio nor video found in segment.";
- }
- if (startingMedia.hasVideo && !trackInfo.hasVideo) {
- return "Only audio found in segment when we expected video. We can't switch to audio only from a stream that had video. To get rid of this message, please add codec information to the manifest.";
- }
- if (!startingMedia.hasVideo && trackInfo.hasVideo) {
- return "Video found in segment when we expected only audio. We can't switch to a stream with video from an audio only stream. To get rid of this message, please add codec information to the manifest.";
- }
- return null;
- };
- const safeBackBufferTrimTime$1 = (seekable3, currentTime, targetDuration) => {
- let trimTime = currentTime - Config$1.BACK_BUFFER_LENGTH;
- if (seekable3.length) {
- trimTime = Math.max(trimTime, seekable3.start(0));
- }
- const maxTrimTime = currentTime - targetDuration;
- return Math.min(maxTrimTime, trimTime);
- };
- const segmentInfoString$1 = (segmentInfo) => {
- const {
- startOfSegment,
- duration: duration5,
- segment,
- part,
- playlist: {
- mediaSequence: seq,
- id,
- segments = []
- },
- mediaIndex: index2,
- partIndex,
- timeline
- } = segmentInfo;
- const segmentLen = segments.length - 1;
- let selection = "mediaIndex/partIndex increment";
- if (segmentInfo.getMediaInfoForTime) {
- selection = `getMediaInfoForTime (${segmentInfo.getMediaInfoForTime})`;
- } else if (segmentInfo.isSyncRequest) {
- selection = "getSyncSegmentCandidate (isSyncRequest)";
- }
- if (segmentInfo.independent) {
- selection += ` with independent ${segmentInfo.independent}`;
- }
- const hasPartIndex = typeof partIndex === "number";
- const name = segmentInfo.segment.uri ? "segment" : "pre-segment";
- const zeroBasedPartCount = hasPartIndex ? getKnownPartCount$1({
- preloadSegment: segment
- }) - 1 : 0;
- return `${name} [${seq + index2}/${seq + segmentLen}]` + (hasPartIndex ? ` part [${partIndex}/${zeroBasedPartCount}]` : "") + ` segment start/end [${segment.start} => ${segment.end}]` + (hasPartIndex ? ` part start/end [${part.start} => ${part.end}]` : "") + ` startOfSegment [${startOfSegment}] duration [${duration5}] timeline [${timeline}] selected by [${selection}] playlist [${id}]`;
- };
- const timingInfoPropertyForMedia$1 = (mediaType) => `${mediaType}TimingInfo`;
- const timestampOffsetForSegment$1 = ({
- segmentTimeline,
- currentTimeline,
- startOfSegment,
- buffered,
- overrideCheck
- }) => {
- if (!overrideCheck && segmentTimeline === currentTimeline) {
- return null;
- }
- if (segmentTimeline < currentTimeline) {
- return startOfSegment;
- }
- return buffered.length ? buffered.end(buffered.length - 1) : startOfSegment;
- };
- const shouldWaitForTimelineChange$1 = ({
- timelineChangeController,
- currentTimeline,
- segmentTimeline,
- loaderType,
- audioDisabled
- }) => {
- if (currentTimeline === segmentTimeline) {
- return false;
- }
- if (loaderType === "audio") {
- const lastMainTimelineChange = timelineChangeController.lastTimelineChange({
- type: "main"
- });
- return !lastMainTimelineChange || lastMainTimelineChange.to !== segmentTimeline;
- }
- if (loaderType === "main" && audioDisabled) {
- const pendingAudioTimelineChange = timelineChangeController.pendingTimelineChange({
- type: "audio"
- });
- if (pendingAudioTimelineChange && pendingAudioTimelineChange.to === segmentTimeline) {
- return false;
- }
- return true;
- }
- return false;
- };
- const mediaDuration$1 = (timingInfos) => {
- let maxDuration = 0;
- ["video", "audio"].forEach(function(type2) {
- const typeTimingInfo = timingInfos[`${type2}TimingInfo`];
- if (!typeTimingInfo) {
- return;
- }
- const {
- start: start2,
- end
- } = typeTimingInfo;
- let duration5;
- if (typeof start2 === "bigint" || typeof end === "bigint") {
- duration5 = window_1.BigInt(end) - window_1.BigInt(start2);
- } else if (typeof start2 === "number" && typeof end === "number") {
- duration5 = end - start2;
- }
- if (typeof duration5 !== "undefined" && duration5 > maxDuration) {
- maxDuration = duration5;
- }
- });
- if (typeof maxDuration === "bigint" && maxDuration < Number.MAX_SAFE_INTEGER) {
- maxDuration = Number(maxDuration);
- }
- return maxDuration;
- };
- const segmentTooLong$1 = ({
- segmentDuration,
- maxDuration
- }) => {
- if (!segmentDuration) {
- return false;
- }
- return Math.round(segmentDuration) > maxDuration + TIME_FUDGE_FACTOR$1;
- };
- const getTroublesomeSegmentDurationMessage$1 = (segmentInfo, sourceType) => {
- if (sourceType !== "hls") {
- return null;
- }
- const segmentDuration = mediaDuration$1({
- audioTimingInfo: segmentInfo.audioTimingInfo,
- videoTimingInfo: segmentInfo.videoTimingInfo
- });
- if (!segmentDuration) {
- return null;
- }
- const targetDuration = segmentInfo.playlist.targetDuration;
- const isSegmentWayTooLong = segmentTooLong$1({
- segmentDuration,
- maxDuration: targetDuration * 2
- });
- const isSegmentSlightlyTooLong = segmentTooLong$1({
- segmentDuration,
- maxDuration: targetDuration
- });
- const segmentTooLongMessage = `Segment with index ${segmentInfo.mediaIndex} from playlist ${segmentInfo.playlist.id} has a duration of ${segmentDuration} when the reported duration is ${segmentInfo.duration} and the target duration is ${targetDuration}. For HLS content, a duration in excess of the target duration may result in playback issues. See the HLS specification section on EXT-X-TARGETDURATION for more details: https://tools.ietf.org/html/draft-pantos-http-live-streaming-23#section-4.3.3.1`;
- if (isSegmentWayTooLong || isSegmentSlightlyTooLong) {
- return {
- severity: isSegmentWayTooLong ? "warn" : "info",
- message: segmentTooLongMessage
- };
- }
- return null;
- };
- class SegmentLoader$1 extends videojs$2.EventTarget {
- constructor(settings, options2 = {}) {
- super();
- if (!settings) {
- throw new TypeError("Initialization settings are required");
- }
- if (typeof settings.currentTime !== "function") {
- throw new TypeError("No currentTime getter specified");
- }
- if (!settings.mediaSource) {
- throw new TypeError("No MediaSource specified");
- }
- this.bandwidth = settings.bandwidth;
- this.throughput = {
- rate: 0,
- count: 0
- };
- this.roundTrip = NaN;
- this.resetStats_();
- this.mediaIndex = null;
- this.partIndex = null;
- this.hasPlayed_ = settings.hasPlayed;
- this.currentTime_ = settings.currentTime;
- this.seekable_ = settings.seekable;
- this.seeking_ = settings.seeking;
- this.duration_ = settings.duration;
- this.mediaSource_ = settings.mediaSource;
- this.vhs_ = settings.vhs;
- this.loaderType_ = settings.loaderType;
- this.currentMediaInfo_ = void 0;
- this.startingMediaInfo_ = void 0;
- this.segmentMetadataTrack_ = settings.segmentMetadataTrack;
- this.goalBufferLength_ = settings.goalBufferLength;
- this.sourceType_ = settings.sourceType;
- this.sourceUpdater_ = settings.sourceUpdater;
- this.inbandTextTracks_ = settings.inbandTextTracks;
- this.state_ = "INIT";
- this.timelineChangeController_ = settings.timelineChangeController;
- this.shouldSaveSegmentTimingInfo_ = true;
- this.parse708captions_ = settings.parse708captions;
- this.useDtsForTimestampOffset_ = settings.useDtsForTimestampOffset;
- this.captionServices_ = settings.captionServices;
- this.exactManifestTimings = settings.exactManifestTimings;
- this.checkBufferTimeout_ = null;
- this.error_ = void 0;
- this.currentTimeline_ = -1;
- this.pendingSegment_ = null;
- this.xhrOptions_ = null;
- this.pendingSegments_ = [];
- this.audioDisabled_ = false;
- this.isPendingTimestampOffset_ = false;
- this.gopBuffer_ = [];
- this.timeMapping_ = 0;
- this.safeAppend_ = videojs$2.browser.IE_VERSION >= 11;
- this.appendInitSegment_ = {
- audio: true,
- video: true
- };
- this.playlistOfLastInitSegment_ = {
- audio: null,
- video: null
- };
- this.callQueue_ = [];
- this.loadQueue_ = [];
- this.metadataQueue_ = {
- id3: [],
- caption: []
- };
- this.waitingOnRemove_ = false;
- this.quotaExceededErrorRetryTimeout_ = null;
- this.activeInitSegmentId_ = null;
- this.initSegments_ = {};
- this.cacheEncryptionKeys_ = settings.cacheEncryptionKeys;
- this.keyCache_ = {};
- this.decrypter_ = settings.decrypter;
- this.syncController_ = settings.syncController;
- this.syncPoint_ = {
- segmentIndex: 0,
- time: 0
- };
- this.transmuxer_ = this.createTransmuxer_();
- this.triggerSyncInfoUpdate_ = () => this.trigger("syncinfoupdate");
- this.syncController_.on("syncinfoupdate", this.triggerSyncInfoUpdate_);
- this.mediaSource_.addEventListener("sourceopen", () => {
- if (!this.isEndOfStream_()) {
- this.ended_ = false;
- }
- });
- this.fetchAtBuffer_ = false;
- this.logger_ = logger$1(`SegmentLoader[${this.loaderType_}]`);
- Object.defineProperty(this, "state", {
- get() {
- return this.state_;
- },
- set(newState) {
- if (newState !== this.state_) {
- this.logger_(`${this.state_} -> ${newState}`);
- this.state_ = newState;
- this.trigger("statechange");
- }
- }
- });
- this.sourceUpdater_.on("ready", () => {
- if (this.hasEnoughInfoToAppend_()) {
- this.processCallQueue_();
- }
- });
- if (this.loaderType_ === "main") {
- this.timelineChangeController_.on("pendingtimelinechange", () => {
- if (this.hasEnoughInfoToAppend_()) {
- this.processCallQueue_();
- }
- });
- }
- if (this.loaderType_ === "audio") {
- this.timelineChangeController_.on("timelinechange", () => {
- if (this.hasEnoughInfoToLoad_()) {
- this.processLoadQueue_();
- }
- if (this.hasEnoughInfoToAppend_()) {
- this.processCallQueue_();
- }
- });
- }
- }
- createTransmuxer_() {
- return segmentTransmuxer$1.createTransmuxer({
- remux: false,
- alignGopsAtEnd: this.safeAppend_,
- keepOriginalTimestamps: true,
- parse708captions: this.parse708captions_,
- captionServices: this.captionServices_
- });
- }
- resetStats_() {
- this.mediaBytesTransferred = 0;
- this.mediaRequests = 0;
- this.mediaRequestsAborted = 0;
- this.mediaRequestsTimedout = 0;
- this.mediaRequestsErrored = 0;
- this.mediaTransferDuration = 0;
- this.mediaSecondsLoaded = 0;
- this.mediaAppends = 0;
- }
- dispose() {
- this.trigger("dispose");
- this.state = "DISPOSED";
- this.pause();
- this.abort_();
- if (this.transmuxer_) {
- this.transmuxer_.terminate();
- }
- this.resetStats_();
- if (this.checkBufferTimeout_) {
- window_1.clearTimeout(this.checkBufferTimeout_);
- }
- if (this.syncController_ && this.triggerSyncInfoUpdate_) {
- this.syncController_.off("syncinfoupdate", this.triggerSyncInfoUpdate_);
- }
- this.off();
- }
- setAudio(enable) {
- this.audioDisabled_ = !enable;
- if (enable) {
- this.appendInitSegment_.audio = true;
- } else {
- this.sourceUpdater_.removeAudio(0, this.duration_());
- }
- }
- abort() {
- if (this.state !== "WAITING") {
- if (this.pendingSegment_) {
- this.pendingSegment_ = null;
- }
- return;
- }
- this.abort_();
- this.state = "READY";
- if (!this.paused()) {
- this.monitorBuffer_();
- }
- }
- abort_() {
- if (this.pendingSegment_ && this.pendingSegment_.abortRequests) {
- this.pendingSegment_.abortRequests();
- }
- this.pendingSegment_ = null;
- this.callQueue_ = [];
- this.loadQueue_ = [];
- this.metadataQueue_.id3 = [];
- this.metadataQueue_.caption = [];
- this.timelineChangeController_.clearPendingTimelineChange(this.loaderType_);
- this.waitingOnRemove_ = false;
- window_1.clearTimeout(this.quotaExceededErrorRetryTimeout_);
- this.quotaExceededErrorRetryTimeout_ = null;
- }
- checkForAbort_(requestId) {
- if (this.state === "APPENDING" && !this.pendingSegment_) {
- this.state = "READY";
- return true;
- }
- if (!this.pendingSegment_ || this.pendingSegment_.requestId !== requestId) {
- return true;
- }
- return false;
- }
- error(error) {
- if (typeof error !== "undefined") {
- this.logger_("error occurred:", error);
- this.error_ = error;
- }
- this.pendingSegment_ = null;
- return this.error_;
- }
- endOfStream() {
- this.ended_ = true;
- if (this.transmuxer_) {
- segmentTransmuxer$1.reset(this.transmuxer_);
- }
- this.gopBuffer_.length = 0;
- this.pause();
- this.trigger("ended");
- }
- buffered_() {
- const trackInfo = this.getMediaInfo_();
- if (!this.sourceUpdater_ || !trackInfo) {
- return createTimeRanges$2();
- }
- if (this.loaderType_ === "main") {
- const {
- hasAudio,
- hasVideo,
- isMuxed: isMuxed3
- } = trackInfo;
- if (hasVideo && hasAudio && !this.audioDisabled_ && !isMuxed3) {
- return this.sourceUpdater_.buffered();
- }
- if (hasVideo) {
- return this.sourceUpdater_.videoBuffered();
- }
- }
- return this.sourceUpdater_.audioBuffered();
- }
- initSegmentForMap(map, set4 = false) {
- if (!map) {
- return null;
- }
- const id = initSegmentId$1(map);
- let storedMap = this.initSegments_[id];
- if (set4 && !storedMap && map.bytes) {
- this.initSegments_[id] = storedMap = {
- resolvedUri: map.resolvedUri,
- byterange: map.byterange,
- bytes: map.bytes,
- tracks: map.tracks,
- timescales: map.timescales
- };
- }
- return storedMap || map;
- }
- segmentKey(key, set4 = false) {
- if (!key) {
- return null;
- }
- const id = segmentKeyId$1(key);
- let storedKey = this.keyCache_[id];
- if (this.cacheEncryptionKeys_ && set4 && !storedKey && key.bytes) {
- this.keyCache_[id] = storedKey = {
- resolvedUri: key.resolvedUri,
- bytes: key.bytes
- };
- }
- const result = {
- resolvedUri: (storedKey || key).resolvedUri
- };
- if (storedKey) {
- result.bytes = storedKey.bytes;
- }
- return result;
- }
- couldBeginLoading_() {
- return this.playlist_ && !this.paused();
- }
- load() {
- this.monitorBuffer_();
- if (!this.playlist_) {
- return;
- }
- if (this.state === "INIT" && this.couldBeginLoading_()) {
- return this.init_();
- }
- if (!this.couldBeginLoading_() || this.state !== "READY" && this.state !== "INIT") {
- return;
- }
- this.state = "READY";
- }
- init_() {
- this.state = "READY";
- this.resetEverything();
- return this.monitorBuffer_();
- }
- playlist(newPlaylist, options2 = {}) {
- if (!newPlaylist) {
- return;
- }
- const oldPlaylist = this.playlist_;
- const segmentInfo = this.pendingSegment_;
- this.playlist_ = newPlaylist;
- this.xhrOptions_ = options2;
- if (this.state === "INIT") {
- newPlaylist.syncInfo = {
- mediaSequence: newPlaylist.mediaSequence,
- time: 0
- };
- if (this.loaderType_ === "main") {
- this.syncController_.setDateTimeMappingForStart(newPlaylist);
- }
- }
- let oldId = null;
- if (oldPlaylist) {
- if (oldPlaylist.id) {
- oldId = oldPlaylist.id;
- } else if (oldPlaylist.uri) {
- oldId = oldPlaylist.uri;
- }
- }
- this.logger_(`playlist update [${oldId} => ${newPlaylist.id || newPlaylist.uri}]`);
- this.trigger("syncinfoupdate");
- if (this.state === "INIT" && this.couldBeginLoading_()) {
- return this.init_();
- }
- if (!oldPlaylist || oldPlaylist.uri !== newPlaylist.uri) {
- if (this.mediaIndex !== null) {
- if (!newPlaylist.endList) {
- this.resetLoader();
- } else {
- this.resyncLoader();
- }
- }
- this.currentMediaInfo_ = void 0;
- this.trigger("playlistupdate");
- return;
- }
- const mediaSequenceDiff = newPlaylist.mediaSequence - oldPlaylist.mediaSequence;
- this.logger_(`live window shift [${mediaSequenceDiff}]`);
- if (this.mediaIndex !== null) {
- this.mediaIndex -= mediaSequenceDiff;
- if (this.mediaIndex < 0) {
- this.mediaIndex = null;
- this.partIndex = null;
- } else {
- const segment = this.playlist_.segments[this.mediaIndex];
- if (this.partIndex && (!segment.parts || !segment.parts.length || !segment.parts[this.partIndex])) {
- const mediaIndex = this.mediaIndex;
- this.logger_(`currently processing part (index ${this.partIndex}) no longer exists.`);
- this.resetLoader();
- this.mediaIndex = mediaIndex;
- }
- }
- }
- if (segmentInfo) {
- segmentInfo.mediaIndex -= mediaSequenceDiff;
- if (segmentInfo.mediaIndex < 0) {
- segmentInfo.mediaIndex = null;
- segmentInfo.partIndex = null;
- } else {
- if (segmentInfo.mediaIndex >= 0) {
- segmentInfo.segment = newPlaylist.segments[segmentInfo.mediaIndex];
- }
- if (segmentInfo.partIndex >= 0 && segmentInfo.segment.parts) {
- segmentInfo.part = segmentInfo.segment.parts[segmentInfo.partIndex];
- }
- }
- }
- this.syncController_.saveExpiredSegmentInfo(oldPlaylist, newPlaylist);
- }
- pause() {
- if (this.checkBufferTimeout_) {
- window_1.clearTimeout(this.checkBufferTimeout_);
- this.checkBufferTimeout_ = null;
- }
- }
- paused() {
- return this.checkBufferTimeout_ === null;
- }
- resetEverything(done) {
- this.ended_ = false;
- this.activeInitSegmentId_ = null;
- this.appendInitSegment_ = {
- audio: true,
- video: true
- };
- this.resetLoader();
- this.remove(0, Infinity, done);
- if (this.transmuxer_) {
- this.transmuxer_.postMessage({
- action: "clearAllMp4Captions"
- });
- this.transmuxer_.postMessage({
- action: "reset"
- });
- }
- }
- resetLoader() {
- this.fetchAtBuffer_ = false;
- this.resyncLoader();
- }
- resyncLoader() {
- if (this.transmuxer_) {
- segmentTransmuxer$1.reset(this.transmuxer_);
- }
- this.mediaIndex = null;
- this.partIndex = null;
- this.syncPoint_ = null;
- this.isPendingTimestampOffset_ = false;
- this.callQueue_ = [];
- this.loadQueue_ = [];
- this.metadataQueue_.id3 = [];
- this.metadataQueue_.caption = [];
- this.abort();
- if (this.transmuxer_) {
- this.transmuxer_.postMessage({
- action: "clearParsedMp4Captions"
- });
- }
- }
- remove(start2, end, done = () => {
- }, force = false) {
- if (end === Infinity) {
- end = this.duration_();
- }
- if (end <= start2) {
- this.logger_("skipping remove because end ${end} is <= start ${start}");
- return;
- }
- if (!this.sourceUpdater_ || !this.getMediaInfo_()) {
- this.logger_("skipping remove because no source updater or starting media info");
- return;
- }
- let removesRemaining = 1;
- const removeFinished = () => {
- removesRemaining--;
- if (removesRemaining === 0) {
- done();
- }
- };
- if (force || !this.audioDisabled_) {
- removesRemaining++;
- this.sourceUpdater_.removeAudio(start2, end, removeFinished);
- }
- if (force || this.loaderType_ === "main") {
- this.gopBuffer_ = removeGopBuffer$1(this.gopBuffer_, start2, end, this.timeMapping_);
- removesRemaining++;
- this.sourceUpdater_.removeVideo(start2, end, removeFinished);
- }
- for (const track in this.inbandTextTracks_) {
- removeCuesFromTrack$1(start2, end, this.inbandTextTracks_[track]);
- }
- removeCuesFromTrack$1(start2, end, this.segmentMetadataTrack_);
- removeFinished();
- }
- monitorBuffer_() {
- if (this.checkBufferTimeout_) {
- window_1.clearTimeout(this.checkBufferTimeout_);
- }
- this.checkBufferTimeout_ = window_1.setTimeout(this.monitorBufferTick_.bind(this), 1);
- }
- monitorBufferTick_() {
- if (this.state === "READY") {
- this.fillBuffer_();
- }
- if (this.checkBufferTimeout_) {
- window_1.clearTimeout(this.checkBufferTimeout_);
- }
- this.checkBufferTimeout_ = window_1.setTimeout(this.monitorBufferTick_.bind(this), CHECK_BUFFER_DELAY$1);
- }
- fillBuffer_() {
- if (this.sourceUpdater_.updating()) {
- return;
- }
- const segmentInfo = this.chooseNextRequest_();
- if (!segmentInfo) {
- return;
- }
- if (typeof segmentInfo.timestampOffset === "number") {
- this.isPendingTimestampOffset_ = false;
- this.timelineChangeController_.pendingTimelineChange({
- type: this.loaderType_,
- from: this.currentTimeline_,
- to: segmentInfo.timeline
- });
- }
- this.loadSegment_(segmentInfo);
- }
- isEndOfStream_(mediaIndex = this.mediaIndex, playlist = this.playlist_, partIndex = this.partIndex) {
- if (!playlist || !this.mediaSource_) {
- return false;
- }
- const segment = typeof mediaIndex === "number" && playlist.segments[mediaIndex];
- const appendedLastSegment = mediaIndex + 1 === playlist.segments.length;
- const appendedLastPart = !segment || !segment.parts || partIndex + 1 === segment.parts.length;
- return playlist.endList && this.mediaSource_.readyState === "open" && appendedLastSegment && appendedLastPart;
- }
- chooseNextRequest_() {
- const buffered = this.buffered_();
- const bufferedEnd = lastBufferedEnd$1(buffered) || 0;
- const bufferedTime = timeAheadOf$1(buffered, this.currentTime_());
- const preloaded = !this.hasPlayed_() && bufferedTime >= 1;
- const haveEnoughBuffer = bufferedTime >= this.goalBufferLength_();
- const segments = this.playlist_.segments;
- if (!segments.length || preloaded || haveEnoughBuffer) {
- return null;
- }
- this.syncPoint_ = this.syncPoint_ || this.syncController_.getSyncPoint(this.playlist_, this.duration_(), this.currentTimeline_, this.currentTime_());
- const next = {
- partIndex: null,
- mediaIndex: null,
- startOfSegment: null,
- playlist: this.playlist_,
- isSyncRequest: Boolean(!this.syncPoint_)
- };
- if (next.isSyncRequest) {
- next.mediaIndex = getSyncSegmentCandidate$1(this.currentTimeline_, segments, bufferedEnd);
- } else if (this.mediaIndex !== null) {
- const segment = segments[this.mediaIndex];
- const partIndex = typeof this.partIndex === "number" ? this.partIndex : -1;
- next.startOfSegment = segment.end ? segment.end : bufferedEnd;
- if (segment.parts && segment.parts[partIndex + 1]) {
- next.mediaIndex = this.mediaIndex;
- next.partIndex = partIndex + 1;
- } else {
- next.mediaIndex = this.mediaIndex + 1;
- }
- } else {
- const {
- segmentIndex,
- startTime,
- partIndex
- } = Playlist$1.getMediaInfoForTime({
- exactManifestTimings: this.exactManifestTimings,
- playlist: this.playlist_,
- currentTime: this.fetchAtBuffer_ ? bufferedEnd : this.currentTime_(),
- startingPartIndex: this.syncPoint_.partIndex,
- startingSegmentIndex: this.syncPoint_.segmentIndex,
- startTime: this.syncPoint_.time
- });
- next.getMediaInfoForTime = this.fetchAtBuffer_ ? `bufferedEnd ${bufferedEnd}` : `currentTime ${this.currentTime_()}`;
- next.mediaIndex = segmentIndex;
- next.startOfSegment = startTime;
- next.partIndex = partIndex;
- }
- const nextSegment = segments[next.mediaIndex];
- let nextPart = nextSegment && typeof next.partIndex === "number" && nextSegment.parts && nextSegment.parts[next.partIndex];
- if (!nextSegment || typeof next.partIndex === "number" && !nextPart) {
- return null;
- }
- if (typeof next.partIndex !== "number" && nextSegment.parts) {
- next.partIndex = 0;
- nextPart = nextSegment.parts[0];
- }
- if (!bufferedTime && nextPart && !nextPart.independent) {
- if (next.partIndex === 0) {
- const lastSegment = segments[next.mediaIndex - 1];
- const lastSegmentLastPart = lastSegment.parts && lastSegment.parts.length && lastSegment.parts[lastSegment.parts.length - 1];
- if (lastSegmentLastPart && lastSegmentLastPart.independent) {
- next.mediaIndex -= 1;
- next.partIndex = lastSegment.parts.length - 1;
- next.independent = "previous segment";
- }
- } else if (nextSegment.parts[next.partIndex - 1].independent) {
- next.partIndex -= 1;
- next.independent = "previous part";
- }
- }
- const ended = this.mediaSource_ && this.mediaSource_.readyState === "ended";
- if (next.mediaIndex >= segments.length - 1 && ended && !this.seeking_()) {
- return null;
- }
- return this.generateSegmentInfo_(next);
- }
- generateSegmentInfo_(options2) {
- const {
- independent,
- playlist,
- mediaIndex,
- startOfSegment,
- isSyncRequest,
- partIndex,
- forceTimestampOffset,
- getMediaInfoForTime: getMediaInfoForTime3
- } = options2;
- const segment = playlist.segments[mediaIndex];
- const part = typeof partIndex === "number" && segment.parts[partIndex];
- const segmentInfo = {
- requestId: "segment-loader-" + Math.random(),
- uri: part && part.resolvedUri || segment.resolvedUri,
- mediaIndex,
- partIndex: part ? partIndex : null,
- isSyncRequest,
- startOfSegment,
- playlist,
- bytes: null,
- encryptedBytes: null,
- timestampOffset: null,
- timeline: segment.timeline,
- duration: part && part.duration || segment.duration,
- segment,
- part,
- byteLength: 0,
- transmuxer: this.transmuxer_,
- getMediaInfoForTime: getMediaInfoForTime3,
- independent
- };
- const overrideCheck = typeof forceTimestampOffset !== "undefined" ? forceTimestampOffset : this.isPendingTimestampOffset_;
- segmentInfo.timestampOffset = this.timestampOffsetForSegment_({
- segmentTimeline: segment.timeline,
- currentTimeline: this.currentTimeline_,
- startOfSegment,
- buffered: this.buffered_(),
- overrideCheck
- });
- const audioBufferedEnd = lastBufferedEnd$1(this.sourceUpdater_.audioBuffered());
- if (typeof audioBufferedEnd === "number") {
- segmentInfo.audioAppendStart = audioBufferedEnd - this.sourceUpdater_.audioTimestampOffset();
- }
- if (this.sourceUpdater_.videoBuffered().length) {
- segmentInfo.gopsToAlignWith = gopsSafeToAlignWith$1(
- this.gopBuffer_,
- this.currentTime_() - this.sourceUpdater_.videoTimestampOffset(),
- this.timeMapping_
- );
- }
- return segmentInfo;
- }
- timestampOffsetForSegment_(options2) {
- return timestampOffsetForSegment$1(options2);
- }
- earlyAbortWhenNeeded_(stats) {
- if (this.vhs_.tech_.paused() || !this.xhrOptions_.timeout || !this.playlist_.attributes.BANDWIDTH) {
- return;
- }
- if (Date.now() - (stats.firstBytesReceivedAt || Date.now()) < 1e3) {
- return;
- }
- const currentTime = this.currentTime_();
- const measuredBandwidth = stats.bandwidth;
- const segmentDuration = this.pendingSegment_.duration;
- const requestTimeRemaining = Playlist$1.estimateSegmentRequestTime(segmentDuration, measuredBandwidth, this.playlist_, stats.bytesReceived);
- const timeUntilRebuffer$1$1 = timeUntilRebuffer$1(this.buffered_(), currentTime, this.vhs_.tech_.playbackRate()) - 1;
- if (requestTimeRemaining <= timeUntilRebuffer$1$1) {
- return;
- }
- const switchCandidate = minRebufferMaxBandwidthSelector$1({
- main: this.vhs_.playlists.main,
- currentTime,
- bandwidth: measuredBandwidth,
- duration: this.duration_(),
- segmentDuration,
- timeUntilRebuffer: timeUntilRebuffer$1$1,
- currentTimeline: this.currentTimeline_,
- syncController: this.syncController_
- });
- if (!switchCandidate) {
- return;
- }
- const rebufferingImpact = requestTimeRemaining - timeUntilRebuffer$1$1;
- const timeSavedBySwitching = rebufferingImpact - switchCandidate.rebufferingImpact;
- let minimumTimeSaving = 0.5;
- if (timeUntilRebuffer$1$1 <= TIME_FUDGE_FACTOR$1) {
- minimumTimeSaving = 1;
- }
- if (!switchCandidate.playlist || switchCandidate.playlist.uri === this.playlist_.uri || timeSavedBySwitching < minimumTimeSaving) {
- return;
- }
- this.bandwidth = switchCandidate.playlist.attributes.BANDWIDTH * Config$1.BANDWIDTH_VARIANCE + 1;
- this.trigger("earlyabort");
- }
- handleAbort_(segmentInfo) {
- this.logger_(`Aborting ${segmentInfoString$1(segmentInfo)}`);
- this.mediaRequestsAborted += 1;
- }
- handleProgress_(event2, simpleSegment) {
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- this.trigger("progress");
- }
- handleTrackInfo_(simpleSegment, trackInfo) {
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- if (this.checkForIllegalMediaSwitch(trackInfo)) {
- return;
- }
- trackInfo = trackInfo || {};
- if (!shallowEqual$1(this.currentMediaInfo_, trackInfo)) {
- this.appendInitSegment_ = {
- audio: true,
- video: true
- };
- this.startingMediaInfo_ = trackInfo;
- this.currentMediaInfo_ = trackInfo;
- this.logger_("trackinfo update", trackInfo);
- this.trigger("trackinfo");
- }
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- this.pendingSegment_.trackInfo = trackInfo;
- if (this.hasEnoughInfoToAppend_()) {
- this.processCallQueue_();
- }
- }
- handleTimingInfo_(simpleSegment, mediaType, timeType, time) {
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- const segmentInfo = this.pendingSegment_;
- const timingInfoProperty = timingInfoPropertyForMedia$1(mediaType);
- segmentInfo[timingInfoProperty] = segmentInfo[timingInfoProperty] || {};
- segmentInfo[timingInfoProperty][timeType] = time;
- this.logger_(`timinginfo: ${mediaType} - ${timeType} - ${time}`);
- if (this.hasEnoughInfoToAppend_()) {
- this.processCallQueue_();
- }
- }
- handleCaptions_(simpleSegment, captionData) {
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- if (captionData.length === 0) {
- this.logger_("SegmentLoader received no captions from a caption event");
- return;
- }
- const segmentInfo = this.pendingSegment_;
- if (!segmentInfo.hasAppendedData_) {
- this.metadataQueue_.caption.push(this.handleCaptions_.bind(this, simpleSegment, captionData));
- return;
- }
- const timestampOffset2 = this.sourceUpdater_.videoTimestampOffset() === null ? this.sourceUpdater_.audioTimestampOffset() : this.sourceUpdater_.videoTimestampOffset();
- const captionTracks = {};
- captionData.forEach((caption) => {
- captionTracks[caption.stream] = captionTracks[caption.stream] || {
- startTime: Infinity,
- captions: [],
- endTime: 0
- };
- const captionTrack = captionTracks[caption.stream];
- captionTrack.startTime = Math.min(captionTrack.startTime, caption.startTime + timestampOffset2);
- captionTrack.endTime = Math.max(captionTrack.endTime, caption.endTime + timestampOffset2);
- captionTrack.captions.push(caption);
- });
- Object.keys(captionTracks).forEach((trackName) => {
- const {
- startTime,
- endTime,
- captions
- } = captionTracks[trackName];
- const inbandTextTracks = this.inbandTextTracks_;
- this.logger_(`adding cues from ${startTime} -> ${endTime} for ${trackName}`);
- createCaptionsTrackIfNotExists$1(inbandTextTracks, this.vhs_.tech_, trackName);
- removeCuesFromTrack$1(startTime, endTime, inbandTextTracks[trackName]);
- addCaptionData$1({
- captionArray: captions,
- inbandTextTracks,
- timestampOffset: timestampOffset2
- });
- });
- if (this.transmuxer_) {
- this.transmuxer_.postMessage({
- action: "clearParsedMp4Captions"
- });
- }
- }
- handleId3_(simpleSegment, id3Frames, dispatchType) {
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- const segmentInfo = this.pendingSegment_;
- if (!segmentInfo.hasAppendedData_) {
- this.metadataQueue_.id3.push(this.handleId3_.bind(this, simpleSegment, id3Frames, dispatchType));
- return;
- }
- const timestampOffset2 = this.sourceUpdater_.videoTimestampOffset() === null ? this.sourceUpdater_.audioTimestampOffset() : this.sourceUpdater_.videoTimestampOffset();
- createMetadataTrackIfNotExists$1(this.inbandTextTracks_, dispatchType, this.vhs_.tech_);
- addMetadata$1({
- inbandTextTracks: this.inbandTextTracks_,
- metadataArray: id3Frames,
- timestampOffset: timestampOffset2,
- videoDuration: this.duration_()
- });
- }
- processMetadataQueue_() {
- this.metadataQueue_.id3.forEach((fn2) => fn2());
- this.metadataQueue_.caption.forEach((fn2) => fn2());
- this.metadataQueue_.id3 = [];
- this.metadataQueue_.caption = [];
- }
- processCallQueue_() {
- const callQueue = this.callQueue_;
- this.callQueue_ = [];
- callQueue.forEach((fun) => fun());
- }
- processLoadQueue_() {
- const loadQueue = this.loadQueue_;
- this.loadQueue_ = [];
- loadQueue.forEach((fun) => fun());
- }
- hasEnoughInfoToLoad_() {
- if (this.loaderType_ !== "audio") {
- return true;
- }
- const segmentInfo = this.pendingSegment_;
- if (!segmentInfo) {
- return false;
- }
- if (!this.getCurrentMediaInfo_()) {
- return true;
- }
- if (shouldWaitForTimelineChange$1({
- timelineChangeController: this.timelineChangeController_,
- currentTimeline: this.currentTimeline_,
- segmentTimeline: segmentInfo.timeline,
- loaderType: this.loaderType_,
- audioDisabled: this.audioDisabled_
- })) {
- return false;
- }
- return true;
- }
- getCurrentMediaInfo_(segmentInfo = this.pendingSegment_) {
- return segmentInfo && segmentInfo.trackInfo || this.currentMediaInfo_;
- }
- getMediaInfo_(segmentInfo = this.pendingSegment_) {
- return this.getCurrentMediaInfo_(segmentInfo) || this.startingMediaInfo_;
- }
- getPendingSegmentPlaylist() {
- return this.pendingSegment_ ? this.pendingSegment_.playlist : null;
- }
- hasEnoughInfoToAppend_() {
- if (!this.sourceUpdater_.ready()) {
- return false;
- }
- if (this.waitingOnRemove_ || this.quotaExceededErrorRetryTimeout_) {
- return false;
- }
- const segmentInfo = this.pendingSegment_;
- const trackInfo = this.getCurrentMediaInfo_();
- if (!segmentInfo || !trackInfo) {
- return false;
- }
- const {
- hasAudio,
- hasVideo,
- isMuxed: isMuxed3
- } = trackInfo;
- if (hasVideo && !segmentInfo.videoTimingInfo) {
- return false;
- }
- if (hasAudio && !this.audioDisabled_ && !isMuxed3 && !segmentInfo.audioTimingInfo) {
- return false;
- }
- if (shouldWaitForTimelineChange$1({
- timelineChangeController: this.timelineChangeController_,
- currentTimeline: this.currentTimeline_,
- segmentTimeline: segmentInfo.timeline,
- loaderType: this.loaderType_,
- audioDisabled: this.audioDisabled_
- })) {
- return false;
- }
- return true;
- }
- handleData_(simpleSegment, result) {
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- if (this.callQueue_.length || !this.hasEnoughInfoToAppend_()) {
- this.callQueue_.push(this.handleData_.bind(this, simpleSegment, result));
- return;
- }
- const segmentInfo = this.pendingSegment_;
- this.setTimeMapping_(segmentInfo.timeline);
- this.updateMediaSecondsLoaded_(segmentInfo.part || segmentInfo.segment);
- if (this.mediaSource_.readyState === "closed") {
- return;
- }
- if (simpleSegment.map) {
- simpleSegment.map = this.initSegmentForMap(simpleSegment.map, true);
- segmentInfo.segment.map = simpleSegment.map;
- }
- if (simpleSegment.key) {
- this.segmentKey(simpleSegment.key, true);
- }
- segmentInfo.isFmp4 = simpleSegment.isFmp4;
- segmentInfo.timingInfo = segmentInfo.timingInfo || {};
- if (segmentInfo.isFmp4) {
- this.trigger("fmp4");
- segmentInfo.timingInfo.start = segmentInfo[timingInfoPropertyForMedia$1(result.type)].start;
- } else {
- const trackInfo = this.getCurrentMediaInfo_();
- const useVideoTimingInfo = this.loaderType_ === "main" && trackInfo && trackInfo.hasVideo;
- let firstVideoFrameTimeForData;
- if (useVideoTimingInfo) {
- firstVideoFrameTimeForData = segmentInfo.videoTimingInfo.start;
- }
- segmentInfo.timingInfo.start = this.trueSegmentStart_({
- currentStart: segmentInfo.timingInfo.start,
- playlist: segmentInfo.playlist,
- mediaIndex: segmentInfo.mediaIndex,
- currentVideoTimestampOffset: this.sourceUpdater_.videoTimestampOffset(),
- useVideoTimingInfo,
- firstVideoFrameTimeForData,
- videoTimingInfo: segmentInfo.videoTimingInfo,
- audioTimingInfo: segmentInfo.audioTimingInfo
- });
- }
- this.updateAppendInitSegmentStatus(segmentInfo, result.type);
- this.updateSourceBufferTimestampOffset_(segmentInfo);
- if (segmentInfo.isSyncRequest) {
- this.updateTimingInfoEnd_(segmentInfo);
- this.syncController_.saveSegmentTimingInfo({
- segmentInfo,
- shouldSaveTimelineMapping: this.loaderType_ === "main"
- });
- const next = this.chooseNextRequest_();
- if (next.mediaIndex !== segmentInfo.mediaIndex || next.partIndex !== segmentInfo.partIndex) {
- this.logger_("sync segment was incorrect, not appending");
- return;
- }
- this.logger_("sync segment was correct, appending");
- }
- segmentInfo.hasAppendedData_ = true;
- this.processMetadataQueue_();
- this.appendData_(segmentInfo, result);
- }
- updateAppendInitSegmentStatus(segmentInfo, type2) {
- if (this.loaderType_ === "main" && typeof segmentInfo.timestampOffset === "number" && !segmentInfo.changedTimestampOffset) {
- this.appendInitSegment_ = {
- audio: true,
- video: true
- };
- }
- if (this.playlistOfLastInitSegment_[type2] !== segmentInfo.playlist) {
- this.appendInitSegment_[type2] = true;
- }
- }
- getInitSegmentAndUpdateState_({
- type: type2,
- initSegment,
- map,
- playlist
- }) {
- if (map) {
- const id = initSegmentId$1(map);
- if (this.activeInitSegmentId_ === id) {
- return null;
- }
- initSegment = this.initSegmentForMap(map, true).bytes;
- this.activeInitSegmentId_ = id;
- }
- if (initSegment && this.appendInitSegment_[type2]) {
- this.playlistOfLastInitSegment_[type2] = playlist;
- this.appendInitSegment_[type2] = false;
- this.activeInitSegmentId_ = null;
- return initSegment;
- }
- return null;
- }
- handleQuotaExceededError_({
- segmentInfo,
- type: type2,
- bytes
- }, error) {
- const audioBuffered = this.sourceUpdater_.audioBuffered();
- const videoBuffered = this.sourceUpdater_.videoBuffered();
- if (audioBuffered.length > 1) {
- this.logger_("On QUOTA_EXCEEDED_ERR, found gaps in the audio buffer: " + timeRangesToArray$1(audioBuffered).join(", "));
- }
- if (videoBuffered.length > 1) {
- this.logger_("On QUOTA_EXCEEDED_ERR, found gaps in the video buffer: " + timeRangesToArray$1(videoBuffered).join(", "));
- }
- const audioBufferStart = audioBuffered.length ? audioBuffered.start(0) : 0;
- const audioBufferEnd = audioBuffered.length ? audioBuffered.end(audioBuffered.length - 1) : 0;
- const videoBufferStart = videoBuffered.length ? videoBuffered.start(0) : 0;
- const videoBufferEnd = videoBuffered.length ? videoBuffered.end(videoBuffered.length - 1) : 0;
- if (audioBufferEnd - audioBufferStart <= MIN_BACK_BUFFER$1 && videoBufferEnd - videoBufferStart <= MIN_BACK_BUFFER$1) {
- this.logger_(`On QUOTA_EXCEEDED_ERR, single segment too large to append to buffer, triggering an error. Appended byte length: ${bytes.byteLength}, audio buffer: ${timeRangesToArray$1(audioBuffered).join(", ")}, video buffer: ${timeRangesToArray$1(videoBuffered).join(", ")}, `);
- this.error({
- message: "Quota exceeded error with append of a single segment of content",
- excludeUntil: Infinity
- });
- this.trigger("error");
- return;
- }
- this.waitingOnRemove_ = true;
- this.callQueue_.push(this.appendToSourceBuffer_.bind(this, {
- segmentInfo,
- type: type2,
- bytes
- }));
- const currentTime = this.currentTime_();
- const timeToRemoveUntil = currentTime - MIN_BACK_BUFFER$1;
- this.logger_(`On QUOTA_EXCEEDED_ERR, removing audio/video from 0 to ${timeToRemoveUntil}`);
- this.remove(0, timeToRemoveUntil, () => {
- this.logger_(`On QUOTA_EXCEEDED_ERR, retrying append in ${MIN_BACK_BUFFER$1}s`);
- this.waitingOnRemove_ = false;
- this.quotaExceededErrorRetryTimeout_ = window_1.setTimeout(() => {
- this.logger_("On QUOTA_EXCEEDED_ERR, re-processing call queue");
- this.quotaExceededErrorRetryTimeout_ = null;
- this.processCallQueue_();
- }, MIN_BACK_BUFFER$1 * 1e3);
- }, true);
- }
- handleAppendError_({
- segmentInfo,
- type: type2,
- bytes
- }, error) {
- if (!error) {
- return;
- }
- if (error.code === QUOTA_EXCEEDED_ERR$1) {
- this.handleQuotaExceededError_({
- segmentInfo,
- type: type2,
- bytes
- });
- return;
- }
- this.logger_("Received non QUOTA_EXCEEDED_ERR on append", error);
- this.error(`${type2} append of ${bytes.length}b failed for segment #${segmentInfo.mediaIndex} in playlist ${segmentInfo.playlist.id}`);
- this.trigger("appenderror");
- }
- appendToSourceBuffer_({
- segmentInfo,
- type: type2,
- initSegment,
- data,
- bytes
- }) {
- if (!bytes) {
- const segments = [data];
- let byteLength = data.byteLength;
- if (initSegment) {
- segments.unshift(initSegment);
- byteLength += initSegment.byteLength;
- }
- bytes = concatSegments$1({
- bytes: byteLength,
- segments
- });
- }
- this.sourceUpdater_.appendBuffer({
- segmentInfo,
- type: type2,
- bytes
- }, this.handleAppendError_.bind(this, {
- segmentInfo,
- type: type2,
- bytes
- }));
- }
- handleSegmentTimingInfo_(type2, requestId, segmentTimingInfo) {
- if (!this.pendingSegment_ || requestId !== this.pendingSegment_.requestId) {
- return;
- }
- const segment = this.pendingSegment_.segment;
- const timingInfoProperty = `${type2}TimingInfo`;
- if (!segment[timingInfoProperty]) {
- segment[timingInfoProperty] = {};
- }
- segment[timingInfoProperty].transmuxerPrependedSeconds = segmentTimingInfo.prependedContentDuration || 0;
- segment[timingInfoProperty].transmuxedPresentationStart = segmentTimingInfo.start.presentation;
- segment[timingInfoProperty].transmuxedDecodeStart = segmentTimingInfo.start.decode;
- segment[timingInfoProperty].transmuxedPresentationEnd = segmentTimingInfo.end.presentation;
- segment[timingInfoProperty].transmuxedDecodeEnd = segmentTimingInfo.end.decode;
- segment[timingInfoProperty].baseMediaDecodeTime = segmentTimingInfo.baseMediaDecodeTime;
- }
- appendData_(segmentInfo, result) {
- const {
- type: type2,
- data
- } = result;
- if (!data || !data.byteLength) {
- return;
- }
- if (type2 === "audio" && this.audioDisabled_) {
- return;
- }
- const initSegment = this.getInitSegmentAndUpdateState_({
- type: type2,
- initSegment: result.initSegment,
- playlist: segmentInfo.playlist,
- map: segmentInfo.isFmp4 ? segmentInfo.segment.map : null
- });
- this.appendToSourceBuffer_({
- segmentInfo,
- type: type2,
- initSegment,
- data
- });
- }
- loadSegment_(segmentInfo) {
- this.state = "WAITING";
- this.pendingSegment_ = segmentInfo;
- this.trimBackBuffer_(segmentInfo);
- if (typeof segmentInfo.timestampOffset === "number") {
- if (this.transmuxer_) {
- this.transmuxer_.postMessage({
- action: "clearAllMp4Captions"
- });
- }
- }
- if (!this.hasEnoughInfoToLoad_()) {
- this.loadQueue_.push(() => {
- const options2 = _extends$2({}, segmentInfo, {
- forceTimestampOffset: true
- });
- _extends$2(segmentInfo, this.generateSegmentInfo_(options2));
- this.isPendingTimestampOffset_ = false;
- this.updateTransmuxerAndRequestSegment_(segmentInfo);
- });
- return;
- }
- this.updateTransmuxerAndRequestSegment_(segmentInfo);
- }
- updateTransmuxerAndRequestSegment_(segmentInfo) {
- if (this.shouldUpdateTransmuxerTimestampOffset_(segmentInfo.timestampOffset)) {
- this.gopBuffer_.length = 0;
- segmentInfo.gopsToAlignWith = [];
- this.timeMapping_ = 0;
- this.transmuxer_.postMessage({
- action: "reset"
- });
- this.transmuxer_.postMessage({
- action: "setTimestampOffset",
- timestampOffset: segmentInfo.timestampOffset
- });
- }
- const simpleSegment = this.createSimplifiedSegmentObj_(segmentInfo);
- const isEndOfStream = this.isEndOfStream_(segmentInfo.mediaIndex, segmentInfo.playlist, segmentInfo.partIndex);
- const isWalkingForward = this.mediaIndex !== null;
- const isDiscontinuity = segmentInfo.timeline !== this.currentTimeline_ && segmentInfo.timeline > 0;
- const isEndOfTimeline = isEndOfStream || isWalkingForward && isDiscontinuity;
- this.logger_(`Requesting ${segmentInfoString$1(segmentInfo)}`);
- if (simpleSegment.map && !simpleSegment.map.bytes) {
- this.logger_("going to request init segment.");
- this.appendInitSegment_ = {
- video: true,
- audio: true
- };
- }
- segmentInfo.abortRequests = mediaSegmentRequest$1({
- xhr: this.vhs_.xhr,
- xhrOptions: this.xhrOptions_,
- decryptionWorker: this.decrypter_,
- segment: simpleSegment,
- abortFn: this.handleAbort_.bind(this, segmentInfo),
- progressFn: this.handleProgress_.bind(this),
- trackInfoFn: this.handleTrackInfo_.bind(this),
- timingInfoFn: this.handleTimingInfo_.bind(this),
- videoSegmentTimingInfoFn: this.handleSegmentTimingInfo_.bind(this, "video", segmentInfo.requestId),
- audioSegmentTimingInfoFn: this.handleSegmentTimingInfo_.bind(this, "audio", segmentInfo.requestId),
- captionsFn: this.handleCaptions_.bind(this),
- isEndOfTimeline,
- endedTimelineFn: () => {
- this.logger_("received endedtimeline callback");
- },
- id3Fn: this.handleId3_.bind(this),
- dataFn: this.handleData_.bind(this),
- doneFn: this.segmentRequestFinished_.bind(this),
- onTransmuxerLog: ({
- message,
- level,
- stream
- }) => {
- this.logger_(`${segmentInfoString$1(segmentInfo)} logged from transmuxer stream ${stream} as a ${level}: ${message}`);
- }
- });
- }
- trimBackBuffer_(segmentInfo) {
- const removeToTime = safeBackBufferTrimTime$1(this.seekable_(), this.currentTime_(), this.playlist_.targetDuration || 10);
- if (removeToTime > 0) {
- this.remove(0, removeToTime);
- }
- }
- createSimplifiedSegmentObj_(segmentInfo) {
- const segment = segmentInfo.segment;
- const part = segmentInfo.part;
- const simpleSegment = {
- resolvedUri: part ? part.resolvedUri : segment.resolvedUri,
- byterange: part ? part.byterange : segment.byterange,
- requestId: segmentInfo.requestId,
- transmuxer: segmentInfo.transmuxer,
- audioAppendStart: segmentInfo.audioAppendStart,
- gopsToAlignWith: segmentInfo.gopsToAlignWith,
- part: segmentInfo.part
- };
- const previousSegment = segmentInfo.playlist.segments[segmentInfo.mediaIndex - 1];
- if (previousSegment && previousSegment.timeline === segment.timeline) {
- if (previousSegment.videoTimingInfo) {
- simpleSegment.baseStartTime = previousSegment.videoTimingInfo.transmuxedDecodeEnd;
- } else if (previousSegment.audioTimingInfo) {
- simpleSegment.baseStartTime = previousSegment.audioTimingInfo.transmuxedDecodeEnd;
- }
- }
- if (segment.key) {
- const iv = segment.key.iv || new Uint32Array([0, 0, 0, segmentInfo.mediaIndex + segmentInfo.playlist.mediaSequence]);
- simpleSegment.key = this.segmentKey(segment.key);
- simpleSegment.key.iv = iv;
- }
- if (segment.map) {
- simpleSegment.map = this.initSegmentForMap(segment.map);
- }
- return simpleSegment;
- }
- saveTransferStats_(stats) {
- this.mediaRequests += 1;
- if (stats) {
- this.mediaBytesTransferred += stats.bytesReceived;
- this.mediaTransferDuration += stats.roundTripTime;
- }
- }
- saveBandwidthRelatedStats_(duration5, stats) {
- this.pendingSegment_.byteLength = stats.bytesReceived;
- if (duration5 < MIN_SEGMENT_DURATION_TO_SAVE_STATS$1) {
- this.logger_(`Ignoring segment's bandwidth because its duration of ${duration5} is less than the min to record ${MIN_SEGMENT_DURATION_TO_SAVE_STATS$1}`);
- return;
- }
- this.bandwidth = stats.bandwidth;
- this.roundTrip = stats.roundTripTime;
- }
- handleTimeout_() {
- this.mediaRequestsTimedout += 1;
- this.bandwidth = 1;
- this.roundTrip = NaN;
- this.trigger("bandwidthupdate");
- this.trigger("timeout");
- }
- segmentRequestFinished_(error, simpleSegment, result) {
- if (this.callQueue_.length) {
- this.callQueue_.push(this.segmentRequestFinished_.bind(this, error, simpleSegment, result));
- return;
- }
- this.saveTransferStats_(simpleSegment.stats);
- if (!this.pendingSegment_) {
- return;
- }
- if (simpleSegment.requestId !== this.pendingSegment_.requestId) {
- return;
- }
- if (error) {
- this.pendingSegment_ = null;
- this.state = "READY";
- if (error.code === REQUEST_ERRORS$1.ABORTED) {
- return;
- }
- this.pause();
- if (error.code === REQUEST_ERRORS$1.TIMEOUT) {
- this.handleTimeout_();
- return;
- }
- this.mediaRequestsErrored += 1;
- this.error(error);
- this.trigger("error");
- return;
- }
- const segmentInfo = this.pendingSegment_;
- this.saveBandwidthRelatedStats_(segmentInfo.duration, simpleSegment.stats);
- segmentInfo.endOfAllRequests = simpleSegment.endOfAllRequests;
- if (result.gopInfo) {
- this.gopBuffer_ = updateGopBuffer$1(this.gopBuffer_, result.gopInfo, this.safeAppend_);
- }
- this.state = "APPENDING";
- this.trigger("appending");
- this.waitForAppendsToComplete_(segmentInfo);
- }
- setTimeMapping_(timeline) {
- const timelineMapping = this.syncController_.mappingForTimeline(timeline);
- if (timelineMapping !== null) {
- this.timeMapping_ = timelineMapping;
- }
- }
- updateMediaSecondsLoaded_(segment) {
- if (typeof segment.start === "number" && typeof segment.end === "number") {
- this.mediaSecondsLoaded += segment.end - segment.start;
- } else {
- this.mediaSecondsLoaded += segment.duration;
- }
- }
- shouldUpdateTransmuxerTimestampOffset_(timestampOffset2) {
- if (timestampOffset2 === null) {
- return false;
- }
- if (this.loaderType_ === "main" && timestampOffset2 !== this.sourceUpdater_.videoTimestampOffset()) {
- return true;
- }
- if (!this.audioDisabled_ && timestampOffset2 !== this.sourceUpdater_.audioTimestampOffset()) {
- return true;
- }
- return false;
- }
- trueSegmentStart_({
- currentStart,
- playlist,
- mediaIndex,
- firstVideoFrameTimeForData,
- currentVideoTimestampOffset,
- useVideoTimingInfo,
- videoTimingInfo,
- audioTimingInfo
- }) {
- if (typeof currentStart !== "undefined") {
- return currentStart;
- }
- if (!useVideoTimingInfo) {
- return audioTimingInfo.start;
- }
- const previousSegment = playlist.segments[mediaIndex - 1];
- if (mediaIndex === 0 || !previousSegment || typeof previousSegment.start === "undefined" || previousSegment.end !== firstVideoFrameTimeForData + currentVideoTimestampOffset) {
- return firstVideoFrameTimeForData;
- }
- return videoTimingInfo.start;
- }
- waitForAppendsToComplete_(segmentInfo) {
- const trackInfo = this.getCurrentMediaInfo_(segmentInfo);
- if (!trackInfo) {
- this.error({
- message: "No starting media returned, likely due to an unsupported media format.",
- playlistExclusionDuration: Infinity
- });
- this.trigger("error");
- return;
- }
- const {
- hasAudio,
- hasVideo,
- isMuxed: isMuxed3
- } = trackInfo;
- const waitForVideo = this.loaderType_ === "main" && hasVideo;
- const waitForAudio = !this.audioDisabled_ && hasAudio && !isMuxed3;
- segmentInfo.waitingOnAppends = 0;
- if (!segmentInfo.hasAppendedData_) {
- if (!segmentInfo.timingInfo && typeof segmentInfo.timestampOffset === "number") {
- this.isPendingTimestampOffset_ = true;
- }
- segmentInfo.timingInfo = {
- start: 0
- };
- segmentInfo.waitingOnAppends++;
- if (!this.isPendingTimestampOffset_) {
- this.updateSourceBufferTimestampOffset_(segmentInfo);
- this.processMetadataQueue_();
- }
- this.checkAppendsDone_(segmentInfo);
- return;
- }
- if (waitForVideo) {
- segmentInfo.waitingOnAppends++;
- }
- if (waitForAudio) {
- segmentInfo.waitingOnAppends++;
- }
- if (waitForVideo) {
- this.sourceUpdater_.videoQueueCallback(this.checkAppendsDone_.bind(this, segmentInfo));
- }
- if (waitForAudio) {
- this.sourceUpdater_.audioQueueCallback(this.checkAppendsDone_.bind(this, segmentInfo));
- }
- }
- checkAppendsDone_(segmentInfo) {
- if (this.checkForAbort_(segmentInfo.requestId)) {
- return;
- }
- segmentInfo.waitingOnAppends--;
- if (segmentInfo.waitingOnAppends === 0) {
- this.handleAppendsDone_();
- }
- }
- checkForIllegalMediaSwitch(trackInfo) {
- const illegalMediaSwitchError = illegalMediaSwitch$1(this.loaderType_, this.getCurrentMediaInfo_(), trackInfo);
- if (illegalMediaSwitchError) {
- this.error({
- message: illegalMediaSwitchError,
- playlistExclusionDuration: Infinity
- });
- this.trigger("error");
- return true;
- }
- return false;
- }
- updateSourceBufferTimestampOffset_(segmentInfo) {
- if (segmentInfo.timestampOffset === null || typeof segmentInfo.timingInfo.start !== "number" || segmentInfo.changedTimestampOffset || this.loaderType_ !== "main") {
- return;
- }
- let didChange = false;
- segmentInfo.timestampOffset -= this.getSegmentStartTimeForTimestampOffsetCalculation_({
- videoTimingInfo: segmentInfo.segment.videoTimingInfo,
- audioTimingInfo: segmentInfo.segment.audioTimingInfo,
- timingInfo: segmentInfo.timingInfo
- });
- segmentInfo.changedTimestampOffset = true;
- if (segmentInfo.timestampOffset !== this.sourceUpdater_.videoTimestampOffset()) {
- this.sourceUpdater_.videoTimestampOffset(segmentInfo.timestampOffset);
- didChange = true;
- }
- if (segmentInfo.timestampOffset !== this.sourceUpdater_.audioTimestampOffset()) {
- this.sourceUpdater_.audioTimestampOffset(segmentInfo.timestampOffset);
- didChange = true;
- }
- if (didChange) {
- this.trigger("timestampoffset");
- }
- }
- getSegmentStartTimeForTimestampOffsetCalculation_({
- videoTimingInfo,
- audioTimingInfo,
- timingInfo
- }) {
- if (!this.useDtsForTimestampOffset_) {
- return timingInfo.start;
- }
- if (videoTimingInfo && typeof videoTimingInfo.transmuxedDecodeStart === "number") {
- return videoTimingInfo.transmuxedDecodeStart;
- }
- if (audioTimingInfo && typeof audioTimingInfo.transmuxedDecodeStart === "number") {
- return audioTimingInfo.transmuxedDecodeStart;
- }
- return timingInfo.start;
- }
- updateTimingInfoEnd_(segmentInfo) {
- segmentInfo.timingInfo = segmentInfo.timingInfo || {};
- const trackInfo = this.getMediaInfo_();
- const useVideoTimingInfo = this.loaderType_ === "main" && trackInfo && trackInfo.hasVideo;
- const prioritizedTimingInfo = useVideoTimingInfo && segmentInfo.videoTimingInfo ? segmentInfo.videoTimingInfo : segmentInfo.audioTimingInfo;
- if (!prioritizedTimingInfo) {
- return;
- }
- segmentInfo.timingInfo.end = typeof prioritizedTimingInfo.end === "number" ? prioritizedTimingInfo.end : prioritizedTimingInfo.start + segmentInfo.duration;
- }
- handleAppendsDone_() {
- if (this.pendingSegment_) {
- this.trigger("appendsdone");
- }
- if (!this.pendingSegment_) {
- this.state = "READY";
- if (!this.paused()) {
- this.monitorBuffer_();
- }
- return;
- }
- const segmentInfo = this.pendingSegment_;
- this.updateTimingInfoEnd_(segmentInfo);
- if (this.shouldSaveSegmentTimingInfo_) {
- this.syncController_.saveSegmentTimingInfo({
- segmentInfo,
- shouldSaveTimelineMapping: this.loaderType_ === "main"
- });
- }
- const segmentDurationMessage = getTroublesomeSegmentDurationMessage$1(segmentInfo, this.sourceType_);
- if (segmentDurationMessage) {
- if (segmentDurationMessage.severity === "warn") {
- videojs$2.log.warn(segmentDurationMessage.message);
- } else {
- this.logger_(segmentDurationMessage.message);
- }
- }
- this.recordThroughput_(segmentInfo);
- this.pendingSegment_ = null;
- this.state = "READY";
- if (segmentInfo.isSyncRequest) {
- this.trigger("syncinfoupdate");
- if (!segmentInfo.hasAppendedData_) {
- this.logger_(`Throwing away un-appended sync request ${segmentInfoString$1(segmentInfo)}`);
- return;
- }
- }
- this.logger_(`Appended ${segmentInfoString$1(segmentInfo)}`);
- this.addSegmentMetadataCue_(segmentInfo);
- this.fetchAtBuffer_ = true;
- if (this.currentTimeline_ !== segmentInfo.timeline) {
- this.timelineChangeController_.lastTimelineChange({
- type: this.loaderType_,
- from: this.currentTimeline_,
- to: segmentInfo.timeline
- });
- if (this.loaderType_ === "main" && !this.audioDisabled_) {
- this.timelineChangeController_.lastTimelineChange({
- type: "audio",
- from: this.currentTimeline_,
- to: segmentInfo.timeline
- });
- }
- }
- this.currentTimeline_ = segmentInfo.timeline;
- this.trigger("syncinfoupdate");
- const segment = segmentInfo.segment;
- const part = segmentInfo.part;
- const badSegmentGuess = segment.end && this.currentTime_() - segment.end > segmentInfo.playlist.targetDuration * 3;
- const badPartGuess = part && part.end && this.currentTime_() - part.end > segmentInfo.playlist.partTargetDuration * 3;
- if (badSegmentGuess || badPartGuess) {
- this.logger_(`bad ${badSegmentGuess ? "segment" : "part"} ${segmentInfoString$1(segmentInfo)}`);
- this.resetEverything();
- return;
- }
- const isWalkingForward = this.mediaIndex !== null;
- if (isWalkingForward) {
- this.trigger("bandwidthupdate");
- }
- this.trigger("progress");
- this.mediaIndex = segmentInfo.mediaIndex;
- this.partIndex = segmentInfo.partIndex;
- if (this.isEndOfStream_(segmentInfo.mediaIndex, segmentInfo.playlist, segmentInfo.partIndex)) {
- this.endOfStream();
- }
- this.trigger("appended");
- if (segmentInfo.hasAppendedData_) {
- this.mediaAppends++;
- }
- if (!this.paused()) {
- this.monitorBuffer_();
- }
- }
- recordThroughput_(segmentInfo) {
- if (segmentInfo.duration < MIN_SEGMENT_DURATION_TO_SAVE_STATS$1) {
- this.logger_(`Ignoring segment's throughput because its duration of ${segmentInfo.duration} is less than the min to record ${MIN_SEGMENT_DURATION_TO_SAVE_STATS$1}`);
- return;
- }
- const rate = this.throughput.rate;
- const segmentProcessingTime = Date.now() - segmentInfo.endOfAllRequests + 1;
- const segmentProcessingThroughput = Math.floor(segmentInfo.byteLength / segmentProcessingTime * 8 * 1e3);
- this.throughput.rate += (segmentProcessingThroughput - rate) / ++this.throughput.count;
- }
- addSegmentMetadataCue_(segmentInfo) {
- if (!this.segmentMetadataTrack_) {
- return;
- }
- const segment = segmentInfo.segment;
- const start2 = segment.start;
- const end = segment.end;
- if (!finite$1(start2) || !finite$1(end)) {
- return;
- }
- removeCuesFromTrack$1(start2, end, this.segmentMetadataTrack_);
- const Cue = window_1.WebKitDataCue || window_1.VTTCue;
- const value = {
- custom: segment.custom,
- dateTimeObject: segment.dateTimeObject,
- dateTimeString: segment.dateTimeString,
- bandwidth: segmentInfo.playlist.attributes.BANDWIDTH,
- resolution: segmentInfo.playlist.attributes.RESOLUTION,
- codecs: segmentInfo.playlist.attributes.CODECS,
- byteLength: segmentInfo.byteLength,
- uri: segmentInfo.uri,
- timeline: segmentInfo.timeline,
- playlist: segmentInfo.playlist.id,
- start: start2,
- end
- };
- const data = JSON.stringify(value);
- const cue = new Cue(start2, end, data);
- cue.value = value;
- this.segmentMetadataTrack_.addCue(cue);
- }
- }
- function noop$1() {
- }
- const toTitleCase$2 = function(string) {
- if (typeof string !== "string") {
- return string;
- }
- return string.replace(/./, (w) => w.toUpperCase());
- };
- const bufferTypes$1 = ["video", "audio"];
- const updating = (type2, sourceUpdater) => {
- const sourceBuffer = sourceUpdater[`${type2}Buffer`];
- return sourceBuffer && sourceBuffer.updating || sourceUpdater.queuePending[type2];
- };
- const nextQueueIndexOfType$1 = (type2, queue) => {
- for (let i2 = 0; i2 < queue.length; i2++) {
- const queueEntry = queue[i2];
- if (queueEntry.type === "mediaSource") {
- return null;
- }
- if (queueEntry.type === type2) {
- return i2;
- }
- }
- return null;
- };
- const shiftQueue$1 = (type2, sourceUpdater) => {
- if (sourceUpdater.queue.length === 0) {
- return;
- }
- let queueIndex = 0;
- let queueEntry = sourceUpdater.queue[queueIndex];
- if (queueEntry.type === "mediaSource") {
- if (!sourceUpdater.updating() && sourceUpdater.mediaSource.readyState !== "closed") {
- sourceUpdater.queue.shift();
- queueEntry.action(sourceUpdater);
- if (queueEntry.doneFn) {
- queueEntry.doneFn();
- }
- shiftQueue$1("audio", sourceUpdater);
- shiftQueue$1("video", sourceUpdater);
- }
- return;
- }
- if (type2 === "mediaSource") {
- return;
- }
- if (!sourceUpdater.ready() || sourceUpdater.mediaSource.readyState === "closed" || updating(type2, sourceUpdater)) {
- return;
- }
- if (queueEntry.type !== type2) {
- queueIndex = nextQueueIndexOfType$1(type2, sourceUpdater.queue);
- if (queueIndex === null) {
- return;
- }
- queueEntry = sourceUpdater.queue[queueIndex];
- }
- sourceUpdater.queue.splice(queueIndex, 1);
- sourceUpdater.queuePending[type2] = queueEntry;
- queueEntry.action(type2, sourceUpdater);
- if (!queueEntry.doneFn) {
- sourceUpdater.queuePending[type2] = null;
- shiftQueue$1(type2, sourceUpdater);
- return;
- }
- };
- const cleanupBuffer$1 = (type2, sourceUpdater) => {
- const buffer = sourceUpdater[`${type2}Buffer`];
- const titleType = toTitleCase$2(type2);
- if (!buffer) {
- return;
- }
- buffer.removeEventListener("updateend", sourceUpdater[`on${titleType}UpdateEnd_`]);
- buffer.removeEventListener("error", sourceUpdater[`on${titleType}Error_`]);
- sourceUpdater.codecs[type2] = null;
- sourceUpdater[`${type2}Buffer`] = null;
- };
- const inSourceBuffers$1 = (mediaSource, sourceBuffer) => mediaSource && sourceBuffer && Array.prototype.indexOf.call(mediaSource.sourceBuffers, sourceBuffer) !== -1;
- const actions$1 = {
- appendBuffer: (bytes, segmentInfo, onError2) => (type2, sourceUpdater) => {
- const sourceBuffer = sourceUpdater[`${type2}Buffer`];
- if (!inSourceBuffers$1(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- sourceUpdater.logger_(`Appending segment ${segmentInfo.mediaIndex}'s ${bytes.length} bytes to ${type2}Buffer`);
- try {
- sourceBuffer.appendBuffer(bytes);
- } catch (e) {
- sourceUpdater.logger_(`Error with code ${e.code} ` + (e.code === QUOTA_EXCEEDED_ERR$1 ? "(QUOTA_EXCEEDED_ERR) " : "") + `when appending segment ${segmentInfo.mediaIndex} to ${type2}Buffer`);
- sourceUpdater.queuePending[type2] = null;
- onError2(e);
- }
- },
- remove: (start2, end) => (type2, sourceUpdater) => {
- const sourceBuffer = sourceUpdater[`${type2}Buffer`];
- if (!inSourceBuffers$1(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- sourceUpdater.logger_(`Removing ${start2} to ${end} from ${type2}Buffer`);
- try {
- sourceBuffer.remove(start2, end);
- } catch (e) {
- sourceUpdater.logger_(`Remove ${start2} to ${end} from ${type2}Buffer failed`);
- }
- },
- timestampOffset: (offset) => (type2, sourceUpdater) => {
- const sourceBuffer = sourceUpdater[`${type2}Buffer`];
- if (!inSourceBuffers$1(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- sourceUpdater.logger_(`Setting ${type2}timestampOffset to ${offset}`);
- sourceBuffer.timestampOffset = offset;
- },
- callback: (callback2) => (type2, sourceUpdater) => {
- callback2();
- },
- endOfStream: (error) => (sourceUpdater) => {
- if (sourceUpdater.mediaSource.readyState !== "open") {
- return;
- }
- sourceUpdater.logger_(`Calling mediaSource endOfStream(${error || ""})`);
- try {
- sourceUpdater.mediaSource.endOfStream(error);
- } catch (e) {
- videojs$2.log.warn("Failed to call media source endOfStream", e);
- }
- },
- duration: (duration5) => (sourceUpdater) => {
- sourceUpdater.logger_(`Setting mediaSource duration to ${duration5}`);
- try {
- sourceUpdater.mediaSource.duration = duration5;
- } catch (e) {
- videojs$2.log.warn("Failed to set media source duration", e);
- }
- },
- abort: () => (type2, sourceUpdater) => {
- if (sourceUpdater.mediaSource.readyState !== "open") {
- return;
- }
- const sourceBuffer = sourceUpdater[`${type2}Buffer`];
- if (!inSourceBuffers$1(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- sourceUpdater.logger_(`calling abort on ${type2}Buffer`);
- try {
- sourceBuffer.abort();
- } catch (e) {
- videojs$2.log.warn(`Failed to abort on ${type2}Buffer`, e);
- }
- },
- addSourceBuffer: (type2, codec) => (sourceUpdater) => {
- const titleType = toTitleCase$2(type2);
- const mime = getMimeForCodec$1(codec);
- sourceUpdater.logger_(`Adding ${type2}Buffer with codec ${codec} to mediaSource`);
- const sourceBuffer = sourceUpdater.mediaSource.addSourceBuffer(mime);
- sourceBuffer.addEventListener("updateend", sourceUpdater[`on${titleType}UpdateEnd_`]);
- sourceBuffer.addEventListener("error", sourceUpdater[`on${titleType}Error_`]);
- sourceUpdater.codecs[type2] = codec;
- sourceUpdater[`${type2}Buffer`] = sourceBuffer;
- },
- removeSourceBuffer: (type2) => (sourceUpdater) => {
- const sourceBuffer = sourceUpdater[`${type2}Buffer`];
- cleanupBuffer$1(type2, sourceUpdater);
- if (!inSourceBuffers$1(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- sourceUpdater.logger_(`Removing ${type2}Buffer with codec ${sourceUpdater.codecs[type2]} from mediaSource`);
- try {
- sourceUpdater.mediaSource.removeSourceBuffer(sourceBuffer);
- } catch (e) {
- videojs$2.log.warn(`Failed to removeSourceBuffer ${type2}Buffer`, e);
- }
- },
- changeType: (codec) => (type2, sourceUpdater) => {
- const sourceBuffer = sourceUpdater[`${type2}Buffer`];
- const mime = getMimeForCodec$1(codec);
- if (!inSourceBuffers$1(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- if (sourceUpdater.codecs[type2] === codec) {
- return;
- }
- sourceUpdater.logger_(`changing ${type2}Buffer codec from ${sourceUpdater.codecs[type2]} to ${codec}`);
- sourceBuffer.changeType(mime);
- sourceUpdater.codecs[type2] = codec;
- }
- };
- const pushQueue$1 = ({
- type: type2,
- sourceUpdater,
- action,
- doneFn,
- name
- }) => {
- sourceUpdater.queue.push({
- type: type2,
- action,
- doneFn,
- name
- });
- shiftQueue$1(type2, sourceUpdater);
- };
- const onUpdateend$1 = (type2, sourceUpdater) => (e) => {
- if (sourceUpdater.queuePending[type2]) {
- const doneFn = sourceUpdater.queuePending[type2].doneFn;
- sourceUpdater.queuePending[type2] = null;
- if (doneFn) {
- doneFn(sourceUpdater[`${type2}Error_`]);
- }
- }
- shiftQueue$1(type2, sourceUpdater);
- };
- class SourceUpdater$1 extends videojs$2.EventTarget {
- constructor(mediaSource) {
- super();
- this.mediaSource = mediaSource;
- this.sourceopenListener_ = () => shiftQueue$1("mediaSource", this);
- this.mediaSource.addEventListener("sourceopen", this.sourceopenListener_);
- this.logger_ = logger$1("SourceUpdater");
- this.audioTimestampOffset_ = 0;
- this.videoTimestampOffset_ = 0;
- this.queue = [];
- this.queuePending = {
- audio: null,
- video: null
- };
- this.delayedAudioAppendQueue_ = [];
- this.videoAppendQueued_ = false;
- this.codecs = {};
- this.onVideoUpdateEnd_ = onUpdateend$1("video", this);
- this.onAudioUpdateEnd_ = onUpdateend$1("audio", this);
- this.onVideoError_ = (e) => {
- this.videoError_ = e;
- };
- this.onAudioError_ = (e) => {
- this.audioError_ = e;
- };
- this.createdSourceBuffers_ = false;
- this.initializedEme_ = false;
- this.triggeredReady_ = false;
- }
- initializedEme() {
- this.initializedEme_ = true;
- this.triggerReady();
- }
- hasCreatedSourceBuffers() {
- return this.createdSourceBuffers_;
- }
- hasInitializedAnyEme() {
- return this.initializedEme_;
- }
- ready() {
- return this.hasCreatedSourceBuffers() && this.hasInitializedAnyEme();
- }
- createSourceBuffers(codecs) {
- if (this.hasCreatedSourceBuffers()) {
- return;
- }
- this.addOrChangeSourceBuffers(codecs);
- this.createdSourceBuffers_ = true;
- this.trigger("createdsourcebuffers");
- this.triggerReady();
- }
- triggerReady() {
- if (this.ready() && !this.triggeredReady_) {
- this.triggeredReady_ = true;
- this.trigger("ready");
- }
- }
- addSourceBuffer(type2, codec) {
- pushQueue$1({
- type: "mediaSource",
- sourceUpdater: this,
- action: actions$1.addSourceBuffer(type2, codec),
- name: "addSourceBuffer"
- });
- }
- abort(type2) {
- pushQueue$1({
- type: type2,
- sourceUpdater: this,
- action: actions$1.abort(type2),
- name: "abort"
- });
- }
- removeSourceBuffer(type2) {
- if (!this.canRemoveSourceBuffer()) {
- videojs$2.log.error("removeSourceBuffer is not supported!");
- return;
- }
- pushQueue$1({
- type: "mediaSource",
- sourceUpdater: this,
- action: actions$1.removeSourceBuffer(type2),
- name: "removeSourceBuffer"
- });
- }
- canRemoveSourceBuffer() {
- return !videojs$2.browser.IE_VERSION && !videojs$2.browser.IS_FIREFOX && window_1.MediaSource && window_1.MediaSource.prototype && typeof window_1.MediaSource.prototype.removeSourceBuffer === "function";
- }
- static canChangeType() {
- return window_1.SourceBuffer && window_1.SourceBuffer.prototype && typeof window_1.SourceBuffer.prototype.changeType === "function";
- }
- canChangeType() {
- return this.constructor.canChangeType();
- }
- changeType(type2, codec) {
- if (!this.canChangeType()) {
- videojs$2.log.error("changeType is not supported!");
- return;
- }
- pushQueue$1({
- type: type2,
- sourceUpdater: this,
- action: actions$1.changeType(codec),
- name: "changeType"
- });
- }
- addOrChangeSourceBuffers(codecs) {
- if (!codecs || typeof codecs !== "object" || Object.keys(codecs).length === 0) {
- throw new Error("Cannot addOrChangeSourceBuffers to undefined codecs");
- }
- Object.keys(codecs).forEach((type2) => {
- const codec = codecs[type2];
- if (!this.hasCreatedSourceBuffers()) {
- return this.addSourceBuffer(type2, codec);
- }
- if (this.canChangeType()) {
- this.changeType(type2, codec);
- }
- });
- }
- appendBuffer(options2, doneFn) {
- const {
- segmentInfo,
- type: type2,
- bytes
- } = options2;
- this.processedAppend_ = true;
- if (type2 === "audio" && this.videoBuffer && !this.videoAppendQueued_) {
- this.delayedAudioAppendQueue_.push([options2, doneFn]);
- this.logger_(`delayed audio append of ${bytes.length} until video append`);
- return;
- }
- const onError2 = doneFn;
- pushQueue$1({
- type: type2,
- sourceUpdater: this,
- action: actions$1.appendBuffer(bytes, segmentInfo || {
- mediaIndex: -1
- }, onError2),
- doneFn,
- name: "appendBuffer"
- });
- if (type2 === "video") {
- this.videoAppendQueued_ = true;
- if (!this.delayedAudioAppendQueue_.length) {
- return;
- }
- const queue = this.delayedAudioAppendQueue_.slice();
- this.logger_(`queuing delayed audio ${queue.length} appendBuffers`);
- this.delayedAudioAppendQueue_.length = 0;
- queue.forEach((que) => {
- this.appendBuffer.apply(this, que);
- });
- }
- }
- audioBuffered() {
- if (!inSourceBuffers$1(this.mediaSource, this.audioBuffer)) {
- return createTimeRanges$2();
- }
- return this.audioBuffer.buffered ? this.audioBuffer.buffered : createTimeRanges$2();
- }
- videoBuffered() {
- if (!inSourceBuffers$1(this.mediaSource, this.videoBuffer)) {
- return createTimeRanges$2();
- }
- return this.videoBuffer.buffered ? this.videoBuffer.buffered : createTimeRanges$2();
- }
- buffered() {
- const video = inSourceBuffers$1(this.mediaSource, this.videoBuffer) ? this.videoBuffer : null;
- const audio = inSourceBuffers$1(this.mediaSource, this.audioBuffer) ? this.audioBuffer : null;
- if (audio && !video) {
- return this.audioBuffered();
- }
- if (video && !audio) {
- return this.videoBuffered();
- }
- return bufferIntersection$1(this.audioBuffered(), this.videoBuffered());
- }
- setDuration(duration5, doneFn = noop$1) {
- pushQueue$1({
- type: "mediaSource",
- sourceUpdater: this,
- action: actions$1.duration(duration5),
- name: "duration",
- doneFn
- });
- }
- endOfStream(error = null, doneFn = noop$1) {
- if (typeof error !== "string") {
- error = void 0;
- }
- pushQueue$1({
- type: "mediaSource",
- sourceUpdater: this,
- action: actions$1.endOfStream(error),
- name: "endOfStream",
- doneFn
- });
- }
- removeAudio(start2, end, done = noop$1) {
- if (!this.audioBuffered().length || this.audioBuffered().end(0) === 0) {
- done();
- return;
- }
- pushQueue$1({
- type: "audio",
- sourceUpdater: this,
- action: actions$1.remove(start2, end),
- doneFn: done,
- name: "remove"
- });
- }
- removeVideo(start2, end, done = noop$1) {
- if (!this.videoBuffered().length || this.videoBuffered().end(0) === 0) {
- done();
- return;
- }
- pushQueue$1({
- type: "video",
- sourceUpdater: this,
- action: actions$1.remove(start2, end),
- doneFn: done,
- name: "remove"
- });
- }
- updating() {
- if (updating("audio", this) || updating("video", this)) {
- return true;
- }
- return false;
- }
- audioTimestampOffset(offset) {
- if (typeof offset !== "undefined" && this.audioBuffer && this.audioTimestampOffset_ !== offset) {
- pushQueue$1({
- type: "audio",
- sourceUpdater: this,
- action: actions$1.timestampOffset(offset),
- name: "timestampOffset"
- });
- this.audioTimestampOffset_ = offset;
- }
- return this.audioTimestampOffset_;
- }
- videoTimestampOffset(offset) {
- if (typeof offset !== "undefined" && this.videoBuffer && this.videoTimestampOffset !== offset) {
- pushQueue$1({
- type: "video",
- sourceUpdater: this,
- action: actions$1.timestampOffset(offset),
- name: "timestampOffset"
- });
- this.videoTimestampOffset_ = offset;
- }
- return this.videoTimestampOffset_;
- }
- audioQueueCallback(callback2) {
- if (!this.audioBuffer) {
- return;
- }
- pushQueue$1({
- type: "audio",
- sourceUpdater: this,
- action: actions$1.callback(callback2),
- name: "callback"
- });
- }
- videoQueueCallback(callback2) {
- if (!this.videoBuffer) {
- return;
- }
- pushQueue$1({
- type: "video",
- sourceUpdater: this,
- action: actions$1.callback(callback2),
- name: "callback"
- });
- }
- dispose() {
- this.trigger("dispose");
- bufferTypes$1.forEach((type2) => {
- this.abort(type2);
- if (this.canRemoveSourceBuffer()) {
- this.removeSourceBuffer(type2);
- } else {
- this[`${type2}QueueCallback`](() => cleanupBuffer$1(type2, this));
- }
- });
- this.videoAppendQueued_ = false;
- this.delayedAudioAppendQueue_.length = 0;
- if (this.sourceopenListener_) {
- this.mediaSource.removeEventListener("sourceopen", this.sourceopenListener_);
- }
- this.off();
- }
- }
- const uint8ToUtf8$1 = (uintArray) => decodeURIComponent(escape(String.fromCharCode.apply(null, uintArray)));
- const VTT_LINE_TERMINATORS$1 = new Uint8Array("\n\n".split("").map((char) => char.charCodeAt(0)));
- class NoVttJsError$1 extends Error {
- constructor() {
- super("Trying to parse received VTT cues, but there is no WebVTT. Make sure vtt.js is loaded.");
- }
- }
- class VTTSegmentLoader$1 extends SegmentLoader$1 {
- constructor(settings, options2 = {}) {
- super(settings, options2);
- this.mediaSource_ = null;
- this.subtitlesTrack_ = null;
- this.loaderType_ = "subtitle";
- this.featuresNativeTextTracks_ = settings.featuresNativeTextTracks;
- this.loadVttJs = settings.loadVttJs;
- this.shouldSaveSegmentTimingInfo_ = false;
- }
- createTransmuxer_() {
- return null;
- }
- buffered_() {
- if (!this.subtitlesTrack_ || !this.subtitlesTrack_.cues || !this.subtitlesTrack_.cues.length) {
- return createTimeRanges$2();
- }
- const cues = this.subtitlesTrack_.cues;
- const start2 = cues[0].startTime;
- const end = cues[cues.length - 1].startTime;
- return createTimeRanges$2([[start2, end]]);
- }
- initSegmentForMap(map, set4 = false) {
- if (!map) {
- return null;
- }
- const id = initSegmentId$1(map);
- let storedMap = this.initSegments_[id];
- if (set4 && !storedMap && map.bytes) {
- const combinedByteLength = VTT_LINE_TERMINATORS$1.byteLength + map.bytes.byteLength;
- const combinedSegment = new Uint8Array(combinedByteLength);
- combinedSegment.set(map.bytes);
- combinedSegment.set(VTT_LINE_TERMINATORS$1, map.bytes.byteLength);
- this.initSegments_[id] = storedMap = {
- resolvedUri: map.resolvedUri,
- byterange: map.byterange,
- bytes: combinedSegment
- };
- }
- return storedMap || map;
- }
- couldBeginLoading_() {
- return this.playlist_ && this.subtitlesTrack_ && !this.paused();
- }
- init_() {
- this.state = "READY";
- this.resetEverything();
- return this.monitorBuffer_();
- }
- track(track) {
- if (typeof track === "undefined") {
- return this.subtitlesTrack_;
- }
- this.subtitlesTrack_ = track;
- if (this.state === "INIT" && this.couldBeginLoading_()) {
- this.init_();
- }
- return this.subtitlesTrack_;
- }
- remove(start2, end) {
- removeCuesFromTrack$1(start2, end, this.subtitlesTrack_);
- }
- fillBuffer_() {
- const segmentInfo = this.chooseNextRequest_();
- if (!segmentInfo) {
- return;
- }
- if (this.syncController_.timestampOffsetForTimeline(segmentInfo.timeline) === null) {
- const checkTimestampOffset = () => {
- this.state = "READY";
- if (!this.paused()) {
- this.monitorBuffer_();
- }
- };
- this.syncController_.one("timestampoffset", checkTimestampOffset);
- this.state = "WAITING_ON_TIMELINE";
- return;
- }
- this.loadSegment_(segmentInfo);
- }
- timestampOffsetForSegment_() {
- return null;
- }
- chooseNextRequest_() {
- return this.skipEmptySegments_(super.chooseNextRequest_());
- }
- skipEmptySegments_(segmentInfo) {
- while (segmentInfo && segmentInfo.segment.empty) {
- if (segmentInfo.mediaIndex + 1 >= segmentInfo.playlist.segments.length) {
- segmentInfo = null;
- break;
- }
- segmentInfo = this.generateSegmentInfo_({
- playlist: segmentInfo.playlist,
- mediaIndex: segmentInfo.mediaIndex + 1,
- startOfSegment: segmentInfo.startOfSegment + segmentInfo.duration,
- isSyncRequest: segmentInfo.isSyncRequest
- });
- }
- return segmentInfo;
- }
- stopForError(error) {
- this.error(error);
- this.state = "READY";
- this.pause();
- this.trigger("error");
- }
- segmentRequestFinished_(error, simpleSegment, result) {
- if (!this.subtitlesTrack_) {
- this.state = "READY";
- return;
- }
- this.saveTransferStats_(simpleSegment.stats);
- if (!this.pendingSegment_) {
- this.state = "READY";
- this.mediaRequestsAborted += 1;
- return;
- }
- if (error) {
- if (error.code === REQUEST_ERRORS$1.TIMEOUT) {
- this.handleTimeout_();
- }
- if (error.code === REQUEST_ERRORS$1.ABORTED) {
- this.mediaRequestsAborted += 1;
- } else {
- this.mediaRequestsErrored += 1;
- }
- this.stopForError(error);
- return;
- }
- const segmentInfo = this.pendingSegment_;
- this.saveBandwidthRelatedStats_(segmentInfo.duration, simpleSegment.stats);
- if (simpleSegment.key) {
- this.segmentKey(simpleSegment.key, true);
- }
- this.state = "APPENDING";
- this.trigger("appending");
- const segment = segmentInfo.segment;
- if (segment.map) {
- segment.map.bytes = simpleSegment.map.bytes;
- }
- segmentInfo.bytes = simpleSegment.bytes;
- if (typeof window_1.WebVTT !== "function" && typeof this.loadVttJs === "function") {
- this.state = "WAITING_ON_VTTJS";
- this.loadVttJs().then(() => this.segmentRequestFinished_(error, simpleSegment, result), () => this.stopForError({
- message: "Error loading vtt.js"
- }));
- return;
- }
- segment.requested = true;
- try {
- this.parseVTTCues_(segmentInfo);
- } catch (e) {
- this.stopForError({
- message: e.message
- });
- return;
- }
- this.updateTimeMapping_(segmentInfo, this.syncController_.timelines[segmentInfo.timeline], this.playlist_);
- if (segmentInfo.cues.length) {
- segmentInfo.timingInfo = {
- start: segmentInfo.cues[0].startTime,
- end: segmentInfo.cues[segmentInfo.cues.length - 1].endTime
- };
- } else {
- segmentInfo.timingInfo = {
- start: segmentInfo.startOfSegment,
- end: segmentInfo.startOfSegment + segmentInfo.duration
- };
- }
- if (segmentInfo.isSyncRequest) {
- this.trigger("syncinfoupdate");
- this.pendingSegment_ = null;
- this.state = "READY";
- return;
- }
- segmentInfo.byteLength = segmentInfo.bytes.byteLength;
- this.mediaSecondsLoaded += segment.duration;
- segmentInfo.cues.forEach((cue) => {
- this.subtitlesTrack_.addCue(this.featuresNativeTextTracks_ ? new window_1.VTTCue(cue.startTime, cue.endTime, cue.text) : cue);
- });
- removeDuplicateCuesFromTrack$1(this.subtitlesTrack_);
- this.handleAppendsDone_();
- }
- handleData_() {
- }
- updateTimingInfoEnd_() {
- }
- parseVTTCues_(segmentInfo) {
- let decoder;
- let decodeBytesToString = false;
- if (typeof window_1.WebVTT !== "function") {
- throw new NoVttJsError$1();
- }
- if (typeof window_1.TextDecoder === "function") {
- decoder = new window_1.TextDecoder("utf8");
- } else {
- decoder = window_1.WebVTT.StringDecoder();
- decodeBytesToString = true;
- }
- const parser2 = new window_1.WebVTT.Parser(window_1, window_1.vttjs, decoder);
- segmentInfo.cues = [];
- segmentInfo.timestampmap = {
- MPEGTS: 0,
- LOCAL: 0
- };
- parser2.oncue = segmentInfo.cues.push.bind(segmentInfo.cues);
- parser2.ontimestampmap = (map) => {
- segmentInfo.timestampmap = map;
- };
- parser2.onparsingerror = (error) => {
- videojs$2.log.warn("Error encountered when parsing cues: " + error.message);
- };
- if (segmentInfo.segment.map) {
- let mapData = segmentInfo.segment.map.bytes;
- if (decodeBytesToString) {
- mapData = uint8ToUtf8$1(mapData);
- }
- parser2.parse(mapData);
- }
- let segmentData = segmentInfo.bytes;
- if (decodeBytesToString) {
- segmentData = uint8ToUtf8$1(segmentData);
- }
- parser2.parse(segmentData);
- parser2.flush();
- }
- updateTimeMapping_(segmentInfo, mappingObj, playlist) {
- const segment = segmentInfo.segment;
- if (!mappingObj) {
- return;
- }
- if (!segmentInfo.cues.length) {
- segment.empty = true;
- return;
- }
- const timestampmap = segmentInfo.timestampmap;
- const diff = timestampmap.MPEGTS / clock$1.ONE_SECOND_IN_TS - timestampmap.LOCAL + mappingObj.mapping;
- segmentInfo.cues.forEach((cue) => {
- cue.startTime += diff;
- cue.endTime += diff;
- });
- if (!playlist.syncInfo) {
- const firstStart = segmentInfo.cues[0].startTime;
- const lastStart = segmentInfo.cues[segmentInfo.cues.length - 1].startTime;
- playlist.syncInfo = {
- mediaSequence: playlist.mediaSequence + segmentInfo.mediaIndex,
- time: Math.min(firstStart, lastStart - segment.duration)
- };
- }
- }
- }
- const findAdCue$1 = function(track, mediaTime) {
- const cues = track.cues;
- for (let i2 = 0; i2 < cues.length; i2++) {
- const cue = cues[i2];
- if (mediaTime >= cue.adStartTime && mediaTime <= cue.adEndTime) {
- return cue;
- }
- }
- return null;
- };
- const updateAdCues$1 = function(media, track, offset = 0) {
- if (!media.segments) {
- return;
- }
- let mediaTime = offset;
- let cue;
- for (let i2 = 0; i2 < media.segments.length; i2++) {
- const segment = media.segments[i2];
- if (!cue) {
- cue = findAdCue$1(track, mediaTime + segment.duration / 2);
- }
- if (cue) {
- if ("cueIn" in segment) {
- cue.endTime = mediaTime;
- cue.adEndTime = mediaTime;
- mediaTime += segment.duration;
- cue = null;
- continue;
- }
- if (mediaTime < cue.endTime) {
- mediaTime += segment.duration;
- continue;
- }
- cue.endTime += segment.duration;
- } else {
- if ("cueOut" in segment) {
- cue = new window_1.VTTCue(mediaTime, mediaTime + segment.duration, segment.cueOut);
- cue.adStartTime = mediaTime;
- cue.adEndTime = mediaTime + parseFloat(segment.cueOut);
- track.addCue(cue);
- }
- if ("cueOutCont" in segment) {
- const [adOffset, adTotal] = segment.cueOutCont.split("/").map(parseFloat);
- cue = new window_1.VTTCue(mediaTime, mediaTime + segment.duration, "");
- cue.adStartTime = mediaTime - adOffset;
- cue.adEndTime = cue.adStartTime + adTotal;
- track.addCue(cue);
- }
- }
- mediaTime += segment.duration;
- }
- };
- const MAX_MEDIA_SEQUENCE_DIFF_FOR_SYNC$1 = 86400;
- const syncPointStrategies$1 = [
- {
- name: "VOD",
- run: (syncController, playlist, duration5, currentTimeline, currentTime) => {
- if (duration5 !== Infinity) {
- const syncPoint = {
- time: 0,
- segmentIndex: 0,
- partIndex: null
- };
- return syncPoint;
- }
- return null;
- }
- },
- {
- name: "ProgramDateTime",
- run: (syncController, playlist, duration5, currentTimeline, currentTime) => {
- if (!Object.keys(syncController.timelineToDatetimeMappings).length) {
- return null;
- }
- let syncPoint = null;
- let lastDistance = null;
- const partsAndSegments = getPartsAndSegments$1(playlist);
- currentTime = currentTime || 0;
- for (let i2 = 0; i2 < partsAndSegments.length; i2++) {
- const index2 = playlist.endList || currentTime === 0 ? i2 : partsAndSegments.length - (i2 + 1);
- const partAndSegment = partsAndSegments[index2];
- const segment = partAndSegment.segment;
- const datetimeMapping = syncController.timelineToDatetimeMappings[segment.timeline];
- if (!datetimeMapping || !segment.dateTimeObject) {
- continue;
- }
- const segmentTime = segment.dateTimeObject.getTime() / 1e3;
- let start2 = segmentTime + datetimeMapping;
- if (segment.parts && typeof partAndSegment.partIndex === "number") {
- for (let z = 0; z < partAndSegment.partIndex; z++) {
- start2 += segment.parts[z].duration;
- }
- }
- const distance2 = Math.abs(currentTime - start2);
- if (lastDistance !== null && (distance2 === 0 || lastDistance < distance2)) {
- break;
- }
- lastDistance = distance2;
- syncPoint = {
- time: start2,
- segmentIndex: partAndSegment.segmentIndex,
- partIndex: partAndSegment.partIndex
- };
- }
- return syncPoint;
- }
- },
- {
- name: "Segment",
- run: (syncController, playlist, duration5, currentTimeline, currentTime) => {
- let syncPoint = null;
- let lastDistance = null;
- currentTime = currentTime || 0;
- const partsAndSegments = getPartsAndSegments$1(playlist);
- for (let i2 = 0; i2 < partsAndSegments.length; i2++) {
- const index2 = playlist.endList || currentTime === 0 ? i2 : partsAndSegments.length - (i2 + 1);
- const partAndSegment = partsAndSegments[index2];
- const segment = partAndSegment.segment;
- const start2 = partAndSegment.part && partAndSegment.part.start || segment && segment.start;
- if (segment.timeline === currentTimeline && typeof start2 !== "undefined") {
- const distance2 = Math.abs(currentTime - start2);
- if (lastDistance !== null && lastDistance < distance2) {
- break;
- }
- if (!syncPoint || lastDistance === null || lastDistance >= distance2) {
- lastDistance = distance2;
- syncPoint = {
- time: start2,
- segmentIndex: partAndSegment.segmentIndex,
- partIndex: partAndSegment.partIndex
- };
- }
- }
- }
- return syncPoint;
- }
- },
- {
- name: "Discontinuity",
- run: (syncController, playlist, duration5, currentTimeline, currentTime) => {
- let syncPoint = null;
- currentTime = currentTime || 0;
- if (playlist.discontinuityStarts && playlist.discontinuityStarts.length) {
- let lastDistance = null;
- for (let i2 = 0; i2 < playlist.discontinuityStarts.length; i2++) {
- const segmentIndex = playlist.discontinuityStarts[i2];
- const discontinuity = playlist.discontinuitySequence + i2 + 1;
- const discontinuitySync = syncController.discontinuities[discontinuity];
- if (discontinuitySync) {
- const distance2 = Math.abs(currentTime - discontinuitySync.time);
- if (lastDistance !== null && lastDistance < distance2) {
- break;
- }
- if (!syncPoint || lastDistance === null || lastDistance >= distance2) {
- lastDistance = distance2;
- syncPoint = {
- time: discontinuitySync.time,
- segmentIndex,
- partIndex: null
- };
- }
- }
- }
- }
- return syncPoint;
- }
- },
- {
- name: "Playlist",
- run: (syncController, playlist, duration5, currentTimeline, currentTime) => {
- if (playlist.syncInfo) {
- const syncPoint = {
- time: playlist.syncInfo.time,
- segmentIndex: playlist.syncInfo.mediaSequence - playlist.mediaSequence,
- partIndex: null
- };
- return syncPoint;
- }
- return null;
- }
- }
- ];
- class SyncController$1 extends videojs$2.EventTarget {
- constructor(options2 = {}) {
- super();
- this.timelines = [];
- this.discontinuities = [];
- this.timelineToDatetimeMappings = {};
- this.logger_ = logger$1("SyncController");
- }
- getSyncPoint(playlist, duration5, currentTimeline, currentTime) {
- const syncPoints = this.runStrategies_(playlist, duration5, currentTimeline, currentTime);
- if (!syncPoints.length) {
- return null;
- }
- return this.selectSyncPoint_(syncPoints, {
- key: "time",
- value: currentTime
- });
- }
- getExpiredTime(playlist, duration5) {
- if (!playlist || !playlist.segments) {
- return null;
- }
- const syncPoints = this.runStrategies_(playlist, duration5, playlist.discontinuitySequence, 0);
- if (!syncPoints.length) {
- return null;
- }
- const syncPoint = this.selectSyncPoint_(syncPoints, {
- key: "segmentIndex",
- value: 0
- });
- if (syncPoint.segmentIndex > 0) {
- syncPoint.time *= -1;
- }
- return Math.abs(syncPoint.time + sumDurations$1({
- defaultDuration: playlist.targetDuration,
- durationList: playlist.segments,
- startIndex: syncPoint.segmentIndex,
- endIndex: 0
- }));
- }
- runStrategies_(playlist, duration5, currentTimeline, currentTime) {
- const syncPoints = [];
- for (let i2 = 0; i2 < syncPointStrategies$1.length; i2++) {
- const strategy = syncPointStrategies$1[i2];
- const syncPoint = strategy.run(this, playlist, duration5, currentTimeline, currentTime);
- if (syncPoint) {
- syncPoint.strategy = strategy.name;
- syncPoints.push({
- strategy: strategy.name,
- syncPoint
- });
- }
- }
- return syncPoints;
- }
- selectSyncPoint_(syncPoints, target) {
- let bestSyncPoint = syncPoints[0].syncPoint;
- let bestDistance = Math.abs(syncPoints[0].syncPoint[target.key] - target.value);
- let bestStrategy = syncPoints[0].strategy;
- for (let i2 = 1; i2 < syncPoints.length; i2++) {
- const newDistance = Math.abs(syncPoints[i2].syncPoint[target.key] - target.value);
- if (newDistance < bestDistance) {
- bestDistance = newDistance;
- bestSyncPoint = syncPoints[i2].syncPoint;
- bestStrategy = syncPoints[i2].strategy;
- }
- }
- this.logger_(`syncPoint for [${target.key}: ${target.value}] chosen with strategy [${bestStrategy}]: [time:${bestSyncPoint.time}, segmentIndex:${bestSyncPoint.segmentIndex}` + (typeof bestSyncPoint.partIndex === "number" ? `,partIndex:${bestSyncPoint.partIndex}` : "") + "]");
- return bestSyncPoint;
- }
- saveExpiredSegmentInfo(oldPlaylist, newPlaylist) {
- const mediaSequenceDiff = newPlaylist.mediaSequence - oldPlaylist.mediaSequence;
- if (mediaSequenceDiff > MAX_MEDIA_SEQUENCE_DIFF_FOR_SYNC$1) {
- videojs$2.log.warn(`Not saving expired segment info. Media sequence gap ${mediaSequenceDiff} is too large.`);
- return;
- }
- for (let i2 = mediaSequenceDiff - 1; i2 >= 0; i2--) {
- const lastRemovedSegment = oldPlaylist.segments[i2];
- if (lastRemovedSegment && typeof lastRemovedSegment.start !== "undefined") {
- newPlaylist.syncInfo = {
- mediaSequence: oldPlaylist.mediaSequence + i2,
- time: lastRemovedSegment.start
- };
- this.logger_(`playlist refresh sync: [time:${newPlaylist.syncInfo.time}, mediaSequence: ${newPlaylist.syncInfo.mediaSequence}]`);
- this.trigger("syncinfoupdate");
- break;
- }
- }
- }
- setDateTimeMappingForStart(playlist) {
- this.timelineToDatetimeMappings = {};
- if (playlist.segments && playlist.segments.length && playlist.segments[0].dateTimeObject) {
- const firstSegment = playlist.segments[0];
- const playlistTimestamp = firstSegment.dateTimeObject.getTime() / 1e3;
- this.timelineToDatetimeMappings[firstSegment.timeline] = -playlistTimestamp;
- }
- }
- saveSegmentTimingInfo({
- segmentInfo,
- shouldSaveTimelineMapping
- }) {
- const didCalculateSegmentTimeMapping = this.calculateSegmentTimeMapping_(segmentInfo, segmentInfo.timingInfo, shouldSaveTimelineMapping);
- const segment = segmentInfo.segment;
- if (didCalculateSegmentTimeMapping) {
- this.saveDiscontinuitySyncInfo_(segmentInfo);
- if (!segmentInfo.playlist.syncInfo) {
- segmentInfo.playlist.syncInfo = {
- mediaSequence: segmentInfo.playlist.mediaSequence + segmentInfo.mediaIndex,
- time: segment.start
- };
- }
- }
- const dateTime = segment.dateTimeObject;
- if (segment.discontinuity && shouldSaveTimelineMapping && dateTime) {
- this.timelineToDatetimeMappings[segment.timeline] = -(dateTime.getTime() / 1e3);
- }
- }
- timestampOffsetForTimeline(timeline) {
- if (typeof this.timelines[timeline] === "undefined") {
- return null;
- }
- return this.timelines[timeline].time;
- }
- mappingForTimeline(timeline) {
- if (typeof this.timelines[timeline] === "undefined") {
- return null;
- }
- return this.timelines[timeline].mapping;
- }
- calculateSegmentTimeMapping_(segmentInfo, timingInfo, shouldSaveTimelineMapping) {
- const segment = segmentInfo.segment;
- const part = segmentInfo.part;
- let mappingObj = this.timelines[segmentInfo.timeline];
- let start2;
- let end;
- if (typeof segmentInfo.timestampOffset === "number") {
- mappingObj = {
- time: segmentInfo.startOfSegment,
- mapping: segmentInfo.startOfSegment - timingInfo.start
- };
- if (shouldSaveTimelineMapping) {
- this.timelines[segmentInfo.timeline] = mappingObj;
- this.trigger("timestampoffset");
- this.logger_(`time mapping for timeline ${segmentInfo.timeline}: [time: ${mappingObj.time}] [mapping: ${mappingObj.mapping}]`);
- }
- start2 = segmentInfo.startOfSegment;
- end = timingInfo.end + mappingObj.mapping;
- } else if (mappingObj) {
- start2 = timingInfo.start + mappingObj.mapping;
- end = timingInfo.end + mappingObj.mapping;
- } else {
- return false;
- }
- if (part) {
- part.start = start2;
- part.end = end;
- }
- if (!segment.start || start2 < segment.start) {
- segment.start = start2;
- }
- segment.end = end;
- return true;
- }
- saveDiscontinuitySyncInfo_(segmentInfo) {
- const playlist = segmentInfo.playlist;
- const segment = segmentInfo.segment;
- if (segment.discontinuity) {
- this.discontinuities[segment.timeline] = {
- time: segment.start,
- accuracy: 0
- };
- } else if (playlist.discontinuityStarts && playlist.discontinuityStarts.length) {
- for (let i2 = 0; i2 < playlist.discontinuityStarts.length; i2++) {
- const segmentIndex = playlist.discontinuityStarts[i2];
- const discontinuity = playlist.discontinuitySequence + i2 + 1;
- const mediaIndexDiff = segmentIndex - segmentInfo.mediaIndex;
- const accuracy = Math.abs(mediaIndexDiff);
- if (!this.discontinuities[discontinuity] || this.discontinuities[discontinuity].accuracy > accuracy) {
- let time;
- if (mediaIndexDiff < 0) {
- time = segment.start - sumDurations$1({
- defaultDuration: playlist.targetDuration,
- durationList: playlist.segments,
- startIndex: segmentInfo.mediaIndex,
- endIndex: segmentIndex
- });
- } else {
- time = segment.end + sumDurations$1({
- defaultDuration: playlist.targetDuration,
- durationList: playlist.segments,
- startIndex: segmentInfo.mediaIndex + 1,
- endIndex: segmentIndex
- });
- }
- this.discontinuities[discontinuity] = {
- time,
- accuracy
- };
- }
- }
- }
- }
- dispose() {
- this.trigger("dispose");
- this.off();
- }
- }
- class TimelineChangeController$1 extends videojs$2.EventTarget {
- constructor() {
- super();
- this.pendingTimelineChanges_ = {};
- this.lastTimelineChanges_ = {};
- }
- clearPendingTimelineChange(type2) {
- this.pendingTimelineChanges_[type2] = null;
- this.trigger("pendingtimelinechange");
- }
- pendingTimelineChange({
- type: type2,
- from: from3,
- to
- }) {
- if (typeof from3 === "number" && typeof to === "number") {
- this.pendingTimelineChanges_[type2] = {
- type: type2,
- from: from3,
- to
- };
- this.trigger("pendingtimelinechange");
- }
- return this.pendingTimelineChanges_[type2];
- }
- lastTimelineChange({
- type: type2,
- from: from3,
- to
- }) {
- if (typeof from3 === "number" && typeof to === "number") {
- this.lastTimelineChanges_[type2] = {
- type: type2,
- from: from3,
- to
- };
- delete this.pendingTimelineChanges_[type2];
- this.trigger("timelinechange");
- }
- return this.lastTimelineChanges_[type2];
- }
- dispose() {
- this.trigger("dispose");
- this.pendingTimelineChanges_ = {};
- this.lastTimelineChanges_ = {};
- this.off();
- }
- }
- const workerCode$2 = transform$1(getWorkerString$1(function() {
- var Stream2 = /* @__PURE__ */ function() {
- function Stream3() {
- this.listeners = {};
- }
- var _proto = Stream3.prototype;
- _proto.on = function on3(type2, listener) {
- if (!this.listeners[type2]) {
- this.listeners[type2] = [];
- }
- this.listeners[type2].push(listener);
- };
- _proto.off = function off2(type2, listener) {
- if (!this.listeners[type2]) {
- return false;
- }
- var index2 = this.listeners[type2].indexOf(listener);
- this.listeners[type2] = this.listeners[type2].slice(0);
- this.listeners[type2].splice(index2, 1);
- return index2 > -1;
- };
- _proto.trigger = function trigger2(type2) {
- var callbacks = this.listeners[type2];
- if (!callbacks) {
- return;
- }
- if (arguments.length === 2) {
- var length = callbacks.length;
- for (var i2 = 0; i2 < length; ++i2) {
- callbacks[i2].call(this, arguments[1]);
- }
- } else {
- var args = Array.prototype.slice.call(arguments, 1);
- var _length = callbacks.length;
- for (var _i = 0; _i < _length; ++_i) {
- callbacks[_i].apply(this, args);
- }
- }
- };
- _proto.dispose = function dispose() {
- this.listeners = {};
- };
- _proto.pipe = function pipe(destination2) {
- this.on("data", function(data) {
- destination2.push(data);
- });
- };
- return Stream3;
- }();
- /*! @name pkcs7 @version 1.0.4 @license Apache-2.0 */
- function unpad(padded) {
- return padded.subarray(0, padded.byteLength - padded[padded.byteLength - 1]);
- }
- /*! @name aes-decrypter @version 4.0.1 @license Apache-2.0 */
- const precompute = function() {
- const tables = [[[], [], [], [], []], [[], [], [], [], []]];
- const encTable = tables[0];
- const decTable = tables[1];
- const sbox = encTable[4];
- const sboxInv = decTable[4];
- let i2;
- let x;
- let xInv;
- const d2 = [];
- const th = [];
- let x2;
- let x4;
- let x8;
- let s;
- let tEnc;
- let tDec;
- for (i2 = 0; i2 < 256; i2++) {
- th[(d2[i2] = i2 << 1 ^ (i2 >> 7) * 283) ^ i2] = i2;
- }
- for (x = xInv = 0; !sbox[x]; x ^= x2 || 1, xInv = th[xInv] || 1) {
- s = xInv ^ xInv << 1 ^ xInv << 2 ^ xInv << 3 ^ xInv << 4;
- s = s >> 8 ^ s & 255 ^ 99;
- sbox[x] = s;
- sboxInv[s] = x;
- x8 = d2[x4 = d2[x2 = d2[x]]];
- tDec = x8 * 16843009 ^ x4 * 65537 ^ x2 * 257 ^ x * 16843008;
- tEnc = d2[s] * 257 ^ s * 16843008;
- for (i2 = 0; i2 < 4; i2++) {
- encTable[i2][x] = tEnc = tEnc << 24 ^ tEnc >>> 8;
- decTable[i2][s] = tDec = tDec << 24 ^ tDec >>> 8;
- }
- }
- for (i2 = 0; i2 < 5; i2++) {
- encTable[i2] = encTable[i2].slice(0);
- decTable[i2] = decTable[i2].slice(0);
- }
- return tables;
- };
- let aesTables = null;
- class AES {
- constructor(key) {
- if (!aesTables) {
- aesTables = precompute();
- }
- this._tables = [[aesTables[0][0].slice(), aesTables[0][1].slice(), aesTables[0][2].slice(), aesTables[0][3].slice(), aesTables[0][4].slice()], [aesTables[1][0].slice(), aesTables[1][1].slice(), aesTables[1][2].slice(), aesTables[1][3].slice(), aesTables[1][4].slice()]];
- let i2;
- let j;
- let tmp;
- const sbox = this._tables[0][4];
- const decTable = this._tables[1];
- const keyLen = key.length;
- let rcon = 1;
- if (keyLen !== 4 && keyLen !== 6 && keyLen !== 8) {
- throw new Error("Invalid aes key size");
- }
- const encKey = key.slice(0);
- const decKey = [];
- this._key = [encKey, decKey];
- for (i2 = keyLen; i2 < 4 * keyLen + 28; i2++) {
- tmp = encKey[i2 - 1];
- if (i2 % keyLen === 0 || keyLen === 8 && i2 % keyLen === 4) {
- tmp = sbox[tmp >>> 24] << 24 ^ sbox[tmp >> 16 & 255] << 16 ^ sbox[tmp >> 8 & 255] << 8 ^ sbox[tmp & 255];
- if (i2 % keyLen === 0) {
- tmp = tmp << 8 ^ tmp >>> 24 ^ rcon << 24;
- rcon = rcon << 1 ^ (rcon >> 7) * 283;
- }
- }
- encKey[i2] = encKey[i2 - keyLen] ^ tmp;
- }
- for (j = 0; i2; j++, i2--) {
- tmp = encKey[j & 3 ? i2 : i2 - 4];
- if (i2 <= 4 || j < 4) {
- decKey[j] = tmp;
- } else {
- decKey[j] = decTable[0][sbox[tmp >>> 24]] ^ decTable[1][sbox[tmp >> 16 & 255]] ^ decTable[2][sbox[tmp >> 8 & 255]] ^ decTable[3][sbox[tmp & 255]];
- }
- }
- }
- decrypt(encrypted0, encrypted1, encrypted2, encrypted3, out, offset) {
- const key = this._key[1];
- let a = encrypted0 ^ key[0];
- let b = encrypted3 ^ key[1];
- let c = encrypted2 ^ key[2];
- let d2 = encrypted1 ^ key[3];
- let a2;
- let b2;
- let c2;
- const nInnerRounds = key.length / 4 - 2;
- let i2;
- let kIndex = 4;
- const table = this._tables[1];
- const table0 = table[0];
- const table1 = table[1];
- const table2 = table[2];
- const table3 = table[3];
- const sbox = table[4];
- for (i2 = 0; i2 < nInnerRounds; i2++) {
- a2 = table0[a >>> 24] ^ table1[b >> 16 & 255] ^ table2[c >> 8 & 255] ^ table3[d2 & 255] ^ key[kIndex];
- b2 = table0[b >>> 24] ^ table1[c >> 16 & 255] ^ table2[d2 >> 8 & 255] ^ table3[a & 255] ^ key[kIndex + 1];
- c2 = table0[c >>> 24] ^ table1[d2 >> 16 & 255] ^ table2[a >> 8 & 255] ^ table3[b & 255] ^ key[kIndex + 2];
- d2 = table0[d2 >>> 24] ^ table1[a >> 16 & 255] ^ table2[b >> 8 & 255] ^ table3[c & 255] ^ key[kIndex + 3];
- kIndex += 4;
- a = a2;
- b = b2;
- c = c2;
- }
- for (i2 = 0; i2 < 4; i2++) {
- out[(3 & -i2) + offset] = sbox[a >>> 24] << 24 ^ sbox[b >> 16 & 255] << 16 ^ sbox[c >> 8 & 255] << 8 ^ sbox[d2 & 255] ^ key[kIndex++];
- a2 = a;
- a = b;
- b = c;
- c = d2;
- d2 = a2;
- }
- }
- }
- class AsyncStream extends Stream2 {
- constructor() {
- super(Stream2);
- this.jobs = [];
- this.delay = 1;
- this.timeout_ = null;
- }
- processJob_() {
- this.jobs.shift()();
- if (this.jobs.length) {
- this.timeout_ = setTimeout(this.processJob_.bind(this), this.delay);
- } else {
- this.timeout_ = null;
- }
- }
- push(job) {
- this.jobs.push(job);
- if (!this.timeout_) {
- this.timeout_ = setTimeout(this.processJob_.bind(this), this.delay);
- }
- }
- }
- const ntoh = function(word) {
- return word << 24 | (word & 65280) << 8 | (word & 16711680) >> 8 | word >>> 24;
- };
- const decrypt3 = function(encrypted, key, initVector) {
- const encrypted32 = new Int32Array(encrypted.buffer, encrypted.byteOffset, encrypted.byteLength >> 2);
- const decipher = new AES(Array.prototype.slice.call(key));
- const decrypted = new Uint8Array(encrypted.byteLength);
- const decrypted32 = new Int32Array(decrypted.buffer);
- let init0;
- let init1;
- let init2;
- let init3;
- let encrypted0;
- let encrypted1;
- let encrypted2;
- let encrypted3;
- let wordIx;
- init0 = initVector[0];
- init1 = initVector[1];
- init2 = initVector[2];
- init3 = initVector[3];
- for (wordIx = 0; wordIx < encrypted32.length; wordIx += 4) {
- encrypted0 = ntoh(encrypted32[wordIx]);
- encrypted1 = ntoh(encrypted32[wordIx + 1]);
- encrypted2 = ntoh(encrypted32[wordIx + 2]);
- encrypted3 = ntoh(encrypted32[wordIx + 3]);
- decipher.decrypt(encrypted0, encrypted1, encrypted2, encrypted3, decrypted32, wordIx);
- decrypted32[wordIx] = ntoh(decrypted32[wordIx] ^ init0);
- decrypted32[wordIx + 1] = ntoh(decrypted32[wordIx + 1] ^ init1);
- decrypted32[wordIx + 2] = ntoh(decrypted32[wordIx + 2] ^ init2);
- decrypted32[wordIx + 3] = ntoh(decrypted32[wordIx + 3] ^ init3);
- init0 = encrypted0;
- init1 = encrypted1;
- init2 = encrypted2;
- init3 = encrypted3;
- }
- return decrypted;
- };
- class Decrypter2 {
- constructor(encrypted, key, initVector, done) {
- const step = Decrypter2.STEP;
- const encrypted32 = new Int32Array(encrypted.buffer);
- const decrypted = new Uint8Array(encrypted.byteLength);
- let i2 = 0;
- this.asyncStream_ = new AsyncStream();
- this.asyncStream_.push(this.decryptChunk_(encrypted32.subarray(i2, i2 + step), key, initVector, decrypted));
- for (i2 = step; i2 < encrypted32.length; i2 += step) {
- initVector = new Uint32Array([ntoh(encrypted32[i2 - 4]), ntoh(encrypted32[i2 - 3]), ntoh(encrypted32[i2 - 2]), ntoh(encrypted32[i2 - 1])]);
- this.asyncStream_.push(this.decryptChunk_(encrypted32.subarray(i2, i2 + step), key, initVector, decrypted));
- }
- this.asyncStream_.push(function() {
- done(null, unpad(decrypted));
- });
- }
- static get STEP() {
- return 32e3;
- }
- decryptChunk_(encrypted, key, initVector, decrypted) {
- return function() {
- const bytes = decrypt3(encrypted, key, initVector);
- decrypted.set(bytes, encrypted.byteOffset);
- };
- }
- }
- var commonjsGlobal2 = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
- var win2;
- if (typeof window !== "undefined") {
- win2 = window;
- } else if (typeof commonjsGlobal2 !== "undefined") {
- win2 = commonjsGlobal2;
- } else if (typeof self !== "undefined") {
- win2 = self;
- } else {
- win2 = {};
- }
- var window_12 = win2;
- var isArrayBufferView4 = function isArrayBufferView5(obj) {
- if (ArrayBuffer.isView === "function") {
- return ArrayBuffer.isView(obj);
- }
- return obj && obj.buffer instanceof ArrayBuffer;
- };
- var BigInt2 = window_12.BigInt || Number;
- [BigInt2("0x1"), BigInt2("0x100"), BigInt2("0x10000"), BigInt2("0x1000000"), BigInt2("0x100000000"), BigInt2("0x10000000000"), BigInt2("0x1000000000000"), BigInt2("0x100000000000000"), BigInt2("0x10000000000000000")];
- (function() {
- var a = new Uint16Array([65484]);
- var b = new Uint8Array(a.buffer, a.byteOffset, a.byteLength);
- if (b[0] === 255) {
- return "big";
- }
- if (b[0] === 204) {
- return "little";
- }
- return "unknown";
- })();
- const createTransferableMessage3 = function(message) {
- const transferable = {};
- Object.keys(message).forEach((key) => {
- const value = message[key];
- if (isArrayBufferView4(value)) {
- transferable[key] = {
- bytes: value.buffer,
- byteOffset: value.byteOffset,
- byteLength: value.byteLength
- };
- } else {
- transferable[key] = value;
- }
- });
- return transferable;
- };
- self.onmessage = function(event2) {
- const data = event2.data;
- const encrypted = new Uint8Array(data.encrypted.bytes, data.encrypted.byteOffset, data.encrypted.byteLength);
- const key = new Uint32Array(data.key.bytes, data.key.byteOffset, data.key.byteLength / 4);
- const iv = new Uint32Array(data.iv.bytes, data.iv.byteOffset, data.iv.byteLength / 4);
- new Decrypter2(encrypted, key, iv, function(err, bytes) {
- self.postMessage(createTransferableMessage3({
- source: data.source,
- decrypted: bytes
- }), [bytes.buffer]);
- });
- };
- }));
- var Decrypter$1 = factory$1(workerCode$2);
- const audioTrackKind_$1 = (properties) => {
- let kind = properties.default ? "main" : "alternative";
- if (properties.characteristics && properties.characteristics.indexOf("public.accessibility.describes-video") >= 0) {
- kind = "main-desc";
- }
- return kind;
- };
- const stopLoaders$1 = (segmentLoader, mediaType) => {
- segmentLoader.abort();
- segmentLoader.pause();
- if (mediaType && mediaType.activePlaylistLoader) {
- mediaType.activePlaylistLoader.pause();
- mediaType.activePlaylistLoader = null;
- }
- };
- const startLoaders$1 = (playlistLoader, mediaType) => {
- mediaType.activePlaylistLoader = playlistLoader;
- playlistLoader.load();
- };
- const onGroupChanged$1 = (type2, settings) => () => {
- const {
- segmentLoaders: {
- [type2]: segmentLoader,
- main: mainSegmentLoader
- },
- mediaTypes: {
- [type2]: mediaType
- }
- } = settings;
- const activeTrack2 = mediaType.activeTrack();
- const activeGroup3 = mediaType.getActiveGroup();
- const previousActiveLoader = mediaType.activePlaylistLoader;
- const lastGroup = mediaType.lastGroup_;
- if (activeGroup3 && lastGroup && activeGroup3.id === lastGroup.id) {
- return;
- }
- mediaType.lastGroup_ = activeGroup3;
- mediaType.lastTrack_ = activeTrack2;
- stopLoaders$1(segmentLoader, mediaType);
- if (!activeGroup3 || activeGroup3.isMainPlaylist) {
- return;
- }
- if (!activeGroup3.playlistLoader) {
- if (previousActiveLoader) {
- mainSegmentLoader.resetEverything();
- }
- return;
- }
- segmentLoader.resyncLoader();
- startLoaders$1(activeGroup3.playlistLoader, mediaType);
- };
- const onGroupChanging$1 = (type2, settings) => () => {
- const {
- segmentLoaders: {
- [type2]: segmentLoader
- },
- mediaTypes: {
- [type2]: mediaType
- }
- } = settings;
- mediaType.lastGroup_ = null;
- segmentLoader.abort();
- segmentLoader.pause();
- };
- const onTrackChanged$1 = (type2, settings) => () => {
- const {
- mainPlaylistLoader,
- segmentLoaders: {
- [type2]: segmentLoader,
- main: mainSegmentLoader
- },
- mediaTypes: {
- [type2]: mediaType
- }
- } = settings;
- const activeTrack2 = mediaType.activeTrack();
- const activeGroup3 = mediaType.getActiveGroup();
- const previousActiveLoader = mediaType.activePlaylistLoader;
- const lastTrack = mediaType.lastTrack_;
- if (lastTrack && activeTrack2 && lastTrack.id === activeTrack2.id) {
- return;
- }
- mediaType.lastGroup_ = activeGroup3;
- mediaType.lastTrack_ = activeTrack2;
- stopLoaders$1(segmentLoader, mediaType);
- if (!activeGroup3) {
- return;
- }
- if (activeGroup3.isMainPlaylist) {
- if (!activeTrack2 || !lastTrack || activeTrack2.id === lastTrack.id) {
- return;
- }
- const pc = settings.vhs.playlistController_;
- const newPlaylist = pc.selectPlaylist();
- if (pc.media() === newPlaylist) {
- return;
- }
- mediaType.logger_(`track change. Switching main audio from ${lastTrack.id} to ${activeTrack2.id}`);
- mainPlaylistLoader.pause();
- mainSegmentLoader.resetEverything();
- pc.fastQualityChange_(newPlaylist);
- return;
- }
- if (type2 === "AUDIO") {
- if (!activeGroup3.playlistLoader) {
- mainSegmentLoader.setAudio(true);
- mainSegmentLoader.resetEverything();
- return;
- }
- segmentLoader.setAudio(true);
- mainSegmentLoader.setAudio(false);
- }
- if (previousActiveLoader === activeGroup3.playlistLoader) {
- startLoaders$1(activeGroup3.playlistLoader, mediaType);
- return;
- }
- if (segmentLoader.track) {
- segmentLoader.track(activeTrack2);
- }
- segmentLoader.resetEverything();
- startLoaders$1(activeGroup3.playlistLoader, mediaType);
- };
- const onError$1 = {
- AUDIO: (type2, settings) => () => {
- const {
- segmentLoaders: {
- [type2]: segmentLoader
- },
- mediaTypes: {
- [type2]: mediaType
- },
- excludePlaylist
- } = settings;
- stopLoaders$1(segmentLoader, mediaType);
- const activeTrack2 = mediaType.activeTrack();
- const activeGroup3 = mediaType.activeGroup();
- const id = (activeGroup3.filter((group) => group.default)[0] || activeGroup3[0]).id;
- const defaultTrack = mediaType.tracks[id];
- if (activeTrack2 === defaultTrack) {
- excludePlaylist({
- error: {
- message: "Problem encountered loading the default audio track."
- }
- });
- return;
- }
- videojs$2.log.warn("Problem encountered loading the alternate audio track.Switching back to default.");
- for (const trackId in mediaType.tracks) {
- mediaType.tracks[trackId].enabled = mediaType.tracks[trackId] === defaultTrack;
- }
- mediaType.onTrackChanged();
- },
- SUBTITLES: (type2, settings) => () => {
- const {
- segmentLoaders: {
- [type2]: segmentLoader
- },
- mediaTypes: {
- [type2]: mediaType
- }
- } = settings;
- videojs$2.log.warn("Problem encountered loading the subtitle track.Disabling subtitle track.");
- stopLoaders$1(segmentLoader, mediaType);
- const track = mediaType.activeTrack();
- if (track) {
- track.mode = "disabled";
- }
- mediaType.onTrackChanged();
- }
- };
- const setupListeners$1 = {
- AUDIO: (type2, playlistLoader, settings) => {
- if (!playlistLoader) {
- return;
- }
- const {
- tech,
- requestOptions,
- segmentLoaders: {
- [type2]: segmentLoader
- }
- } = settings;
- playlistLoader.on("loadedmetadata", () => {
- const media = playlistLoader.media();
- segmentLoader.playlist(media, requestOptions);
- if (!tech.paused() || media.endList && tech.preload() !== "none") {
- segmentLoader.load();
- }
- });
- playlistLoader.on("loadedplaylist", () => {
- segmentLoader.playlist(playlistLoader.media(), requestOptions);
- if (!tech.paused()) {
- segmentLoader.load();
- }
- });
- playlistLoader.on("error", onError$1[type2](type2, settings));
- },
- SUBTITLES: (type2, playlistLoader, settings) => {
- const {
- tech,
- requestOptions,
- segmentLoaders: {
- [type2]: segmentLoader
- },
- mediaTypes: {
- [type2]: mediaType
- }
- } = settings;
- playlistLoader.on("loadedmetadata", () => {
- const media = playlistLoader.media();
- segmentLoader.playlist(media, requestOptions);
- segmentLoader.track(mediaType.activeTrack());
- if (!tech.paused() || media.endList && tech.preload() !== "none") {
- segmentLoader.load();
- }
- });
- playlistLoader.on("loadedplaylist", () => {
- segmentLoader.playlist(playlistLoader.media(), requestOptions);
- if (!tech.paused()) {
- segmentLoader.load();
- }
- });
- playlistLoader.on("error", onError$1[type2](type2, settings));
- }
- };
- const initialize$1 = {
- "AUDIO": (type2, settings) => {
- const {
- vhs,
- sourceType,
- segmentLoaders: {
- [type2]: segmentLoader
- },
- requestOptions,
- main: {
- mediaGroups
- },
- mediaTypes: {
- [type2]: {
- groups,
- tracks,
- logger_
- }
- },
- mainPlaylistLoader
- } = settings;
- const audioOnlyMain = isAudioOnly$1(mainPlaylistLoader.main);
- if (!mediaGroups[type2] || Object.keys(mediaGroups[type2]).length === 0) {
- mediaGroups[type2] = {
- main: {
- default: {
- default: true
- }
- }
- };
- if (audioOnlyMain) {
- mediaGroups[type2].main.default.playlists = mainPlaylistLoader.main.playlists;
- }
- }
- for (const groupId in mediaGroups[type2]) {
- if (!groups[groupId]) {
- groups[groupId] = [];
- }
- for (const variantLabel in mediaGroups[type2][groupId]) {
- let properties = mediaGroups[type2][groupId][variantLabel];
- let playlistLoader;
- if (audioOnlyMain) {
- logger_(`AUDIO group '${groupId}' label '${variantLabel}' is a main playlist`);
- properties.isMainPlaylist = true;
- playlistLoader = null;
- } else if (sourceType === "vhs-json" && properties.playlists) {
- playlistLoader = new PlaylistLoader$1(properties.playlists[0], vhs, requestOptions);
- } else if (properties.resolvedUri) {
- playlistLoader = new PlaylistLoader$1(properties.resolvedUri, vhs, requestOptions);
- } else if (properties.playlists && sourceType === "dash") {
- playlistLoader = new DashPlaylistLoader$1(properties.playlists[0], vhs, requestOptions, mainPlaylistLoader);
- } else {
- playlistLoader = null;
- }
- properties = merge$2({
- id: variantLabel,
- playlistLoader
- }, properties);
- setupListeners$1[type2](type2, properties.playlistLoader, settings);
- groups[groupId].push(properties);
- if (typeof tracks[variantLabel] === "undefined") {
- const track = new videojs$2.AudioTrack({
- id: variantLabel,
- kind: audioTrackKind_$1(properties),
- enabled: false,
- language: properties.language,
- default: properties.default,
- label: variantLabel
- });
- tracks[variantLabel] = track;
- }
- }
- }
- segmentLoader.on("error", onError$1[type2](type2, settings));
- },
- "SUBTITLES": (type2, settings) => {
- const {
- tech,
- vhs,
- sourceType,
- segmentLoaders: {
- [type2]: segmentLoader
- },
- requestOptions,
- main: {
- mediaGroups
- },
- mediaTypes: {
- [type2]: {
- groups,
- tracks
- }
- },
- mainPlaylistLoader
- } = settings;
- for (const groupId in mediaGroups[type2]) {
- if (!groups[groupId]) {
- groups[groupId] = [];
- }
- for (const variantLabel in mediaGroups[type2][groupId]) {
- if (mediaGroups[type2][groupId][variantLabel].forced) {
- continue;
- }
- let properties = mediaGroups[type2][groupId][variantLabel];
- let playlistLoader;
- if (sourceType === "hls") {
- playlistLoader = new PlaylistLoader$1(properties.resolvedUri, vhs, requestOptions);
- } else if (sourceType === "dash") {
- const playlists = properties.playlists.filter((p) => p.excludeUntil !== Infinity);
- if (!playlists.length) {
- return;
- }
- playlistLoader = new DashPlaylistLoader$1(properties.playlists[0], vhs, requestOptions, mainPlaylistLoader);
- } else if (sourceType === "vhs-json") {
- playlistLoader = new PlaylistLoader$1(
- properties.playlists ? properties.playlists[0] : properties.resolvedUri,
- vhs,
- requestOptions
- );
- }
- properties = merge$2({
- id: variantLabel,
- playlistLoader
- }, properties);
- setupListeners$1[type2](type2, properties.playlistLoader, settings);
- groups[groupId].push(properties);
- if (typeof tracks[variantLabel] === "undefined") {
- const track = tech.addRemoteTextTrack({
- id: variantLabel,
- kind: "subtitles",
- default: properties.default && properties.autoselect,
- language: properties.language,
- label: variantLabel
- }, false).track;
- tracks[variantLabel] = track;
- }
- }
- }
- segmentLoader.on("error", onError$1[type2](type2, settings));
- },
- "CLOSED-CAPTIONS": (type2, settings) => {
- const {
- tech,
- main: {
- mediaGroups
- },
- mediaTypes: {
- [type2]: {
- groups,
- tracks
- }
- }
- } = settings;
- for (const groupId in mediaGroups[type2]) {
- if (!groups[groupId]) {
- groups[groupId] = [];
- }
- for (const variantLabel in mediaGroups[type2][groupId]) {
- const properties = mediaGroups[type2][groupId][variantLabel];
- if (!/^(?:CC|SERVICE)/.test(properties.instreamId)) {
- continue;
- }
- const captionServices = tech.options_.vhs && tech.options_.vhs.captionServices || {};
- let newProps = {
- label: variantLabel,
- language: properties.language,
- instreamId: properties.instreamId,
- default: properties.default && properties.autoselect
- };
- if (captionServices[newProps.instreamId]) {
- newProps = merge$2(newProps, captionServices[newProps.instreamId]);
- }
- if (newProps.default === void 0) {
- delete newProps.default;
- }
- groups[groupId].push(merge$2({
- id: variantLabel
- }, properties));
- if (typeof tracks[variantLabel] === "undefined") {
- const track = tech.addRemoteTextTrack({
- id: newProps.instreamId,
- kind: "captions",
- default: newProps.default,
- language: newProps.language,
- label: newProps.label
- }, false).track;
- tracks[variantLabel] = track;
- }
- }
- }
- }
- };
- const groupMatch$1 = (list, media) => {
- for (let i2 = 0; i2 < list.length; i2++) {
- if (playlistMatch$1(media, list[i2])) {
- return true;
- }
- if (list[i2].playlists && groupMatch$1(list[i2].playlists, media)) {
- return true;
- }
- }
- return false;
- };
- const activeGroup$1 = (type2, settings) => (track) => {
- const {
- mainPlaylistLoader,
- mediaTypes: {
- [type2]: {
- groups
- }
- }
- } = settings;
- const media = mainPlaylistLoader.media();
- if (!media) {
- return null;
- }
- let variants = null;
- if (media.attributes[type2]) {
- variants = groups[media.attributes[type2]];
- }
- const groupKeys = Object.keys(groups);
- if (!variants) {
- if (type2 === "AUDIO" && groupKeys.length > 1 && isAudioOnly$1(settings.main)) {
- for (let i2 = 0; i2 < groupKeys.length; i2++) {
- const groupPropertyList = groups[groupKeys[i2]];
- if (groupMatch$1(groupPropertyList, media)) {
- variants = groupPropertyList;
- break;
- }
- }
- } else if (groups.main) {
- variants = groups.main;
- } else if (groupKeys.length === 1) {
- variants = groups[groupKeys[0]];
- }
- }
- if (typeof track === "undefined") {
- return variants;
- }
- if (track === null || !variants) {
- return null;
- }
- return variants.filter((props) => props.id === track.id)[0] || null;
- };
- const activeTrack$1 = {
- AUDIO: (type2, settings) => () => {
- const {
- mediaTypes: {
- [type2]: {
- tracks
- }
- }
- } = settings;
- for (const id in tracks) {
- if (tracks[id].enabled) {
- return tracks[id];
- }
- }
- return null;
- },
- SUBTITLES: (type2, settings) => () => {
- const {
- mediaTypes: {
- [type2]: {
- tracks
- }
- }
- } = settings;
- for (const id in tracks) {
- if (tracks[id].mode === "showing" || tracks[id].mode === "hidden") {
- return tracks[id];
- }
- }
- return null;
- }
- };
- const getActiveGroup$1 = (type2, {
- mediaTypes: mediaTypes2
- }) => () => {
- const activeTrack_ = mediaTypes2[type2].activeTrack();
- if (!activeTrack_) {
- return null;
- }
- return mediaTypes2[type2].activeGroup(activeTrack_);
- };
- const setupMediaGroups$1 = (settings) => {
- ["AUDIO", "SUBTITLES", "CLOSED-CAPTIONS"].forEach((type2) => {
- initialize$1[type2](type2, settings);
- });
- const {
- mediaTypes: mediaTypes2,
- mainPlaylistLoader,
- tech,
- vhs,
- segmentLoaders: {
- ["AUDIO"]: audioSegmentLoader,
- main: mainSegmentLoader
- }
- } = settings;
- ["AUDIO", "SUBTITLES"].forEach((type2) => {
- mediaTypes2[type2].activeGroup = activeGroup$1(type2, settings);
- mediaTypes2[type2].activeTrack = activeTrack$1[type2](type2, settings);
- mediaTypes2[type2].onGroupChanged = onGroupChanged$1(type2, settings);
- mediaTypes2[type2].onGroupChanging = onGroupChanging$1(type2, settings);
- mediaTypes2[type2].onTrackChanged = onTrackChanged$1(type2, settings);
- mediaTypes2[type2].getActiveGroup = getActiveGroup$1(type2, settings);
- });
- const audioGroup = mediaTypes2.AUDIO.activeGroup();
- if (audioGroup) {
- const groupId = (audioGroup.filter((group) => group.default)[0] || audioGroup[0]).id;
- mediaTypes2.AUDIO.tracks[groupId].enabled = true;
- mediaTypes2.AUDIO.onGroupChanged();
- mediaTypes2.AUDIO.onTrackChanged();
- const activeAudioGroup = mediaTypes2.AUDIO.getActiveGroup();
- if (!activeAudioGroup.playlistLoader) {
- mainSegmentLoader.setAudio(true);
- } else {
- mainSegmentLoader.setAudio(false);
- audioSegmentLoader.setAudio(true);
- }
- }
- mainPlaylistLoader.on("mediachange", () => {
- ["AUDIO", "SUBTITLES"].forEach((type2) => mediaTypes2[type2].onGroupChanged());
- });
- mainPlaylistLoader.on("mediachanging", () => {
- ["AUDIO", "SUBTITLES"].forEach((type2) => mediaTypes2[type2].onGroupChanging());
- });
- const onAudioTrackChanged = () => {
- mediaTypes2.AUDIO.onTrackChanged();
- tech.trigger({
- type: "usage",
- name: "vhs-audio-change"
- });
- };
- tech.audioTracks().addEventListener("change", onAudioTrackChanged);
- tech.remoteTextTracks().addEventListener("change", mediaTypes2.SUBTITLES.onTrackChanged);
- vhs.on("dispose", () => {
- tech.audioTracks().removeEventListener("change", onAudioTrackChanged);
- tech.remoteTextTracks().removeEventListener("change", mediaTypes2.SUBTITLES.onTrackChanged);
- });
- tech.clearTracks("audio");
- for (const id in mediaTypes2.AUDIO.tracks) {
- tech.audioTracks().addTrack(mediaTypes2.AUDIO.tracks[id]);
- }
- };
- const createMediaTypes$1 = () => {
- const mediaTypes2 = {};
- ["AUDIO", "SUBTITLES", "CLOSED-CAPTIONS"].forEach((type2) => {
- mediaTypes2[type2] = {
- groups: {},
- tracks: {},
- activePlaylistLoader: null,
- activeGroup: noop$1,
- activeTrack: noop$1,
- getActiveGroup: noop$1,
- onGroupChanged: noop$1,
- onTrackChanged: noop$1,
- lastTrack_: null,
- logger_: logger$1(`MediaGroups[${type2}]`)
- };
- });
- return mediaTypes2;
- };
- const ABORT_EARLY_EXCLUSION_SECONDS = 60 * 2;
- let Vhs$1$1;
- const loaderStats$1 = ["mediaRequests", "mediaRequestsAborted", "mediaRequestsTimedout", "mediaRequestsErrored", "mediaTransferDuration", "mediaBytesTransferred", "mediaAppends"];
- const sumLoaderStat$1 = function(stat) {
- return this.audioSegmentLoader_[stat] + this.mainSegmentLoader_[stat];
- };
- const shouldSwitchToMedia$1 = function({
- currentPlaylist,
- buffered,
- currentTime,
- nextPlaylist,
- bufferLowWaterLine,
- bufferHighWaterLine,
- duration: duration5,
- bufferBasedABR,
- log: log2
- }) {
- if (!nextPlaylist) {
- videojs$2.log.warn("We received no playlist to switch to. Please check your stream.");
- return false;
- }
- const sharedLogLine = `allowing switch ${currentPlaylist && currentPlaylist.id || "null"} -> ${nextPlaylist.id}`;
- if (!currentPlaylist) {
- log2(`${sharedLogLine} as current playlist is not set`);
- return true;
- }
- if (nextPlaylist.id === currentPlaylist.id) {
- return false;
- }
- const isBuffered = Boolean(findRange$1(buffered, currentTime).length);
- if (!currentPlaylist.endList) {
- if (!isBuffered && typeof currentPlaylist.partTargetDuration === "number") {
- log2(`not ${sharedLogLine} as current playlist is live llhls, but currentTime isn't in buffered.`);
- return false;
- }
- log2(`${sharedLogLine} as current playlist is live`);
- return true;
- }
- const forwardBuffer = timeAheadOf$1(buffered, currentTime);
- const maxBufferLowWaterLine = bufferBasedABR ? Config$1.EXPERIMENTAL_MAX_BUFFER_LOW_WATER_LINE : Config$1.MAX_BUFFER_LOW_WATER_LINE;
- if (duration5 < maxBufferLowWaterLine) {
- log2(`${sharedLogLine} as duration < max low water line (${duration5} < ${maxBufferLowWaterLine})`);
- return true;
- }
- const nextBandwidth = nextPlaylist.attributes.BANDWIDTH;
- const currBandwidth = currentPlaylist.attributes.BANDWIDTH;
- if (nextBandwidth < currBandwidth && (!bufferBasedABR || forwardBuffer < bufferHighWaterLine)) {
- let logLine = `${sharedLogLine} as next bandwidth < current bandwidth (${nextBandwidth} < ${currBandwidth})`;
- if (bufferBasedABR) {
- logLine += ` and forwardBuffer < bufferHighWaterLine (${forwardBuffer} < ${bufferHighWaterLine})`;
- }
- log2(logLine);
- return true;
- }
- if ((!bufferBasedABR || nextBandwidth > currBandwidth) && forwardBuffer >= bufferLowWaterLine) {
- let logLine = `${sharedLogLine} as forwardBuffer >= bufferLowWaterLine (${forwardBuffer} >= ${bufferLowWaterLine})`;
- if (bufferBasedABR) {
- logLine += ` and next bandwidth > current bandwidth (${nextBandwidth} > ${currBandwidth})`;
- }
- log2(logLine);
- return true;
- }
- log2(`not ${sharedLogLine} as no switching criteria met`);
- return false;
- };
- class PlaylistController extends videojs$2.EventTarget {
- constructor(options2) {
- super();
- const {
- src,
- withCredentials,
- tech,
- bandwidth: bandwidth2,
- externVhs,
- useCueTags,
- playlistExclusionDuration,
- enableLowInitialPlaylist,
- sourceType,
- cacheEncryptionKeys,
- bufferBasedABR,
- leastPixelDiffSelector,
- captionServices
- } = options2;
- if (!src) {
- throw new Error("A non-empty playlist URL or JSON manifest string is required");
- }
- let {
- maxPlaylistRetries
- } = options2;
- if (maxPlaylistRetries === null || typeof maxPlaylistRetries === "undefined") {
- maxPlaylistRetries = Infinity;
- }
- Vhs$1$1 = externVhs;
- this.bufferBasedABR = Boolean(bufferBasedABR);
- this.leastPixelDiffSelector = Boolean(leastPixelDiffSelector);
- this.withCredentials = withCredentials;
- this.tech_ = tech;
- this.vhs_ = tech.vhs;
- this.sourceType_ = sourceType;
- this.useCueTags_ = useCueTags;
- this.playlistExclusionDuration = playlistExclusionDuration;
- this.maxPlaylistRetries = maxPlaylistRetries;
- this.enableLowInitialPlaylist = enableLowInitialPlaylist;
- if (this.useCueTags_) {
- this.cueTagsTrack_ = this.tech_.addTextTrack("metadata", "ad-cues");
- this.cueTagsTrack_.inBandMetadataTrackDispatchType = "";
- }
- this.requestOptions_ = {
- withCredentials,
- maxPlaylistRetries,
- timeout: null
- };
- this.on("error", this.pauseLoading);
- this.mediaTypes_ = createMediaTypes$1();
- this.mediaSource = new window_1.MediaSource();
- this.handleDurationChange_ = this.handleDurationChange_.bind(this);
- this.handleSourceOpen_ = this.handleSourceOpen_.bind(this);
- this.handleSourceEnded_ = this.handleSourceEnded_.bind(this);
- this.mediaSource.addEventListener("durationchange", this.handleDurationChange_);
- this.mediaSource.addEventListener("sourceopen", this.handleSourceOpen_);
- this.mediaSource.addEventListener("sourceended", this.handleSourceEnded_);
- this.seekable_ = createTimeRanges$2();
- this.hasPlayed_ = false;
- this.syncController_ = new SyncController$1(options2);
- this.segmentMetadataTrack_ = tech.addRemoteTextTrack({
- kind: "metadata",
- label: "segment-metadata"
- }, false).track;
- this.decrypter_ = new Decrypter$1();
- this.sourceUpdater_ = new SourceUpdater$1(this.mediaSource);
- this.inbandTextTracks_ = {};
- this.timelineChangeController_ = new TimelineChangeController$1();
- const segmentLoaderSettings = {
- vhs: this.vhs_,
- parse708captions: options2.parse708captions,
- useDtsForTimestampOffset: options2.useDtsForTimestampOffset,
- captionServices,
- mediaSource: this.mediaSource,
- currentTime: this.tech_.currentTime.bind(this.tech_),
- seekable: () => this.seekable(),
- seeking: () => this.tech_.seeking(),
- duration: () => this.duration(),
- hasPlayed: () => this.hasPlayed_,
- goalBufferLength: () => this.goalBufferLength(),
- bandwidth: bandwidth2,
- syncController: this.syncController_,
- decrypter: this.decrypter_,
- sourceType: this.sourceType_,
- inbandTextTracks: this.inbandTextTracks_,
- cacheEncryptionKeys,
- sourceUpdater: this.sourceUpdater_,
- timelineChangeController: this.timelineChangeController_,
- exactManifestTimings: options2.exactManifestTimings
- };
- this.mainPlaylistLoader_ = this.sourceType_ === "dash" ? new DashPlaylistLoader$1(src, this.vhs_, this.requestOptions_) : new PlaylistLoader$1(src, this.vhs_, this.requestOptions_);
- this.setupMainPlaylistLoaderListeners_();
- this.mainSegmentLoader_ = new SegmentLoader$1(merge$2(segmentLoaderSettings, {
- segmentMetadataTrack: this.segmentMetadataTrack_,
- loaderType: "main"
- }), options2);
- this.audioSegmentLoader_ = new SegmentLoader$1(merge$2(segmentLoaderSettings, {
- loaderType: "audio"
- }), options2);
- this.subtitleSegmentLoader_ = new VTTSegmentLoader$1(merge$2(segmentLoaderSettings, {
- loaderType: "vtt",
- featuresNativeTextTracks: this.tech_.featuresNativeTextTracks,
- loadVttJs: () => new Promise((resolve2, reject2) => {
- function onLoad() {
- tech.off("vttjserror", onError2);
- resolve2();
- }
- function onError2() {
- tech.off("vttjsloaded", onLoad);
- reject2();
- }
- tech.one("vttjsloaded", onLoad);
- tech.one("vttjserror", onError2);
- tech.addWebVttScript_();
- })
- }), options2);
- this.setupSegmentLoaderListeners_();
- if (this.bufferBasedABR) {
- this.mainPlaylistLoader_.one("loadedplaylist", () => this.startABRTimer_());
- this.tech_.on("pause", () => this.stopABRTimer_());
- this.tech_.on("play", () => this.startABRTimer_());
- }
- loaderStats$1.forEach((stat) => {
- this[stat + "_"] = sumLoaderStat$1.bind(this, stat);
- });
- this.logger_ = logger$1("pc");
- this.triggeredFmp4Usage = false;
- if (this.tech_.preload() === "none") {
- this.loadOnPlay_ = () => {
- this.loadOnPlay_ = null;
- this.mainPlaylistLoader_.load();
- };
- this.tech_.one("play", this.loadOnPlay_);
- } else {
- this.mainPlaylistLoader_.load();
- }
- this.timeToLoadedData__ = -1;
- this.mainAppendsToLoadedData__ = -1;
- this.audioAppendsToLoadedData__ = -1;
- const event2 = this.tech_.preload() === "none" ? "play" : "loadstart";
- this.tech_.one(event2, () => {
- const timeToLoadedDataStart = Date.now();
- this.tech_.one("loadeddata", () => {
- this.timeToLoadedData__ = Date.now() - timeToLoadedDataStart;
- this.mainAppendsToLoadedData__ = this.mainSegmentLoader_.mediaAppends;
- this.audioAppendsToLoadedData__ = this.audioSegmentLoader_.mediaAppends;
- });
- });
- }
- mainAppendsToLoadedData_() {
- return this.mainAppendsToLoadedData__;
- }
- audioAppendsToLoadedData_() {
- return this.audioAppendsToLoadedData__;
- }
- appendsToLoadedData_() {
- const main = this.mainAppendsToLoadedData_();
- const audio = this.audioAppendsToLoadedData_();
- if (main === -1 || audio === -1) {
- return -1;
- }
- return main + audio;
- }
- timeToLoadedData_() {
- return this.timeToLoadedData__;
- }
- checkABR_(reason = "abr") {
- const nextPlaylist = this.selectPlaylist();
- if (nextPlaylist && this.shouldSwitchToMedia_(nextPlaylist)) {
- this.switchMedia_(nextPlaylist, reason);
- }
- }
- switchMedia_(playlist, cause, delay) {
- const oldMedia = this.media();
- const oldId = oldMedia && (oldMedia.id || oldMedia.uri);
- const newId = playlist.id || playlist.uri;
- if (oldId && oldId !== newId) {
- this.logger_(`switch media ${oldId} -> ${newId} from ${cause}`);
- this.tech_.trigger({
- type: "usage",
- name: `vhs-rendition-change-${cause}`
- });
- }
- this.mainPlaylistLoader_.media(playlist, delay);
- }
- startABRTimer_() {
- this.stopABRTimer_();
- this.abrTimer_ = window_1.setInterval(() => this.checkABR_(), 250);
- }
- stopABRTimer_() {
- if (this.tech_.scrubbing && this.tech_.scrubbing()) {
- return;
- }
- window_1.clearInterval(this.abrTimer_);
- this.abrTimer_ = null;
- }
- getAudioTrackPlaylists_() {
- const main = this.main();
- const defaultPlaylists = main && main.playlists || [];
- if (!main || !main.mediaGroups || !main.mediaGroups.AUDIO) {
- return defaultPlaylists;
- }
- const AUDIO5 = main.mediaGroups.AUDIO;
- const groupKeys = Object.keys(AUDIO5);
- let track;
- if (Object.keys(this.mediaTypes_.AUDIO.groups).length) {
- track = this.mediaTypes_.AUDIO.activeTrack();
- } else {
- const defaultGroup = AUDIO5.main || groupKeys.length && AUDIO5[groupKeys[0]];
- for (const label2 in defaultGroup) {
- if (defaultGroup[label2].default) {
- track = {
- label: label2
- };
- break;
- }
- }
- }
- if (!track) {
- return defaultPlaylists;
- }
- const playlists = [];
- for (const group in AUDIO5) {
- if (AUDIO5[group][track.label]) {
- const properties = AUDIO5[group][track.label];
- if (properties.playlists && properties.playlists.length) {
- playlists.push.apply(playlists, properties.playlists);
- } else if (properties.uri) {
- playlists.push(properties);
- } else if (main.playlists.length) {
- for (let i2 = 0; i2 < main.playlists.length; i2++) {
- const playlist = main.playlists[i2];
- if (playlist.attributes && playlist.attributes.AUDIO && playlist.attributes.AUDIO === group) {
- playlists.push(playlist);
- }
- }
- }
- }
- }
- if (!playlists.length) {
- return defaultPlaylists;
- }
- return playlists;
- }
- setupMainPlaylistLoaderListeners_() {
- this.mainPlaylistLoader_.on("loadedmetadata", () => {
- const media = this.mainPlaylistLoader_.media();
- const requestTimeout = media.targetDuration * 1.5 * 1e3;
- if (isLowestEnabledRendition$1(this.mainPlaylistLoader_.main, this.mainPlaylistLoader_.media())) {
- this.requestOptions_.timeout = 0;
- } else {
- this.requestOptions_.timeout = requestTimeout;
- }
- if (media.endList && this.tech_.preload() !== "none") {
- this.mainSegmentLoader_.playlist(media, this.requestOptions_);
- this.mainSegmentLoader_.load();
- }
- setupMediaGroups$1({
- sourceType: this.sourceType_,
- segmentLoaders: {
- AUDIO: this.audioSegmentLoader_,
- SUBTITLES: this.subtitleSegmentLoader_,
- main: this.mainSegmentLoader_
- },
- tech: this.tech_,
- requestOptions: this.requestOptions_,
- mainPlaylistLoader: this.mainPlaylistLoader_,
- vhs: this.vhs_,
- main: this.main(),
- mediaTypes: this.mediaTypes_,
- excludePlaylist: this.excludePlaylist.bind(this)
- });
- this.triggerPresenceUsage_(this.main(), media);
- this.setupFirstPlay();
- if (!this.mediaTypes_.AUDIO.activePlaylistLoader || this.mediaTypes_.AUDIO.activePlaylistLoader.media()) {
- this.trigger("selectedinitialmedia");
- } else {
- this.mediaTypes_.AUDIO.activePlaylistLoader.one("loadedmetadata", () => {
- this.trigger("selectedinitialmedia");
- });
- }
- });
- this.mainPlaylistLoader_.on("loadedplaylist", () => {
- if (this.loadOnPlay_) {
- this.tech_.off("play", this.loadOnPlay_);
- }
- let updatedPlaylist = this.mainPlaylistLoader_.media();
- if (!updatedPlaylist) {
- this.excludeUnsupportedVariants_();
- let selectedMedia;
- if (this.enableLowInitialPlaylist) {
- selectedMedia = this.selectInitialPlaylist();
- }
- if (!selectedMedia) {
- selectedMedia = this.selectPlaylist();
- }
- if (!selectedMedia || !this.shouldSwitchToMedia_(selectedMedia)) {
- return;
- }
- this.initialMedia_ = selectedMedia;
- this.switchMedia_(this.initialMedia_, "initial");
- const haveJsonSource = this.sourceType_ === "vhs-json" && this.initialMedia_.segments;
- if (!haveJsonSource) {
- return;
- }
- updatedPlaylist = this.initialMedia_;
- }
- this.handleUpdatedMediaPlaylist(updatedPlaylist);
- });
- this.mainPlaylistLoader_.on("error", () => {
- const error = this.mainPlaylistLoader_.error;
- this.excludePlaylist({
- playlistToExclude: error.playlist,
- error
- });
- });
- this.mainPlaylistLoader_.on("mediachanging", () => {
- this.mainSegmentLoader_.abort();
- this.mainSegmentLoader_.pause();
- });
- this.mainPlaylistLoader_.on("mediachange", () => {
- const media = this.mainPlaylistLoader_.media();
- const requestTimeout = media.targetDuration * 1.5 * 1e3;
- if (isLowestEnabledRendition$1(this.mainPlaylistLoader_.main, this.mainPlaylistLoader_.media())) {
- this.requestOptions_.timeout = 0;
- } else {
- this.requestOptions_.timeout = requestTimeout;
- }
- this.mainPlaylistLoader_.load();
- this.mainSegmentLoader_.playlist(media, this.requestOptions_);
- this.mainSegmentLoader_.load();
- this.tech_.trigger({
- type: "mediachange",
- bubbles: true
- });
- });
- this.mainPlaylistLoader_.on("playlistunchanged", () => {
- const updatedPlaylist = this.mainPlaylistLoader_.media();
- if (updatedPlaylist.lastExcludeReason_ === "playlist-unchanged") {
- return;
- }
- const playlistOutdated = this.stuckAtPlaylistEnd_(updatedPlaylist);
- if (playlistOutdated) {
- this.excludePlaylist({
- error: {
- message: "Playlist no longer updating.",
- reason: "playlist-unchanged"
- }
- });
- this.tech_.trigger("playliststuck");
- }
- });
- this.mainPlaylistLoader_.on("renditiondisabled", () => {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-rendition-disabled"
- });
- });
- this.mainPlaylistLoader_.on("renditionenabled", () => {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-rendition-enabled"
- });
- });
- }
- handleUpdatedMediaPlaylist(updatedPlaylist) {
- if (this.useCueTags_) {
- this.updateAdCues_(updatedPlaylist);
- }
- this.mainSegmentLoader_.playlist(updatedPlaylist, this.requestOptions_);
- this.updateDuration(!updatedPlaylist.endList);
- if (!this.tech_.paused()) {
- this.mainSegmentLoader_.load();
- if (this.audioSegmentLoader_) {
- this.audioSegmentLoader_.load();
- }
- }
- }
- triggerPresenceUsage_(main, media) {
- const mediaGroups = main.mediaGroups || {};
- let defaultDemuxed = true;
- const audioGroupKeys = Object.keys(mediaGroups.AUDIO);
- for (const mediaGroup in mediaGroups.AUDIO) {
- for (const label2 in mediaGroups.AUDIO[mediaGroup]) {
- const properties = mediaGroups.AUDIO[mediaGroup][label2];
- if (!properties.uri) {
- defaultDemuxed = false;
- }
- }
- }
- if (defaultDemuxed) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-demuxed"
- });
- }
- if (Object.keys(mediaGroups.SUBTITLES).length) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-webvtt"
- });
- }
- if (Vhs$1$1.Playlist.isAes(media)) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-aes"
- });
- }
- if (audioGroupKeys.length && Object.keys(mediaGroups.AUDIO[audioGroupKeys[0]]).length > 1) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-alternate-audio"
- });
- }
- if (this.useCueTags_) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-playlist-cue-tags"
- });
- }
- }
- shouldSwitchToMedia_(nextPlaylist) {
- const currentPlaylist = this.mainPlaylistLoader_.media() || this.mainPlaylistLoader_.pendingMedia_;
- const currentTime = this.tech_.currentTime();
- const bufferLowWaterLine = this.bufferLowWaterLine();
- const bufferHighWaterLine = this.bufferHighWaterLine();
- const buffered = this.tech_.buffered();
- return shouldSwitchToMedia$1({
- buffered,
- currentTime,
- currentPlaylist,
- nextPlaylist,
- bufferLowWaterLine,
- bufferHighWaterLine,
- duration: this.duration(),
- bufferBasedABR: this.bufferBasedABR,
- log: this.logger_
- });
- }
- setupSegmentLoaderListeners_() {
- this.mainSegmentLoader_.on("bandwidthupdate", () => {
- this.checkABR_("bandwidthupdate");
- this.tech_.trigger("bandwidthupdate");
- });
- this.mainSegmentLoader_.on("timeout", () => {
- if (this.bufferBasedABR) {
- this.mainSegmentLoader_.load();
- }
- });
- if (!this.bufferBasedABR) {
- this.mainSegmentLoader_.on("progress", () => {
- this.trigger("progress");
- });
- }
- this.mainSegmentLoader_.on("error", () => {
- const error = this.mainSegmentLoader_.error();
- this.excludePlaylist({
- playlistToExclude: error.playlist,
- error
- });
- });
- this.mainSegmentLoader_.on("appenderror", () => {
- this.error = this.mainSegmentLoader_.error_;
- this.trigger("error");
- });
- this.mainSegmentLoader_.on("syncinfoupdate", () => {
- this.onSyncInfoUpdate_();
- });
- this.mainSegmentLoader_.on("timestampoffset", () => {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-timestamp-offset"
- });
- });
- this.audioSegmentLoader_.on("syncinfoupdate", () => {
- this.onSyncInfoUpdate_();
- });
- this.audioSegmentLoader_.on("appenderror", () => {
- this.error = this.audioSegmentLoader_.error_;
- this.trigger("error");
- });
- this.mainSegmentLoader_.on("ended", () => {
- this.logger_("main segment loader ended");
- this.onEndOfStream();
- });
- this.mainSegmentLoader_.on("earlyabort", (event2) => {
- if (this.bufferBasedABR) {
- return;
- }
- this.delegateLoaders_("all", ["abort"]);
- this.excludePlaylist({
- error: {
- message: "Aborted early because there isn't enough bandwidth to complete the request without rebuffering."
- },
- playlistExclusionDuration: ABORT_EARLY_EXCLUSION_SECONDS
- });
- });
- const updateCodecs = () => {
- if (!this.sourceUpdater_.hasCreatedSourceBuffers()) {
- return this.tryToCreateSourceBuffers_();
- }
- const codecs = this.getCodecsOrExclude_();
- if (!codecs) {
- return;
- }
- this.sourceUpdater_.addOrChangeSourceBuffers(codecs);
- };
- this.mainSegmentLoader_.on("trackinfo", updateCodecs);
- this.audioSegmentLoader_.on("trackinfo", updateCodecs);
- this.mainSegmentLoader_.on("fmp4", () => {
- if (!this.triggeredFmp4Usage) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-fmp4"
- });
- this.triggeredFmp4Usage = true;
- }
- });
- this.audioSegmentLoader_.on("fmp4", () => {
- if (!this.triggeredFmp4Usage) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-fmp4"
- });
- this.triggeredFmp4Usage = true;
- }
- });
- this.audioSegmentLoader_.on("ended", () => {
- this.logger_("audioSegmentLoader ended");
- this.onEndOfStream();
- });
- }
- mediaSecondsLoaded_() {
- return Math.max(this.audioSegmentLoader_.mediaSecondsLoaded + this.mainSegmentLoader_.mediaSecondsLoaded);
- }
- load() {
- this.mainSegmentLoader_.load();
- if (this.mediaTypes_.AUDIO.activePlaylistLoader) {
- this.audioSegmentLoader_.load();
- }
- if (this.mediaTypes_.SUBTITLES.activePlaylistLoader) {
- this.subtitleSegmentLoader_.load();
- }
- }
- fastQualityChange_(media = this.selectPlaylist()) {
- if (media === this.mainPlaylistLoader_.media()) {
- this.logger_("skipping fastQualityChange because new media is same as old");
- return;
- }
- this.switchMedia_(media, "fast-quality");
- this.mainSegmentLoader_.resetEverything(() => {
- if (videojs$2.browser.IE_VERSION || videojs$2.browser.IS_EDGE) {
- this.tech_.setCurrentTime(this.tech_.currentTime() + 0.04);
- } else {
- this.tech_.setCurrentTime(this.tech_.currentTime());
- }
- });
- }
- play() {
- if (this.setupFirstPlay()) {
- return;
- }
- if (this.tech_.ended()) {
- this.tech_.setCurrentTime(0);
- }
- if (this.hasPlayed_) {
- this.load();
- }
- const seekable3 = this.tech_.seekable();
- if (this.tech_.duration() === Infinity) {
- if (this.tech_.currentTime() < seekable3.start(0)) {
- return this.tech_.setCurrentTime(seekable3.end(seekable3.length - 1));
- }
- }
- }
- setupFirstPlay() {
- const media = this.mainPlaylistLoader_.media();
- if (!media || this.tech_.paused() || this.hasPlayed_) {
- return false;
- }
- if (!media.endList) {
- const seekable3 = this.seekable();
- if (!seekable3.length) {
- return false;
- }
- if (videojs$2.browser.IE_VERSION && this.tech_.readyState() === 0) {
- this.tech_.one("loadedmetadata", () => {
- this.trigger("firstplay");
- this.tech_.setCurrentTime(seekable3.end(0));
- this.hasPlayed_ = true;
- });
- return false;
- }
- this.trigger("firstplay");
- this.tech_.setCurrentTime(seekable3.end(0));
- }
- this.hasPlayed_ = true;
- this.load();
- return true;
- }
- handleSourceOpen_() {
- this.tryToCreateSourceBuffers_();
- if (this.tech_.autoplay()) {
- const playPromise = this.tech_.play();
- if (typeof playPromise !== "undefined" && typeof playPromise.then === "function") {
- playPromise.then(null, (e) => {
- });
- }
- }
- this.trigger("sourceopen");
- }
- handleSourceEnded_() {
- if (!this.inbandTextTracks_.metadataTrack_) {
- return;
- }
- const cues = this.inbandTextTracks_.metadataTrack_.cues;
- if (!cues || !cues.length) {
- return;
- }
- const duration5 = this.duration();
- cues[cues.length - 1].endTime = isNaN(duration5) || Math.abs(duration5) === Infinity ? Number.MAX_VALUE : duration5;
- }
- handleDurationChange_() {
- this.tech_.trigger("durationchange");
- }
- onEndOfStream() {
- let isEndOfStream = this.mainSegmentLoader_.ended_;
- if (this.mediaTypes_.AUDIO.activePlaylistLoader) {
- const mainMediaInfo = this.mainSegmentLoader_.getCurrentMediaInfo_();
- if (!mainMediaInfo || mainMediaInfo.hasVideo) {
- isEndOfStream = isEndOfStream && this.audioSegmentLoader_.ended_;
- } else {
- isEndOfStream = this.audioSegmentLoader_.ended_;
- }
- }
- if (!isEndOfStream) {
- return;
- }
- this.stopABRTimer_();
- this.sourceUpdater_.endOfStream();
- }
- stuckAtPlaylistEnd_(playlist) {
- const seekable3 = this.seekable();
- if (!seekable3.length) {
- return false;
- }
- const expired = this.syncController_.getExpiredTime(playlist, this.duration());
- if (expired === null) {
- return false;
- }
- const absolutePlaylistEnd = Vhs$1$1.Playlist.playlistEnd(playlist, expired);
- const currentTime = this.tech_.currentTime();
- const buffered = this.tech_.buffered();
- if (!buffered.length) {
- return absolutePlaylistEnd - currentTime <= SAFE_TIME_DELTA$1;
- }
- const bufferedEnd = buffered.end(buffered.length - 1);
- return bufferedEnd - currentTime <= SAFE_TIME_DELTA$1 && absolutePlaylistEnd - bufferedEnd <= SAFE_TIME_DELTA$1;
- }
- excludePlaylist({
- playlistToExclude = this.mainPlaylistLoader_.media(),
- error = {},
- playlistExclusionDuration
- }) {
- playlistToExclude = playlistToExclude || this.mainPlaylistLoader_.media();
- playlistExclusionDuration = playlistExclusionDuration || error.playlistExclusionDuration || this.playlistExclusionDuration;
- if (!playlistToExclude) {
- this.error = error;
- if (this.mediaSource.readyState !== "open") {
- this.trigger("error");
- } else {
- this.sourceUpdater_.endOfStream("network");
- }
- return;
- }
- playlistToExclude.playlistErrors_++;
- const playlists = this.mainPlaylistLoader_.main.playlists;
- const enabledPlaylists = playlists.filter(isEnabled$1);
- const isFinalRendition = enabledPlaylists.length === 1 && enabledPlaylists[0] === playlistToExclude;
- if (playlists.length === 1 && playlistExclusionDuration !== Infinity) {
- videojs$2.log.warn(`Problem encountered with playlist ${playlistToExclude.id}. Trying again since it is the only playlist.`);
- this.tech_.trigger("retryplaylist");
- return this.mainPlaylistLoader_.load(isFinalRendition);
- }
- if (isFinalRendition) {
- let reincluded = false;
- playlists.forEach((playlist) => {
- if (playlist === playlistToExclude) {
- return;
- }
- const excludeUntil2 = playlist.excludeUntil;
- if (typeof excludeUntil2 !== "undefined" && excludeUntil2 !== Infinity) {
- reincluded = true;
- delete playlist.excludeUntil;
- }
- });
- if (reincluded) {
- videojs$2.log.warn("Removing other playlists from the exclusion list because the last rendition is about to be excluded.");
- this.tech_.trigger("retryplaylist");
- }
- }
- let excludeUntil;
- if (playlistToExclude.playlistErrors_ > this.maxPlaylistRetries) {
- excludeUntil = Infinity;
- } else {
- excludeUntil = Date.now() + playlistExclusionDuration * 1e3;
- }
- playlistToExclude.excludeUntil = excludeUntil;
- if (error.reason) {
- playlistToExclude.lastExcludeReason_ = error.reason;
- }
- this.tech_.trigger("excludeplaylist");
- this.tech_.trigger({
- type: "usage",
- name: "vhs-rendition-excluded"
- });
- const nextPlaylist = this.selectPlaylist();
- if (!nextPlaylist) {
- this.error = "Playback cannot continue. No available working or supported playlists.";
- this.trigger("error");
- return;
- }
- const logFn2 = error.internal ? this.logger_ : videojs$2.log.warn;
- const errorMessage = error.message ? " " + error.message : "";
- logFn2(`${error.internal ? "Internal problem" : "Problem"} encountered with playlist ${playlistToExclude.id}.${errorMessage} Switching to playlist ${nextPlaylist.id}.`);
- if (nextPlaylist.attributes.AUDIO !== playlistToExclude.attributes.AUDIO) {
- this.delegateLoaders_("audio", ["abort", "pause"]);
- }
- if (nextPlaylist.attributes.SUBTITLES !== playlistToExclude.attributes.SUBTITLES) {
- this.delegateLoaders_("subtitle", ["abort", "pause"]);
- }
- this.delegateLoaders_("main", ["abort", "pause"]);
- const delayDuration = nextPlaylist.targetDuration / 2 * 1e3 || 5 * 1e3;
- const shouldDelay = typeof nextPlaylist.lastRequest === "number" && Date.now() - nextPlaylist.lastRequest <= delayDuration;
- return this.switchMedia_(nextPlaylist, "exclude", isFinalRendition || shouldDelay);
- }
- pauseLoading() {
- this.delegateLoaders_("all", ["abort", "pause"]);
- this.stopABRTimer_();
- }
- delegateLoaders_(filter, fnNames) {
- const loaders = [];
- const dontFilterPlaylist = filter === "all";
- if (dontFilterPlaylist || filter === "main") {
- loaders.push(this.mainPlaylistLoader_);
- }
- const mediaTypes2 = [];
- if (dontFilterPlaylist || filter === "audio") {
- mediaTypes2.push("AUDIO");
- }
- if (dontFilterPlaylist || filter === "subtitle") {
- mediaTypes2.push("CLOSED-CAPTIONS");
- mediaTypes2.push("SUBTITLES");
- }
- mediaTypes2.forEach((mediaType) => {
- const loader = this.mediaTypes_[mediaType] && this.mediaTypes_[mediaType].activePlaylistLoader;
- if (loader) {
- loaders.push(loader);
- }
- });
- ["main", "audio", "subtitle"].forEach((name) => {
- const loader = this[`${name}SegmentLoader_`];
- if (loader && (filter === name || filter === "all")) {
- loaders.push(loader);
- }
- });
- loaders.forEach((loader) => fnNames.forEach((fnName) => {
- if (typeof loader[fnName] === "function") {
- loader[fnName]();
- }
- }));
- }
- setCurrentTime(currentTime) {
- const buffered = findRange$1(this.tech_.buffered(), currentTime);
- if (!(this.mainPlaylistLoader_ && this.mainPlaylistLoader_.media())) {
- return 0;
- }
- if (!this.mainPlaylistLoader_.media().segments) {
- return 0;
- }
- if (buffered && buffered.length) {
- return currentTime;
- }
- this.mainSegmentLoader_.resetEverything();
- this.mainSegmentLoader_.abort();
- if (this.mediaTypes_.AUDIO.activePlaylistLoader) {
- this.audioSegmentLoader_.resetEverything();
- this.audioSegmentLoader_.abort();
- }
- if (this.mediaTypes_.SUBTITLES.activePlaylistLoader) {
- this.subtitleSegmentLoader_.resetEverything();
- this.subtitleSegmentLoader_.abort();
- }
- this.load();
- }
- duration() {
- if (!this.mainPlaylistLoader_) {
- return 0;
- }
- const media = this.mainPlaylistLoader_.media();
- if (!media) {
- return 0;
- }
- if (!media.endList) {
- return Infinity;
- }
- if (this.mediaSource) {
- return this.mediaSource.duration;
- }
- return Vhs$1$1.Playlist.duration(media);
- }
- seekable() {
- return this.seekable_;
- }
- onSyncInfoUpdate_() {
- let audioSeekable;
- if (!this.mainPlaylistLoader_) {
- return;
- }
- let media = this.mainPlaylistLoader_.media();
- if (!media) {
- return;
- }
- let expired = this.syncController_.getExpiredTime(media, this.duration());
- if (expired === null) {
- return;
- }
- const main = this.mainPlaylistLoader_.main;
- const mainSeekable = Vhs$1$1.Playlist.seekable(media, expired, Vhs$1$1.Playlist.liveEdgeDelay(main, media));
- if (mainSeekable.length === 0) {
- return;
- }
- if (this.mediaTypes_.AUDIO.activePlaylistLoader) {
- media = this.mediaTypes_.AUDIO.activePlaylistLoader.media();
- expired = this.syncController_.getExpiredTime(media, this.duration());
- if (expired === null) {
- return;
- }
- audioSeekable = Vhs$1$1.Playlist.seekable(media, expired, Vhs$1$1.Playlist.liveEdgeDelay(main, media));
- if (audioSeekable.length === 0) {
- return;
- }
- }
- let oldEnd;
- let oldStart;
- if (this.seekable_ && this.seekable_.length) {
- oldEnd = this.seekable_.end(0);
- oldStart = this.seekable_.start(0);
- }
- if (!audioSeekable) {
- this.seekable_ = mainSeekable;
- } else if (audioSeekable.start(0) > mainSeekable.end(0) || mainSeekable.start(0) > audioSeekable.end(0)) {
- this.seekable_ = mainSeekable;
- } else {
- this.seekable_ = createTimeRanges$2([[audioSeekable.start(0) > mainSeekable.start(0) ? audioSeekable.start(0) : mainSeekable.start(0), audioSeekable.end(0) < mainSeekable.end(0) ? audioSeekable.end(0) : mainSeekable.end(0)]]);
- }
- if (this.seekable_ && this.seekable_.length) {
- if (this.seekable_.end(0) === oldEnd && this.seekable_.start(0) === oldStart) {
- return;
- }
- }
- this.logger_(`seekable updated [${printableRange$1(this.seekable_)}]`);
- this.tech_.trigger("seekablechanged");
- }
- updateDuration(isLive) {
- if (this.updateDuration_) {
- this.mediaSource.removeEventListener("sourceopen", this.updateDuration_);
- this.updateDuration_ = null;
- }
- if (this.mediaSource.readyState !== "open") {
- this.updateDuration_ = this.updateDuration.bind(this, isLive);
- this.mediaSource.addEventListener("sourceopen", this.updateDuration_);
- return;
- }
- if (isLive) {
- const seekable3 = this.seekable();
- if (!seekable3.length) {
- return;
- }
- if (isNaN(this.mediaSource.duration) || this.mediaSource.duration < seekable3.end(seekable3.length - 1)) {
- this.sourceUpdater_.setDuration(seekable3.end(seekable3.length - 1));
- }
- return;
- }
- const buffered = this.tech_.buffered();
- let duration5 = Vhs$1$1.Playlist.duration(this.mainPlaylistLoader_.media());
- if (buffered.length > 0) {
- duration5 = Math.max(duration5, buffered.end(buffered.length - 1));
- }
- if (this.mediaSource.duration !== duration5) {
- this.sourceUpdater_.setDuration(duration5);
- }
- }
- dispose() {
- this.trigger("dispose");
- this.decrypter_.terminate();
- this.mainPlaylistLoader_.dispose();
- this.mainSegmentLoader_.dispose();
- if (this.loadOnPlay_) {
- this.tech_.off("play", this.loadOnPlay_);
- }
- ["AUDIO", "SUBTITLES"].forEach((type2) => {
- const groups = this.mediaTypes_[type2].groups;
- for (const id in groups) {
- groups[id].forEach((group) => {
- if (group.playlistLoader) {
- group.playlistLoader.dispose();
- }
- });
- }
- });
- this.audioSegmentLoader_.dispose();
- this.subtitleSegmentLoader_.dispose();
- this.sourceUpdater_.dispose();
- this.timelineChangeController_.dispose();
- this.stopABRTimer_();
- if (this.updateDuration_) {
- this.mediaSource.removeEventListener("sourceopen", this.updateDuration_);
- }
- this.mediaSource.removeEventListener("durationchange", this.handleDurationChange_);
- this.mediaSource.removeEventListener("sourceopen", this.handleSourceOpen_);
- this.mediaSource.removeEventListener("sourceended", this.handleSourceEnded_);
- this.off();
- }
- main() {
- return this.mainPlaylistLoader_.main;
- }
- media() {
- return this.mainPlaylistLoader_.media() || this.initialMedia_;
- }
- areMediaTypesKnown_() {
- const usingAudioLoader = !!this.mediaTypes_.AUDIO.activePlaylistLoader;
- const hasMainMediaInfo = !!this.mainSegmentLoader_.getCurrentMediaInfo_();
- const hasAudioMediaInfo = !usingAudioLoader ? true : !!this.audioSegmentLoader_.getCurrentMediaInfo_();
- if (!hasMainMediaInfo || !hasAudioMediaInfo) {
- return false;
- }
- return true;
- }
- getCodecsOrExclude_() {
- const media = {
- main: this.mainSegmentLoader_.getCurrentMediaInfo_() || {},
- audio: this.audioSegmentLoader_.getCurrentMediaInfo_() || {}
- };
- const playlist = this.mainSegmentLoader_.getPendingSegmentPlaylist() || this.media();
- media.video = media.main;
- const playlistCodecs = codecsForPlaylist$1(this.main(), playlist);
- const codecs = {};
- const usingAudioLoader = !!this.mediaTypes_.AUDIO.activePlaylistLoader;
- if (media.main.hasVideo) {
- codecs.video = playlistCodecs.video || media.main.videoCodec || DEFAULT_VIDEO_CODEC$1;
- }
- if (media.main.isMuxed) {
- codecs.video += `,${playlistCodecs.audio || media.main.audioCodec || DEFAULT_AUDIO_CODEC$1}`;
- }
- if (media.main.hasAudio && !media.main.isMuxed || media.audio.hasAudio || usingAudioLoader) {
- codecs.audio = playlistCodecs.audio || media.main.audioCodec || media.audio.audioCodec || DEFAULT_AUDIO_CODEC$1;
- media.audio.isFmp4 = media.main.hasAudio && !media.main.isMuxed ? media.main.isFmp4 : media.audio.isFmp4;
- }
- if (!codecs.audio && !codecs.video) {
- this.excludePlaylist({
- playlistToExclude: playlist,
- error: {
- message: "Could not determine codecs for playlist."
- },
- playlistExclusionDuration: Infinity
- });
- return;
- }
- const supportFunction = (isFmp4, codec) => isFmp4 ? browserSupportsCodec$1(codec) : muxerSupportsCodec$1(codec);
- const unsupportedCodecs = {};
- let unsupportedAudio;
- ["video", "audio"].forEach(function(type2) {
- if (codecs.hasOwnProperty(type2) && !supportFunction(media[type2].isFmp4, codecs[type2])) {
- const supporter = media[type2].isFmp4 ? "browser" : "muxer";
- unsupportedCodecs[supporter] = unsupportedCodecs[supporter] || [];
- unsupportedCodecs[supporter].push(codecs[type2]);
- if (type2 === "audio") {
- unsupportedAudio = supporter;
- }
- }
- });
- if (usingAudioLoader && unsupportedAudio && playlist.attributes.AUDIO) {
- const audioGroup = playlist.attributes.AUDIO;
- this.main().playlists.forEach((variant) => {
- const variantAudioGroup = variant.attributes && variant.attributes.AUDIO;
- if (variantAudioGroup === audioGroup && variant !== playlist) {
- variant.excludeUntil = Infinity;
- }
- });
- this.logger_(`excluding audio group ${audioGroup} as ${unsupportedAudio} does not support codec(s): "${codecs.audio}"`);
- }
- if (Object.keys(unsupportedCodecs).length) {
- const message = Object.keys(unsupportedCodecs).reduce((acc, supporter) => {
- if (acc) {
- acc += ", ";
- }
- acc += `${supporter} does not support codec(s): "${unsupportedCodecs[supporter].join(",")}"`;
- return acc;
- }, "") + ".";
- this.excludePlaylist({
- playlistToExclude: playlist,
- error: {
- internal: true,
- message
- },
- playlistExclusionDuration: Infinity
- });
- return;
- }
- if (this.sourceUpdater_.hasCreatedSourceBuffers() && !this.sourceUpdater_.canChangeType()) {
- const switchMessages = [];
- ["video", "audio"].forEach((type2) => {
- const newCodec = (parseCodecs$1(this.sourceUpdater_.codecs[type2] || "")[0] || {}).type;
- const oldCodec = (parseCodecs$1(codecs[type2] || "")[0] || {}).type;
- if (newCodec && oldCodec && newCodec.toLowerCase() !== oldCodec.toLowerCase()) {
- switchMessages.push(`"${this.sourceUpdater_.codecs[type2]}" -> "${codecs[type2]}"`);
- }
- });
- if (switchMessages.length) {
- this.excludePlaylist({
- playlistToExclude: playlist,
- error: {
- message: `Codec switching not supported: ${switchMessages.join(", ")}.`,
- internal: true
- },
- playlistExclusionDuration: Infinity
- });
- return;
- }
- }
- return codecs;
- }
- tryToCreateSourceBuffers_() {
- if (this.mediaSource.readyState !== "open" || this.sourceUpdater_.hasCreatedSourceBuffers()) {
- return;
- }
- if (!this.areMediaTypesKnown_()) {
- return;
- }
- const codecs = this.getCodecsOrExclude_();
- if (!codecs) {
- return;
- }
- this.sourceUpdater_.createSourceBuffers(codecs);
- const codecString = [codecs.video, codecs.audio].filter(Boolean).join(",");
- this.excludeIncompatibleVariants_(codecString);
- }
- excludeUnsupportedVariants_() {
- const playlists = this.main().playlists;
- const ids = [];
- Object.keys(playlists).forEach((key) => {
- const variant = playlists[key];
- if (ids.indexOf(variant.id) !== -1) {
- return;
- }
- ids.push(variant.id);
- const codecs = codecsForPlaylist$1(this.main, variant);
- const unsupported = [];
- if (codecs.audio && !muxerSupportsCodec$1(codecs.audio) && !browserSupportsCodec$1(codecs.audio)) {
- unsupported.push(`audio codec ${codecs.audio}`);
- }
- if (codecs.video && !muxerSupportsCodec$1(codecs.video) && !browserSupportsCodec$1(codecs.video)) {
- unsupported.push(`video codec ${codecs.video}`);
- }
- if (codecs.text && codecs.text === "stpp.ttml.im1t") {
- unsupported.push(`text codec ${codecs.text}`);
- }
- if (unsupported.length) {
- variant.excludeUntil = Infinity;
- this.logger_(`excluding ${variant.id} for unsupported: ${unsupported.join(", ")}`);
- }
- });
- }
- excludeIncompatibleVariants_(codecString) {
- const ids = [];
- const playlists = this.main().playlists;
- const codecs = unwrapCodecList$1(parseCodecs$1(codecString));
- const codecCount_ = codecCount$1(codecs);
- const videoDetails = codecs.video && parseCodecs$1(codecs.video)[0] || null;
- const audioDetails = codecs.audio && parseCodecs$1(codecs.audio)[0] || null;
- Object.keys(playlists).forEach((key) => {
- const variant = playlists[key];
- if (ids.indexOf(variant.id) !== -1 || variant.excludeUntil === Infinity) {
- return;
- }
- ids.push(variant.id);
- const exclusionReasons = [];
- const variantCodecs = codecsForPlaylist$1(this.mainPlaylistLoader_.main, variant);
- const variantCodecCount = codecCount$1(variantCodecs);
- if (!variantCodecs.audio && !variantCodecs.video) {
- return;
- }
- if (variantCodecCount !== codecCount_) {
- exclusionReasons.push(`codec count "${variantCodecCount}" !== "${codecCount_}"`);
- }
- if (!this.sourceUpdater_.canChangeType()) {
- const variantVideoDetails = variantCodecs.video && parseCodecs$1(variantCodecs.video)[0] || null;
- const variantAudioDetails = variantCodecs.audio && parseCodecs$1(variantCodecs.audio)[0] || null;
- if (variantVideoDetails && videoDetails && variantVideoDetails.type.toLowerCase() !== videoDetails.type.toLowerCase()) {
- exclusionReasons.push(`video codec "${variantVideoDetails.type}" !== "${videoDetails.type}"`);
- }
- if (variantAudioDetails && audioDetails && variantAudioDetails.type.toLowerCase() !== audioDetails.type.toLowerCase()) {
- exclusionReasons.push(`audio codec "${variantAudioDetails.type}" !== "${audioDetails.type}"`);
- }
- }
- if (exclusionReasons.length) {
- variant.excludeUntil = Infinity;
- this.logger_(`excluding ${variant.id}: ${exclusionReasons.join(" && ")}`);
- }
- });
- }
- updateAdCues_(media) {
- let offset = 0;
- const seekable3 = this.seekable();
- if (seekable3.length) {
- offset = seekable3.start(0);
- }
- updateAdCues$1(media, this.cueTagsTrack_, offset);
- }
- goalBufferLength() {
- const currentTime = this.tech_.currentTime();
- const initial = Config$1.GOAL_BUFFER_LENGTH;
- const rate = Config$1.GOAL_BUFFER_LENGTH_RATE;
- const max2 = Math.max(initial, Config$1.MAX_GOAL_BUFFER_LENGTH);
- return Math.min(initial + currentTime * rate, max2);
- }
- bufferLowWaterLine() {
- const currentTime = this.tech_.currentTime();
- const initial = Config$1.BUFFER_LOW_WATER_LINE;
- const rate = Config$1.BUFFER_LOW_WATER_LINE_RATE;
- const max2 = Math.max(initial, Config$1.MAX_BUFFER_LOW_WATER_LINE);
- const newMax = Math.max(initial, Config$1.EXPERIMENTAL_MAX_BUFFER_LOW_WATER_LINE);
- return Math.min(initial + currentTime * rate, this.bufferBasedABR ? newMax : max2);
- }
- bufferHighWaterLine() {
- return Config$1.BUFFER_HIGH_WATER_LINE;
- }
- }
- const enableFunction$1 = (loader, playlistID, changePlaylistFn) => (enable) => {
- const playlist = loader.main.playlists[playlistID];
- const incompatible = isIncompatible$1(playlist);
- const currentlyEnabled = isEnabled$1(playlist);
- if (typeof enable === "undefined") {
- return currentlyEnabled;
- }
- if (enable) {
- delete playlist.disabled;
- } else {
- playlist.disabled = true;
- }
- if (enable !== currentlyEnabled && !incompatible) {
- changePlaylistFn();
- if (enable) {
- loader.trigger("renditionenabled");
- } else {
- loader.trigger("renditiondisabled");
- }
- }
- return enable;
- };
- class Representation$1 {
- constructor(vhsHandler, playlist, id) {
- const {
- playlistController_: pc
- } = vhsHandler;
- const qualityChangeFunction = pc.fastQualityChange_.bind(pc);
- if (playlist.attributes) {
- const resolution = playlist.attributes.RESOLUTION;
- this.width = resolution && resolution.width;
- this.height = resolution && resolution.height;
- this.bandwidth = playlist.attributes.BANDWIDTH;
- this.frameRate = playlist.attributes["FRAME-RATE"];
- }
- this.codecs = codecsForPlaylist$1(pc.main(), playlist);
- this.playlist = playlist;
- this.id = id;
- this.enabled = enableFunction$1(vhsHandler.playlists, playlist.id, qualityChangeFunction);
- }
- }
- const renditionSelectionMixin$1 = function(vhsHandler) {
- vhsHandler.representations = () => {
- const main = vhsHandler.playlistController_.main();
- const playlists = isAudioOnly$1(main) ? vhsHandler.playlistController_.getAudioTrackPlaylists_() : main.playlists;
- if (!playlists) {
- return [];
- }
- return playlists.filter((media) => !isIncompatible$1(media)).map((e, i2) => new Representation$1(vhsHandler, e, e.id));
- };
- };
- const timerCancelEvents$1 = ["seeking", "seeked", "pause", "playing", "error"];
- class PlaybackWatcher$1 {
- constructor(options2) {
- this.playlistController_ = options2.playlistController;
- this.tech_ = options2.tech;
- this.seekable = options2.seekable;
- this.allowSeeksWithinUnsafeLiveWindow = options2.allowSeeksWithinUnsafeLiveWindow;
- this.liveRangeSafeTimeDelta = options2.liveRangeSafeTimeDelta;
- this.media = options2.media;
- this.consecutiveUpdates = 0;
- this.lastRecordedTime = null;
- this.checkCurrentTimeTimeout_ = null;
- this.logger_ = logger$1("PlaybackWatcher");
- this.logger_("initialize");
- const playHandler = () => this.monitorCurrentTime_();
- const canPlayHandler = () => this.monitorCurrentTime_();
- const waitingHandler = () => this.techWaiting_();
- const cancelTimerHandler = () => this.resetTimeUpdate_();
- const pc = this.playlistController_;
- const loaderTypes = ["main", "subtitle", "audio"];
- const loaderChecks = {};
- loaderTypes.forEach((type2) => {
- loaderChecks[type2] = {
- reset: () => this.resetSegmentDownloads_(type2),
- updateend: () => this.checkSegmentDownloads_(type2)
- };
- pc[`${type2}SegmentLoader_`].on("appendsdone", loaderChecks[type2].updateend);
- pc[`${type2}SegmentLoader_`].on("playlistupdate", loaderChecks[type2].reset);
- this.tech_.on(["seeked", "seeking"], loaderChecks[type2].reset);
- });
- const setSeekingHandlers = (fn2) => {
- ["main", "audio"].forEach((type2) => {
- pc[`${type2}SegmentLoader_`][fn2]("appended", this.seekingAppendCheck_);
- });
- };
- this.seekingAppendCheck_ = () => {
- if (this.fixesBadSeeks_()) {
- this.consecutiveUpdates = 0;
- this.lastRecordedTime = this.tech_.currentTime();
- setSeekingHandlers("off");
- }
- };
- this.clearSeekingAppendCheck_ = () => setSeekingHandlers("off");
- this.watchForBadSeeking_ = () => {
- this.clearSeekingAppendCheck_();
- setSeekingHandlers("on");
- };
- this.tech_.on("seeked", this.clearSeekingAppendCheck_);
- this.tech_.on("seeking", this.watchForBadSeeking_);
- this.tech_.on("waiting", waitingHandler);
- this.tech_.on(timerCancelEvents$1, cancelTimerHandler);
- this.tech_.on("canplay", canPlayHandler);
- this.tech_.one("play", playHandler);
- this.dispose = () => {
- this.clearSeekingAppendCheck_();
- this.logger_("dispose");
- this.tech_.off("waiting", waitingHandler);
- this.tech_.off(timerCancelEvents$1, cancelTimerHandler);
- this.tech_.off("canplay", canPlayHandler);
- this.tech_.off("play", playHandler);
- this.tech_.off("seeking", this.watchForBadSeeking_);
- this.tech_.off("seeked", this.clearSeekingAppendCheck_);
- loaderTypes.forEach((type2) => {
- pc[`${type2}SegmentLoader_`].off("appendsdone", loaderChecks[type2].updateend);
- pc[`${type2}SegmentLoader_`].off("playlistupdate", loaderChecks[type2].reset);
- this.tech_.off(["seeked", "seeking"], loaderChecks[type2].reset);
- });
- if (this.checkCurrentTimeTimeout_) {
- window_1.clearTimeout(this.checkCurrentTimeTimeout_);
- }
- this.resetTimeUpdate_();
- };
- }
- monitorCurrentTime_() {
- this.checkCurrentTime_();
- if (this.checkCurrentTimeTimeout_) {
- window_1.clearTimeout(this.checkCurrentTimeTimeout_);
- }
- this.checkCurrentTimeTimeout_ = window_1.setTimeout(this.monitorCurrentTime_.bind(this), 250);
- }
- resetSegmentDownloads_(type2) {
- const loader = this.playlistController_[`${type2}SegmentLoader_`];
- if (this[`${type2}StalledDownloads_`] > 0) {
- this.logger_(`resetting possible stalled download count for ${type2} loader`);
- }
- this[`${type2}StalledDownloads_`] = 0;
- this[`${type2}Buffered_`] = loader.buffered_();
- }
- checkSegmentDownloads_(type2) {
- const pc = this.playlistController_;
- const loader = pc[`${type2}SegmentLoader_`];
- const buffered = loader.buffered_();
- const isBufferedDifferent = isRangeDifferent$1(this[`${type2}Buffered_`], buffered);
- this[`${type2}Buffered_`] = buffered;
- if (isBufferedDifferent) {
- this.resetSegmentDownloads_(type2);
- return;
- }
- this[`${type2}StalledDownloads_`]++;
- this.logger_(`found #${this[`${type2}StalledDownloads_`]} ${type2} appends that did not increase buffer (possible stalled download)`, {
- playlistId: loader.playlist_ && loader.playlist_.id,
- buffered: timeRangesToArray$1(buffered)
- });
- if (this[`${type2}StalledDownloads_`] < 10) {
- return;
- }
- this.logger_(`${type2} loader stalled download exclusion`);
- this.resetSegmentDownloads_(type2);
- this.tech_.trigger({
- type: "usage",
- name: `vhs-${type2}-download-exclusion`
- });
- if (type2 === "subtitle") {
- return;
- }
- pc.excludePlaylist({
- error: {
- message: `Excessive ${type2} segment downloading detected.`
- },
- playlistExclusionDuration: Infinity
- });
- }
- checkCurrentTime_() {
- if (this.tech_.paused() || this.tech_.seeking()) {
- return;
- }
- const currentTime = this.tech_.currentTime();
- const buffered = this.tech_.buffered();
- if (this.lastRecordedTime === currentTime && (!buffered.length || currentTime + SAFE_TIME_DELTA$1 >= buffered.end(buffered.length - 1))) {
- return this.techWaiting_();
- }
- if (this.consecutiveUpdates >= 5 && currentTime === this.lastRecordedTime) {
- this.consecutiveUpdates++;
- this.waiting_();
- } else if (currentTime === this.lastRecordedTime) {
- this.consecutiveUpdates++;
- } else {
- this.consecutiveUpdates = 0;
- this.lastRecordedTime = currentTime;
- }
- }
- resetTimeUpdate_() {
- this.consecutiveUpdates = 0;
- }
- fixesBadSeeks_() {
- const seeking = this.tech_.seeking();
- if (!seeking) {
- return false;
- }
- const seekable3 = this.seekable();
- const currentTime = this.tech_.currentTime();
- const isAfterSeekableRange = this.afterSeekableWindow_(seekable3, currentTime, this.media(), this.allowSeeksWithinUnsafeLiveWindow);
- let seekTo;
- if (isAfterSeekableRange) {
- const seekableEnd = seekable3.end(seekable3.length - 1);
- seekTo = seekableEnd;
- }
- if (this.beforeSeekableWindow_(seekable3, currentTime)) {
- const seekableStart = seekable3.start(0);
- seekTo = seekableStart + (seekableStart === seekable3.end(0) ? 0 : SAFE_TIME_DELTA$1);
- }
- if (typeof seekTo !== "undefined") {
- this.logger_(`Trying to seek outside of seekable at time ${currentTime} with seekable range ${printableRange$1(seekable3)}. Seeking to ${seekTo}.`);
- this.tech_.setCurrentTime(seekTo);
- return true;
- }
- const sourceUpdater = this.playlistController_.sourceUpdater_;
- const buffered = this.tech_.buffered();
- const audioBuffered = sourceUpdater.audioBuffer ? sourceUpdater.audioBuffered() : null;
- const videoBuffered = sourceUpdater.videoBuffer ? sourceUpdater.videoBuffered() : null;
- const media = this.media();
- const minAppendedDuration = media.partTargetDuration ? media.partTargetDuration : (media.targetDuration - TIME_FUDGE_FACTOR$1) * 2;
- const bufferedToCheck = [audioBuffered, videoBuffered];
- for (let i2 = 0; i2 < bufferedToCheck.length; i2++) {
- if (!bufferedToCheck[i2]) {
- continue;
- }
- const timeAhead = timeAheadOf$1(bufferedToCheck[i2], currentTime);
- if (timeAhead < minAppendedDuration) {
- return false;
- }
- }
- const nextRange = findNextRange$1(buffered, currentTime);
- if (nextRange.length === 0) {
- return false;
- }
- seekTo = nextRange.start(0) + SAFE_TIME_DELTA$1;
- this.logger_(`Buffered region starts (${nextRange.start(0)}) just beyond seek point (${currentTime}). Seeking to ${seekTo}.`);
- this.tech_.setCurrentTime(seekTo);
- return true;
- }
- waiting_() {
- if (this.techWaiting_()) {
- return;
- }
- const currentTime = this.tech_.currentTime();
- const buffered = this.tech_.buffered();
- const currentRange = findRange$1(buffered, currentTime);
- if (currentRange.length && currentTime + 3 <= currentRange.end(0)) {
- this.resetTimeUpdate_();
- this.tech_.setCurrentTime(currentTime);
- this.logger_(`Stopped at ${currentTime} while inside a buffered region [${currentRange.start(0)} -> ${currentRange.end(0)}]. Attempting to resume playback by seeking to the current time.`);
- this.tech_.trigger({
- type: "usage",
- name: "vhs-unknown-waiting"
- });
- return;
- }
- }
- techWaiting_() {
- const seekable3 = this.seekable();
- const currentTime = this.tech_.currentTime();
- if (this.tech_.seeking()) {
- return true;
- }
- if (this.beforeSeekableWindow_(seekable3, currentTime)) {
- const livePoint = seekable3.end(seekable3.length - 1);
- this.logger_(`Fell out of live window at time ${currentTime}. Seeking to live point (seekable end) ${livePoint}`);
- this.resetTimeUpdate_();
- this.tech_.setCurrentTime(livePoint);
- this.tech_.trigger({
- type: "usage",
- name: "vhs-live-resync"
- });
- return true;
- }
- const sourceUpdater = this.tech_.vhs.playlistController_.sourceUpdater_;
- const buffered = this.tech_.buffered();
- const videoUnderflow = this.videoUnderflow_({
- audioBuffered: sourceUpdater.audioBuffered(),
- videoBuffered: sourceUpdater.videoBuffered(),
- currentTime
- });
- if (videoUnderflow) {
- this.resetTimeUpdate_();
- this.tech_.setCurrentTime(currentTime);
- this.tech_.trigger({
- type: "usage",
- name: "vhs-video-underflow"
- });
- return true;
- }
- const nextRange = findNextRange$1(buffered, currentTime);
- if (nextRange.length > 0) {
- this.logger_(`Stopped at ${currentTime} and seeking to ${nextRange.start(0)}`);
- this.resetTimeUpdate_();
- this.skipTheGap_(currentTime);
- return true;
- }
- return false;
- }
- afterSeekableWindow_(seekable3, currentTime, playlist, allowSeeksWithinUnsafeLiveWindow = false) {
- if (!seekable3.length) {
- return false;
- }
- let allowedEnd = seekable3.end(seekable3.length - 1) + SAFE_TIME_DELTA$1;
- const isLive = !playlist.endList;
- if (isLive && allowSeeksWithinUnsafeLiveWindow) {
- allowedEnd = seekable3.end(seekable3.length - 1) + playlist.targetDuration * 3;
- }
- if (currentTime > allowedEnd) {
- return true;
- }
- return false;
- }
- beforeSeekableWindow_(seekable3, currentTime) {
- if (seekable3.length && seekable3.start(0) > 0 && currentTime < seekable3.start(0) - this.liveRangeSafeTimeDelta) {
- return true;
- }
- return false;
- }
- videoUnderflow_({
- videoBuffered,
- audioBuffered,
- currentTime
- }) {
- if (!videoBuffered) {
- return;
- }
- let gap;
- if (videoBuffered.length && audioBuffered.length) {
- const lastVideoRange = findRange$1(videoBuffered, currentTime - 3);
- const videoRange = findRange$1(videoBuffered, currentTime);
- const audioRange = findRange$1(audioBuffered, currentTime);
- if (audioRange.length && !videoRange.length && lastVideoRange.length) {
- gap = {
- start: lastVideoRange.end(0),
- end: audioRange.end(0)
- };
- }
- } else {
- const nextRange = findNextRange$1(videoBuffered, currentTime);
- if (!nextRange.length) {
- gap = this.gapFromVideoUnderflow_(videoBuffered, currentTime);
- }
- }
- if (gap) {
- this.logger_(`Encountered a gap in video from ${gap.start} to ${gap.end}. Seeking to current time ${currentTime}`);
- return true;
- }
- return false;
- }
- skipTheGap_(scheduledCurrentTime) {
- const buffered = this.tech_.buffered();
- const currentTime = this.tech_.currentTime();
- const nextRange = findNextRange$1(buffered, currentTime);
- this.resetTimeUpdate_();
- if (nextRange.length === 0 || currentTime !== scheduledCurrentTime) {
- return;
- }
- this.logger_("skipTheGap_:", "currentTime:", currentTime, "scheduled currentTime:", scheduledCurrentTime, "nextRange start:", nextRange.start(0));
- this.tech_.setCurrentTime(nextRange.start(0) + TIME_FUDGE_FACTOR$1);
- this.tech_.trigger({
- type: "usage",
- name: "vhs-gap-skip"
- });
- }
- gapFromVideoUnderflow_(buffered, currentTime) {
- const gaps = findGaps$1(buffered);
- for (let i2 = 0; i2 < gaps.length; i2++) {
- const start2 = gaps.start(i2);
- const end = gaps.end(i2);
- if (currentTime - start2 < 4 && currentTime - start2 > 2) {
- return {
- start: start2,
- end
- };
- }
- }
- return null;
- }
- }
- const defaultOptions$1 = {
- errorInterval: 30,
- getSource(next) {
- const tech = this.tech({
- IWillNotUseThisInPlugins: true
- });
- const sourceObj = tech.currentSource_ || this.currentSource();
- return next(sourceObj);
- }
- };
- const initPlugin$2 = function(player, options2) {
- let lastCalled = 0;
- let seekTo = 0;
- const localOptions = merge$2(defaultOptions$1, options2);
- player.ready(() => {
- player.trigger({
- type: "usage",
- name: "vhs-error-reload-initialized"
- });
- });
- const loadedMetadataHandler = function() {
- if (seekTo) {
- player.currentTime(seekTo);
- }
- };
- const setSource2 = function(sourceObj) {
- if (sourceObj === null || sourceObj === void 0) {
- return;
- }
- seekTo = player.duration() !== Infinity && player.currentTime() || 0;
- player.one("loadedmetadata", loadedMetadataHandler);
- player.src(sourceObj);
- player.trigger({
- type: "usage",
- name: "vhs-error-reload"
- });
- player.play();
- };
- const errorHandler = function() {
- if (Date.now() - lastCalled < localOptions.errorInterval * 1e3) {
- player.trigger({
- type: "usage",
- name: "vhs-error-reload-canceled"
- });
- return;
- }
- if (!localOptions.getSource || typeof localOptions.getSource !== "function") {
- videojs$2.log.error("ERROR: reloadSourceOnError - The option getSource must be a function!");
- return;
- }
- lastCalled = Date.now();
- return localOptions.getSource.call(player, setSource2);
- };
- const cleanupEvents = function() {
- player.off("loadedmetadata", loadedMetadataHandler);
- player.off("error", errorHandler);
- player.off("dispose", cleanupEvents);
- };
- const reinitPlugin = function(newOptions) {
- cleanupEvents();
- initPlugin$2(player, newOptions);
- };
- player.on("error", errorHandler);
- player.on("dispose", cleanupEvents);
- player.reloadSourceOnError = reinitPlugin;
- };
- const reloadSourceOnError$1 = function(options2) {
- initPlugin$2(this, options2);
- };
- var version$4$1 = "3.0.2";
- var version$3$1 = "6.3.0";
- var version$2$1 = "1.0.1";
- var version$1$2 = "6.0.0";
- var version$7 = "4.0.1";
- const Vhs$2 = {
- PlaylistLoader: PlaylistLoader$1,
- Playlist: Playlist$1,
- utils: utils$1,
- STANDARD_PLAYLIST_SELECTOR: lastBandwidthSelector$1,
- INITIAL_PLAYLIST_SELECTOR: lowestBitrateCompatibleVariantSelector$1,
- lastBandwidthSelector: lastBandwidthSelector$1,
- movingAverageBandwidthSelector: movingAverageBandwidthSelector$1,
- comparePlaylistBandwidth: comparePlaylistBandwidth$1,
- comparePlaylistResolution: comparePlaylistResolution$1,
- xhr: xhrFactory$1()
- };
- Object.keys(Config$1).forEach((prop) => {
- Object.defineProperty(Vhs$2, prop, {
- get() {
- videojs$2.log.warn(`using Vhs.${prop} is UNSAFE be sure you know what you are doing`);
- return Config$1[prop];
- },
- set(value) {
- videojs$2.log.warn(`using Vhs.${prop} is UNSAFE be sure you know what you are doing`);
- if (typeof value !== "number" || value < 0) {
- videojs$2.log.warn(`value of Vhs.${prop} must be greater than or equal to 0`);
- return;
- }
- Config$1[prop] = value;
- }
- });
- });
- const LOCAL_STORAGE_KEY$2 = "videojs-vhs";
- const handleVhsMediaChange$1 = function(qualityLevels2, playlistLoader) {
- const newPlaylist = playlistLoader.media();
- let selectedIndex = -1;
- for (let i2 = 0; i2 < qualityLevels2.length; i2++) {
- if (qualityLevels2[i2].id === newPlaylist.id) {
- selectedIndex = i2;
- break;
- }
- }
- qualityLevels2.selectedIndex_ = selectedIndex;
- qualityLevels2.trigger({
- selectedIndex,
- type: "change"
- });
- };
- const handleVhsLoadedMetadata$1 = function(qualityLevels2, vhs) {
- vhs.representations().forEach((rep2) => {
- qualityLevels2.addQualityLevel(rep2);
- });
- handleVhsMediaChange$1(qualityLevels2, vhs.playlists);
- };
- Vhs$2.canPlaySource = function() {
- return videojs$2.log.warn("VHS is no longer a tech. Please remove it from your player's techOrder.");
- };
- const emeKeySystems$1 = (keySystemOptions, mainPlaylist, audioPlaylist) => {
- if (!keySystemOptions) {
- return keySystemOptions;
- }
- let codecs = {};
- if (mainPlaylist && mainPlaylist.attributes && mainPlaylist.attributes.CODECS) {
- codecs = unwrapCodecList$1(parseCodecs$1(mainPlaylist.attributes.CODECS));
- }
- if (audioPlaylist && audioPlaylist.attributes && audioPlaylist.attributes.CODECS) {
- codecs.audio = audioPlaylist.attributes.CODECS;
- }
- const videoContentType = getMimeForCodec$1(codecs.video);
- const audioContentType = getMimeForCodec$1(codecs.audio);
- const keySystemContentTypes = {};
- for (const keySystem in keySystemOptions) {
- keySystemContentTypes[keySystem] = {};
- if (audioContentType) {
- keySystemContentTypes[keySystem].audioContentType = audioContentType;
- }
- if (videoContentType) {
- keySystemContentTypes[keySystem].videoContentType = videoContentType;
- }
- if (mainPlaylist.contentProtection && mainPlaylist.contentProtection[keySystem] && mainPlaylist.contentProtection[keySystem].pssh) {
- keySystemContentTypes[keySystem].pssh = mainPlaylist.contentProtection[keySystem].pssh;
- }
- if (typeof keySystemOptions[keySystem] === "string") {
- keySystemContentTypes[keySystem].url = keySystemOptions[keySystem];
- }
- }
- return merge$2(keySystemOptions, keySystemContentTypes);
- };
- const getAllPsshKeySystemsOptions$1 = (playlists, keySystems) => {
- return playlists.reduce((keySystemsArr, playlist) => {
- if (!playlist.contentProtection) {
- return keySystemsArr;
- }
- const keySystemsOptions = keySystems.reduce((keySystemsObj, keySystem) => {
- const keySystemOptions = playlist.contentProtection[keySystem];
- if (keySystemOptions && keySystemOptions.pssh) {
- keySystemsObj[keySystem] = {
- pssh: keySystemOptions.pssh
- };
- }
- return keySystemsObj;
- }, {});
- if (Object.keys(keySystemsOptions).length) {
- keySystemsArr.push(keySystemsOptions);
- }
- return keySystemsArr;
- }, []);
- };
- const waitForKeySessionCreation$1 = ({
- player,
- sourceKeySystems,
- audioMedia,
- mainPlaylists
- }) => {
- if (!player.eme.initializeMediaKeys) {
- return Promise.resolve();
- }
- const playlists = audioMedia ? mainPlaylists.concat([audioMedia]) : mainPlaylists;
- const keySystemsOptionsArr = getAllPsshKeySystemsOptions$1(playlists, Object.keys(sourceKeySystems));
- const initializationFinishedPromises = [];
- const keySessionCreatedPromises = [];
- keySystemsOptionsArr.forEach((keySystemsOptions) => {
- keySessionCreatedPromises.push(new Promise((resolve2, reject2) => {
- player.tech_.one("keysessioncreated", resolve2);
- }));
- initializationFinishedPromises.push(new Promise((resolve2, reject2) => {
- player.eme.initializeMediaKeys({
- keySystems: keySystemsOptions
- }, (err) => {
- if (err) {
- reject2(err);
- return;
- }
- resolve2();
- });
- }));
- });
- return Promise.race([
- Promise.all(initializationFinishedPromises),
- Promise.race(keySessionCreatedPromises)
- ]);
- };
- const setupEmeOptions$1 = ({
- player,
- sourceKeySystems,
- media,
- audioMedia
- }) => {
- const sourceOptions = emeKeySystems$1(sourceKeySystems, media, audioMedia);
- if (!sourceOptions) {
- return false;
- }
- player.currentSource().keySystems = sourceOptions;
- if (sourceOptions && !player.eme) {
- videojs$2.log.warn("DRM encrypted source cannot be decrypted without a DRM plugin");
- return false;
- }
- return true;
- };
- const getVhsLocalStorage$1 = () => {
- if (!window_1.localStorage) {
- return null;
- }
- const storedObject = window_1.localStorage.getItem(LOCAL_STORAGE_KEY$2);
- if (!storedObject) {
- return null;
- }
- try {
- return JSON.parse(storedObject);
- } catch (e) {
- return null;
- }
- };
- const updateVhsLocalStorage$1 = (options2) => {
- if (!window_1.localStorage) {
- return false;
- }
- let objectToStore = getVhsLocalStorage$1();
- objectToStore = objectToStore ? merge$2(objectToStore, options2) : options2;
- try {
- window_1.localStorage.setItem(LOCAL_STORAGE_KEY$2, JSON.stringify(objectToStore));
- } catch (e) {
- return false;
- }
- return objectToStore;
- };
- const expandDataUri$1 = (dataUri) => {
- if (dataUri.toLowerCase().indexOf("data:application/vnd.videojs.vhs+json,") === 0) {
- return JSON.parse(dataUri.substring(dataUri.indexOf(",") + 1));
- }
- return dataUri;
- };
- Vhs$2.supportsNativeHls = function() {
- if (!document_1 || !document_1.createElement) {
- return false;
- }
- const video = document_1.createElement("video");
- if (!videojs$2.getTech("Html5").isSupported()) {
- return false;
- }
- const canPlay = [
- "application/vnd.apple.mpegurl",
- "audio/mpegurl",
- "audio/x-mpegurl",
- "application/x-mpegurl",
- "video/x-mpegurl",
- "video/mpegurl",
- "application/mpegurl"
- ];
- return canPlay.some(function(canItPlay) {
- return /maybe|probably/i.test(video.canPlayType(canItPlay));
- });
- }();
- Vhs$2.supportsNativeDash = function() {
- if (!document_1 || !document_1.createElement || !videojs$2.getTech("Html5").isSupported()) {
- return false;
- }
- return /maybe|probably/i.test(document_1.createElement("video").canPlayType("application/dash+xml"));
- }();
- Vhs$2.supportsTypeNatively = (type2) => {
- if (type2 === "hls") {
- return Vhs$2.supportsNativeHls;
- }
- if (type2 === "dash") {
- return Vhs$2.supportsNativeDash;
- }
- return false;
- };
- Vhs$2.isSupported = function() {
- return videojs$2.log.warn("VHS is no longer a tech. Please remove it from your player's techOrder.");
- };
- const Component$2 = videojs$2.getComponent("Component");
- class VhsHandler$1 extends Component$2 {
- constructor(source, tech, options2) {
- super(tech, options2.vhs);
- if (typeof options2.initialBandwidth === "number") {
- this.options_.bandwidth = options2.initialBandwidth;
- }
- this.logger_ = logger$1("VhsHandler");
- if (tech.options_ && tech.options_.playerId) {
- const _player = videojs$2.getPlayer(tech.options_.playerId);
- this.player_ = _player;
- }
- this.tech_ = tech;
- this.source_ = source;
- this.stats = {};
- this.ignoreNextSeekingEvent_ = false;
- this.setOptions_();
- if (this.options_.overrideNative && tech.overrideNativeAudioTracks && tech.overrideNativeVideoTracks) {
- tech.overrideNativeAudioTracks(true);
- tech.overrideNativeVideoTracks(true);
- } else if (this.options_.overrideNative && (tech.featuresNativeVideoTracks || tech.featuresNativeAudioTracks)) {
- throw new Error("Overriding native VHS requires emulated tracks. See https://git.io/vMpjB");
- }
- this.on(document_1, ["fullscreenchange", "webkitfullscreenchange", "mozfullscreenchange", "MSFullscreenChange"], (event2) => {
- const fullscreenElement = document_1.fullscreenElement || document_1.webkitFullscreenElement || document_1.mozFullScreenElement || document_1.msFullscreenElement;
- if (fullscreenElement && fullscreenElement.contains(this.tech_.el())) {
- this.playlistController_.fastQualityChange_();
- } else {
- this.playlistController_.checkABR_();
- }
- });
- this.on(this.tech_, "seeking", function() {
- if (this.ignoreNextSeekingEvent_) {
- this.ignoreNextSeekingEvent_ = false;
- return;
- }
- this.setCurrentTime(this.tech_.currentTime());
- });
- this.on(this.tech_, "error", function() {
- if (this.tech_.error() && this.playlistController_) {
- this.playlistController_.pauseLoading();
- }
- });
- this.on(this.tech_, "play", this.play);
- }
- setOptions_() {
- this.options_.withCredentials = this.options_.withCredentials || false;
- this.options_.limitRenditionByPlayerDimensions = this.options_.limitRenditionByPlayerDimensions === false ? false : true;
- this.options_.useDevicePixelRatio = this.options_.useDevicePixelRatio || false;
- this.options_.useBandwidthFromLocalStorage = typeof this.source_.useBandwidthFromLocalStorage !== "undefined" ? this.source_.useBandwidthFromLocalStorage : this.options_.useBandwidthFromLocalStorage || false;
- this.options_.useNetworkInformationApi = this.options_.useNetworkInformationApi || false;
- this.options_.useDtsForTimestampOffset = this.options_.useDtsForTimestampOffset || false;
- this.options_.customTagParsers = this.options_.customTagParsers || [];
- this.options_.customTagMappers = this.options_.customTagMappers || [];
- this.options_.cacheEncryptionKeys = this.options_.cacheEncryptionKeys || false;
- this.options_.llhls = this.options_.llhls === false ? false : true;
- this.options_.bufferBasedABR = this.options_.bufferBasedABR || false;
- if (typeof this.options_.playlistExclusionDuration !== "number") {
- this.options_.playlistExclusionDuration = 5 * 60;
- }
- if (typeof this.options_.bandwidth !== "number") {
- if (this.options_.useBandwidthFromLocalStorage) {
- const storedObject = getVhsLocalStorage$1();
- if (storedObject && storedObject.bandwidth) {
- this.options_.bandwidth = storedObject.bandwidth;
- this.tech_.trigger({
- type: "usage",
- name: "vhs-bandwidth-from-local-storage"
- });
- }
- if (storedObject && storedObject.throughput) {
- this.options_.throughput = storedObject.throughput;
- this.tech_.trigger({
- type: "usage",
- name: "vhs-throughput-from-local-storage"
- });
- }
- }
- }
- if (typeof this.options_.bandwidth !== "number") {
- this.options_.bandwidth = Config$1.INITIAL_BANDWIDTH;
- }
- this.options_.enableLowInitialPlaylist = this.options_.enableLowInitialPlaylist && this.options_.bandwidth === Config$1.INITIAL_BANDWIDTH;
- ["withCredentials", "useDevicePixelRatio", "limitRenditionByPlayerDimensions", "bandwidth", "customTagParsers", "customTagMappers", "cacheEncryptionKeys", "playlistSelector", "initialPlaylistSelector", "bufferBasedABR", "liveRangeSafeTimeDelta", "llhls", "useNetworkInformationApi", "useDtsForTimestampOffset", "exactManifestTimings", "leastPixelDiffSelector"].forEach((option) => {
- if (typeof this.source_[option] !== "undefined") {
- this.options_[option] = this.source_[option];
- }
- });
- this.limitRenditionByPlayerDimensions = this.options_.limitRenditionByPlayerDimensions;
- this.useDevicePixelRatio = this.options_.useDevicePixelRatio;
- }
- src(src, type2) {
- if (!src) {
- return;
- }
- this.setOptions_();
- this.options_.src = expandDataUri$1(this.source_.src);
- this.options_.tech = this.tech_;
- this.options_.externVhs = Vhs$2;
- this.options_.sourceType = simpleTypeFromSourceType$1(type2);
- this.options_.seekTo = (time) => {
- this.tech_.setCurrentTime(time);
- };
- this.playlistController_ = new PlaylistController(this.options_);
- const playbackWatcherOptions = merge$2({
- liveRangeSafeTimeDelta: SAFE_TIME_DELTA$1
- }, this.options_, {
- seekable: () => this.seekable(),
- media: () => this.playlistController_.media(),
- playlistController: this.playlistController_
- });
- this.playbackWatcher_ = new PlaybackWatcher$1(playbackWatcherOptions);
- this.playlistController_.on("error", () => {
- const player = videojs$2.players[this.tech_.options_.playerId];
- let error = this.playlistController_.error;
- if (typeof error === "object" && !error.code) {
- error.code = 3;
- } else if (typeof error === "string") {
- error = {
- message: error,
- code: 3
- };
- }
- player.error(error);
- });
- const defaultSelector = this.options_.bufferBasedABR ? Vhs$2.movingAverageBandwidthSelector(0.55) : Vhs$2.STANDARD_PLAYLIST_SELECTOR;
- this.playlistController_.selectPlaylist = this.selectPlaylist ? this.selectPlaylist.bind(this) : defaultSelector.bind(this);
- this.playlistController_.selectInitialPlaylist = Vhs$2.INITIAL_PLAYLIST_SELECTOR.bind(this);
- this.playlists = this.playlistController_.mainPlaylistLoader_;
- this.mediaSource = this.playlistController_.mediaSource;
- Object.defineProperties(this, {
- selectPlaylist: {
- get() {
- return this.playlistController_.selectPlaylist;
- },
- set(selectPlaylist) {
- this.playlistController_.selectPlaylist = selectPlaylist.bind(this);
- }
- },
- throughput: {
- get() {
- return this.playlistController_.mainSegmentLoader_.throughput.rate;
- },
- set(throughput) {
- this.playlistController_.mainSegmentLoader_.throughput.rate = throughput;
- this.playlistController_.mainSegmentLoader_.throughput.count = 1;
- }
- },
- bandwidth: {
- get() {
- let playerBandwidthEst = this.playlistController_.mainSegmentLoader_.bandwidth;
- const networkInformation = window_1.navigator.connection || window_1.navigator.mozConnection || window_1.navigator.webkitConnection;
- const tenMbpsAsBitsPerSecond = 1e7;
- if (this.options_.useNetworkInformationApi && networkInformation) {
- const networkInfoBandwidthEstBitsPerSec = networkInformation.downlink * 1e3 * 1e3;
- if (networkInfoBandwidthEstBitsPerSec >= tenMbpsAsBitsPerSecond && playerBandwidthEst >= tenMbpsAsBitsPerSecond) {
- playerBandwidthEst = Math.max(playerBandwidthEst, networkInfoBandwidthEstBitsPerSec);
- } else {
- playerBandwidthEst = networkInfoBandwidthEstBitsPerSec;
- }
- }
- return playerBandwidthEst;
- },
- set(bandwidth2) {
- this.playlistController_.mainSegmentLoader_.bandwidth = bandwidth2;
- this.playlistController_.mainSegmentLoader_.throughput = {
- rate: 0,
- count: 0
- };
- }
- },
- systemBandwidth: {
- get() {
- const invBandwidth = 1 / (this.bandwidth || 1);
- let invThroughput;
- if (this.throughput > 0) {
- invThroughput = 1 / this.throughput;
- } else {
- invThroughput = 0;
- }
- const systemBitrate = Math.floor(1 / (invBandwidth + invThroughput));
- return systemBitrate;
- },
- set() {
- videojs$2.log.error('The "systemBandwidth" property is read-only');
- }
- }
- });
- if (this.options_.bandwidth) {
- this.bandwidth = this.options_.bandwidth;
- }
- if (this.options_.throughput) {
- this.throughput = this.options_.throughput;
- }
- Object.defineProperties(this.stats, {
- bandwidth: {
- get: () => this.bandwidth || 0,
- enumerable: true
- },
- mediaRequests: {
- get: () => this.playlistController_.mediaRequests_() || 0,
- enumerable: true
- },
- mediaRequestsAborted: {
- get: () => this.playlistController_.mediaRequestsAborted_() || 0,
- enumerable: true
- },
- mediaRequestsTimedout: {
- get: () => this.playlistController_.mediaRequestsTimedout_() || 0,
- enumerable: true
- },
- mediaRequestsErrored: {
- get: () => this.playlistController_.mediaRequestsErrored_() || 0,
- enumerable: true
- },
- mediaTransferDuration: {
- get: () => this.playlistController_.mediaTransferDuration_() || 0,
- enumerable: true
- },
- mediaBytesTransferred: {
- get: () => this.playlistController_.mediaBytesTransferred_() || 0,
- enumerable: true
- },
- mediaSecondsLoaded: {
- get: () => this.playlistController_.mediaSecondsLoaded_() || 0,
- enumerable: true
- },
- mediaAppends: {
- get: () => this.playlistController_.mediaAppends_() || 0,
- enumerable: true
- },
- mainAppendsToLoadedData: {
- get: () => this.playlistController_.mainAppendsToLoadedData_() || 0,
- enumerable: true
- },
- audioAppendsToLoadedData: {
- get: () => this.playlistController_.audioAppendsToLoadedData_() || 0,
- enumerable: true
- },
- appendsToLoadedData: {
- get: () => this.playlistController_.appendsToLoadedData_() || 0,
- enumerable: true
- },
- timeToLoadedData: {
- get: () => this.playlistController_.timeToLoadedData_() || 0,
- enumerable: true
- },
- buffered: {
- get: () => timeRangesToArray$1(this.tech_.buffered()),
- enumerable: true
- },
- currentTime: {
- get: () => this.tech_.currentTime(),
- enumerable: true
- },
- currentSource: {
- get: () => this.tech_.currentSource_,
- enumerable: true
- },
- currentTech: {
- get: () => this.tech_.name_,
- enumerable: true
- },
- duration: {
- get: () => this.tech_.duration(),
- enumerable: true
- },
- main: {
- get: () => this.playlists.main,
- enumerable: true
- },
- playerDimensions: {
- get: () => this.tech_.currentDimensions(),
- enumerable: true
- },
- seekable: {
- get: () => timeRangesToArray$1(this.tech_.seekable()),
- enumerable: true
- },
- timestamp: {
- get: () => Date.now(),
- enumerable: true
- },
- videoPlaybackQuality: {
- get: () => this.tech_.getVideoPlaybackQuality(),
- enumerable: true
- }
- });
- this.tech_.one("canplay", this.playlistController_.setupFirstPlay.bind(this.playlistController_));
- this.tech_.on("bandwidthupdate", () => {
- if (this.options_.useBandwidthFromLocalStorage) {
- updateVhsLocalStorage$1({
- bandwidth: this.bandwidth,
- throughput: Math.round(this.throughput)
- });
- }
- });
- this.playlistController_.on("selectedinitialmedia", () => {
- renditionSelectionMixin$1(this);
- });
- this.playlistController_.sourceUpdater_.on("createdsourcebuffers", () => {
- this.setupEme_();
- });
- this.on(this.playlistController_, "progress", function() {
- this.tech_.trigger("progress");
- });
- this.on(this.playlistController_, "firstplay", function() {
- this.ignoreNextSeekingEvent_ = true;
- });
- this.setupQualityLevels_();
- if (!this.tech_.el()) {
- return;
- }
- this.mediaSourceUrl_ = window_1.URL.createObjectURL(this.playlistController_.mediaSource);
- this.tech_.src(this.mediaSourceUrl_);
- }
- createKeySessions_() {
- const audioPlaylistLoader = this.playlistController_.mediaTypes_.AUDIO.activePlaylistLoader;
- this.logger_("waiting for EME key session creation");
- waitForKeySessionCreation$1({
- player: this.player_,
- sourceKeySystems: this.source_.keySystems,
- audioMedia: audioPlaylistLoader && audioPlaylistLoader.media(),
- mainPlaylists: this.playlists.main.playlists
- }).then(() => {
- this.logger_("created EME key session");
- this.playlistController_.sourceUpdater_.initializedEme();
- }).catch((err) => {
- this.logger_("error while creating EME key session", err);
- this.player_.error({
- message: "Failed to initialize media keys for EME",
- code: 3
- });
- });
- }
- handleWaitingForKey_() {
- this.logger_("waitingforkey fired, attempting to create any new key sessions");
- this.createKeySessions_();
- }
- setupEme_() {
- const audioPlaylistLoader = this.playlistController_.mediaTypes_.AUDIO.activePlaylistLoader;
- const didSetupEmeOptions = setupEmeOptions$1({
- player: this.player_,
- sourceKeySystems: this.source_.keySystems,
- media: this.playlists.media(),
- audioMedia: audioPlaylistLoader && audioPlaylistLoader.media()
- });
- this.player_.tech_.on("keystatuschange", (e) => {
- if (e.status !== "output-restricted") {
- return;
- }
- const mainPlaylist = this.playlistController_.main();
- if (!mainPlaylist || !mainPlaylist.playlists) {
- return;
- }
- const excludedHDPlaylists = [];
- mainPlaylist.playlists.forEach((playlist) => {
- if (playlist && playlist.attributes && playlist.attributes.RESOLUTION && playlist.attributes.RESOLUTION.height >= 720) {
- if (!playlist.excludeUntil || playlist.excludeUntil < Infinity) {
- playlist.excludeUntil = Infinity;
- excludedHDPlaylists.push(playlist);
- }
- }
- });
- if (excludedHDPlaylists.length) {
- videojs$2.log.warn('DRM keystatus changed to "output-restricted." Removing the following HD playlists that will most likely fail to play and clearing the buffer. This may be due to HDCP restrictions on the stream and the capabilities of the current device.', ...excludedHDPlaylists);
- this.playlistController_.fastQualityChange_();
- }
- });
- this.handleWaitingForKey_ = this.handleWaitingForKey_.bind(this);
- this.player_.tech_.on("waitingforkey", this.handleWaitingForKey_);
- if (videojs$2.browser.IE_VERSION === 11 || !didSetupEmeOptions) {
- this.playlistController_.sourceUpdater_.initializedEme();
- return;
- }
- this.createKeySessions_();
- }
- setupQualityLevels_() {
- const player = videojs$2.players[this.tech_.options_.playerId];
- if (!player || !player.qualityLevels || this.qualityLevels_) {
- return;
- }
- this.qualityLevels_ = player.qualityLevels();
- this.playlistController_.on("selectedinitialmedia", () => {
- handleVhsLoadedMetadata$1(this.qualityLevels_, this);
- });
- this.playlists.on("mediachange", () => {
- handleVhsMediaChange$1(this.qualityLevels_, this.playlists);
- });
- }
- static version() {
- return {
- "@videojs/http-streaming": version$4$1,
- "mux.js": version$3$1,
- "mpd-parser": version$2$1,
- "m3u8-parser": version$1$2,
- "aes-decrypter": version$7
- };
- }
- version() {
- return this.constructor.version();
- }
- canChangeType() {
- return SourceUpdater$1.canChangeType();
- }
- play() {
- this.playlistController_.play();
- }
- setCurrentTime(currentTime) {
- this.playlistController_.setCurrentTime(currentTime);
- }
- duration() {
- return this.playlistController_.duration();
- }
- seekable() {
- return this.playlistController_.seekable();
- }
- dispose() {
- if (this.playbackWatcher_) {
- this.playbackWatcher_.dispose();
- }
- if (this.playlistController_) {
- this.playlistController_.dispose();
- }
- if (this.qualityLevels_) {
- this.qualityLevels_.dispose();
- }
- if (this.tech_ && this.tech_.vhs) {
- delete this.tech_.vhs;
- }
- if (this.mediaSourceUrl_ && window_1.URL.revokeObjectURL) {
- window_1.URL.revokeObjectURL(this.mediaSourceUrl_);
- this.mediaSourceUrl_ = null;
- }
- if (this.tech_) {
- this.tech_.off("waitingforkey", this.handleWaitingForKey_);
- }
- super.dispose();
- }
- convertToProgramTime(time, callback2) {
- return getProgramTime$1({
- playlist: this.playlistController_.media(),
- time,
- callback: callback2
- });
- }
- seekToProgramTime(programTime, callback2, pauseAfterSeek = true, retryCount = 2) {
- return seekToProgramTime$1({
- programTime,
- playlist: this.playlistController_.media(),
- retryCount,
- pauseAfterSeek,
- seekTo: this.options_.seekTo,
- tech: this.options_.tech,
- callback: callback2
- });
- }
- }
- const VhsSourceHandler$1 = {
- name: "videojs-http-streaming",
- VERSION: version$4$1,
- canHandleSource(srcObj, options2 = {}) {
- const localOptions = merge$2(videojs$2.options, options2);
- return VhsSourceHandler$1.canPlayType(srcObj.type, localOptions);
- },
- handleSource(source, tech, options2 = {}) {
- const localOptions = merge$2(videojs$2.options, options2);
- tech.vhs = new VhsHandler$1(source, tech, localOptions);
- tech.vhs.xhr = xhrFactory$1();
- tech.vhs.src(source.src, source.type);
- return tech.vhs;
- },
- canPlayType(type2, options2) {
- const simpleType = simpleTypeFromSourceType$1(type2);
- if (!simpleType) {
- return "";
- }
- const overrideNative = VhsSourceHandler$1.getOverrideNative(options2);
- const supportsTypeNatively = Vhs$2.supportsTypeNatively(simpleType);
- const canUseMsePlayback = !supportsTypeNatively || overrideNative;
- return canUseMsePlayback ? "maybe" : "";
- },
- getOverrideNative(options2 = {}) {
- const {
- vhs = {}
- } = options2;
- const defaultOverrideNative = !(videojs$2.browser.IS_ANY_SAFARI || videojs$2.browser.IS_IOS);
- const {
- overrideNative = defaultOverrideNative
- } = vhs;
- return overrideNative;
- }
- };
- const supportsNativeMediaSources$1 = () => {
- return browserSupportsCodec$1("avc1.4d400d,mp4a.40.2");
- };
- if (supportsNativeMediaSources$1()) {
- videojs$2.getTech("Html5").registerSourceHandler(VhsSourceHandler$1, 0);
- }
- videojs$2.VhsHandler = VhsHandler$1;
- videojs$2.VhsSourceHandler = VhsSourceHandler$1;
- videojs$2.Vhs = Vhs$2;
- if (!videojs$2.use) {
- videojs$2.registerComponent("Vhs", Vhs$2);
- }
- videojs$2.options.vhs = videojs$2.options.vhs || {};
- if (!videojs$2.getPlugin || !videojs$2.getPlugin("reloadSourceOnError")) {
- videojs$2.registerPlugin("reloadSourceOnError", reloadSourceOnError$1);
- }
- var videoJs = "";
- function _assertThisInitialized(self2) {
- if (self2 === void 0) {
- throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
- }
- return self2;
- }
- function _setPrototypeOf(o, p) {
- _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf2(o2, p2) {
- o2.__proto__ = p2;
- return o2;
- };
- return _setPrototypeOf(o, p);
- }
- function _inheritsLoose(subClass, superClass) {
- subClass.prototype = Object.create(superClass.prototype);
- subClass.prototype.constructor = subClass;
- _setPrototypeOf(subClass, superClass);
- }
- function _isNativeReflectConstruct() {
- if (typeof Reflect === "undefined" || !Reflect.construct)
- return false;
- if (Reflect.construct.sham)
- return false;
- if (typeof Proxy === "function")
- return true;
- try {
- Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function() {
- }));
- return true;
- } catch (e) {
- return false;
- }
- }
- function _construct(Parent, args, Class) {
- if (_isNativeReflectConstruct()) {
- _construct = Reflect.construct.bind();
- } else {
- _construct = function _construct2(Parent2, args2, Class2) {
- var a = [null];
- a.push.apply(a, args2);
- var Constructor = Function.bind.apply(Parent2, a);
- var instance = new Constructor();
- if (Class2)
- _setPrototypeOf(instance, Class2.prototype);
- return instance;
- };
- }
- return _construct.apply(null, arguments);
- }
- function _inherits(subClass, superClass) {
- if (typeof superClass !== "function" && superClass !== null) {
- throw new TypeError("Super expression must either be null or a function");
- }
- subClass.prototype = Object.create(superClass && superClass.prototype, {
- constructor: {
- value: subClass,
- writable: true,
- configurable: true
- }
- });
- Object.defineProperty(subClass, "prototype", {
- writable: false
- });
- if (superClass)
- _setPrototypeOf(subClass, superClass);
- }
- var DEFAULT_LOCATION = "http://example.com";
- var resolveUrl$1 = function resolveUrl3(baseUrl, relativeUrl) {
- if (/^[a-z]+:/i.test(relativeUrl)) {
- return relativeUrl;
- }
- if (/^data:/.test(baseUrl)) {
- baseUrl = window_1.location && window_1.location.href || "";
- }
- var nativeURL = typeof window_1.URL === "function";
- var protocolLess = /^\/\//.test(baseUrl);
- var removeLocation = !window_1.location && !/\/\//i.test(baseUrl);
- if (nativeURL) {
- baseUrl = new window_1.URL(baseUrl, window_1.location || DEFAULT_LOCATION);
- } else if (!/\/\//i.test(baseUrl)) {
- baseUrl = URLToolkit.buildAbsoluteURL(window_1.location && window_1.location.href || "", baseUrl);
- }
- if (nativeURL) {
- var newUrl = new URL(relativeUrl, baseUrl);
- if (removeLocation) {
- return newUrl.href.slice(DEFAULT_LOCATION.length);
- } else if (protocolLess) {
- return newUrl.href.slice(newUrl.protocol.length);
- }
- return newUrl.href;
- }
- return URLToolkit.buildAbsoluteURL(baseUrl, relativeUrl);
- };
- var Stream = /* @__PURE__ */ function() {
- function Stream2() {
- this.listeners = {};
- }
- var _proto = Stream2.prototype;
- _proto.on = function on3(type2, listener) {
- if (!this.listeners[type2]) {
- this.listeners[type2] = [];
- }
- this.listeners[type2].push(listener);
- };
- _proto.off = function off2(type2, listener) {
- if (!this.listeners[type2]) {
- return false;
- }
- var index2 = this.listeners[type2].indexOf(listener);
- this.listeners[type2] = this.listeners[type2].slice(0);
- this.listeners[type2].splice(index2, 1);
- return index2 > -1;
- };
- _proto.trigger = function trigger2(type2) {
- var callbacks = this.listeners[type2];
- if (!callbacks) {
- return;
- }
- if (arguments.length === 2) {
- var length = callbacks.length;
- for (var i2 = 0; i2 < length; ++i2) {
- callbacks[i2].call(this, arguments[1]);
- }
- } else {
- var args = Array.prototype.slice.call(arguments, 1);
- var _length = callbacks.length;
- for (var _i = 0; _i < _length; ++_i) {
- callbacks[_i].apply(this, args);
- }
- }
- };
- _proto.dispose = function dispose() {
- this.listeners = {};
- };
- _proto.pipe = function pipe(destination2) {
- this.on("data", function(data) {
- destination2.push(data);
- });
- };
- return Stream2;
- }();
- var atob3 = function atob4(s) {
- return window_1.atob ? window_1.atob(s) : Buffer.from(s, "base64").toString("binary");
- };
- function decodeB64ToUint8Array(b64Text) {
- var decodedString = atob3(b64Text);
- var array = new Uint8Array(decodedString.length);
- for (var i2 = 0; i2 < decodedString.length; i2++) {
- array[i2] = decodedString.charCodeAt(i2);
- }
- return array;
- }
- /*! @name m3u8-parser @version 4.8.0 @license Apache-2.0 */
- var LineStream = /* @__PURE__ */ function(_Stream) {
- _inheritsLoose(LineStream2, _Stream);
- function LineStream2() {
- var _this;
- _this = _Stream.call(this) || this;
- _this.buffer = "";
- return _this;
- }
- var _proto = LineStream2.prototype;
- _proto.push = function push(data) {
- var nextNewline;
- this.buffer += data;
- nextNewline = this.buffer.indexOf("\n");
- for (; nextNewline > -1; nextNewline = this.buffer.indexOf("\n")) {
- this.trigger("data", this.buffer.substring(0, nextNewline));
- this.buffer = this.buffer.substring(nextNewline + 1);
- }
- };
- return LineStream2;
- }(Stream);
- var TAB = String.fromCharCode(9);
- var parseByterange = function parseByterange2(byterangeString) {
- var match = /([0-9.]*)?@?([0-9.]*)?/.exec(byterangeString || "");
- var result = {};
- if (match[1]) {
- result.length = parseInt(match[1], 10);
- }
- if (match[2]) {
- result.offset = parseInt(match[2], 10);
- }
- return result;
- };
- var attributeSeparator = function attributeSeparator2() {
- var key = "[^=]*";
- var value = '"[^"]*"|[^,]*';
- var keyvalue = "(?:" + key + ")=(?:" + value + ")";
- return new RegExp("(?:^|,)(" + keyvalue + ")");
- };
- var parseAttributes$1 = function parseAttributes(attributes) {
- var attrs = attributes.split(attributeSeparator());
- var result = {};
- var i2 = attrs.length;
- var attr;
- while (i2--) {
- if (attrs[i2] === "") {
- continue;
- }
- attr = /([^=]*)=(.*)/.exec(attrs[i2]).slice(1);
- attr[0] = attr[0].replace(/^\s+|\s+$/g, "");
- attr[1] = attr[1].replace(/^\s+|\s+$/g, "");
- attr[1] = attr[1].replace(/^['"](.*)['"]$/g, "$1");
- result[attr[0]] = attr[1];
- }
- return result;
- };
- var ParseStream = /* @__PURE__ */ function(_Stream) {
- _inheritsLoose(ParseStream2, _Stream);
- function ParseStream2() {
- var _this;
- _this = _Stream.call(this) || this;
- _this.customParsers = [];
- _this.tagMappers = [];
- return _this;
- }
- var _proto = ParseStream2.prototype;
- _proto.push = function push(line) {
- var _this2 = this;
- var match;
- var event2;
- line = line.trim();
- if (line.length === 0) {
- return;
- }
- if (line[0] !== "#") {
- this.trigger("data", {
- type: "uri",
- uri: line
- });
- return;
- }
- var newLines = this.tagMappers.reduce(function(acc, mapper) {
- var mappedLine = mapper(line);
- if (mappedLine === line) {
- return acc;
- }
- return acc.concat([mappedLine]);
- }, [line]);
- newLines.forEach(function(newLine) {
- for (var i2 = 0; i2 < _this2.customParsers.length; i2++) {
- if (_this2.customParsers[i2].call(_this2, newLine)) {
- return;
- }
- }
- if (newLine.indexOf("#EXT") !== 0) {
- _this2.trigger("data", {
- type: "comment",
- text: newLine.slice(1)
- });
- return;
- }
- newLine = newLine.replace("\r", "");
- match = /^#EXTM3U/.exec(newLine);
- if (match) {
- _this2.trigger("data", {
- type: "tag",
- tagType: "m3u"
- });
- return;
- }
- match = /^#EXTINF:?([0-9\.]*)?,?(.*)?$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "inf"
- };
- if (match[1]) {
- event2.duration = parseFloat(match[1]);
- }
- if (match[2]) {
- event2.title = match[2];
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-TARGETDURATION:?([0-9.]*)?/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "targetduration"
- };
- if (match[1]) {
- event2.duration = parseInt(match[1], 10);
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-VERSION:?([0-9.]*)?/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "version"
- };
- if (match[1]) {
- event2.version = parseInt(match[1], 10);
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-MEDIA-SEQUENCE:?(\-?[0-9.]*)?/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "media-sequence"
- };
- if (match[1]) {
- event2.number = parseInt(match[1], 10);
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-DISCONTINUITY-SEQUENCE:?(\-?[0-9.]*)?/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "discontinuity-sequence"
- };
- if (match[1]) {
- event2.number = parseInt(match[1], 10);
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-PLAYLIST-TYPE:?(.*)?$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "playlist-type"
- };
- if (match[1]) {
- event2.playlistType = match[1];
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-BYTERANGE:?(.*)?$/.exec(newLine);
- if (match) {
- event2 = _extends$2(parseByterange(match[1]), {
- type: "tag",
- tagType: "byterange"
- });
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-ALLOW-CACHE:?(YES|NO)?/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "allow-cache"
- };
- if (match[1]) {
- event2.allowed = !/NO/.test(match[1]);
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-MAP:?(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "map"
- };
- if (match[1]) {
- var attributes = parseAttributes$1(match[1]);
- if (attributes.URI) {
- event2.uri = attributes.URI;
- }
- if (attributes.BYTERANGE) {
- event2.byterange = parseByterange(attributes.BYTERANGE);
- }
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-STREAM-INF:?(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "stream-inf"
- };
- if (match[1]) {
- event2.attributes = parseAttributes$1(match[1]);
- if (event2.attributes.RESOLUTION) {
- var split2 = event2.attributes.RESOLUTION.split("x");
- var resolution = {};
- if (split2[0]) {
- resolution.width = parseInt(split2[0], 10);
- }
- if (split2[1]) {
- resolution.height = parseInt(split2[1], 10);
- }
- event2.attributes.RESOLUTION = resolution;
- }
- if (event2.attributes.BANDWIDTH) {
- event2.attributes.BANDWIDTH = parseInt(event2.attributes.BANDWIDTH, 10);
- }
- if (event2.attributes["FRAME-RATE"]) {
- event2.attributes["FRAME-RATE"] = parseFloat(event2.attributes["FRAME-RATE"]);
- }
- if (event2.attributes["PROGRAM-ID"]) {
- event2.attributes["PROGRAM-ID"] = parseInt(event2.attributes["PROGRAM-ID"], 10);
- }
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-MEDIA:?(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "media"
- };
- if (match[1]) {
- event2.attributes = parseAttributes$1(match[1]);
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-ENDLIST/.exec(newLine);
- if (match) {
- _this2.trigger("data", {
- type: "tag",
- tagType: "endlist"
- });
- return;
- }
- match = /^#EXT-X-DISCONTINUITY/.exec(newLine);
- if (match) {
- _this2.trigger("data", {
- type: "tag",
- tagType: "discontinuity"
- });
- return;
- }
- match = /^#EXT-X-PROGRAM-DATE-TIME:?(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "program-date-time"
- };
- if (match[1]) {
- event2.dateTimeString = match[1];
- event2.dateTimeObject = new Date(match[1]);
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-KEY:?(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "key"
- };
- if (match[1]) {
- event2.attributes = parseAttributes$1(match[1]);
- if (event2.attributes.IV) {
- if (event2.attributes.IV.substring(0, 2).toLowerCase() === "0x") {
- event2.attributes.IV = event2.attributes.IV.substring(2);
- }
- event2.attributes.IV = event2.attributes.IV.match(/.{8}/g);
- event2.attributes.IV[0] = parseInt(event2.attributes.IV[0], 16);
- event2.attributes.IV[1] = parseInt(event2.attributes.IV[1], 16);
- event2.attributes.IV[2] = parseInt(event2.attributes.IV[2], 16);
- event2.attributes.IV[3] = parseInt(event2.attributes.IV[3], 16);
- event2.attributes.IV = new Uint32Array(event2.attributes.IV);
- }
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-START:?(.*)$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "start"
- };
- if (match[1]) {
- event2.attributes = parseAttributes$1(match[1]);
- event2.attributes["TIME-OFFSET"] = parseFloat(event2.attributes["TIME-OFFSET"]);
- event2.attributes.PRECISE = /YES/.test(event2.attributes.PRECISE);
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-CUE-OUT-CONT:?(.*)?$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "cue-out-cont"
- };
- if (match[1]) {
- event2.data = match[1];
- } else {
- event2.data = "";
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-CUE-OUT:?(.*)?$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "cue-out"
- };
- if (match[1]) {
- event2.data = match[1];
- } else {
- event2.data = "";
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-CUE-IN:?(.*)?$/.exec(newLine);
- if (match) {
- event2 = {
- type: "tag",
- tagType: "cue-in"
- };
- if (match[1]) {
- event2.data = match[1];
- } else {
- event2.data = "";
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-SKIP:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "skip"
- };
- event2.attributes = parseAttributes$1(match[1]);
- if (event2.attributes.hasOwnProperty("SKIPPED-SEGMENTS")) {
- event2.attributes["SKIPPED-SEGMENTS"] = parseInt(event2.attributes["SKIPPED-SEGMENTS"], 10);
- }
- if (event2.attributes.hasOwnProperty("RECENTLY-REMOVED-DATERANGES")) {
- event2.attributes["RECENTLY-REMOVED-DATERANGES"] = event2.attributes["RECENTLY-REMOVED-DATERANGES"].split(TAB);
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-PART:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "part"
- };
- event2.attributes = parseAttributes$1(match[1]);
- ["DURATION"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = parseFloat(event2.attributes[key]);
- }
- });
- ["INDEPENDENT", "GAP"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = /YES/.test(event2.attributes[key]);
- }
- });
- if (event2.attributes.hasOwnProperty("BYTERANGE")) {
- event2.attributes.byterange = parseByterange(event2.attributes.BYTERANGE);
- }
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-SERVER-CONTROL:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "server-control"
- };
- event2.attributes = parseAttributes$1(match[1]);
- ["CAN-SKIP-UNTIL", "PART-HOLD-BACK", "HOLD-BACK"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = parseFloat(event2.attributes[key]);
- }
- });
- ["CAN-SKIP-DATERANGES", "CAN-BLOCK-RELOAD"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = /YES/.test(event2.attributes[key]);
- }
- });
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-PART-INF:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "part-inf"
- };
- event2.attributes = parseAttributes$1(match[1]);
- ["PART-TARGET"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = parseFloat(event2.attributes[key]);
- }
- });
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-PRELOAD-HINT:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "preload-hint"
- };
- event2.attributes = parseAttributes$1(match[1]);
- ["BYTERANGE-START", "BYTERANGE-LENGTH"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = parseInt(event2.attributes[key], 10);
- var subkey = key === "BYTERANGE-LENGTH" ? "length" : "offset";
- event2.attributes.byterange = event2.attributes.byterange || {};
- event2.attributes.byterange[subkey] = event2.attributes[key];
- delete event2.attributes[key];
- }
- });
- _this2.trigger("data", event2);
- return;
- }
- match = /^#EXT-X-RENDITION-REPORT:(.*)$/.exec(newLine);
- if (match && match[1]) {
- event2 = {
- type: "tag",
- tagType: "rendition-report"
- };
- event2.attributes = parseAttributes$1(match[1]);
- ["LAST-MSN", "LAST-PART"].forEach(function(key) {
- if (event2.attributes.hasOwnProperty(key)) {
- event2.attributes[key] = parseInt(event2.attributes[key], 10);
- }
- });
- _this2.trigger("data", event2);
- return;
- }
- _this2.trigger("data", {
- type: "tag",
- data: newLine.slice(4)
- });
- });
- };
- _proto.addParser = function addParser(_ref) {
- var _this3 = this;
- var expression = _ref.expression, customType = _ref.customType, dataParser = _ref.dataParser, segment = _ref.segment;
- if (typeof dataParser !== "function") {
- dataParser = function dataParser2(line) {
- return line;
- };
- }
- this.customParsers.push(function(line) {
- var match = expression.exec(line);
- if (match) {
- _this3.trigger("data", {
- type: "custom",
- data: dataParser(line),
- customType,
- segment
- });
- return true;
- }
- });
- };
- _proto.addTagMapper = function addTagMapper(_ref2) {
- var expression = _ref2.expression, map = _ref2.map;
- var mapFn = function mapFn2(line) {
- if (expression.test(line)) {
- return map(line);
- }
- return line;
- };
- this.tagMappers.push(mapFn);
- };
- return ParseStream2;
- }(Stream);
- var camelCase = function camelCase2(str) {
- return str.toLowerCase().replace(/-(\w)/g, function(a) {
- return a[1].toUpperCase();
- });
- };
- var camelCaseKeys = function camelCaseKeys2(attributes) {
- var result = {};
- Object.keys(attributes).forEach(function(key) {
- result[camelCase(key)] = attributes[key];
- });
- return result;
- };
- var setHoldBack = function setHoldBack2(manifest) {
- var serverControl = manifest.serverControl, targetDuration = manifest.targetDuration, partTargetDuration = manifest.partTargetDuration;
- if (!serverControl) {
- return;
- }
- var tag = "#EXT-X-SERVER-CONTROL";
- var hb = "holdBack";
- var phb = "partHoldBack";
- var minTargetDuration = targetDuration && targetDuration * 3;
- var minPartDuration = partTargetDuration && partTargetDuration * 2;
- if (targetDuration && !serverControl.hasOwnProperty(hb)) {
- serverControl[hb] = minTargetDuration;
- this.trigger("info", {
- message: tag + " defaulting HOLD-BACK to targetDuration * 3 (" + minTargetDuration + ")."
- });
- }
- if (minTargetDuration && serverControl[hb] < minTargetDuration) {
- this.trigger("warn", {
- message: tag + " clamping HOLD-BACK (" + serverControl[hb] + ") to targetDuration * 3 (" + minTargetDuration + ")"
- });
- serverControl[hb] = minTargetDuration;
- }
- if (partTargetDuration && !serverControl.hasOwnProperty(phb)) {
- serverControl[phb] = partTargetDuration * 3;
- this.trigger("info", {
- message: tag + " defaulting PART-HOLD-BACK to partTargetDuration * 3 (" + serverControl[phb] + ")."
- });
- }
- if (partTargetDuration && serverControl[phb] < minPartDuration) {
- this.trigger("warn", {
- message: tag + " clamping PART-HOLD-BACK (" + serverControl[phb] + ") to partTargetDuration * 2 (" + minPartDuration + ")."
- });
- serverControl[phb] = minPartDuration;
- }
- };
- var Parser = /* @__PURE__ */ function(_Stream) {
- _inheritsLoose(Parser2, _Stream);
- function Parser2() {
- var _this;
- _this = _Stream.call(this) || this;
- _this.lineStream = new LineStream();
- _this.parseStream = new ParseStream();
- _this.lineStream.pipe(_this.parseStream);
- var self2 = _assertThisInitialized(_this);
- var uris = [];
- var currentUri = {};
- var currentMap;
- var _key;
- var hasParts = false;
- var noop2 = function noop3() {
- };
- var defaultMediaGroups = {
- "AUDIO": {},
- "VIDEO": {},
- "CLOSED-CAPTIONS": {},
- "SUBTITLES": {}
- };
- var widevineUuid = "urn:uuid:edef8ba9-79d6-4ace-a3c8-27dcd51d21ed";
- var currentTimeline = 0;
- _this.manifest = {
- allowCache: true,
- discontinuityStarts: [],
- segments: []
- };
- var lastByterangeEnd = 0;
- var lastPartByterangeEnd = 0;
- _this.on("end", function() {
- if (currentUri.uri || !currentUri.parts && !currentUri.preloadHints) {
- return;
- }
- if (!currentUri.map && currentMap) {
- currentUri.map = currentMap;
- }
- if (!currentUri.key && _key) {
- currentUri.key = _key;
- }
- if (!currentUri.timeline && typeof currentTimeline === "number") {
- currentUri.timeline = currentTimeline;
- }
- _this.manifest.preloadSegment = currentUri;
- });
- _this.parseStream.on("data", function(entry) {
- var mediaGroup;
- var rendition;
- ({
- tag: function tag() {
- ({
- version: function version2() {
- if (entry.version) {
- this.manifest.version = entry.version;
- }
- },
- "allow-cache": function allowCache() {
- this.manifest.allowCache = entry.allowed;
- if (!("allowed" in entry)) {
- this.trigger("info", {
- message: "defaulting allowCache to YES"
- });
- this.manifest.allowCache = true;
- }
- },
- byterange: function byterange() {
- var byterange2 = {};
- if ("length" in entry) {
- currentUri.byterange = byterange2;
- byterange2.length = entry.length;
- if (!("offset" in entry)) {
- entry.offset = lastByterangeEnd;
- }
- }
- if ("offset" in entry) {
- currentUri.byterange = byterange2;
- byterange2.offset = entry.offset;
- }
- lastByterangeEnd = byterange2.offset + byterange2.length;
- },
- endlist: function endlist() {
- this.manifest.endList = true;
- },
- inf: function inf() {
- if (!("mediaSequence" in this.manifest)) {
- this.manifest.mediaSequence = 0;
- this.trigger("info", {
- message: "defaulting media sequence to zero"
- });
- }
- if (!("discontinuitySequence" in this.manifest)) {
- this.manifest.discontinuitySequence = 0;
- this.trigger("info", {
- message: "defaulting discontinuity sequence to zero"
- });
- }
- if (entry.duration > 0) {
- currentUri.duration = entry.duration;
- }
- if (entry.duration === 0) {
- currentUri.duration = 0.01;
- this.trigger("info", {
- message: "updating zero segment duration to a small value"
- });
- }
- this.manifest.segments = uris;
- },
- key: function key() {
- if (!entry.attributes) {
- this.trigger("warn", {
- message: "ignoring key declaration without attribute list"
- });
- return;
- }
- if (entry.attributes.METHOD === "NONE") {
- _key = null;
- return;
- }
- if (!entry.attributes.URI) {
- this.trigger("warn", {
- message: "ignoring key declaration without URI"
- });
- return;
- }
- if (entry.attributes.KEYFORMAT === "com.apple.streamingkeydelivery") {
- this.manifest.contentProtection = this.manifest.contentProtection || {};
- this.manifest.contentProtection["com.apple.fps.1_0"] = {
- attributes: entry.attributes
- };
- return;
- }
- if (entry.attributes.KEYFORMAT === "com.microsoft.playready") {
- this.manifest.contentProtection = this.manifest.contentProtection || {};
- this.manifest.contentProtection["com.microsoft.playready"] = {
- uri: entry.attributes.URI
- };
- return;
- }
- if (entry.attributes.KEYFORMAT === widevineUuid) {
- var VALID_METHODS = ["SAMPLE-AES", "SAMPLE-AES-CTR", "SAMPLE-AES-CENC"];
- if (VALID_METHODS.indexOf(entry.attributes.METHOD) === -1) {
- this.trigger("warn", {
- message: "invalid key method provided for Widevine"
- });
- return;
- }
- if (entry.attributes.METHOD === "SAMPLE-AES-CENC") {
- this.trigger("warn", {
- message: "SAMPLE-AES-CENC is deprecated, please use SAMPLE-AES-CTR instead"
- });
- }
- if (entry.attributes.URI.substring(0, 23) !== "data:text/plain;base64,") {
- this.trigger("warn", {
- message: "invalid key URI provided for Widevine"
- });
- return;
- }
- if (!(entry.attributes.KEYID && entry.attributes.KEYID.substring(0, 2) === "0x")) {
- this.trigger("warn", {
- message: "invalid key ID provided for Widevine"
- });
- return;
- }
- this.manifest.contentProtection = this.manifest.contentProtection || {};
- this.manifest.contentProtection["com.widevine.alpha"] = {
- attributes: {
- schemeIdUri: entry.attributes.KEYFORMAT,
- keyId: entry.attributes.KEYID.substring(2)
- },
- pssh: decodeB64ToUint8Array(entry.attributes.URI.split(",")[1])
- };
- return;
- }
- if (!entry.attributes.METHOD) {
- this.trigger("warn", {
- message: "defaulting key method to AES-128"
- });
- }
- _key = {
- method: entry.attributes.METHOD || "AES-128",
- uri: entry.attributes.URI
- };
- if (typeof entry.attributes.IV !== "undefined") {
- _key.iv = entry.attributes.IV;
- }
- },
- "media-sequence": function mediaSequence() {
- if (!isFinite(entry.number)) {
- this.trigger("warn", {
- message: "ignoring invalid media sequence: " + entry.number
- });
- return;
- }
- this.manifest.mediaSequence = entry.number;
- },
- "discontinuity-sequence": function discontinuitySequence() {
- if (!isFinite(entry.number)) {
- this.trigger("warn", {
- message: "ignoring invalid discontinuity sequence: " + entry.number
- });
- return;
- }
- this.manifest.discontinuitySequence = entry.number;
- currentTimeline = entry.number;
- },
- "playlist-type": function playlistType() {
- if (!/VOD|EVENT/.test(entry.playlistType)) {
- this.trigger("warn", {
- message: "ignoring unknown playlist type: " + entry.playlist
- });
- return;
- }
- this.manifest.playlistType = entry.playlistType;
- },
- map: function map() {
- currentMap = {};
- if (entry.uri) {
- currentMap.uri = entry.uri;
- }
- if (entry.byterange) {
- currentMap.byterange = entry.byterange;
- }
- if (_key) {
- currentMap.key = _key;
- }
- },
- "stream-inf": function streamInf() {
- this.manifest.playlists = uris;
- this.manifest.mediaGroups = this.manifest.mediaGroups || defaultMediaGroups;
- if (!entry.attributes) {
- this.trigger("warn", {
- message: "ignoring empty stream-inf attributes"
- });
- return;
- }
- if (!currentUri.attributes) {
- currentUri.attributes = {};
- }
- _extends$2(currentUri.attributes, entry.attributes);
- },
- media: function media() {
- this.manifest.mediaGroups = this.manifest.mediaGroups || defaultMediaGroups;
- if (!(entry.attributes && entry.attributes.TYPE && entry.attributes["GROUP-ID"] && entry.attributes.NAME)) {
- this.trigger("warn", {
- message: "ignoring incomplete or missing media group"
- });
- return;
- }
- var mediaGroupType = this.manifest.mediaGroups[entry.attributes.TYPE];
- mediaGroupType[entry.attributes["GROUP-ID"]] = mediaGroupType[entry.attributes["GROUP-ID"]] || {};
- mediaGroup = mediaGroupType[entry.attributes["GROUP-ID"]];
- rendition = {
- default: /yes/i.test(entry.attributes.DEFAULT)
- };
- if (rendition.default) {
- rendition.autoselect = true;
- } else {
- rendition.autoselect = /yes/i.test(entry.attributes.AUTOSELECT);
- }
- if (entry.attributes.LANGUAGE) {
- rendition.language = entry.attributes.LANGUAGE;
- }
- if (entry.attributes.URI) {
- rendition.uri = entry.attributes.URI;
- }
- if (entry.attributes["INSTREAM-ID"]) {
- rendition.instreamId = entry.attributes["INSTREAM-ID"];
- }
- if (entry.attributes.CHARACTERISTICS) {
- rendition.characteristics = entry.attributes.CHARACTERISTICS;
- }
- if (entry.attributes.FORCED) {
- rendition.forced = /yes/i.test(entry.attributes.FORCED);
- }
- mediaGroup[entry.attributes.NAME] = rendition;
- },
- discontinuity: function discontinuity() {
- currentTimeline += 1;
- currentUri.discontinuity = true;
- this.manifest.discontinuityStarts.push(uris.length);
- },
- "program-date-time": function programDateTime() {
- if (typeof this.manifest.dateTimeString === "undefined") {
- this.manifest.dateTimeString = entry.dateTimeString;
- this.manifest.dateTimeObject = entry.dateTimeObject;
- }
- currentUri.dateTimeString = entry.dateTimeString;
- currentUri.dateTimeObject = entry.dateTimeObject;
- },
- targetduration: function targetduration() {
- if (!isFinite(entry.duration) || entry.duration < 0) {
- this.trigger("warn", {
- message: "ignoring invalid target duration: " + entry.duration
- });
- return;
- }
- this.manifest.targetDuration = entry.duration;
- setHoldBack.call(this, this.manifest);
- },
- start: function start2() {
- if (!entry.attributes || isNaN(entry.attributes["TIME-OFFSET"])) {
- this.trigger("warn", {
- message: "ignoring start declaration without appropriate attribute list"
- });
- return;
- }
- this.manifest.start = {
- timeOffset: entry.attributes["TIME-OFFSET"],
- precise: entry.attributes.PRECISE
- };
- },
- "cue-out": function cueOut() {
- currentUri.cueOut = entry.data;
- },
- "cue-out-cont": function cueOutCont() {
- currentUri.cueOutCont = entry.data;
- },
- "cue-in": function cueIn() {
- currentUri.cueIn = entry.data;
- },
- "skip": function skip() {
- this.manifest.skip = camelCaseKeys(entry.attributes);
- this.warnOnMissingAttributes_("#EXT-X-SKIP", entry.attributes, ["SKIPPED-SEGMENTS"]);
- },
- "part": function part() {
- var _this2 = this;
- hasParts = true;
- var segmentIndex = this.manifest.segments.length;
- var part2 = camelCaseKeys(entry.attributes);
- currentUri.parts = currentUri.parts || [];
- currentUri.parts.push(part2);
- if (part2.byterange) {
- if (!part2.byterange.hasOwnProperty("offset")) {
- part2.byterange.offset = lastPartByterangeEnd;
- }
- lastPartByterangeEnd = part2.byterange.offset + part2.byterange.length;
- }
- var partIndex = currentUri.parts.length - 1;
- this.warnOnMissingAttributes_("#EXT-X-PART #" + partIndex + " for segment #" + segmentIndex, entry.attributes, ["URI", "DURATION"]);
- if (this.manifest.renditionReports) {
- this.manifest.renditionReports.forEach(function(r2, i2) {
- if (!r2.hasOwnProperty("lastPart")) {
- _this2.trigger("warn", {
- message: "#EXT-X-RENDITION-REPORT #" + i2 + " lacks required attribute(s): LAST-PART"
- });
- }
- });
- }
- },
- "server-control": function serverControl() {
- var attrs = this.manifest.serverControl = camelCaseKeys(entry.attributes);
- if (!attrs.hasOwnProperty("canBlockReload")) {
- attrs.canBlockReload = false;
- this.trigger("info", {
- message: "#EXT-X-SERVER-CONTROL defaulting CAN-BLOCK-RELOAD to false"
- });
- }
- setHoldBack.call(this, this.manifest);
- if (attrs.canSkipDateranges && !attrs.hasOwnProperty("canSkipUntil")) {
- this.trigger("warn", {
- message: "#EXT-X-SERVER-CONTROL lacks required attribute CAN-SKIP-UNTIL which is required when CAN-SKIP-DATERANGES is set"
- });
- }
- },
- "preload-hint": function preloadHint() {
- var segmentIndex = this.manifest.segments.length;
- var hint = camelCaseKeys(entry.attributes);
- var isPart = hint.type && hint.type === "PART";
- currentUri.preloadHints = currentUri.preloadHints || [];
- currentUri.preloadHints.push(hint);
- if (hint.byterange) {
- if (!hint.byterange.hasOwnProperty("offset")) {
- hint.byterange.offset = isPart ? lastPartByterangeEnd : 0;
- if (isPart) {
- lastPartByterangeEnd = hint.byterange.offset + hint.byterange.length;
- }
- }
- }
- var index2 = currentUri.preloadHints.length - 1;
- this.warnOnMissingAttributes_("#EXT-X-PRELOAD-HINT #" + index2 + " for segment #" + segmentIndex, entry.attributes, ["TYPE", "URI"]);
- if (!hint.type) {
- return;
- }
- for (var i2 = 0; i2 < currentUri.preloadHints.length - 1; i2++) {
- var otherHint = currentUri.preloadHints[i2];
- if (!otherHint.type) {
- continue;
- }
- if (otherHint.type === hint.type) {
- this.trigger("warn", {
- message: "#EXT-X-PRELOAD-HINT #" + index2 + " for segment #" + segmentIndex + " has the same TYPE " + hint.type + " as preload hint #" + i2
- });
- }
- }
- },
- "rendition-report": function renditionReport() {
- var report = camelCaseKeys(entry.attributes);
- this.manifest.renditionReports = this.manifest.renditionReports || [];
- this.manifest.renditionReports.push(report);
- var index2 = this.manifest.renditionReports.length - 1;
- var required = ["LAST-MSN", "URI"];
- if (hasParts) {
- required.push("LAST-PART");
- }
- this.warnOnMissingAttributes_("#EXT-X-RENDITION-REPORT #" + index2, entry.attributes, required);
- },
- "part-inf": function partInf() {
- this.manifest.partInf = camelCaseKeys(entry.attributes);
- this.warnOnMissingAttributes_("#EXT-X-PART-INF", entry.attributes, ["PART-TARGET"]);
- if (this.manifest.partInf.partTarget) {
- this.manifest.partTargetDuration = this.manifest.partInf.partTarget;
- }
- setHoldBack.call(this, this.manifest);
- }
- }[entry.tagType] || noop2).call(self2);
- },
- uri: function uri() {
- currentUri.uri = entry.uri;
- uris.push(currentUri);
- if (this.manifest.targetDuration && !("duration" in currentUri)) {
- this.trigger("warn", {
- message: "defaulting segment duration to the target duration"
- });
- currentUri.duration = this.manifest.targetDuration;
- }
- if (_key) {
- currentUri.key = _key;
- }
- currentUri.timeline = currentTimeline;
- if (currentMap) {
- currentUri.map = currentMap;
- }
- lastPartByterangeEnd = 0;
- currentUri = {};
- },
- comment: function comment() {
- },
- custom: function custom() {
- if (entry.segment) {
- currentUri.custom = currentUri.custom || {};
- currentUri.custom[entry.customType] = entry.data;
- } else {
- this.manifest.custom = this.manifest.custom || {};
- this.manifest.custom[entry.customType] = entry.data;
- }
- }
- })[entry.type].call(self2);
- });
- return _this;
- }
- var _proto = Parser2.prototype;
- _proto.warnOnMissingAttributes_ = function warnOnMissingAttributes_(identifier, attributes, required) {
- var missing = [];
- required.forEach(function(key) {
- if (!attributes.hasOwnProperty(key)) {
- missing.push(key);
- }
- });
- if (missing.length) {
- this.trigger("warn", {
- message: identifier + " lacks required attribute(s): " + missing.join(", ")
- });
- }
- };
- _proto.push = function push(chunk) {
- this.lineStream.push(chunk);
- };
- _proto.end = function end() {
- this.lineStream.push("\n");
- this.trigger("end");
- };
- _proto.addParser = function addParser(options2) {
- this.parseStream.addParser(options2);
- };
- _proto.addTagMapper = function addTagMapper(options2) {
- this.parseStream.addTagMapper(options2);
- };
- return Parser2;
- }(Stream);
- var regexs = {
- mp4: /^(av0?1|avc0?[1234]|vp0?9|flac|opus|mp3|mp4a|mp4v|stpp.ttml.im1t)/,
- webm: /^(vp0?[89]|av0?1|opus|vorbis)/,
- ogg: /^(vp0?[89]|theora|flac|opus|vorbis)/,
- video: /^(av0?1|avc0?[1234]|vp0?[89]|hvc1|hev1|theora|mp4v)/,
- audio: /^(mp4a|flac|vorbis|opus|ac-[34]|ec-3|alac|mp3|speex|aac)/,
- text: /^(stpp.ttml.im1t)/,
- muxerVideo: /^(avc0?1)/,
- muxerAudio: /^(mp4a)/,
- muxerText: /a^/
- };
- var mediaTypes = ["video", "audio", "text"];
- var upperMediaTypes = ["Video", "Audio", "Text"];
- var translateLegacyCodec2 = function translateLegacyCodec3(codec) {
- if (!codec) {
- return codec;
- }
- return codec.replace(/avc1\.(\d+)\.(\d+)/i, function(orig, profile, avcLevel) {
- var profileHex = ("00" + Number(profile).toString(16)).slice(-2);
- var avcLevelHex = ("00" + Number(avcLevel).toString(16)).slice(-2);
- return "avc1." + profileHex + "00" + avcLevelHex;
- });
- };
- var parseCodecs2 = function parseCodecs3(codecString) {
- if (codecString === void 0) {
- codecString = "";
- }
- var codecs = codecString.split(",");
- var result = [];
- codecs.forEach(function(codec) {
- codec = codec.trim();
- var codecType;
- mediaTypes.forEach(function(name) {
- var match = regexs[name].exec(codec.toLowerCase());
- if (!match || match.length <= 1) {
- return;
- }
- codecType = name;
- var type2 = codec.substring(0, match[1].length);
- var details = codec.replace(type2, "");
- result.push({
- type: type2,
- details,
- mediaType: name
- });
- });
- if (!codecType) {
- result.push({
- type: codec,
- details: "",
- mediaType: "unknown"
- });
- }
- });
- return result;
- };
- var codecsFromDefault2 = function codecsFromDefault3(master, audioGroupId) {
- if (!master.mediaGroups.AUDIO || !audioGroupId) {
- return null;
- }
- var audioGroup = master.mediaGroups.AUDIO[audioGroupId];
- if (!audioGroup) {
- return null;
- }
- for (var name in audioGroup) {
- var audioType = audioGroup[name];
- if (audioType.default && audioType.playlists) {
- return parseCodecs2(audioType.playlists[0].attributes.CODECS);
- }
- }
- return null;
- };
- var isAudioCodec2 = function isAudioCodec3(codec) {
- if (codec === void 0) {
- codec = "";
- }
- return regexs.audio.test(codec.trim().toLowerCase());
- };
- var isTextCodec2 = function isTextCodec3(codec) {
- if (codec === void 0) {
- codec = "";
- }
- return regexs.text.test(codec.trim().toLowerCase());
- };
- var getMimeForCodec2 = function getMimeForCodec3(codecString) {
- if (!codecString || typeof codecString !== "string") {
- return;
- }
- var codecs = codecString.toLowerCase().split(",").map(function(c) {
- return translateLegacyCodec2(c.trim());
- });
- var type2 = "video";
- if (codecs.length === 1 && isAudioCodec2(codecs[0])) {
- type2 = "audio";
- } else if (codecs.length === 1 && isTextCodec2(codecs[0])) {
- type2 = "application";
- }
- var container = "mp4";
- if (codecs.every(function(c) {
- return regexs.mp4.test(c);
- })) {
- container = "mp4";
- } else if (codecs.every(function(c) {
- return regexs.webm.test(c);
- })) {
- container = "webm";
- } else if (codecs.every(function(c) {
- return regexs.ogg.test(c);
- })) {
- container = "ogg";
- }
- return type2 + "/" + container + ';codecs="' + codecString + '"';
- };
- var browserSupportsCodec2 = function browserSupportsCodec3(codecString) {
- if (codecString === void 0) {
- codecString = "";
- }
- return window_1.MediaSource && window_1.MediaSource.isTypeSupported && window_1.MediaSource.isTypeSupported(getMimeForCodec2(codecString)) || false;
- };
- var muxerSupportsCodec2 = function muxerSupportsCodec3(codecString) {
- if (codecString === void 0) {
- codecString = "";
- }
- return codecString.toLowerCase().split(",").every(function(codec) {
- codec = codec.trim();
- for (var i2 = 0; i2 < upperMediaTypes.length; i2++) {
- var type2 = upperMediaTypes[i2];
- if (regexs["muxer" + type2].test(codec)) {
- return true;
- }
- }
- return false;
- });
- };
- var DEFAULT_AUDIO_CODEC = "mp4a.40.2";
- var DEFAULT_VIDEO_CODEC = "avc1.4d400d";
- var MPEGURL_REGEX = /^(audio|video|application)\/(x-|vnd\.apple\.)?mpegurl/i;
- var DASH_REGEX = /^application\/dash\+xml/i;
- var simpleTypeFromSourceType2 = function simpleTypeFromSourceType3(type2) {
- if (MPEGURL_REGEX.test(type2)) {
- return "hls";
- }
- if (DASH_REGEX.test(type2)) {
- return "dash";
- }
- if (type2 === "application/vnd.videojs.vhs+json") {
- return "vhs-json";
- }
- return null;
- };
- var countBits2 = function countBits3(x) {
- return x.toString(2).length;
- };
- var countBytes2 = function countBytes3(x) {
- return Math.ceil(countBits2(x) / 8);
- };
- var isArrayBufferView2 = function isArrayBufferView3(obj) {
- if (ArrayBuffer.isView === "function") {
- return ArrayBuffer.isView(obj);
- }
- return obj && obj.buffer instanceof ArrayBuffer;
- };
- var isTypedArray2 = function isTypedArray3(obj) {
- return isArrayBufferView2(obj);
- };
- var toUint82 = function toUint83(bytes) {
- if (bytes instanceof Uint8Array) {
- return bytes;
- }
- if (!Array.isArray(bytes) && !isTypedArray2(bytes) && !(bytes instanceof ArrayBuffer)) {
- if (typeof bytes !== "number" || typeof bytes === "number" && bytes !== bytes) {
- bytes = 0;
- } else {
- bytes = [bytes];
- }
- }
- return new Uint8Array(bytes && bytes.buffer || bytes, bytes && bytes.byteOffset || 0, bytes && bytes.byteLength || 0);
- };
- var BigInt = window_1.BigInt || Number;
- var BYTE_TABLE = [BigInt("0x1"), BigInt("0x100"), BigInt("0x10000"), BigInt("0x1000000"), BigInt("0x100000000"), BigInt("0x10000000000"), BigInt("0x1000000000000"), BigInt("0x100000000000000"), BigInt("0x10000000000000000")];
- (function() {
- var a = new Uint16Array([65484]);
- var b = new Uint8Array(a.buffer, a.byteOffset, a.byteLength);
- if (b[0] === 255) {
- return "big";
- }
- if (b[0] === 204) {
- return "little";
- }
- return "unknown";
- })();
- var bytesToNumber2 = function bytesToNumber3(bytes, _temp) {
- var _ref = _temp === void 0 ? {} : _temp, _ref$signed = _ref.signed, signed = _ref$signed === void 0 ? false : _ref$signed, _ref$le = _ref.le, le = _ref$le === void 0 ? false : _ref$le;
- bytes = toUint82(bytes);
- var fn2 = le ? "reduce" : "reduceRight";
- var obj = bytes[fn2] ? bytes[fn2] : Array.prototype[fn2];
- var number = obj.call(bytes, function(total, byte, i2) {
- var exponent = le ? i2 : Math.abs(i2 + 1 - bytes.length);
- return total + BigInt(byte) * BYTE_TABLE[exponent];
- }, BigInt(0));
- if (signed) {
- var max2 = BYTE_TABLE[bytes.length] / BigInt(2) - BigInt(1);
- number = BigInt(number);
- if (number > max2) {
- number -= max2;
- number -= max2;
- number -= BigInt(2);
- }
- }
- return Number(number);
- };
- var numberToBytes2 = function numberToBytes3(number, _temp2) {
- var _ref2 = _temp2 === void 0 ? {} : _temp2, _ref2$le = _ref2.le, le = _ref2$le === void 0 ? false : _ref2$le;
- if (typeof number !== "bigint" && typeof number !== "number" || typeof number === "number" && number !== number) {
- number = 0;
- }
- number = BigInt(number);
- var byteCount = countBytes2(number);
- var bytes = new Uint8Array(new ArrayBuffer(byteCount));
- for (var i2 = 0; i2 < byteCount; i2++) {
- var byteIndex = le ? i2 : Math.abs(i2 + 1 - bytes.length);
- bytes[byteIndex] = Number(number / BYTE_TABLE[i2] & BigInt(255));
- if (number < 0) {
- bytes[byteIndex] = Math.abs(~bytes[byteIndex]);
- bytes[byteIndex] -= i2 === 0 ? 1 : 2;
- }
- }
- return bytes;
- };
- var stringToBytes2 = function stringToBytes3(string, stringIsBytes) {
- if (typeof string !== "string" && string && typeof string.toString === "function") {
- string = string.toString();
- }
- if (typeof string !== "string") {
- return new Uint8Array();
- }
- if (!stringIsBytes) {
- string = unescape(encodeURIComponent(string));
- }
- var view = new Uint8Array(string.length);
- for (var i2 = 0; i2 < string.length; i2++) {
- view[i2] = string.charCodeAt(i2);
- }
- return view;
- };
- var concatTypedArrays2 = function concatTypedArrays3() {
- for (var _len = arguments.length, buffers = new Array(_len), _key = 0; _key < _len; _key++) {
- buffers[_key] = arguments[_key];
- }
- buffers = buffers.filter(function(b) {
- return b && (b.byteLength || b.length) && typeof b !== "string";
- });
- if (buffers.length <= 1) {
- return toUint82(buffers[0]);
- }
- var totalLen = buffers.reduce(function(total, buf, i2) {
- return total + (buf.byteLength || buf.length);
- }, 0);
- var tempBuffer = new Uint8Array(totalLen);
- var offset = 0;
- buffers.forEach(function(buf) {
- buf = toUint82(buf);
- tempBuffer.set(buf, offset);
- offset += buf.byteLength;
- });
- return tempBuffer;
- };
- var bytesMatch2 = function bytesMatch3(a, b, _temp3) {
- var _ref3 = _temp3 === void 0 ? {} : _temp3, _ref3$offset = _ref3.offset, offset = _ref3$offset === void 0 ? 0 : _ref3$offset, _ref3$mask = _ref3.mask, mask = _ref3$mask === void 0 ? [] : _ref3$mask;
- a = toUint82(a);
- b = toUint82(b);
- var fn2 = b.every ? b.every : Array.prototype.every;
- return b.length && a.length - offset >= b.length && fn2.call(b, function(bByte, i2) {
- var aByte = mask[i2] ? mask[i2] & a[offset + i2] : a[offset + i2];
- return bByte === aByte;
- });
- };
- var forEachMediaGroup$1 = function forEachMediaGroup2(master, groups, callback2) {
- groups.forEach(function(mediaType) {
- for (var groupKey in master.mediaGroups[mediaType]) {
- for (var labelKey in master.mediaGroups[mediaType][groupKey]) {
- var mediaProperties = master.mediaGroups[mediaType][groupKey][labelKey];
- callback2(mediaProperties, mediaType, groupKey, labelKey);
- }
- }
- });
- };
- /*! @name mpd-parser @version 0.22.1 @license Apache-2.0 */
- var isObject$1 = function isObject(obj) {
- return !!obj && typeof obj === "object";
- };
- var merge = function merge2() {
- for (var _len = arguments.length, objects = new Array(_len), _key = 0; _key < _len; _key++) {
- objects[_key] = arguments[_key];
- }
- return objects.reduce(function(result, source) {
- if (typeof source !== "object") {
- return result;
- }
- Object.keys(source).forEach(function(key) {
- if (Array.isArray(result[key]) && Array.isArray(source[key])) {
- result[key] = result[key].concat(source[key]);
- } else if (isObject$1(result[key]) && isObject$1(source[key])) {
- result[key] = merge2(result[key], source[key]);
- } else {
- result[key] = source[key];
- }
- });
- return result;
- }, {});
- };
- var values = function values2(o) {
- return Object.keys(o).map(function(k) {
- return o[k];
- });
- };
- var range = function range2(start2, end) {
- var result = [];
- for (var i2 = start2; i2 < end; i2++) {
- result.push(i2);
- }
- return result;
- };
- var flatten = function flatten2(lists) {
- return lists.reduce(function(x, y) {
- return x.concat(y);
- }, []);
- };
- var from = function from2(list) {
- if (!list.length) {
- return [];
- }
- var result = [];
- for (var i2 = 0; i2 < list.length; i2++) {
- result.push(list[i2]);
- }
- return result;
- };
- var findIndexes = function findIndexes2(l, key) {
- return l.reduce(function(a, e, i2) {
- if (e[key]) {
- a.push(i2);
- }
- return a;
- }, []);
- };
- var findIndex = function findIndex2(list, matchingFunction) {
- for (var i2 = 0; i2 < list.length; i2++) {
- if (matchingFunction(list[i2])) {
- return i2;
- }
- }
- return -1;
- };
- var union = function union2(lists, keyFunction) {
- return values(lists.reduce(function(acc, list) {
- list.forEach(function(el) {
- acc[keyFunction(el)] = el;
- });
- return acc;
- }, {}));
- };
- var errors = {
- INVALID_NUMBER_OF_PERIOD: "INVALID_NUMBER_OF_PERIOD",
- DASH_EMPTY_MANIFEST: "DASH_EMPTY_MANIFEST",
- DASH_INVALID_XML: "DASH_INVALID_XML",
- NO_BASE_URL: "NO_BASE_URL",
- MISSING_SEGMENT_INFORMATION: "MISSING_SEGMENT_INFORMATION",
- SEGMENT_TIME_UNSPECIFIED: "SEGMENT_TIME_UNSPECIFIED",
- UNSUPPORTED_UTC_TIMING_SCHEME: "UNSUPPORTED_UTC_TIMING_SCHEME"
- };
- var urlTypeToSegment = function urlTypeToSegment2(_ref) {
- var _ref$baseUrl = _ref.baseUrl, baseUrl = _ref$baseUrl === void 0 ? "" : _ref$baseUrl, _ref$source = _ref.source, source = _ref$source === void 0 ? "" : _ref$source, _ref$range = _ref.range, range3 = _ref$range === void 0 ? "" : _ref$range, _ref$indexRange = _ref.indexRange, indexRange = _ref$indexRange === void 0 ? "" : _ref$indexRange;
- var segment = {
- uri: source,
- resolvedUri: resolveUrl$1(baseUrl || "", source)
- };
- if (range3 || indexRange) {
- var rangeStr = range3 ? range3 : indexRange;
- var ranges = rangeStr.split("-");
- var startRange = window_1.BigInt ? window_1.BigInt(ranges[0]) : parseInt(ranges[0], 10);
- var endRange = window_1.BigInt ? window_1.BigInt(ranges[1]) : parseInt(ranges[1], 10);
- if (startRange < Number.MAX_SAFE_INTEGER && typeof startRange === "bigint") {
- startRange = Number(startRange);
- }
- if (endRange < Number.MAX_SAFE_INTEGER && typeof endRange === "bigint") {
- endRange = Number(endRange);
- }
- var length;
- if (typeof endRange === "bigint" || typeof startRange === "bigint") {
- length = window_1.BigInt(endRange) - window_1.BigInt(startRange) + window_1.BigInt(1);
- } else {
- length = endRange - startRange + 1;
- }
- if (typeof length === "bigint" && length < Number.MAX_SAFE_INTEGER) {
- length = Number(length);
- }
- segment.byterange = {
- length,
- offset: startRange
- };
- }
- return segment;
- };
- var byteRangeToString = function byteRangeToString2(byterange) {
- var endRange;
- if (typeof byterange.offset === "bigint" || typeof byterange.length === "bigint") {
- endRange = window_1.BigInt(byterange.offset) + window_1.BigInt(byterange.length) - window_1.BigInt(1);
- } else {
- endRange = byterange.offset + byterange.length - 1;
- }
- return byterange.offset + "-" + endRange;
- };
- var parseEndNumber = function parseEndNumber2(endNumber) {
- if (endNumber && typeof endNumber !== "number") {
- endNumber = parseInt(endNumber, 10);
- }
- if (isNaN(endNumber)) {
- return null;
- }
- return endNumber;
- };
- var segmentRange = {
- static: function _static(attributes) {
- var duration5 = attributes.duration, _attributes$timescale = attributes.timescale, timescale2 = _attributes$timescale === void 0 ? 1 : _attributes$timescale, sourceDuration = attributes.sourceDuration, periodDuration = attributes.periodDuration;
- var endNumber = parseEndNumber(attributes.endNumber);
- var segmentDuration = duration5 / timescale2;
- if (typeof endNumber === "number") {
- return {
- start: 0,
- end: endNumber
- };
- }
- if (typeof periodDuration === "number") {
- return {
- start: 0,
- end: periodDuration / segmentDuration
- };
- }
- return {
- start: 0,
- end: sourceDuration / segmentDuration
- };
- },
- dynamic: function dynamic(attributes) {
- var NOW = attributes.NOW, clientOffset = attributes.clientOffset, availabilityStartTime2 = attributes.availabilityStartTime, _attributes$timescale2 = attributes.timescale, timescale2 = _attributes$timescale2 === void 0 ? 1 : _attributes$timescale2, duration5 = attributes.duration, _attributes$periodSta = attributes.periodStart, periodStart = _attributes$periodSta === void 0 ? 0 : _attributes$periodSta, _attributes$minimumUp = attributes.minimumUpdatePeriod, minimumUpdatePeriod2 = _attributes$minimumUp === void 0 ? 0 : _attributes$minimumUp, _attributes$timeShift = attributes.timeShiftBufferDepth, timeShiftBufferDepth2 = _attributes$timeShift === void 0 ? Infinity : _attributes$timeShift;
- var endNumber = parseEndNumber(attributes.endNumber);
- var now2 = (NOW + clientOffset) / 1e3;
- var periodStartWC = availabilityStartTime2 + periodStart;
- var periodEndWC = now2 + minimumUpdatePeriod2;
- var periodDuration = periodEndWC - periodStartWC;
- var segmentCount = Math.ceil(periodDuration * timescale2 / duration5);
- var availableStart = Math.floor((now2 - periodStartWC - timeShiftBufferDepth2) * timescale2 / duration5);
- var availableEnd = Math.floor((now2 - periodStartWC) * timescale2 / duration5);
- return {
- start: Math.max(0, availableStart),
- end: typeof endNumber === "number" ? endNumber : Math.min(segmentCount, availableEnd)
- };
- }
- };
- var toSegments = function toSegments2(attributes) {
- return function(number) {
- var duration5 = attributes.duration, _attributes$timescale3 = attributes.timescale, timescale2 = _attributes$timescale3 === void 0 ? 1 : _attributes$timescale3, periodStart = attributes.periodStart, _attributes$startNumb = attributes.startNumber, startNumber2 = _attributes$startNumb === void 0 ? 1 : _attributes$startNumb;
- return {
- number: startNumber2 + number,
- duration: duration5 / timescale2,
- timeline: periodStart,
- time: number * duration5
- };
- };
- };
- var parseByDuration = function parseByDuration2(attributes) {
- var type2 = attributes.type, duration5 = attributes.duration, _attributes$timescale4 = attributes.timescale, timescale2 = _attributes$timescale4 === void 0 ? 1 : _attributes$timescale4, periodDuration = attributes.periodDuration, sourceDuration = attributes.sourceDuration;
- var _segmentRange$type = segmentRange[type2](attributes), start2 = _segmentRange$type.start, end = _segmentRange$type.end;
- var segments = range(start2, end).map(toSegments(attributes));
- if (type2 === "static") {
- var index2 = segments.length - 1;
- var sectionDuration = typeof periodDuration === "number" ? periodDuration : sourceDuration;
- segments[index2].duration = sectionDuration - duration5 / timescale2 * index2;
- }
- return segments;
- };
- var segmentsFromBase = function segmentsFromBase2(attributes) {
- var baseUrl = attributes.baseUrl, _attributes$initializ = attributes.initialization, initialization = _attributes$initializ === void 0 ? {} : _attributes$initializ, sourceDuration = attributes.sourceDuration, _attributes$indexRang = attributes.indexRange, indexRange = _attributes$indexRang === void 0 ? "" : _attributes$indexRang, periodStart = attributes.periodStart, presentationTime = attributes.presentationTime, _attributes$number = attributes.number, number = _attributes$number === void 0 ? 0 : _attributes$number, duration5 = attributes.duration;
- if (!baseUrl) {
- throw new Error(errors.NO_BASE_URL);
- }
- var initSegment = urlTypeToSegment({
- baseUrl,
- source: initialization.sourceURL,
- range: initialization.range
- });
- var segment = urlTypeToSegment({
- baseUrl,
- source: baseUrl,
- indexRange
- });
- segment.map = initSegment;
- if (duration5) {
- var segmentTimeInfo = parseByDuration(attributes);
- if (segmentTimeInfo.length) {
- segment.duration = segmentTimeInfo[0].duration;
- segment.timeline = segmentTimeInfo[0].timeline;
- }
- } else if (sourceDuration) {
- segment.duration = sourceDuration;
- segment.timeline = periodStart;
- }
- segment.presentationTime = presentationTime || periodStart;
- segment.number = number;
- return [segment];
- };
- var addSidxSegmentsToPlaylist$1 = function addSidxSegmentsToPlaylist(playlist, sidx, baseUrl) {
- var initSegment = playlist.sidx.map ? playlist.sidx.map : null;
- var sourceDuration = playlist.sidx.duration;
- var timeline = playlist.timeline || 0;
- var sidxByteRange = playlist.sidx.byterange;
- var sidxEnd = sidxByteRange.offset + sidxByteRange.length;
- var timescale2 = sidx.timescale;
- var mediaReferences = sidx.references.filter(function(r2) {
- return r2.referenceType !== 1;
- });
- var segments = [];
- var type2 = playlist.endList ? "static" : "dynamic";
- var periodStart = playlist.sidx.timeline;
- var presentationTime = periodStart;
- var number = playlist.mediaSequence || 0;
- var startIndex;
- if (typeof sidx.firstOffset === "bigint") {
- startIndex = window_1.BigInt(sidxEnd) + sidx.firstOffset;
- } else {
- startIndex = sidxEnd + sidx.firstOffset;
- }
- for (var i2 = 0; i2 < mediaReferences.length; i2++) {
- var reference = sidx.references[i2];
- var size = reference.referencedSize;
- var duration5 = reference.subsegmentDuration;
- var endIndex = void 0;
- if (typeof startIndex === "bigint") {
- endIndex = startIndex + window_1.BigInt(size) - window_1.BigInt(1);
- } else {
- endIndex = startIndex + size - 1;
- }
- var indexRange = startIndex + "-" + endIndex;
- var attributes = {
- baseUrl,
- timescale: timescale2,
- timeline,
- periodStart,
- presentationTime,
- number,
- duration: duration5,
- sourceDuration,
- indexRange,
- type: type2
- };
- var segment = segmentsFromBase(attributes)[0];
- if (initSegment) {
- segment.map = initSegment;
- }
- segments.push(segment);
- if (typeof startIndex === "bigint") {
- startIndex += window_1.BigInt(size);
- } else {
- startIndex += size;
- }
- presentationTime += duration5 / timescale2;
- number++;
- }
- playlist.segments = segments;
- return playlist;
- };
- var SUPPORTED_MEDIA_TYPES = ["AUDIO", "SUBTITLES"];
- var TIME_FUDGE = 1 / 60;
- var getUniqueTimelineStarts = function getUniqueTimelineStarts2(timelineStarts) {
- return union(timelineStarts, function(_ref) {
- var timeline = _ref.timeline;
- return timeline;
- }).sort(function(a, b) {
- return a.timeline > b.timeline ? 1 : -1;
- });
- };
- var findPlaylistWithName = function findPlaylistWithName2(playlists, name) {
- for (var i2 = 0; i2 < playlists.length; i2++) {
- if (playlists[i2].attributes.NAME === name) {
- return playlists[i2];
- }
- }
- return null;
- };
- var getMediaGroupPlaylists = function getMediaGroupPlaylists2(manifest) {
- var mediaGroupPlaylists = [];
- forEachMediaGroup$1(manifest, SUPPORTED_MEDIA_TYPES, function(properties, type2, group, label2) {
- mediaGroupPlaylists = mediaGroupPlaylists.concat(properties.playlists || []);
- });
- return mediaGroupPlaylists;
- };
- var updateMediaSequenceForPlaylist = function updateMediaSequenceForPlaylist2(_ref2) {
- var playlist = _ref2.playlist, mediaSequence = _ref2.mediaSequence;
- playlist.mediaSequence = mediaSequence;
- playlist.segments.forEach(function(segment, index2) {
- segment.number = playlist.mediaSequence + index2;
- });
- };
- var updateSequenceNumbers = function updateSequenceNumbers2(_ref3) {
- var oldPlaylists = _ref3.oldPlaylists, newPlaylists = _ref3.newPlaylists, timelineStarts = _ref3.timelineStarts;
- newPlaylists.forEach(function(playlist) {
- playlist.discontinuitySequence = findIndex(timelineStarts, function(_ref4) {
- var timeline = _ref4.timeline;
- return timeline === playlist.timeline;
- });
- var oldPlaylist = findPlaylistWithName(oldPlaylists, playlist.attributes.NAME);
- if (!oldPlaylist) {
- return;
- }
- if (playlist.sidx) {
- return;
- }
- var firstNewSegment = playlist.segments[0];
- var oldMatchingSegmentIndex = findIndex(oldPlaylist.segments, function(oldSegment) {
- return Math.abs(oldSegment.presentationTime - firstNewSegment.presentationTime) < TIME_FUDGE;
- });
- if (oldMatchingSegmentIndex === -1) {
- updateMediaSequenceForPlaylist({
- playlist,
- mediaSequence: oldPlaylist.mediaSequence + oldPlaylist.segments.length
- });
- playlist.segments[0].discontinuity = true;
- playlist.discontinuityStarts.unshift(0);
- if (!oldPlaylist.segments.length && playlist.timeline > oldPlaylist.timeline || oldPlaylist.segments.length && playlist.timeline > oldPlaylist.segments[oldPlaylist.segments.length - 1].timeline) {
- playlist.discontinuitySequence--;
- }
- return;
- }
- var oldMatchingSegment = oldPlaylist.segments[oldMatchingSegmentIndex];
- if (oldMatchingSegment.discontinuity && !firstNewSegment.discontinuity) {
- firstNewSegment.discontinuity = true;
- playlist.discontinuityStarts.unshift(0);
- playlist.discontinuitySequence--;
- }
- updateMediaSequenceForPlaylist({
- playlist,
- mediaSequence: oldPlaylist.segments[oldMatchingSegmentIndex].number
- });
- });
- };
- var positionManifestOnTimeline = function positionManifestOnTimeline2(_ref5) {
- var oldManifest = _ref5.oldManifest, newManifest = _ref5.newManifest;
- var oldPlaylists = oldManifest.playlists.concat(getMediaGroupPlaylists(oldManifest));
- var newPlaylists = newManifest.playlists.concat(getMediaGroupPlaylists(newManifest));
- newManifest.timelineStarts = getUniqueTimelineStarts([oldManifest.timelineStarts, newManifest.timelineStarts]);
- updateSequenceNumbers({
- oldPlaylists,
- newPlaylists,
- timelineStarts: newManifest.timelineStarts
- });
- return newManifest;
- };
- var generateSidxKey = function generateSidxKey2(sidx) {
- return sidx && sidx.uri + "-" + byteRangeToString(sidx.byterange);
- };
- var mergeDiscontiguousPlaylists = function mergeDiscontiguousPlaylists2(playlists) {
- var mergedPlaylists = values(playlists.reduce(function(acc, playlist) {
- var name = playlist.attributes.id + (playlist.attributes.lang || "");
- if (!acc[name]) {
- acc[name] = playlist;
- acc[name].attributes.timelineStarts = [];
- } else {
- if (playlist.segments) {
- var _acc$name$segments;
- if (playlist.segments[0]) {
- playlist.segments[0].discontinuity = true;
- }
- (_acc$name$segments = acc[name].segments).push.apply(_acc$name$segments, playlist.segments);
- }
- if (playlist.attributes.contentProtection) {
- acc[name].attributes.contentProtection = playlist.attributes.contentProtection;
- }
- }
- acc[name].attributes.timelineStarts.push({
- start: playlist.attributes.periodStart,
- timeline: playlist.attributes.periodStart
- });
- return acc;
- }, {}));
- return mergedPlaylists.map(function(playlist) {
- playlist.discontinuityStarts = findIndexes(playlist.segments || [], "discontinuity");
- return playlist;
- });
- };
- var addSidxSegmentsToPlaylist2 = function addSidxSegmentsToPlaylist3(playlist, sidxMapping) {
- var sidxKey = generateSidxKey(playlist.sidx);
- var sidxMatch = sidxKey && sidxMapping[sidxKey] && sidxMapping[sidxKey].sidx;
- if (sidxMatch) {
- addSidxSegmentsToPlaylist$1(playlist, sidxMatch, playlist.sidx.resolvedUri);
- }
- return playlist;
- };
- var addSidxSegmentsToPlaylists = function addSidxSegmentsToPlaylists2(playlists, sidxMapping) {
- if (sidxMapping === void 0) {
- sidxMapping = {};
- }
- if (!Object.keys(sidxMapping).length) {
- return playlists;
- }
- for (var i2 in playlists) {
- playlists[i2] = addSidxSegmentsToPlaylist2(playlists[i2], sidxMapping);
- }
- return playlists;
- };
- var formatAudioPlaylist = function formatAudioPlaylist2(_ref, isAudioOnly3) {
- var _attributes;
- var attributes = _ref.attributes, segments = _ref.segments, sidx = _ref.sidx, mediaSequence = _ref.mediaSequence, discontinuitySequence = _ref.discontinuitySequence, discontinuityStarts = _ref.discontinuityStarts;
- var playlist = {
- attributes: (_attributes = {
- NAME: attributes.id,
- BANDWIDTH: attributes.bandwidth,
- CODECS: attributes.codecs
- }, _attributes["PROGRAM-ID"] = 1, _attributes),
- uri: "",
- endList: attributes.type === "static",
- timeline: attributes.periodStart,
- resolvedUri: "",
- targetDuration: attributes.duration,
- discontinuitySequence,
- discontinuityStarts,
- timelineStarts: attributes.timelineStarts,
- mediaSequence,
- segments
- };
- if (attributes.contentProtection) {
- playlist.contentProtection = attributes.contentProtection;
- }
- if (sidx) {
- playlist.sidx = sidx;
- }
- if (isAudioOnly3) {
- playlist.attributes.AUDIO = "audio";
- playlist.attributes.SUBTITLES = "subs";
- }
- return playlist;
- };
- var formatVttPlaylist = function formatVttPlaylist2(_ref2) {
- var _m3u8Attributes;
- var attributes = _ref2.attributes, segments = _ref2.segments, mediaSequence = _ref2.mediaSequence, discontinuityStarts = _ref2.discontinuityStarts, discontinuitySequence = _ref2.discontinuitySequence;
- if (typeof segments === "undefined") {
- segments = [{
- uri: attributes.baseUrl,
- timeline: attributes.periodStart,
- resolvedUri: attributes.baseUrl || "",
- duration: attributes.sourceDuration,
- number: 0
- }];
- attributes.duration = attributes.sourceDuration;
- }
- var m3u8Attributes = (_m3u8Attributes = {
- NAME: attributes.id,
- BANDWIDTH: attributes.bandwidth
- }, _m3u8Attributes["PROGRAM-ID"] = 1, _m3u8Attributes);
- if (attributes.codecs) {
- m3u8Attributes.CODECS = attributes.codecs;
- }
- return {
- attributes: m3u8Attributes,
- uri: "",
- endList: attributes.type === "static",
- timeline: attributes.periodStart,
- resolvedUri: attributes.baseUrl || "",
- targetDuration: attributes.duration,
- timelineStarts: attributes.timelineStarts,
- discontinuityStarts,
- discontinuitySequence,
- mediaSequence,
- segments
- };
- };
- var organizeAudioPlaylists = function organizeAudioPlaylists2(playlists, sidxMapping, isAudioOnly3) {
- if (sidxMapping === void 0) {
- sidxMapping = {};
- }
- if (isAudioOnly3 === void 0) {
- isAudioOnly3 = false;
- }
- var mainPlaylist;
- var formattedPlaylists = playlists.reduce(function(a, playlist) {
- var role = playlist.attributes.role && playlist.attributes.role.value || "";
- var language = playlist.attributes.lang || "";
- var label2 = playlist.attributes.label || "main";
- if (language && !playlist.attributes.label) {
- var roleLabel = role ? " (" + role + ")" : "";
- label2 = "" + playlist.attributes.lang + roleLabel;
- }
- if (!a[label2]) {
- a[label2] = {
- language,
- autoselect: true,
- default: role === "main",
- playlists: [],
- uri: ""
- };
- }
- var formatted = addSidxSegmentsToPlaylist2(formatAudioPlaylist(playlist, isAudioOnly3), sidxMapping);
- a[label2].playlists.push(formatted);
- if (typeof mainPlaylist === "undefined" && role === "main") {
- mainPlaylist = playlist;
- mainPlaylist.default = true;
- }
- return a;
- }, {});
- if (!mainPlaylist) {
- var firstLabel = Object.keys(formattedPlaylists)[0];
- formattedPlaylists[firstLabel].default = true;
- }
- return formattedPlaylists;
- };
- var organizeVttPlaylists = function organizeVttPlaylists2(playlists, sidxMapping) {
- if (sidxMapping === void 0) {
- sidxMapping = {};
- }
- return playlists.reduce(function(a, playlist) {
- var label2 = playlist.attributes.lang || "text";
- if (!a[label2]) {
- a[label2] = {
- language: label2,
- default: false,
- autoselect: false,
- playlists: [],
- uri: ""
- };
- }
- a[label2].playlists.push(addSidxSegmentsToPlaylist2(formatVttPlaylist(playlist), sidxMapping));
- return a;
- }, {});
- };
- var organizeCaptionServices = function organizeCaptionServices2(captionServices) {
- return captionServices.reduce(function(svcObj, svc) {
- if (!svc) {
- return svcObj;
- }
- svc.forEach(function(service) {
- var channel = service.channel, language = service.language;
- svcObj[language] = {
- autoselect: false,
- default: false,
- instreamId: channel,
- language
- };
- if (service.hasOwnProperty("aspectRatio")) {
- svcObj[language].aspectRatio = service.aspectRatio;
- }
- if (service.hasOwnProperty("easyReader")) {
- svcObj[language].easyReader = service.easyReader;
- }
- if (service.hasOwnProperty("3D")) {
- svcObj[language]["3D"] = service["3D"];
- }
- });
- return svcObj;
- }, {});
- };
- var formatVideoPlaylist = function formatVideoPlaylist2(_ref3) {
- var _attributes2;
- var attributes = _ref3.attributes, segments = _ref3.segments, sidx = _ref3.sidx, discontinuityStarts = _ref3.discontinuityStarts;
- var playlist = {
- attributes: (_attributes2 = {
- NAME: attributes.id,
- AUDIO: "audio",
- SUBTITLES: "subs",
- RESOLUTION: {
- width: attributes.width,
- height: attributes.height
- },
- CODECS: attributes.codecs,
- BANDWIDTH: attributes.bandwidth
- }, _attributes2["PROGRAM-ID"] = 1, _attributes2),
- uri: "",
- endList: attributes.type === "static",
- timeline: attributes.periodStart,
- resolvedUri: "",
- targetDuration: attributes.duration,
- discontinuityStarts,
- timelineStarts: attributes.timelineStarts,
- segments
- };
- if (attributes.frameRate) {
- playlist.attributes["FRAME-RATE"] = attributes.frameRate;
- }
- if (attributes.contentProtection) {
- playlist.contentProtection = attributes.contentProtection;
- }
- if (sidx) {
- playlist.sidx = sidx;
- }
- return playlist;
- };
- var videoOnly = function videoOnly2(_ref4) {
- var attributes = _ref4.attributes;
- return attributes.mimeType === "video/mp4" || attributes.mimeType === "video/webm" || attributes.contentType === "video";
- };
- var audioOnly = function audioOnly2(_ref5) {
- var attributes = _ref5.attributes;
- return attributes.mimeType === "audio/mp4" || attributes.mimeType === "audio/webm" || attributes.contentType === "audio";
- };
- var vttOnly = function vttOnly2(_ref6) {
- var attributes = _ref6.attributes;
- return attributes.mimeType === "text/vtt" || attributes.contentType === "text";
- };
- var addMediaSequenceValues = function addMediaSequenceValues2(playlists, timelineStarts) {
- playlists.forEach(function(playlist) {
- playlist.mediaSequence = 0;
- playlist.discontinuitySequence = findIndex(timelineStarts, function(_ref7) {
- var timeline = _ref7.timeline;
- return timeline === playlist.timeline;
- });
- if (!playlist.segments) {
- return;
- }
- playlist.segments.forEach(function(segment, index2) {
- segment.number = index2;
- });
- });
- };
- var flattenMediaGroupPlaylists = function flattenMediaGroupPlaylists2(mediaGroupObject) {
- if (!mediaGroupObject) {
- return [];
- }
- return Object.keys(mediaGroupObject).reduce(function(acc, label2) {
- var labelContents = mediaGroupObject[label2];
- return acc.concat(labelContents.playlists);
- }, []);
- };
- var toM3u8 = function toM3u82(_ref8) {
- var _mediaGroups;
- var dashPlaylists = _ref8.dashPlaylists, locations = _ref8.locations, _ref8$sidxMapping = _ref8.sidxMapping, sidxMapping = _ref8$sidxMapping === void 0 ? {} : _ref8$sidxMapping, previousManifest = _ref8.previousManifest;
- if (!dashPlaylists.length) {
- return {};
- }
- var _dashPlaylists$0$attr = dashPlaylists[0].attributes, duration5 = _dashPlaylists$0$attr.sourceDuration, type2 = _dashPlaylists$0$attr.type, suggestedPresentationDelay2 = _dashPlaylists$0$attr.suggestedPresentationDelay, minimumUpdatePeriod2 = _dashPlaylists$0$attr.minimumUpdatePeriod;
- var videoPlaylists = mergeDiscontiguousPlaylists(dashPlaylists.filter(videoOnly)).map(formatVideoPlaylist);
- var audioPlaylists = mergeDiscontiguousPlaylists(dashPlaylists.filter(audioOnly));
- var vttPlaylists = mergeDiscontiguousPlaylists(dashPlaylists.filter(vttOnly));
- var captions = dashPlaylists.map(function(playlist) {
- return playlist.attributes.captionServices;
- }).filter(Boolean);
- var manifest = {
- allowCache: true,
- discontinuityStarts: [],
- segments: [],
- endList: true,
- mediaGroups: (_mediaGroups = {
- AUDIO: {},
- VIDEO: {}
- }, _mediaGroups["CLOSED-CAPTIONS"] = {}, _mediaGroups.SUBTITLES = {}, _mediaGroups),
- uri: "",
- duration: duration5,
- playlists: addSidxSegmentsToPlaylists(videoPlaylists, sidxMapping)
- };
- if (minimumUpdatePeriod2 >= 0) {
- manifest.minimumUpdatePeriod = minimumUpdatePeriod2 * 1e3;
- }
- if (locations) {
- manifest.locations = locations;
- }
- if (type2 === "dynamic") {
- manifest.suggestedPresentationDelay = suggestedPresentationDelay2;
- }
- var isAudioOnly3 = manifest.playlists.length === 0;
- var organizedAudioGroup = audioPlaylists.length ? organizeAudioPlaylists(audioPlaylists, sidxMapping, isAudioOnly3) : null;
- var organizedVttGroup = vttPlaylists.length ? organizeVttPlaylists(vttPlaylists, sidxMapping) : null;
- var formattedPlaylists = videoPlaylists.concat(flattenMediaGroupPlaylists(organizedAudioGroup), flattenMediaGroupPlaylists(organizedVttGroup));
- var playlistTimelineStarts = formattedPlaylists.map(function(_ref9) {
- var timelineStarts = _ref9.timelineStarts;
- return timelineStarts;
- });
- manifest.timelineStarts = getUniqueTimelineStarts(playlistTimelineStarts);
- addMediaSequenceValues(formattedPlaylists, manifest.timelineStarts);
- if (organizedAudioGroup) {
- manifest.mediaGroups.AUDIO.audio = organizedAudioGroup;
- }
- if (organizedVttGroup) {
- manifest.mediaGroups.SUBTITLES.subs = organizedVttGroup;
- }
- if (captions.length) {
- manifest.mediaGroups["CLOSED-CAPTIONS"].cc = organizeCaptionServices(captions);
- }
- if (previousManifest) {
- return positionManifestOnTimeline({
- oldManifest: previousManifest,
- newManifest: manifest
- });
- }
- return manifest;
- };
- var getLiveRValue = function getLiveRValue2(attributes, time, duration5) {
- var NOW = attributes.NOW, clientOffset = attributes.clientOffset, availabilityStartTime2 = attributes.availabilityStartTime, _attributes$timescale = attributes.timescale, timescale2 = _attributes$timescale === void 0 ? 1 : _attributes$timescale, _attributes$periodSta = attributes.periodStart, periodStart = _attributes$periodSta === void 0 ? 0 : _attributes$periodSta, _attributes$minimumUp = attributes.minimumUpdatePeriod, minimumUpdatePeriod2 = _attributes$minimumUp === void 0 ? 0 : _attributes$minimumUp;
- var now2 = (NOW + clientOffset) / 1e3;
- var periodStartWC = availabilityStartTime2 + periodStart;
- var periodEndWC = now2 + minimumUpdatePeriod2;
- var periodDuration = periodEndWC - periodStartWC;
- return Math.ceil((periodDuration * timescale2 - time) / duration5);
- };
- var parseByTimeline = function parseByTimeline2(attributes, segmentTimeline) {
- var type2 = attributes.type, _attributes$minimumUp2 = attributes.minimumUpdatePeriod, minimumUpdatePeriod2 = _attributes$minimumUp2 === void 0 ? 0 : _attributes$minimumUp2, _attributes$media = attributes.media, media = _attributes$media === void 0 ? "" : _attributes$media, sourceDuration = attributes.sourceDuration, _attributes$timescale2 = attributes.timescale, timescale2 = _attributes$timescale2 === void 0 ? 1 : _attributes$timescale2, _attributes$startNumb = attributes.startNumber, startNumber2 = _attributes$startNumb === void 0 ? 1 : _attributes$startNumb, timeline = attributes.periodStart;
- var segments = [];
- var time = -1;
- for (var sIndex = 0; sIndex < segmentTimeline.length; sIndex++) {
- var S = segmentTimeline[sIndex];
- var duration5 = S.d;
- var repeat = S.r || 0;
- var segmentTime = S.t || 0;
- if (time < 0) {
- time = segmentTime;
- }
- if (segmentTime && segmentTime > time) {
- time = segmentTime;
- }
- var count = void 0;
- if (repeat < 0) {
- var nextS = sIndex + 1;
- if (nextS === segmentTimeline.length) {
- if (type2 === "dynamic" && minimumUpdatePeriod2 > 0 && media.indexOf("$Number$") > 0) {
- count = getLiveRValue(attributes, time, duration5);
- } else {
- count = (sourceDuration * timescale2 - time) / duration5;
- }
- } else {
- count = (segmentTimeline[nextS].t - time) / duration5;
- }
- } else {
- count = repeat + 1;
- }
- var end = startNumber2 + segments.length + count;
- var number = startNumber2 + segments.length;
- while (number < end) {
- segments.push({
- number,
- duration: duration5 / timescale2,
- time,
- timeline
- });
- time += duration5;
- number++;
- }
- }
- return segments;
- };
- var identifierPattern = /\$([A-z]*)(?:(%0)([0-9]+)d)?\$/g;
- var identifierReplacement = function identifierReplacement2(values3) {
- return function(match, identifier, format, width2) {
- if (match === "$$") {
- return "$";
- }
- if (typeof values3[identifier] === "undefined") {
- return match;
- }
- var value = "" + values3[identifier];
- if (identifier === "RepresentationID") {
- return value;
- }
- if (!format) {
- width2 = 1;
- } else {
- width2 = parseInt(width2, 10);
- }
- if (value.length >= width2) {
- return value;
- }
- return "" + new Array(width2 - value.length + 1).join("0") + value;
- };
- };
- var constructTemplateUrl = function constructTemplateUrl2(url, values3) {
- return url.replace(identifierPattern, identifierReplacement(values3));
- };
- var parseTemplateInfo = function parseTemplateInfo2(attributes, segmentTimeline) {
- if (!attributes.duration && !segmentTimeline) {
- return [{
- number: attributes.startNumber || 1,
- duration: attributes.sourceDuration,
- time: 0,
- timeline: attributes.periodStart
- }];
- }
- if (attributes.duration) {
- return parseByDuration(attributes);
- }
- return parseByTimeline(attributes, segmentTimeline);
- };
- var segmentsFromTemplate = function segmentsFromTemplate2(attributes, segmentTimeline) {
- var templateValues = {
- RepresentationID: attributes.id,
- Bandwidth: attributes.bandwidth || 0
- };
- var _attributes$initializ = attributes.initialization, initialization = _attributes$initializ === void 0 ? {
- sourceURL: "",
- range: ""
- } : _attributes$initializ;
- var mapSegment = urlTypeToSegment({
- baseUrl: attributes.baseUrl,
- source: constructTemplateUrl(initialization.sourceURL, templateValues),
- range: initialization.range
- });
- var segments = parseTemplateInfo(attributes, segmentTimeline);
- return segments.map(function(segment) {
- templateValues.Number = segment.number;
- templateValues.Time = segment.time;
- var uri = constructTemplateUrl(attributes.media || "", templateValues);
- var timescale2 = attributes.timescale || 1;
- var presentationTimeOffset2 = attributes.presentationTimeOffset || 0;
- var presentationTime = attributes.periodStart + (segment.time - presentationTimeOffset2) / timescale2;
- var map = {
- uri,
- timeline: segment.timeline,
- duration: segment.duration,
- resolvedUri: resolveUrl$1(attributes.baseUrl || "", uri),
- map: mapSegment,
- number: segment.number,
- presentationTime
- };
- return map;
- });
- };
- var SegmentURLToSegmentObject = function SegmentURLToSegmentObject2(attributes, segmentUrl) {
- var baseUrl = attributes.baseUrl, _attributes$initializ = attributes.initialization, initialization = _attributes$initializ === void 0 ? {} : _attributes$initializ;
- var initSegment = urlTypeToSegment({
- baseUrl,
- source: initialization.sourceURL,
- range: initialization.range
- });
- var segment = urlTypeToSegment({
- baseUrl,
- source: segmentUrl.media,
- range: segmentUrl.mediaRange
- });
- segment.map = initSegment;
- return segment;
- };
- var segmentsFromList = function segmentsFromList2(attributes, segmentTimeline) {
- var duration5 = attributes.duration, _attributes$segmentUr = attributes.segmentUrls, segmentUrls = _attributes$segmentUr === void 0 ? [] : _attributes$segmentUr, periodStart = attributes.periodStart;
- if (!duration5 && !segmentTimeline || duration5 && segmentTimeline) {
- throw new Error(errors.SEGMENT_TIME_UNSPECIFIED);
- }
- var segmentUrlMap = segmentUrls.map(function(segmentUrlObject) {
- return SegmentURLToSegmentObject(attributes, segmentUrlObject);
- });
- var segmentTimeInfo;
- if (duration5) {
- segmentTimeInfo = parseByDuration(attributes);
- }
- if (segmentTimeline) {
- segmentTimeInfo = parseByTimeline(attributes, segmentTimeline);
- }
- var segments = segmentTimeInfo.map(function(segmentTime, index2) {
- if (segmentUrlMap[index2]) {
- var segment = segmentUrlMap[index2];
- var timescale2 = attributes.timescale || 1;
- var presentationTimeOffset2 = attributes.presentationTimeOffset || 0;
- segment.timeline = segmentTime.timeline;
- segment.duration = segmentTime.duration;
- segment.number = segmentTime.number;
- segment.presentationTime = periodStart + (segmentTime.time - presentationTimeOffset2) / timescale2;
- return segment;
- }
- }).filter(function(segment) {
- return segment;
- });
- return segments;
- };
- var generateSegments = function generateSegments2(_ref) {
- var attributes = _ref.attributes, segmentInfo = _ref.segmentInfo;
- var segmentAttributes;
- var segmentsFn;
- if (segmentInfo.template) {
- segmentsFn = segmentsFromTemplate;
- segmentAttributes = merge(attributes, segmentInfo.template);
- } else if (segmentInfo.base) {
- segmentsFn = segmentsFromBase;
- segmentAttributes = merge(attributes, segmentInfo.base);
- } else if (segmentInfo.list) {
- segmentsFn = segmentsFromList;
- segmentAttributes = merge(attributes, segmentInfo.list);
- }
- var segmentsInfo = {
- attributes
- };
- if (!segmentsFn) {
- return segmentsInfo;
- }
- var segments = segmentsFn(segmentAttributes, segmentInfo.segmentTimeline);
- if (segmentAttributes.duration) {
- var _segmentAttributes = segmentAttributes, duration5 = _segmentAttributes.duration, _segmentAttributes$ti = _segmentAttributes.timescale, timescale2 = _segmentAttributes$ti === void 0 ? 1 : _segmentAttributes$ti;
- segmentAttributes.duration = duration5 / timescale2;
- } else if (segments.length) {
- segmentAttributes.duration = segments.reduce(function(max2, segment) {
- return Math.max(max2, Math.ceil(segment.duration));
- }, 0);
- } else {
- segmentAttributes.duration = 0;
- }
- segmentsInfo.attributes = segmentAttributes;
- segmentsInfo.segments = segments;
- if (segmentInfo.base && segmentAttributes.indexRange) {
- segmentsInfo.sidx = segments[0];
- segmentsInfo.segments = [];
- }
- return segmentsInfo;
- };
- var toPlaylists = function toPlaylists2(representations) {
- return representations.map(generateSegments);
- };
- var findChildren = function findChildren2(element, name) {
- return from(element.childNodes).filter(function(_ref) {
- var tagName = _ref.tagName;
- return tagName === name;
- });
- };
- var getContent = function getContent2(element) {
- return element.textContent.trim();
- };
- var parseDivisionValue = function parseDivisionValue2(value) {
- return parseFloat(value.split("/").reduce(function(prev, current) {
- return prev / current;
- }));
- };
- var parseDuration = function parseDuration2(str) {
- var SECONDS_IN_YEAR = 365 * 24 * 60 * 60;
- var SECONDS_IN_MONTH = 30 * 24 * 60 * 60;
- var SECONDS_IN_DAY = 24 * 60 * 60;
- var SECONDS_IN_HOUR = 60 * 60;
- var SECONDS_IN_MIN = 60;
- var durationRegex = /P(?:(\d*)Y)?(?:(\d*)M)?(?:(\d*)D)?(?:T(?:(\d*)H)?(?:(\d*)M)?(?:([\d.]*)S)?)?/;
- var match = durationRegex.exec(str);
- if (!match) {
- return 0;
- }
- var _match$slice = match.slice(1), year = _match$slice[0], month = _match$slice[1], day = _match$slice[2], hour = _match$slice[3], minute = _match$slice[4], second = _match$slice[5];
- return parseFloat(year || 0) * SECONDS_IN_YEAR + parseFloat(month || 0) * SECONDS_IN_MONTH + parseFloat(day || 0) * SECONDS_IN_DAY + parseFloat(hour || 0) * SECONDS_IN_HOUR + parseFloat(minute || 0) * SECONDS_IN_MIN + parseFloat(second || 0);
- };
- var parseDate = function parseDate2(str) {
- var dateRegex = /^\d+-\d+-\d+T\d+:\d+:\d+(\.\d+)?$/;
- if (dateRegex.test(str)) {
- str += "Z";
- }
- return Date.parse(str);
- };
- var parsers = {
- mediaPresentationDuration: function mediaPresentationDuration(value) {
- return parseDuration(value);
- },
- availabilityStartTime: function availabilityStartTime(value) {
- return parseDate(value) / 1e3;
- },
- minimumUpdatePeriod: function minimumUpdatePeriod(value) {
- return parseDuration(value);
- },
- suggestedPresentationDelay: function suggestedPresentationDelay(value) {
- return parseDuration(value);
- },
- type: function type(value) {
- return value;
- },
- timeShiftBufferDepth: function timeShiftBufferDepth(value) {
- return parseDuration(value);
- },
- start: function start(value) {
- return parseDuration(value);
- },
- width: function width(value) {
- return parseInt(value, 10);
- },
- height: function height(value) {
- return parseInt(value, 10);
- },
- bandwidth: function bandwidth(value) {
- return parseInt(value, 10);
- },
- frameRate: function frameRate(value) {
- return parseDivisionValue(value);
- },
- startNumber: function startNumber(value) {
- return parseInt(value, 10);
- },
- timescale: function timescale(value) {
- return parseInt(value, 10);
- },
- presentationTimeOffset: function presentationTimeOffset(value) {
- return parseInt(value, 10);
- },
- duration: function duration(value) {
- var parsedValue = parseInt(value, 10);
- if (isNaN(parsedValue)) {
- return parseDuration(value);
- }
- return parsedValue;
- },
- d: function d(value) {
- return parseInt(value, 10);
- },
- t: function t(value) {
- return parseInt(value, 10);
- },
- r: function r(value) {
- return parseInt(value, 10);
- },
- DEFAULT: function DEFAULT(value) {
- return value;
- }
- };
- var parseAttributes2 = function parseAttributes3(el) {
- if (!(el && el.attributes)) {
- return {};
- }
- return from(el.attributes).reduce(function(a, e) {
- var parseFn = parsers[e.name] || parsers.DEFAULT;
- a[e.name] = parseFn(e.value);
- return a;
- }, {});
- };
- var keySystemsMap = {
- "urn:uuid:1077efec-c0b2-4d02-ace3-3c1e52e2fb4b": "org.w3.clearkey",
- "urn:uuid:edef8ba9-79d6-4ace-a3c8-27dcd51d21ed": "com.widevine.alpha",
- "urn:uuid:9a04f079-9840-4286-ab92-e65be0885f95": "com.microsoft.playready",
- "urn:uuid:f239e769-efa3-4850-9c16-a903c6932efb": "com.adobe.primetime"
- };
- var buildBaseUrls = function buildBaseUrls2(referenceUrls, baseUrlElements) {
- if (!baseUrlElements.length) {
- return referenceUrls;
- }
- return flatten(referenceUrls.map(function(reference) {
- return baseUrlElements.map(function(baseUrlElement) {
- return resolveUrl$1(reference, getContent(baseUrlElement));
- });
- }));
- };
- var getSegmentInformation = function getSegmentInformation2(adaptationSet) {
- var segmentTemplate = findChildren(adaptationSet, "SegmentTemplate")[0];
- var segmentList = findChildren(adaptationSet, "SegmentList")[0];
- var segmentUrls = segmentList && findChildren(segmentList, "SegmentURL").map(function(s) {
- return merge({
- tag: "SegmentURL"
- }, parseAttributes2(s));
- });
- var segmentBase = findChildren(adaptationSet, "SegmentBase")[0];
- var segmentTimelineParentNode = segmentList || segmentTemplate;
- var segmentTimeline = segmentTimelineParentNode && findChildren(segmentTimelineParentNode, "SegmentTimeline")[0];
- var segmentInitializationParentNode = segmentList || segmentBase || segmentTemplate;
- var segmentInitialization = segmentInitializationParentNode && findChildren(segmentInitializationParentNode, "Initialization")[0];
- var template = segmentTemplate && parseAttributes2(segmentTemplate);
- if (template && segmentInitialization) {
- template.initialization = segmentInitialization && parseAttributes2(segmentInitialization);
- } else if (template && template.initialization) {
- template.initialization = {
- sourceURL: template.initialization
- };
- }
- var segmentInfo = {
- template,
- segmentTimeline: segmentTimeline && findChildren(segmentTimeline, "S").map(function(s) {
- return parseAttributes2(s);
- }),
- list: segmentList && merge(parseAttributes2(segmentList), {
- segmentUrls,
- initialization: parseAttributes2(segmentInitialization)
- }),
- base: segmentBase && merge(parseAttributes2(segmentBase), {
- initialization: parseAttributes2(segmentInitialization)
- })
- };
- Object.keys(segmentInfo).forEach(function(key) {
- if (!segmentInfo[key]) {
- delete segmentInfo[key];
- }
- });
- return segmentInfo;
- };
- var inheritBaseUrls = function inheritBaseUrls2(adaptationSetAttributes, adaptationSetBaseUrls, adaptationSetSegmentInfo) {
- return function(representation) {
- var repBaseUrlElements = findChildren(representation, "BaseURL");
- var repBaseUrls = buildBaseUrls(adaptationSetBaseUrls, repBaseUrlElements);
- var attributes = merge(adaptationSetAttributes, parseAttributes2(representation));
- var representationSegmentInfo = getSegmentInformation(representation);
- return repBaseUrls.map(function(baseUrl) {
- return {
- segmentInfo: merge(adaptationSetSegmentInfo, representationSegmentInfo),
- attributes: merge(attributes, {
- baseUrl
- })
- };
- });
- };
- };
- var generateKeySystemInformation = function generateKeySystemInformation2(contentProtectionNodes) {
- return contentProtectionNodes.reduce(function(acc, node) {
- var attributes = parseAttributes2(node);
- if (attributes.schemeIdUri) {
- attributes.schemeIdUri = attributes.schemeIdUri.toLowerCase();
- }
- var keySystem = keySystemsMap[attributes.schemeIdUri];
- if (keySystem) {
- acc[keySystem] = {
- attributes
- };
- var psshNode = findChildren(node, "cenc:pssh")[0];
- if (psshNode) {
- var pssh = getContent(psshNode);
- acc[keySystem].pssh = pssh && decodeB64ToUint8Array(pssh);
- }
- }
- return acc;
- }, {});
- };
- var parseCaptionServiceMetadata = function parseCaptionServiceMetadata2(service) {
- if (service.schemeIdUri === "urn:scte:dash:cc:cea-608:2015") {
- var values3 = typeof service.value !== "string" ? [] : service.value.split(";");
- return values3.map(function(value) {
- var channel;
- var language;
- language = value;
- if (/^CC\d=/.test(value)) {
- var _value$split = value.split("=");
- channel = _value$split[0];
- language = _value$split[1];
- } else if (/^CC\d$/.test(value)) {
- channel = value;
- }
- return {
- channel,
- language
- };
- });
- } else if (service.schemeIdUri === "urn:scte:dash:cc:cea-708:2015") {
- var _values = typeof service.value !== "string" ? [] : service.value.split(";");
- return _values.map(function(value) {
- var flags = {
- "channel": void 0,
- "language": void 0,
- "aspectRatio": 1,
- "easyReader": 0,
- "3D": 0
- };
- if (/=/.test(value)) {
- var _value$split2 = value.split("="), channel = _value$split2[0], _value$split2$ = _value$split2[1], opts = _value$split2$ === void 0 ? "" : _value$split2$;
- flags.channel = channel;
- flags.language = value;
- opts.split(",").forEach(function(opt) {
- var _opt$split = opt.split(":"), name = _opt$split[0], val = _opt$split[1];
- if (name === "lang") {
- flags.language = val;
- } else if (name === "er") {
- flags.easyReader = Number(val);
- } else if (name === "war") {
- flags.aspectRatio = Number(val);
- } else if (name === "3D") {
- flags["3D"] = Number(val);
- }
- });
- } else {
- flags.language = value;
- }
- if (flags.channel) {
- flags.channel = "SERVICE" + flags.channel;
- }
- return flags;
- });
- }
- };
- var toRepresentations = function toRepresentations2(periodAttributes, periodBaseUrls, periodSegmentInfo) {
- return function(adaptationSet) {
- var adaptationSetAttributes = parseAttributes2(adaptationSet);
- var adaptationSetBaseUrls = buildBaseUrls(periodBaseUrls, findChildren(adaptationSet, "BaseURL"));
- var role = findChildren(adaptationSet, "Role")[0];
- var roleAttributes = {
- role: parseAttributes2(role)
- };
- var attrs = merge(periodAttributes, adaptationSetAttributes, roleAttributes);
- var accessibility = findChildren(adaptationSet, "Accessibility")[0];
- var captionServices = parseCaptionServiceMetadata(parseAttributes2(accessibility));
- if (captionServices) {
- attrs = merge(attrs, {
- captionServices
- });
- }
- var label2 = findChildren(adaptationSet, "Label")[0];
- if (label2 && label2.childNodes.length) {
- var labelVal = label2.childNodes[0].nodeValue.trim();
- attrs = merge(attrs, {
- label: labelVal
- });
- }
- var contentProtection = generateKeySystemInformation(findChildren(adaptationSet, "ContentProtection"));
- if (Object.keys(contentProtection).length) {
- attrs = merge(attrs, {
- contentProtection
- });
- }
- var segmentInfo = getSegmentInformation(adaptationSet);
- var representations = findChildren(adaptationSet, "Representation");
- var adaptationSetSegmentInfo = merge(periodSegmentInfo, segmentInfo);
- return flatten(representations.map(inheritBaseUrls(attrs, adaptationSetBaseUrls, adaptationSetSegmentInfo)));
- };
- };
- var toAdaptationSets = function toAdaptationSets2(mpdAttributes, mpdBaseUrls) {
- return function(period, index2) {
- var periodBaseUrls = buildBaseUrls(mpdBaseUrls, findChildren(period.node, "BaseURL"));
- var periodAttributes = merge(mpdAttributes, {
- periodStart: period.attributes.start
- });
- if (typeof period.attributes.duration === "number") {
- periodAttributes.periodDuration = period.attributes.duration;
- }
- var adaptationSets = findChildren(period.node, "AdaptationSet");
- var periodSegmentInfo = getSegmentInformation(period.node);
- return flatten(adaptationSets.map(toRepresentations(periodAttributes, periodBaseUrls, periodSegmentInfo)));
- };
- };
- var getPeriodStart = function getPeriodStart2(_ref) {
- var attributes = _ref.attributes, priorPeriodAttributes = _ref.priorPeriodAttributes, mpdType = _ref.mpdType;
- if (typeof attributes.start === "number") {
- return attributes.start;
- }
- if (priorPeriodAttributes && typeof priorPeriodAttributes.start === "number" && typeof priorPeriodAttributes.duration === "number") {
- return priorPeriodAttributes.start + priorPeriodAttributes.duration;
- }
- if (!priorPeriodAttributes && mpdType === "static") {
- return 0;
- }
- return null;
- };
- var inheritAttributes = function inheritAttributes2(mpd, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var _options = options2, _options$manifestUri = _options.manifestUri, manifestUri = _options$manifestUri === void 0 ? "" : _options$manifestUri, _options$NOW = _options.NOW, NOW = _options$NOW === void 0 ? Date.now() : _options$NOW, _options$clientOffset = _options.clientOffset, clientOffset = _options$clientOffset === void 0 ? 0 : _options$clientOffset;
- var periodNodes = findChildren(mpd, "Period");
- if (!periodNodes.length) {
- throw new Error(errors.INVALID_NUMBER_OF_PERIOD);
- }
- var locations = findChildren(mpd, "Location");
- var mpdAttributes = parseAttributes2(mpd);
- var mpdBaseUrls = buildBaseUrls([manifestUri], findChildren(mpd, "BaseURL"));
- mpdAttributes.type = mpdAttributes.type || "static";
- mpdAttributes.sourceDuration = mpdAttributes.mediaPresentationDuration || 0;
- mpdAttributes.NOW = NOW;
- mpdAttributes.clientOffset = clientOffset;
- if (locations.length) {
- mpdAttributes.locations = locations.map(getContent);
- }
- var periods = [];
- periodNodes.forEach(function(node, index2) {
- var attributes = parseAttributes2(node);
- var priorPeriod = periods[index2 - 1];
- attributes.start = getPeriodStart({
- attributes,
- priorPeriodAttributes: priorPeriod ? priorPeriod.attributes : null,
- mpdType: mpdAttributes.type
- });
- periods.push({
- node,
- attributes
- });
- });
- return {
- locations: mpdAttributes.locations,
- representationInfo: flatten(periods.map(toAdaptationSets(mpdAttributes, mpdBaseUrls)))
- };
- };
- var stringToMpdXml = function stringToMpdXml2(manifestString) {
- if (manifestString === "") {
- throw new Error(errors.DASH_EMPTY_MANIFEST);
- }
- var parser2 = new DOMParser();
- var xml;
- var mpd;
- try {
- xml = parser2.parseFromString(manifestString, "application/xml");
- mpd = xml && xml.documentElement.tagName === "MPD" ? xml.documentElement : null;
- } catch (e) {
- }
- if (!mpd || mpd && mpd.getElementsByTagName("parsererror").length > 0) {
- throw new Error(errors.DASH_INVALID_XML);
- }
- return mpd;
- };
- var parseUTCTimingScheme = function parseUTCTimingScheme2(mpd) {
- var UTCTimingNode = findChildren(mpd, "UTCTiming")[0];
- if (!UTCTimingNode) {
- return null;
- }
- var attributes = parseAttributes2(UTCTimingNode);
- switch (attributes.schemeIdUri) {
- case "urn:mpeg:dash:utc:http-head:2014":
- case "urn:mpeg:dash:utc:http-head:2012":
- attributes.method = "HEAD";
- break;
- case "urn:mpeg:dash:utc:http-xsdate:2014":
- case "urn:mpeg:dash:utc:http-iso:2014":
- case "urn:mpeg:dash:utc:http-xsdate:2012":
- case "urn:mpeg:dash:utc:http-iso:2012":
- attributes.method = "GET";
- break;
- case "urn:mpeg:dash:utc:direct:2014":
- case "urn:mpeg:dash:utc:direct:2012":
- attributes.method = "DIRECT";
- attributes.value = Date.parse(attributes.value);
- break;
- case "urn:mpeg:dash:utc:http-ntp:2014":
- case "urn:mpeg:dash:utc:ntp:2014":
- case "urn:mpeg:dash:utc:sntp:2014":
- default:
- throw new Error(errors.UNSUPPORTED_UTC_TIMING_SCHEME);
- }
- return attributes;
- };
- var parse = function parse2(manifestString, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var parsedManifestInfo = inheritAttributes(stringToMpdXml(manifestString), options2);
- var playlists = toPlaylists(parsedManifestInfo.representationInfo);
- return toM3u8({
- dashPlaylists: playlists,
- locations: parsedManifestInfo.locations,
- sidxMapping: options2.sidxMapping,
- previousManifest: options2.previousManifest
- });
- };
- var parseUTCTiming = function parseUTCTiming2(manifestString) {
- return parseUTCTimingScheme(stringToMpdXml(manifestString));
- };
- var MAX_UINT32 = Math.pow(2, 32);
- var getUint64$1 = function(uint8) {
- var dv = new DataView(uint8.buffer, uint8.byteOffset, uint8.byteLength);
- var value;
- if (dv.getBigUint64) {
- value = dv.getBigUint64(0);
- if (value < Number.MAX_SAFE_INTEGER) {
- return Number(value);
- }
- return value;
- }
- return dv.getUint32(0) * MAX_UINT32 + dv.getUint32(4);
- };
- var numbers = {
- getUint64: getUint64$1,
- MAX_UINT32
- };
- var getUint64 = numbers.getUint64;
- var parseSidx = function(data) {
- var view = new DataView(data.buffer, data.byteOffset, data.byteLength), result = {
- version: data[0],
- flags: new Uint8Array(data.subarray(1, 4)),
- references: [],
- referenceId: view.getUint32(4),
- timescale: view.getUint32(8)
- }, i2 = 12;
- if (result.version === 0) {
- result.earliestPresentationTime = view.getUint32(i2);
- result.firstOffset = view.getUint32(i2 + 4);
- i2 += 8;
- } else {
- result.earliestPresentationTime = getUint64(data.subarray(i2));
- result.firstOffset = getUint64(data.subarray(i2 + 8));
- i2 += 16;
- }
- i2 += 2;
- var referenceCount = view.getUint16(i2);
- i2 += 2;
- for (; referenceCount > 0; i2 += 12, referenceCount--) {
- result.references.push({
- referenceType: (data[i2] & 128) >>> 7,
- referencedSize: view.getUint32(i2) & 2147483647,
- subsegmentDuration: view.getUint32(i2 + 4),
- startsWithSap: !!(data[i2 + 8] & 128),
- sapType: (data[i2 + 8] & 112) >>> 4,
- sapDeltaTime: view.getUint32(i2 + 8) & 268435455
- });
- }
- return result;
- };
- var parseSidx_1 = parseSidx;
- var ID3 = toUint82([73, 68, 51]);
- var getId3Size2 = function getId3Size3(bytes, offset) {
- if (offset === void 0) {
- offset = 0;
- }
- bytes = toUint82(bytes);
- var flags = bytes[offset + 5];
- var returnSize = bytes[offset + 6] << 21 | bytes[offset + 7] << 14 | bytes[offset + 8] << 7 | bytes[offset + 9];
- var footerPresent = (flags & 16) >> 4;
- if (footerPresent) {
- return returnSize + 20;
- }
- return returnSize + 10;
- };
- var getId3Offset2 = function getId3Offset3(bytes, offset) {
- if (offset === void 0) {
- offset = 0;
- }
- bytes = toUint82(bytes);
- if (bytes.length - offset < 10 || !bytesMatch2(bytes, ID3, {
- offset
- })) {
- return offset;
- }
- offset += getId3Size2(bytes, offset);
- return getId3Offset3(bytes, offset);
- };
- var normalizePath$1 = function normalizePath3(path) {
- if (typeof path === "string") {
- return stringToBytes2(path);
- }
- if (typeof path === "number") {
- return path;
- }
- return path;
- };
- var normalizePaths$1 = function normalizePaths3(paths) {
- if (!Array.isArray(paths)) {
- return [normalizePath$1(paths)];
- }
- return paths.map(function(p) {
- return normalizePath$1(p);
- });
- };
- var findBox2 = function findBox3(bytes, paths, complete) {
- if (complete === void 0) {
- complete = false;
- }
- paths = normalizePaths$1(paths);
- bytes = toUint82(bytes);
- var results = [];
- if (!paths.length) {
- return results;
- }
- var i2 = 0;
- while (i2 < bytes.length) {
- var size = (bytes[i2] << 24 | bytes[i2 + 1] << 16 | bytes[i2 + 2] << 8 | bytes[i2 + 3]) >>> 0;
- var type2 = bytes.subarray(i2 + 4, i2 + 8);
- if (size === 0) {
- break;
- }
- var end = i2 + size;
- if (end > bytes.length) {
- if (complete) {
- break;
- }
- end = bytes.length;
- }
- var data = bytes.subarray(i2 + 8, end);
- if (bytesMatch2(type2, paths[0])) {
- if (paths.length === 1) {
- results.push(data);
- } else {
- results.push.apply(results, findBox3(data, paths.slice(1), complete));
- }
- }
- i2 = end;
- }
- return results;
- };
- var EBML_TAGS = {
- EBML: toUint82([26, 69, 223, 163]),
- DocType: toUint82([66, 130]),
- Segment: toUint82([24, 83, 128, 103]),
- SegmentInfo: toUint82([21, 73, 169, 102]),
- Tracks: toUint82([22, 84, 174, 107]),
- Track: toUint82([174]),
- TrackNumber: toUint82([215]),
- DefaultDuration: toUint82([35, 227, 131]),
- TrackEntry: toUint82([174]),
- TrackType: toUint82([131]),
- FlagDefault: toUint82([136]),
- CodecID: toUint82([134]),
- CodecPrivate: toUint82([99, 162]),
- VideoTrack: toUint82([224]),
- AudioTrack: toUint82([225]),
- Cluster: toUint82([31, 67, 182, 117]),
- Timestamp: toUint82([231]),
- TimestampScale: toUint82([42, 215, 177]),
- BlockGroup: toUint82([160]),
- BlockDuration: toUint82([155]),
- Block: toUint82([161]),
- SimpleBlock: toUint82([163])
- };
- var LENGTH_TABLE = [128, 64, 32, 16, 8, 4, 2, 1];
- var getLength2 = function getLength3(byte) {
- var len = 1;
- for (var i2 = 0; i2 < LENGTH_TABLE.length; i2++) {
- if (byte & LENGTH_TABLE[i2]) {
- break;
- }
- len++;
- }
- return len;
- };
- var getvint2 = function getvint3(bytes, offset, removeLength, signed) {
- if (removeLength === void 0) {
- removeLength = true;
- }
- if (signed === void 0) {
- signed = false;
- }
- var length = getLength2(bytes[offset]);
- var valueBytes = bytes.subarray(offset, offset + length);
- if (removeLength) {
- valueBytes = Array.prototype.slice.call(bytes, offset, offset + length);
- valueBytes[0] ^= LENGTH_TABLE[length - 1];
- }
- return {
- length,
- value: bytesToNumber2(valueBytes, {
- signed
- }),
- bytes: valueBytes
- };
- };
- var normalizePath4 = function normalizePath5(path) {
- if (typeof path === "string") {
- return path.match(/.{1,2}/g).map(function(p) {
- return normalizePath5(p);
- });
- }
- if (typeof path === "number") {
- return numberToBytes2(path);
- }
- return path;
- };
- var normalizePaths4 = function normalizePaths5(paths) {
- if (!Array.isArray(paths)) {
- return [normalizePath4(paths)];
- }
- return paths.map(function(p) {
- return normalizePath4(p);
- });
- };
- var getInfinityDataSize2 = function getInfinityDataSize3(id, bytes, offset) {
- if (offset >= bytes.length) {
- return bytes.length;
- }
- var innerid = getvint2(bytes, offset, false);
- if (bytesMatch2(id.bytes, innerid.bytes)) {
- return offset;
- }
- var dataHeader = getvint2(bytes, offset + innerid.length);
- return getInfinityDataSize3(id, bytes, offset + dataHeader.length + dataHeader.value + innerid.length);
- };
- var findEbml2 = function findEbml3(bytes, paths) {
- paths = normalizePaths4(paths);
- bytes = toUint82(bytes);
- var results = [];
- if (!paths.length) {
- return results;
- }
- var i2 = 0;
- while (i2 < bytes.length) {
- var id = getvint2(bytes, i2, false);
- var dataHeader = getvint2(bytes, i2 + id.length);
- var dataStart = i2 + id.length + dataHeader.length;
- if (dataHeader.value === 127) {
- dataHeader.value = getInfinityDataSize2(id, bytes, dataStart);
- if (dataHeader.value !== bytes.length) {
- dataHeader.value -= dataStart;
- }
- }
- var dataEnd = dataStart + dataHeader.value > bytes.length ? bytes.length : dataStart + dataHeader.value;
- var data = bytes.subarray(dataStart, dataEnd);
- if (bytesMatch2(paths[0], id.bytes)) {
- if (paths.length === 1) {
- results.push(data);
- } else {
- results = results.concat(findEbml3(data, paths.slice(1)));
- }
- }
- var totalLength = id.length + dataHeader.length + data.length;
- i2 += totalLength;
- }
- return results;
- };
- var NAL_TYPE_ONE = toUint82([0, 0, 0, 1]);
- var NAL_TYPE_TWO = toUint82([0, 0, 1]);
- var EMULATION_PREVENTION = toUint82([0, 0, 3]);
- var discardEmulationPreventionBytes2 = function discardEmulationPreventionBytes3(bytes) {
- var positions = [];
- var i2 = 1;
- while (i2 < bytes.length - 2) {
- if (bytesMatch2(bytes.subarray(i2, i2 + 3), EMULATION_PREVENTION)) {
- positions.push(i2 + 2);
- i2++;
- }
- i2++;
- }
- if (positions.length === 0) {
- return bytes;
- }
- var newLength = bytes.length - positions.length;
- var newData = new Uint8Array(newLength);
- var sourceIndex = 0;
- for (i2 = 0; i2 < newLength; sourceIndex++, i2++) {
- if (sourceIndex === positions[0]) {
- sourceIndex++;
- positions.shift();
- }
- newData[i2] = bytes[sourceIndex];
- }
- return newData;
- };
- var findNal2 = function findNal3(bytes, dataType, types, nalLimit) {
- if (nalLimit === void 0) {
- nalLimit = Infinity;
- }
- bytes = toUint82(bytes);
- types = [].concat(types);
- var i2 = 0;
- var nalStart;
- var nalsFound = 0;
- while (i2 < bytes.length && (nalsFound < nalLimit || nalStart)) {
- var nalOffset = void 0;
- if (bytesMatch2(bytes.subarray(i2), NAL_TYPE_ONE)) {
- nalOffset = 4;
- } else if (bytesMatch2(bytes.subarray(i2), NAL_TYPE_TWO)) {
- nalOffset = 3;
- }
- if (!nalOffset) {
- i2++;
- continue;
- }
- nalsFound++;
- if (nalStart) {
- return discardEmulationPreventionBytes2(bytes.subarray(nalStart, i2));
- }
- var nalType = void 0;
- if (dataType === "h264") {
- nalType = bytes[i2 + nalOffset] & 31;
- } else if (dataType === "h265") {
- nalType = bytes[i2 + nalOffset] >> 1 & 63;
- }
- if (types.indexOf(nalType) !== -1) {
- nalStart = i2 + nalOffset;
- }
- i2 += nalOffset + (dataType === "h264" ? 1 : 2);
- }
- return bytes.subarray(0, 0);
- };
- var findH264Nal2 = function findH264Nal3(bytes, type2, nalLimit) {
- return findNal2(bytes, "h264", type2, nalLimit);
- };
- var findH265Nal2 = function findH265Nal3(bytes, type2, nalLimit) {
- return findNal2(bytes, "h265", type2, nalLimit);
- };
- var CONSTANTS = {
- "webm": toUint82([119, 101, 98, 109]),
- "matroska": toUint82([109, 97, 116, 114, 111, 115, 107, 97]),
- "flac": toUint82([102, 76, 97, 67]),
- "ogg": toUint82([79, 103, 103, 83]),
- "ac3": toUint82([11, 119]),
- "riff": toUint82([82, 73, 70, 70]),
- "avi": toUint82([65, 86, 73]),
- "wav": toUint82([87, 65, 86, 69]),
- "3gp": toUint82([102, 116, 121, 112, 51, 103]),
- "mp4": toUint82([102, 116, 121, 112]),
- "fmp4": toUint82([115, 116, 121, 112]),
- "mov": toUint82([102, 116, 121, 112, 113, 116]),
- "moov": toUint82([109, 111, 111, 118]),
- "moof": toUint82([109, 111, 111, 102])
- };
- var _isLikely = {
- aac: function aac2(bytes) {
- var offset = getId3Offset2(bytes);
- return bytesMatch2(bytes, [255, 16], {
- offset,
- mask: [255, 22]
- });
- },
- mp3: function mp32(bytes) {
- var offset = getId3Offset2(bytes);
- return bytesMatch2(bytes, [255, 2], {
- offset,
- mask: [255, 6]
- });
- },
- webm: function webm2(bytes) {
- var docType = findEbml2(bytes, [EBML_TAGS.EBML, EBML_TAGS.DocType])[0];
- return bytesMatch2(docType, CONSTANTS.webm);
- },
- mkv: function mkv2(bytes) {
- var docType = findEbml2(bytes, [EBML_TAGS.EBML, EBML_TAGS.DocType])[0];
- return bytesMatch2(docType, CONSTANTS.matroska);
- },
- mp4: function mp42(bytes) {
- if (_isLikely["3gp"](bytes) || _isLikely.mov(bytes)) {
- return false;
- }
- if (bytesMatch2(bytes, CONSTANTS.mp4, {
- offset: 4
- }) || bytesMatch2(bytes, CONSTANTS.fmp4, {
- offset: 4
- })) {
- return true;
- }
- if (bytesMatch2(bytes, CONSTANTS.moof, {
- offset: 4
- }) || bytesMatch2(bytes, CONSTANTS.moov, {
- offset: 4
- })) {
- return true;
- }
- },
- mov: function mov2(bytes) {
- return bytesMatch2(bytes, CONSTANTS.mov, {
- offset: 4
- });
- },
- "3gp": function gp2(bytes) {
- return bytesMatch2(bytes, CONSTANTS["3gp"], {
- offset: 4
- });
- },
- ac3: function ac32(bytes) {
- var offset = getId3Offset2(bytes);
- return bytesMatch2(bytes, CONSTANTS.ac3, {
- offset
- });
- },
- ts: function ts2(bytes) {
- if (bytes.length < 189 && bytes.length >= 1) {
- return bytes[0] === 71;
- }
- var i2 = 0;
- while (i2 + 188 < bytes.length && i2 < 188) {
- if (bytes[i2] === 71 && bytes[i2 + 188] === 71) {
- return true;
- }
- i2 += 1;
- }
- return false;
- },
- flac: function flac2(bytes) {
- var offset = getId3Offset2(bytes);
- return bytesMatch2(bytes, CONSTANTS.flac, {
- offset
- });
- },
- ogg: function ogg2(bytes) {
- return bytesMatch2(bytes, CONSTANTS.ogg);
- },
- avi: function avi2(bytes) {
- return bytesMatch2(bytes, CONSTANTS.riff) && bytesMatch2(bytes, CONSTANTS.avi, {
- offset: 8
- });
- },
- wav: function wav2(bytes) {
- return bytesMatch2(bytes, CONSTANTS.riff) && bytesMatch2(bytes, CONSTANTS.wav, {
- offset: 8
- });
- },
- "h264": function h2642(bytes) {
- return findH264Nal2(bytes, 7, 3).length;
- },
- "h265": function h2652(bytes) {
- return findH265Nal2(bytes, [32, 33], 3).length;
- }
- };
- var isLikelyTypes = Object.keys(_isLikely).filter(function(t2) {
- return t2 !== "ts" && t2 !== "h264" && t2 !== "h265";
- }).concat(["ts", "h264", "h265"]);
- isLikelyTypes.forEach(function(type2) {
- var isLikelyFn = _isLikely[type2];
- _isLikely[type2] = function(bytes) {
- return isLikelyFn(toUint82(bytes));
- };
- });
- var isLikely = _isLikely;
- var detectContainerForBytes2 = function detectContainerForBytes3(bytes) {
- bytes = toUint82(bytes);
- for (var i2 = 0; i2 < isLikelyTypes.length; i2++) {
- var type2 = isLikelyTypes[i2];
- if (isLikely[type2](bytes)) {
- return type2;
- }
- }
- return "";
- };
- var isLikelyFmp4MediaSegment2 = function isLikelyFmp4MediaSegment3(bytes) {
- return findBox2(bytes, ["moof"]).length > 0;
- };
- var ONE_SECOND_IN_TS = 9e4, secondsToVideoTs, secondsToAudioTs, videoTsToSeconds, audioTsToSeconds, audioTsToVideoTs, videoTsToAudioTs, metadataTsToSeconds;
- secondsToVideoTs = function(seconds) {
- return seconds * ONE_SECOND_IN_TS;
- };
- secondsToAudioTs = function(seconds, sampleRate) {
- return seconds * sampleRate;
- };
- videoTsToSeconds = function(timestamp) {
- return timestamp / ONE_SECOND_IN_TS;
- };
- audioTsToSeconds = function(timestamp, sampleRate) {
- return timestamp / sampleRate;
- };
- audioTsToVideoTs = function(timestamp, sampleRate) {
- return secondsToVideoTs(audioTsToSeconds(timestamp, sampleRate));
- };
- videoTsToAudioTs = function(timestamp, sampleRate) {
- return secondsToAudioTs(videoTsToSeconds(timestamp), sampleRate);
- };
- metadataTsToSeconds = function(timestamp, timelineStartPts, keepOriginalTimestamps) {
- return videoTsToSeconds(keepOriginalTimestamps ? timestamp : timestamp - timelineStartPts);
- };
- var clock = {
- ONE_SECOND_IN_TS,
- secondsToVideoTs,
- secondsToAudioTs,
- videoTsToSeconds,
- audioTsToSeconds,
- audioTsToVideoTs,
- videoTsToAudioTs,
- metadataTsToSeconds
- };
- function _getPrototypeOf(o) {
- _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf2(o2) {
- return o2.__proto__ || Object.getPrototypeOf(o2);
- };
- return _getPrototypeOf(o);
- }
- function _isNativeFunction(fn2) {
- return Function.toString.call(fn2).indexOf("[native code]") !== -1;
- }
- function _wrapNativeSuper(Class) {
- var _cache = typeof Map === "function" ? /* @__PURE__ */ new Map() : void 0;
- _wrapNativeSuper = function _wrapNativeSuper2(Class2) {
- if (Class2 === null || !_isNativeFunction(Class2))
- return Class2;
- if (typeof Class2 !== "function") {
- throw new TypeError("Super expression must either be null or a function");
- }
- if (typeof _cache !== "undefined") {
- if (_cache.has(Class2))
- return _cache.get(Class2);
- _cache.set(Class2, Wrapper);
- }
- function Wrapper() {
- return _construct(Class2, arguments, _getPrototypeOf(this).constructor);
- }
- Wrapper.prototype = Object.create(Class2.prototype, {
- constructor: {
- value: Wrapper,
- enumerable: false,
- writable: true,
- configurable: true
- }
- });
- return _setPrototypeOf(Wrapper, Class2);
- };
- return _wrapNativeSuper(Class);
- }
- /**
- * @license
- * Video.js 7.21.4 <http://videojs.com/>
- * Copyright Brightcove, Inc. <https://www.brightcove.com/>
- * Available under Apache License Version 2.0
- * <https://github.com/videojs/video.js/blob/main/LICENSE>
- *
- * Includes vtt.js <https://github.com/mozilla/vtt.js>
- * Available under Apache License Version 2.0
- * <https://github.com/mozilla/vtt.js/blob/main/LICENSE>
- */
- var version$5 = "7.21.4";
- var hooks_ = {};
- var hooks = function hooks2(type2, fn2) {
- hooks_[type2] = hooks_[type2] || [];
- if (fn2) {
- hooks_[type2] = hooks_[type2].concat(fn2);
- }
- return hooks_[type2];
- };
- var hook = function hook2(type2, fn2) {
- hooks(type2, fn2);
- };
- var removeHook = function removeHook2(type2, fn2) {
- var index2 = hooks(type2).indexOf(fn2);
- if (index2 <= -1) {
- return false;
- }
- hooks_[type2] = hooks_[type2].slice();
- hooks_[type2].splice(index2, 1);
- return true;
- };
- var hookOnce = function hookOnce2(type2, fn2) {
- hooks(type2, [].concat(fn2).map(function(original) {
- var wrapper = function wrapper2() {
- removeHook(type2, wrapper2);
- return original.apply(void 0, arguments);
- };
- return wrapper;
- }));
- };
- var FullscreenApi = {
- prefixed: true
- };
- var apiMap = [
- ["requestFullscreen", "exitFullscreen", "fullscreenElement", "fullscreenEnabled", "fullscreenchange", "fullscreenerror", "fullscreen"],
- ["webkitRequestFullscreen", "webkitExitFullscreen", "webkitFullscreenElement", "webkitFullscreenEnabled", "webkitfullscreenchange", "webkitfullscreenerror", "-webkit-full-screen"],
- ["mozRequestFullScreen", "mozCancelFullScreen", "mozFullScreenElement", "mozFullScreenEnabled", "mozfullscreenchange", "mozfullscreenerror", "-moz-full-screen"],
- ["msRequestFullscreen", "msExitFullscreen", "msFullscreenElement", "msFullscreenEnabled", "MSFullscreenChange", "MSFullscreenError", "-ms-fullscreen"]
- ];
- var specApi = apiMap[0];
- var browserApi;
- for (var i$2 = 0; i$2 < apiMap.length; i$2++) {
- if (apiMap[i$2][1] in document_1) {
- browserApi = apiMap[i$2];
- break;
- }
- }
- if (browserApi) {
- for (var _i$1 = 0; _i$1 < browserApi.length; _i$1++) {
- FullscreenApi[specApi[_i$1]] = browserApi[_i$1];
- }
- FullscreenApi.prefixed = browserApi[0] !== specApi[0];
- }
- var history = [];
- var LogByTypeFactory = function LogByTypeFactory2(name, log2) {
- return function(type2, level, args) {
- var lvl = log2.levels[level];
- var lvlRegExp = new RegExp("^(" + lvl + ")$");
- if (type2 !== "log") {
- args.unshift(type2.toUpperCase() + ":");
- }
- args.unshift(name + ":");
- if (history) {
- history.push([].concat(args));
- var splice2 = history.length - 1e3;
- history.splice(0, splice2 > 0 ? splice2 : 0);
- }
- if (!window_1.console) {
- return;
- }
- var fn2 = window_1.console[type2];
- if (!fn2 && type2 === "debug") {
- fn2 = window_1.console.info || window_1.console.log;
- }
- if (!fn2 || !lvl || !lvlRegExp.test(type2)) {
- return;
- }
- fn2[Array.isArray(args) ? "apply" : "call"](window_1.console, args);
- };
- };
- function createLogger$1(name) {
- var level = "info";
- var logByType;
- var log2 = function log3() {
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
- logByType("log", level, args);
- };
- logByType = LogByTypeFactory(name, log2);
- log2.createLogger = function(subname) {
- return createLogger$1(name + ": " + subname);
- };
- log2.levels = {
- all: "debug|log|warn|error",
- off: "",
- debug: "debug|log|warn|error",
- info: "log|warn|error",
- warn: "warn|error",
- error: "error",
- DEFAULT: level
- };
- log2.level = function(lvl) {
- if (typeof lvl === "string") {
- if (!log2.levels.hasOwnProperty(lvl)) {
- throw new Error('"' + lvl + '" in not a valid log level');
- }
- level = lvl;
- }
- return level;
- };
- log2.history = function() {
- return history ? [].concat(history) : [];
- };
- log2.history.filter = function(fname) {
- return (history || []).filter(function(historyItem) {
- return new RegExp(".*" + fname + ".*").test(historyItem[0]);
- });
- };
- log2.history.clear = function() {
- if (history) {
- history.length = 0;
- }
- };
- log2.history.disable = function() {
- if (history !== null) {
- history.length = 0;
- history = null;
- }
- };
- log2.history.enable = function() {
- if (history === null) {
- history = [];
- }
- };
- log2.error = function() {
- for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
- args[_key2] = arguments[_key2];
- }
- return logByType("error", level, args);
- };
- log2.warn = function() {
- for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
- args[_key3] = arguments[_key3];
- }
- return logByType("warn", level, args);
- };
- log2.debug = function() {
- for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {
- args[_key4] = arguments[_key4];
- }
- return logByType("debug", level, args);
- };
- return log2;
- }
- var log$1 = createLogger$1("VIDEOJS");
- var createLogger = log$1.createLogger;
- var toString = Object.prototype.toString;
- var keys = function keys2(object) {
- return isObject2(object) ? Object.keys(object) : [];
- };
- function each(object, fn2) {
- keys(object).forEach(function(key) {
- return fn2(object[key], key);
- });
- }
- function reduce(object, fn2, initial) {
- if (initial === void 0) {
- initial = 0;
- }
- return keys(object).reduce(function(accum, key) {
- return fn2(accum, object[key], key);
- }, initial);
- }
- function assign(target) {
- for (var _len = arguments.length, sources = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
- sources[_key - 1] = arguments[_key];
- }
- if (Object.assign) {
- return _extends$2.apply(void 0, [target].concat(sources));
- }
- sources.forEach(function(source) {
- if (!source) {
- return;
- }
- each(source, function(value, key) {
- target[key] = value;
- });
- });
- return target;
- }
- function isObject2(value) {
- return !!value && typeof value === "object";
- }
- function isPlain(value) {
- return isObject2(value) && toString.call(value) === "[object Object]" && value.constructor === Object;
- }
- function computedStyle(el, prop) {
- if (!el || !prop) {
- return "";
- }
- if (typeof window_1.getComputedStyle === "function") {
- var computedStyleValue;
- try {
- computedStyleValue = window_1.getComputedStyle(el);
- } catch (e) {
- return "";
- }
- return computedStyleValue ? computedStyleValue.getPropertyValue(prop) || computedStyleValue[prop] : "";
- }
- return "";
- }
- var USER_AGENT = window_1.navigator && window_1.navigator.userAgent || "";
- var webkitVersionMap = /AppleWebKit\/([\d.]+)/i.exec(USER_AGENT);
- var appleWebkitVersion = webkitVersionMap ? parseFloat(webkitVersionMap.pop()) : null;
- var IS_IPOD = /iPod/i.test(USER_AGENT);
- var IOS_VERSION = function() {
- var match = USER_AGENT.match(/OS (\d+)_/i);
- if (match && match[1]) {
- return match[1];
- }
- return null;
- }();
- var IS_ANDROID = /Android/i.test(USER_AGENT);
- var ANDROID_VERSION = function() {
- var match = USER_AGENT.match(/Android (\d+)(?:\.(\d+))?(?:\.(\d+))*/i);
- if (!match) {
- return null;
- }
- var major = match[1] && parseFloat(match[1]);
- var minor = match[2] && parseFloat(match[2]);
- if (major && minor) {
- return parseFloat(match[1] + "." + match[2]);
- } else if (major) {
- return major;
- }
- return null;
- }();
- var IS_NATIVE_ANDROID = IS_ANDROID && ANDROID_VERSION < 5 && appleWebkitVersion < 537;
- var IS_FIREFOX = /Firefox/i.test(USER_AGENT);
- var IS_EDGE = /Edg/i.test(USER_AGENT);
- var IS_CHROME = !IS_EDGE && (/Chrome/i.test(USER_AGENT) || /CriOS/i.test(USER_AGENT));
- var CHROME_VERSION = function() {
- var match = USER_AGENT.match(/(Chrome|CriOS)\/(\d+)/);
- if (match && match[2]) {
- return parseFloat(match[2]);
- }
- return null;
- }();
- var IE_VERSION = function() {
- var result = /MSIE\s(\d+)\.\d/.exec(USER_AGENT);
- var version2 = result && parseFloat(result[1]);
- if (!version2 && /Trident\/7.0/i.test(USER_AGENT) && /rv:11.0/.test(USER_AGENT)) {
- version2 = 11;
- }
- return version2;
- }();
- var IS_SAFARI = /Safari/i.test(USER_AGENT) && !IS_CHROME && !IS_ANDROID && !IS_EDGE;
- var IS_WINDOWS = /Windows/i.test(USER_AGENT);
- var TOUCH_ENABLED = Boolean(isReal() && ("ontouchstart" in window_1 || window_1.navigator.maxTouchPoints || window_1.DocumentTouch && window_1.document instanceof window_1.DocumentTouch));
- var IS_IPAD = /iPad/i.test(USER_AGENT) || IS_SAFARI && TOUCH_ENABLED && !/iPhone/i.test(USER_AGENT);
- var IS_IPHONE = /iPhone/i.test(USER_AGENT) && !IS_IPAD;
- var IS_IOS = IS_IPHONE || IS_IPAD || IS_IPOD;
- var IS_ANY_SAFARI = (IS_SAFARI || IS_IOS) && !IS_CHROME;
- var browser = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- IS_IPOD,
- IOS_VERSION,
- IS_ANDROID,
- ANDROID_VERSION,
- IS_NATIVE_ANDROID,
- IS_FIREFOX,
- IS_EDGE,
- IS_CHROME,
- CHROME_VERSION,
- IE_VERSION,
- IS_SAFARI,
- IS_WINDOWS,
- TOUCH_ENABLED,
- IS_IPAD,
- IS_IPHONE,
- IS_IOS,
- IS_ANY_SAFARI
- });
- function isNonBlankString(str) {
- return typeof str === "string" && Boolean(str.trim());
- }
- function throwIfWhitespace(str) {
- if (str.indexOf(" ") >= 0) {
- throw new Error("class has illegal whitespace characters");
- }
- }
- function classRegExp(className) {
- return new RegExp("(^|\\s)" + className + "($|\\s)");
- }
- function isReal() {
- return document_1 === window_1.document;
- }
- function isEl(value) {
- return isObject2(value) && value.nodeType === 1;
- }
- function isInFrame() {
- try {
- return window_1.parent !== window_1.self;
- } catch (x) {
- return true;
- }
- }
- function createQuerier(method) {
- return function(selector, context) {
- if (!isNonBlankString(selector)) {
- return document_1[method](null);
- }
- if (isNonBlankString(context)) {
- context = document_1.querySelector(context);
- }
- var ctx = isEl(context) ? context : document_1;
- return ctx[method] && ctx[method](selector);
- };
- }
- function createEl(tagName, properties, attributes, content) {
- if (tagName === void 0) {
- tagName = "div";
- }
- if (properties === void 0) {
- properties = {};
- }
- if (attributes === void 0) {
- attributes = {};
- }
- var el = document_1.createElement(tagName);
- Object.getOwnPropertyNames(properties).forEach(function(propName) {
- var val = properties[propName];
- if (propName.indexOf("aria-") !== -1 || propName === "role" || propName === "type") {
- log$1.warn("Setting attributes in the second argument of createEl()\nhas been deprecated. Use the third argument instead.\n" + ("createEl(type, properties, attributes). Attempting to set " + propName + " to " + val + "."));
- el.setAttribute(propName, val);
- } else if (propName === "textContent") {
- textContent(el, val);
- } else if (el[propName] !== val || propName === "tabIndex") {
- el[propName] = val;
- }
- });
- Object.getOwnPropertyNames(attributes).forEach(function(attrName) {
- el.setAttribute(attrName, attributes[attrName]);
- });
- if (content) {
- appendContent(el, content);
- }
- return el;
- }
- function textContent(el, text) {
- if (typeof el.textContent === "undefined") {
- el.innerText = text;
- } else {
- el.textContent = text;
- }
- return el;
- }
- function prependTo(child, parent) {
- if (parent.firstChild) {
- parent.insertBefore(child, parent.firstChild);
- } else {
- parent.appendChild(child);
- }
- }
- function hasClass(element, classToCheck) {
- throwIfWhitespace(classToCheck);
- if (element.classList) {
- return element.classList.contains(classToCheck);
- }
- return classRegExp(classToCheck).test(element.className);
- }
- function addClass(element, classToAdd) {
- if (element.classList) {
- element.classList.add(classToAdd);
- } else if (!hasClass(element, classToAdd)) {
- element.className = (element.className + " " + classToAdd).trim();
- }
- return element;
- }
- function removeClass(element, classToRemove) {
- if (!element) {
- log$1.warn("removeClass was called with an element that doesn't exist");
- return null;
- }
- if (element.classList) {
- element.classList.remove(classToRemove);
- } else {
- throwIfWhitespace(classToRemove);
- element.className = element.className.split(/\s+/).filter(function(c) {
- return c !== classToRemove;
- }).join(" ");
- }
- return element;
- }
- function toggleClass(element, classToToggle, predicate) {
- var has = hasClass(element, classToToggle);
- if (typeof predicate === "function") {
- predicate = predicate(element, classToToggle);
- }
- if (typeof predicate !== "boolean") {
- predicate = !has;
- }
- if (predicate === has) {
- return;
- }
- if (predicate) {
- addClass(element, classToToggle);
- } else {
- removeClass(element, classToToggle);
- }
- return element;
- }
- function setAttributes(el, attributes) {
- Object.getOwnPropertyNames(attributes).forEach(function(attrName) {
- var attrValue = attributes[attrName];
- if (attrValue === null || typeof attrValue === "undefined" || attrValue === false) {
- el.removeAttribute(attrName);
- } else {
- el.setAttribute(attrName, attrValue === true ? "" : attrValue);
- }
- });
- }
- function getAttributes(tag) {
- var obj = {};
- var knownBooleans = ",autoplay,controls,playsinline,loop,muted,default,defaultMuted,";
- if (tag && tag.attributes && tag.attributes.length > 0) {
- var attrs = tag.attributes;
- for (var i2 = attrs.length - 1; i2 >= 0; i2--) {
- var attrName = attrs[i2].name;
- var attrVal = attrs[i2].value;
- if (typeof tag[attrName] === "boolean" || knownBooleans.indexOf("," + attrName + ",") !== -1) {
- attrVal = attrVal !== null ? true : false;
- }
- obj[attrName] = attrVal;
- }
- }
- return obj;
- }
- function getAttribute(el, attribute) {
- return el.getAttribute(attribute);
- }
- function setAttribute(el, attribute, value) {
- el.setAttribute(attribute, value);
- }
- function removeAttribute(el, attribute) {
- el.removeAttribute(attribute);
- }
- function blockTextSelection() {
- document_1.body.focus();
- document_1.onselectstart = function() {
- return false;
- };
- }
- function unblockTextSelection() {
- document_1.onselectstart = function() {
- return true;
- };
- }
- function getBoundingClientRect(el) {
- if (el && el.getBoundingClientRect && el.parentNode) {
- var rect = el.getBoundingClientRect();
- var result = {};
- ["bottom", "height", "left", "right", "top", "width"].forEach(function(k) {
- if (rect[k] !== void 0) {
- result[k] = rect[k];
- }
- });
- if (!result.height) {
- result.height = parseFloat(computedStyle(el, "height"));
- }
- if (!result.width) {
- result.width = parseFloat(computedStyle(el, "width"));
- }
- return result;
- }
- }
- function findPosition(el) {
- if (!el || el && !el.offsetParent) {
- return {
- left: 0,
- top: 0,
- width: 0,
- height: 0
- };
- }
- var width2 = el.offsetWidth;
- var height2 = el.offsetHeight;
- var left = 0;
- var top = 0;
- while (el.offsetParent && el !== document_1[FullscreenApi.fullscreenElement]) {
- left += el.offsetLeft;
- top += el.offsetTop;
- el = el.offsetParent;
- }
- return {
- left,
- top,
- width: width2,
- height: height2
- };
- }
- function getPointerPosition(el, event2) {
- var translated = {
- x: 0,
- y: 0
- };
- if (IS_IOS) {
- var item = el;
- while (item && item.nodeName.toLowerCase() !== "html") {
- var transform3 = computedStyle(item, "transform");
- if (/^matrix/.test(transform3)) {
- var values3 = transform3.slice(7, -1).split(/,\s/).map(Number);
- translated.x += values3[4];
- translated.y += values3[5];
- } else if (/^matrix3d/.test(transform3)) {
- var _values = transform3.slice(9, -1).split(/,\s/).map(Number);
- translated.x += _values[12];
- translated.y += _values[13];
- }
- item = item.parentNode;
- }
- }
- var position2 = {};
- var boxTarget = findPosition(event2.target);
- var box = findPosition(el);
- var boxW = box.width;
- var boxH = box.height;
- var offsetY = event2.offsetY - (box.top - boxTarget.top);
- var offsetX = event2.offsetX - (box.left - boxTarget.left);
- if (event2.changedTouches) {
- offsetX = event2.changedTouches[0].pageX - box.left;
- offsetY = event2.changedTouches[0].pageY + box.top;
- if (IS_IOS) {
- offsetX -= translated.x;
- offsetY -= translated.y;
- }
- }
- position2.y = 1 - Math.max(0, Math.min(1, offsetY / boxH));
- position2.x = Math.max(0, Math.min(1, offsetX / boxW));
- return position2;
- }
- function isTextNode(value) {
- return isObject2(value) && value.nodeType === 3;
- }
- function emptyEl(el) {
- while (el.firstChild) {
- el.removeChild(el.firstChild);
- }
- return el;
- }
- function normalizeContent(content) {
- if (typeof content === "function") {
- content = content();
- }
- return (Array.isArray(content) ? content : [content]).map(function(value) {
- if (typeof value === "function") {
- value = value();
- }
- if (isEl(value) || isTextNode(value)) {
- return value;
- }
- if (typeof value === "string" && /\S/.test(value)) {
- return document_1.createTextNode(value);
- }
- }).filter(function(value) {
- return value;
- });
- }
- function appendContent(el, content) {
- normalizeContent(content).forEach(function(node) {
- return el.appendChild(node);
- });
- return el;
- }
- function insertContent(el, content) {
- return appendContent(emptyEl(el), content);
- }
- function isSingleLeftClick(event2) {
- if (event2.button === void 0 && event2.buttons === void 0) {
- return true;
- }
- if (event2.button === 0 && event2.buttons === void 0) {
- return true;
- }
- if (event2.type === "mouseup" && event2.button === 0 && event2.buttons === 0) {
- return true;
- }
- if (event2.button !== 0 || event2.buttons !== 1) {
- return false;
- }
- return true;
- }
- var $ = createQuerier("querySelector");
- var $$ = createQuerier("querySelectorAll");
- var Dom$1 = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- isReal,
- isEl,
- isInFrame,
- createEl,
- textContent,
- prependTo,
- hasClass,
- addClass,
- removeClass,
- toggleClass,
- setAttributes,
- getAttributes,
- getAttribute,
- setAttribute,
- removeAttribute,
- blockTextSelection,
- unblockTextSelection,
- getBoundingClientRect,
- findPosition,
- getPointerPosition,
- isTextNode,
- emptyEl,
- normalizeContent,
- appendContent,
- insertContent,
- isSingleLeftClick,
- $,
- $$
- });
- var _windowLoaded = false;
- var videojs$1;
- var autoSetup = function autoSetup2() {
- if (videojs$1.options.autoSetup === false) {
- return;
- }
- var vids = Array.prototype.slice.call(document_1.getElementsByTagName("video"));
- var audios = Array.prototype.slice.call(document_1.getElementsByTagName("audio"));
- var divs = Array.prototype.slice.call(document_1.getElementsByTagName("video-js"));
- var mediaEls = vids.concat(audios, divs);
- if (mediaEls && mediaEls.length > 0) {
- for (var i2 = 0, e = mediaEls.length; i2 < e; i2++) {
- var mediaEl = mediaEls[i2];
- if (mediaEl && mediaEl.getAttribute) {
- if (mediaEl.player === void 0) {
- var options2 = mediaEl.getAttribute("data-setup");
- if (options2 !== null) {
- videojs$1(mediaEl);
- }
- }
- } else {
- autoSetupTimeout(1);
- break;
- }
- }
- } else if (!_windowLoaded) {
- autoSetupTimeout(1);
- }
- };
- function autoSetupTimeout(wait, vjs) {
- if (!isReal()) {
- return;
- }
- if (vjs) {
- videojs$1 = vjs;
- }
- window_1.setTimeout(autoSetup, wait);
- }
- function setWindowLoaded() {
- _windowLoaded = true;
- window_1.removeEventListener("load", setWindowLoaded);
- }
- if (isReal()) {
- if (document_1.readyState === "complete") {
- setWindowLoaded();
- } else {
- window_1.addEventListener("load", setWindowLoaded);
- }
- }
- var createStyleElement = function createStyleElement2(className) {
- var style = document_1.createElement("style");
- style.className = className;
- return style;
- };
- var setTextContent = function setTextContent2(el, content) {
- if (el.styleSheet) {
- el.styleSheet.cssText = content;
- } else {
- el.textContent = content;
- }
- };
- var _initialGuid = 3;
- var _guid = _initialGuid;
- function newGUID() {
- return _guid++;
- }
- var FakeWeakMap;
- if (!window_1.WeakMap) {
- FakeWeakMap = /* @__PURE__ */ function() {
- function FakeWeakMap2() {
- this.vdata = "vdata" + Math.floor(window_1.performance && window_1.performance.now() || Date.now());
- this.data = {};
- }
- var _proto = FakeWeakMap2.prototype;
- _proto.set = function set4(key, value) {
- var access = key[this.vdata] || newGUID();
- if (!key[this.vdata]) {
- key[this.vdata] = access;
- }
- this.data[access] = value;
- return this;
- };
- _proto.get = function get7(key) {
- var access = key[this.vdata];
- if (access) {
- return this.data[access];
- }
- log$1("We have no data for this element", key);
- return void 0;
- };
- _proto.has = function has(key) {
- var access = key[this.vdata];
- return access in this.data;
- };
- _proto["delete"] = function _delete(key) {
- var access = key[this.vdata];
- if (access) {
- delete this.data[access];
- delete key[this.vdata];
- }
- };
- return FakeWeakMap2;
- }();
- }
- var DomData = window_1.WeakMap ? /* @__PURE__ */ new WeakMap() : new FakeWeakMap();
- function _cleanUpEvents(elem, type2) {
- if (!DomData.has(elem)) {
- return;
- }
- var data = DomData.get(elem);
- if (data.handlers[type2].length === 0) {
- delete data.handlers[type2];
- if (elem.removeEventListener) {
- elem.removeEventListener(type2, data.dispatcher, false);
- } else if (elem.detachEvent) {
- elem.detachEvent("on" + type2, data.dispatcher);
- }
- }
- if (Object.getOwnPropertyNames(data.handlers).length <= 0) {
- delete data.handlers;
- delete data.dispatcher;
- delete data.disabled;
- }
- if (Object.getOwnPropertyNames(data).length === 0) {
- DomData["delete"](elem);
- }
- }
- function _handleMultipleEvents(fn2, elem, types, callback2) {
- types.forEach(function(type2) {
- fn2(elem, type2, callback2);
- });
- }
- function fixEvent(event2) {
- if (event2.fixed_) {
- return event2;
- }
- function returnTrue() {
- return true;
- }
- function returnFalse() {
- return false;
- }
- if (!event2 || !event2.isPropagationStopped || !event2.isImmediatePropagationStopped) {
- var old = event2 || window_1.event;
- event2 = {};
- for (var key in old) {
- if (key !== "layerX" && key !== "layerY" && key !== "keyLocation" && key !== "webkitMovementX" && key !== "webkitMovementY" && key !== "path") {
- if (!(key === "returnValue" && old.preventDefault)) {
- event2[key] = old[key];
- }
- }
- }
- if (!event2.target) {
- event2.target = event2.srcElement || document_1;
- }
- if (!event2.relatedTarget) {
- event2.relatedTarget = event2.fromElement === event2.target ? event2.toElement : event2.fromElement;
- }
- event2.preventDefault = function() {
- if (old.preventDefault) {
- old.preventDefault();
- }
- event2.returnValue = false;
- old.returnValue = false;
- event2.defaultPrevented = true;
- };
- event2.defaultPrevented = false;
- event2.stopPropagation = function() {
- if (old.stopPropagation) {
- old.stopPropagation();
- }
- event2.cancelBubble = true;
- old.cancelBubble = true;
- event2.isPropagationStopped = returnTrue;
- };
- event2.isPropagationStopped = returnFalse;
- event2.stopImmediatePropagation = function() {
- if (old.stopImmediatePropagation) {
- old.stopImmediatePropagation();
- }
- event2.isImmediatePropagationStopped = returnTrue;
- event2.stopPropagation();
- };
- event2.isImmediatePropagationStopped = returnFalse;
- if (event2.clientX !== null && event2.clientX !== void 0) {
- var doc = document_1.documentElement;
- var body = document_1.body;
- event2.pageX = event2.clientX + (doc && doc.scrollLeft || body && body.scrollLeft || 0) - (doc && doc.clientLeft || body && body.clientLeft || 0);
- event2.pageY = event2.clientY + (doc && doc.scrollTop || body && body.scrollTop || 0) - (doc && doc.clientTop || body && body.clientTop || 0);
- }
- event2.which = event2.charCode || event2.keyCode;
- if (event2.button !== null && event2.button !== void 0) {
- event2.button = event2.button & 1 ? 0 : event2.button & 4 ? 1 : event2.button & 2 ? 2 : 0;
- }
- }
- event2.fixed_ = true;
- return event2;
- }
- var _supportsPassive;
- var supportsPassive = function supportsPassive2() {
- if (typeof _supportsPassive !== "boolean") {
- _supportsPassive = false;
- try {
- var opts = Object.defineProperty({}, "passive", {
- get: function get7() {
- _supportsPassive = true;
- }
- });
- window_1.addEventListener("test", null, opts);
- window_1.removeEventListener("test", null, opts);
- } catch (e) {
- }
- }
- return _supportsPassive;
- };
- var passiveEvents = ["touchstart", "touchmove"];
- function on(elem, type2, fn2) {
- if (Array.isArray(type2)) {
- return _handleMultipleEvents(on, elem, type2, fn2);
- }
- if (!DomData.has(elem)) {
- DomData.set(elem, {});
- }
- var data = DomData.get(elem);
- if (!data.handlers) {
- data.handlers = {};
- }
- if (!data.handlers[type2]) {
- data.handlers[type2] = [];
- }
- if (!fn2.guid) {
- fn2.guid = newGUID();
- }
- data.handlers[type2].push(fn2);
- if (!data.dispatcher) {
- data.disabled = false;
- data.dispatcher = function(event2, hash) {
- if (data.disabled) {
- return;
- }
- event2 = fixEvent(event2);
- var handlers = data.handlers[event2.type];
- if (handlers) {
- var handlersCopy = handlers.slice(0);
- for (var m = 0, n = handlersCopy.length; m < n; m++) {
- if (event2.isImmediatePropagationStopped()) {
- break;
- } else {
- try {
- handlersCopy[m].call(elem, event2, hash);
- } catch (e) {
- log$1.error(e);
- }
- }
- }
- }
- };
- }
- if (data.handlers[type2].length === 1) {
- if (elem.addEventListener) {
- var options2 = false;
- if (supportsPassive() && passiveEvents.indexOf(type2) > -1) {
- options2 = {
- passive: true
- };
- }
- elem.addEventListener(type2, data.dispatcher, options2);
- } else if (elem.attachEvent) {
- elem.attachEvent("on" + type2, data.dispatcher);
- }
- }
- }
- function off(elem, type2, fn2) {
- if (!DomData.has(elem)) {
- return;
- }
- var data = DomData.get(elem);
- if (!data.handlers) {
- return;
- }
- if (Array.isArray(type2)) {
- return _handleMultipleEvents(off, elem, type2, fn2);
- }
- var removeType = function removeType2(el, t3) {
- data.handlers[t3] = [];
- _cleanUpEvents(el, t3);
- };
- if (type2 === void 0) {
- for (var t2 in data.handlers) {
- if (Object.prototype.hasOwnProperty.call(data.handlers || {}, t2)) {
- removeType(elem, t2);
- }
- }
- return;
- }
- var handlers = data.handlers[type2];
- if (!handlers) {
- return;
- }
- if (!fn2) {
- removeType(elem, type2);
- return;
- }
- if (fn2.guid) {
- for (var n = 0; n < handlers.length; n++) {
- if (handlers[n].guid === fn2.guid) {
- handlers.splice(n--, 1);
- }
- }
- }
- _cleanUpEvents(elem, type2);
- }
- function trigger(elem, event2, hash) {
- var elemData = DomData.has(elem) ? DomData.get(elem) : {};
- var parent = elem.parentNode || elem.ownerDocument;
- if (typeof event2 === "string") {
- event2 = {
- type: event2,
- target: elem
- };
- } else if (!event2.target) {
- event2.target = elem;
- }
- event2 = fixEvent(event2);
- if (elemData.dispatcher) {
- elemData.dispatcher.call(elem, event2, hash);
- }
- if (parent && !event2.isPropagationStopped() && event2.bubbles === true) {
- trigger.call(null, parent, event2, hash);
- } else if (!parent && !event2.defaultPrevented && event2.target && event2.target[event2.type]) {
- if (!DomData.has(event2.target)) {
- DomData.set(event2.target, {});
- }
- var targetData = DomData.get(event2.target);
- if (event2.target[event2.type]) {
- targetData.disabled = true;
- if (typeof event2.target[event2.type] === "function") {
- event2.target[event2.type]();
- }
- targetData.disabled = false;
- }
- }
- return !event2.defaultPrevented;
- }
- function one(elem, type2, fn2) {
- if (Array.isArray(type2)) {
- return _handleMultipleEvents(one, elem, type2, fn2);
- }
- var func = function func2() {
- off(elem, type2, func2);
- fn2.apply(this, arguments);
- };
- func.guid = fn2.guid = fn2.guid || newGUID();
- on(elem, type2, func);
- }
- function any(elem, type2, fn2) {
- var func = function func2() {
- off(elem, type2, func2);
- fn2.apply(this, arguments);
- };
- func.guid = fn2.guid = fn2.guid || newGUID();
- on(elem, type2, func);
- }
- var Events = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- fixEvent,
- on,
- off,
- trigger,
- one,
- any
- });
- var UPDATE_REFRESH_INTERVAL = 30;
- var bind = function bind2(context, fn2, uid) {
- if (!fn2.guid) {
- fn2.guid = newGUID();
- }
- var bound = fn2.bind(context);
- bound.guid = uid ? uid + "_" + fn2.guid : fn2.guid;
- return bound;
- };
- var throttle = function throttle2(fn2, wait) {
- var last = window_1.performance.now();
- var throttled = function throttled2() {
- var now2 = window_1.performance.now();
- if (now2 - last >= wait) {
- fn2.apply(void 0, arguments);
- last = now2;
- }
- };
- return throttled;
- };
- var debounce = function debounce2(func, wait, immediate, context) {
- if (context === void 0) {
- context = window_1;
- }
- var timeout;
- var cancel = function cancel2() {
- context.clearTimeout(timeout);
- timeout = null;
- };
- var debounced = function debounced2() {
- var self2 = this;
- var args = arguments;
- var _later = function later() {
- timeout = null;
- _later = null;
- if (!immediate) {
- func.apply(self2, args);
- }
- };
- if (!timeout && immediate) {
- func.apply(self2, args);
- }
- context.clearTimeout(timeout);
- timeout = context.setTimeout(_later, wait);
- };
- debounced.cancel = cancel;
- return debounced;
- };
- var EventTarget$2 = function EventTarget() {
- };
- EventTarget$2.prototype.allowedEvents_ = {};
- EventTarget$2.prototype.on = function(type2, fn2) {
- var ael = this.addEventListener;
- this.addEventListener = function() {
- };
- on(this, type2, fn2);
- this.addEventListener = ael;
- };
- EventTarget$2.prototype.addEventListener = EventTarget$2.prototype.on;
- EventTarget$2.prototype.off = function(type2, fn2) {
- off(this, type2, fn2);
- };
- EventTarget$2.prototype.removeEventListener = EventTarget$2.prototype.off;
- EventTarget$2.prototype.one = function(type2, fn2) {
- var ael = this.addEventListener;
- this.addEventListener = function() {
- };
- one(this, type2, fn2);
- this.addEventListener = ael;
- };
- EventTarget$2.prototype.any = function(type2, fn2) {
- var ael = this.addEventListener;
- this.addEventListener = function() {
- };
- any(this, type2, fn2);
- this.addEventListener = ael;
- };
- EventTarget$2.prototype.trigger = function(event2) {
- var type2 = event2.type || event2;
- if (typeof event2 === "string") {
- event2 = {
- type: type2
- };
- }
- event2 = fixEvent(event2);
- if (this.allowedEvents_[type2] && this["on" + type2]) {
- this["on" + type2](event2);
- }
- trigger(this, event2);
- };
- EventTarget$2.prototype.dispatchEvent = EventTarget$2.prototype.trigger;
- var EVENT_MAP;
- EventTarget$2.prototype.queueTrigger = function(event2) {
- var _this = this;
- if (!EVENT_MAP) {
- EVENT_MAP = /* @__PURE__ */ new Map();
- }
- var type2 = event2.type || event2;
- var map = EVENT_MAP.get(this);
- if (!map) {
- map = /* @__PURE__ */ new Map();
- EVENT_MAP.set(this, map);
- }
- var oldTimeout = map.get(type2);
- map["delete"](type2);
- window_1.clearTimeout(oldTimeout);
- var timeout = window_1.setTimeout(function() {
- map["delete"](type2);
- if (map.size === 0) {
- map = null;
- EVENT_MAP["delete"](_this);
- }
- _this.trigger(event2);
- }, 0);
- map.set(type2, timeout);
- };
- var objName = function objName2(obj) {
- if (typeof obj.name === "function") {
- return obj.name();
- }
- if (typeof obj.name === "string") {
- return obj.name;
- }
- if (obj.name_) {
- return obj.name_;
- }
- if (obj.constructor && obj.constructor.name) {
- return obj.constructor.name;
- }
- return typeof obj;
- };
- var isEvented = function isEvented2(object) {
- return object instanceof EventTarget$2 || !!object.eventBusEl_ && ["on", "one", "off", "trigger"].every(function(k) {
- return typeof object[k] === "function";
- });
- };
- var addEventedCallback = function addEventedCallback2(target, callback2) {
- if (isEvented(target)) {
- callback2();
- } else {
- if (!target.eventedCallbacks) {
- target.eventedCallbacks = [];
- }
- target.eventedCallbacks.push(callback2);
- }
- };
- var isValidEventType = function isValidEventType2(type2) {
- return typeof type2 === "string" && /\S/.test(type2) || Array.isArray(type2) && !!type2.length;
- };
- var validateTarget = function validateTarget2(target, obj, fnName) {
- if (!target || !target.nodeName && !isEvented(target)) {
- throw new Error("Invalid target for " + objName(obj) + "#" + fnName + "; must be a DOM node or evented object.");
- }
- };
- var validateEventType = function validateEventType2(type2, obj, fnName) {
- if (!isValidEventType(type2)) {
- throw new Error("Invalid event type for " + objName(obj) + "#" + fnName + "; must be a non-empty string or array.");
- }
- };
- var validateListener = function validateListener2(listener, obj, fnName) {
- if (typeof listener !== "function") {
- throw new Error("Invalid listener for " + objName(obj) + "#" + fnName + "; must be a function.");
- }
- };
- var normalizeListenArgs = function normalizeListenArgs2(self2, args, fnName) {
- var isTargetingSelf = args.length < 3 || args[0] === self2 || args[0] === self2.eventBusEl_;
- var target;
- var type2;
- var listener;
- if (isTargetingSelf) {
- target = self2.eventBusEl_;
- if (args.length >= 3) {
- args.shift();
- }
- type2 = args[0];
- listener = args[1];
- } else {
- target = args[0];
- type2 = args[1];
- listener = args[2];
- }
- validateTarget(target, self2, fnName);
- validateEventType(type2, self2, fnName);
- validateListener(listener, self2, fnName);
- listener = bind(self2, listener);
- return {
- isTargetingSelf,
- target,
- type: type2,
- listener
- };
- };
- var listen = function listen2(target, method, type2, listener) {
- validateTarget(target, target, method);
- if (target.nodeName) {
- Events[method](target, type2, listener);
- } else {
- target[method](type2, listener);
- }
- };
- var EventedMixin = {
- on: function on2() {
- var _this = this;
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
- var _normalizeListenArgs = normalizeListenArgs(this, args, "on"), isTargetingSelf = _normalizeListenArgs.isTargetingSelf, target = _normalizeListenArgs.target, type2 = _normalizeListenArgs.type, listener = _normalizeListenArgs.listener;
- listen(target, "on", type2, listener);
- if (!isTargetingSelf) {
- var removeListenerOnDispose = function removeListenerOnDispose2() {
- return _this.off(target, type2, listener);
- };
- removeListenerOnDispose.guid = listener.guid;
- var removeRemoverOnTargetDispose = function removeRemoverOnTargetDispose2() {
- return _this.off("dispose", removeListenerOnDispose);
- };
- removeRemoverOnTargetDispose.guid = listener.guid;
- listen(this, "on", "dispose", removeListenerOnDispose);
- listen(target, "on", "dispose", removeRemoverOnTargetDispose);
- }
- },
- one: function one2() {
- var _this2 = this;
- for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
- args[_key2] = arguments[_key2];
- }
- var _normalizeListenArgs2 = normalizeListenArgs(this, args, "one"), isTargetingSelf = _normalizeListenArgs2.isTargetingSelf, target = _normalizeListenArgs2.target, type2 = _normalizeListenArgs2.type, listener = _normalizeListenArgs2.listener;
- if (isTargetingSelf) {
- listen(target, "one", type2, listener);
- } else {
- var wrapper = function wrapper2() {
- _this2.off(target, type2, wrapper2);
- for (var _len3 = arguments.length, largs = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
- largs[_key3] = arguments[_key3];
- }
- listener.apply(null, largs);
- };
- wrapper.guid = listener.guid;
- listen(target, "one", type2, wrapper);
- }
- },
- any: function any2() {
- var _this3 = this;
- for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {
- args[_key4] = arguments[_key4];
- }
- var _normalizeListenArgs3 = normalizeListenArgs(this, args, "any"), isTargetingSelf = _normalizeListenArgs3.isTargetingSelf, target = _normalizeListenArgs3.target, type2 = _normalizeListenArgs3.type, listener = _normalizeListenArgs3.listener;
- if (isTargetingSelf) {
- listen(target, "any", type2, listener);
- } else {
- var wrapper = function wrapper2() {
- _this3.off(target, type2, wrapper2);
- for (var _len5 = arguments.length, largs = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {
- largs[_key5] = arguments[_key5];
- }
- listener.apply(null, largs);
- };
- wrapper.guid = listener.guid;
- listen(target, "any", type2, wrapper);
- }
- },
- off: function off$12(targetOrType, typeOrListener, listener) {
- if (!targetOrType || isValidEventType(targetOrType)) {
- off(this.eventBusEl_, targetOrType, typeOrListener);
- } else {
- var target = targetOrType;
- var type2 = typeOrListener;
- validateTarget(target, this, "off");
- validateEventType(type2, this, "off");
- validateListener(listener, this, "off");
- listener = bind(this, listener);
- this.off("dispose", listener);
- if (target.nodeName) {
- off(target, type2, listener);
- off(target, "dispose", listener);
- } else if (isEvented(target)) {
- target.off(type2, listener);
- target.off("dispose", listener);
- }
- }
- },
- trigger: function trigger$12(event2, hash) {
- validateTarget(this.eventBusEl_, this, "trigger");
- var type2 = event2 && typeof event2 !== "string" ? event2.type : event2;
- if (!isValidEventType(type2)) {
- var error = "Invalid event type for " + objName(this) + "#trigger; must be a non-empty string or object with a type key that has a non-empty value.";
- if (event2) {
- (this.log || log$1).error(error);
- } else {
- throw new Error(error);
- }
- }
- return trigger(this.eventBusEl_, event2, hash);
- }
- };
- function evented(target, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var _options = options2, eventBusKey = _options.eventBusKey;
- if (eventBusKey) {
- if (!target[eventBusKey].nodeName) {
- throw new Error('The eventBusKey "' + eventBusKey + '" does not refer to an element.');
- }
- target.eventBusEl_ = target[eventBusKey];
- } else {
- target.eventBusEl_ = createEl("span", {
- className: "vjs-event-bus"
- });
- }
- assign(target, EventedMixin);
- if (target.eventedCallbacks) {
- target.eventedCallbacks.forEach(function(callback2) {
- callback2();
- });
- }
- target.on("dispose", function() {
- target.off();
- [target, target.el_, target.eventBusEl_].forEach(function(val) {
- if (val && DomData.has(val)) {
- DomData["delete"](val);
- }
- });
- window_1.setTimeout(function() {
- target.eventBusEl_ = null;
- }, 0);
- });
- return target;
- }
- var StatefulMixin = {
- state: {},
- setState: function setState(stateUpdates) {
- var _this = this;
- if (typeof stateUpdates === "function") {
- stateUpdates = stateUpdates();
- }
- var changes;
- each(stateUpdates, function(value, key) {
- if (_this.state[key] !== value) {
- changes = changes || {};
- changes[key] = {
- from: _this.state[key],
- to: value
- };
- }
- _this.state[key] = value;
- });
- if (changes && isEvented(this)) {
- this.trigger({
- changes,
- type: "statechanged"
- });
- }
- return changes;
- }
- };
- function stateful(target, defaultState) {
- assign(target, StatefulMixin);
- target.state = assign({}, target.state, defaultState);
- if (typeof target.handleStateChanged === "function" && isEvented(target)) {
- target.on("statechanged", target.handleStateChanged);
- }
- return target;
- }
- var toLowerCase = function toLowerCase2(string) {
- if (typeof string !== "string") {
- return string;
- }
- return string.replace(/./, function(w) {
- return w.toLowerCase();
- });
- };
- var toTitleCase$1 = function toTitleCase(string) {
- if (typeof string !== "string") {
- return string;
- }
- return string.replace(/./, function(w) {
- return w.toUpperCase();
- });
- };
- var titleCaseEquals = function titleCaseEquals2(str1, str2) {
- return toTitleCase$1(str1) === toTitleCase$1(str2);
- };
- function mergeOptions$3() {
- var result = {};
- for (var _len = arguments.length, sources = new Array(_len), _key = 0; _key < _len; _key++) {
- sources[_key] = arguments[_key];
- }
- sources.forEach(function(source) {
- if (!source) {
- return;
- }
- each(source, function(value, key) {
- if (!isPlain(value)) {
- result[key] = value;
- return;
- }
- if (!isPlain(result[key])) {
- result[key] = {};
- }
- result[key] = mergeOptions$3(result[key], value);
- });
- });
- return result;
- }
- var MapSham = /* @__PURE__ */ function() {
- function MapSham2() {
- this.map_ = {};
- }
- var _proto = MapSham2.prototype;
- _proto.has = function has(key) {
- return key in this.map_;
- };
- _proto["delete"] = function _delete(key) {
- var has = this.has(key);
- delete this.map_[key];
- return has;
- };
- _proto.set = function set4(key, value) {
- this.map_[key] = value;
- return this;
- };
- _proto.forEach = function forEach(callback2, thisArg) {
- for (var key in this.map_) {
- callback2.call(thisArg, this.map_[key], key, this);
- }
- };
- return MapSham2;
- }();
- var Map$1 = window_1.Map ? window_1.Map : MapSham;
- var SetSham = /* @__PURE__ */ function() {
- function SetSham2() {
- this.set_ = {};
- }
- var _proto = SetSham2.prototype;
- _proto.has = function has(key) {
- return key in this.set_;
- };
- _proto["delete"] = function _delete(key) {
- var has = this.has(key);
- delete this.set_[key];
- return has;
- };
- _proto.add = function add(key) {
- this.set_[key] = 1;
- return this;
- };
- _proto.forEach = function forEach(callback2, thisArg) {
- for (var key in this.set_) {
- callback2.call(thisArg, key, key, this);
- }
- };
- return SetSham2;
- }();
- var Set$1 = window_1.Set ? window_1.Set : SetSham;
- var Component$1 = /* @__PURE__ */ function() {
- function Component2(player, options2, ready) {
- var _this = this;
- if (!player && this.play) {
- this.player_ = player = this;
- } else {
- this.player_ = player;
- }
- this.isDisposed_ = false;
- this.parentComponent_ = null;
- this.options_ = mergeOptions$3({}, this.options_);
- options2 = this.options_ = mergeOptions$3(this.options_, options2);
- this.id_ = options2.id || options2.el && options2.el.id;
- if (!this.id_) {
- var id = player && player.id && player.id() || "no_player";
- this.id_ = id + "_component_" + newGUID();
- }
- this.name_ = options2.name || null;
- if (options2.el) {
- this.el_ = options2.el;
- } else if (options2.createEl !== false) {
- this.el_ = this.createEl();
- }
- if (options2.className && this.el_) {
- options2.className.split(" ").forEach(function(c) {
- return _this.addClass(c);
- });
- }
- if (options2.evented !== false) {
- evented(this, {
- eventBusKey: this.el_ ? "el_" : null
- });
- this.handleLanguagechange = this.handleLanguagechange.bind(this);
- this.on(this.player_, "languagechange", this.handleLanguagechange);
- }
- stateful(this, this.constructor.defaultState);
- this.children_ = [];
- this.childIndex_ = {};
- this.childNameIndex_ = {};
- this.setTimeoutIds_ = new Set$1();
- this.setIntervalIds_ = new Set$1();
- this.rafIds_ = new Set$1();
- this.namedRafs_ = new Map$1();
- this.clearingTimersOnDispose_ = false;
- if (options2.initChildren !== false) {
- this.initChildren();
- }
- this.ready(ready);
- if (options2.reportTouchActivity !== false) {
- this.enableTouchActivity();
- }
- }
- var _proto = Component2.prototype;
- _proto.dispose = function dispose(options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- if (this.isDisposed_) {
- return;
- }
- if (this.readyQueue_) {
- this.readyQueue_.length = 0;
- }
- this.trigger({
- type: "dispose",
- bubbles: false
- });
- this.isDisposed_ = true;
- if (this.children_) {
- for (var i2 = this.children_.length - 1; i2 >= 0; i2--) {
- if (this.children_[i2].dispose) {
- this.children_[i2].dispose();
- }
- }
- }
- this.children_ = null;
- this.childIndex_ = null;
- this.childNameIndex_ = null;
- this.parentComponent_ = null;
- if (this.el_) {
- if (this.el_.parentNode) {
- if (options2.restoreEl) {
- this.el_.parentNode.replaceChild(options2.restoreEl, this.el_);
- } else {
- this.el_.parentNode.removeChild(this.el_);
- }
- }
- this.el_ = null;
- }
- this.player_ = null;
- };
- _proto.isDisposed = function isDisposed() {
- return Boolean(this.isDisposed_);
- };
- _proto.player = function player() {
- return this.player_;
- };
- _proto.options = function options2(obj) {
- if (!obj) {
- return this.options_;
- }
- this.options_ = mergeOptions$3(this.options_, obj);
- return this.options_;
- };
- _proto.el = function el() {
- return this.el_;
- };
- _proto.createEl = function createEl$12(tagName, properties, attributes) {
- return createEl(tagName, properties, attributes);
- };
- _proto.localize = function localize(string, tokens, defaultValue2) {
- if (defaultValue2 === void 0) {
- defaultValue2 = string;
- }
- var code = this.player_.language && this.player_.language();
- var languages = this.player_.languages && this.player_.languages();
- var language = languages && languages[code];
- var primaryCode = code && code.split("-")[0];
- var primaryLang = languages && languages[primaryCode];
- var localizedString = defaultValue2;
- if (language && language[string]) {
- localizedString = language[string];
- } else if (primaryLang && primaryLang[string]) {
- localizedString = primaryLang[string];
- }
- if (tokens) {
- localizedString = localizedString.replace(/\{(\d+)\}/g, function(match, index2) {
- var value = tokens[index2 - 1];
- var ret = value;
- if (typeof value === "undefined") {
- ret = match;
- }
- return ret;
- });
- }
- return localizedString;
- };
- _proto.handleLanguagechange = function handleLanguagechange() {
- };
- _proto.contentEl = function contentEl() {
- return this.contentEl_ || this.el_;
- };
- _proto.id = function id() {
- return this.id_;
- };
- _proto.name = function name() {
- return this.name_;
- };
- _proto.children = function children() {
- return this.children_;
- };
- _proto.getChildById = function getChildById(id) {
- return this.childIndex_[id];
- };
- _proto.getChild = function getChild(name) {
- if (!name) {
- return;
- }
- return this.childNameIndex_[name];
- };
- _proto.getDescendant = function getDescendant() {
- for (var _len = arguments.length, names2 = new Array(_len), _key = 0; _key < _len; _key++) {
- names2[_key] = arguments[_key];
- }
- names2 = names2.reduce(function(acc, n) {
- return acc.concat(n);
- }, []);
- var currentChild = this;
- for (var i2 = 0; i2 < names2.length; i2++) {
- currentChild = currentChild.getChild(names2[i2]);
- if (!currentChild || !currentChild.getChild) {
- return;
- }
- }
- return currentChild;
- };
- _proto.addChild = function addChild(child, options2, index2) {
- if (options2 === void 0) {
- options2 = {};
- }
- if (index2 === void 0) {
- index2 = this.children_.length;
- }
- var component;
- var componentName;
- if (typeof child === "string") {
- componentName = toTitleCase$1(child);
- var componentClassName = options2.componentClass || componentName;
- options2.name = componentName;
- var ComponentClass = Component2.getComponent(componentClassName);
- if (!ComponentClass) {
- throw new Error("Component " + componentClassName + " does not exist");
- }
- if (typeof ComponentClass !== "function") {
- return null;
- }
- component = new ComponentClass(this.player_ || this, options2);
- } else {
- component = child;
- }
- if (component.parentComponent_) {
- component.parentComponent_.removeChild(component);
- }
- this.children_.splice(index2, 0, component);
- component.parentComponent_ = this;
- if (typeof component.id === "function") {
- this.childIndex_[component.id()] = component;
- }
- componentName = componentName || component.name && toTitleCase$1(component.name());
- if (componentName) {
- this.childNameIndex_[componentName] = component;
- this.childNameIndex_[toLowerCase(componentName)] = component;
- }
- if (typeof component.el === "function" && component.el()) {
- var refNode = null;
- if (this.children_[index2 + 1]) {
- if (this.children_[index2 + 1].el_) {
- refNode = this.children_[index2 + 1].el_;
- } else if (isEl(this.children_[index2 + 1])) {
- refNode = this.children_[index2 + 1];
- }
- }
- this.contentEl().insertBefore(component.el(), refNode);
- }
- return component;
- };
- _proto.removeChild = function removeChild(component) {
- if (typeof component === "string") {
- component = this.getChild(component);
- }
- if (!component || !this.children_) {
- return;
- }
- var childFound = false;
- for (var i2 = this.children_.length - 1; i2 >= 0; i2--) {
- if (this.children_[i2] === component) {
- childFound = true;
- this.children_.splice(i2, 1);
- break;
- }
- }
- if (!childFound) {
- return;
- }
- component.parentComponent_ = null;
- this.childIndex_[component.id()] = null;
- this.childNameIndex_[toTitleCase$1(component.name())] = null;
- this.childNameIndex_[toLowerCase(component.name())] = null;
- var compEl = component.el();
- if (compEl && compEl.parentNode === this.contentEl()) {
- this.contentEl().removeChild(component.el());
- }
- };
- _proto.initChildren = function initChildren() {
- var _this2 = this;
- var children = this.options_.children;
- if (children) {
- var parentOptions = this.options_;
- var handleAdd = function handleAdd2(child) {
- var name = child.name;
- var opts = child.opts;
- if (parentOptions[name] !== void 0) {
- opts = parentOptions[name];
- }
- if (opts === false) {
- return;
- }
- if (opts === true) {
- opts = {};
- }
- opts.playerOptions = _this2.options_.playerOptions;
- var newChild = _this2.addChild(name, opts);
- if (newChild) {
- _this2[name] = newChild;
- }
- };
- var workingChildren;
- var Tech2 = Component2.getComponent("Tech");
- if (Array.isArray(children)) {
- workingChildren = children;
- } else {
- workingChildren = Object.keys(children);
- }
- workingChildren.concat(Object.keys(this.options_).filter(function(child) {
- return !workingChildren.some(function(wchild) {
- if (typeof wchild === "string") {
- return child === wchild;
- }
- return child === wchild.name;
- });
- })).map(function(child) {
- var name;
- var opts;
- if (typeof child === "string") {
- name = child;
- opts = children[name] || _this2.options_[name] || {};
- } else {
- name = child.name;
- opts = child;
- }
- return {
- name,
- opts
- };
- }).filter(function(child) {
- var c = Component2.getComponent(child.opts.componentClass || toTitleCase$1(child.name));
- return c && !Tech2.isTech(c);
- }).forEach(handleAdd);
- }
- };
- _proto.buildCSSClass = function buildCSSClass() {
- return "";
- };
- _proto.ready = function ready(fn2, sync) {
- if (sync === void 0) {
- sync = false;
- }
- if (!fn2) {
- return;
- }
- if (!this.isReady_) {
- this.readyQueue_ = this.readyQueue_ || [];
- this.readyQueue_.push(fn2);
- return;
- }
- if (sync) {
- fn2.call(this);
- } else {
- this.setTimeout(fn2, 1);
- }
- };
- _proto.triggerReady = function triggerReady() {
- this.isReady_ = true;
- this.setTimeout(function() {
- var readyQueue = this.readyQueue_;
- this.readyQueue_ = [];
- if (readyQueue && readyQueue.length > 0) {
- readyQueue.forEach(function(fn2) {
- fn2.call(this);
- }, this);
- }
- this.trigger("ready");
- }, 1);
- };
- _proto.$ = function $$12(selector, context) {
- return $(selector, context || this.contentEl());
- };
- _proto.$$ = function $$$12(selector, context) {
- return $$(selector, context || this.contentEl());
- };
- _proto.hasClass = function hasClass$12(classToCheck) {
- return hasClass(this.el_, classToCheck);
- };
- _proto.addClass = function addClass$12(classToAdd) {
- addClass(this.el_, classToAdd);
- };
- _proto.removeClass = function removeClass$12(classToRemove) {
- removeClass(this.el_, classToRemove);
- };
- _proto.toggleClass = function toggleClass$12(classToToggle, predicate) {
- toggleClass(this.el_, classToToggle, predicate);
- };
- _proto.show = function show() {
- this.removeClass("vjs-hidden");
- };
- _proto.hide = function hide() {
- this.addClass("vjs-hidden");
- };
- _proto.lockShowing = function lockShowing() {
- this.addClass("vjs-lock-showing");
- };
- _proto.unlockShowing = function unlockShowing() {
- this.removeClass("vjs-lock-showing");
- };
- _proto.getAttribute = function getAttribute$12(attribute) {
- return getAttribute(this.el_, attribute);
- };
- _proto.setAttribute = function setAttribute$12(attribute, value) {
- setAttribute(this.el_, attribute, value);
- };
- _proto.removeAttribute = function removeAttribute$12(attribute) {
- removeAttribute(this.el_, attribute);
- };
- _proto.width = function width2(num, skipListeners) {
- return this.dimension("width", num, skipListeners);
- };
- _proto.height = function height2(num, skipListeners) {
- return this.dimension("height", num, skipListeners);
- };
- _proto.dimensions = function dimensions(width2, height2) {
- this.width(width2, true);
- this.height(height2);
- };
- _proto.dimension = function dimension(widthOrHeight, num, skipListeners) {
- if (num !== void 0) {
- if (num === null || num !== num) {
- num = 0;
- }
- if (("" + num).indexOf("%") !== -1 || ("" + num).indexOf("px") !== -1) {
- this.el_.style[widthOrHeight] = num;
- } else if (num === "auto") {
- this.el_.style[widthOrHeight] = "";
- } else {
- this.el_.style[widthOrHeight] = num + "px";
- }
- if (!skipListeners) {
- this.trigger("componentresize");
- }
- return;
- }
- if (!this.el_) {
- return 0;
- }
- var val = this.el_.style[widthOrHeight];
- var pxIndex = val.indexOf("px");
- if (pxIndex !== -1) {
- return parseInt(val.slice(0, pxIndex), 10);
- }
- return parseInt(this.el_["offset" + toTitleCase$1(widthOrHeight)], 10);
- };
- _proto.currentDimension = function currentDimension(widthOrHeight) {
- var computedWidthOrHeight = 0;
- if (widthOrHeight !== "width" && widthOrHeight !== "height") {
- throw new Error("currentDimension only accepts width or height value");
- }
- computedWidthOrHeight = computedStyle(this.el_, widthOrHeight);
- computedWidthOrHeight = parseFloat(computedWidthOrHeight);
- if (computedWidthOrHeight === 0 || isNaN(computedWidthOrHeight)) {
- var rule = "offset" + toTitleCase$1(widthOrHeight);
- computedWidthOrHeight = this.el_[rule];
- }
- return computedWidthOrHeight;
- };
- _proto.currentDimensions = function currentDimensions() {
- return {
- width: this.currentDimension("width"),
- height: this.currentDimension("height")
- };
- };
- _proto.currentWidth = function currentWidth() {
- return this.currentDimension("width");
- };
- _proto.currentHeight = function currentHeight() {
- return this.currentDimension("height");
- };
- _proto.focus = function focus() {
- this.el_.focus();
- };
- _proto.blur = function blur() {
- this.el_.blur();
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- if (this.player_) {
- if (!keycode.isEventKey(event2, "Tab")) {
- event2.stopPropagation();
- }
- this.player_.handleKeyDown(event2);
- }
- };
- _proto.handleKeyPress = function handleKeyPress(event2) {
- this.handleKeyDown(event2);
- };
- _proto.emitTapEvents = function emitTapEvents() {
- var touchStart = 0;
- var firstTouch = null;
- var tapMovementThreshold = 10;
- var touchTimeThreshold = 200;
- var couldBeTap;
- this.on("touchstart", function(event2) {
- if (event2.touches.length === 1) {
- firstTouch = {
- pageX: event2.touches[0].pageX,
- pageY: event2.touches[0].pageY
- };
- touchStart = window_1.performance.now();
- couldBeTap = true;
- }
- });
- this.on("touchmove", function(event2) {
- if (event2.touches.length > 1) {
- couldBeTap = false;
- } else if (firstTouch) {
- var xdiff = event2.touches[0].pageX - firstTouch.pageX;
- var ydiff = event2.touches[0].pageY - firstTouch.pageY;
- var touchDistance = Math.sqrt(xdiff * xdiff + ydiff * ydiff);
- if (touchDistance > tapMovementThreshold) {
- couldBeTap = false;
- }
- }
- });
- var noTap = function noTap2() {
- couldBeTap = false;
- };
- this.on("touchleave", noTap);
- this.on("touchcancel", noTap);
- this.on("touchend", function(event2) {
- firstTouch = null;
- if (couldBeTap === true) {
- var touchTime = window_1.performance.now() - touchStart;
- if (touchTime < touchTimeThreshold) {
- event2.preventDefault();
- this.trigger("tap");
- }
- }
- });
- };
- _proto.enableTouchActivity = function enableTouchActivity() {
- if (!this.player() || !this.player().reportUserActivity) {
- return;
- }
- var report = bind(this.player(), this.player().reportUserActivity);
- var touchHolding;
- this.on("touchstart", function() {
- report();
- this.clearInterval(touchHolding);
- touchHolding = this.setInterval(report, 250);
- });
- var touchEnd = function touchEnd2(event2) {
- report();
- this.clearInterval(touchHolding);
- };
- this.on("touchmove", report);
- this.on("touchend", touchEnd);
- this.on("touchcancel", touchEnd);
- };
- _proto.setTimeout = function setTimeout2(fn2, timeout) {
- var _this3 = this;
- var timeoutId;
- fn2 = bind(this, fn2);
- this.clearTimersOnDispose_();
- timeoutId = window_1.setTimeout(function() {
- if (_this3.setTimeoutIds_.has(timeoutId)) {
- _this3.setTimeoutIds_["delete"](timeoutId);
- }
- fn2();
- }, timeout);
- this.setTimeoutIds_.add(timeoutId);
- return timeoutId;
- };
- _proto.clearTimeout = function clearTimeout2(timeoutId) {
- if (this.setTimeoutIds_.has(timeoutId)) {
- this.setTimeoutIds_["delete"](timeoutId);
- window_1.clearTimeout(timeoutId);
- }
- return timeoutId;
- };
- _proto.setInterval = function setInterval2(fn2, interval) {
- fn2 = bind(this, fn2);
- this.clearTimersOnDispose_();
- var intervalId = window_1.setInterval(fn2, interval);
- this.setIntervalIds_.add(intervalId);
- return intervalId;
- };
- _proto.clearInterval = function clearInterval2(intervalId) {
- if (this.setIntervalIds_.has(intervalId)) {
- this.setIntervalIds_["delete"](intervalId);
- window_1.clearInterval(intervalId);
- }
- return intervalId;
- };
- _proto.requestAnimationFrame = function requestAnimationFrame(fn2) {
- var _this4 = this;
- if (!this.supportsRaf_) {
- return this.setTimeout(fn2, 1e3 / 60);
- }
- this.clearTimersOnDispose_();
- var id;
- fn2 = bind(this, fn2);
- id = window_1.requestAnimationFrame(function() {
- if (_this4.rafIds_.has(id)) {
- _this4.rafIds_["delete"](id);
- }
- fn2();
- });
- this.rafIds_.add(id);
- return id;
- };
- _proto.requestNamedAnimationFrame = function requestNamedAnimationFrame(name, fn2) {
- var _this5 = this;
- if (this.namedRafs_.has(name)) {
- return;
- }
- this.clearTimersOnDispose_();
- fn2 = bind(this, fn2);
- var id = this.requestAnimationFrame(function() {
- fn2();
- if (_this5.namedRafs_.has(name)) {
- _this5.namedRafs_["delete"](name);
- }
- });
- this.namedRafs_.set(name, id);
- return name;
- };
- _proto.cancelNamedAnimationFrame = function cancelNamedAnimationFrame(name) {
- if (!this.namedRafs_.has(name)) {
- return;
- }
- this.cancelAnimationFrame(this.namedRafs_.get(name));
- this.namedRafs_["delete"](name);
- };
- _proto.cancelAnimationFrame = function cancelAnimationFrame(id) {
- if (!this.supportsRaf_) {
- return this.clearTimeout(id);
- }
- if (this.rafIds_.has(id)) {
- this.rafIds_["delete"](id);
- window_1.cancelAnimationFrame(id);
- }
- return id;
- };
- _proto.clearTimersOnDispose_ = function clearTimersOnDispose_() {
- var _this6 = this;
- if (this.clearingTimersOnDispose_) {
- return;
- }
- this.clearingTimersOnDispose_ = true;
- this.one("dispose", function() {
- [["namedRafs_", "cancelNamedAnimationFrame"], ["rafIds_", "cancelAnimationFrame"], ["setTimeoutIds_", "clearTimeout"], ["setIntervalIds_", "clearInterval"]].forEach(function(_ref) {
- var idName = _ref[0], cancelName = _ref[1];
- _this6[idName].forEach(function(val, key) {
- return _this6[cancelName](key);
- });
- });
- _this6.clearingTimersOnDispose_ = false;
- });
- };
- Component2.registerComponent = function registerComponent(name, ComponentToRegister) {
- if (typeof name !== "string" || !name) {
- throw new Error('Illegal component name, "' + name + '"; must be a non-empty string.');
- }
- var Tech2 = Component2.getComponent("Tech");
- var isTech = Tech2 && Tech2.isTech(ComponentToRegister);
- var isComp = Component2 === ComponentToRegister || Component2.prototype.isPrototypeOf(ComponentToRegister.prototype);
- if (isTech || !isComp) {
- var reason;
- if (isTech) {
- reason = "techs must be registered using Tech.registerTech()";
- } else {
- reason = "must be a Component subclass";
- }
- throw new Error('Illegal component, "' + name + '"; ' + reason + ".");
- }
- name = toTitleCase$1(name);
- if (!Component2.components_) {
- Component2.components_ = {};
- }
- var Player2 = Component2.getComponent("Player");
- if (name === "Player" && Player2 && Player2.players) {
- var players = Player2.players;
- var playerNames = Object.keys(players);
- if (players && playerNames.length > 0 && playerNames.map(function(pname) {
- return players[pname];
- }).every(Boolean)) {
- throw new Error("Can not register Player component after player has been created.");
- }
- }
- Component2.components_[name] = ComponentToRegister;
- Component2.components_[toLowerCase(name)] = ComponentToRegister;
- return ComponentToRegister;
- };
- Component2.getComponent = function getComponent(name) {
- if (!name || !Component2.components_) {
- return;
- }
- return Component2.components_[name];
- };
- return Component2;
- }();
- Component$1.prototype.supportsRaf_ = typeof window_1.requestAnimationFrame === "function" && typeof window_1.cancelAnimationFrame === "function";
- Component$1.registerComponent("Component", Component$1);
- function rangeCheck(fnName, index2, maxIndex) {
- if (typeof index2 !== "number" || index2 < 0 || index2 > maxIndex) {
- throw new Error("Failed to execute '" + fnName + "' on 'TimeRanges': The index provided (" + index2 + ") is non-numeric or out of bounds (0-" + maxIndex + ").");
- }
- }
- function getRange(fnName, valueIndex, ranges, rangeIndex) {
- rangeCheck(fnName, rangeIndex, ranges.length - 1);
- return ranges[rangeIndex][valueIndex];
- }
- function createTimeRangesObj(ranges) {
- var timeRangesObj;
- if (ranges === void 0 || ranges.length === 0) {
- timeRangesObj = {
- length: 0,
- start: function start2() {
- throw new Error("This TimeRanges object is empty");
- },
- end: function end() {
- throw new Error("This TimeRanges object is empty");
- }
- };
- } else {
- timeRangesObj = {
- length: ranges.length,
- start: getRange.bind(null, "start", 0, ranges),
- end: getRange.bind(null, "end", 1, ranges)
- };
- }
- if (window_1.Symbol && window_1.Symbol.iterator) {
- timeRangesObj[window_1.Symbol.iterator] = function() {
- return (ranges || []).values();
- };
- }
- return timeRangesObj;
- }
- function createTimeRanges(start2, end) {
- if (Array.isArray(start2)) {
- return createTimeRangesObj(start2);
- } else if (start2 === void 0 || end === void 0) {
- return createTimeRangesObj();
- }
- return createTimeRangesObj([[start2, end]]);
- }
- function bufferedPercent(buffered, duration5) {
- var bufferedDuration = 0;
- var start2;
- var end;
- if (!duration5) {
- return 0;
- }
- if (!buffered || !buffered.length) {
- buffered = createTimeRanges(0, 0);
- }
- for (var i2 = 0; i2 < buffered.length; i2++) {
- start2 = buffered.start(i2);
- end = buffered.end(i2);
- if (end > duration5) {
- end = duration5;
- }
- bufferedDuration += end - start2;
- }
- return bufferedDuration / duration5;
- }
- function MediaError(value) {
- if (value instanceof MediaError) {
- return value;
- }
- if (typeof value === "number") {
- this.code = value;
- } else if (typeof value === "string") {
- this.message = value;
- } else if (isObject2(value)) {
- if (typeof value.code === "number") {
- this.code = value.code;
- }
- assign(this, value);
- }
- if (!this.message) {
- this.message = MediaError.defaultMessages[this.code] || "";
- }
- }
- MediaError.prototype.code = 0;
- MediaError.prototype.message = "";
- MediaError.prototype.status = null;
- MediaError.errorTypes = ["MEDIA_ERR_CUSTOM", "MEDIA_ERR_ABORTED", "MEDIA_ERR_NETWORK", "MEDIA_ERR_DECODE", "MEDIA_ERR_SRC_NOT_SUPPORTED", "MEDIA_ERR_ENCRYPTED"];
- MediaError.defaultMessages = {
- 1: "You aborted the media playback",
- 2: "A network error caused the media download to fail part-way.",
- 3: "The media playback was aborted due to a corruption problem or because the media used features your browser did not support.",
- 4: "The media could not be loaded, either because the server or network failed or because the format is not supported.",
- 5: "The media is encrypted and we do not have the keys to decrypt it."
- };
- for (var errNum = 0; errNum < MediaError.errorTypes.length; errNum++) {
- MediaError[MediaError.errorTypes[errNum]] = errNum;
- MediaError.prototype[MediaError.errorTypes[errNum]] = errNum;
- }
- function isPromise(value) {
- return value !== void 0 && value !== null && typeof value.then === "function";
- }
- function silencePromise(value) {
- if (isPromise(value)) {
- value.then(null, function(e) {
- });
- }
- }
- var trackToJson_ = function trackToJson_2(track) {
- var ret = ["kind", "label", "language", "id", "inBandMetadataTrackDispatchType", "mode", "src"].reduce(function(acc, prop, i2) {
- if (track[prop]) {
- acc[prop] = track[prop];
- }
- return acc;
- }, {
- cues: track.cues && Array.prototype.map.call(track.cues, function(cue) {
- return {
- startTime: cue.startTime,
- endTime: cue.endTime,
- text: cue.text,
- id: cue.id
- };
- })
- });
- return ret;
- };
- var textTracksToJson = function textTracksToJson2(tech) {
- var trackEls = tech.$$("track");
- var trackObjs = Array.prototype.map.call(trackEls, function(t2) {
- return t2.track;
- });
- var tracks = Array.prototype.map.call(trackEls, function(trackEl) {
- var json = trackToJson_(trackEl.track);
- if (trackEl.src) {
- json.src = trackEl.src;
- }
- return json;
- });
- return tracks.concat(Array.prototype.filter.call(tech.textTracks(), function(track) {
- return trackObjs.indexOf(track) === -1;
- }).map(trackToJson_));
- };
- var jsonToTextTracks = function jsonToTextTracks2(json, tech) {
- json.forEach(function(track) {
- var addedTrack = tech.addRemoteTextTrack(track).track;
- if (!track.src && track.cues) {
- track.cues.forEach(function(cue) {
- return addedTrack.addCue(cue);
- });
- }
- });
- return tech.textTracks();
- };
- var textTrackConverter = {
- textTracksToJson,
- jsonToTextTracks,
- trackToJson_
- };
- var MODAL_CLASS_NAME = "vjs-modal-dialog";
- var ModalDialog = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(ModalDialog2, _Component);
- function ModalDialog2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- _this.handleKeyDown_ = function(e) {
- return _this.handleKeyDown(e);
- };
- _this.close_ = function(e) {
- return _this.close(e);
- };
- _this.opened_ = _this.hasBeenOpened_ = _this.hasBeenFilled_ = false;
- _this.closeable(!_this.options_.uncloseable);
- _this.content(_this.options_.content);
- _this.contentEl_ = createEl("div", {
- className: MODAL_CLASS_NAME + "-content"
- }, {
- role: "document"
- });
- _this.descEl_ = createEl("p", {
- className: MODAL_CLASS_NAME + "-description vjs-control-text",
- id: _this.el().getAttribute("aria-describedby")
- });
- textContent(_this.descEl_, _this.description());
- _this.el_.appendChild(_this.descEl_);
- _this.el_.appendChild(_this.contentEl_);
- return _this;
- }
- var _proto = ModalDialog2.prototype;
- _proto.createEl = function createEl2() {
- return _Component.prototype.createEl.call(this, "div", {
- className: this.buildCSSClass(),
- tabIndex: -1
- }, {
- "aria-describedby": this.id() + "_description",
- "aria-hidden": "true",
- "aria-label": this.label(),
- "role": "dialog"
- });
- };
- _proto.dispose = function dispose() {
- this.contentEl_ = null;
- this.descEl_ = null;
- this.previouslyActiveEl_ = null;
- _Component.prototype.dispose.call(this);
- };
- _proto.buildCSSClass = function buildCSSClass() {
- return MODAL_CLASS_NAME + " vjs-hidden " + _Component.prototype.buildCSSClass.call(this);
- };
- _proto.label = function label2() {
- return this.localize(this.options_.label || "Modal Window");
- };
- _proto.description = function description() {
- var desc = this.options_.description || this.localize("This is a modal window.");
- if (this.closeable()) {
- desc += " " + this.localize("This modal can be closed by pressing the Escape key or activating the close button.");
- }
- return desc;
- };
- _proto.open = function open() {
- if (!this.opened_) {
- var player = this.player();
- this.trigger("beforemodalopen");
- this.opened_ = true;
- if (this.options_.fillAlways || !this.hasBeenOpened_ && !this.hasBeenFilled_) {
- this.fill();
- }
- this.wasPlaying_ = !player.paused();
- if (this.options_.pauseOnOpen && this.wasPlaying_) {
- player.pause();
- }
- this.on("keydown", this.handleKeyDown_);
- this.hadControls_ = player.controls();
- player.controls(false);
- this.show();
- this.conditionalFocus_();
- this.el().setAttribute("aria-hidden", "false");
- this.trigger("modalopen");
- this.hasBeenOpened_ = true;
- }
- };
- _proto.opened = function opened(value) {
- if (typeof value === "boolean") {
- this[value ? "open" : "close"]();
- }
- return this.opened_;
- };
- _proto.close = function close() {
- if (!this.opened_) {
- return;
- }
- var player = this.player();
- this.trigger("beforemodalclose");
- this.opened_ = false;
- if (this.wasPlaying_ && this.options_.pauseOnOpen) {
- player.play();
- }
- this.off("keydown", this.handleKeyDown_);
- if (this.hadControls_) {
- player.controls(true);
- }
- this.hide();
- this.el().setAttribute("aria-hidden", "true");
- this.trigger("modalclose");
- this.conditionalBlur_();
- if (this.options_.temporary) {
- this.dispose();
- }
- };
- _proto.closeable = function closeable(value) {
- if (typeof value === "boolean") {
- var closeable2 = this.closeable_ = !!value;
- var close = this.getChild("closeButton");
- if (closeable2 && !close) {
- var temp = this.contentEl_;
- this.contentEl_ = this.el_;
- close = this.addChild("closeButton", {
- controlText: "Close Modal Dialog"
- });
- this.contentEl_ = temp;
- this.on(close, "close", this.close_);
- }
- if (!closeable2 && close) {
- this.off(close, "close", this.close_);
- this.removeChild(close);
- close.dispose();
- }
- }
- return this.closeable_;
- };
- _proto.fill = function fill() {
- this.fillWith(this.content());
- };
- _proto.fillWith = function fillWith(content) {
- var contentEl = this.contentEl();
- var parentEl = contentEl.parentNode;
- var nextSiblingEl = contentEl.nextSibling;
- this.trigger("beforemodalfill");
- this.hasBeenFilled_ = true;
- parentEl.removeChild(contentEl);
- this.empty();
- insertContent(contentEl, content);
- this.trigger("modalfill");
- if (nextSiblingEl) {
- parentEl.insertBefore(contentEl, nextSiblingEl);
- } else {
- parentEl.appendChild(contentEl);
- }
- var closeButton = this.getChild("closeButton");
- if (closeButton) {
- parentEl.appendChild(closeButton.el_);
- }
- };
- _proto.empty = function empty() {
- this.trigger("beforemodalempty");
- emptyEl(this.contentEl());
- this.trigger("modalempty");
- };
- _proto.content = function content(value) {
- if (typeof value !== "undefined") {
- this.content_ = value;
- }
- return this.content_;
- };
- _proto.conditionalFocus_ = function conditionalFocus_() {
- var activeEl = document_1.activeElement;
- var playerEl = this.player_.el_;
- this.previouslyActiveEl_ = null;
- if (playerEl.contains(activeEl) || playerEl === activeEl) {
- this.previouslyActiveEl_ = activeEl;
- this.focus();
- }
- };
- _proto.conditionalBlur_ = function conditionalBlur_() {
- if (this.previouslyActiveEl_) {
- this.previouslyActiveEl_.focus();
- this.previouslyActiveEl_ = null;
- }
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- event2.stopPropagation();
- if (keycode.isEventKey(event2, "Escape") && this.closeable()) {
- event2.preventDefault();
- this.close();
- return;
- }
- if (!keycode.isEventKey(event2, "Tab")) {
- return;
- }
- var focusableEls = this.focusableEls_();
- var activeEl = this.el_.querySelector(":focus");
- var focusIndex;
- for (var i2 = 0; i2 < focusableEls.length; i2++) {
- if (activeEl === focusableEls[i2]) {
- focusIndex = i2;
- break;
- }
- }
- if (document_1.activeElement === this.el_) {
- focusIndex = 0;
- }
- if (event2.shiftKey && focusIndex === 0) {
- focusableEls[focusableEls.length - 1].focus();
- event2.preventDefault();
- } else if (!event2.shiftKey && focusIndex === focusableEls.length - 1) {
- focusableEls[0].focus();
- event2.preventDefault();
- }
- };
- _proto.focusableEls_ = function focusableEls_() {
- var allChildren = this.el_.querySelectorAll("*");
- return Array.prototype.filter.call(allChildren, function(child) {
- return (child instanceof window_1.HTMLAnchorElement || child instanceof window_1.HTMLAreaElement) && child.hasAttribute("href") || (child instanceof window_1.HTMLInputElement || child instanceof window_1.HTMLSelectElement || child instanceof window_1.HTMLTextAreaElement || child instanceof window_1.HTMLButtonElement) && !child.hasAttribute("disabled") || child instanceof window_1.HTMLIFrameElement || child instanceof window_1.HTMLObjectElement || child instanceof window_1.HTMLEmbedElement || child.hasAttribute("tabindex") && child.getAttribute("tabindex") !== -1 || child.hasAttribute("contenteditable");
- });
- };
- return ModalDialog2;
- }(Component$1);
- ModalDialog.prototype.options_ = {
- pauseOnOpen: true,
- temporary: true
- };
- Component$1.registerComponent("ModalDialog", ModalDialog);
- var TrackList = /* @__PURE__ */ function(_EventTarget) {
- _inheritsLoose(TrackList2, _EventTarget);
- function TrackList2(tracks) {
- var _this;
- if (tracks === void 0) {
- tracks = [];
- }
- _this = _EventTarget.call(this) || this;
- _this.tracks_ = [];
- Object.defineProperty(_assertThisInitialized(_this), "length", {
- get: function get7() {
- return this.tracks_.length;
- }
- });
- for (var i2 = 0; i2 < tracks.length; i2++) {
- _this.addTrack(tracks[i2]);
- }
- return _this;
- }
- var _proto = TrackList2.prototype;
- _proto.addTrack = function addTrack(track) {
- var _this2 = this;
- var index2 = this.tracks_.length;
- if (!("" + index2 in this)) {
- Object.defineProperty(this, index2, {
- get: function get7() {
- return this.tracks_[index2];
- }
- });
- }
- if (this.tracks_.indexOf(track) === -1) {
- this.tracks_.push(track);
- this.trigger({
- track,
- type: "addtrack",
- target: this
- });
- }
- track.labelchange_ = function() {
- _this2.trigger({
- track,
- type: "labelchange",
- target: _this2
- });
- };
- if (isEvented(track)) {
- track.addEventListener("labelchange", track.labelchange_);
- }
- };
- _proto.removeTrack = function removeTrack(rtrack) {
- var track;
- for (var i2 = 0, l = this.length; i2 < l; i2++) {
- if (this[i2] === rtrack) {
- track = this[i2];
- if (track.off) {
- track.off();
- }
- this.tracks_.splice(i2, 1);
- break;
- }
- }
- if (!track) {
- return;
- }
- this.trigger({
- track,
- type: "removetrack",
- target: this
- });
- };
- _proto.getTrackById = function getTrackById(id) {
- var result = null;
- for (var i2 = 0, l = this.length; i2 < l; i2++) {
- var track = this[i2];
- if (track.id === id) {
- result = track;
- break;
- }
- }
- return result;
- };
- return TrackList2;
- }(EventTarget$2);
- TrackList.prototype.allowedEvents_ = {
- change: "change",
- addtrack: "addtrack",
- removetrack: "removetrack",
- labelchange: "labelchange"
- };
- for (var event$1 in TrackList.prototype.allowedEvents_) {
- TrackList.prototype["on" + event$1] = null;
- }
- var disableOthers$1 = function disableOthers(list, track) {
- for (var i2 = 0; i2 < list.length; i2++) {
- if (!Object.keys(list[i2]).length || track.id === list[i2].id) {
- continue;
- }
- list[i2].enabled = false;
- }
- };
- var AudioTrackList = /* @__PURE__ */ function(_TrackList) {
- _inheritsLoose(AudioTrackList2, _TrackList);
- function AudioTrackList2(tracks) {
- var _this;
- if (tracks === void 0) {
- tracks = [];
- }
- for (var i2 = tracks.length - 1; i2 >= 0; i2--) {
- if (tracks[i2].enabled) {
- disableOthers$1(tracks, tracks[i2]);
- break;
- }
- }
- _this = _TrackList.call(this, tracks) || this;
- _this.changing_ = false;
- return _this;
- }
- var _proto = AudioTrackList2.prototype;
- _proto.addTrack = function addTrack(track) {
- var _this2 = this;
- if (track.enabled) {
- disableOthers$1(this, track);
- }
- _TrackList.prototype.addTrack.call(this, track);
- if (!track.addEventListener) {
- return;
- }
- track.enabledChange_ = function() {
- if (_this2.changing_) {
- return;
- }
- _this2.changing_ = true;
- disableOthers$1(_this2, track);
- _this2.changing_ = false;
- _this2.trigger("change");
- };
- track.addEventListener("enabledchange", track.enabledChange_);
- };
- _proto.removeTrack = function removeTrack(rtrack) {
- _TrackList.prototype.removeTrack.call(this, rtrack);
- if (rtrack.removeEventListener && rtrack.enabledChange_) {
- rtrack.removeEventListener("enabledchange", rtrack.enabledChange_);
- rtrack.enabledChange_ = null;
- }
- };
- return AudioTrackList2;
- }(TrackList);
- var disableOthers2 = function disableOthers3(list, track) {
- for (var i2 = 0; i2 < list.length; i2++) {
- if (!Object.keys(list[i2]).length || track.id === list[i2].id) {
- continue;
- }
- list[i2].selected = false;
- }
- };
- var VideoTrackList = /* @__PURE__ */ function(_TrackList) {
- _inheritsLoose(VideoTrackList2, _TrackList);
- function VideoTrackList2(tracks) {
- var _this;
- if (tracks === void 0) {
- tracks = [];
- }
- for (var i2 = tracks.length - 1; i2 >= 0; i2--) {
- if (tracks[i2].selected) {
- disableOthers2(tracks, tracks[i2]);
- break;
- }
- }
- _this = _TrackList.call(this, tracks) || this;
- _this.changing_ = false;
- Object.defineProperty(_assertThisInitialized(_this), "selectedIndex", {
- get: function get7() {
- for (var _i = 0; _i < this.length; _i++) {
- if (this[_i].selected) {
- return _i;
- }
- }
- return -1;
- },
- set: function set4() {
- }
- });
- return _this;
- }
- var _proto = VideoTrackList2.prototype;
- _proto.addTrack = function addTrack(track) {
- var _this2 = this;
- if (track.selected) {
- disableOthers2(this, track);
- }
- _TrackList.prototype.addTrack.call(this, track);
- if (!track.addEventListener) {
- return;
- }
- track.selectedChange_ = function() {
- if (_this2.changing_) {
- return;
- }
- _this2.changing_ = true;
- disableOthers2(_this2, track);
- _this2.changing_ = false;
- _this2.trigger("change");
- };
- track.addEventListener("selectedchange", track.selectedChange_);
- };
- _proto.removeTrack = function removeTrack(rtrack) {
- _TrackList.prototype.removeTrack.call(this, rtrack);
- if (rtrack.removeEventListener && rtrack.selectedChange_) {
- rtrack.removeEventListener("selectedchange", rtrack.selectedChange_);
- rtrack.selectedChange_ = null;
- }
- };
- return VideoTrackList2;
- }(TrackList);
- var TextTrackList = /* @__PURE__ */ function(_TrackList) {
- _inheritsLoose(TextTrackList2, _TrackList);
- function TextTrackList2() {
- return _TrackList.apply(this, arguments) || this;
- }
- var _proto = TextTrackList2.prototype;
- _proto.addTrack = function addTrack(track) {
- var _this = this;
- _TrackList.prototype.addTrack.call(this, track);
- if (!this.queueChange_) {
- this.queueChange_ = function() {
- return _this.queueTrigger("change");
- };
- }
- if (!this.triggerSelectedlanguagechange) {
- this.triggerSelectedlanguagechange_ = function() {
- return _this.trigger("selectedlanguagechange");
- };
- }
- track.addEventListener("modechange", this.queueChange_);
- var nonLanguageTextTrackKind = ["metadata", "chapters"];
- if (nonLanguageTextTrackKind.indexOf(track.kind) === -1) {
- track.addEventListener("modechange", this.triggerSelectedlanguagechange_);
- }
- };
- _proto.removeTrack = function removeTrack(rtrack) {
- _TrackList.prototype.removeTrack.call(this, rtrack);
- if (rtrack.removeEventListener) {
- if (this.queueChange_) {
- rtrack.removeEventListener("modechange", this.queueChange_);
- }
- if (this.selectedlanguagechange_) {
- rtrack.removeEventListener("modechange", this.triggerSelectedlanguagechange_);
- }
- }
- };
- return TextTrackList2;
- }(TrackList);
- var HtmlTrackElementList = /* @__PURE__ */ function() {
- function HtmlTrackElementList2(trackElements) {
- if (trackElements === void 0) {
- trackElements = [];
- }
- this.trackElements_ = [];
- Object.defineProperty(this, "length", {
- get: function get7() {
- return this.trackElements_.length;
- }
- });
- for (var i2 = 0, length = trackElements.length; i2 < length; i2++) {
- this.addTrackElement_(trackElements[i2]);
- }
- }
- var _proto = HtmlTrackElementList2.prototype;
- _proto.addTrackElement_ = function addTrackElement_(trackElement) {
- var index2 = this.trackElements_.length;
- if (!("" + index2 in this)) {
- Object.defineProperty(this, index2, {
- get: function get7() {
- return this.trackElements_[index2];
- }
- });
- }
- if (this.trackElements_.indexOf(trackElement) === -1) {
- this.trackElements_.push(trackElement);
- }
- };
- _proto.getTrackElementByTrack_ = function getTrackElementByTrack_(track) {
- var trackElement_;
- for (var i2 = 0, length = this.trackElements_.length; i2 < length; i2++) {
- if (track === this.trackElements_[i2].track) {
- trackElement_ = this.trackElements_[i2];
- break;
- }
- }
- return trackElement_;
- };
- _proto.removeTrackElement_ = function removeTrackElement_(trackElement) {
- for (var i2 = 0, length = this.trackElements_.length; i2 < length; i2++) {
- if (trackElement === this.trackElements_[i2]) {
- if (this.trackElements_[i2].track && typeof this.trackElements_[i2].track.off === "function") {
- this.trackElements_[i2].track.off();
- }
- if (typeof this.trackElements_[i2].off === "function") {
- this.trackElements_[i2].off();
- }
- this.trackElements_.splice(i2, 1);
- break;
- }
- }
- };
- return HtmlTrackElementList2;
- }();
- var TextTrackCueList = /* @__PURE__ */ function() {
- function TextTrackCueList2(cues) {
- TextTrackCueList2.prototype.setCues_.call(this, cues);
- Object.defineProperty(this, "length", {
- get: function get7() {
- return this.length_;
- }
- });
- }
- var _proto = TextTrackCueList2.prototype;
- _proto.setCues_ = function setCues_(cues) {
- var oldLength = this.length || 0;
- var i2 = 0;
- var l = cues.length;
- this.cues_ = cues;
- this.length_ = cues.length;
- var defineProp = function defineProp2(index2) {
- if (!("" + index2 in this)) {
- Object.defineProperty(this, "" + index2, {
- get: function get7() {
- return this.cues_[index2];
- }
- });
- }
- };
- if (oldLength < l) {
- i2 = oldLength;
- for (; i2 < l; i2++) {
- defineProp.call(this, i2);
- }
- }
- };
- _proto.getCueById = function getCueById(id) {
- var result = null;
- for (var i2 = 0, l = this.length; i2 < l; i2++) {
- var cue = this[i2];
- if (cue.id === id) {
- result = cue;
- break;
- }
- }
- return result;
- };
- return TextTrackCueList2;
- }();
- var VideoTrackKind = {
- alternative: "alternative",
- captions: "captions",
- main: "main",
- sign: "sign",
- subtitles: "subtitles",
- commentary: "commentary"
- };
- var AudioTrackKind = {
- "alternative": "alternative",
- "descriptions": "descriptions",
- "main": "main",
- "main-desc": "main-desc",
- "translation": "translation",
- "commentary": "commentary"
- };
- var TextTrackKind = {
- subtitles: "subtitles",
- captions: "captions",
- descriptions: "descriptions",
- chapters: "chapters",
- metadata: "metadata"
- };
- var TextTrackMode = {
- disabled: "disabled",
- hidden: "hidden",
- showing: "showing"
- };
- var Track = /* @__PURE__ */ function(_EventTarget) {
- _inheritsLoose(Track2, _EventTarget);
- function Track2(options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- _this = _EventTarget.call(this) || this;
- var trackProps = {
- id: options2.id || "vjs_track_" + newGUID(),
- kind: options2.kind || "",
- language: options2.language || ""
- };
- var label2 = options2.label || "";
- var _loop = function _loop2(key2) {
- Object.defineProperty(_assertThisInitialized(_this), key2, {
- get: function get7() {
- return trackProps[key2];
- },
- set: function set4() {
- }
- });
- };
- for (var key in trackProps) {
- _loop(key);
- }
- Object.defineProperty(_assertThisInitialized(_this), "label", {
- get: function get7() {
- return label2;
- },
- set: function set4(newLabel) {
- if (newLabel !== label2) {
- label2 = newLabel;
- this.trigger("labelchange");
- }
- }
- });
- return _this;
- }
- return Track2;
- }(EventTarget$2);
- var parseUrl = function parseUrl2(url) {
- var props = ["protocol", "hostname", "port", "pathname", "search", "hash", "host"];
- var a = document_1.createElement("a");
- a.href = url;
- var details = {};
- for (var i2 = 0; i2 < props.length; i2++) {
- details[props[i2]] = a[props[i2]];
- }
- if (details.protocol === "http:") {
- details.host = details.host.replace(/:80$/, "");
- }
- if (details.protocol === "https:") {
- details.host = details.host.replace(/:443$/, "");
- }
- if (!details.protocol) {
- details.protocol = window_1.location.protocol;
- }
- if (!details.host) {
- details.host = window_1.location.host;
- }
- return details;
- };
- var getAbsoluteURL = function getAbsoluteURL2(url) {
- if (!url.match(/^https?:\/\//)) {
- var a = document_1.createElement("a");
- a.href = url;
- url = a.href;
- }
- return url;
- };
- var getFileExtension = function getFileExtension2(path) {
- if (typeof path === "string") {
- var splitPathRe = /^(\/?)([\s\S]*?)((?:\.{1,2}|[^\/]+?)(\.([^\.\/\?]+)))(?:[\/]*|[\?].*)$/;
- var pathParts = splitPathRe.exec(path);
- if (pathParts) {
- return pathParts.pop().toLowerCase();
- }
- }
- return "";
- };
- var isCrossOrigin = function isCrossOrigin2(url, winLoc) {
- if (winLoc === void 0) {
- winLoc = window_1.location;
- }
- var urlInfo = parseUrl(url);
- var srcProtocol = urlInfo.protocol === ":" ? winLoc.protocol : urlInfo.protocol;
- var crossOrigin = srcProtocol + urlInfo.host !== winLoc.protocol + winLoc.host;
- return crossOrigin;
- };
- var Url$1 = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- parseUrl,
- getAbsoluteURL,
- getFileExtension,
- isCrossOrigin
- });
- var parseCues = function parseCues2(srcContent, track) {
- var parser2 = new window_1.WebVTT.Parser(window_1, window_1.vttjs, window_1.WebVTT.StringDecoder());
- var errors2 = [];
- parser2.oncue = function(cue) {
- track.addCue(cue);
- };
- parser2.onparsingerror = function(error) {
- errors2.push(error);
- };
- parser2.onflush = function() {
- track.trigger({
- type: "loadeddata",
- target: track
- });
- };
- parser2.parse(srcContent);
- if (errors2.length > 0) {
- if (window_1.console && window_1.console.groupCollapsed) {
- window_1.console.groupCollapsed("Text Track parsing errors for " + track.src);
- }
- errors2.forEach(function(error) {
- return log$1.error(error);
- });
- if (window_1.console && window_1.console.groupEnd) {
- window_1.console.groupEnd();
- }
- }
- parser2.flush();
- };
- var loadTrack = function loadTrack2(src, track) {
- var opts = {
- uri: src
- };
- var crossOrigin = isCrossOrigin(src);
- if (crossOrigin) {
- opts.cors = crossOrigin;
- }
- var withCredentials = track.tech_.crossOrigin() === "use-credentials";
- if (withCredentials) {
- opts.withCredentials = withCredentials;
- }
- XHR(opts, bind(this, function(err, response, responseBody) {
- if (err) {
- return log$1.error(err, response);
- }
- track.loaded_ = true;
- if (typeof window_1.WebVTT !== "function") {
- if (track.tech_) {
- track.tech_.any(["vttjsloaded", "vttjserror"], function(event2) {
- if (event2.type === "vttjserror") {
- log$1.error("vttjs failed to load, stopping trying to process " + track.src);
- return;
- }
- return parseCues(responseBody, track);
- });
- }
- } else {
- parseCues(responseBody, track);
- }
- }));
- };
- var TextTrack = /* @__PURE__ */ function(_Track) {
- _inheritsLoose(TextTrack2, _Track);
- function TextTrack2(options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- if (!options2.tech) {
- throw new Error("A tech was not provided.");
- }
- var settings = mergeOptions$3(options2, {
- kind: TextTrackKind[options2.kind] || "subtitles",
- language: options2.language || options2.srclang || ""
- });
- var mode = TextTrackMode[settings.mode] || "disabled";
- var default_ = settings["default"];
- if (settings.kind === "metadata" || settings.kind === "chapters") {
- mode = "hidden";
- }
- _this = _Track.call(this, settings) || this;
- _this.tech_ = settings.tech;
- _this.cues_ = [];
- _this.activeCues_ = [];
- _this.preload_ = _this.tech_.preloadTextTracks !== false;
- var cues = new TextTrackCueList(_this.cues_);
- var activeCues = new TextTrackCueList(_this.activeCues_);
- var changed = false;
- _this.timeupdateHandler = bind(_assertThisInitialized(_this), function(event2) {
- if (event2 === void 0) {
- event2 = {};
- }
- if (this.tech_.isDisposed()) {
- return;
- }
- if (!this.tech_.isReady_) {
- if (event2.type !== "timeupdate") {
- this.rvf_ = this.tech_.requestVideoFrameCallback(this.timeupdateHandler);
- }
- return;
- }
- this.activeCues = this.activeCues;
- if (changed) {
- this.trigger("cuechange");
- changed = false;
- }
- if (event2.type !== "timeupdate") {
- this.rvf_ = this.tech_.requestVideoFrameCallback(this.timeupdateHandler);
- }
- });
- var disposeHandler = function disposeHandler2() {
- _this.stopTracking();
- };
- _this.tech_.one("dispose", disposeHandler);
- if (mode !== "disabled") {
- _this.startTracking();
- }
- Object.defineProperties(_assertThisInitialized(_this), {
- "default": {
- get: function get7() {
- return default_;
- },
- set: function set4() {
- }
- },
- mode: {
- get: function get7() {
- return mode;
- },
- set: function set4(newMode) {
- if (!TextTrackMode[newMode]) {
- return;
- }
- if (mode === newMode) {
- return;
- }
- mode = newMode;
- if (!this.preload_ && mode !== "disabled" && this.cues.length === 0) {
- loadTrack(this.src, this);
- }
- this.stopTracking();
- if (mode !== "disabled") {
- this.startTracking();
- }
- this.trigger("modechange");
- }
- },
- cues: {
- get: function get7() {
- if (!this.loaded_) {
- return null;
- }
- return cues;
- },
- set: function set4() {
- }
- },
- activeCues: {
- get: function get7() {
- if (!this.loaded_) {
- return null;
- }
- if (this.cues.length === 0) {
- return activeCues;
- }
- var ct2 = this.tech_.currentTime();
- var active = [];
- for (var i2 = 0, l = this.cues.length; i2 < l; i2++) {
- var cue = this.cues[i2];
- if (cue.startTime <= ct2 && cue.endTime >= ct2) {
- active.push(cue);
- } else if (cue.startTime === cue.endTime && cue.startTime <= ct2 && cue.startTime + 0.5 >= ct2) {
- active.push(cue);
- }
- }
- changed = false;
- if (active.length !== this.activeCues_.length) {
- changed = true;
- } else {
- for (var _i = 0; _i < active.length; _i++) {
- if (this.activeCues_.indexOf(active[_i]) === -1) {
- changed = true;
- }
- }
- }
- this.activeCues_ = active;
- activeCues.setCues_(this.activeCues_);
- return activeCues;
- },
- set: function set4() {
- }
- }
- });
- if (settings.src) {
- _this.src = settings.src;
- if (!_this.preload_) {
- _this.loaded_ = true;
- }
- if (_this.preload_ || settings.kind !== "subtitles" && settings.kind !== "captions") {
- loadTrack(_this.src, _assertThisInitialized(_this));
- }
- } else {
- _this.loaded_ = true;
- }
- return _this;
- }
- var _proto = TextTrack2.prototype;
- _proto.startTracking = function startTracking() {
- this.rvf_ = this.tech_.requestVideoFrameCallback(this.timeupdateHandler);
- this.tech_.on("timeupdate", this.timeupdateHandler);
- };
- _proto.stopTracking = function stopTracking() {
- if (this.rvf_) {
- this.tech_.cancelVideoFrameCallback(this.rvf_);
- this.rvf_ = void 0;
- }
- this.tech_.off("timeupdate", this.timeupdateHandler);
- };
- _proto.addCue = function addCue(originalCue) {
- var cue = originalCue;
- if (window_1.vttjs && !(originalCue instanceof window_1.vttjs.VTTCue)) {
- cue = new window_1.vttjs.VTTCue(originalCue.startTime, originalCue.endTime, originalCue.text);
- for (var prop in originalCue) {
- if (!(prop in cue)) {
- cue[prop] = originalCue[prop];
- }
- }
- cue.id = originalCue.id;
- cue.originalCue_ = originalCue;
- }
- var tracks = this.tech_.textTracks();
- for (var i2 = 0; i2 < tracks.length; i2++) {
- if (tracks[i2] !== this) {
- tracks[i2].removeCue(cue);
- }
- }
- this.cues_.push(cue);
- this.cues.setCues_(this.cues_);
- };
- _proto.removeCue = function removeCue(_removeCue) {
- var i2 = this.cues_.length;
- while (i2--) {
- var cue = this.cues_[i2];
- if (cue === _removeCue || cue.originalCue_ && cue.originalCue_ === _removeCue) {
- this.cues_.splice(i2, 1);
- this.cues.setCues_(this.cues_);
- break;
- }
- }
- };
- return TextTrack2;
- }(Track);
- TextTrack.prototype.allowedEvents_ = {
- cuechange: "cuechange"
- };
- var AudioTrack = /* @__PURE__ */ function(_Track) {
- _inheritsLoose(AudioTrack2, _Track);
- function AudioTrack2(options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- var settings = mergeOptions$3(options2, {
- kind: AudioTrackKind[options2.kind] || ""
- });
- _this = _Track.call(this, settings) || this;
- var enabled = false;
- Object.defineProperty(_assertThisInitialized(_this), "enabled", {
- get: function get7() {
- return enabled;
- },
- set: function set4(newEnabled) {
- if (typeof newEnabled !== "boolean" || newEnabled === enabled) {
- return;
- }
- enabled = newEnabled;
- this.trigger("enabledchange");
- }
- });
- if (settings.enabled) {
- _this.enabled = settings.enabled;
- }
- _this.loaded_ = true;
- return _this;
- }
- return AudioTrack2;
- }(Track);
- var VideoTrack = /* @__PURE__ */ function(_Track) {
- _inheritsLoose(VideoTrack2, _Track);
- function VideoTrack2(options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- var settings = mergeOptions$3(options2, {
- kind: VideoTrackKind[options2.kind] || ""
- });
- _this = _Track.call(this, settings) || this;
- var selected = false;
- Object.defineProperty(_assertThisInitialized(_this), "selected", {
- get: function get7() {
- return selected;
- },
- set: function set4(newSelected) {
- if (typeof newSelected !== "boolean" || newSelected === selected) {
- return;
- }
- selected = newSelected;
- this.trigger("selectedchange");
- }
- });
- if (settings.selected) {
- _this.selected = settings.selected;
- }
- return _this;
- }
- return VideoTrack2;
- }(Track);
- var NONE = 0;
- var LOADING = 1;
- var LOADED = 2;
- var ERROR = 3;
- var HTMLTrackElement = /* @__PURE__ */ function(_EventTarget) {
- _inheritsLoose(HTMLTrackElement2, _EventTarget);
- function HTMLTrackElement2(options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- _this = _EventTarget.call(this) || this;
- var readyState;
- var track = new TextTrack(options2);
- _this.kind = track.kind;
- _this.src = track.src;
- _this.srclang = track.language;
- _this.label = track.label;
- _this["default"] = track["default"];
- Object.defineProperties(_assertThisInitialized(_this), {
- readyState: {
- get: function get7() {
- return readyState;
- }
- },
- track: {
- get: function get7() {
- return track;
- }
- }
- });
- readyState = NONE;
- track.addEventListener("loadeddata", function() {
- readyState = LOADED;
- _this.trigger({
- type: "load",
- target: _assertThisInitialized(_this)
- });
- });
- return _this;
- }
- return HTMLTrackElement2;
- }(EventTarget$2);
- HTMLTrackElement.prototype.allowedEvents_ = {
- load: "load"
- };
- HTMLTrackElement.NONE = NONE;
- HTMLTrackElement.LOADING = LOADING;
- HTMLTrackElement.LOADED = LOADED;
- HTMLTrackElement.ERROR = ERROR;
- var NORMAL = {
- audio: {
- ListClass: AudioTrackList,
- TrackClass: AudioTrack,
- capitalName: "Audio"
- },
- video: {
- ListClass: VideoTrackList,
- TrackClass: VideoTrack,
- capitalName: "Video"
- },
- text: {
- ListClass: TextTrackList,
- TrackClass: TextTrack,
- capitalName: "Text"
- }
- };
- Object.keys(NORMAL).forEach(function(type2) {
- NORMAL[type2].getterName = type2 + "Tracks";
- NORMAL[type2].privateName = type2 + "Tracks_";
- });
- var REMOTE = {
- remoteText: {
- ListClass: TextTrackList,
- TrackClass: TextTrack,
- capitalName: "RemoteText",
- getterName: "remoteTextTracks",
- privateName: "remoteTextTracks_"
- },
- remoteTextEl: {
- ListClass: HtmlTrackElementList,
- TrackClass: HTMLTrackElement,
- capitalName: "RemoteTextTrackEls",
- getterName: "remoteTextTrackEls",
- privateName: "remoteTextTrackEls_"
- }
- };
- var ALL = _extends$2({}, NORMAL, REMOTE);
- REMOTE.names = Object.keys(REMOTE);
- NORMAL.names = Object.keys(NORMAL);
- ALL.names = [].concat(REMOTE.names).concat(NORMAL.names);
- function createTrackHelper(self2, kind, label2, language, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var tracks = self2.textTracks();
- options2.kind = kind;
- if (label2) {
- options2.label = label2;
- }
- if (language) {
- options2.language = language;
- }
- options2.tech = self2;
- var track = new ALL.text.TrackClass(options2);
- tracks.addTrack(track);
- return track;
- }
- var Tech$1 = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(Tech2, _Component);
- function Tech2(options2, ready) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- if (ready === void 0) {
- ready = function ready2() {
- };
- }
- options2.reportTouchActivity = false;
- _this = _Component.call(this, null, options2, ready) || this;
- _this.onDurationChange_ = function(e) {
- return _this.onDurationChange(e);
- };
- _this.trackProgress_ = function(e) {
- return _this.trackProgress(e);
- };
- _this.trackCurrentTime_ = function(e) {
- return _this.trackCurrentTime(e);
- };
- _this.stopTrackingCurrentTime_ = function(e) {
- return _this.stopTrackingCurrentTime(e);
- };
- _this.disposeSourceHandler_ = function(e) {
- return _this.disposeSourceHandler(e);
- };
- _this.queuedHanders_ = /* @__PURE__ */ new Set();
- _this.hasStarted_ = false;
- _this.on("playing", function() {
- this.hasStarted_ = true;
- });
- _this.on("loadstart", function() {
- this.hasStarted_ = false;
- });
- ALL.names.forEach(function(name) {
- var props = ALL[name];
- if (options2 && options2[props.getterName]) {
- _this[props.privateName] = options2[props.getterName];
- }
- });
- if (!_this.featuresProgressEvents) {
- _this.manualProgressOn();
- }
- if (!_this.featuresTimeupdateEvents) {
- _this.manualTimeUpdatesOn();
- }
- ["Text", "Audio", "Video"].forEach(function(track) {
- if (options2["native" + track + "Tracks"] === false) {
- _this["featuresNative" + track + "Tracks"] = false;
- }
- });
- if (options2.nativeCaptions === false || options2.nativeTextTracks === false) {
- _this.featuresNativeTextTracks = false;
- } else if (options2.nativeCaptions === true || options2.nativeTextTracks === true) {
- _this.featuresNativeTextTracks = true;
- }
- if (!_this.featuresNativeTextTracks) {
- _this.emulateTextTracks();
- }
- _this.preloadTextTracks = options2.preloadTextTracks !== false;
- _this.autoRemoteTextTracks_ = new ALL.text.ListClass();
- _this.initTrackListeners();
- if (!options2.nativeControlsForTouch) {
- _this.emitTapEvents();
- }
- if (_this.constructor) {
- _this.name_ = _this.constructor.name || "Unknown Tech";
- }
- return _this;
- }
- var _proto = Tech2.prototype;
- _proto.triggerSourceset = function triggerSourceset(src) {
- var _this2 = this;
- if (!this.isReady_) {
- this.one("ready", function() {
- return _this2.setTimeout(function() {
- return _this2.triggerSourceset(src);
- }, 1);
- });
- }
- this.trigger({
- src,
- type: "sourceset"
- });
- };
- _proto.manualProgressOn = function manualProgressOn() {
- this.on("durationchange", this.onDurationChange_);
- this.manualProgress = true;
- this.one("ready", this.trackProgress_);
- };
- _proto.manualProgressOff = function manualProgressOff() {
- this.manualProgress = false;
- this.stopTrackingProgress();
- this.off("durationchange", this.onDurationChange_);
- };
- _proto.trackProgress = function trackProgress(event2) {
- this.stopTrackingProgress();
- this.progressInterval = this.setInterval(bind(this, function() {
- var numBufferedPercent = this.bufferedPercent();
- if (this.bufferedPercent_ !== numBufferedPercent) {
- this.trigger("progress");
- }
- this.bufferedPercent_ = numBufferedPercent;
- if (numBufferedPercent === 1) {
- this.stopTrackingProgress();
- }
- }), 500);
- };
- _proto.onDurationChange = function onDurationChange(event2) {
- this.duration_ = this.duration();
- };
- _proto.buffered = function buffered() {
- return createTimeRanges(0, 0);
- };
- _proto.bufferedPercent = function bufferedPercent$12() {
- return bufferedPercent(this.buffered(), this.duration_);
- };
- _proto.stopTrackingProgress = function stopTrackingProgress() {
- this.clearInterval(this.progressInterval);
- };
- _proto.manualTimeUpdatesOn = function manualTimeUpdatesOn() {
- this.manualTimeUpdates = true;
- this.on("play", this.trackCurrentTime_);
- this.on("pause", this.stopTrackingCurrentTime_);
- };
- _proto.manualTimeUpdatesOff = function manualTimeUpdatesOff() {
- this.manualTimeUpdates = false;
- this.stopTrackingCurrentTime();
- this.off("play", this.trackCurrentTime_);
- this.off("pause", this.stopTrackingCurrentTime_);
- };
- _proto.trackCurrentTime = function trackCurrentTime() {
- if (this.currentTimeInterval) {
- this.stopTrackingCurrentTime();
- }
- this.currentTimeInterval = this.setInterval(function() {
- this.trigger({
- type: "timeupdate",
- target: this,
- manuallyTriggered: true
- });
- }, 250);
- };
- _proto.stopTrackingCurrentTime = function stopTrackingCurrentTime() {
- this.clearInterval(this.currentTimeInterval);
- this.trigger({
- type: "timeupdate",
- target: this,
- manuallyTriggered: true
- });
- };
- _proto.dispose = function dispose() {
- this.clearTracks(NORMAL.names);
- if (this.manualProgress) {
- this.manualProgressOff();
- }
- if (this.manualTimeUpdates) {
- this.manualTimeUpdatesOff();
- }
- _Component.prototype.dispose.call(this);
- };
- _proto.clearTracks = function clearTracks(types) {
- var _this3 = this;
- types = [].concat(types);
- types.forEach(function(type2) {
- var list = _this3[type2 + "Tracks"]() || [];
- var i2 = list.length;
- while (i2--) {
- var track = list[i2];
- if (type2 === "text") {
- _this3.removeRemoteTextTrack(track);
- }
- list.removeTrack(track);
- }
- });
- };
- _proto.cleanupAutoTextTracks = function cleanupAutoTextTracks() {
- var list = this.autoRemoteTextTracks_ || [];
- var i2 = list.length;
- while (i2--) {
- var track = list[i2];
- this.removeRemoteTextTrack(track);
- }
- };
- _proto.reset = function reset3() {
- };
- _proto.crossOrigin = function crossOrigin() {
- };
- _proto.setCrossOrigin = function setCrossOrigin() {
- };
- _proto.error = function error(err) {
- if (err !== void 0) {
- this.error_ = new MediaError(err);
- this.trigger("error");
- }
- return this.error_;
- };
- _proto.played = function played() {
- if (this.hasStarted_) {
- return createTimeRanges(0, 0);
- }
- return createTimeRanges();
- };
- _proto.play = function play() {
- };
- _proto.setScrubbing = function setScrubbing() {
- };
- _proto.scrubbing = function scrubbing() {
- };
- _proto.setCurrentTime = function setCurrentTime() {
- if (this.manualTimeUpdates) {
- this.trigger({
- type: "timeupdate",
- target: this,
- manuallyTriggered: true
- });
- }
- };
- _proto.initTrackListeners = function initTrackListeners() {
- var _this4 = this;
- NORMAL.names.forEach(function(name) {
- var props = NORMAL[name];
- var trackListChanges = function trackListChanges2() {
- _this4.trigger(name + "trackchange");
- };
- var tracks = _this4[props.getterName]();
- tracks.addEventListener("removetrack", trackListChanges);
- tracks.addEventListener("addtrack", trackListChanges);
- _this4.on("dispose", function() {
- tracks.removeEventListener("removetrack", trackListChanges);
- tracks.removeEventListener("addtrack", trackListChanges);
- });
- });
- };
- _proto.addWebVttScript_ = function addWebVttScript_() {
- var _this5 = this;
- if (window_1.WebVTT) {
- return;
- }
- if (document_1.body.contains(this.el())) {
- if (!this.options_["vtt.js"] && isPlain(vtt) && Object.keys(vtt).length > 0) {
- this.trigger("vttjsloaded");
- return;
- }
- var script = document_1.createElement("script");
- script.src = this.options_["vtt.js"] || "https://vjs.zencdn.net/vttjs/0.14.1/vtt.min.js";
- script.onload = function() {
- _this5.trigger("vttjsloaded");
- };
- script.onerror = function() {
- _this5.trigger("vttjserror");
- };
- this.on("dispose", function() {
- script.onload = null;
- script.onerror = null;
- });
- window_1.WebVTT = true;
- this.el().parentNode.appendChild(script);
- } else {
- this.ready(this.addWebVttScript_);
- }
- };
- _proto.emulateTextTracks = function emulateTextTracks() {
- var _this6 = this;
- var tracks = this.textTracks();
- var remoteTracks = this.remoteTextTracks();
- var handleAddTrack = function handleAddTrack2(e) {
- return tracks.addTrack(e.track);
- };
- var handleRemoveTrack = function handleRemoveTrack2(e) {
- return tracks.removeTrack(e.track);
- };
- remoteTracks.on("addtrack", handleAddTrack);
- remoteTracks.on("removetrack", handleRemoveTrack);
- this.addWebVttScript_();
- var updateDisplay = function updateDisplay2() {
- return _this6.trigger("texttrackchange");
- };
- var textTracksChanges = function textTracksChanges2() {
- updateDisplay();
- for (var i2 = 0; i2 < tracks.length; i2++) {
- var track = tracks[i2];
- track.removeEventListener("cuechange", updateDisplay);
- if (track.mode === "showing") {
- track.addEventListener("cuechange", updateDisplay);
- }
- }
- };
- textTracksChanges();
- tracks.addEventListener("change", textTracksChanges);
- tracks.addEventListener("addtrack", textTracksChanges);
- tracks.addEventListener("removetrack", textTracksChanges);
- this.on("dispose", function() {
- remoteTracks.off("addtrack", handleAddTrack);
- remoteTracks.off("removetrack", handleRemoveTrack);
- tracks.removeEventListener("change", textTracksChanges);
- tracks.removeEventListener("addtrack", textTracksChanges);
- tracks.removeEventListener("removetrack", textTracksChanges);
- for (var i2 = 0; i2 < tracks.length; i2++) {
- var track = tracks[i2];
- track.removeEventListener("cuechange", updateDisplay);
- }
- });
- };
- _proto.addTextTrack = function addTextTrack(kind, label2, language) {
- if (!kind) {
- throw new Error("TextTrack kind is required but was not provided");
- }
- return createTrackHelper(this, kind, label2, language);
- };
- _proto.createRemoteTextTrack = function createRemoteTextTrack(options2) {
- var track = mergeOptions$3(options2, {
- tech: this
- });
- return new REMOTE.remoteTextEl.TrackClass(track);
- };
- _proto.addRemoteTextTrack = function addRemoteTextTrack(options2, manualCleanup) {
- var _this7 = this;
- if (options2 === void 0) {
- options2 = {};
- }
- var htmlTrackElement = this.createRemoteTextTrack(options2);
- if (manualCleanup !== true && manualCleanup !== false) {
- log$1.warn('Calling addRemoteTextTrack without explicitly setting the "manualCleanup" parameter to `true` is deprecated and default to `false` in future version of video.js');
- manualCleanup = true;
- }
- this.remoteTextTrackEls().addTrackElement_(htmlTrackElement);
- this.remoteTextTracks().addTrack(htmlTrackElement.track);
- if (manualCleanup !== true) {
- this.ready(function() {
- return _this7.autoRemoteTextTracks_.addTrack(htmlTrackElement.track);
- });
- }
- return htmlTrackElement;
- };
- _proto.removeRemoteTextTrack = function removeRemoteTextTrack(track) {
- var trackElement = this.remoteTextTrackEls().getTrackElementByTrack_(track);
- this.remoteTextTrackEls().removeTrackElement_(trackElement);
- this.remoteTextTracks().removeTrack(track);
- this.autoRemoteTextTracks_.removeTrack(track);
- };
- _proto.getVideoPlaybackQuality = function getVideoPlaybackQuality() {
- return {};
- };
- _proto.requestPictureInPicture = function requestPictureInPicture() {
- var PromiseClass = this.options_.Promise || window_1.Promise;
- if (PromiseClass) {
- return PromiseClass.reject();
- }
- };
- _proto.disablePictureInPicture = function disablePictureInPicture() {
- return true;
- };
- _proto.setDisablePictureInPicture = function setDisablePictureInPicture() {
- };
- _proto.requestVideoFrameCallback = function requestVideoFrameCallback(cb) {
- var _this8 = this;
- var id = newGUID();
- if (!this.isReady_ || this.paused()) {
- this.queuedHanders_.add(id);
- this.one("playing", function() {
- if (_this8.queuedHanders_.has(id)) {
- _this8.queuedHanders_["delete"](id);
- cb();
- }
- });
- } else {
- this.requestNamedAnimationFrame(id, cb);
- }
- return id;
- };
- _proto.cancelVideoFrameCallback = function cancelVideoFrameCallback(id) {
- if (this.queuedHanders_.has(id)) {
- this.queuedHanders_["delete"](id);
- } else {
- this.cancelNamedAnimationFrame(id);
- }
- };
- _proto.setPoster = function setPoster() {
- };
- _proto.playsinline = function playsinline() {
- };
- _proto.setPlaysinline = function setPlaysinline() {
- };
- _proto.overrideNativeAudioTracks = function overrideNativeAudioTracks() {
- };
- _proto.overrideNativeVideoTracks = function overrideNativeVideoTracks() {
- };
- _proto.canPlayType = function canPlayType3() {
- return "";
- };
- Tech2.canPlayType = function canPlayType3() {
- return "";
- };
- Tech2.canPlaySource = function canPlaySource(srcObj, options2) {
- return Tech2.canPlayType(srcObj.type);
- };
- Tech2.isTech = function isTech(component) {
- return component.prototype instanceof Tech2 || component instanceof Tech2 || component === Tech2;
- };
- Tech2.registerTech = function registerTech(name, tech) {
- if (!Tech2.techs_) {
- Tech2.techs_ = {};
- }
- if (!Tech2.isTech(tech)) {
- throw new Error("Tech " + name + " must be a Tech");
- }
- if (!Tech2.canPlayType) {
- throw new Error("Techs must have a static canPlayType method on them");
- }
- if (!Tech2.canPlaySource) {
- throw new Error("Techs must have a static canPlaySource method on them");
- }
- name = toTitleCase$1(name);
- Tech2.techs_[name] = tech;
- Tech2.techs_[toLowerCase(name)] = tech;
- if (name !== "Tech") {
- Tech2.defaultTechOrder_.push(name);
- }
- return tech;
- };
- Tech2.getTech = function getTech(name) {
- if (!name) {
- return;
- }
- if (Tech2.techs_ && Tech2.techs_[name]) {
- return Tech2.techs_[name];
- }
- name = toTitleCase$1(name);
- if (window_1 && window_1.videojs && window_1.videojs[name]) {
- log$1.warn("The " + name + " tech was added to the videojs object when it should be registered using videojs.registerTech(name, tech)");
- return window_1.videojs[name];
- }
- };
- return Tech2;
- }(Component$1);
- ALL.names.forEach(function(name) {
- var props = ALL[name];
- Tech$1.prototype[props.getterName] = function() {
- this[props.privateName] = this[props.privateName] || new props.ListClass();
- return this[props.privateName];
- };
- });
- Tech$1.prototype.featuresVolumeControl = true;
- Tech$1.prototype.featuresMuteControl = true;
- Tech$1.prototype.featuresFullscreenResize = false;
- Tech$1.prototype.featuresPlaybackRate = false;
- Tech$1.prototype.featuresProgressEvents = false;
- Tech$1.prototype.featuresSourceset = false;
- Tech$1.prototype.featuresTimeupdateEvents = false;
- Tech$1.prototype.featuresNativeTextTracks = false;
- Tech$1.prototype.featuresVideoFrameCallback = false;
- Tech$1.withSourceHandlers = function(_Tech) {
- _Tech.registerSourceHandler = function(handler, index2) {
- var handlers = _Tech.sourceHandlers;
- if (!handlers) {
- handlers = _Tech.sourceHandlers = [];
- }
- if (index2 === void 0) {
- index2 = handlers.length;
- }
- handlers.splice(index2, 0, handler);
- };
- _Tech.canPlayType = function(type2) {
- var handlers = _Tech.sourceHandlers || [];
- var can;
- for (var i2 = 0; i2 < handlers.length; i2++) {
- can = handlers[i2].canPlayType(type2);
- if (can) {
- return can;
- }
- }
- return "";
- };
- _Tech.selectSourceHandler = function(source, options2) {
- var handlers = _Tech.sourceHandlers || [];
- var can;
- for (var i2 = 0; i2 < handlers.length; i2++) {
- can = handlers[i2].canHandleSource(source, options2);
- if (can) {
- return handlers[i2];
- }
- }
- return null;
- };
- _Tech.canPlaySource = function(srcObj, options2) {
- var sh = _Tech.selectSourceHandler(srcObj, options2);
- if (sh) {
- return sh.canHandleSource(srcObj, options2);
- }
- return "";
- };
- var deferrable = ["seekable", "seeking", "duration"];
- deferrable.forEach(function(fnName) {
- var originalFn = this[fnName];
- if (typeof originalFn !== "function") {
- return;
- }
- this[fnName] = function() {
- if (this.sourceHandler_ && this.sourceHandler_[fnName]) {
- return this.sourceHandler_[fnName].apply(this.sourceHandler_, arguments);
- }
- return originalFn.apply(this, arguments);
- };
- }, _Tech.prototype);
- _Tech.prototype.setSource = function(source) {
- var sh = _Tech.selectSourceHandler(source, this.options_);
- if (!sh) {
- if (_Tech.nativeSourceHandler) {
- sh = _Tech.nativeSourceHandler;
- } else {
- log$1.error("No source handler found for the current source.");
- }
- }
- this.disposeSourceHandler();
- this.off("dispose", this.disposeSourceHandler_);
- if (sh !== _Tech.nativeSourceHandler) {
- this.currentSource_ = source;
- }
- this.sourceHandler_ = sh.handleSource(source, this, this.options_);
- this.one("dispose", this.disposeSourceHandler_);
- };
- _Tech.prototype.disposeSourceHandler = function() {
- if (this.currentSource_) {
- this.clearTracks(["audio", "video"]);
- this.currentSource_ = null;
- }
- this.cleanupAutoTextTracks();
- if (this.sourceHandler_) {
- if (this.sourceHandler_.dispose) {
- this.sourceHandler_.dispose();
- }
- this.sourceHandler_ = null;
- }
- };
- };
- Component$1.registerComponent("Tech", Tech$1);
- Tech$1.registerTech("Tech", Tech$1);
- Tech$1.defaultTechOrder_ = [];
- var middlewares = {};
- var middlewareInstances = {};
- var TERMINATOR = {};
- function use(type2, middleware) {
- middlewares[type2] = middlewares[type2] || [];
- middlewares[type2].push(middleware);
- }
- function setSource(player, src, next) {
- player.setTimeout(function() {
- return setSourceHelper(src, middlewares[src.type], next, player);
- }, 1);
- }
- function setTech(middleware, tech) {
- middleware.forEach(function(mw) {
- return mw.setTech && mw.setTech(tech);
- });
- }
- function get(middleware, tech, method) {
- return middleware.reduceRight(middlewareIterator(method), tech[method]());
- }
- function set(middleware, tech, method, arg) {
- return tech[method](middleware.reduce(middlewareIterator(method), arg));
- }
- function mediate(middleware, tech, method, arg) {
- if (arg === void 0) {
- arg = null;
- }
- var callMethod = "call" + toTitleCase$1(method);
- var middlewareValue = middleware.reduce(middlewareIterator(callMethod), arg);
- var terminated = middlewareValue === TERMINATOR;
- var returnValue = terminated ? null : tech[method](middlewareValue);
- executeRight(middleware, method, returnValue, terminated);
- return returnValue;
- }
- var allowedGetters = {
- buffered: 1,
- currentTime: 1,
- duration: 1,
- muted: 1,
- played: 1,
- paused: 1,
- seekable: 1,
- volume: 1,
- ended: 1
- };
- var allowedSetters = {
- setCurrentTime: 1,
- setMuted: 1,
- setVolume: 1
- };
- var allowedMediators = {
- play: 1,
- pause: 1
- };
- function middlewareIterator(method) {
- return function(value, mw) {
- if (value === TERMINATOR) {
- return TERMINATOR;
- }
- if (mw[method]) {
- return mw[method](value);
- }
- return value;
- };
- }
- function executeRight(mws, method, value, terminated) {
- for (var i2 = mws.length - 1; i2 >= 0; i2--) {
- var mw = mws[i2];
- if (mw[method]) {
- mw[method](terminated, value);
- }
- }
- }
- function clearCacheForPlayer(player) {
- middlewareInstances[player.id()] = null;
- }
- function getOrCreateFactory(player, mwFactory) {
- var mws = middlewareInstances[player.id()];
- var mw = null;
- if (mws === void 0 || mws === null) {
- mw = mwFactory(player);
- middlewareInstances[player.id()] = [[mwFactory, mw]];
- return mw;
- }
- for (var i2 = 0; i2 < mws.length; i2++) {
- var _mws$i = mws[i2], mwf = _mws$i[0], mwi = _mws$i[1];
- if (mwf !== mwFactory) {
- continue;
- }
- mw = mwi;
- }
- if (mw === null) {
- mw = mwFactory(player);
- mws.push([mwFactory, mw]);
- }
- return mw;
- }
- function setSourceHelper(src, middleware, next, player, acc, lastRun) {
- if (src === void 0) {
- src = {};
- }
- if (middleware === void 0) {
- middleware = [];
- }
- if (acc === void 0) {
- acc = [];
- }
- if (lastRun === void 0) {
- lastRun = false;
- }
- var _middleware = middleware, mwFactory = _middleware[0], mwrest = _middleware.slice(1);
- if (typeof mwFactory === "string") {
- setSourceHelper(src, middlewares[mwFactory], next, player, acc, lastRun);
- } else if (mwFactory) {
- var mw = getOrCreateFactory(player, mwFactory);
- if (!mw.setSource) {
- acc.push(mw);
- return setSourceHelper(src, mwrest, next, player, acc, lastRun);
- }
- mw.setSource(assign({}, src), function(err, _src) {
- if (err) {
- return setSourceHelper(src, mwrest, next, player, acc, lastRun);
- }
- acc.push(mw);
- setSourceHelper(_src, src.type === _src.type ? mwrest : middlewares[_src.type], next, player, acc, lastRun);
- });
- } else if (mwrest.length) {
- setSourceHelper(src, mwrest, next, player, acc, lastRun);
- } else if (lastRun) {
- next(src, acc);
- } else {
- setSourceHelper(src, middlewares["*"], next, player, acc, true);
- }
- }
- var MimetypesKind = {
- opus: "video/ogg",
- ogv: "video/ogg",
- mp4: "video/mp4",
- mov: "video/mp4",
- m4v: "video/mp4",
- mkv: "video/x-matroska",
- m4a: "audio/mp4",
- mp3: "audio/mpeg",
- aac: "audio/aac",
- caf: "audio/x-caf",
- flac: "audio/flac",
- oga: "audio/ogg",
- wav: "audio/wav",
- m3u8: "application/x-mpegURL",
- mpd: "application/dash+xml",
- jpg: "image/jpeg",
- jpeg: "image/jpeg",
- gif: "image/gif",
- png: "image/png",
- svg: "image/svg+xml",
- webp: "image/webp"
- };
- var getMimetype = function getMimetype2(src) {
- if (src === void 0) {
- src = "";
- }
- var ext = getFileExtension(src);
- var mimetype = MimetypesKind[ext.toLowerCase()];
- return mimetype || "";
- };
- var findMimetype = function findMimetype2(player, src) {
- if (!src) {
- return "";
- }
- if (player.cache_.source.src === src && player.cache_.source.type) {
- return player.cache_.source.type;
- }
- var matchingSources = player.cache_.sources.filter(function(s2) {
- return s2.src === src;
- });
- if (matchingSources.length) {
- return matchingSources[0].type;
- }
- var sources = player.$$("source");
- for (var i2 = 0; i2 < sources.length; i2++) {
- var s = sources[i2];
- if (s.type && s.src && s.src === src) {
- return s.type;
- }
- }
- return getMimetype(src);
- };
- var filterSource = function filterSource2(src) {
- if (Array.isArray(src)) {
- var newsrc = [];
- src.forEach(function(srcobj) {
- srcobj = filterSource2(srcobj);
- if (Array.isArray(srcobj)) {
- newsrc = newsrc.concat(srcobj);
- } else if (isObject2(srcobj)) {
- newsrc.push(srcobj);
- }
- });
- src = newsrc;
- } else if (typeof src === "string" && src.trim()) {
- src = [fixSource({
- src
- })];
- } else if (isObject2(src) && typeof src.src === "string" && src.src && src.src.trim()) {
- src = [fixSource(src)];
- } else {
- src = [];
- }
- return src;
- };
- function fixSource(src) {
- if (!src.type) {
- var mimetype = getMimetype(src.src);
- if (mimetype) {
- src.type = mimetype;
- }
- }
- return src;
- }
- var MediaLoader = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(MediaLoader2, _Component);
- function MediaLoader2(player, options2, ready) {
- var _this;
- var options_ = mergeOptions$3({
- createEl: false
- }, options2);
- _this = _Component.call(this, player, options_, ready) || this;
- if (!options2.playerOptions.sources || options2.playerOptions.sources.length === 0) {
- for (var i2 = 0, j = options2.playerOptions.techOrder; i2 < j.length; i2++) {
- var techName = toTitleCase$1(j[i2]);
- var tech = Tech$1.getTech(techName);
- if (!techName) {
- tech = Component$1.getComponent(techName);
- }
- if (tech && tech.isSupported()) {
- player.loadTech_(techName);
- break;
- }
- }
- } else {
- player.src(options2.playerOptions.sources);
- }
- return _this;
- }
- return MediaLoader2;
- }(Component$1);
- Component$1.registerComponent("MediaLoader", MediaLoader);
- var ClickableComponent = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(ClickableComponent2, _Component);
- function ClickableComponent2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- if (_this.options_.controlText) {
- _this.controlText(_this.options_.controlText);
- }
- _this.handleMouseOver_ = function(e) {
- return _this.handleMouseOver(e);
- };
- _this.handleMouseOut_ = function(e) {
- return _this.handleMouseOut(e);
- };
- _this.handleClick_ = function(e) {
- return _this.handleClick(e);
- };
- _this.handleKeyDown_ = function(e) {
- return _this.handleKeyDown(e);
- };
- _this.emitTapEvents();
- _this.enable();
- return _this;
- }
- var _proto = ClickableComponent2.prototype;
- _proto.createEl = function createEl$12(tag, props, attributes) {
- if (tag === void 0) {
- tag = "div";
- }
- if (props === void 0) {
- props = {};
- }
- if (attributes === void 0) {
- attributes = {};
- }
- props = assign({
- className: this.buildCSSClass(),
- tabIndex: 0
- }, props);
- if (tag === "button") {
- log$1.error("Creating a ClickableComponent with an HTML element of " + tag + " is not supported; use a Button instead.");
- }
- attributes = assign({
- role: "button"
- }, attributes);
- this.tabIndex_ = props.tabIndex;
- var el = createEl(tag, props, attributes);
- el.appendChild(createEl("span", {
- className: "vjs-icon-placeholder"
- }, {
- "aria-hidden": true
- }));
- this.createControlTextEl(el);
- return el;
- };
- _proto.dispose = function dispose() {
- this.controlTextEl_ = null;
- _Component.prototype.dispose.call(this);
- };
- _proto.createControlTextEl = function createControlTextEl(el) {
- this.controlTextEl_ = createEl("span", {
- className: "vjs-control-text"
- }, {
- "aria-live": "polite"
- });
- if (el) {
- el.appendChild(this.controlTextEl_);
- }
- this.controlText(this.controlText_, el);
- return this.controlTextEl_;
- };
- _proto.controlText = function controlText(text, el) {
- if (el === void 0) {
- el = this.el();
- }
- if (text === void 0) {
- return this.controlText_ || "Need Text";
- }
- var localizedText = this.localize(text);
- this.controlText_ = text;
- textContent(this.controlTextEl_, localizedText);
- if (!this.nonIconControl && !this.player_.options_.noUITitleAttributes) {
- el.setAttribute("title", localizedText);
- }
- };
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-control vjs-button " + _Component.prototype.buildCSSClass.call(this);
- };
- _proto.enable = function enable() {
- if (!this.enabled_) {
- this.enabled_ = true;
- this.removeClass("vjs-disabled");
- this.el_.setAttribute("aria-disabled", "false");
- if (typeof this.tabIndex_ !== "undefined") {
- this.el_.setAttribute("tabIndex", this.tabIndex_);
- }
- this.on(["tap", "click"], this.handleClick_);
- this.on("keydown", this.handleKeyDown_);
- }
- };
- _proto.disable = function disable() {
- this.enabled_ = false;
- this.addClass("vjs-disabled");
- this.el_.setAttribute("aria-disabled", "true");
- if (typeof this.tabIndex_ !== "undefined") {
- this.el_.removeAttribute("tabIndex");
- }
- this.off("mouseover", this.handleMouseOver_);
- this.off("mouseout", this.handleMouseOut_);
- this.off(["tap", "click"], this.handleClick_);
- this.off("keydown", this.handleKeyDown_);
- };
- _proto.handleLanguagechange = function handleLanguagechange() {
- this.controlText(this.controlText_);
- };
- _proto.handleClick = function handleClick(event2) {
- if (this.options_.clickHandler) {
- this.options_.clickHandler.call(this, arguments);
- }
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Space") || keycode.isEventKey(event2, "Enter")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.trigger("click");
- } else {
- _Component.prototype.handleKeyDown.call(this, event2);
- }
- };
- return ClickableComponent2;
- }(Component$1);
- Component$1.registerComponent("ClickableComponent", ClickableComponent);
- var PosterImage = /* @__PURE__ */ function(_ClickableComponent) {
- _inheritsLoose(PosterImage2, _ClickableComponent);
- function PosterImage2(player, options2) {
- var _this;
- _this = _ClickableComponent.call(this, player, options2) || this;
- _this.update();
- _this.update_ = function(e) {
- return _this.update(e);
- };
- player.on("posterchange", _this.update_);
- return _this;
- }
- var _proto = PosterImage2.prototype;
- _proto.dispose = function dispose() {
- this.player().off("posterchange", this.update_);
- _ClickableComponent.prototype.dispose.call(this);
- };
- _proto.createEl = function createEl$12() {
- var el = createEl("div", {
- className: "vjs-poster",
- tabIndex: -1
- });
- return el;
- };
- _proto.update = function update(event2) {
- var url = this.player().poster();
- this.setSrc(url);
- if (url) {
- this.show();
- } else {
- this.hide();
- }
- };
- _proto.setSrc = function setSrc(url) {
- var backgroundImage = "";
- if (url) {
- backgroundImage = 'url("' + url + '")';
- }
- this.el_.style.backgroundImage = backgroundImage;
- };
- _proto.handleClick = function handleClick(event2) {
- if (!this.player_.controls()) {
- return;
- }
- var sourceIsEncrypted = this.player_.usingPlugin("eme") && this.player_.eme.sessions && this.player_.eme.sessions.length > 0;
- if (this.player_.tech(true) && !((IE_VERSION || IS_EDGE) && sourceIsEncrypted)) {
- this.player_.tech(true).focus();
- }
- if (this.player_.paused()) {
- silencePromise(this.player_.play());
- } else {
- this.player_.pause();
- }
- };
- return PosterImage2;
- }(ClickableComponent);
- Component$1.registerComponent("PosterImage", PosterImage);
- var darkGray = "#222";
- var lightGray = "#ccc";
- var fontMap = {
- monospace: "monospace",
- sansSerif: "sans-serif",
- serif: "serif",
- monospaceSansSerif: '"Andale Mono", "Lucida Console", monospace',
- monospaceSerif: '"Courier New", monospace',
- proportionalSansSerif: "sans-serif",
- proportionalSerif: "serif",
- casual: '"Comic Sans MS", Impact, fantasy',
- script: '"Monotype Corsiva", cursive',
- smallcaps: '"Andale Mono", "Lucida Console", monospace, sans-serif'
- };
- function constructColor(color2, opacity) {
- var hex;
- if (color2.length === 4) {
- hex = color2[1] + color2[1] + color2[2] + color2[2] + color2[3] + color2[3];
- } else if (color2.length === 7) {
- hex = color2.slice(1);
- } else {
- throw new Error("Invalid color code provided, " + color2 + "; must be formatted as e.g. #f0e or #f604e2.");
- }
- return "rgba(" + parseInt(hex.slice(0, 2), 16) + "," + parseInt(hex.slice(2, 4), 16) + "," + parseInt(hex.slice(4, 6), 16) + "," + opacity + ")";
- }
- function tryUpdateStyle(el, style, rule) {
- try {
- el.style[style] = rule;
- } catch (e) {
- return;
- }
- }
- var TextTrackDisplay = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(TextTrackDisplay2, _Component);
- function TextTrackDisplay2(player, options2, ready) {
- var _this;
- _this = _Component.call(this, player, options2, ready) || this;
- var updateDisplayHandler = function updateDisplayHandler2(e) {
- return _this.updateDisplay(e);
- };
- player.on("loadstart", function(e) {
- return _this.toggleDisplay(e);
- });
- player.on("texttrackchange", updateDisplayHandler);
- player.on("loadedmetadata", function(e) {
- return _this.preselectTrack(e);
- });
- player.ready(bind(_assertThisInitialized(_this), function() {
- if (player.tech_ && player.tech_.featuresNativeTextTracks) {
- this.hide();
- return;
- }
- player.on("fullscreenchange", updateDisplayHandler);
- player.on("playerresize", updateDisplayHandler);
- window_1.addEventListener("orientationchange", updateDisplayHandler);
- player.on("dispose", function() {
- return window_1.removeEventListener("orientationchange", updateDisplayHandler);
- });
- var tracks = this.options_.playerOptions.tracks || [];
- for (var i2 = 0; i2 < tracks.length; i2++) {
- this.player_.addRemoteTextTrack(tracks[i2], true);
- }
- this.preselectTrack();
- }));
- return _this;
- }
- var _proto = TextTrackDisplay2.prototype;
- _proto.preselectTrack = function preselectTrack() {
- var modes = {
- captions: 1,
- subtitles: 1
- };
- var trackList = this.player_.textTracks();
- var userPref = this.player_.cache_.selectedLanguage;
- var firstDesc;
- var firstCaptions;
- var preferredTrack;
- for (var i2 = 0; i2 < trackList.length; i2++) {
- var track = trackList[i2];
- if (userPref && userPref.enabled && userPref.language && userPref.language === track.language && track.kind in modes) {
- if (track.kind === userPref.kind) {
- preferredTrack = track;
- } else if (!preferredTrack) {
- preferredTrack = track;
- }
- } else if (userPref && !userPref.enabled) {
- preferredTrack = null;
- firstDesc = null;
- firstCaptions = null;
- } else if (track["default"]) {
- if (track.kind === "descriptions" && !firstDesc) {
- firstDesc = track;
- } else if (track.kind in modes && !firstCaptions) {
- firstCaptions = track;
- }
- }
- }
- if (preferredTrack) {
- preferredTrack.mode = "showing";
- } else if (firstCaptions) {
- firstCaptions.mode = "showing";
- } else if (firstDesc) {
- firstDesc.mode = "showing";
- }
- };
- _proto.toggleDisplay = function toggleDisplay() {
- if (this.player_.tech_ && this.player_.tech_.featuresNativeTextTracks) {
- this.hide();
- } else {
- this.show();
- }
- };
- _proto.createEl = function createEl2() {
- return _Component.prototype.createEl.call(this, "div", {
- className: "vjs-text-track-display"
- }, {
- "translate": "yes",
- "aria-live": "off",
- "aria-atomic": "true"
- });
- };
- _proto.clearDisplay = function clearDisplay() {
- if (typeof window_1.WebVTT === "function") {
- window_1.WebVTT.processCues(window_1, [], this.el_);
- }
- };
- _proto.updateDisplay = function updateDisplay() {
- var tracks = this.player_.textTracks();
- var allowMultipleShowingTracks = this.options_.allowMultipleShowingTracks;
- this.clearDisplay();
- if (allowMultipleShowingTracks) {
- var showingTracks = [];
- for (var _i = 0; _i < tracks.length; ++_i) {
- var track = tracks[_i];
- if (track.mode !== "showing") {
- continue;
- }
- showingTracks.push(track);
- }
- this.updateForTrack(showingTracks);
- return;
- }
- var descriptionsTrack = null;
- var captionsSubtitlesTrack = null;
- var i2 = tracks.length;
- while (i2--) {
- var _track = tracks[i2];
- if (_track.mode === "showing") {
- if (_track.kind === "descriptions") {
- descriptionsTrack = _track;
- } else {
- captionsSubtitlesTrack = _track;
- }
- }
- }
- if (captionsSubtitlesTrack) {
- if (this.getAttribute("aria-live") !== "off") {
- this.setAttribute("aria-live", "off");
- }
- this.updateForTrack(captionsSubtitlesTrack);
- } else if (descriptionsTrack) {
- if (this.getAttribute("aria-live") !== "assertive") {
- this.setAttribute("aria-live", "assertive");
- }
- this.updateForTrack(descriptionsTrack);
- }
- };
- _proto.updateDisplayState = function updateDisplayState(track) {
- var overrides = this.player_.textTrackSettings.getValues();
- var cues = track.activeCues;
- var i2 = cues.length;
- while (i2--) {
- var cue = cues[i2];
- if (!cue) {
- continue;
- }
- var cueDiv = cue.displayState;
- if (overrides.color) {
- cueDiv.firstChild.style.color = overrides.color;
- }
- if (overrides.textOpacity) {
- tryUpdateStyle(cueDiv.firstChild, "color", constructColor(overrides.color || "#fff", overrides.textOpacity));
- }
- if (overrides.backgroundColor) {
- cueDiv.firstChild.style.backgroundColor = overrides.backgroundColor;
- }
- if (overrides.backgroundOpacity) {
- tryUpdateStyle(cueDiv.firstChild, "backgroundColor", constructColor(overrides.backgroundColor || "#000", overrides.backgroundOpacity));
- }
- if (overrides.windowColor) {
- if (overrides.windowOpacity) {
- tryUpdateStyle(cueDiv, "backgroundColor", constructColor(overrides.windowColor, overrides.windowOpacity));
- } else {
- cueDiv.style.backgroundColor = overrides.windowColor;
- }
- }
- if (overrides.edgeStyle) {
- if (overrides.edgeStyle === "dropshadow") {
- cueDiv.firstChild.style.textShadow = "2px 2px 3px " + darkGray + ", 2px 2px 4px " + darkGray + ", 2px 2px 5px " + darkGray;
- } else if (overrides.edgeStyle === "raised") {
- cueDiv.firstChild.style.textShadow = "1px 1px " + darkGray + ", 2px 2px " + darkGray + ", 3px 3px " + darkGray;
- } else if (overrides.edgeStyle === "depressed") {
- cueDiv.firstChild.style.textShadow = "1px 1px " + lightGray + ", 0 1px " + lightGray + ", -1px -1px " + darkGray + ", 0 -1px " + darkGray;
- } else if (overrides.edgeStyle === "uniform") {
- cueDiv.firstChild.style.textShadow = "0 0 4px " + darkGray + ", 0 0 4px " + darkGray + ", 0 0 4px " + darkGray + ", 0 0 4px " + darkGray;
- }
- }
- if (overrides.fontPercent && overrides.fontPercent !== 1) {
- var fontSize = window_1.parseFloat(cueDiv.style.fontSize);
- cueDiv.style.fontSize = fontSize * overrides.fontPercent + "px";
- cueDiv.style.height = "auto";
- cueDiv.style.top = "auto";
- }
- if (overrides.fontFamily && overrides.fontFamily !== "default") {
- if (overrides.fontFamily === "small-caps") {
- cueDiv.firstChild.style.fontVariant = "small-caps";
- } else {
- cueDiv.firstChild.style.fontFamily = fontMap[overrides.fontFamily];
- }
- }
- }
- };
- _proto.updateForTrack = function updateForTrack(tracks) {
- if (!Array.isArray(tracks)) {
- tracks = [tracks];
- }
- if (typeof window_1.WebVTT !== "function" || tracks.every(function(track2) {
- return !track2.activeCues;
- })) {
- return;
- }
- var cues = [];
- for (var i2 = 0; i2 < tracks.length; ++i2) {
- var track = tracks[i2];
- for (var j = 0; j < track.activeCues.length; ++j) {
- cues.push(track.activeCues[j]);
- }
- }
- window_1.WebVTT.processCues(window_1, cues, this.el_);
- for (var _i2 = 0; _i2 < tracks.length; ++_i2) {
- var _track2 = tracks[_i2];
- for (var _j = 0; _j < _track2.activeCues.length; ++_j) {
- var cueEl = _track2.activeCues[_j].displayState;
- addClass(cueEl, "vjs-text-track-cue");
- addClass(cueEl, "vjs-text-track-cue-" + (_track2.language ? _track2.language : _i2));
- if (_track2.language) {
- setAttribute(cueEl, "lang", _track2.language);
- }
- }
- if (this.player_.textTrackSettings) {
- this.updateDisplayState(_track2);
- }
- }
- };
- return TextTrackDisplay2;
- }(Component$1);
- Component$1.registerComponent("TextTrackDisplay", TextTrackDisplay);
- var LoadingSpinner = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(LoadingSpinner2, _Component);
- function LoadingSpinner2() {
- return _Component.apply(this, arguments) || this;
- }
- var _proto = LoadingSpinner2.prototype;
- _proto.createEl = function createEl$12() {
- var isAudio = this.player_.isAudio();
- var playerType = this.localize(isAudio ? "Audio Player" : "Video Player");
- var controlText = createEl("span", {
- className: "vjs-control-text",
- textContent: this.localize("{1} is loading.", [playerType])
- });
- var el = _Component.prototype.createEl.call(this, "div", {
- className: "vjs-loading-spinner",
- dir: "ltr"
- });
- el.appendChild(controlText);
- return el;
- };
- return LoadingSpinner2;
- }(Component$1);
- Component$1.registerComponent("LoadingSpinner", LoadingSpinner);
- var Button = /* @__PURE__ */ function(_ClickableComponent) {
- _inheritsLoose(Button2, _ClickableComponent);
- function Button2() {
- return _ClickableComponent.apply(this, arguments) || this;
- }
- var _proto = Button2.prototype;
- _proto.createEl = function createEl$12(tag, props, attributes) {
- if (props === void 0) {
- props = {};
- }
- if (attributes === void 0) {
- attributes = {};
- }
- tag = "button";
- props = assign({
- className: this.buildCSSClass()
- }, props);
- attributes = assign({
- type: "button"
- }, attributes);
- var el = createEl(tag, props, attributes);
- el.appendChild(createEl("span", {
- className: "vjs-icon-placeholder"
- }, {
- "aria-hidden": true
- }));
- this.createControlTextEl(el);
- return el;
- };
- _proto.addChild = function addChild(child, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var className = this.constructor.name;
- log$1.warn("Adding an actionable (user controllable) child to a Button (" + className + ") is not supported; use a ClickableComponent instead.");
- return Component$1.prototype.addChild.call(this, child, options2);
- };
- _proto.enable = function enable() {
- _ClickableComponent.prototype.enable.call(this);
- this.el_.removeAttribute("disabled");
- };
- _proto.disable = function disable() {
- _ClickableComponent.prototype.disable.call(this);
- this.el_.setAttribute("disabled", "disabled");
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Space") || keycode.isEventKey(event2, "Enter")) {
- event2.stopPropagation();
- return;
- }
- _ClickableComponent.prototype.handleKeyDown.call(this, event2);
- };
- return Button2;
- }(ClickableComponent);
- Component$1.registerComponent("Button", Button);
- var BigPlayButton = /* @__PURE__ */ function(_Button) {
- _inheritsLoose(BigPlayButton2, _Button);
- function BigPlayButton2(player, options2) {
- var _this;
- _this = _Button.call(this, player, options2) || this;
- _this.mouseused_ = false;
- _this.on("mousedown", function(e) {
- return _this.handleMouseDown(e);
- });
- return _this;
- }
- var _proto = BigPlayButton2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-big-play-button";
- };
- _proto.handleClick = function handleClick(event2) {
- var playPromise = this.player_.play();
- if (this.mouseused_ && event2.clientX && event2.clientY) {
- var sourceIsEncrypted = this.player_.usingPlugin("eme") && this.player_.eme.sessions && this.player_.eme.sessions.length > 0;
- silencePromise(playPromise);
- if (this.player_.tech(true) && !((IE_VERSION || IS_EDGE) && sourceIsEncrypted)) {
- this.player_.tech(true).focus();
- }
- return;
- }
- var cb = this.player_.getChild("controlBar");
- var playToggle = cb && cb.getChild("playToggle");
- if (!playToggle) {
- this.player_.tech(true).focus();
- return;
- }
- var playFocus = function playFocus2() {
- return playToggle.focus();
- };
- if (isPromise(playPromise)) {
- playPromise.then(playFocus, function() {
- });
- } else {
- this.setTimeout(playFocus, 1);
- }
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- this.mouseused_ = false;
- _Button.prototype.handleKeyDown.call(this, event2);
- };
- _proto.handleMouseDown = function handleMouseDown(event2) {
- this.mouseused_ = true;
- };
- return BigPlayButton2;
- }(Button);
- BigPlayButton.prototype.controlText_ = "Play Video";
- Component$1.registerComponent("BigPlayButton", BigPlayButton);
- var CloseButton = /* @__PURE__ */ function(_Button) {
- _inheritsLoose(CloseButton2, _Button);
- function CloseButton2(player, options2) {
- var _this;
- _this = _Button.call(this, player, options2) || this;
- _this.controlText(options2 && options2.controlText || _this.localize("Close"));
- return _this;
- }
- var _proto = CloseButton2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-close-button " + _Button.prototype.buildCSSClass.call(this);
- };
- _proto.handleClick = function handleClick(event2) {
- this.trigger({
- type: "close",
- bubbles: false
- });
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Esc")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.trigger("click");
- } else {
- _Button.prototype.handleKeyDown.call(this, event2);
- }
- };
- return CloseButton2;
- }(Button);
- Component$1.registerComponent("CloseButton", CloseButton);
- var PlayToggle = /* @__PURE__ */ function(_Button) {
- _inheritsLoose(PlayToggle2, _Button);
- function PlayToggle2(player, options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- _this = _Button.call(this, player, options2) || this;
- options2.replay = options2.replay === void 0 || options2.replay;
- _this.on(player, "play", function(e) {
- return _this.handlePlay(e);
- });
- _this.on(player, "pause", function(e) {
- return _this.handlePause(e);
- });
- if (options2.replay) {
- _this.on(player, "ended", function(e) {
- return _this.handleEnded(e);
- });
- }
- return _this;
- }
- var _proto = PlayToggle2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-play-control " + _Button.prototype.buildCSSClass.call(this);
- };
- _proto.handleClick = function handleClick(event2) {
- if (this.player_.paused()) {
- silencePromise(this.player_.play());
- } else {
- this.player_.pause();
- }
- };
- _proto.handleSeeked = function handleSeeked(event2) {
- this.removeClass("vjs-ended");
- if (this.player_.paused()) {
- this.handlePause(event2);
- } else {
- this.handlePlay(event2);
- }
- };
- _proto.handlePlay = function handlePlay(event2) {
- this.removeClass("vjs-ended");
- this.removeClass("vjs-paused");
- this.addClass("vjs-playing");
- this.controlText("Pause");
- };
- _proto.handlePause = function handlePause(event2) {
- this.removeClass("vjs-playing");
- this.addClass("vjs-paused");
- this.controlText("Play");
- };
- _proto.handleEnded = function handleEnded(event2) {
- var _this2 = this;
- this.removeClass("vjs-playing");
- this.addClass("vjs-ended");
- this.controlText("Replay");
- this.one(this.player_, "seeked", function(e) {
- return _this2.handleSeeked(e);
- });
- };
- return PlayToggle2;
- }(Button);
- PlayToggle.prototype.controlText_ = "Play";
- Component$1.registerComponent("PlayToggle", PlayToggle);
- var defaultImplementation = function defaultImplementation2(seconds, guide) {
- seconds = seconds < 0 ? 0 : seconds;
- var s = Math.floor(seconds % 60);
- var m = Math.floor(seconds / 60 % 60);
- var h2 = Math.floor(seconds / 3600);
- var gm = Math.floor(guide / 60 % 60);
- var gh = Math.floor(guide / 3600);
- if (isNaN(seconds) || seconds === Infinity) {
- h2 = m = s = "-";
- }
- h2 = h2 > 0 || gh > 0 ? h2 + ":" : "";
- m = ((h2 || gm >= 10) && m < 10 ? "0" + m : m) + ":";
- s = s < 10 ? "0" + s : s;
- return h2 + m + s;
- };
- var implementation = defaultImplementation;
- function setFormatTime(customImplementation) {
- implementation = customImplementation;
- }
- function resetFormatTime() {
- implementation = defaultImplementation;
- }
- function formatTime(seconds, guide) {
- if (guide === void 0) {
- guide = seconds;
- }
- return implementation(seconds, guide);
- }
- var TimeDisplay = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(TimeDisplay2, _Component);
- function TimeDisplay2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- _this.on(player, ["timeupdate", "ended"], function(e) {
- return _this.updateContent(e);
- });
- _this.updateTextNode_();
- return _this;
- }
- var _proto = TimeDisplay2.prototype;
- _proto.createEl = function createEl$12() {
- var className = this.buildCSSClass();
- var el = _Component.prototype.createEl.call(this, "div", {
- className: className + " vjs-time-control vjs-control"
- });
- var span = createEl("span", {
- className: "vjs-control-text",
- textContent: this.localize(this.labelText_) + "\xA0"
- }, {
- role: "presentation"
- });
- el.appendChild(span);
- this.contentEl_ = createEl("span", {
- className: className + "-display"
- }, {
- "aria-live": "off",
- "role": "presentation"
- });
- el.appendChild(this.contentEl_);
- return el;
- };
- _proto.dispose = function dispose() {
- this.contentEl_ = null;
- this.textNode_ = null;
- _Component.prototype.dispose.call(this);
- };
- _proto.updateTextNode_ = function updateTextNode_(time) {
- var _this2 = this;
- if (time === void 0) {
- time = 0;
- }
- time = formatTime(time);
- if (this.formattedTime_ === time) {
- return;
- }
- this.formattedTime_ = time;
- this.requestNamedAnimationFrame("TimeDisplay#updateTextNode_", function() {
- if (!_this2.contentEl_) {
- return;
- }
- var oldNode = _this2.textNode_;
- if (oldNode && _this2.contentEl_.firstChild !== oldNode) {
- oldNode = null;
- log$1.warn("TimeDisplay#updateTextnode_: Prevented replacement of text node element since it was no longer a child of this node. Appending a new node instead.");
- }
- _this2.textNode_ = document_1.createTextNode(_this2.formattedTime_);
- if (!_this2.textNode_) {
- return;
- }
- if (oldNode) {
- _this2.contentEl_.replaceChild(_this2.textNode_, oldNode);
- } else {
- _this2.contentEl_.appendChild(_this2.textNode_);
- }
- });
- };
- _proto.updateContent = function updateContent(event2) {
- };
- return TimeDisplay2;
- }(Component$1);
- TimeDisplay.prototype.labelText_ = "Time";
- TimeDisplay.prototype.controlText_ = "Time";
- Component$1.registerComponent("TimeDisplay", TimeDisplay);
- var CurrentTimeDisplay = /* @__PURE__ */ function(_TimeDisplay) {
- _inheritsLoose(CurrentTimeDisplay2, _TimeDisplay);
- function CurrentTimeDisplay2() {
- return _TimeDisplay.apply(this, arguments) || this;
- }
- var _proto = CurrentTimeDisplay2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-current-time";
- };
- _proto.updateContent = function updateContent(event2) {
- var time;
- if (this.player_.ended()) {
- time = this.player_.duration();
- } else {
- time = this.player_.scrubbing() ? this.player_.getCache().currentTime : this.player_.currentTime();
- }
- this.updateTextNode_(time);
- };
- return CurrentTimeDisplay2;
- }(TimeDisplay);
- CurrentTimeDisplay.prototype.labelText_ = "Current Time";
- CurrentTimeDisplay.prototype.controlText_ = "Current Time";
- Component$1.registerComponent("CurrentTimeDisplay", CurrentTimeDisplay);
- var DurationDisplay = /* @__PURE__ */ function(_TimeDisplay) {
- _inheritsLoose(DurationDisplay2, _TimeDisplay);
- function DurationDisplay2(player, options2) {
- var _this;
- _this = _TimeDisplay.call(this, player, options2) || this;
- var updateContent = function updateContent2(e) {
- return _this.updateContent(e);
- };
- _this.on(player, "durationchange", updateContent);
- _this.on(player, "loadstart", updateContent);
- _this.on(player, "loadedmetadata", updateContent);
- return _this;
- }
- var _proto = DurationDisplay2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-duration";
- };
- _proto.updateContent = function updateContent(event2) {
- var duration5 = this.player_.duration();
- this.updateTextNode_(duration5);
- };
- return DurationDisplay2;
- }(TimeDisplay);
- DurationDisplay.prototype.labelText_ = "Duration";
- DurationDisplay.prototype.controlText_ = "Duration";
- Component$1.registerComponent("DurationDisplay", DurationDisplay);
- var TimeDivider = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(TimeDivider2, _Component);
- function TimeDivider2() {
- return _Component.apply(this, arguments) || this;
- }
- var _proto = TimeDivider2.prototype;
- _proto.createEl = function createEl2() {
- var el = _Component.prototype.createEl.call(this, "div", {
- className: "vjs-time-control vjs-time-divider"
- }, {
- "aria-hidden": true
- });
- var div = _Component.prototype.createEl.call(this, "div");
- var span = _Component.prototype.createEl.call(this, "span", {
- textContent: "/"
- });
- div.appendChild(span);
- el.appendChild(div);
- return el;
- };
- return TimeDivider2;
- }(Component$1);
- Component$1.registerComponent("TimeDivider", TimeDivider);
- var RemainingTimeDisplay = /* @__PURE__ */ function(_TimeDisplay) {
- _inheritsLoose(RemainingTimeDisplay2, _TimeDisplay);
- function RemainingTimeDisplay2(player, options2) {
- var _this;
- _this = _TimeDisplay.call(this, player, options2) || this;
- _this.on(player, "durationchange", function(e) {
- return _this.updateContent(e);
- });
- return _this;
- }
- var _proto = RemainingTimeDisplay2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-remaining-time";
- };
- _proto.createEl = function createEl$12() {
- var el = _TimeDisplay.prototype.createEl.call(this);
- if (this.options_.displayNegative !== false) {
- el.insertBefore(createEl("span", {}, {
- "aria-hidden": true
- }, "-"), this.contentEl_);
- }
- return el;
- };
- _proto.updateContent = function updateContent(event2) {
- if (typeof this.player_.duration() !== "number") {
- return;
- }
- var time;
- if (this.player_.ended()) {
- time = 0;
- } else if (this.player_.remainingTimeDisplay) {
- time = this.player_.remainingTimeDisplay();
- } else {
- time = this.player_.remainingTime();
- }
- this.updateTextNode_(time);
- };
- return RemainingTimeDisplay2;
- }(TimeDisplay);
- RemainingTimeDisplay.prototype.labelText_ = "Remaining Time";
- RemainingTimeDisplay.prototype.controlText_ = "Remaining Time";
- Component$1.registerComponent("RemainingTimeDisplay", RemainingTimeDisplay);
- var LiveDisplay = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(LiveDisplay2, _Component);
- function LiveDisplay2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- _this.updateShowing();
- _this.on(_this.player(), "durationchange", function(e) {
- return _this.updateShowing(e);
- });
- return _this;
- }
- var _proto = LiveDisplay2.prototype;
- _proto.createEl = function createEl$12() {
- var el = _Component.prototype.createEl.call(this, "div", {
- className: "vjs-live-control vjs-control"
- });
- this.contentEl_ = createEl("div", {
- className: "vjs-live-display"
- }, {
- "aria-live": "off"
- });
- this.contentEl_.appendChild(createEl("span", {
- className: "vjs-control-text",
- textContent: this.localize("Stream Type") + "\xA0"
- }));
- this.contentEl_.appendChild(document_1.createTextNode(this.localize("LIVE")));
- el.appendChild(this.contentEl_);
- return el;
- };
- _proto.dispose = function dispose() {
- this.contentEl_ = null;
- _Component.prototype.dispose.call(this);
- };
- _proto.updateShowing = function updateShowing(event2) {
- if (this.player().duration() === Infinity) {
- this.show();
- } else {
- this.hide();
- }
- };
- return LiveDisplay2;
- }(Component$1);
- Component$1.registerComponent("LiveDisplay", LiveDisplay);
- var SeekToLive = /* @__PURE__ */ function(_Button) {
- _inheritsLoose(SeekToLive2, _Button);
- function SeekToLive2(player, options2) {
- var _this;
- _this = _Button.call(this, player, options2) || this;
- _this.updateLiveEdgeStatus();
- if (_this.player_.liveTracker) {
- _this.updateLiveEdgeStatusHandler_ = function(e) {
- return _this.updateLiveEdgeStatus(e);
- };
- _this.on(_this.player_.liveTracker, "liveedgechange", _this.updateLiveEdgeStatusHandler_);
- }
- return _this;
- }
- var _proto = SeekToLive2.prototype;
- _proto.createEl = function createEl$12() {
- var el = _Button.prototype.createEl.call(this, "button", {
- className: "vjs-seek-to-live-control vjs-control"
- });
- this.textEl_ = createEl("span", {
- className: "vjs-seek-to-live-text",
- textContent: this.localize("LIVE")
- }, {
- "aria-hidden": "true"
- });
- el.appendChild(this.textEl_);
- return el;
- };
- _proto.updateLiveEdgeStatus = function updateLiveEdgeStatus() {
- if (!this.player_.liveTracker || this.player_.liveTracker.atLiveEdge()) {
- this.setAttribute("aria-disabled", true);
- this.addClass("vjs-at-live-edge");
- this.controlText("Seek to live, currently playing live");
- } else {
- this.setAttribute("aria-disabled", false);
- this.removeClass("vjs-at-live-edge");
- this.controlText("Seek to live, currently behind live");
- }
- };
- _proto.handleClick = function handleClick() {
- this.player_.liveTracker.seekToLiveEdge();
- };
- _proto.dispose = function dispose() {
- if (this.player_.liveTracker) {
- this.off(this.player_.liveTracker, "liveedgechange", this.updateLiveEdgeStatusHandler_);
- }
- this.textEl_ = null;
- _Button.prototype.dispose.call(this);
- };
- return SeekToLive2;
- }(Button);
- SeekToLive.prototype.controlText_ = "Seek to live, currently playing live";
- Component$1.registerComponent("SeekToLive", SeekToLive);
- var clamp = function clamp2(number, min2, max2) {
- number = Number(number);
- return Math.min(max2, Math.max(min2, isNaN(number) ? min2 : number));
- };
- var Slider = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(Slider2, _Component);
- function Slider2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- _this.handleMouseDown_ = function(e) {
- return _this.handleMouseDown(e);
- };
- _this.handleMouseUp_ = function(e) {
- return _this.handleMouseUp(e);
- };
- _this.handleKeyDown_ = function(e) {
- return _this.handleKeyDown(e);
- };
- _this.handleClick_ = function(e) {
- return _this.handleClick(e);
- };
- _this.handleMouseMove_ = function(e) {
- return _this.handleMouseMove(e);
- };
- _this.update_ = function(e) {
- return _this.update(e);
- };
- _this.bar = _this.getChild(_this.options_.barName);
- _this.vertical(!!_this.options_.vertical);
- _this.enable();
- return _this;
- }
- var _proto = Slider2.prototype;
- _proto.enabled = function enabled() {
- return this.enabled_;
- };
- _proto.enable = function enable() {
- if (this.enabled()) {
- return;
- }
- this.on("mousedown", this.handleMouseDown_);
- this.on("touchstart", this.handleMouseDown_);
- this.on("keydown", this.handleKeyDown_);
- this.on("click", this.handleClick_);
- this.on(this.player_, "controlsvisible", this.update);
- if (this.playerEvent) {
- this.on(this.player_, this.playerEvent, this.update);
- }
- this.removeClass("disabled");
- this.setAttribute("tabindex", 0);
- this.enabled_ = true;
- };
- _proto.disable = function disable() {
- if (!this.enabled()) {
- return;
- }
- var doc = this.bar.el_.ownerDocument;
- this.off("mousedown", this.handleMouseDown_);
- this.off("touchstart", this.handleMouseDown_);
- this.off("keydown", this.handleKeyDown_);
- this.off("click", this.handleClick_);
- this.off(this.player_, "controlsvisible", this.update_);
- this.off(doc, "mousemove", this.handleMouseMove_);
- this.off(doc, "mouseup", this.handleMouseUp_);
- this.off(doc, "touchmove", this.handleMouseMove_);
- this.off(doc, "touchend", this.handleMouseUp_);
- this.removeAttribute("tabindex");
- this.addClass("disabled");
- if (this.playerEvent) {
- this.off(this.player_, this.playerEvent, this.update);
- }
- this.enabled_ = false;
- };
- _proto.createEl = function createEl2(type2, props, attributes) {
- if (props === void 0) {
- props = {};
- }
- if (attributes === void 0) {
- attributes = {};
- }
- props.className = props.className + " vjs-slider";
- props = assign({
- tabIndex: 0
- }, props);
- attributes = assign({
- "role": "slider",
- "aria-valuenow": 0,
- "aria-valuemin": 0,
- "aria-valuemax": 100,
- "tabIndex": 0
- }, attributes);
- return _Component.prototype.createEl.call(this, type2, props, attributes);
- };
- _proto.handleMouseDown = function handleMouseDown(event2) {
- var doc = this.bar.el_.ownerDocument;
- if (event2.type === "mousedown") {
- event2.preventDefault();
- }
- if (event2.type === "touchstart" && !IS_CHROME) {
- event2.preventDefault();
- }
- blockTextSelection();
- this.addClass("vjs-sliding");
- this.trigger("slideractive");
- this.on(doc, "mousemove", this.handleMouseMove_);
- this.on(doc, "mouseup", this.handleMouseUp_);
- this.on(doc, "touchmove", this.handleMouseMove_);
- this.on(doc, "touchend", this.handleMouseUp_);
- this.handleMouseMove(event2, true);
- };
- _proto.handleMouseMove = function handleMouseMove(event2) {
- };
- _proto.handleMouseUp = function handleMouseUp() {
- var doc = this.bar.el_.ownerDocument;
- unblockTextSelection();
- this.removeClass("vjs-sliding");
- this.trigger("sliderinactive");
- this.off(doc, "mousemove", this.handleMouseMove_);
- this.off(doc, "mouseup", this.handleMouseUp_);
- this.off(doc, "touchmove", this.handleMouseMove_);
- this.off(doc, "touchend", this.handleMouseUp_);
- this.update();
- };
- _proto.update = function update() {
- var _this2 = this;
- if (!this.el_ || !this.bar) {
- return;
- }
- var progress = this.getProgress();
- if (progress === this.progress_) {
- return progress;
- }
- this.progress_ = progress;
- this.requestNamedAnimationFrame("Slider#update", function() {
- var sizeKey = _this2.vertical() ? "height" : "width";
- _this2.bar.el().style[sizeKey] = (progress * 100).toFixed(2) + "%";
- });
- return progress;
- };
- _proto.getProgress = function getProgress() {
- return Number(clamp(this.getPercent(), 0, 1).toFixed(4));
- };
- _proto.calculateDistance = function calculateDistance(event2) {
- var position2 = getPointerPosition(this.el_, event2);
- if (this.vertical()) {
- return position2.y;
- }
- return position2.x;
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Left") || keycode.isEventKey(event2, "Down")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.stepBack();
- } else if (keycode.isEventKey(event2, "Right") || keycode.isEventKey(event2, "Up")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.stepForward();
- } else {
- _Component.prototype.handleKeyDown.call(this, event2);
- }
- };
- _proto.handleClick = function handleClick(event2) {
- event2.stopPropagation();
- event2.preventDefault();
- };
- _proto.vertical = function vertical(bool) {
- if (bool === void 0) {
- return this.vertical_ || false;
- }
- this.vertical_ = !!bool;
- if (this.vertical_) {
- this.addClass("vjs-slider-vertical");
- } else {
- this.addClass("vjs-slider-horizontal");
- }
- };
- return Slider2;
- }(Component$1);
- Component$1.registerComponent("Slider", Slider);
- var percentify = function percentify2(time, end) {
- return clamp(time / end * 100, 0, 100).toFixed(2) + "%";
- };
- var LoadProgressBar = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(LoadProgressBar2, _Component);
- function LoadProgressBar2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- _this.partEls_ = [];
- _this.on(player, "progress", function(e) {
- return _this.update(e);
- });
- return _this;
- }
- var _proto = LoadProgressBar2.prototype;
- _proto.createEl = function createEl$12() {
- var el = _Component.prototype.createEl.call(this, "div", {
- className: "vjs-load-progress"
- });
- var wrapper = createEl("span", {
- className: "vjs-control-text"
- });
- var loadedText = createEl("span", {
- textContent: this.localize("Loaded")
- });
- var separator = document_1.createTextNode(": ");
- this.percentageEl_ = createEl("span", {
- className: "vjs-control-text-loaded-percentage",
- textContent: "0%"
- });
- el.appendChild(wrapper);
- wrapper.appendChild(loadedText);
- wrapper.appendChild(separator);
- wrapper.appendChild(this.percentageEl_);
- return el;
- };
- _proto.dispose = function dispose() {
- this.partEls_ = null;
- this.percentageEl_ = null;
- _Component.prototype.dispose.call(this);
- };
- _proto.update = function update(event2) {
- var _this2 = this;
- this.requestNamedAnimationFrame("LoadProgressBar#update", function() {
- var liveTracker = _this2.player_.liveTracker;
- var buffered = _this2.player_.buffered();
- var duration5 = liveTracker && liveTracker.isLive() ? liveTracker.seekableEnd() : _this2.player_.duration();
- var bufferedEnd = _this2.player_.bufferedEnd();
- var children = _this2.partEls_;
- var percent = percentify(bufferedEnd, duration5);
- if (_this2.percent_ !== percent) {
- _this2.el_.style.width = percent;
- textContent(_this2.percentageEl_, percent);
- _this2.percent_ = percent;
- }
- for (var i2 = 0; i2 < buffered.length; i2++) {
- var start2 = buffered.start(i2);
- var end = buffered.end(i2);
- var part = children[i2];
- if (!part) {
- part = _this2.el_.appendChild(createEl());
- children[i2] = part;
- }
- if (part.dataset.start === start2 && part.dataset.end === end) {
- continue;
- }
- part.dataset.start = start2;
- part.dataset.end = end;
- part.style.left = percentify(start2, bufferedEnd);
- part.style.width = percentify(end - start2, bufferedEnd);
- }
- for (var _i = children.length; _i > buffered.length; _i--) {
- _this2.el_.removeChild(children[_i - 1]);
- }
- children.length = buffered.length;
- });
- };
- return LoadProgressBar2;
- }(Component$1);
- Component$1.registerComponent("LoadProgressBar", LoadProgressBar);
- var TimeTooltip = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(TimeTooltip2, _Component);
- function TimeTooltip2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- _this.update = throttle(bind(_assertThisInitialized(_this), _this.update), UPDATE_REFRESH_INTERVAL);
- return _this;
- }
- var _proto = TimeTooltip2.prototype;
- _proto.createEl = function createEl2() {
- return _Component.prototype.createEl.call(this, "div", {
- className: "vjs-time-tooltip"
- }, {
- "aria-hidden": "true"
- });
- };
- _proto.update = function update(seekBarRect, seekBarPoint, content) {
- var tooltipRect = findPosition(this.el_);
- var playerRect = getBoundingClientRect(this.player_.el());
- var seekBarPointPx = seekBarRect.width * seekBarPoint;
- if (!playerRect || !tooltipRect) {
- return;
- }
- var spaceLeftOfPoint = seekBarRect.left - playerRect.left + seekBarPointPx;
- var spaceRightOfPoint = seekBarRect.width - seekBarPointPx + (playerRect.right - seekBarRect.right);
- var pullTooltipBy = tooltipRect.width / 2;
- if (spaceLeftOfPoint < pullTooltipBy) {
- pullTooltipBy += pullTooltipBy - spaceLeftOfPoint;
- } else if (spaceRightOfPoint < pullTooltipBy) {
- pullTooltipBy = spaceRightOfPoint;
- }
- if (pullTooltipBy < 0) {
- pullTooltipBy = 0;
- } else if (pullTooltipBy > tooltipRect.width) {
- pullTooltipBy = tooltipRect.width;
- }
- pullTooltipBy = Math.round(pullTooltipBy);
- this.el_.style.right = "-" + pullTooltipBy + "px";
- this.write(content);
- };
- _proto.write = function write(content) {
- textContent(this.el_, content);
- };
- _proto.updateTime = function updateTime(seekBarRect, seekBarPoint, time, cb) {
- var _this2 = this;
- this.requestNamedAnimationFrame("TimeTooltip#updateTime", function() {
- var content;
- var duration5 = _this2.player_.duration();
- if (_this2.player_.liveTracker && _this2.player_.liveTracker.isLive()) {
- var liveWindow = _this2.player_.liveTracker.liveWindow();
- var secondsBehind = liveWindow - seekBarPoint * liveWindow;
- content = (secondsBehind < 1 ? "" : "-") + formatTime(secondsBehind, liveWindow);
- } else {
- content = formatTime(time, duration5);
- }
- _this2.update(seekBarRect, seekBarPoint, content);
- if (cb) {
- cb();
- }
- });
- };
- return TimeTooltip2;
- }(Component$1);
- Component$1.registerComponent("TimeTooltip", TimeTooltip);
- var PlayProgressBar = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(PlayProgressBar2, _Component);
- function PlayProgressBar2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- _this.update = throttle(bind(_assertThisInitialized(_this), _this.update), UPDATE_REFRESH_INTERVAL);
- return _this;
- }
- var _proto = PlayProgressBar2.prototype;
- _proto.createEl = function createEl2() {
- return _Component.prototype.createEl.call(this, "div", {
- className: "vjs-play-progress vjs-slider-bar"
- }, {
- "aria-hidden": "true"
- });
- };
- _proto.update = function update(seekBarRect, seekBarPoint) {
- var timeTooltip = this.getChild("timeTooltip");
- if (!timeTooltip) {
- return;
- }
- var time = this.player_.scrubbing() ? this.player_.getCache().currentTime : this.player_.currentTime();
- timeTooltip.updateTime(seekBarRect, seekBarPoint, time);
- };
- return PlayProgressBar2;
- }(Component$1);
- PlayProgressBar.prototype.options_ = {
- children: []
- };
- if (!IS_IOS && !IS_ANDROID) {
- PlayProgressBar.prototype.options_.children.push("timeTooltip");
- }
- Component$1.registerComponent("PlayProgressBar", PlayProgressBar);
- var MouseTimeDisplay = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(MouseTimeDisplay2, _Component);
- function MouseTimeDisplay2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- _this.update = throttle(bind(_assertThisInitialized(_this), _this.update), UPDATE_REFRESH_INTERVAL);
- return _this;
- }
- var _proto = MouseTimeDisplay2.prototype;
- _proto.createEl = function createEl2() {
- return _Component.prototype.createEl.call(this, "div", {
- className: "vjs-mouse-display"
- });
- };
- _proto.update = function update(seekBarRect, seekBarPoint) {
- var _this2 = this;
- var time = seekBarPoint * this.player_.duration();
- this.getChild("timeTooltip").updateTime(seekBarRect, seekBarPoint, time, function() {
- _this2.el_.style.left = seekBarRect.width * seekBarPoint + "px";
- });
- };
- return MouseTimeDisplay2;
- }(Component$1);
- MouseTimeDisplay.prototype.options_ = {
- children: ["timeTooltip"]
- };
- Component$1.registerComponent("MouseTimeDisplay", MouseTimeDisplay);
- var STEP_SECONDS = 5;
- var PAGE_KEY_MULTIPLIER = 12;
- var SeekBar = /* @__PURE__ */ function(_Slider) {
- _inheritsLoose(SeekBar2, _Slider);
- function SeekBar2(player, options2) {
- var _this;
- _this = _Slider.call(this, player, options2) || this;
- _this.setEventHandlers_();
- return _this;
- }
- var _proto = SeekBar2.prototype;
- _proto.setEventHandlers_ = function setEventHandlers_() {
- var _this2 = this;
- this.update_ = bind(this, this.update);
- this.update = throttle(this.update_, UPDATE_REFRESH_INTERVAL);
- this.on(this.player_, ["ended", "durationchange", "timeupdate"], this.update);
- if (this.player_.liveTracker) {
- this.on(this.player_.liveTracker, "liveedgechange", this.update);
- }
- this.updateInterval = null;
- this.enableIntervalHandler_ = function(e) {
- return _this2.enableInterval_(e);
- };
- this.disableIntervalHandler_ = function(e) {
- return _this2.disableInterval_(e);
- };
- this.on(this.player_, ["playing"], this.enableIntervalHandler_);
- this.on(this.player_, ["ended", "pause", "waiting"], this.disableIntervalHandler_);
- if ("hidden" in document_1 && "visibilityState" in document_1) {
- this.on(document_1, "visibilitychange", this.toggleVisibility_);
- }
- };
- _proto.toggleVisibility_ = function toggleVisibility_(e) {
- if (document_1.visibilityState === "hidden") {
- this.cancelNamedAnimationFrame("SeekBar#update");
- this.cancelNamedAnimationFrame("Slider#update");
- this.disableInterval_(e);
- } else {
- if (!this.player_.ended() && !this.player_.paused()) {
- this.enableInterval_();
- }
- this.update();
- }
- };
- _proto.enableInterval_ = function enableInterval_() {
- if (this.updateInterval) {
- return;
- }
- this.updateInterval = this.setInterval(this.update, UPDATE_REFRESH_INTERVAL);
- };
- _proto.disableInterval_ = function disableInterval_(e) {
- if (this.player_.liveTracker && this.player_.liveTracker.isLive() && e && e.type !== "ended") {
- return;
- }
- if (!this.updateInterval) {
- return;
- }
- this.clearInterval(this.updateInterval);
- this.updateInterval = null;
- };
- _proto.createEl = function createEl2() {
- return _Slider.prototype.createEl.call(this, "div", {
- className: "vjs-progress-holder"
- }, {
- "aria-label": this.localize("Progress Bar")
- });
- };
- _proto.update = function update(event2) {
- var _this3 = this;
- if (document_1.visibilityState === "hidden") {
- return;
- }
- var percent = _Slider.prototype.update.call(this);
- this.requestNamedAnimationFrame("SeekBar#update", function() {
- var currentTime = _this3.player_.ended() ? _this3.player_.duration() : _this3.getCurrentTime_();
- var liveTracker = _this3.player_.liveTracker;
- var duration5 = _this3.player_.duration();
- if (liveTracker && liveTracker.isLive()) {
- duration5 = _this3.player_.liveTracker.liveCurrentTime();
- }
- if (_this3.percent_ !== percent) {
- _this3.el_.setAttribute("aria-valuenow", (percent * 100).toFixed(2));
- _this3.percent_ = percent;
- }
- if (_this3.currentTime_ !== currentTime || _this3.duration_ !== duration5) {
- _this3.el_.setAttribute("aria-valuetext", _this3.localize("progress bar timing: currentTime={1} duration={2}", [formatTime(currentTime, duration5), formatTime(duration5, duration5)], "{1} of {2}"));
- _this3.currentTime_ = currentTime;
- _this3.duration_ = duration5;
- }
- if (_this3.bar) {
- _this3.bar.update(getBoundingClientRect(_this3.el()), _this3.getProgress());
- }
- });
- return percent;
- };
- _proto.userSeek_ = function userSeek_(ct2) {
- if (this.player_.liveTracker && this.player_.liveTracker.isLive()) {
- this.player_.liveTracker.nextSeekedFromUser();
- }
- this.player_.currentTime(ct2);
- };
- _proto.getCurrentTime_ = function getCurrentTime_() {
- return this.player_.scrubbing() ? this.player_.getCache().currentTime : this.player_.currentTime();
- };
- _proto.getPercent = function getPercent() {
- var currentTime = this.getCurrentTime_();
- var percent;
- var liveTracker = this.player_.liveTracker;
- if (liveTracker && liveTracker.isLive()) {
- percent = (currentTime - liveTracker.seekableStart()) / liveTracker.liveWindow();
- if (liveTracker.atLiveEdge()) {
- percent = 1;
- }
- } else {
- percent = currentTime / this.player_.duration();
- }
- return percent;
- };
- _proto.handleMouseDown = function handleMouseDown(event2) {
- if (!isSingleLeftClick(event2)) {
- return;
- }
- event2.stopPropagation();
- this.videoWasPlaying = !this.player_.paused();
- this.player_.pause();
- _Slider.prototype.handleMouseDown.call(this, event2);
- };
- _proto.handleMouseMove = function handleMouseMove(event2, mouseDown) {
- if (mouseDown === void 0) {
- mouseDown = false;
- }
- if (!isSingleLeftClick(event2)) {
- return;
- }
- if (!mouseDown && !this.player_.scrubbing()) {
- this.player_.scrubbing(true);
- }
- var newTime;
- var distance2 = this.calculateDistance(event2);
- var liveTracker = this.player_.liveTracker;
- if (!liveTracker || !liveTracker.isLive()) {
- newTime = distance2 * this.player_.duration();
- if (newTime === this.player_.duration()) {
- newTime = newTime - 0.1;
- }
- } else {
- if (distance2 >= 0.99) {
- liveTracker.seekToLiveEdge();
- return;
- }
- var seekableStart = liveTracker.seekableStart();
- var seekableEnd = liveTracker.liveCurrentTime();
- newTime = seekableStart + distance2 * liveTracker.liveWindow();
- if (newTime >= seekableEnd) {
- newTime = seekableEnd;
- }
- if (newTime <= seekableStart) {
- newTime = seekableStart + 0.1;
- }
- if (newTime === Infinity) {
- return;
- }
- }
- this.userSeek_(newTime);
- };
- _proto.enable = function enable() {
- _Slider.prototype.enable.call(this);
- var mouseTimeDisplay = this.getChild("mouseTimeDisplay");
- if (!mouseTimeDisplay) {
- return;
- }
- mouseTimeDisplay.show();
- };
- _proto.disable = function disable() {
- _Slider.prototype.disable.call(this);
- var mouseTimeDisplay = this.getChild("mouseTimeDisplay");
- if (!mouseTimeDisplay) {
- return;
- }
- mouseTimeDisplay.hide();
- };
- _proto.handleMouseUp = function handleMouseUp(event2) {
- _Slider.prototype.handleMouseUp.call(this, event2);
- if (event2) {
- event2.stopPropagation();
- }
- this.player_.scrubbing(false);
- this.player_.trigger({
- type: "timeupdate",
- target: this,
- manuallyTriggered: true
- });
- if (this.videoWasPlaying) {
- silencePromise(this.player_.play());
- } else {
- this.update_();
- }
- };
- _proto.stepForward = function stepForward() {
- this.userSeek_(this.player_.currentTime() + STEP_SECONDS);
- };
- _proto.stepBack = function stepBack() {
- this.userSeek_(this.player_.currentTime() - STEP_SECONDS);
- };
- _proto.handleAction = function handleAction(event2) {
- if (this.player_.paused()) {
- this.player_.play();
- } else {
- this.player_.pause();
- }
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- var liveTracker = this.player_.liveTracker;
- if (keycode.isEventKey(event2, "Space") || keycode.isEventKey(event2, "Enter")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.handleAction(event2);
- } else if (keycode.isEventKey(event2, "Home")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.userSeek_(0);
- } else if (keycode.isEventKey(event2, "End")) {
- event2.preventDefault();
- event2.stopPropagation();
- if (liveTracker && liveTracker.isLive()) {
- this.userSeek_(liveTracker.liveCurrentTime());
- } else {
- this.userSeek_(this.player_.duration());
- }
- } else if (/^[0-9]$/.test(keycode(event2))) {
- event2.preventDefault();
- event2.stopPropagation();
- var gotoFraction = (keycode.codes[keycode(event2)] - keycode.codes["0"]) * 10 / 100;
- if (liveTracker && liveTracker.isLive()) {
- this.userSeek_(liveTracker.seekableStart() + liveTracker.liveWindow() * gotoFraction);
- } else {
- this.userSeek_(this.player_.duration() * gotoFraction);
- }
- } else if (keycode.isEventKey(event2, "PgDn")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.userSeek_(this.player_.currentTime() - STEP_SECONDS * PAGE_KEY_MULTIPLIER);
- } else if (keycode.isEventKey(event2, "PgUp")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.userSeek_(this.player_.currentTime() + STEP_SECONDS * PAGE_KEY_MULTIPLIER);
- } else {
- _Slider.prototype.handleKeyDown.call(this, event2);
- }
- };
- _proto.dispose = function dispose() {
- this.disableInterval_();
- this.off(this.player_, ["ended", "durationchange", "timeupdate"], this.update);
- if (this.player_.liveTracker) {
- this.off(this.player_.liveTracker, "liveedgechange", this.update);
- }
- this.off(this.player_, ["playing"], this.enableIntervalHandler_);
- this.off(this.player_, ["ended", "pause", "waiting"], this.disableIntervalHandler_);
- if ("hidden" in document_1 && "visibilityState" in document_1) {
- this.off(document_1, "visibilitychange", this.toggleVisibility_);
- }
- _Slider.prototype.dispose.call(this);
- };
- return SeekBar2;
- }(Slider);
- SeekBar.prototype.options_ = {
- children: ["loadProgressBar", "playProgressBar"],
- barName: "playProgressBar"
- };
- if (!IS_IOS && !IS_ANDROID) {
- SeekBar.prototype.options_.children.splice(1, 0, "mouseTimeDisplay");
- }
- Component$1.registerComponent("SeekBar", SeekBar);
- var ProgressControl = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(ProgressControl2, _Component);
- function ProgressControl2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- _this.handleMouseMove = throttle(bind(_assertThisInitialized(_this), _this.handleMouseMove), UPDATE_REFRESH_INTERVAL);
- _this.throttledHandleMouseSeek = throttle(bind(_assertThisInitialized(_this), _this.handleMouseSeek), UPDATE_REFRESH_INTERVAL);
- _this.handleMouseUpHandler_ = function(e) {
- return _this.handleMouseUp(e);
- };
- _this.handleMouseDownHandler_ = function(e) {
- return _this.handleMouseDown(e);
- };
- _this.enable();
- return _this;
- }
- var _proto = ProgressControl2.prototype;
- _proto.createEl = function createEl2() {
- return _Component.prototype.createEl.call(this, "div", {
- className: "vjs-progress-control vjs-control"
- });
- };
- _proto.handleMouseMove = function handleMouseMove(event2) {
- var seekBar = this.getChild("seekBar");
- if (!seekBar) {
- return;
- }
- var playProgressBar = seekBar.getChild("playProgressBar");
- var mouseTimeDisplay = seekBar.getChild("mouseTimeDisplay");
- if (!playProgressBar && !mouseTimeDisplay) {
- return;
- }
- var seekBarEl = seekBar.el();
- var seekBarRect = findPosition(seekBarEl);
- var seekBarPoint = getPointerPosition(seekBarEl, event2).x;
- seekBarPoint = clamp(seekBarPoint, 0, 1);
- if (mouseTimeDisplay) {
- mouseTimeDisplay.update(seekBarRect, seekBarPoint);
- }
- if (playProgressBar) {
- playProgressBar.update(seekBarRect, seekBar.getProgress());
- }
- };
- _proto.handleMouseSeek = function handleMouseSeek(event2) {
- var seekBar = this.getChild("seekBar");
- if (seekBar) {
- seekBar.handleMouseMove(event2);
- }
- };
- _proto.enabled = function enabled() {
- return this.enabled_;
- };
- _proto.disable = function disable() {
- this.children().forEach(function(child) {
- return child.disable && child.disable();
- });
- if (!this.enabled()) {
- return;
- }
- this.off(["mousedown", "touchstart"], this.handleMouseDownHandler_);
- this.off(this.el_, "mousemove", this.handleMouseMove);
- this.removeListenersAddedOnMousedownAndTouchstart();
- this.addClass("disabled");
- this.enabled_ = false;
- if (this.player_.scrubbing()) {
- var seekBar = this.getChild("seekBar");
- this.player_.scrubbing(false);
- if (seekBar.videoWasPlaying) {
- silencePromise(this.player_.play());
- }
- }
- };
- _proto.enable = function enable() {
- this.children().forEach(function(child) {
- return child.enable && child.enable();
- });
- if (this.enabled()) {
- return;
- }
- this.on(["mousedown", "touchstart"], this.handleMouseDownHandler_);
- this.on(this.el_, "mousemove", this.handleMouseMove);
- this.removeClass("disabled");
- this.enabled_ = true;
- };
- _proto.removeListenersAddedOnMousedownAndTouchstart = function removeListenersAddedOnMousedownAndTouchstart() {
- var doc = this.el_.ownerDocument;
- this.off(doc, "mousemove", this.throttledHandleMouseSeek);
- this.off(doc, "touchmove", this.throttledHandleMouseSeek);
- this.off(doc, "mouseup", this.handleMouseUpHandler_);
- this.off(doc, "touchend", this.handleMouseUpHandler_);
- };
- _proto.handleMouseDown = function handleMouseDown(event2) {
- var doc = this.el_.ownerDocument;
- var seekBar = this.getChild("seekBar");
- if (seekBar) {
- seekBar.handleMouseDown(event2);
- }
- this.on(doc, "mousemove", this.throttledHandleMouseSeek);
- this.on(doc, "touchmove", this.throttledHandleMouseSeek);
- this.on(doc, "mouseup", this.handleMouseUpHandler_);
- this.on(doc, "touchend", this.handleMouseUpHandler_);
- };
- _proto.handleMouseUp = function handleMouseUp(event2) {
- var seekBar = this.getChild("seekBar");
- if (seekBar) {
- seekBar.handleMouseUp(event2);
- }
- this.removeListenersAddedOnMousedownAndTouchstart();
- };
- return ProgressControl2;
- }(Component$1);
- ProgressControl.prototype.options_ = {
- children: ["seekBar"]
- };
- Component$1.registerComponent("ProgressControl", ProgressControl);
- var PictureInPictureToggle = /* @__PURE__ */ function(_Button) {
- _inheritsLoose(PictureInPictureToggle2, _Button);
- function PictureInPictureToggle2(player, options2) {
- var _this;
- _this = _Button.call(this, player, options2) || this;
- _this.on(player, ["enterpictureinpicture", "leavepictureinpicture"], function(e) {
- return _this.handlePictureInPictureChange(e);
- });
- _this.on(player, ["disablepictureinpicturechanged", "loadedmetadata"], function(e) {
- return _this.handlePictureInPictureEnabledChange(e);
- });
- _this.on(player, ["loadedmetadata", "audioonlymodechange", "audiopostermodechange"], function() {
- var isSourceAudio = player.currentType().substring(0, 5) === "audio";
- if (isSourceAudio || player.audioPosterMode() || player.audioOnlyMode()) {
- if (player.isInPictureInPicture()) {
- player.exitPictureInPicture();
- }
- _this.hide();
- } else {
- _this.show();
- }
- });
- _this.disable();
- return _this;
- }
- var _proto = PictureInPictureToggle2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-picture-in-picture-control " + _Button.prototype.buildCSSClass.call(this);
- };
- _proto.handlePictureInPictureEnabledChange = function handlePictureInPictureEnabledChange() {
- if (document_1.pictureInPictureEnabled && this.player_.disablePictureInPicture() === false) {
- this.enable();
- } else {
- this.disable();
- }
- };
- _proto.handlePictureInPictureChange = function handlePictureInPictureChange(event2) {
- if (this.player_.isInPictureInPicture()) {
- this.controlText("Exit Picture-in-Picture");
- } else {
- this.controlText("Picture-in-Picture");
- }
- this.handlePictureInPictureEnabledChange();
- };
- _proto.handleClick = function handleClick(event2) {
- if (!this.player_.isInPictureInPicture()) {
- this.player_.requestPictureInPicture();
- } else {
- this.player_.exitPictureInPicture();
- }
- };
- return PictureInPictureToggle2;
- }(Button);
- PictureInPictureToggle.prototype.controlText_ = "Picture-in-Picture";
- Component$1.registerComponent("PictureInPictureToggle", PictureInPictureToggle);
- var FullscreenToggle = /* @__PURE__ */ function(_Button) {
- _inheritsLoose(FullscreenToggle2, _Button);
- function FullscreenToggle2(player, options2) {
- var _this;
- _this = _Button.call(this, player, options2) || this;
- _this.on(player, "fullscreenchange", function(e) {
- return _this.handleFullscreenChange(e);
- });
- if (document_1[player.fsApi_.fullscreenEnabled] === false) {
- _this.disable();
- }
- return _this;
- }
- var _proto = FullscreenToggle2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-fullscreen-control " + _Button.prototype.buildCSSClass.call(this);
- };
- _proto.handleFullscreenChange = function handleFullscreenChange(event2) {
- if (this.player_.isFullscreen()) {
- this.controlText("Non-Fullscreen");
- } else {
- this.controlText("Fullscreen");
- }
- };
- _proto.handleClick = function handleClick(event2) {
- if (!this.player_.isFullscreen()) {
- this.player_.requestFullscreen();
- } else {
- this.player_.exitFullscreen();
- }
- };
- return FullscreenToggle2;
- }(Button);
- FullscreenToggle.prototype.controlText_ = "Fullscreen";
- Component$1.registerComponent("FullscreenToggle", FullscreenToggle);
- var checkVolumeSupport = function checkVolumeSupport2(self2, player) {
- if (player.tech_ && !player.tech_.featuresVolumeControl) {
- self2.addClass("vjs-hidden");
- }
- self2.on(player, "loadstart", function() {
- if (!player.tech_.featuresVolumeControl) {
- self2.addClass("vjs-hidden");
- } else {
- self2.removeClass("vjs-hidden");
- }
- });
- };
- var VolumeLevel = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(VolumeLevel2, _Component);
- function VolumeLevel2() {
- return _Component.apply(this, arguments) || this;
- }
- var _proto = VolumeLevel2.prototype;
- _proto.createEl = function createEl2() {
- var el = _Component.prototype.createEl.call(this, "div", {
- className: "vjs-volume-level"
- });
- el.appendChild(_Component.prototype.createEl.call(this, "span", {
- className: "vjs-control-text"
- }));
- return el;
- };
- return VolumeLevel2;
- }(Component$1);
- Component$1.registerComponent("VolumeLevel", VolumeLevel);
- var VolumeLevelTooltip = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(VolumeLevelTooltip2, _Component);
- function VolumeLevelTooltip2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- _this.update = throttle(bind(_assertThisInitialized(_this), _this.update), UPDATE_REFRESH_INTERVAL);
- return _this;
- }
- var _proto = VolumeLevelTooltip2.prototype;
- _proto.createEl = function createEl2() {
- return _Component.prototype.createEl.call(this, "div", {
- className: "vjs-volume-tooltip"
- }, {
- "aria-hidden": "true"
- });
- };
- _proto.update = function update(rangeBarRect, rangeBarPoint, vertical, content) {
- if (!vertical) {
- var tooltipRect = getBoundingClientRect(this.el_);
- var playerRect = getBoundingClientRect(this.player_.el());
- var volumeBarPointPx = rangeBarRect.width * rangeBarPoint;
- if (!playerRect || !tooltipRect) {
- return;
- }
- var spaceLeftOfPoint = rangeBarRect.left - playerRect.left + volumeBarPointPx;
- var spaceRightOfPoint = rangeBarRect.width - volumeBarPointPx + (playerRect.right - rangeBarRect.right);
- var pullTooltipBy = tooltipRect.width / 2;
- if (spaceLeftOfPoint < pullTooltipBy) {
- pullTooltipBy += pullTooltipBy - spaceLeftOfPoint;
- } else if (spaceRightOfPoint < pullTooltipBy) {
- pullTooltipBy = spaceRightOfPoint;
- }
- if (pullTooltipBy < 0) {
- pullTooltipBy = 0;
- } else if (pullTooltipBy > tooltipRect.width) {
- pullTooltipBy = tooltipRect.width;
- }
- this.el_.style.right = "-" + pullTooltipBy + "px";
- }
- this.write(content + "%");
- };
- _proto.write = function write(content) {
- textContent(this.el_, content);
- };
- _proto.updateVolume = function updateVolume(rangeBarRect, rangeBarPoint, vertical, volume, cb) {
- var _this2 = this;
- this.requestNamedAnimationFrame("VolumeLevelTooltip#updateVolume", function() {
- _this2.update(rangeBarRect, rangeBarPoint, vertical, volume.toFixed(0));
- if (cb) {
- cb();
- }
- });
- };
- return VolumeLevelTooltip2;
- }(Component$1);
- Component$1.registerComponent("VolumeLevelTooltip", VolumeLevelTooltip);
- var MouseVolumeLevelDisplay = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(MouseVolumeLevelDisplay2, _Component);
- function MouseVolumeLevelDisplay2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- _this.update = throttle(bind(_assertThisInitialized(_this), _this.update), UPDATE_REFRESH_INTERVAL);
- return _this;
- }
- var _proto = MouseVolumeLevelDisplay2.prototype;
- _proto.createEl = function createEl2() {
- return _Component.prototype.createEl.call(this, "div", {
- className: "vjs-mouse-display"
- });
- };
- _proto.update = function update(rangeBarRect, rangeBarPoint, vertical) {
- var _this2 = this;
- var volume = 100 * rangeBarPoint;
- this.getChild("volumeLevelTooltip").updateVolume(rangeBarRect, rangeBarPoint, vertical, volume, function() {
- if (vertical) {
- _this2.el_.style.bottom = rangeBarRect.height * rangeBarPoint + "px";
- } else {
- _this2.el_.style.left = rangeBarRect.width * rangeBarPoint + "px";
- }
- });
- };
- return MouseVolumeLevelDisplay2;
- }(Component$1);
- MouseVolumeLevelDisplay.prototype.options_ = {
- children: ["volumeLevelTooltip"]
- };
- Component$1.registerComponent("MouseVolumeLevelDisplay", MouseVolumeLevelDisplay);
- var VolumeBar = /* @__PURE__ */ function(_Slider) {
- _inheritsLoose(VolumeBar2, _Slider);
- function VolumeBar2(player, options2) {
- var _this;
- _this = _Slider.call(this, player, options2) || this;
- _this.on("slideractive", function(e) {
- return _this.updateLastVolume_(e);
- });
- _this.on(player, "volumechange", function(e) {
- return _this.updateARIAAttributes(e);
- });
- player.ready(function() {
- return _this.updateARIAAttributes();
- });
- return _this;
- }
- var _proto = VolumeBar2.prototype;
- _proto.createEl = function createEl2() {
- return _Slider.prototype.createEl.call(this, "div", {
- className: "vjs-volume-bar vjs-slider-bar"
- }, {
- "aria-label": this.localize("Volume Level"),
- "aria-live": "polite"
- });
- };
- _proto.handleMouseDown = function handleMouseDown(event2) {
- if (!isSingleLeftClick(event2)) {
- return;
- }
- _Slider.prototype.handleMouseDown.call(this, event2);
- };
- _proto.handleMouseMove = function handleMouseMove(event2) {
- var mouseVolumeLevelDisplay = this.getChild("mouseVolumeLevelDisplay");
- if (mouseVolumeLevelDisplay) {
- var volumeBarEl = this.el();
- var volumeBarRect = getBoundingClientRect(volumeBarEl);
- var vertical = this.vertical();
- var volumeBarPoint = getPointerPosition(volumeBarEl, event2);
- volumeBarPoint = vertical ? volumeBarPoint.y : volumeBarPoint.x;
- volumeBarPoint = clamp(volumeBarPoint, 0, 1);
- mouseVolumeLevelDisplay.update(volumeBarRect, volumeBarPoint, vertical);
- }
- if (!isSingleLeftClick(event2)) {
- return;
- }
- this.checkMuted();
- this.player_.volume(this.calculateDistance(event2));
- };
- _proto.checkMuted = function checkMuted() {
- if (this.player_.muted()) {
- this.player_.muted(false);
- }
- };
- _proto.getPercent = function getPercent() {
- if (this.player_.muted()) {
- return 0;
- }
- return this.player_.volume();
- };
- _proto.stepForward = function stepForward() {
- this.checkMuted();
- this.player_.volume(this.player_.volume() + 0.1);
- };
- _proto.stepBack = function stepBack() {
- this.checkMuted();
- this.player_.volume(this.player_.volume() - 0.1);
- };
- _proto.updateARIAAttributes = function updateARIAAttributes(event2) {
- var ariaValue = this.player_.muted() ? 0 : this.volumeAsPercentage_();
- this.el_.setAttribute("aria-valuenow", ariaValue);
- this.el_.setAttribute("aria-valuetext", ariaValue + "%");
- };
- _proto.volumeAsPercentage_ = function volumeAsPercentage_() {
- return Math.round(this.player_.volume() * 100);
- };
- _proto.updateLastVolume_ = function updateLastVolume_() {
- var _this2 = this;
- var volumeBeforeDrag = this.player_.volume();
- this.one("sliderinactive", function() {
- if (_this2.player_.volume() === 0) {
- _this2.player_.lastVolume_(volumeBeforeDrag);
- }
- });
- };
- return VolumeBar2;
- }(Slider);
- VolumeBar.prototype.options_ = {
- children: ["volumeLevel"],
- barName: "volumeLevel"
- };
- if (!IS_IOS && !IS_ANDROID) {
- VolumeBar.prototype.options_.children.splice(0, 0, "mouseVolumeLevelDisplay");
- }
- VolumeBar.prototype.playerEvent = "volumechange";
- Component$1.registerComponent("VolumeBar", VolumeBar);
- var VolumeControl = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(VolumeControl2, _Component);
- function VolumeControl2(player, options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- options2.vertical = options2.vertical || false;
- if (typeof options2.volumeBar === "undefined" || isPlain(options2.volumeBar)) {
- options2.volumeBar = options2.volumeBar || {};
- options2.volumeBar.vertical = options2.vertical;
- }
- _this = _Component.call(this, player, options2) || this;
- checkVolumeSupport(_assertThisInitialized(_this), player);
- _this.throttledHandleMouseMove = throttle(bind(_assertThisInitialized(_this), _this.handleMouseMove), UPDATE_REFRESH_INTERVAL);
- _this.handleMouseUpHandler_ = function(e) {
- return _this.handleMouseUp(e);
- };
- _this.on("mousedown", function(e) {
- return _this.handleMouseDown(e);
- });
- _this.on("touchstart", function(e) {
- return _this.handleMouseDown(e);
- });
- _this.on("mousemove", function(e) {
- return _this.handleMouseMove(e);
- });
- _this.on(_this.volumeBar, ["focus", "slideractive"], function() {
- _this.volumeBar.addClass("vjs-slider-active");
- _this.addClass("vjs-slider-active");
- _this.trigger("slideractive");
- });
- _this.on(_this.volumeBar, ["blur", "sliderinactive"], function() {
- _this.volumeBar.removeClass("vjs-slider-active");
- _this.removeClass("vjs-slider-active");
- _this.trigger("sliderinactive");
- });
- return _this;
- }
- var _proto = VolumeControl2.prototype;
- _proto.createEl = function createEl2() {
- var orientationClass = "vjs-volume-horizontal";
- if (this.options_.vertical) {
- orientationClass = "vjs-volume-vertical";
- }
- return _Component.prototype.createEl.call(this, "div", {
- className: "vjs-volume-control vjs-control " + orientationClass
- });
- };
- _proto.handleMouseDown = function handleMouseDown(event2) {
- var doc = this.el_.ownerDocument;
- this.on(doc, "mousemove", this.throttledHandleMouseMove);
- this.on(doc, "touchmove", this.throttledHandleMouseMove);
- this.on(doc, "mouseup", this.handleMouseUpHandler_);
- this.on(doc, "touchend", this.handleMouseUpHandler_);
- };
- _proto.handleMouseUp = function handleMouseUp(event2) {
- var doc = this.el_.ownerDocument;
- this.off(doc, "mousemove", this.throttledHandleMouseMove);
- this.off(doc, "touchmove", this.throttledHandleMouseMove);
- this.off(doc, "mouseup", this.handleMouseUpHandler_);
- this.off(doc, "touchend", this.handleMouseUpHandler_);
- };
- _proto.handleMouseMove = function handleMouseMove(event2) {
- this.volumeBar.handleMouseMove(event2);
- };
- return VolumeControl2;
- }(Component$1);
- VolumeControl.prototype.options_ = {
- children: ["volumeBar"]
- };
- Component$1.registerComponent("VolumeControl", VolumeControl);
- var checkMuteSupport = function checkMuteSupport2(self2, player) {
- if (player.tech_ && !player.tech_.featuresMuteControl) {
- self2.addClass("vjs-hidden");
- }
- self2.on(player, "loadstart", function() {
- if (!player.tech_.featuresMuteControl) {
- self2.addClass("vjs-hidden");
- } else {
- self2.removeClass("vjs-hidden");
- }
- });
- };
- var MuteToggle = /* @__PURE__ */ function(_Button) {
- _inheritsLoose(MuteToggle2, _Button);
- function MuteToggle2(player, options2) {
- var _this;
- _this = _Button.call(this, player, options2) || this;
- checkMuteSupport(_assertThisInitialized(_this), player);
- _this.on(player, ["loadstart", "volumechange"], function(e) {
- return _this.update(e);
- });
- return _this;
- }
- var _proto = MuteToggle2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-mute-control " + _Button.prototype.buildCSSClass.call(this);
- };
- _proto.handleClick = function handleClick(event2) {
- var vol = this.player_.volume();
- var lastVolume = this.player_.lastVolume_();
- if (vol === 0) {
- var volumeToSet = lastVolume < 0.1 ? 0.1 : lastVolume;
- this.player_.volume(volumeToSet);
- this.player_.muted(false);
- } else {
- this.player_.muted(this.player_.muted() ? false : true);
- }
- };
- _proto.update = function update(event2) {
- this.updateIcon_();
- this.updateControlText_();
- };
- _proto.updateIcon_ = function updateIcon_() {
- var vol = this.player_.volume();
- var level = 3;
- if (IS_IOS && this.player_.tech_ && this.player_.tech_.el_) {
- this.player_.muted(this.player_.tech_.el_.muted);
- }
- if (vol === 0 || this.player_.muted()) {
- level = 0;
- } else if (vol < 0.33) {
- level = 1;
- } else if (vol < 0.67) {
- level = 2;
- }
- for (var i2 = 0; i2 < 4; i2++) {
- removeClass(this.el_, "vjs-vol-" + i2);
- }
- addClass(this.el_, "vjs-vol-" + level);
- };
- _proto.updateControlText_ = function updateControlText_() {
- var soundOff = this.player_.muted() || this.player_.volume() === 0;
- var text = soundOff ? "Unmute" : "Mute";
- if (this.controlText() !== text) {
- this.controlText(text);
- }
- };
- return MuteToggle2;
- }(Button);
- MuteToggle.prototype.controlText_ = "Mute";
- Component$1.registerComponent("MuteToggle", MuteToggle);
- var VolumePanel = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(VolumePanel2, _Component);
- function VolumePanel2(player, options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- if (typeof options2.inline !== "undefined") {
- options2.inline = options2.inline;
- } else {
- options2.inline = true;
- }
- if (typeof options2.volumeControl === "undefined" || isPlain(options2.volumeControl)) {
- options2.volumeControl = options2.volumeControl || {};
- options2.volumeControl.vertical = !options2.inline;
- }
- _this = _Component.call(this, player, options2) || this;
- _this.handleKeyPressHandler_ = function(e) {
- return _this.handleKeyPress(e);
- };
- _this.on(player, ["loadstart"], function(e) {
- return _this.volumePanelState_(e);
- });
- _this.on(_this.muteToggle, "keyup", function(e) {
- return _this.handleKeyPress(e);
- });
- _this.on(_this.volumeControl, "keyup", function(e) {
- return _this.handleVolumeControlKeyUp(e);
- });
- _this.on("keydown", function(e) {
- return _this.handleKeyPress(e);
- });
- _this.on("mouseover", function(e) {
- return _this.handleMouseOver(e);
- });
- _this.on("mouseout", function(e) {
- return _this.handleMouseOut(e);
- });
- _this.on(_this.volumeControl, ["slideractive"], _this.sliderActive_);
- _this.on(_this.volumeControl, ["sliderinactive"], _this.sliderInactive_);
- return _this;
- }
- var _proto = VolumePanel2.prototype;
- _proto.sliderActive_ = function sliderActive_() {
- this.addClass("vjs-slider-active");
- };
- _proto.sliderInactive_ = function sliderInactive_() {
- this.removeClass("vjs-slider-active");
- };
- _proto.volumePanelState_ = function volumePanelState_() {
- if (this.volumeControl.hasClass("vjs-hidden") && this.muteToggle.hasClass("vjs-hidden")) {
- this.addClass("vjs-hidden");
- }
- if (this.volumeControl.hasClass("vjs-hidden") && !this.muteToggle.hasClass("vjs-hidden")) {
- this.addClass("vjs-mute-toggle-only");
- }
- };
- _proto.createEl = function createEl2() {
- var orientationClass = "vjs-volume-panel-horizontal";
- if (!this.options_.inline) {
- orientationClass = "vjs-volume-panel-vertical";
- }
- return _Component.prototype.createEl.call(this, "div", {
- className: "vjs-volume-panel vjs-control " + orientationClass
- });
- };
- _proto.dispose = function dispose() {
- this.handleMouseOut();
- _Component.prototype.dispose.call(this);
- };
- _proto.handleVolumeControlKeyUp = function handleVolumeControlKeyUp(event2) {
- if (keycode.isEventKey(event2, "Esc")) {
- this.muteToggle.focus();
- }
- };
- _proto.handleMouseOver = function handleMouseOver(event2) {
- this.addClass("vjs-hover");
- on(document_1, "keyup", this.handleKeyPressHandler_);
- };
- _proto.handleMouseOut = function handleMouseOut(event2) {
- this.removeClass("vjs-hover");
- off(document_1, "keyup", this.handleKeyPressHandler_);
- };
- _proto.handleKeyPress = function handleKeyPress(event2) {
- if (keycode.isEventKey(event2, "Esc")) {
- this.handleMouseOut();
- }
- };
- return VolumePanel2;
- }(Component$1);
- VolumePanel.prototype.options_ = {
- children: ["muteToggle", "volumeControl"]
- };
- Component$1.registerComponent("VolumePanel", VolumePanel);
- var Menu = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(Menu2, _Component);
- function Menu2(player, options2) {
- var _this;
- _this = _Component.call(this, player, options2) || this;
- if (options2) {
- _this.menuButton_ = options2.menuButton;
- }
- _this.focusedChild_ = -1;
- _this.on("keydown", function(e) {
- return _this.handleKeyDown(e);
- });
- _this.boundHandleBlur_ = function(e) {
- return _this.handleBlur(e);
- };
- _this.boundHandleTapClick_ = function(e) {
- return _this.handleTapClick(e);
- };
- return _this;
- }
- var _proto = Menu2.prototype;
- _proto.addEventListenerForItem = function addEventListenerForItem(component) {
- if (!(component instanceof Component$1)) {
- return;
- }
- this.on(component, "blur", this.boundHandleBlur_);
- this.on(component, ["tap", "click"], this.boundHandleTapClick_);
- };
- _proto.removeEventListenerForItem = function removeEventListenerForItem(component) {
- if (!(component instanceof Component$1)) {
- return;
- }
- this.off(component, "blur", this.boundHandleBlur_);
- this.off(component, ["tap", "click"], this.boundHandleTapClick_);
- };
- _proto.removeChild = function removeChild(component) {
- if (typeof component === "string") {
- component = this.getChild(component);
- }
- this.removeEventListenerForItem(component);
- _Component.prototype.removeChild.call(this, component);
- };
- _proto.addItem = function addItem(component) {
- var childComponent = this.addChild(component);
- if (childComponent) {
- this.addEventListenerForItem(childComponent);
- }
- };
- _proto.createEl = function createEl$12() {
- var contentElType = this.options_.contentElType || "ul";
- this.contentEl_ = createEl(contentElType, {
- className: "vjs-menu-content"
- });
- this.contentEl_.setAttribute("role", "menu");
- var el = _Component.prototype.createEl.call(this, "div", {
- append: this.contentEl_,
- className: "vjs-menu"
- });
- el.appendChild(this.contentEl_);
- on(el, "click", function(event2) {
- event2.preventDefault();
- event2.stopImmediatePropagation();
- });
- return el;
- };
- _proto.dispose = function dispose() {
- this.contentEl_ = null;
- this.boundHandleBlur_ = null;
- this.boundHandleTapClick_ = null;
- _Component.prototype.dispose.call(this);
- };
- _proto.handleBlur = function handleBlur(event2) {
- var relatedTarget = event2.relatedTarget || document_1.activeElement;
- if (!this.children().some(function(element) {
- return element.el() === relatedTarget;
- })) {
- var btn = this.menuButton_;
- if (btn && btn.buttonPressed_ && relatedTarget !== btn.el().firstChild) {
- btn.unpressButton();
- }
- }
- };
- _proto.handleTapClick = function handleTapClick(event2) {
- if (this.menuButton_) {
- this.menuButton_.unpressButton();
- var childComponents = this.children();
- if (!Array.isArray(childComponents)) {
- return;
- }
- var foundComponent = childComponents.filter(function(component) {
- return component.el() === event2.target;
- })[0];
- if (!foundComponent) {
- return;
- }
- if (foundComponent.name() !== "CaptionSettingsMenuItem") {
- this.menuButton_.focus();
- }
- }
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Left") || keycode.isEventKey(event2, "Down")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.stepForward();
- } else if (keycode.isEventKey(event2, "Right") || keycode.isEventKey(event2, "Up")) {
- event2.preventDefault();
- event2.stopPropagation();
- this.stepBack();
- }
- };
- _proto.stepForward = function stepForward() {
- var stepChild = 0;
- if (this.focusedChild_ !== void 0) {
- stepChild = this.focusedChild_ + 1;
- }
- this.focus(stepChild);
- };
- _proto.stepBack = function stepBack() {
- var stepChild = 0;
- if (this.focusedChild_ !== void 0) {
- stepChild = this.focusedChild_ - 1;
- }
- this.focus(stepChild);
- };
- _proto.focus = function focus(item) {
- if (item === void 0) {
- item = 0;
- }
- var children = this.children().slice();
- var haveTitle = children.length && children[0].hasClass("vjs-menu-title");
- if (haveTitle) {
- children.shift();
- }
- if (children.length > 0) {
- if (item < 0) {
- item = 0;
- } else if (item >= children.length) {
- item = children.length - 1;
- }
- this.focusedChild_ = item;
- children[item].el_.focus();
- }
- };
- return Menu2;
- }(Component$1);
- Component$1.registerComponent("Menu", Menu);
- var MenuButton = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(MenuButton2, _Component);
- function MenuButton2(player, options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- _this = _Component.call(this, player, options2) || this;
- _this.menuButton_ = new Button(player, options2);
- _this.menuButton_.controlText(_this.controlText_);
- _this.menuButton_.el_.setAttribute("aria-haspopup", "true");
- var buttonClass = Button.prototype.buildCSSClass();
- _this.menuButton_.el_.className = _this.buildCSSClass() + " " + buttonClass;
- _this.menuButton_.removeClass("vjs-control");
- _this.addChild(_this.menuButton_);
- _this.update();
- _this.enabled_ = true;
- var handleClick = function handleClick2(e) {
- return _this.handleClick(e);
- };
- _this.handleMenuKeyUp_ = function(e) {
- return _this.handleMenuKeyUp(e);
- };
- _this.on(_this.menuButton_, "tap", handleClick);
- _this.on(_this.menuButton_, "click", handleClick);
- _this.on(_this.menuButton_, "keydown", function(e) {
- return _this.handleKeyDown(e);
- });
- _this.on(_this.menuButton_, "mouseenter", function() {
- _this.addClass("vjs-hover");
- _this.menu.show();
- on(document_1, "keyup", _this.handleMenuKeyUp_);
- });
- _this.on("mouseleave", function(e) {
- return _this.handleMouseLeave(e);
- });
- _this.on("keydown", function(e) {
- return _this.handleSubmenuKeyDown(e);
- });
- return _this;
- }
- var _proto = MenuButton2.prototype;
- _proto.update = function update() {
- var menu = this.createMenu();
- if (this.menu) {
- this.menu.dispose();
- this.removeChild(this.menu);
- }
- this.menu = menu;
- this.addChild(menu);
- this.buttonPressed_ = false;
- this.menuButton_.el_.setAttribute("aria-expanded", "false");
- if (this.items && this.items.length <= this.hideThreshold_) {
- this.hide();
- this.menu.contentEl_.removeAttribute("role");
- } else {
- this.show();
- this.menu.contentEl_.setAttribute("role", "menu");
- }
- };
- _proto.createMenu = function createMenu() {
- var menu = new Menu(this.player_, {
- menuButton: this
- });
- this.hideThreshold_ = 0;
- if (this.options_.title) {
- var titleEl = createEl("li", {
- className: "vjs-menu-title",
- textContent: toTitleCase$1(this.options_.title),
- tabIndex: -1
- });
- var titleComponent = new Component$1(this.player_, {
- el: titleEl
- });
- menu.addItem(titleComponent);
- }
- this.items = this.createItems();
- if (this.items) {
- for (var i2 = 0; i2 < this.items.length; i2++) {
- menu.addItem(this.items[i2]);
- }
- }
- return menu;
- };
- _proto.createItems = function createItems() {
- };
- _proto.createEl = function createEl2() {
- return _Component.prototype.createEl.call(this, "div", {
- className: this.buildWrapperCSSClass()
- }, {});
- };
- _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {
- var menuButtonClass = "vjs-menu-button";
- if (this.options_.inline === true) {
- menuButtonClass += "-inline";
- } else {
- menuButtonClass += "-popup";
- }
- var buttonClass = Button.prototype.buildCSSClass();
- return "vjs-menu-button " + menuButtonClass + " " + buttonClass + " " + _Component.prototype.buildCSSClass.call(this);
- };
- _proto.buildCSSClass = function buildCSSClass() {
- var menuButtonClass = "vjs-menu-button";
- if (this.options_.inline === true) {
- menuButtonClass += "-inline";
- } else {
- menuButtonClass += "-popup";
- }
- return "vjs-menu-button " + menuButtonClass + " " + _Component.prototype.buildCSSClass.call(this);
- };
- _proto.controlText = function controlText(text, el) {
- if (el === void 0) {
- el = this.menuButton_.el();
- }
- return this.menuButton_.controlText(text, el);
- };
- _proto.dispose = function dispose() {
- this.handleMouseLeave();
- _Component.prototype.dispose.call(this);
- };
- _proto.handleClick = function handleClick(event2) {
- if (this.buttonPressed_) {
- this.unpressButton();
- } else {
- this.pressButton();
- }
- };
- _proto.handleMouseLeave = function handleMouseLeave(event2) {
- this.removeClass("vjs-hover");
- off(document_1, "keyup", this.handleMenuKeyUp_);
- };
- _proto.focus = function focus() {
- this.menuButton_.focus();
- };
- _proto.blur = function blur() {
- this.menuButton_.blur();
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- if (keycode.isEventKey(event2, "Esc") || keycode.isEventKey(event2, "Tab")) {
- if (this.buttonPressed_) {
- this.unpressButton();
- }
- if (!keycode.isEventKey(event2, "Tab")) {
- event2.preventDefault();
- this.menuButton_.focus();
- }
- } else if (keycode.isEventKey(event2, "Up") || keycode.isEventKey(event2, "Down")) {
- if (!this.buttonPressed_) {
- event2.preventDefault();
- this.pressButton();
- }
- }
- };
- _proto.handleMenuKeyUp = function handleMenuKeyUp(event2) {
- if (keycode.isEventKey(event2, "Esc") || keycode.isEventKey(event2, "Tab")) {
- this.removeClass("vjs-hover");
- }
- };
- _proto.handleSubmenuKeyPress = function handleSubmenuKeyPress(event2) {
- this.handleSubmenuKeyDown(event2);
- };
- _proto.handleSubmenuKeyDown = function handleSubmenuKeyDown(event2) {
- if (keycode.isEventKey(event2, "Esc") || keycode.isEventKey(event2, "Tab")) {
- if (this.buttonPressed_) {
- this.unpressButton();
- }
- if (!keycode.isEventKey(event2, "Tab")) {
- event2.preventDefault();
- this.menuButton_.focus();
- }
- }
- };
- _proto.pressButton = function pressButton() {
- if (this.enabled_) {
- this.buttonPressed_ = true;
- this.menu.show();
- this.menu.lockShowing();
- this.menuButton_.el_.setAttribute("aria-expanded", "true");
- if (IS_IOS && isInFrame()) {
- return;
- }
- this.menu.focus();
- }
- };
- _proto.unpressButton = function unpressButton() {
- if (this.enabled_) {
- this.buttonPressed_ = false;
- this.menu.unlockShowing();
- this.menu.hide();
- this.menuButton_.el_.setAttribute("aria-expanded", "false");
- }
- };
- _proto.disable = function disable() {
- this.unpressButton();
- this.enabled_ = false;
- this.addClass("vjs-disabled");
- this.menuButton_.disable();
- };
- _proto.enable = function enable() {
- this.enabled_ = true;
- this.removeClass("vjs-disabled");
- this.menuButton_.enable();
- };
- return MenuButton2;
- }(Component$1);
- Component$1.registerComponent("MenuButton", MenuButton);
- var TrackButton = /* @__PURE__ */ function(_MenuButton) {
- _inheritsLoose(TrackButton2, _MenuButton);
- function TrackButton2(player, options2) {
- var _this;
- var tracks = options2.tracks;
- _this = _MenuButton.call(this, player, options2) || this;
- if (_this.items.length <= 1) {
- _this.hide();
- }
- if (!tracks) {
- return _assertThisInitialized(_this);
- }
- var updateHandler = bind(_assertThisInitialized(_this), _this.update);
- tracks.addEventListener("removetrack", updateHandler);
- tracks.addEventListener("addtrack", updateHandler);
- tracks.addEventListener("labelchange", updateHandler);
- _this.player_.on("ready", updateHandler);
- _this.player_.on("dispose", function() {
- tracks.removeEventListener("removetrack", updateHandler);
- tracks.removeEventListener("addtrack", updateHandler);
- tracks.removeEventListener("labelchange", updateHandler);
- });
- return _this;
- }
- return TrackButton2;
- }(MenuButton);
- Component$1.registerComponent("TrackButton", TrackButton);
- var MenuKeys = ["Tab", "Esc", "Up", "Down", "Right", "Left"];
- var MenuItem = /* @__PURE__ */ function(_ClickableComponent) {
- _inheritsLoose(MenuItem2, _ClickableComponent);
- function MenuItem2(player, options2) {
- var _this;
- _this = _ClickableComponent.call(this, player, options2) || this;
- _this.selectable = options2.selectable;
- _this.isSelected_ = options2.selected || false;
- _this.multiSelectable = options2.multiSelectable;
- _this.selected(_this.isSelected_);
- if (_this.selectable) {
- if (_this.multiSelectable) {
- _this.el_.setAttribute("role", "menuitemcheckbox");
- } else {
- _this.el_.setAttribute("role", "menuitemradio");
- }
- } else {
- _this.el_.setAttribute("role", "menuitem");
- }
- return _this;
- }
- var _proto = MenuItem2.prototype;
- _proto.createEl = function createEl$12(type2, props, attrs) {
- this.nonIconControl = true;
- var el = _ClickableComponent.prototype.createEl.call(this, "li", assign({
- className: "vjs-menu-item",
- tabIndex: -1
- }, props), attrs);
- el.replaceChild(createEl("span", {
- className: "vjs-menu-item-text",
- textContent: this.localize(this.options_.label)
- }), el.querySelector(".vjs-icon-placeholder"));
- return el;
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- if (!MenuKeys.some(function(key) {
- return keycode.isEventKey(event2, key);
- })) {
- _ClickableComponent.prototype.handleKeyDown.call(this, event2);
- }
- };
- _proto.handleClick = function handleClick(event2) {
- this.selected(true);
- };
- _proto.selected = function selected(_selected) {
- if (this.selectable) {
- if (_selected) {
- this.addClass("vjs-selected");
- this.el_.setAttribute("aria-checked", "true");
- this.controlText(", selected");
- this.isSelected_ = true;
- } else {
- this.removeClass("vjs-selected");
- this.el_.setAttribute("aria-checked", "false");
- this.controlText("");
- this.isSelected_ = false;
- }
- }
- };
- return MenuItem2;
- }(ClickableComponent);
- Component$1.registerComponent("MenuItem", MenuItem);
- var TextTrackMenuItem = /* @__PURE__ */ function(_MenuItem) {
- _inheritsLoose(TextTrackMenuItem2, _MenuItem);
- function TextTrackMenuItem2(player, options2) {
- var _this;
- var track = options2.track;
- var tracks = player.textTracks();
- options2.label = track.label || track.language || "Unknown";
- options2.selected = track.mode === "showing";
- _this = _MenuItem.call(this, player, options2) || this;
- _this.track = track;
- _this.kinds = (options2.kinds || [options2.kind || _this.track.kind]).filter(Boolean);
- var changeHandler = function changeHandler2() {
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
- _this.handleTracksChange.apply(_assertThisInitialized(_this), args);
- };
- var selectedLanguageChangeHandler = function selectedLanguageChangeHandler2() {
- for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
- args[_key2] = arguments[_key2];
- }
- _this.handleSelectedLanguageChange.apply(_assertThisInitialized(_this), args);
- };
- player.on(["loadstart", "texttrackchange"], changeHandler);
- tracks.addEventListener("change", changeHandler);
- tracks.addEventListener("selectedlanguagechange", selectedLanguageChangeHandler);
- _this.on("dispose", function() {
- player.off(["loadstart", "texttrackchange"], changeHandler);
- tracks.removeEventListener("change", changeHandler);
- tracks.removeEventListener("selectedlanguagechange", selectedLanguageChangeHandler);
- });
- if (tracks.onchange === void 0) {
- var event2;
- _this.on(["tap", "click"], function() {
- if (typeof window_1.Event !== "object") {
- try {
- event2 = new window_1.Event("change");
- } catch (err) {
- }
- }
- if (!event2) {
- event2 = document_1.createEvent("Event");
- event2.initEvent("change", true, true);
- }
- tracks.dispatchEvent(event2);
- });
- }
- _this.handleTracksChange();
- return _this;
- }
- var _proto = TextTrackMenuItem2.prototype;
- _proto.handleClick = function handleClick(event2) {
- var referenceTrack = this.track;
- var tracks = this.player_.textTracks();
- _MenuItem.prototype.handleClick.call(this, event2);
- if (!tracks) {
- return;
- }
- for (var i2 = 0; i2 < tracks.length; i2++) {
- var track = tracks[i2];
- if (this.kinds.indexOf(track.kind) === -1) {
- continue;
- }
- if (track === referenceTrack) {
- if (track.mode !== "showing") {
- track.mode = "showing";
- }
- } else if (track.mode !== "disabled") {
- track.mode = "disabled";
- }
- }
- };
- _proto.handleTracksChange = function handleTracksChange(event2) {
- var shouldBeSelected = this.track.mode === "showing";
- if (shouldBeSelected !== this.isSelected_) {
- this.selected(shouldBeSelected);
- }
- };
- _proto.handleSelectedLanguageChange = function handleSelectedLanguageChange(event2) {
- if (this.track.mode === "showing") {
- var selectedLanguage = this.player_.cache_.selectedLanguage;
- if (selectedLanguage && selectedLanguage.enabled && selectedLanguage.language === this.track.language && selectedLanguage.kind !== this.track.kind) {
- return;
- }
- this.player_.cache_.selectedLanguage = {
- enabled: true,
- language: this.track.language,
- kind: this.track.kind
- };
- }
- };
- _proto.dispose = function dispose() {
- this.track = null;
- _MenuItem.prototype.dispose.call(this);
- };
- return TextTrackMenuItem2;
- }(MenuItem);
- Component$1.registerComponent("TextTrackMenuItem", TextTrackMenuItem);
- var OffTextTrackMenuItem = /* @__PURE__ */ function(_TextTrackMenuItem) {
- _inheritsLoose(OffTextTrackMenuItem2, _TextTrackMenuItem);
- function OffTextTrackMenuItem2(player, options2) {
- options2.track = {
- player,
- kind: options2.kind,
- kinds: options2.kinds,
- "default": false,
- mode: "disabled"
- };
- if (!options2.kinds) {
- options2.kinds = [options2.kind];
- }
- if (options2.label) {
- options2.track.label = options2.label;
- } else {
- options2.track.label = options2.kinds.join(" and ") + " off";
- }
- options2.selectable = true;
- options2.multiSelectable = false;
- return _TextTrackMenuItem.call(this, player, options2) || this;
- }
- var _proto = OffTextTrackMenuItem2.prototype;
- _proto.handleTracksChange = function handleTracksChange(event2) {
- var tracks = this.player().textTracks();
- var shouldBeSelected = true;
- for (var i2 = 0, l = tracks.length; i2 < l; i2++) {
- var track = tracks[i2];
- if (this.options_.kinds.indexOf(track.kind) > -1 && track.mode === "showing") {
- shouldBeSelected = false;
- break;
- }
- }
- if (shouldBeSelected !== this.isSelected_) {
- this.selected(shouldBeSelected);
- }
- };
- _proto.handleSelectedLanguageChange = function handleSelectedLanguageChange(event2) {
- var tracks = this.player().textTracks();
- var allHidden = true;
- for (var i2 = 0, l = tracks.length; i2 < l; i2++) {
- var track = tracks[i2];
- if (["captions", "descriptions", "subtitles"].indexOf(track.kind) > -1 && track.mode === "showing") {
- allHidden = false;
- break;
- }
- }
- if (allHidden) {
- this.player_.cache_.selectedLanguage = {
- enabled: false
- };
- }
- };
- return OffTextTrackMenuItem2;
- }(TextTrackMenuItem);
- Component$1.registerComponent("OffTextTrackMenuItem", OffTextTrackMenuItem);
- var TextTrackButton = /* @__PURE__ */ function(_TrackButton) {
- _inheritsLoose(TextTrackButton2, _TrackButton);
- function TextTrackButton2(player, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- options2.tracks = player.textTracks();
- return _TrackButton.call(this, player, options2) || this;
- }
- var _proto = TextTrackButton2.prototype;
- _proto.createItems = function createItems(items, TrackMenuItem) {
- if (items === void 0) {
- items = [];
- }
- if (TrackMenuItem === void 0) {
- TrackMenuItem = TextTrackMenuItem;
- }
- var label2;
- if (this.label_) {
- label2 = this.label_ + " off";
- }
- items.push(new OffTextTrackMenuItem(this.player_, {
- kinds: this.kinds_,
- kind: this.kind_,
- label: label2
- }));
- this.hideThreshold_ += 1;
- var tracks = this.player_.textTracks();
- if (!Array.isArray(this.kinds_)) {
- this.kinds_ = [this.kind_];
- }
- for (var i2 = 0; i2 < tracks.length; i2++) {
- var track = tracks[i2];
- if (this.kinds_.indexOf(track.kind) > -1) {
- var item = new TrackMenuItem(this.player_, {
- track,
- kinds: this.kinds_,
- kind: this.kind_,
- selectable: true,
- multiSelectable: false
- });
- item.addClass("vjs-" + track.kind + "-menu-item");
- items.push(item);
- }
- }
- return items;
- };
- return TextTrackButton2;
- }(TrackButton);
- Component$1.registerComponent("TextTrackButton", TextTrackButton);
- var ChaptersTrackMenuItem = /* @__PURE__ */ function(_MenuItem) {
- _inheritsLoose(ChaptersTrackMenuItem2, _MenuItem);
- function ChaptersTrackMenuItem2(player, options2) {
- var _this;
- var track = options2.track;
- var cue = options2.cue;
- var currentTime = player.currentTime();
- options2.selectable = true;
- options2.multiSelectable = false;
- options2.label = cue.text;
- options2.selected = cue.startTime <= currentTime && currentTime < cue.endTime;
- _this = _MenuItem.call(this, player, options2) || this;
- _this.track = track;
- _this.cue = cue;
- return _this;
- }
- var _proto = ChaptersTrackMenuItem2.prototype;
- _proto.handleClick = function handleClick(event2) {
- _MenuItem.prototype.handleClick.call(this);
- this.player_.currentTime(this.cue.startTime);
- };
- return ChaptersTrackMenuItem2;
- }(MenuItem);
- Component$1.registerComponent("ChaptersTrackMenuItem", ChaptersTrackMenuItem);
- var ChaptersButton = /* @__PURE__ */ function(_TextTrackButton) {
- _inheritsLoose(ChaptersButton2, _TextTrackButton);
- function ChaptersButton2(player, options2, ready) {
- var _this;
- _this = _TextTrackButton.call(this, player, options2, ready) || this;
- _this.selectCurrentItem_ = function() {
- _this.items.forEach(function(item) {
- item.selected(_this.track_.activeCues[0] === item.cue);
- });
- };
- return _this;
- }
- var _proto = ChaptersButton2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-chapters-button " + _TextTrackButton.prototype.buildCSSClass.call(this);
- };
- _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {
- return "vjs-chapters-button " + _TextTrackButton.prototype.buildWrapperCSSClass.call(this);
- };
- _proto.update = function update(event2) {
- if (event2 && event2.track && event2.track.kind !== "chapters") {
- return;
- }
- var track = this.findChaptersTrack();
- if (track !== this.track_) {
- this.setTrack(track);
- _TextTrackButton.prototype.update.call(this);
- } else if (!this.items || track && track.cues && track.cues.length !== this.items.length) {
- _TextTrackButton.prototype.update.call(this);
- }
- };
- _proto.setTrack = function setTrack(track) {
- if (this.track_ === track) {
- return;
- }
- if (!this.updateHandler_) {
- this.updateHandler_ = this.update.bind(this);
- }
- if (this.track_) {
- var remoteTextTrackEl = this.player_.remoteTextTrackEls().getTrackElementByTrack_(this.track_);
- if (remoteTextTrackEl) {
- remoteTextTrackEl.removeEventListener("load", this.updateHandler_);
- }
- this.track_.removeEventListener("cuechange", this.selectCurrentItem_);
- this.track_ = null;
- }
- this.track_ = track;
- if (this.track_) {
- this.track_.mode = "hidden";
- var _remoteTextTrackEl = this.player_.remoteTextTrackEls().getTrackElementByTrack_(this.track_);
- if (_remoteTextTrackEl) {
- _remoteTextTrackEl.addEventListener("load", this.updateHandler_);
- }
- this.track_.addEventListener("cuechange", this.selectCurrentItem_);
- }
- };
- _proto.findChaptersTrack = function findChaptersTrack() {
- var tracks = this.player_.textTracks() || [];
- for (var i2 = tracks.length - 1; i2 >= 0; i2--) {
- var track = tracks[i2];
- if (track.kind === this.kind_) {
- return track;
- }
- }
- };
- _proto.getMenuCaption = function getMenuCaption() {
- if (this.track_ && this.track_.label) {
- return this.track_.label;
- }
- return this.localize(toTitleCase$1(this.kind_));
- };
- _proto.createMenu = function createMenu() {
- this.options_.title = this.getMenuCaption();
- return _TextTrackButton.prototype.createMenu.call(this);
- };
- _proto.createItems = function createItems() {
- var items = [];
- if (!this.track_) {
- return items;
- }
- var cues = this.track_.cues;
- if (!cues) {
- return items;
- }
- for (var i2 = 0, l = cues.length; i2 < l; i2++) {
- var cue = cues[i2];
- var mi = new ChaptersTrackMenuItem(this.player_, {
- track: this.track_,
- cue
- });
- items.push(mi);
- }
- return items;
- };
- return ChaptersButton2;
- }(TextTrackButton);
- ChaptersButton.prototype.kind_ = "chapters";
- ChaptersButton.prototype.controlText_ = "Chapters";
- Component$1.registerComponent("ChaptersButton", ChaptersButton);
- var DescriptionsButton = /* @__PURE__ */ function(_TextTrackButton) {
- _inheritsLoose(DescriptionsButton2, _TextTrackButton);
- function DescriptionsButton2(player, options2, ready) {
- var _this;
- _this = _TextTrackButton.call(this, player, options2, ready) || this;
- var tracks = player.textTracks();
- var changeHandler = bind(_assertThisInitialized(_this), _this.handleTracksChange);
- tracks.addEventListener("change", changeHandler);
- _this.on("dispose", function() {
- tracks.removeEventListener("change", changeHandler);
- });
- return _this;
- }
- var _proto = DescriptionsButton2.prototype;
- _proto.handleTracksChange = function handleTracksChange(event2) {
- var tracks = this.player().textTracks();
- var disabled = false;
- for (var i2 = 0, l = tracks.length; i2 < l; i2++) {
- var track = tracks[i2];
- if (track.kind !== this.kind_ && track.mode === "showing") {
- disabled = true;
- break;
- }
- }
- if (disabled) {
- this.disable();
- } else {
- this.enable();
- }
- };
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-descriptions-button " + _TextTrackButton.prototype.buildCSSClass.call(this);
- };
- _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {
- return "vjs-descriptions-button " + _TextTrackButton.prototype.buildWrapperCSSClass.call(this);
- };
- return DescriptionsButton2;
- }(TextTrackButton);
- DescriptionsButton.prototype.kind_ = "descriptions";
- DescriptionsButton.prototype.controlText_ = "Descriptions";
- Component$1.registerComponent("DescriptionsButton", DescriptionsButton);
- var SubtitlesButton = /* @__PURE__ */ function(_TextTrackButton) {
- _inheritsLoose(SubtitlesButton2, _TextTrackButton);
- function SubtitlesButton2(player, options2, ready) {
- return _TextTrackButton.call(this, player, options2, ready) || this;
- }
- var _proto = SubtitlesButton2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-subtitles-button " + _TextTrackButton.prototype.buildCSSClass.call(this);
- };
- _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {
- return "vjs-subtitles-button " + _TextTrackButton.prototype.buildWrapperCSSClass.call(this);
- };
- return SubtitlesButton2;
- }(TextTrackButton);
- SubtitlesButton.prototype.kind_ = "subtitles";
- SubtitlesButton.prototype.controlText_ = "Subtitles";
- Component$1.registerComponent("SubtitlesButton", SubtitlesButton);
- var CaptionSettingsMenuItem = /* @__PURE__ */ function(_TextTrackMenuItem) {
- _inheritsLoose(CaptionSettingsMenuItem2, _TextTrackMenuItem);
- function CaptionSettingsMenuItem2(player, options2) {
- var _this;
- options2.track = {
- player,
- kind: options2.kind,
- label: options2.kind + " settings",
- selectable: false,
- "default": false,
- mode: "disabled"
- };
- options2.selectable = false;
- options2.name = "CaptionSettingsMenuItem";
- _this = _TextTrackMenuItem.call(this, player, options2) || this;
- _this.addClass("vjs-texttrack-settings");
- _this.controlText(", opens " + options2.kind + " settings dialog");
- return _this;
- }
- var _proto = CaptionSettingsMenuItem2.prototype;
- _proto.handleClick = function handleClick(event2) {
- this.player().getChild("textTrackSettings").open();
- };
- return CaptionSettingsMenuItem2;
- }(TextTrackMenuItem);
- Component$1.registerComponent("CaptionSettingsMenuItem", CaptionSettingsMenuItem);
- var CaptionsButton = /* @__PURE__ */ function(_TextTrackButton) {
- _inheritsLoose(CaptionsButton2, _TextTrackButton);
- function CaptionsButton2(player, options2, ready) {
- return _TextTrackButton.call(this, player, options2, ready) || this;
- }
- var _proto = CaptionsButton2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-captions-button " + _TextTrackButton.prototype.buildCSSClass.call(this);
- };
- _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {
- return "vjs-captions-button " + _TextTrackButton.prototype.buildWrapperCSSClass.call(this);
- };
- _proto.createItems = function createItems() {
- var items = [];
- if (!(this.player().tech_ && this.player().tech_.featuresNativeTextTracks) && this.player().getChild("textTrackSettings")) {
- items.push(new CaptionSettingsMenuItem(this.player_, {
- kind: this.kind_
- }));
- this.hideThreshold_ += 1;
- }
- return _TextTrackButton.prototype.createItems.call(this, items);
- };
- return CaptionsButton2;
- }(TextTrackButton);
- CaptionsButton.prototype.kind_ = "captions";
- CaptionsButton.prototype.controlText_ = "Captions";
- Component$1.registerComponent("CaptionsButton", CaptionsButton);
- var SubsCapsMenuItem = /* @__PURE__ */ function(_TextTrackMenuItem) {
- _inheritsLoose(SubsCapsMenuItem2, _TextTrackMenuItem);
- function SubsCapsMenuItem2() {
- return _TextTrackMenuItem.apply(this, arguments) || this;
- }
- var _proto = SubsCapsMenuItem2.prototype;
- _proto.createEl = function createEl$12(type2, props, attrs) {
- var el = _TextTrackMenuItem.prototype.createEl.call(this, type2, props, attrs);
- var parentSpan = el.querySelector(".vjs-menu-item-text");
- if (this.options_.track.kind === "captions") {
- parentSpan.appendChild(createEl("span", {
- className: "vjs-icon-placeholder"
- }, {
- "aria-hidden": true
- }));
- parentSpan.appendChild(createEl("span", {
- className: "vjs-control-text",
- textContent: " " + this.localize("Captions")
- }));
- }
- return el;
- };
- return SubsCapsMenuItem2;
- }(TextTrackMenuItem);
- Component$1.registerComponent("SubsCapsMenuItem", SubsCapsMenuItem);
- var SubsCapsButton = /* @__PURE__ */ function(_TextTrackButton) {
- _inheritsLoose(SubsCapsButton2, _TextTrackButton);
- function SubsCapsButton2(player, options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- _this = _TextTrackButton.call(this, player, options2) || this;
- _this.label_ = "subtitles";
- if (["en", "en-us", "en-ca", "fr-ca"].indexOf(_this.player_.language_) > -1) {
- _this.label_ = "captions";
- }
- _this.menuButton_.controlText(toTitleCase$1(_this.label_));
- return _this;
- }
- var _proto = SubsCapsButton2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-subs-caps-button " + _TextTrackButton.prototype.buildCSSClass.call(this);
- };
- _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {
- return "vjs-subs-caps-button " + _TextTrackButton.prototype.buildWrapperCSSClass.call(this);
- };
- _proto.createItems = function createItems() {
- var items = [];
- if (!(this.player().tech_ && this.player().tech_.featuresNativeTextTracks) && this.player().getChild("textTrackSettings")) {
- items.push(new CaptionSettingsMenuItem(this.player_, {
- kind: this.label_
- }));
- this.hideThreshold_ += 1;
- }
- items = _TextTrackButton.prototype.createItems.call(this, items, SubsCapsMenuItem);
- return items;
- };
- return SubsCapsButton2;
- }(TextTrackButton);
- SubsCapsButton.prototype.kinds_ = ["captions", "subtitles"];
- SubsCapsButton.prototype.controlText_ = "Subtitles";
- Component$1.registerComponent("SubsCapsButton", SubsCapsButton);
- var AudioTrackMenuItem = /* @__PURE__ */ function(_MenuItem) {
- _inheritsLoose(AudioTrackMenuItem2, _MenuItem);
- function AudioTrackMenuItem2(player, options2) {
- var _this;
- var track = options2.track;
- var tracks = player.audioTracks();
- options2.label = track.label || track.language || "Unknown";
- options2.selected = track.enabled;
- _this = _MenuItem.call(this, player, options2) || this;
- _this.track = track;
- _this.addClass("vjs-" + track.kind + "-menu-item");
- var changeHandler = function changeHandler2() {
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
- _this.handleTracksChange.apply(_assertThisInitialized(_this), args);
- };
- tracks.addEventListener("change", changeHandler);
- _this.on("dispose", function() {
- tracks.removeEventListener("change", changeHandler);
- });
- return _this;
- }
- var _proto = AudioTrackMenuItem2.prototype;
- _proto.createEl = function createEl$12(type2, props, attrs) {
- var el = _MenuItem.prototype.createEl.call(this, type2, props, attrs);
- var parentSpan = el.querySelector(".vjs-menu-item-text");
- if (this.options_.track.kind === "main-desc") {
- parentSpan.appendChild(createEl("span", {
- className: "vjs-icon-placeholder"
- }, {
- "aria-hidden": true
- }));
- parentSpan.appendChild(createEl("span", {
- className: "vjs-control-text",
- textContent: " " + this.localize("Descriptions")
- }));
- }
- return el;
- };
- _proto.handleClick = function handleClick(event2) {
- _MenuItem.prototype.handleClick.call(this, event2);
- this.track.enabled = true;
- if (this.player_.tech_.featuresNativeAudioTracks) {
- var tracks = this.player_.audioTracks();
- for (var i2 = 0; i2 < tracks.length; i2++) {
- var track = tracks[i2];
- if (track === this.track) {
- continue;
- }
- track.enabled = track === this.track;
- }
- }
- };
- _proto.handleTracksChange = function handleTracksChange(event2) {
- this.selected(this.track.enabled);
- };
- return AudioTrackMenuItem2;
- }(MenuItem);
- Component$1.registerComponent("AudioTrackMenuItem", AudioTrackMenuItem);
- var AudioTrackButton = /* @__PURE__ */ function(_TrackButton) {
- _inheritsLoose(AudioTrackButton2, _TrackButton);
- function AudioTrackButton2(player, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- options2.tracks = player.audioTracks();
- return _TrackButton.call(this, player, options2) || this;
- }
- var _proto = AudioTrackButton2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-audio-button " + _TrackButton.prototype.buildCSSClass.call(this);
- };
- _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {
- return "vjs-audio-button " + _TrackButton.prototype.buildWrapperCSSClass.call(this);
- };
- _proto.createItems = function createItems(items) {
- if (items === void 0) {
- items = [];
- }
- this.hideThreshold_ = 1;
- var tracks = this.player_.audioTracks();
- for (var i2 = 0; i2 < tracks.length; i2++) {
- var track = tracks[i2];
- items.push(new AudioTrackMenuItem(this.player_, {
- track,
- selectable: true,
- multiSelectable: false
- }));
- }
- return items;
- };
- return AudioTrackButton2;
- }(TrackButton);
- AudioTrackButton.prototype.controlText_ = "Audio Track";
- Component$1.registerComponent("AudioTrackButton", AudioTrackButton);
- var PlaybackRateMenuItem = /* @__PURE__ */ function(_MenuItem) {
- _inheritsLoose(PlaybackRateMenuItem2, _MenuItem);
- function PlaybackRateMenuItem2(player, options2) {
- var _this;
- var label2 = options2.rate;
- var rate = parseFloat(label2, 10);
- options2.label = label2;
- options2.selected = rate === player.playbackRate();
- options2.selectable = true;
- options2.multiSelectable = false;
- _this = _MenuItem.call(this, player, options2) || this;
- _this.label = label2;
- _this.rate = rate;
- _this.on(player, "ratechange", function(e) {
- return _this.update(e);
- });
- return _this;
- }
- var _proto = PlaybackRateMenuItem2.prototype;
- _proto.handleClick = function handleClick(event2) {
- _MenuItem.prototype.handleClick.call(this);
- this.player().playbackRate(this.rate);
- };
- _proto.update = function update(event2) {
- this.selected(this.player().playbackRate() === this.rate);
- };
- return PlaybackRateMenuItem2;
- }(MenuItem);
- PlaybackRateMenuItem.prototype.contentElType = "button";
- Component$1.registerComponent("PlaybackRateMenuItem", PlaybackRateMenuItem);
- var PlaybackRateMenuButton = /* @__PURE__ */ function(_MenuButton) {
- _inheritsLoose(PlaybackRateMenuButton2, _MenuButton);
- function PlaybackRateMenuButton2(player, options2) {
- var _this;
- _this = _MenuButton.call(this, player, options2) || this;
- _this.menuButton_.el_.setAttribute("aria-describedby", _this.labelElId_);
- _this.updateVisibility();
- _this.updateLabel();
- _this.on(player, "loadstart", function(e) {
- return _this.updateVisibility(e);
- });
- _this.on(player, "ratechange", function(e) {
- return _this.updateLabel(e);
- });
- _this.on(player, "playbackrateschange", function(e) {
- return _this.handlePlaybackRateschange(e);
- });
- return _this;
- }
- var _proto = PlaybackRateMenuButton2.prototype;
- _proto.createEl = function createEl$12() {
- var el = _MenuButton.prototype.createEl.call(this);
- this.labelElId_ = "vjs-playback-rate-value-label-" + this.id_;
- this.labelEl_ = createEl("div", {
- className: "vjs-playback-rate-value",
- id: this.labelElId_,
- textContent: "1x"
- });
- el.appendChild(this.labelEl_);
- return el;
- };
- _proto.dispose = function dispose() {
- this.labelEl_ = null;
- _MenuButton.prototype.dispose.call(this);
- };
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-playback-rate " + _MenuButton.prototype.buildCSSClass.call(this);
- };
- _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {
- return "vjs-playback-rate " + _MenuButton.prototype.buildWrapperCSSClass.call(this);
- };
- _proto.createItems = function createItems() {
- var rates = this.playbackRates();
- var items = [];
- for (var i2 = rates.length - 1; i2 >= 0; i2--) {
- items.push(new PlaybackRateMenuItem(this.player(), {
- rate: rates[i2] + "x"
- }));
- }
- return items;
- };
- _proto.updateARIAAttributes = function updateARIAAttributes() {
- this.el().setAttribute("aria-valuenow", this.player().playbackRate());
- };
- _proto.handleClick = function handleClick(event2) {
- var currentRate = this.player().playbackRate();
- var rates = this.playbackRates();
- var currentIndex = rates.indexOf(currentRate);
- var newIndex = (currentIndex + 1) % rates.length;
- this.player().playbackRate(rates[newIndex]);
- };
- _proto.handlePlaybackRateschange = function handlePlaybackRateschange(event2) {
- this.update();
- };
- _proto.playbackRates = function playbackRates() {
- var player = this.player();
- return player.playbackRates && player.playbackRates() || [];
- };
- _proto.playbackRateSupported = function playbackRateSupported() {
- return this.player().tech_ && this.player().tech_.featuresPlaybackRate && this.playbackRates() && this.playbackRates().length > 0;
- };
- _proto.updateVisibility = function updateVisibility(event2) {
- if (this.playbackRateSupported()) {
- this.removeClass("vjs-hidden");
- } else {
- this.addClass("vjs-hidden");
- }
- };
- _proto.updateLabel = function updateLabel(event2) {
- if (this.playbackRateSupported()) {
- this.labelEl_.textContent = this.player().playbackRate() + "x";
- }
- };
- return PlaybackRateMenuButton2;
- }(MenuButton);
- PlaybackRateMenuButton.prototype.controlText_ = "Playback Rate";
- Component$1.registerComponent("PlaybackRateMenuButton", PlaybackRateMenuButton);
- var Spacer = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(Spacer2, _Component);
- function Spacer2() {
- return _Component.apply(this, arguments) || this;
- }
- var _proto = Spacer2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-spacer " + _Component.prototype.buildCSSClass.call(this);
- };
- _proto.createEl = function createEl2(tag, props, attributes) {
- if (tag === void 0) {
- tag = "div";
- }
- if (props === void 0) {
- props = {};
- }
- if (attributes === void 0) {
- attributes = {};
- }
- if (!props.className) {
- props.className = this.buildCSSClass();
- }
- return _Component.prototype.createEl.call(this, tag, props, attributes);
- };
- return Spacer2;
- }(Component$1);
- Component$1.registerComponent("Spacer", Spacer);
- var CustomControlSpacer = /* @__PURE__ */ function(_Spacer) {
- _inheritsLoose(CustomControlSpacer2, _Spacer);
- function CustomControlSpacer2() {
- return _Spacer.apply(this, arguments) || this;
- }
- var _proto = CustomControlSpacer2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-custom-control-spacer " + _Spacer.prototype.buildCSSClass.call(this);
- };
- _proto.createEl = function createEl2() {
- return _Spacer.prototype.createEl.call(this, "div", {
- className: this.buildCSSClass(),
- textContent: "\xA0"
- });
- };
- return CustomControlSpacer2;
- }(Spacer);
- Component$1.registerComponent("CustomControlSpacer", CustomControlSpacer);
- var ControlBar = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(ControlBar2, _Component);
- function ControlBar2() {
- return _Component.apply(this, arguments) || this;
- }
- var _proto = ControlBar2.prototype;
- _proto.createEl = function createEl2() {
- return _Component.prototype.createEl.call(this, "div", {
- className: "vjs-control-bar",
- dir: "ltr"
- });
- };
- return ControlBar2;
- }(Component$1);
- ControlBar.prototype.options_ = {
- children: ["playToggle", "volumePanel", "currentTimeDisplay", "timeDivider", "durationDisplay", "progressControl", "liveDisplay", "seekToLive", "remainingTimeDisplay", "customControlSpacer", "playbackRateMenuButton", "chaptersButton", "descriptionsButton", "subsCapsButton", "audioTrackButton", "fullscreenToggle"]
- };
- if ("exitPictureInPicture" in document_1) {
- ControlBar.prototype.options_.children.splice(ControlBar.prototype.options_.children.length - 1, 0, "pictureInPictureToggle");
- }
- Component$1.registerComponent("ControlBar", ControlBar);
- var ErrorDisplay = /* @__PURE__ */ function(_ModalDialog) {
- _inheritsLoose(ErrorDisplay2, _ModalDialog);
- function ErrorDisplay2(player, options2) {
- var _this;
- _this = _ModalDialog.call(this, player, options2) || this;
- _this.on(player, "error", function(e) {
- return _this.open(e);
- });
- return _this;
- }
- var _proto = ErrorDisplay2.prototype;
- _proto.buildCSSClass = function buildCSSClass() {
- return "vjs-error-display " + _ModalDialog.prototype.buildCSSClass.call(this);
- };
- _proto.content = function content() {
- var error = this.player().error();
- return error ? this.localize(error.message) : "";
- };
- return ErrorDisplay2;
- }(ModalDialog);
- ErrorDisplay.prototype.options_ = _extends$2({}, ModalDialog.prototype.options_, {
- pauseOnOpen: false,
- fillAlways: true,
- temporary: false,
- uncloseable: true
- });
- Component$1.registerComponent("ErrorDisplay", ErrorDisplay);
- var LOCAL_STORAGE_KEY$1 = "vjs-text-track-settings";
- var COLOR_BLACK = ["#000", "Black"];
- var COLOR_BLUE = ["#00F", "Blue"];
- var COLOR_CYAN = ["#0FF", "Cyan"];
- var COLOR_GREEN = ["#0F0", "Green"];
- var COLOR_MAGENTA = ["#F0F", "Magenta"];
- var COLOR_RED = ["#F00", "Red"];
- var COLOR_WHITE = ["#FFF", "White"];
- var COLOR_YELLOW = ["#FF0", "Yellow"];
- var OPACITY_OPAQUE = ["1", "Opaque"];
- var OPACITY_SEMI = ["0.5", "Semi-Transparent"];
- var OPACITY_TRANS = ["0", "Transparent"];
- var selectConfigs = {
- backgroundColor: {
- selector: ".vjs-bg-color > select",
- id: "captions-background-color-%s",
- label: "Color",
- options: [COLOR_BLACK, COLOR_WHITE, COLOR_RED, COLOR_GREEN, COLOR_BLUE, COLOR_YELLOW, COLOR_MAGENTA, COLOR_CYAN]
- },
- backgroundOpacity: {
- selector: ".vjs-bg-opacity > select",
- id: "captions-background-opacity-%s",
- label: "Transparency",
- options: [OPACITY_OPAQUE, OPACITY_SEMI, OPACITY_TRANS]
- },
- color: {
- selector: ".vjs-fg-color > select",
- id: "captions-foreground-color-%s",
- label: "Color",
- options: [COLOR_WHITE, COLOR_BLACK, COLOR_RED, COLOR_GREEN, COLOR_BLUE, COLOR_YELLOW, COLOR_MAGENTA, COLOR_CYAN]
- },
- edgeStyle: {
- selector: ".vjs-edge-style > select",
- id: "%s",
- label: "Text Edge Style",
- options: [["none", "None"], ["raised", "Raised"], ["depressed", "Depressed"], ["uniform", "Uniform"], ["dropshadow", "Dropshadow"]]
- },
- fontFamily: {
- selector: ".vjs-font-family > select",
- id: "captions-font-family-%s",
- label: "Font Family",
- options: [["proportionalSansSerif", "Proportional Sans-Serif"], ["monospaceSansSerif", "Monospace Sans-Serif"], ["proportionalSerif", "Proportional Serif"], ["monospaceSerif", "Monospace Serif"], ["casual", "Casual"], ["script", "Script"], ["small-caps", "Small Caps"]]
- },
- fontPercent: {
- selector: ".vjs-font-percent > select",
- id: "captions-font-size-%s",
- label: "Font Size",
- options: [["0.50", "50%"], ["0.75", "75%"], ["1.00", "100%"], ["1.25", "125%"], ["1.50", "150%"], ["1.75", "175%"], ["2.00", "200%"], ["3.00", "300%"], ["4.00", "400%"]],
- "default": 2,
- parser: function parser(v) {
- return v === "1.00" ? null : Number(v);
- }
- },
- textOpacity: {
- selector: ".vjs-text-opacity > select",
- id: "captions-foreground-opacity-%s",
- label: "Transparency",
- options: [OPACITY_OPAQUE, OPACITY_SEMI]
- },
- windowColor: {
- selector: ".vjs-window-color > select",
- id: "captions-window-color-%s",
- label: "Color"
- },
- windowOpacity: {
- selector: ".vjs-window-opacity > select",
- id: "captions-window-opacity-%s",
- label: "Transparency",
- options: [OPACITY_TRANS, OPACITY_SEMI, OPACITY_OPAQUE]
- }
- };
- selectConfigs.windowColor.options = selectConfigs.backgroundColor.options;
- function parseOptionValue(value, parser2) {
- if (parser2) {
- value = parser2(value);
- }
- if (value && value !== "none") {
- return value;
- }
- }
- function getSelectedOptionValue(el, parser2) {
- var value = el.options[el.options.selectedIndex].value;
- return parseOptionValue(value, parser2);
- }
- function setSelectedOption(el, value, parser2) {
- if (!value) {
- return;
- }
- for (var i2 = 0; i2 < el.options.length; i2++) {
- if (parseOptionValue(el.options[i2].value, parser2) === value) {
- el.selectedIndex = i2;
- break;
- }
- }
- }
- var TextTrackSettings = /* @__PURE__ */ function(_ModalDialog) {
- _inheritsLoose(TextTrackSettings2, _ModalDialog);
- function TextTrackSettings2(player, options2) {
- var _this;
- options2.temporary = false;
- _this = _ModalDialog.call(this, player, options2) || this;
- _this.updateDisplay = _this.updateDisplay.bind(_assertThisInitialized(_this));
- _this.fill();
- _this.hasBeenOpened_ = _this.hasBeenFilled_ = true;
- _this.endDialog = createEl("p", {
- className: "vjs-control-text",
- textContent: _this.localize("End of dialog window.")
- });
- _this.el().appendChild(_this.endDialog);
- _this.setDefaults();
- if (options2.persistTextTrackSettings === void 0) {
- _this.options_.persistTextTrackSettings = _this.options_.playerOptions.persistTextTrackSettings;
- }
- _this.on(_this.$(".vjs-done-button"), "click", function() {
- _this.saveSettings();
- _this.close();
- });
- _this.on(_this.$(".vjs-default-button"), "click", function() {
- _this.setDefaults();
- _this.updateDisplay();
- });
- each(selectConfigs, function(config) {
- _this.on(_this.$(config.selector), "change", _this.updateDisplay);
- });
- if (_this.options_.persistTextTrackSettings) {
- _this.restoreSettings();
- }
- return _this;
- }
- var _proto = TextTrackSettings2.prototype;
- _proto.dispose = function dispose() {
- this.endDialog = null;
- _ModalDialog.prototype.dispose.call(this);
- };
- _proto.createElSelect_ = function createElSelect_(key, legendId, type2) {
- var _this2 = this;
- if (legendId === void 0) {
- legendId = "";
- }
- if (type2 === void 0) {
- type2 = "label";
- }
- var config = selectConfigs[key];
- var id = config.id.replace("%s", this.id_);
- var selectLabelledbyIds = [legendId, id].join(" ").trim();
- return ["<" + type2 + ' id="' + id + '" class="' + (type2 === "label" ? "vjs-label" : "") + '">', this.localize(config.label), "</" + type2 + ">", '<select aria-labelledby="' + selectLabelledbyIds + '">'].concat(config.options.map(function(o) {
- var optionId = id + "-" + o[1].replace(/\W+/g, "");
- return ['<option id="' + optionId + '" value="' + o[0] + '" ', 'aria-labelledby="' + selectLabelledbyIds + " " + optionId + '">', _this2.localize(o[1]), "</option>"].join("");
- })).concat("</select>").join("");
- };
- _proto.createElFgColor_ = function createElFgColor_() {
- var legendId = "captions-text-legend-" + this.id_;
- return ['<fieldset class="vjs-fg-color vjs-track-setting">', '<legend id="' + legendId + '">', this.localize("Text"), "</legend>", this.createElSelect_("color", legendId), '<span class="vjs-text-opacity vjs-opacity">', this.createElSelect_("textOpacity", legendId), "</span>", "</fieldset>"].join("");
- };
- _proto.createElBgColor_ = function createElBgColor_() {
- var legendId = "captions-background-" + this.id_;
- return ['<fieldset class="vjs-bg-color vjs-track-setting">', '<legend id="' + legendId + '">', this.localize("Background"), "</legend>", this.createElSelect_("backgroundColor", legendId), '<span class="vjs-bg-opacity vjs-opacity">', this.createElSelect_("backgroundOpacity", legendId), "</span>", "</fieldset>"].join("");
- };
- _proto.createElWinColor_ = function createElWinColor_() {
- var legendId = "captions-window-" + this.id_;
- return ['<fieldset class="vjs-window-color vjs-track-setting">', '<legend id="' + legendId + '">', this.localize("Window"), "</legend>", this.createElSelect_("windowColor", legendId), '<span class="vjs-window-opacity vjs-opacity">', this.createElSelect_("windowOpacity", legendId), "</span>", "</fieldset>"].join("");
- };
- _proto.createElColors_ = function createElColors_() {
- return createEl("div", {
- className: "vjs-track-settings-colors",
- innerHTML: [this.createElFgColor_(), this.createElBgColor_(), this.createElWinColor_()].join("")
- });
- };
- _proto.createElFont_ = function createElFont_() {
- return createEl("div", {
- className: "vjs-track-settings-font",
- innerHTML: ['<fieldset class="vjs-font-percent vjs-track-setting">', this.createElSelect_("fontPercent", "", "legend"), "</fieldset>", '<fieldset class="vjs-edge-style vjs-track-setting">', this.createElSelect_("edgeStyle", "", "legend"), "</fieldset>", '<fieldset class="vjs-font-family vjs-track-setting">', this.createElSelect_("fontFamily", "", "legend"), "</fieldset>"].join("")
- });
- };
- _proto.createElControls_ = function createElControls_() {
- var defaultsDescription = this.localize("restore all settings to the default values");
- return createEl("div", {
- className: "vjs-track-settings-controls",
- innerHTML: ['<button type="button" class="vjs-default-button" title="' + defaultsDescription + '">', this.localize("Reset"), '<span class="vjs-control-text"> ' + defaultsDescription + "</span>", "</button>", '<button type="button" class="vjs-done-button">' + this.localize("Done") + "</button>"].join("")
- });
- };
- _proto.content = function content() {
- return [this.createElColors_(), this.createElFont_(), this.createElControls_()];
- };
- _proto.label = function label2() {
- return this.localize("Caption Settings Dialog");
- };
- _proto.description = function description() {
- return this.localize("Beginning of dialog window. Escape will cancel and close the window.");
- };
- _proto.buildCSSClass = function buildCSSClass() {
- return _ModalDialog.prototype.buildCSSClass.call(this) + " vjs-text-track-settings";
- };
- _proto.getValues = function getValues() {
- var _this3 = this;
- return reduce(selectConfigs, function(accum, config, key) {
- var value = getSelectedOptionValue(_this3.$(config.selector), config.parser);
- if (value !== void 0) {
- accum[key] = value;
- }
- return accum;
- }, {});
- };
- _proto.setValues = function setValues(values3) {
- var _this4 = this;
- each(selectConfigs, function(config, key) {
- setSelectedOption(_this4.$(config.selector), values3[key], config.parser);
- });
- };
- _proto.setDefaults = function setDefaults() {
- var _this5 = this;
- each(selectConfigs, function(config) {
- var index2 = config.hasOwnProperty("default") ? config["default"] : 0;
- _this5.$(config.selector).selectedIndex = index2;
- });
- };
- _proto.restoreSettings = function restoreSettings() {
- var values3;
- try {
- values3 = JSON.parse(window_1.localStorage.getItem(LOCAL_STORAGE_KEY$1));
- } catch (err) {
- log$1.warn(err);
- }
- if (values3) {
- this.setValues(values3);
- }
- };
- _proto.saveSettings = function saveSettings() {
- if (!this.options_.persistTextTrackSettings) {
- return;
- }
- var values3 = this.getValues();
- try {
- if (Object.keys(values3).length) {
- window_1.localStorage.setItem(LOCAL_STORAGE_KEY$1, JSON.stringify(values3));
- } else {
- window_1.localStorage.removeItem(LOCAL_STORAGE_KEY$1);
- }
- } catch (err) {
- log$1.warn(err);
- }
- };
- _proto.updateDisplay = function updateDisplay() {
- var ttDisplay = this.player_.getChild("textTrackDisplay");
- if (ttDisplay) {
- ttDisplay.updateDisplay();
- }
- };
- _proto.conditionalBlur_ = function conditionalBlur_() {
- this.previouslyActiveEl_ = null;
- var cb = this.player_.controlBar;
- var subsCapsBtn = cb && cb.subsCapsButton;
- var ccBtn = cb && cb.captionsButton;
- if (subsCapsBtn) {
- subsCapsBtn.focus();
- } else if (ccBtn) {
- ccBtn.focus();
- }
- };
- return TextTrackSettings2;
- }(ModalDialog);
- Component$1.registerComponent("TextTrackSettings", TextTrackSettings);
- var ResizeManager = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(ResizeManager2, _Component);
- function ResizeManager2(player, options2) {
- var _this;
- var RESIZE_OBSERVER_AVAILABLE = options2.ResizeObserver || window_1.ResizeObserver;
- if (options2.ResizeObserver === null) {
- RESIZE_OBSERVER_AVAILABLE = false;
- }
- var options_ = mergeOptions$3({
- createEl: !RESIZE_OBSERVER_AVAILABLE,
- reportTouchActivity: false
- }, options2);
- _this = _Component.call(this, player, options_) || this;
- _this.ResizeObserver = options2.ResizeObserver || window_1.ResizeObserver;
- _this.loadListener_ = null;
- _this.resizeObserver_ = null;
- _this.debouncedHandler_ = debounce(function() {
- _this.resizeHandler();
- }, 100, false, _assertThisInitialized(_this));
- if (RESIZE_OBSERVER_AVAILABLE) {
- _this.resizeObserver_ = new _this.ResizeObserver(_this.debouncedHandler_);
- _this.resizeObserver_.observe(player.el());
- } else {
- _this.loadListener_ = function() {
- if (!_this.el_ || !_this.el_.contentWindow) {
- return;
- }
- var debouncedHandler_ = _this.debouncedHandler_;
- var unloadListener_ = _this.unloadListener_ = function() {
- off(this, "resize", debouncedHandler_);
- off(this, "unload", unloadListener_);
- unloadListener_ = null;
- };
- on(_this.el_.contentWindow, "unload", unloadListener_);
- on(_this.el_.contentWindow, "resize", debouncedHandler_);
- };
- _this.one("load", _this.loadListener_);
- }
- return _this;
- }
- var _proto = ResizeManager2.prototype;
- _proto.createEl = function createEl2() {
- return _Component.prototype.createEl.call(this, "iframe", {
- className: "vjs-resize-manager",
- tabIndex: -1,
- title: this.localize("No content")
- }, {
- "aria-hidden": "true"
- });
- };
- _proto.resizeHandler = function resizeHandler() {
- if (!this.player_ || !this.player_.trigger) {
- return;
- }
- this.player_.trigger("playerresize");
- };
- _proto.dispose = function dispose() {
- if (this.debouncedHandler_) {
- this.debouncedHandler_.cancel();
- }
- if (this.resizeObserver_) {
- if (this.player_.el()) {
- this.resizeObserver_.unobserve(this.player_.el());
- }
- this.resizeObserver_.disconnect();
- }
- if (this.loadListener_) {
- this.off("load", this.loadListener_);
- }
- if (this.el_ && this.el_.contentWindow && this.unloadListener_) {
- this.unloadListener_.call(this.el_.contentWindow);
- }
- this.ResizeObserver = null;
- this.resizeObserver = null;
- this.debouncedHandler_ = null;
- this.loadListener_ = null;
- _Component.prototype.dispose.call(this);
- };
- return ResizeManager2;
- }(Component$1);
- Component$1.registerComponent("ResizeManager", ResizeManager);
- var defaults$1 = {
- trackingThreshold: 20,
- liveTolerance: 15
- };
- var LiveTracker = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(LiveTracker2, _Component);
- function LiveTracker2(player, options2) {
- var _this;
- var options_ = mergeOptions$3(defaults$1, options2, {
- createEl: false
- });
- _this = _Component.call(this, player, options_) || this;
- _this.handleVisibilityChange_ = function(e) {
- return _this.handleVisibilityChange(e);
- };
- _this.trackLiveHandler_ = function() {
- return _this.trackLive_();
- };
- _this.handlePlay_ = function(e) {
- return _this.handlePlay(e);
- };
- _this.handleFirstTimeupdate_ = function(e) {
- return _this.handleFirstTimeupdate(e);
- };
- _this.handleSeeked_ = function(e) {
- return _this.handleSeeked(e);
- };
- _this.seekToLiveEdge_ = function(e) {
- return _this.seekToLiveEdge(e);
- };
- _this.reset_();
- _this.on(_this.player_, "durationchange", function(e) {
- return _this.handleDurationchange(e);
- });
- _this.on(_this.player_, "canplay", function() {
- return _this.toggleTracking();
- });
- if (IE_VERSION && "hidden" in document_1 && "visibilityState" in document_1) {
- _this.on(document_1, "visibilitychange", _this.handleVisibilityChange_);
- }
- return _this;
- }
- var _proto = LiveTracker2.prototype;
- _proto.handleVisibilityChange = function handleVisibilityChange() {
- if (this.player_.duration() !== Infinity) {
- return;
- }
- if (document_1.hidden) {
- this.stopTracking();
- } else {
- this.startTracking();
- }
- };
- _proto.trackLive_ = function trackLive_() {
- var seekable3 = this.player_.seekable();
- if (!seekable3 || !seekable3.length) {
- return;
- }
- var newTime = Number(window_1.performance.now().toFixed(4));
- var deltaTime = this.lastTime_ === -1 ? 0 : (newTime - this.lastTime_) / 1e3;
- this.lastTime_ = newTime;
- this.pastSeekEnd_ = this.pastSeekEnd() + deltaTime;
- var liveCurrentTime = this.liveCurrentTime();
- var currentTime = this.player_.currentTime();
- var isBehind = this.player_.paused() || this.seekedBehindLive_ || Math.abs(liveCurrentTime - currentTime) > this.options_.liveTolerance;
- if (!this.timeupdateSeen_ || liveCurrentTime === Infinity) {
- isBehind = false;
- }
- if (isBehind !== this.behindLiveEdge_) {
- this.behindLiveEdge_ = isBehind;
- this.trigger("liveedgechange");
- }
- };
- _proto.handleDurationchange = function handleDurationchange() {
- this.toggleTracking();
- };
- _proto.toggleTracking = function toggleTracking() {
- if (this.player_.duration() === Infinity && this.liveWindow() >= this.options_.trackingThreshold) {
- if (this.player_.options_.liveui) {
- this.player_.addClass("vjs-liveui");
- }
- this.startTracking();
- } else {
- this.player_.removeClass("vjs-liveui");
- this.stopTracking();
- }
- };
- _proto.startTracking = function startTracking() {
- if (this.isTracking()) {
- return;
- }
- if (!this.timeupdateSeen_) {
- this.timeupdateSeen_ = this.player_.hasStarted();
- }
- this.trackingInterval_ = this.setInterval(this.trackLiveHandler_, UPDATE_REFRESH_INTERVAL);
- this.trackLive_();
- this.on(this.player_, ["play", "pause"], this.trackLiveHandler_);
- if (!this.timeupdateSeen_) {
- this.one(this.player_, "play", this.handlePlay_);
- this.one(this.player_, "timeupdate", this.handleFirstTimeupdate_);
- } else {
- this.on(this.player_, "seeked", this.handleSeeked_);
- }
- };
- _proto.handleFirstTimeupdate = function handleFirstTimeupdate() {
- this.timeupdateSeen_ = true;
- this.on(this.player_, "seeked", this.handleSeeked_);
- };
- _proto.handleSeeked = function handleSeeked() {
- var timeDiff = Math.abs(this.liveCurrentTime() - this.player_.currentTime());
- this.seekedBehindLive_ = this.nextSeekedFromUser_ && timeDiff > 2;
- this.nextSeekedFromUser_ = false;
- this.trackLive_();
- };
- _proto.handlePlay = function handlePlay() {
- this.one(this.player_, "timeupdate", this.seekToLiveEdge_);
- };
- _proto.reset_ = function reset_() {
- this.lastTime_ = -1;
- this.pastSeekEnd_ = 0;
- this.lastSeekEnd_ = -1;
- this.behindLiveEdge_ = true;
- this.timeupdateSeen_ = false;
- this.seekedBehindLive_ = false;
- this.nextSeekedFromUser_ = false;
- this.clearInterval(this.trackingInterval_);
- this.trackingInterval_ = null;
- this.off(this.player_, ["play", "pause"], this.trackLiveHandler_);
- this.off(this.player_, "seeked", this.handleSeeked_);
- this.off(this.player_, "play", this.handlePlay_);
- this.off(this.player_, "timeupdate", this.handleFirstTimeupdate_);
- this.off(this.player_, "timeupdate", this.seekToLiveEdge_);
- };
- _proto.nextSeekedFromUser = function nextSeekedFromUser() {
- this.nextSeekedFromUser_ = true;
- };
- _proto.stopTracking = function stopTracking() {
- if (!this.isTracking()) {
- return;
- }
- this.reset_();
- this.trigger("liveedgechange");
- };
- _proto.seekableEnd = function seekableEnd() {
- var seekable3 = this.player_.seekable();
- var seekableEnds = [];
- var i2 = seekable3 ? seekable3.length : 0;
- while (i2--) {
- seekableEnds.push(seekable3.end(i2));
- }
- return seekableEnds.length ? seekableEnds.sort()[seekableEnds.length - 1] : Infinity;
- };
- _proto.seekableStart = function seekableStart() {
- var seekable3 = this.player_.seekable();
- var seekableStarts = [];
- var i2 = seekable3 ? seekable3.length : 0;
- while (i2--) {
- seekableStarts.push(seekable3.start(i2));
- }
- return seekableStarts.length ? seekableStarts.sort()[0] : 0;
- };
- _proto.liveWindow = function liveWindow() {
- var liveCurrentTime = this.liveCurrentTime();
- if (liveCurrentTime === Infinity) {
- return 0;
- }
- return liveCurrentTime - this.seekableStart();
- };
- _proto.isLive = function isLive() {
- return this.isTracking();
- };
- _proto.atLiveEdge = function atLiveEdge() {
- return !this.behindLiveEdge();
- };
- _proto.liveCurrentTime = function liveCurrentTime() {
- return this.pastSeekEnd() + this.seekableEnd();
- };
- _proto.pastSeekEnd = function pastSeekEnd() {
- var seekableEnd = this.seekableEnd();
- if (this.lastSeekEnd_ !== -1 && seekableEnd !== this.lastSeekEnd_) {
- this.pastSeekEnd_ = 0;
- }
- this.lastSeekEnd_ = seekableEnd;
- return this.pastSeekEnd_;
- };
- _proto.behindLiveEdge = function behindLiveEdge() {
- return this.behindLiveEdge_;
- };
- _proto.isTracking = function isTracking() {
- return typeof this.trackingInterval_ === "number";
- };
- _proto.seekToLiveEdge = function seekToLiveEdge() {
- this.seekedBehindLive_ = false;
- if (this.atLiveEdge()) {
- return;
- }
- this.nextSeekedFromUser_ = false;
- this.player_.currentTime(this.liveCurrentTime());
- };
- _proto.dispose = function dispose() {
- this.off(document_1, "visibilitychange", this.handleVisibilityChange_);
- this.stopTracking();
- _Component.prototype.dispose.call(this);
- };
- return LiveTracker2;
- }(Component$1);
- Component$1.registerComponent("LiveTracker", LiveTracker);
- var sourcesetLoad = function sourcesetLoad2(tech) {
- var el = tech.el();
- if (el.hasAttribute("src")) {
- tech.triggerSourceset(el.src);
- return true;
- }
- var sources = tech.$$("source");
- var srcUrls = [];
- var src = "";
- if (!sources.length) {
- return false;
- }
- for (var i2 = 0; i2 < sources.length; i2++) {
- var url = sources[i2].src;
- if (url && srcUrls.indexOf(url) === -1) {
- srcUrls.push(url);
- }
- }
- if (!srcUrls.length) {
- return false;
- }
- if (srcUrls.length === 1) {
- src = srcUrls[0];
- }
- tech.triggerSourceset(src);
- return true;
- };
- var innerHTMLDescriptorPolyfill = Object.defineProperty({}, "innerHTML", {
- get: function get2() {
- return this.cloneNode(true).innerHTML;
- },
- set: function set2(v) {
- var dummy = document_1.createElement(this.nodeName.toLowerCase());
- dummy.innerHTML = v;
- var docFrag = document_1.createDocumentFragment();
- while (dummy.childNodes.length) {
- docFrag.appendChild(dummy.childNodes[0]);
- }
- this.innerText = "";
- window_1.Element.prototype.appendChild.call(this, docFrag);
- return this.innerHTML;
- }
- });
- var getDescriptor = function getDescriptor2(priority, prop) {
- var descriptor = {};
- for (var i2 = 0; i2 < priority.length; i2++) {
- descriptor = Object.getOwnPropertyDescriptor(priority[i2], prop);
- if (descriptor && descriptor.set && descriptor.get) {
- break;
- }
- }
- descriptor.enumerable = true;
- descriptor.configurable = true;
- return descriptor;
- };
- var getInnerHTMLDescriptor = function getInnerHTMLDescriptor2(tech) {
- return getDescriptor([tech.el(), window_1.HTMLMediaElement.prototype, window_1.Element.prototype, innerHTMLDescriptorPolyfill], "innerHTML");
- };
- var firstSourceWatch = function firstSourceWatch2(tech) {
- var el = tech.el();
- if (el.resetSourceWatch_) {
- return;
- }
- var old = {};
- var innerDescriptor = getInnerHTMLDescriptor(tech);
- var appendWrapper = function appendWrapper2(appendFn) {
- return function() {
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
- var retval = appendFn.apply(el, args);
- sourcesetLoad(tech);
- return retval;
- };
- };
- ["append", "appendChild", "insertAdjacentHTML"].forEach(function(k) {
- if (!el[k]) {
- return;
- }
- old[k] = el[k];
- el[k] = appendWrapper(old[k]);
- });
- Object.defineProperty(el, "innerHTML", mergeOptions$3(innerDescriptor, {
- set: appendWrapper(innerDescriptor.set)
- }));
- el.resetSourceWatch_ = function() {
- el.resetSourceWatch_ = null;
- Object.keys(old).forEach(function(k) {
- el[k] = old[k];
- });
- Object.defineProperty(el, "innerHTML", innerDescriptor);
- };
- tech.one("sourceset", el.resetSourceWatch_);
- };
- var srcDescriptorPolyfill = Object.defineProperty({}, "src", {
- get: function get3() {
- if (this.hasAttribute("src")) {
- return getAbsoluteURL(window_1.Element.prototype.getAttribute.call(this, "src"));
- }
- return "";
- },
- set: function set3(v) {
- window_1.Element.prototype.setAttribute.call(this, "src", v);
- return v;
- }
- });
- var getSrcDescriptor = function getSrcDescriptor2(tech) {
- return getDescriptor([tech.el(), window_1.HTMLMediaElement.prototype, srcDescriptorPolyfill], "src");
- };
- var setupSourceset = function setupSourceset2(tech) {
- if (!tech.featuresSourceset) {
- return;
- }
- var el = tech.el();
- if (el.resetSourceset_) {
- return;
- }
- var srcDescriptor = getSrcDescriptor(tech);
- var oldSetAttribute = el.setAttribute;
- var oldLoad = el.load;
- Object.defineProperty(el, "src", mergeOptions$3(srcDescriptor, {
- set: function set4(v) {
- var retval = srcDescriptor.set.call(el, v);
- tech.triggerSourceset(el.src);
- return retval;
- }
- }));
- el.setAttribute = function(n, v) {
- var retval = oldSetAttribute.call(el, n, v);
- if (/src/i.test(n)) {
- tech.triggerSourceset(el.src);
- }
- return retval;
- };
- el.load = function() {
- var retval = oldLoad.call(el);
- if (!sourcesetLoad(tech)) {
- tech.triggerSourceset("");
- firstSourceWatch(tech);
- }
- return retval;
- };
- if (el.currentSrc) {
- tech.triggerSourceset(el.currentSrc);
- } else if (!sourcesetLoad(tech)) {
- firstSourceWatch(tech);
- }
- el.resetSourceset_ = function() {
- el.resetSourceset_ = null;
- el.load = oldLoad;
- el.setAttribute = oldSetAttribute;
- Object.defineProperty(el, "src", srcDescriptor);
- if (el.resetSourceWatch_) {
- el.resetSourceWatch_();
- }
- };
- };
- var defineLazyProperty = function defineLazyProperty2(obj, key, getValue2, setter) {
- if (setter === void 0) {
- setter = true;
- }
- var set4 = function set5(value) {
- return Object.defineProperty(obj, key, {
- value,
- enumerable: true,
- writable: true
- });
- };
- var options2 = {
- configurable: true,
- enumerable: true,
- get: function get7() {
- var value = getValue2();
- set4(value);
- return value;
- }
- };
- if (setter) {
- options2.set = set4;
- }
- return Object.defineProperty(obj, key, options2);
- };
- var Html5$1 = /* @__PURE__ */ function(_Tech) {
- _inheritsLoose(Html52, _Tech);
- function Html52(options2, ready) {
- var _this;
- _this = _Tech.call(this, options2, ready) || this;
- var source = options2.source;
- var crossoriginTracks = false;
- _this.featuresVideoFrameCallback = _this.featuresVideoFrameCallback && _this.el_.tagName === "VIDEO";
- if (source && (_this.el_.currentSrc !== source.src || options2.tag && options2.tag.initNetworkState_ === 3)) {
- _this.setSource(source);
- } else {
- _this.handleLateInit_(_this.el_);
- }
- if (options2.enableSourceset) {
- _this.setupSourcesetHandling_();
- }
- _this.isScrubbing_ = false;
- if (_this.el_.hasChildNodes()) {
- var nodes = _this.el_.childNodes;
- var nodesLength = nodes.length;
- var removeNodes = [];
- while (nodesLength--) {
- var node = nodes[nodesLength];
- var nodeName = node.nodeName.toLowerCase();
- if (nodeName === "track") {
- if (!_this.featuresNativeTextTracks) {
- removeNodes.push(node);
- } else {
- _this.remoteTextTrackEls().addTrackElement_(node);
- _this.remoteTextTracks().addTrack(node.track);
- _this.textTracks().addTrack(node.track);
- if (!crossoriginTracks && !_this.el_.hasAttribute("crossorigin") && isCrossOrigin(node.src)) {
- crossoriginTracks = true;
- }
- }
- }
- }
- for (var i2 = 0; i2 < removeNodes.length; i2++) {
- _this.el_.removeChild(removeNodes[i2]);
- }
- }
- _this.proxyNativeTracks_();
- if (_this.featuresNativeTextTracks && crossoriginTracks) {
- log$1.warn("Text Tracks are being loaded from another origin but the crossorigin attribute isn't used.\nThis may prevent text tracks from loading.");
- }
- _this.restoreMetadataTracksInIOSNativePlayer_();
- if ((TOUCH_ENABLED || IS_IPHONE || IS_NATIVE_ANDROID) && options2.nativeControlsForTouch === true) {
- _this.setControls(true);
- }
- _this.proxyWebkitFullscreen_();
- _this.triggerReady();
- return _this;
- }
- var _proto = Html52.prototype;
- _proto.dispose = function dispose() {
- if (this.el_ && this.el_.resetSourceset_) {
- this.el_.resetSourceset_();
- }
- Html52.disposeMediaElement(this.el_);
- this.options_ = null;
- _Tech.prototype.dispose.call(this);
- };
- _proto.setupSourcesetHandling_ = function setupSourcesetHandling_() {
- setupSourceset(this);
- };
- _proto.restoreMetadataTracksInIOSNativePlayer_ = function restoreMetadataTracksInIOSNativePlayer_() {
- var textTracks = this.textTracks();
- var metadataTracksPreFullscreenState;
- var takeMetadataTrackSnapshot = function takeMetadataTrackSnapshot2() {
- metadataTracksPreFullscreenState = [];
- for (var i2 = 0; i2 < textTracks.length; i2++) {
- var track = textTracks[i2];
- if (track.kind === "metadata") {
- metadataTracksPreFullscreenState.push({
- track,
- storedMode: track.mode
- });
- }
- }
- };
- takeMetadataTrackSnapshot();
- textTracks.addEventListener("change", takeMetadataTrackSnapshot);
- this.on("dispose", function() {
- return textTracks.removeEventListener("change", takeMetadataTrackSnapshot);
- });
- var restoreTrackMode = function restoreTrackMode2() {
- for (var i2 = 0; i2 < metadataTracksPreFullscreenState.length; i2++) {
- var storedTrack = metadataTracksPreFullscreenState[i2];
- if (storedTrack.track.mode === "disabled" && storedTrack.track.mode !== storedTrack.storedMode) {
- storedTrack.track.mode = storedTrack.storedMode;
- }
- }
- textTracks.removeEventListener("change", restoreTrackMode2);
- };
- this.on("webkitbeginfullscreen", function() {
- textTracks.removeEventListener("change", takeMetadataTrackSnapshot);
- textTracks.removeEventListener("change", restoreTrackMode);
- textTracks.addEventListener("change", restoreTrackMode);
- });
- this.on("webkitendfullscreen", function() {
- textTracks.removeEventListener("change", takeMetadataTrackSnapshot);
- textTracks.addEventListener("change", takeMetadataTrackSnapshot);
- textTracks.removeEventListener("change", restoreTrackMode);
- });
- };
- _proto.overrideNative_ = function overrideNative_(type2, override) {
- var _this2 = this;
- if (override !== this["featuresNative" + type2 + "Tracks"]) {
- return;
- }
- var lowerCaseType = type2.toLowerCase();
- if (this[lowerCaseType + "TracksListeners_"]) {
- Object.keys(this[lowerCaseType + "TracksListeners_"]).forEach(function(eventName) {
- var elTracks = _this2.el()[lowerCaseType + "Tracks"];
- elTracks.removeEventListener(eventName, _this2[lowerCaseType + "TracksListeners_"][eventName]);
- });
- }
- this["featuresNative" + type2 + "Tracks"] = !override;
- this[lowerCaseType + "TracksListeners_"] = null;
- this.proxyNativeTracksForType_(lowerCaseType);
- };
- _proto.overrideNativeAudioTracks = function overrideNativeAudioTracks(override) {
- this.overrideNative_("Audio", override);
- };
- _proto.overrideNativeVideoTracks = function overrideNativeVideoTracks(override) {
- this.overrideNative_("Video", override);
- };
- _proto.proxyNativeTracksForType_ = function proxyNativeTracksForType_(name) {
- var _this3 = this;
- var props = NORMAL[name];
- var elTracks = this.el()[props.getterName];
- var techTracks = this[props.getterName]();
- if (!this["featuresNative" + props.capitalName + "Tracks"] || !elTracks || !elTracks.addEventListener) {
- return;
- }
- var listeners = {
- change: function change(e) {
- var event2 = {
- type: "change",
- target: techTracks,
- currentTarget: techTracks,
- srcElement: techTracks
- };
- techTracks.trigger(event2);
- if (name === "text") {
- _this3[REMOTE.remoteText.getterName]().trigger(event2);
- }
- },
- addtrack: function addtrack(e) {
- techTracks.addTrack(e.track);
- },
- removetrack: function removetrack(e) {
- techTracks.removeTrack(e.track);
- }
- };
- var removeOldTracks = function removeOldTracks2() {
- var removeTracks = [];
- for (var i2 = 0; i2 < techTracks.length; i2++) {
- var found = false;
- for (var j = 0; j < elTracks.length; j++) {
- if (elTracks[j] === techTracks[i2]) {
- found = true;
- break;
- }
- }
- if (!found) {
- removeTracks.push(techTracks[i2]);
- }
- }
- while (removeTracks.length) {
- techTracks.removeTrack(removeTracks.shift());
- }
- };
- this[props.getterName + "Listeners_"] = listeners;
- Object.keys(listeners).forEach(function(eventName) {
- var listener = listeners[eventName];
- elTracks.addEventListener(eventName, listener);
- _this3.on("dispose", function(e) {
- return elTracks.removeEventListener(eventName, listener);
- });
- });
- this.on("loadstart", removeOldTracks);
- this.on("dispose", function(e) {
- return _this3.off("loadstart", removeOldTracks);
- });
- };
- _proto.proxyNativeTracks_ = function proxyNativeTracks_() {
- var _this4 = this;
- NORMAL.names.forEach(function(name) {
- _this4.proxyNativeTracksForType_(name);
- });
- };
- _proto.createEl = function createEl2() {
- var el = this.options_.tag;
- if (!el || !(this.options_.playerElIngest || this.movingMediaElementInDOM)) {
- if (el) {
- var clone = el.cloneNode(true);
- if (el.parentNode) {
- el.parentNode.insertBefore(clone, el);
- }
- Html52.disposeMediaElement(el);
- el = clone;
- } else {
- el = document_1.createElement("video");
- var tagAttributes = this.options_.tag && getAttributes(this.options_.tag);
- var attributes = mergeOptions$3({}, tagAttributes);
- if (!TOUCH_ENABLED || this.options_.nativeControlsForTouch !== true) {
- delete attributes.controls;
- }
- setAttributes(el, assign(attributes, {
- id: this.options_.techId,
- "class": "vjs-tech"
- }));
- }
- el.playerId = this.options_.playerId;
- }
- if (typeof this.options_.preload !== "undefined") {
- setAttribute(el, "preload", this.options_.preload);
- }
- if (this.options_.disablePictureInPicture !== void 0) {
- el.disablePictureInPicture = this.options_.disablePictureInPicture;
- }
- var settingsAttrs = ["loop", "muted", "playsinline", "autoplay"];
- for (var i2 = 0; i2 < settingsAttrs.length; i2++) {
- var attr = settingsAttrs[i2];
- var value = this.options_[attr];
- if (typeof value !== "undefined") {
- if (value) {
- setAttribute(el, attr, attr);
- } else {
- removeAttribute(el, attr);
- }
- el[attr] = value;
- }
- }
- return el;
- };
- _proto.handleLateInit_ = function handleLateInit_(el) {
- if (el.networkState === 0 || el.networkState === 3) {
- return;
- }
- if (el.readyState === 0) {
- var loadstartFired = false;
- var setLoadstartFired = function setLoadstartFired2() {
- loadstartFired = true;
- };
- this.on("loadstart", setLoadstartFired);
- var triggerLoadstart = function triggerLoadstart2() {
- if (!loadstartFired) {
- this.trigger("loadstart");
- }
- };
- this.on("loadedmetadata", triggerLoadstart);
- this.ready(function() {
- this.off("loadstart", setLoadstartFired);
- this.off("loadedmetadata", triggerLoadstart);
- if (!loadstartFired) {
- this.trigger("loadstart");
- }
- });
- return;
- }
- var eventsToTrigger = ["loadstart"];
- eventsToTrigger.push("loadedmetadata");
- if (el.readyState >= 2) {
- eventsToTrigger.push("loadeddata");
- }
- if (el.readyState >= 3) {
- eventsToTrigger.push("canplay");
- }
- if (el.readyState >= 4) {
- eventsToTrigger.push("canplaythrough");
- }
- this.ready(function() {
- eventsToTrigger.forEach(function(type2) {
- this.trigger(type2);
- }, this);
- });
- };
- _proto.setScrubbing = function setScrubbing(isScrubbing) {
- this.isScrubbing_ = isScrubbing;
- };
- _proto.scrubbing = function scrubbing() {
- return this.isScrubbing_;
- };
- _proto.setCurrentTime = function setCurrentTime(seconds) {
- try {
- if (this.isScrubbing_ && this.el_.fastSeek && IS_ANY_SAFARI) {
- this.el_.fastSeek(seconds);
- } else {
- this.el_.currentTime = seconds;
- }
- } catch (e) {
- log$1(e, "Video is not ready. (Video.js)");
- }
- };
- _proto.duration = function duration5() {
- var _this5 = this;
- if (this.el_.duration === Infinity && IS_ANDROID && IS_CHROME && this.el_.currentTime === 0) {
- var checkProgress = function checkProgress2() {
- if (_this5.el_.currentTime > 0) {
- if (_this5.el_.duration === Infinity) {
- _this5.trigger("durationchange");
- }
- _this5.off("timeupdate", checkProgress2);
- }
- };
- this.on("timeupdate", checkProgress);
- return NaN;
- }
- return this.el_.duration || NaN;
- };
- _proto.width = function width2() {
- return this.el_.offsetWidth;
- };
- _proto.height = function height2() {
- return this.el_.offsetHeight;
- };
- _proto.proxyWebkitFullscreen_ = function proxyWebkitFullscreen_() {
- var _this6 = this;
- if (!("webkitDisplayingFullscreen" in this.el_)) {
- return;
- }
- var endFn = function endFn2() {
- this.trigger("fullscreenchange", {
- isFullscreen: false
- });
- if (this.el_.controls && !this.options_.nativeControlsForTouch && this.controls()) {
- this.el_.controls = false;
- }
- };
- var beginFn = function beginFn2() {
- if ("webkitPresentationMode" in this.el_ && this.el_.webkitPresentationMode !== "picture-in-picture") {
- this.one("webkitendfullscreen", endFn);
- this.trigger("fullscreenchange", {
- isFullscreen: true,
- nativeIOSFullscreen: true
- });
- }
- };
- this.on("webkitbeginfullscreen", beginFn);
- this.on("dispose", function() {
- _this6.off("webkitbeginfullscreen", beginFn);
- _this6.off("webkitendfullscreen", endFn);
- });
- };
- _proto.supportsFullScreen = function supportsFullScreen() {
- if (typeof this.el_.webkitEnterFullScreen === "function") {
- var userAgent = window_1.navigator && window_1.navigator.userAgent || "";
- if (/Android/.test(userAgent) || !/Chrome|Mac OS X 10.5/.test(userAgent)) {
- return true;
- }
- }
- return false;
- };
- _proto.enterFullScreen = function enterFullScreen() {
- var video = this.el_;
- if (video.paused && video.networkState <= video.HAVE_METADATA) {
- silencePromise(this.el_.play());
- this.setTimeout(function() {
- video.pause();
- try {
- video.webkitEnterFullScreen();
- } catch (e) {
- this.trigger("fullscreenerror", e);
- }
- }, 0);
- } else {
- try {
- video.webkitEnterFullScreen();
- } catch (e) {
- this.trigger("fullscreenerror", e);
- }
- }
- };
- _proto.exitFullScreen = function exitFullScreen() {
- if (!this.el_.webkitDisplayingFullscreen) {
- this.trigger("fullscreenerror", new Error("The video is not fullscreen"));
- return;
- }
- this.el_.webkitExitFullScreen();
- };
- _proto.requestPictureInPicture = function requestPictureInPicture() {
- return this.el_.requestPictureInPicture();
- };
- _proto.requestVideoFrameCallback = function requestVideoFrameCallback(cb) {
- if (this.featuresVideoFrameCallback && !this.el_.webkitKeys) {
- return this.el_.requestVideoFrameCallback(cb);
- }
- return _Tech.prototype.requestVideoFrameCallback.call(this, cb);
- };
- _proto.cancelVideoFrameCallback = function cancelVideoFrameCallback(id) {
- if (this.featuresVideoFrameCallback && !this.el_.webkitKeys) {
- this.el_.cancelVideoFrameCallback(id);
- } else {
- _Tech.prototype.cancelVideoFrameCallback.call(this, id);
- }
- };
- _proto.src = function src(_src) {
- if (_src === void 0) {
- return this.el_.src;
- }
- this.setSrc(_src);
- };
- _proto.reset = function reset3() {
- Html52.resetMediaElement(this.el_);
- };
- _proto.currentSrc = function currentSrc() {
- if (this.currentSource_) {
- return this.currentSource_.src;
- }
- return this.el_.currentSrc;
- };
- _proto.setControls = function setControls(val) {
- this.el_.controls = !!val;
- };
- _proto.addTextTrack = function addTextTrack(kind, label2, language) {
- if (!this.featuresNativeTextTracks) {
- return _Tech.prototype.addTextTrack.call(this, kind, label2, language);
- }
- return this.el_.addTextTrack(kind, label2, language);
- };
- _proto.createRemoteTextTrack = function createRemoteTextTrack(options2) {
- if (!this.featuresNativeTextTracks) {
- return _Tech.prototype.createRemoteTextTrack.call(this, options2);
- }
- var htmlTrackElement = document_1.createElement("track");
- if (options2.kind) {
- htmlTrackElement.kind = options2.kind;
- }
- if (options2.label) {
- htmlTrackElement.label = options2.label;
- }
- if (options2.language || options2.srclang) {
- htmlTrackElement.srclang = options2.language || options2.srclang;
- }
- if (options2["default"]) {
- htmlTrackElement["default"] = options2["default"];
- }
- if (options2.id) {
- htmlTrackElement.id = options2.id;
- }
- if (options2.src) {
- htmlTrackElement.src = options2.src;
- }
- return htmlTrackElement;
- };
- _proto.addRemoteTextTrack = function addRemoteTextTrack(options2, manualCleanup) {
- var htmlTrackElement = _Tech.prototype.addRemoteTextTrack.call(this, options2, manualCleanup);
- if (this.featuresNativeTextTracks) {
- this.el().appendChild(htmlTrackElement);
- }
- return htmlTrackElement;
- };
- _proto.removeRemoteTextTrack = function removeRemoteTextTrack(track) {
- _Tech.prototype.removeRemoteTextTrack.call(this, track);
- if (this.featuresNativeTextTracks) {
- var tracks = this.$$("track");
- var i2 = tracks.length;
- while (i2--) {
- if (track === tracks[i2] || track === tracks[i2].track) {
- this.el().removeChild(tracks[i2]);
- }
- }
- }
- };
- _proto.getVideoPlaybackQuality = function getVideoPlaybackQuality() {
- if (typeof this.el().getVideoPlaybackQuality === "function") {
- return this.el().getVideoPlaybackQuality();
- }
- var videoPlaybackQuality = {};
- if (typeof this.el().webkitDroppedFrameCount !== "undefined" && typeof this.el().webkitDecodedFrameCount !== "undefined") {
- videoPlaybackQuality.droppedVideoFrames = this.el().webkitDroppedFrameCount;
- videoPlaybackQuality.totalVideoFrames = this.el().webkitDecodedFrameCount;
- }
- if (window_1.performance && typeof window_1.performance.now === "function") {
- videoPlaybackQuality.creationTime = window_1.performance.now();
- } else if (window_1.performance && window_1.performance.timing && typeof window_1.performance.timing.navigationStart === "number") {
- videoPlaybackQuality.creationTime = window_1.Date.now() - window_1.performance.timing.navigationStart;
- }
- return videoPlaybackQuality;
- };
- return Html52;
- }(Tech$1);
- defineLazyProperty(Html5$1, "TEST_VID", function() {
- if (!isReal()) {
- return;
- }
- var video = document_1.createElement("video");
- var track = document_1.createElement("track");
- track.kind = "captions";
- track.srclang = "en";
- track.label = "English";
- video.appendChild(track);
- return video;
- });
- Html5$1.isSupported = function() {
- try {
- Html5$1.TEST_VID.volume = 0.5;
- } catch (e) {
- return false;
- }
- return !!(Html5$1.TEST_VID && Html5$1.TEST_VID.canPlayType);
- };
- Html5$1.canPlayType = function(type2) {
- return Html5$1.TEST_VID.canPlayType(type2);
- };
- Html5$1.canPlaySource = function(srcObj, options2) {
- return Html5$1.canPlayType(srcObj.type);
- };
- Html5$1.canControlVolume = function() {
- try {
- var volume = Html5$1.TEST_VID.volume;
- Html5$1.TEST_VID.volume = volume / 2 + 0.1;
- var canControl = volume !== Html5$1.TEST_VID.volume;
- if (canControl && IS_IOS) {
- window_1.setTimeout(function() {
- if (Html5$1 && Html5$1.prototype) {
- Html5$1.prototype.featuresVolumeControl = volume !== Html5$1.TEST_VID.volume;
- }
- });
- return false;
- }
- return canControl;
- } catch (e) {
- return false;
- }
- };
- Html5$1.canMuteVolume = function() {
- try {
- var muted = Html5$1.TEST_VID.muted;
- Html5$1.TEST_VID.muted = !muted;
- if (Html5$1.TEST_VID.muted) {
- setAttribute(Html5$1.TEST_VID, "muted", "muted");
- } else {
- removeAttribute(Html5$1.TEST_VID, "muted", "muted");
- }
- return muted !== Html5$1.TEST_VID.muted;
- } catch (e) {
- return false;
- }
- };
- Html5$1.canControlPlaybackRate = function() {
- if (IS_ANDROID && IS_CHROME && CHROME_VERSION < 58) {
- return false;
- }
- try {
- var playbackRate = Html5$1.TEST_VID.playbackRate;
- Html5$1.TEST_VID.playbackRate = playbackRate / 2 + 0.1;
- return playbackRate !== Html5$1.TEST_VID.playbackRate;
- } catch (e) {
- return false;
- }
- };
- Html5$1.canOverrideAttributes = function() {
- try {
- var noop2 = function noop3() {
- };
- Object.defineProperty(document_1.createElement("video"), "src", {
- get: noop2,
- set: noop2
- });
- Object.defineProperty(document_1.createElement("audio"), "src", {
- get: noop2,
- set: noop2
- });
- Object.defineProperty(document_1.createElement("video"), "innerHTML", {
- get: noop2,
- set: noop2
- });
- Object.defineProperty(document_1.createElement("audio"), "innerHTML", {
- get: noop2,
- set: noop2
- });
- } catch (e) {
- return false;
- }
- return true;
- };
- Html5$1.supportsNativeTextTracks = function() {
- return IS_ANY_SAFARI || IS_IOS && IS_CHROME;
- };
- Html5$1.supportsNativeVideoTracks = function() {
- return !!(Html5$1.TEST_VID && Html5$1.TEST_VID.videoTracks);
- };
- Html5$1.supportsNativeAudioTracks = function() {
- return !!(Html5$1.TEST_VID && Html5$1.TEST_VID.audioTracks);
- };
- Html5$1.Events = ["loadstart", "suspend", "abort", "error", "emptied", "stalled", "loadedmetadata", "loadeddata", "canplay", "canplaythrough", "playing", "waiting", "seeking", "seeked", "ended", "durationchange", "timeupdate", "progress", "play", "pause", "ratechange", "resize", "volumechange"];
- [["featuresMuteControl", "canMuteVolume"], ["featuresPlaybackRate", "canControlPlaybackRate"], ["featuresSourceset", "canOverrideAttributes"], ["featuresNativeTextTracks", "supportsNativeTextTracks"], ["featuresNativeVideoTracks", "supportsNativeVideoTracks"], ["featuresNativeAudioTracks", "supportsNativeAudioTracks"]].forEach(function(_ref) {
- var key = _ref[0], fn2 = _ref[1];
- defineLazyProperty(Html5$1.prototype, key, function() {
- return Html5$1[fn2]();
- }, true);
- });
- Html5$1.prototype.featuresVolumeControl = Html5$1.canControlVolume();
- Html5$1.prototype.movingMediaElementInDOM = !IS_IOS;
- Html5$1.prototype.featuresFullscreenResize = true;
- Html5$1.prototype.featuresProgressEvents = true;
- Html5$1.prototype.featuresTimeupdateEvents = true;
- Html5$1.prototype.featuresVideoFrameCallback = !!(Html5$1.TEST_VID && Html5$1.TEST_VID.requestVideoFrameCallback);
- var canPlayType;
- Html5$1.patchCanPlayType = function() {
- if (ANDROID_VERSION >= 4 && !IS_FIREFOX && !IS_CHROME) {
- canPlayType = Html5$1.TEST_VID && Html5$1.TEST_VID.constructor.prototype.canPlayType;
- Html5$1.TEST_VID.constructor.prototype.canPlayType = function(type2) {
- var mpegurlRE = /^application\/(?:x-|vnd\.apple\.)mpegurl/i;
- if (type2 && mpegurlRE.test(type2)) {
- return "maybe";
- }
- return canPlayType.call(this, type2);
- };
- }
- };
- Html5$1.unpatchCanPlayType = function() {
- var r2 = Html5$1.TEST_VID.constructor.prototype.canPlayType;
- if (canPlayType) {
- Html5$1.TEST_VID.constructor.prototype.canPlayType = canPlayType;
- }
- return r2;
- };
- Html5$1.patchCanPlayType();
- Html5$1.disposeMediaElement = function(el) {
- if (!el) {
- return;
- }
- if (el.parentNode) {
- el.parentNode.removeChild(el);
- }
- while (el.hasChildNodes()) {
- el.removeChild(el.firstChild);
- }
- el.removeAttribute("src");
- if (typeof el.load === "function") {
- (function() {
- try {
- el.load();
- } catch (e) {
- }
- })();
- }
- };
- Html5$1.resetMediaElement = function(el) {
- if (!el) {
- return;
- }
- var sources = el.querySelectorAll("source");
- var i2 = sources.length;
- while (i2--) {
- el.removeChild(sources[i2]);
- }
- el.removeAttribute("src");
- if (typeof el.load === "function") {
- (function() {
- try {
- el.load();
- } catch (e) {
- }
- })();
- }
- };
- [
- "muted",
- "defaultMuted",
- "autoplay",
- "controls",
- "loop",
- "playsinline"
- ].forEach(function(prop) {
- Html5$1.prototype[prop] = function() {
- return this.el_[prop] || this.el_.hasAttribute(prop);
- };
- });
- [
- "muted",
- "defaultMuted",
- "autoplay",
- "loop",
- "playsinline"
- ].forEach(function(prop) {
- Html5$1.prototype["set" + toTitleCase$1(prop)] = function(v) {
- this.el_[prop] = v;
- if (v) {
- this.el_.setAttribute(prop, prop);
- } else {
- this.el_.removeAttribute(prop);
- }
- };
- });
- [
- "paused",
- "currentTime",
- "buffered",
- "volume",
- "poster",
- "preload",
- "error",
- "seeking",
- "seekable",
- "ended",
- "playbackRate",
- "defaultPlaybackRate",
- "disablePictureInPicture",
- "played",
- "networkState",
- "readyState",
- "videoWidth",
- "videoHeight",
- "crossOrigin"
- ].forEach(function(prop) {
- Html5$1.prototype[prop] = function() {
- return this.el_[prop];
- };
- });
- [
- "volume",
- "src",
- "poster",
- "preload",
- "playbackRate",
- "defaultPlaybackRate",
- "disablePictureInPicture",
- "crossOrigin"
- ].forEach(function(prop) {
- Html5$1.prototype["set" + toTitleCase$1(prop)] = function(v) {
- this.el_[prop] = v;
- };
- });
- [
- "pause",
- "load",
- "play"
- ].forEach(function(prop) {
- Html5$1.prototype[prop] = function() {
- return this.el_[prop]();
- };
- });
- Tech$1.withSourceHandlers(Html5$1);
- Html5$1.nativeSourceHandler = {};
- Html5$1.nativeSourceHandler.canPlayType = function(type2) {
- try {
- return Html5$1.TEST_VID.canPlayType(type2);
- } catch (e) {
- return "";
- }
- };
- Html5$1.nativeSourceHandler.canHandleSource = function(source, options2) {
- if (source.type) {
- return Html5$1.nativeSourceHandler.canPlayType(source.type);
- } else if (source.src) {
- var ext = getFileExtension(source.src);
- return Html5$1.nativeSourceHandler.canPlayType("video/" + ext);
- }
- return "";
- };
- Html5$1.nativeSourceHandler.handleSource = function(source, tech, options2) {
- tech.setSrc(source.src);
- };
- Html5$1.nativeSourceHandler.dispose = function() {
- };
- Html5$1.registerSourceHandler(Html5$1.nativeSourceHandler);
- Tech$1.registerTech("Html5", Html5$1);
- var TECH_EVENTS_RETRIGGER = [
- "progress",
- "abort",
- "suspend",
- "emptied",
- "stalled",
- "loadedmetadata",
- "loadeddata",
- "timeupdate",
- "resize",
- "volumechange",
- "texttrackchange"
- ];
- var TECH_EVENTS_QUEUE = {
- canplay: "CanPlay",
- canplaythrough: "CanPlayThrough",
- playing: "Playing",
- seeked: "Seeked"
- };
- var BREAKPOINT_ORDER = ["tiny", "xsmall", "small", "medium", "large", "xlarge", "huge"];
- var BREAKPOINT_CLASSES = {};
- BREAKPOINT_ORDER.forEach(function(k) {
- var v = k.charAt(0) === "x" ? "x-" + k.substring(1) : k;
- BREAKPOINT_CLASSES[k] = "vjs-layout-" + v;
- });
- var DEFAULT_BREAKPOINTS = {
- tiny: 210,
- xsmall: 320,
- small: 425,
- medium: 768,
- large: 1440,
- xlarge: 2560,
- huge: Infinity
- };
- var Player = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(Player2, _Component);
- function Player2(tag, options2, ready) {
- var _this;
- tag.id = tag.id || options2.id || "vjs_video_" + newGUID();
- options2 = assign(Player2.getTagSettings(tag), options2);
- options2.initChildren = false;
- options2.createEl = false;
- options2.evented = false;
- options2.reportTouchActivity = false;
- if (!options2.language) {
- if (typeof tag.closest === "function") {
- var closest = tag.closest("[lang]");
- if (closest && closest.getAttribute) {
- options2.language = closest.getAttribute("lang");
- }
- } else {
- var element = tag;
- while (element && element.nodeType === 1) {
- if (getAttributes(element).hasOwnProperty("lang")) {
- options2.language = element.getAttribute("lang");
- break;
- }
- element = element.parentNode;
- }
- }
- }
- _this = _Component.call(this, null, options2, ready) || this;
- _this.boundDocumentFullscreenChange_ = function(e) {
- return _this.documentFullscreenChange_(e);
- };
- _this.boundFullWindowOnEscKey_ = function(e) {
- return _this.fullWindowOnEscKey(e);
- };
- _this.boundUpdateStyleEl_ = function(e) {
- return _this.updateStyleEl_(e);
- };
- _this.boundApplyInitTime_ = function(e) {
- return _this.applyInitTime_(e);
- };
- _this.boundUpdateCurrentBreakpoint_ = function(e) {
- return _this.updateCurrentBreakpoint_(e);
- };
- _this.boundHandleTechClick_ = function(e) {
- return _this.handleTechClick_(e);
- };
- _this.boundHandleTechDoubleClick_ = function(e) {
- return _this.handleTechDoubleClick_(e);
- };
- _this.boundHandleTechTouchStart_ = function(e) {
- return _this.handleTechTouchStart_(e);
- };
- _this.boundHandleTechTouchMove_ = function(e) {
- return _this.handleTechTouchMove_(e);
- };
- _this.boundHandleTechTouchEnd_ = function(e) {
- return _this.handleTechTouchEnd_(e);
- };
- _this.boundHandleTechTap_ = function(e) {
- return _this.handleTechTap_(e);
- };
- _this.isFullscreen_ = false;
- _this.log = createLogger(_this.id_);
- _this.fsApi_ = FullscreenApi;
- _this.isPosterFromTech_ = false;
- _this.queuedCallbacks_ = [];
- _this.isReady_ = false;
- _this.hasStarted_ = false;
- _this.userActive_ = false;
- _this.debugEnabled_ = false;
- _this.audioOnlyMode_ = false;
- _this.audioPosterMode_ = false;
- _this.audioOnlyCache_ = {
- playerHeight: null,
- hiddenChildren: []
- };
- if (!_this.options_ || !_this.options_.techOrder || !_this.options_.techOrder.length) {
- throw new Error("No techOrder specified. Did you overwrite videojs.options instead of just changing the properties you want to override?");
- }
- _this.tag = tag;
- _this.tagAttributes = tag && getAttributes(tag);
- _this.language(_this.options_.language);
- if (options2.languages) {
- var languagesToLower = {};
- Object.getOwnPropertyNames(options2.languages).forEach(function(name) {
- languagesToLower[name.toLowerCase()] = options2.languages[name];
- });
- _this.languages_ = languagesToLower;
- } else {
- _this.languages_ = Player2.prototype.options_.languages;
- }
- _this.resetCache_();
- _this.poster_ = options2.poster || "";
- _this.controls_ = !!options2.controls;
- tag.controls = false;
- tag.removeAttribute("controls");
- _this.changingSrc_ = false;
- _this.playCallbacks_ = [];
- _this.playTerminatedQueue_ = [];
- if (tag.hasAttribute("autoplay")) {
- _this.autoplay(true);
- } else {
- _this.autoplay(_this.options_.autoplay);
- }
- if (options2.plugins) {
- Object.keys(options2.plugins).forEach(function(name) {
- if (typeof _this[name] !== "function") {
- throw new Error('plugin "' + name + '" does not exist');
- }
- });
- }
- _this.scrubbing_ = false;
- _this.el_ = _this.createEl();
- evented(_assertThisInitialized(_this), {
- eventBusKey: "el_"
- });
- if (_this.fsApi_.requestFullscreen) {
- on(document_1, _this.fsApi_.fullscreenchange, _this.boundDocumentFullscreenChange_);
- _this.on(_this.fsApi_.fullscreenchange, _this.boundDocumentFullscreenChange_);
- }
- if (_this.fluid_) {
- _this.on(["playerreset", "resize"], _this.boundUpdateStyleEl_);
- }
- var playerOptionsCopy = mergeOptions$3(_this.options_);
- if (options2.plugins) {
- Object.keys(options2.plugins).forEach(function(name) {
- _this[name](options2.plugins[name]);
- });
- }
- if (options2.debug) {
- _this.debug(true);
- }
- _this.options_.playerOptions = playerOptionsCopy;
- _this.middleware_ = [];
- _this.playbackRates(options2.playbackRates);
- _this.initChildren();
- _this.isAudio(tag.nodeName.toLowerCase() === "audio");
- if (_this.controls()) {
- _this.addClass("vjs-controls-enabled");
- } else {
- _this.addClass("vjs-controls-disabled");
- }
- _this.el_.setAttribute("role", "region");
- if (_this.isAudio()) {
- _this.el_.setAttribute("aria-label", _this.localize("Audio Player"));
- } else {
- _this.el_.setAttribute("aria-label", _this.localize("Video Player"));
- }
- if (_this.isAudio()) {
- _this.addClass("vjs-audio");
- }
- if (_this.flexNotSupported_()) {
- _this.addClass("vjs-no-flex");
- }
- if (TOUCH_ENABLED) {
- _this.addClass("vjs-touch-enabled");
- }
- if (!IS_IOS) {
- _this.addClass("vjs-workinghover");
- }
- Player2.players[_this.id_] = _assertThisInitialized(_this);
- var majorVersion = version$5.split(".")[0];
- _this.addClass("vjs-v" + majorVersion);
- _this.userActive(true);
- _this.reportUserActivity();
- _this.one("play", function(e) {
- return _this.listenForUserActivity_(e);
- });
- _this.on("stageclick", function(e) {
- return _this.handleStageClick_(e);
- });
- _this.on("keydown", function(e) {
- return _this.handleKeyDown(e);
- });
- _this.on("languagechange", function(e) {
- return _this.handleLanguagechange(e);
- });
- _this.breakpoints(_this.options_.breakpoints);
- _this.responsive(_this.options_.responsive);
- _this.on("ready", function() {
- _this.audioPosterMode(_this.options_.audioPosterMode);
- _this.audioOnlyMode(_this.options_.audioOnlyMode);
- });
- return _this;
- }
- var _proto = Player2.prototype;
- _proto.dispose = function dispose() {
- var _this2 = this;
- this.trigger("dispose");
- this.off("dispose");
- off(document_1, this.fsApi_.fullscreenchange, this.boundDocumentFullscreenChange_);
- off(document_1, "keydown", this.boundFullWindowOnEscKey_);
- if (this.styleEl_ && this.styleEl_.parentNode) {
- this.styleEl_.parentNode.removeChild(this.styleEl_);
- this.styleEl_ = null;
- }
- Player2.players[this.id_] = null;
- if (this.tag && this.tag.player) {
- this.tag.player = null;
- }
- if (this.el_ && this.el_.player) {
- this.el_.player = null;
- }
- if (this.tech_) {
- this.tech_.dispose();
- this.isPosterFromTech_ = false;
- this.poster_ = "";
- }
- if (this.playerElIngest_) {
- this.playerElIngest_ = null;
- }
- if (this.tag) {
- this.tag = null;
- }
- clearCacheForPlayer(this);
- ALL.names.forEach(function(name) {
- var props = ALL[name];
- var list = _this2[props.getterName]();
- if (list && list.off) {
- list.off();
- }
- });
- _Component.prototype.dispose.call(this, {
- restoreEl: this.options_.restoreEl
- });
- };
- _proto.createEl = function createEl2() {
- var tag = this.tag;
- var el;
- var playerElIngest = this.playerElIngest_ = tag.parentNode && tag.parentNode.hasAttribute && tag.parentNode.hasAttribute("data-vjs-player");
- var divEmbed = this.tag.tagName.toLowerCase() === "video-js";
- if (playerElIngest) {
- el = this.el_ = tag.parentNode;
- } else if (!divEmbed) {
- el = this.el_ = _Component.prototype.createEl.call(this, "div");
- }
- var attrs = getAttributes(tag);
- if (divEmbed) {
- el = this.el_ = tag;
- tag = this.tag = document_1.createElement("video");
- while (el.children.length) {
- tag.appendChild(el.firstChild);
- }
- if (!hasClass(el, "video-js")) {
- addClass(el, "video-js");
- }
- el.appendChild(tag);
- playerElIngest = this.playerElIngest_ = el;
- Object.keys(el).forEach(function(k) {
- try {
- tag[k] = el[k];
- } catch (e) {
- }
- });
- }
- tag.setAttribute("tabindex", "-1");
- attrs.tabindex = "-1";
- if (IE_VERSION || IS_CHROME && IS_WINDOWS) {
- tag.setAttribute("role", "application");
- attrs.role = "application";
- }
- tag.removeAttribute("width");
- tag.removeAttribute("height");
- if ("width" in attrs) {
- delete attrs.width;
- }
- if ("height" in attrs) {
- delete attrs.height;
- }
- Object.getOwnPropertyNames(attrs).forEach(function(attr) {
- if (!(divEmbed && attr === "class")) {
- el.setAttribute(attr, attrs[attr]);
- }
- if (divEmbed) {
- tag.setAttribute(attr, attrs[attr]);
- }
- });
- tag.playerId = tag.id;
- tag.id += "_html5_api";
- tag.className = "vjs-tech";
- tag.player = el.player = this;
- this.addClass("vjs-paused");
- if (window_1.VIDEOJS_NO_DYNAMIC_STYLE !== true) {
- this.styleEl_ = createStyleElement("vjs-styles-dimensions");
- var defaultsStyleEl = $(".vjs-styles-defaults");
- var head = $("head");
- head.insertBefore(this.styleEl_, defaultsStyleEl ? defaultsStyleEl.nextSibling : head.firstChild);
- }
- this.fill_ = false;
- this.fluid_ = false;
- this.width(this.options_.width);
- this.height(this.options_.height);
- this.fill(this.options_.fill);
- this.fluid(this.options_.fluid);
- this.aspectRatio(this.options_.aspectRatio);
- this.crossOrigin(this.options_.crossOrigin || this.options_.crossorigin);
- var links = tag.getElementsByTagName("a");
- for (var i2 = 0; i2 < links.length; i2++) {
- var linkEl = links.item(i2);
- addClass(linkEl, "vjs-hidden");
- linkEl.setAttribute("hidden", "hidden");
- }
- tag.initNetworkState_ = tag.networkState;
- if (tag.parentNode && !playerElIngest) {
- tag.parentNode.insertBefore(el, tag);
- }
- prependTo(tag, el);
- this.children_.unshift(tag);
- this.el_.setAttribute("lang", this.language_);
- this.el_.setAttribute("translate", "no");
- this.el_ = el;
- return el;
- };
- _proto.crossOrigin = function crossOrigin(value) {
- if (!value) {
- return this.techGet_("crossOrigin");
- }
- if (value !== "anonymous" && value !== "use-credentials") {
- log$1.warn('crossOrigin must be "anonymous" or "use-credentials", given "' + value + '"');
- return;
- }
- this.techCall_("setCrossOrigin", value);
- return;
- };
- _proto.width = function width2(value) {
- return this.dimension("width", value);
- };
- _proto.height = function height2(value) {
- return this.dimension("height", value);
- };
- _proto.dimension = function dimension(_dimension, value) {
- var privDimension = _dimension + "_";
- if (value === void 0) {
- return this[privDimension] || 0;
- }
- if (value === "" || value === "auto") {
- this[privDimension] = void 0;
- this.updateStyleEl_();
- return;
- }
- var parsedVal = parseFloat(value);
- if (isNaN(parsedVal)) {
- log$1.error('Improper value "' + value + '" supplied for for ' + _dimension);
- return;
- }
- this[privDimension] = parsedVal;
- this.updateStyleEl_();
- };
- _proto.fluid = function fluid(bool) {
- var _this3 = this;
- if (bool === void 0) {
- return !!this.fluid_;
- }
- this.fluid_ = !!bool;
- if (isEvented(this)) {
- this.off(["playerreset", "resize"], this.boundUpdateStyleEl_);
- }
- if (bool) {
- this.addClass("vjs-fluid");
- this.fill(false);
- addEventedCallback(this, function() {
- _this3.on(["playerreset", "resize"], _this3.boundUpdateStyleEl_);
- });
- } else {
- this.removeClass("vjs-fluid");
- }
- this.updateStyleEl_();
- };
- _proto.fill = function fill(bool) {
- if (bool === void 0) {
- return !!this.fill_;
- }
- this.fill_ = !!bool;
- if (bool) {
- this.addClass("vjs-fill");
- this.fluid(false);
- } else {
- this.removeClass("vjs-fill");
- }
- };
- _proto.aspectRatio = function aspectRatio(ratio) {
- if (ratio === void 0) {
- return this.aspectRatio_;
- }
- if (!/^\d+\:\d+$/.test(ratio)) {
- throw new Error("Improper value supplied for aspect ratio. The format should be width:height, for example 16:9.");
- }
- this.aspectRatio_ = ratio;
- this.fluid(true);
- this.updateStyleEl_();
- };
- _proto.updateStyleEl_ = function updateStyleEl_() {
- if (window_1.VIDEOJS_NO_DYNAMIC_STYLE === true) {
- var _width = typeof this.width_ === "number" ? this.width_ : this.options_.width;
- var _height = typeof this.height_ === "number" ? this.height_ : this.options_.height;
- var techEl = this.tech_ && this.tech_.el();
- if (techEl) {
- if (_width >= 0) {
- techEl.width = _width;
- }
- if (_height >= 0) {
- techEl.height = _height;
- }
- }
- return;
- }
- var width2;
- var height2;
- var aspectRatio;
- var idClass;
- if (this.aspectRatio_ !== void 0 && this.aspectRatio_ !== "auto") {
- aspectRatio = this.aspectRatio_;
- } else if (this.videoWidth() > 0) {
- aspectRatio = this.videoWidth() + ":" + this.videoHeight();
- } else {
- aspectRatio = "16:9";
- }
- var ratioParts = aspectRatio.split(":");
- var ratioMultiplier = ratioParts[1] / ratioParts[0];
- if (this.width_ !== void 0) {
- width2 = this.width_;
- } else if (this.height_ !== void 0) {
- width2 = this.height_ / ratioMultiplier;
- } else {
- width2 = this.videoWidth() || 300;
- }
- if (this.height_ !== void 0) {
- height2 = this.height_;
- } else {
- height2 = width2 * ratioMultiplier;
- }
- if (/^[^a-zA-Z]/.test(this.id())) {
- idClass = "dimensions-" + this.id();
- } else {
- idClass = this.id() + "-dimensions";
- }
- this.addClass(idClass);
- setTextContent(this.styleEl_, "\n ." + idClass + " {\n width: " + width2 + "px;\n height: " + height2 + "px;\n }\n\n ." + idClass + ".vjs-fluid:not(.vjs-audio-only-mode) {\n padding-top: " + ratioMultiplier * 100 + "%;\n }\n ");
- };
- _proto.loadTech_ = function loadTech_(techName, source) {
- var _this4 = this;
- if (this.tech_) {
- this.unloadTech_();
- }
- var titleTechName = toTitleCase$1(techName);
- var camelTechName = techName.charAt(0).toLowerCase() + techName.slice(1);
- if (titleTechName !== "Html5" && this.tag) {
- Tech$1.getTech("Html5").disposeMediaElement(this.tag);
- this.tag.player = null;
- this.tag = null;
- }
- this.techName_ = titleTechName;
- this.isReady_ = false;
- var autoplay = this.autoplay();
- if (typeof this.autoplay() === "string" || this.autoplay() === true && this.options_.normalizeAutoplay) {
- autoplay = false;
- }
- var techOptions = {
- source,
- autoplay,
- "nativeControlsForTouch": this.options_.nativeControlsForTouch,
- "playerId": this.id(),
- "techId": this.id() + "_" + camelTechName + "_api",
- "playsinline": this.options_.playsinline,
- "preload": this.options_.preload,
- "loop": this.options_.loop,
- "disablePictureInPicture": this.options_.disablePictureInPicture,
- "muted": this.options_.muted,
- "poster": this.poster(),
- "language": this.language(),
- "playerElIngest": this.playerElIngest_ || false,
- "vtt.js": this.options_["vtt.js"],
- "canOverridePoster": !!this.options_.techCanOverridePoster,
- "enableSourceset": this.options_.enableSourceset,
- "Promise": this.options_.Promise
- };
- ALL.names.forEach(function(name) {
- var props = ALL[name];
- techOptions[props.getterName] = _this4[props.privateName];
- });
- assign(techOptions, this.options_[titleTechName]);
- assign(techOptions, this.options_[camelTechName]);
- assign(techOptions, this.options_[techName.toLowerCase()]);
- if (this.tag) {
- techOptions.tag = this.tag;
- }
- if (source && source.src === this.cache_.src && this.cache_.currentTime > 0) {
- techOptions.startTime = this.cache_.currentTime;
- }
- var TechClass = Tech$1.getTech(techName);
- if (!TechClass) {
- throw new Error("No Tech named '" + titleTechName + "' exists! '" + titleTechName + "' should be registered using videojs.registerTech()'");
- }
- this.tech_ = new TechClass(techOptions);
- this.tech_.ready(bind(this, this.handleTechReady_), true);
- textTrackConverter.jsonToTextTracks(this.textTracksJson_ || [], this.tech_);
- TECH_EVENTS_RETRIGGER.forEach(function(event2) {
- _this4.on(_this4.tech_, event2, function(e) {
- return _this4["handleTech" + toTitleCase$1(event2) + "_"](e);
- });
- });
- Object.keys(TECH_EVENTS_QUEUE).forEach(function(event2) {
- _this4.on(_this4.tech_, event2, function(eventObj) {
- if (_this4.tech_.playbackRate() === 0 && _this4.tech_.seeking()) {
- _this4.queuedCallbacks_.push({
- callback: _this4["handleTech" + TECH_EVENTS_QUEUE[event2] + "_"].bind(_this4),
- event: eventObj
- });
- return;
- }
- _this4["handleTech" + TECH_EVENTS_QUEUE[event2] + "_"](eventObj);
- });
- });
- this.on(this.tech_, "loadstart", function(e) {
- return _this4.handleTechLoadStart_(e);
- });
- this.on(this.tech_, "sourceset", function(e) {
- return _this4.handleTechSourceset_(e);
- });
- this.on(this.tech_, "waiting", function(e) {
- return _this4.handleTechWaiting_(e);
- });
- this.on(this.tech_, "ended", function(e) {
- return _this4.handleTechEnded_(e);
- });
- this.on(this.tech_, "seeking", function(e) {
- return _this4.handleTechSeeking_(e);
- });
- this.on(this.tech_, "play", function(e) {
- return _this4.handleTechPlay_(e);
- });
- this.on(this.tech_, "firstplay", function(e) {
- return _this4.handleTechFirstPlay_(e);
- });
- this.on(this.tech_, "pause", function(e) {
- return _this4.handleTechPause_(e);
- });
- this.on(this.tech_, "durationchange", function(e) {
- return _this4.handleTechDurationChange_(e);
- });
- this.on(this.tech_, "fullscreenchange", function(e, data) {
- return _this4.handleTechFullscreenChange_(e, data);
- });
- this.on(this.tech_, "fullscreenerror", function(e, err) {
- return _this4.handleTechFullscreenError_(e, err);
- });
- this.on(this.tech_, "enterpictureinpicture", function(e) {
- return _this4.handleTechEnterPictureInPicture_(e);
- });
- this.on(this.tech_, "leavepictureinpicture", function(e) {
- return _this4.handleTechLeavePictureInPicture_(e);
- });
- this.on(this.tech_, "error", function(e) {
- return _this4.handleTechError_(e);
- });
- this.on(this.tech_, "posterchange", function(e) {
- return _this4.handleTechPosterChange_(e);
- });
- this.on(this.tech_, "textdata", function(e) {
- return _this4.handleTechTextData_(e);
- });
- this.on(this.tech_, "ratechange", function(e) {
- return _this4.handleTechRateChange_(e);
- });
- this.on(this.tech_, "loadedmetadata", this.boundUpdateStyleEl_);
- this.usingNativeControls(this.techGet_("controls"));
- if (this.controls() && !this.usingNativeControls()) {
- this.addTechControlsListeners_();
- }
- if (this.tech_.el().parentNode !== this.el() && (titleTechName !== "Html5" || !this.tag)) {
- prependTo(this.tech_.el(), this.el());
- }
- if (this.tag) {
- this.tag.player = null;
- this.tag = null;
- }
- };
- _proto.unloadTech_ = function unloadTech_() {
- var _this5 = this;
- ALL.names.forEach(function(name) {
- var props = ALL[name];
- _this5[props.privateName] = _this5[props.getterName]();
- });
- this.textTracksJson_ = textTrackConverter.textTracksToJson(this.tech_);
- this.isReady_ = false;
- this.tech_.dispose();
- this.tech_ = false;
- if (this.isPosterFromTech_) {
- this.poster_ = "";
- this.trigger("posterchange");
- }
- this.isPosterFromTech_ = false;
- };
- _proto.tech = function tech(safety) {
- if (safety === void 0) {
- log$1.warn("Using the tech directly can be dangerous. I hope you know what you're doing.\nSee https://github.com/videojs/video.js/issues/2617 for more info.\n");
- }
- return this.tech_;
- };
- _proto.addTechControlsListeners_ = function addTechControlsListeners_() {
- this.removeTechControlsListeners_();
- this.on(this.tech_, "click", this.boundHandleTechClick_);
- this.on(this.tech_, "dblclick", this.boundHandleTechDoubleClick_);
- this.on(this.tech_, "touchstart", this.boundHandleTechTouchStart_);
- this.on(this.tech_, "touchmove", this.boundHandleTechTouchMove_);
- this.on(this.tech_, "touchend", this.boundHandleTechTouchEnd_);
- this.on(this.tech_, "tap", this.boundHandleTechTap_);
- };
- _proto.removeTechControlsListeners_ = function removeTechControlsListeners_() {
- this.off(this.tech_, "tap", this.boundHandleTechTap_);
- this.off(this.tech_, "touchstart", this.boundHandleTechTouchStart_);
- this.off(this.tech_, "touchmove", this.boundHandleTechTouchMove_);
- this.off(this.tech_, "touchend", this.boundHandleTechTouchEnd_);
- this.off(this.tech_, "click", this.boundHandleTechClick_);
- this.off(this.tech_, "dblclick", this.boundHandleTechDoubleClick_);
- };
- _proto.handleTechReady_ = function handleTechReady_() {
- this.triggerReady();
- if (this.cache_.volume) {
- this.techCall_("setVolume", this.cache_.volume);
- }
- this.handleTechPosterChange_();
- this.handleTechDurationChange_();
- };
- _proto.handleTechLoadStart_ = function handleTechLoadStart_() {
- this.removeClass("vjs-ended");
- this.removeClass("vjs-seeking");
- this.error(null);
- this.handleTechDurationChange_();
- if (!this.paused()) {
- this.trigger("loadstart");
- this.trigger("firstplay");
- } else {
- this.hasStarted(false);
- this.trigger("loadstart");
- }
- this.manualAutoplay_(this.autoplay() === true && this.options_.normalizeAutoplay ? "play" : this.autoplay());
- };
- _proto.manualAutoplay_ = function manualAutoplay_(type2) {
- var _this6 = this;
- if (!this.tech_ || typeof type2 !== "string") {
- return;
- }
- var resolveMuted = function resolveMuted2() {
- var previouslyMuted = _this6.muted();
- _this6.muted(true);
- var restoreMuted = function restoreMuted2() {
- _this6.muted(previouslyMuted);
- };
- _this6.playTerminatedQueue_.push(restoreMuted);
- var mutedPromise = _this6.play();
- if (!isPromise(mutedPromise)) {
- return;
- }
- return mutedPromise["catch"](function(err) {
- restoreMuted();
- throw new Error("Rejection at manualAutoplay. Restoring muted value. " + (err ? err : ""));
- });
- };
- var promise;
- if (type2 === "any" && !this.muted()) {
- promise = this.play();
- if (isPromise(promise)) {
- promise = promise["catch"](resolveMuted);
- }
- } else if (type2 === "muted" && !this.muted()) {
- promise = resolveMuted();
- } else {
- promise = this.play();
- }
- if (!isPromise(promise)) {
- return;
- }
- return promise.then(function() {
- _this6.trigger({
- type: "autoplay-success",
- autoplay: type2
- });
- })["catch"](function() {
- _this6.trigger({
- type: "autoplay-failure",
- autoplay: type2
- });
- });
- };
- _proto.updateSourceCaches_ = function updateSourceCaches_(srcObj) {
- if (srcObj === void 0) {
- srcObj = "";
- }
- var src = srcObj;
- var type2 = "";
- if (typeof src !== "string") {
- src = srcObj.src;
- type2 = srcObj.type;
- }
- this.cache_.source = this.cache_.source || {};
- this.cache_.sources = this.cache_.sources || [];
- if (src && !type2) {
- type2 = findMimetype(this, src);
- }
- this.cache_.source = mergeOptions$3({}, srcObj, {
- src,
- type: type2
- });
- var matchingSources = this.cache_.sources.filter(function(s) {
- return s.src && s.src === src;
- });
- var sourceElSources = [];
- var sourceEls = this.$$("source");
- var matchingSourceEls = [];
- for (var i2 = 0; i2 < sourceEls.length; i2++) {
- var sourceObj = getAttributes(sourceEls[i2]);
- sourceElSources.push(sourceObj);
- if (sourceObj.src && sourceObj.src === src) {
- matchingSourceEls.push(sourceObj.src);
- }
- }
- if (matchingSourceEls.length && !matchingSources.length) {
- this.cache_.sources = sourceElSources;
- } else if (!matchingSources.length) {
- this.cache_.sources = [this.cache_.source];
- }
- this.cache_.src = src;
- };
- _proto.handleTechSourceset_ = function handleTechSourceset_(event2) {
- var _this7 = this;
- if (!this.changingSrc_) {
- var updateSourceCaches = function updateSourceCaches2(src) {
- return _this7.updateSourceCaches_(src);
- };
- var playerSrc = this.currentSource().src;
- var eventSrc = event2.src;
- if (playerSrc && !/^blob:/.test(playerSrc) && /^blob:/.test(eventSrc)) {
- if (!this.lastSource_ || this.lastSource_.tech !== eventSrc && this.lastSource_.player !== playerSrc) {
- updateSourceCaches = function updateSourceCaches2() {
- };
- }
- }
- updateSourceCaches(eventSrc);
- if (!event2.src) {
- this.tech_.any(["sourceset", "loadstart"], function(e) {
- if (e.type === "sourceset") {
- return;
- }
- var techSrc = _this7.techGet("currentSrc");
- _this7.lastSource_.tech = techSrc;
- _this7.updateSourceCaches_(techSrc);
- });
- }
- }
- this.lastSource_ = {
- player: this.currentSource().src,
- tech: event2.src
- };
- this.trigger({
- src: event2.src,
- type: "sourceset"
- });
- };
- _proto.hasStarted = function hasStarted(request) {
- if (request === void 0) {
- return this.hasStarted_;
- }
- if (request === this.hasStarted_) {
- return;
- }
- this.hasStarted_ = request;
- if (this.hasStarted_) {
- this.addClass("vjs-has-started");
- this.trigger("firstplay");
- } else {
- this.removeClass("vjs-has-started");
- }
- };
- _proto.handleTechPlay_ = function handleTechPlay_() {
- this.removeClass("vjs-ended");
- this.removeClass("vjs-paused");
- this.addClass("vjs-playing");
- this.hasStarted(true);
- this.trigger("play");
- };
- _proto.handleTechRateChange_ = function handleTechRateChange_() {
- if (this.tech_.playbackRate() > 0 && this.cache_.lastPlaybackRate === 0) {
- this.queuedCallbacks_.forEach(function(queued) {
- return queued.callback(queued.event);
- });
- this.queuedCallbacks_ = [];
- }
- this.cache_.lastPlaybackRate = this.tech_.playbackRate();
- this.trigger("ratechange");
- };
- _proto.handleTechWaiting_ = function handleTechWaiting_() {
- var _this8 = this;
- this.addClass("vjs-waiting");
- this.trigger("waiting");
- var timeWhenWaiting = this.currentTime();
- var timeUpdateListener = function timeUpdateListener2() {
- if (timeWhenWaiting !== _this8.currentTime()) {
- _this8.removeClass("vjs-waiting");
- _this8.off("timeupdate", timeUpdateListener2);
- }
- };
- this.on("timeupdate", timeUpdateListener);
- };
- _proto.handleTechCanPlay_ = function handleTechCanPlay_() {
- this.removeClass("vjs-waiting");
- this.trigger("canplay");
- };
- _proto.handleTechCanPlayThrough_ = function handleTechCanPlayThrough_() {
- this.removeClass("vjs-waiting");
- this.trigger("canplaythrough");
- };
- _proto.handleTechPlaying_ = function handleTechPlaying_() {
- this.removeClass("vjs-waiting");
- this.trigger("playing");
- };
- _proto.handleTechSeeking_ = function handleTechSeeking_() {
- this.addClass("vjs-seeking");
- this.trigger("seeking");
- };
- _proto.handleTechSeeked_ = function handleTechSeeked_() {
- this.removeClass("vjs-seeking");
- this.removeClass("vjs-ended");
- this.trigger("seeked");
- };
- _proto.handleTechFirstPlay_ = function handleTechFirstPlay_() {
- if (this.options_.starttime) {
- log$1.warn("Passing the `starttime` option to the player will be deprecated in 6.0");
- this.currentTime(this.options_.starttime);
- }
- this.addClass("vjs-has-started");
- this.trigger("firstplay");
- };
- _proto.handleTechPause_ = function handleTechPause_() {
- this.removeClass("vjs-playing");
- this.addClass("vjs-paused");
- this.trigger("pause");
- };
- _proto.handleTechEnded_ = function handleTechEnded_() {
- this.addClass("vjs-ended");
- this.removeClass("vjs-waiting");
- if (this.options_.loop) {
- this.currentTime(0);
- this.play();
- } else if (!this.paused()) {
- this.pause();
- }
- this.trigger("ended");
- };
- _proto.handleTechDurationChange_ = function handleTechDurationChange_() {
- this.duration(this.techGet_("duration"));
- };
- _proto.handleTechClick_ = function handleTechClick_(event2) {
- if (!this.controls_) {
- return;
- }
- if (this.options_ === void 0 || this.options_.userActions === void 0 || this.options_.userActions.click === void 0 || this.options_.userActions.click !== false) {
- if (this.options_ !== void 0 && this.options_.userActions !== void 0 && typeof this.options_.userActions.click === "function") {
- this.options_.userActions.click.call(this, event2);
- } else if (this.paused()) {
- silencePromise(this.play());
- } else {
- this.pause();
- }
- }
- };
- _proto.handleTechDoubleClick_ = function handleTechDoubleClick_(event2) {
- if (!this.controls_) {
- return;
- }
- var inAllowedEls = Array.prototype.some.call(this.$$(".vjs-control-bar, .vjs-modal-dialog"), function(el) {
- return el.contains(event2.target);
- });
- if (!inAllowedEls) {
- if (this.options_ === void 0 || this.options_.userActions === void 0 || this.options_.userActions.doubleClick === void 0 || this.options_.userActions.doubleClick !== false) {
- if (this.options_ !== void 0 && this.options_.userActions !== void 0 && typeof this.options_.userActions.doubleClick === "function") {
- this.options_.userActions.doubleClick.call(this, event2);
- } else if (this.isFullscreen()) {
- this.exitFullscreen();
- } else {
- this.requestFullscreen();
- }
- }
- }
- };
- _proto.handleTechTap_ = function handleTechTap_() {
- this.userActive(!this.userActive());
- };
- _proto.handleTechTouchStart_ = function handleTechTouchStart_() {
- this.userWasActive = this.userActive();
- };
- _proto.handleTechTouchMove_ = function handleTechTouchMove_() {
- if (this.userWasActive) {
- this.reportUserActivity();
- }
- };
- _proto.handleTechTouchEnd_ = function handleTechTouchEnd_(event2) {
- if (event2.cancelable) {
- event2.preventDefault();
- }
- };
- _proto.handleStageClick_ = function handleStageClick_() {
- this.reportUserActivity();
- };
- _proto.toggleFullscreenClass_ = function toggleFullscreenClass_() {
- if (this.isFullscreen()) {
- this.addClass("vjs-fullscreen");
- } else {
- this.removeClass("vjs-fullscreen");
- }
- };
- _proto.documentFullscreenChange_ = function documentFullscreenChange_(e) {
- var targetPlayer = e.target.player;
- if (targetPlayer && targetPlayer !== this) {
- return;
- }
- var el = this.el();
- var isFs = document_1[this.fsApi_.fullscreenElement] === el;
- if (!isFs && el.matches) {
- isFs = el.matches(":" + this.fsApi_.fullscreen);
- } else if (!isFs && el.msMatchesSelector) {
- isFs = el.msMatchesSelector(":" + this.fsApi_.fullscreen);
- }
- this.isFullscreen(isFs);
- };
- _proto.handleTechFullscreenChange_ = function handleTechFullscreenChange_(event2, data) {
- var _this9 = this;
- if (data) {
- if (data.nativeIOSFullscreen) {
- this.addClass("vjs-ios-native-fs");
- this.tech_.one("webkitendfullscreen", function() {
- _this9.removeClass("vjs-ios-native-fs");
- });
- }
- this.isFullscreen(data.isFullscreen);
- }
- };
- _proto.handleTechFullscreenError_ = function handleTechFullscreenError_(event2, err) {
- this.trigger("fullscreenerror", err);
- };
- _proto.togglePictureInPictureClass_ = function togglePictureInPictureClass_() {
- if (this.isInPictureInPicture()) {
- this.addClass("vjs-picture-in-picture");
- } else {
- this.removeClass("vjs-picture-in-picture");
- }
- };
- _proto.handleTechEnterPictureInPicture_ = function handleTechEnterPictureInPicture_(event2) {
- this.isInPictureInPicture(true);
- };
- _proto.handleTechLeavePictureInPicture_ = function handleTechLeavePictureInPicture_(event2) {
- this.isInPictureInPicture(false);
- };
- _proto.handleTechError_ = function handleTechError_() {
- var error = this.tech_.error();
- this.error(error);
- };
- _proto.handleTechTextData_ = function handleTechTextData_() {
- var data = null;
- if (arguments.length > 1) {
- data = arguments[1];
- }
- this.trigger("textdata", data);
- };
- _proto.getCache = function getCache() {
- return this.cache_;
- };
- _proto.resetCache_ = function resetCache_() {
- this.cache_ = {
- currentTime: 0,
- initTime: 0,
- inactivityTimeout: this.options_.inactivityTimeout,
- duration: NaN,
- lastVolume: 1,
- lastPlaybackRate: this.defaultPlaybackRate(),
- media: null,
- src: "",
- source: {},
- sources: [],
- playbackRates: [],
- volume: 1
- };
- };
- _proto.techCall_ = function techCall_(method, arg) {
- this.ready(function() {
- if (method in allowedSetters) {
- return set(this.middleware_, this.tech_, method, arg);
- } else if (method in allowedMediators) {
- return mediate(this.middleware_, this.tech_, method, arg);
- }
- try {
- if (this.tech_) {
- this.tech_[method](arg);
- }
- } catch (e) {
- log$1(e);
- throw e;
- }
- }, true);
- };
- _proto.techGet_ = function techGet_(method) {
- if (!this.tech_ || !this.tech_.isReady_) {
- return;
- }
- if (method in allowedGetters) {
- return get(this.middleware_, this.tech_, method);
- } else if (method in allowedMediators) {
- return mediate(this.middleware_, this.tech_, method);
- }
- try {
- return this.tech_[method]();
- } catch (e) {
- if (this.tech_[method] === void 0) {
- log$1("Video.js: " + method + " method not defined for " + this.techName_ + " playback technology.", e);
- throw e;
- }
- if (e.name === "TypeError") {
- log$1("Video.js: " + method + " unavailable on " + this.techName_ + " playback technology element.", e);
- this.tech_.isReady_ = false;
- throw e;
- }
- log$1(e);
- throw e;
- }
- };
- _proto.play = function play() {
- var _this10 = this;
- var PromiseClass = this.options_.Promise || window_1.Promise;
- if (PromiseClass) {
- return new PromiseClass(function(resolve2) {
- _this10.play_(resolve2);
- });
- }
- return this.play_();
- };
- _proto.play_ = function play_(callback2) {
- var _this11 = this;
- if (callback2 === void 0) {
- callback2 = silencePromise;
- }
- this.playCallbacks_.push(callback2);
- var isSrcReady = Boolean(!this.changingSrc_ && (this.src() || this.currentSrc()));
- var isSafariOrIOS = Boolean(IS_ANY_SAFARI || IS_IOS);
- if (this.waitToPlay_) {
- this.off(["ready", "loadstart"], this.waitToPlay_);
- this.waitToPlay_ = null;
- }
- if (!this.isReady_ || !isSrcReady) {
- this.waitToPlay_ = function(e) {
- _this11.play_();
- };
- this.one(["ready", "loadstart"], this.waitToPlay_);
- if (!isSrcReady && isSafariOrIOS) {
- this.load();
- }
- return;
- }
- var val = this.techGet_("play");
- var isNativeReplay = isSafariOrIOS && this.hasClass("vjs-ended");
- if (isNativeReplay) {
- this.resetProgressBar_();
- }
- if (val === null) {
- this.runPlayTerminatedQueue_();
- } else {
- this.runPlayCallbacks_(val);
- }
- };
- _proto.runPlayTerminatedQueue_ = function runPlayTerminatedQueue_() {
- var queue = this.playTerminatedQueue_.slice(0);
- this.playTerminatedQueue_ = [];
- queue.forEach(function(q2) {
- q2();
- });
- };
- _proto.runPlayCallbacks_ = function runPlayCallbacks_(val) {
- var callbacks = this.playCallbacks_.slice(0);
- this.playCallbacks_ = [];
- this.playTerminatedQueue_ = [];
- callbacks.forEach(function(cb) {
- cb(val);
- });
- };
- _proto.pause = function pause() {
- this.techCall_("pause");
- };
- _proto.paused = function paused() {
- return this.techGet_("paused") === false ? false : true;
- };
- _proto.played = function played() {
- return this.techGet_("played") || createTimeRanges(0, 0);
- };
- _proto.scrubbing = function scrubbing(isScrubbing) {
- if (typeof isScrubbing === "undefined") {
- return this.scrubbing_;
- }
- this.scrubbing_ = !!isScrubbing;
- this.techCall_("setScrubbing", this.scrubbing_);
- if (isScrubbing) {
- this.addClass("vjs-scrubbing");
- } else {
- this.removeClass("vjs-scrubbing");
- }
- };
- _proto.currentTime = function currentTime(seconds) {
- if (typeof seconds !== "undefined") {
- if (seconds < 0) {
- seconds = 0;
- }
- if (!this.isReady_ || this.changingSrc_ || !this.tech_ || !this.tech_.isReady_) {
- this.cache_.initTime = seconds;
- this.off("canplay", this.boundApplyInitTime_);
- this.one("canplay", this.boundApplyInitTime_);
- return;
- }
- this.techCall_("setCurrentTime", seconds);
- this.cache_.initTime = 0;
- return;
- }
- this.cache_.currentTime = this.techGet_("currentTime") || 0;
- return this.cache_.currentTime;
- };
- _proto.applyInitTime_ = function applyInitTime_() {
- this.currentTime(this.cache_.initTime);
- };
- _proto.duration = function duration5(seconds) {
- if (seconds === void 0) {
- return this.cache_.duration !== void 0 ? this.cache_.duration : NaN;
- }
- seconds = parseFloat(seconds);
- if (seconds < 0) {
- seconds = Infinity;
- }
- if (seconds !== this.cache_.duration) {
- this.cache_.duration = seconds;
- if (seconds === Infinity) {
- this.addClass("vjs-live");
- } else {
- this.removeClass("vjs-live");
- }
- if (!isNaN(seconds)) {
- this.trigger("durationchange");
- }
- }
- };
- _proto.remainingTime = function remainingTime() {
- return this.duration() - this.currentTime();
- };
- _proto.remainingTimeDisplay = function remainingTimeDisplay() {
- return Math.floor(this.duration()) - Math.floor(this.currentTime());
- };
- _proto.buffered = function buffered() {
- var buffered2 = this.techGet_("buffered");
- if (!buffered2 || !buffered2.length) {
- buffered2 = createTimeRanges(0, 0);
- }
- return buffered2;
- };
- _proto.bufferedPercent = function bufferedPercent$12() {
- return bufferedPercent(this.buffered(), this.duration());
- };
- _proto.bufferedEnd = function bufferedEnd() {
- var buffered = this.buffered();
- var duration5 = this.duration();
- var end = buffered.end(buffered.length - 1);
- if (end > duration5) {
- end = duration5;
- }
- return end;
- };
- _proto.volume = function volume(percentAsDecimal) {
- var vol;
- if (percentAsDecimal !== void 0) {
- vol = Math.max(0, Math.min(1, parseFloat(percentAsDecimal)));
- this.cache_.volume = vol;
- this.techCall_("setVolume", vol);
- if (vol > 0) {
- this.lastVolume_(vol);
- }
- return;
- }
- vol = parseFloat(this.techGet_("volume"));
- return isNaN(vol) ? 1 : vol;
- };
- _proto.muted = function muted(_muted) {
- if (_muted !== void 0) {
- this.techCall_("setMuted", _muted);
- return;
- }
- return this.techGet_("muted") || false;
- };
- _proto.defaultMuted = function defaultMuted(_defaultMuted) {
- if (_defaultMuted !== void 0) {
- return this.techCall_("setDefaultMuted", _defaultMuted);
- }
- return this.techGet_("defaultMuted") || false;
- };
- _proto.lastVolume_ = function lastVolume_(percentAsDecimal) {
- if (percentAsDecimal !== void 0 && percentAsDecimal !== 0) {
- this.cache_.lastVolume = percentAsDecimal;
- return;
- }
- return this.cache_.lastVolume;
- };
- _proto.supportsFullScreen = function supportsFullScreen() {
- return this.techGet_("supportsFullScreen") || false;
- };
- _proto.isFullscreen = function isFullscreen(isFS) {
- if (isFS !== void 0) {
- var oldValue = this.isFullscreen_;
- this.isFullscreen_ = Boolean(isFS);
- if (this.isFullscreen_ !== oldValue && this.fsApi_.prefixed) {
- this.trigger("fullscreenchange");
- }
- this.toggleFullscreenClass_();
- return;
- }
- return this.isFullscreen_;
- };
- _proto.requestFullscreen = function requestFullscreen(fullscreenOptions) {
- var PromiseClass = this.options_.Promise || window_1.Promise;
- if (PromiseClass) {
- var self2 = this;
- return new PromiseClass(function(resolve2, reject2) {
- function offHandler() {
- self2.off("fullscreenerror", errorHandler);
- self2.off("fullscreenchange", changeHandler);
- }
- function changeHandler() {
- offHandler();
- resolve2();
- }
- function errorHandler(e, err) {
- offHandler();
- reject2(err);
- }
- self2.one("fullscreenchange", changeHandler);
- self2.one("fullscreenerror", errorHandler);
- var promise = self2.requestFullscreenHelper_(fullscreenOptions);
- if (promise) {
- promise.then(offHandler, offHandler);
- promise.then(resolve2, reject2);
- }
- });
- }
- return this.requestFullscreenHelper_();
- };
- _proto.requestFullscreenHelper_ = function requestFullscreenHelper_(fullscreenOptions) {
- var _this12 = this;
- var fsOptions;
- if (!this.fsApi_.prefixed) {
- fsOptions = this.options_.fullscreen && this.options_.fullscreen.options || {};
- if (fullscreenOptions !== void 0) {
- fsOptions = fullscreenOptions;
- }
- }
- if (this.fsApi_.requestFullscreen) {
- var promise = this.el_[this.fsApi_.requestFullscreen](fsOptions);
- if (promise) {
- promise.then(function() {
- return _this12.isFullscreen(true);
- }, function() {
- return _this12.isFullscreen(false);
- });
- }
- return promise;
- } else if (this.tech_.supportsFullScreen() && !this.options_.preferFullWindow === true) {
- this.techCall_("enterFullScreen");
- } else {
- this.enterFullWindow();
- }
- };
- _proto.exitFullscreen = function exitFullscreen() {
- var PromiseClass = this.options_.Promise || window_1.Promise;
- if (PromiseClass) {
- var self2 = this;
- return new PromiseClass(function(resolve2, reject2) {
- function offHandler() {
- self2.off("fullscreenerror", errorHandler);
- self2.off("fullscreenchange", changeHandler);
- }
- function changeHandler() {
- offHandler();
- resolve2();
- }
- function errorHandler(e, err) {
- offHandler();
- reject2(err);
- }
- self2.one("fullscreenchange", changeHandler);
- self2.one("fullscreenerror", errorHandler);
- var promise = self2.exitFullscreenHelper_();
- if (promise) {
- promise.then(offHandler, offHandler);
- promise.then(resolve2, reject2);
- }
- });
- }
- return this.exitFullscreenHelper_();
- };
- _proto.exitFullscreenHelper_ = function exitFullscreenHelper_() {
- var _this13 = this;
- if (this.fsApi_.requestFullscreen) {
- var promise = document_1[this.fsApi_.exitFullscreen]();
- if (promise) {
- silencePromise(promise.then(function() {
- return _this13.isFullscreen(false);
- }));
- }
- return promise;
- } else if (this.tech_.supportsFullScreen() && !this.options_.preferFullWindow === true) {
- this.techCall_("exitFullScreen");
- } else {
- this.exitFullWindow();
- }
- };
- _proto.enterFullWindow = function enterFullWindow() {
- this.isFullscreen(true);
- this.isFullWindow = true;
- this.docOrigOverflow = document_1.documentElement.style.overflow;
- on(document_1, "keydown", this.boundFullWindowOnEscKey_);
- document_1.documentElement.style.overflow = "hidden";
- addClass(document_1.body, "vjs-full-window");
- this.trigger("enterFullWindow");
- };
- _proto.fullWindowOnEscKey = function fullWindowOnEscKey(event2) {
- if (keycode.isEventKey(event2, "Esc")) {
- if (this.isFullscreen() === true) {
- if (!this.isFullWindow) {
- this.exitFullscreen();
- } else {
- this.exitFullWindow();
- }
- }
- }
- };
- _proto.exitFullWindow = function exitFullWindow() {
- this.isFullscreen(false);
- this.isFullWindow = false;
- off(document_1, "keydown", this.boundFullWindowOnEscKey_);
- document_1.documentElement.style.overflow = this.docOrigOverflow;
- removeClass(document_1.body, "vjs-full-window");
- this.trigger("exitFullWindow");
- };
- _proto.disablePictureInPicture = function disablePictureInPicture(value) {
- if (value === void 0) {
- return this.techGet_("disablePictureInPicture");
- }
- this.techCall_("setDisablePictureInPicture", value);
- this.options_.disablePictureInPicture = value;
- this.trigger("disablepictureinpicturechanged");
- };
- _proto.isInPictureInPicture = function isInPictureInPicture(isPiP) {
- if (isPiP !== void 0) {
- this.isInPictureInPicture_ = !!isPiP;
- this.togglePictureInPictureClass_();
- return;
- }
- return !!this.isInPictureInPicture_;
- };
- _proto.requestPictureInPicture = function requestPictureInPicture() {
- if ("pictureInPictureEnabled" in document_1 && this.disablePictureInPicture() === false) {
- return this.techGet_("requestPictureInPicture");
- }
- };
- _proto.exitPictureInPicture = function exitPictureInPicture() {
- if ("pictureInPictureEnabled" in document_1) {
- return document_1.exitPictureInPicture();
- }
- };
- _proto.handleKeyDown = function handleKeyDown(event2) {
- var userActions = this.options_.userActions;
- if (!userActions || !userActions.hotkeys) {
- return;
- }
- var excludeElement = function excludeElement2(el) {
- var tagName = el.tagName.toLowerCase();
- if (el.isContentEditable) {
- return true;
- }
- var allowedInputTypes = ["button", "checkbox", "hidden", "radio", "reset", "submit"];
- if (tagName === "input") {
- return allowedInputTypes.indexOf(el.type) === -1;
- }
- var excludedTags = ["textarea"];
- return excludedTags.indexOf(tagName) !== -1;
- };
- if (excludeElement(this.el_.ownerDocument.activeElement)) {
- return;
- }
- if (typeof userActions.hotkeys === "function") {
- userActions.hotkeys.call(this, event2);
- } else {
- this.handleHotkeys(event2);
- }
- };
- _proto.handleHotkeys = function handleHotkeys(event2) {
- var hotkeys = this.options_.userActions ? this.options_.userActions.hotkeys : {};
- var _hotkeys$fullscreenKe = hotkeys.fullscreenKey, fullscreenKey = _hotkeys$fullscreenKe === void 0 ? function(keydownEvent) {
- return keycode.isEventKey(keydownEvent, "f");
- } : _hotkeys$fullscreenKe, _hotkeys$muteKey = hotkeys.muteKey, muteKey = _hotkeys$muteKey === void 0 ? function(keydownEvent) {
- return keycode.isEventKey(keydownEvent, "m");
- } : _hotkeys$muteKey, _hotkeys$playPauseKey = hotkeys.playPauseKey, playPauseKey = _hotkeys$playPauseKey === void 0 ? function(keydownEvent) {
- return keycode.isEventKey(keydownEvent, "k") || keycode.isEventKey(keydownEvent, "Space");
- } : _hotkeys$playPauseKey;
- if (fullscreenKey.call(this, event2)) {
- event2.preventDefault();
- event2.stopPropagation();
- var FSToggle = Component$1.getComponent("FullscreenToggle");
- if (document_1[this.fsApi_.fullscreenEnabled] !== false) {
- FSToggle.prototype.handleClick.call(this, event2);
- }
- } else if (muteKey.call(this, event2)) {
- event2.preventDefault();
- event2.stopPropagation();
- var MuteToggle2 = Component$1.getComponent("MuteToggle");
- MuteToggle2.prototype.handleClick.call(this, event2);
- } else if (playPauseKey.call(this, event2)) {
- event2.preventDefault();
- event2.stopPropagation();
- var PlayToggle2 = Component$1.getComponent("PlayToggle");
- PlayToggle2.prototype.handleClick.call(this, event2);
- }
- };
- _proto.canPlayType = function canPlayType3(type2) {
- var can;
- for (var i2 = 0, j = this.options_.techOrder; i2 < j.length; i2++) {
- var techName = j[i2];
- var tech = Tech$1.getTech(techName);
- if (!tech) {
- tech = Component$1.getComponent(techName);
- }
- if (!tech) {
- log$1.error('The "' + techName + '" tech is undefined. Skipped browser support check for that tech.');
- continue;
- }
- if (tech.isSupported()) {
- can = tech.canPlayType(type2);
- if (can) {
- return can;
- }
- }
- }
- return "";
- };
- _proto.selectSource = function selectSource(sources) {
- var _this14 = this;
- var techs = this.options_.techOrder.map(function(techName) {
- return [techName, Tech$1.getTech(techName)];
- }).filter(function(_ref) {
- var techName = _ref[0], tech = _ref[1];
- if (tech) {
- return tech.isSupported();
- }
- log$1.error('The "' + techName + '" tech is undefined. Skipped browser support check for that tech.');
- return false;
- });
- var findFirstPassingTechSourcePair = function findFirstPassingTechSourcePair2(outerArray, innerArray, tester) {
- var found;
- outerArray.some(function(outerChoice) {
- return innerArray.some(function(innerChoice) {
- found = tester(outerChoice, innerChoice);
- if (found) {
- return true;
- }
- });
- });
- return found;
- };
- var foundSourceAndTech;
- var flip = function flip2(fn2) {
- return function(a, b) {
- return fn2(b, a);
- };
- };
- var finder = function finder2(_ref2, source) {
- var techName = _ref2[0], tech = _ref2[1];
- if (tech.canPlaySource(source, _this14.options_[techName.toLowerCase()])) {
- return {
- source,
- tech: techName
- };
- }
- };
- if (this.options_.sourceOrder) {
- foundSourceAndTech = findFirstPassingTechSourcePair(sources, techs, flip(finder));
- } else {
- foundSourceAndTech = findFirstPassingTechSourcePair(techs, sources, finder);
- }
- return foundSourceAndTech || false;
- };
- _proto.handleSrc_ = function handleSrc_(source, isRetry) {
- var _this15 = this;
- if (typeof source === "undefined") {
- return this.cache_.src || "";
- }
- if (this.resetRetryOnError_) {
- this.resetRetryOnError_();
- }
- var sources = filterSource(source);
- if (!sources.length) {
- this.setTimeout(function() {
- this.error({
- code: 4,
- message: this.options_.notSupportedMessage
- });
- }, 0);
- return;
- }
- this.changingSrc_ = true;
- if (!isRetry) {
- this.cache_.sources = sources;
- }
- this.updateSourceCaches_(sources[0]);
- setSource(this, sources[0], function(middlewareSource, mws) {
- _this15.middleware_ = mws;
- if (!isRetry) {
- _this15.cache_.sources = sources;
- }
- _this15.updateSourceCaches_(middlewareSource);
- var err = _this15.src_(middlewareSource);
- if (err) {
- if (sources.length > 1) {
- return _this15.handleSrc_(sources.slice(1));
- }
- _this15.changingSrc_ = false;
- _this15.setTimeout(function() {
- this.error({
- code: 4,
- message: this.options_.notSupportedMessage
- });
- }, 0);
- _this15.triggerReady();
- return;
- }
- setTech(mws, _this15.tech_);
- });
- if (this.options_.retryOnError && sources.length > 1) {
- var retry = function retry2() {
- _this15.error(null);
- _this15.handleSrc_(sources.slice(1), true);
- };
- var stopListeningForErrors = function stopListeningForErrors2() {
- _this15.off("error", retry);
- };
- this.one("error", retry);
- this.one("playing", stopListeningForErrors);
- this.resetRetryOnError_ = function() {
- _this15.off("error", retry);
- _this15.off("playing", stopListeningForErrors);
- };
- }
- };
- _proto.src = function src(source) {
- return this.handleSrc_(source, false);
- };
- _proto.src_ = function src_(source) {
- var _this16 = this;
- var sourceTech = this.selectSource([source]);
- if (!sourceTech) {
- return true;
- }
- if (!titleCaseEquals(sourceTech.tech, this.techName_)) {
- this.changingSrc_ = true;
- this.loadTech_(sourceTech.tech, sourceTech.source);
- this.tech_.ready(function() {
- _this16.changingSrc_ = false;
- });
- return false;
- }
- this.ready(function() {
- if (this.tech_.constructor.prototype.hasOwnProperty("setSource")) {
- this.techCall_("setSource", source);
- } else {
- this.techCall_("src", source.src);
- }
- this.changingSrc_ = false;
- }, true);
- return false;
- };
- _proto.load = function load() {
- this.techCall_("load");
- };
- _proto.reset = function reset3() {
- var _this17 = this;
- var PromiseClass = this.options_.Promise || window_1.Promise;
- if (this.paused() || !PromiseClass) {
- this.doReset_();
- } else {
- var playPromise = this.play();
- silencePromise(playPromise.then(function() {
- return _this17.doReset_();
- }));
- }
- };
- _proto.doReset_ = function doReset_() {
- if (this.tech_) {
- this.tech_.clearTracks("text");
- }
- this.resetCache_();
- this.poster("");
- this.loadTech_(this.options_.techOrder[0], null);
- this.techCall_("reset");
- this.resetControlBarUI_();
- if (isEvented(this)) {
- this.trigger("playerreset");
- }
- };
- _proto.resetControlBarUI_ = function resetControlBarUI_() {
- this.resetProgressBar_();
- this.resetPlaybackRate_();
- this.resetVolumeBar_();
- };
- _proto.resetProgressBar_ = function resetProgressBar_() {
- this.currentTime(0);
- var _ref3 = this.controlBar || {}, durationDisplay = _ref3.durationDisplay, remainingTimeDisplay = _ref3.remainingTimeDisplay;
- if (durationDisplay) {
- durationDisplay.updateContent();
- }
- if (remainingTimeDisplay) {
- remainingTimeDisplay.updateContent();
- }
- };
- _proto.resetPlaybackRate_ = function resetPlaybackRate_() {
- this.playbackRate(this.defaultPlaybackRate());
- this.handleTechRateChange_();
- };
- _proto.resetVolumeBar_ = function resetVolumeBar_() {
- this.volume(1);
- this.trigger("volumechange");
- };
- _proto.currentSources = function currentSources() {
- var source = this.currentSource();
- var sources = [];
- if (Object.keys(source).length !== 0) {
- sources.push(source);
- }
- return this.cache_.sources || sources;
- };
- _proto.currentSource = function currentSource() {
- return this.cache_.source || {};
- };
- _proto.currentSrc = function currentSrc() {
- return this.currentSource() && this.currentSource().src || "";
- };
- _proto.currentType = function currentType() {
- return this.currentSource() && this.currentSource().type || "";
- };
- _proto.preload = function preload(value) {
- if (value !== void 0) {
- this.techCall_("setPreload", value);
- this.options_.preload = value;
- return;
- }
- return this.techGet_("preload");
- };
- _proto.autoplay = function autoplay(value) {
- if (value === void 0) {
- return this.options_.autoplay || false;
- }
- var techAutoplay;
- if (typeof value === "string" && /(any|play|muted)/.test(value) || value === true && this.options_.normalizeAutoplay) {
- this.options_.autoplay = value;
- this.manualAutoplay_(typeof value === "string" ? value : "play");
- techAutoplay = false;
- } else if (!value) {
- this.options_.autoplay = false;
- } else {
- this.options_.autoplay = true;
- }
- techAutoplay = typeof techAutoplay === "undefined" ? this.options_.autoplay : techAutoplay;
- if (this.tech_) {
- this.techCall_("setAutoplay", techAutoplay);
- }
- };
- _proto.playsinline = function playsinline(value) {
- if (value !== void 0) {
- this.techCall_("setPlaysinline", value);
- this.options_.playsinline = value;
- return this;
- }
- return this.techGet_("playsinline");
- };
- _proto.loop = function loop(value) {
- if (value !== void 0) {
- this.techCall_("setLoop", value);
- this.options_.loop = value;
- return;
- }
- return this.techGet_("loop");
- };
- _proto.poster = function poster(src) {
- if (src === void 0) {
- return this.poster_;
- }
- if (!src) {
- src = "";
- }
- if (src === this.poster_) {
- return;
- }
- this.poster_ = src;
- this.techCall_("setPoster", src);
- this.isPosterFromTech_ = false;
- this.trigger("posterchange");
- };
- _proto.handleTechPosterChange_ = function handleTechPosterChange_() {
- if ((!this.poster_ || this.options_.techCanOverridePoster) && this.tech_ && this.tech_.poster) {
- var newPoster = this.tech_.poster() || "";
- if (newPoster !== this.poster_) {
- this.poster_ = newPoster;
- this.isPosterFromTech_ = true;
- this.trigger("posterchange");
- }
- }
- };
- _proto.controls = function controls(bool) {
- if (bool === void 0) {
- return !!this.controls_;
- }
- bool = !!bool;
- if (this.controls_ === bool) {
- return;
- }
- this.controls_ = bool;
- if (this.usingNativeControls()) {
- this.techCall_("setControls", bool);
- }
- if (this.controls_) {
- this.removeClass("vjs-controls-disabled");
- this.addClass("vjs-controls-enabled");
- this.trigger("controlsenabled");
- if (!this.usingNativeControls()) {
- this.addTechControlsListeners_();
- }
- } else {
- this.removeClass("vjs-controls-enabled");
- this.addClass("vjs-controls-disabled");
- this.trigger("controlsdisabled");
- if (!this.usingNativeControls()) {
- this.removeTechControlsListeners_();
- }
- }
- };
- _proto.usingNativeControls = function usingNativeControls(bool) {
- if (bool === void 0) {
- return !!this.usingNativeControls_;
- }
- bool = !!bool;
- if (this.usingNativeControls_ === bool) {
- return;
- }
- this.usingNativeControls_ = bool;
- if (this.usingNativeControls_) {
- this.addClass("vjs-using-native-controls");
- this.trigger("usingnativecontrols");
- } else {
- this.removeClass("vjs-using-native-controls");
- this.trigger("usingcustomcontrols");
- }
- };
- _proto.error = function error(err) {
- var _this18 = this;
- if (err === void 0) {
- return this.error_ || null;
- }
- hooks("beforeerror").forEach(function(hookFunction) {
- var newErr = hookFunction(_this18, err);
- if (!(isObject2(newErr) && !Array.isArray(newErr) || typeof newErr === "string" || typeof newErr === "number" || newErr === null)) {
- _this18.log.error("please return a value that MediaError expects in beforeerror hooks");
- return;
- }
- err = newErr;
- });
- if (this.options_.suppressNotSupportedError && err && err.code === 4) {
- var triggerSuppressedError = function triggerSuppressedError2() {
- this.error(err);
- };
- this.options_.suppressNotSupportedError = false;
- this.any(["click", "touchstart"], triggerSuppressedError);
- this.one("loadstart", function() {
- this.off(["click", "touchstart"], triggerSuppressedError);
- });
- return;
- }
- if (err === null) {
- this.error_ = err;
- this.removeClass("vjs-error");
- if (this.errorDisplay) {
- this.errorDisplay.close();
- }
- return;
- }
- this.error_ = new MediaError(err);
- this.addClass("vjs-error");
- log$1.error("(CODE:" + this.error_.code + " " + MediaError.errorTypes[this.error_.code] + ")", this.error_.message, this.error_);
- this.trigger("error");
- hooks("error").forEach(function(hookFunction) {
- return hookFunction(_this18, _this18.error_);
- });
- return;
- };
- _proto.reportUserActivity = function reportUserActivity(event2) {
- this.userActivity_ = true;
- };
- _proto.userActive = function userActive(bool) {
- if (bool === void 0) {
- return this.userActive_;
- }
- bool = !!bool;
- if (bool === this.userActive_) {
- return;
- }
- this.userActive_ = bool;
- if (this.userActive_) {
- this.userActivity_ = true;
- this.removeClass("vjs-user-inactive");
- this.addClass("vjs-user-active");
- this.trigger("useractive");
- return;
- }
- if (this.tech_) {
- this.tech_.one("mousemove", function(e) {
- e.stopPropagation();
- e.preventDefault();
- });
- }
- this.userActivity_ = false;
- this.removeClass("vjs-user-active");
- this.addClass("vjs-user-inactive");
- this.trigger("userinactive");
- };
- _proto.listenForUserActivity_ = function listenForUserActivity_() {
- var mouseInProgress;
- var lastMoveX;
- var lastMoveY;
- var handleActivity = bind(this, this.reportUserActivity);
- var handleMouseMove = function handleMouseMove2(e) {
- if (e.screenX !== lastMoveX || e.screenY !== lastMoveY) {
- lastMoveX = e.screenX;
- lastMoveY = e.screenY;
- handleActivity();
- }
- };
- var handleMouseDown = function handleMouseDown2() {
- handleActivity();
- this.clearInterval(mouseInProgress);
- mouseInProgress = this.setInterval(handleActivity, 250);
- };
- var handleMouseUpAndMouseLeave = function handleMouseUpAndMouseLeave2(event2) {
- handleActivity();
- this.clearInterval(mouseInProgress);
- };
- this.on("mousedown", handleMouseDown);
- this.on("mousemove", handleMouseMove);
- this.on("mouseup", handleMouseUpAndMouseLeave);
- this.on("mouseleave", handleMouseUpAndMouseLeave);
- var controlBar = this.getChild("controlBar");
- if (controlBar && !IS_IOS && !IS_ANDROID) {
- controlBar.on("mouseenter", function(event2) {
- if (this.player().options_.inactivityTimeout !== 0) {
- this.player().cache_.inactivityTimeout = this.player().options_.inactivityTimeout;
- }
- this.player().options_.inactivityTimeout = 0;
- });
- controlBar.on("mouseleave", function(event2) {
- this.player().options_.inactivityTimeout = this.player().cache_.inactivityTimeout;
- });
- }
- this.on("keydown", handleActivity);
- this.on("keyup", handleActivity);
- var inactivityTimeout;
- this.setInterval(function() {
- if (!this.userActivity_) {
- return;
- }
- this.userActivity_ = false;
- this.userActive(true);
- this.clearTimeout(inactivityTimeout);
- var timeout = this.options_.inactivityTimeout;
- if (timeout <= 0) {
- return;
- }
- inactivityTimeout = this.setTimeout(function() {
- if (!this.userActivity_) {
- this.userActive(false);
- }
- }, timeout);
- }, 250);
- };
- _proto.playbackRate = function playbackRate(rate) {
- if (rate !== void 0) {
- this.techCall_("setPlaybackRate", rate);
- return;
- }
- if (this.tech_ && this.tech_.featuresPlaybackRate) {
- return this.cache_.lastPlaybackRate || this.techGet_("playbackRate");
- }
- return 1;
- };
- _proto.defaultPlaybackRate = function defaultPlaybackRate(rate) {
- if (rate !== void 0) {
- return this.techCall_("setDefaultPlaybackRate", rate);
- }
- if (this.tech_ && this.tech_.featuresPlaybackRate) {
- return this.techGet_("defaultPlaybackRate");
- }
- return 1;
- };
- _proto.isAudio = function isAudio(bool) {
- if (bool !== void 0) {
- this.isAudio_ = !!bool;
- return;
- }
- return !!this.isAudio_;
- };
- _proto.enableAudioOnlyUI_ = function enableAudioOnlyUI_() {
- var _this19 = this;
- this.addClass("vjs-audio-only-mode");
- var playerChildren = this.children();
- var controlBar = this.getChild("ControlBar");
- var controlBarHeight = controlBar && controlBar.currentHeight();
- playerChildren.forEach(function(child) {
- if (child === controlBar) {
- return;
- }
- if (child.el_ && !child.hasClass("vjs-hidden")) {
- child.hide();
- _this19.audioOnlyCache_.hiddenChildren.push(child);
- }
- });
- this.audioOnlyCache_.playerHeight = this.currentHeight();
- this.height(controlBarHeight);
- this.trigger("audioonlymodechange");
- };
- _proto.disableAudioOnlyUI_ = function disableAudioOnlyUI_() {
- this.removeClass("vjs-audio-only-mode");
- this.audioOnlyCache_.hiddenChildren.forEach(function(child) {
- return child.show();
- });
- this.height(this.audioOnlyCache_.playerHeight);
- this.trigger("audioonlymodechange");
- };
- _proto.audioOnlyMode = function audioOnlyMode(value) {
- var _this20 = this;
- if (typeof value !== "boolean" || value === this.audioOnlyMode_) {
- return this.audioOnlyMode_;
- }
- this.audioOnlyMode_ = value;
- var PromiseClass = this.options_.Promise || window_1.Promise;
- if (PromiseClass) {
- if (value) {
- var exitPromises = [];
- if (this.isInPictureInPicture()) {
- exitPromises.push(this.exitPictureInPicture());
- }
- if (this.isFullscreen()) {
- exitPromises.push(this.exitFullscreen());
- }
- if (this.audioPosterMode()) {
- exitPromises.push(this.audioPosterMode(false));
- }
- return PromiseClass.all(exitPromises).then(function() {
- return _this20.enableAudioOnlyUI_();
- });
- }
- return PromiseClass.resolve().then(function() {
- return _this20.disableAudioOnlyUI_();
- });
- }
- if (value) {
- if (this.isInPictureInPicture()) {
- this.exitPictureInPicture();
- }
- if (this.isFullscreen()) {
- this.exitFullscreen();
- }
- this.enableAudioOnlyUI_();
- } else {
- this.disableAudioOnlyUI_();
- }
- };
- _proto.enablePosterModeUI_ = function enablePosterModeUI_() {
- var tech = this.tech_ && this.tech_;
- tech.hide();
- this.addClass("vjs-audio-poster-mode");
- this.trigger("audiopostermodechange");
- };
- _proto.disablePosterModeUI_ = function disablePosterModeUI_() {
- var tech = this.tech_ && this.tech_;
- tech.show();
- this.removeClass("vjs-audio-poster-mode");
- this.trigger("audiopostermodechange");
- };
- _proto.audioPosterMode = function audioPosterMode(value) {
- var _this21 = this;
- if (typeof value !== "boolean" || value === this.audioPosterMode_) {
- return this.audioPosterMode_;
- }
- this.audioPosterMode_ = value;
- var PromiseClass = this.options_.Promise || window_1.Promise;
- if (PromiseClass) {
- if (value) {
- if (this.audioOnlyMode()) {
- var audioOnlyModePromise = this.audioOnlyMode(false);
- return audioOnlyModePromise.then(function() {
- _this21.enablePosterModeUI_();
- });
- }
- return PromiseClass.resolve().then(function() {
- _this21.enablePosterModeUI_();
- });
- }
- return PromiseClass.resolve().then(function() {
- _this21.disablePosterModeUI_();
- });
- }
- if (value) {
- if (this.audioOnlyMode()) {
- this.audioOnlyMode(false);
- }
- this.enablePosterModeUI_();
- return;
- }
- this.disablePosterModeUI_();
- };
- _proto.addTextTrack = function addTextTrack(kind, label2, language) {
- if (this.tech_) {
- return this.tech_.addTextTrack(kind, label2, language);
- }
- };
- _proto.addRemoteTextTrack = function addRemoteTextTrack(options2, manualCleanup) {
- if (this.tech_) {
- return this.tech_.addRemoteTextTrack(options2, manualCleanup);
- }
- };
- _proto.removeRemoteTextTrack = function removeRemoteTextTrack(obj) {
- if (obj === void 0) {
- obj = {};
- }
- var _obj = obj, track = _obj.track;
- if (!track) {
- track = obj;
- }
- if (this.tech_) {
- return this.tech_.removeRemoteTextTrack(track);
- }
- };
- _proto.getVideoPlaybackQuality = function getVideoPlaybackQuality() {
- return this.techGet_("getVideoPlaybackQuality");
- };
- _proto.videoWidth = function videoWidth() {
- return this.tech_ && this.tech_.videoWidth && this.tech_.videoWidth() || 0;
- };
- _proto.videoHeight = function videoHeight() {
- return this.tech_ && this.tech_.videoHeight && this.tech_.videoHeight() || 0;
- };
- _proto.language = function language(code) {
- if (code === void 0) {
- return this.language_;
- }
- if (this.language_ !== String(code).toLowerCase()) {
- this.language_ = String(code).toLowerCase();
- if (isEvented(this)) {
- this.trigger("languagechange");
- }
- }
- };
- _proto.languages = function languages() {
- return mergeOptions$3(Player2.prototype.options_.languages, this.languages_);
- };
- _proto.toJSON = function toJSON() {
- var options2 = mergeOptions$3(this.options_);
- var tracks = options2.tracks;
- options2.tracks = [];
- for (var i2 = 0; i2 < tracks.length; i2++) {
- var track = tracks[i2];
- track = mergeOptions$3(track);
- track.player = void 0;
- options2.tracks[i2] = track;
- }
- return options2;
- };
- _proto.createModal = function createModal(content, options2) {
- var _this22 = this;
- options2 = options2 || {};
- options2.content = content || "";
- var modal = new ModalDialog(this, options2);
- this.addChild(modal);
- modal.on("dispose", function() {
- _this22.removeChild(modal);
- });
- modal.open();
- return modal;
- };
- _proto.updateCurrentBreakpoint_ = function updateCurrentBreakpoint_() {
- if (!this.responsive()) {
- return;
- }
- var currentBreakpoint = this.currentBreakpoint();
- var currentWidth = this.currentWidth();
- for (var i2 = 0; i2 < BREAKPOINT_ORDER.length; i2++) {
- var candidateBreakpoint = BREAKPOINT_ORDER[i2];
- var maxWidth = this.breakpoints_[candidateBreakpoint];
- if (currentWidth <= maxWidth) {
- if (currentBreakpoint === candidateBreakpoint) {
- return;
- }
- if (currentBreakpoint) {
- this.removeClass(BREAKPOINT_CLASSES[currentBreakpoint]);
- }
- this.addClass(BREAKPOINT_CLASSES[candidateBreakpoint]);
- this.breakpoint_ = candidateBreakpoint;
- break;
- }
- }
- };
- _proto.removeCurrentBreakpoint_ = function removeCurrentBreakpoint_() {
- var className = this.currentBreakpointClass();
- this.breakpoint_ = "";
- if (className) {
- this.removeClass(className);
- }
- };
- _proto.breakpoints = function breakpoints(_breakpoints) {
- if (_breakpoints === void 0) {
- return assign(this.breakpoints_);
- }
- this.breakpoint_ = "";
- this.breakpoints_ = assign({}, DEFAULT_BREAKPOINTS, _breakpoints);
- this.updateCurrentBreakpoint_();
- return assign(this.breakpoints_);
- };
- _proto.responsive = function responsive(value) {
- if (value === void 0) {
- return this.responsive_;
- }
- value = Boolean(value);
- var current = this.responsive_;
- if (value === current) {
- return;
- }
- this.responsive_ = value;
- if (value) {
- this.on("playerresize", this.boundUpdateCurrentBreakpoint_);
- this.updateCurrentBreakpoint_();
- } else {
- this.off("playerresize", this.boundUpdateCurrentBreakpoint_);
- this.removeCurrentBreakpoint_();
- }
- return value;
- };
- _proto.currentBreakpoint = function currentBreakpoint() {
- return this.breakpoint_;
- };
- _proto.currentBreakpointClass = function currentBreakpointClass() {
- return BREAKPOINT_CLASSES[this.breakpoint_] || "";
- };
- _proto.loadMedia = function loadMedia(media, ready) {
- var _this23 = this;
- if (!media || typeof media !== "object") {
- return;
- }
- this.reset();
- this.cache_.media = mergeOptions$3(media);
- var _this$cache_$media = this.cache_.media, artwork = _this$cache_$media.artwork, poster = _this$cache_$media.poster, src = _this$cache_$media.src, textTracks = _this$cache_$media.textTracks;
- if (!artwork && poster) {
- this.cache_.media.artwork = [{
- src: poster,
- type: getMimetype(poster)
- }];
- }
- if (src) {
- this.src(src);
- }
- if (poster) {
- this.poster(poster);
- }
- if (Array.isArray(textTracks)) {
- textTracks.forEach(function(tt2) {
- return _this23.addRemoteTextTrack(tt2, false);
- });
- }
- this.ready(ready);
- };
- _proto.getMedia = function getMedia() {
- if (!this.cache_.media) {
- var poster = this.poster();
- var src = this.currentSources();
- var textTracks = Array.prototype.map.call(this.remoteTextTracks(), function(tt2) {
- return {
- kind: tt2.kind,
- label: tt2.label,
- language: tt2.language,
- src: tt2.src
- };
- });
- var media = {
- src,
- textTracks
- };
- if (poster) {
- media.poster = poster;
- media.artwork = [{
- src: media.poster,
- type: getMimetype(media.poster)
- }];
- }
- return media;
- }
- return mergeOptions$3(this.cache_.media);
- };
- Player2.getTagSettings = function getTagSettings(tag) {
- var baseOptions = {
- sources: [],
- tracks: []
- };
- var tagOptions = getAttributes(tag);
- var dataSetup = tagOptions["data-setup"];
- if (hasClass(tag, "vjs-fill")) {
- tagOptions.fill = true;
- }
- if (hasClass(tag, "vjs-fluid")) {
- tagOptions.fluid = true;
- }
- if (dataSetup !== null) {
- var _safeParseTuple = tuple(dataSetup || "{}"), err = _safeParseTuple[0], data = _safeParseTuple[1];
- if (err) {
- log$1.error(err);
- }
- assign(tagOptions, data);
- }
- assign(baseOptions, tagOptions);
- if (tag.hasChildNodes()) {
- var children = tag.childNodes;
- for (var i2 = 0, j = children.length; i2 < j; i2++) {
- var child = children[i2];
- var childName = child.nodeName.toLowerCase();
- if (childName === "source") {
- baseOptions.sources.push(getAttributes(child));
- } else if (childName === "track") {
- baseOptions.tracks.push(getAttributes(child));
- }
- }
- }
- return baseOptions;
- };
- _proto.flexNotSupported_ = function flexNotSupported_() {
- var elem = document_1.createElement("i");
- return !("flexBasis" in elem.style || "webkitFlexBasis" in elem.style || "mozFlexBasis" in elem.style || "msFlexBasis" in elem.style || "msFlexOrder" in elem.style);
- };
- _proto.debug = function debug(enabled) {
- if (enabled === void 0) {
- return this.debugEnabled_;
- }
- if (enabled) {
- this.trigger("debugon");
- this.previousLogLevel_ = this.log.level;
- this.log.level("debug");
- this.debugEnabled_ = true;
- } else {
- this.trigger("debugoff");
- this.log.level(this.previousLogLevel_);
- this.previousLogLevel_ = void 0;
- this.debugEnabled_ = false;
- }
- };
- _proto.playbackRates = function playbackRates(newRates) {
- if (newRates === void 0) {
- return this.cache_.playbackRates;
- }
- if (!Array.isArray(newRates)) {
- return;
- }
- if (!newRates.every(function(rate) {
- return typeof rate === "number";
- })) {
- return;
- }
- this.cache_.playbackRates = newRates;
- this.trigger("playbackrateschange");
- };
- return Player2;
- }(Component$1);
- ALL.names.forEach(function(name) {
- var props = ALL[name];
- Player.prototype[props.getterName] = function() {
- if (this.tech_) {
- return this.tech_[props.getterName]();
- }
- this[props.privateName] = this[props.privateName] || new props.ListClass();
- return this[props.privateName];
- };
- });
- Player.prototype.crossorigin = Player.prototype.crossOrigin;
- Player.players = {};
- var navigator$2 = window_1.navigator;
- Player.prototype.options_ = {
- techOrder: Tech$1.defaultTechOrder_,
- html5: {},
- inactivityTimeout: 2e3,
- playbackRates: [],
- liveui: false,
- children: ["mediaLoader", "posterImage", "textTrackDisplay", "loadingSpinner", "bigPlayButton", "liveTracker", "controlBar", "errorDisplay", "textTrackSettings", "resizeManager"],
- language: navigator$2 && (navigator$2.languages && navigator$2.languages[0] || navigator$2.userLanguage || navigator$2.language) || "en",
- languages: {},
- notSupportedMessage: "No compatible source was found for this media.",
- normalizeAutoplay: false,
- fullscreen: {
- options: {
- navigationUI: "hide"
- }
- },
- breakpoints: {},
- responsive: false,
- audioOnlyMode: false,
- audioPosterMode: false
- };
- [
- "ended",
- "seeking",
- "seekable",
- "networkState",
- "readyState"
- ].forEach(function(fn2) {
- Player.prototype[fn2] = function() {
- return this.techGet_(fn2);
- };
- });
- TECH_EVENTS_RETRIGGER.forEach(function(event2) {
- Player.prototype["handleTech" + toTitleCase$1(event2) + "_"] = function() {
- return this.trigger(event2);
- };
- });
- Component$1.registerComponent("Player", Player);
- var BASE_PLUGIN_NAME = "plugin";
- var PLUGIN_CACHE_KEY = "activePlugins_";
- var pluginStorage = {};
- var pluginExists = function pluginExists2(name) {
- return pluginStorage.hasOwnProperty(name);
- };
- var getPlugin = function getPlugin2(name) {
- return pluginExists(name) ? pluginStorage[name] : void 0;
- };
- var markPluginAsActive = function markPluginAsActive2(player, name) {
- player[PLUGIN_CACHE_KEY] = player[PLUGIN_CACHE_KEY] || {};
- player[PLUGIN_CACHE_KEY][name] = true;
- };
- var triggerSetupEvent = function triggerSetupEvent2(player, hash, before) {
- var eventName = (before ? "before" : "") + "pluginsetup";
- player.trigger(eventName, hash);
- player.trigger(eventName + ":" + hash.name, hash);
- };
- var createBasicPlugin = function createBasicPlugin2(name, plugin) {
- var basicPluginWrapper = function basicPluginWrapper2() {
- triggerSetupEvent(this, {
- name,
- plugin,
- instance: null
- }, true);
- var instance = plugin.apply(this, arguments);
- markPluginAsActive(this, name);
- triggerSetupEvent(this, {
- name,
- plugin,
- instance
- });
- return instance;
- };
- Object.keys(plugin).forEach(function(prop) {
- basicPluginWrapper[prop] = plugin[prop];
- });
- return basicPluginWrapper;
- };
- var createPluginFactory = function createPluginFactory2(name, PluginSubClass) {
- PluginSubClass.prototype.name = name;
- return function() {
- triggerSetupEvent(this, {
- name,
- plugin: PluginSubClass,
- instance: null
- }, true);
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
- var instance = _construct(PluginSubClass, [this].concat(args));
- this[name] = function() {
- return instance;
- };
- triggerSetupEvent(this, instance.getEventHash());
- return instance;
- };
- };
- var Plugin = /* @__PURE__ */ function() {
- function Plugin2(player) {
- if (this.constructor === Plugin2) {
- throw new Error("Plugin must be sub-classed; not directly instantiated.");
- }
- this.player = player;
- if (!this.log) {
- this.log = this.player.log.createLogger(this.name);
- }
- evented(this);
- delete this.trigger;
- stateful(this, this.constructor.defaultState);
- markPluginAsActive(player, this.name);
- this.dispose = this.dispose.bind(this);
- player.on("dispose", this.dispose);
- }
- var _proto = Plugin2.prototype;
- _proto.version = function version2() {
- return this.constructor.VERSION;
- };
- _proto.getEventHash = function getEventHash(hash) {
- if (hash === void 0) {
- hash = {};
- }
- hash.name = this.name;
- hash.plugin = this.constructor;
- hash.instance = this;
- return hash;
- };
- _proto.trigger = function trigger$13(event2, hash) {
- if (hash === void 0) {
- hash = {};
- }
- return trigger(this.eventBusEl_, event2, this.getEventHash(hash));
- };
- _proto.handleStateChanged = function handleStateChanged(e) {
- };
- _proto.dispose = function dispose() {
- var name = this.name, player = this.player;
- this.trigger("dispose");
- this.off();
- player.off("dispose", this.dispose);
- player[PLUGIN_CACHE_KEY][name] = false;
- this.player = this.state = null;
- player[name] = createPluginFactory(name, pluginStorage[name]);
- };
- Plugin2.isBasic = function isBasic(plugin) {
- var p = typeof plugin === "string" ? getPlugin(plugin) : plugin;
- return typeof p === "function" && !Plugin2.prototype.isPrototypeOf(p.prototype);
- };
- Plugin2.registerPlugin = function registerPlugin(name, plugin) {
- if (typeof name !== "string") {
- throw new Error('Illegal plugin name, "' + name + '", must be a string, was ' + typeof name + ".");
- }
- if (pluginExists(name)) {
- log$1.warn('A plugin named "' + name + '" already exists. You may want to avoid re-registering plugins!');
- } else if (Player.prototype.hasOwnProperty(name)) {
- throw new Error('Illegal plugin name, "' + name + '", cannot share a name with an existing player method!');
- }
- if (typeof plugin !== "function") {
- throw new Error('Illegal plugin for "' + name + '", must be a function, was ' + typeof plugin + ".");
- }
- pluginStorage[name] = plugin;
- if (name !== BASE_PLUGIN_NAME) {
- if (Plugin2.isBasic(plugin)) {
- Player.prototype[name] = createBasicPlugin(name, plugin);
- } else {
- Player.prototype[name] = createPluginFactory(name, plugin);
- }
- }
- return plugin;
- };
- Plugin2.deregisterPlugin = function deregisterPlugin(name) {
- if (name === BASE_PLUGIN_NAME) {
- throw new Error("Cannot de-register base plugin.");
- }
- if (pluginExists(name)) {
- delete pluginStorage[name];
- delete Player.prototype[name];
- }
- };
- Plugin2.getPlugins = function getPlugins(names2) {
- if (names2 === void 0) {
- names2 = Object.keys(pluginStorage);
- }
- var result;
- names2.forEach(function(name) {
- var plugin = getPlugin(name);
- if (plugin) {
- result = result || {};
- result[name] = plugin;
- }
- });
- return result;
- };
- Plugin2.getPluginVersion = function getPluginVersion(name) {
- var plugin = getPlugin(name);
- return plugin && plugin.VERSION || "";
- };
- return Plugin2;
- }();
- Plugin.getPlugin = getPlugin;
- Plugin.BASE_PLUGIN_NAME = BASE_PLUGIN_NAME;
- Plugin.registerPlugin(BASE_PLUGIN_NAME, Plugin);
- Player.prototype.usingPlugin = function(name) {
- return !!this[PLUGIN_CACHE_KEY] && this[PLUGIN_CACHE_KEY][name] === true;
- };
- Player.prototype.hasPlugin = function(name) {
- return !!pluginExists(name);
- };
- var hasLogged = false;
- var extend = function extend2(superClass, subClassMethods) {
- if (subClassMethods === void 0) {
- subClassMethods = {};
- }
- if (!hasLogged) {
- log$1.warn("videojs.extend is deprecated as of Video.js 7.22.0 and will be removed in Video.js 8.0.0");
- hasLogged = true;
- }
- var subClass = function subClass2() {
- superClass.apply(this, arguments);
- };
- var methods = {};
- if (typeof subClassMethods === "object") {
- if (subClassMethods.constructor !== Object.prototype.constructor) {
- subClass = subClassMethods.constructor;
- }
- methods = subClassMethods;
- } else if (typeof subClassMethods === "function") {
- subClass = subClassMethods;
- }
- _inherits(subClass, superClass);
- if (superClass) {
- subClass.super_ = superClass;
- }
- for (var name in methods) {
- if (methods.hasOwnProperty(name)) {
- subClass.prototype[name] = methods[name];
- }
- }
- return subClass;
- };
- var normalizeId = function normalizeId2(id) {
- return id.indexOf("#") === 0 ? id.slice(1) : id;
- };
- function videojs(id, options2, ready) {
- var player = videojs.getPlayer(id);
- if (player) {
- if (options2) {
- log$1.warn('Player "' + id + '" is already initialised. Options will not be applied.');
- }
- if (ready) {
- player.ready(ready);
- }
- return player;
- }
- var el = typeof id === "string" ? $("#" + normalizeId(id)) : id;
- if (!isEl(el)) {
- throw new TypeError("The element or ID supplied is not valid. (videojs)");
- }
- if (!el.ownerDocument.defaultView || !el.ownerDocument.body.contains(el)) {
- log$1.warn("The element supplied is not included in the DOM");
- }
- options2 = options2 || {};
- if (options2.restoreEl === true) {
- options2.restoreEl = (el.parentNode && el.parentNode.hasAttribute("data-vjs-player") ? el.parentNode : el).cloneNode(true);
- }
- hooks("beforesetup").forEach(function(hookFunction) {
- var opts = hookFunction(el, mergeOptions$3(options2));
- if (!isObject2(opts) || Array.isArray(opts)) {
- log$1.error("please return an object in beforesetup hooks");
- return;
- }
- options2 = mergeOptions$3(options2, opts);
- });
- var PlayerComponent = Component$1.getComponent("Player");
- player = new PlayerComponent(el, options2, ready);
- hooks("setup").forEach(function(hookFunction) {
- return hookFunction(player);
- });
- return player;
- }
- videojs.hooks_ = hooks_;
- videojs.hooks = hooks;
- videojs.hook = hook;
- videojs.hookOnce = hookOnce;
- videojs.removeHook = removeHook;
- if (window_1.VIDEOJS_NO_DYNAMIC_STYLE !== true && isReal()) {
- var style = $(".vjs-styles-defaults");
- if (!style) {
- style = createStyleElement("vjs-styles-defaults");
- var head = $("head");
- if (head) {
- head.insertBefore(style, head.firstChild);
- }
- setTextContent(style, "\n .video-js {\n width: 300px;\n height: 150px;\n }\n\n .vjs-fluid:not(.vjs-audio-only-mode) {\n padding-top: 56.25%\n }\n ");
- }
- }
- autoSetupTimeout(1, videojs);
- videojs.VERSION = version$5;
- videojs.options = Player.prototype.options_;
- videojs.getPlayers = function() {
- return Player.players;
- };
- videojs.getPlayer = function(id) {
- var players = Player.players;
- var tag;
- if (typeof id === "string") {
- var nId = normalizeId(id);
- var player = players[nId];
- if (player) {
- return player;
- }
- tag = $("#" + nId);
- } else {
- tag = id;
- }
- if (isEl(tag)) {
- var _tag = tag, _player = _tag.player, playerId = _tag.playerId;
- if (_player || players[playerId]) {
- return _player || players[playerId];
- }
- }
- };
- videojs.getAllPlayers = function() {
- return Object.keys(Player.players).map(function(k) {
- return Player.players[k];
- }).filter(Boolean);
- };
- videojs.players = Player.players;
- videojs.getComponent = Component$1.getComponent;
- videojs.registerComponent = function(name, comp) {
- if (Tech$1.isTech(comp)) {
- log$1.warn("The " + name + " tech was registered as a component. It should instead be registered using videojs.registerTech(name, tech)");
- }
- Component$1.registerComponent.call(Component$1, name, comp);
- };
- videojs.getTech = Tech$1.getTech;
- videojs.registerTech = Tech$1.registerTech;
- videojs.use = use;
- Object.defineProperty(videojs, "middleware", {
- value: {},
- writeable: false,
- enumerable: true
- });
- Object.defineProperty(videojs.middleware, "TERMINATOR", {
- value: TERMINATOR,
- writeable: false,
- enumerable: true
- });
- videojs.browser = browser;
- videojs.TOUCH_ENABLED = TOUCH_ENABLED;
- videojs.extend = extend;
- videojs.mergeOptions = mergeOptions$3;
- videojs.bind = bind;
- videojs.registerPlugin = Plugin.registerPlugin;
- videojs.deregisterPlugin = Plugin.deregisterPlugin;
- videojs.plugin = function(name, plugin) {
- log$1.warn("videojs.plugin() is deprecated; use videojs.registerPlugin() instead");
- return Plugin.registerPlugin(name, plugin);
- };
- videojs.getPlugins = Plugin.getPlugins;
- videojs.getPlugin = Plugin.getPlugin;
- videojs.getPluginVersion = Plugin.getPluginVersion;
- videojs.addLanguage = function(code, data) {
- var _mergeOptions;
- code = ("" + code).toLowerCase();
- videojs.options.languages = mergeOptions$3(videojs.options.languages, (_mergeOptions = {}, _mergeOptions[code] = data, _mergeOptions));
- return videojs.options.languages[code];
- };
- videojs.log = log$1;
- videojs.createLogger = createLogger;
- videojs.createTimeRange = videojs.createTimeRanges = createTimeRanges;
- videojs.formatTime = formatTime;
- videojs.setFormatTime = setFormatTime;
- videojs.resetFormatTime = resetFormatTime;
- videojs.parseUrl = parseUrl;
- videojs.isCrossOrigin = isCrossOrigin;
- videojs.EventTarget = EventTarget$2;
- videojs.on = on;
- videojs.one = one;
- videojs.off = off;
- videojs.trigger = trigger;
- videojs.xhr = XHR;
- videojs.TextTrack = TextTrack;
- videojs.AudioTrack = AudioTrack;
- videojs.VideoTrack = VideoTrack;
- ["isEl", "isTextNode", "createEl", "hasClass", "addClass", "removeClass", "toggleClass", "setAttributes", "getAttributes", "emptyEl", "appendContent", "insertContent"].forEach(function(k) {
- videojs[k] = function() {
- log$1.warn("videojs." + k + "() is deprecated; use videojs.dom." + k + "() instead");
- return Dom$1[k].apply(null, arguments);
- };
- });
- videojs.computedStyle = computedStyle;
- videojs.dom = Dom$1;
- videojs.url = Url$1;
- videojs.defineLazyProperty = defineLazyProperty;
- videojs.addLanguage("en", {
- "Non-Fullscreen": "Exit Fullscreen"
- });
- /*! @name @videojs/http-streaming @version 2.16.2 @license Apache-2.0 */
- var resolveUrl4 = resolveUrl$1;
- var resolveManifestRedirect = function resolveManifestRedirect2(handleManifestRedirect, url, req) {
- if (handleManifestRedirect && req && req.responseURL && url !== req.responseURL) {
- return req.responseURL;
- }
- return url;
- };
- var logger = function logger2(source) {
- if (videojs.log.debug) {
- return videojs.log.debug.bind(videojs, "VHS:", source + " >");
- }
- return function() {
- };
- };
- var TIME_FUDGE_FACTOR = 1 / 30;
- var SAFE_TIME_DELTA = TIME_FUDGE_FACTOR * 3;
- var filterRanges = function filterRanges2(timeRanges, predicate) {
- var results = [];
- var i2;
- if (timeRanges && timeRanges.length) {
- for (i2 = 0; i2 < timeRanges.length; i2++) {
- if (predicate(timeRanges.start(i2), timeRanges.end(i2))) {
- results.push([timeRanges.start(i2), timeRanges.end(i2)]);
- }
- }
- }
- return videojs.createTimeRanges(results);
- };
- var findRange = function findRange2(buffered, time) {
- return filterRanges(buffered, function(start2, end) {
- return start2 - SAFE_TIME_DELTA <= time && end + SAFE_TIME_DELTA >= time;
- });
- };
- var findNextRange = function findNextRange2(timeRanges, time) {
- return filterRanges(timeRanges, function(start2) {
- return start2 - TIME_FUDGE_FACTOR >= time;
- });
- };
- var findGaps = function findGaps2(buffered) {
- if (buffered.length < 2) {
- return videojs.createTimeRanges();
- }
- var ranges = [];
- for (var i2 = 1; i2 < buffered.length; i2++) {
- var start2 = buffered.end(i2 - 1);
- var end = buffered.start(i2);
- ranges.push([start2, end]);
- }
- return videojs.createTimeRanges(ranges);
- };
- var bufferIntersection = function bufferIntersection2(bufferA, bufferB) {
- var start2 = null;
- var end = null;
- var arity = 0;
- var extents = [];
- var ranges = [];
- if (!bufferA || !bufferA.length || !bufferB || !bufferB.length) {
- return videojs.createTimeRange();
- }
- var count = bufferA.length;
- while (count--) {
- extents.push({
- time: bufferA.start(count),
- type: "start"
- });
- extents.push({
- time: bufferA.end(count),
- type: "end"
- });
- }
- count = bufferB.length;
- while (count--) {
- extents.push({
- time: bufferB.start(count),
- type: "start"
- });
- extents.push({
- time: bufferB.end(count),
- type: "end"
- });
- }
- extents.sort(function(a, b) {
- return a.time - b.time;
- });
- for (count = 0; count < extents.length; count++) {
- if (extents[count].type === "start") {
- arity++;
- if (arity === 2) {
- start2 = extents[count].time;
- }
- } else if (extents[count].type === "end") {
- arity--;
- if (arity === 1) {
- end = extents[count].time;
- }
- }
- if (start2 !== null && end !== null) {
- ranges.push([start2, end]);
- start2 = null;
- end = null;
- }
- }
- return videojs.createTimeRanges(ranges);
- };
- var printableRange = function printableRange2(range3) {
- var strArr = [];
- if (!range3 || !range3.length) {
- return "";
- }
- for (var i2 = 0; i2 < range3.length; i2++) {
- strArr.push(range3.start(i2) + " => " + range3.end(i2));
- }
- return strArr.join(", ");
- };
- var timeUntilRebuffer = function timeUntilRebuffer2(buffered, currentTime, playbackRate) {
- if (playbackRate === void 0) {
- playbackRate = 1;
- }
- var bufferedEnd = buffered.length ? buffered.end(buffered.length - 1) : 0;
- return (bufferedEnd - currentTime) / playbackRate;
- };
- var timeRangesToArray = function timeRangesToArray2(timeRanges) {
- var timeRangesList = [];
- for (var i2 = 0; i2 < timeRanges.length; i2++) {
- timeRangesList.push({
- start: timeRanges.start(i2),
- end: timeRanges.end(i2)
- });
- }
- return timeRangesList;
- };
- var isRangeDifferent = function isRangeDifferent2(a, b) {
- if (a === b) {
- return false;
- }
- if (!a && b || !b && a) {
- return true;
- }
- if (a.length !== b.length) {
- return true;
- }
- for (var i2 = 0; i2 < a.length; i2++) {
- if (a.start(i2) !== b.start(i2) || a.end(i2) !== b.end(i2)) {
- return true;
- }
- }
- return false;
- };
- var lastBufferedEnd = function lastBufferedEnd2(a) {
- if (!a || !a.length || !a.end) {
- return;
- }
- return a.end(a.length - 1);
- };
- var timeAheadOf = function timeAheadOf2(range3, startTime) {
- var time = 0;
- if (!range3 || !range3.length) {
- return time;
- }
- for (var i2 = 0; i2 < range3.length; i2++) {
- var start2 = range3.start(i2);
- var end = range3.end(i2);
- if (startTime > end) {
- continue;
- }
- if (startTime > start2 && startTime <= end) {
- time += end - startTime;
- continue;
- }
- time += end - start2;
- }
- return time;
- };
- var createTimeRange$1 = videojs.createTimeRange;
- var segmentDurationWithParts = function segmentDurationWithParts2(playlist, segment) {
- if (!segment.preload) {
- return segment.duration;
- }
- var result = 0;
- (segment.parts || []).forEach(function(p) {
- result += p.duration;
- });
- (segment.preloadHints || []).forEach(function(p) {
- if (p.type === "PART") {
- result += playlist.partTargetDuration;
- }
- });
- return result;
- };
- var getPartsAndSegments = function getPartsAndSegments2(playlist) {
- return (playlist.segments || []).reduce(function(acc, segment, si) {
- if (segment.parts) {
- segment.parts.forEach(function(part, pi) {
- acc.push({
- duration: part.duration,
- segmentIndex: si,
- partIndex: pi,
- part,
- segment
- });
- });
- } else {
- acc.push({
- duration: segment.duration,
- segmentIndex: si,
- partIndex: null,
- segment,
- part: null
- });
- }
- return acc;
- }, []);
- };
- var getLastParts = function getLastParts2(media) {
- var lastSegment = media.segments && media.segments.length && media.segments[media.segments.length - 1];
- return lastSegment && lastSegment.parts || [];
- };
- var getKnownPartCount = function getKnownPartCount2(_ref) {
- var preloadSegment = _ref.preloadSegment;
- if (!preloadSegment) {
- return;
- }
- var parts = preloadSegment.parts, preloadHints = preloadSegment.preloadHints;
- var partCount = (preloadHints || []).reduce(function(count, hint) {
- return count + (hint.type === "PART" ? 1 : 0);
- }, 0);
- partCount += parts && parts.length ? parts.length : 0;
- return partCount;
- };
- var liveEdgeDelay = function liveEdgeDelay2(master, media) {
- if (media.endList) {
- return 0;
- }
- if (master && master.suggestedPresentationDelay) {
- return master.suggestedPresentationDelay;
- }
- var hasParts = getLastParts(media).length > 0;
- if (hasParts && media.serverControl && media.serverControl.partHoldBack) {
- return media.serverControl.partHoldBack;
- } else if (hasParts && media.partTargetDuration) {
- return media.partTargetDuration * 3;
- } else if (media.serverControl && media.serverControl.holdBack) {
- return media.serverControl.holdBack;
- } else if (media.targetDuration) {
- return media.targetDuration * 3;
- }
- return 0;
- };
- var backwardDuration = function backwardDuration2(playlist, endSequence) {
- var result = 0;
- var i2 = endSequence - playlist.mediaSequence;
- var segment = playlist.segments[i2];
- if (segment) {
- if (typeof segment.start !== "undefined") {
- return {
- result: segment.start,
- precise: true
- };
- }
- if (typeof segment.end !== "undefined") {
- return {
- result: segment.end - segment.duration,
- precise: true
- };
- }
- }
- while (i2--) {
- segment = playlist.segments[i2];
- if (typeof segment.end !== "undefined") {
- return {
- result: result + segment.end,
- precise: true
- };
- }
- result += segmentDurationWithParts(playlist, segment);
- if (typeof segment.start !== "undefined") {
- return {
- result: result + segment.start,
- precise: true
- };
- }
- }
- return {
- result,
- precise: false
- };
- };
- var forwardDuration = function forwardDuration2(playlist, endSequence) {
- var result = 0;
- var segment;
- var i2 = endSequence - playlist.mediaSequence;
- for (; i2 < playlist.segments.length; i2++) {
- segment = playlist.segments[i2];
- if (typeof segment.start !== "undefined") {
- return {
- result: segment.start - result,
- precise: true
- };
- }
- result += segmentDurationWithParts(playlist, segment);
- if (typeof segment.end !== "undefined") {
- return {
- result: segment.end - result,
- precise: true
- };
- }
- }
- return {
- result: -1,
- precise: false
- };
- };
- var intervalDuration = function intervalDuration2(playlist, endSequence, expired) {
- if (typeof endSequence === "undefined") {
- endSequence = playlist.mediaSequence + playlist.segments.length;
- }
- if (endSequence < playlist.mediaSequence) {
- return 0;
- }
- var backward = backwardDuration(playlist, endSequence);
- if (backward.precise) {
- return backward.result;
- }
- var forward = forwardDuration(playlist, endSequence);
- if (forward.precise) {
- return forward.result;
- }
- return backward.result + expired;
- };
- var duration2 = function duration3(playlist, endSequence, expired) {
- if (!playlist) {
- return 0;
- }
- if (typeof expired !== "number") {
- expired = 0;
- }
- if (typeof endSequence === "undefined") {
- if (playlist.totalDuration) {
- return playlist.totalDuration;
- }
- if (!playlist.endList) {
- return window_1.Infinity;
- }
- }
- return intervalDuration(playlist, endSequence, expired);
- };
- var sumDurations = function sumDurations2(_ref2) {
- var defaultDuration = _ref2.defaultDuration, durationList = _ref2.durationList, startIndex = _ref2.startIndex, endIndex = _ref2.endIndex;
- var durations = 0;
- if (startIndex > endIndex) {
- var _ref3 = [endIndex, startIndex];
- startIndex = _ref3[0];
- endIndex = _ref3[1];
- }
- if (startIndex < 0) {
- for (var i2 = startIndex; i2 < Math.min(0, endIndex); i2++) {
- durations += defaultDuration;
- }
- startIndex = 0;
- }
- for (var _i = startIndex; _i < endIndex; _i++) {
- durations += durationList[_i].duration;
- }
- return durations;
- };
- var playlistEnd = function playlistEnd2(playlist, expired, useSafeLiveEnd, liveEdgePadding) {
- if (!playlist || !playlist.segments) {
- return null;
- }
- if (playlist.endList) {
- return duration2(playlist);
- }
- if (expired === null) {
- return null;
- }
- expired = expired || 0;
- var lastSegmentEndTime = intervalDuration(playlist, playlist.mediaSequence + playlist.segments.length, expired);
- if (useSafeLiveEnd) {
- liveEdgePadding = typeof liveEdgePadding === "number" ? liveEdgePadding : liveEdgeDelay(null, playlist);
- lastSegmentEndTime -= liveEdgePadding;
- }
- return Math.max(0, lastSegmentEndTime);
- };
- var seekable = function seekable2(playlist, expired, liveEdgePadding) {
- var useSafeLiveEnd = true;
- var seekableStart = expired || 0;
- var seekableEnd = playlistEnd(playlist, expired, useSafeLiveEnd, liveEdgePadding);
- if (seekableEnd === null) {
- return createTimeRange$1();
- }
- return createTimeRange$1(seekableStart, seekableEnd);
- };
- var getMediaInfoForTime = function getMediaInfoForTime2(_ref4) {
- var playlist = _ref4.playlist, currentTime = _ref4.currentTime, startingSegmentIndex = _ref4.startingSegmentIndex, startingPartIndex = _ref4.startingPartIndex, startTime = _ref4.startTime, experimentalExactManifestTimings = _ref4.experimentalExactManifestTimings;
- var time = currentTime - startTime;
- var partsAndSegments = getPartsAndSegments(playlist);
- var startIndex = 0;
- for (var i2 = 0; i2 < partsAndSegments.length; i2++) {
- var partAndSegment = partsAndSegments[i2];
- if (startingSegmentIndex !== partAndSegment.segmentIndex) {
- continue;
- }
- if (typeof startingPartIndex === "number" && typeof partAndSegment.partIndex === "number" && startingPartIndex !== partAndSegment.partIndex) {
- continue;
- }
- startIndex = i2;
- break;
- }
- if (time < 0) {
- if (startIndex > 0) {
- for (var _i2 = startIndex - 1; _i2 >= 0; _i2--) {
- var _partAndSegment = partsAndSegments[_i2];
- time += _partAndSegment.duration;
- if (experimentalExactManifestTimings) {
- if (time < 0) {
- continue;
- }
- } else if (time + TIME_FUDGE_FACTOR <= 0) {
- continue;
- }
- return {
- partIndex: _partAndSegment.partIndex,
- segmentIndex: _partAndSegment.segmentIndex,
- startTime: startTime - sumDurations({
- defaultDuration: playlist.targetDuration,
- durationList: partsAndSegments,
- startIndex,
- endIndex: _i2
- })
- };
- }
- }
- return {
- partIndex: partsAndSegments[0] && partsAndSegments[0].partIndex || null,
- segmentIndex: partsAndSegments[0] && partsAndSegments[0].segmentIndex || 0,
- startTime: currentTime
- };
- }
- if (startIndex < 0) {
- for (var _i3 = startIndex; _i3 < 0; _i3++) {
- time -= playlist.targetDuration;
- if (time < 0) {
- return {
- partIndex: partsAndSegments[0] && partsAndSegments[0].partIndex || null,
- segmentIndex: partsAndSegments[0] && partsAndSegments[0].segmentIndex || 0,
- startTime: currentTime
- };
- }
- }
- startIndex = 0;
- }
- for (var _i4 = startIndex; _i4 < partsAndSegments.length; _i4++) {
- var _partAndSegment2 = partsAndSegments[_i4];
- time -= _partAndSegment2.duration;
- if (experimentalExactManifestTimings) {
- if (time > 0) {
- continue;
- }
- } else if (time - TIME_FUDGE_FACTOR >= 0) {
- continue;
- }
- return {
- partIndex: _partAndSegment2.partIndex,
- segmentIndex: _partAndSegment2.segmentIndex,
- startTime: startTime + sumDurations({
- defaultDuration: playlist.targetDuration,
- durationList: partsAndSegments,
- startIndex,
- endIndex: _i4
- })
- };
- }
- return {
- segmentIndex: partsAndSegments[partsAndSegments.length - 1].segmentIndex,
- partIndex: partsAndSegments[partsAndSegments.length - 1].partIndex,
- startTime: currentTime
- };
- };
- var isBlacklisted = function isBlacklisted2(playlist) {
- return playlist.excludeUntil && playlist.excludeUntil > Date.now();
- };
- var isIncompatible = function isIncompatible2(playlist) {
- return playlist.excludeUntil && playlist.excludeUntil === Infinity;
- };
- var isEnabled = function isEnabled2(playlist) {
- var blacklisted = isBlacklisted(playlist);
- return !playlist.disabled && !blacklisted;
- };
- var isDisabled = function isDisabled2(playlist) {
- return playlist.disabled;
- };
- var isAes = function isAes2(media) {
- for (var i2 = 0; i2 < media.segments.length; i2++) {
- if (media.segments[i2].key) {
- return true;
- }
- }
- return false;
- };
- var hasAttribute = function hasAttribute2(attr, playlist) {
- return playlist.attributes && playlist.attributes[attr];
- };
- var estimateSegmentRequestTime = function estimateSegmentRequestTime2(segmentDuration, bandwidth2, playlist, bytesReceived) {
- if (bytesReceived === void 0) {
- bytesReceived = 0;
- }
- if (!hasAttribute("BANDWIDTH", playlist)) {
- return NaN;
- }
- var size = segmentDuration * playlist.attributes.BANDWIDTH;
- return (size - bytesReceived * 8) / bandwidth2;
- };
- var isLowestEnabledRendition = function isLowestEnabledRendition2(master, media) {
- if (master.playlists.length === 1) {
- return true;
- }
- var currentBandwidth = media.attributes.BANDWIDTH || Number.MAX_VALUE;
- return master.playlists.filter(function(playlist) {
- if (!isEnabled(playlist)) {
- return false;
- }
- return (playlist.attributes.BANDWIDTH || 0) < currentBandwidth;
- }).length === 0;
- };
- var playlistMatch = function playlistMatch2(a, b) {
- if (!a && !b || !a && b || a && !b) {
- return false;
- }
- if (a === b) {
- return true;
- }
- if (a.id && b.id && a.id === b.id) {
- return true;
- }
- if (a.resolvedUri && b.resolvedUri && a.resolvedUri === b.resolvedUri) {
- return true;
- }
- if (a.uri && b.uri && a.uri === b.uri) {
- return true;
- }
- return false;
- };
- var someAudioVariant = function someAudioVariant2(master, callback2) {
- var AUDIO5 = master && master.mediaGroups && master.mediaGroups.AUDIO || {};
- var found = false;
- for (var groupName in AUDIO5) {
- for (var label2 in AUDIO5[groupName]) {
- found = callback2(AUDIO5[groupName][label2]);
- if (found) {
- break;
- }
- }
- if (found) {
- break;
- }
- }
- return !!found;
- };
- var isAudioOnly = function isAudioOnly2(master) {
- if (!master || !master.playlists || !master.playlists.length) {
- var found = someAudioVariant(master, function(variant) {
- return variant.playlists && variant.playlists.length || variant.uri;
- });
- return found;
- }
- var _loop = function _loop2(i3) {
- var playlist = master.playlists[i3];
- var CODECS = playlist.attributes && playlist.attributes.CODECS;
- if (CODECS && CODECS.split(",").every(function(c) {
- return isAudioCodec2(c);
- })) {
- return "continue";
- }
- var found2 = someAudioVariant(master, function(variant) {
- return playlistMatch(playlist, variant);
- });
- if (found2) {
- return "continue";
- }
- return {
- v: false
- };
- };
- for (var i2 = 0; i2 < master.playlists.length; i2++) {
- var _ret = _loop(i2);
- if (_ret === "continue")
- continue;
- if (typeof _ret === "object")
- return _ret.v;
- }
- return true;
- };
- var Playlist = {
- liveEdgeDelay,
- duration: duration2,
- seekable,
- getMediaInfoForTime,
- isEnabled,
- isDisabled,
- isBlacklisted,
- isIncompatible,
- playlistEnd,
- isAes,
- hasAttribute,
- estimateSegmentRequestTime,
- isLowestEnabledRendition,
- isAudioOnly,
- playlistMatch,
- segmentDurationWithParts
- };
- var log = videojs.log;
- var createPlaylistID = function createPlaylistID2(index2, uri) {
- return index2 + "-" + uri;
- };
- var groupID = function groupID2(type2, group, label2) {
- return "placeholder-uri-" + type2 + "-" + group + "-" + label2;
- };
- var parseManifest = function parseManifest2(_ref) {
- var onwarn = _ref.onwarn, oninfo = _ref.oninfo, manifestString = _ref.manifestString, _ref$customTagParsers = _ref.customTagParsers, customTagParsers = _ref$customTagParsers === void 0 ? [] : _ref$customTagParsers, _ref$customTagMappers = _ref.customTagMappers, customTagMappers = _ref$customTagMappers === void 0 ? [] : _ref$customTagMappers, experimentalLLHLS = _ref.experimentalLLHLS;
- var parser2 = new Parser();
- if (onwarn) {
- parser2.on("warn", onwarn);
- }
- if (oninfo) {
- parser2.on("info", oninfo);
- }
- customTagParsers.forEach(function(customParser) {
- return parser2.addParser(customParser);
- });
- customTagMappers.forEach(function(mapper) {
- return parser2.addTagMapper(mapper);
- });
- parser2.push(manifestString);
- parser2.end();
- var manifest = parser2.manifest;
- if (!experimentalLLHLS) {
- ["preloadSegment", "skip", "serverControl", "renditionReports", "partInf", "partTargetDuration"].forEach(function(k) {
- if (manifest.hasOwnProperty(k)) {
- delete manifest[k];
- }
- });
- if (manifest.segments) {
- manifest.segments.forEach(function(segment) {
- ["parts", "preloadHints"].forEach(function(k) {
- if (segment.hasOwnProperty(k)) {
- delete segment[k];
- }
- });
- });
- }
- }
- if (!manifest.targetDuration) {
- var targetDuration = 10;
- if (manifest.segments && manifest.segments.length) {
- targetDuration = manifest.segments.reduce(function(acc, s) {
- return Math.max(acc, s.duration);
- }, 0);
- }
- if (onwarn) {
- onwarn("manifest has no targetDuration defaulting to " + targetDuration);
- }
- manifest.targetDuration = targetDuration;
- }
- var parts = getLastParts(manifest);
- if (parts.length && !manifest.partTargetDuration) {
- var partTargetDuration = parts.reduce(function(acc, p) {
- return Math.max(acc, p.duration);
- }, 0);
- if (onwarn) {
- onwarn("manifest has no partTargetDuration defaulting to " + partTargetDuration);
- log.error("LL-HLS manifest has parts but lacks required #EXT-X-PART-INF:PART-TARGET value. See https://datatracker.ietf.org/doc/html/draft-pantos-hls-rfc8216bis-09#section-4.4.3.7. Playback is not guaranteed.");
- }
- manifest.partTargetDuration = partTargetDuration;
- }
- return manifest;
- };
- var forEachMediaGroup3 = function forEachMediaGroup4(master, callback2) {
- if (!master.mediaGroups) {
- return;
- }
- ["AUDIO", "SUBTITLES"].forEach(function(mediaType) {
- if (!master.mediaGroups[mediaType]) {
- return;
- }
- for (var groupKey in master.mediaGroups[mediaType]) {
- for (var labelKey in master.mediaGroups[mediaType][groupKey]) {
- var mediaProperties = master.mediaGroups[mediaType][groupKey][labelKey];
- callback2(mediaProperties, mediaType, groupKey, labelKey);
- }
- }
- });
- };
- var setupMediaPlaylist = function setupMediaPlaylist2(_ref2) {
- var playlist = _ref2.playlist, uri = _ref2.uri, id = _ref2.id;
- playlist.id = id;
- playlist.playlistErrors_ = 0;
- if (uri) {
- playlist.uri = uri;
- }
- playlist.attributes = playlist.attributes || {};
- };
- var setupMediaPlaylists = function setupMediaPlaylists2(master) {
- var i2 = master.playlists.length;
- while (i2--) {
- var playlist = master.playlists[i2];
- setupMediaPlaylist({
- playlist,
- id: createPlaylistID(i2, playlist.uri)
- });
- playlist.resolvedUri = resolveUrl4(master.uri, playlist.uri);
- master.playlists[playlist.id] = playlist;
- master.playlists[playlist.uri] = playlist;
- if (!playlist.attributes.BANDWIDTH) {
- log.warn("Invalid playlist STREAM-INF detected. Missing BANDWIDTH attribute.");
- }
- }
- };
- var resolveMediaGroupUris = function resolveMediaGroupUris2(master) {
- forEachMediaGroup3(master, function(properties) {
- if (properties.uri) {
- properties.resolvedUri = resolveUrl4(master.uri, properties.uri);
- }
- });
- };
- var masterForMedia = function masterForMedia2(media, uri) {
- var id = createPlaylistID(0, uri);
- var master = {
- mediaGroups: {
- "AUDIO": {},
- "VIDEO": {},
- "CLOSED-CAPTIONS": {},
- "SUBTITLES": {}
- },
- uri: window_1.location.href,
- resolvedUri: window_1.location.href,
- playlists: [{
- uri,
- id,
- resolvedUri: uri,
- attributes: {}
- }]
- };
- master.playlists[id] = master.playlists[0];
- master.playlists[uri] = master.playlists[0];
- return master;
- };
- var addPropertiesToMaster = function addPropertiesToMaster2(master, uri, createGroupID) {
- if (createGroupID === void 0) {
- createGroupID = groupID;
- }
- master.uri = uri;
- for (var i2 = 0; i2 < master.playlists.length; i2++) {
- if (!master.playlists[i2].uri) {
- var phonyUri = "placeholder-uri-" + i2;
- master.playlists[i2].uri = phonyUri;
- }
- }
- var audioOnlyMaster = isAudioOnly(master);
- forEachMediaGroup3(master, function(properties, mediaType, groupKey, labelKey) {
- if (!properties.playlists || !properties.playlists.length) {
- if (audioOnlyMaster && mediaType === "AUDIO" && !properties.uri) {
- for (var _i = 0; _i < master.playlists.length; _i++) {
- var p = master.playlists[_i];
- if (p.attributes && p.attributes.AUDIO && p.attributes.AUDIO === groupKey) {
- return;
- }
- }
- }
- properties.playlists = [_extends$2({}, properties)];
- }
- properties.playlists.forEach(function(p2, i3) {
- var groupId = createGroupID(mediaType, groupKey, labelKey, p2);
- var id = createPlaylistID(i3, groupId);
- if (p2.uri) {
- p2.resolvedUri = p2.resolvedUri || resolveUrl4(master.uri, p2.uri);
- } else {
- p2.uri = i3 === 0 ? groupId : id;
- p2.resolvedUri = p2.uri;
- }
- p2.id = p2.id || id;
- p2.attributes = p2.attributes || {};
- master.playlists[p2.id] = p2;
- master.playlists[p2.uri] = p2;
- });
- });
- setupMediaPlaylists(master);
- resolveMediaGroupUris(master);
- };
- var mergeOptions$2 = videojs.mergeOptions, EventTarget$1 = videojs.EventTarget;
- var addLLHLSQueryDirectives = function addLLHLSQueryDirectives2(uri, media) {
- if (media.endList || !media.serverControl) {
- return uri;
- }
- var parameters = {};
- if (media.serverControl.canBlockReload) {
- var preloadSegment = media.preloadSegment;
- var nextMSN = media.mediaSequence + media.segments.length;
- if (preloadSegment) {
- var parts = preloadSegment.parts || [];
- var nextPart = getKnownPartCount(media) - 1;
- if (nextPart > -1 && nextPart !== parts.length - 1) {
- parameters._HLS_part = nextPart;
- }
- if (nextPart > -1 || parts.length) {
- nextMSN--;
- }
- }
- parameters._HLS_msn = nextMSN;
- }
- if (media.serverControl && media.serverControl.canSkipUntil) {
- parameters._HLS_skip = media.serverControl.canSkipDateranges ? "v2" : "YES";
- }
- if (Object.keys(parameters).length) {
- var parsedUri = new window_1.URL(uri);
- ["_HLS_skip", "_HLS_msn", "_HLS_part"].forEach(function(name) {
- if (!parameters.hasOwnProperty(name)) {
- return;
- }
- parsedUri.searchParams.set(name, parameters[name]);
- });
- uri = parsedUri.toString();
- }
- return uri;
- };
- var updateSegment = function updateSegment2(a, b) {
- if (!a) {
- return b;
- }
- var result = mergeOptions$2(a, b);
- if (a.preloadHints && !b.preloadHints) {
- delete result.preloadHints;
- }
- if (a.parts && !b.parts) {
- delete result.parts;
- } else if (a.parts && b.parts) {
- for (var i2 = 0; i2 < b.parts.length; i2++) {
- if (a.parts && a.parts[i2]) {
- result.parts[i2] = mergeOptions$2(a.parts[i2], b.parts[i2]);
- }
- }
- }
- if (!a.skipped && b.skipped) {
- result.skipped = false;
- }
- if (a.preload && !b.preload) {
- result.preload = false;
- }
- return result;
- };
- var updateSegments = function updateSegments2(original, update, offset) {
- var oldSegments = original.slice();
- var newSegments = update.slice();
- offset = offset || 0;
- var result = [];
- var currentMap;
- for (var newIndex = 0; newIndex < newSegments.length; newIndex++) {
- var oldSegment = oldSegments[newIndex + offset];
- var newSegment = newSegments[newIndex];
- if (oldSegment) {
- currentMap = oldSegment.map || currentMap;
- result.push(updateSegment(oldSegment, newSegment));
- } else {
- if (currentMap && !newSegment.map) {
- newSegment.map = currentMap;
- }
- result.push(newSegment);
- }
- }
- return result;
- };
- var resolveSegmentUris = function resolveSegmentUris2(segment, baseUri) {
- if (!segment.resolvedUri && segment.uri) {
- segment.resolvedUri = resolveUrl4(baseUri, segment.uri);
- }
- if (segment.key && !segment.key.resolvedUri) {
- segment.key.resolvedUri = resolveUrl4(baseUri, segment.key.uri);
- }
- if (segment.map && !segment.map.resolvedUri) {
- segment.map.resolvedUri = resolveUrl4(baseUri, segment.map.uri);
- }
- if (segment.map && segment.map.key && !segment.map.key.resolvedUri) {
- segment.map.key.resolvedUri = resolveUrl4(baseUri, segment.map.key.uri);
- }
- if (segment.parts && segment.parts.length) {
- segment.parts.forEach(function(p) {
- if (p.resolvedUri) {
- return;
- }
- p.resolvedUri = resolveUrl4(baseUri, p.uri);
- });
- }
- if (segment.preloadHints && segment.preloadHints.length) {
- segment.preloadHints.forEach(function(p) {
- if (p.resolvedUri) {
- return;
- }
- p.resolvedUri = resolveUrl4(baseUri, p.uri);
- });
- }
- };
- var getAllSegments = function getAllSegments2(media) {
- var segments = media.segments || [];
- var preloadSegment = media.preloadSegment;
- if (preloadSegment && preloadSegment.parts && preloadSegment.parts.length) {
- if (preloadSegment.preloadHints) {
- for (var i2 = 0; i2 < preloadSegment.preloadHints.length; i2++) {
- if (preloadSegment.preloadHints[i2].type === "MAP") {
- return segments;
- }
- }
- }
- preloadSegment.duration = media.targetDuration;
- preloadSegment.preload = true;
- segments.push(preloadSegment);
- }
- return segments;
- };
- var isPlaylistUnchanged = function isPlaylistUnchanged2(a, b) {
- return a === b || a.segments && b.segments && a.segments.length === b.segments.length && a.endList === b.endList && a.mediaSequence === b.mediaSequence && a.preloadSegment === b.preloadSegment;
- };
- var updateMaster$1 = function updateMaster(master, newMedia, unchangedCheck) {
- if (unchangedCheck === void 0) {
- unchangedCheck = isPlaylistUnchanged;
- }
- var result = mergeOptions$2(master, {});
- var oldMedia = result.playlists[newMedia.id];
- if (!oldMedia) {
- return null;
- }
- if (unchangedCheck(oldMedia, newMedia)) {
- return null;
- }
- newMedia.segments = getAllSegments(newMedia);
- var mergedPlaylist = mergeOptions$2(oldMedia, newMedia);
- if (mergedPlaylist.preloadSegment && !newMedia.preloadSegment) {
- delete mergedPlaylist.preloadSegment;
- }
- if (oldMedia.segments) {
- if (newMedia.skip) {
- newMedia.segments = newMedia.segments || [];
- for (var i2 = 0; i2 < newMedia.skip.skippedSegments; i2++) {
- newMedia.segments.unshift({
- skipped: true
- });
- }
- }
- mergedPlaylist.segments = updateSegments(oldMedia.segments, newMedia.segments, newMedia.mediaSequence - oldMedia.mediaSequence);
- }
- mergedPlaylist.segments.forEach(function(segment) {
- resolveSegmentUris(segment, mergedPlaylist.resolvedUri);
- });
- for (var _i = 0; _i < result.playlists.length; _i++) {
- if (result.playlists[_i].id === newMedia.id) {
- result.playlists[_i] = mergedPlaylist;
- }
- }
- result.playlists[newMedia.id] = mergedPlaylist;
- result.playlists[newMedia.uri] = mergedPlaylist;
- forEachMediaGroup3(master, function(properties, mediaType, groupKey, labelKey) {
- if (!properties.playlists) {
- return;
- }
- for (var _i2 = 0; _i2 < properties.playlists.length; _i2++) {
- if (newMedia.id === properties.playlists[_i2].id) {
- properties.playlists[_i2] = mergedPlaylist;
- }
- }
- });
- return result;
- };
- var refreshDelay = function refreshDelay2(media, update) {
- var segments = media.segments || [];
- var lastSegment = segments[segments.length - 1];
- var lastPart = lastSegment && lastSegment.parts && lastSegment.parts[lastSegment.parts.length - 1];
- var lastDuration = lastPart && lastPart.duration || lastSegment && lastSegment.duration;
- if (update && lastDuration) {
- return lastDuration * 1e3;
- }
- return (media.partTargetDuration || media.targetDuration || 10) * 500;
- };
- var PlaylistLoader = /* @__PURE__ */ function(_EventTarget) {
- _inheritsLoose(PlaylistLoader2, _EventTarget);
- function PlaylistLoader2(src, vhs, options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- _this = _EventTarget.call(this) || this;
- if (!src) {
- throw new Error("A non-empty playlist URL or object is required");
- }
- _this.logger_ = logger("PlaylistLoader");
- var _options = options2, _options$withCredenti = _options.withCredentials, withCredentials = _options$withCredenti === void 0 ? false : _options$withCredenti, _options$handleManife = _options.handleManifestRedirects, handleManifestRedirects = _options$handleManife === void 0 ? false : _options$handleManife;
- _this.src = src;
- _this.vhs_ = vhs;
- _this.withCredentials = withCredentials;
- _this.handleManifestRedirects = handleManifestRedirects;
- var vhsOptions = vhs.options_;
- _this.customTagParsers = vhsOptions && vhsOptions.customTagParsers || [];
- _this.customTagMappers = vhsOptions && vhsOptions.customTagMappers || [];
- _this.experimentalLLHLS = vhsOptions && vhsOptions.experimentalLLHLS || false;
- if (videojs.browser.IE_VERSION) {
- _this.experimentalLLHLS = false;
- }
- _this.state = "HAVE_NOTHING";
- _this.handleMediaupdatetimeout_ = _this.handleMediaupdatetimeout_.bind(_assertThisInitialized(_this));
- _this.on("mediaupdatetimeout", _this.handleMediaupdatetimeout_);
- return _this;
- }
- var _proto = PlaylistLoader2.prototype;
- _proto.handleMediaupdatetimeout_ = function handleMediaupdatetimeout_() {
- var _this2 = this;
- if (this.state !== "HAVE_METADATA") {
- return;
- }
- var media = this.media();
- var uri = resolveUrl4(this.master.uri, media.uri);
- if (this.experimentalLLHLS) {
- uri = addLLHLSQueryDirectives(uri, media);
- }
- this.state = "HAVE_CURRENT_METADATA";
- this.request = this.vhs_.xhr({
- uri,
- withCredentials: this.withCredentials
- }, function(error, req) {
- if (!_this2.request) {
- return;
- }
- if (error) {
- return _this2.playlistRequestError(_this2.request, _this2.media(), "HAVE_METADATA");
- }
- _this2.haveMetadata({
- playlistString: _this2.request.responseText,
- url: _this2.media().uri,
- id: _this2.media().id
- });
- });
- };
- _proto.playlistRequestError = function playlistRequestError(xhr, playlist, startingState) {
- var uri = playlist.uri, id = playlist.id;
- this.request = null;
- if (startingState) {
- this.state = startingState;
- }
- this.error = {
- playlist: this.master.playlists[id],
- status: xhr.status,
- message: "HLS playlist request error at URL: " + uri + ".",
- responseText: xhr.responseText,
- code: xhr.status >= 500 ? 4 : 2
- };
- this.trigger("error");
- };
- _proto.parseManifest_ = function parseManifest_(_ref) {
- var _this3 = this;
- var url = _ref.url, manifestString = _ref.manifestString;
- return parseManifest({
- onwarn: function onwarn(_ref2) {
- var message = _ref2.message;
- return _this3.logger_("m3u8-parser warn for " + url + ": " + message);
- },
- oninfo: function oninfo(_ref3) {
- var message = _ref3.message;
- return _this3.logger_("m3u8-parser info for " + url + ": " + message);
- },
- manifestString,
- customTagParsers: this.customTagParsers,
- customTagMappers: this.customTagMappers,
- experimentalLLHLS: this.experimentalLLHLS
- });
- };
- _proto.haveMetadata = function haveMetadata(_ref4) {
- var playlistString = _ref4.playlistString, playlistObject = _ref4.playlistObject, url = _ref4.url, id = _ref4.id;
- this.request = null;
- this.state = "HAVE_METADATA";
- var playlist = playlistObject || this.parseManifest_({
- url,
- manifestString: playlistString
- });
- playlist.lastRequest = Date.now();
- setupMediaPlaylist({
- playlist,
- uri: url,
- id
- });
- var update = updateMaster$1(this.master, playlist);
- this.targetDuration = playlist.partTargetDuration || playlist.targetDuration;
- this.pendingMedia_ = null;
- if (update) {
- this.master = update;
- this.media_ = this.master.playlists[id];
- } else {
- this.trigger("playlistunchanged");
- }
- this.updateMediaUpdateTimeout_(refreshDelay(this.media(), !!update));
- this.trigger("loadedplaylist");
- };
- _proto.dispose = function dispose() {
- this.trigger("dispose");
- this.stopRequest();
- window_1.clearTimeout(this.mediaUpdateTimeout);
- window_1.clearTimeout(this.finalRenditionTimeout);
- this.off();
- };
- _proto.stopRequest = function stopRequest() {
- if (this.request) {
- var oldRequest = this.request;
- this.request = null;
- oldRequest.onreadystatechange = null;
- oldRequest.abort();
- }
- };
- _proto.media = function media(playlist, shouldDelay) {
- var _this4 = this;
- if (!playlist) {
- return this.media_;
- }
- if (this.state === "HAVE_NOTHING") {
- throw new Error("Cannot switch media playlist from " + this.state);
- }
- if (typeof playlist === "string") {
- if (!this.master.playlists[playlist]) {
- throw new Error("Unknown playlist URI: " + playlist);
- }
- playlist = this.master.playlists[playlist];
- }
- window_1.clearTimeout(this.finalRenditionTimeout);
- if (shouldDelay) {
- var delay = (playlist.partTargetDuration || playlist.targetDuration) / 2 * 1e3 || 5 * 1e3;
- this.finalRenditionTimeout = window_1.setTimeout(this.media.bind(this, playlist, false), delay);
- return;
- }
- var startingState = this.state;
- var mediaChange = !this.media_ || playlist.id !== this.media_.id;
- var masterPlaylistRef = this.master.playlists[playlist.id];
- if (masterPlaylistRef && masterPlaylistRef.endList || playlist.endList && playlist.segments.length) {
- if (this.request) {
- this.request.onreadystatechange = null;
- this.request.abort();
- this.request = null;
- }
- this.state = "HAVE_METADATA";
- this.media_ = playlist;
- if (mediaChange) {
- this.trigger("mediachanging");
- if (startingState === "HAVE_MASTER") {
- this.trigger("loadedmetadata");
- } else {
- this.trigger("mediachange");
- }
- }
- return;
- }
- this.updateMediaUpdateTimeout_(refreshDelay(playlist, true));
- if (!mediaChange) {
- return;
- }
- this.state = "SWITCHING_MEDIA";
- if (this.request) {
- if (playlist.resolvedUri === this.request.url) {
- return;
- }
- this.request.onreadystatechange = null;
- this.request.abort();
- this.request = null;
- }
- if (this.media_) {
- this.trigger("mediachanging");
- }
- this.pendingMedia_ = playlist;
- this.request = this.vhs_.xhr({
- uri: playlist.resolvedUri,
- withCredentials: this.withCredentials
- }, function(error, req) {
- if (!_this4.request) {
- return;
- }
- playlist.lastRequest = Date.now();
- playlist.resolvedUri = resolveManifestRedirect(_this4.handleManifestRedirects, playlist.resolvedUri, req);
- if (error) {
- return _this4.playlistRequestError(_this4.request, playlist, startingState);
- }
- _this4.haveMetadata({
- playlistString: req.responseText,
- url: playlist.uri,
- id: playlist.id
- });
- if (startingState === "HAVE_MASTER") {
- _this4.trigger("loadedmetadata");
- } else {
- _this4.trigger("mediachange");
- }
- });
- };
- _proto.pause = function pause() {
- if (this.mediaUpdateTimeout) {
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- }
- this.stopRequest();
- if (this.state === "HAVE_NOTHING") {
- this.started = false;
- }
- if (this.state === "SWITCHING_MEDIA") {
- if (this.media_) {
- this.state = "HAVE_METADATA";
- } else {
- this.state = "HAVE_MASTER";
- }
- } else if (this.state === "HAVE_CURRENT_METADATA") {
- this.state = "HAVE_METADATA";
- }
- };
- _proto.load = function load(shouldDelay) {
- var _this5 = this;
- if (this.mediaUpdateTimeout) {
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- }
- var media = this.media();
- if (shouldDelay) {
- var delay = media ? (media.partTargetDuration || media.targetDuration) / 2 * 1e3 : 5 * 1e3;
- this.mediaUpdateTimeout = window_1.setTimeout(function() {
- _this5.mediaUpdateTimeout = null;
- _this5.load();
- }, delay);
- return;
- }
- if (!this.started) {
- this.start();
- return;
- }
- if (media && !media.endList) {
- this.trigger("mediaupdatetimeout");
- } else {
- this.trigger("loadedplaylist");
- }
- };
- _proto.updateMediaUpdateTimeout_ = function updateMediaUpdateTimeout_(delay) {
- var _this6 = this;
- if (this.mediaUpdateTimeout) {
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- }
- if (!this.media() || this.media().endList) {
- return;
- }
- this.mediaUpdateTimeout = window_1.setTimeout(function() {
- _this6.mediaUpdateTimeout = null;
- _this6.trigger("mediaupdatetimeout");
- _this6.updateMediaUpdateTimeout_(delay);
- }, delay);
- };
- _proto.start = function start2() {
- var _this7 = this;
- this.started = true;
- if (typeof this.src === "object") {
- if (!this.src.uri) {
- this.src.uri = window_1.location.href;
- }
- this.src.resolvedUri = this.src.uri;
- setTimeout(function() {
- _this7.setupInitialPlaylist(_this7.src);
- }, 0);
- return;
- }
- this.request = this.vhs_.xhr({
- uri: this.src,
- withCredentials: this.withCredentials
- }, function(error, req) {
- if (!_this7.request) {
- return;
- }
- _this7.request = null;
- if (error) {
- _this7.error = {
- status: req.status,
- message: "HLS playlist request error at URL: " + _this7.src + ".",
- responseText: req.responseText,
- code: 2
- };
- if (_this7.state === "HAVE_NOTHING") {
- _this7.started = false;
- }
- return _this7.trigger("error");
- }
- _this7.src = resolveManifestRedirect(_this7.handleManifestRedirects, _this7.src, req);
- var manifest = _this7.parseManifest_({
- manifestString: req.responseText,
- url: _this7.src
- });
- _this7.setupInitialPlaylist(manifest);
- });
- };
- _proto.srcUri = function srcUri() {
- return typeof this.src === "string" ? this.src : this.src.uri;
- };
- _proto.setupInitialPlaylist = function setupInitialPlaylist(manifest) {
- this.state = "HAVE_MASTER";
- if (manifest.playlists) {
- this.master = manifest;
- addPropertiesToMaster(this.master, this.srcUri());
- manifest.playlists.forEach(function(playlist) {
- playlist.segments = getAllSegments(playlist);
- playlist.segments.forEach(function(segment) {
- resolveSegmentUris(segment, playlist.resolvedUri);
- });
- });
- this.trigger("loadedplaylist");
- if (!this.request) {
- this.media(this.master.playlists[0]);
- }
- return;
- }
- var uri = this.srcUri() || window_1.location.href;
- this.master = masterForMedia(manifest, uri);
- this.haveMetadata({
- playlistObject: manifest,
- url: uri,
- id: this.master.playlists[0].id
- });
- this.trigger("loadedmetadata");
- };
- return PlaylistLoader2;
- }(EventTarget$1);
- var videojsXHR = videojs.xhr, mergeOptions$1$1 = videojs.mergeOptions;
- var callbackWrapper = function callbackWrapper2(request, error, response, callback2) {
- var reqResponse = request.responseType === "arraybuffer" ? request.response : request.responseText;
- if (!error && reqResponse) {
- request.responseTime = Date.now();
- request.roundTripTime = request.responseTime - request.requestTime;
- request.bytesReceived = reqResponse.byteLength || reqResponse.length;
- if (!request.bandwidth) {
- request.bandwidth = Math.floor(request.bytesReceived / request.roundTripTime * 8 * 1e3);
- }
- }
- if (response.headers) {
- request.responseHeaders = response.headers;
- }
- if (error && error.code === "ETIMEDOUT") {
- request.timedout = true;
- }
- if (!error && !request.aborted && response.statusCode !== 200 && response.statusCode !== 206 && response.statusCode !== 0) {
- error = new Error("XHR Failed with a response of: " + (request && (reqResponse || request.responseText)));
- }
- callback2(error, request);
- };
- var xhrFactory = function xhrFactory2() {
- var xhr = function XhrFunction(options2, callback2) {
- options2 = mergeOptions$1$1({
- timeout: 45e3
- }, options2);
- var beforeRequest = XhrFunction.beforeRequest || videojs.Vhs.xhr.beforeRequest;
- if (beforeRequest && typeof beforeRequest === "function") {
- var newOptions = beforeRequest(options2);
- if (newOptions) {
- options2 = newOptions;
- }
- }
- var xhrMethod = videojs.Vhs.xhr.original === true ? videojsXHR : videojs.Vhs.xhr;
- var request = xhrMethod(options2, function(error, response) {
- return callbackWrapper(request, error, response, callback2);
- });
- var originalAbort = request.abort;
- request.abort = function() {
- request.aborted = true;
- return originalAbort.apply(request, arguments);
- };
- request.uri = options2.uri;
- request.requestTime = Date.now();
- return request;
- };
- xhr.original = true;
- return xhr;
- };
- var byterangeStr = function byterangeStr2(byterange) {
- var byterangeEnd;
- var byterangeStart = byterange.offset;
- if (typeof byterange.offset === "bigint" || typeof byterange.length === "bigint") {
- byterangeEnd = window_1.BigInt(byterange.offset) + window_1.BigInt(byterange.length) - window_1.BigInt(1);
- } else {
- byterangeEnd = byterange.offset + byterange.length - 1;
- }
- return "bytes=" + byterangeStart + "-" + byterangeEnd;
- };
- var segmentXhrHeaders = function segmentXhrHeaders2(segment) {
- var headers = {};
- if (segment.byterange) {
- headers.Range = byterangeStr(segment.byterange);
- }
- return headers;
- };
- var textRange = function textRange2(range3, i2) {
- return range3.start(i2) + "-" + range3.end(i2);
- };
- var formatHexString = function formatHexString2(e, i2) {
- var value = e.toString(16);
- return "00".substring(0, 2 - value.length) + value + (i2 % 2 ? " " : "");
- };
- var formatAsciiString = function formatAsciiString2(e) {
- if (e >= 32 && e < 126) {
- return String.fromCharCode(e);
- }
- return ".";
- };
- var createTransferableMessage = function createTransferableMessage2(message) {
- var transferable = {};
- Object.keys(message).forEach(function(key) {
- var value = message[key];
- if (isArrayBufferView2(value)) {
- transferable[key] = {
- bytes: value.buffer,
- byteOffset: value.byteOffset,
- byteLength: value.byteLength
- };
- } else {
- transferable[key] = value;
- }
- });
- return transferable;
- };
- var initSegmentId = function initSegmentId2(initSegment) {
- var byterange = initSegment.byterange || {
- length: Infinity,
- offset: 0
- };
- return [byterange.length, byterange.offset, initSegment.resolvedUri].join(",");
- };
- var segmentKeyId = function segmentKeyId2(key) {
- return key.resolvedUri;
- };
- var hexDump = function hexDump2(data) {
- var bytes = Array.prototype.slice.call(data);
- var step = 16;
- var result = "";
- var hex;
- var ascii;
- for (var j = 0; j < bytes.length / step; j++) {
- hex = bytes.slice(j * step, j * step + step).map(formatHexString).join("");
- ascii = bytes.slice(j * step, j * step + step).map(formatAsciiString).join("");
- result += hex + " " + ascii + "\n";
- }
- return result;
- };
- var tagDump = function tagDump2(_ref) {
- var bytes = _ref.bytes;
- return hexDump(bytes);
- };
- var textRanges = function textRanges2(ranges) {
- var result = "";
- var i2;
- for (i2 = 0; i2 < ranges.length; i2++) {
- result += textRange(ranges, i2) + " ";
- }
- return result;
- };
- var utils = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- createTransferableMessage,
- initSegmentId,
- segmentKeyId,
- hexDump,
- tagDump,
- textRanges
- });
- var SEGMENT_END_FUDGE_PERCENT = 0.25;
- var playerTimeToProgramTime = function playerTimeToProgramTime2(playerTime, segment) {
- if (!segment.dateTimeObject) {
- return null;
- }
- var transmuxerPrependedSeconds = segment.videoTimingInfo.transmuxerPrependedSeconds;
- var transmuxedStart = segment.videoTimingInfo.transmuxedPresentationStart;
- var startOfSegment = transmuxedStart + transmuxerPrependedSeconds;
- var offsetFromSegmentStart = playerTime - startOfSegment;
- return new Date(segment.dateTimeObject.getTime() + offsetFromSegmentStart * 1e3);
- };
- var originalSegmentVideoDuration = function originalSegmentVideoDuration2(videoTimingInfo) {
- return videoTimingInfo.transmuxedPresentationEnd - videoTimingInfo.transmuxedPresentationStart - videoTimingInfo.transmuxerPrependedSeconds;
- };
- var findSegmentForProgramTime = function findSegmentForProgramTime2(programTime, playlist) {
- var dateTimeObject;
- try {
- dateTimeObject = new Date(programTime);
- } catch (e) {
- return null;
- }
- if (!playlist || !playlist.segments || playlist.segments.length === 0) {
- return null;
- }
- var segment = playlist.segments[0];
- if (dateTimeObject < segment.dateTimeObject) {
- return null;
- }
- for (var i2 = 0; i2 < playlist.segments.length - 1; i2++) {
- segment = playlist.segments[i2];
- var nextSegmentStart = playlist.segments[i2 + 1].dateTimeObject;
- if (dateTimeObject < nextSegmentStart) {
- break;
- }
- }
- var lastSegment = playlist.segments[playlist.segments.length - 1];
- var lastSegmentStart = lastSegment.dateTimeObject;
- var lastSegmentDuration = lastSegment.videoTimingInfo ? originalSegmentVideoDuration(lastSegment.videoTimingInfo) : lastSegment.duration + lastSegment.duration * SEGMENT_END_FUDGE_PERCENT;
- var lastSegmentEnd = new Date(lastSegmentStart.getTime() + lastSegmentDuration * 1e3);
- if (dateTimeObject > lastSegmentEnd) {
- return null;
- }
- if (dateTimeObject > lastSegmentStart) {
- segment = lastSegment;
- }
- return {
- segment,
- estimatedStart: segment.videoTimingInfo ? segment.videoTimingInfo.transmuxedPresentationStart : Playlist.duration(playlist, playlist.mediaSequence + playlist.segments.indexOf(segment)),
- type: segment.videoTimingInfo ? "accurate" : "estimate"
- };
- };
- var findSegmentForPlayerTime = function findSegmentForPlayerTime2(time, playlist) {
- if (!playlist || !playlist.segments || playlist.segments.length === 0) {
- return null;
- }
- var segmentEnd = 0;
- var segment;
- for (var i2 = 0; i2 < playlist.segments.length; i2++) {
- segment = playlist.segments[i2];
- segmentEnd = segment.videoTimingInfo ? segment.videoTimingInfo.transmuxedPresentationEnd : segmentEnd + segment.duration;
- if (time <= segmentEnd) {
- break;
- }
- }
- var lastSegment = playlist.segments[playlist.segments.length - 1];
- if (lastSegment.videoTimingInfo && lastSegment.videoTimingInfo.transmuxedPresentationEnd < time) {
- return null;
- }
- if (time > segmentEnd) {
- if (time > segmentEnd + lastSegment.duration * SEGMENT_END_FUDGE_PERCENT) {
- return null;
- }
- segment = lastSegment;
- }
- return {
- segment,
- estimatedStart: segment.videoTimingInfo ? segment.videoTimingInfo.transmuxedPresentationStart : segmentEnd - segment.duration,
- type: segment.videoTimingInfo ? "accurate" : "estimate"
- };
- };
- var getOffsetFromTimestamp = function getOffsetFromTimestamp2(comparisonTimeStamp, programTime) {
- var segmentDateTime;
- var programDateTime;
- try {
- segmentDateTime = new Date(comparisonTimeStamp);
- programDateTime = new Date(programTime);
- } catch (e) {
- }
- var segmentTimeEpoch = segmentDateTime.getTime();
- var programTimeEpoch = programDateTime.getTime();
- return (programTimeEpoch - segmentTimeEpoch) / 1e3;
- };
- var verifyProgramDateTimeTags = function verifyProgramDateTimeTags2(playlist) {
- if (!playlist.segments || playlist.segments.length === 0) {
- return false;
- }
- for (var i2 = 0; i2 < playlist.segments.length; i2++) {
- var segment = playlist.segments[i2];
- if (!segment.dateTimeObject) {
- return false;
- }
- }
- return true;
- };
- var getProgramTime = function getProgramTime2(_ref) {
- var playlist = _ref.playlist, _ref$time = _ref.time, time = _ref$time === void 0 ? void 0 : _ref$time, callback2 = _ref.callback;
- if (!callback2) {
- throw new Error("getProgramTime: callback must be provided");
- }
- if (!playlist || time === void 0) {
- return callback2({
- message: "getProgramTime: playlist and time must be provided"
- });
- }
- var matchedSegment = findSegmentForPlayerTime(time, playlist);
- if (!matchedSegment) {
- return callback2({
- message: "valid programTime was not found"
- });
- }
- if (matchedSegment.type === "estimate") {
- return callback2({
- message: "Accurate programTime could not be determined. Please seek to e.seekTime and try again",
- seekTime: matchedSegment.estimatedStart
- });
- }
- var programTimeObject = {
- mediaSeconds: time
- };
- var programTime = playerTimeToProgramTime(time, matchedSegment.segment);
- if (programTime) {
- programTimeObject.programDateTime = programTime.toISOString();
- }
- return callback2(null, programTimeObject);
- };
- var seekToProgramTime = function seekToProgramTime2(_ref2) {
- var programTime = _ref2.programTime, playlist = _ref2.playlist, _ref2$retryCount = _ref2.retryCount, retryCount = _ref2$retryCount === void 0 ? 2 : _ref2$retryCount, seekTo = _ref2.seekTo, _ref2$pauseAfterSeek = _ref2.pauseAfterSeek, pauseAfterSeek = _ref2$pauseAfterSeek === void 0 ? true : _ref2$pauseAfterSeek, tech = _ref2.tech, callback2 = _ref2.callback;
- if (!callback2) {
- throw new Error("seekToProgramTime: callback must be provided");
- }
- if (typeof programTime === "undefined" || !playlist || !seekTo) {
- return callback2({
- message: "seekToProgramTime: programTime, seekTo and playlist must be provided"
- });
- }
- if (!playlist.endList && !tech.hasStarted_) {
- return callback2({
- message: "player must be playing a live stream to start buffering"
- });
- }
- if (!verifyProgramDateTimeTags(playlist)) {
- return callback2({
- message: "programDateTime tags must be provided in the manifest " + playlist.resolvedUri
- });
- }
- var matchedSegment = findSegmentForProgramTime(programTime, playlist);
- if (!matchedSegment) {
- return callback2({
- message: programTime + " was not found in the stream"
- });
- }
- var segment = matchedSegment.segment;
- var mediaOffset = getOffsetFromTimestamp(segment.dateTimeObject, programTime);
- if (matchedSegment.type === "estimate") {
- if (retryCount === 0) {
- return callback2({
- message: programTime + " is not buffered yet. Try again"
- });
- }
- seekTo(matchedSegment.estimatedStart + mediaOffset);
- tech.one("seeked", function() {
- seekToProgramTime2({
- programTime,
- playlist,
- retryCount: retryCount - 1,
- seekTo,
- pauseAfterSeek,
- tech,
- callback: callback2
- });
- });
- return;
- }
- var seekToTime = segment.start + mediaOffset;
- var seekedCallback = function seekedCallback2() {
- return callback2(null, tech.currentTime());
- };
- tech.one("seeked", seekedCallback);
- if (pauseAfterSeek) {
- tech.pause();
- }
- seekTo(seekToTime);
- };
- var callbackOnCompleted = function callbackOnCompleted2(request, cb) {
- if (request.readyState === 4) {
- return cb();
- }
- return;
- };
- var containerRequest = function containerRequest2(uri, xhr, cb) {
- var bytes = [];
- var id3Offset;
- var finished = false;
- var endRequestAndCallback = function endRequestAndCallback2(err, req, type2, _bytes) {
- req.abort();
- finished = true;
- return cb(err, req, type2, _bytes);
- };
- var progressListener = function progressListener2(error, request2) {
- if (finished) {
- return;
- }
- if (error) {
- return endRequestAndCallback(error, request2, "", bytes);
- }
- var newPart = request2.responseText.substring(bytes && bytes.byteLength || 0, request2.responseText.length);
- bytes = concatTypedArrays2(bytes, stringToBytes2(newPart, true));
- id3Offset = id3Offset || getId3Offset2(bytes);
- if (bytes.length < 10 || id3Offset && bytes.length < id3Offset + 2) {
- return callbackOnCompleted(request2, function() {
- return endRequestAndCallback(error, request2, "", bytes);
- });
- }
- var type2 = detectContainerForBytes2(bytes);
- if (type2 === "ts" && bytes.length < 188) {
- return callbackOnCompleted(request2, function() {
- return endRequestAndCallback(error, request2, "", bytes);
- });
- }
- if (!type2 && bytes.length < 376) {
- return callbackOnCompleted(request2, function() {
- return endRequestAndCallback(error, request2, "", bytes);
- });
- }
- return endRequestAndCallback(null, request2, type2, bytes);
- };
- var options2 = {
- uri,
- beforeSend: function beforeSend(request2) {
- request2.overrideMimeType("text/plain; charset=x-user-defined");
- request2.addEventListener("progress", function(_ref) {
- _ref.total;
- _ref.loaded;
- return callbackWrapper(request2, null, {
- statusCode: request2.status
- }, progressListener);
- });
- }
- };
- var request = xhr(options2, function(error, response) {
- return callbackWrapper(request, error, response, progressListener);
- });
- return request;
- };
- var EventTarget2 = videojs.EventTarget, mergeOptions$4 = videojs.mergeOptions;
- var dashPlaylistUnchanged = function dashPlaylistUnchanged2(a, b) {
- if (!isPlaylistUnchanged(a, b)) {
- return false;
- }
- if (a.sidx && b.sidx && (a.sidx.offset !== b.sidx.offset || a.sidx.length !== b.sidx.length)) {
- return false;
- } else if (!a.sidx && b.sidx || a.sidx && !b.sidx) {
- return false;
- }
- if (a.segments && !b.segments || !a.segments && b.segments) {
- return false;
- }
- if (!a.segments && !b.segments) {
- return true;
- }
- for (var i2 = 0; i2 < a.segments.length; i2++) {
- var aSegment = a.segments[i2];
- var bSegment = b.segments[i2];
- if (aSegment.uri !== bSegment.uri) {
- return false;
- }
- if (!aSegment.byterange && !bSegment.byterange) {
- continue;
- }
- var aByterange = aSegment.byterange;
- var bByterange = bSegment.byterange;
- if (aByterange && !bByterange || !aByterange && bByterange) {
- return false;
- }
- if (aByterange.offset !== bByterange.offset || aByterange.length !== bByterange.length) {
- return false;
- }
- }
- return true;
- };
- var dashGroupId = function dashGroupId2(type2, group, label2, playlist) {
- var playlistId = playlist.attributes.NAME || label2;
- return "placeholder-uri-" + type2 + "-" + group + "-" + playlistId;
- };
- var parseMasterXml = function parseMasterXml2(_ref) {
- var masterXml = _ref.masterXml, srcUrl = _ref.srcUrl, clientOffset = _ref.clientOffset, sidxMapping = _ref.sidxMapping, previousManifest = _ref.previousManifest;
- var manifest = parse(masterXml, {
- manifestUri: srcUrl,
- clientOffset,
- sidxMapping,
- previousManifest
- });
- addPropertiesToMaster(manifest, srcUrl, dashGroupId);
- return manifest;
- };
- var removeOldMediaGroupLabels = function removeOldMediaGroupLabels2(update, newMaster) {
- forEachMediaGroup3(update, function(properties, type2, group, label2) {
- if (!(label2 in newMaster.mediaGroups[type2][group])) {
- delete update.mediaGroups[type2][group][label2];
- }
- });
- };
- var updateMaster2 = function updateMaster3(oldMaster, newMaster, sidxMapping) {
- var noChanges = true;
- var update = mergeOptions$4(oldMaster, {
- duration: newMaster.duration,
- minimumUpdatePeriod: newMaster.minimumUpdatePeriod,
- timelineStarts: newMaster.timelineStarts
- });
- for (var i2 = 0; i2 < newMaster.playlists.length; i2++) {
- var playlist = newMaster.playlists[i2];
- if (playlist.sidx) {
- var sidxKey = generateSidxKey(playlist.sidx);
- if (sidxMapping && sidxMapping[sidxKey] && sidxMapping[sidxKey].sidx) {
- addSidxSegmentsToPlaylist$1(playlist, sidxMapping[sidxKey].sidx, playlist.sidx.resolvedUri);
- }
- }
- var playlistUpdate = updateMaster$1(update, playlist, dashPlaylistUnchanged);
- if (playlistUpdate) {
- update = playlistUpdate;
- noChanges = false;
- }
- }
- forEachMediaGroup3(newMaster, function(properties, type2, group, label2) {
- if (properties.playlists && properties.playlists.length) {
- var id = properties.playlists[0].id;
- var _playlistUpdate = updateMaster$1(update, properties.playlists[0], dashPlaylistUnchanged);
- if (_playlistUpdate) {
- update = _playlistUpdate;
- if (!(label2 in update.mediaGroups[type2][group])) {
- update.mediaGroups[type2][group][label2] = properties;
- }
- update.mediaGroups[type2][group][label2].playlists[0] = update.playlists[id];
- noChanges = false;
- }
- }
- });
- removeOldMediaGroupLabels(update, newMaster);
- if (newMaster.minimumUpdatePeriod !== oldMaster.minimumUpdatePeriod) {
- noChanges = false;
- }
- if (noChanges) {
- return null;
- }
- return update;
- };
- var equivalentSidx = function equivalentSidx2(a, b) {
- var neitherMap = Boolean(!a.map && !b.map);
- var equivalentMap = neitherMap || Boolean(a.map && b.map && a.map.byterange.offset === b.map.byterange.offset && a.map.byterange.length === b.map.byterange.length);
- return equivalentMap && a.uri === b.uri && a.byterange.offset === b.byterange.offset && a.byterange.length === b.byterange.length;
- };
- var compareSidxEntry = function compareSidxEntry2(playlists, oldSidxMapping) {
- var newSidxMapping = {};
- for (var id in playlists) {
- var playlist = playlists[id];
- var currentSidxInfo = playlist.sidx;
- if (currentSidxInfo) {
- var key = generateSidxKey(currentSidxInfo);
- if (!oldSidxMapping[key]) {
- break;
- }
- var savedSidxInfo = oldSidxMapping[key].sidxInfo;
- if (equivalentSidx(savedSidxInfo, currentSidxInfo)) {
- newSidxMapping[key] = oldSidxMapping[key];
- }
- }
- }
- return newSidxMapping;
- };
- var filterChangedSidxMappings = function filterChangedSidxMappings2(master, oldSidxMapping) {
- var videoSidx = compareSidxEntry(master.playlists, oldSidxMapping);
- var mediaGroupSidx = videoSidx;
- forEachMediaGroup3(master, function(properties, mediaType, groupKey, labelKey) {
- if (properties.playlists && properties.playlists.length) {
- var playlists = properties.playlists;
- mediaGroupSidx = mergeOptions$4(mediaGroupSidx, compareSidxEntry(playlists, oldSidxMapping));
- }
- });
- return mediaGroupSidx;
- };
- var DashPlaylistLoader = /* @__PURE__ */ function(_EventTarget) {
- _inheritsLoose(DashPlaylistLoader2, _EventTarget);
- function DashPlaylistLoader2(srcUrlOrPlaylist, vhs, options2, masterPlaylistLoader) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- _this = _EventTarget.call(this) || this;
- _this.masterPlaylistLoader_ = masterPlaylistLoader || _assertThisInitialized(_this);
- if (!masterPlaylistLoader) {
- _this.isMaster_ = true;
- }
- var _options = options2, _options$withCredenti = _options.withCredentials, withCredentials = _options$withCredenti === void 0 ? false : _options$withCredenti, _options$handleManife = _options.handleManifestRedirects, handleManifestRedirects = _options$handleManife === void 0 ? false : _options$handleManife;
- _this.vhs_ = vhs;
- _this.withCredentials = withCredentials;
- _this.handleManifestRedirects = handleManifestRedirects;
- if (!srcUrlOrPlaylist) {
- throw new Error("A non-empty playlist URL or object is required");
- }
- _this.on("minimumUpdatePeriod", function() {
- _this.refreshXml_();
- });
- _this.on("mediaupdatetimeout", function() {
- _this.refreshMedia_(_this.media().id);
- });
- _this.state = "HAVE_NOTHING";
- _this.loadedPlaylists_ = {};
- _this.logger_ = logger("DashPlaylistLoader");
- if (_this.isMaster_) {
- _this.masterPlaylistLoader_.srcUrl = srcUrlOrPlaylist;
- _this.masterPlaylistLoader_.sidxMapping_ = {};
- } else {
- _this.childPlaylist_ = srcUrlOrPlaylist;
- }
- return _this;
- }
- var _proto = DashPlaylistLoader2.prototype;
- _proto.requestErrored_ = function requestErrored_(err, request, startingState) {
- if (!this.request) {
- return true;
- }
- this.request = null;
- if (err) {
- this.error = typeof err === "object" && !(err instanceof Error) ? err : {
- status: request.status,
- message: "DASH request error at URL: " + request.uri,
- response: request.response,
- code: 2
- };
- if (startingState) {
- this.state = startingState;
- }
- this.trigger("error");
- return true;
- }
- };
- _proto.addSidxSegments_ = function addSidxSegments_(playlist, startingState, cb) {
- var _this2 = this;
- var sidxKey = playlist.sidx && generateSidxKey(playlist.sidx);
- if (!playlist.sidx || !sidxKey || this.masterPlaylistLoader_.sidxMapping_[sidxKey]) {
- this.mediaRequest_ = window_1.setTimeout(function() {
- return cb(false);
- }, 0);
- return;
- }
- var uri = resolveManifestRedirect(this.handleManifestRedirects, playlist.sidx.resolvedUri);
- var fin = function fin2(err, request) {
- if (_this2.requestErrored_(err, request, startingState)) {
- return;
- }
- var sidxMapping = _this2.masterPlaylistLoader_.sidxMapping_;
- var sidx;
- try {
- sidx = parseSidx_1(toUint82(request.response).subarray(8));
- } catch (e) {
- _this2.requestErrored_(e, request, startingState);
- return;
- }
- sidxMapping[sidxKey] = {
- sidxInfo: playlist.sidx,
- sidx
- };
- addSidxSegmentsToPlaylist$1(playlist, sidx, playlist.sidx.resolvedUri);
- return cb(true);
- };
- this.request = containerRequest(uri, this.vhs_.xhr, function(err, request, container, bytes) {
- if (err) {
- return fin(err, request);
- }
- if (!container || container !== "mp4") {
- return fin({
- status: request.status,
- message: "Unsupported " + (container || "unknown") + " container type for sidx segment at URL: " + uri,
- response: "",
- playlist,
- internal: true,
- blacklistDuration: Infinity,
- code: 2
- }, request);
- }
- var _playlist$sidx$bytera = playlist.sidx.byterange, offset = _playlist$sidx$bytera.offset, length = _playlist$sidx$bytera.length;
- if (bytes.length >= length + offset) {
- return fin(err, {
- response: bytes.subarray(offset, offset + length),
- status: request.status,
- uri: request.uri
- });
- }
- _this2.request = _this2.vhs_.xhr({
- uri,
- responseType: "arraybuffer",
- headers: segmentXhrHeaders({
- byterange: playlist.sidx.byterange
- })
- }, fin);
- });
- };
- _proto.dispose = function dispose() {
- this.trigger("dispose");
- this.stopRequest();
- this.loadedPlaylists_ = {};
- window_1.clearTimeout(this.minimumUpdatePeriodTimeout_);
- window_1.clearTimeout(this.mediaRequest_);
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- this.mediaRequest_ = null;
- this.minimumUpdatePeriodTimeout_ = null;
- if (this.masterPlaylistLoader_.createMupOnMedia_) {
- this.off("loadedmetadata", this.masterPlaylistLoader_.createMupOnMedia_);
- this.masterPlaylistLoader_.createMupOnMedia_ = null;
- }
- this.off();
- };
- _proto.hasPendingRequest = function hasPendingRequest() {
- return this.request || this.mediaRequest_;
- };
- _proto.stopRequest = function stopRequest() {
- if (this.request) {
- var oldRequest = this.request;
- this.request = null;
- oldRequest.onreadystatechange = null;
- oldRequest.abort();
- }
- };
- _proto.media = function media(playlist) {
- var _this3 = this;
- if (!playlist) {
- return this.media_;
- }
- if (this.state === "HAVE_NOTHING") {
- throw new Error("Cannot switch media playlist from " + this.state);
- }
- var startingState = this.state;
- if (typeof playlist === "string") {
- if (!this.masterPlaylistLoader_.master.playlists[playlist]) {
- throw new Error("Unknown playlist URI: " + playlist);
- }
- playlist = this.masterPlaylistLoader_.master.playlists[playlist];
- }
- var mediaChange = !this.media_ || playlist.id !== this.media_.id;
- if (mediaChange && this.loadedPlaylists_[playlist.id] && this.loadedPlaylists_[playlist.id].endList) {
- this.state = "HAVE_METADATA";
- this.media_ = playlist;
- if (mediaChange) {
- this.trigger("mediachanging");
- this.trigger("mediachange");
- }
- return;
- }
- if (!mediaChange) {
- return;
- }
- if (this.media_) {
- this.trigger("mediachanging");
- }
- this.addSidxSegments_(playlist, startingState, function(sidxChanged) {
- _this3.haveMetadata({
- startingState,
- playlist
- });
- });
- };
- _proto.haveMetadata = function haveMetadata(_ref2) {
- var startingState = _ref2.startingState, playlist = _ref2.playlist;
- this.state = "HAVE_METADATA";
- this.loadedPlaylists_[playlist.id] = playlist;
- this.mediaRequest_ = null;
- this.refreshMedia_(playlist.id);
- if (startingState === "HAVE_MASTER") {
- this.trigger("loadedmetadata");
- } else {
- this.trigger("mediachange");
- }
- };
- _proto.pause = function pause() {
- if (this.masterPlaylistLoader_.createMupOnMedia_) {
- this.off("loadedmetadata", this.masterPlaylistLoader_.createMupOnMedia_);
- this.masterPlaylistLoader_.createMupOnMedia_ = null;
- }
- this.stopRequest();
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- if (this.isMaster_) {
- window_1.clearTimeout(this.masterPlaylistLoader_.minimumUpdatePeriodTimeout_);
- this.masterPlaylistLoader_.minimumUpdatePeriodTimeout_ = null;
- }
- if (this.state === "HAVE_NOTHING") {
- this.started = false;
- }
- };
- _proto.load = function load(isFinalRendition) {
- var _this4 = this;
- window_1.clearTimeout(this.mediaUpdateTimeout);
- this.mediaUpdateTimeout = null;
- var media = this.media();
- if (isFinalRendition) {
- var delay = media ? media.targetDuration / 2 * 1e3 : 5 * 1e3;
- this.mediaUpdateTimeout = window_1.setTimeout(function() {
- return _this4.load();
- }, delay);
- return;
- }
- if (!this.started) {
- this.start();
- return;
- }
- if (media && !media.endList) {
- if (this.isMaster_ && !this.minimumUpdatePeriodTimeout_) {
- this.trigger("minimumUpdatePeriod");
- this.updateMinimumUpdatePeriodTimeout_();
- }
- this.trigger("mediaupdatetimeout");
- } else {
- this.trigger("loadedplaylist");
- }
- };
- _proto.start = function start2() {
- var _this5 = this;
- this.started = true;
- if (!this.isMaster_) {
- this.mediaRequest_ = window_1.setTimeout(function() {
- return _this5.haveMaster_();
- }, 0);
- return;
- }
- this.requestMaster_(function(req, masterChanged) {
- _this5.haveMaster_();
- if (!_this5.hasPendingRequest() && !_this5.media_) {
- _this5.media(_this5.masterPlaylistLoader_.master.playlists[0]);
- }
- });
- };
- _proto.requestMaster_ = function requestMaster_(cb) {
- var _this6 = this;
- this.request = this.vhs_.xhr({
- uri: this.masterPlaylistLoader_.srcUrl,
- withCredentials: this.withCredentials
- }, function(error, req) {
- if (_this6.requestErrored_(error, req)) {
- if (_this6.state === "HAVE_NOTHING") {
- _this6.started = false;
- }
- return;
- }
- var masterChanged = req.responseText !== _this6.masterPlaylistLoader_.masterXml_;
- _this6.masterPlaylistLoader_.masterXml_ = req.responseText;
- if (req.responseHeaders && req.responseHeaders.date) {
- _this6.masterLoaded_ = Date.parse(req.responseHeaders.date);
- } else {
- _this6.masterLoaded_ = Date.now();
- }
- _this6.masterPlaylistLoader_.srcUrl = resolveManifestRedirect(_this6.handleManifestRedirects, _this6.masterPlaylistLoader_.srcUrl, req);
- if (masterChanged) {
- _this6.handleMaster_();
- _this6.syncClientServerClock_(function() {
- return cb(req, masterChanged);
- });
- return;
- }
- return cb(req, masterChanged);
- });
- };
- _proto.syncClientServerClock_ = function syncClientServerClock_(done) {
- var _this7 = this;
- var utcTiming = parseUTCTiming(this.masterPlaylistLoader_.masterXml_);
- if (utcTiming === null) {
- this.masterPlaylistLoader_.clientOffset_ = this.masterLoaded_ - Date.now();
- return done();
- }
- if (utcTiming.method === "DIRECT") {
- this.masterPlaylistLoader_.clientOffset_ = utcTiming.value - Date.now();
- return done();
- }
- this.request = this.vhs_.xhr({
- uri: resolveUrl4(this.masterPlaylistLoader_.srcUrl, utcTiming.value),
- method: utcTiming.method,
- withCredentials: this.withCredentials
- }, function(error, req) {
- if (!_this7.request) {
- return;
- }
- if (error) {
- _this7.masterPlaylistLoader_.clientOffset_ = _this7.masterLoaded_ - Date.now();
- return done();
- }
- var serverTime;
- if (utcTiming.method === "HEAD") {
- if (!req.responseHeaders || !req.responseHeaders.date) {
- serverTime = _this7.masterLoaded_;
- } else {
- serverTime = Date.parse(req.responseHeaders.date);
- }
- } else {
- serverTime = Date.parse(req.responseText);
- }
- _this7.masterPlaylistLoader_.clientOffset_ = serverTime - Date.now();
- done();
- });
- };
- _proto.haveMaster_ = function haveMaster_() {
- this.state = "HAVE_MASTER";
- if (this.isMaster_) {
- this.trigger("loadedplaylist");
- } else if (!this.media_) {
- this.media(this.childPlaylist_);
- }
- };
- _proto.handleMaster_ = function handleMaster_() {
- this.mediaRequest_ = null;
- var oldMaster = this.masterPlaylistLoader_.master;
- var newMaster = parseMasterXml({
- masterXml: this.masterPlaylistLoader_.masterXml_,
- srcUrl: this.masterPlaylistLoader_.srcUrl,
- clientOffset: this.masterPlaylistLoader_.clientOffset_,
- sidxMapping: this.masterPlaylistLoader_.sidxMapping_,
- previousManifest: oldMaster
- });
- if (oldMaster) {
- newMaster = updateMaster2(oldMaster, newMaster, this.masterPlaylistLoader_.sidxMapping_);
- }
- this.masterPlaylistLoader_.master = newMaster ? newMaster : oldMaster;
- var location = this.masterPlaylistLoader_.master.locations && this.masterPlaylistLoader_.master.locations[0];
- if (location && location !== this.masterPlaylistLoader_.srcUrl) {
- this.masterPlaylistLoader_.srcUrl = location;
- }
- if (!oldMaster || newMaster && newMaster.minimumUpdatePeriod !== oldMaster.minimumUpdatePeriod) {
- this.updateMinimumUpdatePeriodTimeout_();
- }
- return Boolean(newMaster);
- };
- _proto.updateMinimumUpdatePeriodTimeout_ = function updateMinimumUpdatePeriodTimeout_() {
- var mpl = this.masterPlaylistLoader_;
- if (mpl.createMupOnMedia_) {
- mpl.off("loadedmetadata", mpl.createMupOnMedia_);
- mpl.createMupOnMedia_ = null;
- }
- if (mpl.minimumUpdatePeriodTimeout_) {
- window_1.clearTimeout(mpl.minimumUpdatePeriodTimeout_);
- mpl.minimumUpdatePeriodTimeout_ = null;
- }
- var mup = mpl.master && mpl.master.minimumUpdatePeriod;
- if (mup === 0) {
- if (mpl.media()) {
- mup = mpl.media().targetDuration * 1e3;
- } else {
- mpl.createMupOnMedia_ = mpl.updateMinimumUpdatePeriodTimeout_;
- mpl.one("loadedmetadata", mpl.createMupOnMedia_);
- }
- }
- if (typeof mup !== "number" || mup <= 0) {
- if (mup < 0) {
- this.logger_("found invalid minimumUpdatePeriod of " + mup + ", not setting a timeout");
- }
- return;
- }
- this.createMUPTimeout_(mup);
- };
- _proto.createMUPTimeout_ = function createMUPTimeout_(mup) {
- var mpl = this.masterPlaylistLoader_;
- mpl.minimumUpdatePeriodTimeout_ = window_1.setTimeout(function() {
- mpl.minimumUpdatePeriodTimeout_ = null;
- mpl.trigger("minimumUpdatePeriod");
- mpl.createMUPTimeout_(mup);
- }, mup);
- };
- _proto.refreshXml_ = function refreshXml_() {
- var _this8 = this;
- this.requestMaster_(function(req, masterChanged) {
- if (!masterChanged) {
- return;
- }
- if (_this8.media_) {
- _this8.media_ = _this8.masterPlaylistLoader_.master.playlists[_this8.media_.id];
- }
- _this8.masterPlaylistLoader_.sidxMapping_ = filterChangedSidxMappings(_this8.masterPlaylistLoader_.master, _this8.masterPlaylistLoader_.sidxMapping_);
- _this8.addSidxSegments_(_this8.media(), _this8.state, function(sidxChanged) {
- _this8.refreshMedia_(_this8.media().id);
- });
- });
- };
- _proto.refreshMedia_ = function refreshMedia_(mediaID) {
- var _this9 = this;
- if (!mediaID) {
- throw new Error("refreshMedia_ must take a media id");
- }
- if (this.media_ && this.isMaster_) {
- this.handleMaster_();
- }
- var playlists = this.masterPlaylistLoader_.master.playlists;
- var mediaChanged = !this.media_ || this.media_ !== playlists[mediaID];
- if (mediaChanged) {
- this.media_ = playlists[mediaID];
- } else {
- this.trigger("playlistunchanged");
- }
- if (!this.mediaUpdateTimeout) {
- var createMediaUpdateTimeout = function createMediaUpdateTimeout2() {
- if (_this9.media().endList) {
- return;
- }
- _this9.mediaUpdateTimeout = window_1.setTimeout(function() {
- _this9.trigger("mediaupdatetimeout");
- createMediaUpdateTimeout2();
- }, refreshDelay(_this9.media(), Boolean(mediaChanged)));
- };
- createMediaUpdateTimeout();
- }
- this.trigger("loadedplaylist");
- };
- return DashPlaylistLoader2;
- }(EventTarget2);
- var Config = {
- GOAL_BUFFER_LENGTH: 30,
- MAX_GOAL_BUFFER_LENGTH: 60,
- BACK_BUFFER_LENGTH: 30,
- GOAL_BUFFER_LENGTH_RATE: 1,
- INITIAL_BANDWIDTH: 4194304,
- BANDWIDTH_VARIANCE: 1.2,
- BUFFER_LOW_WATER_LINE: 0,
- MAX_BUFFER_LOW_WATER_LINE: 30,
- EXPERIMENTAL_MAX_BUFFER_LOW_WATER_LINE: 16,
- BUFFER_LOW_WATER_LINE_RATE: 1,
- BUFFER_HIGH_WATER_LINE: 30
- };
- var stringToArrayBuffer = function stringToArrayBuffer2(string) {
- var view = new Uint8Array(new ArrayBuffer(string.length));
- for (var i2 = 0; i2 < string.length; i2++) {
- view[i2] = string.charCodeAt(i2);
- }
- return view.buffer;
- };
- var browserWorkerPolyFill = function browserWorkerPolyFill2(workerObj) {
- workerObj.on = workerObj.addEventListener;
- workerObj.off = workerObj.removeEventListener;
- return workerObj;
- };
- var createObjectURL = function createObjectURL2(str) {
- try {
- return URL.createObjectURL(new Blob([str], {
- type: "application/javascript"
- }));
- } catch (e) {
- var blob = new BlobBuilder();
- blob.append(str);
- return URL.createObjectURL(blob.getBlob());
- }
- };
- var factory = function factory2(code) {
- return function() {
- var objectUrl = createObjectURL(code);
- var worker = browserWorkerPolyFill(new Worker(objectUrl));
- worker.objURL = objectUrl;
- var terminate = worker.terminate;
- worker.on = worker.addEventListener;
- worker.off = worker.removeEventListener;
- worker.terminate = function() {
- URL.revokeObjectURL(objectUrl);
- return terminate.call(this);
- };
- return worker;
- };
- };
- var transform = function transform2(code) {
- return "var browserWorkerPolyFill = " + browserWorkerPolyFill.toString() + ";\nbrowserWorkerPolyFill(self);\n" + code;
- };
- var getWorkerString = function getWorkerString2(fn2) {
- return fn2.toString().replace(/^function.+?{/, "").slice(0, -1);
- };
- var workerCode$1 = transform(getWorkerString(function() {
- var Stream2 = function Stream3() {
- this.init = function() {
- var listeners = {};
- this.on = function(type3, listener) {
- if (!listeners[type3]) {
- listeners[type3] = [];
- }
- listeners[type3] = listeners[type3].concat(listener);
- };
- this.off = function(type3, listener) {
- var index2;
- if (!listeners[type3]) {
- return false;
- }
- index2 = listeners[type3].indexOf(listener);
- listeners[type3] = listeners[type3].slice();
- listeners[type3].splice(index2, 1);
- return index2 > -1;
- };
- this.trigger = function(type3) {
- var callbacks, i2, length, args;
- callbacks = listeners[type3];
- if (!callbacks) {
- return;
- }
- if (arguments.length === 2) {
- length = callbacks.length;
- for (i2 = 0; i2 < length; ++i2) {
- callbacks[i2].call(this, arguments[1]);
- }
- } else {
- args = [];
- i2 = arguments.length;
- for (i2 = 1; i2 < arguments.length; ++i2) {
- args.push(arguments[i2]);
- }
- length = callbacks.length;
- for (i2 = 0; i2 < length; ++i2) {
- callbacks[i2].apply(this, args);
- }
- }
- };
- this.dispose = function() {
- listeners = {};
- };
- };
- };
- Stream2.prototype.pipe = function(destination2) {
- this.on("data", function(data) {
- destination2.push(data);
- });
- this.on("done", function(flushSource) {
- destination2.flush(flushSource);
- });
- this.on("partialdone", function(flushSource) {
- destination2.partialFlush(flushSource);
- });
- this.on("endedtimeline", function(flushSource) {
- destination2.endTimeline(flushSource);
- });
- this.on("reset", function(flushSource) {
- destination2.reset(flushSource);
- });
- return destination2;
- };
- Stream2.prototype.push = function(data) {
- this.trigger("data", data);
- };
- Stream2.prototype.flush = function(flushSource) {
- this.trigger("done", flushSource);
- };
- Stream2.prototype.partialFlush = function(flushSource) {
- this.trigger("partialdone", flushSource);
- };
- Stream2.prototype.endTimeline = function(flushSource) {
- this.trigger("endedtimeline", flushSource);
- };
- Stream2.prototype.reset = function(flushSource) {
- this.trigger("reset", flushSource);
- };
- var stream = Stream2;
- var MAX_UINT32$12 = Math.pow(2, 32);
- var getUint64$22 = function getUint643(uint8) {
- var dv = new DataView(uint8.buffer, uint8.byteOffset, uint8.byteLength);
- var value;
- if (dv.getBigUint64) {
- value = dv.getBigUint64(0);
- if (value < Number.MAX_SAFE_INTEGER) {
- return Number(value);
- }
- return value;
- }
- return dv.getUint32(0) * MAX_UINT32$12 + dv.getUint32(4);
- };
- var numbers2 = {
- getUint64: getUint64$22,
- MAX_UINT32: MAX_UINT32$12
- };
- var MAX_UINT322 = numbers2.MAX_UINT32;
- var box, dinf, esds, ftyp, mdat, mfhd, minf, moof, moov, mvex, mvhd, trak, tkhd, mdia, mdhd, hdlr, sdtp, stbl, stsd, traf, trex, trun$1, types, MAJOR_BRAND, MINOR_VERSION, AVC1_BRAND, VIDEO_HDLR, AUDIO_HDLR, HDLR_TYPES, VMHD, SMHD, DREF, STCO, STSC, STSZ, STTS;
- (function() {
- var i2;
- types = {
- avc1: [],
- avcC: [],
- btrt: [],
- dinf: [],
- dref: [],
- esds: [],
- ftyp: [],
- hdlr: [],
- mdat: [],
- mdhd: [],
- mdia: [],
- mfhd: [],
- minf: [],
- moof: [],
- moov: [],
- mp4a: [],
- mvex: [],
- mvhd: [],
- pasp: [],
- sdtp: [],
- smhd: [],
- stbl: [],
- stco: [],
- stsc: [],
- stsd: [],
- stsz: [],
- stts: [],
- styp: [],
- tfdt: [],
- tfhd: [],
- traf: [],
- trak: [],
- trun: [],
- trex: [],
- tkhd: [],
- vmhd: []
- };
- if (typeof Uint8Array === "undefined") {
- return;
- }
- for (i2 in types) {
- if (types.hasOwnProperty(i2)) {
- types[i2] = [i2.charCodeAt(0), i2.charCodeAt(1), i2.charCodeAt(2), i2.charCodeAt(3)];
- }
- }
- MAJOR_BRAND = new Uint8Array(["i".charCodeAt(0), "s".charCodeAt(0), "o".charCodeAt(0), "m".charCodeAt(0)]);
- AVC1_BRAND = new Uint8Array(["a".charCodeAt(0), "v".charCodeAt(0), "c".charCodeAt(0), "1".charCodeAt(0)]);
- MINOR_VERSION = new Uint8Array([0, 0, 0, 1]);
- VIDEO_HDLR = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 118,
- 105,
- 100,
- 101,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 86,
- 105,
- 100,
- 101,
- 111,
- 72,
- 97,
- 110,
- 100,
- 108,
- 101,
- 114,
- 0
- ]);
- AUDIO_HDLR = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 115,
- 111,
- 117,
- 110,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 83,
- 111,
- 117,
- 110,
- 100,
- 72,
- 97,
- 110,
- 100,
- 108,
- 101,
- 114,
- 0
- ]);
- HDLR_TYPES = {
- video: VIDEO_HDLR,
- audio: AUDIO_HDLR
- };
- DREF = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 12,
- 117,
- 114,
- 108,
- 32,
- 0,
- 0,
- 0,
- 1
- ]);
- SMHD = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- STCO = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- STSC = STCO;
- STSZ = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- STTS = STCO;
- VMHD = new Uint8Array([
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- })();
- box = function box2(type3) {
- var payload = [], size = 0, i2, result, view;
- for (i2 = 1; i2 < arguments.length; i2++) {
- payload.push(arguments[i2]);
- }
- i2 = payload.length;
- while (i2--) {
- size += payload[i2].byteLength;
- }
- result = new Uint8Array(size + 8);
- view = new DataView(result.buffer, result.byteOffset, result.byteLength);
- view.setUint32(0, result.byteLength);
- result.set(type3, 4);
- for (i2 = 0, size = 8; i2 < payload.length; i2++) {
- result.set(payload[i2], size);
- size += payload[i2].byteLength;
- }
- return result;
- };
- dinf = function dinf2() {
- return box(types.dinf, box(types.dref, DREF));
- };
- esds = function esds2(track) {
- return box(types.esds, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 3,
- 25,
- 0,
- 0,
- 0,
- 4,
- 17,
- 64,
- 21,
- 0,
- 6,
- 0,
- 0,
- 0,
- 218,
- 192,
- 0,
- 0,
- 218,
- 192,
- 5,
- 2,
- track.audioobjecttype << 3 | track.samplingfrequencyindex >>> 1,
- track.samplingfrequencyindex << 7 | track.channelcount << 3,
- 6,
- 1,
- 2
- ]));
- };
- ftyp = function ftyp2() {
- return box(types.ftyp, MAJOR_BRAND, MINOR_VERSION, MAJOR_BRAND, AVC1_BRAND);
- };
- hdlr = function hdlr2(type3) {
- return box(types.hdlr, HDLR_TYPES[type3]);
- };
- mdat = function mdat2(data) {
- return box(types.mdat, data);
- };
- mdhd = function mdhd2(track) {
- var result = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 2,
- 0,
- 0,
- 0,
- 3,
- 0,
- 1,
- 95,
- 144,
- track.duration >>> 24 & 255,
- track.duration >>> 16 & 255,
- track.duration >>> 8 & 255,
- track.duration & 255,
- 85,
- 196,
- 0,
- 0
- ]);
- if (track.samplerate) {
- result[12] = track.samplerate >>> 24 & 255;
- result[13] = track.samplerate >>> 16 & 255;
- result[14] = track.samplerate >>> 8 & 255;
- result[15] = track.samplerate & 255;
- }
- return box(types.mdhd, result);
- };
- mdia = function mdia2(track) {
- return box(types.mdia, mdhd(track), hdlr(track.type), minf(track));
- };
- mfhd = function mfhd2(sequenceNumber) {
- return box(types.mfhd, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- (sequenceNumber & 4278190080) >> 24,
- (sequenceNumber & 16711680) >> 16,
- (sequenceNumber & 65280) >> 8,
- sequenceNumber & 255
- ]));
- };
- minf = function minf2(track) {
- return box(types.minf, track.type === "video" ? box(types.vmhd, VMHD) : box(types.smhd, SMHD), dinf(), stbl(track));
- };
- moof = function moof2(sequenceNumber, tracks) {
- var trackFragments = [], i2 = tracks.length;
- while (i2--) {
- trackFragments[i2] = traf(tracks[i2]);
- }
- return box.apply(null, [types.moof, mfhd(sequenceNumber)].concat(trackFragments));
- };
- moov = function moov2(tracks) {
- var i2 = tracks.length, boxes = [];
- while (i2--) {
- boxes[i2] = trak(tracks[i2]);
- }
- return box.apply(null, [types.moov, mvhd(4294967295)].concat(boxes).concat(mvex(tracks)));
- };
- mvex = function mvex2(tracks) {
- var i2 = tracks.length, boxes = [];
- while (i2--) {
- boxes[i2] = trex(tracks[i2]);
- }
- return box.apply(null, [types.mvex].concat(boxes));
- };
- mvhd = function mvhd2(duration5) {
- var bytes = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 2,
- 0,
- 1,
- 95,
- 144,
- (duration5 & 4278190080) >> 24,
- (duration5 & 16711680) >> 16,
- (duration5 & 65280) >> 8,
- duration5 & 255,
- 0,
- 1,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 64,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 255,
- 255,
- 255,
- 255
- ]);
- return box(types.mvhd, bytes);
- };
- sdtp = function sdtp2(track) {
- var samples = track.samples || [], bytes = new Uint8Array(4 + samples.length), flags, i2;
- for (i2 = 0; i2 < samples.length; i2++) {
- flags = samples[i2].flags;
- bytes[i2 + 4] = flags.dependsOn << 4 | flags.isDependedOn << 2 | flags.hasRedundancy;
- }
- return box(types.sdtp, bytes);
- };
- stbl = function stbl2(track) {
- return box(types.stbl, stsd(track), box(types.stts, STTS), box(types.stsc, STSC), box(types.stsz, STSZ), box(types.stco, STCO));
- };
- (function() {
- var videoSample, audioSample;
- stsd = function stsd2(track) {
- return box(types.stsd, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1
- ]), track.type === "video" ? videoSample(track) : audioSample(track));
- };
- videoSample = function videoSample2(track) {
- var sps = track.sps || [], pps = track.pps || [], sequenceParameterSets = [], pictureParameterSets = [], i2, avc1Box;
- for (i2 = 0; i2 < sps.length; i2++) {
- sequenceParameterSets.push((sps[i2].byteLength & 65280) >>> 8);
- sequenceParameterSets.push(sps[i2].byteLength & 255);
- sequenceParameterSets = sequenceParameterSets.concat(Array.prototype.slice.call(sps[i2]));
- }
- for (i2 = 0; i2 < pps.length; i2++) {
- pictureParameterSets.push((pps[i2].byteLength & 65280) >>> 8);
- pictureParameterSets.push(pps[i2].byteLength & 255);
- pictureParameterSets = pictureParameterSets.concat(Array.prototype.slice.call(pps[i2]));
- }
- avc1Box = [types.avc1, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- (track.width & 65280) >> 8,
- track.width & 255,
- (track.height & 65280) >> 8,
- track.height & 255,
- 0,
- 72,
- 0,
- 0,
- 0,
- 72,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 19,
- 118,
- 105,
- 100,
- 101,
- 111,
- 106,
- 115,
- 45,
- 99,
- 111,
- 110,
- 116,
- 114,
- 105,
- 98,
- 45,
- 104,
- 108,
- 115,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 24,
- 17,
- 17
- ]), box(types.avcC, new Uint8Array([
- 1,
- track.profileIdc,
- track.profileCompatibility,
- track.levelIdc,
- 255
- ].concat(
- [sps.length],
- sequenceParameterSets,
- [pps.length],
- pictureParameterSets
- ))), box(types.btrt, new Uint8Array([
- 0,
- 28,
- 156,
- 128,
- 0,
- 45,
- 198,
- 192,
- 0,
- 45,
- 198,
- 192
- ]))];
- if (track.sarRatio) {
- var hSpacing = track.sarRatio[0], vSpacing = track.sarRatio[1];
- avc1Box.push(box(types.pasp, new Uint8Array([(hSpacing & 4278190080) >> 24, (hSpacing & 16711680) >> 16, (hSpacing & 65280) >> 8, hSpacing & 255, (vSpacing & 4278190080) >> 24, (vSpacing & 16711680) >> 16, (vSpacing & 65280) >> 8, vSpacing & 255])));
- }
- return box.apply(null, avc1Box);
- };
- audioSample = function audioSample2(track) {
- return box(types.mp4a, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- (track.channelcount & 65280) >> 8,
- track.channelcount & 255,
- (track.samplesize & 65280) >> 8,
- track.samplesize & 255,
- 0,
- 0,
- 0,
- 0,
- (track.samplerate & 65280) >> 8,
- track.samplerate & 255,
- 0,
- 0
- ]), esds(track));
- };
- })();
- tkhd = function tkhd2(track) {
- var result = new Uint8Array([
- 0,
- 0,
- 0,
- 7,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- (track.id & 4278190080) >> 24,
- (track.id & 16711680) >> 16,
- (track.id & 65280) >> 8,
- track.id & 255,
- 0,
- 0,
- 0,
- 0,
- (track.duration & 4278190080) >> 24,
- (track.duration & 16711680) >> 16,
- (track.duration & 65280) >> 8,
- track.duration & 255,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 64,
- 0,
- 0,
- 0,
- (track.width & 65280) >> 8,
- track.width & 255,
- 0,
- 0,
- (track.height & 65280) >> 8,
- track.height & 255,
- 0,
- 0
- ]);
- return box(types.tkhd, result);
- };
- traf = function traf2(track) {
- var trackFragmentHeader, trackFragmentDecodeTime, trackFragmentRun, sampleDependencyTable, dataOffset, upperWordBaseMediaDecodeTime, lowerWordBaseMediaDecodeTime;
- trackFragmentHeader = box(types.tfhd, new Uint8Array([
- 0,
- 0,
- 0,
- 58,
- (track.id & 4278190080) >> 24,
- (track.id & 16711680) >> 16,
- (track.id & 65280) >> 8,
- track.id & 255,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]));
- upperWordBaseMediaDecodeTime = Math.floor(track.baseMediaDecodeTime / MAX_UINT322);
- lowerWordBaseMediaDecodeTime = Math.floor(track.baseMediaDecodeTime % MAX_UINT322);
- trackFragmentDecodeTime = box(types.tfdt, new Uint8Array([
- 1,
- 0,
- 0,
- 0,
- upperWordBaseMediaDecodeTime >>> 24 & 255,
- upperWordBaseMediaDecodeTime >>> 16 & 255,
- upperWordBaseMediaDecodeTime >>> 8 & 255,
- upperWordBaseMediaDecodeTime & 255,
- lowerWordBaseMediaDecodeTime >>> 24 & 255,
- lowerWordBaseMediaDecodeTime >>> 16 & 255,
- lowerWordBaseMediaDecodeTime >>> 8 & 255,
- lowerWordBaseMediaDecodeTime & 255
- ]));
- dataOffset = 32 + 20 + 8 + 16 + 8 + 8;
- if (track.type === "audio") {
- trackFragmentRun = trun$1(track, dataOffset);
- return box(types.traf, trackFragmentHeader, trackFragmentDecodeTime, trackFragmentRun);
- }
- sampleDependencyTable = sdtp(track);
- trackFragmentRun = trun$1(track, sampleDependencyTable.length + dataOffset);
- return box(types.traf, trackFragmentHeader, trackFragmentDecodeTime, trackFragmentRun, sampleDependencyTable);
- };
- trak = function trak2(track) {
- track.duration = track.duration || 4294967295;
- return box(types.trak, tkhd(track), mdia(track));
- };
- trex = function trex2(track) {
- var result = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- (track.id & 4278190080) >> 24,
- (track.id & 16711680) >> 16,
- (track.id & 65280) >> 8,
- track.id & 255,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 1
- ]);
- if (track.type !== "video") {
- result[result.length - 1] = 0;
- }
- return box(types.trex, result);
- };
- (function() {
- var audioTrun, videoTrun, trunHeader;
- trunHeader = function trunHeader2(samples, offset) {
- var durationPresent = 0, sizePresent = 0, flagsPresent = 0, compositionTimeOffset = 0;
- if (samples.length) {
- if (samples[0].duration !== void 0) {
- durationPresent = 1;
- }
- if (samples[0].size !== void 0) {
- sizePresent = 2;
- }
- if (samples[0].flags !== void 0) {
- flagsPresent = 4;
- }
- if (samples[0].compositionTimeOffset !== void 0) {
- compositionTimeOffset = 8;
- }
- }
- return [
- 0,
- 0,
- durationPresent | sizePresent | flagsPresent | compositionTimeOffset,
- 1,
- (samples.length & 4278190080) >>> 24,
- (samples.length & 16711680) >>> 16,
- (samples.length & 65280) >>> 8,
- samples.length & 255,
- (offset & 4278190080) >>> 24,
- (offset & 16711680) >>> 16,
- (offset & 65280) >>> 8,
- offset & 255
- ];
- };
- videoTrun = function videoTrun2(track, offset) {
- var bytesOffest, bytes, header, samples, sample, i2;
- samples = track.samples || [];
- offset += 8 + 12 + 16 * samples.length;
- header = trunHeader(samples, offset);
- bytes = new Uint8Array(header.length + samples.length * 16);
- bytes.set(header);
- bytesOffest = header.length;
- for (i2 = 0; i2 < samples.length; i2++) {
- sample = samples[i2];
- bytes[bytesOffest++] = (sample.duration & 4278190080) >>> 24;
- bytes[bytesOffest++] = (sample.duration & 16711680) >>> 16;
- bytes[bytesOffest++] = (sample.duration & 65280) >>> 8;
- bytes[bytesOffest++] = sample.duration & 255;
- bytes[bytesOffest++] = (sample.size & 4278190080) >>> 24;
- bytes[bytesOffest++] = (sample.size & 16711680) >>> 16;
- bytes[bytesOffest++] = (sample.size & 65280) >>> 8;
- bytes[bytesOffest++] = sample.size & 255;
- bytes[bytesOffest++] = sample.flags.isLeading << 2 | sample.flags.dependsOn;
- bytes[bytesOffest++] = sample.flags.isDependedOn << 6 | sample.flags.hasRedundancy << 4 | sample.flags.paddingValue << 1 | sample.flags.isNonSyncSample;
- bytes[bytesOffest++] = sample.flags.degradationPriority & 240 << 8;
- bytes[bytesOffest++] = sample.flags.degradationPriority & 15;
- bytes[bytesOffest++] = (sample.compositionTimeOffset & 4278190080) >>> 24;
- bytes[bytesOffest++] = (sample.compositionTimeOffset & 16711680) >>> 16;
- bytes[bytesOffest++] = (sample.compositionTimeOffset & 65280) >>> 8;
- bytes[bytesOffest++] = sample.compositionTimeOffset & 255;
- }
- return box(types.trun, bytes);
- };
- audioTrun = function audioTrun2(track, offset) {
- var bytes, bytesOffest, header, samples, sample, i2;
- samples = track.samples || [];
- offset += 8 + 12 + 8 * samples.length;
- header = trunHeader(samples, offset);
- bytes = new Uint8Array(header.length + samples.length * 8);
- bytes.set(header);
- bytesOffest = header.length;
- for (i2 = 0; i2 < samples.length; i2++) {
- sample = samples[i2];
- bytes[bytesOffest++] = (sample.duration & 4278190080) >>> 24;
- bytes[bytesOffest++] = (sample.duration & 16711680) >>> 16;
- bytes[bytesOffest++] = (sample.duration & 65280) >>> 8;
- bytes[bytesOffest++] = sample.duration & 255;
- bytes[bytesOffest++] = (sample.size & 4278190080) >>> 24;
- bytes[bytesOffest++] = (sample.size & 16711680) >>> 16;
- bytes[bytesOffest++] = (sample.size & 65280) >>> 8;
- bytes[bytesOffest++] = sample.size & 255;
- }
- return box(types.trun, bytes);
- };
- trun$1 = function trun2(track, offset) {
- if (track.type === "audio") {
- return audioTrun(track, offset);
- }
- return videoTrun(track, offset);
- };
- })();
- var mp4Generator = {
- ftyp,
- mdat,
- moof,
- moov,
- initSegment: function initSegment(tracks) {
- var fileType = ftyp(), movie = moov(tracks), result;
- result = new Uint8Array(fileType.byteLength + movie.byteLength);
- result.set(fileType);
- result.set(movie, fileType.byteLength);
- return result;
- }
- };
- var groupNalsIntoFrames = function groupNalsIntoFrames2(nalUnits) {
- var i2, currentNal, currentFrame = [], frames = [];
- frames.byteLength = 0;
- frames.nalCount = 0;
- frames.duration = 0;
- currentFrame.byteLength = 0;
- for (i2 = 0; i2 < nalUnits.length; i2++) {
- currentNal = nalUnits[i2];
- if (currentNal.nalUnitType === "access_unit_delimiter_rbsp") {
- if (currentFrame.length) {
- currentFrame.duration = currentNal.dts - currentFrame.dts;
- frames.byteLength += currentFrame.byteLength;
- frames.nalCount += currentFrame.length;
- frames.duration += currentFrame.duration;
- frames.push(currentFrame);
- }
- currentFrame = [currentNal];
- currentFrame.byteLength = currentNal.data.byteLength;
- currentFrame.pts = currentNal.pts;
- currentFrame.dts = currentNal.dts;
- } else {
- if (currentNal.nalUnitType === "slice_layer_without_partitioning_rbsp_idr") {
- currentFrame.keyFrame = true;
- }
- currentFrame.duration = currentNal.dts - currentFrame.dts;
- currentFrame.byteLength += currentNal.data.byteLength;
- currentFrame.push(currentNal);
- }
- }
- if (frames.length && (!currentFrame.duration || currentFrame.duration <= 0)) {
- currentFrame.duration = frames[frames.length - 1].duration;
- }
- frames.byteLength += currentFrame.byteLength;
- frames.nalCount += currentFrame.length;
- frames.duration += currentFrame.duration;
- frames.push(currentFrame);
- return frames;
- };
- var groupFramesIntoGops = function groupFramesIntoGops2(frames) {
- var i2, currentFrame, currentGop = [], gops = [];
- currentGop.byteLength = 0;
- currentGop.nalCount = 0;
- currentGop.duration = 0;
- currentGop.pts = frames[0].pts;
- currentGop.dts = frames[0].dts;
- gops.byteLength = 0;
- gops.nalCount = 0;
- gops.duration = 0;
- gops.pts = frames[0].pts;
- gops.dts = frames[0].dts;
- for (i2 = 0; i2 < frames.length; i2++) {
- currentFrame = frames[i2];
- if (currentFrame.keyFrame) {
- if (currentGop.length) {
- gops.push(currentGop);
- gops.byteLength += currentGop.byteLength;
- gops.nalCount += currentGop.nalCount;
- gops.duration += currentGop.duration;
- }
- currentGop = [currentFrame];
- currentGop.nalCount = currentFrame.length;
- currentGop.byteLength = currentFrame.byteLength;
- currentGop.pts = currentFrame.pts;
- currentGop.dts = currentFrame.dts;
- currentGop.duration = currentFrame.duration;
- } else {
- currentGop.duration += currentFrame.duration;
- currentGop.nalCount += currentFrame.length;
- currentGop.byteLength += currentFrame.byteLength;
- currentGop.push(currentFrame);
- }
- }
- if (gops.length && currentGop.duration <= 0) {
- currentGop.duration = gops[gops.length - 1].duration;
- }
- gops.byteLength += currentGop.byteLength;
- gops.nalCount += currentGop.nalCount;
- gops.duration += currentGop.duration;
- gops.push(currentGop);
- return gops;
- };
- var extendFirstKeyFrame = function extendFirstKeyFrame2(gops) {
- var currentGop;
- if (!gops[0][0].keyFrame && gops.length > 1) {
- currentGop = gops.shift();
- gops.byteLength -= currentGop.byteLength;
- gops.nalCount -= currentGop.nalCount;
- gops[0][0].dts = currentGop.dts;
- gops[0][0].pts = currentGop.pts;
- gops[0][0].duration += currentGop.duration;
- }
- return gops;
- };
- var createDefaultSample = function createDefaultSample2() {
- return {
- size: 0,
- flags: {
- isLeading: 0,
- dependsOn: 1,
- isDependedOn: 0,
- hasRedundancy: 0,
- degradationPriority: 0,
- isNonSyncSample: 1
- }
- };
- };
- var sampleForFrame = function sampleForFrame2(frame, dataOffset) {
- var sample = createDefaultSample();
- sample.dataOffset = dataOffset;
- sample.compositionTimeOffset = frame.pts - frame.dts;
- sample.duration = frame.duration;
- sample.size = 4 * frame.length;
- sample.size += frame.byteLength;
- if (frame.keyFrame) {
- sample.flags.dependsOn = 2;
- sample.flags.isNonSyncSample = 0;
- }
- return sample;
- };
- var generateSampleTable$1 = function generateSampleTable2(gops, baseDataOffset) {
- var h2, i2, sample, currentGop, currentFrame, dataOffset = baseDataOffset || 0, samples = [];
- for (h2 = 0; h2 < gops.length; h2++) {
- currentGop = gops[h2];
- for (i2 = 0; i2 < currentGop.length; i2++) {
- currentFrame = currentGop[i2];
- sample = sampleForFrame(currentFrame, dataOffset);
- dataOffset += sample.size;
- samples.push(sample);
- }
- }
- return samples;
- };
- var concatenateNalData = function concatenateNalData2(gops) {
- var h2, i2, j, currentGop, currentFrame, currentNal, dataOffset = 0, nalsByteLength = gops.byteLength, numberOfNals = gops.nalCount, totalByteLength = nalsByteLength + 4 * numberOfNals, data = new Uint8Array(totalByteLength), view = new DataView(data.buffer);
- for (h2 = 0; h2 < gops.length; h2++) {
- currentGop = gops[h2];
- for (i2 = 0; i2 < currentGop.length; i2++) {
- currentFrame = currentGop[i2];
- for (j = 0; j < currentFrame.length; j++) {
- currentNal = currentFrame[j];
- view.setUint32(dataOffset, currentNal.data.byteLength);
- dataOffset += 4;
- data.set(currentNal.data, dataOffset);
- dataOffset += currentNal.data.byteLength;
- }
- }
- }
- return data;
- };
- var generateSampleTableForFrame = function generateSampleTableForFrame2(frame, baseDataOffset) {
- var sample, dataOffset = baseDataOffset || 0, samples = [];
- sample = sampleForFrame(frame, dataOffset);
- samples.push(sample);
- return samples;
- };
- var concatenateNalDataForFrame = function concatenateNalDataForFrame2(frame) {
- var i2, currentNal, dataOffset = 0, nalsByteLength = frame.byteLength, numberOfNals = frame.length, totalByteLength = nalsByteLength + 4 * numberOfNals, data = new Uint8Array(totalByteLength), view = new DataView(data.buffer);
- for (i2 = 0; i2 < frame.length; i2++) {
- currentNal = frame[i2];
- view.setUint32(dataOffset, currentNal.data.byteLength);
- dataOffset += 4;
- data.set(currentNal.data, dataOffset);
- dataOffset += currentNal.data.byteLength;
- }
- return data;
- };
- var frameUtils = {
- groupNalsIntoFrames,
- groupFramesIntoGops,
- extendFirstKeyFrame,
- generateSampleTable: generateSampleTable$1,
- concatenateNalData,
- generateSampleTableForFrame,
- concatenateNalDataForFrame
- };
- var highPrefix = [33, 16, 5, 32, 164, 27];
- var lowPrefix = [33, 65, 108, 84, 1, 2, 4, 8, 168, 2, 4, 8, 17, 191, 252];
- var zeroFill = function zeroFill2(count) {
- var a = [];
- while (count--) {
- a.push(0);
- }
- return a;
- };
- var makeTable = function makeTable2(metaTable) {
- return Object.keys(metaTable).reduce(function(obj, key) {
- obj[key] = new Uint8Array(metaTable[key].reduce(function(arr, part) {
- return arr.concat(part);
- }, []));
- return obj;
- }, {});
- };
- var silence;
- var silence_1 = function silence_12() {
- if (!silence) {
- var coneOfSilence = {
- 96e3: [highPrefix, [227, 64], zeroFill(154), [56]],
- 88200: [highPrefix, [231], zeroFill(170), [56]],
- 64e3: [highPrefix, [248, 192], zeroFill(240), [56]],
- 48e3: [highPrefix, [255, 192], zeroFill(268), [55, 148, 128], zeroFill(54), [112]],
- 44100: [highPrefix, [255, 192], zeroFill(268), [55, 163, 128], zeroFill(84), [112]],
- 32e3: [highPrefix, [255, 192], zeroFill(268), [55, 234], zeroFill(226), [112]],
- 24e3: [highPrefix, [255, 192], zeroFill(268), [55, 255, 128], zeroFill(268), [111, 112], zeroFill(126), [224]],
- 16e3: [highPrefix, [255, 192], zeroFill(268), [55, 255, 128], zeroFill(268), [111, 255], zeroFill(269), [223, 108], zeroFill(195), [1, 192]],
- 12e3: [lowPrefix, zeroFill(268), [3, 127, 248], zeroFill(268), [6, 255, 240], zeroFill(268), [13, 255, 224], zeroFill(268), [27, 253, 128], zeroFill(259), [56]],
- 11025: [lowPrefix, zeroFill(268), [3, 127, 248], zeroFill(268), [6, 255, 240], zeroFill(268), [13, 255, 224], zeroFill(268), [27, 255, 192], zeroFill(268), [55, 175, 128], zeroFill(108), [112]],
- 8e3: [lowPrefix, zeroFill(268), [3, 121, 16], zeroFill(47), [7]]
- };
- silence = makeTable(coneOfSilence);
- }
- return silence;
- };
- var ONE_SECOND_IN_TS$4 = 9e4, secondsToVideoTs2, secondsToAudioTs2, videoTsToSeconds2, audioTsToSeconds2, audioTsToVideoTs2, videoTsToAudioTs2, metadataTsToSeconds2;
- secondsToVideoTs2 = function secondsToVideoTs3(seconds) {
- return seconds * ONE_SECOND_IN_TS$4;
- };
- secondsToAudioTs2 = function secondsToAudioTs3(seconds, sampleRate) {
- return seconds * sampleRate;
- };
- videoTsToSeconds2 = function videoTsToSeconds3(timestamp) {
- return timestamp / ONE_SECOND_IN_TS$4;
- };
- audioTsToSeconds2 = function audioTsToSeconds3(timestamp, sampleRate) {
- return timestamp / sampleRate;
- };
- audioTsToVideoTs2 = function audioTsToVideoTs3(timestamp, sampleRate) {
- return secondsToVideoTs2(audioTsToSeconds2(timestamp, sampleRate));
- };
- videoTsToAudioTs2 = function videoTsToAudioTs3(timestamp, sampleRate) {
- return secondsToAudioTs2(videoTsToSeconds2(timestamp), sampleRate);
- };
- metadataTsToSeconds2 = function metadataTsToSeconds3(timestamp, timelineStartPts, keepOriginalTimestamps) {
- return videoTsToSeconds2(keepOriginalTimestamps ? timestamp : timestamp - timelineStartPts);
- };
- var clock2 = {
- ONE_SECOND_IN_TS: ONE_SECOND_IN_TS$4,
- secondsToVideoTs: secondsToVideoTs2,
- secondsToAudioTs: secondsToAudioTs2,
- videoTsToSeconds: videoTsToSeconds2,
- audioTsToSeconds: audioTsToSeconds2,
- audioTsToVideoTs: audioTsToVideoTs2,
- videoTsToAudioTs: videoTsToAudioTs2,
- metadataTsToSeconds: metadataTsToSeconds2
- };
- var sumFrameByteLengths = function sumFrameByteLengths2(array) {
- var i2, currentObj, sum = 0;
- for (i2 = 0; i2 < array.length; i2++) {
- currentObj = array[i2];
- sum += currentObj.data.byteLength;
- }
- return sum;
- };
- var prefixWithSilence = function prefixWithSilence2(track, frames, audioAppendStartTs, videoBaseMediaDecodeTime) {
- var baseMediaDecodeTimeTs, frameDuration = 0, audioGapDuration = 0, audioFillFrameCount = 0, audioFillDuration = 0, silentFrame, i2, firstFrame;
- if (!frames.length) {
- return;
- }
- baseMediaDecodeTimeTs = clock2.audioTsToVideoTs(track.baseMediaDecodeTime, track.samplerate);
- frameDuration = Math.ceil(clock2.ONE_SECOND_IN_TS / (track.samplerate / 1024));
- if (audioAppendStartTs && videoBaseMediaDecodeTime) {
- audioGapDuration = baseMediaDecodeTimeTs - Math.max(audioAppendStartTs, videoBaseMediaDecodeTime);
- audioFillFrameCount = Math.floor(audioGapDuration / frameDuration);
- audioFillDuration = audioFillFrameCount * frameDuration;
- }
- if (audioFillFrameCount < 1 || audioFillDuration > clock2.ONE_SECOND_IN_TS / 2) {
- return;
- }
- silentFrame = silence_1()[track.samplerate];
- if (!silentFrame) {
- silentFrame = frames[0].data;
- }
- for (i2 = 0; i2 < audioFillFrameCount; i2++) {
- firstFrame = frames[0];
- frames.splice(0, 0, {
- data: silentFrame,
- dts: firstFrame.dts - frameDuration,
- pts: firstFrame.pts - frameDuration
- });
- }
- track.baseMediaDecodeTime -= Math.floor(clock2.videoTsToAudioTs(audioFillDuration, track.samplerate));
- return audioFillDuration;
- };
- var trimAdtsFramesByEarliestDts = function trimAdtsFramesByEarliestDts2(adtsFrames, track, earliestAllowedDts) {
- if (track.minSegmentDts >= earliestAllowedDts) {
- return adtsFrames;
- }
- track.minSegmentDts = Infinity;
- return adtsFrames.filter(function(currentFrame) {
- if (currentFrame.dts >= earliestAllowedDts) {
- track.minSegmentDts = Math.min(track.minSegmentDts, currentFrame.dts);
- track.minSegmentPts = track.minSegmentDts;
- return true;
- }
- return false;
- });
- };
- var generateSampleTable = function generateSampleTable2(frames) {
- var i2, currentFrame, samples = [];
- for (i2 = 0; i2 < frames.length; i2++) {
- currentFrame = frames[i2];
- samples.push({
- size: currentFrame.data.byteLength,
- duration: 1024
- });
- }
- return samples;
- };
- var concatenateFrameData = function concatenateFrameData2(frames) {
- var i2, currentFrame, dataOffset = 0, data = new Uint8Array(sumFrameByteLengths(frames));
- for (i2 = 0; i2 < frames.length; i2++) {
- currentFrame = frames[i2];
- data.set(currentFrame.data, dataOffset);
- dataOffset += currentFrame.data.byteLength;
- }
- return data;
- };
- var audioFrameUtils = {
- prefixWithSilence,
- trimAdtsFramesByEarliestDts,
- generateSampleTable,
- concatenateFrameData
- };
- var ONE_SECOND_IN_TS$3 = clock2.ONE_SECOND_IN_TS;
- var collectDtsInfo = function collectDtsInfo2(track, data) {
- if (typeof data.pts === "number") {
- if (track.timelineStartInfo.pts === void 0) {
- track.timelineStartInfo.pts = data.pts;
- }
- if (track.minSegmentPts === void 0) {
- track.minSegmentPts = data.pts;
- } else {
- track.minSegmentPts = Math.min(track.minSegmentPts, data.pts);
- }
- if (track.maxSegmentPts === void 0) {
- track.maxSegmentPts = data.pts;
- } else {
- track.maxSegmentPts = Math.max(track.maxSegmentPts, data.pts);
- }
- }
- if (typeof data.dts === "number") {
- if (track.timelineStartInfo.dts === void 0) {
- track.timelineStartInfo.dts = data.dts;
- }
- if (track.minSegmentDts === void 0) {
- track.minSegmentDts = data.dts;
- } else {
- track.minSegmentDts = Math.min(track.minSegmentDts, data.dts);
- }
- if (track.maxSegmentDts === void 0) {
- track.maxSegmentDts = data.dts;
- } else {
- track.maxSegmentDts = Math.max(track.maxSegmentDts, data.dts);
- }
- }
- };
- var clearDtsInfo = function clearDtsInfo2(track) {
- delete track.minSegmentDts;
- delete track.maxSegmentDts;
- delete track.minSegmentPts;
- delete track.maxSegmentPts;
- };
- var calculateTrackBaseMediaDecodeTime = function calculateTrackBaseMediaDecodeTime2(track, keepOriginalTimestamps) {
- var baseMediaDecodeTime, scale, minSegmentDts = track.minSegmentDts;
- if (!keepOriginalTimestamps) {
- minSegmentDts -= track.timelineStartInfo.dts;
- }
- baseMediaDecodeTime = track.timelineStartInfo.baseMediaDecodeTime;
- baseMediaDecodeTime += minSegmentDts;
- baseMediaDecodeTime = Math.max(0, baseMediaDecodeTime);
- if (track.type === "audio") {
- scale = track.samplerate / ONE_SECOND_IN_TS$3;
- baseMediaDecodeTime *= scale;
- baseMediaDecodeTime = Math.floor(baseMediaDecodeTime);
- }
- return baseMediaDecodeTime;
- };
- var trackDecodeInfo = {
- clearDtsInfo,
- calculateTrackBaseMediaDecodeTime,
- collectDtsInfo
- };
- var USER_DATA_REGISTERED_ITU_T_T35 = 4, RBSP_TRAILING_BITS = 128;
- var parseSei = function parseSei2(bytes) {
- var i2 = 0, result = {
- payloadType: -1,
- payloadSize: 0
- }, payloadType = 0, payloadSize = 0;
- while (i2 < bytes.byteLength) {
- if (bytes[i2] === RBSP_TRAILING_BITS) {
- break;
- }
- while (bytes[i2] === 255) {
- payloadType += 255;
- i2++;
- }
- payloadType += bytes[i2++];
- while (bytes[i2] === 255) {
- payloadSize += 255;
- i2++;
- }
- payloadSize += bytes[i2++];
- if (!result.payload && payloadType === USER_DATA_REGISTERED_ITU_T_T35) {
- var userIdentifier = String.fromCharCode(bytes[i2 + 3], bytes[i2 + 4], bytes[i2 + 5], bytes[i2 + 6]);
- if (userIdentifier === "GA94") {
- result.payloadType = payloadType;
- result.payloadSize = payloadSize;
- result.payload = bytes.subarray(i2, i2 + payloadSize);
- break;
- } else {
- result.payload = void 0;
- }
- }
- i2 += payloadSize;
- payloadType = 0;
- payloadSize = 0;
- }
- return result;
- };
- var parseUserData = function parseUserData2(sei) {
- if (sei.payload[0] !== 181) {
- return null;
- }
- if ((sei.payload[1] << 8 | sei.payload[2]) !== 49) {
- return null;
- }
- if (String.fromCharCode(sei.payload[3], sei.payload[4], sei.payload[5], sei.payload[6]) !== "GA94") {
- return null;
- }
- if (sei.payload[7] !== 3) {
- return null;
- }
- return sei.payload.subarray(8, sei.payload.length - 1);
- };
- var parseCaptionPackets = function parseCaptionPackets2(pts, userData) {
- var results = [], i2, count, offset, data;
- if (!(userData[0] & 64)) {
- return results;
- }
- count = userData[0] & 31;
- for (i2 = 0; i2 < count; i2++) {
- offset = i2 * 3;
- data = {
- type: userData[offset + 2] & 3,
- pts
- };
- if (userData[offset + 2] & 4) {
- data.ccData = userData[offset + 3] << 8 | userData[offset + 4];
- results.push(data);
- }
- }
- return results;
- };
- var discardEmulationPreventionBytes$12 = function discardEmulationPreventionBytes5(data) {
- var length = data.byteLength, emulationPreventionBytesPositions = [], i2 = 1, newLength, newData;
- while (i2 < length - 2) {
- if (data[i2] === 0 && data[i2 + 1] === 0 && data[i2 + 2] === 3) {
- emulationPreventionBytesPositions.push(i2 + 2);
- i2 += 2;
- } else {
- i2++;
- }
- }
- if (emulationPreventionBytesPositions.length === 0) {
- return data;
- }
- newLength = length - emulationPreventionBytesPositions.length;
- newData = new Uint8Array(newLength);
- var sourceIndex = 0;
- for (i2 = 0; i2 < newLength; sourceIndex++, i2++) {
- if (sourceIndex === emulationPreventionBytesPositions[0]) {
- sourceIndex++;
- emulationPreventionBytesPositions.shift();
- }
- newData[i2] = data[sourceIndex];
- }
- return newData;
- };
- var captionPacketParser = {
- parseSei,
- parseUserData,
- parseCaptionPackets,
- discardEmulationPreventionBytes: discardEmulationPreventionBytes$12,
- USER_DATA_REGISTERED_ITU_T_T35
- };
- var CaptionStream$1 = function CaptionStream2(options2) {
- options2 = options2 || {};
- CaptionStream2.prototype.init.call(this);
- this.parse708captions_ = typeof options2.parse708captions === "boolean" ? options2.parse708captions : true;
- this.captionPackets_ = [];
- this.ccStreams_ = [
- new Cea608Stream(0, 0),
- new Cea608Stream(0, 1),
- new Cea608Stream(1, 0),
- new Cea608Stream(1, 1)
- ];
- if (this.parse708captions_) {
- this.cc708Stream_ = new Cea708Stream({
- captionServices: options2.captionServices
- });
- }
- this.reset();
- this.ccStreams_.forEach(function(cc) {
- cc.on("data", this.trigger.bind(this, "data"));
- cc.on("partialdone", this.trigger.bind(this, "partialdone"));
- cc.on("done", this.trigger.bind(this, "done"));
- }, this);
- if (this.parse708captions_) {
- this.cc708Stream_.on("data", this.trigger.bind(this, "data"));
- this.cc708Stream_.on("partialdone", this.trigger.bind(this, "partialdone"));
- this.cc708Stream_.on("done", this.trigger.bind(this, "done"));
- }
- };
- CaptionStream$1.prototype = new stream();
- CaptionStream$1.prototype.push = function(event2) {
- var sei, userData, newCaptionPackets;
- if (event2.nalUnitType !== "sei_rbsp") {
- return;
- }
- sei = captionPacketParser.parseSei(event2.escapedRBSP);
- if (!sei.payload) {
- return;
- }
- if (sei.payloadType !== captionPacketParser.USER_DATA_REGISTERED_ITU_T_T35) {
- return;
- }
- userData = captionPacketParser.parseUserData(sei);
- if (!userData) {
- return;
- }
- if (event2.dts < this.latestDts_) {
- this.ignoreNextEqualDts_ = true;
- return;
- } else if (event2.dts === this.latestDts_ && this.ignoreNextEqualDts_) {
- this.numSameDts_--;
- if (!this.numSameDts_) {
- this.ignoreNextEqualDts_ = false;
- }
- return;
- }
- newCaptionPackets = captionPacketParser.parseCaptionPackets(event2.pts, userData);
- this.captionPackets_ = this.captionPackets_.concat(newCaptionPackets);
- if (this.latestDts_ !== event2.dts) {
- this.numSameDts_ = 0;
- }
- this.numSameDts_++;
- this.latestDts_ = event2.dts;
- };
- CaptionStream$1.prototype.flushCCStreams = function(flushType) {
- this.ccStreams_.forEach(function(cc) {
- return flushType === "flush" ? cc.flush() : cc.partialFlush();
- }, this);
- };
- CaptionStream$1.prototype.flushStream = function(flushType) {
- if (!this.captionPackets_.length) {
- this.flushCCStreams(flushType);
- return;
- }
- this.captionPackets_.forEach(function(elem, idx) {
- elem.presortIndex = idx;
- });
- this.captionPackets_.sort(function(a, b) {
- if (a.pts === b.pts) {
- return a.presortIndex - b.presortIndex;
- }
- return a.pts - b.pts;
- });
- this.captionPackets_.forEach(function(packet) {
- if (packet.type < 2) {
- this.dispatchCea608Packet(packet);
- } else {
- this.dispatchCea708Packet(packet);
- }
- }, this);
- this.captionPackets_.length = 0;
- this.flushCCStreams(flushType);
- };
- CaptionStream$1.prototype.flush = function() {
- return this.flushStream("flush");
- };
- CaptionStream$1.prototype.partialFlush = function() {
- return this.flushStream("partialFlush");
- };
- CaptionStream$1.prototype.reset = function() {
- this.latestDts_ = null;
- this.ignoreNextEqualDts_ = false;
- this.numSameDts_ = 0;
- this.activeCea608Channel_ = [null, null];
- this.ccStreams_.forEach(function(ccStream) {
- ccStream.reset();
- });
- };
- CaptionStream$1.prototype.dispatchCea608Packet = function(packet) {
- if (this.setsTextOrXDSActive(packet)) {
- this.activeCea608Channel_[packet.type] = null;
- } else if (this.setsChannel1Active(packet)) {
- this.activeCea608Channel_[packet.type] = 0;
- } else if (this.setsChannel2Active(packet)) {
- this.activeCea608Channel_[packet.type] = 1;
- }
- if (this.activeCea608Channel_[packet.type] === null) {
- return;
- }
- this.ccStreams_[(packet.type << 1) + this.activeCea608Channel_[packet.type]].push(packet);
- };
- CaptionStream$1.prototype.setsChannel1Active = function(packet) {
- return (packet.ccData & 30720) === 4096;
- };
- CaptionStream$1.prototype.setsChannel2Active = function(packet) {
- return (packet.ccData & 30720) === 6144;
- };
- CaptionStream$1.prototype.setsTextOrXDSActive = function(packet) {
- return (packet.ccData & 28928) === 256 || (packet.ccData & 30974) === 4138 || (packet.ccData & 30974) === 6186;
- };
- CaptionStream$1.prototype.dispatchCea708Packet = function(packet) {
- if (this.parse708captions_) {
- this.cc708Stream_.push(packet);
- }
- };
- var CHARACTER_TRANSLATION_708 = {
- 127: 9834,
- 4128: 32,
- 4129: 160,
- 4133: 8230,
- 4138: 352,
- 4140: 338,
- 4144: 9608,
- 4145: 8216,
- 4146: 8217,
- 4147: 8220,
- 4148: 8221,
- 4149: 8226,
- 4153: 8482,
- 4154: 353,
- 4156: 339,
- 4157: 8480,
- 4159: 376,
- 4214: 8539,
- 4215: 8540,
- 4216: 8541,
- 4217: 8542,
- 4218: 9168,
- 4219: 9124,
- 4220: 9123,
- 4221: 9135,
- 4222: 9126,
- 4223: 9121,
- 4256: 12600
- };
- var get708CharFromCode = function get708CharFromCode2(code) {
- var newCode = CHARACTER_TRANSLATION_708[code] || code;
- if (code & 4096 && code === newCode) {
- return "";
- }
- return String.fromCharCode(newCode);
- };
- var within708TextBlock = function within708TextBlock2(b) {
- return 32 <= b && b <= 127 || 160 <= b && b <= 255;
- };
- var Cea708Window = function Cea708Window2(windowNum) {
- this.windowNum = windowNum;
- this.reset();
- };
- Cea708Window.prototype.reset = function() {
- this.clearText();
- this.pendingNewLine = false;
- this.winAttr = {};
- this.penAttr = {};
- this.penLoc = {};
- this.penColor = {};
- this.visible = 0;
- this.rowLock = 0;
- this.columnLock = 0;
- this.priority = 0;
- this.relativePositioning = 0;
- this.anchorVertical = 0;
- this.anchorHorizontal = 0;
- this.anchorPoint = 0;
- this.rowCount = 1;
- this.virtualRowCount = this.rowCount + 1;
- this.columnCount = 41;
- this.windowStyle = 0;
- this.penStyle = 0;
- };
- Cea708Window.prototype.getText = function() {
- return this.rows.join("\n");
- };
- Cea708Window.prototype.clearText = function() {
- this.rows = [""];
- this.rowIdx = 0;
- };
- Cea708Window.prototype.newLine = function(pts) {
- if (this.rows.length >= this.virtualRowCount && typeof this.beforeRowOverflow === "function") {
- this.beforeRowOverflow(pts);
- }
- if (this.rows.length > 0) {
- this.rows.push("");
- this.rowIdx++;
- }
- while (this.rows.length > this.virtualRowCount) {
- this.rows.shift();
- this.rowIdx--;
- }
- };
- Cea708Window.prototype.isEmpty = function() {
- if (this.rows.length === 0) {
- return true;
- } else if (this.rows.length === 1) {
- return this.rows[0] === "";
- }
- return false;
- };
- Cea708Window.prototype.addText = function(text) {
- this.rows[this.rowIdx] += text;
- };
- Cea708Window.prototype.backspace = function() {
- if (!this.isEmpty()) {
- var row = this.rows[this.rowIdx];
- this.rows[this.rowIdx] = row.substr(0, row.length - 1);
- }
- };
- var Cea708Service = function Cea708Service2(serviceNum, encoding, stream2) {
- this.serviceNum = serviceNum;
- this.text = "";
- this.currentWindow = new Cea708Window(-1);
- this.windows = [];
- this.stream = stream2;
- if (typeof encoding === "string") {
- this.createTextDecoder(encoding);
- }
- };
- Cea708Service.prototype.init = function(pts, beforeRowOverflow) {
- this.startPts = pts;
- for (var win3 = 0; win3 < 8; win3++) {
- this.windows[win3] = new Cea708Window(win3);
- if (typeof beforeRowOverflow === "function") {
- this.windows[win3].beforeRowOverflow = beforeRowOverflow;
- }
- }
- };
- Cea708Service.prototype.setCurrentWindow = function(windowNum) {
- this.currentWindow = this.windows[windowNum];
- };
- Cea708Service.prototype.createTextDecoder = function(encoding) {
- if (typeof TextDecoder === "undefined") {
- this.stream.trigger("log", {
- level: "warn",
- message: "The `encoding` option is unsupported without TextDecoder support"
- });
- } else {
- try {
- this.textDecoder_ = new TextDecoder(encoding);
- } catch (error) {
- this.stream.trigger("log", {
- level: "warn",
- message: "TextDecoder could not be created with " + encoding + " encoding. " + error
- });
- }
- }
- };
- var Cea708Stream = function Cea708Stream2(options2) {
- options2 = options2 || {};
- Cea708Stream2.prototype.init.call(this);
- var self2 = this;
- var captionServices = options2.captionServices || {};
- var captionServiceEncodings = {};
- var serviceProps;
- Object.keys(captionServices).forEach(function(serviceName) {
- serviceProps = captionServices[serviceName];
- if (/^SERVICE/.test(serviceName)) {
- captionServiceEncodings[serviceName] = serviceProps.encoding;
- }
- });
- this.serviceEncodings = captionServiceEncodings;
- this.current708Packet = null;
- this.services = {};
- this.push = function(packet) {
- if (packet.type === 3) {
- self2.new708Packet();
- self2.add708Bytes(packet);
- } else {
- if (self2.current708Packet === null) {
- self2.new708Packet();
- }
- self2.add708Bytes(packet);
- }
- };
- };
- Cea708Stream.prototype = new stream();
- Cea708Stream.prototype.new708Packet = function() {
- if (this.current708Packet !== null) {
- this.push708Packet();
- }
- this.current708Packet = {
- data: [],
- ptsVals: []
- };
- };
- Cea708Stream.prototype.add708Bytes = function(packet) {
- var data = packet.ccData;
- var byte0 = data >>> 8;
- var byte1 = data & 255;
- this.current708Packet.ptsVals.push(packet.pts);
- this.current708Packet.data.push(byte0);
- this.current708Packet.data.push(byte1);
- };
- Cea708Stream.prototype.push708Packet = function() {
- var packet708 = this.current708Packet;
- var packetData = packet708.data;
- var serviceNum = null;
- var blockSize = null;
- var i2 = 0;
- var b = packetData[i2++];
- packet708.seq = b >> 6;
- packet708.sizeCode = b & 63;
- for (; i2 < packetData.length; i2++) {
- b = packetData[i2++];
- serviceNum = b >> 5;
- blockSize = b & 31;
- if (serviceNum === 7 && blockSize > 0) {
- b = packetData[i2++];
- serviceNum = b;
- }
- this.pushServiceBlock(serviceNum, i2, blockSize);
- if (blockSize > 0) {
- i2 += blockSize - 1;
- }
- }
- };
- Cea708Stream.prototype.pushServiceBlock = function(serviceNum, start2, size) {
- var b;
- var i2 = start2;
- var packetData = this.current708Packet.data;
- var service = this.services[serviceNum];
- if (!service) {
- service = this.initService(serviceNum, i2);
- }
- for (; i2 < start2 + size && i2 < packetData.length; i2++) {
- b = packetData[i2];
- if (within708TextBlock(b)) {
- i2 = this.handleText(i2, service);
- } else if (b === 24) {
- i2 = this.multiByteCharacter(i2, service);
- } else if (b === 16) {
- i2 = this.extendedCommands(i2, service);
- } else if (128 <= b && b <= 135) {
- i2 = this.setCurrentWindow(i2, service);
- } else if (152 <= b && b <= 159) {
- i2 = this.defineWindow(i2, service);
- } else if (b === 136) {
- i2 = this.clearWindows(i2, service);
- } else if (b === 140) {
- i2 = this.deleteWindows(i2, service);
- } else if (b === 137) {
- i2 = this.displayWindows(i2, service);
- } else if (b === 138) {
- i2 = this.hideWindows(i2, service);
- } else if (b === 139) {
- i2 = this.toggleWindows(i2, service);
- } else if (b === 151) {
- i2 = this.setWindowAttributes(i2, service);
- } else if (b === 144) {
- i2 = this.setPenAttributes(i2, service);
- } else if (b === 145) {
- i2 = this.setPenColor(i2, service);
- } else if (b === 146) {
- i2 = this.setPenLocation(i2, service);
- } else if (b === 143) {
- service = this.reset(i2, service);
- } else if (b === 8) {
- service.currentWindow.backspace();
- } else if (b === 12) {
- service.currentWindow.clearText();
- } else if (b === 13) {
- service.currentWindow.pendingNewLine = true;
- } else if (b === 14) {
- service.currentWindow.clearText();
- } else if (b === 141) {
- i2++;
- } else
- ;
- }
- };
- Cea708Stream.prototype.extendedCommands = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- if (within708TextBlock(b)) {
- i2 = this.handleText(i2, service, {
- isExtended: true
- });
- }
- return i2;
- };
- Cea708Stream.prototype.getPts = function(byteIndex) {
- return this.current708Packet.ptsVals[Math.floor(byteIndex / 2)];
- };
- Cea708Stream.prototype.initService = function(serviceNum, i2) {
- var serviceName = "SERVICE" + serviceNum;
- var self2 = this;
- var serviceName;
- var encoding;
- if (serviceName in this.serviceEncodings) {
- encoding = this.serviceEncodings[serviceName];
- }
- this.services[serviceNum] = new Cea708Service(serviceNum, encoding, self2);
- this.services[serviceNum].init(this.getPts(i2), function(pts) {
- self2.flushDisplayed(pts, self2.services[serviceNum]);
- });
- return this.services[serviceNum];
- };
- Cea708Stream.prototype.handleText = function(i2, service, options2) {
- var isExtended = options2 && options2.isExtended;
- var isMultiByte = options2 && options2.isMultiByte;
- var packetData = this.current708Packet.data;
- var extended = isExtended ? 4096 : 0;
- var currentByte = packetData[i2];
- var nextByte = packetData[i2 + 1];
- var win3 = service.currentWindow;
- var _char;
- var charCodeArray;
- if (service.textDecoder_ && !isExtended) {
- if (isMultiByte) {
- charCodeArray = [currentByte, nextByte];
- i2++;
- } else {
- charCodeArray = [currentByte];
- }
- _char = service.textDecoder_.decode(new Uint8Array(charCodeArray));
- } else {
- _char = get708CharFromCode(extended | currentByte);
- }
- if (win3.pendingNewLine && !win3.isEmpty()) {
- win3.newLine(this.getPts(i2));
- }
- win3.pendingNewLine = false;
- win3.addText(_char);
- return i2;
- };
- Cea708Stream.prototype.multiByteCharacter = function(i2, service) {
- var packetData = this.current708Packet.data;
- var firstByte = packetData[i2 + 1];
- var secondByte = packetData[i2 + 2];
- if (within708TextBlock(firstByte) && within708TextBlock(secondByte)) {
- i2 = this.handleText(++i2, service, {
- isMultiByte: true
- });
- }
- return i2;
- };
- Cea708Stream.prototype.setCurrentWindow = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var windowNum = b & 7;
- service.setCurrentWindow(windowNum);
- return i2;
- };
- Cea708Stream.prototype.defineWindow = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var windowNum = b & 7;
- service.setCurrentWindow(windowNum);
- var win3 = service.currentWindow;
- b = packetData[++i2];
- win3.visible = (b & 32) >> 5;
- win3.rowLock = (b & 16) >> 4;
- win3.columnLock = (b & 8) >> 3;
- win3.priority = b & 7;
- b = packetData[++i2];
- win3.relativePositioning = (b & 128) >> 7;
- win3.anchorVertical = b & 127;
- b = packetData[++i2];
- win3.anchorHorizontal = b;
- b = packetData[++i2];
- win3.anchorPoint = (b & 240) >> 4;
- win3.rowCount = b & 15;
- b = packetData[++i2];
- win3.columnCount = b & 63;
- b = packetData[++i2];
- win3.windowStyle = (b & 56) >> 3;
- win3.penStyle = b & 7;
- win3.virtualRowCount = win3.rowCount + 1;
- return i2;
- };
- Cea708Stream.prototype.setWindowAttributes = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var winAttr = service.currentWindow.winAttr;
- b = packetData[++i2];
- winAttr.fillOpacity = (b & 192) >> 6;
- winAttr.fillRed = (b & 48) >> 4;
- winAttr.fillGreen = (b & 12) >> 2;
- winAttr.fillBlue = b & 3;
- b = packetData[++i2];
- winAttr.borderType = (b & 192) >> 6;
- winAttr.borderRed = (b & 48) >> 4;
- winAttr.borderGreen = (b & 12) >> 2;
- winAttr.borderBlue = b & 3;
- b = packetData[++i2];
- winAttr.borderType += (b & 128) >> 5;
- winAttr.wordWrap = (b & 64) >> 6;
- winAttr.printDirection = (b & 48) >> 4;
- winAttr.scrollDirection = (b & 12) >> 2;
- winAttr.justify = b & 3;
- b = packetData[++i2];
- winAttr.effectSpeed = (b & 240) >> 4;
- winAttr.effectDirection = (b & 12) >> 2;
- winAttr.displayEffect = b & 3;
- return i2;
- };
- Cea708Stream.prototype.flushDisplayed = function(pts, service) {
- var displayedText = [];
- for (var winId = 0; winId < 8; winId++) {
- if (service.windows[winId].visible && !service.windows[winId].isEmpty()) {
- displayedText.push(service.windows[winId].getText());
- }
- }
- service.endPts = pts;
- service.text = displayedText.join("\n\n");
- this.pushCaption(service);
- service.startPts = pts;
- };
- Cea708Stream.prototype.pushCaption = function(service) {
- if (service.text !== "") {
- this.trigger("data", {
- startPts: service.startPts,
- endPts: service.endPts,
- text: service.text,
- stream: "cc708_" + service.serviceNum
- });
- service.text = "";
- service.startPts = service.endPts;
- }
- };
- Cea708Stream.prototype.displayWindows = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- for (var winId = 0; winId < 8; winId++) {
- if (b & 1 << winId) {
- service.windows[winId].visible = 1;
- }
- }
- return i2;
- };
- Cea708Stream.prototype.hideWindows = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- for (var winId = 0; winId < 8; winId++) {
- if (b & 1 << winId) {
- service.windows[winId].visible = 0;
- }
- }
- return i2;
- };
- Cea708Stream.prototype.toggleWindows = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- for (var winId = 0; winId < 8; winId++) {
- if (b & 1 << winId) {
- service.windows[winId].visible ^= 1;
- }
- }
- return i2;
- };
- Cea708Stream.prototype.clearWindows = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- for (var winId = 0; winId < 8; winId++) {
- if (b & 1 << winId) {
- service.windows[winId].clearText();
- }
- }
- return i2;
- };
- Cea708Stream.prototype.deleteWindows = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[++i2];
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- for (var winId = 0; winId < 8; winId++) {
- if (b & 1 << winId) {
- service.windows[winId].reset();
- }
- }
- return i2;
- };
- Cea708Stream.prototype.setPenAttributes = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var penAttr = service.currentWindow.penAttr;
- b = packetData[++i2];
- penAttr.textTag = (b & 240) >> 4;
- penAttr.offset = (b & 12) >> 2;
- penAttr.penSize = b & 3;
- b = packetData[++i2];
- penAttr.italics = (b & 128) >> 7;
- penAttr.underline = (b & 64) >> 6;
- penAttr.edgeType = (b & 56) >> 3;
- penAttr.fontStyle = b & 7;
- return i2;
- };
- Cea708Stream.prototype.setPenColor = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var penColor = service.currentWindow.penColor;
- b = packetData[++i2];
- penColor.fgOpacity = (b & 192) >> 6;
- penColor.fgRed = (b & 48) >> 4;
- penColor.fgGreen = (b & 12) >> 2;
- penColor.fgBlue = b & 3;
- b = packetData[++i2];
- penColor.bgOpacity = (b & 192) >> 6;
- penColor.bgRed = (b & 48) >> 4;
- penColor.bgGreen = (b & 12) >> 2;
- penColor.bgBlue = b & 3;
- b = packetData[++i2];
- penColor.edgeRed = (b & 48) >> 4;
- penColor.edgeGreen = (b & 12) >> 2;
- penColor.edgeBlue = b & 3;
- return i2;
- };
- Cea708Stream.prototype.setPenLocation = function(i2, service) {
- var packetData = this.current708Packet.data;
- var b = packetData[i2];
- var penLoc = service.currentWindow.penLoc;
- service.currentWindow.pendingNewLine = true;
- b = packetData[++i2];
- penLoc.row = b & 15;
- b = packetData[++i2];
- penLoc.column = b & 63;
- return i2;
- };
- Cea708Stream.prototype.reset = function(i2, service) {
- var pts = this.getPts(i2);
- this.flushDisplayed(pts, service);
- return this.initService(service.serviceNum, i2);
- };
- var CHARACTER_TRANSLATION = {
- 42: 225,
- 92: 233,
- 94: 237,
- 95: 243,
- 96: 250,
- 123: 231,
- 124: 247,
- 125: 209,
- 126: 241,
- 127: 9608,
- 304: 174,
- 305: 176,
- 306: 189,
- 307: 191,
- 308: 8482,
- 309: 162,
- 310: 163,
- 311: 9834,
- 312: 224,
- 313: 160,
- 314: 232,
- 315: 226,
- 316: 234,
- 317: 238,
- 318: 244,
- 319: 251,
- 544: 193,
- 545: 201,
- 546: 211,
- 547: 218,
- 548: 220,
- 549: 252,
- 550: 8216,
- 551: 161,
- 552: 42,
- 553: 39,
- 554: 8212,
- 555: 169,
- 556: 8480,
- 557: 8226,
- 558: 8220,
- 559: 8221,
- 560: 192,
- 561: 194,
- 562: 199,
- 563: 200,
- 564: 202,
- 565: 203,
- 566: 235,
- 567: 206,
- 568: 207,
- 569: 239,
- 570: 212,
- 571: 217,
- 572: 249,
- 573: 219,
- 574: 171,
- 575: 187,
- 800: 195,
- 801: 227,
- 802: 205,
- 803: 204,
- 804: 236,
- 805: 210,
- 806: 242,
- 807: 213,
- 808: 245,
- 809: 123,
- 810: 125,
- 811: 92,
- 812: 94,
- 813: 95,
- 814: 124,
- 815: 126,
- 816: 196,
- 817: 228,
- 818: 214,
- 819: 246,
- 820: 223,
- 821: 165,
- 822: 164,
- 823: 9474,
- 824: 197,
- 825: 229,
- 826: 216,
- 827: 248,
- 828: 9484,
- 829: 9488,
- 830: 9492,
- 831: 9496
- };
- var getCharFromCode = function getCharFromCode2(code) {
- if (code === null) {
- return "";
- }
- code = CHARACTER_TRANSLATION[code] || code;
- return String.fromCharCode(code);
- };
- var BOTTOM_ROW = 14;
- var ROWS = [4352, 4384, 4608, 4640, 5376, 5408, 5632, 5664, 5888, 5920, 4096, 4864, 4896, 5120, 5152];
- var createDisplayBuffer = function createDisplayBuffer2() {
- var result = [], i2 = BOTTOM_ROW + 1;
- while (i2--) {
- result.push("");
- }
- return result;
- };
- var Cea608Stream = function Cea608Stream2(field, dataChannel) {
- Cea608Stream2.prototype.init.call(this);
- this.field_ = field || 0;
- this.dataChannel_ = dataChannel || 0;
- this.name_ = "CC" + ((this.field_ << 1 | this.dataChannel_) + 1);
- this.setConstants();
- this.reset();
- this.push = function(packet) {
- var data, swap, char0, char1, text;
- data = packet.ccData & 32639;
- if (data === this.lastControlCode_) {
- this.lastControlCode_ = null;
- return;
- }
- if ((data & 61440) === 4096) {
- this.lastControlCode_ = data;
- } else if (data !== this.PADDING_) {
- this.lastControlCode_ = null;
- }
- char0 = data >>> 8;
- char1 = data & 255;
- if (data === this.PADDING_) {
- return;
- } else if (data === this.RESUME_CAPTION_LOADING_) {
- this.mode_ = "popOn";
- } else if (data === this.END_OF_CAPTION_) {
- this.mode_ = "popOn";
- this.clearFormatting(packet.pts);
- this.flushDisplayed(packet.pts);
- swap = this.displayed_;
- this.displayed_ = this.nonDisplayed_;
- this.nonDisplayed_ = swap;
- this.startPts_ = packet.pts;
- } else if (data === this.ROLL_UP_2_ROWS_) {
- this.rollUpRows_ = 2;
- this.setRollUp(packet.pts);
- } else if (data === this.ROLL_UP_3_ROWS_) {
- this.rollUpRows_ = 3;
- this.setRollUp(packet.pts);
- } else if (data === this.ROLL_UP_4_ROWS_) {
- this.rollUpRows_ = 4;
- this.setRollUp(packet.pts);
- } else if (data === this.CARRIAGE_RETURN_) {
- this.clearFormatting(packet.pts);
- this.flushDisplayed(packet.pts);
- this.shiftRowsUp_();
- this.startPts_ = packet.pts;
- } else if (data === this.BACKSPACE_) {
- if (this.mode_ === "popOn") {
- this.nonDisplayed_[this.row_] = this.nonDisplayed_[this.row_].slice(0, -1);
- } else {
- this.displayed_[this.row_] = this.displayed_[this.row_].slice(0, -1);
- }
- } else if (data === this.ERASE_DISPLAYED_MEMORY_) {
- this.flushDisplayed(packet.pts);
- this.displayed_ = createDisplayBuffer();
- } else if (data === this.ERASE_NON_DISPLAYED_MEMORY_) {
- this.nonDisplayed_ = createDisplayBuffer();
- } else if (data === this.RESUME_DIRECT_CAPTIONING_) {
- if (this.mode_ !== "paintOn") {
- this.flushDisplayed(packet.pts);
- this.displayed_ = createDisplayBuffer();
- }
- this.mode_ = "paintOn";
- this.startPts_ = packet.pts;
- } else if (this.isSpecialCharacter(char0, char1)) {
- char0 = (char0 & 3) << 8;
- text = getCharFromCode(char0 | char1);
- this[this.mode_](packet.pts, text);
- this.column_++;
- } else if (this.isExtCharacter(char0, char1)) {
- if (this.mode_ === "popOn") {
- this.nonDisplayed_[this.row_] = this.nonDisplayed_[this.row_].slice(0, -1);
- } else {
- this.displayed_[this.row_] = this.displayed_[this.row_].slice(0, -1);
- }
- char0 = (char0 & 3) << 8;
- text = getCharFromCode(char0 | char1);
- this[this.mode_](packet.pts, text);
- this.column_++;
- } else if (this.isMidRowCode(char0, char1)) {
- this.clearFormatting(packet.pts);
- this[this.mode_](packet.pts, " ");
- this.column_++;
- if ((char1 & 14) === 14) {
- this.addFormatting(packet.pts, ["i"]);
- }
- if ((char1 & 1) === 1) {
- this.addFormatting(packet.pts, ["u"]);
- }
- } else if (this.isOffsetControlCode(char0, char1)) {
- this.column_ += char1 & 3;
- } else if (this.isPAC(char0, char1)) {
- var row = ROWS.indexOf(data & 7968);
- if (this.mode_ === "rollUp") {
- if (row - this.rollUpRows_ + 1 < 0) {
- row = this.rollUpRows_ - 1;
- }
- this.setRollUp(packet.pts, row);
- }
- if (row !== this.row_) {
- this.clearFormatting(packet.pts);
- this.row_ = row;
- }
- if (char1 & 1 && this.formatting_.indexOf("u") === -1) {
- this.addFormatting(packet.pts, ["u"]);
- }
- if ((data & 16) === 16) {
- this.column_ = ((data & 14) >> 1) * 4;
- }
- if (this.isColorPAC(char1)) {
- if ((char1 & 14) === 14) {
- this.addFormatting(packet.pts, ["i"]);
- }
- }
- } else if (this.isNormalChar(char0)) {
- if (char1 === 0) {
- char1 = null;
- }
- text = getCharFromCode(char0);
- text += getCharFromCode(char1);
- this[this.mode_](packet.pts, text);
- this.column_ += text.length;
- }
- };
- };
- Cea608Stream.prototype = new stream();
- Cea608Stream.prototype.flushDisplayed = function(pts) {
- var content = this.displayed_.map(function(row, index2) {
- try {
- return row.trim();
- } catch (e) {
- this.trigger("log", {
- level: "warn",
- message: "Skipping a malformed 608 caption at index " + index2 + "."
- });
- return "";
- }
- }, this).join("\n").replace(/^\n+|\n+$/g, "");
- if (content.length) {
- this.trigger("data", {
- startPts: this.startPts_,
- endPts: pts,
- text: content,
- stream: this.name_
- });
- }
- };
- Cea608Stream.prototype.reset = function() {
- this.mode_ = "popOn";
- this.topRow_ = 0;
- this.startPts_ = 0;
- this.displayed_ = createDisplayBuffer();
- this.nonDisplayed_ = createDisplayBuffer();
- this.lastControlCode_ = null;
- this.column_ = 0;
- this.row_ = BOTTOM_ROW;
- this.rollUpRows_ = 2;
- this.formatting_ = [];
- };
- Cea608Stream.prototype.setConstants = function() {
- if (this.dataChannel_ === 0) {
- this.BASE_ = 16;
- this.EXT_ = 17;
- this.CONTROL_ = (20 | this.field_) << 8;
- this.OFFSET_ = 23;
- } else if (this.dataChannel_ === 1) {
- this.BASE_ = 24;
- this.EXT_ = 25;
- this.CONTROL_ = (28 | this.field_) << 8;
- this.OFFSET_ = 31;
- }
- this.PADDING_ = 0;
- this.RESUME_CAPTION_LOADING_ = this.CONTROL_ | 32;
- this.END_OF_CAPTION_ = this.CONTROL_ | 47;
- this.ROLL_UP_2_ROWS_ = this.CONTROL_ | 37;
- this.ROLL_UP_3_ROWS_ = this.CONTROL_ | 38;
- this.ROLL_UP_4_ROWS_ = this.CONTROL_ | 39;
- this.CARRIAGE_RETURN_ = this.CONTROL_ | 45;
- this.RESUME_DIRECT_CAPTIONING_ = this.CONTROL_ | 41;
- this.BACKSPACE_ = this.CONTROL_ | 33;
- this.ERASE_DISPLAYED_MEMORY_ = this.CONTROL_ | 44;
- this.ERASE_NON_DISPLAYED_MEMORY_ = this.CONTROL_ | 46;
- };
- Cea608Stream.prototype.isSpecialCharacter = function(char0, char1) {
- return char0 === this.EXT_ && char1 >= 48 && char1 <= 63;
- };
- Cea608Stream.prototype.isExtCharacter = function(char0, char1) {
- return (char0 === this.EXT_ + 1 || char0 === this.EXT_ + 2) && char1 >= 32 && char1 <= 63;
- };
- Cea608Stream.prototype.isMidRowCode = function(char0, char1) {
- return char0 === this.EXT_ && char1 >= 32 && char1 <= 47;
- };
- Cea608Stream.prototype.isOffsetControlCode = function(char0, char1) {
- return char0 === this.OFFSET_ && char1 >= 33 && char1 <= 35;
- };
- Cea608Stream.prototype.isPAC = function(char0, char1) {
- return char0 >= this.BASE_ && char0 < this.BASE_ + 8 && char1 >= 64 && char1 <= 127;
- };
- Cea608Stream.prototype.isColorPAC = function(char1) {
- return char1 >= 64 && char1 <= 79 || char1 >= 96 && char1 <= 127;
- };
- Cea608Stream.prototype.isNormalChar = function(_char2) {
- return _char2 >= 32 && _char2 <= 127;
- };
- Cea608Stream.prototype.setRollUp = function(pts, newBaseRow) {
- if (this.mode_ !== "rollUp") {
- this.row_ = BOTTOM_ROW;
- this.mode_ = "rollUp";
- this.flushDisplayed(pts);
- this.nonDisplayed_ = createDisplayBuffer();
- this.displayed_ = createDisplayBuffer();
- }
- if (newBaseRow !== void 0 && newBaseRow !== this.row_) {
- for (var i2 = 0; i2 < this.rollUpRows_; i2++) {
- this.displayed_[newBaseRow - i2] = this.displayed_[this.row_ - i2];
- this.displayed_[this.row_ - i2] = "";
- }
- }
- if (newBaseRow === void 0) {
- newBaseRow = this.row_;
- }
- this.topRow_ = newBaseRow - this.rollUpRows_ + 1;
- };
- Cea608Stream.prototype.addFormatting = function(pts, format) {
- this.formatting_ = this.formatting_.concat(format);
- var text = format.reduce(function(text2, format2) {
- return text2 + "<" + format2 + ">";
- }, "");
- this[this.mode_](pts, text);
- };
- Cea608Stream.prototype.clearFormatting = function(pts) {
- if (!this.formatting_.length) {
- return;
- }
- var text = this.formatting_.reverse().reduce(function(text2, format) {
- return text2 + "</" + format + ">";
- }, "");
- this.formatting_ = [];
- this[this.mode_](pts, text);
- };
- Cea608Stream.prototype.popOn = function(pts, text) {
- var baseRow = this.nonDisplayed_[this.row_];
- baseRow += text;
- this.nonDisplayed_[this.row_] = baseRow;
- };
- Cea608Stream.prototype.rollUp = function(pts, text) {
- var baseRow = this.displayed_[this.row_];
- baseRow += text;
- this.displayed_[this.row_] = baseRow;
- };
- Cea608Stream.prototype.shiftRowsUp_ = function() {
- var i2;
- for (i2 = 0; i2 < this.topRow_; i2++) {
- this.displayed_[i2] = "";
- }
- for (i2 = this.row_ + 1; i2 < BOTTOM_ROW + 1; i2++) {
- this.displayed_[i2] = "";
- }
- for (i2 = this.topRow_; i2 < this.row_; i2++) {
- this.displayed_[i2] = this.displayed_[i2 + 1];
- }
- this.displayed_[this.row_] = "";
- };
- Cea608Stream.prototype.paintOn = function(pts, text) {
- var baseRow = this.displayed_[this.row_];
- baseRow += text;
- this.displayed_[this.row_] = baseRow;
- };
- var captionStream = {
- CaptionStream: CaptionStream$1,
- Cea608Stream,
- Cea708Stream
- };
- var streamTypes = {
- H264_STREAM_TYPE: 27,
- ADTS_STREAM_TYPE: 15,
- METADATA_STREAM_TYPE: 21
- };
- var MAX_TS = 8589934592;
- var RO_THRESH = 4294967296;
- var TYPE_SHARED = "shared";
- var handleRollover$1 = function handleRollover2(value, reference) {
- var direction = 1;
- if (value > reference) {
- direction = -1;
- }
- while (Math.abs(reference - value) > RO_THRESH) {
- value += direction * MAX_TS;
- }
- return value;
- };
- var TimestampRolloverStream$1 = function TimestampRolloverStream2(type3) {
- var lastDTS, referenceDTS;
- TimestampRolloverStream2.prototype.init.call(this);
- this.type_ = type3 || TYPE_SHARED;
- this.push = function(data) {
- if (this.type_ !== TYPE_SHARED && data.type !== this.type_) {
- return;
- }
- if (referenceDTS === void 0) {
- referenceDTS = data.dts;
- }
- data.dts = handleRollover$1(data.dts, referenceDTS);
- data.pts = handleRollover$1(data.pts, referenceDTS);
- lastDTS = data.dts;
- this.trigger("data", data);
- };
- this.flush = function() {
- referenceDTS = lastDTS;
- this.trigger("done");
- };
- this.endTimeline = function() {
- this.flush();
- this.trigger("endedtimeline");
- };
- this.discontinuity = function() {
- referenceDTS = void 0;
- lastDTS = void 0;
- };
- this.reset = function() {
- this.discontinuity();
- this.trigger("reset");
- };
- };
- TimestampRolloverStream$1.prototype = new stream();
- var timestampRolloverStream = {
- TimestampRolloverStream: TimestampRolloverStream$1,
- handleRollover: handleRollover$1
- };
- var percentEncode$1 = function percentEncode2(bytes, start2, end) {
- var i2, result = "";
- for (i2 = start2; i2 < end; i2++) {
- result += "%" + ("00" + bytes[i2].toString(16)).slice(-2);
- }
- return result;
- }, parseUtf8 = function parseUtf82(bytes, start2, end) {
- return decodeURIComponent(percentEncode$1(bytes, start2, end));
- }, parseIso88591$1 = function parseIso885912(bytes, start2, end) {
- return unescape(percentEncode$1(bytes, start2, end));
- }, parseSyncSafeInteger$1 = function parseSyncSafeInteger2(data) {
- return data[0] << 21 | data[1] << 14 | data[2] << 7 | data[3];
- }, tagParsers = {
- TXXX: function TXXX(tag) {
- var i2;
- if (tag.data[0] !== 3) {
- return;
- }
- for (i2 = 1; i2 < tag.data.length; i2++) {
- if (tag.data[i2] === 0) {
- tag.description = parseUtf8(tag.data, 1, i2);
- tag.value = parseUtf8(tag.data, i2 + 1, tag.data.length).replace(/\0*$/, "");
- break;
- }
- }
- tag.data = tag.value;
- },
- WXXX: function WXXX(tag) {
- var i2;
- if (tag.data[0] !== 3) {
- return;
- }
- for (i2 = 1; i2 < tag.data.length; i2++) {
- if (tag.data[i2] === 0) {
- tag.description = parseUtf8(tag.data, 1, i2);
- tag.url = parseUtf8(tag.data, i2 + 1, tag.data.length);
- break;
- }
- }
- },
- PRIV: function PRIV(tag) {
- var i2;
- for (i2 = 0; i2 < tag.data.length; i2++) {
- if (tag.data[i2] === 0) {
- tag.owner = parseIso88591$1(tag.data, 0, i2);
- break;
- }
- }
- tag.privateData = tag.data.subarray(i2 + 1);
- tag.data = tag.privateData;
- }
- }, _MetadataStream;
- _MetadataStream = function MetadataStream(options2) {
- var settings = {
- descriptor: options2 && options2.descriptor
- }, tagSize = 0, buffer = [], bufferSize = 0, i2;
- _MetadataStream.prototype.init.call(this);
- this.dispatchType = streamTypes.METADATA_STREAM_TYPE.toString(16);
- if (settings.descriptor) {
- for (i2 = 0; i2 < settings.descriptor.length; i2++) {
- this.dispatchType += ("00" + settings.descriptor[i2].toString(16)).slice(-2);
- }
- }
- this.push = function(chunk) {
- var tag, frameStart, frameSize, frame, i3, frameHeader;
- if (chunk.type !== "timed-metadata") {
- return;
- }
- if (chunk.dataAlignmentIndicator) {
- bufferSize = 0;
- buffer.length = 0;
- }
- if (buffer.length === 0 && (chunk.data.length < 10 || chunk.data[0] !== "I".charCodeAt(0) || chunk.data[1] !== "D".charCodeAt(0) || chunk.data[2] !== "3".charCodeAt(0))) {
- this.trigger("log", {
- level: "warn",
- message: "Skipping unrecognized metadata packet"
- });
- return;
- }
- buffer.push(chunk);
- bufferSize += chunk.data.byteLength;
- if (buffer.length === 1) {
- tagSize = parseSyncSafeInteger$1(chunk.data.subarray(6, 10));
- tagSize += 10;
- }
- if (bufferSize < tagSize) {
- return;
- }
- tag = {
- data: new Uint8Array(tagSize),
- frames: [],
- pts: buffer[0].pts,
- dts: buffer[0].dts
- };
- for (i3 = 0; i3 < tagSize; ) {
- tag.data.set(buffer[0].data.subarray(0, tagSize - i3), i3);
- i3 += buffer[0].data.byteLength;
- bufferSize -= buffer[0].data.byteLength;
- buffer.shift();
- }
- frameStart = 10;
- if (tag.data[5] & 64) {
- frameStart += 4;
- frameStart += parseSyncSafeInteger$1(tag.data.subarray(10, 14));
- tagSize -= parseSyncSafeInteger$1(tag.data.subarray(16, 20));
- }
- do {
- frameSize = parseSyncSafeInteger$1(tag.data.subarray(frameStart + 4, frameStart + 8));
- if (frameSize < 1) {
- this.trigger("log", {
- level: "warn",
- message: "Malformed ID3 frame encountered. Skipping metadata parsing."
- });
- return;
- }
- frameHeader = String.fromCharCode(tag.data[frameStart], tag.data[frameStart + 1], tag.data[frameStart + 2], tag.data[frameStart + 3]);
- frame = {
- id: frameHeader,
- data: tag.data.subarray(frameStart + 10, frameStart + frameSize + 10)
- };
- frame.key = frame.id;
- if (tagParsers[frame.id]) {
- tagParsers[frame.id](frame);
- if (frame.owner === "com.apple.streaming.transportStreamTimestamp") {
- var d2 = frame.data, size = (d2[3] & 1) << 30 | d2[4] << 22 | d2[5] << 14 | d2[6] << 6 | d2[7] >>> 2;
- size *= 4;
- size += d2[7] & 3;
- frame.timeStamp = size;
- if (tag.pts === void 0 && tag.dts === void 0) {
- tag.pts = frame.timeStamp;
- tag.dts = frame.timeStamp;
- }
- this.trigger("timestamp", frame);
- }
- }
- tag.frames.push(frame);
- frameStart += 10;
- frameStart += frameSize;
- } while (frameStart < tagSize);
- this.trigger("data", tag);
- };
- };
- _MetadataStream.prototype = new stream();
- var metadataStream = _MetadataStream;
- var TimestampRolloverStream = timestampRolloverStream.TimestampRolloverStream;
- var _TransportPacketStream, _TransportParseStream, _ElementaryStream;
- var MP2T_PACKET_LENGTH$1 = 188, SYNC_BYTE$1 = 71;
- _TransportPacketStream = function TransportPacketStream() {
- var buffer = new Uint8Array(MP2T_PACKET_LENGTH$1), bytesInBuffer = 0;
- _TransportPacketStream.prototype.init.call(this);
- this.push = function(bytes) {
- var startIndex = 0, endIndex = MP2T_PACKET_LENGTH$1, everything;
- if (bytesInBuffer) {
- everything = new Uint8Array(bytes.byteLength + bytesInBuffer);
- everything.set(buffer.subarray(0, bytesInBuffer));
- everything.set(bytes, bytesInBuffer);
- bytesInBuffer = 0;
- } else {
- everything = bytes;
- }
- while (endIndex < everything.byteLength) {
- if (everything[startIndex] === SYNC_BYTE$1 && everything[endIndex] === SYNC_BYTE$1) {
- this.trigger("data", everything.subarray(startIndex, endIndex));
- startIndex += MP2T_PACKET_LENGTH$1;
- endIndex += MP2T_PACKET_LENGTH$1;
- continue;
- }
- startIndex++;
- endIndex++;
- }
- if (startIndex < everything.byteLength) {
- buffer.set(everything.subarray(startIndex), 0);
- bytesInBuffer = everything.byteLength - startIndex;
- }
- };
- this.flush = function() {
- if (bytesInBuffer === MP2T_PACKET_LENGTH$1 && buffer[0] === SYNC_BYTE$1) {
- this.trigger("data", buffer);
- bytesInBuffer = 0;
- }
- this.trigger("done");
- };
- this.endTimeline = function() {
- this.flush();
- this.trigger("endedtimeline");
- };
- this.reset = function() {
- bytesInBuffer = 0;
- this.trigger("reset");
- };
- };
- _TransportPacketStream.prototype = new stream();
- _TransportParseStream = function TransportParseStream() {
- var parsePsi, parsePat2, parsePmt2, self2;
- _TransportParseStream.prototype.init.call(this);
- self2 = this;
- this.packetsWaitingForPmt = [];
- this.programMapTable = void 0;
- parsePsi = function parsePsi2(payload, psi) {
- var offset = 0;
- if (psi.payloadUnitStartIndicator) {
- offset += payload[offset] + 1;
- }
- if (psi.type === "pat") {
- parsePat2(payload.subarray(offset), psi);
- } else {
- parsePmt2(payload.subarray(offset), psi);
- }
- };
- parsePat2 = function parsePat3(payload, pat) {
- pat.section_number = payload[7];
- pat.last_section_number = payload[8];
- self2.pmtPid = (payload[10] & 31) << 8 | payload[11];
- pat.pmtPid = self2.pmtPid;
- };
- parsePmt2 = function parsePmt3(payload, pmt) {
- var sectionLength, tableEnd, programInfoLength, offset;
- if (!(payload[5] & 1)) {
- return;
- }
- self2.programMapTable = {
- video: null,
- audio: null,
- "timed-metadata": {}
- };
- sectionLength = (payload[1] & 15) << 8 | payload[2];
- tableEnd = 3 + sectionLength - 4;
- programInfoLength = (payload[10] & 15) << 8 | payload[11];
- offset = 12 + programInfoLength;
- while (offset < tableEnd) {
- var streamType = payload[offset];
- var pid = (payload[offset + 1] & 31) << 8 | payload[offset + 2];
- if (streamType === streamTypes.H264_STREAM_TYPE && self2.programMapTable.video === null) {
- self2.programMapTable.video = pid;
- } else if (streamType === streamTypes.ADTS_STREAM_TYPE && self2.programMapTable.audio === null) {
- self2.programMapTable.audio = pid;
- } else if (streamType === streamTypes.METADATA_STREAM_TYPE) {
- self2.programMapTable["timed-metadata"][pid] = streamType;
- }
- offset += ((payload[offset + 3] & 15) << 8 | payload[offset + 4]) + 5;
- }
- pmt.programMapTable = self2.programMapTable;
- };
- this.push = function(packet) {
- var result = {}, offset = 4;
- result.payloadUnitStartIndicator = !!(packet[1] & 64);
- result.pid = packet[1] & 31;
- result.pid <<= 8;
- result.pid |= packet[2];
- if ((packet[3] & 48) >>> 4 > 1) {
- offset += packet[offset] + 1;
- }
- if (result.pid === 0) {
- result.type = "pat";
- parsePsi(packet.subarray(offset), result);
- this.trigger("data", result);
- } else if (result.pid === this.pmtPid) {
- result.type = "pmt";
- parsePsi(packet.subarray(offset), result);
- this.trigger("data", result);
- while (this.packetsWaitingForPmt.length) {
- this.processPes_.apply(this, this.packetsWaitingForPmt.shift());
- }
- } else if (this.programMapTable === void 0) {
- this.packetsWaitingForPmt.push([packet, offset, result]);
- } else {
- this.processPes_(packet, offset, result);
- }
- };
- this.processPes_ = function(packet, offset, result) {
- if (result.pid === this.programMapTable.video) {
- result.streamType = streamTypes.H264_STREAM_TYPE;
- } else if (result.pid === this.programMapTable.audio) {
- result.streamType = streamTypes.ADTS_STREAM_TYPE;
- } else {
- result.streamType = this.programMapTable["timed-metadata"][result.pid];
- }
- result.type = "pes";
- result.data = packet.subarray(offset);
- this.trigger("data", result);
- };
- };
- _TransportParseStream.prototype = new stream();
- _TransportParseStream.STREAM_TYPES = {
- h264: 27,
- adts: 15
- };
- _ElementaryStream = function ElementaryStream() {
- var self2 = this, segmentHadPmt = false, video = {
- data: [],
- size: 0
- }, audio = {
- data: [],
- size: 0
- }, timedMetadata = {
- data: [],
- size: 0
- }, programMapTable, parsePes = function parsePes2(payload, pes) {
- var ptsDtsFlags;
- var startPrefix = payload[0] << 16 | payload[1] << 8 | payload[2];
- pes.data = new Uint8Array();
- if (startPrefix !== 1) {
- return;
- }
- pes.packetLength = 6 + (payload[4] << 8 | payload[5]);
- pes.dataAlignmentIndicator = (payload[6] & 4) !== 0;
- ptsDtsFlags = payload[7];
- if (ptsDtsFlags & 192) {
- pes.pts = (payload[9] & 14) << 27 | (payload[10] & 255) << 20 | (payload[11] & 254) << 12 | (payload[12] & 255) << 5 | (payload[13] & 254) >>> 3;
- pes.pts *= 4;
- pes.pts += (payload[13] & 6) >>> 1;
- pes.dts = pes.pts;
- if (ptsDtsFlags & 64) {
- pes.dts = (payload[14] & 14) << 27 | (payload[15] & 255) << 20 | (payload[16] & 254) << 12 | (payload[17] & 255) << 5 | (payload[18] & 254) >>> 3;
- pes.dts *= 4;
- pes.dts += (payload[18] & 6) >>> 1;
- }
- }
- pes.data = payload.subarray(9 + payload[8]);
- }, flushStream = function flushStream2(stream2, type3, forceFlush) {
- var packetData = new Uint8Array(stream2.size), event2 = {
- type: type3
- }, i2 = 0, offset = 0, packetFlushable = false, fragment;
- if (!stream2.data.length || stream2.size < 9) {
- return;
- }
- event2.trackId = stream2.data[0].pid;
- for (i2 = 0; i2 < stream2.data.length; i2++) {
- fragment = stream2.data[i2];
- packetData.set(fragment.data, offset);
- offset += fragment.data.byteLength;
- }
- parsePes(packetData, event2);
- packetFlushable = type3 === "video" || event2.packetLength <= stream2.size;
- if (forceFlush || packetFlushable) {
- stream2.size = 0;
- stream2.data.length = 0;
- }
- if (packetFlushable) {
- self2.trigger("data", event2);
- }
- };
- _ElementaryStream.prototype.init.call(this);
- this.push = function(data) {
- ({
- pat: function pat() {
- },
- pes: function pes() {
- var stream2, streamType;
- switch (data.streamType) {
- case streamTypes.H264_STREAM_TYPE:
- stream2 = video;
- streamType = "video";
- break;
- case streamTypes.ADTS_STREAM_TYPE:
- stream2 = audio;
- streamType = "audio";
- break;
- case streamTypes.METADATA_STREAM_TYPE:
- stream2 = timedMetadata;
- streamType = "timed-metadata";
- break;
- default:
- return;
- }
- if (data.payloadUnitStartIndicator) {
- flushStream(stream2, streamType, true);
- }
- stream2.data.push(data);
- stream2.size += data.data.byteLength;
- },
- pmt: function pmt() {
- var event2 = {
- type: "metadata",
- tracks: []
- };
- programMapTable = data.programMapTable;
- if (programMapTable.video !== null) {
- event2.tracks.push({
- timelineStartInfo: {
- baseMediaDecodeTime: 0
- },
- id: +programMapTable.video,
- codec: "avc",
- type: "video"
- });
- }
- if (programMapTable.audio !== null) {
- event2.tracks.push({
- timelineStartInfo: {
- baseMediaDecodeTime: 0
- },
- id: +programMapTable.audio,
- codec: "adts",
- type: "audio"
- });
- }
- segmentHadPmt = true;
- self2.trigger("data", event2);
- }
- })[data.type]();
- };
- this.reset = function() {
- video.size = 0;
- video.data.length = 0;
- audio.size = 0;
- audio.data.length = 0;
- this.trigger("reset");
- };
- this.flushStreams_ = function() {
- flushStream(video, "video");
- flushStream(audio, "audio");
- flushStream(timedMetadata, "timed-metadata");
- };
- this.flush = function() {
- if (!segmentHadPmt && programMapTable) {
- var pmt = {
- type: "metadata",
- tracks: []
- };
- if (programMapTable.video !== null) {
- pmt.tracks.push({
- timelineStartInfo: {
- baseMediaDecodeTime: 0
- },
- id: +programMapTable.video,
- codec: "avc",
- type: "video"
- });
- }
- if (programMapTable.audio !== null) {
- pmt.tracks.push({
- timelineStartInfo: {
- baseMediaDecodeTime: 0
- },
- id: +programMapTable.audio,
- codec: "adts",
- type: "audio"
- });
- }
- self2.trigger("data", pmt);
- }
- segmentHadPmt = false;
- this.flushStreams_();
- this.trigger("done");
- };
- };
- _ElementaryStream.prototype = new stream();
- var m2ts = {
- PAT_PID: 0,
- MP2T_PACKET_LENGTH: MP2T_PACKET_LENGTH$1,
- TransportPacketStream: _TransportPacketStream,
- TransportParseStream: _TransportParseStream,
- ElementaryStream: _ElementaryStream,
- TimestampRolloverStream,
- CaptionStream: captionStream.CaptionStream,
- Cea608Stream: captionStream.Cea608Stream,
- Cea708Stream: captionStream.Cea708Stream,
- MetadataStream: metadataStream
- };
- for (var type2 in streamTypes) {
- if (streamTypes.hasOwnProperty(type2)) {
- m2ts[type2] = streamTypes[type2];
- }
- }
- var m2ts_1 = m2ts;
- var ONE_SECOND_IN_TS$2 = clock2.ONE_SECOND_IN_TS;
- var _AdtsStream;
- var ADTS_SAMPLING_FREQUENCIES$1 = [96e3, 88200, 64e3, 48e3, 44100, 32e3, 24e3, 22050, 16e3, 12e3, 11025, 8e3, 7350];
- _AdtsStream = function AdtsStream(handlePartialSegments) {
- var buffer, frameNum = 0;
- _AdtsStream.prototype.init.call(this);
- this.skipWarn_ = function(start2, end) {
- this.trigger("log", {
- level: "warn",
- message: "adts skiping bytes " + start2 + " to " + end + " in frame " + frameNum + " outside syncword"
- });
- };
- this.push = function(packet) {
- var i2 = 0, frameLength, protectionSkipBytes, oldBuffer, sampleCount, adtsFrameDuration;
- if (!handlePartialSegments) {
- frameNum = 0;
- }
- if (packet.type !== "audio") {
- return;
- }
- if (buffer && buffer.length) {
- oldBuffer = buffer;
- buffer = new Uint8Array(oldBuffer.byteLength + packet.data.byteLength);
- buffer.set(oldBuffer);
- buffer.set(packet.data, oldBuffer.byteLength);
- } else {
- buffer = packet.data;
- }
- var skip;
- while (i2 + 7 < buffer.length) {
- if (buffer[i2] !== 255 || (buffer[i2 + 1] & 246) !== 240) {
- if (typeof skip !== "number") {
- skip = i2;
- }
- i2++;
- continue;
- }
- if (typeof skip === "number") {
- this.skipWarn_(skip, i2);
- skip = null;
- }
- protectionSkipBytes = (~buffer[i2 + 1] & 1) * 2;
- frameLength = (buffer[i2 + 3] & 3) << 11 | buffer[i2 + 4] << 3 | (buffer[i2 + 5] & 224) >> 5;
- sampleCount = ((buffer[i2 + 6] & 3) + 1) * 1024;
- adtsFrameDuration = sampleCount * ONE_SECOND_IN_TS$2 / ADTS_SAMPLING_FREQUENCIES$1[(buffer[i2 + 2] & 60) >>> 2];
- if (buffer.byteLength - i2 < frameLength) {
- break;
- }
- this.trigger("data", {
- pts: packet.pts + frameNum * adtsFrameDuration,
- dts: packet.dts + frameNum * adtsFrameDuration,
- sampleCount,
- audioobjecttype: (buffer[i2 + 2] >>> 6 & 3) + 1,
- channelcount: (buffer[i2 + 2] & 1) << 2 | (buffer[i2 + 3] & 192) >>> 6,
- samplerate: ADTS_SAMPLING_FREQUENCIES$1[(buffer[i2 + 2] & 60) >>> 2],
- samplingfrequencyindex: (buffer[i2 + 2] & 60) >>> 2,
- samplesize: 16,
- data: buffer.subarray(i2 + 7 + protectionSkipBytes, i2 + frameLength)
- });
- frameNum++;
- i2 += frameLength;
- }
- if (typeof skip === "number") {
- this.skipWarn_(skip, i2);
- skip = null;
- }
- buffer = buffer.subarray(i2);
- };
- this.flush = function() {
- frameNum = 0;
- this.trigger("done");
- };
- this.reset = function() {
- buffer = void 0;
- this.trigger("reset");
- };
- this.endTimeline = function() {
- buffer = void 0;
- this.trigger("endedtimeline");
- };
- };
- _AdtsStream.prototype = new stream();
- var adts = _AdtsStream;
- var ExpGolomb;
- ExpGolomb = function ExpGolomb2(workingData) {
- var workingBytesAvailable = workingData.byteLength, workingWord = 0, workingBitsAvailable = 0;
- this.length = function() {
- return 8 * workingBytesAvailable;
- };
- this.bitsAvailable = function() {
- return 8 * workingBytesAvailable + workingBitsAvailable;
- };
- this.loadWord = function() {
- var position2 = workingData.byteLength - workingBytesAvailable, workingBytes = new Uint8Array(4), availableBytes = Math.min(4, workingBytesAvailable);
- if (availableBytes === 0) {
- throw new Error("no bytes available");
- }
- workingBytes.set(workingData.subarray(position2, position2 + availableBytes));
- workingWord = new DataView(workingBytes.buffer).getUint32(0);
- workingBitsAvailable = availableBytes * 8;
- workingBytesAvailable -= availableBytes;
- };
- this.skipBits = function(count) {
- var skipBytes;
- if (workingBitsAvailable > count) {
- workingWord <<= count;
- workingBitsAvailable -= count;
- } else {
- count -= workingBitsAvailable;
- skipBytes = Math.floor(count / 8);
- count -= skipBytes * 8;
- workingBytesAvailable -= skipBytes;
- this.loadWord();
- workingWord <<= count;
- workingBitsAvailable -= count;
- }
- };
- this.readBits = function(size) {
- var bits = Math.min(workingBitsAvailable, size), valu = workingWord >>> 32 - bits;
- workingBitsAvailable -= bits;
- if (workingBitsAvailable > 0) {
- workingWord <<= bits;
- } else if (workingBytesAvailable > 0) {
- this.loadWord();
- }
- bits = size - bits;
- if (bits > 0) {
- return valu << bits | this.readBits(bits);
- }
- return valu;
- };
- this.skipLeadingZeros = function() {
- var leadingZeroCount;
- for (leadingZeroCount = 0; leadingZeroCount < workingBitsAvailable; ++leadingZeroCount) {
- if ((workingWord & 2147483648 >>> leadingZeroCount) !== 0) {
- workingWord <<= leadingZeroCount;
- workingBitsAvailable -= leadingZeroCount;
- return leadingZeroCount;
- }
- }
- this.loadWord();
- return leadingZeroCount + this.skipLeadingZeros();
- };
- this.skipUnsignedExpGolomb = function() {
- this.skipBits(1 + this.skipLeadingZeros());
- };
- this.skipExpGolomb = function() {
- this.skipBits(1 + this.skipLeadingZeros());
- };
- this.readUnsignedExpGolomb = function() {
- var clz = this.skipLeadingZeros();
- return this.readBits(clz + 1) - 1;
- };
- this.readExpGolomb = function() {
- var valu = this.readUnsignedExpGolomb();
- if (1 & valu) {
- return 1 + valu >>> 1;
- }
- return -1 * (valu >>> 1);
- };
- this.readBoolean = function() {
- return this.readBits(1) === 1;
- };
- this.readUnsignedByte = function() {
- return this.readBits(8);
- };
- this.loadWord();
- };
- var expGolomb = ExpGolomb;
- var _H264Stream, _NalByteStream;
- var PROFILES_WITH_OPTIONAL_SPS_DATA;
- _NalByteStream = function NalByteStream() {
- var syncPoint = 0, i2, buffer;
- _NalByteStream.prototype.init.call(this);
- this.push = function(data) {
- var swapBuffer;
- if (!buffer) {
- buffer = data.data;
- } else {
- swapBuffer = new Uint8Array(buffer.byteLength + data.data.byteLength);
- swapBuffer.set(buffer);
- swapBuffer.set(data.data, buffer.byteLength);
- buffer = swapBuffer;
- }
- var len = buffer.byteLength;
- for (; syncPoint < len - 3; syncPoint++) {
- if (buffer[syncPoint + 2] === 1) {
- i2 = syncPoint + 5;
- break;
- }
- }
- while (i2 < len) {
- switch (buffer[i2]) {
- case 0:
- if (buffer[i2 - 1] !== 0) {
- i2 += 2;
- break;
- } else if (buffer[i2 - 2] !== 0) {
- i2++;
- break;
- }
- if (syncPoint + 3 !== i2 - 2) {
- this.trigger("data", buffer.subarray(syncPoint + 3, i2 - 2));
- }
- do {
- i2++;
- } while (buffer[i2] !== 1 && i2 < len);
- syncPoint = i2 - 2;
- i2 += 3;
- break;
- case 1:
- if (buffer[i2 - 1] !== 0 || buffer[i2 - 2] !== 0) {
- i2 += 3;
- break;
- }
- this.trigger("data", buffer.subarray(syncPoint + 3, i2 - 2));
- syncPoint = i2 - 2;
- i2 += 3;
- break;
- default:
- i2 += 3;
- break;
- }
- }
- buffer = buffer.subarray(syncPoint);
- i2 -= syncPoint;
- syncPoint = 0;
- };
- this.reset = function() {
- buffer = null;
- syncPoint = 0;
- this.trigger("reset");
- };
- this.flush = function() {
- if (buffer && buffer.byteLength > 3) {
- this.trigger("data", buffer.subarray(syncPoint + 3));
- }
- buffer = null;
- syncPoint = 0;
- this.trigger("done");
- };
- this.endTimeline = function() {
- this.flush();
- this.trigger("endedtimeline");
- };
- };
- _NalByteStream.prototype = new stream();
- PROFILES_WITH_OPTIONAL_SPS_DATA = {
- 100: true,
- 110: true,
- 122: true,
- 244: true,
- 44: true,
- 83: true,
- 86: true,
- 118: true,
- 128: true,
- 138: true,
- 139: true,
- 134: true
- };
- _H264Stream = function H264Stream2() {
- var nalByteStream = new _NalByteStream(), self2, trackId, currentPts, currentDts, discardEmulationPreventionBytes5, readSequenceParameterSet, skipScalingList;
- _H264Stream.prototype.init.call(this);
- self2 = this;
- this.push = function(packet) {
- if (packet.type !== "video") {
- return;
- }
- trackId = packet.trackId;
- currentPts = packet.pts;
- currentDts = packet.dts;
- nalByteStream.push(packet);
- };
- nalByteStream.on("data", function(data) {
- var event2 = {
- trackId,
- pts: currentPts,
- dts: currentDts,
- data,
- nalUnitTypeCode: data[0] & 31
- };
- switch (event2.nalUnitTypeCode) {
- case 5:
- event2.nalUnitType = "slice_layer_without_partitioning_rbsp_idr";
- break;
- case 6:
- event2.nalUnitType = "sei_rbsp";
- event2.escapedRBSP = discardEmulationPreventionBytes5(data.subarray(1));
- break;
- case 7:
- event2.nalUnitType = "seq_parameter_set_rbsp";
- event2.escapedRBSP = discardEmulationPreventionBytes5(data.subarray(1));
- event2.config = readSequenceParameterSet(event2.escapedRBSP);
- break;
- case 8:
- event2.nalUnitType = "pic_parameter_set_rbsp";
- break;
- case 9:
- event2.nalUnitType = "access_unit_delimiter_rbsp";
- break;
- }
- self2.trigger("data", event2);
- });
- nalByteStream.on("done", function() {
- self2.trigger("done");
- });
- nalByteStream.on("partialdone", function() {
- self2.trigger("partialdone");
- });
- nalByteStream.on("reset", function() {
- self2.trigger("reset");
- });
- nalByteStream.on("endedtimeline", function() {
- self2.trigger("endedtimeline");
- });
- this.flush = function() {
- nalByteStream.flush();
- };
- this.partialFlush = function() {
- nalByteStream.partialFlush();
- };
- this.reset = function() {
- nalByteStream.reset();
- };
- this.endTimeline = function() {
- nalByteStream.endTimeline();
- };
- skipScalingList = function skipScalingList2(count, expGolombDecoder) {
- var lastScale = 8, nextScale = 8, j, deltaScale;
- for (j = 0; j < count; j++) {
- if (nextScale !== 0) {
- deltaScale = expGolombDecoder.readExpGolomb();
- nextScale = (lastScale + deltaScale + 256) % 256;
- }
- lastScale = nextScale === 0 ? lastScale : nextScale;
- }
- };
- discardEmulationPreventionBytes5 = function discardEmulationPreventionBytes6(data) {
- var length = data.byteLength, emulationPreventionBytesPositions = [], i2 = 1, newLength, newData;
- while (i2 < length - 2) {
- if (data[i2] === 0 && data[i2 + 1] === 0 && data[i2 + 2] === 3) {
- emulationPreventionBytesPositions.push(i2 + 2);
- i2 += 2;
- } else {
- i2++;
- }
- }
- if (emulationPreventionBytesPositions.length === 0) {
- return data;
- }
- newLength = length - emulationPreventionBytesPositions.length;
- newData = new Uint8Array(newLength);
- var sourceIndex = 0;
- for (i2 = 0; i2 < newLength; sourceIndex++, i2++) {
- if (sourceIndex === emulationPreventionBytesPositions[0]) {
- sourceIndex++;
- emulationPreventionBytesPositions.shift();
- }
- newData[i2] = data[sourceIndex];
- }
- return newData;
- };
- readSequenceParameterSet = function readSequenceParameterSet2(data) {
- var frameCropLeftOffset = 0, frameCropRightOffset = 0, frameCropTopOffset = 0, frameCropBottomOffset = 0, expGolombDecoder, profileIdc, levelIdc, profileCompatibility, chromaFormatIdc, picOrderCntType, numRefFramesInPicOrderCntCycle, picWidthInMbsMinus1, picHeightInMapUnitsMinus1, frameMbsOnlyFlag, scalingListCount, sarRatio = [1, 1], aspectRatioIdc, i2;
- expGolombDecoder = new expGolomb(data);
- profileIdc = expGolombDecoder.readUnsignedByte();
- profileCompatibility = expGolombDecoder.readUnsignedByte();
- levelIdc = expGolombDecoder.readUnsignedByte();
- expGolombDecoder.skipUnsignedExpGolomb();
- if (PROFILES_WITH_OPTIONAL_SPS_DATA[profileIdc]) {
- chromaFormatIdc = expGolombDecoder.readUnsignedExpGolomb();
- if (chromaFormatIdc === 3) {
- expGolombDecoder.skipBits(1);
- }
- expGolombDecoder.skipUnsignedExpGolomb();
- expGolombDecoder.skipUnsignedExpGolomb();
- expGolombDecoder.skipBits(1);
- if (expGolombDecoder.readBoolean()) {
- scalingListCount = chromaFormatIdc !== 3 ? 8 : 12;
- for (i2 = 0; i2 < scalingListCount; i2++) {
- if (expGolombDecoder.readBoolean()) {
- if (i2 < 6) {
- skipScalingList(16, expGolombDecoder);
- } else {
- skipScalingList(64, expGolombDecoder);
- }
- }
- }
- }
- }
- expGolombDecoder.skipUnsignedExpGolomb();
- picOrderCntType = expGolombDecoder.readUnsignedExpGolomb();
- if (picOrderCntType === 0) {
- expGolombDecoder.readUnsignedExpGolomb();
- } else if (picOrderCntType === 1) {
- expGolombDecoder.skipBits(1);
- expGolombDecoder.skipExpGolomb();
- expGolombDecoder.skipExpGolomb();
- numRefFramesInPicOrderCntCycle = expGolombDecoder.readUnsignedExpGolomb();
- for (i2 = 0; i2 < numRefFramesInPicOrderCntCycle; i2++) {
- expGolombDecoder.skipExpGolomb();
- }
- }
- expGolombDecoder.skipUnsignedExpGolomb();
- expGolombDecoder.skipBits(1);
- picWidthInMbsMinus1 = expGolombDecoder.readUnsignedExpGolomb();
- picHeightInMapUnitsMinus1 = expGolombDecoder.readUnsignedExpGolomb();
- frameMbsOnlyFlag = expGolombDecoder.readBits(1);
- if (frameMbsOnlyFlag === 0) {
- expGolombDecoder.skipBits(1);
- }
- expGolombDecoder.skipBits(1);
- if (expGolombDecoder.readBoolean()) {
- frameCropLeftOffset = expGolombDecoder.readUnsignedExpGolomb();
- frameCropRightOffset = expGolombDecoder.readUnsignedExpGolomb();
- frameCropTopOffset = expGolombDecoder.readUnsignedExpGolomb();
- frameCropBottomOffset = expGolombDecoder.readUnsignedExpGolomb();
- }
- if (expGolombDecoder.readBoolean()) {
- if (expGolombDecoder.readBoolean()) {
- aspectRatioIdc = expGolombDecoder.readUnsignedByte();
- switch (aspectRatioIdc) {
- case 1:
- sarRatio = [1, 1];
- break;
- case 2:
- sarRatio = [12, 11];
- break;
- case 3:
- sarRatio = [10, 11];
- break;
- case 4:
- sarRatio = [16, 11];
- break;
- case 5:
- sarRatio = [40, 33];
- break;
- case 6:
- sarRatio = [24, 11];
- break;
- case 7:
- sarRatio = [20, 11];
- break;
- case 8:
- sarRatio = [32, 11];
- break;
- case 9:
- sarRatio = [80, 33];
- break;
- case 10:
- sarRatio = [18, 11];
- break;
- case 11:
- sarRatio = [15, 11];
- break;
- case 12:
- sarRatio = [64, 33];
- break;
- case 13:
- sarRatio = [160, 99];
- break;
- case 14:
- sarRatio = [4, 3];
- break;
- case 15:
- sarRatio = [3, 2];
- break;
- case 16:
- sarRatio = [2, 1];
- break;
- case 255: {
- sarRatio = [expGolombDecoder.readUnsignedByte() << 8 | expGolombDecoder.readUnsignedByte(), expGolombDecoder.readUnsignedByte() << 8 | expGolombDecoder.readUnsignedByte()];
- break;
- }
- }
- if (sarRatio) {
- sarRatio[0] / sarRatio[1];
- }
- }
- }
- return {
- profileIdc,
- levelIdc,
- profileCompatibility,
- width: (picWidthInMbsMinus1 + 1) * 16 - frameCropLeftOffset * 2 - frameCropRightOffset * 2,
- height: (2 - frameMbsOnlyFlag) * (picHeightInMapUnitsMinus1 + 1) * 16 - frameCropTopOffset * 2 - frameCropBottomOffset * 2,
- sarRatio
- };
- };
- };
- _H264Stream.prototype = new stream();
- var h2643 = {
- H264Stream: _H264Stream,
- NalByteStream: _NalByteStream
- };
- var ADTS_SAMPLING_FREQUENCIES = [96e3, 88200, 64e3, 48e3, 44100, 32e3, 24e3, 22050, 16e3, 12e3, 11025, 8e3, 7350];
- var parseId3TagSize = function parseId3TagSize2(header, byteIndex) {
- var returnSize = header[byteIndex + 6] << 21 | header[byteIndex + 7] << 14 | header[byteIndex + 8] << 7 | header[byteIndex + 9], flags = header[byteIndex + 5], footerPresent = (flags & 16) >> 4;
- returnSize = returnSize >= 0 ? returnSize : 0;
- if (footerPresent) {
- return returnSize + 20;
- }
- return returnSize + 10;
- };
- var getId3Offset4 = function getId3Offset5(data, offset) {
- if (data.length - offset < 10 || data[offset] !== "I".charCodeAt(0) || data[offset + 1] !== "D".charCodeAt(0) || data[offset + 2] !== "3".charCodeAt(0)) {
- return offset;
- }
- offset += parseId3TagSize(data, offset);
- return getId3Offset5(data, offset);
- };
- var isLikelyAacData$1 = function isLikelyAacData2(data) {
- var offset = getId3Offset4(data, 0);
- return data.length >= offset + 2 && (data[offset] & 255) === 255 && (data[offset + 1] & 240) === 240 && (data[offset + 1] & 22) === 16;
- };
- var parseSyncSafeInteger = function parseSyncSafeInteger2(data) {
- return data[0] << 21 | data[1] << 14 | data[2] << 7 | data[3];
- };
- var percentEncode = function percentEncode2(bytes, start2, end) {
- var i2, result = "";
- for (i2 = start2; i2 < end; i2++) {
- result += "%" + ("00" + bytes[i2].toString(16)).slice(-2);
- }
- return result;
- };
- var parseIso88591 = function parseIso885912(bytes, start2, end) {
- return unescape(percentEncode(bytes, start2, end));
- };
- var parseAdtsSize = function parseAdtsSize2(header, byteIndex) {
- var lowThree = (header[byteIndex + 5] & 224) >> 5, middle = header[byteIndex + 4] << 3, highTwo = header[byteIndex + 3] & 3 << 11;
- return highTwo | middle | lowThree;
- };
- var parseType$2 = function parseType2(header, byteIndex) {
- if (header[byteIndex] === "I".charCodeAt(0) && header[byteIndex + 1] === "D".charCodeAt(0) && header[byteIndex + 2] === "3".charCodeAt(0)) {
- return "timed-metadata";
- } else if (header[byteIndex] & true && (header[byteIndex + 1] & 240) === 240) {
- return "audio";
- }
- return null;
- };
- var parseSampleRate = function parseSampleRate2(packet) {
- var i2 = 0;
- while (i2 + 5 < packet.length) {
- if (packet[i2] !== 255 || (packet[i2 + 1] & 246) !== 240) {
- i2++;
- continue;
- }
- return ADTS_SAMPLING_FREQUENCIES[(packet[i2 + 2] & 60) >>> 2];
- }
- return null;
- };
- var parseAacTimestamp = function parseAacTimestamp2(packet) {
- var frameStart, frameSize, frame, frameHeader;
- frameStart = 10;
- if (packet[5] & 64) {
- frameStart += 4;
- frameStart += parseSyncSafeInteger(packet.subarray(10, 14));
- }
- do {
- frameSize = parseSyncSafeInteger(packet.subarray(frameStart + 4, frameStart + 8));
- if (frameSize < 1) {
- return null;
- }
- frameHeader = String.fromCharCode(packet[frameStart], packet[frameStart + 1], packet[frameStart + 2], packet[frameStart + 3]);
- if (frameHeader === "PRIV") {
- frame = packet.subarray(frameStart + 10, frameStart + frameSize + 10);
- for (var i2 = 0; i2 < frame.byteLength; i2++) {
- if (frame[i2] === 0) {
- var owner = parseIso88591(frame, 0, i2);
- if (owner === "com.apple.streaming.transportStreamTimestamp") {
- var d2 = frame.subarray(i2 + 1);
- var size = (d2[3] & 1) << 30 | d2[4] << 22 | d2[5] << 14 | d2[6] << 6 | d2[7] >>> 2;
- size *= 4;
- size += d2[7] & 3;
- return size;
- }
- break;
- }
- }
- }
- frameStart += 10;
- frameStart += frameSize;
- } while (frameStart < packet.byteLength);
- return null;
- };
- var utils2 = {
- isLikelyAacData: isLikelyAacData$1,
- parseId3TagSize,
- parseAdtsSize,
- parseType: parseType$2,
- parseSampleRate,
- parseAacTimestamp
- };
- var _AacStream;
- _AacStream = function AacStream() {
- var everything = new Uint8Array(), timeStamp = 0;
- _AacStream.prototype.init.call(this);
- this.setTimestamp = function(timestamp) {
- timeStamp = timestamp;
- };
- this.push = function(bytes) {
- var frameSize = 0, byteIndex = 0, bytesLeft, chunk, packet, tempLength;
- if (everything.length) {
- tempLength = everything.length;
- everything = new Uint8Array(bytes.byteLength + tempLength);
- everything.set(everything.subarray(0, tempLength));
- everything.set(bytes, tempLength);
- } else {
- everything = bytes;
- }
- while (everything.length - byteIndex >= 3) {
- if (everything[byteIndex] === "I".charCodeAt(0) && everything[byteIndex + 1] === "D".charCodeAt(0) && everything[byteIndex + 2] === "3".charCodeAt(0)) {
- if (everything.length - byteIndex < 10) {
- break;
- }
- frameSize = utils2.parseId3TagSize(everything, byteIndex);
- if (byteIndex + frameSize > everything.length) {
- break;
- }
- chunk = {
- type: "timed-metadata",
- data: everything.subarray(byteIndex, byteIndex + frameSize)
- };
- this.trigger("data", chunk);
- byteIndex += frameSize;
- continue;
- } else if ((everything[byteIndex] & 255) === 255 && (everything[byteIndex + 1] & 240) === 240) {
- if (everything.length - byteIndex < 7) {
- break;
- }
- frameSize = utils2.parseAdtsSize(everything, byteIndex);
- if (byteIndex + frameSize > everything.length) {
- break;
- }
- packet = {
- type: "audio",
- data: everything.subarray(byteIndex, byteIndex + frameSize),
- pts: timeStamp,
- dts: timeStamp
- };
- this.trigger("data", packet);
- byteIndex += frameSize;
- continue;
- }
- byteIndex++;
- }
- bytesLeft = everything.length - byteIndex;
- if (bytesLeft > 0) {
- everything = everything.subarray(byteIndex);
- } else {
- everything = new Uint8Array();
- }
- };
- this.reset = function() {
- everything = new Uint8Array();
- this.trigger("reset");
- };
- this.endTimeline = function() {
- everything = new Uint8Array();
- this.trigger("endedtimeline");
- };
- };
- _AacStream.prototype = new stream();
- var aac3 = _AacStream;
- var AUDIO_PROPERTIES = ["audioobjecttype", "channelcount", "samplerate", "samplingfrequencyindex", "samplesize"];
- var audioProperties = AUDIO_PROPERTIES;
- var VIDEO_PROPERTIES = ["width", "height", "profileIdc", "levelIdc", "profileCompatibility", "sarRatio"];
- var videoProperties = VIDEO_PROPERTIES;
- var H264Stream = h2643.H264Stream;
- var isLikelyAacData = utils2.isLikelyAacData;
- var ONE_SECOND_IN_TS$12 = clock2.ONE_SECOND_IN_TS;
- var _VideoSegmentStream, _AudioSegmentStream, _Transmuxer, _CoalesceStream;
- var retriggerForStream = function retriggerForStream2(key, event2) {
- event2.stream = key;
- this.trigger("log", event2);
- };
- var addPipelineLogRetriggers = function addPipelineLogRetriggers2(transmuxer2, pipeline) {
- var keys3 = Object.keys(pipeline);
- for (var i2 = 0; i2 < keys3.length; i2++) {
- var key = keys3[i2];
- if (key === "headOfPipeline" || !pipeline[key].on) {
- continue;
- }
- pipeline[key].on("log", retriggerForStream.bind(transmuxer2, key));
- }
- };
- var arrayEquals = function arrayEquals2(a, b) {
- var i2;
- if (a.length !== b.length) {
- return false;
- }
- for (i2 = 0; i2 < a.length; i2++) {
- if (a[i2] !== b[i2]) {
- return false;
- }
- }
- return true;
- };
- var generateSegmentTimingInfo = function generateSegmentTimingInfo2(baseMediaDecodeTime, startDts, startPts, endDts, endPts, prependedContentDuration) {
- var ptsOffsetFromDts = startPts - startDts, decodeDuration = endDts - startDts, presentationDuration = endPts - startPts;
- return {
- start: {
- dts: baseMediaDecodeTime,
- pts: baseMediaDecodeTime + ptsOffsetFromDts
- },
- end: {
- dts: baseMediaDecodeTime + decodeDuration,
- pts: baseMediaDecodeTime + presentationDuration
- },
- prependedContentDuration,
- baseMediaDecodeTime
- };
- };
- _AudioSegmentStream = function AudioSegmentStream(track, options2) {
- var adtsFrames = [], sequenceNumber, earliestAllowedDts = 0, audioAppendStartTs = 0, videoBaseMediaDecodeTime = Infinity;
- options2 = options2 || {};
- sequenceNumber = options2.firstSequenceNumber || 0;
- _AudioSegmentStream.prototype.init.call(this);
- this.push = function(data) {
- trackDecodeInfo.collectDtsInfo(track, data);
- if (track) {
- audioProperties.forEach(function(prop) {
- track[prop] = data[prop];
- });
- }
- adtsFrames.push(data);
- };
- this.setEarliestDts = function(earliestDts) {
- earliestAllowedDts = earliestDts;
- };
- this.setVideoBaseMediaDecodeTime = function(baseMediaDecodeTime) {
- videoBaseMediaDecodeTime = baseMediaDecodeTime;
- };
- this.setAudioAppendStart = function(timestamp) {
- audioAppendStartTs = timestamp;
- };
- this.flush = function() {
- var frames, moof2, mdat2, boxes, frameDuration, segmentDuration, videoClockCyclesOfSilencePrefixed;
- if (adtsFrames.length === 0) {
- this.trigger("done", "AudioSegmentStream");
- return;
- }
- frames = audioFrameUtils.trimAdtsFramesByEarliestDts(adtsFrames, track, earliestAllowedDts);
- track.baseMediaDecodeTime = trackDecodeInfo.calculateTrackBaseMediaDecodeTime(track, options2.keepOriginalTimestamps);
- videoClockCyclesOfSilencePrefixed = audioFrameUtils.prefixWithSilence(track, frames, audioAppendStartTs, videoBaseMediaDecodeTime);
- track.samples = audioFrameUtils.generateSampleTable(frames);
- mdat2 = mp4Generator.mdat(audioFrameUtils.concatenateFrameData(frames));
- adtsFrames = [];
- moof2 = mp4Generator.moof(sequenceNumber, [track]);
- boxes = new Uint8Array(moof2.byteLength + mdat2.byteLength);
- sequenceNumber++;
- boxes.set(moof2);
- boxes.set(mdat2, moof2.byteLength);
- trackDecodeInfo.clearDtsInfo(track);
- frameDuration = Math.ceil(ONE_SECOND_IN_TS$12 * 1024 / track.samplerate);
- if (frames.length) {
- segmentDuration = frames.length * frameDuration;
- this.trigger("segmentTimingInfo", generateSegmentTimingInfo(
- clock2.audioTsToVideoTs(track.baseMediaDecodeTime, track.samplerate),
- frames[0].dts,
- frames[0].pts,
- frames[0].dts + segmentDuration,
- frames[0].pts + segmentDuration,
- videoClockCyclesOfSilencePrefixed || 0
- ));
- this.trigger("timingInfo", {
- start: frames[0].pts,
- end: frames[0].pts + segmentDuration
- });
- }
- this.trigger("data", {
- track,
- boxes
- });
- this.trigger("done", "AudioSegmentStream");
- };
- this.reset = function() {
- trackDecodeInfo.clearDtsInfo(track);
- adtsFrames = [];
- this.trigger("reset");
- };
- };
- _AudioSegmentStream.prototype = new stream();
- _VideoSegmentStream = function VideoSegmentStream(track, options2) {
- var sequenceNumber, nalUnits = [], gopsToAlignWith = [], config, pps;
- options2 = options2 || {};
- sequenceNumber = options2.firstSequenceNumber || 0;
- _VideoSegmentStream.prototype.init.call(this);
- delete track.minPTS;
- this.gopCache_ = [];
- this.push = function(nalUnit) {
- trackDecodeInfo.collectDtsInfo(track, nalUnit);
- if (nalUnit.nalUnitType === "seq_parameter_set_rbsp" && !config) {
- config = nalUnit.config;
- track.sps = [nalUnit.data];
- videoProperties.forEach(function(prop) {
- track[prop] = config[prop];
- }, this);
- }
- if (nalUnit.nalUnitType === "pic_parameter_set_rbsp" && !pps) {
- pps = nalUnit.data;
- track.pps = [nalUnit.data];
- }
- nalUnits.push(nalUnit);
- };
- this.flush = function() {
- var frames, gopForFusion, gops, moof2, mdat2, boxes, prependedContentDuration = 0, firstGop, lastGop;
- while (nalUnits.length) {
- if (nalUnits[0].nalUnitType === "access_unit_delimiter_rbsp") {
- break;
- }
- nalUnits.shift();
- }
- if (nalUnits.length === 0) {
- this.resetStream_();
- this.trigger("done", "VideoSegmentStream");
- return;
- }
- frames = frameUtils.groupNalsIntoFrames(nalUnits);
- gops = frameUtils.groupFramesIntoGops(frames);
- if (!gops[0][0].keyFrame) {
- gopForFusion = this.getGopForFusion_(nalUnits[0], track);
- if (gopForFusion) {
- prependedContentDuration = gopForFusion.duration;
- gops.unshift(gopForFusion);
- gops.byteLength += gopForFusion.byteLength;
- gops.nalCount += gopForFusion.nalCount;
- gops.pts = gopForFusion.pts;
- gops.dts = gopForFusion.dts;
- gops.duration += gopForFusion.duration;
- } else {
- gops = frameUtils.extendFirstKeyFrame(gops);
- }
- }
- if (gopsToAlignWith.length) {
- var alignedGops;
- if (options2.alignGopsAtEnd) {
- alignedGops = this.alignGopsAtEnd_(gops);
- } else {
- alignedGops = this.alignGopsAtStart_(gops);
- }
- if (!alignedGops) {
- this.gopCache_.unshift({
- gop: gops.pop(),
- pps: track.pps,
- sps: track.sps
- });
- this.gopCache_.length = Math.min(6, this.gopCache_.length);
- nalUnits = [];
- this.resetStream_();
- this.trigger("done", "VideoSegmentStream");
- return;
- }
- trackDecodeInfo.clearDtsInfo(track);
- gops = alignedGops;
- }
- trackDecodeInfo.collectDtsInfo(track, gops);
- track.samples = frameUtils.generateSampleTable(gops);
- mdat2 = mp4Generator.mdat(frameUtils.concatenateNalData(gops));
- track.baseMediaDecodeTime = trackDecodeInfo.calculateTrackBaseMediaDecodeTime(track, options2.keepOriginalTimestamps);
- this.trigger("processedGopsInfo", gops.map(function(gop) {
- return {
- pts: gop.pts,
- dts: gop.dts,
- byteLength: gop.byteLength
- };
- }));
- firstGop = gops[0];
- lastGop = gops[gops.length - 1];
- this.trigger("segmentTimingInfo", generateSegmentTimingInfo(track.baseMediaDecodeTime, firstGop.dts, firstGop.pts, lastGop.dts + lastGop.duration, lastGop.pts + lastGop.duration, prependedContentDuration));
- this.trigger("timingInfo", {
- start: gops[0].pts,
- end: gops[gops.length - 1].pts + gops[gops.length - 1].duration
- });
- this.gopCache_.unshift({
- gop: gops.pop(),
- pps: track.pps,
- sps: track.sps
- });
- this.gopCache_.length = Math.min(6, this.gopCache_.length);
- nalUnits = [];
- this.trigger("baseMediaDecodeTime", track.baseMediaDecodeTime);
- this.trigger("timelineStartInfo", track.timelineStartInfo);
- moof2 = mp4Generator.moof(sequenceNumber, [track]);
- boxes = new Uint8Array(moof2.byteLength + mdat2.byteLength);
- sequenceNumber++;
- boxes.set(moof2);
- boxes.set(mdat2, moof2.byteLength);
- this.trigger("data", {
- track,
- boxes
- });
- this.resetStream_();
- this.trigger("done", "VideoSegmentStream");
- };
- this.reset = function() {
- this.resetStream_();
- nalUnits = [];
- this.gopCache_.length = 0;
- gopsToAlignWith.length = 0;
- this.trigger("reset");
- };
- this.resetStream_ = function() {
- trackDecodeInfo.clearDtsInfo(track);
- config = void 0;
- pps = void 0;
- };
- this.getGopForFusion_ = function(nalUnit) {
- var halfSecond = 45e3, allowableOverlap = 1e4, nearestDistance = Infinity, dtsDistance, nearestGopObj, currentGop, currentGopObj, i2;
- for (i2 = 0; i2 < this.gopCache_.length; i2++) {
- currentGopObj = this.gopCache_[i2];
- currentGop = currentGopObj.gop;
- if (!(track.pps && arrayEquals(track.pps[0], currentGopObj.pps[0])) || !(track.sps && arrayEquals(track.sps[0], currentGopObj.sps[0]))) {
- continue;
- }
- if (currentGop.dts < track.timelineStartInfo.dts) {
- continue;
- }
- dtsDistance = nalUnit.dts - currentGop.dts - currentGop.duration;
- if (dtsDistance >= -allowableOverlap && dtsDistance <= halfSecond) {
- if (!nearestGopObj || nearestDistance > dtsDistance) {
- nearestGopObj = currentGopObj;
- nearestDistance = dtsDistance;
- }
- }
- }
- if (nearestGopObj) {
- return nearestGopObj.gop;
- }
- return null;
- };
- this.alignGopsAtStart_ = function(gops) {
- var alignIndex, gopIndex, align, gop, byteLength, nalCount, duration5, alignedGops;
- byteLength = gops.byteLength;
- nalCount = gops.nalCount;
- duration5 = gops.duration;
- alignIndex = gopIndex = 0;
- while (alignIndex < gopsToAlignWith.length && gopIndex < gops.length) {
- align = gopsToAlignWith[alignIndex];
- gop = gops[gopIndex];
- if (align.pts === gop.pts) {
- break;
- }
- if (gop.pts > align.pts) {
- alignIndex++;
- continue;
- }
- gopIndex++;
- byteLength -= gop.byteLength;
- nalCount -= gop.nalCount;
- duration5 -= gop.duration;
- }
- if (gopIndex === 0) {
- return gops;
- }
- if (gopIndex === gops.length) {
- return null;
- }
- alignedGops = gops.slice(gopIndex);
- alignedGops.byteLength = byteLength;
- alignedGops.duration = duration5;
- alignedGops.nalCount = nalCount;
- alignedGops.pts = alignedGops[0].pts;
- alignedGops.dts = alignedGops[0].dts;
- return alignedGops;
- };
- this.alignGopsAtEnd_ = function(gops) {
- var alignIndex, gopIndex, align, gop, alignEndIndex, matchFound;
- alignIndex = gopsToAlignWith.length - 1;
- gopIndex = gops.length - 1;
- alignEndIndex = null;
- matchFound = false;
- while (alignIndex >= 0 && gopIndex >= 0) {
- align = gopsToAlignWith[alignIndex];
- gop = gops[gopIndex];
- if (align.pts === gop.pts) {
- matchFound = true;
- break;
- }
- if (align.pts > gop.pts) {
- alignIndex--;
- continue;
- }
- if (alignIndex === gopsToAlignWith.length - 1) {
- alignEndIndex = gopIndex;
- }
- gopIndex--;
- }
- if (!matchFound && alignEndIndex === null) {
- return null;
- }
- var trimIndex;
- if (matchFound) {
- trimIndex = gopIndex;
- } else {
- trimIndex = alignEndIndex;
- }
- if (trimIndex === 0) {
- return gops;
- }
- var alignedGops = gops.slice(trimIndex);
- var metadata = alignedGops.reduce(function(total, gop2) {
- total.byteLength += gop2.byteLength;
- total.duration += gop2.duration;
- total.nalCount += gop2.nalCount;
- return total;
- }, {
- byteLength: 0,
- duration: 0,
- nalCount: 0
- });
- alignedGops.byteLength = metadata.byteLength;
- alignedGops.duration = metadata.duration;
- alignedGops.nalCount = metadata.nalCount;
- alignedGops.pts = alignedGops[0].pts;
- alignedGops.dts = alignedGops[0].dts;
- return alignedGops;
- };
- this.alignGopsWith = function(newGopsToAlignWith) {
- gopsToAlignWith = newGopsToAlignWith;
- };
- };
- _VideoSegmentStream.prototype = new stream();
- _CoalesceStream = function CoalesceStream(options2, metadataStream2) {
- this.numberOfTracks = 0;
- this.metadataStream = metadataStream2;
- options2 = options2 || {};
- if (typeof options2.remux !== "undefined") {
- this.remuxTracks = !!options2.remux;
- } else {
- this.remuxTracks = true;
- }
- if (typeof options2.keepOriginalTimestamps === "boolean") {
- this.keepOriginalTimestamps = options2.keepOriginalTimestamps;
- } else {
- this.keepOriginalTimestamps = false;
- }
- this.pendingTracks = [];
- this.videoTrack = null;
- this.pendingBoxes = [];
- this.pendingCaptions = [];
- this.pendingMetadata = [];
- this.pendingBytes = 0;
- this.emittedTracks = 0;
- _CoalesceStream.prototype.init.call(this);
- this.push = function(output) {
- if (output.text) {
- return this.pendingCaptions.push(output);
- }
- if (output.frames) {
- return this.pendingMetadata.push(output);
- }
- this.pendingTracks.push(output.track);
- this.pendingBytes += output.boxes.byteLength;
- if (output.track.type === "video") {
- this.videoTrack = output.track;
- this.pendingBoxes.push(output.boxes);
- }
- if (output.track.type === "audio") {
- this.audioTrack = output.track;
- this.pendingBoxes.unshift(output.boxes);
- }
- };
- };
- _CoalesceStream.prototype = new stream();
- _CoalesceStream.prototype.flush = function(flushSource) {
- var offset = 0, event2 = {
- captions: [],
- captionStreams: {},
- metadata: [],
- info: {}
- }, caption, id3, initSegment, timelineStartPts = 0, i2;
- if (this.pendingTracks.length < this.numberOfTracks) {
- if (flushSource !== "VideoSegmentStream" && flushSource !== "AudioSegmentStream") {
- return;
- } else if (this.remuxTracks) {
- return;
- } else if (this.pendingTracks.length === 0) {
- this.emittedTracks++;
- if (this.emittedTracks >= this.numberOfTracks) {
- this.trigger("done");
- this.emittedTracks = 0;
- }
- return;
- }
- }
- if (this.videoTrack) {
- timelineStartPts = this.videoTrack.timelineStartInfo.pts;
- videoProperties.forEach(function(prop) {
- event2.info[prop] = this.videoTrack[prop];
- }, this);
- } else if (this.audioTrack) {
- timelineStartPts = this.audioTrack.timelineStartInfo.pts;
- audioProperties.forEach(function(prop) {
- event2.info[prop] = this.audioTrack[prop];
- }, this);
- }
- if (this.videoTrack || this.audioTrack) {
- if (this.pendingTracks.length === 1) {
- event2.type = this.pendingTracks[0].type;
- } else {
- event2.type = "combined";
- }
- this.emittedTracks += this.pendingTracks.length;
- initSegment = mp4Generator.initSegment(this.pendingTracks);
- event2.initSegment = new Uint8Array(initSegment.byteLength);
- event2.initSegment.set(initSegment);
- event2.data = new Uint8Array(this.pendingBytes);
- for (i2 = 0; i2 < this.pendingBoxes.length; i2++) {
- event2.data.set(this.pendingBoxes[i2], offset);
- offset += this.pendingBoxes[i2].byteLength;
- }
- for (i2 = 0; i2 < this.pendingCaptions.length; i2++) {
- caption = this.pendingCaptions[i2];
- caption.startTime = clock2.metadataTsToSeconds(caption.startPts, timelineStartPts, this.keepOriginalTimestamps);
- caption.endTime = clock2.metadataTsToSeconds(caption.endPts, timelineStartPts, this.keepOriginalTimestamps);
- event2.captionStreams[caption.stream] = true;
- event2.captions.push(caption);
- }
- for (i2 = 0; i2 < this.pendingMetadata.length; i2++) {
- id3 = this.pendingMetadata[i2];
- id3.cueTime = clock2.metadataTsToSeconds(id3.pts, timelineStartPts, this.keepOriginalTimestamps);
- event2.metadata.push(id3);
- }
- event2.metadata.dispatchType = this.metadataStream.dispatchType;
- this.pendingTracks.length = 0;
- this.videoTrack = null;
- this.pendingBoxes.length = 0;
- this.pendingCaptions.length = 0;
- this.pendingBytes = 0;
- this.pendingMetadata.length = 0;
- this.trigger("data", event2);
- for (i2 = 0; i2 < event2.captions.length; i2++) {
- caption = event2.captions[i2];
- this.trigger("caption", caption);
- }
- for (i2 = 0; i2 < event2.metadata.length; i2++) {
- id3 = event2.metadata[i2];
- this.trigger("id3Frame", id3);
- }
- }
- if (this.emittedTracks >= this.numberOfTracks) {
- this.trigger("done");
- this.emittedTracks = 0;
- }
- };
- _CoalesceStream.prototype.setRemux = function(val) {
- this.remuxTracks = val;
- };
- _Transmuxer = function Transmuxer(options2) {
- var self2 = this, hasFlushed = true, videoTrack, audioTrack;
- _Transmuxer.prototype.init.call(this);
- options2 = options2 || {};
- this.baseMediaDecodeTime = options2.baseMediaDecodeTime || 0;
- this.transmuxPipeline_ = {};
- this.setupAacPipeline = function() {
- var pipeline = {};
- this.transmuxPipeline_ = pipeline;
- pipeline.type = "aac";
- pipeline.metadataStream = new m2ts_1.MetadataStream();
- pipeline.aacStream = new aac3();
- pipeline.audioTimestampRolloverStream = new m2ts_1.TimestampRolloverStream("audio");
- pipeline.timedMetadataTimestampRolloverStream = new m2ts_1.TimestampRolloverStream("timed-metadata");
- pipeline.adtsStream = new adts();
- pipeline.coalesceStream = new _CoalesceStream(options2, pipeline.metadataStream);
- pipeline.headOfPipeline = pipeline.aacStream;
- pipeline.aacStream.pipe(pipeline.audioTimestampRolloverStream).pipe(pipeline.adtsStream);
- pipeline.aacStream.pipe(pipeline.timedMetadataTimestampRolloverStream).pipe(pipeline.metadataStream).pipe(pipeline.coalesceStream);
- pipeline.metadataStream.on("timestamp", function(frame) {
- pipeline.aacStream.setTimestamp(frame.timeStamp);
- });
- pipeline.aacStream.on("data", function(data) {
- if (data.type !== "timed-metadata" && data.type !== "audio" || pipeline.audioSegmentStream) {
- return;
- }
- audioTrack = audioTrack || {
- timelineStartInfo: {
- baseMediaDecodeTime: self2.baseMediaDecodeTime
- },
- codec: "adts",
- type: "audio"
- };
- pipeline.coalesceStream.numberOfTracks++;
- pipeline.audioSegmentStream = new _AudioSegmentStream(audioTrack, options2);
- pipeline.audioSegmentStream.on("log", self2.getLogTrigger_("audioSegmentStream"));
- pipeline.audioSegmentStream.on("timingInfo", self2.trigger.bind(self2, "audioTimingInfo"));
- pipeline.adtsStream.pipe(pipeline.audioSegmentStream).pipe(pipeline.coalesceStream);
- self2.trigger("trackinfo", {
- hasAudio: !!audioTrack,
- hasVideo: !!videoTrack
- });
- });
- pipeline.coalesceStream.on("data", this.trigger.bind(this, "data"));
- pipeline.coalesceStream.on("done", this.trigger.bind(this, "done"));
- addPipelineLogRetriggers(this, pipeline);
- };
- this.setupTsPipeline = function() {
- var pipeline = {};
- this.transmuxPipeline_ = pipeline;
- pipeline.type = "ts";
- pipeline.metadataStream = new m2ts_1.MetadataStream();
- pipeline.packetStream = new m2ts_1.TransportPacketStream();
- pipeline.parseStream = new m2ts_1.TransportParseStream();
- pipeline.elementaryStream = new m2ts_1.ElementaryStream();
- pipeline.timestampRolloverStream = new m2ts_1.TimestampRolloverStream();
- pipeline.adtsStream = new adts();
- pipeline.h264Stream = new H264Stream();
- pipeline.captionStream = new m2ts_1.CaptionStream(options2);
- pipeline.coalesceStream = new _CoalesceStream(options2, pipeline.metadataStream);
- pipeline.headOfPipeline = pipeline.packetStream;
- pipeline.packetStream.pipe(pipeline.parseStream).pipe(pipeline.elementaryStream).pipe(pipeline.timestampRolloverStream);
- pipeline.timestampRolloverStream.pipe(pipeline.h264Stream);
- pipeline.timestampRolloverStream.pipe(pipeline.adtsStream);
- pipeline.timestampRolloverStream.pipe(pipeline.metadataStream).pipe(pipeline.coalesceStream);
- pipeline.h264Stream.pipe(pipeline.captionStream).pipe(pipeline.coalesceStream);
- pipeline.elementaryStream.on("data", function(data) {
- var i2;
- if (data.type === "metadata") {
- i2 = data.tracks.length;
- while (i2--) {
- if (!videoTrack && data.tracks[i2].type === "video") {
- videoTrack = data.tracks[i2];
- videoTrack.timelineStartInfo.baseMediaDecodeTime = self2.baseMediaDecodeTime;
- } else if (!audioTrack && data.tracks[i2].type === "audio") {
- audioTrack = data.tracks[i2];
- audioTrack.timelineStartInfo.baseMediaDecodeTime = self2.baseMediaDecodeTime;
- }
- }
- if (videoTrack && !pipeline.videoSegmentStream) {
- pipeline.coalesceStream.numberOfTracks++;
- pipeline.videoSegmentStream = new _VideoSegmentStream(videoTrack, options2);
- pipeline.videoSegmentStream.on("log", self2.getLogTrigger_("videoSegmentStream"));
- pipeline.videoSegmentStream.on("timelineStartInfo", function(timelineStartInfo) {
- if (audioTrack && !options2.keepOriginalTimestamps) {
- audioTrack.timelineStartInfo = timelineStartInfo;
- pipeline.audioSegmentStream.setEarliestDts(timelineStartInfo.dts - self2.baseMediaDecodeTime);
- }
- });
- pipeline.videoSegmentStream.on("processedGopsInfo", self2.trigger.bind(self2, "gopInfo"));
- pipeline.videoSegmentStream.on("segmentTimingInfo", self2.trigger.bind(self2, "videoSegmentTimingInfo"));
- pipeline.videoSegmentStream.on("baseMediaDecodeTime", function(baseMediaDecodeTime) {
- if (audioTrack) {
- pipeline.audioSegmentStream.setVideoBaseMediaDecodeTime(baseMediaDecodeTime);
- }
- });
- pipeline.videoSegmentStream.on("timingInfo", self2.trigger.bind(self2, "videoTimingInfo"));
- pipeline.h264Stream.pipe(pipeline.videoSegmentStream).pipe(pipeline.coalesceStream);
- }
- if (audioTrack && !pipeline.audioSegmentStream) {
- pipeline.coalesceStream.numberOfTracks++;
- pipeline.audioSegmentStream = new _AudioSegmentStream(audioTrack, options2);
- pipeline.audioSegmentStream.on("log", self2.getLogTrigger_("audioSegmentStream"));
- pipeline.audioSegmentStream.on("timingInfo", self2.trigger.bind(self2, "audioTimingInfo"));
- pipeline.audioSegmentStream.on("segmentTimingInfo", self2.trigger.bind(self2, "audioSegmentTimingInfo"));
- pipeline.adtsStream.pipe(pipeline.audioSegmentStream).pipe(pipeline.coalesceStream);
- }
- self2.trigger("trackinfo", {
- hasAudio: !!audioTrack,
- hasVideo: !!videoTrack
- });
- }
- });
- pipeline.coalesceStream.on("data", this.trigger.bind(this, "data"));
- pipeline.coalesceStream.on("id3Frame", function(id3Frame) {
- id3Frame.dispatchType = pipeline.metadataStream.dispatchType;
- self2.trigger("id3Frame", id3Frame);
- });
- pipeline.coalesceStream.on("caption", this.trigger.bind(this, "caption"));
- pipeline.coalesceStream.on("done", this.trigger.bind(this, "done"));
- addPipelineLogRetriggers(this, pipeline);
- };
- this.setBaseMediaDecodeTime = function(baseMediaDecodeTime) {
- var pipeline = this.transmuxPipeline_;
- if (!options2.keepOriginalTimestamps) {
- this.baseMediaDecodeTime = baseMediaDecodeTime;
- }
- if (audioTrack) {
- audioTrack.timelineStartInfo.dts = void 0;
- audioTrack.timelineStartInfo.pts = void 0;
- trackDecodeInfo.clearDtsInfo(audioTrack);
- if (pipeline.audioTimestampRolloverStream) {
- pipeline.audioTimestampRolloverStream.discontinuity();
- }
- }
- if (videoTrack) {
- if (pipeline.videoSegmentStream) {
- pipeline.videoSegmentStream.gopCache_ = [];
- }
- videoTrack.timelineStartInfo.dts = void 0;
- videoTrack.timelineStartInfo.pts = void 0;
- trackDecodeInfo.clearDtsInfo(videoTrack);
- pipeline.captionStream.reset();
- }
- if (pipeline.timestampRolloverStream) {
- pipeline.timestampRolloverStream.discontinuity();
- }
- };
- this.setAudioAppendStart = function(timestamp) {
- if (audioTrack) {
- this.transmuxPipeline_.audioSegmentStream.setAudioAppendStart(timestamp);
- }
- };
- this.setRemux = function(val) {
- var pipeline = this.transmuxPipeline_;
- options2.remux = val;
- if (pipeline && pipeline.coalesceStream) {
- pipeline.coalesceStream.setRemux(val);
- }
- };
- this.alignGopsWith = function(gopsToAlignWith) {
- if (videoTrack && this.transmuxPipeline_.videoSegmentStream) {
- this.transmuxPipeline_.videoSegmentStream.alignGopsWith(gopsToAlignWith);
- }
- };
- this.getLogTrigger_ = function(key) {
- var self3 = this;
- return function(event2) {
- event2.stream = key;
- self3.trigger("log", event2);
- };
- };
- this.push = function(data) {
- if (hasFlushed) {
- var isAac = isLikelyAacData(data);
- if (isAac && this.transmuxPipeline_.type !== "aac") {
- this.setupAacPipeline();
- } else if (!isAac && this.transmuxPipeline_.type !== "ts") {
- this.setupTsPipeline();
- }
- hasFlushed = false;
- }
- this.transmuxPipeline_.headOfPipeline.push(data);
- };
- this.flush = function() {
- hasFlushed = true;
- this.transmuxPipeline_.headOfPipeline.flush();
- };
- this.endTimeline = function() {
- this.transmuxPipeline_.headOfPipeline.endTimeline();
- };
- this.reset = function() {
- if (this.transmuxPipeline_.headOfPipeline) {
- this.transmuxPipeline_.headOfPipeline.reset();
- }
- };
- this.resetCaptions = function() {
- if (this.transmuxPipeline_.captionStream) {
- this.transmuxPipeline_.captionStream.reset();
- }
- };
- };
- _Transmuxer.prototype = new stream();
- var transmuxer = {
- Transmuxer: _Transmuxer,
- VideoSegmentStream: _VideoSegmentStream,
- AudioSegmentStream: _AudioSegmentStream,
- AUDIO_PROPERTIES: audioProperties,
- VIDEO_PROPERTIES: videoProperties,
- generateSegmentTimingInfo
- };
- var toUnsigned$3 = function toUnsigned2(value) {
- return value >>> 0;
- };
- var toHexString$1 = function toHexString2(value) {
- return ("00" + value.toString(16)).slice(-2);
- };
- var bin = {
- toUnsigned: toUnsigned$3,
- toHexString: toHexString$1
- };
- var parseType$1 = function parseType2(buffer) {
- var result = "";
- result += String.fromCharCode(buffer[0]);
- result += String.fromCharCode(buffer[1]);
- result += String.fromCharCode(buffer[2]);
- result += String.fromCharCode(buffer[3]);
- return result;
- };
- var parseType_1 = parseType$1;
- var toUnsigned$2 = bin.toUnsigned;
- var findBox4 = function findBox5(data, path) {
- var results = [], i2, size, type3, end, subresults;
- if (!path.length) {
- return null;
- }
- for (i2 = 0; i2 < data.byteLength; ) {
- size = toUnsigned$2(data[i2] << 24 | data[i2 + 1] << 16 | data[i2 + 2] << 8 | data[i2 + 3]);
- type3 = parseType_1(data.subarray(i2 + 4, i2 + 8));
- end = size > 1 ? i2 + size : data.byteLength;
- if (type3 === path[0]) {
- if (path.length === 1) {
- results.push(data.subarray(i2 + 8, end));
- } else {
- subresults = findBox5(data.subarray(i2 + 8, end), path.slice(1));
- if (subresults.length) {
- results = results.concat(subresults);
- }
- }
- }
- i2 = end;
- }
- return results;
- };
- var findBox_1 = findBox4;
- var toUnsigned$1 = bin.toUnsigned;
- var getUint64$12 = numbers2.getUint64;
- var tfdt = function tfdt2(data) {
- var result = {
- version: data[0],
- flags: new Uint8Array(data.subarray(1, 4))
- };
- if (result.version === 1) {
- result.baseMediaDecodeTime = getUint64$12(data.subarray(4));
- } else {
- result.baseMediaDecodeTime = toUnsigned$1(data[4] << 24 | data[5] << 16 | data[6] << 8 | data[7]);
- }
- return result;
- };
- var parseTfdt = tfdt;
- var parseSampleFlags = function parseSampleFlags2(flags) {
- return {
- isLeading: (flags[0] & 12) >>> 2,
- dependsOn: flags[0] & 3,
- isDependedOn: (flags[1] & 192) >>> 6,
- hasRedundancy: (flags[1] & 48) >>> 4,
- paddingValue: (flags[1] & 14) >>> 1,
- isNonSyncSample: flags[1] & 1,
- degradationPriority: flags[2] << 8 | flags[3]
- };
- };
- var parseSampleFlags_1 = parseSampleFlags;
- var trun = function trun2(data) {
- var result = {
- version: data[0],
- flags: new Uint8Array(data.subarray(1, 4)),
- samples: []
- }, view = new DataView(data.buffer, data.byteOffset, data.byteLength), dataOffsetPresent = result.flags[2] & 1, firstSampleFlagsPresent = result.flags[2] & 4, sampleDurationPresent = result.flags[1] & 1, sampleSizePresent = result.flags[1] & 2, sampleFlagsPresent = result.flags[1] & 4, sampleCompositionTimeOffsetPresent = result.flags[1] & 8, sampleCount = view.getUint32(4), offset = 8, sample;
- if (dataOffsetPresent) {
- result.dataOffset = view.getInt32(offset);
- offset += 4;
- }
- if (firstSampleFlagsPresent && sampleCount) {
- sample = {
- flags: parseSampleFlags_1(data.subarray(offset, offset + 4))
- };
- offset += 4;
- if (sampleDurationPresent) {
- sample.duration = view.getUint32(offset);
- offset += 4;
- }
- if (sampleSizePresent) {
- sample.size = view.getUint32(offset);
- offset += 4;
- }
- if (sampleCompositionTimeOffsetPresent) {
- if (result.version === 1) {
- sample.compositionTimeOffset = view.getInt32(offset);
- } else {
- sample.compositionTimeOffset = view.getUint32(offset);
- }
- offset += 4;
- }
- result.samples.push(sample);
- sampleCount--;
- }
- while (sampleCount--) {
- sample = {};
- if (sampleDurationPresent) {
- sample.duration = view.getUint32(offset);
- offset += 4;
- }
- if (sampleSizePresent) {
- sample.size = view.getUint32(offset);
- offset += 4;
- }
- if (sampleFlagsPresent) {
- sample.flags = parseSampleFlags_1(data.subarray(offset, offset + 4));
- offset += 4;
- }
- if (sampleCompositionTimeOffsetPresent) {
- if (result.version === 1) {
- sample.compositionTimeOffset = view.getInt32(offset);
- } else {
- sample.compositionTimeOffset = view.getUint32(offset);
- }
- offset += 4;
- }
- result.samples.push(sample);
- }
- return result;
- };
- var parseTrun = trun;
- var tfhd = function tfhd2(data) {
- var view = new DataView(data.buffer, data.byteOffset, data.byteLength), result = {
- version: data[0],
- flags: new Uint8Array(data.subarray(1, 4)),
- trackId: view.getUint32(4)
- }, baseDataOffsetPresent = result.flags[2] & 1, sampleDescriptionIndexPresent = result.flags[2] & 2, defaultSampleDurationPresent = result.flags[2] & 8, defaultSampleSizePresent = result.flags[2] & 16, defaultSampleFlagsPresent = result.flags[2] & 32, durationIsEmpty = result.flags[0] & 65536, defaultBaseIsMoof = result.flags[0] & 131072, i2;
- i2 = 8;
- if (baseDataOffsetPresent) {
- i2 += 4;
- result.baseDataOffset = view.getUint32(12);
- i2 += 4;
- }
- if (sampleDescriptionIndexPresent) {
- result.sampleDescriptionIndex = view.getUint32(i2);
- i2 += 4;
- }
- if (defaultSampleDurationPresent) {
- result.defaultSampleDuration = view.getUint32(i2);
- i2 += 4;
- }
- if (defaultSampleSizePresent) {
- result.defaultSampleSize = view.getUint32(i2);
- i2 += 4;
- }
- if (defaultSampleFlagsPresent) {
- result.defaultSampleFlags = view.getUint32(i2);
- }
- if (durationIsEmpty) {
- result.durationIsEmpty = true;
- }
- if (!baseDataOffsetPresent && defaultBaseIsMoof) {
- result.baseDataOffsetIsMoof = true;
- }
- return result;
- };
- var parseTfhd = tfhd;
- var commonjsGlobal2 = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
- var win2;
- if (typeof window !== "undefined") {
- win2 = window;
- } else if (typeof commonjsGlobal2 !== "undefined") {
- win2 = commonjsGlobal2;
- } else if (typeof self !== "undefined") {
- win2 = self;
- } else {
- win2 = {};
- }
- var window_12 = win2;
- var discardEmulationPreventionBytes4 = captionPacketParser.discardEmulationPreventionBytes;
- var CaptionStream = captionStream.CaptionStream;
- var mapToSample = function mapToSample2(offset, samples) {
- var approximateOffset = offset;
- for (var i2 = 0; i2 < samples.length; i2++) {
- var sample = samples[i2];
- if (approximateOffset < sample.size) {
- return sample;
- }
- approximateOffset -= sample.size;
- }
- return null;
- };
- var findSeiNals = function findSeiNals2(avcStream, samples, trackId) {
- var avcView = new DataView(avcStream.buffer, avcStream.byteOffset, avcStream.byteLength), result = {
- logs: [],
- seiNals: []
- }, seiNal, i2, length, lastMatchedSample;
- for (i2 = 0; i2 + 4 < avcStream.length; i2 += length) {
- length = avcView.getUint32(i2);
- i2 += 4;
- if (length <= 0) {
- continue;
- }
- switch (avcStream[i2] & 31) {
- case 6:
- var data = avcStream.subarray(i2 + 1, i2 + 1 + length);
- var matchingSample = mapToSample(i2, samples);
- seiNal = {
- nalUnitType: "sei_rbsp",
- size: length,
- data,
- escapedRBSP: discardEmulationPreventionBytes4(data),
- trackId
- };
- if (matchingSample) {
- seiNal.pts = matchingSample.pts;
- seiNal.dts = matchingSample.dts;
- lastMatchedSample = matchingSample;
- } else if (lastMatchedSample) {
- seiNal.pts = lastMatchedSample.pts;
- seiNal.dts = lastMatchedSample.dts;
- } else {
- result.logs.push({
- level: "warn",
- message: "We've encountered a nal unit without data at " + i2 + " for trackId " + trackId + ". See mux.js#223."
- });
- break;
- }
- result.seiNals.push(seiNal);
- break;
- }
- }
- return result;
- };
- var parseSamples = function parseSamples2(truns, baseMediaDecodeTime, tfhd2) {
- var currentDts = baseMediaDecodeTime;
- var defaultSampleDuration = tfhd2.defaultSampleDuration || 0;
- var defaultSampleSize = tfhd2.defaultSampleSize || 0;
- var trackId = tfhd2.trackId;
- var allSamples = [];
- truns.forEach(function(trun2) {
- var trackRun = parseTrun(trun2);
- var samples = trackRun.samples;
- samples.forEach(function(sample) {
- if (sample.duration === void 0) {
- sample.duration = defaultSampleDuration;
- }
- if (sample.size === void 0) {
- sample.size = defaultSampleSize;
- }
- sample.trackId = trackId;
- sample.dts = currentDts;
- if (sample.compositionTimeOffset === void 0) {
- sample.compositionTimeOffset = 0;
- }
- if (typeof currentDts === "bigint") {
- sample.pts = currentDts + window_12.BigInt(sample.compositionTimeOffset);
- currentDts += window_12.BigInt(sample.duration);
- } else {
- sample.pts = currentDts + sample.compositionTimeOffset;
- currentDts += sample.duration;
- }
- });
- allSamples = allSamples.concat(samples);
- });
- return allSamples;
- };
- var parseCaptionNals = function parseCaptionNals2(segment, videoTrackId) {
- var trafs = findBox_1(segment, ["moof", "traf"]);
- var mdats = findBox_1(segment, ["mdat"]);
- var captionNals = {};
- var mdatTrafPairs = [];
- mdats.forEach(function(mdat2, index2) {
- var matchingTraf = trafs[index2];
- mdatTrafPairs.push({
- mdat: mdat2,
- traf: matchingTraf
- });
- });
- mdatTrafPairs.forEach(function(pair) {
- var mdat2 = pair.mdat;
- var traf2 = pair.traf;
- var tfhd2 = findBox_1(traf2, ["tfhd"]);
- var headerInfo = parseTfhd(tfhd2[0]);
- var trackId = headerInfo.trackId;
- var tfdt2 = findBox_1(traf2, ["tfdt"]);
- var baseMediaDecodeTime = tfdt2.length > 0 ? parseTfdt(tfdt2[0]).baseMediaDecodeTime : 0;
- var truns = findBox_1(traf2, ["trun"]);
- var samples;
- var result;
- if (videoTrackId === trackId && truns.length > 0) {
- samples = parseSamples(truns, baseMediaDecodeTime, headerInfo);
- result = findSeiNals(mdat2, samples, trackId);
- if (!captionNals[trackId]) {
- captionNals[trackId] = {
- seiNals: [],
- logs: []
- };
- }
- captionNals[trackId].seiNals = captionNals[trackId].seiNals.concat(result.seiNals);
- captionNals[trackId].logs = captionNals[trackId].logs.concat(result.logs);
- }
- });
- return captionNals;
- };
- var parseEmbeddedCaptions = function parseEmbeddedCaptions2(segment, trackId, timescale3) {
- var captionNals;
- if (trackId === null) {
- return null;
- }
- captionNals = parseCaptionNals(segment, trackId);
- var trackNals = captionNals[trackId] || {};
- return {
- seiNals: trackNals.seiNals,
- logs: trackNals.logs,
- timescale: timescale3
- };
- };
- var CaptionParser = function CaptionParser2() {
- var isInitialized = false;
- var captionStream2;
- var segmentCache;
- var trackId;
- var timescale3;
- var parsedCaptions;
- var parsingPartial;
- this.isInitialized = function() {
- return isInitialized;
- };
- this.init = function(options2) {
- captionStream2 = new CaptionStream();
- isInitialized = true;
- parsingPartial = options2 ? options2.isPartial : false;
- captionStream2.on("data", function(event2) {
- event2.startTime = event2.startPts / timescale3;
- event2.endTime = event2.endPts / timescale3;
- parsedCaptions.captions.push(event2);
- parsedCaptions.captionStreams[event2.stream] = true;
- });
- captionStream2.on("log", function(log2) {
- parsedCaptions.logs.push(log2);
- });
- };
- this.isNewInit = function(videoTrackIds, timescales) {
- if (videoTrackIds && videoTrackIds.length === 0 || timescales && typeof timescales === "object" && Object.keys(timescales).length === 0) {
- return false;
- }
- return trackId !== videoTrackIds[0] || timescale3 !== timescales[trackId];
- };
- this.parse = function(segment, videoTrackIds, timescales) {
- var parsedData;
- if (!this.isInitialized()) {
- return null;
- } else if (!videoTrackIds || !timescales) {
- return null;
- } else if (this.isNewInit(videoTrackIds, timescales)) {
- trackId = videoTrackIds[0];
- timescale3 = timescales[trackId];
- } else if (trackId === null || !timescale3) {
- segmentCache.push(segment);
- return null;
- }
- while (segmentCache.length > 0) {
- var cachedSegment = segmentCache.shift();
- this.parse(cachedSegment, videoTrackIds, timescales);
- }
- parsedData = parseEmbeddedCaptions(segment, trackId, timescale3);
- if (parsedData && parsedData.logs) {
- parsedCaptions.logs = parsedCaptions.logs.concat(parsedData.logs);
- }
- if (parsedData === null || !parsedData.seiNals) {
- if (parsedCaptions.logs.length) {
- return {
- logs: parsedCaptions.logs,
- captions: [],
- captionStreams: []
- };
- }
- return null;
- }
- this.pushNals(parsedData.seiNals);
- this.flushStream();
- return parsedCaptions;
- };
- this.pushNals = function(nals) {
- if (!this.isInitialized() || !nals || nals.length === 0) {
- return null;
- }
- nals.forEach(function(nal) {
- captionStream2.push(nal);
- });
- };
- this.flushStream = function() {
- if (!this.isInitialized()) {
- return null;
- }
- if (!parsingPartial) {
- captionStream2.flush();
- } else {
- captionStream2.partialFlush();
- }
- };
- this.clearParsedCaptions = function() {
- parsedCaptions.captions = [];
- parsedCaptions.captionStreams = {};
- parsedCaptions.logs = [];
- };
- this.resetCaptionStream = function() {
- if (!this.isInitialized()) {
- return null;
- }
- captionStream2.reset();
- };
- this.clearAllCaptions = function() {
- this.clearParsedCaptions();
- this.resetCaptionStream();
- };
- this.reset = function() {
- segmentCache = [];
- trackId = null;
- timescale3 = null;
- if (!parsedCaptions) {
- parsedCaptions = {
- captions: [],
- captionStreams: {},
- logs: []
- };
- } else {
- this.clearParsedCaptions();
- }
- this.resetCaptionStream();
- };
- this.reset();
- };
- var captionParser = CaptionParser;
- var toUnsigned = bin.toUnsigned;
- var toHexString = bin.toHexString;
- var getUint642 = numbers2.getUint64;
- var timescale2, startTime, compositionStartTime, getVideoTrackIds, getTracks, getTimescaleFromMediaHeader;
- timescale2 = function timescale3(init) {
- var result = {}, traks = findBox_1(init, ["moov", "trak"]);
- return traks.reduce(function(result2, trak2) {
- var tkhd2, version2, index2, id, mdhd2;
- tkhd2 = findBox_1(trak2, ["tkhd"])[0];
- if (!tkhd2) {
- return null;
- }
- version2 = tkhd2[0];
- index2 = version2 === 0 ? 12 : 20;
- id = toUnsigned(tkhd2[index2] << 24 | tkhd2[index2 + 1] << 16 | tkhd2[index2 + 2] << 8 | tkhd2[index2 + 3]);
- mdhd2 = findBox_1(trak2, ["mdia", "mdhd"])[0];
- if (!mdhd2) {
- return null;
- }
- version2 = mdhd2[0];
- index2 = version2 === 0 ? 12 : 20;
- result2[id] = toUnsigned(mdhd2[index2] << 24 | mdhd2[index2 + 1] << 16 | mdhd2[index2 + 2] << 8 | mdhd2[index2 + 3]);
- return result2;
- }, result);
- };
- startTime = function startTime2(timescale3, fragment) {
- var trafs;
- trafs = findBox_1(fragment, ["moof", "traf"]);
- var lowestTime = trafs.reduce(function(acc, traf2) {
- var tfhd2 = findBox_1(traf2, ["tfhd"])[0];
- var id = toUnsigned(tfhd2[4] << 24 | tfhd2[5] << 16 | tfhd2[6] << 8 | tfhd2[7]);
- var scale = timescale3[id] || 9e4;
- var tfdt2 = findBox_1(traf2, ["tfdt"])[0];
- var dv = new DataView(tfdt2.buffer, tfdt2.byteOffset, tfdt2.byteLength);
- var baseTime;
- if (tfdt2[0] === 1) {
- baseTime = getUint642(tfdt2.subarray(4, 12));
- } else {
- baseTime = dv.getUint32(4);
- }
- var seconds;
- if (typeof baseTime === "bigint") {
- seconds = baseTime / window_12.BigInt(scale);
- } else if (typeof baseTime === "number" && !isNaN(baseTime)) {
- seconds = baseTime / scale;
- }
- if (seconds < Number.MAX_SAFE_INTEGER) {
- seconds = Number(seconds);
- }
- if (seconds < acc) {
- acc = seconds;
- }
- return acc;
- }, Infinity);
- return typeof lowestTime === "bigint" || isFinite(lowestTime) ? lowestTime : 0;
- };
- compositionStartTime = function compositionStartTime2(timescales, fragment) {
- var trafBoxes = findBox_1(fragment, ["moof", "traf"]);
- var baseMediaDecodeTime = 0;
- var compositionTimeOffset = 0;
- var trackId;
- if (trafBoxes && trafBoxes.length) {
- var tfhd2 = findBox_1(trafBoxes[0], ["tfhd"])[0];
- var trun2 = findBox_1(trafBoxes[0], ["trun"])[0];
- var tfdt2 = findBox_1(trafBoxes[0], ["tfdt"])[0];
- if (tfhd2) {
- var parsedTfhd = parseTfhd(tfhd2);
- trackId = parsedTfhd.trackId;
- }
- if (tfdt2) {
- var parsedTfdt = parseTfdt(tfdt2);
- baseMediaDecodeTime = parsedTfdt.baseMediaDecodeTime;
- }
- if (trun2) {
- var parsedTrun = parseTrun(trun2);
- if (parsedTrun.samples && parsedTrun.samples.length) {
- compositionTimeOffset = parsedTrun.samples[0].compositionTimeOffset || 0;
- }
- }
- }
- var timescale3 = timescales[trackId] || 9e4;
- if (typeof baseMediaDecodeTime === "bigint") {
- compositionTimeOffset = window_12.BigInt(compositionTimeOffset);
- timescale3 = window_12.BigInt(timescale3);
- }
- var result = (baseMediaDecodeTime + compositionTimeOffset) / timescale3;
- if (typeof result === "bigint" && result < Number.MAX_SAFE_INTEGER) {
- result = Number(result);
- }
- return result;
- };
- getVideoTrackIds = function getVideoTrackIds2(init) {
- var traks = findBox_1(init, ["moov", "trak"]);
- var videoTrackIds = [];
- traks.forEach(function(trak2) {
- var hdlrs = findBox_1(trak2, ["mdia", "hdlr"]);
- var tkhds = findBox_1(trak2, ["tkhd"]);
- hdlrs.forEach(function(hdlr2, index2) {
- var handlerType = parseType_1(hdlr2.subarray(8, 12));
- var tkhd2 = tkhds[index2];
- var view;
- var version2;
- var trackId;
- if (handlerType === "vide") {
- view = new DataView(tkhd2.buffer, tkhd2.byteOffset, tkhd2.byteLength);
- version2 = view.getUint8(0);
- trackId = version2 === 0 ? view.getUint32(12) : view.getUint32(20);
- videoTrackIds.push(trackId);
- }
- });
- });
- return videoTrackIds;
- };
- getTimescaleFromMediaHeader = function getTimescaleFromMediaHeader2(mdhd2) {
- var version2 = mdhd2[0];
- var index2 = version2 === 0 ? 12 : 20;
- return toUnsigned(mdhd2[index2] << 24 | mdhd2[index2 + 1] << 16 | mdhd2[index2 + 2] << 8 | mdhd2[index2 + 3]);
- };
- getTracks = function getTracks2(init) {
- var traks = findBox_1(init, ["moov", "trak"]);
- var tracks = [];
- traks.forEach(function(trak2) {
- var track = {};
- var tkhd2 = findBox_1(trak2, ["tkhd"])[0];
- var view, tkhdVersion;
- if (tkhd2) {
- view = new DataView(tkhd2.buffer, tkhd2.byteOffset, tkhd2.byteLength);
- tkhdVersion = view.getUint8(0);
- track.id = tkhdVersion === 0 ? view.getUint32(12) : view.getUint32(20);
- }
- var hdlr2 = findBox_1(trak2, ["mdia", "hdlr"])[0];
- if (hdlr2) {
- var type3 = parseType_1(hdlr2.subarray(8, 12));
- if (type3 === "vide") {
- track.type = "video";
- } else if (type3 === "soun") {
- track.type = "audio";
- } else {
- track.type = type3;
- }
- }
- var stsd2 = findBox_1(trak2, ["mdia", "minf", "stbl", "stsd"])[0];
- if (stsd2) {
- var sampleDescriptions = stsd2.subarray(8);
- track.codec = parseType_1(sampleDescriptions.subarray(4, 8));
- var codecBox = findBox_1(sampleDescriptions, [track.codec])[0];
- var codecConfig, codecConfigType;
- if (codecBox) {
- if (/^[asm]vc[1-9]$/i.test(track.codec)) {
- codecConfig = codecBox.subarray(78);
- codecConfigType = parseType_1(codecConfig.subarray(4, 8));
- if (codecConfigType === "avcC" && codecConfig.length > 11) {
- track.codec += ".";
- track.codec += toHexString(codecConfig[9]);
- track.codec += toHexString(codecConfig[10]);
- track.codec += toHexString(codecConfig[11]);
- } else {
- track.codec = "avc1.4d400d";
- }
- } else if (/^mp4[a,v]$/i.test(track.codec)) {
- codecConfig = codecBox.subarray(28);
- codecConfigType = parseType_1(codecConfig.subarray(4, 8));
- if (codecConfigType === "esds" && codecConfig.length > 20 && codecConfig[19] !== 0) {
- track.codec += "." + toHexString(codecConfig[19]);
- track.codec += "." + toHexString(codecConfig[20] >>> 2 & 63).replace(/^0/, "");
- } else {
- track.codec = "mp4a.40.2";
- }
- } else {
- track.codec = track.codec.toLowerCase();
- }
- }
- }
- var mdhd2 = findBox_1(trak2, ["mdia", "mdhd"])[0];
- if (mdhd2) {
- track.timescale = getTimescaleFromMediaHeader(mdhd2);
- }
- tracks.push(track);
- });
- return tracks;
- };
- var probe$2 = {
- findBox: findBox_1,
- parseType: parseType_1,
- timescale: timescale2,
- startTime,
- compositionStartTime,
- videoTrackIds: getVideoTrackIds,
- tracks: getTracks,
- getTimescaleFromMediaHeader
- };
- var parsePid = function parsePid2(packet) {
- var pid = packet[1] & 31;
- pid <<= 8;
- pid |= packet[2];
- return pid;
- };
- var parsePayloadUnitStartIndicator = function parsePayloadUnitStartIndicator2(packet) {
- return !!(packet[1] & 64);
- };
- var parseAdaptionField = function parseAdaptionField2(packet) {
- var offset = 0;
- if ((packet[3] & 48) >>> 4 > 1) {
- offset += packet[4] + 1;
- }
- return offset;
- };
- var parseType = function parseType2(packet, pmtPid) {
- var pid = parsePid(packet);
- if (pid === 0) {
- return "pat";
- } else if (pid === pmtPid) {
- return "pmt";
- } else if (pmtPid) {
- return "pes";
- }
- return null;
- };
- var parsePat = function parsePat2(packet) {
- var pusi = parsePayloadUnitStartIndicator(packet);
- var offset = 4 + parseAdaptionField(packet);
- if (pusi) {
- offset += packet[offset] + 1;
- }
- return (packet[offset + 10] & 31) << 8 | packet[offset + 11];
- };
- var parsePmt = function parsePmt2(packet) {
- var programMapTable = {};
- var pusi = parsePayloadUnitStartIndicator(packet);
- var payloadOffset = 4 + parseAdaptionField(packet);
- if (pusi) {
- payloadOffset += packet[payloadOffset] + 1;
- }
- if (!(packet[payloadOffset + 5] & 1)) {
- return;
- }
- var sectionLength, tableEnd, programInfoLength;
- sectionLength = (packet[payloadOffset + 1] & 15) << 8 | packet[payloadOffset + 2];
- tableEnd = 3 + sectionLength - 4;
- programInfoLength = (packet[payloadOffset + 10] & 15) << 8 | packet[payloadOffset + 11];
- var offset = 12 + programInfoLength;
- while (offset < tableEnd) {
- var i2 = payloadOffset + offset;
- programMapTable[(packet[i2 + 1] & 31) << 8 | packet[i2 + 2]] = packet[i2];
- offset += ((packet[i2 + 3] & 15) << 8 | packet[i2 + 4]) + 5;
- }
- return programMapTable;
- };
- var parsePesType = function parsePesType2(packet, programMapTable) {
- var pid = parsePid(packet);
- var type3 = programMapTable[pid];
- switch (type3) {
- case streamTypes.H264_STREAM_TYPE:
- return "video";
- case streamTypes.ADTS_STREAM_TYPE:
- return "audio";
- case streamTypes.METADATA_STREAM_TYPE:
- return "timed-metadata";
- default:
- return null;
- }
- };
- var parsePesTime = function parsePesTime2(packet) {
- var pusi = parsePayloadUnitStartIndicator(packet);
- if (!pusi) {
- return null;
- }
- var offset = 4 + parseAdaptionField(packet);
- if (offset >= packet.byteLength) {
- return null;
- }
- var pes = null;
- var ptsDtsFlags;
- ptsDtsFlags = packet[offset + 7];
- if (ptsDtsFlags & 192) {
- pes = {};
- pes.pts = (packet[offset + 9] & 14) << 27 | (packet[offset + 10] & 255) << 20 | (packet[offset + 11] & 254) << 12 | (packet[offset + 12] & 255) << 5 | (packet[offset + 13] & 254) >>> 3;
- pes.pts *= 4;
- pes.pts += (packet[offset + 13] & 6) >>> 1;
- pes.dts = pes.pts;
- if (ptsDtsFlags & 64) {
- pes.dts = (packet[offset + 14] & 14) << 27 | (packet[offset + 15] & 255) << 20 | (packet[offset + 16] & 254) << 12 | (packet[offset + 17] & 255) << 5 | (packet[offset + 18] & 254) >>> 3;
- pes.dts *= 4;
- pes.dts += (packet[offset + 18] & 6) >>> 1;
- }
- }
- return pes;
- };
- var parseNalUnitType = function parseNalUnitType2(type3) {
- switch (type3) {
- case 5:
- return "slice_layer_without_partitioning_rbsp_idr";
- case 6:
- return "sei_rbsp";
- case 7:
- return "seq_parameter_set_rbsp";
- case 8:
- return "pic_parameter_set_rbsp";
- case 9:
- return "access_unit_delimiter_rbsp";
- default:
- return null;
- }
- };
- var videoPacketContainsKeyFrame = function videoPacketContainsKeyFrame2(packet) {
- var offset = 4 + parseAdaptionField(packet);
- var frameBuffer = packet.subarray(offset);
- var frameI = 0;
- var frameSyncPoint = 0;
- var foundKeyFrame = false;
- var nalType;
- for (; frameSyncPoint < frameBuffer.byteLength - 3; frameSyncPoint++) {
- if (frameBuffer[frameSyncPoint + 2] === 1) {
- frameI = frameSyncPoint + 5;
- break;
- }
- }
- while (frameI < frameBuffer.byteLength) {
- switch (frameBuffer[frameI]) {
- case 0:
- if (frameBuffer[frameI - 1] !== 0) {
- frameI += 2;
- break;
- } else if (frameBuffer[frameI - 2] !== 0) {
- frameI++;
- break;
- }
- if (frameSyncPoint + 3 !== frameI - 2) {
- nalType = parseNalUnitType(frameBuffer[frameSyncPoint + 3] & 31);
- if (nalType === "slice_layer_without_partitioning_rbsp_idr") {
- foundKeyFrame = true;
- }
- }
- do {
- frameI++;
- } while (frameBuffer[frameI] !== 1 && frameI < frameBuffer.length);
- frameSyncPoint = frameI - 2;
- frameI += 3;
- break;
- case 1:
- if (frameBuffer[frameI - 1] !== 0 || frameBuffer[frameI - 2] !== 0) {
- frameI += 3;
- break;
- }
- nalType = parseNalUnitType(frameBuffer[frameSyncPoint + 3] & 31);
- if (nalType === "slice_layer_without_partitioning_rbsp_idr") {
- foundKeyFrame = true;
- }
- frameSyncPoint = frameI - 2;
- frameI += 3;
- break;
- default:
- frameI += 3;
- break;
- }
- }
- frameBuffer = frameBuffer.subarray(frameSyncPoint);
- frameI -= frameSyncPoint;
- frameSyncPoint = 0;
- if (frameBuffer && frameBuffer.byteLength > 3) {
- nalType = parseNalUnitType(frameBuffer[frameSyncPoint + 3] & 31);
- if (nalType === "slice_layer_without_partitioning_rbsp_idr") {
- foundKeyFrame = true;
- }
- }
- return foundKeyFrame;
- };
- var probe$1 = {
- parseType,
- parsePat,
- parsePmt,
- parsePayloadUnitStartIndicator,
- parsePesType,
- parsePesTime,
- videoPacketContainsKeyFrame
- };
- var handleRollover = timestampRolloverStream.handleRollover;
- var probe = {};
- probe.ts = probe$1;
- probe.aac = utils2;
- var ONE_SECOND_IN_TS2 = clock2.ONE_SECOND_IN_TS;
- var MP2T_PACKET_LENGTH = 188, SYNC_BYTE = 71;
- var parsePsi_ = function parsePsi_2(bytes, pmt) {
- var startIndex = 0, endIndex = MP2T_PACKET_LENGTH, packet, type3;
- while (endIndex < bytes.byteLength) {
- if (bytes[startIndex] === SYNC_BYTE && bytes[endIndex] === SYNC_BYTE) {
- packet = bytes.subarray(startIndex, endIndex);
- type3 = probe.ts.parseType(packet, pmt.pid);
- switch (type3) {
- case "pat":
- pmt.pid = probe.ts.parsePat(packet);
- break;
- case "pmt":
- var table = probe.ts.parsePmt(packet);
- pmt.table = pmt.table || {};
- Object.keys(table).forEach(function(key) {
- pmt.table[key] = table[key];
- });
- break;
- }
- startIndex += MP2T_PACKET_LENGTH;
- endIndex += MP2T_PACKET_LENGTH;
- continue;
- }
- startIndex++;
- endIndex++;
- }
- };
- var parseAudioPes_ = function parseAudioPes_2(bytes, pmt, result) {
- var startIndex = 0, endIndex = MP2T_PACKET_LENGTH, packet, type3, pesType, pusi, parsed;
- var endLoop = false;
- while (endIndex <= bytes.byteLength) {
- if (bytes[startIndex] === SYNC_BYTE && (bytes[endIndex] === SYNC_BYTE || endIndex === bytes.byteLength)) {
- packet = bytes.subarray(startIndex, endIndex);
- type3 = probe.ts.parseType(packet, pmt.pid);
- switch (type3) {
- case "pes":
- pesType = probe.ts.parsePesType(packet, pmt.table);
- pusi = probe.ts.parsePayloadUnitStartIndicator(packet);
- if (pesType === "audio" && pusi) {
- parsed = probe.ts.parsePesTime(packet);
- if (parsed) {
- parsed.type = "audio";
- result.audio.push(parsed);
- endLoop = true;
- }
- }
- break;
- }
- if (endLoop) {
- break;
- }
- startIndex += MP2T_PACKET_LENGTH;
- endIndex += MP2T_PACKET_LENGTH;
- continue;
- }
- startIndex++;
- endIndex++;
- }
- endIndex = bytes.byteLength;
- startIndex = endIndex - MP2T_PACKET_LENGTH;
- endLoop = false;
- while (startIndex >= 0) {
- if (bytes[startIndex] === SYNC_BYTE && (bytes[endIndex] === SYNC_BYTE || endIndex === bytes.byteLength)) {
- packet = bytes.subarray(startIndex, endIndex);
- type3 = probe.ts.parseType(packet, pmt.pid);
- switch (type3) {
- case "pes":
- pesType = probe.ts.parsePesType(packet, pmt.table);
- pusi = probe.ts.parsePayloadUnitStartIndicator(packet);
- if (pesType === "audio" && pusi) {
- parsed = probe.ts.parsePesTime(packet);
- if (parsed) {
- parsed.type = "audio";
- result.audio.push(parsed);
- endLoop = true;
- }
- }
- break;
- }
- if (endLoop) {
- break;
- }
- startIndex -= MP2T_PACKET_LENGTH;
- endIndex -= MP2T_PACKET_LENGTH;
- continue;
- }
- startIndex--;
- endIndex--;
- }
- };
- var parseVideoPes_ = function parseVideoPes_2(bytes, pmt, result) {
- var startIndex = 0, endIndex = MP2T_PACKET_LENGTH, packet, type3, pesType, pusi, parsed, frame, i2, pes;
- var endLoop = false;
- var currentFrame = {
- data: [],
- size: 0
- };
- while (endIndex < bytes.byteLength) {
- if (bytes[startIndex] === SYNC_BYTE && bytes[endIndex] === SYNC_BYTE) {
- packet = bytes.subarray(startIndex, endIndex);
- type3 = probe.ts.parseType(packet, pmt.pid);
- switch (type3) {
- case "pes":
- pesType = probe.ts.parsePesType(packet, pmt.table);
- pusi = probe.ts.parsePayloadUnitStartIndicator(packet);
- if (pesType === "video") {
- if (pusi && !endLoop) {
- parsed = probe.ts.parsePesTime(packet);
- if (parsed) {
- parsed.type = "video";
- result.video.push(parsed);
- endLoop = true;
- }
- }
- if (!result.firstKeyFrame) {
- if (pusi) {
- if (currentFrame.size !== 0) {
- frame = new Uint8Array(currentFrame.size);
- i2 = 0;
- while (currentFrame.data.length) {
- pes = currentFrame.data.shift();
- frame.set(pes, i2);
- i2 += pes.byteLength;
- }
- if (probe.ts.videoPacketContainsKeyFrame(frame)) {
- var firstKeyFrame = probe.ts.parsePesTime(frame);
- if (firstKeyFrame) {
- result.firstKeyFrame = firstKeyFrame;
- result.firstKeyFrame.type = "video";
- } else {
- console.warn("Failed to extract PTS/DTS from PES at first keyframe. This could be an unusual TS segment, or else mux.js did not parse your TS segment correctly. If you know your TS segments do contain PTS/DTS on keyframes please file a bug report! You can try ffprobe to double check for yourself.");
- }
- }
- currentFrame.size = 0;
- }
- }
- currentFrame.data.push(packet);
- currentFrame.size += packet.byteLength;
- }
- }
- break;
- }
- if (endLoop && result.firstKeyFrame) {
- break;
- }
- startIndex += MP2T_PACKET_LENGTH;
- endIndex += MP2T_PACKET_LENGTH;
- continue;
- }
- startIndex++;
- endIndex++;
- }
- endIndex = bytes.byteLength;
- startIndex = endIndex - MP2T_PACKET_LENGTH;
- endLoop = false;
- while (startIndex >= 0) {
- if (bytes[startIndex] === SYNC_BYTE && bytes[endIndex] === SYNC_BYTE) {
- packet = bytes.subarray(startIndex, endIndex);
- type3 = probe.ts.parseType(packet, pmt.pid);
- switch (type3) {
- case "pes":
- pesType = probe.ts.parsePesType(packet, pmt.table);
- pusi = probe.ts.parsePayloadUnitStartIndicator(packet);
- if (pesType === "video" && pusi) {
- parsed = probe.ts.parsePesTime(packet);
- if (parsed) {
- parsed.type = "video";
- result.video.push(parsed);
- endLoop = true;
- }
- }
- break;
- }
- if (endLoop) {
- break;
- }
- startIndex -= MP2T_PACKET_LENGTH;
- endIndex -= MP2T_PACKET_LENGTH;
- continue;
- }
- startIndex--;
- endIndex--;
- }
- };
- var adjustTimestamp_ = function adjustTimestamp_2(segmentInfo, baseTimestamp) {
- if (segmentInfo.audio && segmentInfo.audio.length) {
- var audioBaseTimestamp = baseTimestamp;
- if (typeof audioBaseTimestamp === "undefined" || isNaN(audioBaseTimestamp)) {
- audioBaseTimestamp = segmentInfo.audio[0].dts;
- }
- segmentInfo.audio.forEach(function(info) {
- info.dts = handleRollover(info.dts, audioBaseTimestamp);
- info.pts = handleRollover(info.pts, audioBaseTimestamp);
- info.dtsTime = info.dts / ONE_SECOND_IN_TS2;
- info.ptsTime = info.pts / ONE_SECOND_IN_TS2;
- });
- }
- if (segmentInfo.video && segmentInfo.video.length) {
- var videoBaseTimestamp = baseTimestamp;
- if (typeof videoBaseTimestamp === "undefined" || isNaN(videoBaseTimestamp)) {
- videoBaseTimestamp = segmentInfo.video[0].dts;
- }
- segmentInfo.video.forEach(function(info) {
- info.dts = handleRollover(info.dts, videoBaseTimestamp);
- info.pts = handleRollover(info.pts, videoBaseTimestamp);
- info.dtsTime = info.dts / ONE_SECOND_IN_TS2;
- info.ptsTime = info.pts / ONE_SECOND_IN_TS2;
- });
- if (segmentInfo.firstKeyFrame) {
- var frame = segmentInfo.firstKeyFrame;
- frame.dts = handleRollover(frame.dts, videoBaseTimestamp);
- frame.pts = handleRollover(frame.pts, videoBaseTimestamp);
- frame.dtsTime = frame.dts / ONE_SECOND_IN_TS2;
- frame.ptsTime = frame.pts / ONE_SECOND_IN_TS2;
- }
- }
- };
- var inspectAac_ = function inspectAac_2(bytes) {
- var endLoop = false, audioCount = 0, sampleRate = null, timestamp = null, frameSize = 0, byteIndex = 0, packet;
- while (bytes.length - byteIndex >= 3) {
- var type3 = probe.aac.parseType(bytes, byteIndex);
- switch (type3) {
- case "timed-metadata":
- if (bytes.length - byteIndex < 10) {
- endLoop = true;
- break;
- }
- frameSize = probe.aac.parseId3TagSize(bytes, byteIndex);
- if (frameSize > bytes.length) {
- endLoop = true;
- break;
- }
- if (timestamp === null) {
- packet = bytes.subarray(byteIndex, byteIndex + frameSize);
- timestamp = probe.aac.parseAacTimestamp(packet);
- }
- byteIndex += frameSize;
- break;
- case "audio":
- if (bytes.length - byteIndex < 7) {
- endLoop = true;
- break;
- }
- frameSize = probe.aac.parseAdtsSize(bytes, byteIndex);
- if (frameSize > bytes.length) {
- endLoop = true;
- break;
- }
- if (sampleRate === null) {
- packet = bytes.subarray(byteIndex, byteIndex + frameSize);
- sampleRate = probe.aac.parseSampleRate(packet);
- }
- audioCount++;
- byteIndex += frameSize;
- break;
- default:
- byteIndex++;
- break;
- }
- if (endLoop) {
- return null;
- }
- }
- if (sampleRate === null || timestamp === null) {
- return null;
- }
- var audioTimescale = ONE_SECOND_IN_TS2 / sampleRate;
- var result = {
- audio: [{
- type: "audio",
- dts: timestamp,
- pts: timestamp
- }, {
- type: "audio",
- dts: timestamp + audioCount * 1024 * audioTimescale,
- pts: timestamp + audioCount * 1024 * audioTimescale
- }]
- };
- return result;
- };
- var inspectTs_ = function inspectTs_2(bytes) {
- var pmt = {
- pid: null,
- table: null
- };
- var result = {};
- parsePsi_(bytes, pmt);
- for (var pid in pmt.table) {
- if (pmt.table.hasOwnProperty(pid)) {
- var type3 = pmt.table[pid];
- switch (type3) {
- case streamTypes.H264_STREAM_TYPE:
- result.video = [];
- parseVideoPes_(bytes, pmt, result);
- if (result.video.length === 0) {
- delete result.video;
- }
- break;
- case streamTypes.ADTS_STREAM_TYPE:
- result.audio = [];
- parseAudioPes_(bytes, pmt, result);
- if (result.audio.length === 0) {
- delete result.audio;
- }
- break;
- }
- }
- }
- return result;
- };
- var inspect = function inspect2(bytes, baseTimestamp) {
- var isAacData = probe.aac.isLikelyAacData(bytes);
- var result;
- if (isAacData) {
- result = inspectAac_(bytes);
- } else {
- result = inspectTs_(bytes);
- }
- if (!result || !result.audio && !result.video) {
- return null;
- }
- adjustTimestamp_(result, baseTimestamp);
- return result;
- };
- var tsInspector = {
- inspect,
- parseAudioPes_
- };
- var wireTransmuxerEvents = function wireTransmuxerEvents2(self2, transmuxer2) {
- transmuxer2.on("data", function(segment) {
- var initArray = segment.initSegment;
- segment.initSegment = {
- data: initArray.buffer,
- byteOffset: initArray.byteOffset,
- byteLength: initArray.byteLength
- };
- var typedArray = segment.data;
- segment.data = typedArray.buffer;
- self2.postMessage({
- action: "data",
- segment,
- byteOffset: typedArray.byteOffset,
- byteLength: typedArray.byteLength
- }, [segment.data]);
- });
- transmuxer2.on("done", function(data) {
- self2.postMessage({
- action: "done"
- });
- });
- transmuxer2.on("gopInfo", function(gopInfo) {
- self2.postMessage({
- action: "gopInfo",
- gopInfo
- });
- });
- transmuxer2.on("videoSegmentTimingInfo", function(timingInfo) {
- var videoSegmentTimingInfo = {
- start: {
- decode: clock2.videoTsToSeconds(timingInfo.start.dts),
- presentation: clock2.videoTsToSeconds(timingInfo.start.pts)
- },
- end: {
- decode: clock2.videoTsToSeconds(timingInfo.end.dts),
- presentation: clock2.videoTsToSeconds(timingInfo.end.pts)
- },
- baseMediaDecodeTime: clock2.videoTsToSeconds(timingInfo.baseMediaDecodeTime)
- };
- if (timingInfo.prependedContentDuration) {
- videoSegmentTimingInfo.prependedContentDuration = clock2.videoTsToSeconds(timingInfo.prependedContentDuration);
- }
- self2.postMessage({
- action: "videoSegmentTimingInfo",
- videoSegmentTimingInfo
- });
- });
- transmuxer2.on("audioSegmentTimingInfo", function(timingInfo) {
- var audioSegmentTimingInfo = {
- start: {
- decode: clock2.videoTsToSeconds(timingInfo.start.dts),
- presentation: clock2.videoTsToSeconds(timingInfo.start.pts)
- },
- end: {
- decode: clock2.videoTsToSeconds(timingInfo.end.dts),
- presentation: clock2.videoTsToSeconds(timingInfo.end.pts)
- },
- baseMediaDecodeTime: clock2.videoTsToSeconds(timingInfo.baseMediaDecodeTime)
- };
- if (timingInfo.prependedContentDuration) {
- audioSegmentTimingInfo.prependedContentDuration = clock2.videoTsToSeconds(timingInfo.prependedContentDuration);
- }
- self2.postMessage({
- action: "audioSegmentTimingInfo",
- audioSegmentTimingInfo
- });
- });
- transmuxer2.on("id3Frame", function(id3Frame) {
- self2.postMessage({
- action: "id3Frame",
- id3Frame
- });
- });
- transmuxer2.on("caption", function(caption) {
- self2.postMessage({
- action: "caption",
- caption
- });
- });
- transmuxer2.on("trackinfo", function(trackInfo) {
- self2.postMessage({
- action: "trackinfo",
- trackInfo
- });
- });
- transmuxer2.on("audioTimingInfo", function(audioTimingInfo) {
- self2.postMessage({
- action: "audioTimingInfo",
- audioTimingInfo: {
- start: clock2.videoTsToSeconds(audioTimingInfo.start),
- end: clock2.videoTsToSeconds(audioTimingInfo.end)
- }
- });
- });
- transmuxer2.on("videoTimingInfo", function(videoTimingInfo) {
- self2.postMessage({
- action: "videoTimingInfo",
- videoTimingInfo: {
- start: clock2.videoTsToSeconds(videoTimingInfo.start),
- end: clock2.videoTsToSeconds(videoTimingInfo.end)
- }
- });
- });
- transmuxer2.on("log", function(log2) {
- self2.postMessage({
- action: "log",
- log: log2
- });
- });
- };
- var MessageHandlers = /* @__PURE__ */ function() {
- function MessageHandlers2(self2, options2) {
- this.options = options2 || {};
- this.self = self2;
- this.init();
- }
- var _proto = MessageHandlers2.prototype;
- _proto.init = function init() {
- if (this.transmuxer) {
- this.transmuxer.dispose();
- }
- this.transmuxer = new transmuxer.Transmuxer(this.options);
- wireTransmuxerEvents(this.self, this.transmuxer);
- };
- _proto.pushMp4Captions = function pushMp4Captions(data) {
- if (!this.captionParser) {
- this.captionParser = new captionParser();
- this.captionParser.init();
- }
- var segment = new Uint8Array(data.data, data.byteOffset, data.byteLength);
- var parsed = this.captionParser.parse(segment, data.trackIds, data.timescales);
- this.self.postMessage({
- action: "mp4Captions",
- captions: parsed && parsed.captions || [],
- logs: parsed && parsed.logs || [],
- data: segment.buffer
- }, [segment.buffer]);
- };
- _proto.probeMp4StartTime = function probeMp4StartTime(_ref) {
- var timescales = _ref.timescales, data = _ref.data;
- var startTime2 = probe$2.startTime(timescales, data);
- this.self.postMessage({
- action: "probeMp4StartTime",
- startTime: startTime2,
- data
- }, [data.buffer]);
- };
- _proto.probeMp4Tracks = function probeMp4Tracks(_ref2) {
- var data = _ref2.data;
- var tracks = probe$2.tracks(data);
- this.self.postMessage({
- action: "probeMp4Tracks",
- tracks,
- data
- }, [data.buffer]);
- };
- _proto.probeTs = function probeTs(_ref3) {
- var data = _ref3.data, baseStartTime = _ref3.baseStartTime;
- var tsStartTime = typeof baseStartTime === "number" && !isNaN(baseStartTime) ? baseStartTime * clock2.ONE_SECOND_IN_TS : void 0;
- var timeInfo = tsInspector.inspect(data, tsStartTime);
- var result = null;
- if (timeInfo) {
- result = {
- hasVideo: timeInfo.video && timeInfo.video.length === 2 || false,
- hasAudio: timeInfo.audio && timeInfo.audio.length === 2 || false
- };
- if (result.hasVideo) {
- result.videoStart = timeInfo.video[0].ptsTime;
- }
- if (result.hasAudio) {
- result.audioStart = timeInfo.audio[0].ptsTime;
- }
- }
- this.self.postMessage({
- action: "probeTs",
- result,
- data
- }, [data.buffer]);
- };
- _proto.clearAllMp4Captions = function clearAllMp4Captions() {
- if (this.captionParser) {
- this.captionParser.clearAllCaptions();
- }
- };
- _proto.clearParsedMp4Captions = function clearParsedMp4Captions() {
- if (this.captionParser) {
- this.captionParser.clearParsedCaptions();
- }
- };
- _proto.push = function push(data) {
- var segment = new Uint8Array(data.data, data.byteOffset, data.byteLength);
- this.transmuxer.push(segment);
- };
- _proto.reset = function reset3() {
- this.transmuxer.reset();
- };
- _proto.setTimestampOffset = function setTimestampOffset(data) {
- var timestampOffset2 = data.timestampOffset || 0;
- this.transmuxer.setBaseMediaDecodeTime(Math.round(clock2.secondsToVideoTs(timestampOffset2)));
- };
- _proto.setAudioAppendStart = function setAudioAppendStart(data) {
- this.transmuxer.setAudioAppendStart(Math.ceil(clock2.secondsToVideoTs(data.appendStart)));
- };
- _proto.setRemux = function setRemux(data) {
- this.transmuxer.setRemux(data.remux);
- };
- _proto.flush = function flush(data) {
- this.transmuxer.flush();
- self.postMessage({
- action: "done",
- type: "transmuxed"
- });
- };
- _proto.endTimeline = function endTimeline3() {
- this.transmuxer.endTimeline();
- self.postMessage({
- action: "endedtimeline",
- type: "transmuxed"
- });
- };
- _proto.alignGopsWith = function alignGopsWith(data) {
- this.transmuxer.alignGopsWith(data.gopsToAlignWith.slice());
- };
- return MessageHandlers2;
- }();
- self.onmessage = function(event2) {
- if (event2.data.action === "init" && event2.data.options) {
- this.messageHandlers = new MessageHandlers(self, event2.data.options);
- return;
- }
- if (!this.messageHandlers) {
- this.messageHandlers = new MessageHandlers(self);
- }
- if (event2.data && event2.data.action && event2.data.action !== "init") {
- if (this.messageHandlers[event2.data.action]) {
- this.messageHandlers[event2.data.action](event2.data);
- }
- }
- };
- }));
- var TransmuxWorker = factory(workerCode$1);
- var handleData_ = function handleData_2(event2, transmuxedData, callback2) {
- var _event$data$segment = event2.data.segment, type2 = _event$data$segment.type, initSegment = _event$data$segment.initSegment, captions = _event$data$segment.captions, captionStreams = _event$data$segment.captionStreams, metadata = _event$data$segment.metadata, videoFrameDtsTime = _event$data$segment.videoFrameDtsTime, videoFramePtsTime = _event$data$segment.videoFramePtsTime;
- transmuxedData.buffer.push({
- captions,
- captionStreams,
- metadata
- });
- var boxes = event2.data.segment.boxes || {
- data: event2.data.segment.data
- };
- var result = {
- type: type2,
- data: new Uint8Array(boxes.data, boxes.data.byteOffset, boxes.data.byteLength),
- initSegment: new Uint8Array(initSegment.data, initSegment.byteOffset, initSegment.byteLength)
- };
- if (typeof videoFrameDtsTime !== "undefined") {
- result.videoFrameDtsTime = videoFrameDtsTime;
- }
- if (typeof videoFramePtsTime !== "undefined") {
- result.videoFramePtsTime = videoFramePtsTime;
- }
- callback2(result);
- };
- var handleDone_ = function handleDone_2(_ref) {
- var transmuxedData = _ref.transmuxedData, callback2 = _ref.callback;
- transmuxedData.buffer = [];
- callback2(transmuxedData);
- };
- var handleGopInfo_ = function handleGopInfo_2(event2, transmuxedData) {
- transmuxedData.gopInfo = event2.data.gopInfo;
- };
- var processTransmux = function processTransmux2(options2) {
- var transmuxer = options2.transmuxer, bytes = options2.bytes, audioAppendStart = options2.audioAppendStart, gopsToAlignWith = options2.gopsToAlignWith, remux = options2.remux, onData = options2.onData, onTrackInfo = options2.onTrackInfo, onAudioTimingInfo = options2.onAudioTimingInfo, onVideoTimingInfo = options2.onVideoTimingInfo, onVideoSegmentTimingInfo = options2.onVideoSegmentTimingInfo, onAudioSegmentTimingInfo = options2.onAudioSegmentTimingInfo, onId3 = options2.onId3, onCaptions = options2.onCaptions, onDone = options2.onDone, onEndedTimeline = options2.onEndedTimeline, onTransmuxerLog = options2.onTransmuxerLog, isEndOfTimeline = options2.isEndOfTimeline;
- var transmuxedData = {
- buffer: []
- };
- var waitForEndedTimelineEvent = isEndOfTimeline;
- var handleMessage = function handleMessage2(event2) {
- if (transmuxer.currentTransmux !== options2) {
- return;
- }
- if (event2.data.action === "data") {
- handleData_(event2, transmuxedData, onData);
- }
- if (event2.data.action === "trackinfo") {
- onTrackInfo(event2.data.trackInfo);
- }
- if (event2.data.action === "gopInfo") {
- handleGopInfo_(event2, transmuxedData);
- }
- if (event2.data.action === "audioTimingInfo") {
- onAudioTimingInfo(event2.data.audioTimingInfo);
- }
- if (event2.data.action === "videoTimingInfo") {
- onVideoTimingInfo(event2.data.videoTimingInfo);
- }
- if (event2.data.action === "videoSegmentTimingInfo") {
- onVideoSegmentTimingInfo(event2.data.videoSegmentTimingInfo);
- }
- if (event2.data.action === "audioSegmentTimingInfo") {
- onAudioSegmentTimingInfo(event2.data.audioSegmentTimingInfo);
- }
- if (event2.data.action === "id3Frame") {
- onId3([event2.data.id3Frame], event2.data.id3Frame.dispatchType);
- }
- if (event2.data.action === "caption") {
- onCaptions(event2.data.caption);
- }
- if (event2.data.action === "endedtimeline") {
- waitForEndedTimelineEvent = false;
- onEndedTimeline();
- }
- if (event2.data.action === "log") {
- onTransmuxerLog(event2.data.log);
- }
- if (event2.data.type !== "transmuxed") {
- return;
- }
- if (waitForEndedTimelineEvent) {
- return;
- }
- transmuxer.onmessage = null;
- handleDone_({
- transmuxedData,
- callback: onDone
- });
- dequeue(transmuxer);
- };
- transmuxer.onmessage = handleMessage;
- if (audioAppendStart) {
- transmuxer.postMessage({
- action: "setAudioAppendStart",
- appendStart: audioAppendStart
- });
- }
- if (Array.isArray(gopsToAlignWith)) {
- transmuxer.postMessage({
- action: "alignGopsWith",
- gopsToAlignWith
- });
- }
- if (typeof remux !== "undefined") {
- transmuxer.postMessage({
- action: "setRemux",
- remux
- });
- }
- if (bytes.byteLength) {
- var buffer = bytes instanceof ArrayBuffer ? bytes : bytes.buffer;
- var byteOffset = bytes instanceof ArrayBuffer ? 0 : bytes.byteOffset;
- transmuxer.postMessage({
- action: "push",
- data: buffer,
- byteOffset,
- byteLength: bytes.byteLength
- }, [buffer]);
- }
- if (isEndOfTimeline) {
- transmuxer.postMessage({
- action: "endTimeline"
- });
- }
- transmuxer.postMessage({
- action: "flush"
- });
- };
- var dequeue = function dequeue2(transmuxer) {
- transmuxer.currentTransmux = null;
- if (transmuxer.transmuxQueue.length) {
- transmuxer.currentTransmux = transmuxer.transmuxQueue.shift();
- if (typeof transmuxer.currentTransmux === "function") {
- transmuxer.currentTransmux();
- } else {
- processTransmux(transmuxer.currentTransmux);
- }
- }
- };
- var processAction = function processAction2(transmuxer, action) {
- transmuxer.postMessage({
- action
- });
- dequeue(transmuxer);
- };
- var enqueueAction = function enqueueAction2(action, transmuxer) {
- if (!transmuxer.currentTransmux) {
- transmuxer.currentTransmux = action;
- processAction(transmuxer, action);
- return;
- }
- transmuxer.transmuxQueue.push(processAction.bind(null, transmuxer, action));
- };
- var reset = function reset2(transmuxer) {
- enqueueAction("reset", transmuxer);
- };
- var endTimeline = function endTimeline2(transmuxer) {
- enqueueAction("endTimeline", transmuxer);
- };
- var transmux = function transmux2(options2) {
- if (!options2.transmuxer.currentTransmux) {
- options2.transmuxer.currentTransmux = options2;
- processTransmux(options2);
- return;
- }
- options2.transmuxer.transmuxQueue.push(options2);
- };
- var createTransmuxer = function createTransmuxer2(options2) {
- var transmuxer = new TransmuxWorker();
- transmuxer.currentTransmux = null;
- transmuxer.transmuxQueue = [];
- var term = transmuxer.terminate;
- transmuxer.terminate = function() {
- transmuxer.currentTransmux = null;
- transmuxer.transmuxQueue.length = 0;
- return term.call(transmuxer);
- };
- transmuxer.postMessage({
- action: "init",
- options: options2
- });
- return transmuxer;
- };
- var segmentTransmuxer = {
- reset,
- endTimeline,
- transmux,
- createTransmuxer
- };
- var workerCallback = function workerCallback2(options2) {
- var transmuxer = options2.transmuxer;
- var endAction = options2.endAction || options2.action;
- var callback2 = options2.callback;
- var message = _extends$2({}, options2, {
- endAction: null,
- transmuxer: null,
- callback: null
- });
- var listenForEndEvent = function listenForEndEvent2(event2) {
- if (event2.data.action !== endAction) {
- return;
- }
- transmuxer.removeEventListener("message", listenForEndEvent2);
- if (event2.data.data) {
- event2.data.data = new Uint8Array(event2.data.data, options2.byteOffset || 0, options2.byteLength || event2.data.data.byteLength);
- if (options2.data) {
- options2.data = event2.data.data;
- }
- }
- callback2(event2.data);
- };
- transmuxer.addEventListener("message", listenForEndEvent);
- if (options2.data) {
- var isArrayBuffer = options2.data instanceof ArrayBuffer;
- message.byteOffset = isArrayBuffer ? 0 : options2.data.byteOffset;
- message.byteLength = options2.data.byteLength;
- var transfers = [isArrayBuffer ? options2.data : options2.data.buffer];
- transmuxer.postMessage(message, transfers);
- } else {
- transmuxer.postMessage(message);
- }
- };
- var REQUEST_ERRORS = {
- FAILURE: 2,
- TIMEOUT: -101,
- ABORTED: -102
- };
- var abortAll = function abortAll2(activeXhrs) {
- activeXhrs.forEach(function(xhr) {
- xhr.abort();
- });
- };
- var getRequestStats = function getRequestStats2(request) {
- return {
- bandwidth: request.bandwidth,
- bytesReceived: request.bytesReceived || 0,
- roundTripTime: request.roundTripTime || 0
- };
- };
- var getProgressStats = function getProgressStats2(progressEvent) {
- var request = progressEvent.target;
- var roundTripTime = Date.now() - request.requestTime;
- var stats = {
- bandwidth: Infinity,
- bytesReceived: 0,
- roundTripTime: roundTripTime || 0
- };
- stats.bytesReceived = progressEvent.loaded;
- stats.bandwidth = Math.floor(stats.bytesReceived / stats.roundTripTime * 8 * 1e3);
- return stats;
- };
- var handleErrors = function handleErrors2(error, request) {
- if (request.timedout) {
- return {
- status: request.status,
- message: "HLS request timed-out at URL: " + request.uri,
- code: REQUEST_ERRORS.TIMEOUT,
- xhr: request
- };
- }
- if (request.aborted) {
- return {
- status: request.status,
- message: "HLS request aborted at URL: " + request.uri,
- code: REQUEST_ERRORS.ABORTED,
- xhr: request
- };
- }
- if (error) {
- return {
- status: request.status,
- message: "HLS request errored at URL: " + request.uri,
- code: REQUEST_ERRORS.FAILURE,
- xhr: request
- };
- }
- if (request.responseType === "arraybuffer" && request.response.byteLength === 0) {
- return {
- status: request.status,
- message: "Empty HLS response at URL: " + request.uri,
- code: REQUEST_ERRORS.FAILURE,
- xhr: request
- };
- }
- return null;
- };
- var handleKeyResponse = function handleKeyResponse2(segment, objects, finishProcessingFn) {
- return function(error, request) {
- var response = request.response;
- var errorObj = handleErrors(error, request);
- if (errorObj) {
- return finishProcessingFn(errorObj, segment);
- }
- if (response.byteLength !== 16) {
- return finishProcessingFn({
- status: request.status,
- message: "Invalid HLS key at URL: " + request.uri,
- code: REQUEST_ERRORS.FAILURE,
- xhr: request
- }, segment);
- }
- var view = new DataView(response);
- var bytes = new Uint32Array([view.getUint32(0), view.getUint32(4), view.getUint32(8), view.getUint32(12)]);
- for (var i2 = 0; i2 < objects.length; i2++) {
- objects[i2].bytes = bytes;
- }
- return finishProcessingFn(null, segment);
- };
- };
- var parseInitSegment = function parseInitSegment2(segment, _callback) {
- var type2 = detectContainerForBytes2(segment.map.bytes);
- if (type2 !== "mp4") {
- var uri = segment.map.resolvedUri || segment.map.uri;
- return _callback({
- internal: true,
- message: "Found unsupported " + (type2 || "unknown") + " container for initialization segment at URL: " + uri,
- code: REQUEST_ERRORS.FAILURE
- });
- }
- workerCallback({
- action: "probeMp4Tracks",
- data: segment.map.bytes,
- transmuxer: segment.transmuxer,
- callback: function callback2(_ref) {
- var tracks = _ref.tracks, data = _ref.data;
- segment.map.bytes = data;
- tracks.forEach(function(track) {
- segment.map.tracks = segment.map.tracks || {};
- if (segment.map.tracks[track.type]) {
- return;
- }
- segment.map.tracks[track.type] = track;
- if (typeof track.id === "number" && track.timescale) {
- segment.map.timescales = segment.map.timescales || {};
- segment.map.timescales[track.id] = track.timescale;
- }
- });
- return _callback(null);
- }
- });
- };
- var handleInitSegmentResponse = function handleInitSegmentResponse2(_ref2) {
- var segment = _ref2.segment, finishProcessingFn = _ref2.finishProcessingFn;
- return function(error, request) {
- var errorObj = handleErrors(error, request);
- if (errorObj) {
- return finishProcessingFn(errorObj, segment);
- }
- var bytes = new Uint8Array(request.response);
- if (segment.map.key) {
- segment.map.encryptedBytes = bytes;
- return finishProcessingFn(null, segment);
- }
- segment.map.bytes = bytes;
- parseInitSegment(segment, function(parseError) {
- if (parseError) {
- parseError.xhr = request;
- parseError.status = request.status;
- return finishProcessingFn(parseError, segment);
- }
- finishProcessingFn(null, segment);
- });
- };
- };
- var handleSegmentResponse = function handleSegmentResponse2(_ref3) {
- var segment = _ref3.segment, finishProcessingFn = _ref3.finishProcessingFn, responseType = _ref3.responseType;
- return function(error, request) {
- var errorObj = handleErrors(error, request);
- if (errorObj) {
- return finishProcessingFn(errorObj, segment);
- }
- var newBytes = responseType === "arraybuffer" || !request.responseText ? request.response : stringToArrayBuffer(request.responseText.substring(segment.lastReachedChar || 0));
- segment.stats = getRequestStats(request);
- if (segment.key) {
- segment.encryptedBytes = new Uint8Array(newBytes);
- } else {
- segment.bytes = new Uint8Array(newBytes);
- }
- return finishProcessingFn(null, segment);
- };
- };
- var transmuxAndNotify = function transmuxAndNotify2(_ref4) {
- var segment = _ref4.segment, bytes = _ref4.bytes, trackInfoFn = _ref4.trackInfoFn, timingInfoFn = _ref4.timingInfoFn, videoSegmentTimingInfoFn = _ref4.videoSegmentTimingInfoFn, audioSegmentTimingInfoFn = _ref4.audioSegmentTimingInfoFn, id3Fn = _ref4.id3Fn, captionsFn = _ref4.captionsFn, isEndOfTimeline = _ref4.isEndOfTimeline, endedTimelineFn = _ref4.endedTimelineFn, dataFn = _ref4.dataFn, doneFn = _ref4.doneFn, onTransmuxerLog = _ref4.onTransmuxerLog;
- var fmp4Tracks = segment.map && segment.map.tracks || {};
- var isMuxed3 = Boolean(fmp4Tracks.audio && fmp4Tracks.video);
- var audioStartFn = timingInfoFn.bind(null, segment, "audio", "start");
- var audioEndFn = timingInfoFn.bind(null, segment, "audio", "end");
- var videoStartFn = timingInfoFn.bind(null, segment, "video", "start");
- var videoEndFn = timingInfoFn.bind(null, segment, "video", "end");
- var finish = function finish2() {
- return transmux({
- bytes,
- transmuxer: segment.transmuxer,
- audioAppendStart: segment.audioAppendStart,
- gopsToAlignWith: segment.gopsToAlignWith,
- remux: isMuxed3,
- onData: function onData(result) {
- result.type = result.type === "combined" ? "video" : result.type;
- dataFn(segment, result);
- },
- onTrackInfo: function onTrackInfo(trackInfo) {
- if (trackInfoFn) {
- if (isMuxed3) {
- trackInfo.isMuxed = true;
- }
- trackInfoFn(segment, trackInfo);
- }
- },
- onAudioTimingInfo: function onAudioTimingInfo(audioTimingInfo) {
- if (audioStartFn && typeof audioTimingInfo.start !== "undefined") {
- audioStartFn(audioTimingInfo.start);
- audioStartFn = null;
- }
- if (audioEndFn && typeof audioTimingInfo.end !== "undefined") {
- audioEndFn(audioTimingInfo.end);
- }
- },
- onVideoTimingInfo: function onVideoTimingInfo(videoTimingInfo) {
- if (videoStartFn && typeof videoTimingInfo.start !== "undefined") {
- videoStartFn(videoTimingInfo.start);
- videoStartFn = null;
- }
- if (videoEndFn && typeof videoTimingInfo.end !== "undefined") {
- videoEndFn(videoTimingInfo.end);
- }
- },
- onVideoSegmentTimingInfo: function onVideoSegmentTimingInfo(videoSegmentTimingInfo) {
- videoSegmentTimingInfoFn(videoSegmentTimingInfo);
- },
- onAudioSegmentTimingInfo: function onAudioSegmentTimingInfo(audioSegmentTimingInfo) {
- audioSegmentTimingInfoFn(audioSegmentTimingInfo);
- },
- onId3: function onId3(id3Frames, dispatchType) {
- id3Fn(segment, id3Frames, dispatchType);
- },
- onCaptions: function onCaptions(captions) {
- captionsFn(segment, [captions]);
- },
- isEndOfTimeline,
- onEndedTimeline: function onEndedTimeline() {
- endedTimelineFn();
- },
- onTransmuxerLog,
- onDone: function onDone(result) {
- if (!doneFn) {
- return;
- }
- result.type = result.type === "combined" ? "video" : result.type;
- doneFn(null, segment, result);
- }
- });
- };
- workerCallback({
- action: "probeTs",
- transmuxer: segment.transmuxer,
- data: bytes,
- baseStartTime: segment.baseStartTime,
- callback: function callback2(data) {
- segment.bytes = bytes = data.data;
- var probeResult = data.result;
- if (probeResult) {
- trackInfoFn(segment, {
- hasAudio: probeResult.hasAudio,
- hasVideo: probeResult.hasVideo,
- isMuxed: isMuxed3
- });
- trackInfoFn = null;
- if (probeResult.hasAudio && !isMuxed3) {
- audioStartFn(probeResult.audioStart);
- }
- if (probeResult.hasVideo) {
- videoStartFn(probeResult.videoStart);
- }
- audioStartFn = null;
- videoStartFn = null;
- }
- finish();
- }
- });
- };
- var handleSegmentBytes = function handleSegmentBytes2(_ref5) {
- var segment = _ref5.segment, bytes = _ref5.bytes, trackInfoFn = _ref5.trackInfoFn, timingInfoFn = _ref5.timingInfoFn, videoSegmentTimingInfoFn = _ref5.videoSegmentTimingInfoFn, audioSegmentTimingInfoFn = _ref5.audioSegmentTimingInfoFn, id3Fn = _ref5.id3Fn, captionsFn = _ref5.captionsFn, isEndOfTimeline = _ref5.isEndOfTimeline, endedTimelineFn = _ref5.endedTimelineFn, dataFn = _ref5.dataFn, doneFn = _ref5.doneFn, onTransmuxerLog = _ref5.onTransmuxerLog;
- var bytesAsUint8Array = new Uint8Array(bytes);
- if (isLikelyFmp4MediaSegment2(bytesAsUint8Array)) {
- segment.isFmp4 = true;
- var tracks = segment.map.tracks;
- var trackInfo = {
- isFmp4: true,
- hasVideo: !!tracks.video,
- hasAudio: !!tracks.audio
- };
- if (tracks.audio && tracks.audio.codec && tracks.audio.codec !== "enca") {
- trackInfo.audioCodec = tracks.audio.codec;
- }
- if (tracks.video && tracks.video.codec && tracks.video.codec !== "encv") {
- trackInfo.videoCodec = tracks.video.codec;
- }
- if (tracks.video && tracks.audio) {
- trackInfo.isMuxed = true;
- }
- trackInfoFn(segment, trackInfo);
- var finishLoading = function finishLoading2(captions) {
- dataFn(segment, {
- data: bytesAsUint8Array,
- type: trackInfo.hasAudio && !trackInfo.isMuxed ? "audio" : "video"
- });
- if (captions && captions.length) {
- captionsFn(segment, captions);
- }
- doneFn(null, segment, {});
- };
- workerCallback({
- action: "probeMp4StartTime",
- timescales: segment.map.timescales,
- data: bytesAsUint8Array,
- transmuxer: segment.transmuxer,
- callback: function callback2(_ref6) {
- var data = _ref6.data, startTime = _ref6.startTime;
- bytes = data.buffer;
- segment.bytes = bytesAsUint8Array = data;
- if (trackInfo.hasAudio && !trackInfo.isMuxed) {
- timingInfoFn(segment, "audio", "start", startTime);
- }
- if (trackInfo.hasVideo) {
- timingInfoFn(segment, "video", "start", startTime);
- }
- if (!tracks.video || !data.byteLength || !segment.transmuxer) {
- finishLoading();
- return;
- }
- workerCallback({
- action: "pushMp4Captions",
- endAction: "mp4Captions",
- transmuxer: segment.transmuxer,
- data: bytesAsUint8Array,
- timescales: segment.map.timescales,
- trackIds: [tracks.video.id],
- callback: function callback3(message) {
- bytes = message.data.buffer;
- segment.bytes = bytesAsUint8Array = message.data;
- message.logs.forEach(function(log2) {
- onTransmuxerLog(videojs.mergeOptions(log2, {
- stream: "mp4CaptionParser"
- }));
- });
- finishLoading(message.captions);
- }
- });
- }
- });
- return;
- }
- if (!segment.transmuxer) {
- doneFn(null, segment, {});
- return;
- }
- if (typeof segment.container === "undefined") {
- segment.container = detectContainerForBytes2(bytesAsUint8Array);
- }
- if (segment.container !== "ts" && segment.container !== "aac") {
- trackInfoFn(segment, {
- hasAudio: false,
- hasVideo: false
- });
- doneFn(null, segment, {});
- return;
- }
- transmuxAndNotify({
- segment,
- bytes,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- });
- };
- var decrypt = function decrypt2(_ref7, callback2) {
- var id = _ref7.id, key = _ref7.key, encryptedBytes = _ref7.encryptedBytes, decryptionWorker = _ref7.decryptionWorker;
- var decryptionHandler = function decryptionHandler2(event2) {
- if (event2.data.source === id) {
- decryptionWorker.removeEventListener("message", decryptionHandler2);
- var decrypted = event2.data.decrypted;
- callback2(new Uint8Array(decrypted.bytes, decrypted.byteOffset, decrypted.byteLength));
- }
- };
- decryptionWorker.addEventListener("message", decryptionHandler);
- var keyBytes;
- if (key.bytes.slice) {
- keyBytes = key.bytes.slice();
- } else {
- keyBytes = new Uint32Array(Array.prototype.slice.call(key.bytes));
- }
- decryptionWorker.postMessage(createTransferableMessage({
- source: id,
- encrypted: encryptedBytes,
- key: keyBytes,
- iv: key.iv
- }), [encryptedBytes.buffer, keyBytes.buffer]);
- };
- var decryptSegment = function decryptSegment2(_ref8) {
- var decryptionWorker = _ref8.decryptionWorker, segment = _ref8.segment, trackInfoFn = _ref8.trackInfoFn, timingInfoFn = _ref8.timingInfoFn, videoSegmentTimingInfoFn = _ref8.videoSegmentTimingInfoFn, audioSegmentTimingInfoFn = _ref8.audioSegmentTimingInfoFn, id3Fn = _ref8.id3Fn, captionsFn = _ref8.captionsFn, isEndOfTimeline = _ref8.isEndOfTimeline, endedTimelineFn = _ref8.endedTimelineFn, dataFn = _ref8.dataFn, doneFn = _ref8.doneFn, onTransmuxerLog = _ref8.onTransmuxerLog;
- decrypt({
- id: segment.requestId,
- key: segment.key,
- encryptedBytes: segment.encryptedBytes,
- decryptionWorker
- }, function(decryptedBytes) {
- segment.bytes = decryptedBytes;
- handleSegmentBytes({
- segment,
- bytes: segment.bytes,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- });
- });
- };
- var waitForCompletion = function waitForCompletion2(_ref9) {
- var activeXhrs = _ref9.activeXhrs, decryptionWorker = _ref9.decryptionWorker, trackInfoFn = _ref9.trackInfoFn, timingInfoFn = _ref9.timingInfoFn, videoSegmentTimingInfoFn = _ref9.videoSegmentTimingInfoFn, audioSegmentTimingInfoFn = _ref9.audioSegmentTimingInfoFn, id3Fn = _ref9.id3Fn, captionsFn = _ref9.captionsFn, isEndOfTimeline = _ref9.isEndOfTimeline, endedTimelineFn = _ref9.endedTimelineFn, dataFn = _ref9.dataFn, doneFn = _ref9.doneFn, onTransmuxerLog = _ref9.onTransmuxerLog;
- var count = 0;
- var didError = false;
- return function(error, segment) {
- if (didError) {
- return;
- }
- if (error) {
- didError = true;
- abortAll(activeXhrs);
- return doneFn(error, segment);
- }
- count += 1;
- if (count === activeXhrs.length) {
- var segmentFinish = function segmentFinish2() {
- if (segment.encryptedBytes) {
- return decryptSegment({
- decryptionWorker,
- segment,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- });
- }
- handleSegmentBytes({
- segment,
- bytes: segment.bytes,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- });
- };
- segment.endOfAllRequests = Date.now();
- if (segment.map && segment.map.encryptedBytes && !segment.map.bytes) {
- return decrypt({
- decryptionWorker,
- id: segment.requestId + "-init",
- encryptedBytes: segment.map.encryptedBytes,
- key: segment.map.key
- }, function(decryptedBytes) {
- segment.map.bytes = decryptedBytes;
- parseInitSegment(segment, function(parseError) {
- if (parseError) {
- abortAll(activeXhrs);
- return doneFn(parseError, segment);
- }
- segmentFinish();
- });
- });
- }
- segmentFinish();
- }
- };
- };
- var handleLoadEnd = function handleLoadEnd2(_ref10) {
- var loadendState = _ref10.loadendState, abortFn = _ref10.abortFn;
- return function(event2) {
- var request = event2.target;
- if (request.aborted && abortFn && !loadendState.calledAbortFn) {
- abortFn();
- loadendState.calledAbortFn = true;
- }
- };
- };
- var handleProgress = function handleProgress2(_ref11) {
- var segment = _ref11.segment, progressFn = _ref11.progressFn;
- _ref11.trackInfoFn;
- _ref11.timingInfoFn;
- _ref11.videoSegmentTimingInfoFn;
- _ref11.audioSegmentTimingInfoFn;
- _ref11.id3Fn;
- _ref11.captionsFn;
- _ref11.isEndOfTimeline;
- _ref11.endedTimelineFn;
- _ref11.dataFn;
- return function(event2) {
- var request = event2.target;
- if (request.aborted) {
- return;
- }
- segment.stats = videojs.mergeOptions(segment.stats, getProgressStats(event2));
- if (!segment.stats.firstBytesReceivedAt && segment.stats.bytesReceived) {
- segment.stats.firstBytesReceivedAt = Date.now();
- }
- return progressFn(event2, segment);
- };
- };
- var mediaSegmentRequest = function mediaSegmentRequest2(_ref12) {
- var xhr = _ref12.xhr, xhrOptions = _ref12.xhrOptions, decryptionWorker = _ref12.decryptionWorker, segment = _ref12.segment, abortFn = _ref12.abortFn, progressFn = _ref12.progressFn, trackInfoFn = _ref12.trackInfoFn, timingInfoFn = _ref12.timingInfoFn, videoSegmentTimingInfoFn = _ref12.videoSegmentTimingInfoFn, audioSegmentTimingInfoFn = _ref12.audioSegmentTimingInfoFn, id3Fn = _ref12.id3Fn, captionsFn = _ref12.captionsFn, isEndOfTimeline = _ref12.isEndOfTimeline, endedTimelineFn = _ref12.endedTimelineFn, dataFn = _ref12.dataFn, doneFn = _ref12.doneFn, onTransmuxerLog = _ref12.onTransmuxerLog;
- var activeXhrs = [];
- var finishProcessingFn = waitForCompletion({
- activeXhrs,
- decryptionWorker,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn,
- doneFn,
- onTransmuxerLog
- });
- if (segment.key && !segment.key.bytes) {
- var objects = [segment.key];
- if (segment.map && !segment.map.bytes && segment.map.key && segment.map.key.resolvedUri === segment.key.resolvedUri) {
- objects.push(segment.map.key);
- }
- var keyRequestOptions = videojs.mergeOptions(xhrOptions, {
- uri: segment.key.resolvedUri,
- responseType: "arraybuffer"
- });
- var keyRequestCallback = handleKeyResponse(segment, objects, finishProcessingFn);
- var keyXhr = xhr(keyRequestOptions, keyRequestCallback);
- activeXhrs.push(keyXhr);
- }
- if (segment.map && !segment.map.bytes) {
- var differentMapKey = segment.map.key && (!segment.key || segment.key.resolvedUri !== segment.map.key.resolvedUri);
- if (differentMapKey) {
- var mapKeyRequestOptions = videojs.mergeOptions(xhrOptions, {
- uri: segment.map.key.resolvedUri,
- responseType: "arraybuffer"
- });
- var mapKeyRequestCallback = handleKeyResponse(segment, [segment.map.key], finishProcessingFn);
- var mapKeyXhr = xhr(mapKeyRequestOptions, mapKeyRequestCallback);
- activeXhrs.push(mapKeyXhr);
- }
- var initSegmentOptions = videojs.mergeOptions(xhrOptions, {
- uri: segment.map.resolvedUri,
- responseType: "arraybuffer",
- headers: segmentXhrHeaders(segment.map)
- });
- var initSegmentRequestCallback = handleInitSegmentResponse({
- segment,
- finishProcessingFn
- });
- var initSegmentXhr = xhr(initSegmentOptions, initSegmentRequestCallback);
- activeXhrs.push(initSegmentXhr);
- }
- var segmentRequestOptions = videojs.mergeOptions(xhrOptions, {
- uri: segment.part && segment.part.resolvedUri || segment.resolvedUri,
- responseType: "arraybuffer",
- headers: segmentXhrHeaders(segment)
- });
- var segmentRequestCallback = handleSegmentResponse({
- segment,
- finishProcessingFn,
- responseType: segmentRequestOptions.responseType
- });
- var segmentXhr = xhr(segmentRequestOptions, segmentRequestCallback);
- segmentXhr.addEventListener("progress", handleProgress({
- segment,
- progressFn,
- trackInfoFn,
- timingInfoFn,
- videoSegmentTimingInfoFn,
- audioSegmentTimingInfoFn,
- id3Fn,
- captionsFn,
- isEndOfTimeline,
- endedTimelineFn,
- dataFn
- }));
- activeXhrs.push(segmentXhr);
- var loadendState = {};
- activeXhrs.forEach(function(activeXhr) {
- activeXhr.addEventListener("loadend", handleLoadEnd({
- loadendState,
- abortFn
- }));
- });
- return function() {
- return abortAll(activeXhrs);
- };
- };
- var logFn$1 = logger("CodecUtils");
- var getCodecs = function getCodecs2(media) {
- var mediaAttributes = media.attributes || {};
- if (mediaAttributes.CODECS) {
- return parseCodecs2(mediaAttributes.CODECS);
- }
- };
- var isMaat = function isMaat2(master, media) {
- var mediaAttributes = media.attributes || {};
- return master && master.mediaGroups && master.mediaGroups.AUDIO && mediaAttributes.AUDIO && master.mediaGroups.AUDIO[mediaAttributes.AUDIO];
- };
- var isMuxed = function isMuxed2(master, media) {
- if (!isMaat(master, media)) {
- return true;
- }
- var mediaAttributes = media.attributes || {};
- var audioGroup = master.mediaGroups.AUDIO[mediaAttributes.AUDIO];
- for (var groupId in audioGroup) {
- if (!audioGroup[groupId].uri && !audioGroup[groupId].playlists) {
- return true;
- }
- }
- return false;
- };
- var unwrapCodecList = function unwrapCodecList2(codecList) {
- var codecs = {};
- codecList.forEach(function(_ref) {
- var mediaType = _ref.mediaType, type2 = _ref.type, details = _ref.details;
- codecs[mediaType] = codecs[mediaType] || [];
- codecs[mediaType].push(translateLegacyCodec2("" + type2 + details));
- });
- Object.keys(codecs).forEach(function(mediaType) {
- if (codecs[mediaType].length > 1) {
- logFn$1("multiple " + mediaType + " codecs found as attributes: " + codecs[mediaType].join(", ") + ". Setting playlist codecs to null so that we wait for mux.js to probe segments for real codecs.");
- codecs[mediaType] = null;
- return;
- }
- codecs[mediaType] = codecs[mediaType][0];
- });
- return codecs;
- };
- var codecCount = function codecCount2(codecObj) {
- var count = 0;
- if (codecObj.audio) {
- count++;
- }
- if (codecObj.video) {
- count++;
- }
- return count;
- };
- var codecsForPlaylist = function codecsForPlaylist2(master, media) {
- var mediaAttributes = media.attributes || {};
- var codecInfo = unwrapCodecList(getCodecs(media) || []);
- if (isMaat(master, media) && !codecInfo.audio) {
- if (!isMuxed(master, media)) {
- var defaultCodecs = unwrapCodecList(codecsFromDefault2(master, mediaAttributes.AUDIO) || []);
- if (defaultCodecs.audio) {
- codecInfo.audio = defaultCodecs.audio;
- }
- }
- }
- return codecInfo;
- };
- var logFn = logger("PlaylistSelector");
- var representationToString = function representationToString2(representation) {
- if (!representation || !representation.playlist) {
- return;
- }
- var playlist = representation.playlist;
- return JSON.stringify({
- id: playlist.id,
- bandwidth: representation.bandwidth,
- width: representation.width,
- height: representation.height,
- codecs: playlist.attributes && playlist.attributes.CODECS || ""
- });
- };
- var safeGetComputedStyle = function safeGetComputedStyle2(el, property) {
- if (!el) {
- return "";
- }
- var result = window_1.getComputedStyle(el);
- if (!result) {
- return "";
- }
- return result[property];
- };
- var stableSort = function stableSort2(array, sortFn) {
- var newArray = array.slice();
- array.sort(function(left, right) {
- var cmp = sortFn(left, right);
- if (cmp === 0) {
- return newArray.indexOf(left) - newArray.indexOf(right);
- }
- return cmp;
- });
- };
- var comparePlaylistBandwidth = function comparePlaylistBandwidth2(left, right) {
- var leftBandwidth;
- var rightBandwidth;
- if (left.attributes.BANDWIDTH) {
- leftBandwidth = left.attributes.BANDWIDTH;
- }
- leftBandwidth = leftBandwidth || window_1.Number.MAX_VALUE;
- if (right.attributes.BANDWIDTH) {
- rightBandwidth = right.attributes.BANDWIDTH;
- }
- rightBandwidth = rightBandwidth || window_1.Number.MAX_VALUE;
- return leftBandwidth - rightBandwidth;
- };
- var comparePlaylistResolution = function comparePlaylistResolution2(left, right) {
- var leftWidth;
- var rightWidth;
- if (left.attributes.RESOLUTION && left.attributes.RESOLUTION.width) {
- leftWidth = left.attributes.RESOLUTION.width;
- }
- leftWidth = leftWidth || window_1.Number.MAX_VALUE;
- if (right.attributes.RESOLUTION && right.attributes.RESOLUTION.width) {
- rightWidth = right.attributes.RESOLUTION.width;
- }
- rightWidth = rightWidth || window_1.Number.MAX_VALUE;
- if (leftWidth === rightWidth && left.attributes.BANDWIDTH && right.attributes.BANDWIDTH) {
- return left.attributes.BANDWIDTH - right.attributes.BANDWIDTH;
- }
- return leftWidth - rightWidth;
- };
- var simpleSelector = function simpleSelector2(master, playerBandwidth, playerWidth, playerHeight, limitRenditionByPlayerDimensions, masterPlaylistController) {
- if (!master) {
- return;
- }
- var options2 = {
- bandwidth: playerBandwidth,
- width: playerWidth,
- height: playerHeight,
- limitRenditionByPlayerDimensions
- };
- var playlists = master.playlists;
- if (Playlist.isAudioOnly(master)) {
- playlists = masterPlaylistController.getAudioTrackPlaylists_();
- options2.audioOnly = true;
- }
- var sortedPlaylistReps = playlists.map(function(playlist) {
- var bandwidth2;
- var width2 = playlist.attributes && playlist.attributes.RESOLUTION && playlist.attributes.RESOLUTION.width;
- var height2 = playlist.attributes && playlist.attributes.RESOLUTION && playlist.attributes.RESOLUTION.height;
- bandwidth2 = playlist.attributes && playlist.attributes.BANDWIDTH;
- bandwidth2 = bandwidth2 || window_1.Number.MAX_VALUE;
- return {
- bandwidth: bandwidth2,
- width: width2,
- height: height2,
- playlist
- };
- });
- stableSort(sortedPlaylistReps, function(left, right) {
- return left.bandwidth - right.bandwidth;
- });
- sortedPlaylistReps = sortedPlaylistReps.filter(function(rep2) {
- return !Playlist.isIncompatible(rep2.playlist);
- });
- var enabledPlaylistReps = sortedPlaylistReps.filter(function(rep2) {
- return Playlist.isEnabled(rep2.playlist);
- });
- if (!enabledPlaylistReps.length) {
- enabledPlaylistReps = sortedPlaylistReps.filter(function(rep2) {
- return !Playlist.isDisabled(rep2.playlist);
- });
- }
- var bandwidthPlaylistReps = enabledPlaylistReps.filter(function(rep2) {
- return rep2.bandwidth * Config.BANDWIDTH_VARIANCE < playerBandwidth;
- });
- var highestRemainingBandwidthRep = bandwidthPlaylistReps[bandwidthPlaylistReps.length - 1];
- var bandwidthBestRep = bandwidthPlaylistReps.filter(function(rep2) {
- return rep2.bandwidth === highestRemainingBandwidthRep.bandwidth;
- })[0];
- if (limitRenditionByPlayerDimensions === false) {
- var _chosenRep = bandwidthBestRep || enabledPlaylistReps[0] || sortedPlaylistReps[0];
- if (_chosenRep && _chosenRep.playlist) {
- var type2 = "sortedPlaylistReps";
- if (bandwidthBestRep) {
- type2 = "bandwidthBestRep";
- }
- if (enabledPlaylistReps[0]) {
- type2 = "enabledPlaylistReps";
- }
- logFn("choosing " + representationToString(_chosenRep) + " using " + type2 + " with options", options2);
- return _chosenRep.playlist;
- }
- logFn("could not choose a playlist with options", options2);
- return null;
- }
- var haveResolution = bandwidthPlaylistReps.filter(function(rep2) {
- return rep2.width && rep2.height;
- });
- stableSort(haveResolution, function(left, right) {
- return left.width - right.width;
- });
- var resolutionBestRepList = haveResolution.filter(function(rep2) {
- return rep2.width === playerWidth && rep2.height === playerHeight;
- });
- highestRemainingBandwidthRep = resolutionBestRepList[resolutionBestRepList.length - 1];
- var resolutionBestRep = resolutionBestRepList.filter(function(rep2) {
- return rep2.bandwidth === highestRemainingBandwidthRep.bandwidth;
- })[0];
- var resolutionPlusOneList;
- var resolutionPlusOneSmallest;
- var resolutionPlusOneRep;
- if (!resolutionBestRep) {
- resolutionPlusOneList = haveResolution.filter(function(rep2) {
- return rep2.width > playerWidth || rep2.height > playerHeight;
- });
- resolutionPlusOneSmallest = resolutionPlusOneList.filter(function(rep2) {
- return rep2.width === resolutionPlusOneList[0].width && rep2.height === resolutionPlusOneList[0].height;
- });
- highestRemainingBandwidthRep = resolutionPlusOneSmallest[resolutionPlusOneSmallest.length - 1];
- resolutionPlusOneRep = resolutionPlusOneSmallest.filter(function(rep2) {
- return rep2.bandwidth === highestRemainingBandwidthRep.bandwidth;
- })[0];
- }
- var leastPixelDiffRep;
- if (masterPlaylistController.experimentalLeastPixelDiffSelector) {
- var leastPixelDiffList = haveResolution.map(function(rep2) {
- rep2.pixelDiff = Math.abs(rep2.width - playerWidth) + Math.abs(rep2.height - playerHeight);
- return rep2;
- });
- stableSort(leastPixelDiffList, function(left, right) {
- if (left.pixelDiff === right.pixelDiff) {
- return right.bandwidth - left.bandwidth;
- }
- return left.pixelDiff - right.pixelDiff;
- });
- leastPixelDiffRep = leastPixelDiffList[0];
- }
- var chosenRep = leastPixelDiffRep || resolutionPlusOneRep || resolutionBestRep || bandwidthBestRep || enabledPlaylistReps[0] || sortedPlaylistReps[0];
- if (chosenRep && chosenRep.playlist) {
- var _type = "sortedPlaylistReps";
- if (leastPixelDiffRep) {
- _type = "leastPixelDiffRep";
- } else if (resolutionPlusOneRep) {
- _type = "resolutionPlusOneRep";
- } else if (resolutionBestRep) {
- _type = "resolutionBestRep";
- } else if (bandwidthBestRep) {
- _type = "bandwidthBestRep";
- } else if (enabledPlaylistReps[0]) {
- _type = "enabledPlaylistReps";
- }
- logFn("choosing " + representationToString(chosenRep) + " using " + _type + " with options", options2);
- return chosenRep.playlist;
- }
- logFn("could not choose a playlist with options", options2);
- return null;
- };
- var lastBandwidthSelector = function lastBandwidthSelector2() {
- var pixelRatio = this.useDevicePixelRatio ? window_1.devicePixelRatio || 1 : 1;
- return simpleSelector(this.playlists.master, this.systemBandwidth, parseInt(safeGetComputedStyle(this.tech_.el(), "width"), 10) * pixelRatio, parseInt(safeGetComputedStyle(this.tech_.el(), "height"), 10) * pixelRatio, this.limitRenditionByPlayerDimensions, this.masterPlaylistController_);
- };
- var movingAverageBandwidthSelector = function movingAverageBandwidthSelector2(decay) {
- var average = -1;
- var lastSystemBandwidth = -1;
- if (decay < 0 || decay > 1) {
- throw new Error("Moving average bandwidth decay must be between 0 and 1.");
- }
- return function() {
- var pixelRatio = this.useDevicePixelRatio ? window_1.devicePixelRatio || 1 : 1;
- if (average < 0) {
- average = this.systemBandwidth;
- lastSystemBandwidth = this.systemBandwidth;
- }
- if (this.systemBandwidth > 0 && this.systemBandwidth !== lastSystemBandwidth) {
- average = decay * this.systemBandwidth + (1 - decay) * average;
- lastSystemBandwidth = this.systemBandwidth;
- }
- return simpleSelector(this.playlists.master, average, parseInt(safeGetComputedStyle(this.tech_.el(), "width"), 10) * pixelRatio, parseInt(safeGetComputedStyle(this.tech_.el(), "height"), 10) * pixelRatio, this.limitRenditionByPlayerDimensions, this.masterPlaylistController_);
- };
- };
- var minRebufferMaxBandwidthSelector = function minRebufferMaxBandwidthSelector2(settings) {
- var master = settings.master, currentTime = settings.currentTime, bandwidth2 = settings.bandwidth, duration5 = settings.duration, segmentDuration = settings.segmentDuration, timeUntilRebuffer3 = settings.timeUntilRebuffer, currentTimeline = settings.currentTimeline, syncController = settings.syncController;
- var compatiblePlaylists = master.playlists.filter(function(playlist) {
- return !Playlist.isIncompatible(playlist);
- });
- var enabledPlaylists = compatiblePlaylists.filter(Playlist.isEnabled);
- if (!enabledPlaylists.length) {
- enabledPlaylists = compatiblePlaylists.filter(function(playlist) {
- return !Playlist.isDisabled(playlist);
- });
- }
- var bandwidthPlaylists = enabledPlaylists.filter(Playlist.hasAttribute.bind(null, "BANDWIDTH"));
- var rebufferingEstimates = bandwidthPlaylists.map(function(playlist) {
- var syncPoint = syncController.getSyncPoint(playlist, duration5, currentTimeline, currentTime);
- var numRequests = syncPoint ? 1 : 2;
- var requestTimeEstimate = Playlist.estimateSegmentRequestTime(segmentDuration, bandwidth2, playlist);
- var rebufferingImpact = requestTimeEstimate * numRequests - timeUntilRebuffer3;
- return {
- playlist,
- rebufferingImpact
- };
- });
- var noRebufferingPlaylists = rebufferingEstimates.filter(function(estimate) {
- return estimate.rebufferingImpact <= 0;
- });
- stableSort(noRebufferingPlaylists, function(a, b) {
- return comparePlaylistBandwidth(b.playlist, a.playlist);
- });
- if (noRebufferingPlaylists.length) {
- return noRebufferingPlaylists[0];
- }
- stableSort(rebufferingEstimates, function(a, b) {
- return a.rebufferingImpact - b.rebufferingImpact;
- });
- return rebufferingEstimates[0] || null;
- };
- var lowestBitrateCompatibleVariantSelector = function lowestBitrateCompatibleVariantSelector2() {
- var _this = this;
- var playlists = this.playlists.master.playlists.filter(Playlist.isEnabled);
- stableSort(playlists, function(a, b) {
- return comparePlaylistBandwidth(a, b);
- });
- var playlistsWithVideo = playlists.filter(function(playlist) {
- return !!codecsForPlaylist(_this.playlists.master, playlist).video;
- });
- return playlistsWithVideo[0] || null;
- };
- var concatSegments = function concatSegments2(segmentObj) {
- var offset = 0;
- var tempBuffer;
- if (segmentObj.bytes) {
- tempBuffer = new Uint8Array(segmentObj.bytes);
- segmentObj.segments.forEach(function(segment) {
- tempBuffer.set(segment, offset);
- offset += segment.byteLength;
- });
- }
- return tempBuffer;
- };
- var createCaptionsTrackIfNotExists = function createCaptionsTrackIfNotExists2(inbandTextTracks, tech, captionStream) {
- if (!inbandTextTracks[captionStream]) {
- tech.trigger({
- type: "usage",
- name: "vhs-608"
- });
- tech.trigger({
- type: "usage",
- name: "hls-608"
- });
- var instreamId = captionStream;
- if (/^cc708_/.test(captionStream)) {
- instreamId = "SERVICE" + captionStream.split("_")[1];
- }
- var track = tech.textTracks().getTrackById(instreamId);
- if (track) {
- inbandTextTracks[captionStream] = track;
- } else {
- var captionServices = tech.options_.vhs && tech.options_.vhs.captionServices || {};
- var label2 = captionStream;
- var language = captionStream;
- var def = false;
- var captionService = captionServices[instreamId];
- if (captionService) {
- label2 = captionService.label;
- language = captionService.language;
- def = captionService["default"];
- }
- inbandTextTracks[captionStream] = tech.addRemoteTextTrack({
- kind: "captions",
- id: instreamId,
- "default": def,
- label: label2,
- language
- }, false).track;
- }
- }
- };
- var addCaptionData = function addCaptionData2(_ref) {
- var inbandTextTracks = _ref.inbandTextTracks, captionArray = _ref.captionArray, timestampOffset2 = _ref.timestampOffset;
- if (!captionArray) {
- return;
- }
- var Cue = window_1.WebKitDataCue || window_1.VTTCue;
- captionArray.forEach(function(caption) {
- var track = caption.stream;
- inbandTextTracks[track].addCue(new Cue(caption.startTime + timestampOffset2, caption.endTime + timestampOffset2, caption.text));
- });
- };
- var deprecateOldCue = function deprecateOldCue2(cue) {
- Object.defineProperties(cue.frame, {
- id: {
- get: function get7() {
- videojs.log.warn("cue.frame.id is deprecated. Use cue.value.key instead.");
- return cue.value.key;
- }
- },
- value: {
- get: function get7() {
- videojs.log.warn("cue.frame.value is deprecated. Use cue.value.data instead.");
- return cue.value.data;
- }
- },
- privateData: {
- get: function get7() {
- videojs.log.warn("cue.frame.privateData is deprecated. Use cue.value.data instead.");
- return cue.value.data;
- }
- }
- });
- };
- var addMetadata = function addMetadata2(_ref2) {
- var inbandTextTracks = _ref2.inbandTextTracks, metadataArray = _ref2.metadataArray, timestampOffset2 = _ref2.timestampOffset, videoDuration = _ref2.videoDuration;
- if (!metadataArray) {
- return;
- }
- var Cue = window_1.WebKitDataCue || window_1.VTTCue;
- var metadataTrack = inbandTextTracks.metadataTrack_;
- if (!metadataTrack) {
- return;
- }
- metadataArray.forEach(function(metadata) {
- var time = metadata.cueTime + timestampOffset2;
- if (typeof time !== "number" || window_1.isNaN(time) || time < 0 || !(time < Infinity)) {
- return;
- }
- metadata.frames.forEach(function(frame) {
- var cue = new Cue(time, time, frame.value || frame.url || frame.data || "");
- cue.frame = frame;
- cue.value = frame;
- deprecateOldCue(cue);
- metadataTrack.addCue(cue);
- });
- });
- if (!metadataTrack.cues || !metadataTrack.cues.length) {
- return;
- }
- var cues = metadataTrack.cues;
- var cuesArray = [];
- for (var i2 = 0; i2 < cues.length; i2++) {
- if (cues[i2]) {
- cuesArray.push(cues[i2]);
- }
- }
- var cuesGroupedByStartTime = cuesArray.reduce(function(obj, cue) {
- var timeSlot = obj[cue.startTime] || [];
- timeSlot.push(cue);
- obj[cue.startTime] = timeSlot;
- return obj;
- }, {});
- var sortedStartTimes = Object.keys(cuesGroupedByStartTime).sort(function(a, b) {
- return Number(a) - Number(b);
- });
- sortedStartTimes.forEach(function(startTime, idx) {
- var cueGroup = cuesGroupedByStartTime[startTime];
- var nextTime = Number(sortedStartTimes[idx + 1]) || videoDuration;
- cueGroup.forEach(function(cue) {
- cue.endTime = nextTime;
- });
- });
- };
- var createMetadataTrackIfNotExists = function createMetadataTrackIfNotExists2(inbandTextTracks, dispatchType, tech) {
- if (inbandTextTracks.metadataTrack_) {
- return;
- }
- inbandTextTracks.metadataTrack_ = tech.addRemoteTextTrack({
- kind: "metadata",
- label: "Timed Metadata"
- }, false).track;
- inbandTextTracks.metadataTrack_.inBandMetadataTrackDispatchType = dispatchType;
- };
- var removeCuesFromTrack = function removeCuesFromTrack2(start2, end, track) {
- var i2;
- var cue;
- if (!track) {
- return;
- }
- if (!track.cues) {
- return;
- }
- i2 = track.cues.length;
- while (i2--) {
- cue = track.cues[i2];
- if (cue.startTime >= start2 && cue.endTime <= end) {
- track.removeCue(cue);
- }
- }
- };
- var removeDuplicateCuesFromTrack = function removeDuplicateCuesFromTrack2(track) {
- var cues = track.cues;
- if (!cues) {
- return;
- }
- for (var i2 = 0; i2 < cues.length; i2++) {
- var duplicates = [];
- var occurrences = 0;
- for (var j = 0; j < cues.length; j++) {
- if (cues[i2].startTime === cues[j].startTime && cues[i2].endTime === cues[j].endTime && cues[i2].text === cues[j].text) {
- occurrences++;
- if (occurrences > 1) {
- duplicates.push(cues[j]);
- }
- }
- }
- if (duplicates.length) {
- duplicates.forEach(function(dupe) {
- return track.removeCue(dupe);
- });
- }
- }
- };
- var gopsSafeToAlignWith = function gopsSafeToAlignWith2(buffer, currentTime, mapping) {
- if (typeof currentTime === "undefined" || currentTime === null || !buffer.length) {
- return [];
- }
- var currentTimePts = Math.ceil((currentTime - mapping + 3) * clock.ONE_SECOND_IN_TS);
- var i2;
- for (i2 = 0; i2 < buffer.length; i2++) {
- if (buffer[i2].pts > currentTimePts) {
- break;
- }
- }
- return buffer.slice(i2);
- };
- var updateGopBuffer = function updateGopBuffer2(buffer, gops, replace) {
- if (!gops.length) {
- return buffer;
- }
- if (replace) {
- return gops.slice();
- }
- var start2 = gops[0].pts;
- var i2 = 0;
- for (i2; i2 < buffer.length; i2++) {
- if (buffer[i2].pts >= start2) {
- break;
- }
- }
- return buffer.slice(0, i2).concat(gops);
- };
- var removeGopBuffer = function removeGopBuffer2(buffer, start2, end, mapping) {
- var startPts = Math.ceil((start2 - mapping) * clock.ONE_SECOND_IN_TS);
- var endPts = Math.ceil((end - mapping) * clock.ONE_SECOND_IN_TS);
- var updatedBuffer = buffer.slice();
- var i2 = buffer.length;
- while (i2--) {
- if (buffer[i2].pts <= endPts) {
- break;
- }
- }
- if (i2 === -1) {
- return updatedBuffer;
- }
- var j = i2 + 1;
- while (j--) {
- if (buffer[j].pts <= startPts) {
- break;
- }
- }
- j = Math.max(j, 0);
- updatedBuffer.splice(j, i2 - j + 1);
- return updatedBuffer;
- };
- var shallowEqual = function shallowEqual2(a, b) {
- if (!a && !b || !a && b || a && !b) {
- return false;
- }
- if (a === b) {
- return true;
- }
- var akeys = Object.keys(a).sort();
- var bkeys = Object.keys(b).sort();
- if (akeys.length !== bkeys.length) {
- return false;
- }
- for (var i2 = 0; i2 < akeys.length; i2++) {
- var key = akeys[i2];
- if (key !== bkeys[i2]) {
- return false;
- }
- if (a[key] !== b[key]) {
- return false;
- }
- }
- return true;
- };
- var QUOTA_EXCEEDED_ERR = 22;
- var getSyncSegmentCandidate = function getSyncSegmentCandidate2(currentTimeline, segments, targetTime) {
- segments = segments || [];
- var timelineSegments = [];
- var time = 0;
- for (var i2 = 0; i2 < segments.length; i2++) {
- var segment = segments[i2];
- if (currentTimeline === segment.timeline) {
- timelineSegments.push(i2);
- time += segment.duration;
- if (time > targetTime) {
- return i2;
- }
- }
- }
- if (timelineSegments.length === 0) {
- return 0;
- }
- return timelineSegments[timelineSegments.length - 1];
- };
- var MIN_BACK_BUFFER = 1;
- var CHECK_BUFFER_DELAY = 500;
- var finite = function finite2(num) {
- return typeof num === "number" && isFinite(num);
- };
- var MIN_SEGMENT_DURATION_TO_SAVE_STATS = 1 / 60;
- var illegalMediaSwitch = function illegalMediaSwitch2(loaderType, startingMedia, trackInfo) {
- if (loaderType !== "main" || !startingMedia || !trackInfo) {
- return null;
- }
- if (!trackInfo.hasAudio && !trackInfo.hasVideo) {
- return "Neither audio nor video found in segment.";
- }
- if (startingMedia.hasVideo && !trackInfo.hasVideo) {
- return "Only audio found in segment when we expected video. We can't switch to audio only from a stream that had video. To get rid of this message, please add codec information to the manifest.";
- }
- if (!startingMedia.hasVideo && trackInfo.hasVideo) {
- return "Video found in segment when we expected only audio. We can't switch to a stream with video from an audio only stream. To get rid of this message, please add codec information to the manifest.";
- }
- return null;
- };
- var safeBackBufferTrimTime = function safeBackBufferTrimTime2(seekable3, currentTime, targetDuration) {
- var trimTime = currentTime - Config.BACK_BUFFER_LENGTH;
- if (seekable3.length) {
- trimTime = Math.max(trimTime, seekable3.start(0));
- }
- var maxTrimTime = currentTime - targetDuration;
- return Math.min(maxTrimTime, trimTime);
- };
- var segmentInfoString = function segmentInfoString2(segmentInfo) {
- var startOfSegment = segmentInfo.startOfSegment, duration5 = segmentInfo.duration, segment = segmentInfo.segment, part = segmentInfo.part, _segmentInfo$playlist = segmentInfo.playlist, seq = _segmentInfo$playlist.mediaSequence, id = _segmentInfo$playlist.id, _segmentInfo$playlist2 = _segmentInfo$playlist.segments, segments = _segmentInfo$playlist2 === void 0 ? [] : _segmentInfo$playlist2, index2 = segmentInfo.mediaIndex, partIndex = segmentInfo.partIndex, timeline = segmentInfo.timeline;
- var segmentLen = segments.length - 1;
- var selection = "mediaIndex/partIndex increment";
- if (segmentInfo.getMediaInfoForTime) {
- selection = "getMediaInfoForTime (" + segmentInfo.getMediaInfoForTime + ")";
- } else if (segmentInfo.isSyncRequest) {
- selection = "getSyncSegmentCandidate (isSyncRequest)";
- }
- if (segmentInfo.independent) {
- selection += " with independent " + segmentInfo.independent;
- }
- var hasPartIndex = typeof partIndex === "number";
- var name = segmentInfo.segment.uri ? "segment" : "pre-segment";
- var zeroBasedPartCount = hasPartIndex ? getKnownPartCount({
- preloadSegment: segment
- }) - 1 : 0;
- return name + " [" + (seq + index2) + "/" + (seq + segmentLen) + "]" + (hasPartIndex ? " part [" + partIndex + "/" + zeroBasedPartCount + "]" : "") + (" segment start/end [" + segment.start + " => " + segment.end + "]") + (hasPartIndex ? " part start/end [" + part.start + " => " + part.end + "]" : "") + (" startOfSegment [" + startOfSegment + "]") + (" duration [" + duration5 + "]") + (" timeline [" + timeline + "]") + (" selected by [" + selection + "]") + (" playlist [" + id + "]");
- };
- var timingInfoPropertyForMedia = function timingInfoPropertyForMedia2(mediaType) {
- return mediaType + "TimingInfo";
- };
- var timestampOffsetForSegment = function timestampOffsetForSegment2(_ref) {
- var segmentTimeline = _ref.segmentTimeline, currentTimeline = _ref.currentTimeline, startOfSegment = _ref.startOfSegment, buffered = _ref.buffered, overrideCheck = _ref.overrideCheck;
- if (!overrideCheck && segmentTimeline === currentTimeline) {
- return null;
- }
- if (segmentTimeline < currentTimeline) {
- return startOfSegment;
- }
- return buffered.length ? buffered.end(buffered.length - 1) : startOfSegment;
- };
- var shouldWaitForTimelineChange = function shouldWaitForTimelineChange2(_ref2) {
- var timelineChangeController = _ref2.timelineChangeController, currentTimeline = _ref2.currentTimeline, segmentTimeline = _ref2.segmentTimeline, loaderType = _ref2.loaderType, audioDisabled = _ref2.audioDisabled;
- if (currentTimeline === segmentTimeline) {
- return false;
- }
- if (loaderType === "audio") {
- var lastMainTimelineChange = timelineChangeController.lastTimelineChange({
- type: "main"
- });
- return !lastMainTimelineChange || lastMainTimelineChange.to !== segmentTimeline;
- }
- if (loaderType === "main" && audioDisabled) {
- var pendingAudioTimelineChange = timelineChangeController.pendingTimelineChange({
- type: "audio"
- });
- if (pendingAudioTimelineChange && pendingAudioTimelineChange.to === segmentTimeline) {
- return false;
- }
- return true;
- }
- return false;
- };
- var mediaDuration = function mediaDuration2(timingInfos) {
- var maxDuration = 0;
- ["video", "audio"].forEach(function(type2) {
- var typeTimingInfo = timingInfos[type2 + "TimingInfo"];
- if (!typeTimingInfo) {
- return;
- }
- var start2 = typeTimingInfo.start, end = typeTimingInfo.end;
- var duration5;
- if (typeof start2 === "bigint" || typeof end === "bigint") {
- duration5 = window_1.BigInt(end) - window_1.BigInt(start2);
- } else if (typeof start2 === "number" && typeof end === "number") {
- duration5 = end - start2;
- }
- if (typeof duration5 !== "undefined" && duration5 > maxDuration) {
- maxDuration = duration5;
- }
- });
- if (typeof maxDuration === "bigint" && maxDuration < Number.MAX_SAFE_INTEGER) {
- maxDuration = Number(maxDuration);
- }
- return maxDuration;
- };
- var segmentTooLong = function segmentTooLong2(_ref3) {
- var segmentDuration = _ref3.segmentDuration, maxDuration = _ref3.maxDuration;
- if (!segmentDuration) {
- return false;
- }
- return Math.round(segmentDuration) > maxDuration + TIME_FUDGE_FACTOR;
- };
- var getTroublesomeSegmentDurationMessage = function getTroublesomeSegmentDurationMessage2(segmentInfo, sourceType) {
- if (sourceType !== "hls") {
- return null;
- }
- var segmentDuration = mediaDuration({
- audioTimingInfo: segmentInfo.audioTimingInfo,
- videoTimingInfo: segmentInfo.videoTimingInfo
- });
- if (!segmentDuration) {
- return null;
- }
- var targetDuration = segmentInfo.playlist.targetDuration;
- var isSegmentWayTooLong = segmentTooLong({
- segmentDuration,
- maxDuration: targetDuration * 2
- });
- var isSegmentSlightlyTooLong = segmentTooLong({
- segmentDuration,
- maxDuration: targetDuration
- });
- var segmentTooLongMessage = "Segment with index " + segmentInfo.mediaIndex + " " + ("from playlist " + segmentInfo.playlist.id + " ") + ("has a duration of " + segmentDuration + " ") + ("when the reported duration is " + segmentInfo.duration + " ") + ("and the target duration is " + targetDuration + ". ") + "For HLS content, a duration in excess of the target duration may result in playback issues. See the HLS specification section on EXT-X-TARGETDURATION for more details: https://tools.ietf.org/html/draft-pantos-http-live-streaming-23#section-4.3.3.1";
- if (isSegmentWayTooLong || isSegmentSlightlyTooLong) {
- return {
- severity: isSegmentWayTooLong ? "warn" : "info",
- message: segmentTooLongMessage
- };
- }
- return null;
- };
- var SegmentLoader = /* @__PURE__ */ function(_videojs$EventTarget) {
- _inheritsLoose(SegmentLoader2, _videojs$EventTarget);
- function SegmentLoader2(settings, options2) {
- var _this;
- _this = _videojs$EventTarget.call(this) || this;
- if (!settings) {
- throw new TypeError("Initialization settings are required");
- }
- if (typeof settings.currentTime !== "function") {
- throw new TypeError("No currentTime getter specified");
- }
- if (!settings.mediaSource) {
- throw new TypeError("No MediaSource specified");
- }
- _this.bandwidth = settings.bandwidth;
- _this.throughput = {
- rate: 0,
- count: 0
- };
- _this.roundTrip = NaN;
- _this.resetStats_();
- _this.mediaIndex = null;
- _this.partIndex = null;
- _this.hasPlayed_ = settings.hasPlayed;
- _this.currentTime_ = settings.currentTime;
- _this.seekable_ = settings.seekable;
- _this.seeking_ = settings.seeking;
- _this.duration_ = settings.duration;
- _this.mediaSource_ = settings.mediaSource;
- _this.vhs_ = settings.vhs;
- _this.loaderType_ = settings.loaderType;
- _this.currentMediaInfo_ = void 0;
- _this.startingMediaInfo_ = void 0;
- _this.segmentMetadataTrack_ = settings.segmentMetadataTrack;
- _this.goalBufferLength_ = settings.goalBufferLength;
- _this.sourceType_ = settings.sourceType;
- _this.sourceUpdater_ = settings.sourceUpdater;
- _this.inbandTextTracks_ = settings.inbandTextTracks;
- _this.state_ = "INIT";
- _this.timelineChangeController_ = settings.timelineChangeController;
- _this.shouldSaveSegmentTimingInfo_ = true;
- _this.parse708captions_ = settings.parse708captions;
- _this.useDtsForTimestampOffset_ = settings.useDtsForTimestampOffset;
- _this.captionServices_ = settings.captionServices;
- _this.experimentalExactManifestTimings = settings.experimentalExactManifestTimings;
- _this.checkBufferTimeout_ = null;
- _this.error_ = void 0;
- _this.currentTimeline_ = -1;
- _this.pendingSegment_ = null;
- _this.xhrOptions_ = null;
- _this.pendingSegments_ = [];
- _this.audioDisabled_ = false;
- _this.isPendingTimestampOffset_ = false;
- _this.gopBuffer_ = [];
- _this.timeMapping_ = 0;
- _this.safeAppend_ = videojs.browser.IE_VERSION >= 11;
- _this.appendInitSegment_ = {
- audio: true,
- video: true
- };
- _this.playlistOfLastInitSegment_ = {
- audio: null,
- video: null
- };
- _this.callQueue_ = [];
- _this.loadQueue_ = [];
- _this.metadataQueue_ = {
- id3: [],
- caption: []
- };
- _this.waitingOnRemove_ = false;
- _this.quotaExceededErrorRetryTimeout_ = null;
- _this.activeInitSegmentId_ = null;
- _this.initSegments_ = {};
- _this.cacheEncryptionKeys_ = settings.cacheEncryptionKeys;
- _this.keyCache_ = {};
- _this.decrypter_ = settings.decrypter;
- _this.syncController_ = settings.syncController;
- _this.syncPoint_ = {
- segmentIndex: 0,
- time: 0
- };
- _this.transmuxer_ = _this.createTransmuxer_();
- _this.triggerSyncInfoUpdate_ = function() {
- return _this.trigger("syncinfoupdate");
- };
- _this.syncController_.on("syncinfoupdate", _this.triggerSyncInfoUpdate_);
- _this.mediaSource_.addEventListener("sourceopen", function() {
- if (!_this.isEndOfStream_()) {
- _this.ended_ = false;
- }
- });
- _this.fetchAtBuffer_ = false;
- _this.logger_ = logger("SegmentLoader[" + _this.loaderType_ + "]");
- Object.defineProperty(_assertThisInitialized(_this), "state", {
- get: function get7() {
- return this.state_;
- },
- set: function set4(newState) {
- if (newState !== this.state_) {
- this.logger_(this.state_ + " -> " + newState);
- this.state_ = newState;
- this.trigger("statechange");
- }
- }
- });
- _this.sourceUpdater_.on("ready", function() {
- if (_this.hasEnoughInfoToAppend_()) {
- _this.processCallQueue_();
- }
- });
- if (_this.loaderType_ === "main") {
- _this.timelineChangeController_.on("pendingtimelinechange", function() {
- if (_this.hasEnoughInfoToAppend_()) {
- _this.processCallQueue_();
- }
- });
- }
- if (_this.loaderType_ === "audio") {
- _this.timelineChangeController_.on("timelinechange", function() {
- if (_this.hasEnoughInfoToLoad_()) {
- _this.processLoadQueue_();
- }
- if (_this.hasEnoughInfoToAppend_()) {
- _this.processCallQueue_();
- }
- });
- }
- return _this;
- }
- var _proto = SegmentLoader2.prototype;
- _proto.createTransmuxer_ = function createTransmuxer_() {
- return segmentTransmuxer.createTransmuxer({
- remux: false,
- alignGopsAtEnd: this.safeAppend_,
- keepOriginalTimestamps: true,
- parse708captions: this.parse708captions_,
- captionServices: this.captionServices_
- });
- };
- _proto.resetStats_ = function resetStats_() {
- this.mediaBytesTransferred = 0;
- this.mediaRequests = 0;
- this.mediaRequestsAborted = 0;
- this.mediaRequestsTimedout = 0;
- this.mediaRequestsErrored = 0;
- this.mediaTransferDuration = 0;
- this.mediaSecondsLoaded = 0;
- this.mediaAppends = 0;
- };
- _proto.dispose = function dispose() {
- this.trigger("dispose");
- this.state = "DISPOSED";
- this.pause();
- this.abort_();
- if (this.transmuxer_) {
- this.transmuxer_.terminate();
- }
- this.resetStats_();
- if (this.checkBufferTimeout_) {
- window_1.clearTimeout(this.checkBufferTimeout_);
- }
- if (this.syncController_ && this.triggerSyncInfoUpdate_) {
- this.syncController_.off("syncinfoupdate", this.triggerSyncInfoUpdate_);
- }
- this.off();
- };
- _proto.setAudio = function setAudio(enable) {
- this.audioDisabled_ = !enable;
- if (enable) {
- this.appendInitSegment_.audio = true;
- } else {
- this.sourceUpdater_.removeAudio(0, this.duration_());
- }
- };
- _proto.abort = function abort2() {
- if (this.state !== "WAITING") {
- if (this.pendingSegment_) {
- this.pendingSegment_ = null;
- }
- return;
- }
- this.abort_();
- this.state = "READY";
- if (!this.paused()) {
- this.monitorBuffer_();
- }
- };
- _proto.abort_ = function abort_() {
- if (this.pendingSegment_ && this.pendingSegment_.abortRequests) {
- this.pendingSegment_.abortRequests();
- }
- this.pendingSegment_ = null;
- this.callQueue_ = [];
- this.loadQueue_ = [];
- this.metadataQueue_.id3 = [];
- this.metadataQueue_.caption = [];
- this.timelineChangeController_.clearPendingTimelineChange(this.loaderType_);
- this.waitingOnRemove_ = false;
- window_1.clearTimeout(this.quotaExceededErrorRetryTimeout_);
- this.quotaExceededErrorRetryTimeout_ = null;
- };
- _proto.checkForAbort_ = function checkForAbort_(requestId) {
- if (this.state === "APPENDING" && !this.pendingSegment_) {
- this.state = "READY";
- return true;
- }
- if (!this.pendingSegment_ || this.pendingSegment_.requestId !== requestId) {
- return true;
- }
- return false;
- };
- _proto.error = function error(_error) {
- if (typeof _error !== "undefined") {
- this.logger_("error occurred:", _error);
- this.error_ = _error;
- }
- this.pendingSegment_ = null;
- return this.error_;
- };
- _proto.endOfStream = function endOfStream2() {
- this.ended_ = true;
- if (this.transmuxer_) {
- segmentTransmuxer.reset(this.transmuxer_);
- }
- this.gopBuffer_.length = 0;
- this.pause();
- this.trigger("ended");
- };
- _proto.buffered_ = function buffered_() {
- var trackInfo = this.getMediaInfo_();
- if (!this.sourceUpdater_ || !trackInfo) {
- return videojs.createTimeRanges();
- }
- if (this.loaderType_ === "main") {
- var hasAudio = trackInfo.hasAudio, hasVideo = trackInfo.hasVideo, isMuxed3 = trackInfo.isMuxed;
- if (hasVideo && hasAudio && !this.audioDisabled_ && !isMuxed3) {
- return this.sourceUpdater_.buffered();
- }
- if (hasVideo) {
- return this.sourceUpdater_.videoBuffered();
- }
- }
- return this.sourceUpdater_.audioBuffered();
- };
- _proto.initSegmentForMap = function initSegmentForMap(map, set4) {
- if (set4 === void 0) {
- set4 = false;
- }
- if (!map) {
- return null;
- }
- var id = initSegmentId(map);
- var storedMap = this.initSegments_[id];
- if (set4 && !storedMap && map.bytes) {
- this.initSegments_[id] = storedMap = {
- resolvedUri: map.resolvedUri,
- byterange: map.byterange,
- bytes: map.bytes,
- tracks: map.tracks,
- timescales: map.timescales
- };
- }
- return storedMap || map;
- };
- _proto.segmentKey = function segmentKey(key, set4) {
- if (set4 === void 0) {
- set4 = false;
- }
- if (!key) {
- return null;
- }
- var id = segmentKeyId(key);
- var storedKey = this.keyCache_[id];
- if (this.cacheEncryptionKeys_ && set4 && !storedKey && key.bytes) {
- this.keyCache_[id] = storedKey = {
- resolvedUri: key.resolvedUri,
- bytes: key.bytes
- };
- }
- var result = {
- resolvedUri: (storedKey || key).resolvedUri
- };
- if (storedKey) {
- result.bytes = storedKey.bytes;
- }
- return result;
- };
- _proto.couldBeginLoading_ = function couldBeginLoading_() {
- return this.playlist_ && !this.paused();
- };
- _proto.load = function load() {
- this.monitorBuffer_();
- if (!this.playlist_) {
- return;
- }
- if (this.state === "INIT" && this.couldBeginLoading_()) {
- return this.init_();
- }
- if (!this.couldBeginLoading_() || this.state !== "READY" && this.state !== "INIT") {
- return;
- }
- this.state = "READY";
- };
- _proto.init_ = function init_() {
- this.state = "READY";
- this.resetEverything();
- return this.monitorBuffer_();
- };
- _proto.playlist = function playlist(newPlaylist, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- if (!newPlaylist) {
- return;
- }
- var oldPlaylist = this.playlist_;
- var segmentInfo = this.pendingSegment_;
- this.playlist_ = newPlaylist;
- this.xhrOptions_ = options2;
- if (this.state === "INIT") {
- newPlaylist.syncInfo = {
- mediaSequence: newPlaylist.mediaSequence,
- time: 0
- };
- if (this.loaderType_ === "main") {
- this.syncController_.setDateTimeMappingForStart(newPlaylist);
- }
- }
- var oldId = null;
- if (oldPlaylist) {
- if (oldPlaylist.id) {
- oldId = oldPlaylist.id;
- } else if (oldPlaylist.uri) {
- oldId = oldPlaylist.uri;
- }
- }
- this.logger_("playlist update [" + oldId + " => " + (newPlaylist.id || newPlaylist.uri) + "]");
- this.trigger("syncinfoupdate");
- if (this.state === "INIT" && this.couldBeginLoading_()) {
- return this.init_();
- }
- if (!oldPlaylist || oldPlaylist.uri !== newPlaylist.uri) {
- if (this.mediaIndex !== null) {
- if (!newPlaylist.endList) {
- this.resetLoader();
- } else {
- this.resyncLoader();
- }
- }
- this.currentMediaInfo_ = void 0;
- this.trigger("playlistupdate");
- return;
- }
- var mediaSequenceDiff = newPlaylist.mediaSequence - oldPlaylist.mediaSequence;
- this.logger_("live window shift [" + mediaSequenceDiff + "]");
- if (this.mediaIndex !== null) {
- this.mediaIndex -= mediaSequenceDiff;
- if (this.mediaIndex < 0) {
- this.mediaIndex = null;
- this.partIndex = null;
- } else {
- var segment = this.playlist_.segments[this.mediaIndex];
- if (this.partIndex && (!segment.parts || !segment.parts.length || !segment.parts[this.partIndex])) {
- var mediaIndex = this.mediaIndex;
- this.logger_("currently processing part (index " + this.partIndex + ") no longer exists.");
- this.resetLoader();
- this.mediaIndex = mediaIndex;
- }
- }
- }
- if (segmentInfo) {
- segmentInfo.mediaIndex -= mediaSequenceDiff;
- if (segmentInfo.mediaIndex < 0) {
- segmentInfo.mediaIndex = null;
- segmentInfo.partIndex = null;
- } else {
- if (segmentInfo.mediaIndex >= 0) {
- segmentInfo.segment = newPlaylist.segments[segmentInfo.mediaIndex];
- }
- if (segmentInfo.partIndex >= 0 && segmentInfo.segment.parts) {
- segmentInfo.part = segmentInfo.segment.parts[segmentInfo.partIndex];
- }
- }
- }
- this.syncController_.saveExpiredSegmentInfo(oldPlaylist, newPlaylist);
- };
- _proto.pause = function pause() {
- if (this.checkBufferTimeout_) {
- window_1.clearTimeout(this.checkBufferTimeout_);
- this.checkBufferTimeout_ = null;
- }
- };
- _proto.paused = function paused() {
- return this.checkBufferTimeout_ === null;
- };
- _proto.resetEverything = function resetEverything(done) {
- this.ended_ = false;
- this.activeInitSegmentId_ = null;
- this.appendInitSegment_ = {
- audio: true,
- video: true
- };
- this.resetLoader();
- this.remove(0, Infinity, done);
- if (this.transmuxer_) {
- this.transmuxer_.postMessage({
- action: "clearAllMp4Captions"
- });
- this.transmuxer_.postMessage({
- action: "reset"
- });
- }
- };
- _proto.resetLoader = function resetLoader() {
- this.fetchAtBuffer_ = false;
- this.resyncLoader();
- };
- _proto.resyncLoader = function resyncLoader() {
- if (this.transmuxer_) {
- segmentTransmuxer.reset(this.transmuxer_);
- }
- this.mediaIndex = null;
- this.partIndex = null;
- this.syncPoint_ = null;
- this.isPendingTimestampOffset_ = false;
- this.callQueue_ = [];
- this.loadQueue_ = [];
- this.metadataQueue_.id3 = [];
- this.metadataQueue_.caption = [];
- this.abort();
- if (this.transmuxer_) {
- this.transmuxer_.postMessage({
- action: "clearParsedMp4Captions"
- });
- }
- };
- _proto.remove = function remove2(start2, end, done, force) {
- if (done === void 0) {
- done = function done2() {
- };
- }
- if (force === void 0) {
- force = false;
- }
- if (end === Infinity) {
- end = this.duration_();
- }
- if (end <= start2) {
- this.logger_("skipping remove because end ${end} is <= start ${start}");
- return;
- }
- if (!this.sourceUpdater_ || !this.getMediaInfo_()) {
- this.logger_("skipping remove because no source updater or starting media info");
- return;
- }
- var removesRemaining = 1;
- var removeFinished = function removeFinished2() {
- removesRemaining--;
- if (removesRemaining === 0) {
- done();
- }
- };
- if (force || !this.audioDisabled_) {
- removesRemaining++;
- this.sourceUpdater_.removeAudio(start2, end, removeFinished);
- }
- if (force || this.loaderType_ === "main") {
- this.gopBuffer_ = removeGopBuffer(this.gopBuffer_, start2, end, this.timeMapping_);
- removesRemaining++;
- this.sourceUpdater_.removeVideo(start2, end, removeFinished);
- }
- for (var track in this.inbandTextTracks_) {
- removeCuesFromTrack(start2, end, this.inbandTextTracks_[track]);
- }
- removeCuesFromTrack(start2, end, this.segmentMetadataTrack_);
- removeFinished();
- };
- _proto.monitorBuffer_ = function monitorBuffer_() {
- if (this.checkBufferTimeout_) {
- window_1.clearTimeout(this.checkBufferTimeout_);
- }
- this.checkBufferTimeout_ = window_1.setTimeout(this.monitorBufferTick_.bind(this), 1);
- };
- _proto.monitorBufferTick_ = function monitorBufferTick_() {
- if (this.state === "READY") {
- this.fillBuffer_();
- }
- if (this.checkBufferTimeout_) {
- window_1.clearTimeout(this.checkBufferTimeout_);
- }
- this.checkBufferTimeout_ = window_1.setTimeout(this.monitorBufferTick_.bind(this), CHECK_BUFFER_DELAY);
- };
- _proto.fillBuffer_ = function fillBuffer_() {
- if (this.sourceUpdater_.updating()) {
- return;
- }
- var segmentInfo = this.chooseNextRequest_();
- if (!segmentInfo) {
- return;
- }
- if (typeof segmentInfo.timestampOffset === "number") {
- this.isPendingTimestampOffset_ = false;
- this.timelineChangeController_.pendingTimelineChange({
- type: this.loaderType_,
- from: this.currentTimeline_,
- to: segmentInfo.timeline
- });
- }
- this.loadSegment_(segmentInfo);
- };
- _proto.isEndOfStream_ = function isEndOfStream_(mediaIndex, playlist, partIndex) {
- if (mediaIndex === void 0) {
- mediaIndex = this.mediaIndex;
- }
- if (playlist === void 0) {
- playlist = this.playlist_;
- }
- if (partIndex === void 0) {
- partIndex = this.partIndex;
- }
- if (!playlist || !this.mediaSource_) {
- return false;
- }
- var segment = typeof mediaIndex === "number" && playlist.segments[mediaIndex];
- var appendedLastSegment = mediaIndex + 1 === playlist.segments.length;
- var appendedLastPart = !segment || !segment.parts || partIndex + 1 === segment.parts.length;
- return playlist.endList && this.mediaSource_.readyState === "open" && appendedLastSegment && appendedLastPart;
- };
- _proto.chooseNextRequest_ = function chooseNextRequest_() {
- var buffered = this.buffered_();
- var bufferedEnd = lastBufferedEnd(buffered) || 0;
- var bufferedTime = timeAheadOf(buffered, this.currentTime_());
- var preloaded = !this.hasPlayed_() && bufferedTime >= 1;
- var haveEnoughBuffer = bufferedTime >= this.goalBufferLength_();
- var segments = this.playlist_.segments;
- if (!segments.length || preloaded || haveEnoughBuffer) {
- return null;
- }
- this.syncPoint_ = this.syncPoint_ || this.syncController_.getSyncPoint(this.playlist_, this.duration_(), this.currentTimeline_, this.currentTime_());
- var next = {
- partIndex: null,
- mediaIndex: null,
- startOfSegment: null,
- playlist: this.playlist_,
- isSyncRequest: Boolean(!this.syncPoint_)
- };
- if (next.isSyncRequest) {
- next.mediaIndex = getSyncSegmentCandidate(this.currentTimeline_, segments, bufferedEnd);
- } else if (this.mediaIndex !== null) {
- var segment = segments[this.mediaIndex];
- var partIndex = typeof this.partIndex === "number" ? this.partIndex : -1;
- next.startOfSegment = segment.end ? segment.end : bufferedEnd;
- if (segment.parts && segment.parts[partIndex + 1]) {
- next.mediaIndex = this.mediaIndex;
- next.partIndex = partIndex + 1;
- } else {
- next.mediaIndex = this.mediaIndex + 1;
- }
- } else {
- var _Playlist$getMediaInf = Playlist.getMediaInfoForTime({
- experimentalExactManifestTimings: this.experimentalExactManifestTimings,
- playlist: this.playlist_,
- currentTime: this.fetchAtBuffer_ ? bufferedEnd : this.currentTime_(),
- startingPartIndex: this.syncPoint_.partIndex,
- startingSegmentIndex: this.syncPoint_.segmentIndex,
- startTime: this.syncPoint_.time
- }), segmentIndex = _Playlist$getMediaInf.segmentIndex, startTime = _Playlist$getMediaInf.startTime, _partIndex = _Playlist$getMediaInf.partIndex;
- next.getMediaInfoForTime = this.fetchAtBuffer_ ? "bufferedEnd " + bufferedEnd : "currentTime " + this.currentTime_();
- next.mediaIndex = segmentIndex;
- next.startOfSegment = startTime;
- next.partIndex = _partIndex;
- }
- var nextSegment = segments[next.mediaIndex];
- var nextPart = nextSegment && typeof next.partIndex === "number" && nextSegment.parts && nextSegment.parts[next.partIndex];
- if (!nextSegment || typeof next.partIndex === "number" && !nextPart) {
- return null;
- }
- if (typeof next.partIndex !== "number" && nextSegment.parts) {
- next.partIndex = 0;
- nextPart = nextSegment.parts[0];
- }
- if (!bufferedTime && nextPart && !nextPart.independent) {
- if (next.partIndex === 0) {
- var lastSegment = segments[next.mediaIndex - 1];
- var lastSegmentLastPart = lastSegment.parts && lastSegment.parts.length && lastSegment.parts[lastSegment.parts.length - 1];
- if (lastSegmentLastPart && lastSegmentLastPart.independent) {
- next.mediaIndex -= 1;
- next.partIndex = lastSegment.parts.length - 1;
- next.independent = "previous segment";
- }
- } else if (nextSegment.parts[next.partIndex - 1].independent) {
- next.partIndex -= 1;
- next.independent = "previous part";
- }
- }
- var ended = this.mediaSource_ && this.mediaSource_.readyState === "ended";
- if (next.mediaIndex >= segments.length - 1 && ended && !this.seeking_()) {
- return null;
- }
- return this.generateSegmentInfo_(next);
- };
- _proto.generateSegmentInfo_ = function generateSegmentInfo_(options2) {
- var independent = options2.independent, playlist = options2.playlist, mediaIndex = options2.mediaIndex, startOfSegment = options2.startOfSegment, isSyncRequest = options2.isSyncRequest, partIndex = options2.partIndex, forceTimestampOffset = options2.forceTimestampOffset, getMediaInfoForTime3 = options2.getMediaInfoForTime;
- var segment = playlist.segments[mediaIndex];
- var part = typeof partIndex === "number" && segment.parts[partIndex];
- var segmentInfo = {
- requestId: "segment-loader-" + Math.random(),
- uri: part && part.resolvedUri || segment.resolvedUri,
- mediaIndex,
- partIndex: part ? partIndex : null,
- isSyncRequest,
- startOfSegment,
- playlist,
- bytes: null,
- encryptedBytes: null,
- timestampOffset: null,
- timeline: segment.timeline,
- duration: part && part.duration || segment.duration,
- segment,
- part,
- byteLength: 0,
- transmuxer: this.transmuxer_,
- getMediaInfoForTime: getMediaInfoForTime3,
- independent
- };
- var overrideCheck = typeof forceTimestampOffset !== "undefined" ? forceTimestampOffset : this.isPendingTimestampOffset_;
- segmentInfo.timestampOffset = this.timestampOffsetForSegment_({
- segmentTimeline: segment.timeline,
- currentTimeline: this.currentTimeline_,
- startOfSegment,
- buffered: this.buffered_(),
- overrideCheck
- });
- var audioBufferedEnd = lastBufferedEnd(this.sourceUpdater_.audioBuffered());
- if (typeof audioBufferedEnd === "number") {
- segmentInfo.audioAppendStart = audioBufferedEnd - this.sourceUpdater_.audioTimestampOffset();
- }
- if (this.sourceUpdater_.videoBuffered().length) {
- segmentInfo.gopsToAlignWith = gopsSafeToAlignWith(
- this.gopBuffer_,
- this.currentTime_() - this.sourceUpdater_.videoTimestampOffset(),
- this.timeMapping_
- );
- }
- return segmentInfo;
- };
- _proto.timestampOffsetForSegment_ = function timestampOffsetForSegment_(options2) {
- return timestampOffsetForSegment(options2);
- };
- _proto.earlyAbortWhenNeeded_ = function earlyAbortWhenNeeded_(stats) {
- if (this.vhs_.tech_.paused() || !this.xhrOptions_.timeout || !this.playlist_.attributes.BANDWIDTH) {
- return;
- }
- if (Date.now() - (stats.firstBytesReceivedAt || Date.now()) < 1e3) {
- return;
- }
- var currentTime = this.currentTime_();
- var measuredBandwidth = stats.bandwidth;
- var segmentDuration = this.pendingSegment_.duration;
- var requestTimeRemaining = Playlist.estimateSegmentRequestTime(segmentDuration, measuredBandwidth, this.playlist_, stats.bytesReceived);
- var timeUntilRebuffer$12 = timeUntilRebuffer(this.buffered_(), currentTime, this.vhs_.tech_.playbackRate()) - 1;
- if (requestTimeRemaining <= timeUntilRebuffer$12) {
- return;
- }
- var switchCandidate = minRebufferMaxBandwidthSelector({
- master: this.vhs_.playlists.master,
- currentTime,
- bandwidth: measuredBandwidth,
- duration: this.duration_(),
- segmentDuration,
- timeUntilRebuffer: timeUntilRebuffer$12,
- currentTimeline: this.currentTimeline_,
- syncController: this.syncController_
- });
- if (!switchCandidate) {
- return;
- }
- var rebufferingImpact = requestTimeRemaining - timeUntilRebuffer$12;
- var timeSavedBySwitching = rebufferingImpact - switchCandidate.rebufferingImpact;
- var minimumTimeSaving = 0.5;
- if (timeUntilRebuffer$12 <= TIME_FUDGE_FACTOR) {
- minimumTimeSaving = 1;
- }
- if (!switchCandidate.playlist || switchCandidate.playlist.uri === this.playlist_.uri || timeSavedBySwitching < minimumTimeSaving) {
- return;
- }
- this.bandwidth = switchCandidate.playlist.attributes.BANDWIDTH * Config.BANDWIDTH_VARIANCE + 1;
- this.trigger("earlyabort");
- };
- _proto.handleAbort_ = function handleAbort_(segmentInfo) {
- this.logger_("Aborting " + segmentInfoString(segmentInfo));
- this.mediaRequestsAborted += 1;
- };
- _proto.handleProgress_ = function handleProgress_(event2, simpleSegment) {
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- this.trigger("progress");
- };
- _proto.handleTrackInfo_ = function handleTrackInfo_(simpleSegment, trackInfo) {
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- if (this.checkForIllegalMediaSwitch(trackInfo)) {
- return;
- }
- trackInfo = trackInfo || {};
- if (!shallowEqual(this.currentMediaInfo_, trackInfo)) {
- this.appendInitSegment_ = {
- audio: true,
- video: true
- };
- this.startingMediaInfo_ = trackInfo;
- this.currentMediaInfo_ = trackInfo;
- this.logger_("trackinfo update", trackInfo);
- this.trigger("trackinfo");
- }
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- this.pendingSegment_.trackInfo = trackInfo;
- if (this.hasEnoughInfoToAppend_()) {
- this.processCallQueue_();
- }
- };
- _proto.handleTimingInfo_ = function handleTimingInfo_(simpleSegment, mediaType, timeType, time) {
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- var segmentInfo = this.pendingSegment_;
- var timingInfoProperty = timingInfoPropertyForMedia(mediaType);
- segmentInfo[timingInfoProperty] = segmentInfo[timingInfoProperty] || {};
- segmentInfo[timingInfoProperty][timeType] = time;
- this.logger_("timinginfo: " + mediaType + " - " + timeType + " - " + time);
- if (this.hasEnoughInfoToAppend_()) {
- this.processCallQueue_();
- }
- };
- _proto.handleCaptions_ = function handleCaptions_(simpleSegment, captionData) {
- var _this2 = this;
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- if (captionData.length === 0) {
- this.logger_("SegmentLoader received no captions from a caption event");
- return;
- }
- var segmentInfo = this.pendingSegment_;
- if (!segmentInfo.hasAppendedData_) {
- this.metadataQueue_.caption.push(this.handleCaptions_.bind(this, simpleSegment, captionData));
- return;
- }
- var timestampOffset2 = this.sourceUpdater_.videoTimestampOffset() === null ? this.sourceUpdater_.audioTimestampOffset() : this.sourceUpdater_.videoTimestampOffset();
- var captionTracks = {};
- captionData.forEach(function(caption) {
- captionTracks[caption.stream] = captionTracks[caption.stream] || {
- startTime: Infinity,
- captions: [],
- endTime: 0
- };
- var captionTrack = captionTracks[caption.stream];
- captionTrack.startTime = Math.min(captionTrack.startTime, caption.startTime + timestampOffset2);
- captionTrack.endTime = Math.max(captionTrack.endTime, caption.endTime + timestampOffset2);
- captionTrack.captions.push(caption);
- });
- Object.keys(captionTracks).forEach(function(trackName) {
- var _captionTracks$trackN = captionTracks[trackName], startTime = _captionTracks$trackN.startTime, endTime = _captionTracks$trackN.endTime, captions = _captionTracks$trackN.captions;
- var inbandTextTracks = _this2.inbandTextTracks_;
- _this2.logger_("adding cues from " + startTime + " -> " + endTime + " for " + trackName);
- createCaptionsTrackIfNotExists(inbandTextTracks, _this2.vhs_.tech_, trackName);
- removeCuesFromTrack(startTime, endTime, inbandTextTracks[trackName]);
- addCaptionData({
- captionArray: captions,
- inbandTextTracks,
- timestampOffset: timestampOffset2
- });
- });
- if (this.transmuxer_) {
- this.transmuxer_.postMessage({
- action: "clearParsedMp4Captions"
- });
- }
- };
- _proto.handleId3_ = function handleId3_(simpleSegment, id3Frames, dispatchType) {
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- var segmentInfo = this.pendingSegment_;
- if (!segmentInfo.hasAppendedData_) {
- this.metadataQueue_.id3.push(this.handleId3_.bind(this, simpleSegment, id3Frames, dispatchType));
- return;
- }
- var timestampOffset2 = this.sourceUpdater_.videoTimestampOffset() === null ? this.sourceUpdater_.audioTimestampOffset() : this.sourceUpdater_.videoTimestampOffset();
- createMetadataTrackIfNotExists(this.inbandTextTracks_, dispatchType, this.vhs_.tech_);
- addMetadata({
- inbandTextTracks: this.inbandTextTracks_,
- metadataArray: id3Frames,
- timestampOffset: timestampOffset2,
- videoDuration: this.duration_()
- });
- };
- _proto.processMetadataQueue_ = function processMetadataQueue_() {
- this.metadataQueue_.id3.forEach(function(fn2) {
- return fn2();
- });
- this.metadataQueue_.caption.forEach(function(fn2) {
- return fn2();
- });
- this.metadataQueue_.id3 = [];
- this.metadataQueue_.caption = [];
- };
- _proto.processCallQueue_ = function processCallQueue_() {
- var callQueue = this.callQueue_;
- this.callQueue_ = [];
- callQueue.forEach(function(fun) {
- return fun();
- });
- };
- _proto.processLoadQueue_ = function processLoadQueue_() {
- var loadQueue = this.loadQueue_;
- this.loadQueue_ = [];
- loadQueue.forEach(function(fun) {
- return fun();
- });
- };
- _proto.hasEnoughInfoToLoad_ = function hasEnoughInfoToLoad_() {
- if (this.loaderType_ !== "audio") {
- return true;
- }
- var segmentInfo = this.pendingSegment_;
- if (!segmentInfo) {
- return false;
- }
- if (!this.getCurrentMediaInfo_()) {
- return true;
- }
- if (shouldWaitForTimelineChange({
- timelineChangeController: this.timelineChangeController_,
- currentTimeline: this.currentTimeline_,
- segmentTimeline: segmentInfo.timeline,
- loaderType: this.loaderType_,
- audioDisabled: this.audioDisabled_
- })) {
- return false;
- }
- return true;
- };
- _proto.getCurrentMediaInfo_ = function getCurrentMediaInfo_(segmentInfo) {
- if (segmentInfo === void 0) {
- segmentInfo = this.pendingSegment_;
- }
- return segmentInfo && segmentInfo.trackInfo || this.currentMediaInfo_;
- };
- _proto.getMediaInfo_ = function getMediaInfo_(segmentInfo) {
- if (segmentInfo === void 0) {
- segmentInfo = this.pendingSegment_;
- }
- return this.getCurrentMediaInfo_(segmentInfo) || this.startingMediaInfo_;
- };
- _proto.getPendingSegmentPlaylist = function getPendingSegmentPlaylist() {
- return this.pendingSegment_ ? this.pendingSegment_.playlist : null;
- };
- _proto.hasEnoughInfoToAppend_ = function hasEnoughInfoToAppend_() {
- if (!this.sourceUpdater_.ready()) {
- return false;
- }
- if (this.waitingOnRemove_ || this.quotaExceededErrorRetryTimeout_) {
- return false;
- }
- var segmentInfo = this.pendingSegment_;
- var trackInfo = this.getCurrentMediaInfo_();
- if (!segmentInfo || !trackInfo) {
- return false;
- }
- var hasAudio = trackInfo.hasAudio, hasVideo = trackInfo.hasVideo, isMuxed3 = trackInfo.isMuxed;
- if (hasVideo && !segmentInfo.videoTimingInfo) {
- return false;
- }
- if (hasAudio && !this.audioDisabled_ && !isMuxed3 && !segmentInfo.audioTimingInfo) {
- return false;
- }
- if (shouldWaitForTimelineChange({
- timelineChangeController: this.timelineChangeController_,
- currentTimeline: this.currentTimeline_,
- segmentTimeline: segmentInfo.timeline,
- loaderType: this.loaderType_,
- audioDisabled: this.audioDisabled_
- })) {
- return false;
- }
- return true;
- };
- _proto.handleData_ = function handleData_3(simpleSegment, result) {
- this.earlyAbortWhenNeeded_(simpleSegment.stats);
- if (this.checkForAbort_(simpleSegment.requestId)) {
- return;
- }
- if (this.callQueue_.length || !this.hasEnoughInfoToAppend_()) {
- this.callQueue_.push(this.handleData_.bind(this, simpleSegment, result));
- return;
- }
- var segmentInfo = this.pendingSegment_;
- this.setTimeMapping_(segmentInfo.timeline);
- this.updateMediaSecondsLoaded_(segmentInfo.part || segmentInfo.segment);
- if (this.mediaSource_.readyState === "closed") {
- return;
- }
- if (simpleSegment.map) {
- simpleSegment.map = this.initSegmentForMap(simpleSegment.map, true);
- segmentInfo.segment.map = simpleSegment.map;
- }
- if (simpleSegment.key) {
- this.segmentKey(simpleSegment.key, true);
- }
- segmentInfo.isFmp4 = simpleSegment.isFmp4;
- segmentInfo.timingInfo = segmentInfo.timingInfo || {};
- if (segmentInfo.isFmp4) {
- this.trigger("fmp4");
- segmentInfo.timingInfo.start = segmentInfo[timingInfoPropertyForMedia(result.type)].start;
- } else {
- var trackInfo = this.getCurrentMediaInfo_();
- var useVideoTimingInfo = this.loaderType_ === "main" && trackInfo && trackInfo.hasVideo;
- var firstVideoFrameTimeForData;
- if (useVideoTimingInfo) {
- firstVideoFrameTimeForData = segmentInfo.videoTimingInfo.start;
- }
- segmentInfo.timingInfo.start = this.trueSegmentStart_({
- currentStart: segmentInfo.timingInfo.start,
- playlist: segmentInfo.playlist,
- mediaIndex: segmentInfo.mediaIndex,
- currentVideoTimestampOffset: this.sourceUpdater_.videoTimestampOffset(),
- useVideoTimingInfo,
- firstVideoFrameTimeForData,
- videoTimingInfo: segmentInfo.videoTimingInfo,
- audioTimingInfo: segmentInfo.audioTimingInfo
- });
- }
- this.updateAppendInitSegmentStatus(segmentInfo, result.type);
- this.updateSourceBufferTimestampOffset_(segmentInfo);
- if (segmentInfo.isSyncRequest) {
- this.updateTimingInfoEnd_(segmentInfo);
- this.syncController_.saveSegmentTimingInfo({
- segmentInfo,
- shouldSaveTimelineMapping: this.loaderType_ === "main"
- });
- var next = this.chooseNextRequest_();
- if (next.mediaIndex !== segmentInfo.mediaIndex || next.partIndex !== segmentInfo.partIndex) {
- this.logger_("sync segment was incorrect, not appending");
- return;
- }
- this.logger_("sync segment was correct, appending");
- }
- segmentInfo.hasAppendedData_ = true;
- this.processMetadataQueue_();
- this.appendData_(segmentInfo, result);
- };
- _proto.updateAppendInitSegmentStatus = function updateAppendInitSegmentStatus(segmentInfo, type2) {
- if (this.loaderType_ === "main" && typeof segmentInfo.timestampOffset === "number" && !segmentInfo.changedTimestampOffset) {
- this.appendInitSegment_ = {
- audio: true,
- video: true
- };
- }
- if (this.playlistOfLastInitSegment_[type2] !== segmentInfo.playlist) {
- this.appendInitSegment_[type2] = true;
- }
- };
- _proto.getInitSegmentAndUpdateState_ = function getInitSegmentAndUpdateState_(_ref4) {
- var type2 = _ref4.type, initSegment = _ref4.initSegment, map = _ref4.map, playlist = _ref4.playlist;
- if (map) {
- var id = initSegmentId(map);
- if (this.activeInitSegmentId_ === id) {
- return null;
- }
- initSegment = this.initSegmentForMap(map, true).bytes;
- this.activeInitSegmentId_ = id;
- }
- if (initSegment && this.appendInitSegment_[type2]) {
- this.playlistOfLastInitSegment_[type2] = playlist;
- this.appendInitSegment_[type2] = false;
- this.activeInitSegmentId_ = null;
- return initSegment;
- }
- return null;
- };
- _proto.handleQuotaExceededError_ = function handleQuotaExceededError_(_ref5, error) {
- var _this3 = this;
- var segmentInfo = _ref5.segmentInfo, type2 = _ref5.type, bytes = _ref5.bytes;
- var audioBuffered = this.sourceUpdater_.audioBuffered();
- var videoBuffered = this.sourceUpdater_.videoBuffered();
- if (audioBuffered.length > 1) {
- this.logger_("On QUOTA_EXCEEDED_ERR, found gaps in the audio buffer: " + timeRangesToArray(audioBuffered).join(", "));
- }
- if (videoBuffered.length > 1) {
- this.logger_("On QUOTA_EXCEEDED_ERR, found gaps in the video buffer: " + timeRangesToArray(videoBuffered).join(", "));
- }
- var audioBufferStart = audioBuffered.length ? audioBuffered.start(0) : 0;
- var audioBufferEnd = audioBuffered.length ? audioBuffered.end(audioBuffered.length - 1) : 0;
- var videoBufferStart = videoBuffered.length ? videoBuffered.start(0) : 0;
- var videoBufferEnd = videoBuffered.length ? videoBuffered.end(videoBuffered.length - 1) : 0;
- if (audioBufferEnd - audioBufferStart <= MIN_BACK_BUFFER && videoBufferEnd - videoBufferStart <= MIN_BACK_BUFFER) {
- this.logger_("On QUOTA_EXCEEDED_ERR, single segment too large to append to buffer, triggering an error. " + ("Appended byte length: " + bytes.byteLength + ", ") + ("audio buffer: " + timeRangesToArray(audioBuffered).join(", ") + ", ") + ("video buffer: " + timeRangesToArray(videoBuffered).join(", ") + ", "));
- this.error({
- message: "Quota exceeded error with append of a single segment of content",
- excludeUntil: Infinity
- });
- this.trigger("error");
- return;
- }
- this.waitingOnRemove_ = true;
- this.callQueue_.push(this.appendToSourceBuffer_.bind(this, {
- segmentInfo,
- type: type2,
- bytes
- }));
- var currentTime = this.currentTime_();
- var timeToRemoveUntil = currentTime - MIN_BACK_BUFFER;
- this.logger_("On QUOTA_EXCEEDED_ERR, removing audio/video from 0 to " + timeToRemoveUntil);
- this.remove(0, timeToRemoveUntil, function() {
- _this3.logger_("On QUOTA_EXCEEDED_ERR, retrying append in " + MIN_BACK_BUFFER + "s");
- _this3.waitingOnRemove_ = false;
- _this3.quotaExceededErrorRetryTimeout_ = window_1.setTimeout(function() {
- _this3.logger_("On QUOTA_EXCEEDED_ERR, re-processing call queue");
- _this3.quotaExceededErrorRetryTimeout_ = null;
- _this3.processCallQueue_();
- }, MIN_BACK_BUFFER * 1e3);
- }, true);
- };
- _proto.handleAppendError_ = function handleAppendError_(_ref6, error) {
- var segmentInfo = _ref6.segmentInfo, type2 = _ref6.type, bytes = _ref6.bytes;
- if (!error) {
- return;
- }
- if (error.code === QUOTA_EXCEEDED_ERR) {
- this.handleQuotaExceededError_({
- segmentInfo,
- type: type2,
- bytes
- });
- return;
- }
- this.logger_("Received non QUOTA_EXCEEDED_ERR on append", error);
- this.error(type2 + " append of " + bytes.length + "b failed for segment " + ("#" + segmentInfo.mediaIndex + " in playlist " + segmentInfo.playlist.id));
- this.trigger("appenderror");
- };
- _proto.appendToSourceBuffer_ = function appendToSourceBuffer_(_ref7) {
- var segmentInfo = _ref7.segmentInfo, type2 = _ref7.type, initSegment = _ref7.initSegment, data = _ref7.data, bytes = _ref7.bytes;
- if (!bytes) {
- var segments = [data];
- var byteLength = data.byteLength;
- if (initSegment) {
- segments.unshift(initSegment);
- byteLength += initSegment.byteLength;
- }
- bytes = concatSegments({
- bytes: byteLength,
- segments
- });
- }
- this.sourceUpdater_.appendBuffer({
- segmentInfo,
- type: type2,
- bytes
- }, this.handleAppendError_.bind(this, {
- segmentInfo,
- type: type2,
- bytes
- }));
- };
- _proto.handleSegmentTimingInfo_ = function handleSegmentTimingInfo_(type2, requestId, segmentTimingInfo) {
- if (!this.pendingSegment_ || requestId !== this.pendingSegment_.requestId) {
- return;
- }
- var segment = this.pendingSegment_.segment;
- var timingInfoProperty = type2 + "TimingInfo";
- if (!segment[timingInfoProperty]) {
- segment[timingInfoProperty] = {};
- }
- segment[timingInfoProperty].transmuxerPrependedSeconds = segmentTimingInfo.prependedContentDuration || 0;
- segment[timingInfoProperty].transmuxedPresentationStart = segmentTimingInfo.start.presentation;
- segment[timingInfoProperty].transmuxedDecodeStart = segmentTimingInfo.start.decode;
- segment[timingInfoProperty].transmuxedPresentationEnd = segmentTimingInfo.end.presentation;
- segment[timingInfoProperty].transmuxedDecodeEnd = segmentTimingInfo.end.decode;
- segment[timingInfoProperty].baseMediaDecodeTime = segmentTimingInfo.baseMediaDecodeTime;
- };
- _proto.appendData_ = function appendData_(segmentInfo, result) {
- var type2 = result.type, data = result.data;
- if (!data || !data.byteLength) {
- return;
- }
- if (type2 === "audio" && this.audioDisabled_) {
- return;
- }
- var initSegment = this.getInitSegmentAndUpdateState_({
- type: type2,
- initSegment: result.initSegment,
- playlist: segmentInfo.playlist,
- map: segmentInfo.isFmp4 ? segmentInfo.segment.map : null
- });
- this.appendToSourceBuffer_({
- segmentInfo,
- type: type2,
- initSegment,
- data
- });
- };
- _proto.loadSegment_ = function loadSegment_(segmentInfo) {
- var _this4 = this;
- this.state = "WAITING";
- this.pendingSegment_ = segmentInfo;
- this.trimBackBuffer_(segmentInfo);
- if (typeof segmentInfo.timestampOffset === "number") {
- if (this.transmuxer_) {
- this.transmuxer_.postMessage({
- action: "clearAllMp4Captions"
- });
- }
- }
- if (!this.hasEnoughInfoToLoad_()) {
- this.loadQueue_.push(function() {
- var options2 = _extends$2({}, segmentInfo, {
- forceTimestampOffset: true
- });
- _extends$2(segmentInfo, _this4.generateSegmentInfo_(options2));
- _this4.isPendingTimestampOffset_ = false;
- _this4.updateTransmuxerAndRequestSegment_(segmentInfo);
- });
- return;
- }
- this.updateTransmuxerAndRequestSegment_(segmentInfo);
- };
- _proto.updateTransmuxerAndRequestSegment_ = function updateTransmuxerAndRequestSegment_(segmentInfo) {
- var _this5 = this;
- if (this.shouldUpdateTransmuxerTimestampOffset_(segmentInfo.timestampOffset)) {
- this.gopBuffer_.length = 0;
- segmentInfo.gopsToAlignWith = [];
- this.timeMapping_ = 0;
- this.transmuxer_.postMessage({
- action: "reset"
- });
- this.transmuxer_.postMessage({
- action: "setTimestampOffset",
- timestampOffset: segmentInfo.timestampOffset
- });
- }
- var simpleSegment = this.createSimplifiedSegmentObj_(segmentInfo);
- var isEndOfStream = this.isEndOfStream_(segmentInfo.mediaIndex, segmentInfo.playlist, segmentInfo.partIndex);
- var isWalkingForward = this.mediaIndex !== null;
- var isDiscontinuity = segmentInfo.timeline !== this.currentTimeline_ && segmentInfo.timeline > 0;
- var isEndOfTimeline = isEndOfStream || isWalkingForward && isDiscontinuity;
- this.logger_("Requesting " + segmentInfoString(segmentInfo));
- if (simpleSegment.map && !simpleSegment.map.bytes) {
- this.logger_("going to request init segment.");
- this.appendInitSegment_ = {
- video: true,
- audio: true
- };
- }
- segmentInfo.abortRequests = mediaSegmentRequest({
- xhr: this.vhs_.xhr,
- xhrOptions: this.xhrOptions_,
- decryptionWorker: this.decrypter_,
- segment: simpleSegment,
- abortFn: this.handleAbort_.bind(this, segmentInfo),
- progressFn: this.handleProgress_.bind(this),
- trackInfoFn: this.handleTrackInfo_.bind(this),
- timingInfoFn: this.handleTimingInfo_.bind(this),
- videoSegmentTimingInfoFn: this.handleSegmentTimingInfo_.bind(this, "video", segmentInfo.requestId),
- audioSegmentTimingInfoFn: this.handleSegmentTimingInfo_.bind(this, "audio", segmentInfo.requestId),
- captionsFn: this.handleCaptions_.bind(this),
- isEndOfTimeline,
- endedTimelineFn: function endedTimelineFn() {
- _this5.logger_("received endedtimeline callback");
- },
- id3Fn: this.handleId3_.bind(this),
- dataFn: this.handleData_.bind(this),
- doneFn: this.segmentRequestFinished_.bind(this),
- onTransmuxerLog: function onTransmuxerLog(_ref8) {
- var message = _ref8.message, level = _ref8.level, stream = _ref8.stream;
- _this5.logger_(segmentInfoString(segmentInfo) + " logged from transmuxer stream " + stream + " as a " + level + ": " + message);
- }
- });
- };
- _proto.trimBackBuffer_ = function trimBackBuffer_(segmentInfo) {
- var removeToTime = safeBackBufferTrimTime(this.seekable_(), this.currentTime_(), this.playlist_.targetDuration || 10);
- if (removeToTime > 0) {
- this.remove(0, removeToTime);
- }
- };
- _proto.createSimplifiedSegmentObj_ = function createSimplifiedSegmentObj_(segmentInfo) {
- var segment = segmentInfo.segment;
- var part = segmentInfo.part;
- var simpleSegment = {
- resolvedUri: part ? part.resolvedUri : segment.resolvedUri,
- byterange: part ? part.byterange : segment.byterange,
- requestId: segmentInfo.requestId,
- transmuxer: segmentInfo.transmuxer,
- audioAppendStart: segmentInfo.audioAppendStart,
- gopsToAlignWith: segmentInfo.gopsToAlignWith,
- part: segmentInfo.part
- };
- var previousSegment = segmentInfo.playlist.segments[segmentInfo.mediaIndex - 1];
- if (previousSegment && previousSegment.timeline === segment.timeline) {
- if (previousSegment.videoTimingInfo) {
- simpleSegment.baseStartTime = previousSegment.videoTimingInfo.transmuxedDecodeEnd;
- } else if (previousSegment.audioTimingInfo) {
- simpleSegment.baseStartTime = previousSegment.audioTimingInfo.transmuxedDecodeEnd;
- }
- }
- if (segment.key) {
- var iv = segment.key.iv || new Uint32Array([0, 0, 0, segmentInfo.mediaIndex + segmentInfo.playlist.mediaSequence]);
- simpleSegment.key = this.segmentKey(segment.key);
- simpleSegment.key.iv = iv;
- }
- if (segment.map) {
- simpleSegment.map = this.initSegmentForMap(segment.map);
- }
- return simpleSegment;
- };
- _proto.saveTransferStats_ = function saveTransferStats_(stats) {
- this.mediaRequests += 1;
- if (stats) {
- this.mediaBytesTransferred += stats.bytesReceived;
- this.mediaTransferDuration += stats.roundTripTime;
- }
- };
- _proto.saveBandwidthRelatedStats_ = function saveBandwidthRelatedStats_(duration5, stats) {
- this.pendingSegment_.byteLength = stats.bytesReceived;
- if (duration5 < MIN_SEGMENT_DURATION_TO_SAVE_STATS) {
- this.logger_("Ignoring segment's bandwidth because its duration of " + duration5 + (" is less than the min to record " + MIN_SEGMENT_DURATION_TO_SAVE_STATS));
- return;
- }
- this.bandwidth = stats.bandwidth;
- this.roundTrip = stats.roundTripTime;
- };
- _proto.handleTimeout_ = function handleTimeout_() {
- this.mediaRequestsTimedout += 1;
- this.bandwidth = 1;
- this.roundTrip = NaN;
- this.trigger("bandwidthupdate");
- this.trigger("timeout");
- };
- _proto.segmentRequestFinished_ = function segmentRequestFinished_(error, simpleSegment, result) {
- if (this.callQueue_.length) {
- this.callQueue_.push(this.segmentRequestFinished_.bind(this, error, simpleSegment, result));
- return;
- }
- this.saveTransferStats_(simpleSegment.stats);
- if (!this.pendingSegment_) {
- return;
- }
- if (simpleSegment.requestId !== this.pendingSegment_.requestId) {
- return;
- }
- if (error) {
- this.pendingSegment_ = null;
- this.state = "READY";
- if (error.code === REQUEST_ERRORS.ABORTED) {
- return;
- }
- this.pause();
- if (error.code === REQUEST_ERRORS.TIMEOUT) {
- this.handleTimeout_();
- return;
- }
- this.mediaRequestsErrored += 1;
- this.error(error);
- this.trigger("error");
- return;
- }
- var segmentInfo = this.pendingSegment_;
- this.saveBandwidthRelatedStats_(segmentInfo.duration, simpleSegment.stats);
- segmentInfo.endOfAllRequests = simpleSegment.endOfAllRequests;
- if (result.gopInfo) {
- this.gopBuffer_ = updateGopBuffer(this.gopBuffer_, result.gopInfo, this.safeAppend_);
- }
- this.state = "APPENDING";
- this.trigger("appending");
- this.waitForAppendsToComplete_(segmentInfo);
- };
- _proto.setTimeMapping_ = function setTimeMapping_(timeline) {
- var timelineMapping = this.syncController_.mappingForTimeline(timeline);
- if (timelineMapping !== null) {
- this.timeMapping_ = timelineMapping;
- }
- };
- _proto.updateMediaSecondsLoaded_ = function updateMediaSecondsLoaded_(segment) {
- if (typeof segment.start === "number" && typeof segment.end === "number") {
- this.mediaSecondsLoaded += segment.end - segment.start;
- } else {
- this.mediaSecondsLoaded += segment.duration;
- }
- };
- _proto.shouldUpdateTransmuxerTimestampOffset_ = function shouldUpdateTransmuxerTimestampOffset_(timestampOffset2) {
- if (timestampOffset2 === null) {
- return false;
- }
- if (this.loaderType_ === "main" && timestampOffset2 !== this.sourceUpdater_.videoTimestampOffset()) {
- return true;
- }
- if (!this.audioDisabled_ && timestampOffset2 !== this.sourceUpdater_.audioTimestampOffset()) {
- return true;
- }
- return false;
- };
- _proto.trueSegmentStart_ = function trueSegmentStart_(_ref9) {
- var currentStart = _ref9.currentStart, playlist = _ref9.playlist, mediaIndex = _ref9.mediaIndex, firstVideoFrameTimeForData = _ref9.firstVideoFrameTimeForData, currentVideoTimestampOffset = _ref9.currentVideoTimestampOffset, useVideoTimingInfo = _ref9.useVideoTimingInfo, videoTimingInfo = _ref9.videoTimingInfo, audioTimingInfo = _ref9.audioTimingInfo;
- if (typeof currentStart !== "undefined") {
- return currentStart;
- }
- if (!useVideoTimingInfo) {
- return audioTimingInfo.start;
- }
- var previousSegment = playlist.segments[mediaIndex - 1];
- if (mediaIndex === 0 || !previousSegment || typeof previousSegment.start === "undefined" || previousSegment.end !== firstVideoFrameTimeForData + currentVideoTimestampOffset) {
- return firstVideoFrameTimeForData;
- }
- return videoTimingInfo.start;
- };
- _proto.waitForAppendsToComplete_ = function waitForAppendsToComplete_(segmentInfo) {
- var trackInfo = this.getCurrentMediaInfo_(segmentInfo);
- if (!trackInfo) {
- this.error({
- message: "No starting media returned, likely due to an unsupported media format.",
- blacklistDuration: Infinity
- });
- this.trigger("error");
- return;
- }
- var hasAudio = trackInfo.hasAudio, hasVideo = trackInfo.hasVideo, isMuxed3 = trackInfo.isMuxed;
- var waitForVideo = this.loaderType_ === "main" && hasVideo;
- var waitForAudio = !this.audioDisabled_ && hasAudio && !isMuxed3;
- segmentInfo.waitingOnAppends = 0;
- if (!segmentInfo.hasAppendedData_) {
- if (!segmentInfo.timingInfo && typeof segmentInfo.timestampOffset === "number") {
- this.isPendingTimestampOffset_ = true;
- }
- segmentInfo.timingInfo = {
- start: 0
- };
- segmentInfo.waitingOnAppends++;
- if (!this.isPendingTimestampOffset_) {
- this.updateSourceBufferTimestampOffset_(segmentInfo);
- this.processMetadataQueue_();
- }
- this.checkAppendsDone_(segmentInfo);
- return;
- }
- if (waitForVideo) {
- segmentInfo.waitingOnAppends++;
- }
- if (waitForAudio) {
- segmentInfo.waitingOnAppends++;
- }
- if (waitForVideo) {
- this.sourceUpdater_.videoQueueCallback(this.checkAppendsDone_.bind(this, segmentInfo));
- }
- if (waitForAudio) {
- this.sourceUpdater_.audioQueueCallback(this.checkAppendsDone_.bind(this, segmentInfo));
- }
- };
- _proto.checkAppendsDone_ = function checkAppendsDone_(segmentInfo) {
- if (this.checkForAbort_(segmentInfo.requestId)) {
- return;
- }
- segmentInfo.waitingOnAppends--;
- if (segmentInfo.waitingOnAppends === 0) {
- this.handleAppendsDone_();
- }
- };
- _proto.checkForIllegalMediaSwitch = function checkForIllegalMediaSwitch(trackInfo) {
- var illegalMediaSwitchError = illegalMediaSwitch(this.loaderType_, this.getCurrentMediaInfo_(), trackInfo);
- if (illegalMediaSwitchError) {
- this.error({
- message: illegalMediaSwitchError,
- blacklistDuration: Infinity
- });
- this.trigger("error");
- return true;
- }
- return false;
- };
- _proto.updateSourceBufferTimestampOffset_ = function updateSourceBufferTimestampOffset_(segmentInfo) {
- if (segmentInfo.timestampOffset === null || typeof segmentInfo.timingInfo.start !== "number" || segmentInfo.changedTimestampOffset || this.loaderType_ !== "main") {
- return;
- }
- var didChange = false;
- segmentInfo.timestampOffset -= this.getSegmentStartTimeForTimestampOffsetCalculation_({
- videoTimingInfo: segmentInfo.segment.videoTimingInfo,
- audioTimingInfo: segmentInfo.segment.audioTimingInfo,
- timingInfo: segmentInfo.timingInfo
- });
- segmentInfo.changedTimestampOffset = true;
- if (segmentInfo.timestampOffset !== this.sourceUpdater_.videoTimestampOffset()) {
- this.sourceUpdater_.videoTimestampOffset(segmentInfo.timestampOffset);
- didChange = true;
- }
- if (segmentInfo.timestampOffset !== this.sourceUpdater_.audioTimestampOffset()) {
- this.sourceUpdater_.audioTimestampOffset(segmentInfo.timestampOffset);
- didChange = true;
- }
- if (didChange) {
- this.trigger("timestampoffset");
- }
- };
- _proto.getSegmentStartTimeForTimestampOffsetCalculation_ = function getSegmentStartTimeForTimestampOffsetCalculation_(_ref10) {
- var videoTimingInfo = _ref10.videoTimingInfo, audioTimingInfo = _ref10.audioTimingInfo, timingInfo = _ref10.timingInfo;
- if (!this.useDtsForTimestampOffset_) {
- return timingInfo.start;
- }
- if (videoTimingInfo && typeof videoTimingInfo.transmuxedDecodeStart === "number") {
- return videoTimingInfo.transmuxedDecodeStart;
- }
- if (audioTimingInfo && typeof audioTimingInfo.transmuxedDecodeStart === "number") {
- return audioTimingInfo.transmuxedDecodeStart;
- }
- return timingInfo.start;
- };
- _proto.updateTimingInfoEnd_ = function updateTimingInfoEnd_(segmentInfo) {
- segmentInfo.timingInfo = segmentInfo.timingInfo || {};
- var trackInfo = this.getMediaInfo_();
- var useVideoTimingInfo = this.loaderType_ === "main" && trackInfo && trackInfo.hasVideo;
- var prioritizedTimingInfo = useVideoTimingInfo && segmentInfo.videoTimingInfo ? segmentInfo.videoTimingInfo : segmentInfo.audioTimingInfo;
- if (!prioritizedTimingInfo) {
- return;
- }
- segmentInfo.timingInfo.end = typeof prioritizedTimingInfo.end === "number" ? prioritizedTimingInfo.end : prioritizedTimingInfo.start + segmentInfo.duration;
- };
- _proto.handleAppendsDone_ = function handleAppendsDone_() {
- if (this.pendingSegment_) {
- this.trigger("appendsdone");
- }
- if (!this.pendingSegment_) {
- this.state = "READY";
- if (!this.paused()) {
- this.monitorBuffer_();
- }
- return;
- }
- var segmentInfo = this.pendingSegment_;
- this.updateTimingInfoEnd_(segmentInfo);
- if (this.shouldSaveSegmentTimingInfo_) {
- this.syncController_.saveSegmentTimingInfo({
- segmentInfo,
- shouldSaveTimelineMapping: this.loaderType_ === "main"
- });
- }
- var segmentDurationMessage = getTroublesomeSegmentDurationMessage(segmentInfo, this.sourceType_);
- if (segmentDurationMessage) {
- if (segmentDurationMessage.severity === "warn") {
- videojs.log.warn(segmentDurationMessage.message);
- } else {
- this.logger_(segmentDurationMessage.message);
- }
- }
- this.recordThroughput_(segmentInfo);
- this.pendingSegment_ = null;
- this.state = "READY";
- if (segmentInfo.isSyncRequest) {
- this.trigger("syncinfoupdate");
- if (!segmentInfo.hasAppendedData_) {
- this.logger_("Throwing away un-appended sync request " + segmentInfoString(segmentInfo));
- return;
- }
- }
- this.logger_("Appended " + segmentInfoString(segmentInfo));
- this.addSegmentMetadataCue_(segmentInfo);
- this.fetchAtBuffer_ = true;
- if (this.currentTimeline_ !== segmentInfo.timeline) {
- this.timelineChangeController_.lastTimelineChange({
- type: this.loaderType_,
- from: this.currentTimeline_,
- to: segmentInfo.timeline
- });
- if (this.loaderType_ === "main" && !this.audioDisabled_) {
- this.timelineChangeController_.lastTimelineChange({
- type: "audio",
- from: this.currentTimeline_,
- to: segmentInfo.timeline
- });
- }
- }
- this.currentTimeline_ = segmentInfo.timeline;
- this.trigger("syncinfoupdate");
- var segment = segmentInfo.segment;
- var part = segmentInfo.part;
- var badSegmentGuess = segment.end && this.currentTime_() - segment.end > segmentInfo.playlist.targetDuration * 3;
- var badPartGuess = part && part.end && this.currentTime_() - part.end > segmentInfo.playlist.partTargetDuration * 3;
- if (badSegmentGuess || badPartGuess) {
- this.logger_("bad " + (badSegmentGuess ? "segment" : "part") + " " + segmentInfoString(segmentInfo));
- this.resetEverything();
- return;
- }
- var isWalkingForward = this.mediaIndex !== null;
- if (isWalkingForward) {
- this.trigger("bandwidthupdate");
- }
- this.trigger("progress");
- this.mediaIndex = segmentInfo.mediaIndex;
- this.partIndex = segmentInfo.partIndex;
- if (this.isEndOfStream_(segmentInfo.mediaIndex, segmentInfo.playlist, segmentInfo.partIndex)) {
- this.endOfStream();
- }
- this.trigger("appended");
- if (segmentInfo.hasAppendedData_) {
- this.mediaAppends++;
- }
- if (!this.paused()) {
- this.monitorBuffer_();
- }
- };
- _proto.recordThroughput_ = function recordThroughput_(segmentInfo) {
- if (segmentInfo.duration < MIN_SEGMENT_DURATION_TO_SAVE_STATS) {
- this.logger_("Ignoring segment's throughput because its duration of " + segmentInfo.duration + (" is less than the min to record " + MIN_SEGMENT_DURATION_TO_SAVE_STATS));
- return;
- }
- var rate = this.throughput.rate;
- var segmentProcessingTime = Date.now() - segmentInfo.endOfAllRequests + 1;
- var segmentProcessingThroughput = Math.floor(segmentInfo.byteLength / segmentProcessingTime * 8 * 1e3);
- this.throughput.rate += (segmentProcessingThroughput - rate) / ++this.throughput.count;
- };
- _proto.addSegmentMetadataCue_ = function addSegmentMetadataCue_(segmentInfo) {
- if (!this.segmentMetadataTrack_) {
- return;
- }
- var segment = segmentInfo.segment;
- var start2 = segment.start;
- var end = segment.end;
- if (!finite(start2) || !finite(end)) {
- return;
- }
- removeCuesFromTrack(start2, end, this.segmentMetadataTrack_);
- var Cue = window_1.WebKitDataCue || window_1.VTTCue;
- var value = {
- custom: segment.custom,
- dateTimeObject: segment.dateTimeObject,
- dateTimeString: segment.dateTimeString,
- bandwidth: segmentInfo.playlist.attributes.BANDWIDTH,
- resolution: segmentInfo.playlist.attributes.RESOLUTION,
- codecs: segmentInfo.playlist.attributes.CODECS,
- byteLength: segmentInfo.byteLength,
- uri: segmentInfo.uri,
- timeline: segmentInfo.timeline,
- playlist: segmentInfo.playlist.id,
- start: start2,
- end
- };
- var data = JSON.stringify(value);
- var cue = new Cue(start2, end, data);
- cue.value = value;
- this.segmentMetadataTrack_.addCue(cue);
- };
- return SegmentLoader2;
- }(videojs.EventTarget);
- function noop() {
- }
- var toTitleCase2 = function toTitleCase3(string) {
- if (typeof string !== "string") {
- return string;
- }
- return string.replace(/./, function(w) {
- return w.toUpperCase();
- });
- };
- var bufferTypes = ["video", "audio"];
- var _updating = function updating2(type2, sourceUpdater) {
- var sourceBuffer = sourceUpdater[type2 + "Buffer"];
- return sourceBuffer && sourceBuffer.updating || sourceUpdater.queuePending[type2];
- };
- var nextQueueIndexOfType = function nextQueueIndexOfType2(type2, queue) {
- for (var i2 = 0; i2 < queue.length; i2++) {
- var queueEntry = queue[i2];
- if (queueEntry.type === "mediaSource") {
- return null;
- }
- if (queueEntry.type === type2) {
- return i2;
- }
- }
- return null;
- };
- var shiftQueue = function shiftQueue2(type2, sourceUpdater) {
- if (sourceUpdater.queue.length === 0) {
- return;
- }
- var queueIndex = 0;
- var queueEntry = sourceUpdater.queue[queueIndex];
- if (queueEntry.type === "mediaSource") {
- if (!sourceUpdater.updating() && sourceUpdater.mediaSource.readyState !== "closed") {
- sourceUpdater.queue.shift();
- queueEntry.action(sourceUpdater);
- if (queueEntry.doneFn) {
- queueEntry.doneFn();
- }
- shiftQueue2("audio", sourceUpdater);
- shiftQueue2("video", sourceUpdater);
- }
- return;
- }
- if (type2 === "mediaSource") {
- return;
- }
- if (!sourceUpdater.ready() || sourceUpdater.mediaSource.readyState === "closed" || _updating(type2, sourceUpdater)) {
- return;
- }
- if (queueEntry.type !== type2) {
- queueIndex = nextQueueIndexOfType(type2, sourceUpdater.queue);
- if (queueIndex === null) {
- return;
- }
- queueEntry = sourceUpdater.queue[queueIndex];
- }
- sourceUpdater.queue.splice(queueIndex, 1);
- sourceUpdater.queuePending[type2] = queueEntry;
- queueEntry.action(type2, sourceUpdater);
- if (!queueEntry.doneFn) {
- sourceUpdater.queuePending[type2] = null;
- shiftQueue2(type2, sourceUpdater);
- return;
- }
- };
- var cleanupBuffer = function cleanupBuffer2(type2, sourceUpdater) {
- var buffer = sourceUpdater[type2 + "Buffer"];
- var titleType = toTitleCase2(type2);
- if (!buffer) {
- return;
- }
- buffer.removeEventListener("updateend", sourceUpdater["on" + titleType + "UpdateEnd_"]);
- buffer.removeEventListener("error", sourceUpdater["on" + titleType + "Error_"]);
- sourceUpdater.codecs[type2] = null;
- sourceUpdater[type2 + "Buffer"] = null;
- };
- var inSourceBuffers = function inSourceBuffers2(mediaSource, sourceBuffer) {
- return mediaSource && sourceBuffer && Array.prototype.indexOf.call(mediaSource.sourceBuffers, sourceBuffer) !== -1;
- };
- var actions = {
- appendBuffer: function appendBuffer(bytes, segmentInfo, onError2) {
- return function(type2, sourceUpdater) {
- var sourceBuffer = sourceUpdater[type2 + "Buffer"];
- if (!inSourceBuffers(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- sourceUpdater.logger_("Appending segment " + segmentInfo.mediaIndex + "'s " + bytes.length + " bytes to " + type2 + "Buffer");
- try {
- sourceBuffer.appendBuffer(bytes);
- } catch (e) {
- sourceUpdater.logger_("Error with code " + e.code + " " + (e.code === QUOTA_EXCEEDED_ERR ? "(QUOTA_EXCEEDED_ERR) " : "") + ("when appending segment " + segmentInfo.mediaIndex + " to " + type2 + "Buffer"));
- sourceUpdater.queuePending[type2] = null;
- onError2(e);
- }
- };
- },
- remove: function remove(start2, end) {
- return function(type2, sourceUpdater) {
- var sourceBuffer = sourceUpdater[type2 + "Buffer"];
- if (!inSourceBuffers(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- sourceUpdater.logger_("Removing " + start2 + " to " + end + " from " + type2 + "Buffer");
- try {
- sourceBuffer.remove(start2, end);
- } catch (e) {
- sourceUpdater.logger_("Remove " + start2 + " to " + end + " from " + type2 + "Buffer failed");
- }
- };
- },
- timestampOffset: function timestampOffset(offset) {
- return function(type2, sourceUpdater) {
- var sourceBuffer = sourceUpdater[type2 + "Buffer"];
- if (!inSourceBuffers(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- sourceUpdater.logger_("Setting " + type2 + "timestampOffset to " + offset);
- sourceBuffer.timestampOffset = offset;
- };
- },
- callback: function callback(_callback) {
- return function(type2, sourceUpdater) {
- _callback();
- };
- },
- endOfStream: function endOfStream(error) {
- return function(sourceUpdater) {
- if (sourceUpdater.mediaSource.readyState !== "open") {
- return;
- }
- sourceUpdater.logger_("Calling mediaSource endOfStream(" + (error || "") + ")");
- try {
- sourceUpdater.mediaSource.endOfStream(error);
- } catch (e) {
- videojs.log.warn("Failed to call media source endOfStream", e);
- }
- };
- },
- duration: function duration4(_duration) {
- return function(sourceUpdater) {
- sourceUpdater.logger_("Setting mediaSource duration to " + _duration);
- try {
- sourceUpdater.mediaSource.duration = _duration;
- } catch (e) {
- videojs.log.warn("Failed to set media source duration", e);
- }
- };
- },
- abort: function abort() {
- return function(type2, sourceUpdater) {
- if (sourceUpdater.mediaSource.readyState !== "open") {
- return;
- }
- var sourceBuffer = sourceUpdater[type2 + "Buffer"];
- if (!inSourceBuffers(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- sourceUpdater.logger_("calling abort on " + type2 + "Buffer");
- try {
- sourceBuffer.abort();
- } catch (e) {
- videojs.log.warn("Failed to abort on " + type2 + "Buffer", e);
- }
- };
- },
- addSourceBuffer: function addSourceBuffer(type2, codec) {
- return function(sourceUpdater) {
- var titleType = toTitleCase2(type2);
- var mime = getMimeForCodec2(codec);
- sourceUpdater.logger_("Adding " + type2 + "Buffer with codec " + codec + " to mediaSource");
- var sourceBuffer = sourceUpdater.mediaSource.addSourceBuffer(mime);
- sourceBuffer.addEventListener("updateend", sourceUpdater["on" + titleType + "UpdateEnd_"]);
- sourceBuffer.addEventListener("error", sourceUpdater["on" + titleType + "Error_"]);
- sourceUpdater.codecs[type2] = codec;
- sourceUpdater[type2 + "Buffer"] = sourceBuffer;
- };
- },
- removeSourceBuffer: function removeSourceBuffer(type2) {
- return function(sourceUpdater) {
- var sourceBuffer = sourceUpdater[type2 + "Buffer"];
- cleanupBuffer(type2, sourceUpdater);
- if (!inSourceBuffers(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- sourceUpdater.logger_("Removing " + type2 + "Buffer with codec " + sourceUpdater.codecs[type2] + " from mediaSource");
- try {
- sourceUpdater.mediaSource.removeSourceBuffer(sourceBuffer);
- } catch (e) {
- videojs.log.warn("Failed to removeSourceBuffer " + type2 + "Buffer", e);
- }
- };
- },
- changeType: function changeType(codec) {
- return function(type2, sourceUpdater) {
- var sourceBuffer = sourceUpdater[type2 + "Buffer"];
- var mime = getMimeForCodec2(codec);
- if (!inSourceBuffers(sourceUpdater.mediaSource, sourceBuffer)) {
- return;
- }
- if (sourceUpdater.codecs[type2] === codec) {
- return;
- }
- sourceUpdater.logger_("changing " + type2 + "Buffer codec from " + sourceUpdater.codecs[type2] + " to " + codec);
- sourceBuffer.changeType(mime);
- sourceUpdater.codecs[type2] = codec;
- };
- }
- };
- var pushQueue = function pushQueue2(_ref) {
- var type2 = _ref.type, sourceUpdater = _ref.sourceUpdater, action = _ref.action, doneFn = _ref.doneFn, name = _ref.name;
- sourceUpdater.queue.push({
- type: type2,
- action,
- doneFn,
- name
- });
- shiftQueue(type2, sourceUpdater);
- };
- var onUpdateend = function onUpdateend2(type2, sourceUpdater) {
- return function(e) {
- if (sourceUpdater.queuePending[type2]) {
- var doneFn = sourceUpdater.queuePending[type2].doneFn;
- sourceUpdater.queuePending[type2] = null;
- if (doneFn) {
- doneFn(sourceUpdater[type2 + "Error_"]);
- }
- }
- shiftQueue(type2, sourceUpdater);
- };
- };
- var SourceUpdater = /* @__PURE__ */ function(_videojs$EventTarget) {
- _inheritsLoose(SourceUpdater2, _videojs$EventTarget);
- function SourceUpdater2(mediaSource) {
- var _this;
- _this = _videojs$EventTarget.call(this) || this;
- _this.mediaSource = mediaSource;
- _this.sourceopenListener_ = function() {
- return shiftQueue("mediaSource", _assertThisInitialized(_this));
- };
- _this.mediaSource.addEventListener("sourceopen", _this.sourceopenListener_);
- _this.logger_ = logger("SourceUpdater");
- _this.audioTimestampOffset_ = 0;
- _this.videoTimestampOffset_ = 0;
- _this.queue = [];
- _this.queuePending = {
- audio: null,
- video: null
- };
- _this.delayedAudioAppendQueue_ = [];
- _this.videoAppendQueued_ = false;
- _this.codecs = {};
- _this.onVideoUpdateEnd_ = onUpdateend("video", _assertThisInitialized(_this));
- _this.onAudioUpdateEnd_ = onUpdateend("audio", _assertThisInitialized(_this));
- _this.onVideoError_ = function(e) {
- _this.videoError_ = e;
- };
- _this.onAudioError_ = function(e) {
- _this.audioError_ = e;
- };
- _this.createdSourceBuffers_ = false;
- _this.initializedEme_ = false;
- _this.triggeredReady_ = false;
- return _this;
- }
- var _proto = SourceUpdater2.prototype;
- _proto.initializedEme = function initializedEme() {
- this.initializedEme_ = true;
- this.triggerReady();
- };
- _proto.hasCreatedSourceBuffers = function hasCreatedSourceBuffers() {
- return this.createdSourceBuffers_;
- };
- _proto.hasInitializedAnyEme = function hasInitializedAnyEme() {
- return this.initializedEme_;
- };
- _proto.ready = function ready() {
- return this.hasCreatedSourceBuffers() && this.hasInitializedAnyEme();
- };
- _proto.createSourceBuffers = function createSourceBuffers(codecs) {
- if (this.hasCreatedSourceBuffers()) {
- return;
- }
- this.addOrChangeSourceBuffers(codecs);
- this.createdSourceBuffers_ = true;
- this.trigger("createdsourcebuffers");
- this.triggerReady();
- };
- _proto.triggerReady = function triggerReady() {
- if (this.ready() && !this.triggeredReady_) {
- this.triggeredReady_ = true;
- this.trigger("ready");
- }
- };
- _proto.addSourceBuffer = function addSourceBuffer2(type2, codec) {
- pushQueue({
- type: "mediaSource",
- sourceUpdater: this,
- action: actions.addSourceBuffer(type2, codec),
- name: "addSourceBuffer"
- });
- };
- _proto.abort = function abort2(type2) {
- pushQueue({
- type: type2,
- sourceUpdater: this,
- action: actions.abort(type2),
- name: "abort"
- });
- };
- _proto.removeSourceBuffer = function removeSourceBuffer2(type2) {
- if (!this.canRemoveSourceBuffer()) {
- videojs.log.error("removeSourceBuffer is not supported!");
- return;
- }
- pushQueue({
- type: "mediaSource",
- sourceUpdater: this,
- action: actions.removeSourceBuffer(type2),
- name: "removeSourceBuffer"
- });
- };
- _proto.canRemoveSourceBuffer = function canRemoveSourceBuffer() {
- return !videojs.browser.IE_VERSION && !videojs.browser.IS_FIREFOX && window_1.MediaSource && window_1.MediaSource.prototype && typeof window_1.MediaSource.prototype.removeSourceBuffer === "function";
- };
- SourceUpdater2.canChangeType = function canChangeType() {
- return window_1.SourceBuffer && window_1.SourceBuffer.prototype && typeof window_1.SourceBuffer.prototype.changeType === "function";
- };
- _proto.canChangeType = function canChangeType() {
- return this.constructor.canChangeType();
- };
- _proto.changeType = function changeType2(type2, codec) {
- if (!this.canChangeType()) {
- videojs.log.error("changeType is not supported!");
- return;
- }
- pushQueue({
- type: type2,
- sourceUpdater: this,
- action: actions.changeType(codec),
- name: "changeType"
- });
- };
- _proto.addOrChangeSourceBuffers = function addOrChangeSourceBuffers(codecs) {
- var _this2 = this;
- if (!codecs || typeof codecs !== "object" || Object.keys(codecs).length === 0) {
- throw new Error("Cannot addOrChangeSourceBuffers to undefined codecs");
- }
- Object.keys(codecs).forEach(function(type2) {
- var codec = codecs[type2];
- if (!_this2.hasCreatedSourceBuffers()) {
- return _this2.addSourceBuffer(type2, codec);
- }
- if (_this2.canChangeType()) {
- _this2.changeType(type2, codec);
- }
- });
- };
- _proto.appendBuffer = function appendBuffer2(options2, doneFn) {
- var _this3 = this;
- var segmentInfo = options2.segmentInfo, type2 = options2.type, bytes = options2.bytes;
- this.processedAppend_ = true;
- if (type2 === "audio" && this.videoBuffer && !this.videoAppendQueued_) {
- this.delayedAudioAppendQueue_.push([options2, doneFn]);
- this.logger_("delayed audio append of " + bytes.length + " until video append");
- return;
- }
- var onError2 = doneFn;
- pushQueue({
- type: type2,
- sourceUpdater: this,
- action: actions.appendBuffer(bytes, segmentInfo || {
- mediaIndex: -1
- }, onError2),
- doneFn,
- name: "appendBuffer"
- });
- if (type2 === "video") {
- this.videoAppendQueued_ = true;
- if (!this.delayedAudioAppendQueue_.length) {
- return;
- }
- var queue = this.delayedAudioAppendQueue_.slice();
- this.logger_("queuing delayed audio " + queue.length + " appendBuffers");
- this.delayedAudioAppendQueue_.length = 0;
- queue.forEach(function(que) {
- _this3.appendBuffer.apply(_this3, que);
- });
- }
- };
- _proto.audioBuffered = function audioBuffered() {
- if (!inSourceBuffers(this.mediaSource, this.audioBuffer)) {
- return videojs.createTimeRange();
- }
- return this.audioBuffer.buffered ? this.audioBuffer.buffered : videojs.createTimeRange();
- };
- _proto.videoBuffered = function videoBuffered() {
- if (!inSourceBuffers(this.mediaSource, this.videoBuffer)) {
- return videojs.createTimeRange();
- }
- return this.videoBuffer.buffered ? this.videoBuffer.buffered : videojs.createTimeRange();
- };
- _proto.buffered = function buffered() {
- var video = inSourceBuffers(this.mediaSource, this.videoBuffer) ? this.videoBuffer : null;
- var audio = inSourceBuffers(this.mediaSource, this.audioBuffer) ? this.audioBuffer : null;
- if (audio && !video) {
- return this.audioBuffered();
- }
- if (video && !audio) {
- return this.videoBuffered();
- }
- return bufferIntersection(this.audioBuffered(), this.videoBuffered());
- };
- _proto.setDuration = function setDuration(duration5, doneFn) {
- if (doneFn === void 0) {
- doneFn = noop;
- }
- pushQueue({
- type: "mediaSource",
- sourceUpdater: this,
- action: actions.duration(duration5),
- name: "duration",
- doneFn
- });
- };
- _proto.endOfStream = function endOfStream2(error, doneFn) {
- if (error === void 0) {
- error = null;
- }
- if (doneFn === void 0) {
- doneFn = noop;
- }
- if (typeof error !== "string") {
- error = void 0;
- }
- pushQueue({
- type: "mediaSource",
- sourceUpdater: this,
- action: actions.endOfStream(error),
- name: "endOfStream",
- doneFn
- });
- };
- _proto.removeAudio = function removeAudio(start2, end, done) {
- if (done === void 0) {
- done = noop;
- }
- if (!this.audioBuffered().length || this.audioBuffered().end(0) === 0) {
- done();
- return;
- }
- pushQueue({
- type: "audio",
- sourceUpdater: this,
- action: actions.remove(start2, end),
- doneFn: done,
- name: "remove"
- });
- };
- _proto.removeVideo = function removeVideo(start2, end, done) {
- if (done === void 0) {
- done = noop;
- }
- if (!this.videoBuffered().length || this.videoBuffered().end(0) === 0) {
- done();
- return;
- }
- pushQueue({
- type: "video",
- sourceUpdater: this,
- action: actions.remove(start2, end),
- doneFn: done,
- name: "remove"
- });
- };
- _proto.updating = function updating3() {
- if (_updating("audio", this) || _updating("video", this)) {
- return true;
- }
- return false;
- };
- _proto.audioTimestampOffset = function audioTimestampOffset(offset) {
- if (typeof offset !== "undefined" && this.audioBuffer && this.audioTimestampOffset_ !== offset) {
- pushQueue({
- type: "audio",
- sourceUpdater: this,
- action: actions.timestampOffset(offset),
- name: "timestampOffset"
- });
- this.audioTimestampOffset_ = offset;
- }
- return this.audioTimestampOffset_;
- };
- _proto.videoTimestampOffset = function videoTimestampOffset(offset) {
- if (typeof offset !== "undefined" && this.videoBuffer && this.videoTimestampOffset !== offset) {
- pushQueue({
- type: "video",
- sourceUpdater: this,
- action: actions.timestampOffset(offset),
- name: "timestampOffset"
- });
- this.videoTimestampOffset_ = offset;
- }
- return this.videoTimestampOffset_;
- };
- _proto.audioQueueCallback = function audioQueueCallback(callback2) {
- if (!this.audioBuffer) {
- return;
- }
- pushQueue({
- type: "audio",
- sourceUpdater: this,
- action: actions.callback(callback2),
- name: "callback"
- });
- };
- _proto.videoQueueCallback = function videoQueueCallback(callback2) {
- if (!this.videoBuffer) {
- return;
- }
- pushQueue({
- type: "video",
- sourceUpdater: this,
- action: actions.callback(callback2),
- name: "callback"
- });
- };
- _proto.dispose = function dispose() {
- var _this4 = this;
- this.trigger("dispose");
- bufferTypes.forEach(function(type2) {
- _this4.abort(type2);
- if (_this4.canRemoveSourceBuffer()) {
- _this4.removeSourceBuffer(type2);
- } else {
- _this4[type2 + "QueueCallback"](function() {
- return cleanupBuffer(type2, _this4);
- });
- }
- });
- this.videoAppendQueued_ = false;
- this.delayedAudioAppendQueue_.length = 0;
- if (this.sourceopenListener_) {
- this.mediaSource.removeEventListener("sourceopen", this.sourceopenListener_);
- }
- this.off();
- };
- return SourceUpdater2;
- }(videojs.EventTarget);
- var uint8ToUtf8 = function uint8ToUtf82(uintArray) {
- return decodeURIComponent(escape(String.fromCharCode.apply(null, uintArray)));
- };
- var VTT_LINE_TERMINATORS = new Uint8Array("\n\n".split("").map(function(_char3) {
- return _char3.charCodeAt(0);
- }));
- var NoVttJsError = /* @__PURE__ */ function(_Error) {
- _inheritsLoose(NoVttJsError2, _Error);
- function NoVttJsError2() {
- return _Error.call(this, "Trying to parse received VTT cues, but there is no WebVTT. Make sure vtt.js is loaded.") || this;
- }
- return NoVttJsError2;
- }(/* @__PURE__ */ _wrapNativeSuper(Error));
- var VTTSegmentLoader = /* @__PURE__ */ function(_SegmentLoader) {
- _inheritsLoose(VTTSegmentLoader2, _SegmentLoader);
- function VTTSegmentLoader2(settings, options2) {
- var _this;
- if (options2 === void 0) {
- options2 = {};
- }
- _this = _SegmentLoader.call(this, settings, options2) || this;
- _this.mediaSource_ = null;
- _this.subtitlesTrack_ = null;
- _this.loaderType_ = "subtitle";
- _this.featuresNativeTextTracks_ = settings.featuresNativeTextTracks;
- _this.loadVttJs = settings.loadVttJs;
- _this.shouldSaveSegmentTimingInfo_ = false;
- return _this;
- }
- var _proto = VTTSegmentLoader2.prototype;
- _proto.createTransmuxer_ = function createTransmuxer_() {
- return null;
- };
- _proto.buffered_ = function buffered_() {
- if (!this.subtitlesTrack_ || !this.subtitlesTrack_.cues || !this.subtitlesTrack_.cues.length) {
- return videojs.createTimeRanges();
- }
- var cues = this.subtitlesTrack_.cues;
- var start2 = cues[0].startTime;
- var end = cues[cues.length - 1].startTime;
- return videojs.createTimeRanges([[start2, end]]);
- };
- _proto.initSegmentForMap = function initSegmentForMap(map, set4) {
- if (set4 === void 0) {
- set4 = false;
- }
- if (!map) {
- return null;
- }
- var id = initSegmentId(map);
- var storedMap = this.initSegments_[id];
- if (set4 && !storedMap && map.bytes) {
- var combinedByteLength = VTT_LINE_TERMINATORS.byteLength + map.bytes.byteLength;
- var combinedSegment = new Uint8Array(combinedByteLength);
- combinedSegment.set(map.bytes);
- combinedSegment.set(VTT_LINE_TERMINATORS, map.bytes.byteLength);
- this.initSegments_[id] = storedMap = {
- resolvedUri: map.resolvedUri,
- byterange: map.byterange,
- bytes: combinedSegment
- };
- }
- return storedMap || map;
- };
- _proto.couldBeginLoading_ = function couldBeginLoading_() {
- return this.playlist_ && this.subtitlesTrack_ && !this.paused();
- };
- _proto.init_ = function init_() {
- this.state = "READY";
- this.resetEverything();
- return this.monitorBuffer_();
- };
- _proto.track = function track(_track) {
- if (typeof _track === "undefined") {
- return this.subtitlesTrack_;
- }
- this.subtitlesTrack_ = _track;
- if (this.state === "INIT" && this.couldBeginLoading_()) {
- this.init_();
- }
- return this.subtitlesTrack_;
- };
- _proto.remove = function remove2(start2, end) {
- removeCuesFromTrack(start2, end, this.subtitlesTrack_);
- };
- _proto.fillBuffer_ = function fillBuffer_() {
- var _this2 = this;
- var segmentInfo = this.chooseNextRequest_();
- if (!segmentInfo) {
- return;
- }
- if (this.syncController_.timestampOffsetForTimeline(segmentInfo.timeline) === null) {
- var checkTimestampOffset = function checkTimestampOffset2() {
- _this2.state = "READY";
- if (!_this2.paused()) {
- _this2.monitorBuffer_();
- }
- };
- this.syncController_.one("timestampoffset", checkTimestampOffset);
- this.state = "WAITING_ON_TIMELINE";
- return;
- }
- this.loadSegment_(segmentInfo);
- };
- _proto.timestampOffsetForSegment_ = function timestampOffsetForSegment_() {
- return null;
- };
- _proto.chooseNextRequest_ = function chooseNextRequest_() {
- return this.skipEmptySegments_(_SegmentLoader.prototype.chooseNextRequest_.call(this));
- };
- _proto.skipEmptySegments_ = function skipEmptySegments_(segmentInfo) {
- while (segmentInfo && segmentInfo.segment.empty) {
- if (segmentInfo.mediaIndex + 1 >= segmentInfo.playlist.segments.length) {
- segmentInfo = null;
- break;
- }
- segmentInfo = this.generateSegmentInfo_({
- playlist: segmentInfo.playlist,
- mediaIndex: segmentInfo.mediaIndex + 1,
- startOfSegment: segmentInfo.startOfSegment + segmentInfo.duration,
- isSyncRequest: segmentInfo.isSyncRequest
- });
- }
- return segmentInfo;
- };
- _proto.stopForError = function stopForError(error) {
- this.error(error);
- this.state = "READY";
- this.pause();
- this.trigger("error");
- };
- _proto.segmentRequestFinished_ = function segmentRequestFinished_(error, simpleSegment, result) {
- var _this3 = this;
- if (!this.subtitlesTrack_) {
- this.state = "READY";
- return;
- }
- this.saveTransferStats_(simpleSegment.stats);
- if (!this.pendingSegment_) {
- this.state = "READY";
- this.mediaRequestsAborted += 1;
- return;
- }
- if (error) {
- if (error.code === REQUEST_ERRORS.TIMEOUT) {
- this.handleTimeout_();
- }
- if (error.code === REQUEST_ERRORS.ABORTED) {
- this.mediaRequestsAborted += 1;
- } else {
- this.mediaRequestsErrored += 1;
- }
- this.stopForError(error);
- return;
- }
- var segmentInfo = this.pendingSegment_;
- this.saveBandwidthRelatedStats_(segmentInfo.duration, simpleSegment.stats);
- if (simpleSegment.key) {
- this.segmentKey(simpleSegment.key, true);
- }
- this.state = "APPENDING";
- this.trigger("appending");
- var segment = segmentInfo.segment;
- if (segment.map) {
- segment.map.bytes = simpleSegment.map.bytes;
- }
- segmentInfo.bytes = simpleSegment.bytes;
- if (typeof window_1.WebVTT !== "function" && typeof this.loadVttJs === "function") {
- this.state = "WAITING_ON_VTTJS";
- this.loadVttJs().then(function() {
- return _this3.segmentRequestFinished_(error, simpleSegment, result);
- }, function() {
- return _this3.stopForError({
- message: "Error loading vtt.js"
- });
- });
- return;
- }
- segment.requested = true;
- try {
- this.parseVTTCues_(segmentInfo);
- } catch (e) {
- this.stopForError({
- message: e.message
- });
- return;
- }
- this.updateTimeMapping_(segmentInfo, this.syncController_.timelines[segmentInfo.timeline], this.playlist_);
- if (segmentInfo.cues.length) {
- segmentInfo.timingInfo = {
- start: segmentInfo.cues[0].startTime,
- end: segmentInfo.cues[segmentInfo.cues.length - 1].endTime
- };
- } else {
- segmentInfo.timingInfo = {
- start: segmentInfo.startOfSegment,
- end: segmentInfo.startOfSegment + segmentInfo.duration
- };
- }
- if (segmentInfo.isSyncRequest) {
- this.trigger("syncinfoupdate");
- this.pendingSegment_ = null;
- this.state = "READY";
- return;
- }
- segmentInfo.byteLength = segmentInfo.bytes.byteLength;
- this.mediaSecondsLoaded += segment.duration;
- segmentInfo.cues.forEach(function(cue) {
- _this3.subtitlesTrack_.addCue(_this3.featuresNativeTextTracks_ ? new window_1.VTTCue(cue.startTime, cue.endTime, cue.text) : cue);
- });
- removeDuplicateCuesFromTrack(this.subtitlesTrack_);
- this.handleAppendsDone_();
- };
- _proto.handleData_ = function handleData_3() {
- };
- _proto.updateTimingInfoEnd_ = function updateTimingInfoEnd_() {
- };
- _proto.parseVTTCues_ = function parseVTTCues_(segmentInfo) {
- var decoder;
- var decodeBytesToString = false;
- if (typeof window_1.WebVTT !== "function") {
- throw new NoVttJsError();
- }
- if (typeof window_1.TextDecoder === "function") {
- decoder = new window_1.TextDecoder("utf8");
- } else {
- decoder = window_1.WebVTT.StringDecoder();
- decodeBytesToString = true;
- }
- var parser2 = new window_1.WebVTT.Parser(window_1, window_1.vttjs, decoder);
- segmentInfo.cues = [];
- segmentInfo.timestampmap = {
- MPEGTS: 0,
- LOCAL: 0
- };
- parser2.oncue = segmentInfo.cues.push.bind(segmentInfo.cues);
- parser2.ontimestampmap = function(map) {
- segmentInfo.timestampmap = map;
- };
- parser2.onparsingerror = function(error) {
- videojs.log.warn("Error encountered when parsing cues: " + error.message);
- };
- if (segmentInfo.segment.map) {
- var mapData = segmentInfo.segment.map.bytes;
- if (decodeBytesToString) {
- mapData = uint8ToUtf8(mapData);
- }
- parser2.parse(mapData);
- }
- var segmentData = segmentInfo.bytes;
- if (decodeBytesToString) {
- segmentData = uint8ToUtf8(segmentData);
- }
- parser2.parse(segmentData);
- parser2.flush();
- };
- _proto.updateTimeMapping_ = function updateTimeMapping_(segmentInfo, mappingObj, playlist) {
- var segment = segmentInfo.segment;
- if (!mappingObj) {
- return;
- }
- if (!segmentInfo.cues.length) {
- segment.empty = true;
- return;
- }
- var timestampmap = segmentInfo.timestampmap;
- var diff = timestampmap.MPEGTS / clock.ONE_SECOND_IN_TS - timestampmap.LOCAL + mappingObj.mapping;
- segmentInfo.cues.forEach(function(cue) {
- cue.startTime += diff;
- cue.endTime += diff;
- });
- if (!playlist.syncInfo) {
- var firstStart = segmentInfo.cues[0].startTime;
- var lastStart = segmentInfo.cues[segmentInfo.cues.length - 1].startTime;
- playlist.syncInfo = {
- mediaSequence: playlist.mediaSequence + segmentInfo.mediaIndex,
- time: Math.min(firstStart, lastStart - segment.duration)
- };
- }
- };
- return VTTSegmentLoader2;
- }(SegmentLoader);
- var findAdCue = function findAdCue2(track, mediaTime) {
- var cues = track.cues;
- for (var i2 = 0; i2 < cues.length; i2++) {
- var cue = cues[i2];
- if (mediaTime >= cue.adStartTime && mediaTime <= cue.adEndTime) {
- return cue;
- }
- }
- return null;
- };
- var updateAdCues = function updateAdCues2(media, track, offset) {
- if (offset === void 0) {
- offset = 0;
- }
- if (!media.segments) {
- return;
- }
- var mediaTime = offset;
- var cue;
- for (var i2 = 0; i2 < media.segments.length; i2++) {
- var segment = media.segments[i2];
- if (!cue) {
- cue = findAdCue(track, mediaTime + segment.duration / 2);
- }
- if (cue) {
- if ("cueIn" in segment) {
- cue.endTime = mediaTime;
- cue.adEndTime = mediaTime;
- mediaTime += segment.duration;
- cue = null;
- continue;
- }
- if (mediaTime < cue.endTime) {
- mediaTime += segment.duration;
- continue;
- }
- cue.endTime += segment.duration;
- } else {
- if ("cueOut" in segment) {
- cue = new window_1.VTTCue(mediaTime, mediaTime + segment.duration, segment.cueOut);
- cue.adStartTime = mediaTime;
- cue.adEndTime = mediaTime + parseFloat(segment.cueOut);
- track.addCue(cue);
- }
- if ("cueOutCont" in segment) {
- var _segment$cueOutCont$s = segment.cueOutCont.split("/").map(parseFloat), adOffset = _segment$cueOutCont$s[0], adTotal = _segment$cueOutCont$s[1];
- cue = new window_1.VTTCue(mediaTime, mediaTime + segment.duration, "");
- cue.adStartTime = mediaTime - adOffset;
- cue.adEndTime = cue.adStartTime + adTotal;
- track.addCue(cue);
- }
- }
- mediaTime += segment.duration;
- }
- };
- var MAX_MEDIA_SEQUENCE_DIFF_FOR_SYNC = 86400;
- var syncPointStrategies = [
- {
- name: "VOD",
- run: function run(syncController, playlist, duration5, currentTimeline, currentTime) {
- if (duration5 !== Infinity) {
- var syncPoint = {
- time: 0,
- segmentIndex: 0,
- partIndex: null
- };
- return syncPoint;
- }
- return null;
- }
- },
- {
- name: "ProgramDateTime",
- run: function run2(syncController, playlist, duration5, currentTimeline, currentTime) {
- if (!Object.keys(syncController.timelineToDatetimeMappings).length) {
- return null;
- }
- var syncPoint = null;
- var lastDistance = null;
- var partsAndSegments = getPartsAndSegments(playlist);
- currentTime = currentTime || 0;
- for (var i2 = 0; i2 < partsAndSegments.length; i2++) {
- var index2 = playlist.endList || currentTime === 0 ? i2 : partsAndSegments.length - (i2 + 1);
- var partAndSegment = partsAndSegments[index2];
- var segment = partAndSegment.segment;
- var datetimeMapping = syncController.timelineToDatetimeMappings[segment.timeline];
- if (!datetimeMapping || !segment.dateTimeObject) {
- continue;
- }
- var segmentTime = segment.dateTimeObject.getTime() / 1e3;
- var start2 = segmentTime + datetimeMapping;
- if (segment.parts && typeof partAndSegment.partIndex === "number") {
- for (var z = 0; z < partAndSegment.partIndex; z++) {
- start2 += segment.parts[z].duration;
- }
- }
- var distance2 = Math.abs(currentTime - start2);
- if (lastDistance !== null && (distance2 === 0 || lastDistance < distance2)) {
- break;
- }
- lastDistance = distance2;
- syncPoint = {
- time: start2,
- segmentIndex: partAndSegment.segmentIndex,
- partIndex: partAndSegment.partIndex
- };
- }
- return syncPoint;
- }
- },
- {
- name: "Segment",
- run: function run3(syncController, playlist, duration5, currentTimeline, currentTime) {
- var syncPoint = null;
- var lastDistance = null;
- currentTime = currentTime || 0;
- var partsAndSegments = getPartsAndSegments(playlist);
- for (var i2 = 0; i2 < partsAndSegments.length; i2++) {
- var index2 = playlist.endList || currentTime === 0 ? i2 : partsAndSegments.length - (i2 + 1);
- var partAndSegment = partsAndSegments[index2];
- var segment = partAndSegment.segment;
- var start2 = partAndSegment.part && partAndSegment.part.start || segment && segment.start;
- if (segment.timeline === currentTimeline && typeof start2 !== "undefined") {
- var distance2 = Math.abs(currentTime - start2);
- if (lastDistance !== null && lastDistance < distance2) {
- break;
- }
- if (!syncPoint || lastDistance === null || lastDistance >= distance2) {
- lastDistance = distance2;
- syncPoint = {
- time: start2,
- segmentIndex: partAndSegment.segmentIndex,
- partIndex: partAndSegment.partIndex
- };
- }
- }
- }
- return syncPoint;
- }
- },
- {
- name: "Discontinuity",
- run: function run4(syncController, playlist, duration5, currentTimeline, currentTime) {
- var syncPoint = null;
- currentTime = currentTime || 0;
- if (playlist.discontinuityStarts && playlist.discontinuityStarts.length) {
- var lastDistance = null;
- for (var i2 = 0; i2 < playlist.discontinuityStarts.length; i2++) {
- var segmentIndex = playlist.discontinuityStarts[i2];
- var discontinuity = playlist.discontinuitySequence + i2 + 1;
- var discontinuitySync = syncController.discontinuities[discontinuity];
- if (discontinuitySync) {
- var distance2 = Math.abs(currentTime - discontinuitySync.time);
- if (lastDistance !== null && lastDistance < distance2) {
- break;
- }
- if (!syncPoint || lastDistance === null || lastDistance >= distance2) {
- lastDistance = distance2;
- syncPoint = {
- time: discontinuitySync.time,
- segmentIndex,
- partIndex: null
- };
- }
- }
- }
- }
- return syncPoint;
- }
- },
- {
- name: "Playlist",
- run: function run5(syncController, playlist, duration5, currentTimeline, currentTime) {
- if (playlist.syncInfo) {
- var syncPoint = {
- time: playlist.syncInfo.time,
- segmentIndex: playlist.syncInfo.mediaSequence - playlist.mediaSequence,
- partIndex: null
- };
- return syncPoint;
- }
- return null;
- }
- }
- ];
- var SyncController = /* @__PURE__ */ function(_videojs$EventTarget) {
- _inheritsLoose(SyncController2, _videojs$EventTarget);
- function SyncController2(options2) {
- var _this;
- _this = _videojs$EventTarget.call(this) || this;
- _this.timelines = [];
- _this.discontinuities = [];
- _this.timelineToDatetimeMappings = {};
- _this.logger_ = logger("SyncController");
- return _this;
- }
- var _proto = SyncController2.prototype;
- _proto.getSyncPoint = function getSyncPoint(playlist, duration5, currentTimeline, currentTime) {
- var syncPoints = this.runStrategies_(playlist, duration5, currentTimeline, currentTime);
- if (!syncPoints.length) {
- return null;
- }
- return this.selectSyncPoint_(syncPoints, {
- key: "time",
- value: currentTime
- });
- };
- _proto.getExpiredTime = function getExpiredTime(playlist, duration5) {
- if (!playlist || !playlist.segments) {
- return null;
- }
- var syncPoints = this.runStrategies_(playlist, duration5, playlist.discontinuitySequence, 0);
- if (!syncPoints.length) {
- return null;
- }
- var syncPoint = this.selectSyncPoint_(syncPoints, {
- key: "segmentIndex",
- value: 0
- });
- if (syncPoint.segmentIndex > 0) {
- syncPoint.time *= -1;
- }
- return Math.abs(syncPoint.time + sumDurations({
- defaultDuration: playlist.targetDuration,
- durationList: playlist.segments,
- startIndex: syncPoint.segmentIndex,
- endIndex: 0
- }));
- };
- _proto.runStrategies_ = function runStrategies_(playlist, duration5, currentTimeline, currentTime) {
- var syncPoints = [];
- for (var i2 = 0; i2 < syncPointStrategies.length; i2++) {
- var strategy = syncPointStrategies[i2];
- var syncPoint = strategy.run(this, playlist, duration5, currentTimeline, currentTime);
- if (syncPoint) {
- syncPoint.strategy = strategy.name;
- syncPoints.push({
- strategy: strategy.name,
- syncPoint
- });
- }
- }
- return syncPoints;
- };
- _proto.selectSyncPoint_ = function selectSyncPoint_(syncPoints, target) {
- var bestSyncPoint = syncPoints[0].syncPoint;
- var bestDistance = Math.abs(syncPoints[0].syncPoint[target.key] - target.value);
- var bestStrategy = syncPoints[0].strategy;
- for (var i2 = 1; i2 < syncPoints.length; i2++) {
- var newDistance = Math.abs(syncPoints[i2].syncPoint[target.key] - target.value);
- if (newDistance < bestDistance) {
- bestDistance = newDistance;
- bestSyncPoint = syncPoints[i2].syncPoint;
- bestStrategy = syncPoints[i2].strategy;
- }
- }
- this.logger_("syncPoint for [" + target.key + ": " + target.value + "] chosen with strategy" + (" [" + bestStrategy + "]: [time:" + bestSyncPoint.time + ",") + (" segmentIndex:" + bestSyncPoint.segmentIndex) + (typeof bestSyncPoint.partIndex === "number" ? ",partIndex:" + bestSyncPoint.partIndex : "") + "]");
- return bestSyncPoint;
- };
- _proto.saveExpiredSegmentInfo = function saveExpiredSegmentInfo(oldPlaylist, newPlaylist) {
- var mediaSequenceDiff = newPlaylist.mediaSequence - oldPlaylist.mediaSequence;
- if (mediaSequenceDiff > MAX_MEDIA_SEQUENCE_DIFF_FOR_SYNC) {
- videojs.log.warn("Not saving expired segment info. Media sequence gap " + mediaSequenceDiff + " is too large.");
- return;
- }
- for (var i2 = mediaSequenceDiff - 1; i2 >= 0; i2--) {
- var lastRemovedSegment = oldPlaylist.segments[i2];
- if (lastRemovedSegment && typeof lastRemovedSegment.start !== "undefined") {
- newPlaylist.syncInfo = {
- mediaSequence: oldPlaylist.mediaSequence + i2,
- time: lastRemovedSegment.start
- };
- this.logger_("playlist refresh sync: [time:" + newPlaylist.syncInfo.time + "," + (" mediaSequence: " + newPlaylist.syncInfo.mediaSequence + "]"));
- this.trigger("syncinfoupdate");
- break;
- }
- }
- };
- _proto.setDateTimeMappingForStart = function setDateTimeMappingForStart(playlist) {
- this.timelineToDatetimeMappings = {};
- if (playlist.segments && playlist.segments.length && playlist.segments[0].dateTimeObject) {
- var firstSegment = playlist.segments[0];
- var playlistTimestamp = firstSegment.dateTimeObject.getTime() / 1e3;
- this.timelineToDatetimeMappings[firstSegment.timeline] = -playlistTimestamp;
- }
- };
- _proto.saveSegmentTimingInfo = function saveSegmentTimingInfo(_ref) {
- var segmentInfo = _ref.segmentInfo, shouldSaveTimelineMapping = _ref.shouldSaveTimelineMapping;
- var didCalculateSegmentTimeMapping = this.calculateSegmentTimeMapping_(segmentInfo, segmentInfo.timingInfo, shouldSaveTimelineMapping);
- var segment = segmentInfo.segment;
- if (didCalculateSegmentTimeMapping) {
- this.saveDiscontinuitySyncInfo_(segmentInfo);
- if (!segmentInfo.playlist.syncInfo) {
- segmentInfo.playlist.syncInfo = {
- mediaSequence: segmentInfo.playlist.mediaSequence + segmentInfo.mediaIndex,
- time: segment.start
- };
- }
- }
- var dateTime = segment.dateTimeObject;
- if (segment.discontinuity && shouldSaveTimelineMapping && dateTime) {
- this.timelineToDatetimeMappings[segment.timeline] = -(dateTime.getTime() / 1e3);
- }
- };
- _proto.timestampOffsetForTimeline = function timestampOffsetForTimeline(timeline) {
- if (typeof this.timelines[timeline] === "undefined") {
- return null;
- }
- return this.timelines[timeline].time;
- };
- _proto.mappingForTimeline = function mappingForTimeline(timeline) {
- if (typeof this.timelines[timeline] === "undefined") {
- return null;
- }
- return this.timelines[timeline].mapping;
- };
- _proto.calculateSegmentTimeMapping_ = function calculateSegmentTimeMapping_(segmentInfo, timingInfo, shouldSaveTimelineMapping) {
- var segment = segmentInfo.segment;
- var part = segmentInfo.part;
- var mappingObj = this.timelines[segmentInfo.timeline];
- var start2;
- var end;
- if (typeof segmentInfo.timestampOffset === "number") {
- mappingObj = {
- time: segmentInfo.startOfSegment,
- mapping: segmentInfo.startOfSegment - timingInfo.start
- };
- if (shouldSaveTimelineMapping) {
- this.timelines[segmentInfo.timeline] = mappingObj;
- this.trigger("timestampoffset");
- this.logger_("time mapping for timeline " + segmentInfo.timeline + ": " + ("[time: " + mappingObj.time + "] [mapping: " + mappingObj.mapping + "]"));
- }
- start2 = segmentInfo.startOfSegment;
- end = timingInfo.end + mappingObj.mapping;
- } else if (mappingObj) {
- start2 = timingInfo.start + mappingObj.mapping;
- end = timingInfo.end + mappingObj.mapping;
- } else {
- return false;
- }
- if (part) {
- part.start = start2;
- part.end = end;
- }
- if (!segment.start || start2 < segment.start) {
- segment.start = start2;
- }
- segment.end = end;
- return true;
- };
- _proto.saveDiscontinuitySyncInfo_ = function saveDiscontinuitySyncInfo_(segmentInfo) {
- var playlist = segmentInfo.playlist;
- var segment = segmentInfo.segment;
- if (segment.discontinuity) {
- this.discontinuities[segment.timeline] = {
- time: segment.start,
- accuracy: 0
- };
- } else if (playlist.discontinuityStarts && playlist.discontinuityStarts.length) {
- for (var i2 = 0; i2 < playlist.discontinuityStarts.length; i2++) {
- var segmentIndex = playlist.discontinuityStarts[i2];
- var discontinuity = playlist.discontinuitySequence + i2 + 1;
- var mediaIndexDiff = segmentIndex - segmentInfo.mediaIndex;
- var accuracy = Math.abs(mediaIndexDiff);
- if (!this.discontinuities[discontinuity] || this.discontinuities[discontinuity].accuracy > accuracy) {
- var time = void 0;
- if (mediaIndexDiff < 0) {
- time = segment.start - sumDurations({
- defaultDuration: playlist.targetDuration,
- durationList: playlist.segments,
- startIndex: segmentInfo.mediaIndex,
- endIndex: segmentIndex
- });
- } else {
- time = segment.end + sumDurations({
- defaultDuration: playlist.targetDuration,
- durationList: playlist.segments,
- startIndex: segmentInfo.mediaIndex + 1,
- endIndex: segmentIndex
- });
- }
- this.discontinuities[discontinuity] = {
- time,
- accuracy
- };
- }
- }
- }
- };
- _proto.dispose = function dispose() {
- this.trigger("dispose");
- this.off();
- };
- return SyncController2;
- }(videojs.EventTarget);
- var TimelineChangeController = /* @__PURE__ */ function(_videojs$EventTarget) {
- _inheritsLoose(TimelineChangeController2, _videojs$EventTarget);
- function TimelineChangeController2() {
- var _this;
- _this = _videojs$EventTarget.call(this) || this;
- _this.pendingTimelineChanges_ = {};
- _this.lastTimelineChanges_ = {};
- return _this;
- }
- var _proto = TimelineChangeController2.prototype;
- _proto.clearPendingTimelineChange = function clearPendingTimelineChange(type2) {
- this.pendingTimelineChanges_[type2] = null;
- this.trigger("pendingtimelinechange");
- };
- _proto.pendingTimelineChange = function pendingTimelineChange(_ref) {
- var type2 = _ref.type, from3 = _ref.from, to = _ref.to;
- if (typeof from3 === "number" && typeof to === "number") {
- this.pendingTimelineChanges_[type2] = {
- type: type2,
- from: from3,
- to
- };
- this.trigger("pendingtimelinechange");
- }
- return this.pendingTimelineChanges_[type2];
- };
- _proto.lastTimelineChange = function lastTimelineChange(_ref2) {
- var type2 = _ref2.type, from3 = _ref2.from, to = _ref2.to;
- if (typeof from3 === "number" && typeof to === "number") {
- this.lastTimelineChanges_[type2] = {
- type: type2,
- from: from3,
- to
- };
- delete this.pendingTimelineChanges_[type2];
- this.trigger("timelinechange");
- }
- return this.lastTimelineChanges_[type2];
- };
- _proto.dispose = function dispose() {
- this.trigger("dispose");
- this.pendingTimelineChanges_ = {};
- this.lastTimelineChanges_ = {};
- this.off();
- };
- return TimelineChangeController2;
- }(videojs.EventTarget);
- var workerCode = transform(getWorkerString(function() {
- var commonjsGlobal2 = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
- function createCommonjsModule(fn2, basedir, module2) {
- return module2 = {
- path: basedir,
- exports: {},
- require: function require2(path, base2) {
- return commonjsRequire(path, base2 === void 0 || base2 === null ? module2.path : base2);
- }
- }, fn2(module2, module2.exports), module2.exports;
- }
- function commonjsRequire() {
- throw new Error("Dynamic requires are not currently supported by @rollup/plugin-commonjs");
- }
- var createClass = createCommonjsModule(function(module2) {
- function _defineProperties(target, props) {
- for (var i2 = 0; i2 < props.length; i2++) {
- var descriptor = props[i2];
- descriptor.enumerable = descriptor.enumerable || false;
- descriptor.configurable = true;
- if ("value" in descriptor)
- descriptor.writable = true;
- Object.defineProperty(target, descriptor.key, descriptor);
- }
- }
- function _createClass(Constructor, protoProps, staticProps) {
- if (protoProps)
- _defineProperties(Constructor.prototype, protoProps);
- if (staticProps)
- _defineProperties(Constructor, staticProps);
- return Constructor;
- }
- module2.exports = _createClass;
- module2.exports["default"] = module2.exports, module2.exports.__esModule = true;
- });
- var setPrototypeOf = createCommonjsModule(function(module2) {
- function _setPrototypeOf2(o, p) {
- module2.exports = _setPrototypeOf2 = Object.setPrototypeOf || function _setPrototypeOf3(o2, p2) {
- o2.__proto__ = p2;
- return o2;
- };
- module2.exports["default"] = module2.exports, module2.exports.__esModule = true;
- return _setPrototypeOf2(o, p);
- }
- module2.exports = _setPrototypeOf2;
- module2.exports["default"] = module2.exports, module2.exports.__esModule = true;
- });
- var inheritsLoose = createCommonjsModule(function(module2) {
- function _inheritsLoose2(subClass, superClass) {
- subClass.prototype = Object.create(superClass.prototype);
- subClass.prototype.constructor = subClass;
- setPrototypeOf(subClass, superClass);
- }
- module2.exports = _inheritsLoose2;
- module2.exports["default"] = module2.exports, module2.exports.__esModule = true;
- });
- var Stream2 = /* @__PURE__ */ function() {
- function Stream3() {
- this.listeners = {};
- }
- var _proto = Stream3.prototype;
- _proto.on = function on3(type2, listener) {
- if (!this.listeners[type2]) {
- this.listeners[type2] = [];
- }
- this.listeners[type2].push(listener);
- };
- _proto.off = function off2(type2, listener) {
- if (!this.listeners[type2]) {
- return false;
- }
- var index2 = this.listeners[type2].indexOf(listener);
- this.listeners[type2] = this.listeners[type2].slice(0);
- this.listeners[type2].splice(index2, 1);
- return index2 > -1;
- };
- _proto.trigger = function trigger2(type2) {
- var callbacks = this.listeners[type2];
- if (!callbacks) {
- return;
- }
- if (arguments.length === 2) {
- var length = callbacks.length;
- for (var i2 = 0; i2 < length; ++i2) {
- callbacks[i2].call(this, arguments[1]);
- }
- } else {
- var args = Array.prototype.slice.call(arguments, 1);
- var _length = callbacks.length;
- for (var _i = 0; _i < _length; ++_i) {
- callbacks[_i].apply(this, args);
- }
- }
- };
- _proto.dispose = function dispose() {
- this.listeners = {};
- };
- _proto.pipe = function pipe(destination2) {
- this.on("data", function(data) {
- destination2.push(data);
- });
- };
- return Stream3;
- }();
- /*! @name pkcs7 @version 1.0.4 @license Apache-2.0 */
- function unpad(padded) {
- return padded.subarray(0, padded.byteLength - padded[padded.byteLength - 1]);
- }
- /*! @name aes-decrypter @version 3.1.3 @license Apache-2.0 */
- var precompute = function precompute2() {
- var tables = [[[], [], [], [], []], [[], [], [], [], []]];
- var encTable = tables[0];
- var decTable = tables[1];
- var sbox = encTable[4];
- var sboxInv = decTable[4];
- var i2;
- var x;
- var xInv;
- var d2 = [];
- var th = [];
- var x2;
- var x4;
- var x8;
- var s;
- var tEnc;
- var tDec;
- for (i2 = 0; i2 < 256; i2++) {
- th[(d2[i2] = i2 << 1 ^ (i2 >> 7) * 283) ^ i2] = i2;
- }
- for (x = xInv = 0; !sbox[x]; x ^= x2 || 1, xInv = th[xInv] || 1) {
- s = xInv ^ xInv << 1 ^ xInv << 2 ^ xInv << 3 ^ xInv << 4;
- s = s >> 8 ^ s & 255 ^ 99;
- sbox[x] = s;
- sboxInv[s] = x;
- x8 = d2[x4 = d2[x2 = d2[x]]];
- tDec = x8 * 16843009 ^ x4 * 65537 ^ x2 * 257 ^ x * 16843008;
- tEnc = d2[s] * 257 ^ s * 16843008;
- for (i2 = 0; i2 < 4; i2++) {
- encTable[i2][x] = tEnc = tEnc << 24 ^ tEnc >>> 8;
- decTable[i2][s] = tDec = tDec << 24 ^ tDec >>> 8;
- }
- }
- for (i2 = 0; i2 < 5; i2++) {
- encTable[i2] = encTable[i2].slice(0);
- decTable[i2] = decTable[i2].slice(0);
- }
- return tables;
- };
- var aesTables = null;
- var AES = /* @__PURE__ */ function() {
- function AES2(key) {
- if (!aesTables) {
- aesTables = precompute();
- }
- this._tables = [[aesTables[0][0].slice(), aesTables[0][1].slice(), aesTables[0][2].slice(), aesTables[0][3].slice(), aesTables[0][4].slice()], [aesTables[1][0].slice(), aesTables[1][1].slice(), aesTables[1][2].slice(), aesTables[1][3].slice(), aesTables[1][4].slice()]];
- var i2;
- var j;
- var tmp;
- var sbox = this._tables[0][4];
- var decTable = this._tables[1];
- var keyLen = key.length;
- var rcon = 1;
- if (keyLen !== 4 && keyLen !== 6 && keyLen !== 8) {
- throw new Error("Invalid aes key size");
- }
- var encKey = key.slice(0);
- var decKey = [];
- this._key = [encKey, decKey];
- for (i2 = keyLen; i2 < 4 * keyLen + 28; i2++) {
- tmp = encKey[i2 - 1];
- if (i2 % keyLen === 0 || keyLen === 8 && i2 % keyLen === 4) {
- tmp = sbox[tmp >>> 24] << 24 ^ sbox[tmp >> 16 & 255] << 16 ^ sbox[tmp >> 8 & 255] << 8 ^ sbox[tmp & 255];
- if (i2 % keyLen === 0) {
- tmp = tmp << 8 ^ tmp >>> 24 ^ rcon << 24;
- rcon = rcon << 1 ^ (rcon >> 7) * 283;
- }
- }
- encKey[i2] = encKey[i2 - keyLen] ^ tmp;
- }
- for (j = 0; i2; j++, i2--) {
- tmp = encKey[j & 3 ? i2 : i2 - 4];
- if (i2 <= 4 || j < 4) {
- decKey[j] = tmp;
- } else {
- decKey[j] = decTable[0][sbox[tmp >>> 24]] ^ decTable[1][sbox[tmp >> 16 & 255]] ^ decTable[2][sbox[tmp >> 8 & 255]] ^ decTable[3][sbox[tmp & 255]];
- }
- }
- }
- var _proto = AES2.prototype;
- _proto.decrypt = function decrypt4(encrypted0, encrypted1, encrypted2, encrypted3, out, offset) {
- var key = this._key[1];
- var a = encrypted0 ^ key[0];
- var b = encrypted3 ^ key[1];
- var c = encrypted2 ^ key[2];
- var d2 = encrypted1 ^ key[3];
- var a2;
- var b2;
- var c2;
- var nInnerRounds = key.length / 4 - 2;
- var i2;
- var kIndex = 4;
- var table = this._tables[1];
- var table0 = table[0];
- var table1 = table[1];
- var table2 = table[2];
- var table3 = table[3];
- var sbox = table[4];
- for (i2 = 0; i2 < nInnerRounds; i2++) {
- a2 = table0[a >>> 24] ^ table1[b >> 16 & 255] ^ table2[c >> 8 & 255] ^ table3[d2 & 255] ^ key[kIndex];
- b2 = table0[b >>> 24] ^ table1[c >> 16 & 255] ^ table2[d2 >> 8 & 255] ^ table3[a & 255] ^ key[kIndex + 1];
- c2 = table0[c >>> 24] ^ table1[d2 >> 16 & 255] ^ table2[a >> 8 & 255] ^ table3[b & 255] ^ key[kIndex + 2];
- d2 = table0[d2 >>> 24] ^ table1[a >> 16 & 255] ^ table2[b >> 8 & 255] ^ table3[c & 255] ^ key[kIndex + 3];
- kIndex += 4;
- a = a2;
- b = b2;
- c = c2;
- }
- for (i2 = 0; i2 < 4; i2++) {
- out[(3 & -i2) + offset] = sbox[a >>> 24] << 24 ^ sbox[b >> 16 & 255] << 16 ^ sbox[c >> 8 & 255] << 8 ^ sbox[d2 & 255] ^ key[kIndex++];
- a2 = a;
- a = b;
- b = c;
- c = d2;
- d2 = a2;
- }
- };
- return AES2;
- }();
- var AsyncStream = /* @__PURE__ */ function(_Stream) {
- inheritsLoose(AsyncStream2, _Stream);
- function AsyncStream2() {
- var _this;
- _this = _Stream.call(this, Stream2) || this;
- _this.jobs = [];
- _this.delay = 1;
- _this.timeout_ = null;
- return _this;
- }
- var _proto = AsyncStream2.prototype;
- _proto.processJob_ = function processJob_() {
- this.jobs.shift()();
- if (this.jobs.length) {
- this.timeout_ = setTimeout(this.processJob_.bind(this), this.delay);
- } else {
- this.timeout_ = null;
- }
- };
- _proto.push = function push(job) {
- this.jobs.push(job);
- if (!this.timeout_) {
- this.timeout_ = setTimeout(this.processJob_.bind(this), this.delay);
- }
- };
- return AsyncStream2;
- }(Stream2);
- var ntoh = function ntoh2(word) {
- return word << 24 | (word & 65280) << 8 | (word & 16711680) >> 8 | word >>> 24;
- };
- var decrypt3 = function decrypt4(encrypted, key, initVector) {
- var encrypted32 = new Int32Array(encrypted.buffer, encrypted.byteOffset, encrypted.byteLength >> 2);
- var decipher = new AES(Array.prototype.slice.call(key));
- var decrypted = new Uint8Array(encrypted.byteLength);
- var decrypted32 = new Int32Array(decrypted.buffer);
- var init0;
- var init1;
- var init2;
- var init3;
- var encrypted0;
- var encrypted1;
- var encrypted2;
- var encrypted3;
- var wordIx;
- init0 = initVector[0];
- init1 = initVector[1];
- init2 = initVector[2];
- init3 = initVector[3];
- for (wordIx = 0; wordIx < encrypted32.length; wordIx += 4) {
- encrypted0 = ntoh(encrypted32[wordIx]);
- encrypted1 = ntoh(encrypted32[wordIx + 1]);
- encrypted2 = ntoh(encrypted32[wordIx + 2]);
- encrypted3 = ntoh(encrypted32[wordIx + 3]);
- decipher.decrypt(encrypted0, encrypted1, encrypted2, encrypted3, decrypted32, wordIx);
- decrypted32[wordIx] = ntoh(decrypted32[wordIx] ^ init0);
- decrypted32[wordIx + 1] = ntoh(decrypted32[wordIx + 1] ^ init1);
- decrypted32[wordIx + 2] = ntoh(decrypted32[wordIx + 2] ^ init2);
- decrypted32[wordIx + 3] = ntoh(decrypted32[wordIx + 3] ^ init3);
- init0 = encrypted0;
- init1 = encrypted1;
- init2 = encrypted2;
- init3 = encrypted3;
- }
- return decrypted;
- };
- var Decrypter2 = /* @__PURE__ */ function() {
- function Decrypter3(encrypted, key, initVector, done) {
- var step = Decrypter3.STEP;
- var encrypted32 = new Int32Array(encrypted.buffer);
- var decrypted = new Uint8Array(encrypted.byteLength);
- var i2 = 0;
- this.asyncStream_ = new AsyncStream();
- this.asyncStream_.push(this.decryptChunk_(encrypted32.subarray(i2, i2 + step), key, initVector, decrypted));
- for (i2 = step; i2 < encrypted32.length; i2 += step) {
- initVector = new Uint32Array([ntoh(encrypted32[i2 - 4]), ntoh(encrypted32[i2 - 3]), ntoh(encrypted32[i2 - 2]), ntoh(encrypted32[i2 - 1])]);
- this.asyncStream_.push(this.decryptChunk_(encrypted32.subarray(i2, i2 + step), key, initVector, decrypted));
- }
- this.asyncStream_.push(function() {
- done(null, unpad(decrypted));
- });
- }
- var _proto = Decrypter3.prototype;
- _proto.decryptChunk_ = function decryptChunk_(encrypted, key, initVector, decrypted) {
- return function() {
- var bytes = decrypt3(encrypted, key, initVector);
- decrypted.set(bytes, encrypted.byteOffset);
- };
- };
- createClass(Decrypter3, null, [{
- key: "STEP",
- get: function get7() {
- return 32e3;
- }
- }]);
- return Decrypter3;
- }();
- var win2;
- if (typeof window !== "undefined") {
- win2 = window;
- } else if (typeof commonjsGlobal2 !== "undefined") {
- win2 = commonjsGlobal2;
- } else if (typeof self !== "undefined") {
- win2 = self;
- } else {
- win2 = {};
- }
- var window_12 = win2;
- var isArrayBufferView4 = function isArrayBufferView5(obj) {
- if (ArrayBuffer.isView === "function") {
- return ArrayBuffer.isView(obj);
- }
- return obj && obj.buffer instanceof ArrayBuffer;
- };
- var BigInt2 = window_12.BigInt || Number;
- [BigInt2("0x1"), BigInt2("0x100"), BigInt2("0x10000"), BigInt2("0x1000000"), BigInt2("0x100000000"), BigInt2("0x10000000000"), BigInt2("0x1000000000000"), BigInt2("0x100000000000000"), BigInt2("0x10000000000000000")];
- var createTransferableMessage3 = function createTransferableMessage4(message) {
- var transferable = {};
- Object.keys(message).forEach(function(key) {
- var value = message[key];
- if (isArrayBufferView4(value)) {
- transferable[key] = {
- bytes: value.buffer,
- byteOffset: value.byteOffset,
- byteLength: value.byteLength
- };
- } else {
- transferable[key] = value;
- }
- });
- return transferable;
- };
- self.onmessage = function(event2) {
- var data = event2.data;
- var encrypted = new Uint8Array(data.encrypted.bytes, data.encrypted.byteOffset, data.encrypted.byteLength);
- var key = new Uint32Array(data.key.bytes, data.key.byteOffset, data.key.byteLength / 4);
- var iv = new Uint32Array(data.iv.bytes, data.iv.byteOffset, data.iv.byteLength / 4);
- new Decrypter2(encrypted, key, iv, function(err, bytes) {
- self.postMessage(createTransferableMessage3({
- source: data.source,
- decrypted: bytes
- }), [bytes.buffer]);
- });
- };
- }));
- var Decrypter = factory(workerCode);
- var audioTrackKind_ = function audioTrackKind_2(properties) {
- var kind = properties["default"] ? "main" : "alternative";
- if (properties.characteristics && properties.characteristics.indexOf("public.accessibility.describes-video") >= 0) {
- kind = "main-desc";
- }
- return kind;
- };
- var stopLoaders = function stopLoaders2(segmentLoader, mediaType) {
- segmentLoader.abort();
- segmentLoader.pause();
- if (mediaType && mediaType.activePlaylistLoader) {
- mediaType.activePlaylistLoader.pause();
- mediaType.activePlaylistLoader = null;
- }
- };
- var startLoaders = function startLoaders2(playlistLoader, mediaType) {
- mediaType.activePlaylistLoader = playlistLoader;
- playlistLoader.load();
- };
- var onGroupChanged = function onGroupChanged2(type2, settings) {
- return function() {
- var _settings$segmentLoad = settings.segmentLoaders, segmentLoader = _settings$segmentLoad[type2], mainSegmentLoader = _settings$segmentLoad.main, mediaType = settings.mediaTypes[type2];
- var activeTrack2 = mediaType.activeTrack();
- var activeGroup3 = mediaType.getActiveGroup();
- var previousActiveLoader = mediaType.activePlaylistLoader;
- var lastGroup = mediaType.lastGroup_;
- if (activeGroup3 && lastGroup && activeGroup3.id === lastGroup.id) {
- return;
- }
- mediaType.lastGroup_ = activeGroup3;
- mediaType.lastTrack_ = activeTrack2;
- stopLoaders(segmentLoader, mediaType);
- if (!activeGroup3 || activeGroup3.isMasterPlaylist) {
- return;
- }
- if (!activeGroup3.playlistLoader) {
- if (previousActiveLoader) {
- mainSegmentLoader.resetEverything();
- }
- return;
- }
- segmentLoader.resyncLoader();
- startLoaders(activeGroup3.playlistLoader, mediaType);
- };
- };
- var onGroupChanging = function onGroupChanging2(type2, settings) {
- return function() {
- var segmentLoader = settings.segmentLoaders[type2], mediaType = settings.mediaTypes[type2];
- mediaType.lastGroup_ = null;
- segmentLoader.abort();
- segmentLoader.pause();
- };
- };
- var onTrackChanged = function onTrackChanged2(type2, settings) {
- return function() {
- var masterPlaylistLoader = settings.masterPlaylistLoader, _settings$segmentLoad2 = settings.segmentLoaders, segmentLoader = _settings$segmentLoad2[type2], mainSegmentLoader = _settings$segmentLoad2.main, mediaType = settings.mediaTypes[type2];
- var activeTrack2 = mediaType.activeTrack();
- var activeGroup3 = mediaType.getActiveGroup();
- var previousActiveLoader = mediaType.activePlaylistLoader;
- var lastTrack = mediaType.lastTrack_;
- if (lastTrack && activeTrack2 && lastTrack.id === activeTrack2.id) {
- return;
- }
- mediaType.lastGroup_ = activeGroup3;
- mediaType.lastTrack_ = activeTrack2;
- stopLoaders(segmentLoader, mediaType);
- if (!activeGroup3) {
- return;
- }
- if (activeGroup3.isMasterPlaylist) {
- if (!activeTrack2 || !lastTrack || activeTrack2.id === lastTrack.id) {
- return;
- }
- var mpc = settings.vhs.masterPlaylistController_;
- var newPlaylist = mpc.selectPlaylist();
- if (mpc.media() === newPlaylist) {
- return;
- }
- mediaType.logger_("track change. Switching master audio from " + lastTrack.id + " to " + activeTrack2.id);
- masterPlaylistLoader.pause();
- mainSegmentLoader.resetEverything();
- mpc.fastQualityChange_(newPlaylist);
- return;
- }
- if (type2 === "AUDIO") {
- if (!activeGroup3.playlistLoader) {
- mainSegmentLoader.setAudio(true);
- mainSegmentLoader.resetEverything();
- return;
- }
- segmentLoader.setAudio(true);
- mainSegmentLoader.setAudio(false);
- }
- if (previousActiveLoader === activeGroup3.playlistLoader) {
- startLoaders(activeGroup3.playlistLoader, mediaType);
- return;
- }
- if (segmentLoader.track) {
- segmentLoader.track(activeTrack2);
- }
- segmentLoader.resetEverything();
- startLoaders(activeGroup3.playlistLoader, mediaType);
- };
- };
- var onError = {
- AUDIO: function AUDIO(type2, settings) {
- return function() {
- var segmentLoader = settings.segmentLoaders[type2], mediaType = settings.mediaTypes[type2], blacklistCurrentPlaylist = settings.blacklistCurrentPlaylist;
- stopLoaders(segmentLoader, mediaType);
- var activeTrack2 = mediaType.activeTrack();
- var activeGroup3 = mediaType.activeGroup();
- var id = (activeGroup3.filter(function(group) {
- return group["default"];
- })[0] || activeGroup3[0]).id;
- var defaultTrack = mediaType.tracks[id];
- if (activeTrack2 === defaultTrack) {
- blacklistCurrentPlaylist({
- message: "Problem encountered loading the default audio track."
- });
- return;
- }
- videojs.log.warn("Problem encountered loading the alternate audio track.Switching back to default.");
- for (var trackId in mediaType.tracks) {
- mediaType.tracks[trackId].enabled = mediaType.tracks[trackId] === defaultTrack;
- }
- mediaType.onTrackChanged();
- };
- },
- SUBTITLES: function SUBTITLES(type2, settings) {
- return function() {
- var segmentLoader = settings.segmentLoaders[type2], mediaType = settings.mediaTypes[type2];
- videojs.log.warn("Problem encountered loading the subtitle track.Disabling subtitle track.");
- stopLoaders(segmentLoader, mediaType);
- var track = mediaType.activeTrack();
- if (track) {
- track.mode = "disabled";
- }
- mediaType.onTrackChanged();
- };
- }
- };
- var setupListeners = {
- AUDIO: function AUDIO2(type2, playlistLoader, settings) {
- if (!playlistLoader) {
- return;
- }
- var tech = settings.tech, requestOptions = settings.requestOptions, segmentLoader = settings.segmentLoaders[type2];
- playlistLoader.on("loadedmetadata", function() {
- var media = playlistLoader.media();
- segmentLoader.playlist(media, requestOptions);
- if (!tech.paused() || media.endList && tech.preload() !== "none") {
- segmentLoader.load();
- }
- });
- playlistLoader.on("loadedplaylist", function() {
- segmentLoader.playlist(playlistLoader.media(), requestOptions);
- if (!tech.paused()) {
- segmentLoader.load();
- }
- });
- playlistLoader.on("error", onError[type2](type2, settings));
- },
- SUBTITLES: function SUBTITLES2(type2, playlistLoader, settings) {
- var tech = settings.tech, requestOptions = settings.requestOptions, segmentLoader = settings.segmentLoaders[type2], mediaType = settings.mediaTypes[type2];
- playlistLoader.on("loadedmetadata", function() {
- var media = playlistLoader.media();
- segmentLoader.playlist(media, requestOptions);
- segmentLoader.track(mediaType.activeTrack());
- if (!tech.paused() || media.endList && tech.preload() !== "none") {
- segmentLoader.load();
- }
- });
- playlistLoader.on("loadedplaylist", function() {
- segmentLoader.playlist(playlistLoader.media(), requestOptions);
- if (!tech.paused()) {
- segmentLoader.load();
- }
- });
- playlistLoader.on("error", onError[type2](type2, settings));
- }
- };
- var initialize = {
- "AUDIO": function AUDIO3(type2, settings) {
- var vhs = settings.vhs, sourceType = settings.sourceType, segmentLoader = settings.segmentLoaders[type2], requestOptions = settings.requestOptions, mediaGroups = settings.master.mediaGroups, _settings$mediaTypes$ = settings.mediaTypes[type2], groups = _settings$mediaTypes$.groups, tracks = _settings$mediaTypes$.tracks, logger_ = _settings$mediaTypes$.logger_, masterPlaylistLoader = settings.masterPlaylistLoader;
- var audioOnlyMaster = isAudioOnly(masterPlaylistLoader.master);
- if (!mediaGroups[type2] || Object.keys(mediaGroups[type2]).length === 0) {
- mediaGroups[type2] = {
- main: {
- "default": {
- "default": true
- }
- }
- };
- if (audioOnlyMaster) {
- mediaGroups[type2].main["default"].playlists = masterPlaylistLoader.master.playlists;
- }
- }
- for (var groupId in mediaGroups[type2]) {
- if (!groups[groupId]) {
- groups[groupId] = [];
- }
- for (var variantLabel in mediaGroups[type2][groupId]) {
- var properties = mediaGroups[type2][groupId][variantLabel];
- var playlistLoader = void 0;
- if (audioOnlyMaster) {
- logger_("AUDIO group '" + groupId + "' label '" + variantLabel + "' is a master playlist");
- properties.isMasterPlaylist = true;
- playlistLoader = null;
- } else if (sourceType === "vhs-json" && properties.playlists) {
- playlistLoader = new PlaylistLoader(properties.playlists[0], vhs, requestOptions);
- } else if (properties.resolvedUri) {
- playlistLoader = new PlaylistLoader(properties.resolvedUri, vhs, requestOptions);
- } else if (properties.playlists && sourceType === "dash") {
- playlistLoader = new DashPlaylistLoader(properties.playlists[0], vhs, requestOptions, masterPlaylistLoader);
- } else {
- playlistLoader = null;
- }
- properties = videojs.mergeOptions({
- id: variantLabel,
- playlistLoader
- }, properties);
- setupListeners[type2](type2, properties.playlistLoader, settings);
- groups[groupId].push(properties);
- if (typeof tracks[variantLabel] === "undefined") {
- var track = new videojs.AudioTrack({
- id: variantLabel,
- kind: audioTrackKind_(properties),
- enabled: false,
- language: properties.language,
- "default": properties["default"],
- label: variantLabel
- });
- tracks[variantLabel] = track;
- }
- }
- }
- segmentLoader.on("error", onError[type2](type2, settings));
- },
- "SUBTITLES": function SUBTITLES3(type2, settings) {
- var tech = settings.tech, vhs = settings.vhs, sourceType = settings.sourceType, segmentLoader = settings.segmentLoaders[type2], requestOptions = settings.requestOptions, mediaGroups = settings.master.mediaGroups, _settings$mediaTypes$2 = settings.mediaTypes[type2], groups = _settings$mediaTypes$2.groups, tracks = _settings$mediaTypes$2.tracks, masterPlaylistLoader = settings.masterPlaylistLoader;
- for (var groupId in mediaGroups[type2]) {
- if (!groups[groupId]) {
- groups[groupId] = [];
- }
- for (var variantLabel in mediaGroups[type2][groupId]) {
- if (mediaGroups[type2][groupId][variantLabel].forced) {
- continue;
- }
- var properties = mediaGroups[type2][groupId][variantLabel];
- var playlistLoader = void 0;
- if (sourceType === "hls") {
- playlistLoader = new PlaylistLoader(properties.resolvedUri, vhs, requestOptions);
- } else if (sourceType === "dash") {
- var playlists = properties.playlists.filter(function(p) {
- return p.excludeUntil !== Infinity;
- });
- if (!playlists.length) {
- return;
- }
- playlistLoader = new DashPlaylistLoader(properties.playlists[0], vhs, requestOptions, masterPlaylistLoader);
- } else if (sourceType === "vhs-json") {
- playlistLoader = new PlaylistLoader(
- properties.playlists ? properties.playlists[0] : properties.resolvedUri,
- vhs,
- requestOptions
- );
- }
- properties = videojs.mergeOptions({
- id: variantLabel,
- playlistLoader
- }, properties);
- setupListeners[type2](type2, properties.playlistLoader, settings);
- groups[groupId].push(properties);
- if (typeof tracks[variantLabel] === "undefined") {
- var track = tech.addRemoteTextTrack({
- id: variantLabel,
- kind: "subtitles",
- "default": properties["default"] && properties.autoselect,
- language: properties.language,
- label: variantLabel
- }, false).track;
- tracks[variantLabel] = track;
- }
- }
- }
- segmentLoader.on("error", onError[type2](type2, settings));
- },
- "CLOSED-CAPTIONS": function CLOSEDCAPTIONS(type2, settings) {
- var tech = settings.tech, mediaGroups = settings.master.mediaGroups, _settings$mediaTypes$3 = settings.mediaTypes[type2], groups = _settings$mediaTypes$3.groups, tracks = _settings$mediaTypes$3.tracks;
- for (var groupId in mediaGroups[type2]) {
- if (!groups[groupId]) {
- groups[groupId] = [];
- }
- for (var variantLabel in mediaGroups[type2][groupId]) {
- var properties = mediaGroups[type2][groupId][variantLabel];
- if (!/^(?:CC|SERVICE)/.test(properties.instreamId)) {
- continue;
- }
- var captionServices = tech.options_.vhs && tech.options_.vhs.captionServices || {};
- var newProps = {
- label: variantLabel,
- language: properties.language,
- instreamId: properties.instreamId,
- "default": properties["default"] && properties.autoselect
- };
- if (captionServices[newProps.instreamId]) {
- newProps = videojs.mergeOptions(newProps, captionServices[newProps.instreamId]);
- }
- if (newProps["default"] === void 0) {
- delete newProps["default"];
- }
- groups[groupId].push(videojs.mergeOptions({
- id: variantLabel
- }, properties));
- if (typeof tracks[variantLabel] === "undefined") {
- var track = tech.addRemoteTextTrack({
- id: newProps.instreamId,
- kind: "captions",
- "default": newProps["default"],
- language: newProps.language,
- label: newProps.label
- }, false).track;
- tracks[variantLabel] = track;
- }
- }
- }
- }
- };
- var groupMatch = function groupMatch2(list, media) {
- for (var i2 = 0; i2 < list.length; i2++) {
- if (playlistMatch(media, list[i2])) {
- return true;
- }
- if (list[i2].playlists && groupMatch2(list[i2].playlists, media)) {
- return true;
- }
- }
- return false;
- };
- var activeGroup = function activeGroup2(type2, settings) {
- return function(track) {
- var masterPlaylistLoader = settings.masterPlaylistLoader, groups = settings.mediaTypes[type2].groups;
- var media = masterPlaylistLoader.media();
- if (!media) {
- return null;
- }
- var variants = null;
- if (media.attributes[type2]) {
- variants = groups[media.attributes[type2]];
- }
- var groupKeys = Object.keys(groups);
- if (!variants) {
- if (type2 === "AUDIO" && groupKeys.length > 1 && isAudioOnly(settings.master)) {
- for (var i2 = 0; i2 < groupKeys.length; i2++) {
- var groupPropertyList = groups[groupKeys[i2]];
- if (groupMatch(groupPropertyList, media)) {
- variants = groupPropertyList;
- break;
- }
- }
- } else if (groups.main) {
- variants = groups.main;
- } else if (groupKeys.length === 1) {
- variants = groups[groupKeys[0]];
- }
- }
- if (typeof track === "undefined") {
- return variants;
- }
- if (track === null || !variants) {
- return null;
- }
- return variants.filter(function(props) {
- return props.id === track.id;
- })[0] || null;
- };
- };
- var activeTrack = {
- AUDIO: function AUDIO4(type2, settings) {
- return function() {
- var tracks = settings.mediaTypes[type2].tracks;
- for (var id in tracks) {
- if (tracks[id].enabled) {
- return tracks[id];
- }
- }
- return null;
- };
- },
- SUBTITLES: function SUBTITLES4(type2, settings) {
- return function() {
- var tracks = settings.mediaTypes[type2].tracks;
- for (var id in tracks) {
- if (tracks[id].mode === "showing" || tracks[id].mode === "hidden") {
- return tracks[id];
- }
- }
- return null;
- };
- }
- };
- var getActiveGroup = function getActiveGroup2(type2, _ref) {
- var mediaTypes2 = _ref.mediaTypes;
- return function() {
- var activeTrack_ = mediaTypes2[type2].activeTrack();
- if (!activeTrack_) {
- return null;
- }
- return mediaTypes2[type2].activeGroup(activeTrack_);
- };
- };
- var setupMediaGroups = function setupMediaGroups2(settings) {
- ["AUDIO", "SUBTITLES", "CLOSED-CAPTIONS"].forEach(function(type2) {
- initialize[type2](type2, settings);
- });
- var mediaTypes2 = settings.mediaTypes, masterPlaylistLoader = settings.masterPlaylistLoader, tech = settings.tech, vhs = settings.vhs, _settings$segmentLoad3 = settings.segmentLoaders, audioSegmentLoader = _settings$segmentLoad3["AUDIO"], mainSegmentLoader = _settings$segmentLoad3.main;
- ["AUDIO", "SUBTITLES"].forEach(function(type2) {
- mediaTypes2[type2].activeGroup = activeGroup(type2, settings);
- mediaTypes2[type2].activeTrack = activeTrack[type2](type2, settings);
- mediaTypes2[type2].onGroupChanged = onGroupChanged(type2, settings);
- mediaTypes2[type2].onGroupChanging = onGroupChanging(type2, settings);
- mediaTypes2[type2].onTrackChanged = onTrackChanged(type2, settings);
- mediaTypes2[type2].getActiveGroup = getActiveGroup(type2, settings);
- });
- var audioGroup = mediaTypes2.AUDIO.activeGroup();
- if (audioGroup) {
- var groupId = (audioGroup.filter(function(group) {
- return group["default"];
- })[0] || audioGroup[0]).id;
- mediaTypes2.AUDIO.tracks[groupId].enabled = true;
- mediaTypes2.AUDIO.onGroupChanged();
- mediaTypes2.AUDIO.onTrackChanged();
- var activeAudioGroup = mediaTypes2.AUDIO.getActiveGroup();
- if (!activeAudioGroup.playlistLoader) {
- mainSegmentLoader.setAudio(true);
- } else {
- mainSegmentLoader.setAudio(false);
- audioSegmentLoader.setAudio(true);
- }
- }
- masterPlaylistLoader.on("mediachange", function() {
- ["AUDIO", "SUBTITLES"].forEach(function(type2) {
- return mediaTypes2[type2].onGroupChanged();
- });
- });
- masterPlaylistLoader.on("mediachanging", function() {
- ["AUDIO", "SUBTITLES"].forEach(function(type2) {
- return mediaTypes2[type2].onGroupChanging();
- });
- });
- var onAudioTrackChanged = function onAudioTrackChanged2() {
- mediaTypes2.AUDIO.onTrackChanged();
- tech.trigger({
- type: "usage",
- name: "vhs-audio-change"
- });
- tech.trigger({
- type: "usage",
- name: "hls-audio-change"
- });
- };
- tech.audioTracks().addEventListener("change", onAudioTrackChanged);
- tech.remoteTextTracks().addEventListener("change", mediaTypes2.SUBTITLES.onTrackChanged);
- vhs.on("dispose", function() {
- tech.audioTracks().removeEventListener("change", onAudioTrackChanged);
- tech.remoteTextTracks().removeEventListener("change", mediaTypes2.SUBTITLES.onTrackChanged);
- });
- tech.clearTracks("audio");
- for (var id in mediaTypes2.AUDIO.tracks) {
- tech.audioTracks().addTrack(mediaTypes2.AUDIO.tracks[id]);
- }
- };
- var createMediaTypes = function createMediaTypes2() {
- var mediaTypes2 = {};
- ["AUDIO", "SUBTITLES", "CLOSED-CAPTIONS"].forEach(function(type2) {
- mediaTypes2[type2] = {
- groups: {},
- tracks: {},
- activePlaylistLoader: null,
- activeGroup: noop,
- activeTrack: noop,
- getActiveGroup: noop,
- onGroupChanged: noop,
- onTrackChanged: noop,
- lastTrack_: null,
- logger_: logger("MediaGroups[" + type2 + "]")
- };
- });
- return mediaTypes2;
- };
- var ABORT_EARLY_BLACKLIST_SECONDS = 60 * 2;
- var Vhs$1;
- var loaderStats = ["mediaRequests", "mediaRequestsAborted", "mediaRequestsTimedout", "mediaRequestsErrored", "mediaTransferDuration", "mediaBytesTransferred", "mediaAppends"];
- var sumLoaderStat = function sumLoaderStat2(stat) {
- return this.audioSegmentLoader_[stat] + this.mainSegmentLoader_[stat];
- };
- var shouldSwitchToMedia = function shouldSwitchToMedia2(_ref) {
- var currentPlaylist = _ref.currentPlaylist, buffered = _ref.buffered, currentTime = _ref.currentTime, nextPlaylist = _ref.nextPlaylist, bufferLowWaterLine = _ref.bufferLowWaterLine, bufferHighWaterLine = _ref.bufferHighWaterLine, duration5 = _ref.duration, experimentalBufferBasedABR = _ref.experimentalBufferBasedABR, log2 = _ref.log;
- if (!nextPlaylist) {
- videojs.log.warn("We received no playlist to switch to. Please check your stream.");
- return false;
- }
- var sharedLogLine = "allowing switch " + (currentPlaylist && currentPlaylist.id || "null") + " -> " + nextPlaylist.id;
- if (!currentPlaylist) {
- log2(sharedLogLine + " as current playlist is not set");
- return true;
- }
- if (nextPlaylist.id === currentPlaylist.id) {
- return false;
- }
- var isBuffered = Boolean(findRange(buffered, currentTime).length);
- if (!currentPlaylist.endList) {
- if (!isBuffered && typeof currentPlaylist.partTargetDuration === "number") {
- log2("not " + sharedLogLine + " as current playlist is live llhls, but currentTime isn't in buffered.");
- return false;
- }
- log2(sharedLogLine + " as current playlist is live");
- return true;
- }
- var forwardBuffer = timeAheadOf(buffered, currentTime);
- var maxBufferLowWaterLine = experimentalBufferBasedABR ? Config.EXPERIMENTAL_MAX_BUFFER_LOW_WATER_LINE : Config.MAX_BUFFER_LOW_WATER_LINE;
- if (duration5 < maxBufferLowWaterLine) {
- log2(sharedLogLine + " as duration < max low water line (" + duration5 + " < " + maxBufferLowWaterLine + ")");
- return true;
- }
- var nextBandwidth = nextPlaylist.attributes.BANDWIDTH;
- var currBandwidth = currentPlaylist.attributes.BANDWIDTH;
- if (nextBandwidth < currBandwidth && (!experimentalBufferBasedABR || forwardBuffer < bufferHighWaterLine)) {
- var logLine = sharedLogLine + " as next bandwidth < current bandwidth (" + nextBandwidth + " < " + currBandwidth + ")";
- if (experimentalBufferBasedABR) {
- logLine += " and forwardBuffer < bufferHighWaterLine (" + forwardBuffer + " < " + bufferHighWaterLine + ")";
- }
- log2(logLine);
- return true;
- }
- if ((!experimentalBufferBasedABR || nextBandwidth > currBandwidth) && forwardBuffer >= bufferLowWaterLine) {
- var _logLine = sharedLogLine + " as forwardBuffer >= bufferLowWaterLine (" + forwardBuffer + " >= " + bufferLowWaterLine + ")";
- if (experimentalBufferBasedABR) {
- _logLine += " and next bandwidth > current bandwidth (" + nextBandwidth + " > " + currBandwidth + ")";
- }
- log2(_logLine);
- return true;
- }
- log2("not " + sharedLogLine + " as no switching criteria met");
- return false;
- };
- var MasterPlaylistController = /* @__PURE__ */ function(_videojs$EventTarget) {
- _inheritsLoose(MasterPlaylistController2, _videojs$EventTarget);
- function MasterPlaylistController2(options2) {
- var _this;
- _this = _videojs$EventTarget.call(this) || this;
- var src = options2.src, handleManifestRedirects = options2.handleManifestRedirects, withCredentials = options2.withCredentials, tech = options2.tech, bandwidth2 = options2.bandwidth, externVhs = options2.externVhs, useCueTags = options2.useCueTags, blacklistDuration = options2.blacklistDuration, enableLowInitialPlaylist = options2.enableLowInitialPlaylist, sourceType = options2.sourceType, cacheEncryptionKeys = options2.cacheEncryptionKeys, experimentalBufferBasedABR = options2.experimentalBufferBasedABR, experimentalLeastPixelDiffSelector = options2.experimentalLeastPixelDiffSelector, captionServices = options2.captionServices;
- if (!src) {
- throw new Error("A non-empty playlist URL or JSON manifest string is required");
- }
- var maxPlaylistRetries = options2.maxPlaylistRetries;
- if (maxPlaylistRetries === null || typeof maxPlaylistRetries === "undefined") {
- maxPlaylistRetries = Infinity;
- }
- Vhs$1 = externVhs;
- _this.experimentalBufferBasedABR = Boolean(experimentalBufferBasedABR);
- _this.experimentalLeastPixelDiffSelector = Boolean(experimentalLeastPixelDiffSelector);
- _this.withCredentials = withCredentials;
- _this.tech_ = tech;
- _this.vhs_ = tech.vhs;
- _this.sourceType_ = sourceType;
- _this.useCueTags_ = useCueTags;
- _this.blacklistDuration = blacklistDuration;
- _this.maxPlaylistRetries = maxPlaylistRetries;
- _this.enableLowInitialPlaylist = enableLowInitialPlaylist;
- if (_this.useCueTags_) {
- _this.cueTagsTrack_ = _this.tech_.addTextTrack("metadata", "ad-cues");
- _this.cueTagsTrack_.inBandMetadataTrackDispatchType = "";
- }
- _this.requestOptions_ = {
- withCredentials,
- handleManifestRedirects,
- maxPlaylistRetries,
- timeout: null
- };
- _this.on("error", _this.pauseLoading);
- _this.mediaTypes_ = createMediaTypes();
- _this.mediaSource = new window_1.MediaSource();
- _this.handleDurationChange_ = _this.handleDurationChange_.bind(_assertThisInitialized(_this));
- _this.handleSourceOpen_ = _this.handleSourceOpen_.bind(_assertThisInitialized(_this));
- _this.handleSourceEnded_ = _this.handleSourceEnded_.bind(_assertThisInitialized(_this));
- _this.mediaSource.addEventListener("durationchange", _this.handleDurationChange_);
- _this.mediaSource.addEventListener("sourceopen", _this.handleSourceOpen_);
- _this.mediaSource.addEventListener("sourceended", _this.handleSourceEnded_);
- _this.seekable_ = videojs.createTimeRanges();
- _this.hasPlayed_ = false;
- _this.syncController_ = new SyncController(options2);
- _this.segmentMetadataTrack_ = tech.addRemoteTextTrack({
- kind: "metadata",
- label: "segment-metadata"
- }, false).track;
- _this.decrypter_ = new Decrypter();
- _this.sourceUpdater_ = new SourceUpdater(_this.mediaSource);
- _this.inbandTextTracks_ = {};
- _this.timelineChangeController_ = new TimelineChangeController();
- var segmentLoaderSettings = {
- vhs: _this.vhs_,
- parse708captions: options2.parse708captions,
- useDtsForTimestampOffset: options2.useDtsForTimestampOffset,
- captionServices,
- mediaSource: _this.mediaSource,
- currentTime: _this.tech_.currentTime.bind(_this.tech_),
- seekable: function seekable3() {
- return _this.seekable();
- },
- seeking: function seeking() {
- return _this.tech_.seeking();
- },
- duration: function duration5() {
- return _this.duration();
- },
- hasPlayed: function hasPlayed() {
- return _this.hasPlayed_;
- },
- goalBufferLength: function goalBufferLength() {
- return _this.goalBufferLength();
- },
- bandwidth: bandwidth2,
- syncController: _this.syncController_,
- decrypter: _this.decrypter_,
- sourceType: _this.sourceType_,
- inbandTextTracks: _this.inbandTextTracks_,
- cacheEncryptionKeys,
- sourceUpdater: _this.sourceUpdater_,
- timelineChangeController: _this.timelineChangeController_,
- experimentalExactManifestTimings: options2.experimentalExactManifestTimings
- };
- _this.masterPlaylistLoader_ = _this.sourceType_ === "dash" ? new DashPlaylistLoader(src, _this.vhs_, _this.requestOptions_) : new PlaylistLoader(src, _this.vhs_, _this.requestOptions_);
- _this.setupMasterPlaylistLoaderListeners_();
- _this.mainSegmentLoader_ = new SegmentLoader(videojs.mergeOptions(segmentLoaderSettings, {
- segmentMetadataTrack: _this.segmentMetadataTrack_,
- loaderType: "main"
- }), options2);
- _this.audioSegmentLoader_ = new SegmentLoader(videojs.mergeOptions(segmentLoaderSettings, {
- loaderType: "audio"
- }), options2);
- _this.subtitleSegmentLoader_ = new VTTSegmentLoader(videojs.mergeOptions(segmentLoaderSettings, {
- loaderType: "vtt",
- featuresNativeTextTracks: _this.tech_.featuresNativeTextTracks,
- loadVttJs: function loadVttJs() {
- return new Promise(function(resolve2, reject2) {
- function onLoad() {
- tech.off("vttjserror", onError2);
- resolve2();
- }
- function onError2() {
- tech.off("vttjsloaded", onLoad);
- reject2();
- }
- tech.one("vttjsloaded", onLoad);
- tech.one("vttjserror", onError2);
- tech.addWebVttScript_();
- });
- }
- }), options2);
- _this.setupSegmentLoaderListeners_();
- if (_this.experimentalBufferBasedABR) {
- _this.masterPlaylistLoader_.one("loadedplaylist", function() {
- return _this.startABRTimer_();
- });
- _this.tech_.on("pause", function() {
- return _this.stopABRTimer_();
- });
- _this.tech_.on("play", function() {
- return _this.startABRTimer_();
- });
- }
- loaderStats.forEach(function(stat) {
- _this[stat + "_"] = sumLoaderStat.bind(_assertThisInitialized(_this), stat);
- });
- _this.logger_ = logger("MPC");
- _this.triggeredFmp4Usage = false;
- if (_this.tech_.preload() === "none") {
- _this.loadOnPlay_ = function() {
- _this.loadOnPlay_ = null;
- _this.masterPlaylistLoader_.load();
- };
- _this.tech_.one("play", _this.loadOnPlay_);
- } else {
- _this.masterPlaylistLoader_.load();
- }
- _this.timeToLoadedData__ = -1;
- _this.mainAppendsToLoadedData__ = -1;
- _this.audioAppendsToLoadedData__ = -1;
- var event2 = _this.tech_.preload() === "none" ? "play" : "loadstart";
- _this.tech_.one(event2, function() {
- var timeToLoadedDataStart = Date.now();
- _this.tech_.one("loadeddata", function() {
- _this.timeToLoadedData__ = Date.now() - timeToLoadedDataStart;
- _this.mainAppendsToLoadedData__ = _this.mainSegmentLoader_.mediaAppends;
- _this.audioAppendsToLoadedData__ = _this.audioSegmentLoader_.mediaAppends;
- });
- });
- return _this;
- }
- var _proto = MasterPlaylistController2.prototype;
- _proto.mainAppendsToLoadedData_ = function mainAppendsToLoadedData_() {
- return this.mainAppendsToLoadedData__;
- };
- _proto.audioAppendsToLoadedData_ = function audioAppendsToLoadedData_() {
- return this.audioAppendsToLoadedData__;
- };
- _proto.appendsToLoadedData_ = function appendsToLoadedData_() {
- var main = this.mainAppendsToLoadedData_();
- var audio = this.audioAppendsToLoadedData_();
- if (main === -1 || audio === -1) {
- return -1;
- }
- return main + audio;
- };
- _proto.timeToLoadedData_ = function timeToLoadedData_() {
- return this.timeToLoadedData__;
- };
- _proto.checkABR_ = function checkABR_(reason) {
- if (reason === void 0) {
- reason = "abr";
- }
- var nextPlaylist = this.selectPlaylist();
- if (nextPlaylist && this.shouldSwitchToMedia_(nextPlaylist)) {
- this.switchMedia_(nextPlaylist, reason);
- }
- };
- _proto.switchMedia_ = function switchMedia_(playlist, cause, delay) {
- var oldMedia = this.media();
- var oldId = oldMedia && (oldMedia.id || oldMedia.uri);
- var newId = playlist.id || playlist.uri;
- if (oldId && oldId !== newId) {
- this.logger_("switch media " + oldId + " -> " + newId + " from " + cause);
- this.tech_.trigger({
- type: "usage",
- name: "vhs-rendition-change-" + cause
- });
- }
- this.masterPlaylistLoader_.media(playlist, delay);
- };
- _proto.startABRTimer_ = function startABRTimer_() {
- var _this2 = this;
- this.stopABRTimer_();
- this.abrTimer_ = window_1.setInterval(function() {
- return _this2.checkABR_();
- }, 250);
- };
- _proto.stopABRTimer_ = function stopABRTimer_() {
- if (this.tech_.scrubbing && this.tech_.scrubbing()) {
- return;
- }
- window_1.clearInterval(this.abrTimer_);
- this.abrTimer_ = null;
- };
- _proto.getAudioTrackPlaylists_ = function getAudioTrackPlaylists_() {
- var master = this.master();
- var defaultPlaylists = master && master.playlists || [];
- if (!master || !master.mediaGroups || !master.mediaGroups.AUDIO) {
- return defaultPlaylists;
- }
- var AUDIO5 = master.mediaGroups.AUDIO;
- var groupKeys = Object.keys(AUDIO5);
- var track;
- if (Object.keys(this.mediaTypes_.AUDIO.groups).length) {
- track = this.mediaTypes_.AUDIO.activeTrack();
- } else {
- var defaultGroup = AUDIO5.main || groupKeys.length && AUDIO5[groupKeys[0]];
- for (var label2 in defaultGroup) {
- if (defaultGroup[label2]["default"]) {
- track = {
- label: label2
- };
- break;
- }
- }
- }
- if (!track) {
- return defaultPlaylists;
- }
- var playlists = [];
- for (var group in AUDIO5) {
- if (AUDIO5[group][track.label]) {
- var properties = AUDIO5[group][track.label];
- if (properties.playlists && properties.playlists.length) {
- playlists.push.apply(playlists, properties.playlists);
- } else if (properties.uri) {
- playlists.push(properties);
- } else if (master.playlists.length) {
- for (var i2 = 0; i2 < master.playlists.length; i2++) {
- var playlist = master.playlists[i2];
- if (playlist.attributes && playlist.attributes.AUDIO && playlist.attributes.AUDIO === group) {
- playlists.push(playlist);
- }
- }
- }
- }
- }
- if (!playlists.length) {
- return defaultPlaylists;
- }
- return playlists;
- };
- _proto.setupMasterPlaylistLoaderListeners_ = function setupMasterPlaylistLoaderListeners_() {
- var _this3 = this;
- this.masterPlaylistLoader_.on("loadedmetadata", function() {
- var media = _this3.masterPlaylistLoader_.media();
- var requestTimeout = media.targetDuration * 1.5 * 1e3;
- if (isLowestEnabledRendition(_this3.masterPlaylistLoader_.master, _this3.masterPlaylistLoader_.media())) {
- _this3.requestOptions_.timeout = 0;
- } else {
- _this3.requestOptions_.timeout = requestTimeout;
- }
- if (media.endList && _this3.tech_.preload() !== "none") {
- _this3.mainSegmentLoader_.playlist(media, _this3.requestOptions_);
- _this3.mainSegmentLoader_.load();
- }
- setupMediaGroups({
- sourceType: _this3.sourceType_,
- segmentLoaders: {
- AUDIO: _this3.audioSegmentLoader_,
- SUBTITLES: _this3.subtitleSegmentLoader_,
- main: _this3.mainSegmentLoader_
- },
- tech: _this3.tech_,
- requestOptions: _this3.requestOptions_,
- masterPlaylistLoader: _this3.masterPlaylistLoader_,
- vhs: _this3.vhs_,
- master: _this3.master(),
- mediaTypes: _this3.mediaTypes_,
- blacklistCurrentPlaylist: _this3.blacklistCurrentPlaylist.bind(_this3)
- });
- _this3.triggerPresenceUsage_(_this3.master(), media);
- _this3.setupFirstPlay();
- if (!_this3.mediaTypes_.AUDIO.activePlaylistLoader || _this3.mediaTypes_.AUDIO.activePlaylistLoader.media()) {
- _this3.trigger("selectedinitialmedia");
- } else {
- _this3.mediaTypes_.AUDIO.activePlaylistLoader.one("loadedmetadata", function() {
- _this3.trigger("selectedinitialmedia");
- });
- }
- });
- this.masterPlaylistLoader_.on("loadedplaylist", function() {
- if (_this3.loadOnPlay_) {
- _this3.tech_.off("play", _this3.loadOnPlay_);
- }
- var updatedPlaylist = _this3.masterPlaylistLoader_.media();
- if (!updatedPlaylist) {
- _this3.excludeUnsupportedVariants_();
- var selectedMedia;
- if (_this3.enableLowInitialPlaylist) {
- selectedMedia = _this3.selectInitialPlaylist();
- }
- if (!selectedMedia) {
- selectedMedia = _this3.selectPlaylist();
- }
- if (!selectedMedia || !_this3.shouldSwitchToMedia_(selectedMedia)) {
- return;
- }
- _this3.initialMedia_ = selectedMedia;
- _this3.switchMedia_(_this3.initialMedia_, "initial");
- var haveJsonSource = _this3.sourceType_ === "vhs-json" && _this3.initialMedia_.segments;
- if (!haveJsonSource) {
- return;
- }
- updatedPlaylist = _this3.initialMedia_;
- }
- _this3.handleUpdatedMediaPlaylist(updatedPlaylist);
- });
- this.masterPlaylistLoader_.on("error", function() {
- _this3.blacklistCurrentPlaylist(_this3.masterPlaylistLoader_.error);
- });
- this.masterPlaylistLoader_.on("mediachanging", function() {
- _this3.mainSegmentLoader_.abort();
- _this3.mainSegmentLoader_.pause();
- });
- this.masterPlaylistLoader_.on("mediachange", function() {
- var media = _this3.masterPlaylistLoader_.media();
- var requestTimeout = media.targetDuration * 1.5 * 1e3;
- if (isLowestEnabledRendition(_this3.masterPlaylistLoader_.master, _this3.masterPlaylistLoader_.media())) {
- _this3.requestOptions_.timeout = 0;
- } else {
- _this3.requestOptions_.timeout = requestTimeout;
- }
- _this3.masterPlaylistLoader_.load();
- _this3.mainSegmentLoader_.playlist(media, _this3.requestOptions_);
- _this3.mainSegmentLoader_.load();
- _this3.tech_.trigger({
- type: "mediachange",
- bubbles: true
- });
- });
- this.masterPlaylistLoader_.on("playlistunchanged", function() {
- var updatedPlaylist = _this3.masterPlaylistLoader_.media();
- if (updatedPlaylist.lastExcludeReason_ === "playlist-unchanged") {
- return;
- }
- var playlistOutdated = _this3.stuckAtPlaylistEnd_(updatedPlaylist);
- if (playlistOutdated) {
- _this3.blacklistCurrentPlaylist({
- message: "Playlist no longer updating.",
- reason: "playlist-unchanged"
- });
- _this3.tech_.trigger("playliststuck");
- }
- });
- this.masterPlaylistLoader_.on("renditiondisabled", function() {
- _this3.tech_.trigger({
- type: "usage",
- name: "vhs-rendition-disabled"
- });
- _this3.tech_.trigger({
- type: "usage",
- name: "hls-rendition-disabled"
- });
- });
- this.masterPlaylistLoader_.on("renditionenabled", function() {
- _this3.tech_.trigger({
- type: "usage",
- name: "vhs-rendition-enabled"
- });
- _this3.tech_.trigger({
- type: "usage",
- name: "hls-rendition-enabled"
- });
- });
- };
- _proto.handleUpdatedMediaPlaylist = function handleUpdatedMediaPlaylist(updatedPlaylist) {
- if (this.useCueTags_) {
- this.updateAdCues_(updatedPlaylist);
- }
- this.mainSegmentLoader_.playlist(updatedPlaylist, this.requestOptions_);
- this.updateDuration(!updatedPlaylist.endList);
- if (!this.tech_.paused()) {
- this.mainSegmentLoader_.load();
- if (this.audioSegmentLoader_) {
- this.audioSegmentLoader_.load();
- }
- }
- };
- _proto.triggerPresenceUsage_ = function triggerPresenceUsage_(master, media) {
- var mediaGroups = master.mediaGroups || {};
- var defaultDemuxed = true;
- var audioGroupKeys = Object.keys(mediaGroups.AUDIO);
- for (var mediaGroup in mediaGroups.AUDIO) {
- for (var label2 in mediaGroups.AUDIO[mediaGroup]) {
- var properties = mediaGroups.AUDIO[mediaGroup][label2];
- if (!properties.uri) {
- defaultDemuxed = false;
- }
- }
- }
- if (defaultDemuxed) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-demuxed"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-demuxed"
- });
- }
- if (Object.keys(mediaGroups.SUBTITLES).length) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-webvtt"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-webvtt"
- });
- }
- if (Vhs$1.Playlist.isAes(media)) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-aes"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-aes"
- });
- }
- if (audioGroupKeys.length && Object.keys(mediaGroups.AUDIO[audioGroupKeys[0]]).length > 1) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-alternate-audio"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-alternate-audio"
- });
- }
- if (this.useCueTags_) {
- this.tech_.trigger({
- type: "usage",
- name: "vhs-playlist-cue-tags"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-playlist-cue-tags"
- });
- }
- };
- _proto.shouldSwitchToMedia_ = function shouldSwitchToMedia_(nextPlaylist) {
- var currentPlaylist = this.masterPlaylistLoader_.media() || this.masterPlaylistLoader_.pendingMedia_;
- var currentTime = this.tech_.currentTime();
- var bufferLowWaterLine = this.bufferLowWaterLine();
- var bufferHighWaterLine = this.bufferHighWaterLine();
- var buffered = this.tech_.buffered();
- return shouldSwitchToMedia({
- buffered,
- currentTime,
- currentPlaylist,
- nextPlaylist,
- bufferLowWaterLine,
- bufferHighWaterLine,
- duration: this.duration(),
- experimentalBufferBasedABR: this.experimentalBufferBasedABR,
- log: this.logger_
- });
- };
- _proto.setupSegmentLoaderListeners_ = function setupSegmentLoaderListeners_() {
- var _this4 = this;
- this.mainSegmentLoader_.on("bandwidthupdate", function() {
- _this4.checkABR_("bandwidthupdate");
- _this4.tech_.trigger("bandwidthupdate");
- });
- this.mainSegmentLoader_.on("timeout", function() {
- if (_this4.experimentalBufferBasedABR) {
- _this4.mainSegmentLoader_.load();
- }
- });
- if (!this.experimentalBufferBasedABR) {
- this.mainSegmentLoader_.on("progress", function() {
- _this4.trigger("progress");
- });
- }
- this.mainSegmentLoader_.on("error", function() {
- _this4.blacklistCurrentPlaylist(_this4.mainSegmentLoader_.error());
- });
- this.mainSegmentLoader_.on("appenderror", function() {
- _this4.error = _this4.mainSegmentLoader_.error_;
- _this4.trigger("error");
- });
- this.mainSegmentLoader_.on("syncinfoupdate", function() {
- _this4.onSyncInfoUpdate_();
- });
- this.mainSegmentLoader_.on("timestampoffset", function() {
- _this4.tech_.trigger({
- type: "usage",
- name: "vhs-timestamp-offset"
- });
- _this4.tech_.trigger({
- type: "usage",
- name: "hls-timestamp-offset"
- });
- });
- this.audioSegmentLoader_.on("syncinfoupdate", function() {
- _this4.onSyncInfoUpdate_();
- });
- this.audioSegmentLoader_.on("appenderror", function() {
- _this4.error = _this4.audioSegmentLoader_.error_;
- _this4.trigger("error");
- });
- this.mainSegmentLoader_.on("ended", function() {
- _this4.logger_("main segment loader ended");
- _this4.onEndOfStream();
- });
- this.mainSegmentLoader_.on("earlyabort", function(event2) {
- if (_this4.experimentalBufferBasedABR) {
- return;
- }
- _this4.delegateLoaders_("all", ["abort"]);
- _this4.blacklistCurrentPlaylist({
- message: "Aborted early because there isn't enough bandwidth to complete the request without rebuffering."
- }, ABORT_EARLY_BLACKLIST_SECONDS);
- });
- var updateCodecs = function updateCodecs2() {
- if (!_this4.sourceUpdater_.hasCreatedSourceBuffers()) {
- return _this4.tryToCreateSourceBuffers_();
- }
- var codecs = _this4.getCodecsOrExclude_();
- if (!codecs) {
- return;
- }
- _this4.sourceUpdater_.addOrChangeSourceBuffers(codecs);
- };
- this.mainSegmentLoader_.on("trackinfo", updateCodecs);
- this.audioSegmentLoader_.on("trackinfo", updateCodecs);
- this.mainSegmentLoader_.on("fmp4", function() {
- if (!_this4.triggeredFmp4Usage) {
- _this4.tech_.trigger({
- type: "usage",
- name: "vhs-fmp4"
- });
- _this4.tech_.trigger({
- type: "usage",
- name: "hls-fmp4"
- });
- _this4.triggeredFmp4Usage = true;
- }
- });
- this.audioSegmentLoader_.on("fmp4", function() {
- if (!_this4.triggeredFmp4Usage) {
- _this4.tech_.trigger({
- type: "usage",
- name: "vhs-fmp4"
- });
- _this4.tech_.trigger({
- type: "usage",
- name: "hls-fmp4"
- });
- _this4.triggeredFmp4Usage = true;
- }
- });
- this.audioSegmentLoader_.on("ended", function() {
- _this4.logger_("audioSegmentLoader ended");
- _this4.onEndOfStream();
- });
- };
- _proto.mediaSecondsLoaded_ = function mediaSecondsLoaded_() {
- return Math.max(this.audioSegmentLoader_.mediaSecondsLoaded + this.mainSegmentLoader_.mediaSecondsLoaded);
- };
- _proto.load = function load() {
- this.mainSegmentLoader_.load();
- if (this.mediaTypes_.AUDIO.activePlaylistLoader) {
- this.audioSegmentLoader_.load();
- }
- if (this.mediaTypes_.SUBTITLES.activePlaylistLoader) {
- this.subtitleSegmentLoader_.load();
- }
- };
- _proto.smoothQualityChange_ = function smoothQualityChange_(media) {
- if (media === void 0) {
- media = this.selectPlaylist();
- }
- this.fastQualityChange_(media);
- };
- _proto.fastQualityChange_ = function fastQualityChange_(media) {
- var _this5 = this;
- if (media === void 0) {
- media = this.selectPlaylist();
- }
- if (media === this.masterPlaylistLoader_.media()) {
- this.logger_("skipping fastQualityChange because new media is same as old");
- return;
- }
- this.switchMedia_(media, "fast-quality");
- this.mainSegmentLoader_.resetEverything(function() {
- if (videojs.browser.IE_VERSION || videojs.browser.IS_EDGE) {
- _this5.tech_.setCurrentTime(_this5.tech_.currentTime() + 0.04);
- } else {
- _this5.tech_.setCurrentTime(_this5.tech_.currentTime());
- }
- });
- };
- _proto.play = function play() {
- if (this.setupFirstPlay()) {
- return;
- }
- if (this.tech_.ended()) {
- this.tech_.setCurrentTime(0);
- }
- if (this.hasPlayed_) {
- this.load();
- }
- var seekable3 = this.tech_.seekable();
- if (this.tech_.duration() === Infinity) {
- if (this.tech_.currentTime() < seekable3.start(0)) {
- return this.tech_.setCurrentTime(seekable3.end(seekable3.length - 1));
- }
- }
- };
- _proto.setupFirstPlay = function setupFirstPlay() {
- var _this6 = this;
- var media = this.masterPlaylistLoader_.media();
- if (!media || this.tech_.paused() || this.hasPlayed_) {
- return false;
- }
- if (!media.endList) {
- var seekable3 = this.seekable();
- if (!seekable3.length) {
- return false;
- }
- if (videojs.browser.IE_VERSION && this.tech_.readyState() === 0) {
- this.tech_.one("loadedmetadata", function() {
- _this6.trigger("firstplay");
- _this6.tech_.setCurrentTime(seekable3.end(0));
- _this6.hasPlayed_ = true;
- });
- return false;
- }
- this.trigger("firstplay");
- this.tech_.setCurrentTime(seekable3.end(0));
- }
- this.hasPlayed_ = true;
- this.load();
- return true;
- };
- _proto.handleSourceOpen_ = function handleSourceOpen_() {
- this.tryToCreateSourceBuffers_();
- if (this.tech_.autoplay()) {
- var playPromise = this.tech_.play();
- if (typeof playPromise !== "undefined" && typeof playPromise.then === "function") {
- playPromise.then(null, function(e) {
- });
- }
- }
- this.trigger("sourceopen");
- };
- _proto.handleSourceEnded_ = function handleSourceEnded_() {
- if (!this.inbandTextTracks_.metadataTrack_) {
- return;
- }
- var cues = this.inbandTextTracks_.metadataTrack_.cues;
- if (!cues || !cues.length) {
- return;
- }
- var duration5 = this.duration();
- cues[cues.length - 1].endTime = isNaN(duration5) || Math.abs(duration5) === Infinity ? Number.MAX_VALUE : duration5;
- };
- _proto.handleDurationChange_ = function handleDurationChange_() {
- this.tech_.trigger("durationchange");
- };
- _proto.onEndOfStream = function onEndOfStream() {
- var isEndOfStream = this.mainSegmentLoader_.ended_;
- if (this.mediaTypes_.AUDIO.activePlaylistLoader) {
- var mainMediaInfo = this.mainSegmentLoader_.getCurrentMediaInfo_();
- if (!mainMediaInfo || mainMediaInfo.hasVideo) {
- isEndOfStream = isEndOfStream && this.audioSegmentLoader_.ended_;
- } else {
- isEndOfStream = this.audioSegmentLoader_.ended_;
- }
- }
- if (!isEndOfStream) {
- return;
- }
- this.stopABRTimer_();
- this.sourceUpdater_.endOfStream();
- };
- _proto.stuckAtPlaylistEnd_ = function stuckAtPlaylistEnd_(playlist) {
- var seekable3 = this.seekable();
- if (!seekable3.length) {
- return false;
- }
- var expired = this.syncController_.getExpiredTime(playlist, this.duration());
- if (expired === null) {
- return false;
- }
- var absolutePlaylistEnd = Vhs$1.Playlist.playlistEnd(playlist, expired);
- var currentTime = this.tech_.currentTime();
- var buffered = this.tech_.buffered();
- if (!buffered.length) {
- return absolutePlaylistEnd - currentTime <= SAFE_TIME_DELTA;
- }
- var bufferedEnd = buffered.end(buffered.length - 1);
- return bufferedEnd - currentTime <= SAFE_TIME_DELTA && absolutePlaylistEnd - bufferedEnd <= SAFE_TIME_DELTA;
- };
- _proto.blacklistCurrentPlaylist = function blacklistCurrentPlaylist(error, blacklistDuration) {
- if (error === void 0) {
- error = {};
- }
- var currentPlaylist = error.playlist || this.masterPlaylistLoader_.media();
- blacklistDuration = blacklistDuration || error.blacklistDuration || this.blacklistDuration;
- if (!currentPlaylist) {
- this.error = error;
- if (this.mediaSource.readyState !== "open") {
- this.trigger("error");
- } else {
- this.sourceUpdater_.endOfStream("network");
- }
- return;
- }
- currentPlaylist.playlistErrors_++;
- var playlists = this.masterPlaylistLoader_.master.playlists;
- var enabledPlaylists = playlists.filter(isEnabled);
- var isFinalRendition = enabledPlaylists.length === 1 && enabledPlaylists[0] === currentPlaylist;
- if (playlists.length === 1 && blacklistDuration !== Infinity) {
- videojs.log.warn("Problem encountered with playlist " + currentPlaylist.id + ". Trying again since it is the only playlist.");
- this.tech_.trigger("retryplaylist");
- return this.masterPlaylistLoader_.load(isFinalRendition);
- }
- if (isFinalRendition) {
- var reincluded = false;
- playlists.forEach(function(playlist) {
- if (playlist === currentPlaylist) {
- return;
- }
- var excludeUntil2 = playlist.excludeUntil;
- if (typeof excludeUntil2 !== "undefined" && excludeUntil2 !== Infinity) {
- reincluded = true;
- delete playlist.excludeUntil;
- }
- });
- if (reincluded) {
- videojs.log.warn("Removing other playlists from the exclusion list because the last rendition is about to be excluded.");
- this.tech_.trigger("retryplaylist");
- }
- }
- var excludeUntil;
- if (currentPlaylist.playlistErrors_ > this.maxPlaylistRetries) {
- excludeUntil = Infinity;
- } else {
- excludeUntil = Date.now() + blacklistDuration * 1e3;
- }
- currentPlaylist.excludeUntil = excludeUntil;
- if (error.reason) {
- currentPlaylist.lastExcludeReason_ = error.reason;
- }
- this.tech_.trigger("blacklistplaylist");
- this.tech_.trigger({
- type: "usage",
- name: "vhs-rendition-blacklisted"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-rendition-blacklisted"
- });
- var nextPlaylist = this.selectPlaylist();
- if (!nextPlaylist) {
- this.error = "Playback cannot continue. No available working or supported playlists.";
- this.trigger("error");
- return;
- }
- var logFn2 = error.internal ? this.logger_ : videojs.log.warn;
- var errorMessage = error.message ? " " + error.message : "";
- logFn2((error.internal ? "Internal problem" : "Problem") + " encountered with playlist " + currentPlaylist.id + "." + (errorMessage + " Switching to playlist " + nextPlaylist.id + "."));
- if (nextPlaylist.attributes.AUDIO !== currentPlaylist.attributes.AUDIO) {
- this.delegateLoaders_("audio", ["abort", "pause"]);
- }
- if (nextPlaylist.attributes.SUBTITLES !== currentPlaylist.attributes.SUBTITLES) {
- this.delegateLoaders_("subtitle", ["abort", "pause"]);
- }
- this.delegateLoaders_("main", ["abort", "pause"]);
- var delayDuration = nextPlaylist.targetDuration / 2 * 1e3 || 5 * 1e3;
- var shouldDelay = typeof nextPlaylist.lastRequest === "number" && Date.now() - nextPlaylist.lastRequest <= delayDuration;
- return this.switchMedia_(nextPlaylist, "exclude", isFinalRendition || shouldDelay);
- };
- _proto.pauseLoading = function pauseLoading() {
- this.delegateLoaders_("all", ["abort", "pause"]);
- this.stopABRTimer_();
- };
- _proto.delegateLoaders_ = function delegateLoaders_(filter, fnNames) {
- var _this7 = this;
- var loaders = [];
- var dontFilterPlaylist = filter === "all";
- if (dontFilterPlaylist || filter === "main") {
- loaders.push(this.masterPlaylistLoader_);
- }
- var mediaTypes2 = [];
- if (dontFilterPlaylist || filter === "audio") {
- mediaTypes2.push("AUDIO");
- }
- if (dontFilterPlaylist || filter === "subtitle") {
- mediaTypes2.push("CLOSED-CAPTIONS");
- mediaTypes2.push("SUBTITLES");
- }
- mediaTypes2.forEach(function(mediaType) {
- var loader = _this7.mediaTypes_[mediaType] && _this7.mediaTypes_[mediaType].activePlaylistLoader;
- if (loader) {
- loaders.push(loader);
- }
- });
- ["main", "audio", "subtitle"].forEach(function(name) {
- var loader = _this7[name + "SegmentLoader_"];
- if (loader && (filter === name || filter === "all")) {
- loaders.push(loader);
- }
- });
- loaders.forEach(function(loader) {
- return fnNames.forEach(function(fnName) {
- if (typeof loader[fnName] === "function") {
- loader[fnName]();
- }
- });
- });
- };
- _proto.setCurrentTime = function setCurrentTime(currentTime) {
- var buffered = findRange(this.tech_.buffered(), currentTime);
- if (!(this.masterPlaylistLoader_ && this.masterPlaylistLoader_.media())) {
- return 0;
- }
- if (!this.masterPlaylistLoader_.media().segments) {
- return 0;
- }
- if (buffered && buffered.length) {
- return currentTime;
- }
- this.mainSegmentLoader_.resetEverything();
- this.mainSegmentLoader_.abort();
- if (this.mediaTypes_.AUDIO.activePlaylistLoader) {
- this.audioSegmentLoader_.resetEverything();
- this.audioSegmentLoader_.abort();
- }
- if (this.mediaTypes_.SUBTITLES.activePlaylistLoader) {
- this.subtitleSegmentLoader_.resetEverything();
- this.subtitleSegmentLoader_.abort();
- }
- this.load();
- };
- _proto.duration = function duration5() {
- if (!this.masterPlaylistLoader_) {
- return 0;
- }
- var media = this.masterPlaylistLoader_.media();
- if (!media) {
- return 0;
- }
- if (!media.endList) {
- return Infinity;
- }
- if (this.mediaSource) {
- return this.mediaSource.duration;
- }
- return Vhs$1.Playlist.duration(media);
- };
- _proto.seekable = function seekable3() {
- return this.seekable_;
- };
- _proto.onSyncInfoUpdate_ = function onSyncInfoUpdate_() {
- var audioSeekable;
- if (!this.masterPlaylistLoader_) {
- return;
- }
- var media = this.masterPlaylistLoader_.media();
- if (!media) {
- return;
- }
- var expired = this.syncController_.getExpiredTime(media, this.duration());
- if (expired === null) {
- return;
- }
- var master = this.masterPlaylistLoader_.master;
- var mainSeekable = Vhs$1.Playlist.seekable(media, expired, Vhs$1.Playlist.liveEdgeDelay(master, media));
- if (mainSeekable.length === 0) {
- return;
- }
- if (this.mediaTypes_.AUDIO.activePlaylistLoader) {
- media = this.mediaTypes_.AUDIO.activePlaylistLoader.media();
- expired = this.syncController_.getExpiredTime(media, this.duration());
- if (expired === null) {
- return;
- }
- audioSeekable = Vhs$1.Playlist.seekable(media, expired, Vhs$1.Playlist.liveEdgeDelay(master, media));
- if (audioSeekable.length === 0) {
- return;
- }
- }
- var oldEnd;
- var oldStart;
- if (this.seekable_ && this.seekable_.length) {
- oldEnd = this.seekable_.end(0);
- oldStart = this.seekable_.start(0);
- }
- if (!audioSeekable) {
- this.seekable_ = mainSeekable;
- } else if (audioSeekable.start(0) > mainSeekable.end(0) || mainSeekable.start(0) > audioSeekable.end(0)) {
- this.seekable_ = mainSeekable;
- } else {
- this.seekable_ = videojs.createTimeRanges([[audioSeekable.start(0) > mainSeekable.start(0) ? audioSeekable.start(0) : mainSeekable.start(0), audioSeekable.end(0) < mainSeekable.end(0) ? audioSeekable.end(0) : mainSeekable.end(0)]]);
- }
- if (this.seekable_ && this.seekable_.length) {
- if (this.seekable_.end(0) === oldEnd && this.seekable_.start(0) === oldStart) {
- return;
- }
- }
- this.logger_("seekable updated [" + printableRange(this.seekable_) + "]");
- this.tech_.trigger("seekablechanged");
- };
- _proto.updateDuration = function updateDuration(isLive) {
- if (this.updateDuration_) {
- this.mediaSource.removeEventListener("sourceopen", this.updateDuration_);
- this.updateDuration_ = null;
- }
- if (this.mediaSource.readyState !== "open") {
- this.updateDuration_ = this.updateDuration.bind(this, isLive);
- this.mediaSource.addEventListener("sourceopen", this.updateDuration_);
- return;
- }
- if (isLive) {
- var seekable3 = this.seekable();
- if (!seekable3.length) {
- return;
- }
- if (isNaN(this.mediaSource.duration) || this.mediaSource.duration < seekable3.end(seekable3.length - 1)) {
- this.sourceUpdater_.setDuration(seekable3.end(seekable3.length - 1));
- }
- return;
- }
- var buffered = this.tech_.buffered();
- var duration5 = Vhs$1.Playlist.duration(this.masterPlaylistLoader_.media());
- if (buffered.length > 0) {
- duration5 = Math.max(duration5, buffered.end(buffered.length - 1));
- }
- if (this.mediaSource.duration !== duration5) {
- this.sourceUpdater_.setDuration(duration5);
- }
- };
- _proto.dispose = function dispose() {
- var _this8 = this;
- this.trigger("dispose");
- this.decrypter_.terminate();
- this.masterPlaylistLoader_.dispose();
- this.mainSegmentLoader_.dispose();
- if (this.loadOnPlay_) {
- this.tech_.off("play", this.loadOnPlay_);
- }
- ["AUDIO", "SUBTITLES"].forEach(function(type2) {
- var groups = _this8.mediaTypes_[type2].groups;
- for (var id in groups) {
- groups[id].forEach(function(group) {
- if (group.playlistLoader) {
- group.playlistLoader.dispose();
- }
- });
- }
- });
- this.audioSegmentLoader_.dispose();
- this.subtitleSegmentLoader_.dispose();
- this.sourceUpdater_.dispose();
- this.timelineChangeController_.dispose();
- this.stopABRTimer_();
- if (this.updateDuration_) {
- this.mediaSource.removeEventListener("sourceopen", this.updateDuration_);
- }
- this.mediaSource.removeEventListener("durationchange", this.handleDurationChange_);
- this.mediaSource.removeEventListener("sourceopen", this.handleSourceOpen_);
- this.mediaSource.removeEventListener("sourceended", this.handleSourceEnded_);
- this.off();
- };
- _proto.master = function master() {
- return this.masterPlaylistLoader_.master;
- };
- _proto.media = function media() {
- return this.masterPlaylistLoader_.media() || this.initialMedia_;
- };
- _proto.areMediaTypesKnown_ = function areMediaTypesKnown_() {
- var usingAudioLoader = !!this.mediaTypes_.AUDIO.activePlaylistLoader;
- var hasMainMediaInfo = !!this.mainSegmentLoader_.getCurrentMediaInfo_();
- var hasAudioMediaInfo = !usingAudioLoader ? true : !!this.audioSegmentLoader_.getCurrentMediaInfo_();
- if (!hasMainMediaInfo || !hasAudioMediaInfo) {
- return false;
- }
- return true;
- };
- _proto.getCodecsOrExclude_ = function getCodecsOrExclude_() {
- var _this9 = this;
- var media = {
- main: this.mainSegmentLoader_.getCurrentMediaInfo_() || {},
- audio: this.audioSegmentLoader_.getCurrentMediaInfo_() || {}
- };
- var playlist = this.mainSegmentLoader_.getPendingSegmentPlaylist() || this.media();
- media.video = media.main;
- var playlistCodecs = codecsForPlaylist(this.master(), playlist);
- var codecs = {};
- var usingAudioLoader = !!this.mediaTypes_.AUDIO.activePlaylistLoader;
- if (media.main.hasVideo) {
- codecs.video = playlistCodecs.video || media.main.videoCodec || DEFAULT_VIDEO_CODEC;
- }
- if (media.main.isMuxed) {
- codecs.video += "," + (playlistCodecs.audio || media.main.audioCodec || DEFAULT_AUDIO_CODEC);
- }
- if (media.main.hasAudio && !media.main.isMuxed || media.audio.hasAudio || usingAudioLoader) {
- codecs.audio = playlistCodecs.audio || media.main.audioCodec || media.audio.audioCodec || DEFAULT_AUDIO_CODEC;
- media.audio.isFmp4 = media.main.hasAudio && !media.main.isMuxed ? media.main.isFmp4 : media.audio.isFmp4;
- }
- if (!codecs.audio && !codecs.video) {
- this.blacklistCurrentPlaylist({
- playlist,
- message: "Could not determine codecs for playlist.",
- blacklistDuration: Infinity
- });
- return;
- }
- var supportFunction = function supportFunction2(isFmp4, codec) {
- return isFmp4 ? browserSupportsCodec2(codec) : muxerSupportsCodec2(codec);
- };
- var unsupportedCodecs = {};
- var unsupportedAudio;
- ["video", "audio"].forEach(function(type2) {
- if (codecs.hasOwnProperty(type2) && !supportFunction(media[type2].isFmp4, codecs[type2])) {
- var supporter = media[type2].isFmp4 ? "browser" : "muxer";
- unsupportedCodecs[supporter] = unsupportedCodecs[supporter] || [];
- unsupportedCodecs[supporter].push(codecs[type2]);
- if (type2 === "audio") {
- unsupportedAudio = supporter;
- }
- }
- });
- if (usingAudioLoader && unsupportedAudio && playlist.attributes.AUDIO) {
- var audioGroup = playlist.attributes.AUDIO;
- this.master().playlists.forEach(function(variant) {
- var variantAudioGroup = variant.attributes && variant.attributes.AUDIO;
- if (variantAudioGroup === audioGroup && variant !== playlist) {
- variant.excludeUntil = Infinity;
- }
- });
- this.logger_("excluding audio group " + audioGroup + " as " + unsupportedAudio + ' does not support codec(s): "' + codecs.audio + '"');
- }
- if (Object.keys(unsupportedCodecs).length) {
- var message = Object.keys(unsupportedCodecs).reduce(function(acc, supporter) {
- if (acc) {
- acc += ", ";
- }
- acc += supporter + ' does not support codec(s): "' + unsupportedCodecs[supporter].join(",") + '"';
- return acc;
- }, "") + ".";
- this.blacklistCurrentPlaylist({
- playlist,
- internal: true,
- message,
- blacklistDuration: Infinity
- });
- return;
- }
- if (this.sourceUpdater_.hasCreatedSourceBuffers() && !this.sourceUpdater_.canChangeType()) {
- var switchMessages = [];
- ["video", "audio"].forEach(function(type2) {
- var newCodec = (parseCodecs2(_this9.sourceUpdater_.codecs[type2] || "")[0] || {}).type;
- var oldCodec = (parseCodecs2(codecs[type2] || "")[0] || {}).type;
- if (newCodec && oldCodec && newCodec.toLowerCase() !== oldCodec.toLowerCase()) {
- switchMessages.push('"' + _this9.sourceUpdater_.codecs[type2] + '" -> "' + codecs[type2] + '"');
- }
- });
- if (switchMessages.length) {
- this.blacklistCurrentPlaylist({
- playlist,
- message: "Codec switching not supported: " + switchMessages.join(", ") + ".",
- blacklistDuration: Infinity,
- internal: true
- });
- return;
- }
- }
- return codecs;
- };
- _proto.tryToCreateSourceBuffers_ = function tryToCreateSourceBuffers_() {
- if (this.mediaSource.readyState !== "open" || this.sourceUpdater_.hasCreatedSourceBuffers()) {
- return;
- }
- if (!this.areMediaTypesKnown_()) {
- return;
- }
- var codecs = this.getCodecsOrExclude_();
- if (!codecs) {
- return;
- }
- this.sourceUpdater_.createSourceBuffers(codecs);
- var codecString = [codecs.video, codecs.audio].filter(Boolean).join(",");
- this.excludeIncompatibleVariants_(codecString);
- };
- _proto.excludeUnsupportedVariants_ = function excludeUnsupportedVariants_() {
- var _this10 = this;
- var playlists = this.master().playlists;
- var ids = [];
- Object.keys(playlists).forEach(function(key) {
- var variant = playlists[key];
- if (ids.indexOf(variant.id) !== -1) {
- return;
- }
- ids.push(variant.id);
- var codecs = codecsForPlaylist(_this10.master, variant);
- var unsupported = [];
- if (codecs.audio && !muxerSupportsCodec2(codecs.audio) && !browserSupportsCodec2(codecs.audio)) {
- unsupported.push("audio codec " + codecs.audio);
- }
- if (codecs.video && !muxerSupportsCodec2(codecs.video) && !browserSupportsCodec2(codecs.video)) {
- unsupported.push("video codec " + codecs.video);
- }
- if (codecs.text && codecs.text === "stpp.ttml.im1t") {
- unsupported.push("text codec " + codecs.text);
- }
- if (unsupported.length) {
- variant.excludeUntil = Infinity;
- _this10.logger_("excluding " + variant.id + " for unsupported: " + unsupported.join(", "));
- }
- });
- };
- _proto.excludeIncompatibleVariants_ = function excludeIncompatibleVariants_(codecString) {
- var _this11 = this;
- var ids = [];
- var playlists = this.master().playlists;
- var codecs = unwrapCodecList(parseCodecs2(codecString));
- var codecCount_ = codecCount(codecs);
- var videoDetails = codecs.video && parseCodecs2(codecs.video)[0] || null;
- var audioDetails = codecs.audio && parseCodecs2(codecs.audio)[0] || null;
- Object.keys(playlists).forEach(function(key) {
- var variant = playlists[key];
- if (ids.indexOf(variant.id) !== -1 || variant.excludeUntil === Infinity) {
- return;
- }
- ids.push(variant.id);
- var blacklistReasons = [];
- var variantCodecs = codecsForPlaylist(_this11.masterPlaylistLoader_.master, variant);
- var variantCodecCount = codecCount(variantCodecs);
- if (!variantCodecs.audio && !variantCodecs.video) {
- return;
- }
- if (variantCodecCount !== codecCount_) {
- blacklistReasons.push('codec count "' + variantCodecCount + '" !== "' + codecCount_ + '"');
- }
- if (!_this11.sourceUpdater_.canChangeType()) {
- var variantVideoDetails = variantCodecs.video && parseCodecs2(variantCodecs.video)[0] || null;
- var variantAudioDetails = variantCodecs.audio && parseCodecs2(variantCodecs.audio)[0] || null;
- if (variantVideoDetails && videoDetails && variantVideoDetails.type.toLowerCase() !== videoDetails.type.toLowerCase()) {
- blacklistReasons.push('video codec "' + variantVideoDetails.type + '" !== "' + videoDetails.type + '"');
- }
- if (variantAudioDetails && audioDetails && variantAudioDetails.type.toLowerCase() !== audioDetails.type.toLowerCase()) {
- blacklistReasons.push('audio codec "' + variantAudioDetails.type + '" !== "' + audioDetails.type + '"');
- }
- }
- if (blacklistReasons.length) {
- variant.excludeUntil = Infinity;
- _this11.logger_("blacklisting " + variant.id + ": " + blacklistReasons.join(" && "));
- }
- });
- };
- _proto.updateAdCues_ = function updateAdCues_(media) {
- var offset = 0;
- var seekable3 = this.seekable();
- if (seekable3.length) {
- offset = seekable3.start(0);
- }
- updateAdCues(media, this.cueTagsTrack_, offset);
- };
- _proto.goalBufferLength = function goalBufferLength() {
- var currentTime = this.tech_.currentTime();
- var initial = Config.GOAL_BUFFER_LENGTH;
- var rate = Config.GOAL_BUFFER_LENGTH_RATE;
- var max2 = Math.max(initial, Config.MAX_GOAL_BUFFER_LENGTH);
- return Math.min(initial + currentTime * rate, max2);
- };
- _proto.bufferLowWaterLine = function bufferLowWaterLine() {
- var currentTime = this.tech_.currentTime();
- var initial = Config.BUFFER_LOW_WATER_LINE;
- var rate = Config.BUFFER_LOW_WATER_LINE_RATE;
- var max2 = Math.max(initial, Config.MAX_BUFFER_LOW_WATER_LINE);
- var newMax = Math.max(initial, Config.EXPERIMENTAL_MAX_BUFFER_LOW_WATER_LINE);
- return Math.min(initial + currentTime * rate, this.experimentalBufferBasedABR ? newMax : max2);
- };
- _proto.bufferHighWaterLine = function bufferHighWaterLine() {
- return Config.BUFFER_HIGH_WATER_LINE;
- };
- return MasterPlaylistController2;
- }(videojs.EventTarget);
- var enableFunction = function enableFunction2(loader, playlistID, changePlaylistFn) {
- return function(enable) {
- var playlist = loader.master.playlists[playlistID];
- var incompatible = isIncompatible(playlist);
- var currentlyEnabled = isEnabled(playlist);
- if (typeof enable === "undefined") {
- return currentlyEnabled;
- }
- if (enable) {
- delete playlist.disabled;
- } else {
- playlist.disabled = true;
- }
- if (enable !== currentlyEnabled && !incompatible) {
- changePlaylistFn();
- if (enable) {
- loader.trigger("renditionenabled");
- } else {
- loader.trigger("renditiondisabled");
- }
- }
- return enable;
- };
- };
- var Representation = function Representation2(vhsHandler, playlist, id) {
- var mpc = vhsHandler.masterPlaylistController_, smoothQualityChange = vhsHandler.options_.smoothQualityChange;
- var changeType2 = smoothQualityChange ? "smooth" : "fast";
- var qualityChangeFunction = mpc[changeType2 + "QualityChange_"].bind(mpc);
- if (playlist.attributes) {
- var resolution = playlist.attributes.RESOLUTION;
- this.width = resolution && resolution.width;
- this.height = resolution && resolution.height;
- this.bandwidth = playlist.attributes.BANDWIDTH;
- this.frameRate = playlist.attributes["FRAME-RATE"];
- }
- this.codecs = codecsForPlaylist(mpc.master(), playlist);
- this.playlist = playlist;
- this.id = id;
- this.enabled = enableFunction(vhsHandler.playlists, playlist.id, qualityChangeFunction);
- };
- var renditionSelectionMixin = function renditionSelectionMixin2(vhsHandler) {
- vhsHandler.representations = function() {
- var master = vhsHandler.masterPlaylistController_.master();
- var playlists = isAudioOnly(master) ? vhsHandler.masterPlaylistController_.getAudioTrackPlaylists_() : master.playlists;
- if (!playlists) {
- return [];
- }
- return playlists.filter(function(media) {
- return !isIncompatible(media);
- }).map(function(e, i2) {
- return new Representation(vhsHandler, e, e.id);
- });
- };
- };
- var timerCancelEvents = ["seeking", "seeked", "pause", "playing", "error"];
- var PlaybackWatcher = /* @__PURE__ */ function() {
- function PlaybackWatcher2(options2) {
- var _this = this;
- this.masterPlaylistController_ = options2.masterPlaylistController;
- this.tech_ = options2.tech;
- this.seekable = options2.seekable;
- this.allowSeeksWithinUnsafeLiveWindow = options2.allowSeeksWithinUnsafeLiveWindow;
- this.liveRangeSafeTimeDelta = options2.liveRangeSafeTimeDelta;
- this.media = options2.media;
- this.consecutiveUpdates = 0;
- this.lastRecordedTime = null;
- this.timer_ = null;
- this.checkCurrentTimeTimeout_ = null;
- this.logger_ = logger("PlaybackWatcher");
- this.logger_("initialize");
- var playHandler = function playHandler2() {
- return _this.monitorCurrentTime_();
- };
- var canPlayHandler = function canPlayHandler2() {
- return _this.monitorCurrentTime_();
- };
- var waitingHandler = function waitingHandler2() {
- return _this.techWaiting_();
- };
- var cancelTimerHandler = function cancelTimerHandler2() {
- return _this.cancelTimer_();
- };
- var mpc = this.masterPlaylistController_;
- var loaderTypes = ["main", "subtitle", "audio"];
- var loaderChecks = {};
- loaderTypes.forEach(function(type2) {
- loaderChecks[type2] = {
- reset: function reset3() {
- return _this.resetSegmentDownloads_(type2);
- },
- updateend: function updateend() {
- return _this.checkSegmentDownloads_(type2);
- }
- };
- mpc[type2 + "SegmentLoader_"].on("appendsdone", loaderChecks[type2].updateend);
- mpc[type2 + "SegmentLoader_"].on("playlistupdate", loaderChecks[type2].reset);
- _this.tech_.on(["seeked", "seeking"], loaderChecks[type2].reset);
- });
- var setSeekingHandlers = function setSeekingHandlers2(fn2) {
- ["main", "audio"].forEach(function(type2) {
- mpc[type2 + "SegmentLoader_"][fn2]("appended", _this.seekingAppendCheck_);
- });
- };
- this.seekingAppendCheck_ = function() {
- if (_this.fixesBadSeeks_()) {
- _this.consecutiveUpdates = 0;
- _this.lastRecordedTime = _this.tech_.currentTime();
- setSeekingHandlers("off");
- }
- };
- this.clearSeekingAppendCheck_ = function() {
- return setSeekingHandlers("off");
- };
- this.watchForBadSeeking_ = function() {
- _this.clearSeekingAppendCheck_();
- setSeekingHandlers("on");
- };
- this.tech_.on("seeked", this.clearSeekingAppendCheck_);
- this.tech_.on("seeking", this.watchForBadSeeking_);
- this.tech_.on("waiting", waitingHandler);
- this.tech_.on(timerCancelEvents, cancelTimerHandler);
- this.tech_.on("canplay", canPlayHandler);
- this.tech_.one("play", playHandler);
- this.dispose = function() {
- _this.clearSeekingAppendCheck_();
- _this.logger_("dispose");
- _this.tech_.off("waiting", waitingHandler);
- _this.tech_.off(timerCancelEvents, cancelTimerHandler);
- _this.tech_.off("canplay", canPlayHandler);
- _this.tech_.off("play", playHandler);
- _this.tech_.off("seeking", _this.watchForBadSeeking_);
- _this.tech_.off("seeked", _this.clearSeekingAppendCheck_);
- loaderTypes.forEach(function(type2) {
- mpc[type2 + "SegmentLoader_"].off("appendsdone", loaderChecks[type2].updateend);
- mpc[type2 + "SegmentLoader_"].off("playlistupdate", loaderChecks[type2].reset);
- _this.tech_.off(["seeked", "seeking"], loaderChecks[type2].reset);
- });
- if (_this.checkCurrentTimeTimeout_) {
- window_1.clearTimeout(_this.checkCurrentTimeTimeout_);
- }
- _this.cancelTimer_();
- };
- }
- var _proto = PlaybackWatcher2.prototype;
- _proto.monitorCurrentTime_ = function monitorCurrentTime_() {
- this.checkCurrentTime_();
- if (this.checkCurrentTimeTimeout_) {
- window_1.clearTimeout(this.checkCurrentTimeTimeout_);
- }
- this.checkCurrentTimeTimeout_ = window_1.setTimeout(this.monitorCurrentTime_.bind(this), 250);
- };
- _proto.resetSegmentDownloads_ = function resetSegmentDownloads_(type2) {
- var loader = this.masterPlaylistController_[type2 + "SegmentLoader_"];
- if (this[type2 + "StalledDownloads_"] > 0) {
- this.logger_("resetting possible stalled download count for " + type2 + " loader");
- }
- this[type2 + "StalledDownloads_"] = 0;
- this[type2 + "Buffered_"] = loader.buffered_();
- };
- _proto.checkSegmentDownloads_ = function checkSegmentDownloads_(type2) {
- var mpc = this.masterPlaylistController_;
- var loader = mpc[type2 + "SegmentLoader_"];
- var buffered = loader.buffered_();
- var isBufferedDifferent = isRangeDifferent(this[type2 + "Buffered_"], buffered);
- this[type2 + "Buffered_"] = buffered;
- if (isBufferedDifferent) {
- this.resetSegmentDownloads_(type2);
- return;
- }
- this[type2 + "StalledDownloads_"]++;
- this.logger_("found #" + this[type2 + "StalledDownloads_"] + " " + type2 + " appends that did not increase buffer (possible stalled download)", {
- playlistId: loader.playlist_ && loader.playlist_.id,
- buffered: timeRangesToArray(buffered)
- });
- if (this[type2 + "StalledDownloads_"] < 10) {
- return;
- }
- this.logger_(type2 + " loader stalled download exclusion");
- this.resetSegmentDownloads_(type2);
- this.tech_.trigger({
- type: "usage",
- name: "vhs-" + type2 + "-download-exclusion"
- });
- if (type2 === "subtitle") {
- return;
- }
- mpc.blacklistCurrentPlaylist({
- message: "Excessive " + type2 + " segment downloading detected."
- }, Infinity);
- };
- _proto.checkCurrentTime_ = function checkCurrentTime_() {
- if (this.tech_.paused() || this.tech_.seeking()) {
- return;
- }
- var currentTime = this.tech_.currentTime();
- var buffered = this.tech_.buffered();
- if (this.lastRecordedTime === currentTime && (!buffered.length || currentTime + SAFE_TIME_DELTA >= buffered.end(buffered.length - 1))) {
- return this.techWaiting_();
- }
- if (this.consecutiveUpdates >= 5 && currentTime === this.lastRecordedTime) {
- this.consecutiveUpdates++;
- this.waiting_();
- } else if (currentTime === this.lastRecordedTime) {
- this.consecutiveUpdates++;
- } else {
- this.consecutiveUpdates = 0;
- this.lastRecordedTime = currentTime;
- }
- };
- _proto.cancelTimer_ = function cancelTimer_() {
- this.consecutiveUpdates = 0;
- if (this.timer_) {
- this.logger_("cancelTimer_");
- clearTimeout(this.timer_);
- }
- this.timer_ = null;
- };
- _proto.fixesBadSeeks_ = function fixesBadSeeks_() {
- var seeking = this.tech_.seeking();
- if (!seeking) {
- return false;
- }
- var seekable3 = this.seekable();
- var currentTime = this.tech_.currentTime();
- var isAfterSeekableRange = this.afterSeekableWindow_(seekable3, currentTime, this.media(), this.allowSeeksWithinUnsafeLiveWindow);
- var seekTo;
- if (isAfterSeekableRange) {
- var seekableEnd = seekable3.end(seekable3.length - 1);
- seekTo = seekableEnd;
- }
- if (this.beforeSeekableWindow_(seekable3, currentTime)) {
- var seekableStart = seekable3.start(0);
- seekTo = seekableStart + (seekableStart === seekable3.end(0) ? 0 : SAFE_TIME_DELTA);
- }
- if (typeof seekTo !== "undefined") {
- this.logger_("Trying to seek outside of seekable at time " + currentTime + " with " + ("seekable range " + printableRange(seekable3) + ". Seeking to ") + (seekTo + "."));
- this.tech_.setCurrentTime(seekTo);
- return true;
- }
- var sourceUpdater = this.masterPlaylistController_.sourceUpdater_;
- var buffered = this.tech_.buffered();
- var audioBuffered = sourceUpdater.audioBuffer ? sourceUpdater.audioBuffered() : null;
- var videoBuffered = sourceUpdater.videoBuffer ? sourceUpdater.videoBuffered() : null;
- var media = this.media();
- var minAppendedDuration = media.partTargetDuration ? media.partTargetDuration : (media.targetDuration - TIME_FUDGE_FACTOR) * 2;
- var bufferedToCheck = [audioBuffered, videoBuffered];
- for (var i2 = 0; i2 < bufferedToCheck.length; i2++) {
- if (!bufferedToCheck[i2]) {
- continue;
- }
- var timeAhead = timeAheadOf(bufferedToCheck[i2], currentTime);
- if (timeAhead < minAppendedDuration) {
- return false;
- }
- }
- var nextRange = findNextRange(buffered, currentTime);
- if (nextRange.length === 0) {
- return false;
- }
- seekTo = nextRange.start(0) + SAFE_TIME_DELTA;
- this.logger_("Buffered region starts (" + nextRange.start(0) + ") " + (" just beyond seek point (" + currentTime + "). Seeking to " + seekTo + "."));
- this.tech_.setCurrentTime(seekTo);
- return true;
- };
- _proto.waiting_ = function waiting_() {
- if (this.techWaiting_()) {
- return;
- }
- var currentTime = this.tech_.currentTime();
- var buffered = this.tech_.buffered();
- var currentRange = findRange(buffered, currentTime);
- if (currentRange.length && currentTime + 3 <= currentRange.end(0)) {
- this.cancelTimer_();
- this.tech_.setCurrentTime(currentTime);
- this.logger_("Stopped at " + currentTime + " while inside a buffered region " + ("[" + currentRange.start(0) + " -> " + currentRange.end(0) + "]. Attempting to resume ") + "playback by seeking to the current time.");
- this.tech_.trigger({
- type: "usage",
- name: "vhs-unknown-waiting"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-unknown-waiting"
- });
- return;
- }
- };
- _proto.techWaiting_ = function techWaiting_() {
- var seekable3 = this.seekable();
- var currentTime = this.tech_.currentTime();
- if (this.tech_.seeking() || this.timer_ !== null) {
- return true;
- }
- if (this.beforeSeekableWindow_(seekable3, currentTime)) {
- var livePoint = seekable3.end(seekable3.length - 1);
- this.logger_("Fell out of live window at time " + currentTime + ". Seeking to " + ("live point (seekable end) " + livePoint));
- this.cancelTimer_();
- this.tech_.setCurrentTime(livePoint);
- this.tech_.trigger({
- type: "usage",
- name: "vhs-live-resync"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-live-resync"
- });
- return true;
- }
- var sourceUpdater = this.tech_.vhs.masterPlaylistController_.sourceUpdater_;
- var buffered = this.tech_.buffered();
- var videoUnderflow = this.videoUnderflow_({
- audioBuffered: sourceUpdater.audioBuffered(),
- videoBuffered: sourceUpdater.videoBuffered(),
- currentTime
- });
- if (videoUnderflow) {
- this.cancelTimer_();
- this.tech_.setCurrentTime(currentTime);
- this.tech_.trigger({
- type: "usage",
- name: "vhs-video-underflow"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-video-underflow"
- });
- return true;
- }
- var nextRange = findNextRange(buffered, currentTime);
- if (nextRange.length > 0) {
- var difference = nextRange.start(0) - currentTime;
- this.logger_("Stopped at " + currentTime + ", setting timer for " + difference + ", seeking " + ("to " + nextRange.start(0)));
- this.cancelTimer_();
- this.timer_ = setTimeout(this.skipTheGap_.bind(this), difference * 1e3, currentTime);
- return true;
- }
- return false;
- };
- _proto.afterSeekableWindow_ = function afterSeekableWindow_(seekable3, currentTime, playlist, allowSeeksWithinUnsafeLiveWindow) {
- if (allowSeeksWithinUnsafeLiveWindow === void 0) {
- allowSeeksWithinUnsafeLiveWindow = false;
- }
- if (!seekable3.length) {
- return false;
- }
- var allowedEnd = seekable3.end(seekable3.length - 1) + SAFE_TIME_DELTA;
- var isLive = !playlist.endList;
- if (isLive && allowSeeksWithinUnsafeLiveWindow) {
- allowedEnd = seekable3.end(seekable3.length - 1) + playlist.targetDuration * 3;
- }
- if (currentTime > allowedEnd) {
- return true;
- }
- return false;
- };
- _proto.beforeSeekableWindow_ = function beforeSeekableWindow_(seekable3, currentTime) {
- if (seekable3.length && seekable3.start(0) > 0 && currentTime < seekable3.start(0) - this.liveRangeSafeTimeDelta) {
- return true;
- }
- return false;
- };
- _proto.videoUnderflow_ = function videoUnderflow_(_ref) {
- var videoBuffered = _ref.videoBuffered, audioBuffered = _ref.audioBuffered, currentTime = _ref.currentTime;
- if (!videoBuffered) {
- return;
- }
- var gap;
- if (videoBuffered.length && audioBuffered.length) {
- var lastVideoRange = findRange(videoBuffered, currentTime - 3);
- var videoRange = findRange(videoBuffered, currentTime);
- var audioRange = findRange(audioBuffered, currentTime);
- if (audioRange.length && !videoRange.length && lastVideoRange.length) {
- gap = {
- start: lastVideoRange.end(0),
- end: audioRange.end(0)
- };
- }
- } else {
- var nextRange = findNextRange(videoBuffered, currentTime);
- if (!nextRange.length) {
- gap = this.gapFromVideoUnderflow_(videoBuffered, currentTime);
- }
- }
- if (gap) {
- this.logger_("Encountered a gap in video from " + gap.start + " to " + gap.end + ". " + ("Seeking to current time " + currentTime));
- return true;
- }
- return false;
- };
- _proto.skipTheGap_ = function skipTheGap_(scheduledCurrentTime) {
- var buffered = this.tech_.buffered();
- var currentTime = this.tech_.currentTime();
- var nextRange = findNextRange(buffered, currentTime);
- this.cancelTimer_();
- if (nextRange.length === 0 || currentTime !== scheduledCurrentTime) {
- return;
- }
- this.logger_("skipTheGap_:", "currentTime:", currentTime, "scheduled currentTime:", scheduledCurrentTime, "nextRange start:", nextRange.start(0));
- this.tech_.setCurrentTime(nextRange.start(0) + TIME_FUDGE_FACTOR);
- this.tech_.trigger({
- type: "usage",
- name: "vhs-gap-skip"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-gap-skip"
- });
- };
- _proto.gapFromVideoUnderflow_ = function gapFromVideoUnderflow_(buffered, currentTime) {
- var gaps = findGaps(buffered);
- for (var i2 = 0; i2 < gaps.length; i2++) {
- var start2 = gaps.start(i2);
- var end = gaps.end(i2);
- if (currentTime - start2 < 4 && currentTime - start2 > 2) {
- return {
- start: start2,
- end
- };
- }
- }
- return null;
- };
- return PlaybackWatcher2;
- }();
- var defaultOptions = {
- errorInterval: 30,
- getSource: function getSource(next) {
- var tech = this.tech({
- IWillNotUseThisInPlugins: true
- });
- var sourceObj = tech.currentSource_ || this.currentSource();
- return next(sourceObj);
- }
- };
- var initPlugin = function initPlugin2(player, options2) {
- var lastCalled = 0;
- var seekTo = 0;
- var localOptions = videojs.mergeOptions(defaultOptions, options2);
- player.ready(function() {
- player.trigger({
- type: "usage",
- name: "vhs-error-reload-initialized"
- });
- player.trigger({
- type: "usage",
- name: "hls-error-reload-initialized"
- });
- });
- var loadedMetadataHandler = function loadedMetadataHandler2() {
- if (seekTo) {
- player.currentTime(seekTo);
- }
- };
- var setSource2 = function setSource3(sourceObj) {
- if (sourceObj === null || sourceObj === void 0) {
- return;
- }
- seekTo = player.duration() !== Infinity && player.currentTime() || 0;
- player.one("loadedmetadata", loadedMetadataHandler);
- player.src(sourceObj);
- player.trigger({
- type: "usage",
- name: "vhs-error-reload"
- });
- player.trigger({
- type: "usage",
- name: "hls-error-reload"
- });
- player.play();
- };
- var errorHandler = function errorHandler2() {
- if (Date.now() - lastCalled < localOptions.errorInterval * 1e3) {
- player.trigger({
- type: "usage",
- name: "vhs-error-reload-canceled"
- });
- player.trigger({
- type: "usage",
- name: "hls-error-reload-canceled"
- });
- return;
- }
- if (!localOptions.getSource || typeof localOptions.getSource !== "function") {
- videojs.log.error("ERROR: reloadSourceOnError - The option getSource must be a function!");
- return;
- }
- lastCalled = Date.now();
- return localOptions.getSource.call(player, setSource2);
- };
- var cleanupEvents = function cleanupEvents2() {
- player.off("loadedmetadata", loadedMetadataHandler);
- player.off("error", errorHandler);
- player.off("dispose", cleanupEvents2);
- };
- var reinitPlugin = function reinitPlugin2(newOptions) {
- cleanupEvents();
- initPlugin2(player, newOptions);
- };
- player.on("error", errorHandler);
- player.on("dispose", cleanupEvents);
- player.reloadSourceOnError = reinitPlugin;
- };
- var reloadSourceOnError = function reloadSourceOnError2(options2) {
- initPlugin(this, options2);
- };
- var version$4 = "2.16.2";
- var version$3 = "6.0.1";
- var version$2 = "0.22.1";
- var version$1$1 = "4.8.0";
- var version$6 = "3.1.3";
- var Vhs = {
- PlaylistLoader,
- Playlist,
- utils,
- STANDARD_PLAYLIST_SELECTOR: lastBandwidthSelector,
- INITIAL_PLAYLIST_SELECTOR: lowestBitrateCompatibleVariantSelector,
- lastBandwidthSelector,
- movingAverageBandwidthSelector,
- comparePlaylistBandwidth,
- comparePlaylistResolution,
- xhr: xhrFactory()
- };
- Object.keys(Config).forEach(function(prop) {
- Object.defineProperty(Vhs, prop, {
- get: function get7() {
- videojs.log.warn("using Vhs." + prop + " is UNSAFE be sure you know what you are doing");
- return Config[prop];
- },
- set: function set4(value) {
- videojs.log.warn("using Vhs." + prop + " is UNSAFE be sure you know what you are doing");
- if (typeof value !== "number" || value < 0) {
- videojs.log.warn("value of Vhs." + prop + " must be greater than or equal to 0");
- return;
- }
- Config[prop] = value;
- }
- });
- });
- var LOCAL_STORAGE_KEY = "videojs-vhs";
- var handleVhsMediaChange = function handleVhsMediaChange2(qualityLevels2, playlistLoader) {
- var newPlaylist = playlistLoader.media();
- var selectedIndex = -1;
- for (var i2 = 0; i2 < qualityLevels2.length; i2++) {
- if (qualityLevels2[i2].id === newPlaylist.id) {
- selectedIndex = i2;
- break;
- }
- }
- qualityLevels2.selectedIndex_ = selectedIndex;
- qualityLevels2.trigger({
- selectedIndex,
- type: "change"
- });
- };
- var handleVhsLoadedMetadata = function handleVhsLoadedMetadata2(qualityLevels2, vhs) {
- vhs.representations().forEach(function(rep2) {
- qualityLevels2.addQualityLevel(rep2);
- });
- handleVhsMediaChange(qualityLevels2, vhs.playlists);
- };
- Vhs.canPlaySource = function() {
- return videojs.log.warn("HLS is no longer a tech. Please remove it from your player's techOrder.");
- };
- var emeKeySystems = function emeKeySystems2(keySystemOptions, mainPlaylist, audioPlaylist) {
- if (!keySystemOptions) {
- return keySystemOptions;
- }
- var codecs = {};
- if (mainPlaylist && mainPlaylist.attributes && mainPlaylist.attributes.CODECS) {
- codecs = unwrapCodecList(parseCodecs2(mainPlaylist.attributes.CODECS));
- }
- if (audioPlaylist && audioPlaylist.attributes && audioPlaylist.attributes.CODECS) {
- codecs.audio = audioPlaylist.attributes.CODECS;
- }
- var videoContentType = getMimeForCodec2(codecs.video);
- var audioContentType = getMimeForCodec2(codecs.audio);
- var keySystemContentTypes = {};
- for (var keySystem in keySystemOptions) {
- keySystemContentTypes[keySystem] = {};
- if (audioContentType) {
- keySystemContentTypes[keySystem].audioContentType = audioContentType;
- }
- if (videoContentType) {
- keySystemContentTypes[keySystem].videoContentType = videoContentType;
- }
- if (mainPlaylist.contentProtection && mainPlaylist.contentProtection[keySystem] && mainPlaylist.contentProtection[keySystem].pssh) {
- keySystemContentTypes[keySystem].pssh = mainPlaylist.contentProtection[keySystem].pssh;
- }
- if (typeof keySystemOptions[keySystem] === "string") {
- keySystemContentTypes[keySystem].url = keySystemOptions[keySystem];
- }
- }
- return videojs.mergeOptions(keySystemOptions, keySystemContentTypes);
- };
- var getAllPsshKeySystemsOptions = function getAllPsshKeySystemsOptions2(playlists, keySystems) {
- return playlists.reduce(function(keySystemsArr, playlist) {
- if (!playlist.contentProtection) {
- return keySystemsArr;
- }
- var keySystemsOptions = keySystems.reduce(function(keySystemsObj, keySystem) {
- var keySystemOptions = playlist.contentProtection[keySystem];
- if (keySystemOptions && keySystemOptions.pssh) {
- keySystemsObj[keySystem] = {
- pssh: keySystemOptions.pssh
- };
- }
- return keySystemsObj;
- }, {});
- if (Object.keys(keySystemsOptions).length) {
- keySystemsArr.push(keySystemsOptions);
- }
- return keySystemsArr;
- }, []);
- };
- var waitForKeySessionCreation = function waitForKeySessionCreation2(_ref) {
- var player = _ref.player, sourceKeySystems = _ref.sourceKeySystems, audioMedia = _ref.audioMedia, mainPlaylists = _ref.mainPlaylists;
- if (!player.eme.initializeMediaKeys) {
- return Promise.resolve();
- }
- var playlists = audioMedia ? mainPlaylists.concat([audioMedia]) : mainPlaylists;
- var keySystemsOptionsArr = getAllPsshKeySystemsOptions(playlists, Object.keys(sourceKeySystems));
- var initializationFinishedPromises = [];
- var keySessionCreatedPromises = [];
- keySystemsOptionsArr.forEach(function(keySystemsOptions) {
- keySessionCreatedPromises.push(new Promise(function(resolve2, reject2) {
- player.tech_.one("keysessioncreated", resolve2);
- }));
- initializationFinishedPromises.push(new Promise(function(resolve2, reject2) {
- player.eme.initializeMediaKeys({
- keySystems: keySystemsOptions
- }, function(err) {
- if (err) {
- reject2(err);
- return;
- }
- resolve2();
- });
- }));
- });
- return Promise.race([
- Promise.all(initializationFinishedPromises),
- Promise.race(keySessionCreatedPromises)
- ]);
- };
- var setupEmeOptions = function setupEmeOptions2(_ref2) {
- var player = _ref2.player, sourceKeySystems = _ref2.sourceKeySystems, media = _ref2.media, audioMedia = _ref2.audioMedia;
- var sourceOptions = emeKeySystems(sourceKeySystems, media, audioMedia);
- if (!sourceOptions) {
- return false;
- }
- player.currentSource().keySystems = sourceOptions;
- if (sourceOptions && !player.eme) {
- videojs.log.warn("DRM encrypted source cannot be decrypted without a DRM plugin");
- return false;
- }
- return true;
- };
- var getVhsLocalStorage = function getVhsLocalStorage2() {
- if (!window_1.localStorage) {
- return null;
- }
- var storedObject = window_1.localStorage.getItem(LOCAL_STORAGE_KEY);
- if (!storedObject) {
- return null;
- }
- try {
- return JSON.parse(storedObject);
- } catch (e) {
- return null;
- }
- };
- var updateVhsLocalStorage = function updateVhsLocalStorage2(options2) {
- if (!window_1.localStorage) {
- return false;
- }
- var objectToStore = getVhsLocalStorage();
- objectToStore = objectToStore ? videojs.mergeOptions(objectToStore, options2) : options2;
- try {
- window_1.localStorage.setItem(LOCAL_STORAGE_KEY, JSON.stringify(objectToStore));
- } catch (e) {
- return false;
- }
- return objectToStore;
- };
- var expandDataUri = function expandDataUri2(dataUri) {
- if (dataUri.toLowerCase().indexOf("data:application/vnd.videojs.vhs+json,") === 0) {
- return JSON.parse(dataUri.substring(dataUri.indexOf(",") + 1));
- }
- return dataUri;
- };
- Vhs.supportsNativeHls = function() {
- if (!document_1 || !document_1.createElement) {
- return false;
- }
- var video = document_1.createElement("video");
- if (!videojs.getTech("Html5").isSupported()) {
- return false;
- }
- var canPlay = [
- "application/vnd.apple.mpegurl",
- "audio/mpegurl",
- "audio/x-mpegurl",
- "application/x-mpegurl",
- "video/x-mpegurl",
- "video/mpegurl",
- "application/mpegurl"
- ];
- return canPlay.some(function(canItPlay) {
- return /maybe|probably/i.test(video.canPlayType(canItPlay));
- });
- }();
- Vhs.supportsNativeDash = function() {
- if (!document_1 || !document_1.createElement || !videojs.getTech("Html5").isSupported()) {
- return false;
- }
- return /maybe|probably/i.test(document_1.createElement("video").canPlayType("application/dash+xml"));
- }();
- Vhs.supportsTypeNatively = function(type2) {
- if (type2 === "hls") {
- return Vhs.supportsNativeHls;
- }
- if (type2 === "dash") {
- return Vhs.supportsNativeDash;
- }
- return false;
- };
- Vhs.isSupported = function() {
- return videojs.log.warn("HLS is no longer a tech. Please remove it from your player's techOrder.");
- };
- var Component = videojs.getComponent("Component");
- var VhsHandler = /* @__PURE__ */ function(_Component) {
- _inheritsLoose(VhsHandler2, _Component);
- function VhsHandler2(source, tech, options2) {
- var _this;
- _this = _Component.call(this, tech, videojs.mergeOptions(options2.hls, options2.vhs)) || this;
- if (options2.hls && Object.keys(options2.hls).length) {
- videojs.log.warn("Using hls options is deprecated. Please rename `hls` to `vhs` in your options object.");
- }
- if (typeof options2.initialBandwidth === "number") {
- _this.options_.bandwidth = options2.initialBandwidth;
- }
- _this.logger_ = logger("VhsHandler");
- if (tech.options_ && tech.options_.playerId) {
- var _player = videojs(tech.options_.playerId);
- if (!_player.hasOwnProperty("hls")) {
- Object.defineProperty(_player, "hls", {
- get: function get7() {
- videojs.log.warn("player.hls is deprecated. Use player.tech().vhs instead.");
- tech.trigger({
- type: "usage",
- name: "hls-player-access"
- });
- return _assertThisInitialized(_this);
- },
- configurable: true
- });
- }
- if (!_player.hasOwnProperty("vhs")) {
- Object.defineProperty(_player, "vhs", {
- get: function get7() {
- videojs.log.warn("player.vhs is deprecated. Use player.tech().vhs instead.");
- tech.trigger({
- type: "usage",
- name: "vhs-player-access"
- });
- return _assertThisInitialized(_this);
- },
- configurable: true
- });
- }
- if (!_player.hasOwnProperty("dash")) {
- Object.defineProperty(_player, "dash", {
- get: function get7() {
- videojs.log.warn("player.dash is deprecated. Use player.tech().vhs instead.");
- return _assertThisInitialized(_this);
- },
- configurable: true
- });
- }
- _this.player_ = _player;
- }
- _this.tech_ = tech;
- _this.source_ = source;
- _this.stats = {};
- _this.ignoreNextSeekingEvent_ = false;
- _this.setOptions_();
- if (_this.options_.overrideNative && tech.overrideNativeAudioTracks && tech.overrideNativeVideoTracks) {
- tech.overrideNativeAudioTracks(true);
- tech.overrideNativeVideoTracks(true);
- } else if (_this.options_.overrideNative && (tech.featuresNativeVideoTracks || tech.featuresNativeAudioTracks)) {
- throw new Error("Overriding native HLS requires emulated tracks. See https://git.io/vMpjB");
- }
- _this.on(document_1, ["fullscreenchange", "webkitfullscreenchange", "mozfullscreenchange", "MSFullscreenChange"], function(event2) {
- var fullscreenElement = document_1.fullscreenElement || document_1.webkitFullscreenElement || document_1.mozFullScreenElement || document_1.msFullscreenElement;
- if (fullscreenElement && fullscreenElement.contains(_this.tech_.el())) {
- _this.masterPlaylistController_.fastQualityChange_();
- } else {
- _this.masterPlaylistController_.checkABR_();
- }
- });
- _this.on(_this.tech_, "seeking", function() {
- if (this.ignoreNextSeekingEvent_) {
- this.ignoreNextSeekingEvent_ = false;
- return;
- }
- this.setCurrentTime(this.tech_.currentTime());
- });
- _this.on(_this.tech_, "error", function() {
- if (this.tech_.error() && this.masterPlaylistController_) {
- this.masterPlaylistController_.pauseLoading();
- }
- });
- _this.on(_this.tech_, "play", _this.play);
- return _this;
- }
- var _proto = VhsHandler2.prototype;
- _proto.setOptions_ = function setOptions_() {
- var _this2 = this;
- this.options_.withCredentials = this.options_.withCredentials || false;
- this.options_.handleManifestRedirects = this.options_.handleManifestRedirects === false ? false : true;
- this.options_.limitRenditionByPlayerDimensions = this.options_.limitRenditionByPlayerDimensions === false ? false : true;
- this.options_.useDevicePixelRatio = this.options_.useDevicePixelRatio || false;
- this.options_.smoothQualityChange = this.options_.smoothQualityChange || false;
- this.options_.useBandwidthFromLocalStorage = typeof this.source_.useBandwidthFromLocalStorage !== "undefined" ? this.source_.useBandwidthFromLocalStorage : this.options_.useBandwidthFromLocalStorage || false;
- this.options_.useNetworkInformationApi = this.options_.useNetworkInformationApi || false;
- this.options_.useDtsForTimestampOffset = this.options_.useDtsForTimestampOffset || false;
- this.options_.customTagParsers = this.options_.customTagParsers || [];
- this.options_.customTagMappers = this.options_.customTagMappers || [];
- this.options_.cacheEncryptionKeys = this.options_.cacheEncryptionKeys || false;
- if (typeof this.options_.blacklistDuration !== "number") {
- this.options_.blacklistDuration = 5 * 60;
- }
- if (typeof this.options_.bandwidth !== "number") {
- if (this.options_.useBandwidthFromLocalStorage) {
- var storedObject = getVhsLocalStorage();
- if (storedObject && storedObject.bandwidth) {
- this.options_.bandwidth = storedObject.bandwidth;
- this.tech_.trigger({
- type: "usage",
- name: "vhs-bandwidth-from-local-storage"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-bandwidth-from-local-storage"
- });
- }
- if (storedObject && storedObject.throughput) {
- this.options_.throughput = storedObject.throughput;
- this.tech_.trigger({
- type: "usage",
- name: "vhs-throughput-from-local-storage"
- });
- this.tech_.trigger({
- type: "usage",
- name: "hls-throughput-from-local-storage"
- });
- }
- }
- }
- if (typeof this.options_.bandwidth !== "number") {
- this.options_.bandwidth = Config.INITIAL_BANDWIDTH;
- }
- this.options_.enableLowInitialPlaylist = this.options_.enableLowInitialPlaylist && this.options_.bandwidth === Config.INITIAL_BANDWIDTH;
- ["withCredentials", "useDevicePixelRatio", "limitRenditionByPlayerDimensions", "bandwidth", "smoothQualityChange", "customTagParsers", "customTagMappers", "handleManifestRedirects", "cacheEncryptionKeys", "playlistSelector", "initialPlaylistSelector", "experimentalBufferBasedABR", "liveRangeSafeTimeDelta", "experimentalLLHLS", "useNetworkInformationApi", "useDtsForTimestampOffset", "experimentalExactManifestTimings", "experimentalLeastPixelDiffSelector"].forEach(function(option) {
- if (typeof _this2.source_[option] !== "undefined") {
- _this2.options_[option] = _this2.source_[option];
- }
- });
- this.limitRenditionByPlayerDimensions = this.options_.limitRenditionByPlayerDimensions;
- this.useDevicePixelRatio = this.options_.useDevicePixelRatio;
- };
- _proto.src = function src(_src, type2) {
- var _this3 = this;
- if (!_src) {
- return;
- }
- this.setOptions_();
- this.options_.src = expandDataUri(this.source_.src);
- this.options_.tech = this.tech_;
- this.options_.externVhs = Vhs;
- this.options_.sourceType = simpleTypeFromSourceType2(type2);
- this.options_.seekTo = function(time) {
- _this3.tech_.setCurrentTime(time);
- };
- if (this.options_.smoothQualityChange) {
- videojs.log.warn("smoothQualityChange is deprecated and will be removed in the next major version");
- }
- this.masterPlaylistController_ = new MasterPlaylistController(this.options_);
- var playbackWatcherOptions = videojs.mergeOptions({
- liveRangeSafeTimeDelta: SAFE_TIME_DELTA
- }, this.options_, {
- seekable: function seekable3() {
- return _this3.seekable();
- },
- media: function media() {
- return _this3.masterPlaylistController_.media();
- },
- masterPlaylistController: this.masterPlaylistController_
- });
- this.playbackWatcher_ = new PlaybackWatcher(playbackWatcherOptions);
- this.masterPlaylistController_.on("error", function() {
- var player = videojs.players[_this3.tech_.options_.playerId];
- var error = _this3.masterPlaylistController_.error;
- if (typeof error === "object" && !error.code) {
- error.code = 3;
- } else if (typeof error === "string") {
- error = {
- message: error,
- code: 3
- };
- }
- player.error(error);
- });
- var defaultSelector = this.options_.experimentalBufferBasedABR ? Vhs.movingAverageBandwidthSelector(0.55) : Vhs.STANDARD_PLAYLIST_SELECTOR;
- this.masterPlaylistController_.selectPlaylist = this.selectPlaylist ? this.selectPlaylist.bind(this) : defaultSelector.bind(this);
- this.masterPlaylistController_.selectInitialPlaylist = Vhs.INITIAL_PLAYLIST_SELECTOR.bind(this);
- this.playlists = this.masterPlaylistController_.masterPlaylistLoader_;
- this.mediaSource = this.masterPlaylistController_.mediaSource;
- Object.defineProperties(this, {
- selectPlaylist: {
- get: function get7() {
- return this.masterPlaylistController_.selectPlaylist;
- },
- set: function set4(selectPlaylist) {
- this.masterPlaylistController_.selectPlaylist = selectPlaylist.bind(this);
- }
- },
- throughput: {
- get: function get7() {
- return this.masterPlaylistController_.mainSegmentLoader_.throughput.rate;
- },
- set: function set4(throughput) {
- this.masterPlaylistController_.mainSegmentLoader_.throughput.rate = throughput;
- this.masterPlaylistController_.mainSegmentLoader_.throughput.count = 1;
- }
- },
- bandwidth: {
- get: function get7() {
- var playerBandwidthEst = this.masterPlaylistController_.mainSegmentLoader_.bandwidth;
- var networkInformation = window_1.navigator.connection || window_1.navigator.mozConnection || window_1.navigator.webkitConnection;
- var tenMbpsAsBitsPerSecond = 1e7;
- if (this.options_.useNetworkInformationApi && networkInformation) {
- var networkInfoBandwidthEstBitsPerSec = networkInformation.downlink * 1e3 * 1e3;
- if (networkInfoBandwidthEstBitsPerSec >= tenMbpsAsBitsPerSecond && playerBandwidthEst >= tenMbpsAsBitsPerSecond) {
- playerBandwidthEst = Math.max(playerBandwidthEst, networkInfoBandwidthEstBitsPerSec);
- } else {
- playerBandwidthEst = networkInfoBandwidthEstBitsPerSec;
- }
- }
- return playerBandwidthEst;
- },
- set: function set4(bandwidth2) {
- this.masterPlaylistController_.mainSegmentLoader_.bandwidth = bandwidth2;
- this.masterPlaylistController_.mainSegmentLoader_.throughput = {
- rate: 0,
- count: 0
- };
- }
- },
- systemBandwidth: {
- get: function get7() {
- var invBandwidth = 1 / (this.bandwidth || 1);
- var invThroughput;
- if (this.throughput > 0) {
- invThroughput = 1 / this.throughput;
- } else {
- invThroughput = 0;
- }
- var systemBitrate = Math.floor(1 / (invBandwidth + invThroughput));
- return systemBitrate;
- },
- set: function set4() {
- videojs.log.error('The "systemBandwidth" property is read-only');
- }
- }
- });
- if (this.options_.bandwidth) {
- this.bandwidth = this.options_.bandwidth;
- }
- if (this.options_.throughput) {
- this.throughput = this.options_.throughput;
- }
- Object.defineProperties(this.stats, {
- bandwidth: {
- get: function get7() {
- return _this3.bandwidth || 0;
- },
- enumerable: true
- },
- mediaRequests: {
- get: function get7() {
- return _this3.masterPlaylistController_.mediaRequests_() || 0;
- },
- enumerable: true
- },
- mediaRequestsAborted: {
- get: function get7() {
- return _this3.masterPlaylistController_.mediaRequestsAborted_() || 0;
- },
- enumerable: true
- },
- mediaRequestsTimedout: {
- get: function get7() {
- return _this3.masterPlaylistController_.mediaRequestsTimedout_() || 0;
- },
- enumerable: true
- },
- mediaRequestsErrored: {
- get: function get7() {
- return _this3.masterPlaylistController_.mediaRequestsErrored_() || 0;
- },
- enumerable: true
- },
- mediaTransferDuration: {
- get: function get7() {
- return _this3.masterPlaylistController_.mediaTransferDuration_() || 0;
- },
- enumerable: true
- },
- mediaBytesTransferred: {
- get: function get7() {
- return _this3.masterPlaylistController_.mediaBytesTransferred_() || 0;
- },
- enumerable: true
- },
- mediaSecondsLoaded: {
- get: function get7() {
- return _this3.masterPlaylistController_.mediaSecondsLoaded_() || 0;
- },
- enumerable: true
- },
- mediaAppends: {
- get: function get7() {
- return _this3.masterPlaylistController_.mediaAppends_() || 0;
- },
- enumerable: true
- },
- mainAppendsToLoadedData: {
- get: function get7() {
- return _this3.masterPlaylistController_.mainAppendsToLoadedData_() || 0;
- },
- enumerable: true
- },
- audioAppendsToLoadedData: {
- get: function get7() {
- return _this3.masterPlaylistController_.audioAppendsToLoadedData_() || 0;
- },
- enumerable: true
- },
- appendsToLoadedData: {
- get: function get7() {
- return _this3.masterPlaylistController_.appendsToLoadedData_() || 0;
- },
- enumerable: true
- },
- timeToLoadedData: {
- get: function get7() {
- return _this3.masterPlaylistController_.timeToLoadedData_() || 0;
- },
- enumerable: true
- },
- buffered: {
- get: function get7() {
- return timeRangesToArray(_this3.tech_.buffered());
- },
- enumerable: true
- },
- currentTime: {
- get: function get7() {
- return _this3.tech_.currentTime();
- },
- enumerable: true
- },
- currentSource: {
- get: function get7() {
- return _this3.tech_.currentSource_;
- },
- enumerable: true
- },
- currentTech: {
- get: function get7() {
- return _this3.tech_.name_;
- },
- enumerable: true
- },
- duration: {
- get: function get7() {
- return _this3.tech_.duration();
- },
- enumerable: true
- },
- master: {
- get: function get7() {
- return _this3.playlists.master;
- },
- enumerable: true
- },
- playerDimensions: {
- get: function get7() {
- return _this3.tech_.currentDimensions();
- },
- enumerable: true
- },
- seekable: {
- get: function get7() {
- return timeRangesToArray(_this3.tech_.seekable());
- },
- enumerable: true
- },
- timestamp: {
- get: function get7() {
- return Date.now();
- },
- enumerable: true
- },
- videoPlaybackQuality: {
- get: function get7() {
- return _this3.tech_.getVideoPlaybackQuality();
- },
- enumerable: true
- }
- });
- this.tech_.one("canplay", this.masterPlaylistController_.setupFirstPlay.bind(this.masterPlaylistController_));
- this.tech_.on("bandwidthupdate", function() {
- if (_this3.options_.useBandwidthFromLocalStorage) {
- updateVhsLocalStorage({
- bandwidth: _this3.bandwidth,
- throughput: Math.round(_this3.throughput)
- });
- }
- });
- this.masterPlaylistController_.on("selectedinitialmedia", function() {
- renditionSelectionMixin(_this3);
- });
- this.masterPlaylistController_.sourceUpdater_.on("createdsourcebuffers", function() {
- _this3.setupEme_();
- });
- this.on(this.masterPlaylistController_, "progress", function() {
- this.tech_.trigger("progress");
- });
- this.on(this.masterPlaylistController_, "firstplay", function() {
- this.ignoreNextSeekingEvent_ = true;
- });
- this.setupQualityLevels_();
- if (!this.tech_.el()) {
- return;
- }
- this.mediaSourceUrl_ = window_1.URL.createObjectURL(this.masterPlaylistController_.mediaSource);
- this.tech_.src(this.mediaSourceUrl_);
- };
- _proto.createKeySessions_ = function createKeySessions_() {
- var _this4 = this;
- var audioPlaylistLoader = this.masterPlaylistController_.mediaTypes_.AUDIO.activePlaylistLoader;
- this.logger_("waiting for EME key session creation");
- waitForKeySessionCreation({
- player: this.player_,
- sourceKeySystems: this.source_.keySystems,
- audioMedia: audioPlaylistLoader && audioPlaylistLoader.media(),
- mainPlaylists: this.playlists.master.playlists
- }).then(function() {
- _this4.logger_("created EME key session");
- _this4.masterPlaylistController_.sourceUpdater_.initializedEme();
- })["catch"](function(err) {
- _this4.logger_("error while creating EME key session", err);
- _this4.player_.error({
- message: "Failed to initialize media keys for EME",
- code: 3
- });
- });
- };
- _proto.handleWaitingForKey_ = function handleWaitingForKey_() {
- this.logger_("waitingforkey fired, attempting to create any new key sessions");
- this.createKeySessions_();
- };
- _proto.setupEme_ = function setupEme_() {
- var _this5 = this;
- var audioPlaylistLoader = this.masterPlaylistController_.mediaTypes_.AUDIO.activePlaylistLoader;
- var didSetupEmeOptions = setupEmeOptions({
- player: this.player_,
- sourceKeySystems: this.source_.keySystems,
- media: this.playlists.media(),
- audioMedia: audioPlaylistLoader && audioPlaylistLoader.media()
- });
- this.player_.tech_.on("keystatuschange", function(e) {
- if (e.status !== "output-restricted") {
- return;
- }
- var masterPlaylist = _this5.masterPlaylistController_.master();
- if (!masterPlaylist || !masterPlaylist.playlists) {
- return;
- }
- var excludedHDPlaylists = [];
- masterPlaylist.playlists.forEach(function(playlist) {
- if (playlist && playlist.attributes && playlist.attributes.RESOLUTION && playlist.attributes.RESOLUTION.height >= 720) {
- if (!playlist.excludeUntil || playlist.excludeUntil < Infinity) {
- playlist.excludeUntil = Infinity;
- excludedHDPlaylists.push(playlist);
- }
- }
- });
- if (excludedHDPlaylists.length) {
- var _videojs$log;
- (_videojs$log = videojs.log).warn.apply(_videojs$log, ['DRM keystatus changed to "output-restricted." Removing the following HD playlists that will most likely fail to play and clearing the buffer. This may be due to HDCP restrictions on the stream and the capabilities of the current device.'].concat(excludedHDPlaylists));
- _this5.masterPlaylistController_.fastQualityChange_();
- }
- });
- this.handleWaitingForKey_ = this.handleWaitingForKey_.bind(this);
- this.player_.tech_.on("waitingforkey", this.handleWaitingForKey_);
- if (videojs.browser.IE_VERSION === 11 || !didSetupEmeOptions) {
- this.masterPlaylistController_.sourceUpdater_.initializedEme();
- return;
- }
- this.createKeySessions_();
- };
- _proto.setupQualityLevels_ = function setupQualityLevels_() {
- var _this6 = this;
- var player = videojs.players[this.tech_.options_.playerId];
- if (!player || !player.qualityLevels || this.qualityLevels_) {
- return;
- }
- this.qualityLevels_ = player.qualityLevels();
- this.masterPlaylistController_.on("selectedinitialmedia", function() {
- handleVhsLoadedMetadata(_this6.qualityLevels_, _this6);
- });
- this.playlists.on("mediachange", function() {
- handleVhsMediaChange(_this6.qualityLevels_, _this6.playlists);
- });
- };
- VhsHandler2.version = function version$52() {
- return {
- "@videojs/http-streaming": version$4,
- "mux.js": version$3,
- "mpd-parser": version$2,
- "m3u8-parser": version$1$1,
- "aes-decrypter": version$6
- };
- };
- _proto.version = function version2() {
- return this.constructor.version();
- };
- _proto.canChangeType = function canChangeType() {
- return SourceUpdater.canChangeType();
- };
- _proto.play = function play() {
- this.masterPlaylistController_.play();
- };
- _proto.setCurrentTime = function setCurrentTime(currentTime) {
- this.masterPlaylistController_.setCurrentTime(currentTime);
- };
- _proto.duration = function duration5() {
- return this.masterPlaylistController_.duration();
- };
- _proto.seekable = function seekable3() {
- return this.masterPlaylistController_.seekable();
- };
- _proto.dispose = function dispose() {
- if (this.playbackWatcher_) {
- this.playbackWatcher_.dispose();
- }
- if (this.masterPlaylistController_) {
- this.masterPlaylistController_.dispose();
- }
- if (this.qualityLevels_) {
- this.qualityLevels_.dispose();
- }
- if (this.player_) {
- delete this.player_.vhs;
- delete this.player_.dash;
- delete this.player_.hls;
- }
- if (this.tech_ && this.tech_.vhs) {
- delete this.tech_.vhs;
- }
- if (this.tech_) {
- delete this.tech_.hls;
- }
- if (this.mediaSourceUrl_ && window_1.URL.revokeObjectURL) {
- window_1.URL.revokeObjectURL(this.mediaSourceUrl_);
- this.mediaSourceUrl_ = null;
- }
- if (this.tech_) {
- this.tech_.off("waitingforkey", this.handleWaitingForKey_);
- }
- _Component.prototype.dispose.call(this);
- };
- _proto.convertToProgramTime = function convertToProgramTime(time, callback2) {
- return getProgramTime({
- playlist: this.masterPlaylistController_.media(),
- time,
- callback: callback2
- });
- };
- _proto.seekToProgramTime = function seekToProgramTime$12(programTime, callback2, pauseAfterSeek, retryCount) {
- if (pauseAfterSeek === void 0) {
- pauseAfterSeek = true;
- }
- if (retryCount === void 0) {
- retryCount = 2;
- }
- return seekToProgramTime({
- programTime,
- playlist: this.masterPlaylistController_.media(),
- retryCount,
- pauseAfterSeek,
- seekTo: this.options_.seekTo,
- tech: this.options_.tech,
- callback: callback2
- });
- };
- return VhsHandler2;
- }(Component);
- var VhsSourceHandler = {
- name: "videojs-http-streaming",
- VERSION: version$4,
- canHandleSource: function canHandleSource(srcObj, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var localOptions = videojs.mergeOptions(videojs.options, options2);
- return VhsSourceHandler.canPlayType(srcObj.type, localOptions);
- },
- handleSource: function handleSource(source, tech, options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var localOptions = videojs.mergeOptions(videojs.options, options2);
- tech.vhs = new VhsHandler(source, tech, localOptions);
- if (!videojs.hasOwnProperty("hls")) {
- Object.defineProperty(tech, "hls", {
- get: function get7() {
- videojs.log.warn("player.tech().hls is deprecated. Use player.tech().vhs instead.");
- return tech.vhs;
- },
- configurable: true
- });
- }
- tech.vhs.xhr = xhrFactory();
- tech.vhs.src(source.src, source.type);
- return tech.vhs;
- },
- canPlayType: function canPlayType2(type2, options2) {
- var simpleType = simpleTypeFromSourceType2(type2);
- if (!simpleType) {
- return "";
- }
- var overrideNative = VhsSourceHandler.getOverrideNative(options2);
- var supportsTypeNatively = Vhs.supportsTypeNatively(simpleType);
- var canUseMsePlayback = !supportsTypeNatively || overrideNative;
- return canUseMsePlayback ? "maybe" : "";
- },
- getOverrideNative: function getOverrideNative(options2) {
- if (options2 === void 0) {
- options2 = {};
- }
- var _options = options2, _options$vhs = _options.vhs, vhs = _options$vhs === void 0 ? {} : _options$vhs, _options$hls = _options.hls, hls = _options$hls === void 0 ? {} : _options$hls;
- var defaultOverrideNative = !(videojs.browser.IS_ANY_SAFARI || videojs.browser.IS_IOS);
- var _vhs$overrideNative = vhs.overrideNative, overrideNative = _vhs$overrideNative === void 0 ? defaultOverrideNative : _vhs$overrideNative;
- var _hls$overrideNative = hls.overrideNative, legacyOverrideNative = _hls$overrideNative === void 0 ? false : _hls$overrideNative;
- return legacyOverrideNative || overrideNative;
- }
- };
- var supportsNativeMediaSources = function supportsNativeMediaSources2() {
- return browserSupportsCodec2("avc1.4d400d,mp4a.40.2");
- };
- if (supportsNativeMediaSources()) {
- videojs.getTech("Html5").registerSourceHandler(VhsSourceHandler, 0);
- }
- videojs.VhsHandler = VhsHandler;
- Object.defineProperty(videojs, "HlsHandler", {
- get: function get4() {
- videojs.log.warn("videojs.HlsHandler is deprecated. Use videojs.VhsHandler instead.");
- return VhsHandler;
- },
- configurable: true
- });
- videojs.VhsSourceHandler = VhsSourceHandler;
- Object.defineProperty(videojs, "HlsSourceHandler", {
- get: function get5() {
- videojs.log.warn("videojs.HlsSourceHandler is deprecated. Use videojs.VhsSourceHandler instead.");
- return VhsSourceHandler;
- },
- configurable: true
- });
- videojs.Vhs = Vhs;
- Object.defineProperty(videojs, "Hls", {
- get: function get6() {
- videojs.log.warn("videojs.Hls is deprecated. Use videojs.Vhs instead.");
- return Vhs;
- },
- configurable: true
- });
- if (!videojs.use) {
- videojs.registerComponent("Hls", Vhs);
- videojs.registerComponent("Vhs", Vhs);
- }
- videojs.options.vhs = videojs.options.vhs || {};
- videojs.options.hls = videojs.options.hls || {};
- if (!videojs.getPlugin || !videojs.getPlugin("reloadSourceOnError")) {
- var registerPlugin = videojs.registerPlugin || videojs.plugin;
- registerPlugin("reloadSourceOnError", reloadSourceOnError);
- }
- const version = "5.4.2";
- var version$1 = "2.2.1";
- function FlashRtmpDecorator(Flash2) {
- Flash2.streamingFormats = {
- "rtmp/mp4": "MP4",
- "rtmp/flv": "FLV"
- };
- Flash2.streamFromParts = function(connection, stream) {
- return connection + "&" + stream;
- };
- Flash2.streamToParts = function(src) {
- var parts = {
- connection: "",
- stream: ""
- };
- if (!src) {
- return parts;
- }
- var connEnd = src.search(/&(?![\w-]+=)/);
- var streamBegin = void 0;
- if (connEnd !== -1) {
- streamBegin = connEnd + 1;
- } else {
- connEnd = streamBegin = src.lastIndexOf("/") + 1;
- if (connEnd === 0) {
- connEnd = streamBegin = src.length;
- }
- }
- parts.connection = src.substring(0, connEnd);
- parts.stream = src.substring(streamBegin, src.length);
- return parts;
- };
- Flash2.isStreamingType = function(srcType) {
- return srcType in Flash2.streamingFormats;
- };
- Flash2.RTMP_RE = /^rtmp[set]?:\/\//i;
- Flash2.isStreamingSrc = function(src) {
- return Flash2.RTMP_RE.test(src);
- };
- Flash2.rtmpSourceHandler = {};
- Flash2.rtmpSourceHandler.canPlayType = function(type2) {
- if (Flash2.isStreamingType(type2)) {
- return "maybe";
- }
- return "";
- };
- Flash2.rtmpSourceHandler.canHandleSource = function(source, options2) {
- var can = Flash2.rtmpSourceHandler.canPlayType(source.type);
- if (can) {
- return can;
- }
- if (Flash2.isStreamingSrc(source.src)) {
- return "maybe";
- }
- return "";
- };
- Flash2.rtmpSourceHandler.handleSource = function(source, tech, options2) {
- var srcParts = Flash2.streamToParts(source.src);
- tech.setRtmpConnection(srcParts.connection);
- tech.setRtmpStream(srcParts.stream);
- };
- Flash2.registerSourceHandler(Flash2.rtmpSourceHandler);
- return Flash2;
- }
- var classCallCheck = function(instance, Constructor) {
- if (!(instance instanceof Constructor)) {
- throw new TypeError("Cannot call a class as a function");
- }
- };
- var inherits = function(subClass, superClass) {
- if (typeof superClass !== "function" && superClass !== null) {
- throw new TypeError("Super expression must either be null or a function, not " + typeof superClass);
- }
- subClass.prototype = Object.create(superClass && superClass.prototype, {
- constructor: {
- value: subClass,
- enumerable: false,
- writable: true,
- configurable: true
- }
- });
- if (superClass)
- Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;
- };
- var possibleConstructorReturn = function(self2, call) {
- if (!self2) {
- throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
- }
- return call && (typeof call === "object" || typeof call === "function") ? call : self2;
- };
- var Tech = videojs.getComponent("Tech");
- var Dom = videojs.dom;
- var Url = videojs.url;
- var createTimeRange = videojs.createTimeRange;
- var mergeOptions$1 = videojs.mergeOptions;
- var navigator$1 = window_1 && window_1.navigator || {};
- var Flash = function(_Tech) {
- inherits(Flash2, _Tech);
- function Flash2(options2, ready) {
- classCallCheck(this, Flash2);
- var _this = possibleConstructorReturn(this, _Tech.call(this, options2, ready));
- if (options2.source) {
- _this.ready(function() {
- this.setSource(options2.source);
- }, true);
- }
- if (options2.startTime) {
- _this.ready(function() {
- this.load();
- this.play();
- this.currentTime(options2.startTime);
- }, true);
- }
- window_1.videojs = window_1.videojs || {};
- window_1.videojs.Flash = window_1.videojs.Flash || {};
- window_1.videojs.Flash.onReady = Flash2.onReady;
- window_1.videojs.Flash.onEvent = Flash2.onEvent;
- window_1.videojs.Flash.onError = Flash2.onError;
- _this.on("seeked", function() {
- this.lastSeekTarget_ = void 0;
- });
- return _this;
- }
- Flash2.prototype.createEl = function createEl2() {
- var options2 = this.options_;
- if (!options2.swf) {
- options2.swf = "https://vjs.zencdn.net/swf/" + version + "/video-js.swf";
- }
- var objId = options2.techId;
- var flashVars = mergeOptions$1({
- readyFunction: "videojs.Flash.onReady",
- eventProxyFunction: "videojs.Flash.onEvent",
- errorEventProxyFunction: "videojs.Flash.onError",
- autoplay: options2.autoplay,
- preload: options2.preload,
- loop: options2.loop,
- muted: options2.muted
- }, options2.flashVars);
- var params = mergeOptions$1({
- wmode: "opaque",
- bgcolor: "#000000"
- }, options2.params);
- var attributes = mergeOptions$1({
- id: objId,
- name: objId,
- "class": "vjs-tech"
- }, options2.attributes);
- this.el_ = Flash2.embed(options2.swf, flashVars, params, attributes);
- this.el_.tech = this;
- return this.el_;
- };
- Flash2.prototype.play = function play() {
- if (this.ended()) {
- this.setCurrentTime(0);
- }
- this.el_.vjs_play();
- };
- Flash2.prototype.pause = function pause() {
- this.el_.vjs_pause();
- };
- Flash2.prototype.src = function src(_src) {
- if (_src === void 0) {
- return this.currentSrc();
- }
- return this.setSrc(_src);
- };
- Flash2.prototype.setSrc = function setSrc(src) {
- var _this2 = this;
- src = Url.getAbsoluteURL(src);
- this.el_.vjs_src(src);
- if (this.autoplay()) {
- this.setTimeout(function() {
- return _this2.play();
- }, 0);
- }
- };
- Flash2.prototype.seeking = function seeking() {
- return this.lastSeekTarget_ !== void 0;
- };
- Flash2.prototype.setCurrentTime = function setCurrentTime(time) {
- var seekable3 = this.seekable();
- if (seekable3.length) {
- time = time > seekable3.start(0) ? time : seekable3.start(0);
- time = time < seekable3.end(seekable3.length - 1) ? time : seekable3.end(seekable3.length - 1);
- this.lastSeekTarget_ = time;
- this.trigger("seeking");
- this.el_.vjs_setProperty("currentTime", time);
- _Tech.prototype.setCurrentTime.call(this);
- }
- };
- Flash2.prototype.currentTime = function currentTime() {
- if (this.seeking()) {
- return this.lastSeekTarget_ || 0;
- }
- return this.el_.vjs_getProperty("currentTime");
- };
- Flash2.prototype.currentSrc = function currentSrc() {
- if (this.currentSource_) {
- return this.currentSource_.src;
- }
- return this.el_.vjs_getProperty("currentSrc");
- };
- Flash2.prototype.duration = function duration5() {
- if (this.readyState() === 0) {
- return NaN;
- }
- var duration6 = this.el_.vjs_getProperty("duration");
- return duration6 >= 0 ? duration6 : Infinity;
- };
- Flash2.prototype.load = function load() {
- this.el_.vjs_load();
- };
- Flash2.prototype.poster = function poster() {
- this.el_.vjs_getProperty("poster");
- };
- Flash2.prototype.setPoster = function setPoster() {
- };
- Flash2.prototype.seekable = function seekable3() {
- var duration5 = this.duration();
- if (duration5 === 0) {
- return createTimeRange();
- }
- return createTimeRange(0, duration5);
- };
- Flash2.prototype.buffered = function buffered() {
- var ranges = this.el_.vjs_getProperty("buffered");
- if (ranges.length === 0) {
- return createTimeRange();
- }
- return createTimeRange(ranges[0][0], ranges[0][1]);
- };
- Flash2.prototype.supportsFullScreen = function supportsFullScreen() {
- return false;
- };
- Flash2.prototype.enterFullScreen = function enterFullScreen() {
- return false;
- };
- Flash2.prototype.getVideoPlaybackQuality = function getVideoPlaybackQuality() {
- var videoPlaybackQuality = this.el_.vjs_getProperty("getVideoPlaybackQuality");
- if (window_1.performance && typeof window_1.performance.now === "function") {
- videoPlaybackQuality.creationTime = window_1.performance.now();
- } else if (window_1.performance && window_1.performance.timing && typeof window_1.performance.timing.navigationStart === "number") {
- videoPlaybackQuality.creationTime = window_1.Date.now() - window_1.performance.timing.navigationStart;
- }
- return videoPlaybackQuality;
- };
- return Flash2;
- }(Tech);
- var _readWrite = ["rtmpConnection", "rtmpStream", "preload", "defaultPlaybackRate", "playbackRate", "autoplay", "loop", "controls", "volume", "muted", "defaultMuted"];
- var _readOnly = ["networkState", "readyState", "initialTime", "startOffsetTime", "paused", "ended", "videoWidth", "videoHeight"];
- var _api = Flash.prototype;
- function _createSetter(attr) {
- var attrUpper = attr.charAt(0).toUpperCase() + attr.slice(1);
- _api["set" + attrUpper] = function(val) {
- return this.el_.vjs_setProperty(attr, val);
- };
- }
- function _createGetter(attr) {
- _api[attr] = function() {
- return this.el_.vjs_getProperty(attr);
- };
- }
- for (var i$1 = 0; i$1 < _readWrite.length; i$1++) {
- _createGetter(_readWrite[i$1]);
- _createSetter(_readWrite[i$1]);
- }
- for (var _i = 0; _i < _readOnly.length; _i++) {
- _createGetter(_readOnly[_i]);
- }
- Flash.isSupported = function() {
- if (videojs.browser.IS_CHROME && (!videojs.browser.IS_ANDROID || !videojs.browser.IS_IOS) || videojs.browser.IS_SAFARI && !videojs.browser.IS_IOS || videojs.browser.IS_EDGE) {
- return true;
- }
- return Flash.version()[0] >= 10;
- };
- Tech.withSourceHandlers(Flash);
- Flash.nativeSourceHandler = {};
- Flash.nativeSourceHandler.canPlayType = function(type2) {
- if (type2 in Flash.formats) {
- return "maybe";
- }
- return "";
- };
- Flash.nativeSourceHandler.canHandleSource = function(source, options2) {
- var type2 = void 0;
- function guessMimeType(src) {
- var ext = Url.getFileExtension(src);
- if (ext) {
- return "video/" + ext;
- }
- return "";
- }
- if (!source.type) {
- type2 = guessMimeType(source.src);
- } else {
- type2 = source.type.replace(/;.*/, "").toLowerCase();
- }
- return Flash.nativeSourceHandler.canPlayType(type2);
- };
- Flash.nativeSourceHandler.handleSource = function(source, tech, options2) {
- tech.setSrc(source.src);
- };
- Flash.nativeSourceHandler.dispose = function() {
- };
- Flash.registerSourceHandler(Flash.nativeSourceHandler);
- Flash.formats = {
- "video/flv": "FLV",
- "video/x-flv": "FLV",
- "video/mp4": "MP4",
- "video/m4v": "MP4"
- };
- Flash.onReady = function(currSwf) {
- var el = Dom.$("#" + currSwf);
- var tech = el && el.tech;
- if (tech && tech.el()) {
- Flash.checkReady(tech);
- }
- };
- Flash.checkReady = function(tech) {
- if (!tech.el()) {
- return;
- }
- if (tech.el().vjs_getProperty) {
- tech.triggerReady();
- } else {
- this.setTimeout(function() {
- Flash.checkReady(tech);
- }, 50);
- }
- };
- Flash.onEvent = function(swfID, eventName) {
- var tech = Dom.$("#" + swfID).tech;
- var args = Array.prototype.slice.call(arguments, 2);
- tech.setTimeout(function() {
- tech.trigger(eventName, args);
- }, 1);
- };
- Flash.onError = function(swfID, err) {
- var tech = Dom.$("#" + swfID).tech;
- if (err === "srcnotfound") {
- return tech.error(4);
- }
- if (typeof err === "string") {
- tech.error("FLASH: " + err);
- } else {
- err.origin = "flash";
- tech.error(err);
- }
- };
- Flash.version = function() {
- var version$$1 = "0,0,0";
- try {
- version$$1 = new window_1.ActiveXObject("ShockwaveFlash.ShockwaveFlash").GetVariable("$version").replace(/\D+/g, ",").match(/^,?(.+),?$/)[1];
- } catch (e) {
- try {
- if (navigator$1.mimeTypes["application/x-shockwave-flash"].enabledPlugin) {
- version$$1 = (navigator$1.plugins["Shockwave Flash 2.0"] || navigator$1.plugins["Shockwave Flash"]).description.replace(/\D+/g, ",").match(/^,?(.+),?$/)[1];
- }
- } catch (err) {
- }
- }
- return version$$1.split(",");
- };
- Flash.embed = function(swf, flashVars, params, attributes) {
- var code = Flash.getEmbedCode(swf, flashVars, params, attributes);
- var obj = Dom.createEl("div", { innerHTML: code }).childNodes[0];
- return obj;
- };
- Flash.getEmbedCode = function(swf, flashVars, params, attributes) {
- var objTag = '<object type="application/x-shockwave-flash" ';
- var flashVarsString = "";
- var paramsString = "";
- var attrsString = "";
- if (flashVars) {
- Object.getOwnPropertyNames(flashVars).forEach(function(key) {
- flashVarsString += key + "=" + flashVars[key] + "&";
- });
- }
- params = mergeOptions$1({
- movie: swf,
- flashvars: flashVarsString,
- allowScriptAccess: "always",
- allowNetworking: "all"
- }, params);
- Object.getOwnPropertyNames(params).forEach(function(key) {
- paramsString += '<param name="' + key + '" value="' + params[key] + '" />';
- });
- attributes = mergeOptions$1({
- data: swf,
- width: "100%",
- height: "100%"
- }, attributes);
- Object.getOwnPropertyNames(attributes).forEach(function(key) {
- attrsString += key + '="' + attributes[key] + '" ';
- });
- return "" + objTag + attrsString + ">" + paramsString + "</object>";
- };
- FlashRtmpDecorator(Flash);
- if (Tech.getTech("Flash")) {
- videojs.log.warn("Not using videojs-flash as it appears to already be registered");
- videojs.log.warn("videojs-flash should only be used with video.js@6 and above");
- } else {
- videojs.registerTech("Flash", Flash);
- }
- Flash.VERSION = version$1;
- var flv = { exports: {} };
- (function(module2, exports2) {
- (function webpackUniversalModuleDefinition(root2, factory3) {
- module2.exports = factory3();
- })(self, function() {
- return function() {
- var __webpack_modules__ = {
- "./node_modules/es6-promise/dist/es6-promise.js": function(module3, __unused_webpack_exports, __webpack_require__2) {
- /*!
- * @overview es6-promise - a tiny implementation of Promises/A+.
- * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors (Conversion to ES6 API by Jake Archibald)
- * @license Licensed under MIT license
- * See https://raw.githubusercontent.com/stefanpenner/es6-promise/master/LICENSE
- * @version v4.2.8+1e68dce6
- */
- (function(global2, factory3) {
- module3.exports = factory3();
- })(this, function() {
- function objectOrFunction(x) {
- var type2 = typeof x;
- return x !== null && (type2 === "object" || type2 === "function");
- }
- function isFunction2(x) {
- return typeof x === "function";
- }
- var _isArray = void 0;
- if (Array.isArray) {
- _isArray = Array.isArray;
- } else {
- _isArray = function(x) {
- return Object.prototype.toString.call(x) === "[object Array]";
- };
- }
- var isArray2 = _isArray;
- var len = 0;
- var vertxNext = void 0;
- var customSchedulerFn = void 0;
- var asap = function asap2(callback2, arg) {
- queue[len] = callback2;
- queue[len + 1] = arg;
- len += 2;
- if (len === 2) {
- if (customSchedulerFn) {
- customSchedulerFn(flush);
- } else {
- scheduleFlush();
- }
- }
- };
- function setScheduler(scheduleFn) {
- customSchedulerFn = scheduleFn;
- }
- function setAsap(asapFn) {
- asap = asapFn;
- }
- var browserWindow = typeof window !== "undefined" ? window : void 0;
- var browserGlobal = browserWindow || {};
- var BrowserMutationObserver = browserGlobal.MutationObserver || browserGlobal.WebKitMutationObserver;
- var isNode = typeof self === "undefined" && typeof process !== "undefined" && {}.toString.call(process) === "[object process]";
- var isWorker = typeof Uint8ClampedArray !== "undefined" && typeof importScripts !== "undefined" && typeof MessageChannel !== "undefined";
- function useNextTick() {
- return function() {
- return process.nextTick(flush);
- };
- }
- function useVertxTimer() {
- if (typeof vertxNext !== "undefined") {
- return function() {
- vertxNext(flush);
- };
- }
- return useSetTimeout();
- }
- function useMutationObserver() {
- var iterations = 0;
- var observer = new BrowserMutationObserver(flush);
- var node = document.createTextNode("");
- observer.observe(node, { characterData: true });
- return function() {
- node.data = iterations = ++iterations % 2;
- };
- }
- function useMessageChannel() {
- var channel = new MessageChannel();
- channel.port1.onmessage = flush;
- return function() {
- return channel.port2.postMessage(0);
- };
- }
- function useSetTimeout() {
- var globalSetTimeout = setTimeout;
- return function() {
- return globalSetTimeout(flush, 1);
- };
- }
- var queue = new Array(1e3);
- function flush() {
- for (var i2 = 0; i2 < len; i2 += 2) {
- var callback2 = queue[i2];
- var arg = queue[i2 + 1];
- callback2(arg);
- queue[i2] = void 0;
- queue[i2 + 1] = void 0;
- }
- len = 0;
- }
- function attemptVertx() {
- try {
- var vertx = Function("return this")().require("vertx");
- vertxNext = vertx.runOnLoop || vertx.runOnContext;
- return useVertxTimer();
- } catch (e) {
- return useSetTimeout();
- }
- }
- var scheduleFlush = void 0;
- if (isNode) {
- scheduleFlush = useNextTick();
- } else if (BrowserMutationObserver) {
- scheduleFlush = useMutationObserver();
- } else if (isWorker) {
- scheduleFlush = useMessageChannel();
- } else if (browserWindow === void 0 && true) {
- scheduleFlush = attemptVertx();
- } else {
- scheduleFlush = useSetTimeout();
- }
- function then(onFulfillment, onRejection) {
- var parent = this;
- var child = new this.constructor(noop2);
- if (child[PROMISE_ID] === void 0) {
- makePromise(child);
- }
- var _state = parent._state;
- if (_state) {
- var callback2 = arguments[_state - 1];
- asap(function() {
- return invokeCallback(_state, child, callback2, parent._result);
- });
- } else {
- subscribe(parent, child, onFulfillment, onRejection);
- }
- return child;
- }
- function resolve$1(object) {
- var Constructor = this;
- if (object && typeof object === "object" && object.constructor === Constructor) {
- return object;
- }
- var promise = new Constructor(noop2);
- resolve2(promise, object);
- return promise;
- }
- var PROMISE_ID = Math.random().toString(36).substring(2);
- function noop2() {
- }
- var PENDING = void 0;
- var FULFILLED = 1;
- var REJECTED = 2;
- function selfFulfillment() {
- return new TypeError("You cannot resolve a promise with itself");
- }
- function cannotReturnOwn() {
- return new TypeError("A promises callback cannot return that same promise.");
- }
- function tryThen(then$$1, value, fulfillmentHandler, rejectionHandler) {
- try {
- then$$1.call(value, fulfillmentHandler, rejectionHandler);
- } catch (e) {
- return e;
- }
- }
- function handleForeignThenable(promise, thenable, then$$1) {
- asap(function(promise2) {
- var sealed = false;
- var error = tryThen(then$$1, thenable, function(value) {
- if (sealed) {
- return;
- }
- sealed = true;
- if (thenable !== value) {
- resolve2(promise2, value);
- } else {
- fulfill(promise2, value);
- }
- }, function(reason) {
- if (sealed) {
- return;
- }
- sealed = true;
- reject2(promise2, reason);
- }, "Settle: " + (promise2._label || " unknown promise"));
- if (!sealed && error) {
- sealed = true;
- reject2(promise2, error);
- }
- }, promise);
- }
- function handleOwnThenable(promise, thenable) {
- if (thenable._state === FULFILLED) {
- fulfill(promise, thenable._result);
- } else if (thenable._state === REJECTED) {
- reject2(promise, thenable._result);
- } else {
- subscribe(thenable, void 0, function(value) {
- return resolve2(promise, value);
- }, function(reason) {
- return reject2(promise, reason);
- });
- }
- }
- function handleMaybeThenable(promise, maybeThenable, then$$1) {
- if (maybeThenable.constructor === promise.constructor && then$$1 === then && maybeThenable.constructor.resolve === resolve$1) {
- handleOwnThenable(promise, maybeThenable);
- } else {
- if (then$$1 === void 0) {
- fulfill(promise, maybeThenable);
- } else if (isFunction2(then$$1)) {
- handleForeignThenable(promise, maybeThenable, then$$1);
- } else {
- fulfill(promise, maybeThenable);
- }
- }
- }
- function resolve2(promise, value) {
- if (promise === value) {
- reject2(promise, selfFulfillment());
- } else if (objectOrFunction(value)) {
- var then$$1 = void 0;
- try {
- then$$1 = value.then;
- } catch (error) {
- reject2(promise, error);
- return;
- }
- handleMaybeThenable(promise, value, then$$1);
- } else {
- fulfill(promise, value);
- }
- }
- function publishRejection(promise) {
- if (promise._onerror) {
- promise._onerror(promise._result);
- }
- publish(promise);
- }
- function fulfill(promise, value) {
- if (promise._state !== PENDING) {
- return;
- }
- promise._result = value;
- promise._state = FULFILLED;
- if (promise._subscribers.length !== 0) {
- asap(publish, promise);
- }
- }
- function reject2(promise, reason) {
- if (promise._state !== PENDING) {
- return;
- }
- promise._state = REJECTED;
- promise._result = reason;
- asap(publishRejection, promise);
- }
- function subscribe(parent, child, onFulfillment, onRejection) {
- var _subscribers = parent._subscribers;
- var length = _subscribers.length;
- parent._onerror = null;
- _subscribers[length] = child;
- _subscribers[length + FULFILLED] = onFulfillment;
- _subscribers[length + REJECTED] = onRejection;
- if (length === 0 && parent._state) {
- asap(publish, parent);
- }
- }
- function publish(promise) {
- var subscribers = promise._subscribers;
- var settled = promise._state;
- if (subscribers.length === 0) {
- return;
- }
- var child = void 0, callback2 = void 0, detail = promise._result;
- for (var i2 = 0; i2 < subscribers.length; i2 += 3) {
- child = subscribers[i2];
- callback2 = subscribers[i2 + settled];
- if (child) {
- invokeCallback(settled, child, callback2, detail);
- } else {
- callback2(detail);
- }
- }
- promise._subscribers.length = 0;
- }
- function invokeCallback(settled, promise, callback2, detail) {
- var hasCallback = isFunction2(callback2), value = void 0, error = void 0, succeeded = true;
- if (hasCallback) {
- try {
- value = callback2(detail);
- } catch (e) {
- succeeded = false;
- error = e;
- }
- if (promise === value) {
- reject2(promise, cannotReturnOwn());
- return;
- }
- } else {
- value = detail;
- }
- if (promise._state !== PENDING)
- ;
- else if (hasCallback && succeeded) {
- resolve2(promise, value);
- } else if (succeeded === false) {
- reject2(promise, error);
- } else if (settled === FULFILLED) {
- fulfill(promise, value);
- } else if (settled === REJECTED) {
- reject2(promise, value);
- }
- }
- function initializePromise(promise, resolver) {
- try {
- resolver(function resolvePromise(value) {
- resolve2(promise, value);
- }, function rejectPromise(reason) {
- reject2(promise, reason);
- });
- } catch (e) {
- reject2(promise, e);
- }
- }
- var id = 0;
- function nextId() {
- return id++;
- }
- function makePromise(promise) {
- promise[PROMISE_ID] = id++;
- promise._state = void 0;
- promise._result = void 0;
- promise._subscribers = [];
- }
- function validationError() {
- return new Error("Array Methods must be provided an Array");
- }
- var Enumerator = function() {
- function Enumerator2(Constructor, input) {
- this._instanceConstructor = Constructor;
- this.promise = new Constructor(noop2);
- if (!this.promise[PROMISE_ID]) {
- makePromise(this.promise);
- }
- if (isArray2(input)) {
- this.length = input.length;
- this._remaining = input.length;
- this._result = new Array(this.length);
- if (this.length === 0) {
- fulfill(this.promise, this._result);
- } else {
- this.length = this.length || 0;
- this._enumerate(input);
- if (this._remaining === 0) {
- fulfill(this.promise, this._result);
- }
- }
- } else {
- reject2(this.promise, validationError());
- }
- }
- Enumerator2.prototype._enumerate = function _enumerate(input) {
- for (var i2 = 0; this._state === PENDING && i2 < input.length; i2++) {
- this._eachEntry(input[i2], i2);
- }
- };
- Enumerator2.prototype._eachEntry = function _eachEntry(entry, i2) {
- var c = this._instanceConstructor;
- var resolve$$1 = c.resolve;
- if (resolve$$1 === resolve$1) {
- var _then = void 0;
- var error = void 0;
- var didError = false;
- try {
- _then = entry.then;
- } catch (e) {
- didError = true;
- error = e;
- }
- if (_then === then && entry._state !== PENDING) {
- this._settledAt(entry._state, i2, entry._result);
- } else if (typeof _then !== "function") {
- this._remaining--;
- this._result[i2] = entry;
- } else if (c === Promise$12) {
- var promise = new c(noop2);
- if (didError) {
- reject2(promise, error);
- } else {
- handleMaybeThenable(promise, entry, _then);
- }
- this._willSettleAt(promise, i2);
- } else {
- this._willSettleAt(new c(function(resolve$$12) {
- return resolve$$12(entry);
- }), i2);
- }
- } else {
- this._willSettleAt(resolve$$1(entry), i2);
- }
- };
- Enumerator2.prototype._settledAt = function _settledAt(state, i2, value) {
- var promise = this.promise;
- if (promise._state === PENDING) {
- this._remaining--;
- if (state === REJECTED) {
- reject2(promise, value);
- } else {
- this._result[i2] = value;
- }
- }
- if (this._remaining === 0) {
- fulfill(promise, this._result);
- }
- };
- Enumerator2.prototype._willSettleAt = function _willSettleAt(promise, i2) {
- var enumerator = this;
- subscribe(promise, void 0, function(value) {
- return enumerator._settledAt(FULFILLED, i2, value);
- }, function(reason) {
- return enumerator._settledAt(REJECTED, i2, reason);
- });
- };
- return Enumerator2;
- }();
- function all(entries) {
- return new Enumerator(this, entries).promise;
- }
- function race(entries) {
- var Constructor = this;
- if (!isArray2(entries)) {
- return new Constructor(function(_, reject3) {
- return reject3(new TypeError("You must pass an array to race."));
- });
- } else {
- return new Constructor(function(resolve3, reject3) {
- var length = entries.length;
- for (var i2 = 0; i2 < length; i2++) {
- Constructor.resolve(entries[i2]).then(resolve3, reject3);
- }
- });
- }
- }
- function reject$1(reason) {
- var Constructor = this;
- var promise = new Constructor(noop2);
- reject2(promise, reason);
- return promise;
- }
- function needsResolver() {
- throw new TypeError("You must pass a resolver function as the first argument to the promise constructor");
- }
- function needsNew() {
- throw new TypeError("Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.");
- }
- var Promise$12 = function() {
- function Promise2(resolver) {
- this[PROMISE_ID] = nextId();
- this._result = this._state = void 0;
- this._subscribers = [];
- if (noop2 !== resolver) {
- typeof resolver !== "function" && needsResolver();
- this instanceof Promise2 ? initializePromise(this, resolver) : needsNew();
- }
- }
- Promise2.prototype.catch = function _catch(onRejection) {
- return this.then(null, onRejection);
- };
- Promise2.prototype.finally = function _finally(callback2) {
- var promise = this;
- var constructor = promise.constructor;
- if (isFunction2(callback2)) {
- return promise.then(function(value) {
- return constructor.resolve(callback2()).then(function() {
- return value;
- });
- }, function(reason) {
- return constructor.resolve(callback2()).then(function() {
- throw reason;
- });
- });
- }
- return promise.then(callback2, callback2);
- };
- return Promise2;
- }();
- Promise$12.prototype.then = then;
- Promise$12.all = all;
- Promise$12.race = race;
- Promise$12.resolve = resolve$1;
- Promise$12.reject = reject$1;
- Promise$12._setScheduler = setScheduler;
- Promise$12._setAsap = setAsap;
- Promise$12._asap = asap;
- function polyfill() {
- var local = void 0;
- if (typeof __webpack_require__2.g !== "undefined") {
- local = __webpack_require__2.g;
- } else if (typeof self !== "undefined") {
- local = self;
- } else {
- try {
- local = Function("return this")();
- } catch (e) {
- throw new Error("polyfill failed because global object is unavailable in this environment");
- }
- }
- var P2 = local.Promise;
- if (P2) {
- var promiseToString = null;
- try {
- promiseToString = Object.prototype.toString.call(P2.resolve());
- } catch (e) {
- }
- if (promiseToString === "[object Promise]" && !P2.cast) {
- return;
- }
- }
- local.Promise = Promise$12;
- }
- Promise$12.polyfill = polyfill;
- Promise$12.Promise = Promise$12;
- return Promise$12;
- });
- },
- "./node_modules/events/events.js": function(module3) {
- var R2 = typeof Reflect === "object" ? Reflect : null;
- var ReflectApply = R2 && typeof R2.apply === "function" ? R2.apply : function ReflectApply2(target, receiver, args) {
- return Function.prototype.apply.call(target, receiver, args);
- };
- var ReflectOwnKeys;
- if (R2 && typeof R2.ownKeys === "function") {
- ReflectOwnKeys = R2.ownKeys;
- } else if (Object.getOwnPropertySymbols) {
- ReflectOwnKeys = function ReflectOwnKeys2(target) {
- return Object.getOwnPropertyNames(target).concat(Object.getOwnPropertySymbols(target));
- };
- } else {
- ReflectOwnKeys = function ReflectOwnKeys2(target) {
- return Object.getOwnPropertyNames(target);
- };
- }
- function ProcessEmitWarning(warning) {
- if (console && console.warn)
- console.warn(warning);
- }
- var NumberIsNaN = Number.isNaN || function NumberIsNaN2(value) {
- return value !== value;
- };
- function EventEmitter() {
- EventEmitter.init.call(this);
- }
- module3.exports = EventEmitter;
- module3.exports.once = once;
- EventEmitter.EventEmitter = EventEmitter;
- EventEmitter.prototype._events = void 0;
- EventEmitter.prototype._eventsCount = 0;
- EventEmitter.prototype._maxListeners = void 0;
- var defaultMaxListeners = 10;
- function checkListener(listener) {
- if (typeof listener !== "function") {
- throw new TypeError('The "listener" argument must be of type Function. Received type ' + typeof listener);
- }
- }
- Object.defineProperty(EventEmitter, "defaultMaxListeners", {
- enumerable: true,
- get: function() {
- return defaultMaxListeners;
- },
- set: function(arg) {
- if (typeof arg !== "number" || arg < 0 || NumberIsNaN(arg)) {
- throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received ' + arg + ".");
- }
- defaultMaxListeners = arg;
- }
- });
- EventEmitter.init = function() {
- if (this._events === void 0 || this._events === Object.getPrototypeOf(this)._events) {
- this._events = /* @__PURE__ */ Object.create(null);
- this._eventsCount = 0;
- }
- this._maxListeners = this._maxListeners || void 0;
- };
- EventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {
- if (typeof n !== "number" || n < 0 || NumberIsNaN(n)) {
- throw new RangeError('The value of "n" is out of range. It must be a non-negative number. Received ' + n + ".");
- }
- this._maxListeners = n;
- return this;
- };
- function _getMaxListeners(that) {
- if (that._maxListeners === void 0)
- return EventEmitter.defaultMaxListeners;
- return that._maxListeners;
- }
- EventEmitter.prototype.getMaxListeners = function getMaxListeners() {
- return _getMaxListeners(this);
- };
- EventEmitter.prototype.emit = function emit(type2) {
- var args = [];
- for (var i2 = 1; i2 < arguments.length; i2++)
- args.push(arguments[i2]);
- var doError = type2 === "error";
- var events = this._events;
- if (events !== void 0)
- doError = doError && events.error === void 0;
- else if (!doError)
- return false;
- if (doError) {
- var er;
- if (args.length > 0)
- er = args[0];
- if (er instanceof Error) {
- throw er;
- }
- var err = new Error("Unhandled error." + (er ? " (" + er.message + ")" : ""));
- err.context = er;
- throw err;
- }
- var handler = events[type2];
- if (handler === void 0)
- return false;
- if (typeof handler === "function") {
- ReflectApply(handler, this, args);
- } else {
- var len = handler.length;
- var listeners = arrayClone(handler, len);
- for (var i2 = 0; i2 < len; ++i2)
- ReflectApply(listeners[i2], this, args);
- }
- return true;
- };
- function _addListener(target, type2, listener, prepend) {
- var m;
- var events;
- var existing;
- checkListener(listener);
- events = target._events;
- if (events === void 0) {
- events = target._events = /* @__PURE__ */ Object.create(null);
- target._eventsCount = 0;
- } else {
- if (events.newListener !== void 0) {
- target.emit("newListener", type2, listener.listener ? listener.listener : listener);
- events = target._events;
- }
- existing = events[type2];
- }
- if (existing === void 0) {
- existing = events[type2] = listener;
- ++target._eventsCount;
- } else {
- if (typeof existing === "function") {
- existing = events[type2] = prepend ? [listener, existing] : [existing, listener];
- } else if (prepend) {
- existing.unshift(listener);
- } else {
- existing.push(listener);
- }
- m = _getMaxListeners(target);
- if (m > 0 && existing.length > m && !existing.warned) {
- existing.warned = true;
- var w = new Error("Possible EventEmitter memory leak detected. " + existing.length + " " + String(type2) + " listeners added. Use emitter.setMaxListeners() to increase limit");
- w.name = "MaxListenersExceededWarning";
- w.emitter = target;
- w.type = type2;
- w.count = existing.length;
- ProcessEmitWarning(w);
- }
- }
- return target;
- }
- EventEmitter.prototype.addListener = function addListener(type2, listener) {
- return _addListener(this, type2, listener, false);
- };
- EventEmitter.prototype.on = EventEmitter.prototype.addListener;
- EventEmitter.prototype.prependListener = function prependListener(type2, listener) {
- return _addListener(this, type2, listener, true);
- };
- function onceWrapper() {
- if (!this.fired) {
- this.target.removeListener(this.type, this.wrapFn);
- this.fired = true;
- if (arguments.length === 0)
- return this.listener.call(this.target);
- return this.listener.apply(this.target, arguments);
- }
- }
- function _onceWrap(target, type2, listener) {
- var state = { fired: false, wrapFn: void 0, target, type: type2, listener };
- var wrapped = onceWrapper.bind(state);
- wrapped.listener = listener;
- state.wrapFn = wrapped;
- return wrapped;
- }
- EventEmitter.prototype.once = function once2(type2, listener) {
- checkListener(listener);
- this.on(type2, _onceWrap(this, type2, listener));
- return this;
- };
- EventEmitter.prototype.prependOnceListener = function prependOnceListener(type2, listener) {
- checkListener(listener);
- this.prependListener(type2, _onceWrap(this, type2, listener));
- return this;
- };
- EventEmitter.prototype.removeListener = function removeListener(type2, listener) {
- var list, events, position2, i2, originalListener;
- checkListener(listener);
- events = this._events;
- if (events === void 0)
- return this;
- list = events[type2];
- if (list === void 0)
- return this;
- if (list === listener || list.listener === listener) {
- if (--this._eventsCount === 0)
- this._events = /* @__PURE__ */ Object.create(null);
- else {
- delete events[type2];
- if (events.removeListener)
- this.emit("removeListener", type2, list.listener || listener);
- }
- } else if (typeof list !== "function") {
- position2 = -1;
- for (i2 = list.length - 1; i2 >= 0; i2--) {
- if (list[i2] === listener || list[i2].listener === listener) {
- originalListener = list[i2].listener;
- position2 = i2;
- break;
- }
- }
- if (position2 < 0)
- return this;
- if (position2 === 0)
- list.shift();
- else {
- spliceOne(list, position2);
- }
- if (list.length === 1)
- events[type2] = list[0];
- if (events.removeListener !== void 0)
- this.emit("removeListener", type2, originalListener || listener);
- }
- return this;
- };
- EventEmitter.prototype.off = EventEmitter.prototype.removeListener;
- EventEmitter.prototype.removeAllListeners = function removeAllListeners(type2) {
- var listeners, events, i2;
- events = this._events;
- if (events === void 0)
- return this;
- if (events.removeListener === void 0) {
- if (arguments.length === 0) {
- this._events = /* @__PURE__ */ Object.create(null);
- this._eventsCount = 0;
- } else if (events[type2] !== void 0) {
- if (--this._eventsCount === 0)
- this._events = /* @__PURE__ */ Object.create(null);
- else
- delete events[type2];
- }
- return this;
- }
- if (arguments.length === 0) {
- var keys3 = Object.keys(events);
- var key;
- for (i2 = 0; i2 < keys3.length; ++i2) {
- key = keys3[i2];
- if (key === "removeListener")
- continue;
- this.removeAllListeners(key);
- }
- this.removeAllListeners("removeListener");
- this._events = /* @__PURE__ */ Object.create(null);
- this._eventsCount = 0;
- return this;
- }
- listeners = events[type2];
- if (typeof listeners === "function") {
- this.removeListener(type2, listeners);
- } else if (listeners !== void 0) {
- for (i2 = listeners.length - 1; i2 >= 0; i2--) {
- this.removeListener(type2, listeners[i2]);
- }
- }
- return this;
- };
- function _listeners(target, type2, unwrap) {
- var events = target._events;
- if (events === void 0)
- return [];
- var evlistener = events[type2];
- if (evlistener === void 0)
- return [];
- if (typeof evlistener === "function")
- return unwrap ? [evlistener.listener || evlistener] : [evlistener];
- return unwrap ? unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);
- }
- EventEmitter.prototype.listeners = function listeners(type2) {
- return _listeners(this, type2, true);
- };
- EventEmitter.prototype.rawListeners = function rawListeners(type2) {
- return _listeners(this, type2, false);
- };
- EventEmitter.listenerCount = function(emitter, type2) {
- if (typeof emitter.listenerCount === "function") {
- return emitter.listenerCount(type2);
- } else {
- return listenerCount.call(emitter, type2);
- }
- };
- EventEmitter.prototype.listenerCount = listenerCount;
- function listenerCount(type2) {
- var events = this._events;
- if (events !== void 0) {
- var evlistener = events[type2];
- if (typeof evlistener === "function") {
- return 1;
- } else if (evlistener !== void 0) {
- return evlistener.length;
- }
- }
- return 0;
- }
- EventEmitter.prototype.eventNames = function eventNames() {
- return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];
- };
- function arrayClone(arr, n) {
- var copy2 = new Array(n);
- for (var i2 = 0; i2 < n; ++i2)
- copy2[i2] = arr[i2];
- return copy2;
- }
- function spliceOne(list, index2) {
- for (; index2 + 1 < list.length; index2++)
- list[index2] = list[index2 + 1];
- list.pop();
- }
- function unwrapListeners(arr) {
- var ret = new Array(arr.length);
- for (var i2 = 0; i2 < ret.length; ++i2) {
- ret[i2] = arr[i2].listener || arr[i2];
- }
- return ret;
- }
- function once(emitter, name) {
- return new Promise(function(resolve2, reject2) {
- function errorListener(err) {
- emitter.removeListener(name, resolver);
- reject2(err);
- }
- function resolver() {
- if (typeof emitter.removeListener === "function") {
- emitter.removeListener("error", errorListener);
- }
- resolve2([].slice.call(arguments));
- }
- eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });
- if (name !== "error") {
- addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });
- }
- });
- }
- function addErrorHandlerIfEventEmitter(emitter, handler, flags) {
- if (typeof emitter.on === "function") {
- eventTargetAgnosticAddListener(emitter, "error", handler, flags);
- }
- }
- function eventTargetAgnosticAddListener(emitter, name, listener, flags) {
- if (typeof emitter.on === "function") {
- if (flags.once) {
- emitter.once(name, listener);
- } else {
- emitter.on(name, listener);
- }
- } else if (typeof emitter.addEventListener === "function") {
- emitter.addEventListener(name, function wrapListener(arg) {
- if (flags.once) {
- emitter.removeEventListener(name, wrapListener);
- }
- listener(arg);
- });
- } else {
- throw new TypeError('The "emitter" argument must be of type EventEmitter. Received type ' + typeof emitter);
- }
- }
- },
- "./node_modules/webworkify-webpack/index.js": function(module3, __unused_webpack_exports, __webpack_require__2) {
- function webpackBootstrapFunc(modules) {
- var installedModules = {};
- function __nested_webpack_require_164__(moduleId) {
- if (installedModules[moduleId])
- return installedModules[moduleId].exports;
- var module4 = installedModules[moduleId] = {
- i: moduleId,
- l: false,
- exports: {}
- };
- modules[moduleId].call(module4.exports, module4, module4.exports, __nested_webpack_require_164__);
- module4.l = true;
- return module4.exports;
- }
- __nested_webpack_require_164__.m = modules;
- __nested_webpack_require_164__.c = installedModules;
- __nested_webpack_require_164__.i = function(value) {
- return value;
- };
- __nested_webpack_require_164__.d = function(exports3, name, getter) {
- if (!__nested_webpack_require_164__.o(exports3, name)) {
- Object.defineProperty(exports3, name, {
- configurable: false,
- enumerable: true,
- get: getter
- });
- }
- };
- __nested_webpack_require_164__.r = function(exports3) {
- Object.defineProperty(exports3, "__esModule", { value: true });
- };
- __nested_webpack_require_164__.n = function(module4) {
- var getter = module4 && module4.__esModule ? function getDefault() {
- return module4["default"];
- } : function getModuleExports() {
- return module4;
- };
- __nested_webpack_require_164__.d(getter, "a", getter);
- return getter;
- };
- __nested_webpack_require_164__.o = function(object, property) {
- return Object.prototype.hasOwnProperty.call(object, property);
- };
- __nested_webpack_require_164__.p = "/";
- __nested_webpack_require_164__.oe = function(err) {
- console.error(err);
- throw err;
- };
- var f = __nested_webpack_require_164__(__nested_webpack_require_164__.s = ENTRY_MODULE);
- return f.default || f;
- }
- var moduleNameReqExp = "[\\.|\\-|\\+|\\w|/|@]+";
- var dependencyRegExp = "\\(\\s*(/\\*.*?\\*/)?\\s*.*?(" + moduleNameReqExp + ").*?\\)";
- function quoteRegExp(str) {
- return (str + "").replace(/[.?*+^$[\]\\(){}|-]/g, "\\$&");
- }
- function isNumeric(n) {
- return !isNaN(1 * n);
- }
- function getModuleDependencies(sources, module4, queueName) {
- var retval = {};
- retval[queueName] = [];
- var fnString = module4.toString();
- var wrapperSignature = fnString.match(/^function\s?\w*\(\w+,\s*\w+,\s*(\w+)\)/);
- if (!wrapperSignature)
- return retval;
- var webpackRequireName = wrapperSignature[1];
- var re = new RegExp("(\\\\n|\\W)" + quoteRegExp(webpackRequireName) + dependencyRegExp, "g");
- var match;
- while (match = re.exec(fnString)) {
- if (match[3] === "dll-reference")
- continue;
- retval[queueName].push(match[3]);
- }
- re = new RegExp("\\(" + quoteRegExp(webpackRequireName) + '\\("(dll-reference\\s(' + moduleNameReqExp + '))"\\)\\)' + dependencyRegExp, "g");
- while (match = re.exec(fnString)) {
- if (!sources[match[2]]) {
- retval[queueName].push(match[1]);
- sources[match[2]] = __webpack_require__2(match[1]).m;
- }
- retval[match[2]] = retval[match[2]] || [];
- retval[match[2]].push(match[4]);
- }
- var keys3 = Object.keys(retval);
- for (var i2 = 0; i2 < keys3.length; i2++) {
- for (var j = 0; j < retval[keys3[i2]].length; j++) {
- if (isNumeric(retval[keys3[i2]][j])) {
- retval[keys3[i2]][j] = 1 * retval[keys3[i2]][j];
- }
- }
- }
- return retval;
- }
- function hasValuesInQueues(queues) {
- var keys3 = Object.keys(queues);
- return keys3.reduce(function(hasValues, key) {
- return hasValues || queues[key].length > 0;
- }, false);
- }
- function getRequiredModules(sources, moduleId) {
- var modulesQueue = {
- main: [moduleId]
- };
- var requiredModules = {
- main: []
- };
- var seenModules = {
- main: {}
- };
- while (hasValuesInQueues(modulesQueue)) {
- var queues = Object.keys(modulesQueue);
- for (var i2 = 0; i2 < queues.length; i2++) {
- var queueName = queues[i2];
- var queue = modulesQueue[queueName];
- var moduleToCheck = queue.pop();
- seenModules[queueName] = seenModules[queueName] || {};
- if (seenModules[queueName][moduleToCheck] || !sources[queueName][moduleToCheck])
- continue;
- seenModules[queueName][moduleToCheck] = true;
- requiredModules[queueName] = requiredModules[queueName] || [];
- requiredModules[queueName].push(moduleToCheck);
- var newModules = getModuleDependencies(sources, sources[queueName][moduleToCheck], queueName);
- var newModulesKeys = Object.keys(newModules);
- for (var j = 0; j < newModulesKeys.length; j++) {
- modulesQueue[newModulesKeys[j]] = modulesQueue[newModulesKeys[j]] || [];
- modulesQueue[newModulesKeys[j]] = modulesQueue[newModulesKeys[j]].concat(newModules[newModulesKeys[j]]);
- }
- }
- }
- return requiredModules;
- }
- module3.exports = function(moduleId, options2) {
- options2 = options2 || {};
- var sources = {
- main: __webpack_require__2.m
- };
- var requiredModules = options2.all ? { main: Object.keys(sources.main) } : getRequiredModules(sources, moduleId);
- var src = "";
- Object.keys(requiredModules).filter(function(m) {
- return m !== "main";
- }).forEach(function(module4) {
- var entryModule = 0;
- while (requiredModules[module4][entryModule]) {
- entryModule++;
- }
- requiredModules[module4].push(entryModule);
- sources[module4][entryModule] = "(function(module, exports, __webpack_require__) { module.exports = __webpack_require__; })";
- src = src + "var " + module4 + " = (" + webpackBootstrapFunc.toString().replace("ENTRY_MODULE", JSON.stringify(entryModule)) + ")({" + requiredModules[module4].map(function(id) {
- return "" + JSON.stringify(id) + ": " + sources[module4][id].toString();
- }).join(",") + "});\n";
- });
- src = src + "new ((" + webpackBootstrapFunc.toString().replace("ENTRY_MODULE", JSON.stringify(moduleId)) + ")({" + requiredModules.main.map(function(id) {
- return "" + JSON.stringify(id) + ": " + sources.main[id].toString();
- }).join(",") + "}))(self);";
- var blob = new window.Blob([src], { type: "text/javascript" });
- if (options2.bare) {
- return blob;
- }
- var URL2 = window.URL || window.webkitURL || window.mozURL || window.msURL;
- var workerUrl = URL2.createObjectURL(blob);
- var worker = new window.Worker(workerUrl);
- worker.objectURL = workerUrl;
- return worker;
- };
- },
- "./src/config.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- __webpack_require__2.d(__webpack_exports__2, {
- "defaultConfig": function() {
- return defaultConfig;
- },
- "createDefaultConfig": function() {
- return createDefaultConfig;
- }
- });
- var defaultConfig = {
- enableWorker: false,
- enableStashBuffer: true,
- stashInitialSize: void 0,
- isLive: false,
- lazyLoad: true,
- lazyLoadMaxDuration: 3 * 60,
- lazyLoadRecoverDuration: 30,
- deferLoadAfterSourceOpen: true,
- autoCleanupMaxBackwardDuration: 3 * 60,
- autoCleanupMinBackwardDuration: 2 * 60,
- statisticsInfoReportInterval: 600,
- fixAudioTimestampGap: true,
- accurateSeek: false,
- seekType: "range",
- seekParamStart: "bstart",
- seekParamEnd: "bend",
- rangeLoadZeroStart: false,
- customSeekHandler: void 0,
- reuseRedirectedURL: false,
- headers: void 0,
- customLoader: void 0
- };
- function createDefaultConfig() {
- return Object.assign({}, defaultConfig);
- }
- },
- "./src/core/features.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _io_io_controller_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/io/io-controller.js");
- var _config_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/config.js");
- var Features = function() {
- function Features2() {
- }
- Features2.supportMSEH264Playback = function() {
- return window.MediaSource && window.MediaSource.isTypeSupported('video/mp4; codecs="avc1.42E01E,mp4a.40.2"');
- };
- Features2.supportNetworkStreamIO = function() {
- var ioctl = new _io_io_controller_js__WEBPACK_IMPORTED_MODULE_0__.default({}, (0, _config_js__WEBPACK_IMPORTED_MODULE_1__.createDefaultConfig)());
- var loaderType = ioctl.loaderType;
- ioctl.destroy();
- return loaderType == "fetch-stream-loader" || loaderType == "xhr-moz-chunked-loader";
- };
- Features2.getNetworkLoaderTypeName = function() {
- var ioctl = new _io_io_controller_js__WEBPACK_IMPORTED_MODULE_0__.default({}, (0, _config_js__WEBPACK_IMPORTED_MODULE_1__.createDefaultConfig)());
- var loaderType = ioctl.loaderType;
- ioctl.destroy();
- return loaderType;
- };
- Features2.supportNativeMediaPlayback = function(mimeType) {
- if (Features2.videoElement == void 0) {
- Features2.videoElement = window.document.createElement("video");
- }
- var canPlay = Features2.videoElement.canPlayType(mimeType);
- return canPlay === "probably" || canPlay == "maybe";
- };
- Features2.getFeatureList = function() {
- var features = {
- mseFlvPlayback: false,
- mseLiveFlvPlayback: false,
- networkStreamIO: false,
- networkLoaderName: "",
- nativeMP4H264Playback: false,
- nativeWebmVP8Playback: false,
- nativeWebmVP9Playback: false
- };
- features.mseFlvPlayback = Features2.supportMSEH264Playback();
- features.networkStreamIO = Features2.supportNetworkStreamIO();
- features.networkLoaderName = Features2.getNetworkLoaderTypeName();
- features.mseLiveFlvPlayback = features.mseFlvPlayback && features.networkStreamIO;
- features.nativeMP4H264Playback = Features2.supportNativeMediaPlayback('video/mp4; codecs="avc1.42001E, mp4a.40.2"');
- features.nativeWebmVP8Playback = Features2.supportNativeMediaPlayback('video/webm; codecs="vp8.0, vorbis"');
- features.nativeWebmVP9Playback = Features2.supportNativeMediaPlayback('video/webm; codecs="vp9"');
- return features;
- };
- return Features2;
- }();
- __webpack_exports__2["default"] = Features;
- },
- "./src/core/media-info.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var MediaInfo = function() {
- function MediaInfo2() {
- this.mimeType = null;
- this.duration = null;
- this.hasAudio = null;
- this.hasVideo = null;
- this.audioCodec = null;
- this.videoCodec = null;
- this.audioDataRate = null;
- this.videoDataRate = null;
- this.audioSampleRate = null;
- this.audioChannelCount = null;
- this.width = null;
- this.height = null;
- this.fps = null;
- this.profile = null;
- this.level = null;
- this.refFrames = null;
- this.chromaFormat = null;
- this.sarNum = null;
- this.sarDen = null;
- this.metadata = null;
- this.segments = null;
- this.segmentCount = null;
- this.hasKeyframesIndex = null;
- this.keyframesIndex = null;
- }
- MediaInfo2.prototype.isComplete = function() {
- var audioInfoComplete = this.hasAudio === false || this.hasAudio === true && this.audioCodec != null && this.audioSampleRate != null && this.audioChannelCount != null;
- var videoInfoComplete = this.hasVideo === false || this.hasVideo === true && this.videoCodec != null && this.width != null && this.height != null && this.fps != null && this.profile != null && this.level != null && this.refFrames != null && this.chromaFormat != null && this.sarNum != null && this.sarDen != null;
- return this.mimeType != null && this.duration != null && this.metadata != null && this.hasKeyframesIndex != null && audioInfoComplete && videoInfoComplete;
- };
- MediaInfo2.prototype.isSeekable = function() {
- return this.hasKeyframesIndex === true;
- };
- MediaInfo2.prototype.getNearestKeyframe = function(milliseconds) {
- if (this.keyframesIndex == null) {
- return null;
- }
- var table = this.keyframesIndex;
- var keyframeIdx = this._search(table.times, milliseconds);
- return {
- index: keyframeIdx,
- milliseconds: table.times[keyframeIdx],
- fileposition: table.filepositions[keyframeIdx]
- };
- };
- MediaInfo2.prototype._search = function(list, value) {
- var idx = 0;
- var last = list.length - 1;
- var mid = 0;
- var lbound = 0;
- var ubound = last;
- if (value < list[0]) {
- idx = 0;
- lbound = ubound + 1;
- }
- while (lbound <= ubound) {
- mid = lbound + Math.floor((ubound - lbound) / 2);
- if (mid === last || value >= list[mid] && value < list[mid + 1]) {
- idx = mid;
- break;
- } else if (list[mid] < value) {
- lbound = mid + 1;
- } else {
- ubound = mid - 1;
- }
- }
- return idx;
- };
- return MediaInfo2;
- }();
- __webpack_exports__2["default"] = MediaInfo;
- },
- "./src/core/media-segment-info.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- __webpack_require__2.d(__webpack_exports__2, {
- "SampleInfo": function() {
- return SampleInfo;
- },
- "MediaSegmentInfo": function() {
- return MediaSegmentInfo;
- },
- "IDRSampleList": function() {
- return IDRSampleList;
- },
- "MediaSegmentInfoList": function() {
- return MediaSegmentInfoList;
- }
- });
- var SampleInfo = function() {
- function SampleInfo2(dts, pts, duration5, originalDts, isSync) {
- this.dts = dts;
- this.pts = pts;
- this.duration = duration5;
- this.originalDts = originalDts;
- this.isSyncPoint = isSync;
- this.fileposition = null;
- }
- return SampleInfo2;
- }();
- var MediaSegmentInfo = function() {
- function MediaSegmentInfo2() {
- this.beginDts = 0;
- this.endDts = 0;
- this.beginPts = 0;
- this.endPts = 0;
- this.originalBeginDts = 0;
- this.originalEndDts = 0;
- this.syncPoints = [];
- this.firstSample = null;
- this.lastSample = null;
- }
- MediaSegmentInfo2.prototype.appendSyncPoint = function(sampleInfo) {
- sampleInfo.isSyncPoint = true;
- this.syncPoints.push(sampleInfo);
- };
- return MediaSegmentInfo2;
- }();
- var IDRSampleList = function() {
- function IDRSampleList2() {
- this._list = [];
- }
- IDRSampleList2.prototype.clear = function() {
- this._list = [];
- };
- IDRSampleList2.prototype.appendArray = function(syncPoints) {
- var list = this._list;
- if (syncPoints.length === 0) {
- return;
- }
- if (list.length > 0 && syncPoints[0].originalDts < list[list.length - 1].originalDts) {
- this.clear();
- }
- Array.prototype.push.apply(list, syncPoints);
- };
- IDRSampleList2.prototype.getLastSyncPointBeforeDts = function(dts) {
- if (this._list.length == 0) {
- return null;
- }
- var list = this._list;
- var idx = 0;
- var last = list.length - 1;
- var mid = 0;
- var lbound = 0;
- var ubound = last;
- if (dts < list[0].dts) {
- idx = 0;
- lbound = ubound + 1;
- }
- while (lbound <= ubound) {
- mid = lbound + Math.floor((ubound - lbound) / 2);
- if (mid === last || dts >= list[mid].dts && dts < list[mid + 1].dts) {
- idx = mid;
- break;
- } else if (list[mid].dts < dts) {
- lbound = mid + 1;
- } else {
- ubound = mid - 1;
- }
- }
- return this._list[idx];
- };
- return IDRSampleList2;
- }();
- var MediaSegmentInfoList = function() {
- function MediaSegmentInfoList2(type2) {
- this._type = type2;
- this._list = [];
- this._lastAppendLocation = -1;
- }
- Object.defineProperty(MediaSegmentInfoList2.prototype, "type", {
- get: function() {
- return this._type;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(MediaSegmentInfoList2.prototype, "length", {
- get: function() {
- return this._list.length;
- },
- enumerable: false,
- configurable: true
- });
- MediaSegmentInfoList2.prototype.isEmpty = function() {
- return this._list.length === 0;
- };
- MediaSegmentInfoList2.prototype.clear = function() {
- this._list = [];
- this._lastAppendLocation = -1;
- };
- MediaSegmentInfoList2.prototype._searchNearestSegmentBefore = function(originalBeginDts) {
- var list = this._list;
- if (list.length === 0) {
- return -2;
- }
- var last = list.length - 1;
- var mid = 0;
- var lbound = 0;
- var ubound = last;
- var idx = 0;
- if (originalBeginDts < list[0].originalBeginDts) {
- idx = -1;
- return idx;
- }
- while (lbound <= ubound) {
- mid = lbound + Math.floor((ubound - lbound) / 2);
- if (mid === last || originalBeginDts > list[mid].lastSample.originalDts && originalBeginDts < list[mid + 1].originalBeginDts) {
- idx = mid;
- break;
- } else if (list[mid].originalBeginDts < originalBeginDts) {
- lbound = mid + 1;
- } else {
- ubound = mid - 1;
- }
- }
- return idx;
- };
- MediaSegmentInfoList2.prototype._searchNearestSegmentAfter = function(originalBeginDts) {
- return this._searchNearestSegmentBefore(originalBeginDts) + 1;
- };
- MediaSegmentInfoList2.prototype.append = function(mediaSegmentInfo) {
- var list = this._list;
- var msi = mediaSegmentInfo;
- var lastAppendIdx = this._lastAppendLocation;
- var insertIdx = 0;
- if (lastAppendIdx !== -1 && lastAppendIdx < list.length && msi.originalBeginDts >= list[lastAppendIdx].lastSample.originalDts && (lastAppendIdx === list.length - 1 || lastAppendIdx < list.length - 1 && msi.originalBeginDts < list[lastAppendIdx + 1].originalBeginDts)) {
- insertIdx = lastAppendIdx + 1;
- } else {
- if (list.length > 0) {
- insertIdx = this._searchNearestSegmentBefore(msi.originalBeginDts) + 1;
- }
- }
- this._lastAppendLocation = insertIdx;
- this._list.splice(insertIdx, 0, msi);
- };
- MediaSegmentInfoList2.prototype.getLastSegmentBefore = function(originalBeginDts) {
- var idx = this._searchNearestSegmentBefore(originalBeginDts);
- if (idx >= 0) {
- return this._list[idx];
- } else {
- return null;
- }
- };
- MediaSegmentInfoList2.prototype.getLastSampleBefore = function(originalBeginDts) {
- var segment = this.getLastSegmentBefore(originalBeginDts);
- if (segment != null) {
- return segment.lastSample;
- } else {
- return null;
- }
- };
- MediaSegmentInfoList2.prototype.getLastSyncPointBefore = function(originalBeginDts) {
- var segmentIdx = this._searchNearestSegmentBefore(originalBeginDts);
- var syncPoints = this._list[segmentIdx].syncPoints;
- while (syncPoints.length === 0 && segmentIdx > 0) {
- segmentIdx--;
- syncPoints = this._list[segmentIdx].syncPoints;
- }
- if (syncPoints.length > 0) {
- return syncPoints[syncPoints.length - 1];
- } else {
- return null;
- }
- };
- return MediaSegmentInfoList2;
- }();
- },
- "./src/core/mse-controller.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./node_modules/events/events.js");
- var events__WEBPACK_IMPORTED_MODULE_0___default = /* @__PURE__ */ __webpack_require__2.n(events__WEBPACK_IMPORTED_MODULE_0__);
- var _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/utils/logger.js");
- var _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/utils/browser.js");
- var _mse_events_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__2("./src/core/mse-events.js");
- var _media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__2("./src/core/media-segment-info.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__2("./src/utils/exception.js");
- var MSEController = function() {
- function MSEController2(config) {
- this.TAG = "MSEController";
- this._config = config;
- this._emitter = new (events__WEBPACK_IMPORTED_MODULE_0___default())();
- if (this._config.isLive && this._config.autoCleanupSourceBuffer == void 0) {
- this._config.autoCleanupSourceBuffer = true;
- }
- this.e = {
- onSourceOpen: this._onSourceOpen.bind(this),
- onSourceEnded: this._onSourceEnded.bind(this),
- onSourceClose: this._onSourceClose.bind(this),
- onSourceBufferError: this._onSourceBufferError.bind(this),
- onSourceBufferUpdateEnd: this._onSourceBufferUpdateEnd.bind(this)
- };
- this._mediaSource = null;
- this._mediaSourceObjectURL = null;
- this._mediaElement = null;
- this._isBufferFull = false;
- this._hasPendingEos = false;
- this._requireSetMediaDuration = false;
- this._pendingMediaDuration = 0;
- this._pendingSourceBufferInit = [];
- this._mimeTypes = {
- video: null,
- audio: null
- };
- this._sourceBuffers = {
- video: null,
- audio: null
- };
- this._lastInitSegments = {
- video: null,
- audio: null
- };
- this._pendingSegments = {
- video: [],
- audio: []
- };
- this._pendingRemoveRanges = {
- video: [],
- audio: []
- };
- this._idrList = new _media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__.IDRSampleList();
- }
- MSEController2.prototype.destroy = function() {
- if (this._mediaElement || this._mediaSource) {
- this.detachMediaElement();
- }
- this.e = null;
- this._emitter.removeAllListeners();
- this._emitter = null;
- };
- MSEController2.prototype.on = function(event2, listener) {
- this._emitter.addListener(event2, listener);
- };
- MSEController2.prototype.off = function(event2, listener) {
- this._emitter.removeListener(event2, listener);
- };
- MSEController2.prototype.attachMediaElement = function(mediaElement) {
- if (this._mediaSource) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_5__.IllegalStateException("MediaSource has been attached to an HTMLMediaElement!");
- }
- var ms = this._mediaSource = new window.MediaSource();
- ms.addEventListener("sourceopen", this.e.onSourceOpen);
- ms.addEventListener("sourceended", this.e.onSourceEnded);
- ms.addEventListener("sourceclose", this.e.onSourceClose);
- this._mediaElement = mediaElement;
- this._mediaSourceObjectURL = window.URL.createObjectURL(this._mediaSource);
- mediaElement.src = this._mediaSourceObjectURL;
- };
- MSEController2.prototype.detachMediaElement = function() {
- if (this._mediaSource) {
- var ms = this._mediaSource;
- for (var type2 in this._sourceBuffers) {
- var ps = this._pendingSegments[type2];
- ps.splice(0, ps.length);
- this._pendingSegments[type2] = null;
- this._pendingRemoveRanges[type2] = null;
- this._lastInitSegments[type2] = null;
- var sb = this._sourceBuffers[type2];
- if (sb) {
- if (ms.readyState !== "closed") {
- try {
- ms.removeSourceBuffer(sb);
- } catch (error) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.e(this.TAG, error.message);
- }
- sb.removeEventListener("error", this.e.onSourceBufferError);
- sb.removeEventListener("updateend", this.e.onSourceBufferUpdateEnd);
- }
- this._mimeTypes[type2] = null;
- this._sourceBuffers[type2] = null;
- }
- }
- if (ms.readyState === "open") {
- try {
- ms.endOfStream();
- } catch (error) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.e(this.TAG, error.message);
- }
- }
- ms.removeEventListener("sourceopen", this.e.onSourceOpen);
- ms.removeEventListener("sourceended", this.e.onSourceEnded);
- ms.removeEventListener("sourceclose", this.e.onSourceClose);
- this._pendingSourceBufferInit = [];
- this._isBufferFull = false;
- this._idrList.clear();
- this._mediaSource = null;
- }
- if (this._mediaElement) {
- this._mediaElement.src = "";
- this._mediaElement.removeAttribute("src");
- this._mediaElement = null;
- }
- if (this._mediaSourceObjectURL) {
- window.URL.revokeObjectURL(this._mediaSourceObjectURL);
- this._mediaSourceObjectURL = null;
- }
- };
- MSEController2.prototype.appendInitSegment = function(initSegment, deferred) {
- if (!this._mediaSource || this._mediaSource.readyState !== "open") {
- this._pendingSourceBufferInit.push(initSegment);
- this._pendingSegments[initSegment.type].push(initSegment);
- return;
- }
- var is = initSegment;
- var mimeType = "" + is.container;
- if (is.codec && is.codec.length > 0) {
- mimeType += ";codecs=" + is.codec;
- }
- var firstInitSegment = false;
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.v(this.TAG, "Received Initialization Segment, mimeType: " + mimeType);
- this._lastInitSegments[is.type] = is;
- if (mimeType !== this._mimeTypes[is.type]) {
- if (!this._mimeTypes[is.type]) {
- firstInitSegment = true;
- try {
- var sb = this._sourceBuffers[is.type] = this._mediaSource.addSourceBuffer(mimeType);
- sb.addEventListener("error", this.e.onSourceBufferError);
- sb.addEventListener("updateend", this.e.onSourceBufferUpdateEnd);
- } catch (error) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.e(this.TAG, error.message);
- this._emitter.emit(_mse_events_js__WEBPACK_IMPORTED_MODULE_3__.default.ERROR, { code: error.code, msg: error.message });
- return;
- }
- } else {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.v(this.TAG, "Notice: " + is.type + " mimeType changed, origin: " + this._mimeTypes[is.type] + ", target: " + mimeType);
- }
- this._mimeTypes[is.type] = mimeType;
- }
- if (!deferred) {
- this._pendingSegments[is.type].push(is);
- }
- if (!firstInitSegment) {
- if (this._sourceBuffers[is.type] && !this._sourceBuffers[is.type].updating) {
- this._doAppendSegments();
- }
- }
- if (_utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.safari && is.container === "audio/mpeg" && is.mediaDuration > 0) {
- this._requireSetMediaDuration = true;
- this._pendingMediaDuration = is.mediaDuration / 1e3;
- this._updateMediaSourceDuration();
- }
- };
- MSEController2.prototype.appendMediaSegment = function(mediaSegment) {
- var ms = mediaSegment;
- this._pendingSegments[ms.type].push(ms);
- if (this._config.autoCleanupSourceBuffer && this._needCleanupSourceBuffer()) {
- this._doCleanupSourceBuffer();
- }
- var sb = this._sourceBuffers[ms.type];
- if (sb && !sb.updating && !this._hasPendingRemoveRanges()) {
- this._doAppendSegments();
- }
- };
- MSEController2.prototype.seek = function(seconds) {
- for (var type2 in this._sourceBuffers) {
- if (!this._sourceBuffers[type2]) {
- continue;
- }
- var sb = this._sourceBuffers[type2];
- if (this._mediaSource.readyState === "open") {
- try {
- sb.abort();
- } catch (error) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.e(this.TAG, error.message);
- }
- }
- this._idrList.clear();
- var ps = this._pendingSegments[type2];
- ps.splice(0, ps.length);
- if (this._mediaSource.readyState === "closed") {
- continue;
- }
- for (var i2 = 0; i2 < sb.buffered.length; i2++) {
- var start2 = sb.buffered.start(i2);
- var end = sb.buffered.end(i2);
- this._pendingRemoveRanges[type2].push({ start: start2, end });
- }
- if (!sb.updating) {
- this._doRemoveRanges();
- }
- if (_utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.safari) {
- var lastInitSegment = this._lastInitSegments[type2];
- if (lastInitSegment) {
- this._pendingSegments[type2].push(lastInitSegment);
- if (!sb.updating) {
- this._doAppendSegments();
- }
- }
- }
- }
- };
- MSEController2.prototype.endOfStream = function() {
- var ms = this._mediaSource;
- var sb = this._sourceBuffers;
- if (!ms || ms.readyState !== "open") {
- if (ms && ms.readyState === "closed" && this._hasPendingSegments()) {
- this._hasPendingEos = true;
- }
- return;
- }
- if (sb.video && sb.video.updating || sb.audio && sb.audio.updating) {
- this._hasPendingEos = true;
- } else {
- this._hasPendingEos = false;
- ms.endOfStream();
- }
- };
- MSEController2.prototype.getNearestKeyframe = function(dts) {
- return this._idrList.getLastSyncPointBeforeDts(dts);
- };
- MSEController2.prototype._needCleanupSourceBuffer = function() {
- if (!this._config.autoCleanupSourceBuffer) {
- return false;
- }
- var currentTime = this._mediaElement.currentTime;
- for (var type2 in this._sourceBuffers) {
- var sb = this._sourceBuffers[type2];
- if (sb) {
- var buffered = sb.buffered;
- if (buffered.length >= 1) {
- if (currentTime - buffered.start(0) >= this._config.autoCleanupMaxBackwardDuration) {
- return true;
- }
- }
- }
- }
- return false;
- };
- MSEController2.prototype._doCleanupSourceBuffer = function() {
- var currentTime = this._mediaElement.currentTime;
- for (var type2 in this._sourceBuffers) {
- var sb = this._sourceBuffers[type2];
- if (sb) {
- var buffered = sb.buffered;
- var doRemove = false;
- for (var i2 = 0; i2 < buffered.length; i2++) {
- var start2 = buffered.start(i2);
- var end = buffered.end(i2);
- if (start2 <= currentTime && currentTime < end + 3) {
- if (currentTime - start2 >= this._config.autoCleanupMaxBackwardDuration) {
- doRemove = true;
- var removeEnd = currentTime - this._config.autoCleanupMinBackwardDuration;
- this._pendingRemoveRanges[type2].push({ start: start2, end: removeEnd });
- }
- } else if (end < currentTime) {
- doRemove = true;
- this._pendingRemoveRanges[type2].push({ start: start2, end });
- }
- }
- if (doRemove && !sb.updating) {
- this._doRemoveRanges();
- }
- }
- }
- };
- MSEController2.prototype._updateMediaSourceDuration = function() {
- var sb = this._sourceBuffers;
- if (this._mediaElement.readyState === 0 || this._mediaSource.readyState !== "open") {
- return;
- }
- if (sb.video && sb.video.updating || sb.audio && sb.audio.updating) {
- return;
- }
- var current = this._mediaSource.duration;
- var target = this._pendingMediaDuration;
- if (target > 0 && (isNaN(current) || target > current)) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.v(this.TAG, "Update MediaSource duration from " + current + " to " + target);
- this._mediaSource.duration = target;
- }
- this._requireSetMediaDuration = false;
- this._pendingMediaDuration = 0;
- };
- MSEController2.prototype._doRemoveRanges = function() {
- for (var type2 in this._pendingRemoveRanges) {
- if (!this._sourceBuffers[type2] || this._sourceBuffers[type2].updating) {
- continue;
- }
- var sb = this._sourceBuffers[type2];
- var ranges = this._pendingRemoveRanges[type2];
- while (ranges.length && !sb.updating) {
- var range3 = ranges.shift();
- sb.remove(range3.start, range3.end);
- }
- }
- };
- MSEController2.prototype._doAppendSegments = function() {
- var pendingSegments = this._pendingSegments;
- for (var type2 in pendingSegments) {
- if (!this._sourceBuffers[type2] || this._sourceBuffers[type2].updating) {
- continue;
- }
- if (pendingSegments[type2].length > 0) {
- var segment = pendingSegments[type2].shift();
- if (segment.timestampOffset) {
- var currentOffset = this._sourceBuffers[type2].timestampOffset;
- var targetOffset = segment.timestampOffset / 1e3;
- var delta = Math.abs(currentOffset - targetOffset);
- if (delta > 0.1) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.v(this.TAG, "Update MPEG audio timestampOffset from " + currentOffset + " to " + targetOffset);
- this._sourceBuffers[type2].timestampOffset = targetOffset;
- }
- delete segment.timestampOffset;
- }
- if (!segment.data || segment.data.byteLength === 0) {
- continue;
- }
- try {
- this._sourceBuffers[type2].appendBuffer(segment.data);
- this._isBufferFull = false;
- if (type2 === "video" && segment.hasOwnProperty("info")) {
- this._idrList.appendArray(segment.info.syncPoints);
- }
- } catch (error) {
- this._pendingSegments[type2].unshift(segment);
- if (error.code === 22) {
- if (!this._isBufferFull) {
- this._emitter.emit(_mse_events_js__WEBPACK_IMPORTED_MODULE_3__.default.BUFFER_FULL);
- }
- this._isBufferFull = true;
- } else {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.e(this.TAG, error.message);
- this._emitter.emit(_mse_events_js__WEBPACK_IMPORTED_MODULE_3__.default.ERROR, { code: error.code, msg: error.message });
- }
- }
- }
- }
- };
- MSEController2.prototype._onSourceOpen = function() {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.v(this.TAG, "MediaSource onSourceOpen");
- this._mediaSource.removeEventListener("sourceopen", this.e.onSourceOpen);
- if (this._pendingSourceBufferInit.length > 0) {
- var pendings = this._pendingSourceBufferInit;
- while (pendings.length) {
- var segment = pendings.shift();
- this.appendInitSegment(segment, true);
- }
- }
- if (this._hasPendingSegments()) {
- this._doAppendSegments();
- }
- this._emitter.emit(_mse_events_js__WEBPACK_IMPORTED_MODULE_3__.default.SOURCE_OPEN);
- };
- MSEController2.prototype._onSourceEnded = function() {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.v(this.TAG, "MediaSource onSourceEnded");
- };
- MSEController2.prototype._onSourceClose = function() {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.v(this.TAG, "MediaSource onSourceClose");
- if (this._mediaSource && this.e != null) {
- this._mediaSource.removeEventListener("sourceopen", this.e.onSourceOpen);
- this._mediaSource.removeEventListener("sourceended", this.e.onSourceEnded);
- this._mediaSource.removeEventListener("sourceclose", this.e.onSourceClose);
- }
- };
- MSEController2.prototype._hasPendingSegments = function() {
- var ps = this._pendingSegments;
- return ps.video.length > 0 || ps.audio.length > 0;
- };
- MSEController2.prototype._hasPendingRemoveRanges = function() {
- var prr = this._pendingRemoveRanges;
- return prr.video.length > 0 || prr.audio.length > 0;
- };
- MSEController2.prototype._onSourceBufferUpdateEnd = function() {
- if (this._requireSetMediaDuration) {
- this._updateMediaSourceDuration();
- } else if (this._hasPendingRemoveRanges()) {
- this._doRemoveRanges();
- } else if (this._hasPendingSegments()) {
- this._doAppendSegments();
- } else if (this._hasPendingEos) {
- this.endOfStream();
- }
- this._emitter.emit(_mse_events_js__WEBPACK_IMPORTED_MODULE_3__.default.UPDATE_END);
- };
- MSEController2.prototype._onSourceBufferError = function(e) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.e(this.TAG, "SourceBuffer Error: " + e);
- };
- return MSEController2;
- }();
- __webpack_exports__2["default"] = MSEController;
- },
- "./src/core/mse-events.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var MSEEvents = {
- ERROR: "error",
- SOURCE_OPEN: "source_open",
- UPDATE_END: "update_end",
- BUFFER_FULL: "buffer_full"
- };
- __webpack_exports__2["default"] = MSEEvents;
- },
- "./src/core/transmuxer.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./node_modules/events/events.js");
- var events__WEBPACK_IMPORTED_MODULE_0___default = /* @__PURE__ */ __webpack_require__2.n(events__WEBPACK_IMPORTED_MODULE_0__);
- var webworkify_webpack__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./node_modules/webworkify-webpack/index.js");
- var webworkify_webpack__WEBPACK_IMPORTED_MODULE_1___default = /* @__PURE__ */ __webpack_require__2.n(webworkify_webpack__WEBPACK_IMPORTED_MODULE_1__);
- var _utils_logger_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/utils/logger.js");
- var _utils_logging_control_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__2("./src/utils/logging-control.js");
- var _transmuxing_controller_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__2("./src/core/transmuxing-controller.js");
- var _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__2("./src/core/transmuxing-events.js");
- var _media_info_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__2("./src/core/media-info.js");
- var Transmuxer = function() {
- function Transmuxer2(mediaDataSource, config) {
- this.TAG = "Transmuxer";
- this._emitter = new (events__WEBPACK_IMPORTED_MODULE_0___default())();
- if (config.enableWorker && typeof Worker !== "undefined") {
- try {
- this._worker = webworkify_webpack__WEBPACK_IMPORTED_MODULE_1___default()("./src/core/transmuxing-worker.js");
- this._workerDestroying = false;
- this._worker.addEventListener("message", this._onWorkerMessage.bind(this));
- this._worker.postMessage({ cmd: "init", param: [mediaDataSource, config] });
- this.e = {
- onLoggingConfigChanged: this._onLoggingConfigChanged.bind(this)
- };
- _utils_logging_control_js__WEBPACK_IMPORTED_MODULE_3__.default.registerListener(this.e.onLoggingConfigChanged);
- this._worker.postMessage({ cmd: "logging_config", param: _utils_logging_control_js__WEBPACK_IMPORTED_MODULE_3__.default.getConfig() });
- } catch (error) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_2__.default.e(this.TAG, "Error while initialize transmuxing worker, fallback to inline transmuxing");
- this._worker = null;
- this._controller = new _transmuxing_controller_js__WEBPACK_IMPORTED_MODULE_4__.default(mediaDataSource, config);
- }
- } else {
- this._controller = new _transmuxing_controller_js__WEBPACK_IMPORTED_MODULE_4__.default(mediaDataSource, config);
- }
- if (this._controller) {
- var ctl = this._controller;
- ctl.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.IO_ERROR, this._onIOError.bind(this));
- ctl.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.DEMUX_ERROR, this._onDemuxError.bind(this));
- ctl.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.INIT_SEGMENT, this._onInitSegment.bind(this));
- ctl.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.MEDIA_SEGMENT, this._onMediaSegment.bind(this));
- ctl.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.LOADING_COMPLETE, this._onLoadingComplete.bind(this));
- ctl.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.RECOVERED_EARLY_EOF, this._onRecoveredEarlyEof.bind(this));
- ctl.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.MEDIA_INFO, this._onMediaInfo.bind(this));
- ctl.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.METADATA_ARRIVED, this._onMetaDataArrived.bind(this));
- ctl.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.SCRIPTDATA_ARRIVED, this._onScriptDataArrived.bind(this));
- ctl.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.STATISTICS_INFO, this._onStatisticsInfo.bind(this));
- ctl.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.RECOMMEND_SEEKPOINT, this._onRecommendSeekpoint.bind(this));
- }
- }
- Transmuxer2.prototype.destroy = function() {
- if (this._worker) {
- if (!this._workerDestroying) {
- this._workerDestroying = true;
- this._worker.postMessage({ cmd: "destroy" });
- _utils_logging_control_js__WEBPACK_IMPORTED_MODULE_3__.default.removeListener(this.e.onLoggingConfigChanged);
- this.e = null;
- }
- } else {
- this._controller.destroy();
- this._controller = null;
- }
- this._emitter.removeAllListeners();
- this._emitter = null;
- };
- Transmuxer2.prototype.on = function(event2, listener) {
- this._emitter.addListener(event2, listener);
- };
- Transmuxer2.prototype.off = function(event2, listener) {
- this._emitter.removeListener(event2, listener);
- };
- Transmuxer2.prototype.hasWorker = function() {
- return this._worker != null;
- };
- Transmuxer2.prototype.open = function() {
- if (this._worker) {
- this._worker.postMessage({ cmd: "start" });
- } else {
- this._controller.start();
- }
- };
- Transmuxer2.prototype.close = function() {
- if (this._worker) {
- this._worker.postMessage({ cmd: "stop" });
- } else {
- this._controller.stop();
- }
- };
- Transmuxer2.prototype.seek = function(milliseconds) {
- if (this._worker) {
- this._worker.postMessage({ cmd: "seek", param: milliseconds });
- } else {
- this._controller.seek(milliseconds);
- }
- };
- Transmuxer2.prototype.pause = function() {
- if (this._worker) {
- this._worker.postMessage({ cmd: "pause" });
- } else {
- this._controller.pause();
- }
- };
- Transmuxer2.prototype.resume = function() {
- if (this._worker) {
- this._worker.postMessage({ cmd: "resume" });
- } else {
- this._controller.resume();
- }
- };
- Transmuxer2.prototype._onInitSegment = function(type2, initSegment) {
- var _this = this;
- Promise.resolve().then(function() {
- _this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.INIT_SEGMENT, type2, initSegment);
- });
- };
- Transmuxer2.prototype._onMediaSegment = function(type2, mediaSegment) {
- var _this = this;
- Promise.resolve().then(function() {
- _this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.MEDIA_SEGMENT, type2, mediaSegment);
- });
- };
- Transmuxer2.prototype._onLoadingComplete = function() {
- var _this = this;
- Promise.resolve().then(function() {
- _this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.LOADING_COMPLETE);
- });
- };
- Transmuxer2.prototype._onRecoveredEarlyEof = function() {
- var _this = this;
- Promise.resolve().then(function() {
- _this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.RECOVERED_EARLY_EOF);
- });
- };
- Transmuxer2.prototype._onMediaInfo = function(mediaInfo) {
- var _this = this;
- Promise.resolve().then(function() {
- _this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.MEDIA_INFO, mediaInfo);
- });
- };
- Transmuxer2.prototype._onMetaDataArrived = function(metadata) {
- var _this = this;
- Promise.resolve().then(function() {
- _this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.METADATA_ARRIVED, metadata);
- });
- };
- Transmuxer2.prototype._onScriptDataArrived = function(data) {
- var _this = this;
- Promise.resolve().then(function() {
- _this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.SCRIPTDATA_ARRIVED, data);
- });
- };
- Transmuxer2.prototype._onStatisticsInfo = function(statisticsInfo) {
- var _this = this;
- Promise.resolve().then(function() {
- _this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.STATISTICS_INFO, statisticsInfo);
- });
- };
- Transmuxer2.prototype._onIOError = function(type2, info) {
- var _this = this;
- Promise.resolve().then(function() {
- _this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.IO_ERROR, type2, info);
- });
- };
- Transmuxer2.prototype._onDemuxError = function(type2, info) {
- var _this = this;
- Promise.resolve().then(function() {
- _this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.DEMUX_ERROR, type2, info);
- });
- };
- Transmuxer2.prototype._onRecommendSeekpoint = function(milliseconds) {
- var _this = this;
- Promise.resolve().then(function() {
- _this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.RECOMMEND_SEEKPOINT, milliseconds);
- });
- };
- Transmuxer2.prototype._onLoggingConfigChanged = function(config) {
- if (this._worker) {
- this._worker.postMessage({ cmd: "logging_config", param: config });
- }
- };
- Transmuxer2.prototype._onWorkerMessage = function(e) {
- var message = e.data;
- var data = message.data;
- if (message.msg === "destroyed" || this._workerDestroying) {
- this._workerDestroying = false;
- this._worker.terminate();
- this._worker = null;
- return;
- }
- switch (message.msg) {
- case _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.INIT_SEGMENT:
- case _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.MEDIA_SEGMENT:
- this._emitter.emit(message.msg, data.type, data.data);
- break;
- case _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.LOADING_COMPLETE:
- case _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.RECOVERED_EARLY_EOF:
- this._emitter.emit(message.msg);
- break;
- case _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.MEDIA_INFO:
- Object.setPrototypeOf(data, _media_info_js__WEBPACK_IMPORTED_MODULE_6__.default.prototype);
- this._emitter.emit(message.msg, data);
- break;
- case _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.METADATA_ARRIVED:
- case _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.SCRIPTDATA_ARRIVED:
- case _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.STATISTICS_INFO:
- this._emitter.emit(message.msg, data);
- break;
- case _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.IO_ERROR:
- case _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.DEMUX_ERROR:
- this._emitter.emit(message.msg, data.type, data.info);
- break;
- case _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.RECOMMEND_SEEKPOINT:
- this._emitter.emit(message.msg, data);
- break;
- case "logcat_callback":
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_2__.default.emitter.emit("log", data.type, data.logcat);
- break;
- }
- };
- return Transmuxer2;
- }();
- __webpack_exports__2["default"] = Transmuxer;
- },
- "./src/core/transmuxing-controller.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./node_modules/events/events.js");
- var events__WEBPACK_IMPORTED_MODULE_0___default = /* @__PURE__ */ __webpack_require__2.n(events__WEBPACK_IMPORTED_MODULE_0__);
- var _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/utils/logger.js");
- var _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/utils/browser.js");
- var _media_info_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__2("./src/core/media-info.js");
- var _demux_flv_demuxer_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__2("./src/demux/flv-demuxer.js");
- var _remux_mp4_remuxer_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__2("./src/remux/mp4-remuxer.js");
- var _demux_demux_errors_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__2("./src/demux/demux-errors.js");
- var _io_io_controller_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__2("./src/io/io-controller.js");
- var _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__2("./src/core/transmuxing-events.js");
- var TransmuxingController = function() {
- function TransmuxingController2(mediaDataSource, config) {
- this.TAG = "TransmuxingController";
- this._emitter = new (events__WEBPACK_IMPORTED_MODULE_0___default())();
- this._config = config;
- if (!mediaDataSource.segments) {
- mediaDataSource.segments = [{
- duration: mediaDataSource.duration,
- filesize: mediaDataSource.filesize,
- url: mediaDataSource.url
- }];
- }
- if (typeof mediaDataSource.cors !== "boolean") {
- mediaDataSource.cors = true;
- }
- if (typeof mediaDataSource.withCredentials !== "boolean") {
- mediaDataSource.withCredentials = false;
- }
- this._mediaDataSource = mediaDataSource;
- this._currentSegmentIndex = 0;
- var totalDuration = 0;
- this._mediaDataSource.segments.forEach(function(segment) {
- segment.timestampBase = totalDuration;
- totalDuration += segment.duration;
- segment.cors = mediaDataSource.cors;
- segment.withCredentials = mediaDataSource.withCredentials;
- if (config.referrerPolicy) {
- segment.referrerPolicy = config.referrerPolicy;
- }
- });
- if (!isNaN(totalDuration) && this._mediaDataSource.duration !== totalDuration) {
- this._mediaDataSource.duration = totalDuration;
- }
- this._mediaInfo = null;
- this._demuxer = null;
- this._remuxer = null;
- this._ioctl = null;
- this._pendingSeekTime = null;
- this._pendingResolveSeekPoint = null;
- this._statisticsReporter = null;
- }
- TransmuxingController2.prototype.destroy = function() {
- this._mediaInfo = null;
- this._mediaDataSource = null;
- if (this._statisticsReporter) {
- this._disableStatisticsReporter();
- }
- if (this._ioctl) {
- this._ioctl.destroy();
- this._ioctl = null;
- }
- if (this._demuxer) {
- this._demuxer.destroy();
- this._demuxer = null;
- }
- if (this._remuxer) {
- this._remuxer.destroy();
- this._remuxer = null;
- }
- this._emitter.removeAllListeners();
- this._emitter = null;
- };
- TransmuxingController2.prototype.on = function(event2, listener) {
- this._emitter.addListener(event2, listener);
- };
- TransmuxingController2.prototype.off = function(event2, listener) {
- this._emitter.removeListener(event2, listener);
- };
- TransmuxingController2.prototype.start = function() {
- this._loadSegment(0);
- this._enableStatisticsReporter();
- };
- TransmuxingController2.prototype._loadSegment = function(segmentIndex, optionalFrom) {
- this._currentSegmentIndex = segmentIndex;
- var dataSource = this._mediaDataSource.segments[segmentIndex];
- var ioctl = this._ioctl = new _io_io_controller_js__WEBPACK_IMPORTED_MODULE_7__.default(dataSource, this._config, segmentIndex);
- ioctl.onError = this._onIOException.bind(this);
- ioctl.onSeeked = this._onIOSeeked.bind(this);
- ioctl.onComplete = this._onIOComplete.bind(this);
- ioctl.onRedirect = this._onIORedirect.bind(this);
- ioctl.onRecoveredEarlyEof = this._onIORecoveredEarlyEof.bind(this);
- if (optionalFrom) {
- this._demuxer.bindDataSource(this._ioctl);
- } else {
- ioctl.onDataArrival = this._onInitChunkArrival.bind(this);
- }
- ioctl.open(optionalFrom);
- };
- TransmuxingController2.prototype.stop = function() {
- this._internalAbort();
- this._disableStatisticsReporter();
- };
- TransmuxingController2.prototype._internalAbort = function() {
- if (this._ioctl) {
- this._ioctl.destroy();
- this._ioctl = null;
- }
- };
- TransmuxingController2.prototype.pause = function() {
- if (this._ioctl && this._ioctl.isWorking()) {
- this._ioctl.pause();
- this._disableStatisticsReporter();
- }
- };
- TransmuxingController2.prototype.resume = function() {
- if (this._ioctl && this._ioctl.isPaused()) {
- this._ioctl.resume();
- this._enableStatisticsReporter();
- }
- };
- TransmuxingController2.prototype.seek = function(milliseconds) {
- if (this._mediaInfo == null || !this._mediaInfo.isSeekable()) {
- return;
- }
- var targetSegmentIndex = this._searchSegmentIndexContains(milliseconds);
- if (targetSegmentIndex === this._currentSegmentIndex) {
- var segmentInfo = this._mediaInfo.segments[targetSegmentIndex];
- if (segmentInfo == void 0) {
- this._pendingSeekTime = milliseconds;
- } else {
- var keyframe = segmentInfo.getNearestKeyframe(milliseconds);
- this._remuxer.seek(keyframe.milliseconds);
- this._ioctl.seek(keyframe.fileposition);
- this._pendingResolveSeekPoint = keyframe.milliseconds;
- }
- } else {
- var targetSegmentInfo = this._mediaInfo.segments[targetSegmentIndex];
- if (targetSegmentInfo == void 0) {
- this._pendingSeekTime = milliseconds;
- this._internalAbort();
- this._remuxer.seek();
- this._remuxer.insertDiscontinuity();
- this._loadSegment(targetSegmentIndex);
- } else {
- var keyframe = targetSegmentInfo.getNearestKeyframe(milliseconds);
- this._internalAbort();
- this._remuxer.seek(milliseconds);
- this._remuxer.insertDiscontinuity();
- this._demuxer.resetMediaInfo();
- this._demuxer.timestampBase = this._mediaDataSource.segments[targetSegmentIndex].timestampBase;
- this._loadSegment(targetSegmentIndex, keyframe.fileposition);
- this._pendingResolveSeekPoint = keyframe.milliseconds;
- this._reportSegmentMediaInfo(targetSegmentIndex);
- }
- }
- this._enableStatisticsReporter();
- };
- TransmuxingController2.prototype._searchSegmentIndexContains = function(milliseconds) {
- var segments = this._mediaDataSource.segments;
- var idx = segments.length - 1;
- for (var i2 = 0; i2 < segments.length; i2++) {
- if (milliseconds < segments[i2].timestampBase) {
- idx = i2 - 1;
- break;
- }
- }
- return idx;
- };
- TransmuxingController2.prototype._onInitChunkArrival = function(data, byteStart) {
- var _this = this;
- var probeData = null;
- var consumed = 0;
- if (byteStart > 0) {
- this._demuxer.bindDataSource(this._ioctl);
- this._demuxer.timestampBase = this._mediaDataSource.segments[this._currentSegmentIndex].timestampBase;
- consumed = this._demuxer.parseChunks(data, byteStart);
- } else if ((probeData = _demux_flv_demuxer_js__WEBPACK_IMPORTED_MODULE_4__.default.probe(data)).match) {
- this._demuxer = new _demux_flv_demuxer_js__WEBPACK_IMPORTED_MODULE_4__.default(probeData, this._config);
- if (!this._remuxer) {
- this._remuxer = new _remux_mp4_remuxer_js__WEBPACK_IMPORTED_MODULE_5__.default(this._config);
- }
- var mds = this._mediaDataSource;
- if (mds.duration != void 0 && !isNaN(mds.duration)) {
- this._demuxer.overridedDuration = mds.duration;
- }
- if (typeof mds.hasAudio === "boolean") {
- this._demuxer.overridedHasAudio = mds.hasAudio;
- }
- if (typeof mds.hasVideo === "boolean") {
- this._demuxer.overridedHasVideo = mds.hasVideo;
- }
- this._demuxer.timestampBase = mds.segments[this._currentSegmentIndex].timestampBase;
- this._demuxer.onError = this._onDemuxException.bind(this);
- this._demuxer.onMediaInfo = this._onMediaInfo.bind(this);
- this._demuxer.onMetaDataArrived = this._onMetaDataArrived.bind(this);
- this._demuxer.onScriptDataArrived = this._onScriptDataArrived.bind(this);
- this._remuxer.bindDataSource(this._demuxer.bindDataSource(this._ioctl));
- this._remuxer.onInitSegment = this._onRemuxerInitSegmentArrival.bind(this);
- this._remuxer.onMediaSegment = this._onRemuxerMediaSegmentArrival.bind(this);
- consumed = this._demuxer.parseChunks(data, byteStart);
- } else {
- probeData = null;
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.e(this.TAG, "Non-FLV, Unsupported media type!");
- Promise.resolve().then(function() {
- _this._internalAbort();
- });
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.DEMUX_ERROR, _demux_demux_errors_js__WEBPACK_IMPORTED_MODULE_6__.default.FORMAT_UNSUPPORTED, "Non-FLV, Unsupported media type");
- consumed = 0;
- }
- return consumed;
- };
- TransmuxingController2.prototype._onMediaInfo = function(mediaInfo) {
- var _this = this;
- if (this._mediaInfo == null) {
- this._mediaInfo = Object.assign({}, mediaInfo);
- this._mediaInfo.keyframesIndex = null;
- this._mediaInfo.segments = [];
- this._mediaInfo.segmentCount = this._mediaDataSource.segments.length;
- Object.setPrototypeOf(this._mediaInfo, _media_info_js__WEBPACK_IMPORTED_MODULE_3__.default.prototype);
- }
- var segmentInfo = Object.assign({}, mediaInfo);
- Object.setPrototypeOf(segmentInfo, _media_info_js__WEBPACK_IMPORTED_MODULE_3__.default.prototype);
- this._mediaInfo.segments[this._currentSegmentIndex] = segmentInfo;
- this._reportSegmentMediaInfo(this._currentSegmentIndex);
- if (this._pendingSeekTime != null) {
- Promise.resolve().then(function() {
- var target = _this._pendingSeekTime;
- _this._pendingSeekTime = null;
- _this.seek(target);
- });
- }
- };
- TransmuxingController2.prototype._onMetaDataArrived = function(metadata) {
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.METADATA_ARRIVED, metadata);
- };
- TransmuxingController2.prototype._onScriptDataArrived = function(data) {
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.SCRIPTDATA_ARRIVED, data);
- };
- TransmuxingController2.prototype._onIOSeeked = function() {
- this._remuxer.insertDiscontinuity();
- };
- TransmuxingController2.prototype._onIOComplete = function(extraData) {
- var segmentIndex = extraData;
- var nextSegmentIndex = segmentIndex + 1;
- if (nextSegmentIndex < this._mediaDataSource.segments.length) {
- this._internalAbort();
- this._remuxer.flushStashedSamples();
- this._loadSegment(nextSegmentIndex);
- } else {
- this._remuxer.flushStashedSamples();
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.LOADING_COMPLETE);
- this._disableStatisticsReporter();
- }
- };
- TransmuxingController2.prototype._onIORedirect = function(redirectedURL) {
- var segmentIndex = this._ioctl.extraData;
- this._mediaDataSource.segments[segmentIndex].redirectedURL = redirectedURL;
- };
- TransmuxingController2.prototype._onIORecoveredEarlyEof = function() {
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.RECOVERED_EARLY_EOF);
- };
- TransmuxingController2.prototype._onIOException = function(type2, info) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.e(this.TAG, "IOException: type = " + type2 + ", code = " + info.code + ", msg = " + info.msg);
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.IO_ERROR, type2, info);
- this._disableStatisticsReporter();
- };
- TransmuxingController2.prototype._onDemuxException = function(type2, info) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.e(this.TAG, "DemuxException: type = " + type2 + ", info = " + info);
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.DEMUX_ERROR, type2, info);
- };
- TransmuxingController2.prototype._onRemuxerInitSegmentArrival = function(type2, initSegment) {
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.INIT_SEGMENT, type2, initSegment);
- };
- TransmuxingController2.prototype._onRemuxerMediaSegmentArrival = function(type2, mediaSegment) {
- if (this._pendingSeekTime != null) {
- return;
- }
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.MEDIA_SEGMENT, type2, mediaSegment);
- if (this._pendingResolveSeekPoint != null && type2 === "video") {
- var syncPoints = mediaSegment.info.syncPoints;
- var seekpoint = this._pendingResolveSeekPoint;
- this._pendingResolveSeekPoint = null;
- if (_utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.safari && syncPoints.length > 0 && syncPoints[0].originalDts === seekpoint) {
- seekpoint = syncPoints[0].pts;
- }
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.RECOMMEND_SEEKPOINT, seekpoint);
- }
- };
- TransmuxingController2.prototype._enableStatisticsReporter = function() {
- if (this._statisticsReporter == null) {
- this._statisticsReporter = self.setInterval(this._reportStatisticsInfo.bind(this), this._config.statisticsInfoReportInterval);
- }
- };
- TransmuxingController2.prototype._disableStatisticsReporter = function() {
- if (this._statisticsReporter) {
- self.clearInterval(this._statisticsReporter);
- this._statisticsReporter = null;
- }
- };
- TransmuxingController2.prototype._reportSegmentMediaInfo = function(segmentIndex) {
- var segmentInfo = this._mediaInfo.segments[segmentIndex];
- var exportInfo = Object.assign({}, segmentInfo);
- exportInfo.duration = this._mediaInfo.duration;
- exportInfo.segmentCount = this._mediaInfo.segmentCount;
- delete exportInfo.segments;
- delete exportInfo.keyframesIndex;
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.MEDIA_INFO, exportInfo);
- };
- TransmuxingController2.prototype._reportStatisticsInfo = function() {
- var info = {};
- info.url = this._ioctl.currentURL;
- info.hasRedirect = this._ioctl.hasRedirect;
- if (info.hasRedirect) {
- info.redirectedURL = this._ioctl.currentRedirectedURL;
- }
- info.speed = this._ioctl.currentSpeed;
- info.loaderType = this._ioctl.loaderType;
- info.currentSegmentIndex = this._currentSegmentIndex;
- info.totalSegmentCount = this._mediaDataSource.segments.length;
- this._emitter.emit(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_8__.default.STATISTICS_INFO, info);
- };
- return TransmuxingController2;
- }();
- __webpack_exports__2["default"] = TransmuxingController;
- },
- "./src/core/transmuxing-events.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var TransmuxingEvents = {
- IO_ERROR: "io_error",
- DEMUX_ERROR: "demux_error",
- INIT_SEGMENT: "init_segment",
- MEDIA_SEGMENT: "media_segment",
- LOADING_COMPLETE: "loading_complete",
- RECOVERED_EARLY_EOF: "recovered_early_eof",
- MEDIA_INFO: "media_info",
- METADATA_ARRIVED: "metadata_arrived",
- SCRIPTDATA_ARRIVED: "scriptdata_arrived",
- STATISTICS_INFO: "statistics_info",
- RECOMMEND_SEEKPOINT: "recommend_seekpoint"
- };
- __webpack_exports__2["default"] = TransmuxingEvents;
- },
- "./src/core/transmuxing-worker.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _utils_logging_control_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/utils/logging-control.js");
- var _utils_polyfill_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/utils/polyfill.js");
- var _transmuxing_controller_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/core/transmuxing-controller.js");
- var _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__2("./src/core/transmuxing-events.js");
- var TransmuxingWorker = function(self2) {
- var controller = null;
- var logcatListener = onLogcatCallback.bind(this);
- _utils_polyfill_js__WEBPACK_IMPORTED_MODULE_1__.default.install();
- self2.addEventListener("message", function(e) {
- switch (e.data.cmd) {
- case "init":
- controller = new _transmuxing_controller_js__WEBPACK_IMPORTED_MODULE_2__.default(e.data.param[0], e.data.param[1]);
- controller.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.IO_ERROR, onIOError.bind(this));
- controller.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.DEMUX_ERROR, onDemuxError.bind(this));
- controller.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.INIT_SEGMENT, onInitSegment.bind(this));
- controller.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.MEDIA_SEGMENT, onMediaSegment.bind(this));
- controller.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.LOADING_COMPLETE, onLoadingComplete.bind(this));
- controller.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.RECOVERED_EARLY_EOF, onRecoveredEarlyEof.bind(this));
- controller.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.MEDIA_INFO, onMediaInfo.bind(this));
- controller.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.METADATA_ARRIVED, onMetaDataArrived.bind(this));
- controller.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.SCRIPTDATA_ARRIVED, onScriptDataArrived.bind(this));
- controller.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.STATISTICS_INFO, onStatisticsInfo.bind(this));
- controller.on(_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.RECOMMEND_SEEKPOINT, onRecommendSeekpoint.bind(this));
- break;
- case "destroy":
- if (controller) {
- controller.destroy();
- controller = null;
- }
- self2.postMessage({ msg: "destroyed" });
- break;
- case "start":
- controller.start();
- break;
- case "stop":
- controller.stop();
- break;
- case "seek":
- controller.seek(e.data.param);
- break;
- case "pause":
- controller.pause();
- break;
- case "resume":
- controller.resume();
- break;
- case "logging_config": {
- var config = e.data.param;
- _utils_logging_control_js__WEBPACK_IMPORTED_MODULE_0__.default.applyConfig(config);
- if (config.enableCallback === true) {
- _utils_logging_control_js__WEBPACK_IMPORTED_MODULE_0__.default.addLogListener(logcatListener);
- } else {
- _utils_logging_control_js__WEBPACK_IMPORTED_MODULE_0__.default.removeLogListener(logcatListener);
- }
- break;
- }
- }
- });
- function onInitSegment(type2, initSegment) {
- var obj = {
- msg: _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.INIT_SEGMENT,
- data: {
- type: type2,
- data: initSegment
- }
- };
- self2.postMessage(obj, [initSegment.data]);
- }
- function onMediaSegment(type2, mediaSegment) {
- var obj = {
- msg: _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.MEDIA_SEGMENT,
- data: {
- type: type2,
- data: mediaSegment
- }
- };
- self2.postMessage(obj, [mediaSegment.data]);
- }
- function onLoadingComplete() {
- var obj = {
- msg: _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.LOADING_COMPLETE
- };
- self2.postMessage(obj);
- }
- function onRecoveredEarlyEof() {
- var obj = {
- msg: _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.RECOVERED_EARLY_EOF
- };
- self2.postMessage(obj);
- }
- function onMediaInfo(mediaInfo) {
- var obj = {
- msg: _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.MEDIA_INFO,
- data: mediaInfo
- };
- self2.postMessage(obj);
- }
- function onMetaDataArrived(metadata) {
- var obj = {
- msg: _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.METADATA_ARRIVED,
- data: metadata
- };
- self2.postMessage(obj);
- }
- function onScriptDataArrived(data) {
- var obj = {
- msg: _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.SCRIPTDATA_ARRIVED,
- data
- };
- self2.postMessage(obj);
- }
- function onStatisticsInfo(statInfo) {
- var obj = {
- msg: _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.STATISTICS_INFO,
- data: statInfo
- };
- self2.postMessage(obj);
- }
- function onIOError(type2, info) {
- self2.postMessage({
- msg: _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.IO_ERROR,
- data: {
- type: type2,
- info
- }
- });
- }
- function onDemuxError(type2, info) {
- self2.postMessage({
- msg: _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.DEMUX_ERROR,
- data: {
- type: type2,
- info
- }
- });
- }
- function onRecommendSeekpoint(milliseconds) {
- self2.postMessage({
- msg: _transmuxing_events_js__WEBPACK_IMPORTED_MODULE_3__.default.RECOMMEND_SEEKPOINT,
- data: milliseconds
- });
- }
- function onLogcatCallback(type2, str) {
- self2.postMessage({
- msg: "logcat_callback",
- data: {
- type: type2,
- logcat: str
- }
- });
- }
- };
- __webpack_exports__2["default"] = TransmuxingWorker;
- },
- "./src/demux/amf-parser.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/utils/logger.js");
- var _utils_utf8_conv_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/utils/utf8-conv.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/utils/exception.js");
- var le = function() {
- var buf = new ArrayBuffer(2);
- new DataView(buf).setInt16(0, 256, true);
- return new Int16Array(buf)[0] === 256;
- }();
- var AMF = function() {
- function AMF2() {
- }
- AMF2.parseScriptData = function(arrayBuffer, dataOffset, dataSize) {
- var data = {};
- try {
- var name_1 = AMF2.parseValue(arrayBuffer, dataOffset, dataSize);
- var value = AMF2.parseValue(arrayBuffer, dataOffset + name_1.size, dataSize - name_1.size);
- data[name_1.data] = value.data;
- } catch (e) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.e("AMF", e.toString());
- }
- return data;
- };
- AMF2.parseObject = function(arrayBuffer, dataOffset, dataSize) {
- if (dataSize < 3) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__.IllegalStateException("Data not enough when parse ScriptDataObject");
- }
- var name = AMF2.parseString(arrayBuffer, dataOffset, dataSize);
- var value = AMF2.parseValue(arrayBuffer, dataOffset + name.size, dataSize - name.size);
- var isObjectEnd = value.objectEnd;
- return {
- data: {
- name: name.data,
- value: value.data
- },
- size: name.size + value.size,
- objectEnd: isObjectEnd
- };
- };
- AMF2.parseVariable = function(arrayBuffer, dataOffset, dataSize) {
- return AMF2.parseObject(arrayBuffer, dataOffset, dataSize);
- };
- AMF2.parseString = function(arrayBuffer, dataOffset, dataSize) {
- if (dataSize < 2) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__.IllegalStateException("Data not enough when parse String");
- }
- var v = new DataView(arrayBuffer, dataOffset, dataSize);
- var length = v.getUint16(0, !le);
- var str;
- if (length > 0) {
- str = (0, _utils_utf8_conv_js__WEBPACK_IMPORTED_MODULE_1__.default)(new Uint8Array(arrayBuffer, dataOffset + 2, length));
- } else {
- str = "";
- }
- return {
- data: str,
- size: 2 + length
- };
- };
- AMF2.parseLongString = function(arrayBuffer, dataOffset, dataSize) {
- if (dataSize < 4) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__.IllegalStateException("Data not enough when parse LongString");
- }
- var v = new DataView(arrayBuffer, dataOffset, dataSize);
- var length = v.getUint32(0, !le);
- var str;
- if (length > 0) {
- str = (0, _utils_utf8_conv_js__WEBPACK_IMPORTED_MODULE_1__.default)(new Uint8Array(arrayBuffer, dataOffset + 4, length));
- } else {
- str = "";
- }
- return {
- data: str,
- size: 4 + length
- };
- };
- AMF2.parseDate = function(arrayBuffer, dataOffset, dataSize) {
- if (dataSize < 10) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__.IllegalStateException("Data size invalid when parse Date");
- }
- var v = new DataView(arrayBuffer, dataOffset, dataSize);
- var timestamp = v.getFloat64(0, !le);
- var localTimeOffset = v.getInt16(8, !le);
- timestamp += localTimeOffset * 60 * 1e3;
- return {
- data: new Date(timestamp),
- size: 8 + 2
- };
- };
- AMF2.parseValue = function(arrayBuffer, dataOffset, dataSize) {
- if (dataSize < 1) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__.IllegalStateException("Data not enough when parse Value");
- }
- var v = new DataView(arrayBuffer, dataOffset, dataSize);
- var offset = 1;
- var type2 = v.getUint8(0);
- var value;
- var objectEnd = false;
- try {
- switch (type2) {
- case 0:
- value = v.getFloat64(1, !le);
- offset += 8;
- break;
- case 1: {
- var b = v.getUint8(1);
- value = b ? true : false;
- offset += 1;
- break;
- }
- case 2: {
- var amfstr = AMF2.parseString(arrayBuffer, dataOffset + 1, dataSize - 1);
- value = amfstr.data;
- offset += amfstr.size;
- break;
- }
- case 3: {
- value = {};
- var terminal = 0;
- if ((v.getUint32(dataSize - 4, !le) & 16777215) === 9) {
- terminal = 3;
- }
- while (offset < dataSize - 4) {
- var amfobj = AMF2.parseObject(arrayBuffer, dataOffset + offset, dataSize - offset - terminal);
- if (amfobj.objectEnd)
- break;
- value[amfobj.data.name] = amfobj.data.value;
- offset += amfobj.size;
- }
- if (offset <= dataSize - 3) {
- var marker = v.getUint32(offset - 1, !le) & 16777215;
- if (marker === 9) {
- offset += 3;
- }
- }
- break;
- }
- case 8: {
- value = {};
- offset += 4;
- var terminal = 0;
- if ((v.getUint32(dataSize - 4, !le) & 16777215) === 9) {
- terminal = 3;
- }
- while (offset < dataSize - 8) {
- var amfvar = AMF2.parseVariable(arrayBuffer, dataOffset + offset, dataSize - offset - terminal);
- if (amfvar.objectEnd)
- break;
- value[amfvar.data.name] = amfvar.data.value;
- offset += amfvar.size;
- }
- if (offset <= dataSize - 3) {
- var marker = v.getUint32(offset - 1, !le) & 16777215;
- if (marker === 9) {
- offset += 3;
- }
- }
- break;
- }
- case 9:
- value = void 0;
- offset = 1;
- objectEnd = true;
- break;
- case 10: {
- value = [];
- var strictArrayLength = v.getUint32(1, !le);
- offset += 4;
- for (var i2 = 0; i2 < strictArrayLength; i2++) {
- var val = AMF2.parseValue(arrayBuffer, dataOffset + offset, dataSize - offset);
- value.push(val.data);
- offset += val.size;
- }
- break;
- }
- case 11: {
- var date = AMF2.parseDate(arrayBuffer, dataOffset + 1, dataSize - 1);
- value = date.data;
- offset += date.size;
- break;
- }
- case 12: {
- var amfLongStr = AMF2.parseString(arrayBuffer, dataOffset + 1, dataSize - 1);
- value = amfLongStr.data;
- offset += amfLongStr.size;
- break;
- }
- default:
- offset = dataSize;
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w("AMF", "Unsupported AMF value type " + type2);
- }
- } catch (e) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.e("AMF", e.toString());
- }
- return {
- data: value,
- size: offset,
- objectEnd
- };
- };
- return AMF2;
- }();
- __webpack_exports__2["default"] = AMF;
- },
- "./src/demux/demux-errors.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var DemuxErrors = {
- OK: "OK",
- FORMAT_ERROR: "FormatError",
- FORMAT_UNSUPPORTED: "FormatUnsupported",
- CODEC_UNSUPPORTED: "CodecUnsupported"
- };
- __webpack_exports__2["default"] = DemuxErrors;
- },
- "./src/demux/exp-golomb.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/utils/exception.js");
- var ExpGolomb = function() {
- function ExpGolomb2(uint8array) {
- this.TAG = "ExpGolomb";
- this._buffer = uint8array;
- this._buffer_index = 0;
- this._total_bytes = uint8array.byteLength;
- this._total_bits = uint8array.byteLength * 8;
- this._current_word = 0;
- this._current_word_bits_left = 0;
- }
- ExpGolomb2.prototype.destroy = function() {
- this._buffer = null;
- };
- ExpGolomb2.prototype._fillCurrentWord = function() {
- var buffer_bytes_left = this._total_bytes - this._buffer_index;
- if (buffer_bytes_left <= 0)
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_0__.IllegalStateException("ExpGolomb: _fillCurrentWord() but no bytes available");
- var bytes_read = Math.min(4, buffer_bytes_left);
- var word = new Uint8Array(4);
- word.set(this._buffer.subarray(this._buffer_index, this._buffer_index + bytes_read));
- this._current_word = new DataView(word.buffer).getUint32(0, false);
- this._buffer_index += bytes_read;
- this._current_word_bits_left = bytes_read * 8;
- };
- ExpGolomb2.prototype.readBits = function(bits) {
- if (bits > 32)
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_0__.InvalidArgumentException("ExpGolomb: readBits() bits exceeded max 32bits!");
- if (bits <= this._current_word_bits_left) {
- var result_1 = this._current_word >>> 32 - bits;
- this._current_word <<= bits;
- this._current_word_bits_left -= bits;
- return result_1;
- }
- var result = this._current_word_bits_left ? this._current_word : 0;
- result = result >>> 32 - this._current_word_bits_left;
- var bits_need_left = bits - this._current_word_bits_left;
- this._fillCurrentWord();
- var bits_read_next = Math.min(bits_need_left, this._current_word_bits_left);
- var result2 = this._current_word >>> 32 - bits_read_next;
- this._current_word <<= bits_read_next;
- this._current_word_bits_left -= bits_read_next;
- result = result << bits_read_next | result2;
- return result;
- };
- ExpGolomb2.prototype.readBool = function() {
- return this.readBits(1) === 1;
- };
- ExpGolomb2.prototype.readByte = function() {
- return this.readBits(8);
- };
- ExpGolomb2.prototype._skipLeadingZero = function() {
- var zero_count;
- for (zero_count = 0; zero_count < this._current_word_bits_left; zero_count++) {
- if (0 !== (this._current_word & 2147483648 >>> zero_count)) {
- this._current_word <<= zero_count;
- this._current_word_bits_left -= zero_count;
- return zero_count;
- }
- }
- this._fillCurrentWord();
- return zero_count + this._skipLeadingZero();
- };
- ExpGolomb2.prototype.readUEG = function() {
- var leading_zeros = this._skipLeadingZero();
- return this.readBits(leading_zeros + 1) - 1;
- };
- ExpGolomb2.prototype.readSEG = function() {
- var value = this.readUEG();
- if (value & 1) {
- return value + 1 >>> 1;
- } else {
- return -1 * (value >>> 1);
- }
- };
- return ExpGolomb2;
- }();
- __webpack_exports__2["default"] = ExpGolomb;
- },
- "./src/demux/flv-demuxer.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/utils/logger.js");
- var _amf_parser_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/demux/amf-parser.js");
- var _sps_parser_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/demux/sps-parser.js");
- var _demux_errors_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__2("./src/demux/demux-errors.js");
- var _core_media_info_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__2("./src/core/media-info.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__2("./src/utils/exception.js");
- function ReadBig32(array, index2) {
- return array[index2] << 24 | array[index2 + 1] << 16 | array[index2 + 2] << 8 | array[index2 + 3];
- }
- var FLVDemuxer = function() {
- function FLVDemuxer2(probeData, config) {
- this.TAG = "FLVDemuxer";
- this._config = config;
- this._onError = null;
- this._onMediaInfo = null;
- this._onMetaDataArrived = null;
- this._onScriptDataArrived = null;
- this._onTrackMetadata = null;
- this._onDataAvailable = null;
- this._dataOffset = probeData.dataOffset;
- this._firstParse = true;
- this._dispatch = false;
- this._hasAudio = probeData.hasAudioTrack;
- this._hasVideo = probeData.hasVideoTrack;
- this._hasAudioFlagOverrided = false;
- this._hasVideoFlagOverrided = false;
- this._audioInitialMetadataDispatched = false;
- this._videoInitialMetadataDispatched = false;
- this._mediaInfo = new _core_media_info_js__WEBPACK_IMPORTED_MODULE_4__.default();
- this._mediaInfo.hasAudio = this._hasAudio;
- this._mediaInfo.hasVideo = this._hasVideo;
- this._metadata = null;
- this._audioMetadata = null;
- this._videoMetadata = null;
- this._naluLengthSize = 4;
- this._timestampBase = 0;
- this._timescale = 1e3;
- this._duration = 0;
- this._durationOverrided = false;
- this._referenceFrameRate = {
- fixed: true,
- fps: 23.976,
- fps_num: 23976,
- fps_den: 1e3
- };
- this._flvSoundRateTable = [5500, 11025, 22050, 44100, 48e3];
- this._mpegSamplingRates = [
- 96e3,
- 88200,
- 64e3,
- 48e3,
- 44100,
- 32e3,
- 24e3,
- 22050,
- 16e3,
- 12e3,
- 11025,
- 8e3,
- 7350
- ];
- this._mpegAudioV10SampleRateTable = [44100, 48e3, 32e3, 0];
- this._mpegAudioV20SampleRateTable = [22050, 24e3, 16e3, 0];
- this._mpegAudioV25SampleRateTable = [11025, 12e3, 8e3, 0];
- this._mpegAudioL1BitRateTable = [0, 32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448, -1];
- this._mpegAudioL2BitRateTable = [0, 32, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, -1];
- this._mpegAudioL3BitRateTable = [0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, -1];
- this._videoTrack = { type: "video", id: 1, sequenceNumber: 0, samples: [], length: 0 };
- this._audioTrack = { type: "audio", id: 2, sequenceNumber: 0, samples: [], length: 0 };
- this._littleEndian = function() {
- var buf = new ArrayBuffer(2);
- new DataView(buf).setInt16(0, 256, true);
- return new Int16Array(buf)[0] === 256;
- }();
- }
- FLVDemuxer2.prototype.destroy = function() {
- this._mediaInfo = null;
- this._metadata = null;
- this._audioMetadata = null;
- this._videoMetadata = null;
- this._videoTrack = null;
- this._audioTrack = null;
- this._onError = null;
- this._onMediaInfo = null;
- this._onMetaDataArrived = null;
- this._onScriptDataArrived = null;
- this._onTrackMetadata = null;
- this._onDataAvailable = null;
- };
- FLVDemuxer2.probe = function(buffer) {
- var data = new Uint8Array(buffer);
- var mismatch = { match: false };
- if (data[0] !== 70 || data[1] !== 76 || data[2] !== 86 || data[3] !== 1) {
- return mismatch;
- }
- var hasAudio = (data[4] & 4) >>> 2 !== 0;
- var hasVideo = (data[4] & 1) !== 0;
- var offset = ReadBig32(data, 5);
- if (offset < 9) {
- return mismatch;
- }
- return {
- match: true,
- consumed: offset,
- dataOffset: offset,
- hasAudioTrack: hasAudio,
- hasVideoTrack: hasVideo
- };
- };
- FLVDemuxer2.prototype.bindDataSource = function(loader) {
- loader.onDataArrival = this.parseChunks.bind(this);
- return this;
- };
- Object.defineProperty(FLVDemuxer2.prototype, "onTrackMetadata", {
- get: function() {
- return this._onTrackMetadata;
- },
- set: function(callback2) {
- this._onTrackMetadata = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FLVDemuxer2.prototype, "onMediaInfo", {
- get: function() {
- return this._onMediaInfo;
- },
- set: function(callback2) {
- this._onMediaInfo = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FLVDemuxer2.prototype, "onMetaDataArrived", {
- get: function() {
- return this._onMetaDataArrived;
- },
- set: function(callback2) {
- this._onMetaDataArrived = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FLVDemuxer2.prototype, "onScriptDataArrived", {
- get: function() {
- return this._onScriptDataArrived;
- },
- set: function(callback2) {
- this._onScriptDataArrived = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FLVDemuxer2.prototype, "onError", {
- get: function() {
- return this._onError;
- },
- set: function(callback2) {
- this._onError = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FLVDemuxer2.prototype, "onDataAvailable", {
- get: function() {
- return this._onDataAvailable;
- },
- set: function(callback2) {
- this._onDataAvailable = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FLVDemuxer2.prototype, "timestampBase", {
- get: function() {
- return this._timestampBase;
- },
- set: function(base2) {
- this._timestampBase = base2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FLVDemuxer2.prototype, "overridedDuration", {
- get: function() {
- return this._duration;
- },
- set: function(duration5) {
- this._durationOverrided = true;
- this._duration = duration5;
- this._mediaInfo.duration = duration5;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FLVDemuxer2.prototype, "overridedHasAudio", {
- set: function(hasAudio) {
- this._hasAudioFlagOverrided = true;
- this._hasAudio = hasAudio;
- this._mediaInfo.hasAudio = hasAudio;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FLVDemuxer2.prototype, "overridedHasVideo", {
- set: function(hasVideo) {
- this._hasVideoFlagOverrided = true;
- this._hasVideo = hasVideo;
- this._mediaInfo.hasVideo = hasVideo;
- },
- enumerable: false,
- configurable: true
- });
- FLVDemuxer2.prototype.resetMediaInfo = function() {
- this._mediaInfo = new _core_media_info_js__WEBPACK_IMPORTED_MODULE_4__.default();
- };
- FLVDemuxer2.prototype._isInitialMetadataDispatched = function() {
- if (this._hasAudio && this._hasVideo) {
- return this._audioInitialMetadataDispatched && this._videoInitialMetadataDispatched;
- }
- if (this._hasAudio && !this._hasVideo) {
- return this._audioInitialMetadataDispatched;
- }
- if (!this._hasAudio && this._hasVideo) {
- return this._videoInitialMetadataDispatched;
- }
- return false;
- };
- FLVDemuxer2.prototype.parseChunks = function(chunk, byteStart) {
- if (!this._onError || !this._onMediaInfo || !this._onTrackMetadata || !this._onDataAvailable) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_5__.IllegalStateException("Flv: onError & onMediaInfo & onTrackMetadata & onDataAvailable callback must be specified");
- }
- var offset = 0;
- var le = this._littleEndian;
- if (byteStart === 0) {
- if (chunk.byteLength > 13) {
- var probeData = FLVDemuxer2.probe(chunk);
- offset = probeData.dataOffset;
- } else {
- return 0;
- }
- }
- if (this._firstParse) {
- this._firstParse = false;
- if (byteStart + offset !== this._dataOffset) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "First time parsing but chunk byteStart invalid!");
- }
- var v = new DataView(chunk, offset);
- var prevTagSize0 = v.getUint32(0, !le);
- if (prevTagSize0 !== 0) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "PrevTagSize0 !== 0 !!!");
- }
- offset += 4;
- }
- while (offset < chunk.byteLength) {
- this._dispatch = true;
- var v = new DataView(chunk, offset);
- if (offset + 11 + 4 > chunk.byteLength) {
- break;
- }
- var tagType = v.getUint8(0);
- var dataSize = v.getUint32(0, !le) & 16777215;
- if (offset + 11 + dataSize + 4 > chunk.byteLength) {
- break;
- }
- if (tagType !== 8 && tagType !== 9 && tagType !== 18) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Unsupported tag type " + tagType + ", skipped");
- offset += 11 + dataSize + 4;
- continue;
- }
- var ts22 = v.getUint8(4);
- var ts1 = v.getUint8(5);
- var ts0 = v.getUint8(6);
- var ts3 = v.getUint8(7);
- var timestamp = ts0 | ts1 << 8 | ts22 << 16 | ts3 << 24;
- var streamId = v.getUint32(7, !le) & 16777215;
- if (streamId !== 0) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Meet tag which has StreamID != 0!");
- }
- var dataOffset = offset + 11;
- switch (tagType) {
- case 8:
- this._parseAudioData(chunk, dataOffset, dataSize, timestamp);
- break;
- case 9:
- this._parseVideoData(chunk, dataOffset, dataSize, timestamp, byteStart + offset);
- break;
- case 18:
- this._parseScriptData(chunk, dataOffset, dataSize);
- break;
- }
- var prevTagSize = v.getUint32(11 + dataSize, !le);
- if (prevTagSize !== 11 + dataSize) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Invalid PrevTagSize " + prevTagSize);
- }
- offset += 11 + dataSize + 4;
- }
- if (this._isInitialMetadataDispatched()) {
- if (this._dispatch && (this._audioTrack.length || this._videoTrack.length)) {
- this._onDataAvailable(this._audioTrack, this._videoTrack);
- }
- }
- return offset;
- };
- FLVDemuxer2.prototype._parseScriptData = function(arrayBuffer, dataOffset, dataSize) {
- var scriptData = _amf_parser_js__WEBPACK_IMPORTED_MODULE_1__.default.parseScriptData(arrayBuffer, dataOffset, dataSize);
- if (scriptData.hasOwnProperty("onMetaData")) {
- if (scriptData.onMetaData == null || typeof scriptData.onMetaData !== "object") {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Invalid onMetaData structure!");
- return;
- }
- if (this._metadata) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Found another onMetaData tag!");
- }
- this._metadata = scriptData;
- var onMetaData = this._metadata.onMetaData;
- if (this._onMetaDataArrived) {
- this._onMetaDataArrived(Object.assign({}, onMetaData));
- }
- if (typeof onMetaData.hasAudio === "boolean") {
- if (this._hasAudioFlagOverrided === false) {
- this._hasAudio = onMetaData.hasAudio;
- this._mediaInfo.hasAudio = this._hasAudio;
- }
- }
- if (typeof onMetaData.hasVideo === "boolean") {
- if (this._hasVideoFlagOverrided === false) {
- this._hasVideo = onMetaData.hasVideo;
- this._mediaInfo.hasVideo = this._hasVideo;
- }
- }
- if (typeof onMetaData.audiodatarate === "number") {
- this._mediaInfo.audioDataRate = onMetaData.audiodatarate;
- }
- if (typeof onMetaData.videodatarate === "number") {
- this._mediaInfo.videoDataRate = onMetaData.videodatarate;
- }
- if (typeof onMetaData.width === "number") {
- this._mediaInfo.width = onMetaData.width;
- }
- if (typeof onMetaData.height === "number") {
- this._mediaInfo.height = onMetaData.height;
- }
- if (typeof onMetaData.duration === "number") {
- if (!this._durationOverrided) {
- var duration5 = Math.floor(onMetaData.duration * this._timescale);
- this._duration = duration5;
- this._mediaInfo.duration = duration5;
- }
- } else {
- this._mediaInfo.duration = 0;
- }
- if (typeof onMetaData.framerate === "number") {
- var fps_num = Math.floor(onMetaData.framerate * 1e3);
- if (fps_num > 0) {
- var fps = fps_num / 1e3;
- this._referenceFrameRate.fixed = true;
- this._referenceFrameRate.fps = fps;
- this._referenceFrameRate.fps_num = fps_num;
- this._referenceFrameRate.fps_den = 1e3;
- this._mediaInfo.fps = fps;
- }
- }
- if (typeof onMetaData.keyframes === "object") {
- this._mediaInfo.hasKeyframesIndex = true;
- var keyframes = onMetaData.keyframes;
- this._mediaInfo.keyframesIndex = this._parseKeyframesIndex(keyframes);
- onMetaData.keyframes = null;
- } else {
- this._mediaInfo.hasKeyframesIndex = false;
- }
- this._dispatch = false;
- this._mediaInfo.metadata = onMetaData;
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.v(this.TAG, "Parsed onMetaData");
- if (this._mediaInfo.isComplete()) {
- this._onMediaInfo(this._mediaInfo);
- }
- }
- if (Object.keys(scriptData).length > 0) {
- if (this._onScriptDataArrived) {
- this._onScriptDataArrived(Object.assign({}, scriptData));
- }
- }
- };
- FLVDemuxer2.prototype._parseKeyframesIndex = function(keyframes) {
- var times = [];
- var filepositions = [];
- for (var i2 = 1; i2 < keyframes.times.length; i2++) {
- var time = this._timestampBase + Math.floor(keyframes.times[i2] * 1e3);
- times.push(time);
- filepositions.push(keyframes.filepositions[i2]);
- }
- return {
- times,
- filepositions
- };
- };
- FLVDemuxer2.prototype._parseAudioData = function(arrayBuffer, dataOffset, dataSize, tagTimestamp) {
- if (dataSize <= 1) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Flv: Invalid audio packet, missing SoundData payload!");
- return;
- }
- if (this._hasAudioFlagOverrided === true && this._hasAudio === false) {
- return;
- }
- this._littleEndian;
- var v = new DataView(arrayBuffer, dataOffset, dataSize);
- var soundSpec = v.getUint8(0);
- var soundFormat = soundSpec >>> 4;
- if (soundFormat !== 2 && soundFormat !== 10) {
- this._onError(_demux_errors_js__WEBPACK_IMPORTED_MODULE_3__.default.CODEC_UNSUPPORTED, "Flv: Unsupported audio codec idx: " + soundFormat);
- return;
- }
- var soundRate = 0;
- var soundRateIndex = (soundSpec & 12) >>> 2;
- if (soundRateIndex >= 0 && soundRateIndex <= 4) {
- soundRate = this._flvSoundRateTable[soundRateIndex];
- } else {
- this._onError(_demux_errors_js__WEBPACK_IMPORTED_MODULE_3__.default.FORMAT_ERROR, "Flv: Invalid audio sample rate idx: " + soundRateIndex);
- return;
- }
- var soundType = soundSpec & 1;
- var meta2 = this._audioMetadata;
- var track = this._audioTrack;
- if (!meta2) {
- if (this._hasAudio === false && this._hasAudioFlagOverrided === false) {
- this._hasAudio = true;
- this._mediaInfo.hasAudio = true;
- }
- meta2 = this._audioMetadata = {};
- meta2.type = "audio";
- meta2.id = track.id;
- meta2.timescale = this._timescale;
- meta2.duration = this._duration;
- meta2.audioSampleRate = soundRate;
- meta2.channelCount = soundType === 0 ? 1 : 2;
- }
- if (soundFormat === 10) {
- var aacData = this._parseAACAudioData(arrayBuffer, dataOffset + 1, dataSize - 1);
- if (aacData == void 0) {
- return;
- }
- if (aacData.packetType === 0) {
- if (meta2.config) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Found another AudioSpecificConfig!");
- }
- var misc = aacData.data;
- meta2.audioSampleRate = misc.samplingRate;
- meta2.channelCount = misc.channelCount;
- meta2.codec = misc.codec;
- meta2.originalCodec = misc.originalCodec;
- meta2.config = misc.config;
- meta2.refSampleDuration = 1024 / meta2.audioSampleRate * meta2.timescale;
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.v(this.TAG, "Parsed AudioSpecificConfig");
- if (this._isInitialMetadataDispatched()) {
- if (this._dispatch && (this._audioTrack.length || this._videoTrack.length)) {
- this._onDataAvailable(this._audioTrack, this._videoTrack);
- }
- } else {
- this._audioInitialMetadataDispatched = true;
- }
- this._dispatch = false;
- this._onTrackMetadata("audio", meta2);
- var mi = this._mediaInfo;
- mi.audioCodec = meta2.originalCodec;
- mi.audioSampleRate = meta2.audioSampleRate;
- mi.audioChannelCount = meta2.channelCount;
- if (mi.hasVideo) {
- if (mi.videoCodec != null) {
- mi.mimeType = 'video/x-flv; codecs="' + mi.videoCodec + "," + mi.audioCodec + '"';
- }
- } else {
- mi.mimeType = 'video/x-flv; codecs="' + mi.audioCodec + '"';
- }
- if (mi.isComplete()) {
- this._onMediaInfo(mi);
- }
- } else if (aacData.packetType === 1) {
- var dts = this._timestampBase + tagTimestamp;
- var aacSample = { unit: aacData.data, length: aacData.data.byteLength, dts, pts: dts };
- track.samples.push(aacSample);
- track.length += aacData.data.length;
- } else {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.e(this.TAG, "Flv: Unsupported AAC data type " + aacData.packetType);
- }
- } else if (soundFormat === 2) {
- if (!meta2.codec) {
- var misc = this._parseMP3AudioData(arrayBuffer, dataOffset + 1, dataSize - 1, true);
- if (misc == void 0) {
- return;
- }
- meta2.audioSampleRate = misc.samplingRate;
- meta2.channelCount = misc.channelCount;
- meta2.codec = misc.codec;
- meta2.originalCodec = misc.originalCodec;
- meta2.refSampleDuration = 1152 / meta2.audioSampleRate * meta2.timescale;
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.v(this.TAG, "Parsed MPEG Audio Frame Header");
- this._audioInitialMetadataDispatched = true;
- this._onTrackMetadata("audio", meta2);
- var mi = this._mediaInfo;
- mi.audioCodec = meta2.codec;
- mi.audioSampleRate = meta2.audioSampleRate;
- mi.audioChannelCount = meta2.channelCount;
- mi.audioDataRate = misc.bitRate;
- if (mi.hasVideo) {
- if (mi.videoCodec != null) {
- mi.mimeType = 'video/x-flv; codecs="' + mi.videoCodec + "," + mi.audioCodec + '"';
- }
- } else {
- mi.mimeType = 'video/x-flv; codecs="' + mi.audioCodec + '"';
- }
- if (mi.isComplete()) {
- this._onMediaInfo(mi);
- }
- }
- var data = this._parseMP3AudioData(arrayBuffer, dataOffset + 1, dataSize - 1, false);
- if (data == void 0) {
- return;
- }
- var dts = this._timestampBase + tagTimestamp;
- var mp3Sample = { unit: data, length: data.byteLength, dts, pts: dts };
- track.samples.push(mp3Sample);
- track.length += data.length;
- }
- };
- FLVDemuxer2.prototype._parseAACAudioData = function(arrayBuffer, dataOffset, dataSize) {
- if (dataSize <= 1) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Flv: Invalid AAC packet, missing AACPacketType or/and Data!");
- return;
- }
- var result = {};
- var array = new Uint8Array(arrayBuffer, dataOffset, dataSize);
- result.packetType = array[0];
- if (array[0] === 0) {
- result.data = this._parseAACAudioSpecificConfig(arrayBuffer, dataOffset + 1, dataSize - 1);
- } else {
- result.data = array.subarray(1);
- }
- return result;
- };
- FLVDemuxer2.prototype._parseAACAudioSpecificConfig = function(arrayBuffer, dataOffset, dataSize) {
- var array = new Uint8Array(arrayBuffer, dataOffset, dataSize);
- var config = null;
- var audioObjectType = 0;
- var originalAudioObjectType = 0;
- var samplingIndex = 0;
- var extensionSamplingIndex = null;
- audioObjectType = originalAudioObjectType = array[0] >>> 3;
- samplingIndex = (array[0] & 7) << 1 | array[1] >>> 7;
- if (samplingIndex < 0 || samplingIndex >= this._mpegSamplingRates.length) {
- this._onError(_demux_errors_js__WEBPACK_IMPORTED_MODULE_3__.default.FORMAT_ERROR, "Flv: AAC invalid sampling frequency index!");
- return;
- }
- var samplingFrequence = this._mpegSamplingRates[samplingIndex];
- var channelConfig = (array[1] & 120) >>> 3;
- if (channelConfig < 0 || channelConfig >= 8) {
- this._onError(_demux_errors_js__WEBPACK_IMPORTED_MODULE_3__.default.FORMAT_ERROR, "Flv: AAC invalid channel configuration");
- return;
- }
- if (audioObjectType === 5) {
- extensionSamplingIndex = (array[1] & 7) << 1 | array[2] >>> 7;
- (array[2] & 124) >>> 2;
- }
- var userAgent = self.navigator.userAgent.toLowerCase();
- if (userAgent.indexOf("firefox") !== -1) {
- if (samplingIndex >= 6) {
- audioObjectType = 5;
- config = new Array(4);
- extensionSamplingIndex = samplingIndex - 3;
- } else {
- audioObjectType = 2;
- config = new Array(2);
- extensionSamplingIndex = samplingIndex;
- }
- } else if (userAgent.indexOf("android") !== -1) {
- audioObjectType = 2;
- config = new Array(2);
- extensionSamplingIndex = samplingIndex;
- } else {
- audioObjectType = 5;
- extensionSamplingIndex = samplingIndex;
- config = new Array(4);
- if (samplingIndex >= 6) {
- extensionSamplingIndex = samplingIndex - 3;
- } else if (channelConfig === 1) {
- audioObjectType = 2;
- config = new Array(2);
- extensionSamplingIndex = samplingIndex;
- }
- }
- config[0] = audioObjectType << 3;
- config[0] |= (samplingIndex & 15) >>> 1;
- config[1] = (samplingIndex & 15) << 7;
- config[1] |= (channelConfig & 15) << 3;
- if (audioObjectType === 5) {
- config[1] |= (extensionSamplingIndex & 15) >>> 1;
- config[2] = (extensionSamplingIndex & 1) << 7;
- config[2] |= 2 << 2;
- config[3] = 0;
- }
- return {
- config,
- samplingRate: samplingFrequence,
- channelCount: channelConfig,
- codec: "mp4a.40." + audioObjectType,
- originalCodec: "mp4a.40." + originalAudioObjectType
- };
- };
- FLVDemuxer2.prototype._parseMP3AudioData = function(arrayBuffer, dataOffset, dataSize, requestHeader) {
- if (dataSize < 4) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Flv: Invalid MP3 packet, header missing!");
- return;
- }
- this._littleEndian;
- var array = new Uint8Array(arrayBuffer, dataOffset, dataSize);
- var result = null;
- if (requestHeader) {
- if (array[0] !== 255) {
- return;
- }
- var ver = array[1] >>> 3 & 3;
- var layer = (array[1] & 6) >> 1;
- var bitrate_index = (array[2] & 240) >>> 4;
- var sampling_freq_index = (array[2] & 12) >>> 2;
- var channel_mode = array[3] >>> 6 & 3;
- var channel_count = channel_mode !== 3 ? 2 : 1;
- var sample_rate = 0;
- var bit_rate = 0;
- var codec = "mp3";
- switch (ver) {
- case 0:
- sample_rate = this._mpegAudioV25SampleRateTable[sampling_freq_index];
- break;
- case 2:
- sample_rate = this._mpegAudioV20SampleRateTable[sampling_freq_index];
- break;
- case 3:
- sample_rate = this._mpegAudioV10SampleRateTable[sampling_freq_index];
- break;
- }
- switch (layer) {
- case 1:
- if (bitrate_index < this._mpegAudioL3BitRateTable.length) {
- bit_rate = this._mpegAudioL3BitRateTable[bitrate_index];
- }
- break;
- case 2:
- if (bitrate_index < this._mpegAudioL2BitRateTable.length) {
- bit_rate = this._mpegAudioL2BitRateTable[bitrate_index];
- }
- break;
- case 3:
- if (bitrate_index < this._mpegAudioL1BitRateTable.length) {
- bit_rate = this._mpegAudioL1BitRateTable[bitrate_index];
- }
- break;
- }
- result = {
- bitRate: bit_rate,
- samplingRate: sample_rate,
- channelCount: channel_count,
- codec,
- originalCodec: codec
- };
- } else {
- result = array;
- }
- return result;
- };
- FLVDemuxer2.prototype._parseVideoData = function(arrayBuffer, dataOffset, dataSize, tagTimestamp, tagPosition) {
- if (dataSize <= 1) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Flv: Invalid video packet, missing VideoData payload!");
- return;
- }
- if (this._hasVideoFlagOverrided === true && this._hasVideo === false) {
- return;
- }
- var spec = new Uint8Array(arrayBuffer, dataOffset, dataSize)[0];
- var frameType = (spec & 240) >>> 4;
- var codecId = spec & 15;
- if (codecId !== 7) {
- this._onError(_demux_errors_js__WEBPACK_IMPORTED_MODULE_3__.default.CODEC_UNSUPPORTED, "Flv: Unsupported codec in video frame: " + codecId);
- return;
- }
- this._parseAVCVideoPacket(arrayBuffer, dataOffset + 1, dataSize - 1, tagTimestamp, tagPosition, frameType);
- };
- FLVDemuxer2.prototype._parseAVCVideoPacket = function(arrayBuffer, dataOffset, dataSize, tagTimestamp, tagPosition, frameType) {
- if (dataSize < 4) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Flv: Invalid AVC packet, missing AVCPacketType or/and CompositionTime");
- return;
- }
- var le = this._littleEndian;
- var v = new DataView(arrayBuffer, dataOffset, dataSize);
- var packetType = v.getUint8(0);
- var cts_unsigned = v.getUint32(0, !le) & 16777215;
- var cts = cts_unsigned << 8 >> 8;
- if (packetType === 0) {
- this._parseAVCDecoderConfigurationRecord(arrayBuffer, dataOffset + 4, dataSize - 4);
- } else if (packetType === 1) {
- this._parseAVCVideoData(arrayBuffer, dataOffset + 4, dataSize - 4, tagTimestamp, tagPosition, frameType, cts);
- } else if (packetType === 2)
- ;
- else {
- this._onError(_demux_errors_js__WEBPACK_IMPORTED_MODULE_3__.default.FORMAT_ERROR, "Flv: Invalid video packet type " + packetType);
- return;
- }
- };
- FLVDemuxer2.prototype._parseAVCDecoderConfigurationRecord = function(arrayBuffer, dataOffset, dataSize) {
- if (dataSize < 7) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Flv: Invalid AVCDecoderConfigurationRecord, lack of data!");
- return;
- }
- var meta2 = this._videoMetadata;
- var track = this._videoTrack;
- var le = this._littleEndian;
- var v = new DataView(arrayBuffer, dataOffset, dataSize);
- if (!meta2) {
- if (this._hasVideo === false && this._hasVideoFlagOverrided === false) {
- this._hasVideo = true;
- this._mediaInfo.hasVideo = true;
- }
- meta2 = this._videoMetadata = {};
- meta2.type = "video";
- meta2.id = track.id;
- meta2.timescale = this._timescale;
- meta2.duration = this._duration;
- } else {
- if (typeof meta2.avcc !== "undefined") {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Found another AVCDecoderConfigurationRecord!");
- }
- }
- var version2 = v.getUint8(0);
- var avcProfile = v.getUint8(1);
- v.getUint8(2);
- v.getUint8(3);
- if (version2 !== 1 || avcProfile === 0) {
- this._onError(_demux_errors_js__WEBPACK_IMPORTED_MODULE_3__.default.FORMAT_ERROR, "Flv: Invalid AVCDecoderConfigurationRecord");
- return;
- }
- this._naluLengthSize = (v.getUint8(4) & 3) + 1;
- if (this._naluLengthSize !== 3 && this._naluLengthSize !== 4) {
- this._onError(_demux_errors_js__WEBPACK_IMPORTED_MODULE_3__.default.FORMAT_ERROR, "Flv: Strange NaluLengthSizeMinusOne: " + (this._naluLengthSize - 1));
- return;
- }
- var spsCount = v.getUint8(5) & 31;
- if (spsCount === 0) {
- this._onError(_demux_errors_js__WEBPACK_IMPORTED_MODULE_3__.default.FORMAT_ERROR, "Flv: Invalid AVCDecoderConfigurationRecord: No SPS");
- return;
- } else if (spsCount > 1) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Flv: Strange AVCDecoderConfigurationRecord: SPS Count = " + spsCount);
- }
- var offset = 6;
- for (var i2 = 0; i2 < spsCount; i2++) {
- var len = v.getUint16(offset, !le);
- offset += 2;
- if (len === 0) {
- continue;
- }
- var sps = new Uint8Array(arrayBuffer, dataOffset + offset, len);
- offset += len;
- var config = _sps_parser_js__WEBPACK_IMPORTED_MODULE_2__.default.parseSPS(sps);
- if (i2 !== 0) {
- continue;
- }
- meta2.codecWidth = config.codec_size.width;
- meta2.codecHeight = config.codec_size.height;
- meta2.presentWidth = config.present_size.width;
- meta2.presentHeight = config.present_size.height;
- meta2.profile = config.profile_string;
- meta2.level = config.level_string;
- meta2.bitDepth = config.bit_depth;
- meta2.chromaFormat = config.chroma_format;
- meta2.sarRatio = config.sar_ratio;
- meta2.frameRate = config.frame_rate;
- if (config.frame_rate.fixed === false || config.frame_rate.fps_num === 0 || config.frame_rate.fps_den === 0) {
- meta2.frameRate = this._referenceFrameRate;
- }
- var fps_den = meta2.frameRate.fps_den;
- var fps_num = meta2.frameRate.fps_num;
- meta2.refSampleDuration = meta2.timescale * (fps_den / fps_num);
- var codecArray = sps.subarray(1, 4);
- var codecString = "avc1.";
- for (var j = 0; j < 3; j++) {
- var h2 = codecArray[j].toString(16);
- if (h2.length < 2) {
- h2 = "0" + h2;
- }
- codecString += h2;
- }
- meta2.codec = codecString;
- var mi = this._mediaInfo;
- mi.width = meta2.codecWidth;
- mi.height = meta2.codecHeight;
- mi.fps = meta2.frameRate.fps;
- mi.profile = meta2.profile;
- mi.level = meta2.level;
- mi.refFrames = config.ref_frames;
- mi.chromaFormat = config.chroma_format_string;
- mi.sarNum = meta2.sarRatio.width;
- mi.sarDen = meta2.sarRatio.height;
- mi.videoCodec = codecString;
- if (mi.hasAudio) {
- if (mi.audioCodec != null) {
- mi.mimeType = 'video/x-flv; codecs="' + mi.videoCodec + "," + mi.audioCodec + '"';
- }
- } else {
- mi.mimeType = 'video/x-flv; codecs="' + mi.videoCodec + '"';
- }
- if (mi.isComplete()) {
- this._onMediaInfo(mi);
- }
- }
- var ppsCount = v.getUint8(offset);
- if (ppsCount === 0) {
- this._onError(_demux_errors_js__WEBPACK_IMPORTED_MODULE_3__.default.FORMAT_ERROR, "Flv: Invalid AVCDecoderConfigurationRecord: No PPS");
- return;
- } else if (ppsCount > 1) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Flv: Strange AVCDecoderConfigurationRecord: PPS Count = " + ppsCount);
- }
- offset++;
- for (var i2 = 0; i2 < ppsCount; i2++) {
- var len = v.getUint16(offset, !le);
- offset += 2;
- if (len === 0) {
- continue;
- }
- offset += len;
- }
- meta2.avcc = new Uint8Array(dataSize);
- meta2.avcc.set(new Uint8Array(arrayBuffer, dataOffset, dataSize), 0);
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.v(this.TAG, "Parsed AVCDecoderConfigurationRecord");
- if (this._isInitialMetadataDispatched()) {
- if (this._dispatch && (this._audioTrack.length || this._videoTrack.length)) {
- this._onDataAvailable(this._audioTrack, this._videoTrack);
- }
- } else {
- this._videoInitialMetadataDispatched = true;
- }
- this._dispatch = false;
- this._onTrackMetadata("video", meta2);
- };
- FLVDemuxer2.prototype._parseAVCVideoData = function(arrayBuffer, dataOffset, dataSize, tagTimestamp, tagPosition, frameType, cts) {
- var le = this._littleEndian;
- var v = new DataView(arrayBuffer, dataOffset, dataSize);
- var units = [], length = 0;
- var offset = 0;
- var lengthSize = this._naluLengthSize;
- var dts = this._timestampBase + tagTimestamp;
- var keyframe = frameType === 1;
- while (offset < dataSize) {
- if (offset + 4 >= dataSize) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Malformed Nalu near timestamp " + dts + ", offset = " + offset + ", dataSize = " + dataSize);
- break;
- }
- var naluSize = v.getUint32(offset, !le);
- if (lengthSize === 3) {
- naluSize >>>= 8;
- }
- if (naluSize > dataSize - lengthSize) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Malformed Nalus near timestamp " + dts + ", NaluSize > DataSize!");
- return;
- }
- var unitType = v.getUint8(offset + lengthSize) & 31;
- if (unitType === 5) {
- keyframe = true;
- }
- var data = new Uint8Array(arrayBuffer, dataOffset + offset, lengthSize + naluSize);
- var unit = { type: unitType, data };
- units.push(unit);
- length += data.byteLength;
- offset += lengthSize + naluSize;
- }
- if (units.length) {
- var track = this._videoTrack;
- var avcSample = {
- units,
- length,
- isKeyframe: keyframe,
- dts,
- cts,
- pts: dts + cts
- };
- if (keyframe) {
- avcSample.fileposition = tagPosition;
- }
- track.samples.push(avcSample);
- track.length += length;
- }
- };
- return FLVDemuxer2;
- }();
- __webpack_exports__2["default"] = FLVDemuxer;
- },
- "./src/demux/sps-parser.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _exp_golomb_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/demux/exp-golomb.js");
- var SPSParser = function() {
- function SPSParser2() {
- }
- SPSParser2._ebsp2rbsp = function(uint8array) {
- var src = uint8array;
- var src_length = src.byteLength;
- var dst = new Uint8Array(src_length);
- var dst_idx = 0;
- for (var i2 = 0; i2 < src_length; i2++) {
- if (i2 >= 2) {
- if (src[i2] === 3 && src[i2 - 1] === 0 && src[i2 - 2] === 0) {
- continue;
- }
- }
- dst[dst_idx] = src[i2];
- dst_idx++;
- }
- return new Uint8Array(dst.buffer, 0, dst_idx);
- };
- SPSParser2.parseSPS = function(uint8array) {
- var rbsp = SPSParser2._ebsp2rbsp(uint8array);
- var gb = new _exp_golomb_js__WEBPACK_IMPORTED_MODULE_0__.default(rbsp);
- gb.readByte();
- var profile_idc = gb.readByte();
- gb.readByte();
- var level_idc = gb.readByte();
- gb.readUEG();
- var profile_string = SPSParser2.getProfileString(profile_idc);
- var level_string = SPSParser2.getLevelString(level_idc);
- var chroma_format_idc = 1;
- var chroma_format = 420;
- var chroma_format_table = [0, 420, 422, 444];
- var bit_depth = 8;
- if (profile_idc === 100 || profile_idc === 110 || profile_idc === 122 || profile_idc === 244 || profile_idc === 44 || profile_idc === 83 || profile_idc === 86 || profile_idc === 118 || profile_idc === 128 || profile_idc === 138 || profile_idc === 144) {
- chroma_format_idc = gb.readUEG();
- if (chroma_format_idc === 3) {
- gb.readBits(1);
- }
- if (chroma_format_idc <= 3) {
- chroma_format = chroma_format_table[chroma_format_idc];
- }
- bit_depth = gb.readUEG() + 8;
- gb.readUEG();
- gb.readBits(1);
- if (gb.readBool()) {
- var scaling_list_count = chroma_format_idc !== 3 ? 8 : 12;
- for (var i2 = 0; i2 < scaling_list_count; i2++) {
- if (gb.readBool()) {
- if (i2 < 6) {
- SPSParser2._skipScalingList(gb, 16);
- } else {
- SPSParser2._skipScalingList(gb, 64);
- }
- }
- }
- }
- }
- gb.readUEG();
- var pic_order_cnt_type = gb.readUEG();
- if (pic_order_cnt_type === 0) {
- gb.readUEG();
- } else if (pic_order_cnt_type === 1) {
- gb.readBits(1);
- gb.readSEG();
- gb.readSEG();
- var num_ref_frames_in_pic_order_cnt_cycle = gb.readUEG();
- for (var i2 = 0; i2 < num_ref_frames_in_pic_order_cnt_cycle; i2++) {
- gb.readSEG();
- }
- }
- var ref_frames = gb.readUEG();
- gb.readBits(1);
- var pic_width_in_mbs_minus1 = gb.readUEG();
- var pic_height_in_map_units_minus1 = gb.readUEG();
- var frame_mbs_only_flag = gb.readBits(1);
- if (frame_mbs_only_flag === 0) {
- gb.readBits(1);
- }
- gb.readBits(1);
- var frame_crop_left_offset = 0;
- var frame_crop_right_offset = 0;
- var frame_crop_top_offset = 0;
- var frame_crop_bottom_offset = 0;
- var frame_cropping_flag = gb.readBool();
- if (frame_cropping_flag) {
- frame_crop_left_offset = gb.readUEG();
- frame_crop_right_offset = gb.readUEG();
- frame_crop_top_offset = gb.readUEG();
- frame_crop_bottom_offset = gb.readUEG();
- }
- var sar_width = 1, sar_height = 1;
- var fps = 0, fps_fixed = true, fps_num = 0, fps_den = 0;
- var vui_parameters_present_flag = gb.readBool();
- if (vui_parameters_present_flag) {
- if (gb.readBool()) {
- var aspect_ratio_idc = gb.readByte();
- var sar_w_table = [1, 12, 10, 16, 40, 24, 20, 32, 80, 18, 15, 64, 160, 4, 3, 2];
- var sar_h_table = [1, 11, 11, 11, 33, 11, 11, 11, 33, 11, 11, 33, 99, 3, 2, 1];
- if (aspect_ratio_idc > 0 && aspect_ratio_idc < 16) {
- sar_width = sar_w_table[aspect_ratio_idc - 1];
- sar_height = sar_h_table[aspect_ratio_idc - 1];
- } else if (aspect_ratio_idc === 255) {
- sar_width = gb.readByte() << 8 | gb.readByte();
- sar_height = gb.readByte() << 8 | gb.readByte();
- }
- }
- if (gb.readBool()) {
- gb.readBool();
- }
- if (gb.readBool()) {
- gb.readBits(4);
- if (gb.readBool()) {
- gb.readBits(24);
- }
- }
- if (gb.readBool()) {
- gb.readUEG();
- gb.readUEG();
- }
- if (gb.readBool()) {
- var num_units_in_tick = gb.readBits(32);
- var time_scale = gb.readBits(32);
- fps_fixed = gb.readBool();
- fps_num = time_scale;
- fps_den = num_units_in_tick * 2;
- fps = fps_num / fps_den;
- }
- }
- var sarScale = 1;
- if (sar_width !== 1 || sar_height !== 1) {
- sarScale = sar_width / sar_height;
- }
- var crop_unit_x = 0, crop_unit_y = 0;
- if (chroma_format_idc === 0) {
- crop_unit_x = 1;
- crop_unit_y = 2 - frame_mbs_only_flag;
- } else {
- var sub_wc = chroma_format_idc === 3 ? 1 : 2;
- var sub_hc = chroma_format_idc === 1 ? 2 : 1;
- crop_unit_x = sub_wc;
- crop_unit_y = sub_hc * (2 - frame_mbs_only_flag);
- }
- var codec_width = (pic_width_in_mbs_minus1 + 1) * 16;
- var codec_height = (2 - frame_mbs_only_flag) * ((pic_height_in_map_units_minus1 + 1) * 16);
- codec_width -= (frame_crop_left_offset + frame_crop_right_offset) * crop_unit_x;
- codec_height -= (frame_crop_top_offset + frame_crop_bottom_offset) * crop_unit_y;
- var present_width = Math.ceil(codec_width * sarScale);
- gb.destroy();
- gb = null;
- return {
- profile_string,
- level_string,
- bit_depth,
- ref_frames,
- chroma_format,
- chroma_format_string: SPSParser2.getChromaFormatString(chroma_format),
- frame_rate: {
- fixed: fps_fixed,
- fps,
- fps_den,
- fps_num
- },
- sar_ratio: {
- width: sar_width,
- height: sar_height
- },
- codec_size: {
- width: codec_width,
- height: codec_height
- },
- present_size: {
- width: present_width,
- height: codec_height
- }
- };
- };
- SPSParser2._skipScalingList = function(gb, count) {
- var last_scale = 8, next_scale = 8;
- var delta_scale = 0;
- for (var i2 = 0; i2 < count; i2++) {
- if (next_scale !== 0) {
- delta_scale = gb.readSEG();
- next_scale = (last_scale + delta_scale + 256) % 256;
- }
- last_scale = next_scale === 0 ? last_scale : next_scale;
- }
- };
- SPSParser2.getProfileString = function(profile_idc) {
- switch (profile_idc) {
- case 66:
- return "Baseline";
- case 77:
- return "Main";
- case 88:
- return "Extended";
- case 100:
- return "High";
- case 110:
- return "High10";
- case 122:
- return "High422";
- case 244:
- return "High444";
- default:
- return "Unknown";
- }
- };
- SPSParser2.getLevelString = function(level_idc) {
- return (level_idc / 10).toFixed(1);
- };
- SPSParser2.getChromaFormatString = function(chroma) {
- switch (chroma) {
- case 420:
- return "4:2:0";
- case 422:
- return "4:2:2";
- case 444:
- return "4:4:4";
- default:
- return "Unknown";
- }
- };
- return SPSParser2;
- }();
- __webpack_exports__2["default"] = SPSParser;
- },
- "./src/flv.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _utils_polyfill_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/utils/polyfill.js");
- var _core_features_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/core/features.js");
- var _io_loader_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/io/loader.js");
- var _player_flv_player_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__2("./src/player/flv-player.js");
- var _player_native_player_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__2("./src/player/native-player.js");
- var _player_player_events_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__2("./src/player/player-events.js");
- var _player_player_errors_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__2("./src/player/player-errors.js");
- var _utils_logging_control_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__2("./src/utils/logging-control.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__2("./src/utils/exception.js");
- _utils_polyfill_js__WEBPACK_IMPORTED_MODULE_0__.default.install();
- function createPlayer(mediaDataSource, optionalConfig) {
- var mds = mediaDataSource;
- if (mds == null || typeof mds !== "object") {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_8__.InvalidArgumentException("MediaDataSource must be an javascript object!");
- }
- if (!mds.hasOwnProperty("type")) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_8__.InvalidArgumentException("MediaDataSource must has type field to indicate video file type!");
- }
- switch (mds.type) {
- case "flv":
- return new _player_flv_player_js__WEBPACK_IMPORTED_MODULE_3__.default(mds, optionalConfig);
- default:
- return new _player_native_player_js__WEBPACK_IMPORTED_MODULE_4__.default(mds, optionalConfig);
- }
- }
- function isSupported() {
- return _core_features_js__WEBPACK_IMPORTED_MODULE_1__.default.supportMSEH264Playback();
- }
- function getFeatureList() {
- return _core_features_js__WEBPACK_IMPORTED_MODULE_1__.default.getFeatureList();
- }
- var flvjs2 = {};
- flvjs2.createPlayer = createPlayer;
- flvjs2.isSupported = isSupported;
- flvjs2.getFeatureList = getFeatureList;
- flvjs2.BaseLoader = _io_loader_js__WEBPACK_IMPORTED_MODULE_2__.BaseLoader;
- flvjs2.LoaderStatus = _io_loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderStatus;
- flvjs2.LoaderErrors = _io_loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderErrors;
- flvjs2.Events = _player_player_events_js__WEBPACK_IMPORTED_MODULE_5__.default;
- flvjs2.ErrorTypes = _player_player_errors_js__WEBPACK_IMPORTED_MODULE_6__.ErrorTypes;
- flvjs2.ErrorDetails = _player_player_errors_js__WEBPACK_IMPORTED_MODULE_6__.ErrorDetails;
- flvjs2.FlvPlayer = _player_flv_player_js__WEBPACK_IMPORTED_MODULE_3__.default;
- flvjs2.NativePlayer = _player_native_player_js__WEBPACK_IMPORTED_MODULE_4__.default;
- flvjs2.LoggingControl = _utils_logging_control_js__WEBPACK_IMPORTED_MODULE_7__.default;
- Object.defineProperty(flvjs2, "version", {
- enumerable: true,
- get: function() {
- return "1.6.2";
- }
- });
- __webpack_exports__2["default"] = flvjs2;
- },
- "./src/index.js": function(module3, __unused_webpack_exports, __webpack_require__2) {
- module3.exports = __webpack_require__2("./src/flv.js").default;
- },
- "./src/io/fetch-stream-loader.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _utils_browser_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/utils/browser.js");
- var _loader_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/io/loader.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/utils/exception.js");
- var __extends = function() {
- var extendStatics = function(d2, b) {
- extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(d3, b2) {
- d3.__proto__ = b2;
- } || function(d3, b2) {
- for (var p in b2)
- if (Object.prototype.hasOwnProperty.call(b2, p))
- d3[p] = b2[p];
- };
- return extendStatics(d2, b);
- };
- return function(d2, b) {
- if (typeof b !== "function" && b !== null)
- throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
- extendStatics(d2, b);
- function __() {
- this.constructor = d2;
- }
- d2.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var FetchStreamLoader = function(_super) {
- __extends(FetchStreamLoader2, _super);
- function FetchStreamLoader2(seekHandler, config) {
- var _this = _super.call(this, "fetch-stream-loader") || this;
- _this.TAG = "FetchStreamLoader";
- _this._seekHandler = seekHandler;
- _this._config = config;
- _this._needStash = true;
- _this._requestAbort = false;
- _this._contentLength = null;
- _this._receivedLength = 0;
- return _this;
- }
- FetchStreamLoader2.isSupported = function() {
- try {
- var isWorkWellEdge = _utils_browser_js__WEBPACK_IMPORTED_MODULE_0__.default.msedge && _utils_browser_js__WEBPACK_IMPORTED_MODULE_0__.default.version.minor >= 15048;
- var browserNotBlacklisted = _utils_browser_js__WEBPACK_IMPORTED_MODULE_0__.default.msedge ? isWorkWellEdge : true;
- return self.fetch && self.ReadableStream && browserNotBlacklisted;
- } catch (e) {
- return false;
- }
- };
- FetchStreamLoader2.prototype.destroy = function() {
- if (this.isWorking()) {
- this.abort();
- }
- _super.prototype.destroy.call(this);
- };
- FetchStreamLoader2.prototype.open = function(dataSource, range3) {
- var _this = this;
- this._dataSource = dataSource;
- this._range = range3;
- var sourceURL = dataSource.url;
- if (this._config.reuseRedirectedURL && dataSource.redirectedURL != void 0) {
- sourceURL = dataSource.redirectedURL;
- }
- var seekConfig = this._seekHandler.getConfig(sourceURL, range3);
- var headers = new self.Headers();
- if (typeof seekConfig.headers === "object") {
- var configHeaders = seekConfig.headers;
- for (var key in configHeaders) {
- if (configHeaders.hasOwnProperty(key)) {
- headers.append(key, configHeaders[key]);
- }
- }
- }
- var params = {
- method: "GET",
- headers,
- mode: "cors",
- cache: "default",
- referrerPolicy: "no-referrer-when-downgrade"
- };
- if (typeof this._config.headers === "object") {
- for (var key in this._config.headers) {
- headers.append(key, this._config.headers[key]);
- }
- }
- if (dataSource.cors === false) {
- params.mode = "same-origin";
- }
- if (dataSource.withCredentials) {
- params.credentials = "include";
- }
- if (dataSource.referrerPolicy) {
- params.referrerPolicy = dataSource.referrerPolicy;
- }
- if (self.AbortController) {
- this._abortController = new self.AbortController();
- params.signal = this._abortController.signal;
- }
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kConnecting;
- self.fetch(seekConfig.url, params).then(function(res) {
- if (_this._requestAbort) {
- _this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kIdle;
- res.body.cancel();
- return;
- }
- if (res.ok && (res.status >= 200 && res.status <= 299)) {
- if (res.url !== seekConfig.url) {
- if (_this._onURLRedirect) {
- var redirectedURL = _this._seekHandler.removeURLParameters(res.url);
- _this._onURLRedirect(redirectedURL);
- }
- }
- var lengthHeader = res.headers.get("Content-Length");
- if (lengthHeader != null) {
- _this._contentLength = parseInt(lengthHeader);
- if (_this._contentLength !== 0) {
- if (_this._onContentLengthKnown) {
- _this._onContentLengthKnown(_this._contentLength);
- }
- }
- }
- return _this._pump.call(_this, res.body.getReader());
- } else {
- _this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kError;
- if (_this._onError) {
- _this._onError(_loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderErrors.HTTP_STATUS_CODE_INVALID, { code: res.status, msg: res.statusText });
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__.RuntimeException("FetchStreamLoader: Http code invalid, " + res.status + " " + res.statusText);
- }
- }
- }).catch(function(e) {
- if (_this._abortController && _this._abortController.signal.aborted) {
- return;
- }
- _this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kError;
- if (_this._onError) {
- _this._onError(_loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderErrors.EXCEPTION, { code: -1, msg: e.message });
- } else {
- throw e;
- }
- });
- };
- FetchStreamLoader2.prototype.abort = function() {
- this._requestAbort = true;
- if (this._status !== _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kBuffering || !_utils_browser_js__WEBPACK_IMPORTED_MODULE_0__.default.chrome) {
- if (this._abortController) {
- try {
- this._abortController.abort();
- } catch (e) {
- }
- }
- }
- };
- FetchStreamLoader2.prototype._pump = function(reader) {
- var _this = this;
- return reader.read().then(function(result) {
- if (result.done) {
- if (_this._contentLength !== null && _this._receivedLength < _this._contentLength) {
- _this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kError;
- var type2 = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderErrors.EARLY_EOF;
- var info = { code: -1, msg: "Fetch stream meet Early-EOF" };
- if (_this._onError) {
- _this._onError(type2, info);
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__.RuntimeException(info.msg);
- }
- } else {
- _this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kComplete;
- if (_this._onComplete) {
- _this._onComplete(_this._range.from, _this._range.from + _this._receivedLength - 1);
- }
- }
- } else {
- if (_this._abortController && _this._abortController.signal.aborted) {
- _this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kComplete;
- return;
- } else if (_this._requestAbort === true) {
- _this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kComplete;
- return reader.cancel();
- }
- _this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kBuffering;
- var chunk = result.value.buffer;
- var byteStart = _this._range.from + _this._receivedLength;
- _this._receivedLength += chunk.byteLength;
- if (_this._onDataArrival) {
- _this._onDataArrival(chunk, byteStart, _this._receivedLength);
- }
- _this._pump(reader);
- }
- }).catch(function(e) {
- if (_this._abortController && _this._abortController.signal.aborted) {
- _this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kComplete;
- return;
- }
- if (e.code === 11 && _utils_browser_js__WEBPACK_IMPORTED_MODULE_0__.default.msedge) {
- return;
- }
- _this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kError;
- var type2 = 0;
- var info = null;
- if ((e.code === 19 || e.message === "network error") && (_this._contentLength === null || _this._contentLength !== null && _this._receivedLength < _this._contentLength)) {
- type2 = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderErrors.EARLY_EOF;
- info = { code: e.code, msg: "Fetch stream meet Early-EOF" };
- } else {
- type2 = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderErrors.EXCEPTION;
- info = { code: e.code, msg: e.message };
- }
- if (_this._onError) {
- _this._onError(type2, info);
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__.RuntimeException(info.msg);
- }
- });
- };
- return FetchStreamLoader2;
- }(_loader_js__WEBPACK_IMPORTED_MODULE_1__.BaseLoader);
- __webpack_exports__2["default"] = FetchStreamLoader;
- },
- "./src/io/io-controller.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/utils/logger.js");
- var _speed_sampler_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/io/speed-sampler.js");
- var _loader_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/io/loader.js");
- var _fetch_stream_loader_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__2("./src/io/fetch-stream-loader.js");
- var _xhr_moz_chunked_loader_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__2("./src/io/xhr-moz-chunked-loader.js");
- var _xhr_range_loader_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__2("./src/io/xhr-range-loader.js");
- var _websocket_loader_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__2("./src/io/websocket-loader.js");
- var _range_seek_handler_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__2("./src/io/range-seek-handler.js");
- var _param_seek_handler_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__2("./src/io/param-seek-handler.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__2("./src/utils/exception.js");
- var IOController = function() {
- function IOController2(dataSource, config, extraData) {
- this.TAG = "IOController";
- this._config = config;
- this._extraData = extraData;
- this._stashInitialSize = 1024 * 384;
- if (config.stashInitialSize != void 0 && config.stashInitialSize > 0) {
- this._stashInitialSize = config.stashInitialSize;
- }
- this._stashUsed = 0;
- this._stashSize = this._stashInitialSize;
- this._bufferSize = 1024 * 1024 * 3;
- this._stashBuffer = new ArrayBuffer(this._bufferSize);
- this._stashByteStart = 0;
- this._enableStash = true;
- if (config.enableStashBuffer === false) {
- this._enableStash = false;
- }
- this._loader = null;
- this._loaderClass = null;
- this._seekHandler = null;
- this._dataSource = dataSource;
- this._isWebSocketURL = /wss?:\/\/(.+?)/.test(dataSource.url);
- this._refTotalLength = dataSource.filesize ? dataSource.filesize : null;
- this._totalLength = this._refTotalLength;
- this._fullRequestFlag = false;
- this._currentRange = null;
- this._redirectedURL = null;
- this._speedNormalized = 0;
- this._speedSampler = new _speed_sampler_js__WEBPACK_IMPORTED_MODULE_1__.default();
- this._speedNormalizeList = [64, 128, 256, 384, 512, 768, 1024, 1536, 2048, 3072, 4096];
- this._isEarlyEofReconnecting = false;
- this._paused = false;
- this._resumeFrom = 0;
- this._onDataArrival = null;
- this._onSeeked = null;
- this._onError = null;
- this._onComplete = null;
- this._onRedirect = null;
- this._onRecoveredEarlyEof = null;
- this._selectSeekHandler();
- this._selectLoader();
- this._createLoader();
- }
- IOController2.prototype.destroy = function() {
- if (this._loader.isWorking()) {
- this._loader.abort();
- }
- this._loader.destroy();
- this._loader = null;
- this._loaderClass = null;
- this._dataSource = null;
- this._stashBuffer = null;
- this._stashUsed = this._stashSize = this._bufferSize = this._stashByteStart = 0;
- this._currentRange = null;
- this._speedSampler = null;
- this._isEarlyEofReconnecting = false;
- this._onDataArrival = null;
- this._onSeeked = null;
- this._onError = null;
- this._onComplete = null;
- this._onRedirect = null;
- this._onRecoveredEarlyEof = null;
- this._extraData = null;
- };
- IOController2.prototype.isWorking = function() {
- return this._loader && this._loader.isWorking() && !this._paused;
- };
- IOController2.prototype.isPaused = function() {
- return this._paused;
- };
- Object.defineProperty(IOController2.prototype, "status", {
- get: function() {
- return this._loader.status;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "extraData", {
- get: function() {
- return this._extraData;
- },
- set: function(data) {
- this._extraData = data;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "onDataArrival", {
- get: function() {
- return this._onDataArrival;
- },
- set: function(callback2) {
- this._onDataArrival = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "onSeeked", {
- get: function() {
- return this._onSeeked;
- },
- set: function(callback2) {
- this._onSeeked = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "onError", {
- get: function() {
- return this._onError;
- },
- set: function(callback2) {
- this._onError = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "onComplete", {
- get: function() {
- return this._onComplete;
- },
- set: function(callback2) {
- this._onComplete = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "onRedirect", {
- get: function() {
- return this._onRedirect;
- },
- set: function(callback2) {
- this._onRedirect = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "onRecoveredEarlyEof", {
- get: function() {
- return this._onRecoveredEarlyEof;
- },
- set: function(callback2) {
- this._onRecoveredEarlyEof = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "currentURL", {
- get: function() {
- return this._dataSource.url;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "hasRedirect", {
- get: function() {
- return this._redirectedURL != null || this._dataSource.redirectedURL != void 0;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "currentRedirectedURL", {
- get: function() {
- return this._redirectedURL || this._dataSource.redirectedURL;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "currentSpeed", {
- get: function() {
- if (this._loaderClass === _xhr_range_loader_js__WEBPACK_IMPORTED_MODULE_5__.default) {
- return this._loader.currentSpeed;
- }
- return this._speedSampler.lastSecondKBps;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(IOController2.prototype, "loaderType", {
- get: function() {
- return this._loader.type;
- },
- enumerable: false,
- configurable: true
- });
- IOController2.prototype._selectSeekHandler = function() {
- var config = this._config;
- if (config.seekType === "range") {
- this._seekHandler = new _range_seek_handler_js__WEBPACK_IMPORTED_MODULE_7__.default(this._config.rangeLoadZeroStart);
- } else if (config.seekType === "param") {
- var paramStart = config.seekParamStart || "bstart";
- var paramEnd = config.seekParamEnd || "bend";
- this._seekHandler = new _param_seek_handler_js__WEBPACK_IMPORTED_MODULE_8__.default(paramStart, paramEnd);
- } else if (config.seekType === "custom") {
- if (typeof config.customSeekHandler !== "function") {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_9__.InvalidArgumentException("Custom seekType specified in config but invalid customSeekHandler!");
- }
- this._seekHandler = new config.customSeekHandler();
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_9__.InvalidArgumentException("Invalid seekType in config: " + config.seekType);
- }
- };
- IOController2.prototype._selectLoader = function() {
- if (this._config.customLoader != null) {
- this._loaderClass = this._config.customLoader;
- } else if (this._isWebSocketURL) {
- this._loaderClass = _websocket_loader_js__WEBPACK_IMPORTED_MODULE_6__.default;
- } else if (_fetch_stream_loader_js__WEBPACK_IMPORTED_MODULE_3__.default.isSupported()) {
- this._loaderClass = _fetch_stream_loader_js__WEBPACK_IMPORTED_MODULE_3__.default;
- } else if (_xhr_moz_chunked_loader_js__WEBPACK_IMPORTED_MODULE_4__.default.isSupported()) {
- this._loaderClass = _xhr_moz_chunked_loader_js__WEBPACK_IMPORTED_MODULE_4__.default;
- } else if (_xhr_range_loader_js__WEBPACK_IMPORTED_MODULE_5__.default.isSupported()) {
- this._loaderClass = _xhr_range_loader_js__WEBPACK_IMPORTED_MODULE_5__.default;
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_9__.RuntimeException("Your browser doesn't support xhr with arraybuffer responseType!");
- }
- };
- IOController2.prototype._createLoader = function() {
- this._loader = new this._loaderClass(this._seekHandler, this._config);
- if (this._loader.needStashBuffer === false) {
- this._enableStash = false;
- }
- this._loader.onContentLengthKnown = this._onContentLengthKnown.bind(this);
- this._loader.onURLRedirect = this._onURLRedirect.bind(this);
- this._loader.onDataArrival = this._onLoaderChunkArrival.bind(this);
- this._loader.onComplete = this._onLoaderComplete.bind(this);
- this._loader.onError = this._onLoaderError.bind(this);
- };
- IOController2.prototype.open = function(optionalFrom) {
- this._currentRange = { from: 0, to: -1 };
- if (optionalFrom) {
- this._currentRange.from = optionalFrom;
- }
- this._speedSampler.reset();
- if (!optionalFrom) {
- this._fullRequestFlag = true;
- }
- this._loader.open(this._dataSource, Object.assign({}, this._currentRange));
- };
- IOController2.prototype.abort = function() {
- this._loader.abort();
- if (this._paused) {
- this._paused = false;
- this._resumeFrom = 0;
- }
- };
- IOController2.prototype.pause = function() {
- if (this.isWorking()) {
- this._loader.abort();
- if (this._stashUsed !== 0) {
- this._resumeFrom = this._stashByteStart;
- this._currentRange.to = this._stashByteStart - 1;
- } else {
- this._resumeFrom = this._currentRange.to + 1;
- }
- this._stashUsed = 0;
- this._stashByteStart = 0;
- this._paused = true;
- }
- };
- IOController2.prototype.resume = function() {
- if (this._paused) {
- this._paused = false;
- var bytes = this._resumeFrom;
- this._resumeFrom = 0;
- this._internalSeek(bytes, true);
- }
- };
- IOController2.prototype.seek = function(bytes) {
- this._paused = false;
- this._stashUsed = 0;
- this._stashByteStart = 0;
- this._internalSeek(bytes, true);
- };
- IOController2.prototype._internalSeek = function(bytes, dropUnconsumed) {
- if (this._loader.isWorking()) {
- this._loader.abort();
- }
- this._flushStashBuffer(dropUnconsumed);
- this._loader.destroy();
- this._loader = null;
- var requestRange = { from: bytes, to: -1 };
- this._currentRange = { from: requestRange.from, to: -1 };
- this._speedSampler.reset();
- this._stashSize = this._stashInitialSize;
- this._createLoader();
- this._loader.open(this._dataSource, requestRange);
- if (this._onSeeked) {
- this._onSeeked();
- }
- };
- IOController2.prototype.updateUrl = function(url) {
- if (!url || typeof url !== "string" || url.length === 0) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_9__.InvalidArgumentException("Url must be a non-empty string!");
- }
- this._dataSource.url = url;
- };
- IOController2.prototype._expandBuffer = function(expectedBytes) {
- var bufferNewSize = this._stashSize;
- while (bufferNewSize + 1024 * 1024 * 1 < expectedBytes) {
- bufferNewSize *= 2;
- }
- bufferNewSize += 1024 * 1024 * 1;
- if (bufferNewSize === this._bufferSize) {
- return;
- }
- var newBuffer = new ArrayBuffer(bufferNewSize);
- if (this._stashUsed > 0) {
- var stashOldArray = new Uint8Array(this._stashBuffer, 0, this._stashUsed);
- var stashNewArray = new Uint8Array(newBuffer, 0, bufferNewSize);
- stashNewArray.set(stashOldArray, 0);
- }
- this._stashBuffer = newBuffer;
- this._bufferSize = bufferNewSize;
- };
- IOController2.prototype._normalizeSpeed = function(input) {
- var list = this._speedNormalizeList;
- var last = list.length - 1;
- var mid = 0;
- var lbound = 0;
- var ubound = last;
- if (input < list[0]) {
- return list[0];
- }
- while (lbound <= ubound) {
- mid = lbound + Math.floor((ubound - lbound) / 2);
- if (mid === last || input >= list[mid] && input < list[mid + 1]) {
- return list[mid];
- } else if (list[mid] < input) {
- lbound = mid + 1;
- } else {
- ubound = mid - 1;
- }
- }
- };
- IOController2.prototype._adjustStashSize = function(normalized) {
- var stashSizeKB = 0;
- if (this._config.isLive) {
- stashSizeKB = normalized;
- } else {
- if (normalized < 512) {
- stashSizeKB = normalized;
- } else if (normalized >= 512 && normalized <= 1024) {
- stashSizeKB = Math.floor(normalized * 1.5);
- } else {
- stashSizeKB = normalized * 2;
- }
- }
- if (stashSizeKB > 8192) {
- stashSizeKB = 8192;
- }
- var bufferSize = stashSizeKB * 1024 + 1024 * 1024 * 1;
- if (this._bufferSize < bufferSize) {
- this._expandBuffer(bufferSize);
- }
- this._stashSize = stashSizeKB * 1024;
- };
- IOController2.prototype._dispatchChunks = function(chunks, byteStart) {
- this._currentRange.to = byteStart + chunks.byteLength - 1;
- return this._onDataArrival(chunks, byteStart);
- };
- IOController2.prototype._onURLRedirect = function(redirectedURL) {
- this._redirectedURL = redirectedURL;
- if (this._onRedirect) {
- this._onRedirect(redirectedURL);
- }
- };
- IOController2.prototype._onContentLengthKnown = function(contentLength) {
- if (contentLength && this._fullRequestFlag) {
- this._totalLength = contentLength;
- this._fullRequestFlag = false;
- }
- };
- IOController2.prototype._onLoaderChunkArrival = function(chunk, byteStart, receivedLength) {
- if (!this._onDataArrival) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_9__.IllegalStateException("IOController: No existing consumer (onDataArrival) callback!");
- }
- if (this._paused) {
- return;
- }
- if (this._isEarlyEofReconnecting) {
- this._isEarlyEofReconnecting = false;
- if (this._onRecoveredEarlyEof) {
- this._onRecoveredEarlyEof();
- }
- }
- this._speedSampler.addBytes(chunk.byteLength);
- var KBps = this._speedSampler.lastSecondKBps;
- if (KBps !== 0) {
- var normalized = this._normalizeSpeed(KBps);
- if (this._speedNormalized !== normalized) {
- this._speedNormalized = normalized;
- this._adjustStashSize(normalized);
- }
- }
- if (!this._enableStash) {
- if (this._stashUsed === 0) {
- var consumed = this._dispatchChunks(chunk, byteStart);
- if (consumed < chunk.byteLength) {
- var remain = chunk.byteLength - consumed;
- if (remain > this._bufferSize) {
- this._expandBuffer(remain);
- }
- var stashArray = new Uint8Array(this._stashBuffer, 0, this._bufferSize);
- stashArray.set(new Uint8Array(chunk, consumed), 0);
- this._stashUsed += remain;
- this._stashByteStart = byteStart + consumed;
- }
- } else {
- if (this._stashUsed + chunk.byteLength > this._bufferSize) {
- this._expandBuffer(this._stashUsed + chunk.byteLength);
- }
- var stashArray = new Uint8Array(this._stashBuffer, 0, this._bufferSize);
- stashArray.set(new Uint8Array(chunk), this._stashUsed);
- this._stashUsed += chunk.byteLength;
- var consumed = this._dispatchChunks(this._stashBuffer.slice(0, this._stashUsed), this._stashByteStart);
- if (consumed < this._stashUsed && consumed > 0) {
- var remainArray = new Uint8Array(this._stashBuffer, consumed);
- stashArray.set(remainArray, 0);
- }
- this._stashUsed -= consumed;
- this._stashByteStart += consumed;
- }
- } else {
- if (this._stashUsed === 0 && this._stashByteStart === 0) {
- this._stashByteStart = byteStart;
- }
- if (this._stashUsed + chunk.byteLength <= this._stashSize) {
- var stashArray = new Uint8Array(this._stashBuffer, 0, this._stashSize);
- stashArray.set(new Uint8Array(chunk), this._stashUsed);
- this._stashUsed += chunk.byteLength;
- } else {
- var stashArray = new Uint8Array(this._stashBuffer, 0, this._bufferSize);
- if (this._stashUsed > 0) {
- var buffer = this._stashBuffer.slice(0, this._stashUsed);
- var consumed = this._dispatchChunks(buffer, this._stashByteStart);
- if (consumed < buffer.byteLength) {
- if (consumed > 0) {
- var remainArray = new Uint8Array(buffer, consumed);
- stashArray.set(remainArray, 0);
- this._stashUsed = remainArray.byteLength;
- this._stashByteStart += consumed;
- }
- } else {
- this._stashUsed = 0;
- this._stashByteStart += consumed;
- }
- if (this._stashUsed + chunk.byteLength > this._bufferSize) {
- this._expandBuffer(this._stashUsed + chunk.byteLength);
- stashArray = new Uint8Array(this._stashBuffer, 0, this._bufferSize);
- }
- stashArray.set(new Uint8Array(chunk), this._stashUsed);
- this._stashUsed += chunk.byteLength;
- } else {
- var consumed = this._dispatchChunks(chunk, byteStart);
- if (consumed < chunk.byteLength) {
- var remain = chunk.byteLength - consumed;
- if (remain > this._bufferSize) {
- this._expandBuffer(remain);
- stashArray = new Uint8Array(this._stashBuffer, 0, this._bufferSize);
- }
- stashArray.set(new Uint8Array(chunk, consumed), 0);
- this._stashUsed += remain;
- this._stashByteStart = byteStart + consumed;
- }
- }
- }
- }
- };
- IOController2.prototype._flushStashBuffer = function(dropUnconsumed) {
- if (this._stashUsed > 0) {
- var buffer = this._stashBuffer.slice(0, this._stashUsed);
- var consumed = this._dispatchChunks(buffer, this._stashByteStart);
- var remain = buffer.byteLength - consumed;
- if (consumed < buffer.byteLength) {
- if (dropUnconsumed) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, remain + " bytes unconsumed data remain when flush buffer, dropped");
- } else {
- if (consumed > 0) {
- var stashArray = new Uint8Array(this._stashBuffer, 0, this._bufferSize);
- var remainArray = new Uint8Array(buffer, consumed);
- stashArray.set(remainArray, 0);
- this._stashUsed = remainArray.byteLength;
- this._stashByteStart += consumed;
- }
- return 0;
- }
- }
- this._stashUsed = 0;
- this._stashByteStart = 0;
- return remain;
- }
- return 0;
- };
- IOController2.prototype._onLoaderComplete = function(from3, to) {
- this._flushStashBuffer(true);
- if (this._onComplete) {
- this._onComplete(this._extraData);
- }
- };
- IOController2.prototype._onLoaderError = function(type2, data) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.e(this.TAG, "Loader error, code = " + data.code + ", msg = " + data.msg);
- this._flushStashBuffer(false);
- if (this._isEarlyEofReconnecting) {
- this._isEarlyEofReconnecting = false;
- type2 = _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderErrors.UNRECOVERABLE_EARLY_EOF;
- }
- switch (type2) {
- case _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderErrors.EARLY_EOF: {
- if (!this._config.isLive) {
- if (this._totalLength) {
- var nextFrom = this._currentRange.to + 1;
- if (nextFrom < this._totalLength) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Connection lost, trying reconnect...");
- this._isEarlyEofReconnecting = true;
- this._internalSeek(nextFrom, false);
- }
- return;
- }
- }
- type2 = _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderErrors.UNRECOVERABLE_EARLY_EOF;
- break;
- }
- case _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderErrors.UNRECOVERABLE_EARLY_EOF:
- case _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderErrors.CONNECTING_TIMEOUT:
- case _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderErrors.HTTP_STATUS_CODE_INVALID:
- case _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderErrors.EXCEPTION:
- break;
- }
- if (this._onError) {
- this._onError(type2, data);
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_9__.RuntimeException("IOException: " + data.msg);
- }
- };
- return IOController2;
- }();
- __webpack_exports__2["default"] = IOController;
- },
- "./src/io/loader.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- __webpack_require__2.d(__webpack_exports__2, {
- "LoaderStatus": function() {
- return LoaderStatus;
- },
- "LoaderErrors": function() {
- return LoaderErrors;
- },
- "BaseLoader": function() {
- return BaseLoader;
- }
- });
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/utils/exception.js");
- var LoaderStatus = {
- kIdle: 0,
- kConnecting: 1,
- kBuffering: 2,
- kError: 3,
- kComplete: 4
- };
- var LoaderErrors = {
- OK: "OK",
- EXCEPTION: "Exception",
- HTTP_STATUS_CODE_INVALID: "HttpStatusCodeInvalid",
- CONNECTING_TIMEOUT: "ConnectingTimeout",
- EARLY_EOF: "EarlyEof",
- UNRECOVERABLE_EARLY_EOF: "UnrecoverableEarlyEof"
- };
- var BaseLoader = function() {
- function BaseLoader2(typeName) {
- this._type = typeName || "undefined";
- this._status = LoaderStatus.kIdle;
- this._needStash = false;
- this._onContentLengthKnown = null;
- this._onURLRedirect = null;
- this._onDataArrival = null;
- this._onError = null;
- this._onComplete = null;
- }
- BaseLoader2.prototype.destroy = function() {
- this._status = LoaderStatus.kIdle;
- this._onContentLengthKnown = null;
- this._onURLRedirect = null;
- this._onDataArrival = null;
- this._onError = null;
- this._onComplete = null;
- };
- BaseLoader2.prototype.isWorking = function() {
- return this._status === LoaderStatus.kConnecting || this._status === LoaderStatus.kBuffering;
- };
- Object.defineProperty(BaseLoader2.prototype, "type", {
- get: function() {
- return this._type;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(BaseLoader2.prototype, "status", {
- get: function() {
- return this._status;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(BaseLoader2.prototype, "needStashBuffer", {
- get: function() {
- return this._needStash;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(BaseLoader2.prototype, "onContentLengthKnown", {
- get: function() {
- return this._onContentLengthKnown;
- },
- set: function(callback2) {
- this._onContentLengthKnown = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(BaseLoader2.prototype, "onURLRedirect", {
- get: function() {
- return this._onURLRedirect;
- },
- set: function(callback2) {
- this._onURLRedirect = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(BaseLoader2.prototype, "onDataArrival", {
- get: function() {
- return this._onDataArrival;
- },
- set: function(callback2) {
- this._onDataArrival = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(BaseLoader2.prototype, "onError", {
- get: function() {
- return this._onError;
- },
- set: function(callback2) {
- this._onError = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(BaseLoader2.prototype, "onComplete", {
- get: function() {
- return this._onComplete;
- },
- set: function(callback2) {
- this._onComplete = callback2;
- },
- enumerable: false,
- configurable: true
- });
- BaseLoader2.prototype.open = function(dataSource, range3) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_0__.NotImplementedException("Unimplemented abstract function!");
- };
- BaseLoader2.prototype.abort = function() {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_0__.NotImplementedException("Unimplemented abstract function!");
- };
- return BaseLoader2;
- }();
- },
- "./src/io/param-seek-handler.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var ParamSeekHandler = function() {
- function ParamSeekHandler2(paramStart, paramEnd) {
- this._startName = paramStart;
- this._endName = paramEnd;
- }
- ParamSeekHandler2.prototype.getConfig = function(baseUrl, range3) {
- var url = baseUrl;
- if (range3.from !== 0 || range3.to !== -1) {
- var needAnd = true;
- if (url.indexOf("?") === -1) {
- url += "?";
- needAnd = false;
- }
- if (needAnd) {
- url += "&";
- }
- url += this._startName + "=" + range3.from.toString();
- if (range3.to !== -1) {
- url += "&" + this._endName + "=" + range3.to.toString();
- }
- }
- return {
- url,
- headers: {}
- };
- };
- ParamSeekHandler2.prototype.removeURLParameters = function(seekedURL) {
- var baseURL = seekedURL.split("?")[0];
- var params = void 0;
- var queryIndex = seekedURL.indexOf("?");
- if (queryIndex !== -1) {
- params = seekedURL.substring(queryIndex + 1);
- }
- var resultParams = "";
- if (params != void 0 && params.length > 0) {
- var pairs = params.split("&");
- for (var i2 = 0; i2 < pairs.length; i2++) {
- var pair = pairs[i2].split("=");
- var requireAnd = i2 > 0;
- if (pair[0] !== this._startName && pair[0] !== this._endName) {
- if (requireAnd) {
- resultParams += "&";
- }
- resultParams += pairs[i2];
- }
- }
- }
- return resultParams.length === 0 ? baseURL : baseURL + "?" + resultParams;
- };
- return ParamSeekHandler2;
- }();
- __webpack_exports__2["default"] = ParamSeekHandler;
- },
- "./src/io/range-seek-handler.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var RangeSeekHandler = function() {
- function RangeSeekHandler2(zeroStart) {
- this._zeroStart = zeroStart || false;
- }
- RangeSeekHandler2.prototype.getConfig = function(url, range3) {
- var headers = {};
- if (range3.from !== 0 || range3.to !== -1) {
- var param = void 0;
- if (range3.to !== -1) {
- param = "bytes=" + range3.from.toString() + "-" + range3.to.toString();
- } else {
- param = "bytes=" + range3.from.toString() + "-";
- }
- headers["Range"] = param;
- } else if (this._zeroStart) {
- headers["Range"] = "bytes=0-";
- }
- return {
- url,
- headers
- };
- };
- RangeSeekHandler2.prototype.removeURLParameters = function(seekedURL) {
- return seekedURL;
- };
- return RangeSeekHandler2;
- }();
- __webpack_exports__2["default"] = RangeSeekHandler;
- },
- "./src/io/speed-sampler.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var SpeedSampler = function() {
- function SpeedSampler2() {
- this._firstCheckpoint = 0;
- this._lastCheckpoint = 0;
- this._intervalBytes = 0;
- this._totalBytes = 0;
- this._lastSecondBytes = 0;
- if (self.performance && self.performance.now) {
- this._now = self.performance.now.bind(self.performance);
- } else {
- this._now = Date.now;
- }
- }
- SpeedSampler2.prototype.reset = function() {
- this._firstCheckpoint = this._lastCheckpoint = 0;
- this._totalBytes = this._intervalBytes = 0;
- this._lastSecondBytes = 0;
- };
- SpeedSampler2.prototype.addBytes = function(bytes) {
- if (this._firstCheckpoint === 0) {
- this._firstCheckpoint = this._now();
- this._lastCheckpoint = this._firstCheckpoint;
- this._intervalBytes += bytes;
- this._totalBytes += bytes;
- } else if (this._now() - this._lastCheckpoint < 1e3) {
- this._intervalBytes += bytes;
- this._totalBytes += bytes;
- } else {
- this._lastSecondBytes = this._intervalBytes;
- this._intervalBytes = bytes;
- this._totalBytes += bytes;
- this._lastCheckpoint = this._now();
- }
- };
- Object.defineProperty(SpeedSampler2.prototype, "currentKBps", {
- get: function() {
- this.addBytes(0);
- var durationSeconds = (this._now() - this._lastCheckpoint) / 1e3;
- if (durationSeconds == 0)
- durationSeconds = 1;
- return this._intervalBytes / durationSeconds / 1024;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(SpeedSampler2.prototype, "lastSecondKBps", {
- get: function() {
- this.addBytes(0);
- if (this._lastSecondBytes !== 0) {
- return this._lastSecondBytes / 1024;
- } else {
- if (this._now() - this._lastCheckpoint >= 500) {
- return this.currentKBps;
- } else {
- return 0;
- }
- }
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(SpeedSampler2.prototype, "averageKBps", {
- get: function() {
- var durationSeconds = (this._now() - this._firstCheckpoint) / 1e3;
- return this._totalBytes / durationSeconds / 1024;
- },
- enumerable: false,
- configurable: true
- });
- return SpeedSampler2;
- }();
- __webpack_exports__2["default"] = SpeedSampler;
- },
- "./src/io/websocket-loader.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _loader_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/io/loader.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/utils/exception.js");
- var __extends = function() {
- var extendStatics = function(d2, b) {
- extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(d3, b2) {
- d3.__proto__ = b2;
- } || function(d3, b2) {
- for (var p in b2)
- if (Object.prototype.hasOwnProperty.call(b2, p))
- d3[p] = b2[p];
- };
- return extendStatics(d2, b);
- };
- return function(d2, b) {
- if (typeof b !== "function" && b !== null)
- throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
- extendStatics(d2, b);
- function __() {
- this.constructor = d2;
- }
- d2.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var WebSocketLoader = function(_super) {
- __extends(WebSocketLoader2, _super);
- function WebSocketLoader2() {
- var _this = _super.call(this, "websocket-loader") || this;
- _this.TAG = "WebSocketLoader";
- _this._needStash = true;
- _this._ws = null;
- _this._requestAbort = false;
- _this._receivedLength = 0;
- return _this;
- }
- WebSocketLoader2.isSupported = function() {
- try {
- return typeof self.WebSocket !== "undefined";
- } catch (e) {
- return false;
- }
- };
- WebSocketLoader2.prototype.destroy = function() {
- if (this._ws) {
- this.abort();
- }
- _super.prototype.destroy.call(this);
- };
- WebSocketLoader2.prototype.open = function(dataSource) {
- try {
- var ws = this._ws = new self.WebSocket(dataSource.url);
- ws.binaryType = "arraybuffer";
- ws.onopen = this._onWebSocketOpen.bind(this);
- ws.onclose = this._onWebSocketClose.bind(this);
- ws.onmessage = this._onWebSocketMessage.bind(this);
- ws.onerror = this._onWebSocketError.bind(this);
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderStatus.kConnecting;
- } catch (e) {
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderStatus.kError;
- var info = { code: e.code, msg: e.message };
- if (this._onError) {
- this._onError(_loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderErrors.EXCEPTION, info);
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_1__.RuntimeException(info.msg);
- }
- }
- };
- WebSocketLoader2.prototype.abort = function() {
- var ws = this._ws;
- if (ws && (ws.readyState === 0 || ws.readyState === 1)) {
- this._requestAbort = true;
- ws.close();
- }
- this._ws = null;
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderStatus.kComplete;
- };
- WebSocketLoader2.prototype._onWebSocketOpen = function(e) {
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderStatus.kBuffering;
- };
- WebSocketLoader2.prototype._onWebSocketClose = function(e) {
- if (this._requestAbort === true) {
- this._requestAbort = false;
- return;
- }
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderStatus.kComplete;
- if (this._onComplete) {
- this._onComplete(0, this._receivedLength - 1);
- }
- };
- WebSocketLoader2.prototype._onWebSocketMessage = function(e) {
- var _this = this;
- if (e.data instanceof ArrayBuffer) {
- this._dispatchArrayBuffer(e.data);
- } else if (e.data instanceof Blob) {
- var reader_1 = new FileReader();
- reader_1.onload = function() {
- _this._dispatchArrayBuffer(reader_1.result);
- };
- reader_1.readAsArrayBuffer(e.data);
- } else {
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderStatus.kError;
- var info = { code: -1, msg: "Unsupported WebSocket message type: " + e.data.constructor.name };
- if (this._onError) {
- this._onError(_loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderErrors.EXCEPTION, info);
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_1__.RuntimeException(info.msg);
- }
- }
- };
- WebSocketLoader2.prototype._dispatchArrayBuffer = function(arraybuffer) {
- var chunk = arraybuffer;
- var byteStart = this._receivedLength;
- this._receivedLength += chunk.byteLength;
- if (this._onDataArrival) {
- this._onDataArrival(chunk, byteStart, this._receivedLength);
- }
- };
- WebSocketLoader2.prototype._onWebSocketError = function(e) {
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderStatus.kError;
- var info = {
- code: e.code,
- msg: e.message
- };
- if (this._onError) {
- this._onError(_loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderErrors.EXCEPTION, info);
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_1__.RuntimeException(info.msg);
- }
- };
- return WebSocketLoader2;
- }(_loader_js__WEBPACK_IMPORTED_MODULE_0__.BaseLoader);
- __webpack_exports__2["default"] = WebSocketLoader;
- },
- "./src/io/xhr-moz-chunked-loader.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/utils/logger.js");
- var _loader_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/io/loader.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/utils/exception.js");
- var __extends = function() {
- var extendStatics = function(d2, b) {
- extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(d3, b2) {
- d3.__proto__ = b2;
- } || function(d3, b2) {
- for (var p in b2)
- if (Object.prototype.hasOwnProperty.call(b2, p))
- d3[p] = b2[p];
- };
- return extendStatics(d2, b);
- };
- return function(d2, b) {
- if (typeof b !== "function" && b !== null)
- throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
- extendStatics(d2, b);
- function __() {
- this.constructor = d2;
- }
- d2.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var MozChunkedLoader = function(_super) {
- __extends(MozChunkedLoader2, _super);
- function MozChunkedLoader2(seekHandler, config) {
- var _this = _super.call(this, "xhr-moz-chunked-loader") || this;
- _this.TAG = "MozChunkedLoader";
- _this._seekHandler = seekHandler;
- _this._config = config;
- _this._needStash = true;
- _this._xhr = null;
- _this._requestAbort = false;
- _this._contentLength = null;
- _this._receivedLength = 0;
- return _this;
- }
- MozChunkedLoader2.isSupported = function() {
- try {
- var xhr = new XMLHttpRequest();
- xhr.open("GET", "https://example.com", true);
- xhr.responseType = "moz-chunked-arraybuffer";
- return xhr.responseType === "moz-chunked-arraybuffer";
- } catch (e) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w("MozChunkedLoader", e.message);
- return false;
- }
- };
- MozChunkedLoader2.prototype.destroy = function() {
- if (this.isWorking()) {
- this.abort();
- }
- if (this._xhr) {
- this._xhr.onreadystatechange = null;
- this._xhr.onprogress = null;
- this._xhr.onloadend = null;
- this._xhr.onerror = null;
- this._xhr = null;
- }
- _super.prototype.destroy.call(this);
- };
- MozChunkedLoader2.prototype.open = function(dataSource, range3) {
- this._dataSource = dataSource;
- this._range = range3;
- var sourceURL = dataSource.url;
- if (this._config.reuseRedirectedURL && dataSource.redirectedURL != void 0) {
- sourceURL = dataSource.redirectedURL;
- }
- var seekConfig = this._seekHandler.getConfig(sourceURL, range3);
- this._requestURL = seekConfig.url;
- var xhr = this._xhr = new XMLHttpRequest();
- xhr.open("GET", seekConfig.url, true);
- xhr.responseType = "moz-chunked-arraybuffer";
- xhr.onreadystatechange = this._onReadyStateChange.bind(this);
- xhr.onprogress = this._onProgress.bind(this);
- xhr.onloadend = this._onLoadEnd.bind(this);
- xhr.onerror = this._onXhrError.bind(this);
- if (dataSource.withCredentials) {
- xhr.withCredentials = true;
- }
- if (typeof seekConfig.headers === "object") {
- var headers = seekConfig.headers;
- for (var key in headers) {
- if (headers.hasOwnProperty(key)) {
- xhr.setRequestHeader(key, headers[key]);
- }
- }
- }
- if (typeof this._config.headers === "object") {
- var headers = this._config.headers;
- for (var key in headers) {
- if (headers.hasOwnProperty(key)) {
- xhr.setRequestHeader(key, headers[key]);
- }
- }
- }
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kConnecting;
- xhr.send();
- };
- MozChunkedLoader2.prototype.abort = function() {
- this._requestAbort = true;
- if (this._xhr) {
- this._xhr.abort();
- }
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kComplete;
- };
- MozChunkedLoader2.prototype._onReadyStateChange = function(e) {
- var xhr = e.target;
- if (xhr.readyState === 2) {
- if (xhr.responseURL != void 0 && xhr.responseURL !== this._requestURL) {
- if (this._onURLRedirect) {
- var redirectedURL = this._seekHandler.removeURLParameters(xhr.responseURL);
- this._onURLRedirect(redirectedURL);
- }
- }
- if (xhr.status !== 0 && (xhr.status < 200 || xhr.status > 299)) {
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kError;
- if (this._onError) {
- this._onError(_loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderErrors.HTTP_STATUS_CODE_INVALID, { code: xhr.status, msg: xhr.statusText });
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__.RuntimeException("MozChunkedLoader: Http code invalid, " + xhr.status + " " + xhr.statusText);
- }
- } else {
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kBuffering;
- }
- }
- };
- MozChunkedLoader2.prototype._onProgress = function(e) {
- if (this._status === _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kError) {
- return;
- }
- if (this._contentLength === null) {
- if (e.total !== null && e.total !== 0) {
- this._contentLength = e.total;
- if (this._onContentLengthKnown) {
- this._onContentLengthKnown(this._contentLength);
- }
- }
- }
- var chunk = e.target.response;
- var byteStart = this._range.from + this._receivedLength;
- this._receivedLength += chunk.byteLength;
- if (this._onDataArrival) {
- this._onDataArrival(chunk, byteStart, this._receivedLength);
- }
- };
- MozChunkedLoader2.prototype._onLoadEnd = function(e) {
- if (this._requestAbort === true) {
- this._requestAbort = false;
- return;
- } else if (this._status === _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kError) {
- return;
- }
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kComplete;
- if (this._onComplete) {
- this._onComplete(this._range.from, this._range.from + this._receivedLength - 1);
- }
- };
- MozChunkedLoader2.prototype._onXhrError = function(e) {
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderStatus.kError;
- var type2 = 0;
- var info = null;
- if (this._contentLength && e.loaded < this._contentLength) {
- type2 = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderErrors.EARLY_EOF;
- info = { code: -1, msg: "Moz-Chunked stream meet Early-Eof" };
- } else {
- type2 = _loader_js__WEBPACK_IMPORTED_MODULE_1__.LoaderErrors.EXCEPTION;
- info = { code: -1, msg: e.constructor.name + " " + e.type };
- }
- if (this._onError) {
- this._onError(type2, info);
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_2__.RuntimeException(info.msg);
- }
- };
- return MozChunkedLoader2;
- }(_loader_js__WEBPACK_IMPORTED_MODULE_1__.BaseLoader);
- __webpack_exports__2["default"] = MozChunkedLoader;
- },
- "./src/io/xhr-range-loader.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/utils/logger.js");
- var _speed_sampler_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/io/speed-sampler.js");
- var _loader_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/io/loader.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__2("./src/utils/exception.js");
- var __extends = function() {
- var extendStatics = function(d2, b) {
- extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(d3, b2) {
- d3.__proto__ = b2;
- } || function(d3, b2) {
- for (var p in b2)
- if (Object.prototype.hasOwnProperty.call(b2, p))
- d3[p] = b2[p];
- };
- return extendStatics(d2, b);
- };
- return function(d2, b) {
- if (typeof b !== "function" && b !== null)
- throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
- extendStatics(d2, b);
- function __() {
- this.constructor = d2;
- }
- d2.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var RangeLoader = function(_super) {
- __extends(RangeLoader2, _super);
- function RangeLoader2(seekHandler, config) {
- var _this = _super.call(this, "xhr-range-loader") || this;
- _this.TAG = "RangeLoader";
- _this._seekHandler = seekHandler;
- _this._config = config;
- _this._needStash = false;
- _this._chunkSizeKBList = [
- 128,
- 256,
- 384,
- 512,
- 768,
- 1024,
- 1536,
- 2048,
- 3072,
- 4096,
- 5120,
- 6144,
- 7168,
- 8192
- ];
- _this._currentChunkSizeKB = 384;
- _this._currentSpeedNormalized = 0;
- _this._zeroSpeedChunkCount = 0;
- _this._xhr = null;
- _this._speedSampler = new _speed_sampler_js__WEBPACK_IMPORTED_MODULE_1__.default();
- _this._requestAbort = false;
- _this._waitForTotalLength = false;
- _this._totalLengthReceived = false;
- _this._currentRequestURL = null;
- _this._currentRedirectedURL = null;
- _this._currentRequestRange = null;
- _this._totalLength = null;
- _this._contentLength = null;
- _this._receivedLength = 0;
- _this._lastTimeLoaded = 0;
- return _this;
- }
- RangeLoader2.isSupported = function() {
- try {
- var xhr = new XMLHttpRequest();
- xhr.open("GET", "https://example.com", true);
- xhr.responseType = "arraybuffer";
- return xhr.responseType === "arraybuffer";
- } catch (e) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w("RangeLoader", e.message);
- return false;
- }
- };
- RangeLoader2.prototype.destroy = function() {
- if (this.isWorking()) {
- this.abort();
- }
- if (this._xhr) {
- this._xhr.onreadystatechange = null;
- this._xhr.onprogress = null;
- this._xhr.onload = null;
- this._xhr.onerror = null;
- this._xhr = null;
- }
- _super.prototype.destroy.call(this);
- };
- Object.defineProperty(RangeLoader2.prototype, "currentSpeed", {
- get: function() {
- return this._speedSampler.lastSecondKBps;
- },
- enumerable: false,
- configurable: true
- });
- RangeLoader2.prototype.open = function(dataSource, range3) {
- this._dataSource = dataSource;
- this._range = range3;
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderStatus.kConnecting;
- var useRefTotalLength = false;
- if (this._dataSource.filesize != void 0 && this._dataSource.filesize !== 0) {
- useRefTotalLength = true;
- this._totalLength = this._dataSource.filesize;
- }
- if (!this._totalLengthReceived && !useRefTotalLength) {
- this._waitForTotalLength = true;
- this._internalOpen(this._dataSource, { from: 0, to: -1 });
- } else {
- this._openSubRange();
- }
- };
- RangeLoader2.prototype._openSubRange = function() {
- var chunkSize = this._currentChunkSizeKB * 1024;
- var from3 = this._range.from + this._receivedLength;
- var to = from3 + chunkSize;
- if (this._contentLength != null) {
- if (to - this._range.from >= this._contentLength) {
- to = this._range.from + this._contentLength - 1;
- }
- }
- this._currentRequestRange = { from: from3, to };
- this._internalOpen(this._dataSource, this._currentRequestRange);
- };
- RangeLoader2.prototype._internalOpen = function(dataSource, range3) {
- this._lastTimeLoaded = 0;
- var sourceURL = dataSource.url;
- if (this._config.reuseRedirectedURL) {
- if (this._currentRedirectedURL != void 0) {
- sourceURL = this._currentRedirectedURL;
- } else if (dataSource.redirectedURL != void 0) {
- sourceURL = dataSource.redirectedURL;
- }
- }
- var seekConfig = this._seekHandler.getConfig(sourceURL, range3);
- this._currentRequestURL = seekConfig.url;
- var xhr = this._xhr = new XMLHttpRequest();
- xhr.open("GET", seekConfig.url, true);
- xhr.responseType = "arraybuffer";
- xhr.onreadystatechange = this._onReadyStateChange.bind(this);
- xhr.onprogress = this._onProgress.bind(this);
- xhr.onload = this._onLoad.bind(this);
- xhr.onerror = this._onXhrError.bind(this);
- if (dataSource.withCredentials) {
- xhr.withCredentials = true;
- }
- if (typeof seekConfig.headers === "object") {
- var headers = seekConfig.headers;
- for (var key in headers) {
- if (headers.hasOwnProperty(key)) {
- xhr.setRequestHeader(key, headers[key]);
- }
- }
- }
- if (typeof this._config.headers === "object") {
- var headers = this._config.headers;
- for (var key in headers) {
- if (headers.hasOwnProperty(key)) {
- xhr.setRequestHeader(key, headers[key]);
- }
- }
- }
- xhr.send();
- };
- RangeLoader2.prototype.abort = function() {
- this._requestAbort = true;
- this._internalAbort();
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderStatus.kComplete;
- };
- RangeLoader2.prototype._internalAbort = function() {
- if (this._xhr) {
- this._xhr.onreadystatechange = null;
- this._xhr.onprogress = null;
- this._xhr.onload = null;
- this._xhr.onerror = null;
- this._xhr.abort();
- this._xhr = null;
- }
- };
- RangeLoader2.prototype._onReadyStateChange = function(e) {
- var xhr = e.target;
- if (xhr.readyState === 2) {
- if (xhr.responseURL != void 0) {
- var redirectedURL = this._seekHandler.removeURLParameters(xhr.responseURL);
- if (xhr.responseURL !== this._currentRequestURL && redirectedURL !== this._currentRedirectedURL) {
- this._currentRedirectedURL = redirectedURL;
- if (this._onURLRedirect) {
- this._onURLRedirect(redirectedURL);
- }
- }
- }
- if (xhr.status >= 200 && xhr.status <= 299) {
- if (this._waitForTotalLength) {
- return;
- }
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderStatus.kBuffering;
- } else {
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderStatus.kError;
- if (this._onError) {
- this._onError(_loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderErrors.HTTP_STATUS_CODE_INVALID, { code: xhr.status, msg: xhr.statusText });
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_3__.RuntimeException("RangeLoader: Http code invalid, " + xhr.status + " " + xhr.statusText);
- }
- }
- }
- };
- RangeLoader2.prototype._onProgress = function(e) {
- if (this._status === _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderStatus.kError) {
- return;
- }
- if (this._contentLength === null) {
- var openNextRange = false;
- if (this._waitForTotalLength) {
- this._waitForTotalLength = false;
- this._totalLengthReceived = true;
- openNextRange = true;
- var total = e.total;
- this._internalAbort();
- if (total != null & total !== 0) {
- this._totalLength = total;
- }
- }
- if (this._range.to === -1) {
- this._contentLength = this._totalLength - this._range.from;
- } else {
- this._contentLength = this._range.to - this._range.from + 1;
- }
- if (openNextRange) {
- this._openSubRange();
- return;
- }
- if (this._onContentLengthKnown) {
- this._onContentLengthKnown(this._contentLength);
- }
- }
- var delta = e.loaded - this._lastTimeLoaded;
- this._lastTimeLoaded = e.loaded;
- this._speedSampler.addBytes(delta);
- };
- RangeLoader2.prototype._normalizeSpeed = function(input) {
- var list = this._chunkSizeKBList;
- var last = list.length - 1;
- var mid = 0;
- var lbound = 0;
- var ubound = last;
- if (input < list[0]) {
- return list[0];
- }
- while (lbound <= ubound) {
- mid = lbound + Math.floor((ubound - lbound) / 2);
- if (mid === last || input >= list[mid] && input < list[mid + 1]) {
- return list[mid];
- } else if (list[mid] < input) {
- lbound = mid + 1;
- } else {
- ubound = mid - 1;
- }
- }
- };
- RangeLoader2.prototype._onLoad = function(e) {
- if (this._status === _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderStatus.kError) {
- return;
- }
- if (this._waitForTotalLength) {
- this._waitForTotalLength = false;
- return;
- }
- this._lastTimeLoaded = 0;
- var KBps = this._speedSampler.lastSecondKBps;
- if (KBps === 0) {
- this._zeroSpeedChunkCount++;
- if (this._zeroSpeedChunkCount >= 3) {
- KBps = this._speedSampler.currentKBps;
- }
- }
- if (KBps !== 0) {
- var normalized = this._normalizeSpeed(KBps);
- if (this._currentSpeedNormalized !== normalized) {
- this._currentSpeedNormalized = normalized;
- this._currentChunkSizeKB = normalized;
- }
- }
- var chunk = e.target.response;
- var byteStart = this._range.from + this._receivedLength;
- this._receivedLength += chunk.byteLength;
- var reportComplete = false;
- if (this._contentLength != null && this._receivedLength < this._contentLength) {
- this._openSubRange();
- } else {
- reportComplete = true;
- }
- if (this._onDataArrival) {
- this._onDataArrival(chunk, byteStart, this._receivedLength);
- }
- if (reportComplete) {
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderStatus.kComplete;
- if (this._onComplete) {
- this._onComplete(this._range.from, this._range.from + this._receivedLength - 1);
- }
- }
- };
- RangeLoader2.prototype._onXhrError = function(e) {
- this._status = _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderStatus.kError;
- var type2 = 0;
- var info = null;
- if (this._contentLength && this._receivedLength > 0 && this._receivedLength < this._contentLength) {
- type2 = _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderErrors.EARLY_EOF;
- info = { code: -1, msg: "RangeLoader meet Early-Eof" };
- } else {
- type2 = _loader_js__WEBPACK_IMPORTED_MODULE_2__.LoaderErrors.EXCEPTION;
- info = { code: -1, msg: e.constructor.name + " " + e.type };
- }
- if (this._onError) {
- this._onError(type2, info);
- } else {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_3__.RuntimeException(info.msg);
- }
- };
- return RangeLoader2;
- }(_loader_js__WEBPACK_IMPORTED_MODULE_2__.BaseLoader);
- __webpack_exports__2["default"] = RangeLoader;
- },
- "./src/player/flv-player.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./node_modules/events/events.js");
- var events__WEBPACK_IMPORTED_MODULE_0___default = /* @__PURE__ */ __webpack_require__2.n(events__WEBPACK_IMPORTED_MODULE_0__);
- var _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/utils/logger.js");
- var _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/utils/browser.js");
- var _player_events_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__2("./src/player/player-events.js");
- var _core_transmuxer_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__2("./src/core/transmuxer.js");
- var _core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__2("./src/core/transmuxing-events.js");
- var _core_mse_controller_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__2("./src/core/mse-controller.js");
- var _core_mse_events_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__2("./src/core/mse-events.js");
- var _player_errors_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__2("./src/player/player-errors.js");
- var _config_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__2("./src/config.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__2("./src/utils/exception.js");
- var FlvPlayer = function() {
- function FlvPlayer2(mediaDataSource, config) {
- this.TAG = "FlvPlayer";
- this._type = "FlvPlayer";
- this._emitter = new (events__WEBPACK_IMPORTED_MODULE_0___default())();
- this._config = (0, _config_js__WEBPACK_IMPORTED_MODULE_9__.createDefaultConfig)();
- if (typeof config === "object") {
- Object.assign(this._config, config);
- }
- if (mediaDataSource.type.toLowerCase() !== "flv") {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_10__.InvalidArgumentException("FlvPlayer requires an flv MediaDataSource input!");
- }
- if (mediaDataSource.isLive === true) {
- this._config.isLive = true;
- }
- this.e = {
- onvLoadedMetadata: this._onvLoadedMetadata.bind(this),
- onvSeeking: this._onvSeeking.bind(this),
- onvCanPlay: this._onvCanPlay.bind(this),
- onvStalled: this._onvStalled.bind(this),
- onvProgress: this._onvProgress.bind(this)
- };
- if (self.performance && self.performance.now) {
- this._now = self.performance.now.bind(self.performance);
- } else {
- this._now = Date.now;
- }
- this._pendingSeekTime = null;
- this._requestSetTime = false;
- this._seekpointRecord = null;
- this._progressChecker = null;
- this._mediaDataSource = mediaDataSource;
- this._mediaElement = null;
- this._msectl = null;
- this._transmuxer = null;
- this._mseSourceOpened = false;
- this._hasPendingLoad = false;
- this._receivedCanPlay = false;
- this._mediaInfo = null;
- this._statisticsInfo = null;
- var chromeNeedIDRFix = _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.chrome && (_utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.version.major < 50 || _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.version.major === 50 && _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.version.build < 2661);
- this._alwaysSeekKeyframe = chromeNeedIDRFix || _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.msedge || _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.msie ? true : false;
- if (this._alwaysSeekKeyframe) {
- this._config.accurateSeek = false;
- }
- }
- FlvPlayer2.prototype.destroy = function() {
- if (this._progressChecker != null) {
- window.clearInterval(this._progressChecker);
- this._progressChecker = null;
- }
- if (this._transmuxer) {
- this.unload();
- }
- if (this._mediaElement) {
- this.detachMediaElement();
- }
- this.e = null;
- this._mediaDataSource = null;
- this._emitter.removeAllListeners();
- this._emitter = null;
- };
- FlvPlayer2.prototype.on = function(event2, listener) {
- var _this = this;
- if (event2 === _player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.MEDIA_INFO) {
- if (this._mediaInfo != null) {
- Promise.resolve().then(function() {
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.MEDIA_INFO, _this.mediaInfo);
- });
- }
- } else if (event2 === _player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.STATISTICS_INFO) {
- if (this._statisticsInfo != null) {
- Promise.resolve().then(function() {
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.STATISTICS_INFO, _this.statisticsInfo);
- });
- }
- }
- this._emitter.addListener(event2, listener);
- };
- FlvPlayer2.prototype.off = function(event2, listener) {
- this._emitter.removeListener(event2, listener);
- };
- FlvPlayer2.prototype.attachMediaElement = function(mediaElement) {
- var _this = this;
- this._mediaElement = mediaElement;
- mediaElement.addEventListener("loadedmetadata", this.e.onvLoadedMetadata);
- mediaElement.addEventListener("seeking", this.e.onvSeeking);
- mediaElement.addEventListener("canplay", this.e.onvCanPlay);
- mediaElement.addEventListener("stalled", this.e.onvStalled);
- mediaElement.addEventListener("progress", this.e.onvProgress);
- this._msectl = new _core_mse_controller_js__WEBPACK_IMPORTED_MODULE_6__.default(this._config);
- this._msectl.on(_core_mse_events_js__WEBPACK_IMPORTED_MODULE_7__.default.UPDATE_END, this._onmseUpdateEnd.bind(this));
- this._msectl.on(_core_mse_events_js__WEBPACK_IMPORTED_MODULE_7__.default.BUFFER_FULL, this._onmseBufferFull.bind(this));
- this._msectl.on(_core_mse_events_js__WEBPACK_IMPORTED_MODULE_7__.default.SOURCE_OPEN, function() {
- _this._mseSourceOpened = true;
- if (_this._hasPendingLoad) {
- _this._hasPendingLoad = false;
- _this.load();
- }
- });
- this._msectl.on(_core_mse_events_js__WEBPACK_IMPORTED_MODULE_7__.default.ERROR, function(info) {
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.ERROR, _player_errors_js__WEBPACK_IMPORTED_MODULE_8__.ErrorTypes.MEDIA_ERROR, _player_errors_js__WEBPACK_IMPORTED_MODULE_8__.ErrorDetails.MEDIA_MSE_ERROR, info);
- });
- this._msectl.attachMediaElement(mediaElement);
- if (this._pendingSeekTime != null) {
- try {
- mediaElement.currentTime = this._pendingSeekTime;
- this._pendingSeekTime = null;
- } catch (e) {
- }
- }
- };
- FlvPlayer2.prototype.detachMediaElement = function() {
- if (this._mediaElement) {
- this._msectl.detachMediaElement();
- this._mediaElement.removeEventListener("loadedmetadata", this.e.onvLoadedMetadata);
- this._mediaElement.removeEventListener("seeking", this.e.onvSeeking);
- this._mediaElement.removeEventListener("canplay", this.e.onvCanPlay);
- this._mediaElement.removeEventListener("stalled", this.e.onvStalled);
- this._mediaElement.removeEventListener("progress", this.e.onvProgress);
- this._mediaElement = null;
- }
- if (this._msectl) {
- this._msectl.destroy();
- this._msectl = null;
- }
- };
- FlvPlayer2.prototype.load = function() {
- var _this = this;
- if (!this._mediaElement) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_10__.IllegalStateException("HTMLMediaElement must be attached before load()!");
- }
- if (this._transmuxer) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_10__.IllegalStateException("FlvPlayer.load() has been called, please call unload() first!");
- }
- if (this._hasPendingLoad) {
- return;
- }
- if (this._config.deferLoadAfterSourceOpen && this._mseSourceOpened === false) {
- this._hasPendingLoad = true;
- return;
- }
- if (this._mediaElement.readyState > 0) {
- this._requestSetTime = true;
- this._mediaElement.currentTime = 0;
- }
- this._transmuxer = new _core_transmuxer_js__WEBPACK_IMPORTED_MODULE_4__.default(this._mediaDataSource, this._config);
- this._transmuxer.on(_core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.INIT_SEGMENT, function(type2, is) {
- _this._msectl.appendInitSegment(is);
- });
- this._transmuxer.on(_core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.MEDIA_SEGMENT, function(type2, ms) {
- _this._msectl.appendMediaSegment(ms);
- if (_this._config.lazyLoad && !_this._config.isLive) {
- var currentTime = _this._mediaElement.currentTime;
- if (ms.info.endDts >= (currentTime + _this._config.lazyLoadMaxDuration) * 1e3) {
- if (_this._progressChecker == null) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.v(_this.TAG, "Maximum buffering duration exceeded, suspend transmuxing task");
- _this._suspendTransmuxer();
- }
- }
- }
- });
- this._transmuxer.on(_core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.LOADING_COMPLETE, function() {
- _this._msectl.endOfStream();
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.LOADING_COMPLETE);
- });
- this._transmuxer.on(_core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.RECOVERED_EARLY_EOF, function() {
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.RECOVERED_EARLY_EOF);
- });
- this._transmuxer.on(_core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.IO_ERROR, function(detail, info) {
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.ERROR, _player_errors_js__WEBPACK_IMPORTED_MODULE_8__.ErrorTypes.NETWORK_ERROR, detail, info);
- });
- this._transmuxer.on(_core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.DEMUX_ERROR, function(detail, info) {
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.ERROR, _player_errors_js__WEBPACK_IMPORTED_MODULE_8__.ErrorTypes.MEDIA_ERROR, detail, { code: -1, msg: info });
- });
- this._transmuxer.on(_core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.MEDIA_INFO, function(mediaInfo) {
- _this._mediaInfo = mediaInfo;
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.MEDIA_INFO, Object.assign({}, mediaInfo));
- });
- this._transmuxer.on(_core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.METADATA_ARRIVED, function(metadata) {
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.METADATA_ARRIVED, metadata);
- });
- this._transmuxer.on(_core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.SCRIPTDATA_ARRIVED, function(data) {
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.SCRIPTDATA_ARRIVED, data);
- });
- this._transmuxer.on(_core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.STATISTICS_INFO, function(statInfo) {
- _this._statisticsInfo = _this._fillStatisticsInfo(statInfo);
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_3__.default.STATISTICS_INFO, Object.assign({}, _this._statisticsInfo));
- });
- this._transmuxer.on(_core_transmuxing_events_js__WEBPACK_IMPORTED_MODULE_5__.default.RECOMMEND_SEEKPOINT, function(milliseconds) {
- if (_this._mediaElement && !_this._config.accurateSeek) {
- _this._requestSetTime = true;
- _this._mediaElement.currentTime = milliseconds / 1e3;
- }
- });
- this._transmuxer.open();
- };
- FlvPlayer2.prototype.unload = function() {
- if (this._mediaElement) {
- this._mediaElement.pause();
- }
- if (this._msectl) {
- this._msectl.seek(0);
- }
- if (this._transmuxer) {
- this._transmuxer.close();
- this._transmuxer.destroy();
- this._transmuxer = null;
- }
- };
- FlvPlayer2.prototype.play = function() {
- return this._mediaElement.play();
- };
- FlvPlayer2.prototype.pause = function() {
- this._mediaElement.pause();
- };
- Object.defineProperty(FlvPlayer2.prototype, "type", {
- get: function() {
- return this._type;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FlvPlayer2.prototype, "buffered", {
- get: function() {
- return this._mediaElement.buffered;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FlvPlayer2.prototype, "duration", {
- get: function() {
- return this._mediaElement.duration;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FlvPlayer2.prototype, "volume", {
- get: function() {
- return this._mediaElement.volume;
- },
- set: function(value) {
- this._mediaElement.volume = value;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FlvPlayer2.prototype, "muted", {
- get: function() {
- return this._mediaElement.muted;
- },
- set: function(muted) {
- this._mediaElement.muted = muted;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FlvPlayer2.prototype, "currentTime", {
- get: function() {
- if (this._mediaElement) {
- return this._mediaElement.currentTime;
- }
- return 0;
- },
- set: function(seconds) {
- if (this._mediaElement) {
- this._internalSeek(seconds);
- } else {
- this._pendingSeekTime = seconds;
- }
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FlvPlayer2.prototype, "mediaInfo", {
- get: function() {
- return Object.assign({}, this._mediaInfo);
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(FlvPlayer2.prototype, "statisticsInfo", {
- get: function() {
- if (this._statisticsInfo == null) {
- this._statisticsInfo = {};
- }
- this._statisticsInfo = this._fillStatisticsInfo(this._statisticsInfo);
- return Object.assign({}, this._statisticsInfo);
- },
- enumerable: false,
- configurable: true
- });
- FlvPlayer2.prototype._fillStatisticsInfo = function(statInfo) {
- statInfo.playerType = this._type;
- if (!(this._mediaElement instanceof HTMLVideoElement)) {
- return statInfo;
- }
- var hasQualityInfo = true;
- var decoded = 0;
- var dropped = 0;
- if (this._mediaElement.getVideoPlaybackQuality) {
- var quality = this._mediaElement.getVideoPlaybackQuality();
- decoded = quality.totalVideoFrames;
- dropped = quality.droppedVideoFrames;
- } else if (this._mediaElement.webkitDecodedFrameCount != void 0) {
- decoded = this._mediaElement.webkitDecodedFrameCount;
- dropped = this._mediaElement.webkitDroppedFrameCount;
- } else {
- hasQualityInfo = false;
- }
- if (hasQualityInfo) {
- statInfo.decodedFrames = decoded;
- statInfo.droppedFrames = dropped;
- }
- return statInfo;
- };
- FlvPlayer2.prototype._onmseUpdateEnd = function() {
- if (!this._config.lazyLoad || this._config.isLive) {
- return;
- }
- var buffered = this._mediaElement.buffered;
- var currentTime = this._mediaElement.currentTime;
- var currentRangeEnd = 0;
- for (var i2 = 0; i2 < buffered.length; i2++) {
- var start2 = buffered.start(i2);
- var end = buffered.end(i2);
- if (start2 <= currentTime && currentTime < end) {
- currentRangeEnd = end;
- break;
- }
- }
- if (currentRangeEnd >= currentTime + this._config.lazyLoadMaxDuration && this._progressChecker == null) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.v(this.TAG, "Maximum buffering duration exceeded, suspend transmuxing task");
- this._suspendTransmuxer();
- }
- };
- FlvPlayer2.prototype._onmseBufferFull = function() {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.v(this.TAG, "MSE SourceBuffer is full, suspend transmuxing task");
- if (this._progressChecker == null) {
- this._suspendTransmuxer();
- }
- };
- FlvPlayer2.prototype._suspendTransmuxer = function() {
- if (this._transmuxer) {
- this._transmuxer.pause();
- if (this._progressChecker == null) {
- this._progressChecker = window.setInterval(this._checkProgressAndResume.bind(this), 1e3);
- }
- }
- };
- FlvPlayer2.prototype._checkProgressAndResume = function() {
- var currentTime = this._mediaElement.currentTime;
- var buffered = this._mediaElement.buffered;
- var needResume = false;
- for (var i2 = 0; i2 < buffered.length; i2++) {
- var from3 = buffered.start(i2);
- var to = buffered.end(i2);
- if (currentTime >= from3 && currentTime < to) {
- if (currentTime >= to - this._config.lazyLoadRecoverDuration) {
- needResume = true;
- }
- break;
- }
- }
- if (needResume) {
- window.clearInterval(this._progressChecker);
- this._progressChecker = null;
- if (needResume) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.v(this.TAG, "Continue loading from paused position");
- this._transmuxer.resume();
- }
- }
- };
- FlvPlayer2.prototype._isTimepointBuffered = function(seconds) {
- var buffered = this._mediaElement.buffered;
- for (var i2 = 0; i2 < buffered.length; i2++) {
- var from3 = buffered.start(i2);
- var to = buffered.end(i2);
- if (seconds >= from3 && seconds < to) {
- return true;
- }
- }
- return false;
- };
- FlvPlayer2.prototype._internalSeek = function(seconds) {
- var directSeek = this._isTimepointBuffered(seconds);
- var directSeekBegin = false;
- var directSeekBeginTime = 0;
- if (seconds < 1 && this._mediaElement.buffered.length > 0) {
- var videoBeginTime = this._mediaElement.buffered.start(0);
- if (videoBeginTime < 1 && seconds < videoBeginTime || _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.safari) {
- directSeekBegin = true;
- directSeekBeginTime = _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.safari ? 0.1 : videoBeginTime;
- }
- }
- if (directSeekBegin) {
- this._requestSetTime = true;
- this._mediaElement.currentTime = directSeekBeginTime;
- } else if (directSeek) {
- if (!this._alwaysSeekKeyframe) {
- this._requestSetTime = true;
- this._mediaElement.currentTime = seconds;
- } else {
- var idr = this._msectl.getNearestKeyframe(Math.floor(seconds * 1e3));
- this._requestSetTime = true;
- if (idr != null) {
- this._mediaElement.currentTime = idr.dts / 1e3;
- } else {
- this._mediaElement.currentTime = seconds;
- }
- }
- if (this._progressChecker != null) {
- this._checkProgressAndResume();
- }
- } else {
- if (this._progressChecker != null) {
- window.clearInterval(this._progressChecker);
- this._progressChecker = null;
- }
- this._msectl.seek(seconds);
- this._transmuxer.seek(Math.floor(seconds * 1e3));
- if (this._config.accurateSeek) {
- this._requestSetTime = true;
- this._mediaElement.currentTime = seconds;
- }
- }
- };
- FlvPlayer2.prototype._checkAndApplyUnbufferedSeekpoint = function() {
- if (this._seekpointRecord) {
- if (this._seekpointRecord.recordTime <= this._now() - 100) {
- var target = this._mediaElement.currentTime;
- this._seekpointRecord = null;
- if (!this._isTimepointBuffered(target)) {
- if (this._progressChecker != null) {
- window.clearTimeout(this._progressChecker);
- this._progressChecker = null;
- }
- this._msectl.seek(target);
- this._transmuxer.seek(Math.floor(target * 1e3));
- if (this._config.accurateSeek) {
- this._requestSetTime = true;
- this._mediaElement.currentTime = target;
- }
- }
- } else {
- window.setTimeout(this._checkAndApplyUnbufferedSeekpoint.bind(this), 50);
- }
- }
- };
- FlvPlayer2.prototype._checkAndResumeStuckPlayback = function(stalled) {
- var media = this._mediaElement;
- if (stalled || !this._receivedCanPlay || media.readyState < 2) {
- var buffered = media.buffered;
- if (buffered.length > 0 && media.currentTime < buffered.start(0)) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.w(this.TAG, "Playback seems stuck at " + media.currentTime + ", seek to " + buffered.start(0));
- this._requestSetTime = true;
- this._mediaElement.currentTime = buffered.start(0);
- this._mediaElement.removeEventListener("progress", this.e.onvProgress);
- }
- } else {
- this._mediaElement.removeEventListener("progress", this.e.onvProgress);
- }
- };
- FlvPlayer2.prototype._onvLoadedMetadata = function(e) {
- if (this._pendingSeekTime != null) {
- this._mediaElement.currentTime = this._pendingSeekTime;
- this._pendingSeekTime = null;
- }
- };
- FlvPlayer2.prototype._onvSeeking = function(e) {
- var target = this._mediaElement.currentTime;
- var buffered = this._mediaElement.buffered;
- if (this._requestSetTime) {
- this._requestSetTime = false;
- return;
- }
- if (target < 1 && buffered.length > 0) {
- var videoBeginTime = buffered.start(0);
- if (videoBeginTime < 1 && target < videoBeginTime || _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.safari) {
- this._requestSetTime = true;
- this._mediaElement.currentTime = _utils_browser_js__WEBPACK_IMPORTED_MODULE_2__.default.safari ? 0.1 : videoBeginTime;
- return;
- }
- }
- if (this._isTimepointBuffered(target)) {
- if (this._alwaysSeekKeyframe) {
- var idr = this._msectl.getNearestKeyframe(Math.floor(target * 1e3));
- if (idr != null) {
- this._requestSetTime = true;
- this._mediaElement.currentTime = idr.dts / 1e3;
- }
- }
- if (this._progressChecker != null) {
- this._checkProgressAndResume();
- }
- return;
- }
- this._seekpointRecord = {
- seekPoint: target,
- recordTime: this._now()
- };
- window.setTimeout(this._checkAndApplyUnbufferedSeekpoint.bind(this), 50);
- };
- FlvPlayer2.prototype._onvCanPlay = function(e) {
- this._receivedCanPlay = true;
- this._mediaElement.removeEventListener("canplay", this.e.onvCanPlay);
- };
- FlvPlayer2.prototype._onvStalled = function(e) {
- this._checkAndResumeStuckPlayback(true);
- };
- FlvPlayer2.prototype._onvProgress = function(e) {
- this._checkAndResumeStuckPlayback();
- };
- return FlvPlayer2;
- }();
- __webpack_exports__2["default"] = FlvPlayer;
- },
- "./src/player/native-player.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./node_modules/events/events.js");
- var events__WEBPACK_IMPORTED_MODULE_0___default = /* @__PURE__ */ __webpack_require__2.n(events__WEBPACK_IMPORTED_MODULE_0__);
- var _player_events_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/player/player-events.js");
- var _config_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/config.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__2("./src/utils/exception.js");
- var NativePlayer = function() {
- function NativePlayer2(mediaDataSource, config) {
- this.TAG = "NativePlayer";
- this._type = "NativePlayer";
- this._emitter = new (events__WEBPACK_IMPORTED_MODULE_0___default())();
- this._config = (0, _config_js__WEBPACK_IMPORTED_MODULE_2__.createDefaultConfig)();
- if (typeof config === "object") {
- Object.assign(this._config, config);
- }
- if (mediaDataSource.type.toLowerCase() === "flv") {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_3__.InvalidArgumentException("NativePlayer does't support flv MediaDataSource input!");
- }
- if (mediaDataSource.hasOwnProperty("segments")) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_3__.InvalidArgumentException("NativePlayer(" + mediaDataSource.type + ") doesn't support multipart playback!");
- }
- this.e = {
- onvLoadedMetadata: this._onvLoadedMetadata.bind(this)
- };
- this._pendingSeekTime = null;
- this._statisticsReporter = null;
- this._mediaDataSource = mediaDataSource;
- this._mediaElement = null;
- }
- NativePlayer2.prototype.destroy = function() {
- if (this._mediaElement) {
- this.unload();
- this.detachMediaElement();
- }
- this.e = null;
- this._mediaDataSource = null;
- this._emitter.removeAllListeners();
- this._emitter = null;
- };
- NativePlayer2.prototype.on = function(event2, listener) {
- var _this = this;
- if (event2 === _player_events_js__WEBPACK_IMPORTED_MODULE_1__.default.MEDIA_INFO) {
- if (this._mediaElement != null && this._mediaElement.readyState !== 0) {
- Promise.resolve().then(function() {
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_1__.default.MEDIA_INFO, _this.mediaInfo);
- });
- }
- } else if (event2 === _player_events_js__WEBPACK_IMPORTED_MODULE_1__.default.STATISTICS_INFO) {
- if (this._mediaElement != null && this._mediaElement.readyState !== 0) {
- Promise.resolve().then(function() {
- _this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_1__.default.STATISTICS_INFO, _this.statisticsInfo);
- });
- }
- }
- this._emitter.addListener(event2, listener);
- };
- NativePlayer2.prototype.off = function(event2, listener) {
- this._emitter.removeListener(event2, listener);
- };
- NativePlayer2.prototype.attachMediaElement = function(mediaElement) {
- this._mediaElement = mediaElement;
- mediaElement.addEventListener("loadedmetadata", this.e.onvLoadedMetadata);
- if (this._pendingSeekTime != null) {
- try {
- mediaElement.currentTime = this._pendingSeekTime;
- this._pendingSeekTime = null;
- } catch (e) {
- }
- }
- };
- NativePlayer2.prototype.detachMediaElement = function() {
- if (this._mediaElement) {
- this._mediaElement.src = "";
- this._mediaElement.removeAttribute("src");
- this._mediaElement.removeEventListener("loadedmetadata", this.e.onvLoadedMetadata);
- this._mediaElement = null;
- }
- if (this._statisticsReporter != null) {
- window.clearInterval(this._statisticsReporter);
- this._statisticsReporter = null;
- }
- };
- NativePlayer2.prototype.load = function() {
- if (!this._mediaElement) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_3__.IllegalStateException("HTMLMediaElement must be attached before load()!");
- }
- this._mediaElement.src = this._mediaDataSource.url;
- if (this._mediaElement.readyState > 0) {
- this._mediaElement.currentTime = 0;
- }
- this._mediaElement.preload = "auto";
- this._mediaElement.load();
- this._statisticsReporter = window.setInterval(this._reportStatisticsInfo.bind(this), this._config.statisticsInfoReportInterval);
- };
- NativePlayer2.prototype.unload = function() {
- if (this._mediaElement) {
- this._mediaElement.src = "";
- this._mediaElement.removeAttribute("src");
- }
- if (this._statisticsReporter != null) {
- window.clearInterval(this._statisticsReporter);
- this._statisticsReporter = null;
- }
- };
- NativePlayer2.prototype.play = function() {
- return this._mediaElement.play();
- };
- NativePlayer2.prototype.pause = function() {
- this._mediaElement.pause();
- };
- Object.defineProperty(NativePlayer2.prototype, "type", {
- get: function() {
- return this._type;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(NativePlayer2.prototype, "buffered", {
- get: function() {
- return this._mediaElement.buffered;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(NativePlayer2.prototype, "duration", {
- get: function() {
- return this._mediaElement.duration;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(NativePlayer2.prototype, "volume", {
- get: function() {
- return this._mediaElement.volume;
- },
- set: function(value) {
- this._mediaElement.volume = value;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(NativePlayer2.prototype, "muted", {
- get: function() {
- return this._mediaElement.muted;
- },
- set: function(muted) {
- this._mediaElement.muted = muted;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(NativePlayer2.prototype, "currentTime", {
- get: function() {
- if (this._mediaElement) {
- return this._mediaElement.currentTime;
- }
- return 0;
- },
- set: function(seconds) {
- if (this._mediaElement) {
- this._mediaElement.currentTime = seconds;
- } else {
- this._pendingSeekTime = seconds;
- }
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(NativePlayer2.prototype, "mediaInfo", {
- get: function() {
- var mediaPrefix = this._mediaElement instanceof HTMLAudioElement ? "audio/" : "video/";
- var info = {
- mimeType: mediaPrefix + this._mediaDataSource.type
- };
- if (this._mediaElement) {
- info.duration = Math.floor(this._mediaElement.duration * 1e3);
- if (this._mediaElement instanceof HTMLVideoElement) {
- info.width = this._mediaElement.videoWidth;
- info.height = this._mediaElement.videoHeight;
- }
- }
- return info;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(NativePlayer2.prototype, "statisticsInfo", {
- get: function() {
- var info = {
- playerType: this._type,
- url: this._mediaDataSource.url
- };
- if (!(this._mediaElement instanceof HTMLVideoElement)) {
- return info;
- }
- var hasQualityInfo = true;
- var decoded = 0;
- var dropped = 0;
- if (this._mediaElement.getVideoPlaybackQuality) {
- var quality = this._mediaElement.getVideoPlaybackQuality();
- decoded = quality.totalVideoFrames;
- dropped = quality.droppedVideoFrames;
- } else if (this._mediaElement.webkitDecodedFrameCount != void 0) {
- decoded = this._mediaElement.webkitDecodedFrameCount;
- dropped = this._mediaElement.webkitDroppedFrameCount;
- } else {
- hasQualityInfo = false;
- }
- if (hasQualityInfo) {
- info.decodedFrames = decoded;
- info.droppedFrames = dropped;
- }
- return info;
- },
- enumerable: false,
- configurable: true
- });
- NativePlayer2.prototype._onvLoadedMetadata = function(e) {
- if (this._pendingSeekTime != null) {
- this._mediaElement.currentTime = this._pendingSeekTime;
- this._pendingSeekTime = null;
- }
- this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_1__.default.MEDIA_INFO, this.mediaInfo);
- };
- NativePlayer2.prototype._reportStatisticsInfo = function() {
- this._emitter.emit(_player_events_js__WEBPACK_IMPORTED_MODULE_1__.default.STATISTICS_INFO, this.statisticsInfo);
- };
- return NativePlayer2;
- }();
- __webpack_exports__2["default"] = NativePlayer;
- },
- "./src/player/player-errors.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- __webpack_require__2.d(__webpack_exports__2, {
- "ErrorTypes": function() {
- return ErrorTypes;
- },
- "ErrorDetails": function() {
- return ErrorDetails;
- }
- });
- var _io_loader_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/io/loader.js");
- var _demux_demux_errors_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/demux/demux-errors.js");
- var ErrorTypes = {
- NETWORK_ERROR: "NetworkError",
- MEDIA_ERROR: "MediaError",
- OTHER_ERROR: "OtherError"
- };
- var ErrorDetails = {
- NETWORK_EXCEPTION: _io_loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderErrors.EXCEPTION,
- NETWORK_STATUS_CODE_INVALID: _io_loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderErrors.HTTP_STATUS_CODE_INVALID,
- NETWORK_TIMEOUT: _io_loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderErrors.CONNECTING_TIMEOUT,
- NETWORK_UNRECOVERABLE_EARLY_EOF: _io_loader_js__WEBPACK_IMPORTED_MODULE_0__.LoaderErrors.UNRECOVERABLE_EARLY_EOF,
- MEDIA_MSE_ERROR: "MediaMSEError",
- MEDIA_FORMAT_ERROR: _demux_demux_errors_js__WEBPACK_IMPORTED_MODULE_1__.default.FORMAT_ERROR,
- MEDIA_FORMAT_UNSUPPORTED: _demux_demux_errors_js__WEBPACK_IMPORTED_MODULE_1__.default.FORMAT_UNSUPPORTED,
- MEDIA_CODEC_UNSUPPORTED: _demux_demux_errors_js__WEBPACK_IMPORTED_MODULE_1__.default.CODEC_UNSUPPORTED
- };
- },
- "./src/player/player-events.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var PlayerEvents = {
- ERROR: "error",
- LOADING_COMPLETE: "loading_complete",
- RECOVERED_EARLY_EOF: "recovered_early_eof",
- MEDIA_INFO: "media_info",
- METADATA_ARRIVED: "metadata_arrived",
- SCRIPTDATA_ARRIVED: "scriptdata_arrived",
- STATISTICS_INFO: "statistics_info"
- };
- __webpack_exports__2["default"] = PlayerEvents;
- },
- "./src/remux/aac-silent.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var AAC = function() {
- function AAC2() {
- }
- AAC2.getSilentFrame = function(codec, channelCount) {
- if (codec === "mp4a.40.2") {
- if (channelCount === 1) {
- return new Uint8Array([0, 200, 0, 128, 35, 128]);
- } else if (channelCount === 2) {
- return new Uint8Array([33, 0, 73, 144, 2, 25, 0, 35, 128]);
- } else if (channelCount === 3) {
- return new Uint8Array([0, 200, 0, 128, 32, 132, 1, 38, 64, 8, 100, 0, 142]);
- } else if (channelCount === 4) {
- return new Uint8Array([0, 200, 0, 128, 32, 132, 1, 38, 64, 8, 100, 0, 128, 44, 128, 8, 2, 56]);
- } else if (channelCount === 5) {
- return new Uint8Array([0, 200, 0, 128, 32, 132, 1, 38, 64, 8, 100, 0, 130, 48, 4, 153, 0, 33, 144, 2, 56]);
- } else if (channelCount === 6) {
- return new Uint8Array([0, 200, 0, 128, 32, 132, 1, 38, 64, 8, 100, 0, 130, 48, 4, 153, 0, 33, 144, 2, 0, 178, 0, 32, 8, 224]);
- }
- } else {
- if (channelCount === 1) {
- return new Uint8Array([1, 64, 34, 128, 163, 78, 230, 128, 186, 8, 0, 0, 0, 28, 6, 241, 193, 10, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 94]);
- } else if (channelCount === 2) {
- return new Uint8Array([1, 64, 34, 128, 163, 94, 230, 128, 186, 8, 0, 0, 0, 0, 149, 0, 6, 241, 161, 10, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 94]);
- } else if (channelCount === 3) {
- return new Uint8Array([1, 64, 34, 128, 163, 94, 230, 128, 186, 8, 0, 0, 0, 0, 149, 0, 6, 241, 161, 10, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 94]);
- }
- }
- return null;
- };
- return AAC2;
- }();
- __webpack_exports__2["default"] = AAC;
- },
- "./src/remux/mp4-generator.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var MP4 = function() {
- function MP42() {
- }
- MP42.init = function() {
- MP42.types = {
- avc1: [],
- avcC: [],
- btrt: [],
- dinf: [],
- dref: [],
- esds: [],
- ftyp: [],
- hdlr: [],
- mdat: [],
- mdhd: [],
- mdia: [],
- mfhd: [],
- minf: [],
- moof: [],
- moov: [],
- mp4a: [],
- mvex: [],
- mvhd: [],
- sdtp: [],
- stbl: [],
- stco: [],
- stsc: [],
- stsd: [],
- stsz: [],
- stts: [],
- tfdt: [],
- tfhd: [],
- traf: [],
- trak: [],
- trun: [],
- trex: [],
- tkhd: [],
- vmhd: [],
- smhd: [],
- ".mp3": []
- };
- for (var name_1 in MP42.types) {
- if (MP42.types.hasOwnProperty(name_1)) {
- MP42.types[name_1] = [
- name_1.charCodeAt(0),
- name_1.charCodeAt(1),
- name_1.charCodeAt(2),
- name_1.charCodeAt(3)
- ];
- }
- }
- var constants = MP42.constants = {};
- constants.FTYP = new Uint8Array([
- 105,
- 115,
- 111,
- 109,
- 0,
- 0,
- 0,
- 1,
- 105,
- 115,
- 111,
- 109,
- 97,
- 118,
- 99,
- 49
- ]);
- constants.STSD_PREFIX = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1
- ]);
- constants.STTS = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- constants.STSC = constants.STCO = constants.STTS;
- constants.STSZ = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- constants.HDLR_VIDEO = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 118,
- 105,
- 100,
- 101,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 86,
- 105,
- 100,
- 101,
- 111,
- 72,
- 97,
- 110,
- 100,
- 108,
- 101,
- 114,
- 0
- ]);
- constants.HDLR_AUDIO = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 115,
- 111,
- 117,
- 110,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 83,
- 111,
- 117,
- 110,
- 100,
- 72,
- 97,
- 110,
- 100,
- 108,
- 101,
- 114,
- 0
- ]);
- constants.DREF = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 12,
- 117,
- 114,
- 108,
- 32,
- 0,
- 0,
- 0,
- 1
- ]);
- constants.SMHD = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- constants.VMHD = new Uint8Array([
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0
- ]);
- };
- MP42.box = function(type2) {
- var size = 8;
- var result = null;
- var datas = Array.prototype.slice.call(arguments, 1);
- var arrayCount = datas.length;
- for (var i2 = 0; i2 < arrayCount; i2++) {
- size += datas[i2].byteLength;
- }
- result = new Uint8Array(size);
- result[0] = size >>> 24 & 255;
- result[1] = size >>> 16 & 255;
- result[2] = size >>> 8 & 255;
- result[3] = size & 255;
- result.set(type2, 4);
- var offset = 8;
- for (var i2 = 0; i2 < arrayCount; i2++) {
- result.set(datas[i2], offset);
- offset += datas[i2].byteLength;
- }
- return result;
- };
- MP42.generateInitSegment = function(meta2) {
- var ftyp = MP42.box(MP42.types.ftyp, MP42.constants.FTYP);
- var moov = MP42.moov(meta2);
- var result = new Uint8Array(ftyp.byteLength + moov.byteLength);
- result.set(ftyp, 0);
- result.set(moov, ftyp.byteLength);
- return result;
- };
- MP42.moov = function(meta2) {
- var mvhd = MP42.mvhd(meta2.timescale, meta2.duration);
- var trak = MP42.trak(meta2);
- var mvex = MP42.mvex(meta2);
- return MP42.box(MP42.types.moov, mvhd, trak, mvex);
- };
- MP42.mvhd = function(timescale2, duration5) {
- return MP42.box(MP42.types.mvhd, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- timescale2 >>> 24 & 255,
- timescale2 >>> 16 & 255,
- timescale2 >>> 8 & 255,
- timescale2 & 255,
- duration5 >>> 24 & 255,
- duration5 >>> 16 & 255,
- duration5 >>> 8 & 255,
- duration5 & 255,
- 0,
- 1,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 64,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 255,
- 255,
- 255,
- 255
- ]));
- };
- MP42.trak = function(meta2) {
- return MP42.box(MP42.types.trak, MP42.tkhd(meta2), MP42.mdia(meta2));
- };
- MP42.tkhd = function(meta2) {
- var trackId = meta2.id, duration5 = meta2.duration;
- var width2 = meta2.presentWidth, height2 = meta2.presentHeight;
- return MP42.box(MP42.types.tkhd, new Uint8Array([
- 0,
- 0,
- 0,
- 7,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- trackId >>> 24 & 255,
- trackId >>> 16 & 255,
- trackId >>> 8 & 255,
- trackId & 255,
- 0,
- 0,
- 0,
- 0,
- duration5 >>> 24 & 255,
- duration5 >>> 16 & 255,
- duration5 >>> 8 & 255,
- duration5 & 255,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 64,
- 0,
- 0,
- 0,
- width2 >>> 8 & 255,
- width2 & 255,
- 0,
- 0,
- height2 >>> 8 & 255,
- height2 & 255,
- 0,
- 0
- ]));
- };
- MP42.mdia = function(meta2) {
- return MP42.box(MP42.types.mdia, MP42.mdhd(meta2), MP42.hdlr(meta2), MP42.minf(meta2));
- };
- MP42.mdhd = function(meta2) {
- var timescale2 = meta2.timescale;
- var duration5 = meta2.duration;
- return MP42.box(MP42.types.mdhd, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- timescale2 >>> 24 & 255,
- timescale2 >>> 16 & 255,
- timescale2 >>> 8 & 255,
- timescale2 & 255,
- duration5 >>> 24 & 255,
- duration5 >>> 16 & 255,
- duration5 >>> 8 & 255,
- duration5 & 255,
- 85,
- 196,
- 0,
- 0
- ]));
- };
- MP42.hdlr = function(meta2) {
- var data = null;
- if (meta2.type === "audio") {
- data = MP42.constants.HDLR_AUDIO;
- } else {
- data = MP42.constants.HDLR_VIDEO;
- }
- return MP42.box(MP42.types.hdlr, data);
- };
- MP42.minf = function(meta2) {
- var xmhd = null;
- if (meta2.type === "audio") {
- xmhd = MP42.box(MP42.types.smhd, MP42.constants.SMHD);
- } else {
- xmhd = MP42.box(MP42.types.vmhd, MP42.constants.VMHD);
- }
- return MP42.box(MP42.types.minf, xmhd, MP42.dinf(), MP42.stbl(meta2));
- };
- MP42.dinf = function() {
- var result = MP42.box(MP42.types.dinf, MP42.box(MP42.types.dref, MP42.constants.DREF));
- return result;
- };
- MP42.stbl = function(meta2) {
- var result = MP42.box(
- MP42.types.stbl,
- MP42.stsd(meta2),
- MP42.box(MP42.types.stts, MP42.constants.STTS),
- MP42.box(MP42.types.stsc, MP42.constants.STSC),
- MP42.box(MP42.types.stsz, MP42.constants.STSZ),
- MP42.box(MP42.types.stco, MP42.constants.STCO)
- );
- return result;
- };
- MP42.stsd = function(meta2) {
- if (meta2.type === "audio") {
- if (meta2.codec === "mp3") {
- return MP42.box(MP42.types.stsd, MP42.constants.STSD_PREFIX, MP42.mp3(meta2));
- }
- return MP42.box(MP42.types.stsd, MP42.constants.STSD_PREFIX, MP42.mp4a(meta2));
- } else {
- return MP42.box(MP42.types.stsd, MP42.constants.STSD_PREFIX, MP42.avc1(meta2));
- }
- };
- MP42.mp3 = function(meta2) {
- var channelCount = meta2.channelCount;
- var sampleRate = meta2.audioSampleRate;
- var data = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- channelCount,
- 0,
- 16,
- 0,
- 0,
- 0,
- 0,
- sampleRate >>> 8 & 255,
- sampleRate & 255,
- 0,
- 0
- ]);
- return MP42.box(MP42.types[".mp3"], data);
- };
- MP42.mp4a = function(meta2) {
- var channelCount = meta2.channelCount;
- var sampleRate = meta2.audioSampleRate;
- var data = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- channelCount,
- 0,
- 16,
- 0,
- 0,
- 0,
- 0,
- sampleRate >>> 8 & 255,
- sampleRate & 255,
- 0,
- 0
- ]);
- return MP42.box(MP42.types.mp4a, data, MP42.esds(meta2));
- };
- MP42.esds = function(meta2) {
- var config = meta2.config || [];
- var configSize = config.length;
- var data = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 3,
- 23 + configSize,
- 0,
- 1,
- 0,
- 4,
- 15 + configSize,
- 64,
- 21,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 5
- ].concat([
- configSize
- ]).concat(config).concat([
- 6,
- 1,
- 2
- ]));
- return MP42.box(MP42.types.esds, data);
- };
- MP42.avc1 = function(meta2) {
- var avcc = meta2.avcc;
- var width2 = meta2.codecWidth, height2 = meta2.codecHeight;
- var data = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- width2 >>> 8 & 255,
- width2 & 255,
- height2 >>> 8 & 255,
- height2 & 255,
- 0,
- 72,
- 0,
- 0,
- 0,
- 72,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 10,
- 120,
- 113,
- 113,
- 47,
- 102,
- 108,
- 118,
- 46,
- 106,
- 115,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 24,
- 255,
- 255
- ]);
- return MP42.box(MP42.types.avc1, data, MP42.box(MP42.types.avcC, avcc));
- };
- MP42.mvex = function(meta2) {
- return MP42.box(MP42.types.mvex, MP42.trex(meta2));
- };
- MP42.trex = function(meta2) {
- var trackId = meta2.id;
- var data = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- trackId >>> 24 & 255,
- trackId >>> 16 & 255,
- trackId >>> 8 & 255,
- trackId & 255,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 1
- ]);
- return MP42.box(MP42.types.trex, data);
- };
- MP42.moof = function(track, baseMediaDecodeTime) {
- return MP42.box(MP42.types.moof, MP42.mfhd(track.sequenceNumber), MP42.traf(track, baseMediaDecodeTime));
- };
- MP42.mfhd = function(sequenceNumber) {
- var data = new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- sequenceNumber >>> 24 & 255,
- sequenceNumber >>> 16 & 255,
- sequenceNumber >>> 8 & 255,
- sequenceNumber & 255
- ]);
- return MP42.box(MP42.types.mfhd, data);
- };
- MP42.traf = function(track, baseMediaDecodeTime) {
- var trackId = track.id;
- var tfhd = MP42.box(MP42.types.tfhd, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- trackId >>> 24 & 255,
- trackId >>> 16 & 255,
- trackId >>> 8 & 255,
- trackId & 255
- ]));
- var tfdt = MP42.box(MP42.types.tfdt, new Uint8Array([
- 0,
- 0,
- 0,
- 0,
- baseMediaDecodeTime >>> 24 & 255,
- baseMediaDecodeTime >>> 16 & 255,
- baseMediaDecodeTime >>> 8 & 255,
- baseMediaDecodeTime & 255
- ]));
- var sdtp = MP42.sdtp(track);
- var trun = MP42.trun(track, sdtp.byteLength + 16 + 16 + 8 + 16 + 8 + 8);
- return MP42.box(MP42.types.traf, tfhd, tfdt, trun, sdtp);
- };
- MP42.sdtp = function(track) {
- var samples = track.samples || [];
- var sampleCount = samples.length;
- var data = new Uint8Array(4 + sampleCount);
- for (var i2 = 0; i2 < sampleCount; i2++) {
- var flags = samples[i2].flags;
- data[i2 + 4] = flags.isLeading << 6 | flags.dependsOn << 4 | flags.isDependedOn << 2 | flags.hasRedundancy;
- }
- return MP42.box(MP42.types.sdtp, data);
- };
- MP42.trun = function(track, offset) {
- var samples = track.samples || [];
- var sampleCount = samples.length;
- var dataSize = 12 + 16 * sampleCount;
- var data = new Uint8Array(dataSize);
- offset += 8 + dataSize;
- data.set([
- 0,
- 0,
- 15,
- 1,
- sampleCount >>> 24 & 255,
- sampleCount >>> 16 & 255,
- sampleCount >>> 8 & 255,
- sampleCount & 255,
- offset >>> 24 & 255,
- offset >>> 16 & 255,
- offset >>> 8 & 255,
- offset & 255
- ], 0);
- for (var i2 = 0; i2 < sampleCount; i2++) {
- var duration5 = samples[i2].duration;
- var size = samples[i2].size;
- var flags = samples[i2].flags;
- var cts = samples[i2].cts;
- data.set([
- duration5 >>> 24 & 255,
- duration5 >>> 16 & 255,
- duration5 >>> 8 & 255,
- duration5 & 255,
- size >>> 24 & 255,
- size >>> 16 & 255,
- size >>> 8 & 255,
- size & 255,
- flags.isLeading << 2 | flags.dependsOn,
- flags.isDependedOn << 6 | flags.hasRedundancy << 4 | flags.isNonSync,
- 0,
- 0,
- cts >>> 24 & 255,
- cts >>> 16 & 255,
- cts >>> 8 & 255,
- cts & 255
- ], 12 + 16 * i2);
- }
- return MP42.box(MP42.types.trun, data);
- };
- MP42.mdat = function(data) {
- return MP42.box(MP42.types.mdat, data);
- };
- return MP42;
- }();
- MP4.init();
- __webpack_exports__2["default"] = MP4;
- },
- "./src/remux/mp4-remuxer.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./src/utils/logger.js");
- var _mp4_generator_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/remux/mp4-generator.js");
- var _aac_silent_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__2("./src/remux/aac-silent.js");
- var _utils_browser_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__2("./src/utils/browser.js");
- var _core_media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__2("./src/core/media-segment-info.js");
- var _utils_exception_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__2("./src/utils/exception.js");
- var MP4Remuxer = function() {
- function MP4Remuxer2(config) {
- this.TAG = "MP4Remuxer";
- this._config = config;
- this._isLive = config.isLive === true ? true : false;
- this._dtsBase = -1;
- this._dtsBaseInited = false;
- this._audioDtsBase = Infinity;
- this._videoDtsBase = Infinity;
- this._audioNextDts = void 0;
- this._videoNextDts = void 0;
- this._audioStashedLastSample = null;
- this._videoStashedLastSample = null;
- this._audioMeta = null;
- this._videoMeta = null;
- this._audioSegmentInfoList = new _core_media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__.MediaSegmentInfoList("audio");
- this._videoSegmentInfoList = new _core_media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__.MediaSegmentInfoList("video");
- this._onInitSegment = null;
- this._onMediaSegment = null;
- this._forceFirstIDR = _utils_browser_js__WEBPACK_IMPORTED_MODULE_3__.default.chrome && (_utils_browser_js__WEBPACK_IMPORTED_MODULE_3__.default.version.major < 50 || _utils_browser_js__WEBPACK_IMPORTED_MODULE_3__.default.version.major === 50 && _utils_browser_js__WEBPACK_IMPORTED_MODULE_3__.default.version.build < 2661) ? true : false;
- this._fillSilentAfterSeek = _utils_browser_js__WEBPACK_IMPORTED_MODULE_3__.default.msedge || _utils_browser_js__WEBPACK_IMPORTED_MODULE_3__.default.msie;
- this._mp3UseMpegAudio = !_utils_browser_js__WEBPACK_IMPORTED_MODULE_3__.default.firefox;
- this._fillAudioTimestampGap = this._config.fixAudioTimestampGap;
- }
- MP4Remuxer2.prototype.destroy = function() {
- this._dtsBase = -1;
- this._dtsBaseInited = false;
- this._audioMeta = null;
- this._videoMeta = null;
- this._audioSegmentInfoList.clear();
- this._audioSegmentInfoList = null;
- this._videoSegmentInfoList.clear();
- this._videoSegmentInfoList = null;
- this._onInitSegment = null;
- this._onMediaSegment = null;
- };
- MP4Remuxer2.prototype.bindDataSource = function(producer) {
- producer.onDataAvailable = this.remux.bind(this);
- producer.onTrackMetadata = this._onTrackMetadataReceived.bind(this);
- return this;
- };
- Object.defineProperty(MP4Remuxer2.prototype, "onInitSegment", {
- get: function() {
- return this._onInitSegment;
- },
- set: function(callback2) {
- this._onInitSegment = callback2;
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(MP4Remuxer2.prototype, "onMediaSegment", {
- get: function() {
- return this._onMediaSegment;
- },
- set: function(callback2) {
- this._onMediaSegment = callback2;
- },
- enumerable: false,
- configurable: true
- });
- MP4Remuxer2.prototype.insertDiscontinuity = function() {
- this._audioNextDts = this._videoNextDts = void 0;
- };
- MP4Remuxer2.prototype.seek = function(originalDts) {
- this._audioStashedLastSample = null;
- this._videoStashedLastSample = null;
- this._videoSegmentInfoList.clear();
- this._audioSegmentInfoList.clear();
- };
- MP4Remuxer2.prototype.remux = function(audioTrack, videoTrack) {
- if (!this._onMediaSegment) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_5__.IllegalStateException("MP4Remuxer: onMediaSegment callback must be specificed!");
- }
- if (!this._dtsBaseInited) {
- this._calculateDtsBase(audioTrack, videoTrack);
- }
- this._remuxVideo(videoTrack);
- this._remuxAudio(audioTrack);
- };
- MP4Remuxer2.prototype._onTrackMetadataReceived = function(type2, metadata) {
- var metabox = null;
- var container = "mp4";
- var codec = metadata.codec;
- if (type2 === "audio") {
- this._audioMeta = metadata;
- if (metadata.codec === "mp3" && this._mp3UseMpegAudio) {
- container = "mpeg";
- codec = "";
- metabox = new Uint8Array();
- } else {
- metabox = _mp4_generator_js__WEBPACK_IMPORTED_MODULE_1__.default.generateInitSegment(metadata);
- }
- } else if (type2 === "video") {
- this._videoMeta = metadata;
- metabox = _mp4_generator_js__WEBPACK_IMPORTED_MODULE_1__.default.generateInitSegment(metadata);
- } else {
- return;
- }
- if (!this._onInitSegment) {
- throw new _utils_exception_js__WEBPACK_IMPORTED_MODULE_5__.IllegalStateException("MP4Remuxer: onInitSegment callback must be specified!");
- }
- this._onInitSegment(type2, {
- type: type2,
- data: metabox.buffer,
- codec,
- container: type2 + "/" + container,
- mediaDuration: metadata.duration
- });
- };
- MP4Remuxer2.prototype._calculateDtsBase = function(audioTrack, videoTrack) {
- if (this._dtsBaseInited) {
- return;
- }
- if (audioTrack.samples && audioTrack.samples.length) {
- this._audioDtsBase = audioTrack.samples[0].dts;
- }
- if (videoTrack.samples && videoTrack.samples.length) {
- this._videoDtsBase = videoTrack.samples[0].dts;
- }
- this._dtsBase = Math.min(this._audioDtsBase, this._videoDtsBase);
- this._dtsBaseInited = true;
- };
- MP4Remuxer2.prototype.flushStashedSamples = function() {
- var videoSample = this._videoStashedLastSample;
- var audioSample = this._audioStashedLastSample;
- var videoTrack = {
- type: "video",
- id: 1,
- sequenceNumber: 0,
- samples: [],
- length: 0
- };
- if (videoSample != null) {
- videoTrack.samples.push(videoSample);
- videoTrack.length = videoSample.length;
- }
- var audioTrack = {
- type: "audio",
- id: 2,
- sequenceNumber: 0,
- samples: [],
- length: 0
- };
- if (audioSample != null) {
- audioTrack.samples.push(audioSample);
- audioTrack.length = audioSample.length;
- }
- this._videoStashedLastSample = null;
- this._audioStashedLastSample = null;
- this._remuxVideo(videoTrack, true);
- this._remuxAudio(audioTrack, true);
- };
- MP4Remuxer2.prototype._remuxAudio = function(audioTrack, force) {
- if (this._audioMeta == null) {
- return;
- }
- var track = audioTrack;
- var samples = track.samples;
- var dtsCorrection = void 0;
- var firstDts = -1, lastDts = -1;
- var refSampleDuration = this._audioMeta.refSampleDuration;
- var mpegRawTrack = this._audioMeta.codec === "mp3" && this._mp3UseMpegAudio;
- var firstSegmentAfterSeek = this._dtsBaseInited && this._audioNextDts === void 0;
- var insertPrefixSilentFrame = false;
- if (!samples || samples.length === 0) {
- return;
- }
- if (samples.length === 1 && !force) {
- return;
- }
- var offset = 0;
- var mdatbox = null;
- var mdatBytes = 0;
- if (mpegRawTrack) {
- offset = 0;
- mdatBytes = track.length;
- } else {
- offset = 8;
- mdatBytes = 8 + track.length;
- }
- var lastSample = null;
- if (samples.length > 1) {
- lastSample = samples.pop();
- mdatBytes -= lastSample.length;
- }
- if (this._audioStashedLastSample != null) {
- var sample = this._audioStashedLastSample;
- this._audioStashedLastSample = null;
- samples.unshift(sample);
- mdatBytes += sample.length;
- }
- if (lastSample != null) {
- this._audioStashedLastSample = lastSample;
- }
- var firstSampleOriginalDts = samples[0].dts - this._dtsBase;
- if (this._audioNextDts) {
- dtsCorrection = firstSampleOriginalDts - this._audioNextDts;
- } else {
- if (this._audioSegmentInfoList.isEmpty()) {
- dtsCorrection = 0;
- if (this._fillSilentAfterSeek && !this._videoSegmentInfoList.isEmpty()) {
- if (this._audioMeta.originalCodec !== "mp3") {
- insertPrefixSilentFrame = true;
- }
- }
- } else {
- var lastSample_1 = this._audioSegmentInfoList.getLastSampleBefore(firstSampleOriginalDts);
- if (lastSample_1 != null) {
- var distance2 = firstSampleOriginalDts - (lastSample_1.originalDts + lastSample_1.duration);
- if (distance2 <= 3) {
- distance2 = 0;
- }
- var expectedDts = lastSample_1.dts + lastSample_1.duration + distance2;
- dtsCorrection = firstSampleOriginalDts - expectedDts;
- } else {
- dtsCorrection = 0;
- }
- }
- }
- if (insertPrefixSilentFrame) {
- var firstSampleDts = firstSampleOriginalDts - dtsCorrection;
- var videoSegment = this._videoSegmentInfoList.getLastSegmentBefore(firstSampleOriginalDts);
- if (videoSegment != null && videoSegment.beginDts < firstSampleDts) {
- var silentUnit = _aac_silent_js__WEBPACK_IMPORTED_MODULE_2__.default.getSilentFrame(this._audioMeta.originalCodec, this._audioMeta.channelCount);
- if (silentUnit) {
- var dts = videoSegment.beginDts;
- var silentFrameDuration = firstSampleDts - videoSegment.beginDts;
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.v(this.TAG, "InsertPrefixSilentAudio: dts: " + dts + ", duration: " + silentFrameDuration);
- samples.unshift({ unit: silentUnit, dts, pts: dts });
- mdatBytes += silentUnit.byteLength;
- }
- } else {
- insertPrefixSilentFrame = false;
- }
- }
- var mp4Samples = [];
- for (var i2 = 0; i2 < samples.length; i2++) {
- var sample = samples[i2];
- var unit = sample.unit;
- var originalDts = sample.dts - this._dtsBase;
- var dts = originalDts;
- var needFillSilentFrames = false;
- var silentFrames = null;
- var sampleDuration = 0;
- if (originalDts < -1e-3) {
- continue;
- }
- if (this._audioMeta.codec !== "mp3") {
- var curRefDts = originalDts;
- var maxAudioFramesDrift = 3;
- if (this._audioNextDts) {
- curRefDts = this._audioNextDts;
- }
- dtsCorrection = originalDts - curRefDts;
- if (dtsCorrection <= -maxAudioFramesDrift * refSampleDuration) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Dropping 1 audio frame (originalDts: " + originalDts + " ms ,curRefDts: " + curRefDts + " ms) due to dtsCorrection: " + dtsCorrection + " ms overlap.");
- continue;
- } else if (dtsCorrection >= maxAudioFramesDrift * refSampleDuration && this._fillAudioTimestampGap && !_utils_browser_js__WEBPACK_IMPORTED_MODULE_3__.default.safari) {
- needFillSilentFrames = true;
- var frameCount = Math.floor(dtsCorrection / refSampleDuration);
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Large audio timestamp gap detected, may cause AV sync to drift. Silent frames will be generated to avoid unsync.\n" + ("originalDts: " + originalDts + " ms, curRefDts: " + curRefDts + " ms, ") + ("dtsCorrection: " + Math.round(dtsCorrection) + " ms, generate: " + frameCount + " frames"));
- dts = Math.floor(curRefDts);
- sampleDuration = Math.floor(curRefDts + refSampleDuration) - dts;
- var silentUnit = _aac_silent_js__WEBPACK_IMPORTED_MODULE_2__.default.getSilentFrame(this._audioMeta.originalCodec, this._audioMeta.channelCount);
- if (silentUnit == null) {
- _utils_logger_js__WEBPACK_IMPORTED_MODULE_0__.default.w(this.TAG, "Unable to generate silent frame for " + (this._audioMeta.originalCodec + " with " + this._audioMeta.channelCount + " channels, repeat last frame"));
- silentUnit = unit;
- }
- silentFrames = [];
- for (var j = 0; j < frameCount; j++) {
- curRefDts = curRefDts + refSampleDuration;
- var intDts = Math.floor(curRefDts);
- var intDuration = Math.floor(curRefDts + refSampleDuration) - intDts;
- var frame = {
- dts: intDts,
- pts: intDts,
- cts: 0,
- unit: silentUnit,
- size: silentUnit.byteLength,
- duration: intDuration,
- originalDts,
- flags: {
- isLeading: 0,
- dependsOn: 1,
- isDependedOn: 0,
- hasRedundancy: 0
- }
- };
- silentFrames.push(frame);
- mdatBytes += frame.size;
- }
- this._audioNextDts = curRefDts + refSampleDuration;
- } else {
- dts = Math.floor(curRefDts);
- sampleDuration = Math.floor(curRefDts + refSampleDuration) - dts;
- this._audioNextDts = curRefDts + refSampleDuration;
- }
- } else {
- dts = originalDts - dtsCorrection;
- if (i2 !== samples.length - 1) {
- var nextDts = samples[i2 + 1].dts - this._dtsBase - dtsCorrection;
- sampleDuration = nextDts - dts;
- } else {
- if (lastSample != null) {
- var nextDts = lastSample.dts - this._dtsBase - dtsCorrection;
- sampleDuration = nextDts - dts;
- } else if (mp4Samples.length >= 1) {
- sampleDuration = mp4Samples[mp4Samples.length - 1].duration;
- } else {
- sampleDuration = Math.floor(refSampleDuration);
- }
- }
- this._audioNextDts = dts + sampleDuration;
- }
- if (firstDts === -1) {
- firstDts = dts;
- }
- mp4Samples.push({
- dts,
- pts: dts,
- cts: 0,
- unit: sample.unit,
- size: sample.unit.byteLength,
- duration: sampleDuration,
- originalDts,
- flags: {
- isLeading: 0,
- dependsOn: 1,
- isDependedOn: 0,
- hasRedundancy: 0
- }
- });
- if (needFillSilentFrames) {
- mp4Samples.push.apply(mp4Samples, silentFrames);
- }
- }
- if (mp4Samples.length === 0) {
- track.samples = [];
- track.length = 0;
- return;
- }
- if (mpegRawTrack) {
- mdatbox = new Uint8Array(mdatBytes);
- } else {
- mdatbox = new Uint8Array(mdatBytes);
- mdatbox[0] = mdatBytes >>> 24 & 255;
- mdatbox[1] = mdatBytes >>> 16 & 255;
- mdatbox[2] = mdatBytes >>> 8 & 255;
- mdatbox[3] = mdatBytes & 255;
- mdatbox.set(_mp4_generator_js__WEBPACK_IMPORTED_MODULE_1__.default.types.mdat, 4);
- }
- for (var i2 = 0; i2 < mp4Samples.length; i2++) {
- var unit = mp4Samples[i2].unit;
- mdatbox.set(unit, offset);
- offset += unit.byteLength;
- }
- var latest = mp4Samples[mp4Samples.length - 1];
- lastDts = latest.dts + latest.duration;
- var info = new _core_media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__.MediaSegmentInfo();
- info.beginDts = firstDts;
- info.endDts = lastDts;
- info.beginPts = firstDts;
- info.endPts = lastDts;
- info.originalBeginDts = mp4Samples[0].originalDts;
- info.originalEndDts = latest.originalDts + latest.duration;
- info.firstSample = new _core_media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__.SampleInfo(mp4Samples[0].dts, mp4Samples[0].pts, mp4Samples[0].duration, mp4Samples[0].originalDts, false);
- info.lastSample = new _core_media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__.SampleInfo(latest.dts, latest.pts, latest.duration, latest.originalDts, false);
- if (!this._isLive) {
- this._audioSegmentInfoList.append(info);
- }
- track.samples = mp4Samples;
- track.sequenceNumber++;
- var moofbox = null;
- if (mpegRawTrack) {
- moofbox = new Uint8Array();
- } else {
- moofbox = _mp4_generator_js__WEBPACK_IMPORTED_MODULE_1__.default.moof(track, firstDts);
- }
- track.samples = [];
- track.length = 0;
- var segment = {
- type: "audio",
- data: this._mergeBoxes(moofbox, mdatbox).buffer,
- sampleCount: mp4Samples.length,
- info
- };
- if (mpegRawTrack && firstSegmentAfterSeek) {
- segment.timestampOffset = firstDts;
- }
- this._onMediaSegment("audio", segment);
- };
- MP4Remuxer2.prototype._remuxVideo = function(videoTrack, force) {
- if (this._videoMeta == null) {
- return;
- }
- var track = videoTrack;
- var samples = track.samples;
- var dtsCorrection = void 0;
- var firstDts = -1, lastDts = -1;
- var firstPts = -1, lastPts = -1;
- if (!samples || samples.length === 0) {
- return;
- }
- if (samples.length === 1 && !force) {
- return;
- }
- var offset = 8;
- var mdatbox = null;
- var mdatBytes = 8 + videoTrack.length;
- var lastSample = null;
- if (samples.length > 1) {
- lastSample = samples.pop();
- mdatBytes -= lastSample.length;
- }
- if (this._videoStashedLastSample != null) {
- var sample = this._videoStashedLastSample;
- this._videoStashedLastSample = null;
- samples.unshift(sample);
- mdatBytes += sample.length;
- }
- if (lastSample != null) {
- this._videoStashedLastSample = lastSample;
- }
- var firstSampleOriginalDts = samples[0].dts - this._dtsBase;
- if (this._videoNextDts) {
- dtsCorrection = firstSampleOriginalDts - this._videoNextDts;
- } else {
- if (this._videoSegmentInfoList.isEmpty()) {
- dtsCorrection = 0;
- } else {
- var lastSample_2 = this._videoSegmentInfoList.getLastSampleBefore(firstSampleOriginalDts);
- if (lastSample_2 != null) {
- var distance2 = firstSampleOriginalDts - (lastSample_2.originalDts + lastSample_2.duration);
- if (distance2 <= 3) {
- distance2 = 0;
- }
- var expectedDts = lastSample_2.dts + lastSample_2.duration + distance2;
- dtsCorrection = firstSampleOriginalDts - expectedDts;
- } else {
- dtsCorrection = 0;
- }
- }
- }
- var info = new _core_media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__.MediaSegmentInfo();
- var mp4Samples = [];
- for (var i2 = 0; i2 < samples.length; i2++) {
- var sample = samples[i2];
- var originalDts = sample.dts - this._dtsBase;
- var isKeyframe = sample.isKeyframe;
- var dts = originalDts - dtsCorrection;
- var cts = sample.cts;
- var pts = dts + cts;
- if (firstDts === -1) {
- firstDts = dts;
- firstPts = pts;
- }
- var sampleDuration = 0;
- if (i2 !== samples.length - 1) {
- var nextDts = samples[i2 + 1].dts - this._dtsBase - dtsCorrection;
- sampleDuration = nextDts - dts;
- } else {
- if (lastSample != null) {
- var nextDts = lastSample.dts - this._dtsBase - dtsCorrection;
- sampleDuration = nextDts - dts;
- } else if (mp4Samples.length >= 1) {
- sampleDuration = mp4Samples[mp4Samples.length - 1].duration;
- } else {
- sampleDuration = Math.floor(this._videoMeta.refSampleDuration);
- }
- }
- if (isKeyframe) {
- var syncPoint = new _core_media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__.SampleInfo(dts, pts, sampleDuration, sample.dts, true);
- syncPoint.fileposition = sample.fileposition;
- info.appendSyncPoint(syncPoint);
- }
- mp4Samples.push({
- dts,
- pts,
- cts,
- units: sample.units,
- size: sample.length,
- isKeyframe,
- duration: sampleDuration,
- originalDts,
- flags: {
- isLeading: 0,
- dependsOn: isKeyframe ? 2 : 1,
- isDependedOn: isKeyframe ? 1 : 0,
- hasRedundancy: 0,
- isNonSync: isKeyframe ? 0 : 1
- }
- });
- }
- mdatbox = new Uint8Array(mdatBytes);
- mdatbox[0] = mdatBytes >>> 24 & 255;
- mdatbox[1] = mdatBytes >>> 16 & 255;
- mdatbox[2] = mdatBytes >>> 8 & 255;
- mdatbox[3] = mdatBytes & 255;
- mdatbox.set(_mp4_generator_js__WEBPACK_IMPORTED_MODULE_1__.default.types.mdat, 4);
- for (var i2 = 0; i2 < mp4Samples.length; i2++) {
- var units = mp4Samples[i2].units;
- while (units.length) {
- var unit = units.shift();
- var data = unit.data;
- mdatbox.set(data, offset);
- offset += data.byteLength;
- }
- }
- var latest = mp4Samples[mp4Samples.length - 1];
- lastDts = latest.dts + latest.duration;
- lastPts = latest.pts + latest.duration;
- this._videoNextDts = lastDts;
- info.beginDts = firstDts;
- info.endDts = lastDts;
- info.beginPts = firstPts;
- info.endPts = lastPts;
- info.originalBeginDts = mp4Samples[0].originalDts;
- info.originalEndDts = latest.originalDts + latest.duration;
- info.firstSample = new _core_media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__.SampleInfo(mp4Samples[0].dts, mp4Samples[0].pts, mp4Samples[0].duration, mp4Samples[0].originalDts, mp4Samples[0].isKeyframe);
- info.lastSample = new _core_media_segment_info_js__WEBPACK_IMPORTED_MODULE_4__.SampleInfo(latest.dts, latest.pts, latest.duration, latest.originalDts, latest.isKeyframe);
- if (!this._isLive) {
- this._videoSegmentInfoList.append(info);
- }
- track.samples = mp4Samples;
- track.sequenceNumber++;
- if (this._forceFirstIDR) {
- var flags = mp4Samples[0].flags;
- flags.dependsOn = 2;
- flags.isNonSync = 0;
- }
- var moofbox = _mp4_generator_js__WEBPACK_IMPORTED_MODULE_1__.default.moof(track, firstDts);
- track.samples = [];
- track.length = 0;
- this._onMediaSegment("video", {
- type: "video",
- data: this._mergeBoxes(moofbox, mdatbox).buffer,
- sampleCount: mp4Samples.length,
- info
- });
- };
- MP4Remuxer2.prototype._mergeBoxes = function(moof, mdat) {
- var result = new Uint8Array(moof.byteLength + mdat.byteLength);
- result.set(moof, 0);
- result.set(mdat, moof.byteLength);
- return result;
- };
- return MP4Remuxer2;
- }();
- __webpack_exports__2["default"] = MP4Remuxer;
- },
- "./src/utils/browser.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var Browser = {};
- function detect() {
- var ua = self.navigator.userAgent.toLowerCase();
- var match = /(edge)\/([\w.]+)/.exec(ua) || /(opr)[\/]([\w.]+)/.exec(ua) || /(chrome)[ \/]([\w.]+)/.exec(ua) || /(iemobile)[\/]([\w.]+)/.exec(ua) || /(version)(applewebkit)[ \/]([\w.]+).*(safari)[ \/]([\w.]+)/.exec(ua) || /(webkit)[ \/]([\w.]+).*(version)[ \/]([\w.]+).*(safari)[ \/]([\w.]+)/.exec(ua) || /(webkit)[ \/]([\w.]+)/.exec(ua) || /(opera)(?:.*version|)[ \/]([\w.]+)/.exec(ua) || /(msie) ([\w.]+)/.exec(ua) || ua.indexOf("trident") >= 0 && /(rv)(?::| )([\w.]+)/.exec(ua) || ua.indexOf("compatible") < 0 && /(firefox)[ \/]([\w.]+)/.exec(ua) || [];
- var platform_match = /(ipad)/.exec(ua) || /(ipod)/.exec(ua) || /(windows phone)/.exec(ua) || /(iphone)/.exec(ua) || /(kindle)/.exec(ua) || /(android)/.exec(ua) || /(windows)/.exec(ua) || /(mac)/.exec(ua) || /(linux)/.exec(ua) || /(cros)/.exec(ua) || [];
- var matched = {
- browser: match[5] || match[3] || match[1] || "",
- version: match[2] || match[4] || "0",
- majorVersion: match[4] || match[2] || "0",
- platform: platform_match[0] || ""
- };
- var browser2 = {};
- if (matched.browser) {
- browser2[matched.browser] = true;
- var versionArray = matched.majorVersion.split(".");
- browser2.version = {
- major: parseInt(matched.majorVersion, 10),
- string: matched.version
- };
- if (versionArray.length > 1) {
- browser2.version.minor = parseInt(versionArray[1], 10);
- }
- if (versionArray.length > 2) {
- browser2.version.build = parseInt(versionArray[2], 10);
- }
- }
- if (matched.platform) {
- browser2[matched.platform] = true;
- }
- if (browser2.chrome || browser2.opr || browser2.safari) {
- browser2.webkit = true;
- }
- if (browser2.rv || browser2.iemobile) {
- if (browser2.rv) {
- delete browser2.rv;
- }
- var msie = "msie";
- matched.browser = msie;
- browser2[msie] = true;
- }
- if (browser2.edge) {
- delete browser2.edge;
- var msedge = "msedge";
- matched.browser = msedge;
- browser2[msedge] = true;
- }
- if (browser2.opr) {
- var opera = "opera";
- matched.browser = opera;
- browser2[opera] = true;
- }
- if (browser2.safari && browser2.android) {
- var android = "android";
- matched.browser = android;
- browser2[android] = true;
- }
- browser2.name = matched.browser;
- browser2.platform = matched.platform;
- for (var key in Browser) {
- if (Browser.hasOwnProperty(key)) {
- delete Browser[key];
- }
- }
- Object.assign(Browser, browser2);
- }
- detect();
- __webpack_exports__2["default"] = Browser;
- },
- "./src/utils/exception.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- __webpack_require__2.d(__webpack_exports__2, {
- "RuntimeException": function() {
- return RuntimeException;
- },
- "IllegalStateException": function() {
- return IllegalStateException;
- },
- "InvalidArgumentException": function() {
- return InvalidArgumentException;
- },
- "NotImplementedException": function() {
- return NotImplementedException;
- }
- });
- var __extends = function() {
- var extendStatics = function(d2, b) {
- extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(d3, b2) {
- d3.__proto__ = b2;
- } || function(d3, b2) {
- for (var p in b2)
- if (Object.prototype.hasOwnProperty.call(b2, p))
- d3[p] = b2[p];
- };
- return extendStatics(d2, b);
- };
- return function(d2, b) {
- if (typeof b !== "function" && b !== null)
- throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
- extendStatics(d2, b);
- function __() {
- this.constructor = d2;
- }
- d2.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
- };
- }();
- var RuntimeException = function() {
- function RuntimeException2(message) {
- this._message = message;
- }
- Object.defineProperty(RuntimeException2.prototype, "name", {
- get: function() {
- return "RuntimeException";
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(RuntimeException2.prototype, "message", {
- get: function() {
- return this._message;
- },
- enumerable: false,
- configurable: true
- });
- RuntimeException2.prototype.toString = function() {
- return this.name + ": " + this.message;
- };
- return RuntimeException2;
- }();
- var IllegalStateException = function(_super) {
- __extends(IllegalStateException2, _super);
- function IllegalStateException2(message) {
- return _super.call(this, message) || this;
- }
- Object.defineProperty(IllegalStateException2.prototype, "name", {
- get: function() {
- return "IllegalStateException";
- },
- enumerable: false,
- configurable: true
- });
- return IllegalStateException2;
- }(RuntimeException);
- var InvalidArgumentException = function(_super) {
- __extends(InvalidArgumentException2, _super);
- function InvalidArgumentException2(message) {
- return _super.call(this, message) || this;
- }
- Object.defineProperty(InvalidArgumentException2.prototype, "name", {
- get: function() {
- return "InvalidArgumentException";
- },
- enumerable: false,
- configurable: true
- });
- return InvalidArgumentException2;
- }(RuntimeException);
- var NotImplementedException = function(_super) {
- __extends(NotImplementedException2, _super);
- function NotImplementedException2(message) {
- return _super.call(this, message) || this;
- }
- Object.defineProperty(NotImplementedException2.prototype, "name", {
- get: function() {
- return "NotImplementedException";
- },
- enumerable: false,
- configurable: true
- });
- return NotImplementedException2;
- }(RuntimeException);
- },
- "./src/utils/logger.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./node_modules/events/events.js");
- var events__WEBPACK_IMPORTED_MODULE_0___default = /* @__PURE__ */ __webpack_require__2.n(events__WEBPACK_IMPORTED_MODULE_0__);
- var Log = function() {
- function Log2() {
- }
- Log2.e = function(tag, msg) {
- if (!tag || Log2.FORCE_GLOBAL_TAG)
- tag = Log2.GLOBAL_TAG;
- var str = "[" + tag + "] > " + msg;
- if (Log2.ENABLE_CALLBACK) {
- Log2.emitter.emit("log", "error", str);
- }
- if (!Log2.ENABLE_ERROR) {
- return;
- }
- if (console.error) {
- console.error(str);
- } else if (console.warn) {
- console.warn(str);
- } else {
- console.log(str);
- }
- };
- Log2.i = function(tag, msg) {
- if (!tag || Log2.FORCE_GLOBAL_TAG)
- tag = Log2.GLOBAL_TAG;
- var str = "[" + tag + "] > " + msg;
- if (Log2.ENABLE_CALLBACK) {
- Log2.emitter.emit("log", "info", str);
- }
- if (!Log2.ENABLE_INFO) {
- return;
- }
- if (console.info) {
- console.info(str);
- } else {
- console.log(str);
- }
- };
- Log2.w = function(tag, msg) {
- if (!tag || Log2.FORCE_GLOBAL_TAG)
- tag = Log2.GLOBAL_TAG;
- var str = "[" + tag + "] > " + msg;
- if (Log2.ENABLE_CALLBACK) {
- Log2.emitter.emit("log", "warn", str);
- }
- if (!Log2.ENABLE_WARN) {
- return;
- }
- if (console.warn) {
- console.warn(str);
- } else {
- console.log(str);
- }
- };
- Log2.d = function(tag, msg) {
- if (!tag || Log2.FORCE_GLOBAL_TAG)
- tag = Log2.GLOBAL_TAG;
- var str = "[" + tag + "] > " + msg;
- if (Log2.ENABLE_CALLBACK) {
- Log2.emitter.emit("log", "debug", str);
- }
- if (!Log2.ENABLE_DEBUG) {
- return;
- }
- if (console.debug) {
- console.debug(str);
- } else {
- console.log(str);
- }
- };
- Log2.v = function(tag, msg) {
- if (!tag || Log2.FORCE_GLOBAL_TAG)
- tag = Log2.GLOBAL_TAG;
- var str = "[" + tag + "] > " + msg;
- if (Log2.ENABLE_CALLBACK) {
- Log2.emitter.emit("log", "verbose", str);
- }
- if (!Log2.ENABLE_VERBOSE) {
- return;
- }
- console.log(str);
- };
- return Log2;
- }();
- Log.GLOBAL_TAG = "flv.js";
- Log.FORCE_GLOBAL_TAG = false;
- Log.ENABLE_ERROR = true;
- Log.ENABLE_INFO = true;
- Log.ENABLE_WARN = true;
- Log.ENABLE_DEBUG = true;
- Log.ENABLE_VERBOSE = true;
- Log.ENABLE_CALLBACK = false;
- Log.emitter = new (events__WEBPACK_IMPORTED_MODULE_0___default())();
- __webpack_exports__2["default"] = Log;
- },
- "./src/utils/logging-control.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__2("./node_modules/events/events.js");
- var events__WEBPACK_IMPORTED_MODULE_0___default = /* @__PURE__ */ __webpack_require__2.n(events__WEBPACK_IMPORTED_MODULE_0__);
- var _logger_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__2("./src/utils/logger.js");
- var LoggingControl = function() {
- function LoggingControl2() {
- }
- Object.defineProperty(LoggingControl2, "forceGlobalTag", {
- get: function() {
- return _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.FORCE_GLOBAL_TAG;
- },
- set: function(enable) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.FORCE_GLOBAL_TAG = enable;
- LoggingControl2._notifyChange();
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(LoggingControl2, "globalTag", {
- get: function() {
- return _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.GLOBAL_TAG;
- },
- set: function(tag) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.GLOBAL_TAG = tag;
- LoggingControl2._notifyChange();
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(LoggingControl2, "enableAll", {
- get: function() {
- return _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_VERBOSE && _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_DEBUG && _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_INFO && _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_WARN && _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_ERROR;
- },
- set: function(enable) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_VERBOSE = enable;
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_DEBUG = enable;
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_INFO = enable;
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_WARN = enable;
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_ERROR = enable;
- LoggingControl2._notifyChange();
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(LoggingControl2, "enableDebug", {
- get: function() {
- return _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_DEBUG;
- },
- set: function(enable) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_DEBUG = enable;
- LoggingControl2._notifyChange();
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(LoggingControl2, "enableVerbose", {
- get: function() {
- return _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_VERBOSE;
- },
- set: function(enable) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_VERBOSE = enable;
- LoggingControl2._notifyChange();
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(LoggingControl2, "enableInfo", {
- get: function() {
- return _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_INFO;
- },
- set: function(enable) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_INFO = enable;
- LoggingControl2._notifyChange();
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(LoggingControl2, "enableWarn", {
- get: function() {
- return _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_WARN;
- },
- set: function(enable) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_WARN = enable;
- LoggingControl2._notifyChange();
- },
- enumerable: false,
- configurable: true
- });
- Object.defineProperty(LoggingControl2, "enableError", {
- get: function() {
- return _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_ERROR;
- },
- set: function(enable) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_ERROR = enable;
- LoggingControl2._notifyChange();
- },
- enumerable: false,
- configurable: true
- });
- LoggingControl2.getConfig = function() {
- return {
- globalTag: _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.GLOBAL_TAG,
- forceGlobalTag: _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.FORCE_GLOBAL_TAG,
- enableVerbose: _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_VERBOSE,
- enableDebug: _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_DEBUG,
- enableInfo: _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_INFO,
- enableWarn: _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_WARN,
- enableError: _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_ERROR,
- enableCallback: _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_CALLBACK
- };
- };
- LoggingControl2.applyConfig = function(config) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.GLOBAL_TAG = config.globalTag;
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.FORCE_GLOBAL_TAG = config.forceGlobalTag;
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_VERBOSE = config.enableVerbose;
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_DEBUG = config.enableDebug;
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_INFO = config.enableInfo;
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_WARN = config.enableWarn;
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_ERROR = config.enableError;
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_CALLBACK = config.enableCallback;
- };
- LoggingControl2._notifyChange = function() {
- var emitter = LoggingControl2.emitter;
- if (emitter.listenerCount("change") > 0) {
- var config = LoggingControl2.getConfig();
- emitter.emit("change", config);
- }
- };
- LoggingControl2.registerListener = function(listener) {
- LoggingControl2.emitter.addListener("change", listener);
- };
- LoggingControl2.removeListener = function(listener) {
- LoggingControl2.emitter.removeListener("change", listener);
- };
- LoggingControl2.addLogListener = function(listener) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.emitter.addListener("log", listener);
- if (_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.emitter.listenerCount("log") > 0) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_CALLBACK = true;
- LoggingControl2._notifyChange();
- }
- };
- LoggingControl2.removeLogListener = function(listener) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.emitter.removeListener("log", listener);
- if (_logger_js__WEBPACK_IMPORTED_MODULE_1__.default.emitter.listenerCount("log") === 0) {
- _logger_js__WEBPACK_IMPORTED_MODULE_1__.default.ENABLE_CALLBACK = false;
- LoggingControl2._notifyChange();
- }
- };
- return LoggingControl2;
- }();
- LoggingControl.emitter = new (events__WEBPACK_IMPORTED_MODULE_0___default())();
- __webpack_exports__2["default"] = LoggingControl;
- },
- "./src/utils/polyfill.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- var Polyfill = function() {
- function Polyfill2() {
- }
- Polyfill2.install = function() {
- Object.setPrototypeOf = Object.setPrototypeOf || function(obj, proto) {
- obj.__proto__ = proto;
- return obj;
- };
- Object.assign = Object.assign || function(target) {
- if (target === void 0 || target === null) {
- throw new TypeError("Cannot convert undefined or null to object");
- }
- var output = Object(target);
- for (var i2 = 1; i2 < arguments.length; i2++) {
- var source = arguments[i2];
- if (source !== void 0 && source !== null) {
- for (var key in source) {
- if (source.hasOwnProperty(key)) {
- output[key] = source[key];
- }
- }
- }
- }
- return output;
- };
- if (typeof self.Promise !== "function") {
- __webpack_require__2("./node_modules/es6-promise/dist/es6-promise.js").polyfill();
- }
- };
- return Polyfill2;
- }();
- Polyfill.install();
- __webpack_exports__2["default"] = Polyfill;
- },
- "./src/utils/utf8-conv.js": function(__unused_webpack_module, __webpack_exports__2, __webpack_require__2) {
- __webpack_require__2.r(__webpack_exports__2);
- function checkContinuation(uint8array, start2, checkLength) {
- var array = uint8array;
- if (start2 + checkLength < array.length) {
- while (checkLength--) {
- if ((array[++start2] & 192) !== 128)
- return false;
- }
- return true;
- } else {
- return false;
- }
- }
- function decodeUTF8(uint8array) {
- var out = [];
- var input = uint8array;
- var i2 = 0;
- var length = uint8array.length;
- while (i2 < length) {
- if (input[i2] < 128) {
- out.push(String.fromCharCode(input[i2]));
- ++i2;
- continue;
- } else if (input[i2] < 192)
- ;
- else if (input[i2] < 224) {
- if (checkContinuation(input, i2, 1)) {
- var ucs4 = (input[i2] & 31) << 6 | input[i2 + 1] & 63;
- if (ucs4 >= 128) {
- out.push(String.fromCharCode(ucs4 & 65535));
- i2 += 2;
- continue;
- }
- }
- } else if (input[i2] < 240) {
- if (checkContinuation(input, i2, 2)) {
- var ucs4 = (input[i2] & 15) << 12 | (input[i2 + 1] & 63) << 6 | input[i2 + 2] & 63;
- if (ucs4 >= 2048 && (ucs4 & 63488) !== 55296) {
- out.push(String.fromCharCode(ucs4 & 65535));
- i2 += 3;
- continue;
- }
- }
- } else if (input[i2] < 248) {
- if (checkContinuation(input, i2, 3)) {
- var ucs4 = (input[i2] & 7) << 18 | (input[i2 + 1] & 63) << 12 | (input[i2 + 2] & 63) << 6 | input[i2 + 3] & 63;
- if (ucs4 > 65536 && ucs4 < 1114112) {
- ucs4 -= 65536;
- out.push(String.fromCharCode(ucs4 >>> 10 | 55296));
- out.push(String.fromCharCode(ucs4 & 1023 | 56320));
- i2 += 4;
- continue;
- }
- }
- }
- out.push(String.fromCharCode(65533));
- ++i2;
- }
- return out.join("");
- }
- __webpack_exports__2["default"] = decodeUTF8;
- }
- };
- var __webpack_module_cache__ = {};
- function __webpack_require__(moduleId) {
- var cachedModule = __webpack_module_cache__[moduleId];
- if (cachedModule !== void 0) {
- return cachedModule.exports;
- }
- var module3 = __webpack_module_cache__[moduleId] = {
- exports: {}
- };
- __webpack_modules__[moduleId].call(module3.exports, module3, module3.exports, __webpack_require__);
- return module3.exports;
- }
- __webpack_require__.m = __webpack_modules__;
- !function() {
- __webpack_require__.n = function(module3) {
- var getter = module3 && module3.__esModule ? function() {
- return module3["default"];
- } : function() {
- return module3;
- };
- __webpack_require__.d(getter, { a: getter });
- return getter;
- };
- }();
- !function() {
- __webpack_require__.d = function(exports3, definition) {
- for (var key in definition) {
- if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports3, key)) {
- Object.defineProperty(exports3, key, { enumerable: true, get: definition[key] });
- }
- }
- };
- }();
- !function() {
- __webpack_require__.g = function() {
- if (typeof globalThis === "object")
- return globalThis;
- try {
- return this || new Function("return this")();
- } catch (e) {
- if (typeof window === "object")
- return window;
- }
- }();
- }();
- !function() {
- __webpack_require__.o = function(obj, prop) {
- return Object.prototype.hasOwnProperty.call(obj, prop);
- };
- }();
- !function() {
- __webpack_require__.r = function(exports3) {
- if (typeof Symbol !== "undefined" && Symbol.toStringTag) {
- Object.defineProperty(exports3, Symbol.toStringTag, { value: "Module" });
- }
- Object.defineProperty(exports3, "__esModule", { value: true });
- };
- }();
- var __webpack_exports__ = __webpack_require__("./src/index.js");
- return __webpack_exports__;
- }();
- });
- })(flv);
- var flvjs = /* @__PURE__ */ getDefaultExportFromCjs(flv.exports);
- const Html5 = videojs$2.getTech("Html5");
- const mergeOptions = videojs$2.mergeOptions || videojs$2.util.mergeOptions;
- const defaults = {
- mediaDataSource: {},
- config: {}
- };
- class Flvjs extends Html5 {
- constructor(options2, ready) {
- options2 = mergeOptions(defaults, options2);
- super(options2, ready);
- }
- setSrc(src) {
- if (this.flvPlayer) {
- this.flvPlayer.detachMediaElement();
- this.flvPlayer.destroy();
- }
- const mediaDataSource = this.options_.mediaDataSource;
- const config = this.options_.config;
- mediaDataSource.type = mediaDataSource.type === void 0 ? "flv" : mediaDataSource.type;
- mediaDataSource.url = src;
- this.flvPlayer = flvjs.createPlayer(mediaDataSource, config);
- this.flvPlayer.attachMediaElement(this.el_);
- this.flvPlayer.load();
- }
- dispose() {
- if (this.flvPlayer) {
- this.flvPlayer.detachMediaElement();
- this.flvPlayer.destroy();
- }
- super.dispose();
- }
- }
- Flvjs.isSupported = function() {
- return flvjs && flvjs.isSupported();
- };
- Flvjs.formats = {
- "video/flv": "FLV",
- "video/x-flv": "FLV"
- };
- Flvjs.canPlayType = function(type2) {
- if (Flvjs.isSupported() && type2 in Flvjs.formats) {
- return "maybe";
- }
- return "";
- };
- Flvjs.canPlaySource = function(srcObj, options2) {
- return Flvjs.canPlayType(srcObj.type);
- };
- Flvjs.VERSION = "__VERSION__";
- videojs$2.registerTech("Flvjs", Flvjs);
- var VideoWindow$1 = "";
- class VideoWindow {
- constructor(viewer2, position2, videoInfo, offsetHeight) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!position2)
- throw new Cesium.DeveloperError("no position object!");
- this.viewer = viewer2;
- this.position = position2;
- this.offsetHeight = offsetHeight;
- if (position2 instanceof Cesium.Cartesian3) {
- this.position = position2;
- } else {
- this.position = Cesium.Cartesian3.fromDegrees(position2[0], position2[1], position2[2] || 0);
- }
- if (document.getElementsByClassName("popup-video").length > 0) {
- document.getElementsByClassName("popup-video")[0].remove();
- viewer2.entities.remove(viewer2.entities.getById("videoPopupPoint"));
- }
- this.id = "popup_video_" + getGuid();
- this.popupDiv = document.createElement("div");
- this.popupDiv.classList.add("popup-video");
- this.popupDiv.id = this.id;
- this.viewer.container.append(this.popupDiv);
- this.popupDiv.innerHTML = this._createHtml(videoInfo);
- switch (videoInfo.type) {
- case "hls":
- this.videotype = "application/x-mpegURL";
- break;
- case "rtmp":
- this.videotype = "rtmp/flv";
- break;
- case "flv":
- this.videotype = "video/x-flv";
- break;
- case "mp4":
- this.videotype = "video/mp4";
- break;
- }
- this.videoPlayer = videojs$2(document.querySelector("#myvideo"), {
- controls: true,
- autoplay: "muted",
- loop: true,
- muted: false,
- fluid: true,
- aspectRatio: "16:9",
- reload: "auto",
- fullscreen: {
- options: {
- navigationUI: "hide"
- }
- },
- sources: [{
- src: videoInfo.url,
- type: this.videotype
- }]
- }, function onPlayerReady() {
- });
- this.viewer.scene.postRender.addEventListener(this.postRender, this);
- this.initPoint();
- document.getElementsByClassName("popup-video1-close-button")[0].onclick = () => {
- this.close();
- };
- }
- postRender() {
- this.viewer.scene.canvas.height;
- const windowPosition = new Cesium.Cartesian2();
- Cesium.SceneTransforms.wgs84ToWindowCoordinates(
- this.viewer.scene,
- this.position,
- windowPosition
- );
- let elWidth = this.popupDiv.offsetWidth;
- let elHeight = this.popupDiv.offsetHeight;
- if (!!this.offsetHeight) {
- elHeight += this.offsetHeight;
- }
- this.popupDiv.style.left = windowPosition.x - elWidth / 2 + "px";
- this.popupDiv.style.top = windowPosition.y - elHeight + "px";
- const camerPosition = this.viewer.camera.position;
- let height2 = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(camerPosition).height;
- height2 += this.viewer.scene.globe.ellipsoid.maximumRadius;
- if (!(Cesium.Cartesian3.distance(camerPosition, this.position) > height2) && this.viewer.camera.positionCartographic.height < 5e7) {
- this.popupDiv.style.display = "block";
- } else {
- this.popupDiv.style.display = "none";
- }
- }
- _createHtml(videoInfo) {
- let html = `
- <div class="popup-video-header">
- ${videoInfo.name}
- <span class="popup-video1-close-button">\xD7</span>
- </div>
- <div class="popup-video-content">
- <video id="myvideo" class="video-js vjs-big-play-centered vjs-fluid" controls preload="auto" width="100%" height="100%"></video>
- </div>
- <div class="popup-video-tip">
- </div>
- `;
- return html;
- }
- initPoint() {
- this.billboard = new Cesium.Entity({
- id: "videoPopupPoint",
- name: "popupPoint",
- position: this.position,
- billboard: {
- image: "jt3dSDK/imgs/point/point.png",
- horizontalOrigin: Cesium.HorizontalOrigin.center,
- verticalOrigin: Cesium.VerticalOrigin.bottom,
- scale: 1,
- pixelOffset: new Cesium.Cartesian2(0, 0),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- }
- });
- this.viewer.entities.add(this.billboard);
- }
- }
- Object.assign(VideoWindow.prototype, {
- close() {
- this.popupDiv.remove();
- this.viewer.scene.postRender.removeEventListener(this.postRender, this);
- this.viewer.entities.remove(this.billboard);
- videojs$2("myvideo").dispose();
- this.videoPlayer.dispose();
- }
- });
- var VideoWindow2$1 = "";
- class VideoWindow2 {
- constructor(viewer2, position2, videoInfo) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!position2)
- throw new Cesium.DeveloperError("no position object!");
- this.viewer = viewer2;
- this.position = position2;
- if (position2 instanceof Cesium.Cartesian3) {
- this.position = position2;
- } else {
- this.position = Cesium.Cartesian3.fromDegrees(position2[0], position2[1], position2[2] || 0);
- }
- if (document.getElementsByClassName("popup-video2").length > 0) {
- document.getElementsByClassName("popup-video2")[0].remove();
- }
- this.id = "popup_video_" + getGuid();
- this.popupDiv = document.createElement("div");
- this.popupDiv.classList.add("popup-video2");
- this.popupDiv.id = this.id;
- this.viewer.container.append(this.popupDiv);
- this.popupDiv.innerHTML = this._createHtml(videoInfo);
- switch (videoInfo.type) {
- case "hls":
- this.videotype = "application/x-mpegURL";
- break;
- case "rtmp":
- this.videotype = "rtmp/flv";
- break;
- case "flv":
- this.videotype = "video/x-flv";
- break;
- case "mp4":
- this.videotype = "video/mp4";
- break;
- }
- this.videoPlayer = videojs$2(document.querySelector("#myvideo"), {
- controls: true,
- autoplay: "muted",
- loop: true,
- muted: false,
- fluid: true,
- aspectRatio: "16:9",
- reload: "auto",
- fullscreen: {
- options: {
- navigationUI: "hide"
- }
- },
- sources: [{
- src: videoInfo.url,
- type: this.videotype
- }]
- }, function onPlayerReady() {
- console.log("onPlayerReady", this);
- });
- this.viewer.scene.postRender.addEventListener(this.postRender, this);
- document.getElementsByClassName("popup-video2-close-button")[0].onclick = () => {
- this.close();
- };
- }
- postRender() {
- this.viewer.scene.canvas.height;
- const windowPosition = new Cesium.Cartesian2();
- Cesium.SceneTransforms.wgs84ToWindowCoordinates(
- this.viewer.scene,
- this.position,
- windowPosition
- );
- this.popupDiv.style.left = windowPosition.x - this.popupDiv.offsetWidth - 120 + "px";
- this.popupDiv.style.top = windowPosition.y + "px";
- const camerPosition = this.viewer.camera.position;
- let height2 = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(camerPosition).height;
- height2 += this.viewer.scene.globe.ellipsoid.maximumRadius;
- if (!(Cesium.Cartesian3.distance(camerPosition, this.position) > height2) && this.viewer.camera.positionCartographic.height < 5e7) {
- this.popupDiv.style.display = "block";
- } else {
- this.popupDiv.style.display = "none";
- }
- }
- _createHtml(videoInfo) {
- let html = `
- <div class="rightLine-1"></div>
- <div class="rightLine-2"></div>
- <div class="rightLine-3"></div>
- <div class="popup-header">
- <span class="popup-title" >${videoInfo.name}</span>
- <span class="popup-video2-close-button" title="\u5173\u95ED" >\xD7</span>
- </div>
- <div class="popup-content">
- <video id="myvideo" class="video-js vjs-big-play-centered vjs-fluid" controls preload="auto" width="100%" height="100%"></video>
- </div>
- `;
- return html;
- }
- }
- Object.assign(VideoWindow2.prototype, {
- close() {
- this.popupDiv.remove();
- this.viewer.scene.postRender.removeEventListener(this.postRender, this);
- }
- });
- var VideoWindow3$1 = "";
- class VideoWindow3 {
- constructor(viewer2, position2, videoInfo) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!position2)
- throw new Cesium.DeveloperError("no position object!");
- this.viewer = viewer2;
- this.position = position2;
- if (position2 instanceof Cesium.Cartesian3) {
- this.position = position2;
- } else {
- this.position = Cesium.Cartesian3.fromDegrees(position2[0], position2[1], position2[2] || 0);
- }
- if (document.getElementsByClassName("popup-video3").length > 0) {
- document.getElementsByClassName("popup-video3")[0].remove();
- }
- this.id = "popup_video_" + getGuid();
- this.popupDiv = document.createElement("div");
- this.popupDiv.classList.add("popup-video3");
- this.popupDiv.id = this.id;
- this.viewer.container.append(this.popupDiv);
- this.popupDiv.innerHTML = this._createHtml(videoInfo);
- switch (videoInfo.type) {
- case "hls":
- this.videotype = "application/x-mpegURL";
- break;
- case "rtmp":
- this.videotype = "rtmp/flv";
- break;
- case "flv":
- this.videotype = "video/x-flv";
- break;
- case "mp4":
- this.videotype = "video/mp4";
- break;
- }
- this.videoPlayer = videojs$2(document.querySelector("#myvideo"), {
- controls: true,
- autoplay: "muted",
- loop: true,
- muted: false,
- fluid: true,
- aspectRatio: "16:9",
- reload: "auto",
- fullscreen: {
- options: {
- navigationUI: "hide"
- }
- },
- sources: [{
- src: videoInfo.url,
- type: this.videotype
- }]
- }, function onPlayerReady() {
- });
- this.viewer.scene.postRender.addEventListener(this.postRender, this);
- document.getElementsByClassName("popup-video3-close-button")[0].onclick = () => {
- this.close();
- };
- }
- postRender() {
- this.viewer.scene.canvas.height;
- const windowPosition = new Cesium.Cartesian2();
- Cesium.SceneTransforms.wgs84ToWindowCoordinates(
- this.viewer.scene,
- this.position,
- windowPosition
- );
- this.popupDiv.style.left = windowPosition.x + 70 + "px";
- this.popupDiv.style.top = windowPosition.y - this.popupDiv.offsetHeight - 20 + "px";
- const camerPosition = this.viewer.camera.position;
- let height2 = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(camerPosition).height;
- height2 += this.viewer.scene.globe.ellipsoid.maximumRadius;
- if (!(Cesium.Cartesian3.distance(camerPosition, this.position) > height2) && this.viewer.camera.positionCartographic.height < 5e7) {
- this.popupDiv.style.display = "block";
- } else {
- this.popupDiv.style.display = "none";
- }
- }
- _createHtml(videoInfo) {
- let html = `
- <div class="leftLine-1"></div>
- <div class="leftLine-2"></div>
- <div class="popup-header">
- <span class="popup-title" >${videoInfo.name}</span>
- <span class="popup-video3-close-button" title="\u5173\u95ED" >\xD7</span>
- </div>
- <div class="popup-content">
- <video id="myvideo" class="video-js vjs-big-play-centered vjs-fluid" controls preload="auto" width="100%" height="100%"></video>
- </div>
- `;
- return html;
- }
- }
- Object.assign(VideoWindow3.prototype, {
- close() {
- this.popupDiv.remove();
- this.viewer.scene.postRender.removeEventListener(this.postRender, this);
- }
- });
- var HtmlWindow1 = "";
- class HtmlWindow {
- constructor(viewer2, position2, title, html, offsetHeight) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!position2)
- throw new Cesium.DeveloperError("no position object!");
- this.viewer = viewer2;
- this.offsetHeight = offsetHeight;
- if (position2 instanceof Cesium.Cartesian3) {
- this.position = position2;
- } else {
- this.position = Cesium.Cartesian3.fromDegrees(position2[0], position2[1], position2[2] || 0);
- }
- if (document.getElementsByClassName("popup1").length > 0) {
- document.getElementsByClassName("popup1")[0].remove();
- viewer2.entities.remove(viewer2.entities.getById("popupPoint"));
- }
- this.id = "popup_" + getGuid();
- this.popupDiv = document.createElement("div");
- this.popupDiv.classList.add("popup1");
- this.popupDiv.id = this.id;
- this.viewer.container.append(this.popupDiv);
- this.popupDiv.innerHTML = this._createHtml(title, html);
- this.viewer.scene.postRender.addEventListener(this.postRender, this);
- this.initPoint();
- document.getElementsByClassName("popup1-close-button")[0].onclick = () => {
- this.close();
- };
- }
- postRender() {
- this.viewer.scene.canvas.height;
- const windowPosition = new Cesium.Cartesian2();
- Cesium.SceneTransforms.wgs84ToWindowCoordinates(
- this.viewer.scene,
- this.position,
- windowPosition
- );
- let elWidth = this.popupDiv.offsetWidth;
- let elHeight = this.popupDiv.offsetHeight;
- if (!!this.offsetHeight) {
- elHeight += this.offsetHeight;
- }
- this.popupDiv.style.left = windowPosition.x - elWidth / 2 + "px";
- this.popupDiv.style.top = windowPosition.y - elHeight + "px";
- const camerPosition = this.viewer.camera.position;
- let height2 = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(camerPosition).height;
- height2 += this.viewer.scene.globe.ellipsoid.maximumRadius;
- if (!(Cesium.Cartesian3.distance(camerPosition, this.position) > height2) && this.viewer.camera.positionCartographic.height < 5e7) {
- this.popupDiv.style.display = "block";
- } else {
- this.popupDiv.style.display = "none";
- }
- }
- _createHtml(header, content) {
- let html = `
- <div class="popup-header">
- ${header}
- <span class="popup1-close-button">\xD7</span>
- </div>
- <div class="popup-content">
- ${content}
- </div>
- <div class="popup-tip">
- </div>
- `;
- return html;
- }
- initPoint() {
- this.billboard = this.viewer.entities.add({
- id: "popupPoint",
- name: "popupPoint",
- position: this.position,
- billboard: {
- image: "jt3dSDK/imgs/point/point.png",
- horizontalOrigin: Cesium.HorizontalOrigin.center,
- verticalOrigin: Cesium.VerticalOrigin.bottom,
- scale: 1,
- pixelOffset: new Cesium.Cartesian2(0, 0),
- disableDepthTestDistance: Number.POSITIVE_INFINITY
- }
- });
- }
- }
- Object.assign(HtmlWindow.prototype, {
- close() {
- this.popupDiv.remove();
- this.viewer.scene.postRender.removeEventListener(this.postRender, this);
- this.viewer.entities.remove(this.billboard);
- }
- });
- var HtmlWindow2$1 = "";
- class HtmlWindow2 {
- constructor(viewer2, position2, title, html) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!position2)
- throw new Cesium.DeveloperError("no position object!");
- this.viewer = viewer2;
- this.position = position2;
- if (position2 instanceof Cesium.Cartesian3) {
- this.position = position2;
- } else {
- this.position = Cesium.Cartesian3.fromDegrees(position2[0], position2[1], position2[2] || 0);
- }
- if (document.getElementsByClassName("popup2").length > 0) {
- document.getElementsByClassName("popup2")[0].remove();
- }
- this.id = "popup_" + getGuid();
- this.popupDiv = document.createElement("div");
- this.popupDiv.classList.add("popup2");
- this.popupDiv.id = this.id;
- this.viewer.container.append(this.popupDiv);
- this.popupDiv.innerHTML = this._createHtml(title, html);
- this.viewer.scene.postRender.addEventListener(this.postRender, this);
- document.getElementsByClassName("popup2-close-button")[0].onclick = () => {
- this.close();
- };
- }
- postRender() {
- this.viewer.scene.canvas.height;
- const windowPosition = new Cesium.Cartesian2();
- Cesium.SceneTransforms.wgs84ToWindowCoordinates(
- this.viewer.scene,
- this.position,
- windowPosition
- );
- this.popupDiv.style.left = windowPosition.x - this.popupDiv.offsetWidth - 120 + "px";
- this.popupDiv.style.top = windowPosition.y + "px";
- const camerPosition = this.viewer.camera.position;
- let height2 = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(camerPosition).height;
- height2 += this.viewer.scene.globe.ellipsoid.maximumRadius;
- if (!(Cesium.Cartesian3.distance(camerPosition, this.position) > height2) && this.viewer.camera.positionCartographic.height < 5e7) {
- this.popupDiv.style.display = "block";
- } else {
- this.popupDiv.style.display = "none";
- }
- }
- _createHtml(title, content) {
- let html = `
- <div class="rightLine-1"></div>
- <div class="rightLine-2"></div>
- <div class="rightLine-3"></div>
- <div class="popup-header">
- <span class="popup-title" >${title}</span>
- <span class="popup2-close-button" title="\u5173\u95ED" >\xD7</span>
- </div>
- <div class="popup-content">
- ${content}
- </div>
- `;
- return html;
- }
- }
- Object.assign(HtmlWindow2.prototype, {
- close() {
- this.popupDiv.remove();
- this.viewer.scene.postRender.removeEventListener(this.postRender, this);
- }
- });
- var HtmlWindow3$1 = "";
- class HtmlWindow3 {
- constructor(viewer2, position2, title, html) {
- if (!viewer2)
- throw new Cesium.DeveloperError("no viewer object!");
- if (!position2)
- throw new Cesium.DeveloperError("no position object!");
- this.viewer = viewer2;
- this.position = position2;
- if (position2 instanceof Cesium.Cartesian3) {
- this.position = position2;
- } else {
- this.position = Cesium.Cartesian3.fromDegrees(position2[0], position2[1], position2[2] || 0);
- }
- if (document.getElementsByClassName("popup3").length > 0) {
- document.getElementsByClassName("popup3")[0].remove();
- }
- this.id = "popup_" + getGuid();
- this.popupDiv = document.createElement("div");
- this.popupDiv.classList.add("popup3");
- this.popupDiv.id = this.id;
- this.viewer.container.append(this.popupDiv);
- this.popupDiv.innerHTML = this._createHtml(title, html);
- this.viewer.scene.postRender.addEventListener(this.postRender, this);
- document.getElementsByClassName("popup3-close-button")[0].onclick = () => {
- this.close();
- };
- }
- postRender() {
- this.viewer.scene.canvas.height;
- const windowPosition = new Cesium.Cartesian2();
- Cesium.SceneTransforms.wgs84ToWindowCoordinates(
- this.viewer.scene,
- this.position,
- windowPosition
- );
- this.popupDiv.style.left = windowPosition.x + 70 + "px";
- this.popupDiv.style.top = windowPosition.y - this.popupDiv.offsetHeight - 20 + "px";
- const camerPosition = this.viewer.camera.position;
- let height2 = this.viewer.scene.globe.ellipsoid.cartesianToCartographic(camerPosition).height;
- height2 += this.viewer.scene.globe.ellipsoid.maximumRadius;
- if (!(Cesium.Cartesian3.distance(camerPosition, this.position) > height2) && this.viewer.camera.positionCartographic.height < 5e7) {
- this.popupDiv.style.display = "block";
- } else {
- this.popupDiv.style.display = "none";
- }
- }
- _createHtml(title, content) {
- let html = `
- <div class="leftLine-1"></div>
- <div class="leftLine-2"></div>
- <div class="popup-header">
- <span class="popup-title" >${title}</span>
- <span class="popup3-close-button" title="\u5173\u95ED" >\xD7</span>
- </div>
- <div class="popup-content">
- ${content}
- </div>
- `;
- return html;
- }
- }
- Object.assign(HtmlWindow3.prototype, {
- close() {
- this.popupDiv.remove();
- this.viewer.scene.postRender.removeEventListener(this.postRender, this);
- }
- });
- let PopupWindow = {
- MultiFieldAdaptWindow,
- VideoWindow,
- VideoWindow2,
- VideoWindow3,
- HtmlWindow,
- HtmlWindow2,
- HtmlWindow3
- };
- class AroundPoint {
- constructor(viewer2, amount, position2) {
- this._viewer = viewer2;
- this._amount = amount;
- this._position = position2;
- this._range = this._viewer.camera.positionCartographic.height;
- }
- _bindEvent() {
- let _self = this;
- this._viewer.clock.onTick.addEventListener(this._aroundPoint, this);
- var handler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- handler.setInputAction(function(click) {
- _self.stop();
- }, Cesium.ScreenSpaceEventType.LEFT_DOWN);
- }
- _unbindEvent() {
- this._viewer.camera.lookAtTransform(Cesium.Matrix4.IDENTITY);
- this._viewer.clock.onTick.removeEventListener(this._aroundPoint, this);
- }
- start() {
- this._viewer.clock.shouldAnimate = true;
- this._unbindEvent();
- this._bindEvent();
- return this;
- }
- stop() {
- this._unbindEvent();
- return this;
- }
- _aroundPoint() {
- let heading = this._viewer.camera.heading;
- let pitch = this._viewer.camera.pitch;
- let range3 = this._range;
- heading += Cesium.Math.toRadians(this._amount);
- if (heading >= Math.PI * 2 || heading <= -Math.PI * 2) {
- heading = 0;
- }
- this._viewer.camera.lookAt(
- this._position,
- new Cesium.HeadingPitchRange(
- heading,
- pitch,
- range3
- )
- );
- }
- }
- class AroundView {
- constructor(viewer2, amount) {
- this._viewer = viewer2;
- this._amount = amount;
- }
- _bindEvent() {
- let _self = this;
- this._viewer.clock.onTick.addEventListener(this._aroundView, this);
- var handler = new Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
- handler.setInputAction(function(click) {
- _self.stop();
- }, Cesium.ScreenSpaceEventType.LEFT_DOWN);
- }
- _unbindEvent() {
- this._viewer.camera.lookAtTransform(Cesium.Matrix4.IDENTITY);
- this._viewer.clock.onTick.removeEventListener(this._aroundView, this);
- }
- start() {
- this._viewer.clock.shouldAnimate = true;
- this._unbindEvent();
- this._bindEvent();
- return this;
- }
- stop() {
- this._unbindEvent();
- return this;
- }
- _aroundView() {
- let heading = this._viewer.camera.heading;
- let pitch = this._viewer.camera.pitch;
- let roll = this._viewer.camera.roll;
- heading += Cesium.Math.toRadians(this._amount);
- if (heading >= Math.PI * 2 || heading <= -Math.PI * 2) {
- heading = 0;
- }
- this._viewer.camera.setView({
- orientation: {
- heading,
- pitch,
- roll
- }
- });
- }
- }
- export { AroundPoint, AroundView, CircleObject, CommonTools, CoordTransform, CrImageServerLayer, DrawMilitaryPlot, DrawPoint, DrawTools, LocateUtil, PointObject, PolygonObject, PolylineObject, PopupWindow, CreateRemindertip as ReminderTip, Roaming, RuntimeEnvironment, SceneControl, SceneEffects, SketchViewModel, SpatialAnalysis, StatusBar, TerrainAnalysis, TrackRoam, WallObject, common, jtMap3d, LoadMapData as layer };
|