1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404840584068407840884098410841184128413841484158416841784188419842084218422842384248425842684278428842984308431843284338434843584368437843884398440844184428443844484458446844784488449845084518452845384548455845684578458845984608461846284638464846584668467846884698470847184728473847484758476847784788479848084818482848384848485848684878488848984908491849284938494849584968497849884998500850185028503850485058506850785088509851085118512851385148515851685178518851985208521852285238524852585268527852885298530853185328533853485358536853785388539854085418542854385448545854685478548854985508551855285538554855585568557855885598560856185628563856485658566856785688569857085718572857385748575857685778578857985808581858285838584858585868587858885898590859185928593859485958596859785988599860086018602860386048605860686078608860986108611861286138614861586168617861886198620862186228623862486258626862786288629863086318632863386348635863686378638863986408641864286438644864586468647864886498650865186528653865486558656865786588659866086618662866386648665866686678668866986708671867286738674867586768677867886798680868186828683868486858686868786888689869086918692869386948695869686978698869987008701870287038704870587068707870887098710871187128713871487158716871787188719872087218722872387248725872687278728872987308731873287338734873587368737873887398740874187428743874487458746874787488749875087518752875387548755875687578758875987608761876287638764876587668767876887698770877187728773877487758776877787788779878087818782878387848785878687878788878987908791879287938794879587968797879887998800880188028803880488058806880788088809881088118812881388148815881688178818881988208821882288238824882588268827882888298830883188328833883488358836883788388839884088418842884388448845884688478848884988508851885288538854885588568857885888598860886188628863886488658866886788688869887088718872887388748875887688778878887988808881888288838884888588868887888888898890889188928893889488958896889788988899890089018902890389048905890689078908890989108911891289138914891589168917891889198920892189228923892489258926892789288929893089318932893389348935893689378938893989408941894289438944894589468947894889498950895189528953895489558956895789588959896089618962896389648965896689678968896989708971897289738974897589768977897889798980898189828983898489858986898789888989899089918992899389948995899689978998899990009001900290039004900590069007900890099010901190129013901490159016901790189019902090219022902390249025902690279028902990309031903290339034903590369037903890399040904190429043904490459046904790489049905090519052905390549055905690579058905990609061906290639064906590669067906890699070907190729073907490759076907790789079908090819082908390849085908690879088908990909091909290939094909590969097909890999100910191029103910491059106910791089109911091119112911391149115911691179118911991209121912291239124912591269127912891299130913191329133913491359136913791389139914091419142914391449145914691479148914991509151915291539154915591569157915891599160916191629163916491659166916791689169917091719172917391749175917691779178917991809181918291839184918591869187918891899190919191929193919491959196919791989199920092019202920392049205920692079208920992109211921292139214921592169217921892199220922192229223922492259226922792289229923092319232923392349235923692379238923992409241924292439244924592469247924892499250925192529253925492559256925792589259926092619262926392649265926692679268926992709271927292739274927592769277927892799280928192829283928492859286928792889289929092919292929392949295929692979298929993009301930293039304930593069307930893099310931193129313931493159316931793189319932093219322932393249325932693279328932993309331933293339334933593369337933893399340934193429343934493459346934793489349935093519352935393549355935693579358935993609361936293639364936593669367936893699370937193729373937493759376937793789379938093819382938393849385938693879388938993909391939293939394939593969397939893999400940194029403940494059406940794089409941094119412941394149415941694179418941994209421942294239424942594269427942894299430943194329433943494359436943794389439944094419442944394449445944694479448944994509451945294539454945594569457945894599460946194629463946494659466946794689469947094719472947394749475947694779478947994809481948294839484948594869487948894899490949194929493949494959496949794989499950095019502950395049505950695079508950995109511951295139514951595169517951895199520952195229523952495259526952795289529953095319532953395349535953695379538953995409541954295439544954595469547954895499550955195529553955495559556955795589559956095619562956395649565956695679568956995709571957295739574957595769577957895799580958195829583958495859586958795889589959095919592959395949595959695979598959996009601960296039604960596069607960896099610961196129613961496159616961796189619962096219622962396249625962696279628962996309631963296339634963596369637963896399640964196429643964496459646964796489649965096519652965396549655965696579658965996609661966296639664966596669667966896699670967196729673967496759676967796789679968096819682968396849685968696879688968996909691969296939694969596969697969896999700970197029703970497059706970797089709971097119712971397149715971697179718971997209721972297239724972597269727972897299730973197329733973497359736973797389739974097419742974397449745974697479748974997509751975297539754975597569757975897599760976197629763976497659766976797689769977097719772977397749775977697779778977997809781978297839784978597869787978897899790979197929793979497959796979797989799980098019802980398049805980698079808980998109811981298139814981598169817981898199820982198229823982498259826982798289829983098319832983398349835983698379838983998409841984298439844984598469847984898499850985198529853985498559856985798589859986098619862986398649865986698679868986998709871987298739874987598769877987898799880988198829883988498859886988798889889989098919892989398949895989698979898989999009901990299039904990599069907990899099910991199129913991499159916991799189919992099219922992399249925992699279928992999309931993299339934993599369937993899399940994199429943994499459946994799489949995099519952995399549955995699579958995999609961996299639964996599669967996899699970997199729973997499759976997799789979998099819982998399849985998699879988998999909991999299939994999599969997999899991000010001100021000310004100051000610007100081000910010100111001210013100141001510016100171001810019100201002110022100231002410025100261002710028100291003010031100321003310034100351003610037100381003910040100411004210043100441004510046100471004810049100501005110052100531005410055100561005710058100591006010061100621006310064100651006610067100681006910070100711007210073100741007510076100771007810079100801008110082100831008410085100861008710088100891009010091100921009310094100951009610097100981009910100101011010210103101041010510106101071010810109101101011110112101131011410115101161011710118101191012010121101221012310124101251012610127101281012910130101311013210133101341013510136101371013810139101401014110142101431014410145101461014710148101491015010151101521015310154101551015610157101581015910160101611016210163101641016510166101671016810169101701017110172101731017410175101761017710178101791018010181101821018310184101851018610187101881018910190101911019210193101941019510196101971019810199102001020110202102031020410205102061020710208102091021010211102121021310214102151021610217102181021910220102211022210223102241022510226102271022810229102301023110232102331023410235102361023710238102391024010241102421024310244102451024610247102481024910250102511025210253102541025510256102571025810259102601026110262102631026410265102661026710268102691027010271102721027310274102751027610277102781027910280102811028210283102841028510286102871028810289102901029110292102931029410295102961029710298102991030010301103021030310304103051030610307103081030910310103111031210313103141031510316103171031810319103201032110322103231032410325103261032710328103291033010331103321033310334103351033610337103381033910340103411034210343103441034510346103471034810349103501035110352103531035410355103561035710358103591036010361103621036310364103651036610367103681036910370103711037210373103741037510376103771037810379103801038110382103831038410385103861038710388103891039010391103921039310394103951039610397103981039910400104011040210403104041040510406104071040810409104101041110412104131041410415104161041710418104191042010421104221042310424104251042610427104281042910430104311043210433104341043510436104371043810439104401044110442104431044410445104461044710448104491045010451104521045310454104551045610457104581045910460104611046210463104641046510466104671046810469104701047110472104731047410475104761047710478104791048010481104821048310484104851048610487104881048910490104911049210493104941049510496104971049810499105001050110502105031050410505105061050710508105091051010511105121051310514105151051610517105181051910520105211052210523105241052510526105271052810529105301053110532105331053410535105361053710538105391054010541105421054310544105451054610547105481054910550105511055210553105541055510556105571055810559105601056110562105631056410565105661056710568105691057010571105721057310574105751057610577105781057910580105811058210583105841058510586105871058810589105901059110592105931059410595105961059710598105991060010601106021060310604106051060610607106081060910610106111061210613106141061510616106171061810619106201062110622106231062410625106261062710628106291063010631106321063310634106351063610637106381063910640106411064210643106441064510646106471064810649106501065110652106531065410655106561065710658106591066010661106621066310664106651066610667106681066910670106711067210673106741067510676106771067810679106801068110682106831068410685106861068710688106891069010691106921069310694106951069610697106981069910700107011070210703107041070510706107071070810709107101071110712107131071410715107161071710718107191072010721107221072310724107251072610727107281072910730107311073210733107341073510736107371073810739107401074110742107431074410745107461074710748107491075010751107521075310754107551075610757107581075910760107611076210763107641076510766107671076810769107701077110772107731077410775107761077710778107791078010781107821078310784107851078610787107881078910790107911079210793107941079510796107971079810799108001080110802108031080410805108061080710808108091081010811108121081310814108151081610817108181081910820108211082210823108241082510826108271082810829108301083110832108331083410835108361083710838108391084010841108421084310844108451084610847108481084910850108511085210853108541085510856108571085810859108601086110862108631086410865108661086710868108691087010871108721087310874108751087610877108781087910880108811088210883108841088510886108871088810889108901089110892108931089410895108961089710898108991090010901109021090310904109051090610907109081090910910109111091210913109141091510916109171091810919109201092110922109231092410925109261092710928109291093010931109321093310934109351093610937109381093910940109411094210943109441094510946109471094810949109501095110952109531095410955109561095710958109591096010961109621096310964109651096610967109681096910970109711097210973109741097510976109771097810979109801098110982109831098410985109861098710988109891099010991109921099310994109951099610997109981099911000110011100211003110041100511006110071100811009110101101111012110131101411015110161101711018110191102011021110221102311024110251102611027110281102911030110311103211033110341103511036110371103811039110401104111042110431104411045110461104711048110491105011051110521105311054110551105611057110581105911060110611106211063110641106511066110671106811069110701107111072110731107411075110761107711078110791108011081110821108311084110851108611087110881108911090110911109211093110941109511096110971109811099111001110111102111031110411105111061110711108111091111011111111121111311114111151111611117111181111911120111211112211123111241112511126111271112811129111301113111132111331113411135111361113711138111391114011141111421114311144111451114611147111481114911150111511115211153111541115511156111571115811159111601116111162111631116411165111661116711168111691117011171111721117311174111751117611177111781117911180111811118211183111841118511186111871118811189111901119111192111931119411195111961119711198111991120011201112021120311204112051120611207112081120911210112111121211213112141121511216112171121811219112201122111222112231122411225112261122711228112291123011231112321123311234112351123611237112381123911240112411124211243112441124511246112471124811249112501125111252112531125411255112561125711258112591126011261112621126311264112651126611267112681126911270112711127211273112741127511276112771127811279112801128111282112831128411285112861128711288112891129011291112921129311294112951129611297112981129911300113011130211303113041130511306113071130811309113101131111312113131131411315113161131711318113191132011321113221132311324113251132611327113281132911330113311133211333113341133511336113371133811339113401134111342113431134411345113461134711348113491135011351113521135311354113551135611357113581135911360113611136211363113641136511366113671136811369113701137111372113731137411375113761137711378113791138011381113821138311384113851138611387113881138911390113911139211393113941139511396113971139811399114001140111402114031140411405114061140711408114091141011411114121141311414114151141611417114181141911420114211142211423114241142511426114271142811429114301143111432114331143411435114361143711438114391144011441114421144311444114451144611447114481144911450114511145211453114541145511456114571145811459114601146111462114631146411465114661146711468114691147011471114721147311474114751147611477114781147911480114811148211483114841148511486114871148811489114901149111492114931149411495114961149711498114991150011501115021150311504115051150611507115081150911510115111151211513115141151511516115171151811519115201152111522115231152411525115261152711528115291153011531115321153311534115351153611537115381153911540115411154211543115441154511546115471154811549115501155111552115531155411555115561155711558115591156011561115621156311564115651156611567115681156911570115711157211573115741157511576115771157811579115801158111582115831158411585115861158711588115891159011591115921159311594115951159611597115981159911600116011160211603116041160511606116071160811609116101161111612116131161411615116161161711618116191162011621116221162311624116251162611627116281162911630116311163211633116341163511636116371163811639116401164111642116431164411645116461164711648116491165011651116521165311654116551165611657116581165911660116611166211663116641166511666116671166811669116701167111672116731167411675116761167711678116791168011681116821168311684116851168611687116881168911690116911169211693116941169511696116971169811699117001170111702117031170411705117061170711708117091171011711117121171311714117151171611717117181171911720117211172211723117241172511726117271172811729117301173111732117331173411735117361173711738117391174011741117421174311744117451174611747117481174911750117511175211753117541175511756117571175811759117601176111762117631176411765117661176711768117691177011771117721177311774117751177611777117781177911780117811178211783117841178511786117871178811789117901179111792117931179411795117961179711798117991180011801118021180311804118051180611807118081180911810118111181211813118141181511816118171181811819118201182111822118231182411825118261182711828118291183011831118321183311834118351183611837118381183911840118411184211843118441184511846118471184811849118501185111852118531185411855118561185711858118591186011861118621186311864118651186611867118681186911870118711187211873118741187511876118771187811879118801188111882118831188411885118861188711888118891189011891118921189311894118951189611897118981189911900119011190211903119041190511906119071190811909119101191111912119131191411915119161191711918119191192011921119221192311924119251192611927119281192911930119311193211933119341193511936119371193811939119401194111942119431194411945119461194711948119491195011951119521195311954119551195611957119581195911960119611196211963119641196511966119671196811969119701197111972119731197411975119761197711978119791198011981119821198311984119851198611987119881198911990119911199211993119941199511996119971199811999120001200112002120031200412005120061200712008120091201012011120121201312014120151201612017120181201912020120211202212023120241202512026120271202812029120301203112032120331203412035120361203712038120391204012041120421204312044120451204612047120481204912050120511205212053120541205512056120571205812059120601206112062120631206412065120661206712068120691207012071120721207312074120751207612077120781207912080120811208212083120841208512086120871208812089120901209112092120931209412095120961209712098120991210012101121021210312104121051210612107121081210912110121111211212113121141211512116121171211812119121201212112122121231212412125121261212712128121291213012131121321213312134121351213612137121381213912140121411214212143121441214512146121471214812149121501215112152121531215412155121561215712158121591216012161121621216312164121651216612167121681216912170121711217212173121741217512176121771217812179121801218112182121831218412185121861218712188121891219012191121921219312194121951219612197121981219912200122011220212203122041220512206122071220812209122101221112212122131221412215122161221712218122191222012221122221222312224122251222612227122281222912230122311223212233122341223512236122371223812239122401224112242122431224412245122461224712248122491225012251122521225312254122551225612257122581225912260122611226212263122641226512266122671226812269122701227112272122731227412275122761227712278122791228012281122821228312284122851228612287122881228912290122911229212293122941229512296122971229812299123001230112302123031230412305123061230712308123091231012311123121231312314123151231612317123181231912320123211232212323123241232512326123271232812329123301233112332123331233412335123361233712338123391234012341123421234312344123451234612347123481234912350123511235212353123541235512356123571235812359123601236112362123631236412365123661236712368123691237012371123721237312374123751237612377123781237912380123811238212383123841238512386123871238812389123901239112392123931239412395123961239712398123991240012401124021240312404124051240612407124081240912410124111241212413124141241512416124171241812419124201242112422124231242412425124261242712428124291243012431124321243312434124351243612437124381243912440124411244212443124441244512446124471244812449124501245112452124531245412455124561245712458124591246012461124621246312464124651246612467124681246912470124711247212473124741247512476124771247812479124801248112482124831248412485124861248712488124891249012491124921249312494124951249612497124981249912500125011250212503125041250512506125071250812509125101251112512125131251412515125161251712518125191252012521125221252312524125251252612527125281252912530125311253212533125341253512536125371253812539125401254112542125431254412545125461254712548125491255012551125521255312554125551255612557125581255912560125611256212563125641256512566125671256812569125701257112572125731257412575125761257712578125791258012581125821258312584125851258612587125881258912590125911259212593125941259512596125971259812599126001260112602126031260412605126061260712608126091261012611126121261312614126151261612617126181261912620126211262212623126241262512626126271262812629126301263112632126331263412635126361263712638126391264012641126421264312644126451264612647126481264912650126511265212653126541265512656126571265812659126601266112662126631266412665126661266712668126691267012671126721267312674126751267612677126781267912680126811268212683126841268512686126871268812689126901269112692126931269412695126961269712698126991270012701127021270312704127051270612707127081270912710127111271212713127141271512716127171271812719127201272112722127231272412725127261272712728127291273012731127321273312734127351273612737127381273912740127411274212743127441274512746127471274812749127501275112752127531275412755127561275712758127591276012761127621276312764127651276612767127681276912770127711277212773127741277512776127771277812779127801278112782127831278412785127861278712788127891279012791127921279312794127951279612797127981279912800128011280212803128041280512806128071280812809128101281112812128131281412815128161281712818128191282012821128221282312824128251282612827128281282912830128311283212833128341283512836128371283812839128401284112842128431284412845128461284712848128491285012851128521285312854128551285612857128581285912860128611286212863128641286512866128671286812869128701287112872128731287412875128761287712878128791288012881128821288312884128851288612887128881288912890128911289212893128941289512896128971289812899129001290112902129031290412905129061290712908129091291012911129121291312914129151291612917129181291912920129211292212923129241292512926129271292812929129301293112932129331293412935129361293712938129391294012941129421294312944129451294612947129481294912950129511295212953129541295512956129571295812959129601296112962129631296412965129661296712968129691297012971129721297312974129751297612977129781297912980129811298212983129841298512986129871298812989129901299112992129931299412995129961299712998129991300013001130021300313004130051300613007130081300913010130111301213013130141301513016130171301813019130201302113022130231302413025130261302713028130291303013031130321303313034130351303613037130381303913040130411304213043130441304513046130471304813049130501305113052130531305413055130561305713058130591306013061130621306313064130651306613067130681306913070130711307213073130741307513076130771307813079130801308113082130831308413085130861308713088130891309013091130921309313094130951309613097130981309913100131011310213103131041310513106131071310813109131101311113112131131311413115131161311713118131191312013121131221312313124131251312613127131281312913130131311313213133131341313513136131371313813139131401314113142131431314413145131461314713148131491315013151131521315313154131551315613157131581315913160131611316213163131641316513166131671316813169131701317113172131731317413175131761317713178131791318013181131821318313184131851318613187131881318913190131911319213193131941319513196131971319813199132001320113202132031320413205132061320713208132091321013211132121321313214132151321613217132181321913220132211322213223132241322513226132271322813229132301323113232132331323413235132361323713238132391324013241132421324313244132451324613247132481324913250132511325213253132541325513256132571325813259132601326113262132631326413265132661326713268132691327013271132721327313274132751327613277132781327913280132811328213283132841328513286132871328813289132901329113292132931329413295132961329713298132991330013301133021330313304133051330613307133081330913310133111331213313133141331513316133171331813319133201332113322133231332413325133261332713328133291333013331133321333313334133351333613337133381333913340133411334213343133441334513346133471334813349133501335113352133531335413355133561335713358133591336013361133621336313364133651336613367133681336913370133711337213373133741337513376133771337813379133801338113382133831338413385133861338713388133891339013391133921339313394133951339613397133981339913400134011340213403134041340513406134071340813409134101341113412134131341413415134161341713418134191342013421134221342313424134251342613427134281342913430134311343213433134341343513436134371343813439134401344113442134431344413445134461344713448134491345013451134521345313454134551345613457134581345913460134611346213463134641346513466134671346813469134701347113472134731347413475134761347713478134791348013481134821348313484134851348613487134881348913490134911349213493134941349513496134971349813499135001350113502135031350413505135061350713508135091351013511135121351313514135151351613517135181351913520135211352213523135241352513526135271352813529135301353113532135331353413535135361353713538135391354013541135421354313544135451354613547135481354913550135511355213553135541355513556135571355813559135601356113562135631356413565135661356713568135691357013571135721357313574135751357613577135781357913580135811358213583135841358513586135871358813589135901359113592135931359413595135961359713598135991360013601136021360313604136051360613607136081360913610136111361213613136141361513616136171361813619136201362113622136231362413625136261362713628136291363013631136321363313634136351363613637136381363913640136411364213643136441364513646136471364813649136501365113652136531365413655136561365713658136591366013661136621366313664136651366613667136681366913670136711367213673136741367513676136771367813679136801368113682136831368413685136861368713688136891369013691136921369313694136951369613697136981369913700137011370213703137041370513706137071370813709137101371113712137131371413715137161371713718137191372013721137221372313724137251372613727137281372913730137311373213733137341373513736137371373813739137401374113742137431374413745137461374713748137491375013751137521375313754137551375613757137581375913760137611376213763137641376513766137671376813769137701377113772137731377413775137761377713778137791378013781137821378313784137851378613787137881378913790137911379213793137941379513796137971379813799138001380113802138031380413805138061380713808138091381013811138121381313814138151381613817138181381913820138211382213823138241382513826138271382813829138301383113832138331383413835138361383713838138391384013841138421384313844138451384613847138481384913850138511385213853138541385513856138571385813859138601386113862138631386413865138661386713868138691387013871138721387313874138751387613877138781387913880138811388213883138841388513886138871388813889138901389113892138931389413895138961389713898138991390013901139021390313904139051390613907139081390913910139111391213913139141391513916139171391813919139201392113922139231392413925139261392713928139291393013931139321393313934139351393613937139381393913940139411394213943139441394513946139471394813949139501395113952139531395413955139561395713958139591396013961139621396313964139651396613967139681396913970139711397213973139741397513976139771397813979139801398113982139831398413985139861398713988139891399013991139921399313994139951399613997139981399914000140011400214003140041400514006140071400814009140101401114012140131401414015140161401714018140191402014021140221402314024140251402614027140281402914030140311403214033140341403514036140371403814039140401404114042140431404414045140461404714048140491405014051140521405314054140551405614057140581405914060140611406214063140641406514066140671406814069140701407114072140731407414075140761407714078140791408014081140821408314084140851408614087140881408914090140911409214093140941409514096140971409814099141001410114102141031410414105141061410714108141091411014111141121411314114141151411614117141181411914120141211412214123141241412514126141271412814129141301413114132141331413414135141361413714138141391414014141141421414314144141451414614147141481414914150141511415214153141541415514156141571415814159141601416114162141631416414165141661416714168141691417014171141721417314174141751417614177141781417914180141811418214183141841418514186141871418814189141901419114192141931419414195141961419714198141991420014201142021420314204142051420614207142081420914210142111421214213142141421514216142171421814219142201422114222142231422414225142261422714228142291423014231142321423314234142351423614237142381423914240142411424214243142441424514246142471424814249142501425114252142531425414255142561425714258142591426014261142621426314264142651426614267142681426914270142711427214273142741427514276142771427814279142801428114282142831428414285142861428714288142891429014291142921429314294142951429614297142981429914300143011430214303143041430514306143071430814309143101431114312143131431414315143161431714318143191432014321143221432314324143251432614327143281432914330143311433214333143341433514336143371433814339143401434114342143431434414345143461434714348143491435014351143521435314354143551435614357143581435914360143611436214363143641436514366143671436814369143701437114372143731437414375143761437714378143791438014381143821438314384143851438614387143881438914390143911439214393143941439514396143971439814399144001440114402144031440414405144061440714408144091441014411144121441314414144151441614417144181441914420144211442214423144241442514426144271442814429144301443114432144331443414435144361443714438144391444014441144421444314444144451444614447144481444914450144511445214453144541445514456144571445814459144601446114462144631446414465144661446714468144691447014471144721447314474144751447614477144781447914480144811448214483144841448514486144871448814489144901449114492144931449414495144961449714498144991450014501145021450314504145051450614507145081450914510145111451214513145141451514516145171451814519145201452114522145231452414525145261452714528145291453014531145321453314534145351453614537145381453914540145411454214543145441454514546145471454814549145501455114552145531455414555145561455714558145591456014561145621456314564145651456614567145681456914570145711457214573145741457514576145771457814579145801458114582145831458414585145861458714588145891459014591145921459314594145951459614597145981459914600146011460214603146041460514606146071460814609146101461114612146131461414615146161461714618146191462014621146221462314624146251462614627146281462914630146311463214633146341463514636146371463814639146401464114642146431464414645146461464714648146491465014651146521465314654146551465614657146581465914660146611466214663146641466514666146671466814669146701467114672146731467414675146761467714678146791468014681146821468314684146851468614687146881468914690146911469214693146941469514696146971469814699147001470114702147031470414705147061470714708147091471014711147121471314714147151471614717147181471914720147211472214723147241472514726147271472814729147301473114732147331473414735147361473714738147391474014741147421474314744147451474614747147481474914750147511475214753147541475514756147571475814759147601476114762147631476414765147661476714768147691477014771147721477314774147751477614777147781477914780147811478214783147841478514786147871478814789147901479114792147931479414795147961479714798147991480014801148021480314804148051480614807148081480914810148111481214813148141481514816148171481814819148201482114822148231482414825148261482714828148291483014831148321483314834148351483614837148381483914840148411484214843148441484514846148471484814849148501485114852148531485414855148561485714858148591486014861148621486314864148651486614867148681486914870148711487214873148741487514876148771487814879148801488114882148831488414885148861488714888148891489014891148921489314894148951489614897148981489914900149011490214903149041490514906149071490814909149101491114912149131491414915149161491714918149191492014921149221492314924149251492614927149281492914930149311493214933149341493514936149371493814939149401494114942149431494414945149461494714948149491495014951149521495314954149551495614957149581495914960149611496214963149641496514966149671496814969149701497114972149731497414975149761497714978149791498014981149821498314984149851498614987149881498914990149911499214993149941499514996149971499814999150001500115002150031500415005150061500715008150091501015011150121501315014150151501615017150181501915020150211502215023150241502515026150271502815029150301503115032150331503415035150361503715038150391504015041150421504315044150451504615047150481504915050150511505215053150541505515056150571505815059150601506115062150631506415065150661506715068150691507015071150721507315074150751507615077150781507915080150811508215083150841508515086150871508815089150901509115092150931509415095150961509715098150991510015101151021510315104151051510615107151081510915110151111511215113151141511515116151171511815119151201512115122151231512415125151261512715128151291513015131151321513315134151351513615137151381513915140151411514215143151441514515146151471514815149151501515115152151531515415155151561515715158151591516015161151621516315164151651516615167151681516915170151711517215173151741517515176151771517815179151801518115182151831518415185151861518715188151891519015191151921519315194151951519615197151981519915200152011520215203152041520515206152071520815209152101521115212152131521415215152161521715218152191522015221152221522315224152251522615227152281522915230152311523215233152341523515236152371523815239152401524115242152431524415245152461524715248152491525015251152521525315254152551525615257152581525915260152611526215263152641526515266152671526815269152701527115272152731527415275152761527715278152791528015281152821528315284152851528615287152881528915290152911529215293152941529515296152971529815299153001530115302153031530415305153061530715308153091531015311153121531315314153151531615317153181531915320153211532215323153241532515326153271532815329153301533115332153331533415335153361533715338153391534015341153421534315344153451534615347153481534915350153511535215353153541535515356153571535815359153601536115362153631536415365153661536715368153691537015371153721537315374153751537615377153781537915380153811538215383153841538515386153871538815389153901539115392153931539415395153961539715398153991540015401154021540315404154051540615407154081540915410154111541215413154141541515416154171541815419154201542115422154231542415425154261542715428154291543015431154321543315434154351543615437154381543915440154411544215443154441544515446154471544815449154501545115452154531545415455154561545715458154591546015461154621546315464154651546615467154681546915470154711547215473154741547515476154771547815479154801548115482154831548415485154861548715488154891549015491154921549315494154951549615497154981549915500155011550215503155041550515506155071550815509155101551115512155131551415515155161551715518155191552015521155221552315524155251552615527155281552915530155311553215533155341553515536155371553815539155401554115542155431554415545155461554715548155491555015551155521555315554155551555615557155581555915560155611556215563155641556515566155671556815569155701557115572155731557415575155761557715578155791558015581155821558315584155851558615587155881558915590155911559215593155941559515596155971559815599156001560115602156031560415605156061560715608156091561015611156121561315614156151561615617156181561915620156211562215623156241562515626156271562815629156301563115632156331563415635156361563715638156391564015641156421564315644156451564615647156481564915650156511565215653156541565515656156571565815659156601566115662156631566415665156661566715668156691567015671156721567315674156751567615677156781567915680156811568215683156841568515686156871568815689156901569115692156931569415695156961569715698156991570015701157021570315704157051570615707157081570915710157111571215713157141571515716157171571815719157201572115722157231572415725157261572715728157291573015731157321573315734157351573615737157381573915740157411574215743157441574515746157471574815749157501575115752157531575415755157561575715758157591576015761157621576315764157651576615767157681576915770157711577215773157741577515776157771577815779157801578115782157831578415785157861578715788157891579015791157921579315794157951579615797157981579915800158011580215803158041580515806158071580815809158101581115812158131581415815158161581715818158191582015821158221582315824158251582615827158281582915830158311583215833158341583515836158371583815839158401584115842158431584415845158461584715848158491585015851158521585315854158551585615857158581585915860158611586215863158641586515866158671586815869158701587115872158731587415875158761587715878158791588015881158821588315884158851588615887158881588915890158911589215893158941589515896158971589815899159001590115902159031590415905159061590715908159091591015911159121591315914159151591615917159181591915920159211592215923159241592515926159271592815929159301593115932159331593415935159361593715938159391594015941159421594315944159451594615947159481594915950159511595215953159541595515956159571595815959159601596115962159631596415965159661596715968159691597015971159721597315974159751597615977159781597915980159811598215983159841598515986159871598815989159901599115992159931599415995159961599715998159991600016001160021600316004160051600616007160081600916010160111601216013160141601516016160171601816019160201602116022160231602416025160261602716028160291603016031160321603316034160351603616037160381603916040160411604216043160441604516046160471604816049160501605116052160531605416055160561605716058160591606016061160621606316064160651606616067160681606916070160711607216073160741607516076160771607816079160801608116082160831608416085160861608716088160891609016091160921609316094160951609616097160981609916100161011610216103161041610516106161071610816109161101611116112161131611416115161161611716118161191612016121161221612316124161251612616127161281612916130161311613216133161341613516136161371613816139161401614116142161431614416145161461614716148161491615016151161521615316154161551615616157161581615916160161611616216163161641616516166161671616816169161701617116172161731617416175161761617716178161791618016181161821618316184161851618616187161881618916190161911619216193161941619516196161971619816199162001620116202162031620416205162061620716208162091621016211162121621316214162151621616217162181621916220162211622216223162241622516226162271622816229162301623116232162331623416235162361623716238162391624016241162421624316244162451624616247162481624916250162511625216253162541625516256162571625816259162601626116262162631626416265162661626716268162691627016271162721627316274162751627616277162781627916280162811628216283162841628516286162871628816289162901629116292162931629416295162961629716298162991630016301163021630316304163051630616307163081630916310163111631216313163141631516316163171631816319163201632116322163231632416325163261632716328163291633016331163321633316334163351633616337163381633916340163411634216343163441634516346163471634816349163501635116352163531635416355163561635716358163591636016361163621636316364163651636616367163681636916370163711637216373163741637516376163771637816379163801638116382163831638416385163861638716388163891639016391163921639316394163951639616397163981639916400164011640216403164041640516406164071640816409164101641116412164131641416415164161641716418164191642016421164221642316424164251642616427164281642916430164311643216433164341643516436164371643816439164401644116442164431644416445164461644716448164491645016451164521645316454164551645616457164581645916460164611646216463164641646516466164671646816469164701647116472164731647416475164761647716478164791648016481164821648316484164851648616487164881648916490164911649216493164941649516496164971649816499165001650116502165031650416505165061650716508165091651016511165121651316514165151651616517165181651916520165211652216523165241652516526165271652816529165301653116532165331653416535165361653716538165391654016541165421654316544165451654616547165481654916550165511655216553165541655516556165571655816559165601656116562165631656416565165661656716568165691657016571165721657316574165751657616577165781657916580165811658216583165841658516586165871658816589165901659116592165931659416595165961659716598165991660016601166021660316604166051660616607166081660916610166111661216613166141661516616166171661816619166201662116622166231662416625166261662716628166291663016631166321663316634166351663616637166381663916640166411664216643166441664516646166471664816649166501665116652166531665416655166561665716658166591666016661166621666316664166651666616667166681666916670166711667216673166741667516676166771667816679166801668116682166831668416685166861668716688166891669016691166921669316694166951669616697166981669916700167011670216703167041670516706167071670816709167101671116712167131671416715167161671716718167191672016721167221672316724167251672616727167281672916730167311673216733167341673516736167371673816739167401674116742167431674416745167461674716748167491675016751167521675316754167551675616757167581675916760167611676216763167641676516766167671676816769167701677116772167731677416775167761677716778167791678016781167821678316784167851678616787167881678916790167911679216793167941679516796167971679816799168001680116802168031680416805168061680716808168091681016811168121681316814168151681616817 |
- "use strict";
- const _export_sfc = (sfc, props2) => {
- const target = sfc.__vccOpts || sfc;
- for (const [key, val] of props2) {
- target[key] = val;
- }
- return target;
- };
- function makeMap(str, expectsLowerCase) {
- const map2 = /* @__PURE__ */ Object.create(null);
- const list = str.split(",");
- for (let i = 0; i < list.length; i++) {
- map2[list[i]] = true;
- }
- return expectsLowerCase ? (val) => !!map2[val.toLowerCase()] : (val) => !!map2[val];
- }
- function normalizeStyle(value2) {
- if (isArray$2(value2)) {
- const res = {};
- for (let i = 0; i < value2.length; i++) {
- const item = value2[i];
- const normalized = isString$1(item) ? parseStringStyle(item) : normalizeStyle(item);
- if (normalized) {
- for (const key in normalized) {
- res[key] = normalized[key];
- }
- }
- }
- return res;
- } else if (isString$1(value2)) {
- return value2;
- } else if (isObject$2(value2)) {
- return value2;
- }
- }
- const listDelimiterRE = /;(?![^(]*\))/g;
- const propertyDelimiterRE = /:([^]+)/;
- const styleCommentRE = /\/\*.*?\*\//gs;
- function parseStringStyle(cssText) {
- const ret = {};
- cssText.replace(styleCommentRE, "").split(listDelimiterRE).forEach((item) => {
- if (item) {
- const tmp = item.split(propertyDelimiterRE);
- tmp.length > 1 && (ret[tmp[0].trim()] = tmp[1].trim());
- }
- });
- return ret;
- }
- function normalizeClass(value2) {
- let res = "";
- if (isString$1(value2)) {
- res = value2;
- } else if (isArray$2(value2)) {
- for (let i = 0; i < value2.length; i++) {
- const normalized = normalizeClass(value2[i]);
- if (normalized) {
- res += normalized + " ";
- }
- }
- } else if (isObject$2(value2)) {
- for (const name in value2) {
- if (value2[name]) {
- res += name + " ";
- }
- }
- }
- return res.trim();
- }
- const toDisplayString = (val) => {
- return isString$1(val) ? val : val == null ? "" : isArray$2(val) || isObject$2(val) && (val.toString === objectToString || !isFunction$1(val.toString)) ? JSON.stringify(val, replacer, 2) : String(val);
- };
- const replacer = (_key, val) => {
- if (val && val.__v_isRef) {
- return replacer(_key, val.value);
- } else if (isMap(val)) {
- return {
- [`Map(${val.size})`]: [...val.entries()].reduce((entries, [key, val2]) => {
- entries[`${key} =>`] = val2;
- return entries;
- }, {})
- };
- } else if (isSet(val)) {
- return {
- [`Set(${val.size})`]: [...val.values()]
- };
- } else if (isObject$2(val) && !isArray$2(val) && !isPlainObject$1(val)) {
- return String(val);
- }
- return val;
- };
- const EMPTY_OBJ = Object.freeze({});
- const EMPTY_ARR = Object.freeze([]);
- const NOOP = () => {
- };
- const NO = () => false;
- const onRE = /^on[^a-z]/;
- const isOn = (key) => onRE.test(key);
- const isModelListener = (key) => key.startsWith("onUpdate:");
- const extend$1 = Object.assign;
- const remove = (arr, el) => {
- const i = arr.indexOf(el);
- if (i > -1) {
- arr.splice(i, 1);
- }
- };
- const hasOwnProperty$1 = Object.prototype.hasOwnProperty;
- const hasOwn = (val, key) => hasOwnProperty$1.call(val, key);
- const isArray$2 = Array.isArray;
- const isMap = (val) => toTypeString(val) === "[object Map]";
- const isSet = (val) => toTypeString(val) === "[object Set]";
- const isFunction$1 = (val) => typeof val === "function";
- const isString$1 = (val) => typeof val === "string";
- const isSymbol = (val) => typeof val === "symbol";
- const isObject$2 = (val) => val !== null && typeof val === "object";
- const isPromise = (val) => {
- return isObject$2(val) && isFunction$1(val.then) && isFunction$1(val.catch);
- };
- const objectToString = Object.prototype.toString;
- const toTypeString = (value2) => objectToString.call(value2);
- const toRawType = (value2) => {
- return toTypeString(value2).slice(8, -1);
- };
- const isPlainObject$1 = (val) => toTypeString(val) === "[object Object]";
- const isIntegerKey = (key) => isString$1(key) && key !== "NaN" && key[0] !== "-" && "" + parseInt(key, 10) === key;
- const isReservedProp = /* @__PURE__ */ makeMap(
- // the leading comma is intentional so empty string "" is also included
- ",key,ref,ref_for,ref_key,onVnodeBeforeMount,onVnodeMounted,onVnodeBeforeUpdate,onVnodeUpdated,onVnodeBeforeUnmount,onVnodeUnmounted"
- );
- const isBuiltInDirective = /* @__PURE__ */ makeMap("bind,cloak,else-if,else,for,html,if,model,on,once,pre,show,slot,text,memo");
- const cacheStringFunction = (fn) => {
- const cache = /* @__PURE__ */ Object.create(null);
- return (str) => {
- const hit = cache[str];
- return hit || (cache[str] = fn(str));
- };
- };
- const camelizeRE = /-(\w)/g;
- const camelize = cacheStringFunction((str) => {
- return str.replace(camelizeRE, (_, c) => c ? c.toUpperCase() : "");
- });
- const hyphenateRE = /\B([A-Z])/g;
- const hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, "-$1").toLowerCase());
- const capitalize = cacheStringFunction((str) => str.charAt(0).toUpperCase() + str.slice(1));
- const toHandlerKey = cacheStringFunction((str) => str ? `on${capitalize(str)}` : ``);
- const hasChanged = (value2, oldValue) => !Object.is(value2, oldValue);
- const invokeArrayFns$1 = (fns, arg) => {
- for (let i = 0; i < fns.length; i++) {
- fns[i](arg);
- }
- };
- const def = (obj, key, value2) => {
- Object.defineProperty(obj, key, {
- configurable: true,
- enumerable: false,
- value: value2
- });
- };
- const looseToNumber = (val) => {
- const n2 = parseFloat(val);
- return isNaN(n2) ? val : n2;
- };
- const LINEFEED = "\n";
- const SLOT_DEFAULT_NAME = "d";
- const ON_SHOW = "onShow";
- const ON_HIDE = "onHide";
- const ON_LAUNCH = "onLaunch";
- const ON_ERROR = "onError";
- const ON_THEME_CHANGE = "onThemeChange";
- const ON_PAGE_NOT_FOUND = "onPageNotFound";
- const ON_UNHANDLE_REJECTION = "onUnhandledRejection";
- const ON_LOAD = "onLoad";
- const ON_READY = "onReady";
- const ON_UNLOAD = "onUnload";
- const ON_INIT = "onInit";
- const ON_SAVE_EXIT_STATE = "onSaveExitState";
- const ON_RESIZE = "onResize";
- const ON_BACK_PRESS = "onBackPress";
- const ON_PAGE_SCROLL = "onPageScroll";
- const ON_TAB_ITEM_TAP = "onTabItemTap";
- const ON_REACH_BOTTOM = "onReachBottom";
- const ON_PULL_DOWN_REFRESH = "onPullDownRefresh";
- const ON_SHARE_TIMELINE = "onShareTimeline";
- const ON_ADD_TO_FAVORITES = "onAddToFavorites";
- const ON_SHARE_APP_MESSAGE = "onShareAppMessage";
- const ON_NAVIGATION_BAR_BUTTON_TAP = "onNavigationBarButtonTap";
- const ON_NAVIGATION_BAR_SEARCH_INPUT_CLICKED = "onNavigationBarSearchInputClicked";
- const ON_NAVIGATION_BAR_SEARCH_INPUT_CHANGED = "onNavigationBarSearchInputChanged";
- const ON_NAVIGATION_BAR_SEARCH_INPUT_CONFIRMED = "onNavigationBarSearchInputConfirmed";
- const ON_NAVIGATION_BAR_SEARCH_INPUT_FOCUS_CHANGED = "onNavigationBarSearchInputFocusChanged";
- const customizeRE = /:/g;
- function customizeEvent(str) {
- return camelize(str.replace(customizeRE, "-"));
- }
- function hasLeadingSlash(str) {
- return str.indexOf("/") === 0;
- }
- function addLeadingSlash(str) {
- return hasLeadingSlash(str) ? str : "/" + str;
- }
- const invokeArrayFns = (fns, arg) => {
- let ret;
- for (let i = 0; i < fns.length; i++) {
- ret = fns[i](arg);
- }
- return ret;
- };
- function once(fn, ctx = null) {
- let res;
- return (...args) => {
- if (fn) {
- res = fn.apply(ctx, args);
- fn = null;
- }
- return res;
- };
- }
- function getValueByDataPath(obj, path) {
- if (!isString$1(path)) {
- return;
- }
- path = path.replace(/\[(\d+)\]/g, ".$1");
- const parts = path.split(".");
- let key = parts[0];
- if (!obj) {
- obj = {};
- }
- if (parts.length === 1) {
- return obj[key];
- }
- return getValueByDataPath(obj[key], parts.slice(1).join("."));
- }
- function sortObject(obj) {
- let sortObj = {};
- if (isPlainObject$1(obj)) {
- Object.keys(obj).sort().forEach((key) => {
- const _key = key;
- sortObj[_key] = obj[_key];
- });
- }
- return !Object.keys(sortObj) ? obj : sortObj;
- }
- const encode$1 = encodeURIComponent;
- function stringifyQuery(obj, encodeStr = encode$1) {
- const res = obj ? Object.keys(obj).map((key) => {
- let val = obj[key];
- if (typeof val === void 0 || val === null) {
- val = "";
- } else if (isPlainObject$1(val)) {
- val = JSON.stringify(val);
- }
- return encodeStr(key) + "=" + encodeStr(val);
- }).filter((x) => x.length > 0).join("&") : null;
- return res ? `?${res}` : "";
- }
- const PAGE_HOOKS = [
- ON_INIT,
- ON_LOAD,
- ON_SHOW,
- ON_HIDE,
- ON_UNLOAD,
- ON_BACK_PRESS,
- ON_PAGE_SCROLL,
- ON_TAB_ITEM_TAP,
- ON_REACH_BOTTOM,
- ON_PULL_DOWN_REFRESH,
- ON_SHARE_TIMELINE,
- ON_SHARE_APP_MESSAGE,
- ON_ADD_TO_FAVORITES,
- ON_SAVE_EXIT_STATE,
- ON_NAVIGATION_BAR_BUTTON_TAP,
- ON_NAVIGATION_BAR_SEARCH_INPUT_CLICKED,
- ON_NAVIGATION_BAR_SEARCH_INPUT_CHANGED,
- ON_NAVIGATION_BAR_SEARCH_INPUT_CONFIRMED,
- ON_NAVIGATION_BAR_SEARCH_INPUT_FOCUS_CHANGED
- ];
- function isRootHook(name) {
- return PAGE_HOOKS.indexOf(name) > -1;
- }
- const UniLifecycleHooks = [
- ON_SHOW,
- ON_HIDE,
- ON_LAUNCH,
- ON_ERROR,
- ON_THEME_CHANGE,
- ON_PAGE_NOT_FOUND,
- ON_UNHANDLE_REJECTION,
- ON_INIT,
- ON_LOAD,
- ON_READY,
- ON_UNLOAD,
- ON_RESIZE,
- ON_BACK_PRESS,
- ON_PAGE_SCROLL,
- ON_TAB_ITEM_TAP,
- ON_REACH_BOTTOM,
- ON_PULL_DOWN_REFRESH,
- ON_SHARE_TIMELINE,
- ON_ADD_TO_FAVORITES,
- ON_SHARE_APP_MESSAGE,
- ON_SAVE_EXIT_STATE,
- ON_NAVIGATION_BAR_BUTTON_TAP,
- ON_NAVIGATION_BAR_SEARCH_INPUT_CLICKED,
- ON_NAVIGATION_BAR_SEARCH_INPUT_CHANGED,
- ON_NAVIGATION_BAR_SEARCH_INPUT_CONFIRMED,
- ON_NAVIGATION_BAR_SEARCH_INPUT_FOCUS_CHANGED
- ];
- const MINI_PROGRAM_PAGE_RUNTIME_HOOKS = /* @__PURE__ */ (() => {
- return {
- onPageScroll: 1,
- onShareAppMessage: 1 << 1,
- onShareTimeline: 1 << 2
- };
- })();
- function isUniLifecycleHook(name, value2, checkType = true) {
- if (checkType && !isFunction$1(value2)) {
- return false;
- }
- if (UniLifecycleHooks.indexOf(name) > -1) {
- return true;
- } else if (name.indexOf("on") === 0) {
- return true;
- }
- return false;
- }
- let vueApp;
- const createVueAppHooks = [];
- function onCreateVueApp(hook) {
- if (vueApp) {
- return hook(vueApp);
- }
- createVueAppHooks.push(hook);
- }
- function invokeCreateVueAppHook(app) {
- vueApp = app;
- createVueAppHooks.forEach((hook) => hook(app));
- }
- const invokeCreateErrorHandler = once((app, createErrorHandler2) => {
- if (isFunction$1(app._component.onError)) {
- return createErrorHandler2(app);
- }
- });
- const E = function() {
- };
- E.prototype = {
- on: function(name, callback, ctx) {
- var e2 = this.e || (this.e = {});
- (e2[name] || (e2[name] = [])).push({
- fn: callback,
- ctx
- });
- return this;
- },
- once: function(name, callback, ctx) {
- var self = this;
- function listener() {
- self.off(name, listener);
- callback.apply(ctx, arguments);
- }
- listener._ = callback;
- return this.on(name, listener, ctx);
- },
- emit: function(name) {
- var data = [].slice.call(arguments, 1);
- var evtArr = ((this.e || (this.e = {}))[name] || []).slice();
- var i = 0;
- var len = evtArr.length;
- for (i; i < len; i++) {
- evtArr[i].fn.apply(evtArr[i].ctx, data);
- }
- return this;
- },
- off: function(name, callback) {
- var e2 = this.e || (this.e = {});
- var evts = e2[name];
- var liveEvents = [];
- if (evts && callback) {
- for (var i = 0, len = evts.length; i < len; i++) {
- if (evts[i].fn !== callback && evts[i].fn._ !== callback)
- liveEvents.push(evts[i]);
- }
- }
- liveEvents.length ? e2[name] = liveEvents : delete e2[name];
- return this;
- }
- };
- var E$1 = E;
- const LOCALE_ZH_HANS = "zh-Hans";
- const LOCALE_ZH_HANT = "zh-Hant";
- const LOCALE_EN = "en";
- const LOCALE_FR = "fr";
- const LOCALE_ES = "es";
- function include(str, parts) {
- return !!parts.find((part) => str.indexOf(part) !== -1);
- }
- function startsWith(str, parts) {
- return parts.find((part) => str.indexOf(part) === 0);
- }
- function normalizeLocale$1(locale2, messages3) {
- if (!locale2) {
- return;
- }
- locale2 = locale2.trim().replace(/_/g, "-");
- if (messages3 && messages3[locale2]) {
- return locale2;
- }
- locale2 = locale2.toLowerCase();
- if (locale2 === "chinese") {
- return LOCALE_ZH_HANS;
- }
- if (locale2.indexOf("zh") === 0) {
- if (locale2.indexOf("-hans") > -1) {
- return LOCALE_ZH_HANS;
- }
- if (locale2.indexOf("-hant") > -1) {
- return LOCALE_ZH_HANT;
- }
- if (include(locale2, ["-tw", "-hk", "-mo", "-cht"])) {
- return LOCALE_ZH_HANT;
- }
- return LOCALE_ZH_HANS;
- }
- let locales2 = [LOCALE_EN, LOCALE_FR, LOCALE_ES];
- if (messages3 && Object.keys(messages3).length > 0) {
- locales2 = Object.keys(messages3);
- }
- const lang2 = startsWith(locale2, locales2);
- if (lang2) {
- return lang2;
- }
- }
- function getBaseSystemInfo() {
- return wx.getSystemInfoSync();
- }
- function validateProtocolFail(name, msg) {
- console.warn(`${name}: ${msg}`);
- }
- function validateProtocol(name, data, protocol, onFail) {
- if (!onFail) {
- onFail = validateProtocolFail;
- }
- for (const key in protocol) {
- const errMsg = validateProp$1(key, data[key], protocol[key], !hasOwn(data, key));
- if (isString$1(errMsg)) {
- onFail(name, errMsg);
- }
- }
- }
- function validateProtocols(name, args, protocol, onFail) {
- if (!protocol) {
- return;
- }
- if (!isArray$2(protocol)) {
- return validateProtocol(name, args[0] || /* @__PURE__ */ Object.create(null), protocol, onFail);
- }
- const len = protocol.length;
- const argsLen = args.length;
- for (let i = 0; i < len; i++) {
- const opts = protocol[i];
- const data = /* @__PURE__ */ Object.create(null);
- if (argsLen > i) {
- data[opts.name] = args[i];
- }
- validateProtocol(name, data, { [opts.name]: opts }, onFail);
- }
- }
- function validateProp$1(name, value2, prop, isAbsent) {
- if (!isPlainObject$1(prop)) {
- prop = { type: prop };
- }
- const { type: type2, required: required2, validator } = prop;
- if (required2 && isAbsent) {
- return 'Missing required args: "' + name + '"';
- }
- if (value2 == null && !required2) {
- return;
- }
- if (type2 != null) {
- let isValid2 = false;
- const types2 = isArray$2(type2) ? type2 : [type2];
- const expectedTypes = [];
- for (let i = 0; i < types2.length && !isValid2; i++) {
- const { valid, expectedType } = assertType$1(value2, types2[i]);
- expectedTypes.push(expectedType || "");
- isValid2 = valid;
- }
- if (!isValid2) {
- return getInvalidTypeMessage$1(name, value2, expectedTypes);
- }
- }
- if (validator) {
- return validator(value2);
- }
- }
- const isSimpleType$1 = /* @__PURE__ */ makeMap("String,Number,Boolean,Function,Symbol");
- function assertType$1(value2, type2) {
- let valid;
- const expectedType = getType$1(type2);
- if (isSimpleType$1(expectedType)) {
- const t2 = typeof value2;
- valid = t2 === expectedType.toLowerCase();
- if (!valid && t2 === "object") {
- valid = value2 instanceof type2;
- }
- } else if (expectedType === "Object") {
- valid = isObject$2(value2);
- } else if (expectedType === "Array") {
- valid = isArray$2(value2);
- } else {
- {
- valid = value2 instanceof type2;
- }
- }
- return {
- valid,
- expectedType
- };
- }
- function getInvalidTypeMessage$1(name, value2, expectedTypes) {
- let message = `Invalid args: type check failed for args "${name}". Expected ${expectedTypes.map(capitalize).join(", ")}`;
- const expectedType = expectedTypes[0];
- const receivedType = toRawType(value2);
- const expectedValue = styleValue$1(value2, expectedType);
- const receivedValue = styleValue$1(value2, receivedType);
- if (expectedTypes.length === 1 && isExplicable$1(expectedType) && !isBoolean$1(expectedType, receivedType)) {
- message += ` with value ${expectedValue}`;
- }
- message += `, got ${receivedType} `;
- if (isExplicable$1(receivedType)) {
- message += `with value ${receivedValue}.`;
- }
- return message;
- }
- function getType$1(ctor) {
- const match = ctor && ctor.toString().match(/^\s*function (\w+)/);
- return match ? match[1] : "";
- }
- function styleValue$1(value2, type2) {
- if (type2 === "String") {
- return `"${value2}"`;
- } else if (type2 === "Number") {
- return `${Number(value2)}`;
- } else {
- return `${value2}`;
- }
- }
- function isExplicable$1(type2) {
- const explicitTypes = ["string", "number", "boolean"];
- return explicitTypes.some((elem) => type2.toLowerCase() === elem);
- }
- function isBoolean$1(...args) {
- return args.some((elem) => elem.toLowerCase() === "boolean");
- }
- function tryCatch(fn) {
- return function() {
- try {
- return fn.apply(fn, arguments);
- } catch (e2) {
- console.error(e2);
- }
- };
- }
- let invokeCallbackId = 1;
- const invokeCallbacks = {};
- function addInvokeCallback(id, name, callback, keepAlive = false) {
- invokeCallbacks[id] = {
- name,
- keepAlive,
- callback
- };
- return id;
- }
- function invokeCallback(id, res, extras) {
- if (typeof id === "number") {
- const opts = invokeCallbacks[id];
- if (opts) {
- if (!opts.keepAlive) {
- delete invokeCallbacks[id];
- }
- return opts.callback(res, extras);
- }
- }
- return res;
- }
- const API_SUCCESS = "success";
- const API_FAIL = "fail";
- const API_COMPLETE = "complete";
- function getApiCallbacks(args) {
- const apiCallbacks = {};
- for (const name in args) {
- const fn = args[name];
- if (isFunction$1(fn)) {
- apiCallbacks[name] = tryCatch(fn);
- delete args[name];
- }
- }
- return apiCallbacks;
- }
- function normalizeErrMsg$1(errMsg, name) {
- if (!errMsg || errMsg.indexOf(":fail") === -1) {
- return name + ":ok";
- }
- return name + errMsg.substring(errMsg.indexOf(":fail"));
- }
- function createAsyncApiCallback(name, args = {}, { beforeAll, beforeSuccess } = {}) {
- if (!isPlainObject$1(args)) {
- args = {};
- }
- const { success, fail, complete } = getApiCallbacks(args);
- const hasSuccess = isFunction$1(success);
- const hasFail = isFunction$1(fail);
- const hasComplete = isFunction$1(complete);
- const callbackId = invokeCallbackId++;
- addInvokeCallback(callbackId, name, (res) => {
- res = res || {};
- res.errMsg = normalizeErrMsg$1(res.errMsg, name);
- isFunction$1(beforeAll) && beforeAll(res);
- if (res.errMsg === name + ":ok") {
- isFunction$1(beforeSuccess) && beforeSuccess(res, args);
- hasSuccess && success(res);
- } else {
- hasFail && fail(res);
- }
- hasComplete && complete(res);
- });
- return callbackId;
- }
- const HOOK_SUCCESS = "success";
- const HOOK_FAIL = "fail";
- const HOOK_COMPLETE = "complete";
- const globalInterceptors = {};
- const scopedInterceptors = {};
- function wrapperHook(hook, params) {
- return function(data) {
- return hook(data, params) || data;
- };
- }
- function queue$1(hooks2, data, params) {
- let promise2 = false;
- for (let i = 0; i < hooks2.length; i++) {
- const hook = hooks2[i];
- if (promise2) {
- promise2 = Promise.resolve(wrapperHook(hook, params));
- } else {
- const res = hook(data, params);
- if (isPromise(res)) {
- promise2 = Promise.resolve(res);
- }
- if (res === false) {
- return {
- then() {
- },
- catch() {
- }
- };
- }
- }
- }
- return promise2 || {
- then(callback) {
- return callback(data);
- },
- catch() {
- }
- };
- }
- function wrapperOptions(interceptors2, options = {}) {
- [HOOK_SUCCESS, HOOK_FAIL, HOOK_COMPLETE].forEach((name) => {
- const hooks2 = interceptors2[name];
- if (!isArray$2(hooks2)) {
- return;
- }
- const oldCallback = options[name];
- options[name] = function callbackInterceptor(res) {
- queue$1(hooks2, res, options).then((res2) => {
- return isFunction$1(oldCallback) && oldCallback(res2) || res2;
- });
- };
- });
- return options;
- }
- function wrapperReturnValue(method3, returnValue) {
- const returnValueHooks = [];
- if (isArray$2(globalInterceptors.returnValue)) {
- returnValueHooks.push(...globalInterceptors.returnValue);
- }
- const interceptor = scopedInterceptors[method3];
- if (interceptor && isArray$2(interceptor.returnValue)) {
- returnValueHooks.push(...interceptor.returnValue);
- }
- returnValueHooks.forEach((hook) => {
- returnValue = hook(returnValue) || returnValue;
- });
- return returnValue;
- }
- function getApiInterceptorHooks(method3) {
- const interceptor = /* @__PURE__ */ Object.create(null);
- Object.keys(globalInterceptors).forEach((hook) => {
- if (hook !== "returnValue") {
- interceptor[hook] = globalInterceptors[hook].slice();
- }
- });
- const scopedInterceptor = scopedInterceptors[method3];
- if (scopedInterceptor) {
- Object.keys(scopedInterceptor).forEach((hook) => {
- if (hook !== "returnValue") {
- interceptor[hook] = (interceptor[hook] || []).concat(scopedInterceptor[hook]);
- }
- });
- }
- return interceptor;
- }
- function invokeApi(method3, api, options, params) {
- const interceptor = getApiInterceptorHooks(method3);
- if (interceptor && Object.keys(interceptor).length) {
- if (isArray$2(interceptor.invoke)) {
- const res = queue$1(interceptor.invoke, options);
- return res.then((options2) => {
- return api(wrapperOptions(getApiInterceptorHooks(method3), options2), ...params);
- });
- } else {
- return api(wrapperOptions(interceptor, options), ...params);
- }
- }
- return api(options, ...params);
- }
- function hasCallback(args) {
- if (isPlainObject$1(args) && [API_SUCCESS, API_FAIL, API_COMPLETE].find((cb) => isFunction$1(args[cb]))) {
- return true;
- }
- return false;
- }
- function handlePromise(promise2) {
- return promise2;
- }
- function promisify$1(name, fn) {
- return (args = {}, ...rest) => {
- if (hasCallback(args)) {
- return wrapperReturnValue(name, invokeApi(name, fn, args, rest));
- }
- return wrapperReturnValue(name, handlePromise(new Promise((resolve2, reject) => {
- invokeApi(name, fn, extend$1(args, { success: resolve2, fail: reject }), rest);
- })));
- };
- }
- function formatApiArgs(args, options) {
- const params = args[0];
- if (!options || !isPlainObject$1(options.formatArgs) && isPlainObject$1(params)) {
- return;
- }
- const formatArgs = options.formatArgs;
- const keys2 = Object.keys(formatArgs);
- for (let i = 0; i < keys2.length; i++) {
- const name = keys2[i];
- const formatterOrDefaultValue = formatArgs[name];
- if (isFunction$1(formatterOrDefaultValue)) {
- const errMsg = formatterOrDefaultValue(args[0][name], params);
- if (isString$1(errMsg)) {
- return errMsg;
- }
- } else {
- if (!hasOwn(params, name)) {
- params[name] = formatterOrDefaultValue;
- }
- }
- }
- }
- function invokeSuccess(id, name, res) {
- return invokeCallback(id, extend$1(res || {}, { errMsg: name + ":ok" }));
- }
- function invokeFail(id, name, errMsg, errRes) {
- return invokeCallback(id, extend$1({ errMsg: name + ":fail" + (errMsg ? " " + errMsg : "") }, errRes));
- }
- function beforeInvokeApi(name, args, protocol, options) {
- {
- validateProtocols(name, args, protocol);
- }
- if (options && options.beforeInvoke) {
- const errMsg2 = options.beforeInvoke(args);
- if (isString$1(errMsg2)) {
- return errMsg2;
- }
- }
- const errMsg = formatApiArgs(args, options);
- if (errMsg) {
- return errMsg;
- }
- }
- function normalizeErrMsg(errMsg) {
- if (!errMsg || isString$1(errMsg)) {
- return errMsg;
- }
- if (errMsg.stack) {
- console.error(errMsg.message + LINEFEED + errMsg.stack);
- return errMsg.message;
- }
- return errMsg;
- }
- function wrapperTaskApi(name, fn, protocol, options) {
- return (args) => {
- const id = createAsyncApiCallback(name, args, options);
- const errMsg = beforeInvokeApi(name, [args], protocol, options);
- if (errMsg) {
- return invokeFail(id, name, errMsg);
- }
- return fn(args, {
- resolve: (res) => invokeSuccess(id, name, res),
- reject: (errMsg2, errRes) => invokeFail(id, name, normalizeErrMsg(errMsg2), errRes)
- });
- };
- }
- function wrapperSyncApi(name, fn, protocol, options) {
- return (...args) => {
- const errMsg = beforeInvokeApi(name, args, protocol, options);
- if (errMsg) {
- throw new Error(errMsg);
- }
- return fn.apply(null, args);
- };
- }
- function wrapperAsyncApi(name, fn, protocol, options) {
- return wrapperTaskApi(name, fn, protocol, options);
- }
- function defineSyncApi(name, fn, protocol, options) {
- return wrapperSyncApi(name, fn, protocol, options);
- }
- function defineAsyncApi(name, fn, protocol, options) {
- return promisify$1(name, wrapperAsyncApi(name, fn, protocol, options));
- }
- const API_UPX2PX = "upx2px";
- const Upx2pxProtocol = [
- {
- name: "upx",
- type: [Number, String],
- required: true
- }
- ];
- const EPS = 1e-4;
- const BASE_DEVICE_WIDTH = 750;
- let isIOS = false;
- let deviceWidth = 0;
- let deviceDPR = 0;
- function checkDeviceWidth() {
- const { platform: platform2, pixelRatio, windowWidth } = getBaseSystemInfo();
- deviceWidth = windowWidth;
- deviceDPR = pixelRatio;
- isIOS = platform2 === "ios";
- }
- const upx2px = defineSyncApi(API_UPX2PX, (number3, newDeviceWidth) => {
- if (deviceWidth === 0) {
- checkDeviceWidth();
- }
- number3 = Number(number3);
- if (number3 === 0) {
- return 0;
- }
- let width = newDeviceWidth || deviceWidth;
- let result = number3 / BASE_DEVICE_WIDTH * width;
- if (result < 0) {
- result = -result;
- }
- result = Math.floor(result + EPS);
- if (result === 0) {
- if (deviceDPR === 1 || !isIOS) {
- result = 1;
- } else {
- result = 0.5;
- }
- }
- return number3 < 0 ? -result : result;
- }, Upx2pxProtocol);
- const API_ADD_INTERCEPTOR = "addInterceptor";
- const API_REMOVE_INTERCEPTOR = "removeInterceptor";
- const AddInterceptorProtocol = [
- {
- name: "method",
- type: [String, Object],
- required: true
- }
- ];
- const RemoveInterceptorProtocol = AddInterceptorProtocol;
- function mergeInterceptorHook(interceptors2, interceptor) {
- Object.keys(interceptor).forEach((hook) => {
- if (isFunction$1(interceptor[hook])) {
- interceptors2[hook] = mergeHook(interceptors2[hook], interceptor[hook]);
- }
- });
- }
- function removeInterceptorHook(interceptors2, interceptor) {
- if (!interceptors2 || !interceptor) {
- return;
- }
- Object.keys(interceptor).forEach((name) => {
- const hooks2 = interceptors2[name];
- const hook = interceptor[name];
- if (isArray$2(hooks2) && isFunction$1(hook)) {
- remove(hooks2, hook);
- }
- });
- }
- function mergeHook(parentVal, childVal) {
- const res = childVal ? parentVal ? parentVal.concat(childVal) : isArray$2(childVal) ? childVal : [childVal] : parentVal;
- return res ? dedupeHooks(res) : res;
- }
- function dedupeHooks(hooks2) {
- const res = [];
- for (let i = 0; i < hooks2.length; i++) {
- if (res.indexOf(hooks2[i]) === -1) {
- res.push(hooks2[i]);
- }
- }
- return res;
- }
- const addInterceptor = defineSyncApi(API_ADD_INTERCEPTOR, (method3, interceptor) => {
- if (isString$1(method3) && isPlainObject$1(interceptor)) {
- mergeInterceptorHook(scopedInterceptors[method3] || (scopedInterceptors[method3] = {}), interceptor);
- } else if (isPlainObject$1(method3)) {
- mergeInterceptorHook(globalInterceptors, method3);
- }
- }, AddInterceptorProtocol);
- const removeInterceptor = defineSyncApi(API_REMOVE_INTERCEPTOR, (method3, interceptor) => {
- if (isString$1(method3)) {
- if (isPlainObject$1(interceptor)) {
- removeInterceptorHook(scopedInterceptors[method3], interceptor);
- } else {
- delete scopedInterceptors[method3];
- }
- } else if (isPlainObject$1(method3)) {
- removeInterceptorHook(globalInterceptors, method3);
- }
- }, RemoveInterceptorProtocol);
- const interceptors = {};
- const API_ON = "$on";
- const OnProtocol = [
- {
- name: "event",
- type: String,
- required: true
- },
- {
- name: "callback",
- type: Function,
- required: true
- }
- ];
- const API_ONCE = "$once";
- const OnceProtocol = OnProtocol;
- const API_OFF = "$off";
- const OffProtocol = [
- {
- name: "event",
- type: [String, Array]
- },
- {
- name: "callback",
- type: Function
- }
- ];
- const API_EMIT = "$emit";
- const EmitProtocol = [
- {
- name: "event",
- type: String,
- required: true
- }
- ];
- const emitter = new E$1();
- const $on = defineSyncApi(API_ON, (name, callback) => {
- emitter.on(name, callback);
- return () => emitter.off(name, callback);
- }, OnProtocol);
- const $once = defineSyncApi(API_ONCE, (name, callback) => {
- emitter.once(name, callback);
- return () => emitter.off(name, callback);
- }, OnceProtocol);
- const $off = defineSyncApi(API_OFF, (name, callback) => {
- if (!name) {
- emitter.e = {};
- return;
- }
- if (!isArray$2(name))
- name = [name];
- name.forEach((n2) => emitter.off(n2, callback));
- }, OffProtocol);
- const $emit = defineSyncApi(API_EMIT, (name, ...args) => {
- emitter.emit(name, ...args);
- }, EmitProtocol);
- let cid;
- let cidErrMsg;
- let enabled;
- function normalizePushMessage(message) {
- try {
- return JSON.parse(message);
- } catch (e2) {
- }
- return message;
- }
- function invokePushCallback(args) {
- if (args.type === "enabled") {
- enabled = true;
- } else if (args.type === "clientId") {
- cid = args.cid;
- cidErrMsg = args.errMsg;
- invokeGetPushCidCallbacks(cid, args.errMsg);
- } else if (args.type === "pushMsg") {
- const message = {
- type: "receive",
- data: normalizePushMessage(args.message)
- };
- for (let i = 0; i < onPushMessageCallbacks.length; i++) {
- const callback = onPushMessageCallbacks[i];
- callback(message);
- if (message.stopped) {
- break;
- }
- }
- } else if (args.type === "click") {
- onPushMessageCallbacks.forEach((callback) => {
- callback({
- type: "click",
- data: normalizePushMessage(args.message)
- });
- });
- }
- }
- const getPushCidCallbacks = [];
- function invokeGetPushCidCallbacks(cid2, errMsg) {
- getPushCidCallbacks.forEach((callback) => {
- callback(cid2, errMsg);
- });
- getPushCidCallbacks.length = 0;
- }
- const API_GET_PUSH_CLIENT_ID = "getPushClientId";
- const getPushClientId = defineAsyncApi(API_GET_PUSH_CLIENT_ID, (_, { resolve: resolve2, reject }) => {
- Promise.resolve().then(() => {
- if (typeof enabled === "undefined") {
- enabled = false;
- cid = "";
- cidErrMsg = "uniPush is not enabled";
- }
- getPushCidCallbacks.push((cid2, errMsg) => {
- if (cid2) {
- resolve2({ cid: cid2 });
- } else {
- reject(errMsg);
- }
- });
- if (typeof cid !== "undefined") {
- invokeGetPushCidCallbacks(cid, cidErrMsg);
- }
- });
- });
- const onPushMessageCallbacks = [];
- const onPushMessage = (fn) => {
- if (onPushMessageCallbacks.indexOf(fn) === -1) {
- onPushMessageCallbacks.push(fn);
- }
- };
- const offPushMessage = (fn) => {
- if (!fn) {
- onPushMessageCallbacks.length = 0;
- } else {
- const index2 = onPushMessageCallbacks.indexOf(fn);
- if (index2 > -1) {
- onPushMessageCallbacks.splice(index2, 1);
- }
- }
- };
- const SYNC_API_RE = /^\$|getLocale|setLocale|sendNativeEvent|restoreGlobal|requireGlobal|getCurrentSubNVue|getMenuButtonBoundingClientRect|^report|interceptors|Interceptor$|getSubNVueById|requireNativePlugin|upx2px|hideKeyboard|canIUse|^create|Sync$|Manager$|base64ToArrayBuffer|arrayBufferToBase64|getDeviceInfo|getAppBaseInfo|getWindowInfo|getSystemSetting|getAppAuthorizeSetting/;
- const CONTEXT_API_RE = /^create|Manager$/;
- const CONTEXT_API_RE_EXC = ["createBLEConnection"];
- const ASYNC_API = ["createBLEConnection"];
- const CALLBACK_API_RE = /^on|^off/;
- function isContextApi(name) {
- return CONTEXT_API_RE.test(name) && CONTEXT_API_RE_EXC.indexOf(name) === -1;
- }
- function isSyncApi(name) {
- return SYNC_API_RE.test(name) && ASYNC_API.indexOf(name) === -1;
- }
- function isCallbackApi(name) {
- return CALLBACK_API_RE.test(name) && name !== "onPush";
- }
- function shouldPromise(name) {
- if (isContextApi(name) || isSyncApi(name) || isCallbackApi(name)) {
- return false;
- }
- return true;
- }
- if (!Promise.prototype.finally) {
- Promise.prototype.finally = function(onfinally) {
- const promise2 = this.constructor;
- return this.then((value2) => promise2.resolve(onfinally && onfinally()).then(() => value2), (reason) => promise2.resolve(onfinally && onfinally()).then(() => {
- throw reason;
- }));
- };
- }
- function promisify(name, api) {
- if (!shouldPromise(name)) {
- return api;
- }
- if (!isFunction$1(api)) {
- return api;
- }
- return function promiseApi(options = {}, ...rest) {
- if (isFunction$1(options.success) || isFunction$1(options.fail) || isFunction$1(options.complete)) {
- return wrapperReturnValue(name, invokeApi(name, api, options, rest));
- }
- return wrapperReturnValue(name, handlePromise(new Promise((resolve2, reject) => {
- invokeApi(name, api, extend$1({}, options, {
- success: resolve2,
- fail: reject
- }), rest);
- })));
- };
- }
- const CALLBACKS = ["success", "fail", "cancel", "complete"];
- function initWrapper(protocols2) {
- function processCallback(methodName, method3, returnValue) {
- return function(res) {
- return method3(processReturnValue(methodName, res, returnValue));
- };
- }
- function processArgs(methodName, fromArgs, argsOption = {}, returnValue = {}, keepFromArgs = false) {
- if (isPlainObject$1(fromArgs)) {
- const toArgs = keepFromArgs === true ? fromArgs : {};
- if (isFunction$1(argsOption)) {
- argsOption = argsOption(fromArgs, toArgs) || {};
- }
- for (const key in fromArgs) {
- if (hasOwn(argsOption, key)) {
- let keyOption = argsOption[key];
- if (isFunction$1(keyOption)) {
- keyOption = keyOption(fromArgs[key], fromArgs, toArgs);
- }
- if (!keyOption) {
- console.warn(`微信小程序 ${methodName} 暂不支持 ${key}`);
- } else if (isString$1(keyOption)) {
- toArgs[keyOption] = fromArgs[key];
- } else if (isPlainObject$1(keyOption)) {
- toArgs[keyOption.name ? keyOption.name : key] = keyOption.value;
- }
- } else if (CALLBACKS.indexOf(key) !== -1) {
- const callback = fromArgs[key];
- if (isFunction$1(callback)) {
- toArgs[key] = processCallback(methodName, callback, returnValue);
- }
- } else {
- if (!keepFromArgs && !hasOwn(toArgs, key)) {
- toArgs[key] = fromArgs[key];
- }
- }
- }
- return toArgs;
- } else if (isFunction$1(fromArgs)) {
- fromArgs = processCallback(methodName, fromArgs, returnValue);
- }
- return fromArgs;
- }
- function processReturnValue(methodName, res, returnValue, keepReturnValue = false) {
- if (isFunction$1(protocols2.returnValue)) {
- res = protocols2.returnValue(methodName, res);
- }
- return processArgs(methodName, res, returnValue, {}, keepReturnValue);
- }
- return function wrapper(methodName, method3) {
- if (!hasOwn(protocols2, methodName)) {
- return method3;
- }
- const protocol = protocols2[methodName];
- if (!protocol) {
- return function() {
- console.error(`微信小程序 暂不支持${methodName}`);
- };
- }
- return function(arg1, arg2) {
- let options = protocol;
- if (isFunction$1(protocol)) {
- options = protocol(arg1);
- }
- arg1 = processArgs(methodName, arg1, options.args, options.returnValue);
- const args = [arg1];
- if (typeof arg2 !== "undefined") {
- args.push(arg2);
- }
- const returnValue = wx[options.name || methodName].apply(wx, args);
- if (isSyncApi(methodName)) {
- return processReturnValue(methodName, returnValue, options.returnValue, isContextApi(methodName));
- }
- return returnValue;
- };
- };
- }
- const getLocale$1 = () => {
- const app = isFunction$1(getApp) && getApp({ allowDefault: true });
- if (app && app.$vm) {
- return app.$vm.$locale;
- }
- return normalizeLocale$1(wx.getSystemInfoSync().language) || LOCALE_EN;
- };
- const setLocale = (locale2) => {
- const app = isFunction$1(getApp) && getApp();
- if (!app) {
- return false;
- }
- const oldLocale = app.$vm.$locale;
- if (oldLocale !== locale2) {
- app.$vm.$locale = locale2;
- onLocaleChangeCallbacks.forEach((fn) => fn({ locale: locale2 }));
- return true;
- }
- return false;
- };
- const onLocaleChangeCallbacks = [];
- const onLocaleChange = (fn) => {
- if (onLocaleChangeCallbacks.indexOf(fn) === -1) {
- onLocaleChangeCallbacks.push(fn);
- }
- };
- if (typeof global !== "undefined") {
- global.getLocale = getLocale$1;
- }
- const UUID_KEY = "__DC_STAT_UUID";
- let deviceId;
- function useDeviceId(global2 = wx) {
- return function addDeviceId(_, toRes) {
- deviceId = deviceId || global2.getStorageSync(UUID_KEY);
- if (!deviceId) {
- deviceId = Date.now() + "" + Math.floor(Math.random() * 1e7);
- wx.setStorage({
- key: UUID_KEY,
- data: deviceId
- });
- }
- toRes.deviceId = deviceId;
- };
- }
- function addSafeAreaInsets(fromRes, toRes) {
- if (fromRes.safeArea) {
- const safeArea = fromRes.safeArea;
- toRes.safeAreaInsets = {
- top: safeArea.top,
- left: safeArea.left,
- right: fromRes.windowWidth - safeArea.right,
- bottom: fromRes.screenHeight - safeArea.bottom
- };
- }
- }
- function populateParameters(fromRes, toRes) {
- const { brand = "", model = "", system = "", language = "", theme, version: version2, platform: platform2, fontSizeSetting, SDKVersion, pixelRatio, deviceOrientation } = fromRes;
- let osName = "";
- let osVersion = "";
- {
- osName = system.split(" ")[0] || "";
- osVersion = system.split(" ")[1] || "";
- }
- let hostVersion = version2;
- let deviceType = getGetDeviceType(fromRes, model);
- let deviceBrand = getDeviceBrand(brand);
- let _hostName = getHostName(fromRes);
- let _deviceOrientation = deviceOrientation;
- let _devicePixelRatio = pixelRatio;
- let _SDKVersion = SDKVersion;
- const hostLanguage = language.replace(/_/g, "-");
- const parameters = {
- appId: "__UNI__EEB6DFC",
- appName: "car_applet",
- appVersion: "1.0.0",
- appVersionCode: "100",
- appLanguage: getAppLanguage(hostLanguage),
- uniCompileVersion: "3.8.7",
- uniRuntimeVersion: "3.8.7",
- uniPlatform: "mp-weixin",
- deviceBrand,
- deviceModel: model,
- deviceType,
- devicePixelRatio: _devicePixelRatio,
- deviceOrientation: _deviceOrientation,
- osName: osName.toLocaleLowerCase(),
- osVersion,
- hostTheme: theme,
- hostVersion,
- hostLanguage,
- hostName: _hostName,
- hostSDKVersion: _SDKVersion,
- hostFontSizeSetting: fontSizeSetting,
- windowTop: 0,
- windowBottom: 0,
- // TODO
- osLanguage: void 0,
- osTheme: void 0,
- ua: void 0,
- hostPackageName: void 0,
- browserName: void 0,
- browserVersion: void 0
- };
- extend$1(toRes, parameters);
- }
- function getGetDeviceType(fromRes, model) {
- let deviceType = fromRes.deviceType || "phone";
- {
- const deviceTypeMaps = {
- ipad: "pad",
- windows: "pc",
- mac: "pc"
- };
- const deviceTypeMapsKeys = Object.keys(deviceTypeMaps);
- const _model = model.toLocaleLowerCase();
- for (let index2 = 0; index2 < deviceTypeMapsKeys.length; index2++) {
- const _m = deviceTypeMapsKeys[index2];
- if (_model.indexOf(_m) !== -1) {
- deviceType = deviceTypeMaps[_m];
- break;
- }
- }
- }
- return deviceType;
- }
- function getDeviceBrand(brand) {
- let deviceBrand = brand;
- if (deviceBrand) {
- deviceBrand = deviceBrand.toLocaleLowerCase();
- }
- return deviceBrand;
- }
- function getAppLanguage(defaultLanguage) {
- return getLocale$1 ? getLocale$1() : defaultLanguage;
- }
- function getHostName(fromRes) {
- const _platform = "WeChat";
- let _hostName = fromRes.hostName || _platform;
- {
- if (fromRes.environment) {
- _hostName = fromRes.environment;
- } else if (fromRes.host && fromRes.host.env) {
- _hostName = fromRes.host.env;
- }
- }
- return _hostName;
- }
- const getSystemInfo = {
- returnValue: (fromRes, toRes) => {
- addSafeAreaInsets(fromRes, toRes);
- useDeviceId()(fromRes, toRes);
- populateParameters(fromRes, toRes);
- }
- };
- const getSystemInfoSync = getSystemInfo;
- const redirectTo = {};
- const previewImage = {
- args(fromArgs, toArgs) {
- let currentIndex = parseInt(fromArgs.current);
- if (isNaN(currentIndex)) {
- return;
- }
- const urls = fromArgs.urls;
- if (!isArray$2(urls)) {
- return;
- }
- const len = urls.length;
- if (!len) {
- return;
- }
- if (currentIndex < 0) {
- currentIndex = 0;
- } else if (currentIndex >= len) {
- currentIndex = len - 1;
- }
- if (currentIndex > 0) {
- toArgs.current = urls[currentIndex];
- toArgs.urls = urls.filter((item, index2) => index2 < currentIndex ? item !== urls[currentIndex] : true);
- } else {
- toArgs.current = urls[0];
- }
- return {
- indicator: false,
- loop: false
- };
- }
- };
- const showActionSheet = {
- args(fromArgs, toArgs) {
- toArgs.alertText = fromArgs.title;
- }
- };
- const getDeviceInfo = {
- returnValue: (fromRes, toRes) => {
- const { brand, model } = fromRes;
- let deviceType = getGetDeviceType(fromRes, model);
- let deviceBrand = getDeviceBrand(brand);
- useDeviceId()(fromRes, toRes);
- toRes = sortObject(extend$1(toRes, {
- deviceType,
- deviceBrand,
- deviceModel: model
- }));
- }
- };
- const getAppBaseInfo = {
- returnValue: (fromRes, toRes) => {
- const { version: version2, language, SDKVersion, theme } = fromRes;
- let _hostName = getHostName(fromRes);
- let hostLanguage = language.replace(/_/g, "-");
- toRes = sortObject(extend$1(toRes, {
- hostVersion: version2,
- hostLanguage,
- hostName: _hostName,
- hostSDKVersion: SDKVersion,
- hostTheme: theme,
- appId: "__UNI__EEB6DFC",
- appName: "car_applet",
- appVersion: "1.0.0",
- appVersionCode: "100",
- appLanguage: getAppLanguage(hostLanguage)
- }));
- }
- };
- const getWindowInfo = {
- returnValue: (fromRes, toRes) => {
- addSafeAreaInsets(fromRes, toRes);
- toRes = sortObject(extend$1(toRes, {
- windowTop: 0,
- windowBottom: 0
- }));
- }
- };
- const getAppAuthorizeSetting = {
- returnValue: function(fromRes, toRes) {
- const { locationReducedAccuracy } = fromRes;
- toRes.locationAccuracy = "unsupported";
- if (locationReducedAccuracy === true) {
- toRes.locationAccuracy = "reduced";
- } else if (locationReducedAccuracy === false) {
- toRes.locationAccuracy = "full";
- }
- }
- };
- const baseApis = {
- $on,
- $off,
- $once,
- $emit,
- upx2px,
- interceptors,
- addInterceptor,
- removeInterceptor,
- onCreateVueApp,
- invokeCreateVueAppHook,
- getLocale: getLocale$1,
- setLocale,
- onLocaleChange,
- getPushClientId,
- onPushMessage,
- offPushMessage,
- invokePushCallback
- };
- function initUni(api, protocols2, platform2 = wx) {
- const wrapper = initWrapper(protocols2);
- const UniProxyHandlers = {
- get(target, key) {
- if (hasOwn(target, key)) {
- return target[key];
- }
- if (hasOwn(api, key)) {
- return promisify(key, api[key]);
- }
- if (hasOwn(baseApis, key)) {
- return promisify(key, baseApis[key]);
- }
- return promisify(key, wrapper(key, platform2[key]));
- }
- };
- return new Proxy({}, UniProxyHandlers);
- }
- function initGetProvider(providers) {
- return function getProvider2({ service, success, fail, complete }) {
- let res;
- if (providers[service]) {
- res = {
- errMsg: "getProvider:ok",
- service,
- provider: providers[service]
- };
- isFunction$1(success) && success(res);
- } else {
- res = {
- errMsg: "getProvider:fail:服务[" + service + "]不存在"
- };
- isFunction$1(fail) && fail(res);
- }
- isFunction$1(complete) && complete(res);
- };
- }
- const objectKeys = [
- "qy",
- "env",
- "error",
- "version",
- "lanDebug",
- "cloud",
- "serviceMarket",
- "router",
- "worklet",
- "__webpack_require_UNI_MP_PLUGIN__"
- ];
- const singlePageDisableKey = ["lanDebug", "router", "worklet"];
- const launchOption = wx.getLaunchOptionsSync ? wx.getLaunchOptionsSync() : null;
- function isWxKey(key) {
- if (launchOption && launchOption.scene === 1154 && singlePageDisableKey.includes(key)) {
- return false;
- }
- return objectKeys.indexOf(key) > -1 || typeof wx[key] === "function";
- }
- function initWx() {
- const newWx = {};
- for (const key in wx) {
- if (isWxKey(key)) {
- newWx[key] = wx[key];
- }
- }
- if (typeof globalThis !== "undefined" && typeof requireMiniProgram === "undefined") {
- globalThis.wx = newWx;
- }
- return newWx;
- }
- const mocks$1 = ["__route__", "__wxExparserNodeId__", "__wxWebviewId__"];
- const getProvider = initGetProvider({
- oauth: ["weixin"],
- share: ["weixin"],
- payment: ["wxpay"],
- push: ["weixin"]
- });
- function initComponentMocks(component) {
- const res = /* @__PURE__ */ Object.create(null);
- mocks$1.forEach((name) => {
- res[name] = component[name];
- });
- return res;
- }
- function createSelectorQuery() {
- const query = wx$2.createSelectorQuery();
- const oldIn = query.in;
- query.in = function newIn(component) {
- return oldIn.call(this, initComponentMocks(component));
- };
- return query;
- }
- const wx$2 = initWx();
- let baseInfo = wx$2.getAppBaseInfo && wx$2.getAppBaseInfo();
- if (!baseInfo) {
- baseInfo = wx$2.getSystemInfoSync();
- }
- const host = baseInfo ? baseInfo.host : null;
- const shareVideoMessage = host && host.env === "SAAASDK" ? wx$2.miniapp.shareVideoMessage : wx$2.shareVideoMessage;
- var shims = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- createSelectorQuery,
- getProvider,
- shareVideoMessage
- });
- const compressImage = {
- args(fromArgs, toArgs) {
- if (fromArgs.compressedHeight && !toArgs.compressHeight) {
- toArgs.compressHeight = fromArgs.compressedHeight;
- }
- if (fromArgs.compressedWidth && !toArgs.compressWidth) {
- toArgs.compressWidth = fromArgs.compressedWidth;
- }
- }
- };
- var protocols = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- compressImage,
- getAppAuthorizeSetting,
- getAppBaseInfo,
- getDeviceInfo,
- getSystemInfo,
- getSystemInfoSync,
- getWindowInfo,
- previewImage,
- redirectTo,
- showActionSheet
- });
- const wx$1 = initWx();
- var index$1 = initUni(shims, protocols, wx$1);
- function warn$1(msg, ...args) {
- console.warn(`[Vue warn] ${msg}`, ...args);
- }
- let activeEffectScope;
- class EffectScope {
- constructor(detached = false) {
- this.detached = detached;
- this._active = true;
- this.effects = [];
- this.cleanups = [];
- this.parent = activeEffectScope;
- if (!detached && activeEffectScope) {
- this.index = (activeEffectScope.scopes || (activeEffectScope.scopes = [])).push(this) - 1;
- }
- }
- get active() {
- return this._active;
- }
- run(fn) {
- if (this._active) {
- const currentEffectScope = activeEffectScope;
- try {
- activeEffectScope = this;
- return fn();
- } finally {
- activeEffectScope = currentEffectScope;
- }
- } else {
- warn$1(`cannot run an inactive effect scope.`);
- }
- }
- /**
- * This should only be called on non-detached scopes
- * @internal
- */
- on() {
- activeEffectScope = this;
- }
- /**
- * This should only be called on non-detached scopes
- * @internal
- */
- off() {
- activeEffectScope = this.parent;
- }
- stop(fromParent) {
- if (this._active) {
- let i, l;
- for (i = 0, l = this.effects.length; i < l; i++) {
- this.effects[i].stop();
- }
- for (i = 0, l = this.cleanups.length; i < l; i++) {
- this.cleanups[i]();
- }
- if (this.scopes) {
- for (i = 0, l = this.scopes.length; i < l; i++) {
- this.scopes[i].stop(true);
- }
- }
- if (!this.detached && this.parent && !fromParent) {
- const last = this.parent.scopes.pop();
- if (last && last !== this) {
- this.parent.scopes[this.index] = last;
- last.index = this.index;
- }
- }
- this.parent = void 0;
- this._active = false;
- }
- }
- }
- function recordEffectScope(effect, scope = activeEffectScope) {
- if (scope && scope.active) {
- scope.effects.push(effect);
- }
- }
- function getCurrentScope() {
- return activeEffectScope;
- }
- 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 i = 0; i < deps.length; i++) {
- deps[i].w |= trackOpBit;
- }
- }
- };
- const finalizeDepMarkers = (effect) => {
- const { deps } = effect;
- if (deps.length) {
- let ptr = 0;
- for (let i = 0; i < deps.length; i++) {
- const dep = deps[i];
- if (wasTracked(dep) && !newTracked(dep)) {
- dep.delete(effect);
- } else {
- deps[ptr++] = dep;
- }
- dep.w &= ~trackOpBit;
- dep.n &= ~trackOpBit;
- }
- deps.length = ptr;
- }
- };
- const targetMap = /* @__PURE__ */ new WeakMap();
- let effectTrackDepth = 0;
- let trackOpBit = 1;
- const maxMarkerBits = 30;
- let activeEffect;
- const ITERATE_KEY = Symbol("iterate");
- const MAP_KEY_ITERATE_KEY = Symbol("Map key iterate");
- class ReactiveEffect {
- constructor(fn, scheduler = null, scope) {
- this.fn = fn;
- 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(effect) {
- const { deps } = effect;
- if (deps.length) {
- for (let i = 0; i < deps.length; i++) {
- deps[i].delete(effect);
- }
- deps.length = 0;
- }
- }
- let shouldTrack = true;
- const trackStack = [];
- function pauseTracking() {
- trackStack.push(shouldTrack);
- shouldTrack = false;
- }
- function resetTracking() {
- const last = trackStack.pop();
- shouldTrack = last === void 0 ? true : last;
- }
- function track(target, type2, key) {
- if (shouldTrack && activeEffect) {
- let depsMap = targetMap.get(target);
- if (!depsMap) {
- targetMap.set(target, depsMap = /* @__PURE__ */ new Map());
- }
- let dep = depsMap.get(key);
- if (!dep) {
- depsMap.set(key, dep = createDep());
- }
- const eventInfo = { effect: activeEffect, target, type: type2, key };
- trackEffects(dep, eventInfo);
- }
- }
- 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);
- if (activeEffect.onTrack) {
- activeEffect.onTrack(Object.assign({ effect: activeEffect }, debuggerEventExtraInfo));
- }
- }
- }
- function trigger(target, type2, key, newValue, oldValue, oldTarget) {
- const depsMap = targetMap.get(target);
- if (!depsMap) {
- return;
- }
- let deps = [];
- if (type2 === "clear") {
- deps = [...depsMap.values()];
- } else if (key === "length" && isArray$2(target)) {
- const newLength = Number(newValue);
- depsMap.forEach((dep, key2) => {
- if (key2 === "length" || key2 >= newLength) {
- deps.push(dep);
- }
- });
- } else {
- if (key !== void 0) {
- deps.push(depsMap.get(key));
- }
- switch (type2) {
- case "add":
- if (!isArray$2(target)) {
- deps.push(depsMap.get(ITERATE_KEY));
- if (isMap(target)) {
- deps.push(depsMap.get(MAP_KEY_ITERATE_KEY));
- }
- } else if (isIntegerKey(key)) {
- deps.push(depsMap.get("length"));
- }
- break;
- case "delete":
- if (!isArray$2(target)) {
- deps.push(depsMap.get(ITERATE_KEY));
- if (isMap(target)) {
- deps.push(depsMap.get(MAP_KEY_ITERATE_KEY));
- }
- }
- break;
- case "set":
- if (isMap(target)) {
- deps.push(depsMap.get(ITERATE_KEY));
- }
- break;
- }
- }
- const eventInfo = { target, type: type2, key, newValue, oldValue, oldTarget };
- if (deps.length === 1) {
- if (deps[0]) {
- {
- triggerEffects(deps[0], eventInfo);
- }
- }
- } else {
- const effects = [];
- for (const dep of deps) {
- if (dep) {
- effects.push(...dep);
- }
- }
- {
- triggerEffects(createDep(effects), eventInfo);
- }
- }
- }
- function triggerEffects(dep, debuggerEventExtraInfo) {
- const effects = isArray$2(dep) ? dep : [...dep];
- for (const effect of effects) {
- if (effect.computed) {
- triggerEffect(effect, debuggerEventExtraInfo);
- }
- }
- for (const effect of effects) {
- if (!effect.computed) {
- triggerEffect(effect, debuggerEventExtraInfo);
- }
- }
- }
- function triggerEffect(effect, debuggerEventExtraInfo) {
- if (effect !== activeEffect || effect.allowRecurse) {
- if (effect.onTrigger) {
- effect.onTrigger(extend$1({ effect }, debuggerEventExtraInfo));
- }
- if (effect.scheduler) {
- effect.scheduler();
- } else {
- effect.run();
- }
- }
- }
- const isNonTrackableKeys = /* @__PURE__ */ makeMap(`__proto__,__v_isRef,__isVue`);
- const builtInSymbols = new Set(
- /* @__PURE__ */ Object.getOwnPropertyNames(Symbol).filter((key) => key !== "arguments" && key !== "caller").map((key) => Symbol[key]).filter(isSymbol)
- );
- const get$1$1 = /* @__PURE__ */ createGetter();
- const shallowGet = /* @__PURE__ */ createGetter(false, true);
- const readonlyGet = /* @__PURE__ */ createGetter(true);
- const shallowReadonlyGet = /* @__PURE__ */ createGetter(true, true);
- const arrayInstrumentations = /* @__PURE__ */ createArrayInstrumentations();
- function createArrayInstrumentations() {
- const instrumentations = {};
- ["includes", "indexOf", "lastIndexOf"].forEach((key) => {
- instrumentations[key] = function(...args) {
- const arr = toRaw(this);
- for (let i = 0, l = this.length; i < l; i++) {
- track(arr, "get", i + "");
- }
- const res = arr[key](...args);
- if (res === -1 || res === false) {
- return arr[key](...args.map(toRaw));
- } else {
- return res;
- }
- };
- });
- ["push", "pop", "shift", "unshift", "splice"].forEach((key) => {
- instrumentations[key] = function(...args) {
- pauseTracking();
- const res = toRaw(this)[key].apply(this, args);
- resetTracking();
- return res;
- };
- });
- return instrumentations;
- }
- function hasOwnProperty(key) {
- const obj = toRaw(this);
- track(obj, "has", key);
- return obj.hasOwnProperty(key);
- }
- function createGetter(isReadonly2 = false, shallow = false) {
- return function get2(target, key, receiver) {
- if (key === "__v_isReactive") {
- return !isReadonly2;
- } else if (key === "__v_isReadonly") {
- return isReadonly2;
- } else if (key === "__v_isShallow") {
- return shallow;
- } else if (key === "__v_raw" && receiver === (isReadonly2 ? shallow ? shallowReadonlyMap : readonlyMap : shallow ? shallowReactiveMap : reactiveMap).get(target)) {
- return target;
- }
- const targetIsArray = isArray$2(target);
- if (!isReadonly2) {
- if (targetIsArray && hasOwn(arrayInstrumentations, key)) {
- return Reflect.get(arrayInstrumentations, key, receiver);
- }
- if (key === "hasOwnProperty") {
- return hasOwnProperty;
- }
- }
- const res = Reflect.get(target, key, receiver);
- if (isSymbol(key) ? builtInSymbols.has(key) : isNonTrackableKeys(key)) {
- return res;
- }
- if (!isReadonly2) {
- track(target, "get", key);
- }
- if (shallow) {
- return res;
- }
- if (isRef(res)) {
- return targetIsArray && isIntegerKey(key) ? res : res.value;
- }
- if (isObject$2(res)) {
- return isReadonly2 ? readonly(res) : reactive(res);
- }
- return res;
- };
- }
- const set$1$1 = /* @__PURE__ */ createSetter();
- const shallowSet = /* @__PURE__ */ createSetter(true);
- function createSetter(shallow = false) {
- return function set2(target, key, value2, receiver) {
- let oldValue = target[key];
- if (isReadonly(oldValue) && isRef(oldValue) && !isRef(value2)) {
- return false;
- }
- if (!shallow) {
- if (!isShallow(value2) && !isReadonly(value2)) {
- oldValue = toRaw(oldValue);
- value2 = toRaw(value2);
- }
- if (!isArray$2(target) && isRef(oldValue) && !isRef(value2)) {
- oldValue.value = value2;
- return true;
- }
- }
- const hadKey = isArray$2(target) && isIntegerKey(key) ? Number(key) < target.length : hasOwn(target, key);
- const result = Reflect.set(target, key, value2, receiver);
- if (target === toRaw(receiver)) {
- if (!hadKey) {
- trigger(target, "add", key, value2);
- } else if (hasChanged(value2, oldValue)) {
- trigger(target, "set", key, value2, oldValue);
- }
- }
- return result;
- };
- }
- function deleteProperty(target, key) {
- const hadKey = hasOwn(target, key);
- const oldValue = target[key];
- const result = Reflect.deleteProperty(target, key);
- if (result && hadKey) {
- trigger(target, "delete", key, void 0, oldValue);
- }
- return result;
- }
- function has$1(target, key) {
- const result = Reflect.has(target, key);
- if (!isSymbol(key) || !builtInSymbols.has(key)) {
- track(target, "has", key);
- }
- return result;
- }
- function ownKeys(target) {
- track(target, "iterate", isArray$2(target) ? "length" : ITERATE_KEY);
- return Reflect.ownKeys(target);
- }
- const mutableHandlers = {
- get: get$1$1,
- set: set$1$1,
- deleteProperty,
- has: has$1,
- ownKeys
- };
- const readonlyHandlers = {
- get: readonlyGet,
- set(target, key) {
- {
- warn$1(`Set operation on key "${String(key)}" failed: target is readonly.`, target);
- }
- return true;
- },
- deleteProperty(target, key) {
- {
- warn$1(`Delete operation on key "${String(key)}" failed: target is readonly.`, target);
- }
- return true;
- }
- };
- const shallowReactiveHandlers = /* @__PURE__ */ extend$1({}, mutableHandlers, {
- get: shallowGet,
- set: shallowSet
- });
- const shallowReadonlyHandlers = /* @__PURE__ */ extend$1({}, readonlyHandlers, {
- get: shallowReadonlyGet
- });
- const toShallow = (value2) => value2;
- const getProto = (v) => Reflect.getPrototypeOf(v);
- function get$3(target, key, isReadonly2 = false, isShallow2 = false) {
- target = target[
- "__v_raw"
- /* ReactiveFlags.RAW */
- ];
- const rawTarget = toRaw(target);
- const rawKey = toRaw(key);
- if (!isReadonly2) {
- if (key !== rawKey) {
- track(rawTarget, "get", key);
- }
- track(rawTarget, "get", rawKey);
- }
- const { has: has2 } = getProto(rawTarget);
- const wrap = isShallow2 ? toShallow : isReadonly2 ? toReadonly : toReactive;
- if (has2.call(rawTarget, key)) {
- return wrap(target.get(key));
- } else if (has2.call(rawTarget, rawKey)) {
- return wrap(target.get(rawKey));
- } else if (target !== rawTarget) {
- target.get(key);
- }
- }
- function has(key, isReadonly2 = false) {
- const target = this[
- "__v_raw"
- /* ReactiveFlags.RAW */
- ];
- const rawTarget = toRaw(target);
- const rawKey = toRaw(key);
- if (!isReadonly2) {
- if (key !== rawKey) {
- track(rawTarget, "has", key);
- }
- track(rawTarget, "has", rawKey);
- }
- return key === rawKey ? target.has(key) : target.has(key) || target.has(rawKey);
- }
- function size(target, isReadonly2 = false) {
- target = target[
- "__v_raw"
- /* ReactiveFlags.RAW */
- ];
- !isReadonly2 && track(toRaw(target), "iterate", ITERATE_KEY);
- return Reflect.get(target, "size", target);
- }
- function add$2(value2) {
- value2 = toRaw(value2);
- const target = toRaw(this);
- const proto2 = getProto(target);
- const hadKey = proto2.has.call(target, value2);
- if (!hadKey) {
- target.add(value2);
- trigger(target, "add", value2, value2);
- }
- return this;
- }
- function set$2(key, value2) {
- value2 = toRaw(value2);
- const target = toRaw(this);
- const { has: has2, get: get2 } = getProto(target);
- let hadKey = has2.call(target, key);
- if (!hadKey) {
- key = toRaw(key);
- hadKey = has2.call(target, key);
- } else {
- checkIdentityKeys(target, has2, key);
- }
- const oldValue = get2.call(target, key);
- target.set(key, value2);
- if (!hadKey) {
- trigger(target, "add", key, value2);
- } else if (hasChanged(value2, oldValue)) {
- trigger(target, "set", key, value2, oldValue);
- }
- return this;
- }
- function deleteEntry(key) {
- const target = toRaw(this);
- const { has: has2, get: get2 } = getProto(target);
- let hadKey = has2.call(target, key);
- if (!hadKey) {
- key = toRaw(key);
- hadKey = has2.call(target, key);
- } else {
- checkIdentityKeys(target, has2, key);
- }
- const oldValue = get2 ? get2.call(target, key) : void 0;
- const result = target.delete(key);
- if (hadKey) {
- trigger(target, "delete", key, void 0, oldValue);
- }
- return result;
- }
- function clear() {
- const target = toRaw(this);
- const hadItems = target.size !== 0;
- const oldTarget = isMap(target) ? new Map(target) : new Set(target);
- const result = target.clear();
- if (hadItems) {
- trigger(target, "clear", void 0, void 0, oldTarget);
- }
- return result;
- }
- function createForEach(isReadonly2, isShallow2) {
- return function forEach3(callback, thisArg) {
- const observed = this;
- const target = observed[
- "__v_raw"
- /* ReactiveFlags.RAW */
- ];
- const rawTarget = toRaw(target);
- const wrap = isShallow2 ? toShallow : isReadonly2 ? toReadonly : toReactive;
- !isReadonly2 && track(rawTarget, "iterate", ITERATE_KEY);
- return target.forEach((value2, key) => {
- return callback.call(thisArg, wrap(value2), wrap(key), observed);
- });
- };
- }
- function createIterableMethod(method3, isReadonly2, isShallow2) {
- return function(...args) {
- const target = this[
- "__v_raw"
- /* ReactiveFlags.RAW */
- ];
- const rawTarget = toRaw(target);
- const targetIsMap = isMap(rawTarget);
- const isPair = method3 === "entries" || method3 === Symbol.iterator && targetIsMap;
- const isKeyOnly = method3 === "keys" && targetIsMap;
- const innerIterator = target[method3](...args);
- const wrap = isShallow2 ? toShallow : isReadonly2 ? toReadonly : toReactive;
- !isReadonly2 && track(rawTarget, "iterate", isKeyOnly ? MAP_KEY_ITERATE_KEY : ITERATE_KEY);
- return {
- // iterator protocol
- next() {
- const { value: value2, done } = innerIterator.next();
- return done ? { value: value2, done } : {
- value: isPair ? [wrap(value2[0]), wrap(value2[1])] : wrap(value2),
- done
- };
- },
- // iterable protocol
- [Symbol.iterator]() {
- return this;
- }
- };
- };
- }
- function createReadonlyMethod(type2) {
- return function(...args) {
- {
- const key = args[0] ? `on key "${args[0]}" ` : ``;
- console.warn(`${capitalize(type2)} operation ${key}failed: target is readonly.`, toRaw(this));
- }
- return type2 === "delete" ? false : this;
- };
- }
- function createInstrumentations() {
- const mutableInstrumentations2 = {
- get(key) {
- return get$3(this, key);
- },
- get size() {
- return size(this);
- },
- has,
- add: add$2,
- set: set$2,
- delete: deleteEntry,
- clear,
- forEach: createForEach(false, false)
- };
- const shallowInstrumentations2 = {
- get(key) {
- return get$3(this, key, false, true);
- },
- get size() {
- return size(this);
- },
- has,
- add: add$2,
- set: set$2,
- delete: deleteEntry,
- clear,
- forEach: createForEach(false, true)
- };
- const readonlyInstrumentations2 = {
- get(key) {
- return get$3(this, key, true);
- },
- get size() {
- return size(this, true);
- },
- has(key) {
- return has.call(this, key, true);
- },
- add: createReadonlyMethod(
- "add"
- /* TriggerOpTypes.ADD */
- ),
- set: createReadonlyMethod(
- "set"
- /* TriggerOpTypes.SET */
- ),
- delete: createReadonlyMethod(
- "delete"
- /* TriggerOpTypes.DELETE */
- ),
- clear: createReadonlyMethod(
- "clear"
- /* TriggerOpTypes.CLEAR */
- ),
- forEach: createForEach(true, false)
- };
- const shallowReadonlyInstrumentations2 = {
- get(key) {
- return get$3(this, key, true, true);
- },
- get size() {
- return size(this, true);
- },
- has(key) {
- return has.call(this, key, true);
- },
- add: createReadonlyMethod(
- "add"
- /* TriggerOpTypes.ADD */
- ),
- set: createReadonlyMethod(
- "set"
- /* TriggerOpTypes.SET */
- ),
- delete: createReadonlyMethod(
- "delete"
- /* TriggerOpTypes.DELETE */
- ),
- clear: createReadonlyMethod(
- "clear"
- /* TriggerOpTypes.CLEAR */
- ),
- forEach: createForEach(true, true)
- };
- const iteratorMethods = ["keys", "values", "entries", Symbol.iterator];
- iteratorMethods.forEach((method3) => {
- mutableInstrumentations2[method3] = createIterableMethod(method3, false, false);
- readonlyInstrumentations2[method3] = createIterableMethod(method3, true, false);
- shallowInstrumentations2[method3] = createIterableMethod(method3, false, true);
- shallowReadonlyInstrumentations2[method3] = createIterableMethod(method3, true, true);
- });
- return [
- mutableInstrumentations2,
- readonlyInstrumentations2,
- shallowInstrumentations2,
- shallowReadonlyInstrumentations2
- ];
- }
- const [mutableInstrumentations, readonlyInstrumentations, shallowInstrumentations, shallowReadonlyInstrumentations] = /* @__PURE__ */ createInstrumentations();
- function createInstrumentationGetter(isReadonly2, shallow) {
- const instrumentations = shallow ? isReadonly2 ? shallowReadonlyInstrumentations : shallowInstrumentations : isReadonly2 ? readonlyInstrumentations : mutableInstrumentations;
- return (target, key, receiver) => {
- if (key === "__v_isReactive") {
- return !isReadonly2;
- } else if (key === "__v_isReadonly") {
- return isReadonly2;
- } else if (key === "__v_raw") {
- return target;
- }
- return Reflect.get(hasOwn(instrumentations, key) && key in target ? instrumentations : target, key, receiver);
- };
- }
- const mutableCollectionHandlers = {
- get: /* @__PURE__ */ createInstrumentationGetter(false, false)
- };
- const shallowCollectionHandlers = {
- get: /* @__PURE__ */ createInstrumentationGetter(false, true)
- };
- const readonlyCollectionHandlers = {
- get: /* @__PURE__ */ createInstrumentationGetter(true, false)
- };
- const shallowReadonlyCollectionHandlers = {
- get: /* @__PURE__ */ createInstrumentationGetter(true, true)
- };
- function checkIdentityKeys(target, has2, key) {
- const rawKey = toRaw(key);
- if (rawKey !== key && has2.call(target, rawKey)) {
- const type2 = toRawType(target);
- console.warn(`Reactive ${type2} contains both the raw and reactive versions of the same object${type2 === `Map` ? ` as keys` : ``}, which can lead to inconsistencies. Avoid differentiating between the raw and reactive versions of an object and only use the reactive version if possible.`);
- }
- }
- const reactiveMap = /* @__PURE__ */ new WeakMap();
- const shallowReactiveMap = /* @__PURE__ */ new WeakMap();
- const readonlyMap = /* @__PURE__ */ new WeakMap();
- const shallowReadonlyMap = /* @__PURE__ */ new WeakMap();
- function targetTypeMap(rawType) {
- switch (rawType) {
- case "Object":
- case "Array":
- return 1;
- case "Map":
- case "Set":
- case "WeakMap":
- case "WeakSet":
- return 2;
- default:
- return 0;
- }
- }
- function getTargetType(value2) {
- return value2[
- "__v_skip"
- /* ReactiveFlags.SKIP */
- ] || !Object.isExtensible(value2) ? 0 : targetTypeMap(toRawType(value2));
- }
- function reactive(target) {
- if (isReadonly(target)) {
- return target;
- }
- return createReactiveObject(target, false, mutableHandlers, mutableCollectionHandlers, reactiveMap);
- }
- function shallowReactive(target) {
- return createReactiveObject(target, false, shallowReactiveHandlers, shallowCollectionHandlers, shallowReactiveMap);
- }
- function readonly(target) {
- return createReactiveObject(target, true, readonlyHandlers, readonlyCollectionHandlers, readonlyMap);
- }
- function shallowReadonly(target) {
- return createReactiveObject(target, true, shallowReadonlyHandlers, shallowReadonlyCollectionHandlers, shallowReadonlyMap);
- }
- function createReactiveObject(target, isReadonly2, baseHandlers, collectionHandlers, proxyMap) {
- if (!isObject$2(target)) {
- {
- console.warn(`value cannot be made reactive: ${String(target)}`);
- }
- return target;
- }
- if (target[
- "__v_raw"
- /* ReactiveFlags.RAW */
- ] && !(isReadonly2 && target[
- "__v_isReactive"
- /* ReactiveFlags.IS_REACTIVE */
- ])) {
- return target;
- }
- const existingProxy = proxyMap.get(target);
- if (existingProxy) {
- return existingProxy;
- }
- const targetType = getTargetType(target);
- if (targetType === 0) {
- return target;
- }
- const proxy = new Proxy(target, targetType === 2 ? collectionHandlers : baseHandlers);
- proxyMap.set(target, proxy);
- return proxy;
- }
- function isReactive(value2) {
- if (isReadonly(value2)) {
- return isReactive(value2[
- "__v_raw"
- /* ReactiveFlags.RAW */
- ]);
- }
- return !!(value2 && value2[
- "__v_isReactive"
- /* ReactiveFlags.IS_REACTIVE */
- ]);
- }
- function isReadonly(value2) {
- return !!(value2 && value2[
- "__v_isReadonly"
- /* ReactiveFlags.IS_READONLY */
- ]);
- }
- function isShallow(value2) {
- return !!(value2 && value2[
- "__v_isShallow"
- /* ReactiveFlags.IS_SHALLOW */
- ]);
- }
- function isProxy(value2) {
- return isReactive(value2) || isReadonly(value2);
- }
- function toRaw(observed) {
- const raw = observed && observed[
- "__v_raw"
- /* ReactiveFlags.RAW */
- ];
- return raw ? toRaw(raw) : observed;
- }
- function markRaw(value2) {
- def(value2, "__v_skip", true);
- return value2;
- }
- const toReactive = (value2) => isObject$2(value2) ? reactive(value2) : value2;
- const toReadonly = (value2) => isObject$2(value2) ? readonly(value2) : value2;
- function trackRefValue(ref2) {
- if (shouldTrack && activeEffect) {
- ref2 = toRaw(ref2);
- {
- trackEffects(ref2.dep || (ref2.dep = createDep()), {
- target: ref2,
- type: "get",
- key: "value"
- });
- }
- }
- }
- function triggerRefValue(ref2, newVal) {
- ref2 = toRaw(ref2);
- const dep = ref2.dep;
- if (dep) {
- {
- triggerEffects(dep, {
- target: ref2,
- type: "set",
- key: "value",
- newValue: newVal
- });
- }
- }
- }
- function isRef(r) {
- return !!(r && r.__v_isRef === true);
- }
- function ref(value2) {
- return createRef(value2, false);
- }
- function createRef(rawValue, shallow) {
- if (isRef(rawValue)) {
- return rawValue;
- }
- return new RefImpl(rawValue, shallow);
- }
- class RefImpl {
- constructor(value2, __v_isShallow) {
- this.__v_isShallow = __v_isShallow;
- this.dep = void 0;
- this.__v_isRef = true;
- this._rawValue = __v_isShallow ? value2 : toRaw(value2);
- this._value = __v_isShallow ? value2 : toReactive(value2);
- }
- get value() {
- trackRefValue(this);
- return this._value;
- }
- set value(newVal) {
- const useDirectValue = this.__v_isShallow || isShallow(newVal) || isReadonly(newVal);
- newVal = useDirectValue ? newVal : toRaw(newVal);
- if (hasChanged(newVal, this._rawValue)) {
- this._rawValue = newVal;
- this._value = useDirectValue ? newVal : toReactive(newVal);
- triggerRefValue(this, newVal);
- }
- }
- }
- function unref(ref2) {
- return isRef(ref2) ? ref2.value : ref2;
- }
- const shallowUnwrapHandlers = {
- get: (target, key, receiver) => unref(Reflect.get(target, key, receiver)),
- set: (target, key, value2, receiver) => {
- const oldValue = target[key];
- if (isRef(oldValue) && !isRef(value2)) {
- oldValue.value = value2;
- return true;
- } else {
- return Reflect.set(target, key, value2, receiver);
- }
- }
- };
- function proxyRefs(objectWithRefs) {
- return isReactive(objectWithRefs) ? objectWithRefs : new Proxy(objectWithRefs, shallowUnwrapHandlers);
- }
- var _a;
- class ComputedRefImpl {
- constructor(getter, _setter, isReadonly2, isSSR) {
- this._setter = _setter;
- this.dep = void 0;
- this.__v_isRef = true;
- this[_a] = 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"
- /* ReactiveFlags.IS_READONLY */
- ] = isReadonly2;
- }
- get value() {
- const self = toRaw(this);
- trackRefValue(self);
- if (self._dirty || !self._cacheable) {
- self._dirty = false;
- self._value = self.effect.run();
- }
- return self._value;
- }
- set value(newValue) {
- this._setter(newValue);
- }
- }
- _a = "__v_isReadonly";
- function computed$1(getterOrOptions, debugOptions, isSSR = false) {
- let getter;
- let setter;
- const onlyGetter = isFunction$1(getterOrOptions);
- if (onlyGetter) {
- getter = getterOrOptions;
- setter = () => {
- console.warn("Write operation failed: computed value is readonly");
- };
- } else {
- getter = getterOrOptions.get;
- setter = getterOrOptions.set;
- }
- const cRef = new ComputedRefImpl(getter, setter, onlyGetter || !setter, isSSR);
- if (debugOptions && !isSSR) {
- cRef.effect.onTrack = debugOptions.onTrack;
- cRef.effect.onTrigger = debugOptions.onTrigger;
- }
- return cRef;
- }
- const stack = [];
- function pushWarningContext(vnode) {
- stack.push(vnode);
- }
- function popWarningContext() {
- stack.pop();
- }
- function warn$2(msg, ...args) {
- pauseTracking();
- const instance = stack.length ? stack[stack.length - 1].component : null;
- const appWarnHandler = instance && instance.appContext.config.warnHandler;
- const trace = getComponentTrace();
- if (appWarnHandler) {
- callWithErrorHandling(appWarnHandler, instance, 11, [
- msg + args.join(""),
- instance && instance.proxy,
- trace.map(({ vnode }) => `at <${formatComponentName(instance, vnode.type)}>`).join("\n"),
- trace
- ]);
- } else {
- const warnArgs = [`[Vue warn]: ${msg}`, ...args];
- if (trace.length && // avoid spamming console during tests
- true) {
- warnArgs.push(`
- `, ...formatTrace(trace));
- }
- console.warn(...warnArgs);
- }
- resetTracking();
- }
- function getComponentTrace() {
- let currentVNode = stack[stack.length - 1];
- if (!currentVNode) {
- return [];
- }
- const normalizedStack = [];
- while (currentVNode) {
- const last = normalizedStack[0];
- if (last && last.vnode === currentVNode) {
- last.recurseCount++;
- } else {
- normalizedStack.push({
- vnode: currentVNode,
- recurseCount: 0
- });
- }
- const parentInstance = currentVNode.component && currentVNode.component.parent;
- currentVNode = parentInstance && parentInstance.vnode;
- }
- return normalizedStack;
- }
- function formatTrace(trace) {
- const logs = [];
- trace.forEach((entry, i) => {
- logs.push(...i === 0 ? [] : [`
- `], ...formatTraceEntry(entry));
- });
- return logs;
- }
- function formatTraceEntry({ vnode, recurseCount }) {
- const postfix = recurseCount > 0 ? `... (${recurseCount} recursive calls)` : ``;
- const isRoot = vnode.component ? vnode.component.parent == null : false;
- const open = ` at <${formatComponentName(vnode.component, vnode.type, isRoot)}`;
- const close = `>` + postfix;
- return vnode.props ? [open, ...formatProps(vnode.props), close] : [open + close];
- }
- function formatProps(props2) {
- const res = [];
- const keys2 = Object.keys(props2);
- keys2.slice(0, 3).forEach((key) => {
- res.push(...formatProp(key, props2[key]));
- });
- if (keys2.length > 3) {
- res.push(` ...`);
- }
- return res;
- }
- function formatProp(key, value2, raw) {
- if (isString$1(value2)) {
- value2 = JSON.stringify(value2);
- return raw ? value2 : [`${key}=${value2}`];
- } else if (typeof value2 === "number" || typeof value2 === "boolean" || value2 == null) {
- return raw ? value2 : [`${key}=${value2}`];
- } else if (isRef(value2)) {
- value2 = formatProp(key, toRaw(value2.value), true);
- return raw ? value2 : [`${key}=Ref<`, value2, `>`];
- } else if (isFunction$1(value2)) {
- return [`${key}=fn${value2.name ? `<${value2.name}>` : ``}`];
- } else {
- value2 = toRaw(value2);
- return raw ? value2 : [`${key}=`, value2];
- }
- }
- const ErrorTypeStrings = {
- [
- "sp"
- /* LifecycleHooks.SERVER_PREFETCH */
- ]: "serverPrefetch hook",
- [
- "bc"
- /* LifecycleHooks.BEFORE_CREATE */
- ]: "beforeCreate hook",
- [
- "c"
- /* LifecycleHooks.CREATED */
- ]: "created hook",
- [
- "bm"
- /* LifecycleHooks.BEFORE_MOUNT */
- ]: "beforeMount hook",
- [
- "m"
- /* LifecycleHooks.MOUNTED */
- ]: "mounted hook",
- [
- "bu"
- /* LifecycleHooks.BEFORE_UPDATE */
- ]: "beforeUpdate hook",
- [
- "u"
- /* LifecycleHooks.UPDATED */
- ]: "updated",
- [
- "bum"
- /* LifecycleHooks.BEFORE_UNMOUNT */
- ]: "beforeUnmount hook",
- [
- "um"
- /* LifecycleHooks.UNMOUNTED */
- ]: "unmounted hook",
- [
- "a"
- /* LifecycleHooks.ACTIVATED */
- ]: "activated hook",
- [
- "da"
- /* LifecycleHooks.DEACTIVATED */
- ]: "deactivated hook",
- [
- "ec"
- /* LifecycleHooks.ERROR_CAPTURED */
- ]: "errorCaptured hook",
- [
- "rtc"
- /* LifecycleHooks.RENDER_TRACKED */
- ]: "renderTracked hook",
- [
- "rtg"
- /* LifecycleHooks.RENDER_TRIGGERED */
- ]: "renderTriggered hook",
- [
- 0
- /* ErrorCodes.SETUP_FUNCTION */
- ]: "setup function",
- [
- 1
- /* ErrorCodes.RENDER_FUNCTION */
- ]: "render function",
- [
- 2
- /* ErrorCodes.WATCH_GETTER */
- ]: "watcher getter",
- [
- 3
- /* ErrorCodes.WATCH_CALLBACK */
- ]: "watcher callback",
- [
- 4
- /* ErrorCodes.WATCH_CLEANUP */
- ]: "watcher cleanup function",
- [
- 5
- /* ErrorCodes.NATIVE_EVENT_HANDLER */
- ]: "native event handler",
- [
- 6
- /* ErrorCodes.COMPONENT_EVENT_HANDLER */
- ]: "component event handler",
- [
- 7
- /* ErrorCodes.VNODE_HOOK */
- ]: "vnode hook",
- [
- 8
- /* ErrorCodes.DIRECTIVE_HOOK */
- ]: "directive hook",
- [
- 9
- /* ErrorCodes.TRANSITION_HOOK */
- ]: "transition hook",
- [
- 10
- /* ErrorCodes.APP_ERROR_HANDLER */
- ]: "app errorHandler",
- [
- 11
- /* ErrorCodes.APP_WARN_HANDLER */
- ]: "app warnHandler",
- [
- 12
- /* ErrorCodes.FUNCTION_REF */
- ]: "ref function",
- [
- 13
- /* ErrorCodes.ASYNC_COMPONENT_LOADER */
- ]: "async component loader",
- [
- 14
- /* ErrorCodes.SCHEDULER */
- ]: "scheduler flush. This is likely a Vue internals bug. Please open an issue at https://new-issue.vuejs.org/?repo=vuejs/core"
- };
- function callWithErrorHandling(fn, instance, type2, args) {
- let res;
- try {
- res = args ? fn(...args) : fn();
- } catch (err) {
- handleError(err, instance, type2);
- }
- return res;
- }
- function callWithAsyncErrorHandling(fn, instance, type2, args) {
- if (isFunction$1(fn)) {
- const res = callWithErrorHandling(fn, instance, type2, args);
- if (res && isPromise(res)) {
- res.catch((err) => {
- handleError(err, instance, type2);
- });
- }
- return res;
- }
- const values = [];
- for (let i = 0; i < fn.length; i++) {
- values.push(callWithAsyncErrorHandling(fn[i], instance, type2, args));
- }
- return values;
- }
- function handleError(err, instance, type2, throwInDev = true) {
- const contextVNode = instance ? instance.vnode : null;
- if (instance) {
- let cur = instance.parent;
- const exposedInstance = instance.proxy;
- const errorInfo = ErrorTypeStrings[type2] || type2;
- while (cur) {
- const errorCapturedHooks = cur.ec;
- if (errorCapturedHooks) {
- for (let i = 0; i < errorCapturedHooks.length; i++) {
- if (errorCapturedHooks[i](err, exposedInstance, errorInfo) === false) {
- return;
- }
- }
- }
- cur = cur.parent;
- }
- const appErrorHandler = instance.appContext.config.errorHandler;
- if (appErrorHandler) {
- callWithErrorHandling(appErrorHandler, null, 10, [err, exposedInstance, errorInfo]);
- return;
- }
- }
- logError(err, type2, contextVNode, throwInDev);
- }
- function logError(err, type2, contextVNode, throwInDev = true) {
- {
- const info = ErrorTypeStrings[type2] || type2;
- if (contextVNode) {
- pushWarningContext(contextVNode);
- }
- warn$2(`Unhandled error${info ? ` during execution of ${info}` : ``}`);
- if (contextVNode) {
- popWarningContext();
- }
- if (throwInDev) {
- console.error(err);
- } else {
- console.error(err);
- }
- }
- }
- let isFlushing = false;
- let isFlushPending = false;
- const queue = [];
- let flushIndex = 0;
- const pendingPostFlushCbs = [];
- let activePostFlushCbs = null;
- let postFlushIndex = 0;
- const resolvedPromise = /* @__PURE__ */ Promise.resolve();
- let currentFlushPromise = null;
- const RECURSION_LIMIT = 100;
- function nextTick$1(fn) {
- const p2 = currentFlushPromise || resolvedPromise;
- return fn ? p2.then(this ? fn.bind(this) : fn) : p2;
- }
- function findInsertionIndex(id) {
- let start = flushIndex + 1;
- let end = queue.length;
- while (start < end) {
- const middle = start + end >>> 1;
- const middleJobId = getId(queue[middle]);
- middleJobId < id ? start = middle + 1 : end = middle;
- }
- return start;
- }
- function queueJob(job) {
- if (!queue.length || !queue.includes(job, isFlushing && job.allowRecurse ? flushIndex + 1 : flushIndex)) {
- if (job.id == null) {
- queue.push(job);
- } else {
- queue.splice(findInsertionIndex(job.id), 0, job);
- }
- queueFlush();
- }
- }
- function queueFlush() {
- if (!isFlushing && !isFlushPending) {
- isFlushPending = true;
- currentFlushPromise = resolvedPromise.then(flushJobs);
- }
- }
- function hasQueueJob(job) {
- return queue.indexOf(job) > -1;
- }
- function invalidateJob(job) {
- const i = queue.indexOf(job);
- if (i > flushIndex) {
- queue.splice(i, 1);
- }
- }
- function queuePostFlushCb(cb) {
- if (!isArray$2(cb)) {
- if (!activePostFlushCbs || !activePostFlushCbs.includes(cb, cb.allowRecurse ? postFlushIndex + 1 : postFlushIndex)) {
- pendingPostFlushCbs.push(cb);
- }
- } else {
- pendingPostFlushCbs.push(...cb);
- }
- queueFlush();
- }
- function flushPreFlushCbs(seen, i = isFlushing ? flushIndex + 1 : 0) {
- {
- seen = seen || /* @__PURE__ */ new Map();
- }
- for (; i < queue.length; i++) {
- const cb = queue[i];
- if (cb && cb.pre) {
- if (checkRecursiveUpdates(seen, cb)) {
- continue;
- }
- queue.splice(i, 1);
- i--;
- cb();
- }
- }
- }
- function flushPostFlushCbs(seen) {
- if (pendingPostFlushCbs.length) {
- const deduped = [...new Set(pendingPostFlushCbs)];
- pendingPostFlushCbs.length = 0;
- if (activePostFlushCbs) {
- activePostFlushCbs.push(...deduped);
- return;
- }
- activePostFlushCbs = deduped;
- {
- seen = seen || /* @__PURE__ */ new Map();
- }
- activePostFlushCbs.sort((a, b) => getId(a) - getId(b));
- for (postFlushIndex = 0; postFlushIndex < activePostFlushCbs.length; postFlushIndex++) {
- if (checkRecursiveUpdates(seen, activePostFlushCbs[postFlushIndex])) {
- continue;
- }
- activePostFlushCbs[postFlushIndex]();
- }
- activePostFlushCbs = null;
- postFlushIndex = 0;
- }
- }
- const getId = (job) => job.id == null ? Infinity : job.id;
- const comparator = (a, b) => {
- const diff2 = getId(a) - getId(b);
- if (diff2 === 0) {
- if (a.pre && !b.pre)
- return -1;
- if (b.pre && !a.pre)
- return 1;
- }
- return diff2;
- };
- function flushJobs(seen) {
- isFlushPending = false;
- isFlushing = true;
- {
- seen = seen || /* @__PURE__ */ new Map();
- }
- queue.sort(comparator);
- const check = (job) => checkRecursiveUpdates(seen, job);
- try {
- for (flushIndex = 0; flushIndex < queue.length; flushIndex++) {
- const job = queue[flushIndex];
- if (job && job.active !== false) {
- if (check(job)) {
- continue;
- }
- callWithErrorHandling(
- job,
- null,
- 14
- /* ErrorCodes.SCHEDULER */
- );
- }
- }
- } finally {
- flushIndex = 0;
- queue.length = 0;
- flushPostFlushCbs(seen);
- isFlushing = false;
- currentFlushPromise = null;
- if (queue.length || pendingPostFlushCbs.length) {
- flushJobs(seen);
- }
- }
- }
- function checkRecursiveUpdates(seen, fn) {
- if (!seen.has(fn)) {
- seen.set(fn, 1);
- } else {
- const count = seen.get(fn);
- if (count > RECURSION_LIMIT) {
- const instance = fn.ownerInstance;
- const componentName = instance && getComponentName(instance.type);
- warn$2(`Maximum recursive updates exceeded${componentName ? ` in component <${componentName}>` : ``}. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.`);
- return true;
- } else {
- seen.set(fn, count + 1);
- }
- }
- }
- let devtools;
- let buffer = [];
- let devtoolsNotInstalled = false;
- function emit$1(event, ...args) {
- if (devtools) {
- devtools.emit(event, ...args);
- } else if (!devtoolsNotInstalled) {
- buffer.push({ event, args });
- }
- }
- function setDevtoolsHook(hook, target) {
- var _a2, _b;
- devtools = hook;
- if (devtools) {
- devtools.enabled = true;
- buffer.forEach(({ event, args }) => devtools.emit(event, ...args));
- buffer = [];
- } else if (
- // handle late devtools injection - only do this if we are in an actual
- // browser environment to avoid the timer handle stalling test runner exit
- // (#4815)
- typeof window !== "undefined" && // some envs mock window but not fully
- // eslint-disable-next-line no-restricted-globals
- window.HTMLElement && // also exclude jsdom
- // eslint-disable-next-line no-restricted-globals
- !((_b = (_a2 = window.navigator) === null || _a2 === void 0 ? void 0 : _a2.userAgent) === null || _b === void 0 ? void 0 : _b.includes("jsdom"))
- ) {
- const replay = target.__VUE_DEVTOOLS_HOOK_REPLAY__ = target.__VUE_DEVTOOLS_HOOK_REPLAY__ || [];
- replay.push((newHook) => {
- setDevtoolsHook(newHook, target);
- });
- setTimeout(() => {
- if (!devtools) {
- target.__VUE_DEVTOOLS_HOOK_REPLAY__ = null;
- devtoolsNotInstalled = true;
- buffer = [];
- }
- }, 3e3);
- } else {
- devtoolsNotInstalled = true;
- buffer = [];
- }
- }
- function devtoolsInitApp(app, version2) {
- emit$1("app:init", app, version2, {
- Fragment,
- Text: Text$1,
- Comment,
- Static
- });
- }
- const devtoolsComponentAdded = /* @__PURE__ */ createDevtoolsComponentHook(
- "component:added"
- /* DevtoolsHooks.COMPONENT_ADDED */
- );
- const devtoolsComponentUpdated = /* @__PURE__ */ createDevtoolsComponentHook(
- "component:updated"
- /* DevtoolsHooks.COMPONENT_UPDATED */
- );
- const _devtoolsComponentRemoved = /* @__PURE__ */ createDevtoolsComponentHook(
- "component:removed"
- /* DevtoolsHooks.COMPONENT_REMOVED */
- );
- const devtoolsComponentRemoved = (component) => {
- if (devtools && typeof devtools.cleanupBuffer === "function" && // remove the component if it wasn't buffered
- !devtools.cleanupBuffer(component)) {
- _devtoolsComponentRemoved(component);
- }
- };
- function createDevtoolsComponentHook(hook) {
- return (component) => {
- emit$1(
- hook,
- component.appContext.app,
- component.uid,
- // fixed by xxxxxx
- // 为 0 是 App,无 parent 是 Page 指向 App
- component.uid === 0 ? void 0 : component.parent ? component.parent.uid : 0,
- component
- );
- };
- }
- const devtoolsPerfStart = /* @__PURE__ */ createDevtoolsPerformanceHook(
- "perf:start"
- /* DevtoolsHooks.PERFORMANCE_START */
- );
- const devtoolsPerfEnd = /* @__PURE__ */ createDevtoolsPerformanceHook(
- "perf:end"
- /* DevtoolsHooks.PERFORMANCE_END */
- );
- function createDevtoolsPerformanceHook(hook) {
- return (component, type2, time) => {
- emit$1(hook, component.appContext.app, component.uid, component, type2, time);
- };
- }
- function devtoolsComponentEmit(component, event, params) {
- emit$1("component:emit", component.appContext.app, component, event, params);
- }
- function emit(instance, event, ...rawArgs) {
- if (instance.isUnmounted)
- return;
- const props2 = instance.vnode.props || EMPTY_OBJ;
- {
- const { emitsOptions, propsOptions: [propsOptions] } = instance;
- if (emitsOptions) {
- if (!(event in emitsOptions) && true) {
- if (!propsOptions || !(toHandlerKey(event) in propsOptions)) {
- warn$2(`Component emitted event "${event}" but it is neither declared in the emits option nor as an "${toHandlerKey(event)}" prop.`);
- }
- } else {
- const validator = emitsOptions[event];
- if (isFunction$1(validator)) {
- const isValid2 = validator(...rawArgs);
- if (!isValid2) {
- warn$2(`Invalid event arguments: event validation failed for event "${event}".`);
- }
- }
- }
- }
- }
- let args = rawArgs;
- const isModelListener2 = event.startsWith("update:");
- const modelArg = isModelListener2 && event.slice(7);
- if (modelArg && modelArg in props2) {
- const modifiersKey = `${modelArg === "modelValue" ? "model" : modelArg}Modifiers`;
- const { number: number3, trim: trim2 } = props2[modifiersKey] || EMPTY_OBJ;
- if (trim2) {
- args = rawArgs.map((a) => isString$1(a) ? a.trim() : a);
- }
- if (number3) {
- args = rawArgs.map(looseToNumber);
- }
- }
- {
- devtoolsComponentEmit(instance, event, args);
- }
- {
- const lowerCaseEvent = event.toLowerCase();
- if (lowerCaseEvent !== event && props2[toHandlerKey(lowerCaseEvent)]) {
- warn$2(`Event "${lowerCaseEvent}" is emitted in component ${formatComponentName(instance, instance.type)} but the handler is registered for "${event}". Note that HTML attributes are case-insensitive and you cannot use v-on to listen to camelCase events when using in-DOM templates. You should probably use "${hyphenate(event)}" instead of "${event}".`);
- }
- }
- let handlerName;
- let handler = props2[handlerName = toHandlerKey(event)] || // also try camelCase event handler (#2249)
- props2[handlerName = toHandlerKey(camelize(event))];
- if (!handler && isModelListener2) {
- handler = props2[handlerName = toHandlerKey(hyphenate(event))];
- }
- if (handler) {
- callWithAsyncErrorHandling(handler, instance, 6, args);
- }
- const onceHandler = props2[handlerName + `Once`];
- if (onceHandler) {
- if (!instance.emitted) {
- instance.emitted = {};
- } else if (instance.emitted[handlerName]) {
- return;
- }
- instance.emitted[handlerName] = true;
- callWithAsyncErrorHandling(onceHandler, instance, 6, args);
- }
- }
- function normalizeEmitsOptions(comp, appContext, asMixin = false) {
- const cache = appContext.emitsCache;
- const cached = cache.get(comp);
- if (cached !== void 0) {
- return cached;
- }
- const raw = comp.emits;
- let normalized = {};
- let hasExtends = false;
- if (!isFunction$1(comp)) {
- const extendEmits = (raw2) => {
- const normalizedFromExtend = normalizeEmitsOptions(raw2, appContext, true);
- if (normalizedFromExtend) {
- hasExtends = true;
- extend$1(normalized, normalizedFromExtend);
- }
- };
- if (!asMixin && appContext.mixins.length) {
- appContext.mixins.forEach(extendEmits);
- }
- if (comp.extends) {
- extendEmits(comp.extends);
- }
- if (comp.mixins) {
- comp.mixins.forEach(extendEmits);
- }
- }
- if (!raw && !hasExtends) {
- if (isObject$2(comp)) {
- cache.set(comp, null);
- }
- return null;
- }
- if (isArray$2(raw)) {
- raw.forEach((key) => normalized[key] = null);
- } else {
- extend$1(normalized, raw);
- }
- if (isObject$2(comp)) {
- cache.set(comp, normalized);
- }
- return normalized;
- }
- function isEmitListener(options, key) {
- if (!options || !isOn(key)) {
- return false;
- }
- key = key.slice(2).replace(/Once$/, "");
- return hasOwn(options, key[0].toLowerCase() + key.slice(1)) || hasOwn(options, hyphenate(key)) || hasOwn(options, key);
- }
- let currentRenderingInstance = null;
- function setCurrentRenderingInstance(instance) {
- const prev = currentRenderingInstance;
- currentRenderingInstance = instance;
- instance && instance.type.__scopeId || null;
- return prev;
- }
- function provide(key, value2) {
- if (!currentInstance) {
- {
- warn$2(`provide() can only be used inside setup().`);
- }
- } else {
- let provides = currentInstance.provides;
- const parentProvides = currentInstance.parent && currentInstance.parent.provides;
- if (parentProvides === provides) {
- provides = currentInstance.provides = Object.create(parentProvides);
- }
- provides[key] = value2;
- if (currentInstance.type.mpType === "app") {
- currentInstance.appContext.app.provide(key, value2);
- }
- }
- }
- function inject(key, defaultValue, treatDefaultAsFactory = false) {
- const instance = currentInstance || currentRenderingInstance;
- if (instance) {
- const provides = instance.parent == null ? instance.vnode.appContext && instance.vnode.appContext.provides : instance.parent.provides;
- if (provides && key in provides) {
- return provides[key];
- } else if (arguments.length > 1) {
- return treatDefaultAsFactory && isFunction$1(defaultValue) ? defaultValue.call(instance.proxy) : defaultValue;
- } else {
- warn$2(`injection "${String(key)}" not found.`);
- }
- } else {
- warn$2(`inject() can only be used inside setup() or functional components.`);
- }
- }
- const INITIAL_WATCHER_VALUE = {};
- function watch(source, cb, options) {
- if (!isFunction$1(cb)) {
- warn$2(`\`watch(fn, options?)\` signature has been moved to a separate API. Use \`watchEffect(fn, options?)\` instead. \`watch\` now only supports \`watch(source, cb, options?) signature.`);
- }
- return doWatch(source, cb, options);
- }
- function doWatch(source, cb, { immediate, deep, flush, onTrack, onTrigger } = EMPTY_OBJ) {
- if (!cb) {
- if (immediate !== void 0) {
- warn$2(`watch() "immediate" option is only respected when using the watch(source, callback, options?) signature.`);
- }
- if (deep !== void 0) {
- warn$2(`watch() "deep" option is only respected when using the watch(source, callback, options?) signature.`);
- }
- }
- const warnInvalidSource = (s2) => {
- warn$2(`Invalid watch source: `, s2, `A watch source can only be a getter/effect function, a ref, a reactive object, or an array of these types.`);
- };
- const instance = getCurrentScope() === (currentInstance === null || currentInstance === void 0 ? void 0 : currentInstance.scope) ? currentInstance : null;
- let getter;
- let forceTrigger = false;
- let isMultiSource = false;
- if (isRef(source)) {
- getter = () => source.value;
- forceTrigger = isShallow(source);
- } else if (isReactive(source)) {
- getter = () => source;
- deep = true;
- } else if (isArray$2(source)) {
- isMultiSource = true;
- forceTrigger = source.some((s2) => isReactive(s2) || isShallow(s2));
- getter = () => source.map((s2) => {
- if (isRef(s2)) {
- return s2.value;
- } else if (isReactive(s2)) {
- return traverse(s2);
- } else if (isFunction$1(s2)) {
- return callWithErrorHandling(
- s2,
- instance,
- 2
- /* ErrorCodes.WATCH_GETTER */
- );
- } else {
- warnInvalidSource(s2);
- }
- });
- } else if (isFunction$1(source)) {
- if (cb) {
- getter = () => callWithErrorHandling(
- source,
- instance,
- 2
- /* ErrorCodes.WATCH_GETTER */
- );
- } else {
- getter = () => {
- if (instance && instance.isUnmounted) {
- return;
- }
- if (cleanup) {
- cleanup();
- }
- return callWithAsyncErrorHandling(source, instance, 3, [onCleanup]);
- };
- }
- } else {
- getter = NOOP;
- warnInvalidSource(source);
- }
- if (cb && deep) {
- const baseGetter = getter;
- getter = () => traverse(baseGetter());
- }
- let cleanup;
- let onCleanup = (fn) => {
- cleanup = effect.onStop = () => {
- callWithErrorHandling(
- fn,
- instance,
- 4
- /* ErrorCodes.WATCH_CLEANUP */
- );
- };
- };
- let oldValue = isMultiSource ? new Array(source.length).fill(INITIAL_WATCHER_VALUE) : INITIAL_WATCHER_VALUE;
- const job = () => {
- if (!effect.active) {
- return;
- }
- if (cb) {
- const newValue = effect.run();
- if (deep || forceTrigger || (isMultiSource ? newValue.some((v, i) => hasChanged(v, oldValue[i])) : hasChanged(newValue, oldValue)) || false) {
- if (cleanup) {
- cleanup();
- }
- callWithAsyncErrorHandling(cb, instance, 3, [
- newValue,
- // pass undefined as the old value when it's changed for the first time
- oldValue === INITIAL_WATCHER_VALUE ? void 0 : isMultiSource && oldValue[0] === INITIAL_WATCHER_VALUE ? [] : oldValue,
- onCleanup
- ]);
- oldValue = newValue;
- }
- } else {
- effect.run();
- }
- };
- job.allowRecurse = !!cb;
- let scheduler;
- if (flush === "sync") {
- scheduler = job;
- } else if (flush === "post") {
- scheduler = () => queuePostRenderEffect$1(job, instance && instance.suspense);
- } else {
- job.pre = true;
- if (instance)
- job.id = instance.uid;
- scheduler = () => queueJob(job);
- }
- const effect = new ReactiveEffect(getter, scheduler);
- {
- effect.onTrack = onTrack;
- effect.onTrigger = onTrigger;
- }
- if (cb) {
- if (immediate) {
- job();
- } else {
- oldValue = effect.run();
- }
- } else if (flush === "post") {
- queuePostRenderEffect$1(effect.run.bind(effect), instance && instance.suspense);
- } else {
- effect.run();
- }
- const unwatch = () => {
- effect.stop();
- if (instance && instance.scope) {
- remove(instance.scope.effects, effect);
- }
- };
- return unwatch;
- }
- function instanceWatch(source, value2, options) {
- const publicThis = this.proxy;
- const getter = isString$1(source) ? source.includes(".") ? createPathGetter(publicThis, source) : () => publicThis[source] : source.bind(publicThis, publicThis);
- let cb;
- if (isFunction$1(value2)) {
- cb = value2;
- } else {
- cb = value2.handler;
- options = value2;
- }
- const cur = currentInstance;
- setCurrentInstance(this);
- const res = doWatch(getter, cb.bind(publicThis), options);
- if (cur) {
- setCurrentInstance(cur);
- } else {
- unsetCurrentInstance();
- }
- return res;
- }
- function createPathGetter(ctx, path) {
- const segments = path.split(".");
- return () => {
- let cur = ctx;
- for (let i = 0; i < segments.length && cur; i++) {
- cur = cur[segments[i]];
- }
- return cur;
- };
- }
- function traverse(value2, seen) {
- if (!isObject$2(value2) || value2[
- "__v_skip"
- /* ReactiveFlags.SKIP */
- ]) {
- return value2;
- }
- seen = seen || /* @__PURE__ */ new Set();
- if (seen.has(value2)) {
- return value2;
- }
- seen.add(value2);
- if (isRef(value2)) {
- traverse(value2.value, seen);
- } else if (isArray$2(value2)) {
- for (let i = 0; i < value2.length; i++) {
- traverse(value2[i], seen);
- }
- } else if (isSet(value2) || isMap(value2)) {
- value2.forEach((v) => {
- traverse(v, seen);
- });
- } else if (isPlainObject$1(value2)) {
- for (const key in value2) {
- traverse(value2[key], seen);
- }
- }
- return value2;
- }
- function defineComponent(options) {
- return isFunction$1(options) ? { setup: options, name: options.name } : options;
- }
- const isKeepAlive = (vnode) => vnode.type.__isKeepAlive;
- function onActivated(hook, target) {
- registerKeepAliveHook(hook, "a", target);
- }
- function onDeactivated(hook, target) {
- registerKeepAliveHook(hook, "da", target);
- }
- function registerKeepAliveHook(hook, type2, target = currentInstance) {
- const wrappedHook = hook.__wdc || (hook.__wdc = () => {
- let current = target;
- while (current) {
- if (current.isDeactivated) {
- return;
- }
- current = current.parent;
- }
- return hook();
- });
- injectHook(type2, wrappedHook, target);
- if (target) {
- let current = target.parent;
- while (current && current.parent) {
- if (isKeepAlive(current.parent.vnode)) {
- injectToKeepAliveRoot(wrappedHook, type2, target, current);
- }
- current = current.parent;
- }
- }
- }
- function injectToKeepAliveRoot(hook, type2, target, keepAliveRoot) {
- const injected = injectHook(
- type2,
- hook,
- keepAliveRoot,
- true
- /* prepend */
- );
- onUnmounted(() => {
- remove(keepAliveRoot[type2], injected);
- }, target);
- }
- function injectHook(type2, hook, target = currentInstance, prepend = false) {
- if (target) {
- if (isRootHook(type2)) {
- target = target.root;
- }
- const hooks2 = target[type2] || (target[type2] = []);
- const wrappedHook = hook.__weh || (hook.__weh = (...args) => {
- if (target.isUnmounted) {
- return;
- }
- pauseTracking();
- setCurrentInstance(target);
- const res = callWithAsyncErrorHandling(hook, target, type2, args);
- unsetCurrentInstance();
- resetTracking();
- return res;
- });
- if (prepend) {
- hooks2.unshift(wrappedHook);
- } else {
- hooks2.push(wrappedHook);
- }
- return wrappedHook;
- } else {
- const apiName = toHandlerKey((ErrorTypeStrings[type2] || type2.replace(/^on/, "")).replace(/ hook$/, ""));
- warn$2(`${apiName} is called when there is no active component instance to be associated with. Lifecycle injection APIs can only be used during execution of setup().`);
- }
- }
- const createHook$1 = (lifecycle) => (hook, target = currentInstance) => (
- // post-create lifecycle registrations are noops during SSR (except for serverPrefetch)
- (!isInSSRComponentSetup || lifecycle === "sp") && injectHook(lifecycle, (...args) => hook(...args), target)
- );
- const onBeforeMount = createHook$1(
- "bm"
- /* LifecycleHooks.BEFORE_MOUNT */
- );
- const onMounted = createHook$1(
- "m"
- /* LifecycleHooks.MOUNTED */
- );
- const onBeforeUpdate = createHook$1(
- "bu"
- /* LifecycleHooks.BEFORE_UPDATE */
- );
- const onUpdated = createHook$1(
- "u"
- /* LifecycleHooks.UPDATED */
- );
- const onBeforeUnmount = createHook$1(
- "bum"
- /* LifecycleHooks.BEFORE_UNMOUNT */
- );
- const onUnmounted = createHook$1(
- "um"
- /* LifecycleHooks.UNMOUNTED */
- );
- const onServerPrefetch = createHook$1(
- "sp"
- /* LifecycleHooks.SERVER_PREFETCH */
- );
- const onRenderTriggered = createHook$1(
- "rtg"
- /* LifecycleHooks.RENDER_TRIGGERED */
- );
- const onRenderTracked = createHook$1(
- "rtc"
- /* LifecycleHooks.RENDER_TRACKED */
- );
- function onErrorCaptured(hook, target = currentInstance) {
- injectHook("ec", hook, target);
- }
- function validateDirectiveName(name) {
- if (isBuiltInDirective(name)) {
- warn$2("Do not use built-in directive ids as custom directive id: " + name);
- }
- }
- const COMPONENTS = "components";
- function resolveComponent(name, maybeSelfReference) {
- return resolveAsset(COMPONENTS, name, true, maybeSelfReference) || name;
- }
- function resolveAsset(type2, name, warnMissing = true, maybeSelfReference = false) {
- const instance = currentRenderingInstance || currentInstance;
- if (instance) {
- const Component2 = instance.type;
- if (type2 === COMPONENTS) {
- const selfName = getComponentName(
- Component2,
- false
- /* do not include inferred name to avoid breaking existing code */
- );
- if (selfName && (selfName === name || selfName === camelize(name) || selfName === capitalize(camelize(name)))) {
- return Component2;
- }
- }
- const res = (
- // local registration
- // check instance[type] first which is resolved for options API
- resolve(instance[type2] || Component2[type2], name) || // global registration
- resolve(instance.appContext[type2], name)
- );
- if (!res && maybeSelfReference) {
- return Component2;
- }
- if (warnMissing && !res) {
- const extra = type2 === COMPONENTS ? `
- If this is a native custom element, make sure to exclude it from component resolution via compilerOptions.isCustomElement.` : ``;
- warn$2(`Failed to resolve ${type2.slice(0, -1)}: ${name}${extra}`);
- }
- return res;
- } else {
- warn$2(`resolve${capitalize(type2.slice(0, -1))} can only be used in render() or setup().`);
- }
- }
- function resolve(registry, name) {
- return registry && (registry[name] || registry[camelize(name)] || registry[capitalize(camelize(name))]);
- }
- const getPublicInstance = (i) => {
- if (!i)
- return null;
- if (isStatefulComponent(i))
- return getExposeProxy(i) || i.proxy;
- return getPublicInstance(i.parent);
- };
- const publicPropertiesMap = (
- // Move PURE marker to new line to workaround compiler discarding it
- // due to type annotation
- /* @__PURE__ */ extend$1(/* @__PURE__ */ Object.create(null), {
- $: (i) => i,
- // fixed by xxxxxx vue-i18n 在 dev 模式,访问了 $el,故模拟一个假的
- // $el: i => i.vnode.el,
- $el: (i) => i.__$el || (i.__$el = {}),
- $data: (i) => i.data,
- $props: (i) => shallowReadonly(i.props),
- $attrs: (i) => shallowReadonly(i.attrs),
- $slots: (i) => shallowReadonly(i.slots),
- $refs: (i) => shallowReadonly(i.refs),
- $parent: (i) => getPublicInstance(i.parent),
- $root: (i) => getPublicInstance(i.root),
- $emit: (i) => i.emit,
- $options: (i) => resolveMergedOptions(i),
- $forceUpdate: (i) => i.f || (i.f = () => queueJob(i.update)),
- // $nextTick: i => i.n || (i.n = nextTick.bind(i.proxy!)),// fixed by xxxxxx
- $watch: (i) => instanceWatch.bind(i)
- })
- );
- const isReservedPrefix = (key) => key === "_" || key === "$";
- const hasSetupBinding = (state, key) => state !== EMPTY_OBJ && !state.__isScriptSetup && hasOwn(state, key);
- const PublicInstanceProxyHandlers = {
- get({ _: instance }, key) {
- const { ctx, setupState, data, props: props2, accessCache, type: type2, appContext } = instance;
- if (key === "__isVue") {
- return true;
- }
- let normalizedProps;
- if (key[0] !== "$") {
- const n2 = accessCache[key];
- if (n2 !== void 0) {
- switch (n2) {
- case 1:
- return setupState[key];
- case 2:
- return data[key];
- case 4:
- return ctx[key];
- case 3:
- return props2[key];
- }
- } else if (hasSetupBinding(setupState, key)) {
- accessCache[key] = 1;
- return setupState[key];
- } else if (data !== EMPTY_OBJ && hasOwn(data, key)) {
- accessCache[key] = 2;
- return data[key];
- } else if (
- // only cache other properties when instance has declared (thus stable)
- // props
- (normalizedProps = instance.propsOptions[0]) && hasOwn(normalizedProps, key)
- ) {
- accessCache[key] = 3;
- return props2[key];
- } else if (ctx !== EMPTY_OBJ && hasOwn(ctx, key)) {
- accessCache[key] = 4;
- return ctx[key];
- } else if (shouldCacheAccess) {
- accessCache[key] = 0;
- }
- }
- const publicGetter = publicPropertiesMap[key];
- let cssModule, globalProperties;
- if (publicGetter) {
- if (key === "$attrs") {
- track(instance, "get", key);
- }
- return publicGetter(instance);
- } else if (
- // css module (injected by vue-loader)
- (cssModule = type2.__cssModules) && (cssModule = cssModule[key])
- ) {
- return cssModule;
- } else if (ctx !== EMPTY_OBJ && hasOwn(ctx, key)) {
- accessCache[key] = 4;
- return ctx[key];
- } else if (
- // global properties
- globalProperties = appContext.config.globalProperties, hasOwn(globalProperties, key)
- ) {
- {
- return globalProperties[key];
- }
- } else if (currentRenderingInstance && (!isString$1(key) || // #1091 avoid internal isRef/isVNode checks on component instance leading
- // to infinite warning loop
- key.indexOf("__v") !== 0)) {
- if (data !== EMPTY_OBJ && isReservedPrefix(key[0]) && hasOwn(data, key)) {
- warn$2(`Property ${JSON.stringify(key)} must be accessed via $data because it starts with a reserved character ("$" or "_") and is not proxied on the render context.`);
- } else if (instance === currentRenderingInstance) {
- warn$2(`Property ${JSON.stringify(key)} was accessed during render but is not defined on instance.`);
- }
- }
- },
- set({ _: instance }, key, value2) {
- const { data, setupState, ctx } = instance;
- if (hasSetupBinding(setupState, key)) {
- setupState[key] = value2;
- return true;
- } else if (setupState.__isScriptSetup && hasOwn(setupState, key)) {
- warn$2(`Cannot mutate <script setup> binding "${key}" from Options API.`);
- return false;
- } else if (data !== EMPTY_OBJ && hasOwn(data, key)) {
- data[key] = value2;
- return true;
- } else if (hasOwn(instance.props, key)) {
- warn$2(`Attempting to mutate prop "${key}". Props are readonly.`);
- return false;
- }
- if (key[0] === "$" && key.slice(1) in instance) {
- warn$2(`Attempting to mutate public property "${key}". Properties starting with $ are reserved and readonly.`);
- return false;
- } else {
- if (key in instance.appContext.config.globalProperties) {
- Object.defineProperty(ctx, key, {
- enumerable: true,
- configurable: true,
- value: value2
- });
- } else {
- ctx[key] = value2;
- }
- }
- return true;
- },
- has({ _: { data, setupState, accessCache, ctx, appContext, propsOptions } }, key) {
- let normalizedProps;
- return !!accessCache[key] || data !== EMPTY_OBJ && hasOwn(data, key) || hasSetupBinding(setupState, key) || (normalizedProps = propsOptions[0]) && hasOwn(normalizedProps, key) || hasOwn(ctx, key) || hasOwn(publicPropertiesMap, key) || hasOwn(appContext.config.globalProperties, key);
- },
- defineProperty(target, key, descriptor) {
- if (descriptor.get != null) {
- target._.accessCache[key] = 0;
- } else if (hasOwn(descriptor, "value")) {
- this.set(target, key, descriptor.value, null);
- }
- return Reflect.defineProperty(target, key, descriptor);
- }
- };
- {
- PublicInstanceProxyHandlers.ownKeys = (target) => {
- warn$2(`Avoid app logic that relies on enumerating keys on a component instance. The keys will be empty in production mode to avoid performance overhead.`);
- return Reflect.ownKeys(target);
- };
- }
- function createDevRenderContext(instance) {
- const target = {};
- Object.defineProperty(target, `_`, {
- configurable: true,
- enumerable: false,
- get: () => instance
- });
- Object.keys(publicPropertiesMap).forEach((key) => {
- Object.defineProperty(target, key, {
- configurable: true,
- enumerable: false,
- get: () => publicPropertiesMap[key](instance),
- // intercepted by the proxy so no need for implementation,
- // but needed to prevent set errors
- set: NOOP
- });
- });
- return target;
- }
- function exposePropsOnRenderContext(instance) {
- const { ctx, propsOptions: [propsOptions] } = instance;
- if (propsOptions) {
- Object.keys(propsOptions).forEach((key) => {
- Object.defineProperty(ctx, key, {
- enumerable: true,
- configurable: true,
- get: () => instance.props[key],
- set: NOOP
- });
- });
- }
- }
- function exposeSetupStateOnRenderContext(instance) {
- const { ctx, setupState } = instance;
- Object.keys(toRaw(setupState)).forEach((key) => {
- if (!setupState.__isScriptSetup) {
- if (isReservedPrefix(key[0])) {
- warn$2(`setup() return property ${JSON.stringify(key)} should not start with "$" or "_" which are reserved prefixes for Vue internals.`);
- return;
- }
- Object.defineProperty(ctx, key, {
- enumerable: true,
- configurable: true,
- get: () => setupState[key],
- set: NOOP
- });
- }
- });
- }
- function createDuplicateChecker() {
- const cache = /* @__PURE__ */ Object.create(null);
- return (type2, key) => {
- if (cache[key]) {
- warn$2(`${type2} property "${key}" is already defined in ${cache[key]}.`);
- } else {
- cache[key] = type2;
- }
- };
- }
- let shouldCacheAccess = true;
- function applyOptions$1(instance) {
- const options = resolveMergedOptions(instance);
- const publicThis = instance.proxy;
- const ctx = instance.ctx;
- shouldCacheAccess = false;
- if (options.beforeCreate) {
- callHook$1(
- options.beforeCreate,
- instance,
- "bc"
- /* LifecycleHooks.BEFORE_CREATE */
- );
- }
- const {
- // state
- data: dataOptions,
- computed: computedOptions,
- methods,
- watch: watchOptions,
- provide: provideOptions,
- inject: injectOptions,
- // lifecycle
- created,
- beforeMount,
- mounted,
- beforeUpdate,
- updated,
- activated,
- deactivated,
- beforeDestroy,
- beforeUnmount,
- destroyed,
- unmounted,
- render,
- renderTracked,
- renderTriggered,
- errorCaptured,
- serverPrefetch,
- // public API
- expose,
- inheritAttrs,
- // assets
- components,
- directives,
- filters
- } = options;
- const checkDuplicateProperties = createDuplicateChecker();
- {
- const [propsOptions] = instance.propsOptions;
- if (propsOptions) {
- for (const key in propsOptions) {
- checkDuplicateProperties("Props", key);
- }
- }
- }
- if (injectOptions) {
- resolveInjections(injectOptions, ctx, checkDuplicateProperties, instance.appContext.config.unwrapInjectedRef);
- }
- if (methods) {
- for (const key in methods) {
- const methodHandler = methods[key];
- if (isFunction$1(methodHandler)) {
- {
- Object.defineProperty(ctx, key, {
- value: methodHandler.bind(publicThis),
- configurable: true,
- enumerable: true,
- writable: true
- });
- }
- {
- checkDuplicateProperties("Methods", key);
- }
- } else {
- warn$2(`Method "${key}" has type "${typeof methodHandler}" in the component definition. Did you reference the function correctly?`);
- }
- }
- }
- if (dataOptions) {
- if (!isFunction$1(dataOptions)) {
- warn$2(`The data option must be a function. Plain object usage is no longer supported.`);
- }
- const data = dataOptions.call(publicThis, publicThis);
- if (isPromise(data)) {
- warn$2(`data() returned a Promise - note data() cannot be async; If you intend to perform data fetching before component renders, use async setup() + <Suspense>.`);
- }
- if (!isObject$2(data)) {
- warn$2(`data() should return an object.`);
- } else {
- instance.data = reactive(data);
- {
- for (const key in data) {
- checkDuplicateProperties("Data", key);
- if (!isReservedPrefix(key[0])) {
- Object.defineProperty(ctx, key, {
- configurable: true,
- enumerable: true,
- get: () => data[key],
- set: NOOP
- });
- }
- }
- }
- }
- }
- shouldCacheAccess = true;
- if (computedOptions) {
- for (const key in computedOptions) {
- const opt = computedOptions[key];
- const get2 = isFunction$1(opt) ? opt.bind(publicThis, publicThis) : isFunction$1(opt.get) ? opt.get.bind(publicThis, publicThis) : NOOP;
- if (get2 === NOOP) {
- warn$2(`Computed property "${key}" has no getter.`);
- }
- const set2 = !isFunction$1(opt) && isFunction$1(opt.set) ? opt.set.bind(publicThis) : () => {
- warn$2(`Write operation failed: computed property "${key}" is readonly.`);
- };
- const c = computed({
- get: get2,
- set: set2
- });
- Object.defineProperty(ctx, key, {
- enumerable: true,
- configurable: true,
- get: () => c.value,
- set: (v) => c.value = v
- });
- {
- checkDuplicateProperties("Computed", key);
- }
- }
- }
- if (watchOptions) {
- for (const key in watchOptions) {
- createWatcher(watchOptions[key], ctx, publicThis, key);
- }
- }
- {
- if (provideOptions) {
- const provides = isFunction$1(provideOptions) ? provideOptions.call(publicThis) : provideOptions;
- Reflect.ownKeys(provides).forEach((key) => {
- provide(key, provides[key]);
- });
- }
- }
- {
- if (created) {
- callHook$1(
- created,
- instance,
- "c"
- /* LifecycleHooks.CREATED */
- );
- }
- }
- function registerLifecycleHook(register2, hook) {
- if (isArray$2(hook)) {
- hook.forEach((_hook) => register2(_hook.bind(publicThis)));
- } else if (hook) {
- register2(hook.bind(publicThis));
- }
- }
- registerLifecycleHook(onBeforeMount, beforeMount);
- registerLifecycleHook(onMounted, mounted);
- registerLifecycleHook(onBeforeUpdate, beforeUpdate);
- registerLifecycleHook(onUpdated, updated);
- registerLifecycleHook(onActivated, activated);
- registerLifecycleHook(onDeactivated, deactivated);
- registerLifecycleHook(onErrorCaptured, errorCaptured);
- registerLifecycleHook(onRenderTracked, renderTracked);
- registerLifecycleHook(onRenderTriggered, renderTriggered);
- registerLifecycleHook(onBeforeUnmount, beforeUnmount);
- registerLifecycleHook(onUnmounted, unmounted);
- registerLifecycleHook(onServerPrefetch, serverPrefetch);
- if (isArray$2(expose)) {
- if (expose.length) {
- const exposed = instance.exposed || (instance.exposed = {});
- expose.forEach((key) => {
- Object.defineProperty(exposed, key, {
- get: () => publicThis[key],
- set: (val) => publicThis[key] = val
- });
- });
- } else if (!instance.exposed) {
- instance.exposed = {};
- }
- }
- if (render && instance.render === NOOP) {
- instance.render = render;
- }
- if (inheritAttrs != null) {
- instance.inheritAttrs = inheritAttrs;
- }
- if (components)
- instance.components = components;
- if (directives)
- instance.directives = directives;
- if (instance.ctx.$onApplyOptions) {
- instance.ctx.$onApplyOptions(options, instance, publicThis);
- }
- }
- function resolveInjections(injectOptions, ctx, checkDuplicateProperties = NOOP, unwrapRef = false) {
- if (isArray$2(injectOptions)) {
- injectOptions = normalizeInject(injectOptions);
- }
- for (const key in injectOptions) {
- const opt = injectOptions[key];
- let injected;
- if (isObject$2(opt)) {
- if ("default" in opt) {
- injected = inject(
- opt.from || key,
- opt.default,
- true
- /* treat default function as factory */
- );
- } else {
- injected = inject(opt.from || key);
- }
- } else {
- injected = inject(opt);
- }
- if (isRef(injected)) {
- if (unwrapRef) {
- Object.defineProperty(ctx, key, {
- enumerable: true,
- configurable: true,
- get: () => injected.value,
- set: (v) => injected.value = v
- });
- } else {
- {
- warn$2(`injected property "${key}" is a ref and will be auto-unwrapped and no longer needs \`.value\` in the next minor release. To opt-in to the new behavior now, set \`app.config.unwrapInjectedRef = true\` (this config is temporary and will not be needed in the future.)`);
- }
- ctx[key] = injected;
- }
- } else {
- ctx[key] = injected;
- }
- {
- checkDuplicateProperties("Inject", key);
- }
- }
- }
- function callHook$1(hook, instance, type2) {
- callWithAsyncErrorHandling(isArray$2(hook) ? hook.map((h) => h.bind(instance.proxy)) : hook.bind(instance.proxy), instance, type2);
- }
- function createWatcher(raw, ctx, publicThis, key) {
- const getter = key.includes(".") ? createPathGetter(publicThis, key) : () => publicThis[key];
- if (isString$1(raw)) {
- const handler = ctx[raw];
- if (isFunction$1(handler)) {
- watch(getter, handler);
- } else {
- warn$2(`Invalid watch handler specified by key "${raw}"`, handler);
- }
- } else if (isFunction$1(raw)) {
- watch(getter, raw.bind(publicThis));
- } else if (isObject$2(raw)) {
- if (isArray$2(raw)) {
- raw.forEach((r) => createWatcher(r, ctx, publicThis, key));
- } else {
- const handler = isFunction$1(raw.handler) ? raw.handler.bind(publicThis) : ctx[raw.handler];
- if (isFunction$1(handler)) {
- watch(getter, handler, raw);
- } else {
- warn$2(`Invalid watch handler specified by key "${raw.handler}"`, handler);
- }
- }
- } else {
- warn$2(`Invalid watch option: "${key}"`, raw);
- }
- }
- function resolveMergedOptions(instance) {
- const base = instance.type;
- const { mixins, extends: extendsOptions } = base;
- const { mixins: globalMixins, optionsCache: cache, config: { optionMergeStrategies } } = instance.appContext;
- const cached = cache.get(base);
- let resolved;
- if (cached) {
- resolved = cached;
- } else if (!globalMixins.length && !mixins && !extendsOptions) {
- {
- resolved = base;
- }
- } else {
- resolved = {};
- if (globalMixins.length) {
- globalMixins.forEach((m) => mergeOptions(resolved, m, optionMergeStrategies, true));
- }
- mergeOptions(resolved, base, optionMergeStrategies);
- }
- if (isObject$2(base)) {
- cache.set(base, resolved);
- }
- return resolved;
- }
- function mergeOptions(to2, from2, strats, asMixin = false) {
- const { mixins, extends: extendsOptions } = from2;
- if (extendsOptions) {
- mergeOptions(to2, extendsOptions, strats, true);
- }
- if (mixins) {
- mixins.forEach((m) => mergeOptions(to2, m, strats, true));
- }
- for (const key in from2) {
- if (asMixin && key === "expose") {
- warn$2(`"expose" option is ignored when declared in mixins or extends. It should only be declared in the base component itself.`);
- } else {
- const strat = internalOptionMergeStrats[key] || strats && strats[key];
- to2[key] = strat ? strat(to2[key], from2[key]) : from2[key];
- }
- }
- return to2;
- }
- const internalOptionMergeStrats = {
- data: mergeDataFn,
- props: mergeObjectOptions,
- emits: mergeObjectOptions,
- // objects
- methods: mergeObjectOptions,
- computed: mergeObjectOptions,
- // lifecycle
- beforeCreate: mergeAsArray$1,
- created: mergeAsArray$1,
- beforeMount: mergeAsArray$1,
- mounted: mergeAsArray$1,
- beforeUpdate: mergeAsArray$1,
- updated: mergeAsArray$1,
- beforeDestroy: mergeAsArray$1,
- beforeUnmount: mergeAsArray$1,
- destroyed: mergeAsArray$1,
- unmounted: mergeAsArray$1,
- activated: mergeAsArray$1,
- deactivated: mergeAsArray$1,
- errorCaptured: mergeAsArray$1,
- serverPrefetch: mergeAsArray$1,
- // assets
- components: mergeObjectOptions,
- directives: mergeObjectOptions,
- // watch
- watch: mergeWatchOptions,
- // provide / inject
- provide: mergeDataFn,
- inject: mergeInject
- };
- function mergeDataFn(to2, from2) {
- if (!from2) {
- return to2;
- }
- if (!to2) {
- return from2;
- }
- return function mergedDataFn() {
- return extend$1(isFunction$1(to2) ? to2.call(this, this) : to2, isFunction$1(from2) ? from2.call(this, this) : from2);
- };
- }
- function mergeInject(to2, from2) {
- return mergeObjectOptions(normalizeInject(to2), normalizeInject(from2));
- }
- function normalizeInject(raw) {
- if (isArray$2(raw)) {
- const res = {};
- for (let i = 0; i < raw.length; i++) {
- res[raw[i]] = raw[i];
- }
- return res;
- }
- return raw;
- }
- function mergeAsArray$1(to2, from2) {
- return to2 ? [...new Set([].concat(to2, from2))] : from2;
- }
- function mergeObjectOptions(to2, from2) {
- return to2 ? extend$1(extend$1(/* @__PURE__ */ Object.create(null), to2), from2) : from2;
- }
- function mergeWatchOptions(to2, from2) {
- if (!to2)
- return from2;
- if (!from2)
- return to2;
- const merged = extend$1(/* @__PURE__ */ Object.create(null), to2);
- for (const key in from2) {
- merged[key] = mergeAsArray$1(to2[key], from2[key]);
- }
- return merged;
- }
- function initProps$1(instance, rawProps, isStateful, isSSR = false) {
- const props2 = {};
- const attrs = {};
- instance.propsDefaults = /* @__PURE__ */ Object.create(null);
- setFullProps(instance, rawProps, props2, attrs);
- for (const key in instance.propsOptions[0]) {
- if (!(key in props2)) {
- props2[key] = void 0;
- }
- }
- {
- validateProps(rawProps || {}, props2, instance);
- }
- if (isStateful) {
- instance.props = isSSR ? props2 : shallowReactive(props2);
- } else {
- if (!instance.type.props) {
- instance.props = attrs;
- } else {
- instance.props = props2;
- }
- }
- instance.attrs = attrs;
- }
- function isInHmrContext(instance) {
- while (instance) {
- if (instance.type.__hmrId)
- return true;
- instance = instance.parent;
- }
- }
- function updateProps(instance, rawProps, rawPrevProps, optimized) {
- const { props: props2, attrs, vnode: { patchFlag } } = instance;
- const rawCurrentProps = toRaw(props2);
- const [options] = instance.propsOptions;
- let hasAttrsChanged = false;
- if (
- // always force full diff in dev
- // - #1942 if hmr is enabled with sfc component
- // - vite#872 non-sfc component used by sfc component
- !isInHmrContext(instance) && (optimized || patchFlag > 0) && !(patchFlag & 16)
- ) {
- if (patchFlag & 8) {
- const propsToUpdate = instance.vnode.dynamicProps;
- for (let i = 0; i < propsToUpdate.length; i++) {
- let key = propsToUpdate[i];
- if (isEmitListener(instance.emitsOptions, key)) {
- continue;
- }
- const value2 = rawProps[key];
- if (options) {
- if (hasOwn(attrs, key)) {
- if (value2 !== attrs[key]) {
- attrs[key] = value2;
- hasAttrsChanged = true;
- }
- } else {
- const camelizedKey = camelize(key);
- props2[camelizedKey] = resolvePropValue(
- options,
- rawCurrentProps,
- camelizedKey,
- value2,
- instance,
- false
- /* isAbsent */
- );
- }
- } else {
- if (value2 !== attrs[key]) {
- attrs[key] = value2;
- hasAttrsChanged = true;
- }
- }
- }
- }
- } else {
- if (setFullProps(instance, rawProps, props2, attrs)) {
- hasAttrsChanged = true;
- }
- let kebabKey;
- for (const key in rawCurrentProps) {
- if (!rawProps || // for camelCase
- !hasOwn(rawProps, key) && // it's possible the original props was passed in as kebab-case
- // and converted to camelCase (#955)
- ((kebabKey = hyphenate(key)) === key || !hasOwn(rawProps, kebabKey))) {
- if (options) {
- if (rawPrevProps && // for camelCase
- (rawPrevProps[key] !== void 0 || // for kebab-case
- rawPrevProps[kebabKey] !== void 0)) {
- props2[key] = resolvePropValue(
- options,
- rawCurrentProps,
- key,
- void 0,
- instance,
- true
- /* isAbsent */
- );
- }
- } else {
- delete props2[key];
- }
- }
- }
- if (attrs !== rawCurrentProps) {
- for (const key in attrs) {
- if (!rawProps || !hasOwn(rawProps, key) && true) {
- delete attrs[key];
- hasAttrsChanged = true;
- }
- }
- }
- }
- if (hasAttrsChanged) {
- trigger(instance, "set", "$attrs");
- }
- {
- validateProps(rawProps || {}, props2, instance);
- }
- }
- function setFullProps(instance, rawProps, props2, attrs) {
- const [options, needCastKeys] = instance.propsOptions;
- let hasAttrsChanged = false;
- let rawCastValues;
- if (rawProps) {
- for (let key in rawProps) {
- if (isReservedProp(key)) {
- continue;
- }
- const value2 = rawProps[key];
- let camelKey;
- if (options && hasOwn(options, camelKey = camelize(key))) {
- if (!needCastKeys || !needCastKeys.includes(camelKey)) {
- props2[camelKey] = value2;
- } else {
- (rawCastValues || (rawCastValues = {}))[camelKey] = value2;
- }
- } else if (!isEmitListener(instance.emitsOptions, key)) {
- if (!(key in attrs) || value2 !== attrs[key]) {
- attrs[key] = value2;
- hasAttrsChanged = true;
- }
- }
- }
- }
- if (needCastKeys) {
- const rawCurrentProps = toRaw(props2);
- const castValues = rawCastValues || EMPTY_OBJ;
- for (let i = 0; i < needCastKeys.length; i++) {
- const key = needCastKeys[i];
- props2[key] = resolvePropValue(options, rawCurrentProps, key, castValues[key], instance, !hasOwn(castValues, key));
- }
- }
- return hasAttrsChanged;
- }
- function resolvePropValue(options, props2, key, value2, instance, isAbsent) {
- const opt = options[key];
- if (opt != null) {
- const hasDefault = hasOwn(opt, "default");
- if (hasDefault && value2 === void 0) {
- const defaultValue = opt.default;
- if (opt.type !== Function && isFunction$1(defaultValue)) {
- const { propsDefaults } = instance;
- if (key in propsDefaults) {
- value2 = propsDefaults[key];
- } else {
- setCurrentInstance(instance);
- value2 = propsDefaults[key] = defaultValue.call(null, props2);
- unsetCurrentInstance();
- }
- } else {
- value2 = defaultValue;
- }
- }
- if (opt[
- 0
- /* BooleanFlags.shouldCast */
- ]) {
- if (isAbsent && !hasDefault) {
- value2 = false;
- } else if (opt[
- 1
- /* BooleanFlags.shouldCastTrue */
- ] && (value2 === "" || value2 === hyphenate(key))) {
- value2 = true;
- }
- }
- }
- return value2;
- }
- function normalizePropsOptions(comp, appContext, asMixin = false) {
- const cache = appContext.propsCache;
- const cached = cache.get(comp);
- if (cached) {
- return cached;
- }
- const raw = comp.props;
- const normalized = {};
- const needCastKeys = [];
- let hasExtends = false;
- if (!isFunction$1(comp)) {
- const extendProps = (raw2) => {
- hasExtends = true;
- const [props2, keys2] = normalizePropsOptions(raw2, appContext, true);
- extend$1(normalized, props2);
- if (keys2)
- needCastKeys.push(...keys2);
- };
- if (!asMixin && appContext.mixins.length) {
- appContext.mixins.forEach(extendProps);
- }
- if (comp.extends) {
- extendProps(comp.extends);
- }
- if (comp.mixins) {
- comp.mixins.forEach(extendProps);
- }
- }
- if (!raw && !hasExtends) {
- if (isObject$2(comp)) {
- cache.set(comp, EMPTY_ARR);
- }
- return EMPTY_ARR;
- }
- if (isArray$2(raw)) {
- for (let i = 0; i < raw.length; i++) {
- if (!isString$1(raw[i])) {
- warn$2(`props must be strings when using array syntax.`, raw[i]);
- }
- const normalizedKey = camelize(raw[i]);
- if (validatePropName(normalizedKey)) {
- normalized[normalizedKey] = EMPTY_OBJ;
- }
- }
- } else if (raw) {
- if (!isObject$2(raw)) {
- warn$2(`invalid props options`, raw);
- }
- for (const key in raw) {
- const normalizedKey = camelize(key);
- if (validatePropName(normalizedKey)) {
- const opt = raw[key];
- const prop = normalized[normalizedKey] = isArray$2(opt) || isFunction$1(opt) ? { type: opt } : Object.assign({}, opt);
- if (prop) {
- const booleanIndex = getTypeIndex(Boolean, prop.type);
- const stringIndex = getTypeIndex(String, prop.type);
- prop[
- 0
- /* BooleanFlags.shouldCast */
- ] = booleanIndex > -1;
- prop[
- 1
- /* BooleanFlags.shouldCastTrue */
- ] = stringIndex < 0 || booleanIndex < stringIndex;
- if (booleanIndex > -1 || hasOwn(prop, "default")) {
- needCastKeys.push(normalizedKey);
- }
- }
- }
- }
- }
- const res = [normalized, needCastKeys];
- if (isObject$2(comp)) {
- cache.set(comp, res);
- }
- return res;
- }
- function validatePropName(key) {
- if (key[0] !== "$") {
- return true;
- } else {
- warn$2(`Invalid prop name: "${key}" is a reserved property.`);
- }
- return false;
- }
- function getType(ctor) {
- const match = ctor && ctor.toString().match(/^\s*(function|class) (\w+)/);
- return match ? match[2] : ctor === null ? "null" : "";
- }
- function isSameType(a, b) {
- return getType(a) === getType(b);
- }
- function getTypeIndex(type2, expectedTypes) {
- if (isArray$2(expectedTypes)) {
- return expectedTypes.findIndex((t2) => isSameType(t2, type2));
- } else if (isFunction$1(expectedTypes)) {
- return isSameType(expectedTypes, type2) ? 0 : -1;
- }
- return -1;
- }
- function validateProps(rawProps, props2, instance) {
- const resolvedValues = toRaw(props2);
- const options = instance.propsOptions[0];
- for (const key in options) {
- let opt = options[key];
- if (opt == null)
- continue;
- validateProp(key, resolvedValues[key], opt, !hasOwn(rawProps, key) && !hasOwn(rawProps, hyphenate(key)));
- }
- }
- function validateProp(name, value2, prop, isAbsent) {
- const { type: type2, required: required2, validator } = prop;
- if (required2 && isAbsent) {
- warn$2('Missing required prop: "' + name + '"');
- return;
- }
- if (value2 == null && !prop.required) {
- return;
- }
- if (type2 != null && type2 !== true) {
- let isValid2 = false;
- const types2 = isArray$2(type2) ? type2 : [type2];
- const expectedTypes = [];
- for (let i = 0; i < types2.length && !isValid2; i++) {
- const { valid, expectedType } = assertType(value2, types2[i]);
- expectedTypes.push(expectedType || "");
- isValid2 = valid;
- }
- if (!isValid2) {
- warn$2(getInvalidTypeMessage(name, value2, expectedTypes));
- return;
- }
- }
- if (validator && !validator(value2)) {
- warn$2('Invalid prop: custom validator check failed for prop "' + name + '".');
- }
- }
- const isSimpleType = /* @__PURE__ */ makeMap("String,Number,Boolean,Function,Symbol,BigInt");
- function assertType(value2, type2) {
- let valid;
- const expectedType = getType(type2);
- if (isSimpleType(expectedType)) {
- const t2 = typeof value2;
- valid = t2 === expectedType.toLowerCase();
- if (!valid && t2 === "object") {
- valid = value2 instanceof type2;
- }
- } else if (expectedType === "Object") {
- valid = isObject$2(value2);
- } else if (expectedType === "Array") {
- valid = isArray$2(value2);
- } else if (expectedType === "null") {
- valid = value2 === null;
- } else {
- valid = value2 instanceof type2;
- }
- return {
- valid,
- expectedType
- };
- }
- function getInvalidTypeMessage(name, value2, expectedTypes) {
- let message = `Invalid prop: type check failed for prop "${name}". Expected ${expectedTypes.map(capitalize).join(" | ")}`;
- const expectedType = expectedTypes[0];
- const receivedType = toRawType(value2);
- const expectedValue = styleValue(value2, expectedType);
- const receivedValue = styleValue(value2, receivedType);
- if (expectedTypes.length === 1 && isExplicable(expectedType) && !isBoolean(expectedType, receivedType)) {
- message += ` with value ${expectedValue}`;
- }
- message += `, got ${receivedType} `;
- if (isExplicable(receivedType)) {
- message += `with value ${receivedValue}.`;
- }
- return message;
- }
- function styleValue(value2, type2) {
- if (type2 === "String") {
- return `"${value2}"`;
- } else if (type2 === "Number") {
- return `${Number(value2)}`;
- } else {
- return `${value2}`;
- }
- }
- function isExplicable(type2) {
- const explicitTypes = ["string", "number", "boolean"];
- return explicitTypes.some((elem) => type2.toLowerCase() === elem);
- }
- function isBoolean(...args) {
- return args.some((elem) => elem.toLowerCase() === "boolean");
- }
- function createAppContext() {
- return {
- app: null,
- config: {
- isNativeTag: NO,
- performance: false,
- globalProperties: {},
- optionMergeStrategies: {},
- errorHandler: void 0,
- warnHandler: void 0,
- compilerOptions: {}
- },
- mixins: [],
- components: {},
- directives: {},
- provides: /* @__PURE__ */ Object.create(null),
- optionsCache: /* @__PURE__ */ new WeakMap(),
- propsCache: /* @__PURE__ */ new WeakMap(),
- emitsCache: /* @__PURE__ */ new WeakMap()
- };
- }
- let uid$1 = 0;
- function createAppAPI(render, hydrate) {
- return function createApp2(rootComponent, rootProps = null) {
- if (!isFunction$1(rootComponent)) {
- rootComponent = Object.assign({}, rootComponent);
- }
- if (rootProps != null && !isObject$2(rootProps)) {
- warn$2(`root props passed to app.mount() must be an object.`);
- rootProps = null;
- }
- const context = createAppContext();
- const installedPlugins = /* @__PURE__ */ new Set();
- const app = context.app = {
- _uid: uid$1++,
- _component: rootComponent,
- _props: rootProps,
- _container: null,
- _context: context,
- _instance: null,
- version: version$1,
- get config() {
- return context.config;
- },
- set config(v) {
- {
- warn$2(`app.config cannot be replaced. Modify individual options instead.`);
- }
- },
- use(plugin2, ...options) {
- if (installedPlugins.has(plugin2)) {
- warn$2(`Plugin has already been applied to target app.`);
- } else if (plugin2 && isFunction$1(plugin2.install)) {
- installedPlugins.add(plugin2);
- plugin2.install(app, ...options);
- } else if (isFunction$1(plugin2)) {
- installedPlugins.add(plugin2);
- plugin2(app, ...options);
- } else {
- warn$2(`A plugin must either be a function or an object with an "install" function.`);
- }
- return app;
- },
- mixin(mixin2) {
- {
- if (!context.mixins.includes(mixin2)) {
- context.mixins.push(mixin2);
- } else {
- warn$2("Mixin has already been applied to target app" + (mixin2.name ? `: ${mixin2.name}` : ""));
- }
- }
- return app;
- },
- component(name, component) {
- {
- validateComponentName(name, context.config);
- }
- if (!component) {
- return context.components[name];
- }
- if (context.components[name]) {
- warn$2(`Component "${name}" has already been registered in target app.`);
- }
- context.components[name] = component;
- return app;
- },
- directive(name, directive) {
- {
- validateDirectiveName(name);
- }
- if (!directive) {
- return context.directives[name];
- }
- if (context.directives[name]) {
- warn$2(`Directive "${name}" has already been registered in target app.`);
- }
- context.directives[name] = directive;
- return app;
- },
- // fixed by xxxxxx
- mount() {
- },
- // fixed by xxxxxx
- unmount() {
- },
- provide(key, value2) {
- if (key in context.provides) {
- warn$2(`App already provides property with key "${String(key)}". It will be overwritten with the new value.`);
- }
- context.provides[key] = value2;
- return app;
- }
- };
- return app;
- };
- }
- let supported;
- let perf;
- function startMeasure(instance, type2) {
- if (instance.appContext.config.performance && isSupported()) {
- perf.mark(`vue-${type2}-${instance.uid}`);
- }
- {
- devtoolsPerfStart(instance, type2, isSupported() ? perf.now() : Date.now());
- }
- }
- function endMeasure(instance, type2) {
- if (instance.appContext.config.performance && isSupported()) {
- const startTag = `vue-${type2}-${instance.uid}`;
- const endTag = startTag + `:end`;
- perf.mark(endTag);
- perf.measure(`<${formatComponentName(instance, instance.type)}> ${type2}`, startTag, endTag);
- perf.clearMarks(startTag);
- perf.clearMarks(endTag);
- }
- {
- devtoolsPerfEnd(instance, type2, isSupported() ? perf.now() : Date.now());
- }
- }
- function isSupported() {
- if (supported !== void 0) {
- return supported;
- }
- if (typeof window !== "undefined" && window.performance) {
- supported = true;
- perf = window.performance;
- } else {
- supported = false;
- }
- return supported;
- }
- const queuePostRenderEffect$1 = queuePostFlushCb;
- const Fragment = Symbol("Fragment");
- const Text$1 = Symbol("Text");
- const Comment = Symbol("Comment");
- const Static = Symbol("Static");
- function isVNode(value2) {
- return value2 ? value2.__v_isVNode === true : false;
- }
- const InternalObjectKey = `__vInternal`;
- function guardReactiveProps(props2) {
- if (!props2)
- return null;
- return isProxy(props2) || InternalObjectKey in props2 ? extend$1({}, props2) : props2;
- }
- const emptyAppContext = createAppContext();
- let uid = 0;
- function createComponentInstance(vnode, parent, suspense) {
- const type2 = vnode.type;
- const appContext = (parent ? parent.appContext : vnode.appContext) || emptyAppContext;
- const instance = {
- uid: uid++,
- vnode,
- type: type2,
- parent,
- appContext,
- root: null,
- next: null,
- subTree: null,
- effect: null,
- update: null,
- scope: new EffectScope(
- true
- /* detached */
- ),
- render: null,
- proxy: null,
- exposed: null,
- exposeProxy: null,
- withProxy: null,
- provides: parent ? parent.provides : Object.create(appContext.provides),
- accessCache: null,
- renderCache: [],
- // local resolved assets
- components: null,
- directives: null,
- // resolved props and emits options
- propsOptions: normalizePropsOptions(type2, appContext),
- emitsOptions: normalizeEmitsOptions(type2, appContext),
- // emit
- emit: null,
- emitted: null,
- // props default value
- propsDefaults: EMPTY_OBJ,
- // inheritAttrs
- inheritAttrs: type2.inheritAttrs,
- // state
- ctx: EMPTY_OBJ,
- data: EMPTY_OBJ,
- props: EMPTY_OBJ,
- attrs: EMPTY_OBJ,
- slots: EMPTY_OBJ,
- refs: EMPTY_OBJ,
- setupState: EMPTY_OBJ,
- setupContext: null,
- // suspense related
- suspense,
- suspenseId: suspense ? suspense.pendingId : 0,
- asyncDep: null,
- asyncResolved: false,
- // lifecycle hooks
- // not using enums here because it results in computed properties
- isMounted: false,
- isUnmounted: false,
- isDeactivated: false,
- bc: null,
- c: null,
- bm: null,
- m: null,
- bu: null,
- u: null,
- um: null,
- bum: null,
- da: null,
- a: null,
- rtg: null,
- rtc: null,
- ec: null,
- sp: null
- };
- {
- instance.ctx = createDevRenderContext(instance);
- }
- instance.root = parent ? parent.root : instance;
- instance.emit = emit.bind(null, instance);
- if (vnode.ce) {
- vnode.ce(instance);
- }
- return instance;
- }
- let currentInstance = null;
- const getCurrentInstance = () => currentInstance || currentRenderingInstance;
- const setCurrentInstance = (instance) => {
- currentInstance = instance;
- instance.scope.on();
- };
- const unsetCurrentInstance = () => {
- currentInstance && currentInstance.scope.off();
- currentInstance = null;
- };
- const isBuiltInTag = /* @__PURE__ */ makeMap("slot,component");
- function validateComponentName(name, config2) {
- const appIsNativeTag = config2.isNativeTag || NO;
- if (isBuiltInTag(name) || appIsNativeTag(name)) {
- warn$2("Do not use built-in or reserved HTML elements as component id: " + name);
- }
- }
- function isStatefulComponent(instance) {
- return instance.vnode.shapeFlag & 4;
- }
- let isInSSRComponentSetup = false;
- function setupComponent(instance, isSSR = false) {
- isInSSRComponentSetup = isSSR;
- const {
- props: props2
- /*, children*/
- } = instance.vnode;
- const isStateful = isStatefulComponent(instance);
- initProps$1(instance, props2, isStateful, isSSR);
- const setupResult = isStateful ? setupStatefulComponent(instance, isSSR) : void 0;
- isInSSRComponentSetup = false;
- return setupResult;
- }
- function setupStatefulComponent(instance, isSSR) {
- const Component2 = instance.type;
- {
- if (Component2.name) {
- validateComponentName(Component2.name, instance.appContext.config);
- }
- if (Component2.components) {
- const names = Object.keys(Component2.components);
- for (let i = 0; i < names.length; i++) {
- validateComponentName(names[i], instance.appContext.config);
- }
- }
- if (Component2.directives) {
- const names = Object.keys(Component2.directives);
- for (let i = 0; i < names.length; i++) {
- validateDirectiveName(names[i]);
- }
- }
- if (Component2.compilerOptions && isRuntimeOnly()) {
- warn$2(`"compilerOptions" is only supported when using a build of Vue that includes the runtime compiler. Since you are using a runtime-only build, the options should be passed via your build tool config instead.`);
- }
- }
- instance.accessCache = /* @__PURE__ */ Object.create(null);
- instance.proxy = markRaw(new Proxy(instance.ctx, PublicInstanceProxyHandlers));
- {
- exposePropsOnRenderContext(instance);
- }
- const { setup } = Component2;
- if (setup) {
- const setupContext = instance.setupContext = setup.length > 1 ? createSetupContext(instance) : null;
- setCurrentInstance(instance);
- pauseTracking();
- const setupResult = callWithErrorHandling(setup, instance, 0, [shallowReadonly(instance.props), setupContext]);
- resetTracking();
- unsetCurrentInstance();
- if (isPromise(setupResult)) {
- setupResult.then(unsetCurrentInstance, unsetCurrentInstance);
- {
- warn$2(`setup() returned a Promise, but the version of Vue you are using does not support it yet.`);
- }
- } else {
- handleSetupResult(instance, setupResult, isSSR);
- }
- } else {
- finishComponentSetup(instance, isSSR);
- }
- }
- function handleSetupResult(instance, setupResult, isSSR) {
- if (isFunction$1(setupResult)) {
- {
- instance.render = setupResult;
- }
- } else if (isObject$2(setupResult)) {
- if (isVNode(setupResult)) {
- warn$2(`setup() should not return VNodes directly - return a render function instead.`);
- }
- {
- instance.devtoolsRawSetupState = setupResult;
- }
- instance.setupState = proxyRefs(setupResult);
- {
- exposeSetupStateOnRenderContext(instance);
- }
- } else if (setupResult !== void 0) {
- warn$2(`setup() should return an object. Received: ${setupResult === null ? "null" : typeof setupResult}`);
- }
- finishComponentSetup(instance, isSSR);
- }
- let compile;
- const isRuntimeOnly = () => !compile;
- function finishComponentSetup(instance, isSSR, skipOptions) {
- const Component2 = instance.type;
- if (!instance.render) {
- instance.render = Component2.render || NOOP;
- }
- {
- setCurrentInstance(instance);
- pauseTracking();
- applyOptions$1(instance);
- resetTracking();
- unsetCurrentInstance();
- }
- if (!Component2.render && instance.render === NOOP && !isSSR) {
- if (Component2.template) {
- warn$2(
- `Component provided template option but runtime compilation is not supported in this build of Vue. Configure your bundler to alias "vue" to "vue/dist/vue.esm-bundler.js".`
- /* should not happen */
- );
- } else {
- warn$2(`Component is missing template or render function.`);
- }
- }
- }
- function createAttrsProxy(instance) {
- return new Proxy(
- instance.attrs,
- {
- get(target, key) {
- track(instance, "get", "$attrs");
- return target[key];
- },
- set() {
- warn$2(`setupContext.attrs is readonly.`);
- return false;
- },
- deleteProperty() {
- warn$2(`setupContext.attrs is readonly.`);
- return false;
- }
- }
- );
- }
- function createSetupContext(instance) {
- const expose = (exposed) => {
- {
- if (instance.exposed) {
- warn$2(`expose() should be called only once per setup().`);
- }
- if (exposed != null) {
- let exposedType = typeof exposed;
- if (exposedType === "object") {
- if (isArray$2(exposed)) {
- exposedType = "array";
- } else if (isRef(exposed)) {
- exposedType = "ref";
- }
- }
- if (exposedType !== "object") {
- warn$2(`expose() should be passed a plain object, received ${exposedType}.`);
- }
- }
- }
- instance.exposed = exposed || {};
- };
- let attrs;
- {
- return Object.freeze({
- get attrs() {
- return attrs || (attrs = createAttrsProxy(instance));
- },
- get slots() {
- return shallowReadonly(instance.slots);
- },
- get emit() {
- return (event, ...args) => instance.emit(event, ...args);
- },
- expose
- });
- }
- }
- function getExposeProxy(instance) {
- if (instance.exposed) {
- return instance.exposeProxy || (instance.exposeProxy = new Proxy(proxyRefs(markRaw(instance.exposed)), {
- get(target, key) {
- if (key in target) {
- return target[key];
- }
- return instance.proxy[key];
- },
- has(target, key) {
- return key in target || key in publicPropertiesMap;
- }
- }));
- }
- }
- const classifyRE = /(?:^|[-_])(\w)/g;
- const classify = (str) => str.replace(classifyRE, (c) => c.toUpperCase()).replace(/[-_]/g, "");
- function getComponentName(Component2, includeInferred = true) {
- return isFunction$1(Component2) ? Component2.displayName || Component2.name : Component2.name || includeInferred && Component2.__name;
- }
- function formatComponentName(instance, Component2, isRoot = false) {
- let name = getComponentName(Component2);
- if (!name && Component2.__file) {
- const match = Component2.__file.match(/([^/\\]+)\.\w+$/);
- if (match) {
- name = match[1];
- }
- }
- if (!name && instance && instance.parent) {
- const inferFromRegistry = (registry) => {
- for (const key in registry) {
- if (registry[key] === Component2) {
- return key;
- }
- }
- };
- name = inferFromRegistry(instance.components || instance.parent.type.components) || inferFromRegistry(instance.appContext.components);
- }
- return name ? classify(name) : isRoot ? `App` : `Anonymous`;
- }
- const computed = (getterOrOptions, debugOptions) => {
- return computed$1(getterOrOptions, debugOptions, isInSSRComponentSetup);
- };
- const version$1 = "3.2.47";
- function unwrapper(target) {
- return unref(target);
- }
- const ARRAYTYPE = "[object Array]";
- const OBJECTTYPE = "[object Object]";
- function diff$1(current, pre) {
- const result = {};
- syncKeys(current, pre);
- _diff(current, pre, "", result);
- return result;
- }
- function syncKeys(current, pre) {
- current = unwrapper(current);
- if (current === pre)
- return;
- const rootCurrentType = toTypeString(current);
- const rootPreType = toTypeString(pre);
- if (rootCurrentType == OBJECTTYPE && rootPreType == OBJECTTYPE) {
- for (let key in pre) {
- const currentValue = current[key];
- if (currentValue === void 0) {
- current[key] = null;
- } else {
- syncKeys(currentValue, pre[key]);
- }
- }
- } else if (rootCurrentType == ARRAYTYPE && rootPreType == ARRAYTYPE) {
- if (current.length >= pre.length) {
- pre.forEach((item, index2) => {
- syncKeys(current[index2], item);
- });
- }
- }
- }
- function _diff(current, pre, path, result) {
- current = unwrapper(current);
- if (current === pre)
- return;
- const rootCurrentType = toTypeString(current);
- const rootPreType = toTypeString(pre);
- if (rootCurrentType == OBJECTTYPE) {
- if (rootPreType != OBJECTTYPE || Object.keys(current).length < Object.keys(pre).length) {
- setResult(result, path, current);
- } else {
- for (let key in current) {
- const currentValue = unwrapper(current[key]);
- const preValue = pre[key];
- const currentType = toTypeString(currentValue);
- const preType = toTypeString(preValue);
- if (currentType != ARRAYTYPE && currentType != OBJECTTYPE) {
- if (currentValue != preValue) {
- setResult(result, (path == "" ? "" : path + ".") + key, currentValue);
- }
- } else if (currentType == ARRAYTYPE) {
- if (preType != ARRAYTYPE) {
- setResult(result, (path == "" ? "" : path + ".") + key, currentValue);
- } else {
- if (currentValue.length < preValue.length) {
- setResult(result, (path == "" ? "" : path + ".") + key, currentValue);
- } else {
- currentValue.forEach((item, index2) => {
- _diff(item, preValue[index2], (path == "" ? "" : path + ".") + key + "[" + index2 + "]", result);
- });
- }
- }
- } else if (currentType == OBJECTTYPE) {
- if (preType != OBJECTTYPE || Object.keys(currentValue).length < Object.keys(preValue).length) {
- setResult(result, (path == "" ? "" : path + ".") + key, currentValue);
- } else {
- for (let subKey in currentValue) {
- _diff(currentValue[subKey], preValue[subKey], (path == "" ? "" : path + ".") + key + "." + subKey, result);
- }
- }
- }
- }
- }
- } else if (rootCurrentType == ARRAYTYPE) {
- if (rootPreType != ARRAYTYPE) {
- setResult(result, path, current);
- } else {
- if (current.length < pre.length) {
- setResult(result, path, current);
- } else {
- current.forEach((item, index2) => {
- _diff(item, pre[index2], path + "[" + index2 + "]", result);
- });
- }
- }
- } else {
- setResult(result, path, current);
- }
- }
- function setResult(result, k, v) {
- result[k] = v;
- }
- function hasComponentEffect(instance) {
- return queue.includes(instance.update);
- }
- function flushCallbacks(instance) {
- const ctx = instance.ctx;
- const callbacks = ctx.__next_tick_callbacks;
- if (callbacks && callbacks.length) {
- const copies = callbacks.slice(0);
- callbacks.length = 0;
- for (let i = 0; i < copies.length; i++) {
- copies[i]();
- }
- }
- }
- function nextTick(instance, fn) {
- const ctx = instance.ctx;
- if (!ctx.__next_tick_pending && !hasComponentEffect(instance)) {
- return nextTick$1(fn && fn.bind(instance.proxy));
- }
- let _resolve;
- if (!ctx.__next_tick_callbacks) {
- ctx.__next_tick_callbacks = [];
- }
- ctx.__next_tick_callbacks.push(() => {
- if (fn) {
- callWithErrorHandling(
- fn.bind(instance.proxy),
- instance,
- 14
- /* ErrorCodes.SCHEDULER */
- );
- } else if (_resolve) {
- _resolve(instance.proxy);
- }
- });
- return new Promise((resolve2) => {
- _resolve = resolve2;
- });
- }
- function clone$3(src, seen) {
- src = unwrapper(src);
- const type2 = typeof src;
- if (type2 === "object" && src !== null) {
- let copy = seen.get(src);
- if (typeof copy !== "undefined") {
- return copy;
- }
- if (isArray$2(src)) {
- const len = src.length;
- copy = new Array(len);
- seen.set(src, copy);
- for (let i = 0; i < len; i++) {
- copy[i] = clone$3(src[i], seen);
- }
- } else {
- copy = {};
- seen.set(src, copy);
- for (const name in src) {
- if (hasOwn(src, name)) {
- copy[name] = clone$3(src[name], seen);
- }
- }
- }
- return copy;
- }
- if (type2 !== "symbol") {
- return src;
- }
- }
- function deepCopy(src) {
- return clone$3(src, typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : /* @__PURE__ */ new Map());
- }
- function getMPInstanceData(instance, keys2) {
- const data = instance.data;
- const ret = /* @__PURE__ */ Object.create(null);
- keys2.forEach((key) => {
- ret[key] = data[key];
- });
- return ret;
- }
- function patch(instance, data, oldData) {
- if (!data) {
- return;
- }
- data = deepCopy(data);
- const ctx = instance.ctx;
- const mpType = ctx.mpType;
- if (mpType === "page" || mpType === "component") {
- data.r0 = 1;
- const mpInstance = ctx.$scope;
- const keys2 = Object.keys(data);
- const diffData = diff$1(data, oldData || getMPInstanceData(mpInstance, keys2));
- if (Object.keys(diffData).length) {
- ctx.__next_tick_pending = true;
- mpInstance.setData(diffData, () => {
- ctx.__next_tick_pending = false;
- flushCallbacks(instance);
- });
- flushPreFlushCbs();
- } else {
- flushCallbacks(instance);
- }
- }
- }
- function initAppConfig(appConfig) {
- appConfig.globalProperties.$nextTick = function $nextTick(fn) {
- return nextTick(this.$, fn);
- };
- }
- function onApplyOptions(options, instance, publicThis) {
- instance.appContext.config.globalProperties.$applyOptions(options, instance, publicThis);
- const computedOptions = options.computed;
- if (computedOptions) {
- const keys2 = Object.keys(computedOptions);
- if (keys2.length) {
- const ctx = instance.ctx;
- if (!ctx.$computedKeys) {
- ctx.$computedKeys = [];
- }
- ctx.$computedKeys.push(...keys2);
- }
- }
- delete instance.ctx.$onApplyOptions;
- }
- function setRef$1(instance, isUnmount = false) {
- const { setupState, $templateRefs, ctx: { $scope, $mpPlatform } } = instance;
- if ($mpPlatform === "mp-alipay") {
- return;
- }
- if (!$templateRefs || !$scope) {
- return;
- }
- if (isUnmount) {
- return $templateRefs.forEach((templateRef) => setTemplateRef(templateRef, null, setupState));
- }
- const check = $mpPlatform === "mp-baidu" || $mpPlatform === "mp-toutiao";
- const doSetByRefs = (refs) => {
- const mpComponents = (
- // 字节小程序 selectAllComponents 可能返回 null
- // https://github.com/dcloudio/uni-app/issues/3954
- ($scope.selectAllComponents(".r") || []).concat($scope.selectAllComponents(".r-i-f") || [])
- );
- return refs.filter((templateRef) => {
- const refValue = findComponentPublicInstance(mpComponents, templateRef.i);
- if (check && refValue === null) {
- return true;
- }
- setTemplateRef(templateRef, refValue, setupState);
- return false;
- });
- };
- const doSet = () => {
- const refs = doSetByRefs($templateRefs);
- if (refs.length && instance.proxy && instance.proxy.$scope) {
- instance.proxy.$scope.setData({ r1: 1 }, () => {
- doSetByRefs(refs);
- });
- }
- };
- if ($scope._$setRef) {
- $scope._$setRef(doSet);
- } else {
- nextTick(instance, doSet);
- }
- }
- function toSkip(value2) {
- if (isObject$2(value2)) {
- markRaw(value2);
- }
- return value2;
- }
- function findComponentPublicInstance(mpComponents, id) {
- const mpInstance = mpComponents.find((com) => com && (com.properties || com.props).uI === id);
- if (mpInstance) {
- const vm = mpInstance.$vm;
- if (vm) {
- return getExposeProxy(vm.$) || vm;
- }
- return toSkip(mpInstance);
- }
- return null;
- }
- function setTemplateRef({ r, f: f2 }, refValue, setupState) {
- if (isFunction$1(r)) {
- r(refValue, {});
- } else {
- const _isString = isString$1(r);
- const _isRef = isRef(r);
- if (_isString || _isRef) {
- if (f2) {
- if (!_isRef) {
- return;
- }
- if (!isArray$2(r.value)) {
- r.value = [];
- }
- const existing = r.value;
- if (existing.indexOf(refValue) === -1) {
- existing.push(refValue);
- if (!refValue) {
- return;
- }
- onBeforeUnmount(() => remove(existing, refValue), refValue.$);
- }
- } else if (_isString) {
- if (hasOwn(setupState, r)) {
- setupState[r] = refValue;
- }
- } else if (isRef(r)) {
- r.value = refValue;
- } else {
- warnRef(r);
- }
- } else {
- warnRef(r);
- }
- }
- }
- function warnRef(ref2) {
- warn$2("Invalid template ref type:", ref2, `(${typeof ref2})`);
- }
- var MPType;
- (function(MPType2) {
- MPType2["APP"] = "app";
- MPType2["PAGE"] = "page";
- MPType2["COMPONENT"] = "component";
- })(MPType || (MPType = {}));
- const queuePostRenderEffect = queuePostFlushCb;
- function mountComponent(initialVNode, options) {
- const instance = initialVNode.component = createComponentInstance(initialVNode, options.parentComponent, null);
- {
- instance.ctx.$onApplyOptions = onApplyOptions;
- instance.ctx.$children = [];
- }
- if (options.mpType === "app") {
- instance.render = NOOP;
- }
- if (options.onBeforeSetup) {
- options.onBeforeSetup(instance, options);
- }
- {
- pushWarningContext(initialVNode);
- startMeasure(instance, `mount`);
- }
- {
- startMeasure(instance, `init`);
- }
- setupComponent(instance);
- {
- endMeasure(instance, `init`);
- }
- {
- if (options.parentComponent && instance.proxy) {
- options.parentComponent.ctx.$children.push(getExposeProxy(instance) || instance.proxy);
- }
- }
- setupRenderEffect(instance);
- {
- popWarningContext();
- endMeasure(instance, `mount`);
- }
- return instance.proxy;
- }
- const getFunctionalFallthrough = (attrs) => {
- let res;
- for (const key in attrs) {
- if (key === "class" || key === "style" || isOn(key)) {
- (res || (res = {}))[key] = attrs[key];
- }
- }
- return res;
- };
- function renderComponentRoot(instance) {
- const { type: Component2, vnode, proxy, withProxy, props: props2, propsOptions: [propsOptions], slots, attrs, emit: emit2, render, renderCache, data, setupState, ctx, uid: uid2, appContext: { app: { config: { globalProperties: { pruneComponentPropsCache: pruneComponentPropsCache2 } } } }, inheritAttrs } = instance;
- instance.$templateRefs = [];
- instance.$ei = 0;
- pruneComponentPropsCache2(uid2);
- instance.__counter = instance.__counter === 0 ? 1 : 0;
- let result;
- const prev = setCurrentRenderingInstance(instance);
- try {
- if (vnode.shapeFlag & 4) {
- fallthroughAttrs(inheritAttrs, props2, propsOptions, attrs);
- const proxyToUse = withProxy || proxy;
- result = render.call(proxyToUse, proxyToUse, renderCache, props2, setupState, data, ctx);
- } else {
- fallthroughAttrs(inheritAttrs, props2, propsOptions, Component2.props ? attrs : getFunctionalFallthrough(attrs));
- const render2 = Component2;
- result = render2.length > 1 ? render2(props2, { attrs, slots, emit: emit2 }) : render2(
- props2,
- null
- /* we know it doesn't need it */
- );
- }
- } catch (err) {
- handleError(
- err,
- instance,
- 1
- /* ErrorCodes.RENDER_FUNCTION */
- );
- result = false;
- }
- setRef$1(instance);
- setCurrentRenderingInstance(prev);
- return result;
- }
- function fallthroughAttrs(inheritAttrs, props2, propsOptions, fallthroughAttrs2) {
- if (props2 && fallthroughAttrs2 && inheritAttrs !== false) {
- const keys2 = Object.keys(fallthroughAttrs2).filter((key) => key !== "class" && key !== "style");
- if (!keys2.length) {
- return;
- }
- if (propsOptions && keys2.some(isModelListener)) {
- keys2.forEach((key) => {
- if (!isModelListener(key) || !(key.slice(9) in propsOptions)) {
- props2[key] = fallthroughAttrs2[key];
- }
- });
- } else {
- keys2.forEach((key) => props2[key] = fallthroughAttrs2[key]);
- }
- }
- }
- const updateComponentPreRender = (instance) => {
- pauseTracking();
- flushPreFlushCbs();
- resetTracking();
- };
- function componentUpdateScopedSlotsFn() {
- const scopedSlotsData = this.$scopedSlotsData;
- if (!scopedSlotsData || scopedSlotsData.length === 0) {
- return;
- }
- const mpInstance = this.ctx.$scope;
- const oldData = mpInstance.data;
- const diffData = /* @__PURE__ */ Object.create(null);
- scopedSlotsData.forEach(({ path, index: index2, data }) => {
- const oldScopedSlotData = getValueByDataPath(oldData, path);
- const diffPath = isString$1(index2) ? `${path}.${index2}` : `${path}[${index2}]`;
- if (typeof oldScopedSlotData === "undefined" || typeof oldScopedSlotData[index2] === "undefined") {
- diffData[diffPath] = data;
- } else {
- const diffScopedSlotData = diff$1(data, oldScopedSlotData[index2]);
- Object.keys(diffScopedSlotData).forEach((name) => {
- diffData[diffPath + "." + name] = diffScopedSlotData[name];
- });
- }
- });
- scopedSlotsData.length = 0;
- if (Object.keys(diffData).length) {
- mpInstance.setData(diffData);
- }
- }
- function toggleRecurse({ effect, update }, allowed) {
- effect.allowRecurse = update.allowRecurse = allowed;
- }
- function setupRenderEffect(instance) {
- const updateScopedSlots = componentUpdateScopedSlotsFn.bind(instance);
- instance.$updateScopedSlots = () => nextTick$1(() => queueJob(updateScopedSlots));
- const componentUpdateFn = () => {
- if (!instance.isMounted) {
- onBeforeUnmount(() => {
- setRef$1(instance, true);
- }, instance);
- {
- startMeasure(instance, `patch`);
- }
- patch(instance, renderComponentRoot(instance));
- {
- endMeasure(instance, `patch`);
- }
- {
- devtoolsComponentAdded(instance);
- }
- } else {
- const { next, bu, u } = instance;
- {
- pushWarningContext(next || instance.vnode);
- }
- toggleRecurse(instance, false);
- updateComponentPreRender();
- if (bu) {
- invokeArrayFns$1(bu);
- }
- toggleRecurse(instance, true);
- {
- startMeasure(instance, `patch`);
- }
- patch(instance, renderComponentRoot(instance));
- {
- endMeasure(instance, `patch`);
- }
- if (u) {
- queuePostRenderEffect(u);
- }
- {
- devtoolsComponentUpdated(instance);
- }
- {
- popWarningContext();
- }
- }
- };
- const effect = instance.effect = new ReactiveEffect(
- componentUpdateFn,
- () => queueJob(instance.update),
- instance.scope
- // track it in component's effect scope
- );
- const update = instance.update = effect.run.bind(effect);
- update.id = instance.uid;
- toggleRecurse(instance, true);
- {
- effect.onTrack = instance.rtc ? (e2) => invokeArrayFns$1(instance.rtc, e2) : void 0;
- effect.onTrigger = instance.rtg ? (e2) => invokeArrayFns$1(instance.rtg, e2) : void 0;
- update.ownerInstance = instance;
- }
- update();
- }
- function unmountComponent(instance) {
- const { bum, scope, update, um } = instance;
- if (bum) {
- invokeArrayFns$1(bum);
- }
- scope.stop();
- if (update) {
- update.active = false;
- }
- if (um) {
- queuePostRenderEffect(um);
- }
- queuePostRenderEffect(() => {
- instance.isUnmounted = true;
- });
- {
- devtoolsComponentRemoved(instance);
- }
- }
- const oldCreateApp = createAppAPI();
- function getTarget() {
- if (typeof window !== "undefined") {
- return window;
- }
- if (typeof globalThis !== "undefined") {
- return globalThis;
- }
- if (typeof global !== "undefined") {
- return global;
- }
- if (typeof my !== "undefined") {
- return my;
- }
- }
- function createVueApp(rootComponent, rootProps = null) {
- const target = getTarget();
- target.__VUE__ = true;
- {
- setDevtoolsHook(target.__VUE_DEVTOOLS_GLOBAL_HOOK__, target);
- }
- const app = oldCreateApp(rootComponent, rootProps);
- const appContext = app._context;
- initAppConfig(appContext.config);
- const createVNode = (initialVNode) => {
- initialVNode.appContext = appContext;
- initialVNode.shapeFlag = 6;
- return initialVNode;
- };
- const createComponent2 = function createComponent3(initialVNode, options) {
- return mountComponent(createVNode(initialVNode), options);
- };
- const destroyComponent = function destroyComponent2(component) {
- return component && unmountComponent(component.$);
- };
- app.mount = function mount() {
- rootComponent.render = NOOP;
- const instance = mountComponent(createVNode({ type: rootComponent }), {
- mpType: MPType.APP,
- mpInstance: null,
- parentComponent: null,
- slots: [],
- props: null
- });
- app._instance = instance.$;
- {
- devtoolsInitApp(app, version$1);
- }
- instance.$app = app;
- instance.$createComponent = createComponent2;
- instance.$destroyComponent = destroyComponent;
- appContext.$appInstance = instance;
- return instance;
- };
- app.unmount = function unmount() {
- warn$2(`Cannot unmount an app.`);
- };
- return app;
- }
- function injectLifecycleHook(name, hook, publicThis, instance) {
- if (isFunction$1(hook)) {
- injectHook(name, hook.bind(publicThis), instance);
- }
- }
- function initHooks$1(options, instance, publicThis) {
- const mpType = options.mpType || publicThis.$mpType;
- if (!mpType || mpType === "component") {
- return;
- }
- Object.keys(options).forEach((name) => {
- if (isUniLifecycleHook(name, options[name], false)) {
- const hooks2 = options[name];
- if (isArray$2(hooks2)) {
- hooks2.forEach((hook) => injectLifecycleHook(name, hook, publicThis, instance));
- } else {
- injectLifecycleHook(name, hooks2, publicThis, instance);
- }
- }
- });
- }
- function applyOptions$2(options, instance, publicThis) {
- initHooks$1(options, instance, publicThis);
- }
- function set$3(target, key, val) {
- return target[key] = val;
- }
- function createErrorHandler(app) {
- return function errorHandler(err, instance, _info) {
- if (!instance) {
- throw err;
- }
- const appInstance = app._instance;
- if (!appInstance || !appInstance.proxy) {
- throw err;
- }
- {
- appInstance.proxy.$callHook(ON_ERROR, err);
- }
- };
- }
- function mergeAsArray(to2, from2) {
- return to2 ? [...new Set([].concat(to2, from2))] : from2;
- }
- function initOptionMergeStrategies(optionMergeStrategies) {
- UniLifecycleHooks.forEach((name) => {
- optionMergeStrategies[name] = mergeAsArray;
- });
- }
- let realAtob;
- const b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
- const b64re = /^(?:[A-Za-z\d+/]{4})*?(?:[A-Za-z\d+/]{2}(?:==)?|[A-Za-z\d+/]{3}=?)?$/;
- if (typeof atob !== "function") {
- realAtob = function(str) {
- str = String(str).replace(/[\t\n\f\r ]+/g, "");
- if (!b64re.test(str)) {
- throw new Error("Failed to execute 'atob' on 'Window': The string to be decoded is not correctly encoded.");
- }
- str += "==".slice(2 - (str.length & 3));
- var bitmap;
- var result = "";
- var r1;
- var r2;
- var i = 0;
- for (; i < str.length; ) {
- bitmap = b64.indexOf(str.charAt(i++)) << 18 | b64.indexOf(str.charAt(i++)) << 12 | (r1 = b64.indexOf(str.charAt(i++))) << 6 | (r2 = b64.indexOf(str.charAt(i++)));
- result += r1 === 64 ? String.fromCharCode(bitmap >> 16 & 255) : r2 === 64 ? String.fromCharCode(bitmap >> 16 & 255, bitmap >> 8 & 255) : String.fromCharCode(bitmap >> 16 & 255, bitmap >> 8 & 255, bitmap & 255);
- }
- return result;
- };
- } else {
- realAtob = atob;
- }
- function b64DecodeUnicode(str) {
- return decodeURIComponent(realAtob(str).split("").map(function(c) {
- return "%" + ("00" + c.charCodeAt(0).toString(16)).slice(-2);
- }).join(""));
- }
- function getCurrentUserInfo() {
- const token2 = index$1.getStorageSync("uni_id_token") || "";
- const tokenArr = token2.split(".");
- if (!token2 || tokenArr.length !== 3) {
- return {
- uid: null,
- role: [],
- permission: [],
- tokenExpired: 0
- };
- }
- let userInfo;
- try {
- userInfo = JSON.parse(b64DecodeUnicode(tokenArr[1]));
- } catch (error2) {
- throw new Error("获取当前用户信息出错,详细错误信息为:" + error2.message);
- }
- userInfo.tokenExpired = userInfo.exp * 1e3;
- delete userInfo.exp;
- delete userInfo.iat;
- return userInfo;
- }
- function uniIdMixin(globalProperties) {
- globalProperties.uniIDHasRole = function(roleId) {
- const { role } = getCurrentUserInfo();
- return role.indexOf(roleId) > -1;
- };
- globalProperties.uniIDHasPermission = function(permissionId) {
- const { permission } = getCurrentUserInfo();
- return this.uniIDHasRole("admin") || permission.indexOf(permissionId) > -1;
- };
- globalProperties.uniIDTokenValid = function() {
- const { tokenExpired } = getCurrentUserInfo();
- return tokenExpired > Date.now();
- };
- }
- function initApp(app) {
- const appConfig = app._context.config;
- appConfig.errorHandler = invokeCreateErrorHandler(app, createErrorHandler);
- initOptionMergeStrategies(appConfig.optionMergeStrategies);
- const globalProperties = appConfig.globalProperties;
- {
- uniIdMixin(globalProperties);
- }
- {
- globalProperties.$set = set$3;
- globalProperties.$applyOptions = applyOptions$2;
- }
- {
- index$1.invokeCreateVueAppHook(app);
- }
- }
- const propsCaches = /* @__PURE__ */ Object.create(null);
- function renderProps(props2) {
- const { uid: uid2, __counter } = getCurrentInstance();
- const propsId = (propsCaches[uid2] || (propsCaches[uid2] = [])).push(guardReactiveProps(props2)) - 1;
- return uid2 + "," + propsId + "," + __counter;
- }
- function pruneComponentPropsCache(uid2) {
- delete propsCaches[uid2];
- }
- function findComponentPropsData(up) {
- if (!up) {
- return;
- }
- const [uid2, propsId] = up.split(",");
- if (!propsCaches[uid2]) {
- return;
- }
- return propsCaches[uid2][parseInt(propsId)];
- }
- var plugin = {
- install(app) {
- initApp(app);
- app.config.globalProperties.pruneComponentPropsCache = pruneComponentPropsCache;
- const oldMount = app.mount;
- app.mount = function mount(rootContainer) {
- const instance = oldMount.call(app, rootContainer);
- const createApp2 = getCreateApp();
- if (createApp2) {
- createApp2(instance);
- } else {
- if (typeof createMiniProgramApp !== "undefined") {
- createMiniProgramApp(instance);
- }
- }
- return instance;
- };
- }
- };
- function getCreateApp() {
- const method3 = "createApp";
- if (typeof global !== "undefined") {
- return global[method3];
- } else if (typeof my !== "undefined") {
- return my[method3];
- }
- }
- function vOn(value2, key) {
- const instance = getCurrentInstance();
- const ctx = instance.ctx;
- const extraKey = typeof key !== "undefined" && (ctx.$mpPlatform === "mp-weixin" || ctx.$mpPlatform === "mp-qq") && (isString$1(key) || typeof key === "number") ? "_" + key : "";
- const name = "e" + instance.$ei++ + extraKey;
- const mpInstance = ctx.$scope;
- if (!value2) {
- delete mpInstance[name];
- return name;
- }
- const existingInvoker = mpInstance[name];
- if (existingInvoker) {
- existingInvoker.value = value2;
- } else {
- mpInstance[name] = createInvoker(value2, instance);
- }
- return name;
- }
- function createInvoker(initialValue, instance) {
- const invoker = (e2) => {
- patchMPEvent(e2);
- let args = [e2];
- if (e2.detail && e2.detail.__args__) {
- args = e2.detail.__args__;
- }
- const eventValue = invoker.value;
- const invoke = () => callWithAsyncErrorHandling(patchStopImmediatePropagation(e2, eventValue), instance, 5, args);
- const eventTarget = e2.target;
- const eventSync = eventTarget ? eventTarget.dataset ? String(eventTarget.dataset.eventsync) === "true" : false : false;
- if (bubbles.includes(e2.type) && !eventSync) {
- setTimeout(invoke);
- } else {
- const res = invoke();
- if (e2.type === "input" && (isArray$2(res) || isPromise(res))) {
- return;
- }
- return res;
- }
- };
- invoker.value = initialValue;
- return invoker;
- }
- const bubbles = [
- // touch事件暂不做延迟,否则在 Android 上会影响性能,比如一些拖拽跟手手势等
- // 'touchstart',
- // 'touchmove',
- // 'touchcancel',
- // 'touchend',
- "tap",
- "longpress",
- "longtap",
- "transitionend",
- "animationstart",
- "animationiteration",
- "animationend",
- "touchforcechange"
- ];
- function patchMPEvent(event) {
- if (event.type && event.target) {
- event.preventDefault = NOOP;
- event.stopPropagation = NOOP;
- event.stopImmediatePropagation = NOOP;
- if (!hasOwn(event, "detail")) {
- event.detail = {};
- }
- if (hasOwn(event, "markerId")) {
- event.detail = typeof event.detail === "object" ? event.detail : {};
- event.detail.markerId = event.markerId;
- }
- if (isPlainObject$1(event.detail) && hasOwn(event.detail, "checked") && !hasOwn(event.detail, "value")) {
- event.detail.value = event.detail.checked;
- }
- if (isPlainObject$1(event.detail)) {
- event.target = extend$1({}, event.target, event.detail);
- }
- }
- }
- function patchStopImmediatePropagation(e2, value2) {
- if (isArray$2(value2)) {
- const originalStop = e2.stopImmediatePropagation;
- e2.stopImmediatePropagation = () => {
- originalStop && originalStop.call(e2);
- e2._stopped = true;
- };
- return value2.map((fn) => (e3) => !e3._stopped && fn(e3));
- } else {
- return value2;
- }
- }
- function vFor(source, renderItem) {
- let ret;
- if (isArray$2(source) || isString$1(source)) {
- ret = new Array(source.length);
- for (let i = 0, l = source.length; i < l; i++) {
- ret[i] = renderItem(source[i], i, i);
- }
- } else if (typeof source === "number") {
- if (!Number.isInteger(source)) {
- warn$2(`The v-for range expect an integer value but got ${source}.`);
- return [];
- }
- ret = new Array(source);
- for (let i = 0; i < source; i++) {
- ret[i] = renderItem(i + 1, i, i);
- }
- } else if (isObject$2(source)) {
- if (source[Symbol.iterator]) {
- ret = Array.from(source, (item, i) => renderItem(item, i, i));
- } else {
- const keys2 = Object.keys(source);
- ret = new Array(keys2.length);
- for (let i = 0, l = keys2.length; i < l; i++) {
- const key = keys2[i];
- ret[i] = renderItem(source[key], key, i);
- }
- }
- } else {
- ret = [];
- }
- return ret;
- }
- function stringifyStyle(value2) {
- if (isString$1(value2)) {
- return value2;
- }
- return stringify(normalizeStyle(value2));
- }
- function stringify(styles) {
- let ret = "";
- if (!styles || isString$1(styles)) {
- return ret;
- }
- for (const key in styles) {
- ret += `${key.startsWith(`--`) ? key : hyphenate(key)}:${styles[key]};`;
- }
- return ret;
- }
- function setRef(ref2, id, opts = {}) {
- const { $templateRefs } = getCurrentInstance();
- $templateRefs.push({ i: id, r: ref2, k: opts.k, f: opts.f });
- }
- const o = (value2, key) => vOn(value2, key);
- const f = (source, renderItem) => vFor(source, renderItem);
- const s = (value2) => stringifyStyle(value2);
- const e = (target, ...sources) => extend$1(target, ...sources);
- const n = (value2) => normalizeClass(value2);
- const t = (val) => toDisplayString(val);
- const p = (props2) => renderProps(props2);
- const sr = (ref2, id, opts) => setRef(ref2, id, opts);
- function createApp$1(rootComponent, rootProps = null) {
- rootComponent && (rootComponent.mpType = "app");
- return createVueApp(rootComponent, rootProps).use(plugin);
- }
- const createSSRApp = createApp$1;
- const MP_METHODS = [
- "createSelectorQuery",
- "createIntersectionObserver",
- "selectAllComponents",
- "selectComponent"
- ];
- function createEmitFn(oldEmit, ctx) {
- return function emit2(event, ...args) {
- const scope = ctx.$scope;
- if (scope && event) {
- const detail = { __args__: args };
- {
- scope.triggerEvent(event, detail);
- }
- }
- return oldEmit.apply(this, [event, ...args]);
- };
- }
- function initBaseInstance(instance, options) {
- const ctx = instance.ctx;
- ctx.mpType = options.mpType;
- ctx.$mpType = options.mpType;
- ctx.$mpPlatform = "mp-weixin";
- ctx.$scope = options.mpInstance;
- ctx.$mp = {};
- {
- ctx._self = {};
- }
- instance.slots = {};
- if (isArray$2(options.slots) && options.slots.length) {
- options.slots.forEach((name) => {
- instance.slots[name] = true;
- });
- if (instance.slots[SLOT_DEFAULT_NAME]) {
- instance.slots.default = true;
- }
- }
- ctx.getOpenerEventChannel = function() {
- {
- return options.mpInstance.getOpenerEventChannel();
- }
- };
- ctx.$hasHook = hasHook;
- ctx.$callHook = callHook;
- instance.emit = createEmitFn(instance.emit, ctx);
- }
- function initComponentInstance(instance, options) {
- initBaseInstance(instance, options);
- const ctx = instance.ctx;
- MP_METHODS.forEach((method3) => {
- ctx[method3] = function(...args) {
- const mpInstance = ctx.$scope;
- if (mpInstance && mpInstance[method3]) {
- return mpInstance[method3].apply(mpInstance, args);
- }
- };
- });
- }
- function initMocks(instance, mpInstance, mocks2) {
- const ctx = instance.ctx;
- mocks2.forEach((mock) => {
- if (hasOwn(mpInstance, mock)) {
- instance[mock] = ctx[mock] = mpInstance[mock];
- }
- });
- }
- function hasHook(name) {
- const hooks2 = this.$[name];
- if (hooks2 && hooks2.length) {
- return true;
- }
- return false;
- }
- function callHook(name, args) {
- if (name === "mounted") {
- callHook.call(this, "bm");
- this.$.isMounted = true;
- name = "m";
- }
- const hooks2 = this.$[name];
- return hooks2 && invokeArrayFns(hooks2, args);
- }
- const PAGE_INIT_HOOKS = [
- ON_LOAD,
- ON_SHOW,
- ON_HIDE,
- ON_UNLOAD,
- ON_RESIZE,
- ON_TAB_ITEM_TAP,
- ON_REACH_BOTTOM,
- ON_PULL_DOWN_REFRESH,
- ON_ADD_TO_FAVORITES
- // 'onReady', // lifetimes.ready
- // 'onPageScroll', // 影响性能,开发者手动注册
- // 'onShareTimeline', // 右上角菜单,开发者手动注册
- // 'onShareAppMessage' // 右上角菜单,开发者手动注册
- ];
- function findHooks(vueOptions, hooks2 = /* @__PURE__ */ new Set()) {
- if (vueOptions) {
- Object.keys(vueOptions).forEach((name) => {
- if (isUniLifecycleHook(name, vueOptions[name])) {
- hooks2.add(name);
- }
- });
- {
- const { extends: extendsOptions, mixins } = vueOptions;
- if (mixins) {
- mixins.forEach((mixin2) => findHooks(mixin2, hooks2));
- }
- if (extendsOptions) {
- findHooks(extendsOptions, hooks2);
- }
- }
- }
- return hooks2;
- }
- function initHook(mpOptions, hook, excludes) {
- if (excludes.indexOf(hook) === -1 && !hasOwn(mpOptions, hook)) {
- mpOptions[hook] = function(args) {
- return this.$vm && this.$vm.$callHook(hook, args);
- };
- }
- }
- const EXCLUDE_HOOKS = [ON_READY];
- function initHooks(mpOptions, hooks2, excludes = EXCLUDE_HOOKS) {
- hooks2.forEach((hook) => initHook(mpOptions, hook, excludes));
- }
- function initUnknownHooks(mpOptions, vueOptions, excludes = EXCLUDE_HOOKS) {
- findHooks(vueOptions).forEach((hook) => initHook(mpOptions, hook, excludes));
- }
- function initRuntimeHooks(mpOptions, runtimeHooks) {
- if (!runtimeHooks) {
- return;
- }
- const hooks2 = Object.keys(MINI_PROGRAM_PAGE_RUNTIME_HOOKS);
- hooks2.forEach((hook) => {
- if (runtimeHooks & MINI_PROGRAM_PAGE_RUNTIME_HOOKS[hook]) {
- initHook(mpOptions, hook, []);
- }
- });
- }
- const findMixinRuntimeHooks = /* @__PURE__ */ once(() => {
- const runtimeHooks = [];
- const app = isFunction$1(getApp) && getApp({ allowDefault: true });
- if (app && app.$vm && app.$vm.$) {
- const mixins = app.$vm.$.appContext.mixins;
- if (isArray$2(mixins)) {
- const hooks2 = Object.keys(MINI_PROGRAM_PAGE_RUNTIME_HOOKS);
- mixins.forEach((mixin2) => {
- hooks2.forEach((hook) => {
- if (hasOwn(mixin2, hook) && !runtimeHooks.includes(hook)) {
- runtimeHooks.push(hook);
- }
- });
- });
- }
- }
- return runtimeHooks;
- });
- function initMixinRuntimeHooks(mpOptions) {
- initHooks(mpOptions, findMixinRuntimeHooks());
- }
- const HOOKS = [
- ON_SHOW,
- ON_HIDE,
- ON_ERROR,
- ON_THEME_CHANGE,
- ON_PAGE_NOT_FOUND,
- ON_UNHANDLE_REJECTION
- ];
- function parseApp(instance, parseAppOptions) {
- const internalInstance = instance.$;
- const appOptions = {
- globalData: instance.$options && instance.$options.globalData || {},
- $vm: instance,
- onLaunch(options) {
- this.$vm = instance;
- const ctx = internalInstance.ctx;
- if (this.$vm && ctx.$scope) {
- return;
- }
- initBaseInstance(internalInstance, {
- mpType: "app",
- mpInstance: this,
- slots: []
- });
- ctx.globalData = this.globalData;
- instance.$callHook(ON_LAUNCH, options);
- }
- };
- initLocale(instance);
- const vueOptions = instance.$.type;
- initHooks(appOptions, HOOKS);
- initUnknownHooks(appOptions, vueOptions);
- {
- const methods = vueOptions.methods;
- methods && extend$1(appOptions, methods);
- }
- if (parseAppOptions) {
- parseAppOptions.parse(appOptions);
- }
- return appOptions;
- }
- function initCreateApp(parseAppOptions) {
- return function createApp2(vm) {
- return App(parseApp(vm, parseAppOptions));
- };
- }
- function initCreateSubpackageApp(parseAppOptions) {
- return function createApp2(vm) {
- const appOptions = parseApp(vm, parseAppOptions);
- const app = isFunction$1(getApp) && getApp({
- allowDefault: true
- });
- if (!app)
- return;
- vm.$.ctx.$scope = app;
- const globalData = app.globalData;
- if (globalData) {
- Object.keys(appOptions.globalData).forEach((name) => {
- if (!hasOwn(globalData, name)) {
- globalData[name] = appOptions.globalData[name];
- }
- });
- }
- Object.keys(appOptions).forEach((name) => {
- if (!hasOwn(app, name)) {
- app[name] = appOptions[name];
- }
- });
- initAppLifecycle(appOptions, vm);
- };
- }
- function initAppLifecycle(appOptions, vm) {
- if (isFunction$1(appOptions.onLaunch)) {
- const args = wx.getLaunchOptionsSync && wx.getLaunchOptionsSync();
- appOptions.onLaunch(args);
- }
- if (isFunction$1(appOptions.onShow) && wx.onAppShow) {
- wx.onAppShow((args) => {
- vm.$callHook("onShow", args);
- });
- }
- if (isFunction$1(appOptions.onHide) && wx.onAppHide) {
- wx.onAppHide((args) => {
- vm.$callHook("onHide", args);
- });
- }
- }
- function initLocale(appVm) {
- const locale2 = ref(normalizeLocale$1(wx.getSystemInfoSync().language) || LOCALE_EN);
- Object.defineProperty(appVm, "$locale", {
- get() {
- return locale2.value;
- },
- set(v) {
- locale2.value = v;
- }
- });
- }
- function initVueIds(vueIds, mpInstance) {
- if (!vueIds) {
- return;
- }
- const ids = vueIds.split(",");
- const len = ids.length;
- if (len === 1) {
- mpInstance._$vueId = ids[0];
- } else if (len === 2) {
- mpInstance._$vueId = ids[0];
- mpInstance._$vuePid = ids[1];
- }
- }
- const EXTRAS = ["externalClasses"];
- function initExtraOptions(miniProgramComponentOptions, vueOptions) {
- EXTRAS.forEach((name) => {
- if (hasOwn(vueOptions, name)) {
- miniProgramComponentOptions[name] = vueOptions[name];
- }
- });
- }
- const WORKLET_RE = /_(.*)_worklet_factory_/;
- function initWorkletMethods(mpMethods, vueMethods) {
- if (vueMethods) {
- Object.keys(vueMethods).forEach((name) => {
- const matches = name.match(WORKLET_RE);
- if (matches) {
- const workletName = matches[1];
- mpMethods[name] = vueMethods[name];
- mpMethods[workletName] = vueMethods[workletName];
- }
- });
- }
- }
- function initWxsCallMethods(methods, wxsCallMethods) {
- if (!isArray$2(wxsCallMethods)) {
- return;
- }
- wxsCallMethods.forEach((callMethod) => {
- methods[callMethod] = function(args) {
- return this.$vm[callMethod](args);
- };
- });
- }
- function selectAllComponents(mpInstance, selector, $refs) {
- const components = mpInstance.selectAllComponents(selector);
- components.forEach((component) => {
- const ref2 = component.properties.uR;
- $refs[ref2] = component.$vm || component;
- });
- }
- function initRefs(instance, mpInstance) {
- Object.defineProperty(instance, "refs", {
- get() {
- const $refs = {};
- selectAllComponents(mpInstance, ".r", $refs);
- const forComponents = mpInstance.selectAllComponents(".r-i-f");
- forComponents.forEach((component) => {
- const ref2 = component.properties.uR;
- if (!ref2) {
- return;
- }
- if (!$refs[ref2]) {
- $refs[ref2] = [];
- }
- $refs[ref2].push(component.$vm || component);
- });
- return $refs;
- }
- });
- }
- function findVmByVueId(instance, vuePid) {
- const $children = instance.$children;
- for (let i = $children.length - 1; i >= 0; i--) {
- const childVm = $children[i];
- if (childVm.$scope._$vueId === vuePid) {
- return childVm;
- }
- }
- let parentVm;
- for (let i = $children.length - 1; i >= 0; i--) {
- parentVm = findVmByVueId($children[i], vuePid);
- if (parentVm) {
- return parentVm;
- }
- }
- }
- const builtInProps = [
- // 百度小程序,快手小程序自定义组件不支持绑定动态事件,动态dataset,故通过props传递事件信息
- // event-opts
- "eO",
- // 组件 ref
- "uR",
- // 组件 ref-in-for
- "uRIF",
- // 组件 id
- "uI",
- // 组件类型 m: 小程序组件
- "uT",
- // 组件 props
- "uP",
- // 小程序不能直接定义 $slots 的 props,所以通过 vueSlots 转换到 $slots
- "uS"
- ];
- function initDefaultProps(options, isBehavior = false) {
- const properties = {};
- if (!isBehavior) {
- builtInProps.forEach((name) => {
- properties[name] = {
- type: null,
- value: ""
- };
- });
- properties.uS = {
- type: null,
- value: [],
- observer: function(newVal) {
- const $slots = /* @__PURE__ */ Object.create(null);
- newVal && newVal.forEach((slotName) => {
- $slots[slotName] = true;
- });
- this.setData({
- $slots
- });
- }
- };
- }
- if (options.behaviors) {
- if (options.behaviors.includes("wx://form-field")) {
- if (!options.properties || !options.properties.name) {
- properties.name = {
- type: null,
- value: ""
- };
- }
- if (!options.properties || !options.properties.value) {
- properties.value = {
- type: null,
- value: ""
- };
- }
- }
- }
- return properties;
- }
- function initVirtualHostProps(options) {
- const properties = {};
- {
- if (options && options.virtualHost) {
- properties.virtualHostStyle = {
- type: null,
- value: ""
- };
- properties.virtualHostClass = {
- type: null,
- value: ""
- };
- }
- }
- return properties;
- }
- function initProps(mpComponentOptions) {
- if (!mpComponentOptions.properties) {
- mpComponentOptions.properties = {};
- }
- extend$1(mpComponentOptions.properties, initDefaultProps(mpComponentOptions), initVirtualHostProps(mpComponentOptions.options));
- }
- const PROP_TYPES = [String, Number, Boolean, Object, Array, null];
- function parsePropType(type2, defaultValue) {
- if (isArray$2(type2) && type2.length === 1) {
- return type2[0];
- }
- return type2;
- }
- function normalizePropType(type2, defaultValue) {
- const res = parsePropType(type2);
- return PROP_TYPES.indexOf(res) !== -1 ? res : null;
- }
- function initPageProps({ properties }, rawProps) {
- if (isArray$2(rawProps)) {
- rawProps.forEach((key) => {
- properties[key] = {
- type: String,
- value: ""
- };
- });
- } else if (isPlainObject$1(rawProps)) {
- Object.keys(rawProps).forEach((key) => {
- const opts = rawProps[key];
- if (isPlainObject$1(opts)) {
- let value2 = opts.default;
- if (isFunction$1(value2)) {
- value2 = value2();
- }
- const type2 = opts.type;
- opts.type = normalizePropType(type2);
- properties[key] = {
- type: opts.type,
- value: value2
- };
- } else {
- properties[key] = {
- type: normalizePropType(opts)
- };
- }
- });
- }
- }
- function findPropsData(properties, isPage2) {
- return (isPage2 ? findPagePropsData(properties) : findComponentPropsData(properties.uP)) || {};
- }
- function findPagePropsData(properties) {
- const propsData = {};
- if (isPlainObject$1(properties)) {
- Object.keys(properties).forEach((name) => {
- if (builtInProps.indexOf(name) === -1) {
- propsData[name] = properties[name];
- }
- });
- }
- return propsData;
- }
- function initFormField(vm) {
- const vueOptions = vm.$options;
- if (isArray$2(vueOptions.behaviors) && vueOptions.behaviors.includes("uni://form-field")) {
- vm.$watch("modelValue", () => {
- vm.$scope && vm.$scope.setData({
- name: vm.name,
- value: vm.modelValue
- });
- }, {
- immediate: true
- });
- }
- }
- function initData(_) {
- return {};
- }
- function initPropsObserver(componentOptions) {
- const observe = function observe2() {
- const up = this.properties.uP;
- if (!up) {
- return;
- }
- if (this.$vm) {
- updateComponentProps(up, this.$vm.$);
- } else if (this.properties.uT === "m") {
- updateMiniProgramComponentProperties(up, this);
- }
- };
- {
- if (!componentOptions.observers) {
- componentOptions.observers = {};
- }
- componentOptions.observers.uP = observe;
- }
- }
- function updateMiniProgramComponentProperties(up, mpInstance) {
- const prevProps = mpInstance.properties;
- const nextProps = findComponentPropsData(up) || {};
- if (hasPropsChanged(prevProps, nextProps, false)) {
- mpInstance.setData(nextProps);
- }
- }
- function updateComponentProps(up, instance) {
- const prevProps = toRaw(instance.props);
- const nextProps = findComponentPropsData(up) || {};
- if (hasPropsChanged(prevProps, nextProps)) {
- updateProps(instance, nextProps, prevProps, false);
- if (hasQueueJob(instance.update)) {
- invalidateJob(instance.update);
- }
- {
- instance.update();
- }
- }
- }
- function hasPropsChanged(prevProps, nextProps, checkLen = true) {
- const nextKeys = Object.keys(nextProps);
- if (checkLen && nextKeys.length !== Object.keys(prevProps).length) {
- return true;
- }
- for (let i = 0; i < nextKeys.length; i++) {
- const key = nextKeys[i];
- if (nextProps[key] !== prevProps[key]) {
- return true;
- }
- }
- return false;
- }
- function initBehaviors(vueOptions) {
- const vueBehaviors = vueOptions.behaviors;
- let vueProps = vueOptions.props;
- if (!vueProps) {
- vueOptions.props = vueProps = [];
- }
- const behaviors = [];
- if (isArray$2(vueBehaviors)) {
- vueBehaviors.forEach((behavior) => {
- behaviors.push(behavior.replace("uni://", "wx://"));
- if (behavior === "uni://form-field") {
- if (isArray$2(vueProps)) {
- vueProps.push("name");
- vueProps.push("modelValue");
- } else {
- vueProps.name = {
- type: String,
- default: ""
- };
- vueProps.modelValue = {
- type: [String, Number, Boolean, Array, Object, Date],
- default: ""
- };
- }
- }
- });
- }
- return behaviors;
- }
- function applyOptions(componentOptions, vueOptions) {
- componentOptions.data = initData();
- componentOptions.behaviors = initBehaviors(vueOptions);
- }
- function parseComponent(vueOptions, { parse, mocks: mocks2, isPage: isPage2, initRelation: initRelation2, handleLink: handleLink2, initLifetimes: initLifetimes2 }) {
- vueOptions = vueOptions.default || vueOptions;
- const options = {
- multipleSlots: true,
- // styleIsolation: 'apply-shared',
- addGlobalClass: true,
- pureDataPattern: /^uP$/
- };
- if (isArray$2(vueOptions.mixins)) {
- vueOptions.mixins.forEach((item) => {
- if (isObject$2(item.options)) {
- extend$1(options, item.options);
- }
- });
- }
- if (vueOptions.options) {
- extend$1(options, vueOptions.options);
- }
- const mpComponentOptions = {
- options,
- lifetimes: initLifetimes2({ mocks: mocks2, isPage: isPage2, initRelation: initRelation2, vueOptions }),
- pageLifetimes: {
- show() {
- this.$vm && this.$vm.$callHook("onPageShow");
- },
- hide() {
- this.$vm && this.$vm.$callHook("onPageHide");
- },
- resize(size2) {
- this.$vm && this.$vm.$callHook("onPageResize", size2);
- }
- },
- methods: {
- __l: handleLink2
- }
- };
- {
- applyOptions(mpComponentOptions, vueOptions);
- }
- initProps(mpComponentOptions);
- initPropsObserver(mpComponentOptions);
- initExtraOptions(mpComponentOptions, vueOptions);
- initWxsCallMethods(mpComponentOptions.methods, vueOptions.wxsCallMethods);
- {
- initWorkletMethods(mpComponentOptions.methods, vueOptions.methods);
- }
- if (parse) {
- parse(mpComponentOptions, { handleLink: handleLink2 });
- }
- return mpComponentOptions;
- }
- function initCreateComponent(parseOptions2) {
- return function createComponent2(vueComponentOptions) {
- return Component(parseComponent(vueComponentOptions, parseOptions2));
- };
- }
- let $createComponentFn;
- let $destroyComponentFn;
- function getAppVm() {
- return getApp().$vm;
- }
- function $createComponent(initialVNode, options) {
- if (!$createComponentFn) {
- $createComponentFn = getAppVm().$createComponent;
- }
- const proxy = $createComponentFn(initialVNode, options);
- return getExposeProxy(proxy.$) || proxy;
- }
- function $destroyComponent(instance) {
- if (!$destroyComponentFn) {
- $destroyComponentFn = getAppVm().$destroyComponent;
- }
- return $destroyComponentFn(instance);
- }
- function parsePage(vueOptions, parseOptions2) {
- const { parse, mocks: mocks2, isPage: isPage2, initRelation: initRelation2, handleLink: handleLink2, initLifetimes: initLifetimes2 } = parseOptions2;
- const miniProgramPageOptions = parseComponent(vueOptions, {
- mocks: mocks2,
- isPage: isPage2,
- initRelation: initRelation2,
- handleLink: handleLink2,
- initLifetimes: initLifetimes2
- });
- initPageProps(miniProgramPageOptions, (vueOptions.default || vueOptions).props);
- const methods = miniProgramPageOptions.methods;
- methods.onLoad = function(query) {
- this.options = query;
- this.$page = {
- fullPath: addLeadingSlash(this.route + stringifyQuery(query))
- };
- return this.$vm && this.$vm.$callHook(ON_LOAD, query);
- };
- initHooks(methods, PAGE_INIT_HOOKS);
- {
- initUnknownHooks(methods, vueOptions);
- }
- initRuntimeHooks(methods, vueOptions.__runtimeHooks);
- initMixinRuntimeHooks(methods);
- parse && parse(miniProgramPageOptions, { handleLink: handleLink2 });
- return miniProgramPageOptions;
- }
- function initCreatePage(parseOptions2) {
- return function createPage2(vuePageOptions) {
- return Component(parsePage(vuePageOptions, parseOptions2));
- };
- }
- function initCreatePluginApp(parseAppOptions) {
- return function createApp2(vm) {
- initAppLifecycle(parseApp(vm, parseAppOptions), vm);
- };
- }
- const MPPage = Page;
- const MPComponent = Component;
- function initTriggerEvent(mpInstance) {
- const oldTriggerEvent = mpInstance.triggerEvent;
- const newTriggerEvent = function(event, ...args) {
- return oldTriggerEvent.apply(mpInstance, [customizeEvent(event), ...args]);
- };
- try {
- mpInstance.triggerEvent = newTriggerEvent;
- } catch (error2) {
- mpInstance._triggerEvent = newTriggerEvent;
- }
- }
- function initMiniProgramHook(name, options, isComponent) {
- const oldHook = options[name];
- if (!oldHook) {
- options[name] = function() {
- initTriggerEvent(this);
- };
- } else {
- options[name] = function(...args) {
- initTriggerEvent(this);
- return oldHook.apply(this, args);
- };
- }
- }
- Page = function(options) {
- initMiniProgramHook(ON_LOAD, options);
- return MPPage(options);
- };
- Component = function(options) {
- initMiniProgramHook("created", options);
- const isVueComponent = options.properties && options.properties.uP;
- if (!isVueComponent) {
- initProps(options);
- initPropsObserver(options);
- }
- return MPComponent(options);
- };
- function initLifetimes({ mocks: mocks2, isPage: isPage2, initRelation: initRelation2, vueOptions }) {
- return {
- attached() {
- let properties = this.properties;
- initVueIds(properties.uI, this);
- const relationOptions = {
- vuePid: this._$vuePid
- };
- initRelation2(this, relationOptions);
- const mpInstance = this;
- const isMiniProgramPage = isPage2(mpInstance);
- let propsData = properties;
- this.$vm = $createComponent({
- type: vueOptions,
- props: findPropsData(propsData, isMiniProgramPage)
- }, {
- mpType: isMiniProgramPage ? "page" : "component",
- mpInstance,
- slots: properties.uS || {},
- parentComponent: relationOptions.parent && relationOptions.parent.$,
- onBeforeSetup(instance, options) {
- initRefs(instance, mpInstance);
- initMocks(instance, mpInstance, mocks2);
- initComponentInstance(instance, options);
- }
- });
- if (!isMiniProgramPage) {
- initFormField(this.$vm);
- }
- },
- ready() {
- if (this.$vm) {
- {
- this.$vm.$callHook("mounted");
- this.$vm.$callHook(ON_READY);
- }
- }
- },
- detached() {
- if (this.$vm) {
- pruneComponentPropsCache(this.$vm.$.uid);
- $destroyComponent(this.$vm);
- }
- }
- };
- }
- const mocks = ["__route__", "__wxExparserNodeId__", "__wxWebviewId__"];
- function isPage(mpInstance) {
- return !!mpInstance.route;
- }
- function initRelation(mpInstance, detail) {
- mpInstance.triggerEvent("__l", detail);
- }
- function handleLink(event) {
- const detail = event.detail || event.value;
- const vuePid = detail.vuePid;
- let parentVm;
- if (vuePid) {
- parentVm = findVmByVueId(this.$vm, vuePid);
- }
- if (!parentVm) {
- parentVm = this.$vm;
- }
- detail.parent = parentVm;
- }
- var parseOptions = /* @__PURE__ */ Object.freeze({
- __proto__: null,
- handleLink,
- initLifetimes,
- initRelation,
- isPage,
- mocks
- });
- const createApp = initCreateApp();
- const createPage = initCreatePage(parseOptions);
- const createComponent = initCreateComponent(parseOptions);
- const createPluginApp = initCreatePluginApp();
- const createSubpackageApp = initCreateSubpackageApp();
- {
- wx.createApp = global.createApp = createApp;
- wx.createPage = createPage;
- wx.createComponent = createComponent;
- wx.createPluginApp = global.createPluginApp = createPluginApp;
- wx.createSubpackageApp = global.createSubpackageApp = createSubpackageApp;
- }
- const mixin = {
- // 定义每个组件都可能需要用到的外部样式以及类名
- props: {
- // 每个组件都有的父组件传递的样式,可以为字符串或者对象形式
- customStyle: {
- type: [Object, String],
- default: () => ({})
- },
- customClass: {
- type: String,
- default: ""
- },
- // 跳转的页面路径
- url: {
- type: String,
- default: ""
- },
- // 页面跳转的类型
- linkType: {
- type: String,
- default: "navigateTo"
- }
- },
- data() {
- return {};
- },
- onLoad() {
- this.$u.getRect = this.$uGetRect;
- },
- created() {
- this.$u.getRect = this.$uGetRect;
- },
- computed: {
- // 在2.x版本中,将会把$u挂载到uni对象下,导致在模板中无法使用uni.$u.xxx形式
- // 所以这里通过computed计算属性将其附加到this.$u上,就可以在模板或者js中使用uni.$u.xxx
- // 只在nvue环境通过此方式引入完整的$u,其他平台会出现性能问题,非nvue则按需引入(主要原因是props过大)
- $u() {
- return index$1.$u.deepMerge(index$1.$u, {
- props: void 0,
- http: void 0,
- mixin: void 0
- });
- },
- /**
- * 生成bem规则类名
- * 由于微信小程序,H5,nvue之间绑定class的差异,无法通过:class="[bem()]"的形式进行同用
- * 故采用如下折中做法,最后返回的是数组(一般平台)或字符串(支付宝和字节跳动平台),类似['a', 'b', 'c']或'a b c'的形式
- * @param {String} name 组件名称
- * @param {Array} fixed 一直会存在的类名
- * @param {Array} change 会根据变量值为true或者false而出现或者隐藏的类名
- * @returns {Array|string}
- */
- bem() {
- return function(name, fixed, change) {
- const prefix = `u-${name}--`;
- const classes = {};
- if (fixed) {
- fixed.map((item) => {
- classes[prefix + this[item]] = true;
- });
- }
- if (change) {
- change.map((item) => {
- this[item] ? classes[prefix + item] = this[item] : delete classes[prefix + item];
- });
- }
- return Object.keys(classes);
- };
- }
- },
- methods: {
- // 跳转某一个页面
- openPage(urlKey = "url") {
- const url3 = this[urlKey];
- if (url3) {
- this.$u.route({ type: this.linkType, url: url3 });
- }
- },
- // 查询节点信息
- // 目前此方法在支付宝小程序中无法获取组件跟接点的尺寸,为支付宝的bug(2020-07-21)
- // 解决办法为在组件根部再套一个没有任何作用的view元素
- $uGetRect(selector, all) {
- return new Promise((resolve2) => {
- index$1.createSelectorQuery().in(this)[all ? "selectAll" : "select"](selector).boundingClientRect((rect) => {
- if (all && Array.isArray(rect) && rect.length) {
- resolve2(rect);
- }
- if (!all && rect) {
- resolve2(rect);
- }
- }).exec();
- });
- },
- getParentData(parentName = "") {
- if (!this.parent)
- this.parent = {};
- this.parent = index$1.$u.$parent.call(this, parentName);
- if (this.parent.children) {
- this.parent.children.indexOf(this) === -1 && this.parent.children.push(this);
- }
- if (this.parent && this.parentData) {
- Object.keys(this.parentData).map((key) => {
- this.parentData[key] = this.parent[key];
- });
- }
- },
- // 阻止事件冒泡
- preventEvent(e2) {
- e2 && typeof e2.stopPropagation === "function" && e2.stopPropagation();
- },
- // 空操作
- noop(e2) {
- this.preventEvent(e2);
- }
- },
- onReachBottom() {
- index$1.$emit("uOnReachBottom");
- },
- beforeDestroy() {
- if (this.parent && index$1.$u.test.array(this.parent.children)) {
- const childrenList = this.parent.children;
- childrenList.map((child, index2) => {
- if (child === this) {
- childrenList.splice(index2, 1);
- }
- });
- }
- }
- };
- const mpMixin = {
- // 将自定义节点设置成虚拟的,更加接近Vue组件的表现,能更好的使用flex属性
- options: {
- virtualHost: true
- }
- };
- const { toString: toString$1 } = Object.prototype;
- function isArray$1(val) {
- return toString$1.call(val) === "[object Array]";
- }
- function isObject$1(val) {
- return val !== null && typeof val === "object";
- }
- function isDate$1(val) {
- return toString$1.call(val) === "[object Date]";
- }
- function isURLSearchParams(val) {
- return typeof URLSearchParams !== "undefined" && val instanceof URLSearchParams;
- }
- function forEach(obj, fn) {
- if (obj === null || typeof obj === "undefined") {
- return;
- }
- if (typeof obj !== "object") {
- obj = [obj];
- }
- if (isArray$1(obj)) {
- for (let i = 0, l = obj.length; i < l; i++) {
- fn.call(null, obj[i], i, obj);
- }
- } else {
- for (const key in obj) {
- if (Object.prototype.hasOwnProperty.call(obj, key)) {
- fn.call(null, obj[key], key, obj);
- }
- }
- }
- }
- function isPlainObject(obj) {
- return Object.prototype.toString.call(obj) === "[object Object]";
- }
- function deepMerge$2() {
- const result = {};
- function assignValue(val, key) {
- if (typeof result[key] === "object" && typeof val === "object") {
- result[key] = deepMerge$2(result[key], val);
- } else if (typeof val === "object") {
- result[key] = deepMerge$2({}, val);
- } else {
- result[key] = val;
- }
- }
- for (let i = 0, l = arguments.length; i < l; i++) {
- forEach(arguments[i], assignValue);
- }
- return result;
- }
- function isUndefined$1(val) {
- return typeof val === "undefined";
- }
- function encode(val) {
- return encodeURIComponent(val).replace(/%40/gi, "@").replace(/%3A/gi, ":").replace(/%24/g, "$").replace(/%2C/gi, ",").replace(/%20/g, "+").replace(/%5B/gi, "[").replace(/%5D/gi, "]");
- }
- function buildURL(url3, params) {
- if (!params) {
- return url3;
- }
- let serializedParams;
- if (isURLSearchParams(params)) {
- serializedParams = params.toString();
- } else {
- const parts = [];
- forEach(params, (val, key) => {
- if (val === null || typeof val === "undefined") {
- return;
- }
- if (isArray$1(val)) {
- key = `${key}[]`;
- } else {
- val = [val];
- }
- forEach(val, (v) => {
- if (isDate$1(v)) {
- v = v.toISOString();
- } else if (isObject$1(v)) {
- v = JSON.stringify(v);
- }
- parts.push(`${encode(key)}=${encode(v)}`);
- });
- });
- serializedParams = parts.join("&");
- }
- if (serializedParams) {
- const hashmarkIndex = url3.indexOf("#");
- if (hashmarkIndex !== -1) {
- url3 = url3.slice(0, hashmarkIndex);
- }
- url3 += (url3.indexOf("?") === -1 ? "?" : "&") + serializedParams;
- }
- return url3;
- }
- function isAbsoluteURL(url3) {
- return /^([a-z][a-z\d+\-.]*:)?\/\//i.test(url3);
- }
- function combineURLs(baseURL, relativeURL) {
- return relativeURL ? `${baseURL.replace(/\/+$/, "")}/${relativeURL.replace(/^\/+/, "")}` : baseURL;
- }
- function buildFullPath(baseURL, requestedURL) {
- if (baseURL && !isAbsoluteURL(requestedURL)) {
- return combineURLs(baseURL, requestedURL);
- }
- return requestedURL;
- }
- function settle(resolve2, reject, response) {
- const { validateStatus: validateStatus2 } = response.config;
- const status = response.statusCode;
- if (status && (!validateStatus2 || validateStatus2(status))) {
- resolve2(response);
- } else {
- reject(response);
- }
- }
- const mergeKeys$1 = (keys2, config2) => {
- const config3 = {};
- keys2.forEach((prop) => {
- if (!isUndefined$1(config2[prop])) {
- config3[prop] = config2[prop];
- }
- });
- return config3;
- };
- const adapter = (config2) => new Promise((resolve2, reject) => {
- const fullPath = buildURL(buildFullPath(config2.baseURL, config2.url), config2.params);
- const _config = {
- url: fullPath,
- header: config2.header,
- complete: (response) => {
- config2.fullPath = fullPath;
- response.config = config2;
- try {
- if (typeof response.data === "string") {
- response.data = JSON.parse(response.data);
- }
- } catch (e2) {
- }
- settle(resolve2, reject, response);
- }
- };
- let requestTask;
- if (config2.method === "UPLOAD") {
- delete _config.header["content-type"];
- delete _config.header["Content-Type"];
- const otherConfig = {
- filePath: config2.filePath,
- name: config2.name
- };
- const optionalKeys = [
- "formData"
- ];
- requestTask = index$1.uploadFile({ ..._config, ...otherConfig, ...mergeKeys$1(optionalKeys, config2) });
- } else if (config2.method === "DOWNLOAD") {
- requestTask = index$1.downloadFile(_config);
- } else {
- const optionalKeys = [
- "data",
- "method",
- "timeout",
- "dataType",
- "responseType"
- ];
- requestTask = index$1.request({ ..._config, ...mergeKeys$1(optionalKeys, config2) });
- }
- if (config2.getTask) {
- config2.getTask(requestTask, config2);
- }
- });
- const dispatchRequest = (config2) => adapter(config2);
- function InterceptorManager() {
- this.handlers = [];
- }
- InterceptorManager.prototype.use = function use(fulfilled, rejected) {
- this.handlers.push({
- fulfilled,
- rejected
- });
- return this.handlers.length - 1;
- };
- InterceptorManager.prototype.eject = function eject(id) {
- if (this.handlers[id]) {
- this.handlers[id] = null;
- }
- };
- InterceptorManager.prototype.forEach = function forEach2(fn) {
- this.handlers.forEach((h) => {
- if (h !== null) {
- fn(h);
- }
- });
- };
- const mergeKeys = (keys2, globalsConfig, config2) => {
- const config3 = {};
- keys2.forEach((prop) => {
- if (!isUndefined$1(config2[prop])) {
- config3[prop] = config2[prop];
- } else if (!isUndefined$1(globalsConfig[prop])) {
- config3[prop] = globalsConfig[prop];
- }
- });
- return config3;
- };
- const mergeConfig = (globalsConfig, config2 = {}) => {
- const method3 = config2.method || globalsConfig.method || "GET";
- let config3 = {
- baseURL: globalsConfig.baseURL || "",
- method: method3,
- url: config2.url || "",
- params: config2.params || {},
- custom: { ...globalsConfig.custom || {}, ...config2.custom || {} },
- header: deepMerge$2(globalsConfig.header || {}, config2.header || {})
- };
- const defaultToConfig2Keys = ["getTask", "validateStatus"];
- config3 = { ...config3, ...mergeKeys(defaultToConfig2Keys, globalsConfig, config2) };
- if (method3 === "DOWNLOAD")
- ;
- else if (method3 === "UPLOAD") {
- delete config3.header["content-type"];
- delete config3.header["Content-Type"];
- const uploadKeys = [
- "filePath",
- "name",
- "formData"
- ];
- uploadKeys.forEach((prop) => {
- if (!isUndefined$1(config2[prop])) {
- config3[prop] = config2[prop];
- }
- });
- } else {
- const defaultsKeys = [
- "data",
- "timeout",
- "dataType",
- "responseType"
- ];
- config3 = { ...config3, ...mergeKeys(defaultsKeys, globalsConfig, config2) };
- }
- return config3;
- };
- const defaults$1 = {
- baseURL: "",
- header: {},
- method: "GET",
- dataType: "json",
- responseType: "text",
- custom: {},
- timeout: 6e4,
- validateStatus: function validateStatus(status) {
- return status >= 200 && status < 300;
- }
- };
- var clone$2 = function() {
- function _instanceof(obj, type2) {
- return type2 != null && obj instanceof type2;
- }
- var nativeMap;
- try {
- nativeMap = Map;
- } catch (_) {
- nativeMap = function() {
- };
- }
- var nativeSet;
- try {
- nativeSet = Set;
- } catch (_) {
- nativeSet = function() {
- };
- }
- var nativePromise;
- try {
- nativePromise = Promise;
- } catch (_) {
- nativePromise = function() {
- };
- }
- function clone2(parent, circular, depth, prototype, includeNonEnumerable) {
- if (typeof circular === "object") {
- depth = circular.depth;
- prototype = circular.prototype;
- includeNonEnumerable = circular.includeNonEnumerable;
- circular = circular.circular;
- }
- var allParents = [];
- var allChildren = [];
- var useBuffer = typeof Buffer != "undefined";
- if (typeof circular == "undefined")
- circular = true;
- if (typeof depth == "undefined")
- depth = Infinity;
- function _clone(parent2, depth2) {
- if (parent2 === null)
- return null;
- if (depth2 === 0)
- return parent2;
- var child;
- var proto2;
- if (typeof parent2 != "object") {
- return parent2;
- }
- if (_instanceof(parent2, nativeMap)) {
- child = new nativeMap();
- } else if (_instanceof(parent2, nativeSet)) {
- child = new nativeSet();
- } else if (_instanceof(parent2, nativePromise)) {
- child = new nativePromise(function(resolve2, reject) {
- parent2.then(function(value2) {
- resolve2(_clone(value2, depth2 - 1));
- }, function(err) {
- reject(_clone(err, depth2 - 1));
- });
- });
- } else if (clone2.__isArray(parent2)) {
- child = [];
- } else if (clone2.__isRegExp(parent2)) {
- child = new RegExp(parent2.source, __getRegExpFlags(parent2));
- if (parent2.lastIndex)
- child.lastIndex = parent2.lastIndex;
- } else if (clone2.__isDate(parent2)) {
- child = new Date(parent2.getTime());
- } else if (useBuffer && Buffer.isBuffer(parent2)) {
- if (Buffer.from) {
- child = Buffer.from(parent2);
- } else {
- child = new Buffer(parent2.length);
- parent2.copy(child);
- }
- return child;
- } else if (_instanceof(parent2, Error)) {
- child = Object.create(parent2);
- } else {
- if (typeof prototype == "undefined") {
- proto2 = Object.getPrototypeOf(parent2);
- child = Object.create(proto2);
- } else {
- child = Object.create(prototype);
- proto2 = prototype;
- }
- }
- if (circular) {
- var index2 = allParents.indexOf(parent2);
- if (index2 != -1) {
- return allChildren[index2];
- }
- allParents.push(parent2);
- allChildren.push(child);
- }
- if (_instanceof(parent2, nativeMap)) {
- parent2.forEach(function(value2, key) {
- var keyChild = _clone(key, depth2 - 1);
- var valueChild = _clone(value2, depth2 - 1);
- child.set(keyChild, valueChild);
- });
- }
- if (_instanceof(parent2, nativeSet)) {
- parent2.forEach(function(value2) {
- var entryChild = _clone(value2, depth2 - 1);
- child.add(entryChild);
- });
- }
- for (var i in parent2) {
- var attrs = Object.getOwnPropertyDescriptor(parent2, i);
- if (attrs) {
- child[i] = _clone(parent2[i], depth2 - 1);
- }
- try {
- var objProperty = Object.getOwnPropertyDescriptor(parent2, i);
- if (objProperty.set === "undefined") {
- continue;
- }
- child[i] = _clone(parent2[i], depth2 - 1);
- } catch (e2) {
- if (e2 instanceof TypeError) {
- continue;
- } else if (e2 instanceof ReferenceError) {
- continue;
- }
- }
- }
- if (Object.getOwnPropertySymbols) {
- var symbols = Object.getOwnPropertySymbols(parent2);
- for (var i = 0; i < symbols.length; i++) {
- var symbol = symbols[i];
- var descriptor = Object.getOwnPropertyDescriptor(parent2, symbol);
- if (descriptor && !descriptor.enumerable && !includeNonEnumerable) {
- continue;
- }
- child[symbol] = _clone(parent2[symbol], depth2 - 1);
- Object.defineProperty(child, symbol, descriptor);
- }
- }
- if (includeNonEnumerable) {
- var allPropertyNames = Object.getOwnPropertyNames(parent2);
- for (var i = 0; i < allPropertyNames.length; i++) {
- var propertyName = allPropertyNames[i];
- var descriptor = Object.getOwnPropertyDescriptor(parent2, propertyName);
- if (descriptor && descriptor.enumerable) {
- continue;
- }
- child[propertyName] = _clone(parent2[propertyName], depth2 - 1);
- Object.defineProperty(child, propertyName, descriptor);
- }
- }
- return child;
- }
- return _clone(parent, depth);
- }
- clone2.clonePrototype = function clonePrototype(parent) {
- if (parent === null)
- return null;
- var c = function() {
- };
- c.prototype = parent;
- return new c();
- };
- function __objToStr(o2) {
- return Object.prototype.toString.call(o2);
- }
- clone2.__objToStr = __objToStr;
- function __isDate(o2) {
- return typeof o2 === "object" && __objToStr(o2) === "[object Date]";
- }
- clone2.__isDate = __isDate;
- function __isArray(o2) {
- return typeof o2 === "object" && __objToStr(o2) === "[object Array]";
- }
- clone2.__isArray = __isArray;
- function __isRegExp(o2) {
- return typeof o2 === "object" && __objToStr(o2) === "[object RegExp]";
- }
- clone2.__isRegExp = __isRegExp;
- function __getRegExpFlags(re) {
- var flags = "";
- if (re.global)
- flags += "g";
- if (re.ignoreCase)
- flags += "i";
- if (re.multiline)
- flags += "m";
- return flags;
- }
- clone2.__getRegExpFlags = __getRegExpFlags;
- return clone2;
- }();
- class Request {
- /**
- * @param {Object} arg - 全局配置
- * @param {String} arg.baseURL - 全局根路径
- * @param {Object} arg.header - 全局header
- * @param {String} arg.method = [GET|POST|PUT|DELETE|CONNECT|HEAD|OPTIONS|TRACE] - 全局默认请求方式
- * @param {String} arg.dataType = [json] - 全局默认的dataType
- * @param {String} arg.responseType = [text|arraybuffer] - 全局默认的responseType。支付宝小程序不支持
- * @param {Object} arg.custom - 全局默认的自定义参数
- * @param {Number} arg.timeout - 全局默认的超时时间,单位 ms。默认60000。H5(HBuilderX 2.9.9+)、APP(HBuilderX 2.9.9+)、微信小程序(2.10.0)、支付宝小程序
- * @param {Boolean} arg.sslVerify - 全局默认的是否验证 ssl 证书。默认true.仅App安卓端支持(HBuilderX 2.3.3+)
- * @param {Boolean} arg.withCredentials - 全局默认的跨域请求时是否携带凭证(cookies)。默认false。仅H5支持(HBuilderX 2.6.15+)
- * @param {Boolean} arg.firstIpv4 - 全DNS解析时优先使用ipv4。默认false。仅 App-Android 支持 (HBuilderX 2.8.0+)
- * @param {Function(statusCode):Boolean} arg.validateStatus - 全局默认的自定义验证器。默认statusCode >= 200 && statusCode < 300
- */
- constructor(arg = {}) {
- if (!isPlainObject(arg)) {
- arg = {};
- console.warn("设置全局参数必须接收一个Object");
- }
- this.config = clone$2({ ...defaults$1, ...arg });
- this.interceptors = {
- request: new InterceptorManager(),
- response: new InterceptorManager()
- };
- }
- /**
- * @Function
- * @param {Request~setConfigCallback} f - 设置全局默认配置
- */
- setConfig(f2) {
- this.config = f2(this.config);
- }
- middleware(config2) {
- config2 = mergeConfig(this.config, config2);
- const chain = [dispatchRequest, void 0];
- let promise2 = Promise.resolve(config2);
- this.interceptors.request.forEach((interceptor) => {
- chain.unshift(interceptor.fulfilled, interceptor.rejected);
- });
- this.interceptors.response.forEach((interceptor) => {
- chain.push(interceptor.fulfilled, interceptor.rejected);
- });
- while (chain.length) {
- promise2 = promise2.then(chain.shift(), chain.shift());
- }
- return promise2;
- }
- /**
- * @Function
- * @param {Object} config - 请求配置项
- * @prop {String} options.url - 请求路径
- * @prop {Object} options.data - 请求参数
- * @prop {Object} [options.responseType = config.responseType] [text|arraybuffer] - 响应的数据类型
- * @prop {Object} [options.dataType = config.dataType] - 如果设为 json,会尝试对返回的数据做一次 JSON.parse
- * @prop {Object} [options.header = config.header] - 请求header
- * @prop {Object} [options.method = config.method] - 请求方法
- * @returns {Promise<unknown>}
- */
- request(config2 = {}) {
- return this.middleware(config2);
- }
- get(url3, options = {}) {
- return this.middleware({
- url: url3,
- method: "GET",
- ...options
- });
- }
- post(url3, data, options = {}) {
- return this.middleware({
- url: url3,
- data,
- method: "POST",
- ...options
- });
- }
- put(url3, data, options = {}) {
- return this.middleware({
- url: url3,
- data,
- method: "PUT",
- ...options
- });
- }
- delete(url3, data, options = {}) {
- return this.middleware({
- url: url3,
- data,
- method: "DELETE",
- ...options
- });
- }
- connect(url3, data, options = {}) {
- return this.middleware({
- url: url3,
- data,
- method: "CONNECT",
- ...options
- });
- }
- head(url3, data, options = {}) {
- return this.middleware({
- url: url3,
- data,
- method: "HEAD",
- ...options
- });
- }
- options(url3, data, options = {}) {
- return this.middleware({
- url: url3,
- data,
- method: "OPTIONS",
- ...options
- });
- }
- trace(url3, data, options = {}) {
- return this.middleware({
- url: url3,
- data,
- method: "TRACE",
- ...options
- });
- }
- upload(url3, config2 = {}) {
- config2.url = url3;
- config2.method = "UPLOAD";
- return this.middleware(config2);
- }
- download(url3, config2 = {}) {
- config2.url = url3;
- config2.method = "DOWNLOAD";
- return this.middleware(config2);
- }
- }
- class Router {
- constructor() {
- this.config = {
- type: "navigateTo",
- url: "",
- delta: 1,
- // navigateBack页面后退时,回退的层数
- params: {},
- // 传递的参数
- animationType: "pop-in",
- // 窗口动画,只在APP有效
- animationDuration: 300,
- // 窗口动画持续时间,单位毫秒,只在APP有效
- intercept: false
- // 是否需要拦截
- };
- this.route = this.route.bind(this);
- }
- // 判断url前面是否有"/",如果没有则加上,否则无法跳转
- addRootPath(url3) {
- return url3[0] === "/" ? url3 : `/${url3}`;
- }
- // 整合路由参数
- mixinParam(url3, params) {
- url3 = url3 && this.addRootPath(url3);
- let query = "";
- if (/.*\/.*\?.*=.*/.test(url3)) {
- query = index$1.$u.queryParams(params, false);
- return url3 += `&${query}`;
- }
- query = index$1.$u.queryParams(params);
- return url3 += query;
- }
- // 对外的方法名称
- async route(options = {}, params = {}) {
- let mergeConfig2 = {};
- if (typeof options === "string") {
- mergeConfig2.url = this.mixinParam(options, params);
- mergeConfig2.type = "navigateTo";
- } else {
- mergeConfig2 = index$1.$u.deepMerge(this.config, options);
- mergeConfig2.url = this.mixinParam(options.url, options.params);
- }
- if (mergeConfig2.url === index$1.$u.page())
- return;
- if (params.intercept) {
- this.config.intercept = params.intercept;
- }
- mergeConfig2.params = params;
- mergeConfig2 = index$1.$u.deepMerge(this.config, mergeConfig2);
- if (typeof index$1.$u.routeIntercept === "function") {
- const isNext = await new Promise((resolve2, reject) => {
- index$1.$u.routeIntercept(mergeConfig2, resolve2);
- });
- isNext && this.openPage(mergeConfig2);
- } else {
- this.openPage(mergeConfig2);
- }
- }
- // 执行路由跳转
- openPage(config2) {
- const {
- url: url3,
- type: type2,
- delta,
- animationType,
- animationDuration
- } = config2;
- if (config2.type == "navigateTo" || config2.type == "to") {
- index$1.navigateTo({
- url: url3,
- animationType,
- animationDuration
- });
- }
- if (config2.type == "redirectTo" || config2.type == "redirect") {
- index$1.redirectTo({
- url: url3
- });
- }
- if (config2.type == "switchTab" || config2.type == "tab") {
- index$1.switchTab({
- url: url3
- });
- }
- if (config2.type == "reLaunch" || config2.type == "launch") {
- index$1.reLaunch({
- url: url3
- });
- }
- if (config2.type == "navigateBack" || config2.type == "back") {
- index$1.navigateBack({
- delta
- });
- }
- }
- }
- const route = new Router().route;
- function colorGradient(startColor = "rgb(0, 0, 0)", endColor = "rgb(255, 255, 255)", step = 10) {
- const startRGB = hexToRgb(startColor, false);
- const startR = startRGB[0];
- const startG = startRGB[1];
- const startB = startRGB[2];
- const endRGB = hexToRgb(endColor, false);
- const endR = endRGB[0];
- const endG = endRGB[1];
- const endB = endRGB[2];
- const sR = (endR - startR) / step;
- const sG = (endG - startG) / step;
- const sB = (endB - startB) / step;
- const colorArr = [];
- for (let i = 0; i < step; i++) {
- let hex2 = rgbToHex(`rgb(${Math.round(sR * i + startR)},${Math.round(sG * i + startG)},${Math.round(sB * i + startB)})`);
- if (i === 0)
- hex2 = rgbToHex(startColor);
- if (i === step - 1)
- hex2 = rgbToHex(endColor);
- colorArr.push(hex2);
- }
- return colorArr;
- }
- function hexToRgb(sColor, str = true) {
- const reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
- sColor = String(sColor).toLowerCase();
- if (sColor && reg.test(sColor)) {
- if (sColor.length === 4) {
- let sColorNew = "#";
- for (let i = 1; i < 4; i += 1) {
- sColorNew += sColor.slice(i, i + 1).concat(sColor.slice(i, i + 1));
- }
- sColor = sColorNew;
- }
- const sColorChange = [];
- for (let i = 1; i < 7; i += 2) {
- sColorChange.push(parseInt(`0x${sColor.slice(i, i + 2)}`));
- }
- if (!str) {
- return sColorChange;
- }
- return `rgb(${sColorChange[0]},${sColorChange[1]},${sColorChange[2]})`;
- }
- if (/^(rgb|RGB)/.test(sColor)) {
- const arr = sColor.replace(/(?:\(|\)|rgb|RGB)*/g, "").split(",");
- return arr.map((val) => Number(val));
- }
- return sColor;
- }
- function rgbToHex(rgb) {
- const _this = rgb;
- const reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
- if (/^(rgb|RGB)/.test(_this)) {
- const aColor = _this.replace(/(?:\(|\)|rgb|RGB)*/g, "").split(",");
- let strHex = "#";
- for (let i = 0; i < aColor.length; i++) {
- let hex2 = Number(aColor[i]).toString(16);
- hex2 = String(hex2).length == 1 ? `${0}${hex2}` : hex2;
- if (hex2 === "0") {
- hex2 += hex2;
- }
- strHex += hex2;
- }
- if (strHex.length !== 7) {
- strHex = _this;
- }
- return strHex;
- }
- if (reg.test(_this)) {
- const aNum = _this.replace(/#/, "").split("");
- if (aNum.length === 6) {
- return _this;
- }
- if (aNum.length === 3) {
- let numHex = "#";
- for (let i = 0; i < aNum.length; i += 1) {
- numHex += aNum[i] + aNum[i];
- }
- return numHex;
- }
- } else {
- return _this;
- }
- }
- function colorToRgba(color2, alpha) {
- color2 = rgbToHex(color2);
- const reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
- let sColor = String(color2).toLowerCase();
- if (sColor && reg.test(sColor)) {
- if (sColor.length === 4) {
- let sColorNew = "#";
- for (let i = 1; i < 4; i += 1) {
- sColorNew += sColor.slice(i, i + 1).concat(sColor.slice(i, i + 1));
- }
- sColor = sColorNew;
- }
- const sColorChange = [];
- for (let i = 1; i < 7; i += 2) {
- sColorChange.push(parseInt(`0x${sColor.slice(i, i + 2)}`));
- }
- return `rgba(${sColorChange.join(",")},${alpha})`;
- }
- return sColor;
- }
- const colorGradient$1 = {
- colorGradient,
- hexToRgb,
- rgbToHex,
- colorToRgba
- };
- function email(value2) {
- return /^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/.test(value2);
- }
- function mobile(value2) {
- return /^1[23456789]\d{9}$/.test(value2);
- }
- function url(value2) {
- return /^((https|http|ftp|rtsp|mms):\/\/)(([0-9a-zA-Z_!~*'().&=+$%-]+: )?[0-9a-zA-Z_!~*'().&=+$%-]+@)?(([0-9]{1,3}.){3}[0-9]{1,3}|([0-9a-zA-Z_!~*'()-]+.)*([0-9a-zA-Z][0-9a-zA-Z-]{0,61})?[0-9a-zA-Z].[a-zA-Z]{2,6})(:[0-9]{1,4})?((\/?)|(\/[0-9a-zA-Z_!~*'().;?:@&=+$,%#-]+)+\/?)$/.test(value2);
- }
- function date$1(value2) {
- if (!value2)
- return false;
- if (number$1(value2))
- value2 = +value2;
- return !/Invalid|NaN/.test(new Date(value2).toString());
- }
- function dateISO(value2) {
- return /^\d{4}[\/\-](0?[1-9]|1[012])[\/\-](0?[1-9]|[12][0-9]|3[01])$/.test(value2);
- }
- function number$1(value2) {
- return /^[\+-]?(\d+\.?\d*|\.\d+|\d\.\d+e\+\d+)$/.test(value2);
- }
- function string$1(value2) {
- return typeof value2 === "string";
- }
- function digits(value2) {
- return /^\d+$/.test(value2);
- }
- function idCard(value2) {
- return /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/.test(
- value2
- );
- }
- function carNo(value2) {
- const xreg = /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领A-Z]{1}[A-Z]{1}(([0-9]{5}[DF]$)|([DF][A-HJ-NP-Z0-9][0-9]{4}$))/;
- const creg = /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领A-Z]{1}[A-Z]{1}[A-HJ-NP-Z0-9]{4}[A-HJ-NP-Z0-9挂学警港澳]{1}$/;
- if (value2.length === 7) {
- return creg.test(value2);
- }
- if (value2.length === 8) {
- return xreg.test(value2);
- }
- return false;
- }
- function amount(value2) {
- return /^[1-9]\d*(,\d{3})*(\.\d{1,2})?$|^0\.\d{1,2}$/.test(value2);
- }
- function chinese(value2) {
- const reg = /^[\u4e00-\u9fa5]+$/gi;
- return reg.test(value2);
- }
- function letter(value2) {
- return /^[a-zA-Z]*$/.test(value2);
- }
- function enOrNum(value2) {
- const reg = /^[0-9a-zA-Z]*$/g;
- return reg.test(value2);
- }
- function contains(value2, param) {
- return value2.indexOf(param) >= 0;
- }
- function range$2(value2, param) {
- return value2 >= param[0] && value2 <= param[1];
- }
- function rangeLength(value2, param) {
- return value2.length >= param[0] && value2.length <= param[1];
- }
- function landline(value2) {
- const reg = /^\d{3,4}-\d{7,8}(-\d{3,4})?$/;
- return reg.test(value2);
- }
- function empty(value2) {
- switch (typeof value2) {
- case "undefined":
- return true;
- case "string":
- if (value2.replace(/(^[ \t\n\r]*)|([ \t\n\r]*$)/g, "").length == 0)
- return true;
- break;
- case "boolean":
- if (!value2)
- return true;
- break;
- case "number":
- if (value2 === 0 || isNaN(value2))
- return true;
- break;
- case "object":
- if (value2 === null || value2.length === 0)
- return true;
- for (const i in value2) {
- return false;
- }
- return true;
- }
- return false;
- }
- function jsonString(value2) {
- if (typeof value2 === "string") {
- try {
- const obj = JSON.parse(value2);
- if (typeof obj === "object" && obj) {
- return true;
- }
- return false;
- } catch (e2) {
- return false;
- }
- }
- return false;
- }
- function array$1(value2) {
- if (typeof Array.isArray === "function") {
- return Array.isArray(value2);
- }
- return Object.prototype.toString.call(value2) === "[object Array]";
- }
- function object$1(value2) {
- return Object.prototype.toString.call(value2) === "[object Object]";
- }
- function code(value2, len = 6) {
- return new RegExp(`^\\d{${len}}$`).test(value2);
- }
- function func(value2) {
- return typeof value2 === "function";
- }
- function promise(value2) {
- return object$1(value2) && func(value2.then) && func(value2.catch);
- }
- function image(value2) {
- const newValue = value2.split("?")[0];
- const IMAGE_REGEXP = /\.(jpeg|jpg|gif|png|svg|webp|jfif|bmp|dpg)/i;
- return IMAGE_REGEXP.test(newValue);
- }
- function video(value2) {
- const VIDEO_REGEXP = /\.(mp4|mpg|mpeg|dat|asf|avi|rm|rmvb|mov|wmv|flv|mkv|m3u8)/i;
- return VIDEO_REGEXP.test(value2);
- }
- function regExp(o2) {
- return o2 && Object.prototype.toString.call(o2) === "[object RegExp]";
- }
- const test = {
- email,
- mobile,
- url,
- date: date$1,
- dateISO,
- number: number$1,
- digits,
- idCard,
- carNo,
- amount,
- chinese,
- letter,
- enOrNum,
- contains,
- range: range$2,
- rangeLength,
- empty,
- isEmpty: empty,
- jsonString,
- landline,
- object: object$1,
- array: array$1,
- code,
- func,
- promise,
- video,
- image,
- regExp,
- string: string$1
- };
- let timeout = null;
- function debounce(func2, wait = 500, immediate = false) {
- if (timeout !== null)
- clearTimeout(timeout);
- if (immediate) {
- const callNow = !timeout;
- timeout = setTimeout(() => {
- timeout = null;
- }, wait);
- if (callNow)
- typeof func2 === "function" && func2();
- } else {
- timeout = setTimeout(() => {
- typeof func2 === "function" && func2();
- }, wait);
- }
- }
- let flag;
- function throttle(func2, wait = 500, immediate = true) {
- if (immediate) {
- if (!flag) {
- flag = true;
- typeof func2 === "function" && func2();
- setTimeout(() => {
- flag = false;
- }, wait);
- }
- } else if (!flag) {
- flag = true;
- setTimeout(() => {
- flag = false;
- typeof func2 === "function" && func2();
- }, wait);
- }
- }
- function strip(num, precision = 15) {
- return +parseFloat(Number(num).toPrecision(precision));
- }
- function digitLength(num) {
- const eSplit = num.toString().split(/[eE]/);
- const len = (eSplit[0].split(".")[1] || "").length - +(eSplit[1] || 0);
- return len > 0 ? len : 0;
- }
- function float2Fixed(num) {
- if (num.toString().indexOf("e") === -1) {
- return Number(num.toString().replace(".", ""));
- }
- const dLen = digitLength(num);
- return dLen > 0 ? strip(Number(num) * Math.pow(10, dLen)) : Number(num);
- }
- function checkBoundary(num) {
- {
- if (num > Number.MAX_SAFE_INTEGER || num < Number.MIN_SAFE_INTEGER) {
- console.warn(`${num} 超出了精度限制,结果可能不正确`);
- }
- }
- }
- function iteratorOperation(arr, operation) {
- const [num1, num2, ...others] = arr;
- let res = operation(num1, num2);
- others.forEach((num) => {
- res = operation(res, num);
- });
- return res;
- }
- function times(...nums) {
- if (nums.length > 2) {
- return iteratorOperation(nums, times);
- }
- const [num1, num2] = nums;
- const num1Changed = float2Fixed(num1);
- const num2Changed = float2Fixed(num2);
- const baseNum = digitLength(num1) + digitLength(num2);
- const leftValue = num1Changed * num2Changed;
- checkBoundary(leftValue);
- return leftValue / Math.pow(10, baseNum);
- }
- function divide(...nums) {
- if (nums.length > 2) {
- return iteratorOperation(nums, divide);
- }
- const [num1, num2] = nums;
- const num1Changed = float2Fixed(num1);
- const num2Changed = float2Fixed(num2);
- checkBoundary(num1Changed);
- checkBoundary(num2Changed);
- return times(num1Changed / num2Changed, strip(Math.pow(10, digitLength(num2) - digitLength(num1))));
- }
- function round$1(num, ratio) {
- const base = Math.pow(10, ratio);
- let result = divide(Math.round(Math.abs(times(num, base))), base);
- if (num < 0 && result !== 0) {
- result = times(result, -1);
- }
- return result;
- }
- function range$1(min2 = 0, max2 = 0, value2 = 0) {
- return Math.max(min2, Math.min(max2, Number(value2)));
- }
- function getPx(value2, unit = false) {
- if (test.number(value2)) {
- return unit ? `${value2}px` : Number(value2);
- }
- if (/(rpx|upx)$/.test(value2)) {
- return unit ? `${index$1.upx2px(parseInt(value2))}px` : Number(index$1.upx2px(parseInt(value2)));
- }
- return unit ? `${parseInt(value2)}px` : parseInt(value2);
- }
- function sleep(value2 = 30) {
- return new Promise((resolve2) => {
- setTimeout(() => {
- resolve2();
- }, value2);
- });
- }
- function os() {
- return index$1.getSystemInfoSync().platform.toLowerCase();
- }
- function sys() {
- return index$1.getSystemInfoSync();
- }
- function random(min2, max2) {
- if (min2 >= 0 && max2 > 0 && max2 >= min2) {
- const gab = max2 - min2 + 1;
- return Math.floor(Math.random() * gab + min2);
- }
- return 0;
- }
- function guid(len = 32, firstU = true, radix = null) {
- const chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split("");
- const uuid = [];
- radix = radix || chars.length;
- if (len) {
- for (let i = 0; i < len; i++)
- uuid[i] = chars[0 | Math.random() * radix];
- } else {
- let r;
- uuid[8] = uuid[13] = uuid[18] = uuid[23] = "-";
- uuid[14] = "4";
- for (let i = 0; i < 36; i++) {
- if (!uuid[i]) {
- r = 0 | Math.random() * 16;
- uuid[i] = chars[i == 19 ? r & 3 | 8 : r];
- }
- }
- }
- if (firstU) {
- uuid.shift();
- return `u${uuid.join("")}`;
- }
- return uuid.join("");
- }
- function $parent(name = void 0) {
- let parent = this.$parent;
- while (parent) {
- if (parent.$options && parent.$options.name !== name) {
- parent = parent.$parent;
- } else {
- return parent;
- }
- }
- return false;
- }
- function addStyle(customStyle, target = "object") {
- if (test.empty(customStyle) || typeof customStyle === "object" && target === "object" || target === "string" && typeof customStyle === "string") {
- return customStyle;
- }
- if (target === "object") {
- customStyle = trim(customStyle);
- const styleArray = customStyle.split(";");
- const style = {};
- for (let i = 0; i < styleArray.length; i++) {
- if (styleArray[i]) {
- const item = styleArray[i].split(":");
- style[trim(item[0])] = trim(item[1]);
- }
- }
- return style;
- }
- let string2 = "";
- for (const i in customStyle) {
- const key = i.replace(/([A-Z])/g, "-$1").toLowerCase();
- string2 += `${key}:${customStyle[i]};`;
- }
- return trim(string2);
- }
- function addUnit(value2 = "auto", unit = "") {
- if (!unit) {
- unit = index$1.$u.config.unit || "px";
- }
- value2 = String(value2);
- return test.number(value2) ? `${value2}${unit}` : value2;
- }
- function deepClone(obj) {
- if ([null, void 0, NaN, false].includes(obj))
- return obj;
- if (typeof obj !== "object" && typeof obj !== "function") {
- return obj;
- }
- const o2 = test.array(obj) ? [] : {};
- for (const i in obj) {
- if (obj.hasOwnProperty(i)) {
- o2[i] = typeof obj[i] === "object" ? deepClone(obj[i]) : obj[i];
- }
- }
- return o2;
- }
- function deepMerge$1(target = {}, source = {}) {
- target = deepClone(target);
- if (typeof target !== "object" || typeof source !== "object")
- return false;
- for (const prop in source) {
- if (!source.hasOwnProperty(prop))
- continue;
- if (prop in target) {
- if (source[prop] == null) {
- target[prop] = source[prop];
- } else if (typeof target[prop] !== "object") {
- target[prop] = source[prop];
- } else if (typeof source[prop] !== "object") {
- target[prop] = source[prop];
- } else if (target[prop].concat && source[prop].concat) {
- target[prop] = target[prop].concat(source[prop]);
- } else {
- target[prop] = deepMerge$1(target[prop], source[prop]);
- }
- } else {
- target[prop] = source[prop];
- }
- }
- return target;
- }
- function error(err) {
- {
- console.error(`uView提示:${err}`);
- }
- }
- function randomArray(array3 = []) {
- return array3.sort(() => Math.random() - 0.5);
- }
- if (!String.prototype.padStart) {
- String.prototype.padStart = function(maxLength, fillString = " ") {
- if (Object.prototype.toString.call(fillString) !== "[object String]") {
- throw new TypeError(
- "fillString must be String"
- );
- }
- const str = this;
- if (str.length >= maxLength)
- return String(str);
- const fillLength = maxLength - str.length;
- let times2 = Math.ceil(fillLength / fillString.length);
- while (times2 >>= 1) {
- fillString += fillString;
- if (times2 === 1) {
- fillString += fillString;
- }
- }
- return fillString.slice(0, fillLength) + str;
- };
- }
- function timeFormat(dateTime = null, formatStr = "yyyy-mm-dd") {
- let date3;
- if (!dateTime) {
- date3 = /* @__PURE__ */ new Date();
- } else if (/^\d{10}$/.test(dateTime.toString().trim())) {
- date3 = new Date(dateTime * 1e3);
- } else if (typeof dateTime === "string" && /^\d+$/.test(dateTime.trim())) {
- date3 = new Date(Number(dateTime));
- } else {
- date3 = new Date(
- typeof dateTime === "string" ? dateTime.replace(/-/g, "/") : dateTime
- );
- }
- const timeSource = {
- "y": date3.getFullYear().toString(),
- // 年
- "m": (date3.getMonth() + 1).toString().padStart(2, "0"),
- // 月
- "d": date3.getDate().toString().padStart(2, "0"),
- // 日
- "h": date3.getHours().toString().padStart(2, "0"),
- // 时
- "M": date3.getMinutes().toString().padStart(2, "0"),
- // 分
- "s": date3.getSeconds().toString().padStart(2, "0")
- // 秒
- // 有其他格式化字符需求可以继续添加,必须转化成字符串
- };
- for (const key in timeSource) {
- const [ret] = new RegExp(`${key}+`).exec(formatStr) || [];
- if (ret) {
- const beginIndex = key === "y" && ret.length === 2 ? 2 : 0;
- formatStr = formatStr.replace(ret, timeSource[key].slice(beginIndex));
- }
- }
- return formatStr;
- }
- function timeFrom(timestamp = null, format2 = "yyyy-mm-dd") {
- if (timestamp == null)
- timestamp = Number(/* @__PURE__ */ new Date());
- timestamp = parseInt(timestamp);
- if (timestamp.toString().length == 10)
- timestamp *= 1e3;
- let timer = (/* @__PURE__ */ new Date()).getTime() - timestamp;
- timer = parseInt(timer / 1e3);
- let tips = "";
- switch (true) {
- case timer < 300:
- tips = "刚刚";
- break;
- case (timer >= 300 && timer < 3600):
- tips = `${parseInt(timer / 60)}分钟前`;
- break;
- case (timer >= 3600 && timer < 86400):
- tips = `${parseInt(timer / 3600)}小时前`;
- break;
- case (timer >= 86400 && timer < 2592e3):
- tips = `${parseInt(timer / 86400)}天前`;
- break;
- default:
- if (format2 === false) {
- if (timer >= 2592e3 && timer < 365 * 86400) {
- tips = `${parseInt(timer / (86400 * 30))}个月前`;
- } else {
- tips = `${parseInt(timer / (86400 * 365))}年前`;
- }
- } else {
- tips = timeFormat(timestamp, format2);
- }
- }
- return tips;
- }
- function trim(str, pos = "both") {
- str = String(str);
- if (pos == "both") {
- return str.replace(/^\s+|\s+$/g, "");
- }
- if (pos == "left") {
- return str.replace(/^\s*/, "");
- }
- if (pos == "right") {
- return str.replace(/(\s*$)/g, "");
- }
- if (pos == "all") {
- return str.replace(/\s+/g, "");
- }
- return str;
- }
- function queryParams(data = {}, isPrefix = true, arrayFormat = "brackets") {
- const prefix = isPrefix ? "?" : "";
- const _result = [];
- if (["indices", "brackets", "repeat", "comma"].indexOf(arrayFormat) == -1)
- arrayFormat = "brackets";
- for (const key in data) {
- const value2 = data[key];
- if (["", void 0, null].indexOf(value2) >= 0) {
- continue;
- }
- if (value2.constructor === Array) {
- switch (arrayFormat) {
- case "indices":
- for (let i = 0; i < value2.length; i++) {
- _result.push(`${key}[${i}]=${value2[i]}`);
- }
- break;
- case "brackets":
- value2.forEach((_value) => {
- _result.push(`${key}[]=${_value}`);
- });
- break;
- case "repeat":
- value2.forEach((_value) => {
- _result.push(`${key}=${_value}`);
- });
- break;
- case "comma":
- let commaStr = "";
- value2.forEach((_value) => {
- commaStr += (commaStr ? "," : "") + _value;
- });
- _result.push(`${key}=${commaStr}`);
- break;
- default:
- value2.forEach((_value) => {
- _result.push(`${key}[]=${_value}`);
- });
- }
- } else {
- _result.push(`${key}=${value2}`);
- }
- }
- return _result.length ? prefix + _result.join("&") : "";
- }
- function toast(title, duration = 2e3) {
- index$1.showToast({
- title: String(title),
- icon: "none",
- duration
- });
- }
- function type2icon(type2 = "success", fill = false) {
- if (["primary", "info", "error", "warning", "success"].indexOf(type2) == -1)
- type2 = "success";
- let iconName = "";
- switch (type2) {
- case "primary":
- iconName = "info-circle";
- break;
- case "info":
- iconName = "info-circle";
- break;
- case "error":
- iconName = "close-circle";
- break;
- case "warning":
- iconName = "error-circle";
- break;
- case "success":
- iconName = "checkmark-circle";
- break;
- default:
- iconName = "checkmark-circle";
- }
- if (fill)
- iconName += "-fill";
- return iconName;
- }
- function priceFormat(number3, decimals = 0, decimalPoint = ".", thousandsSeparator = ",") {
- number3 = `${number3}`.replace(/[^0-9+-Ee.]/g, "");
- const n2 = !isFinite(+number3) ? 0 : +number3;
- const prec = !isFinite(+decimals) ? 0 : Math.abs(decimals);
- const sep = typeof thousandsSeparator === "undefined" ? "," : thousandsSeparator;
- const dec = typeof decimalPoint === "undefined" ? "." : decimalPoint;
- let s2 = "";
- s2 = (prec ? round$1(n2, prec) + "" : `${Math.round(n2)}`).split(".");
- const re = /(-?\d+)(\d{3})/;
- while (re.test(s2[0])) {
- s2[0] = s2[0].replace(re, `$1${sep}$2`);
- }
- if ((s2[1] || "").length < prec) {
- s2[1] = s2[1] || "";
- s2[1] += new Array(prec - s2[1].length + 1).join("0");
- }
- return s2.join(dec);
- }
- function getDuration(value2, unit = true) {
- const valueNum = parseInt(value2);
- if (unit) {
- if (/s$/.test(value2))
- return value2;
- return value2 > 30 ? `${value2}ms` : `${value2}s`;
- }
- if (/ms$/.test(value2))
- return valueNum;
- if (/s$/.test(value2))
- return valueNum > 30 ? valueNum : valueNum * 1e3;
- return valueNum;
- }
- function padZero(value2) {
- return `00${value2}`.slice(-2);
- }
- function formValidate(instance, event) {
- const formItem = index$1.$u.$parent.call(instance, "u-form-item");
- const form = index$1.$u.$parent.call(instance, "u-form");
- if (formItem && form) {
- form.validateField(formItem.prop, () => {
- }, event);
- }
- }
- function getProperty(obj, key) {
- if (!obj) {
- return;
- }
- if (typeof key !== "string" || key === "") {
- return "";
- }
- if (key.indexOf(".") !== -1) {
- const keys2 = key.split(".");
- let firstObj = obj[keys2[0]] || {};
- for (let i = 1; i < keys2.length; i++) {
- if (firstObj) {
- firstObj = firstObj[keys2[i]];
- }
- }
- return firstObj;
- }
- return obj[key];
- }
- function setProperty(obj, key, value2) {
- if (!obj) {
- return;
- }
- const inFn = function(_obj, keys2, v) {
- if (keys2.length === 1) {
- _obj[keys2[0]] = v;
- return;
- }
- while (keys2.length > 1) {
- const k = keys2[0];
- if (!_obj[k] || typeof _obj[k] !== "object") {
- _obj[k] = {};
- }
- keys2.shift();
- inFn(_obj[k], keys2, v);
- }
- };
- if (typeof key !== "string" || key === "")
- ;
- else if (key.indexOf(".") !== -1) {
- const keys2 = key.split(".");
- inFn(obj, keys2, value2);
- } else {
- obj[key] = value2;
- }
- }
- function page() {
- const pages2 = getCurrentPages();
- return `/${pages2[pages2.length - 1].route || ""}`;
- }
- function pages() {
- const pages2 = getCurrentPages();
- return pages2;
- }
- function setConfig({
- props: props2 = {},
- config: config2 = {},
- color: color2 = {},
- zIndex: zIndex2 = {}
- }) {
- const {
- deepMerge: deepMerge2
- } = index$1.$u;
- index$1.$u.config = deepMerge2(index$1.$u.config, config2);
- index$1.$u.props = deepMerge2(index$1.$u.props, props2);
- index$1.$u.color = deepMerge2(index$1.$u.color, color2);
- index$1.$u.zIndex = deepMerge2(index$1.$u.zIndex, zIndex2);
- }
- const index = {
- range: range$1,
- getPx,
- sleep,
- os,
- sys,
- random,
- guid,
- $parent,
- addStyle,
- addUnit,
- deepClone,
- deepMerge: deepMerge$1,
- error,
- randomArray,
- timeFormat,
- timeFrom,
- trim,
- queryParams,
- toast,
- type2icon,
- priceFormat,
- getDuration,
- padZero,
- formValidate,
- getProperty,
- setProperty,
- page,
- pages,
- setConfig
- };
- const version = "3";
- {
- console.log(`
- %c uview-plus V${version} %c https://ijry.github.io/uview-plus/
- `, "color: #ffffff; background: #3c9cff; padding:5px 0;", "color: #3c9cff;background: #ffffff; padding:5px 0;");
- }
- const config = {
- v: version,
- version,
- // 主题名称
- type: [
- "primary",
- "success",
- "info",
- "error",
- "warning"
- ],
- // 颜色部分,本来可以通过scss的:export导出供js使用,但是奈何nvue不支持
- color: {
- "u-primary": "#2979ff",
- "u-warning": "#ff9900",
- "u-success": "#19be6b",
- "u-error": "#fa3534",
- "u-info": "#909399",
- "u-main-color": "#303133",
- "u-content-color": "#606266",
- "u-tips-color": "#909399",
- "u-light-color": "#c0c4cc"
- },
- // 默认单位,可以通过配置为rpx,那么在用于传入组件大小参数为数值时,就默认为rpx
- unit: "px"
- };
- const ActionSheet = {
- // action-sheet组件
- actionSheet: {
- show: false,
- title: "",
- description: "",
- actions: () => [],
- index: "",
- cancelText: "",
- closeOnClickAction: true,
- safeAreaInsetBottom: true,
- openType: "",
- closeOnClickOverlay: true,
- round: 0
- }
- };
- const Album = {
- // album 组件
- album: {
- urls: () => [],
- keyName: "",
- singleSize: 180,
- multipleSize: 70,
- space: 6,
- singleMode: "scaleToFill",
- multipleMode: "aspectFill",
- maxCount: 9,
- previewFullImage: true,
- rowCount: 3,
- showMore: true
- }
- };
- const Alert = {
- // alert警告组件
- alert: {
- title: "",
- type: "warning",
- description: "",
- closable: false,
- showIcon: false,
- effect: "light",
- center: false,
- fontSize: 14
- }
- };
- const Avatar = {
- // avatar 组件
- avatar: {
- src: "",
- shape: "circle",
- size: 40,
- mode: "scaleToFill",
- text: "",
- bgColor: "#c0c4cc",
- color: "#ffffff",
- fontSize: 18,
- icon: "",
- mpAvatar: false,
- randomBgColor: false,
- defaultUrl: "",
- colorIndex: "",
- name: ""
- }
- };
- const AvatarGroup = {
- // avatarGroup 组件
- avatarGroup: {
- urls: () => [],
- maxCount: 5,
- shape: "circle",
- mode: "scaleToFill",
- showMore: true,
- size: 40,
- keyName: "",
- gap: 0.5,
- extraValue: 0
- }
- };
- const Backtop = {
- // backtop组件
- backtop: {
- mode: "circle",
- icon: "arrow-upward",
- text: "",
- duration: 100,
- scrollTop: 0,
- top: 400,
- bottom: 100,
- right: 20,
- zIndex: 9,
- iconStyle: () => ({
- color: "#909399",
- fontSize: "19px"
- })
- }
- };
- const Badge = {
- // 徽标数组件
- badge: {
- isDot: false,
- value: "",
- show: true,
- max: 999,
- type: "error",
- showZero: false,
- bgColor: null,
- color: null,
- shape: "circle",
- numberType: "overflow",
- offset: () => [],
- inverted: false,
- absolute: false
- }
- };
- const Button = {
- // button组件
- button: {
- hairline: false,
- type: "info",
- size: "normal",
- shape: "square",
- plain: false,
- disabled: false,
- loading: false,
- loadingText: "",
- loadingMode: "spinner",
- loadingSize: 15,
- openType: "",
- formType: "",
- appParameter: "",
- hoverStopPropagation: true,
- lang: "en",
- sessionFrom: "",
- sendMessageTitle: "",
- sendMessagePath: "",
- sendMessageImg: "",
- showMessageCard: false,
- dataName: "",
- throttleTime: 0,
- hoverStartTime: 0,
- hoverStayTime: 200,
- text: "",
- icon: "",
- iconColor: "",
- color: ""
- }
- };
- const Calendar = {
- // calendar 组件
- calendar: {
- title: "日期选择",
- showTitle: true,
- showSubtitle: true,
- mode: "single",
- startText: "开始",
- endText: "结束",
- customList: () => [],
- color: "#3c9cff",
- minDate: 0,
- maxDate: 0,
- defaultDate: null,
- maxCount: Number.MAX_SAFE_INTEGER,
- // Infinity
- rowHeight: 56,
- formatter: null,
- showLunar: false,
- showMark: true,
- confirmText: "确定",
- confirmDisabledText: "确定",
- show: false,
- closeOnClickOverlay: false,
- readonly: false,
- showConfirm: true,
- maxRange: Number.MAX_SAFE_INTEGER,
- // Infinity
- rangePrompt: "",
- showRangePrompt: true,
- allowSameDay: false,
- round: 0,
- monthNum: 3
- }
- };
- const CarKeyboard = {
- // 车牌号键盘
- carKeyboard: {
- random: false
- }
- };
- const Cell = {
- // cell组件的props
- cell: {
- customClass: "",
- title: "",
- label: "",
- value: "",
- icon: "",
- disabled: false,
- border: true,
- center: false,
- url: "",
- linkType: "navigateTo",
- clickable: false,
- isLink: false,
- required: false,
- arrowDirection: "",
- iconStyle: {},
- rightIconStyle: {},
- rightIcon: "arrow-right",
- titleStyle: {},
- size: "",
- stop: true,
- name: ""
- }
- };
- const CellGroup = {
- // cell-group组件的props
- cellGroup: {
- title: "",
- border: true,
- customStyle: {}
- }
- };
- const Checkbox = {
- // checkbox组件
- checkbox: {
- name: "",
- shape: "",
- size: "",
- checkbox: false,
- disabled: "",
- activeColor: "",
- inactiveColor: "",
- iconSize: "",
- iconColor: "",
- label: "",
- labelSize: "",
- labelColor: "",
- labelDisabled: ""
- }
- };
- const CheckboxGroup = {
- // checkbox-group组件
- checkboxGroup: {
- name: "",
- value: () => [],
- shape: "square",
- disabled: false,
- activeColor: "#2979ff",
- inactiveColor: "#c8c9cc",
- size: 18,
- placement: "row",
- labelSize: 14,
- labelColor: "#303133",
- labelDisabled: false,
- iconColor: "#ffffff",
- iconSize: 12,
- iconPlacement: "left",
- borderBottom: false
- }
- };
- const CircleProgress = {
- // circleProgress 组件
- circleProgress: {
- percentage: 30
- }
- };
- const Code = {
- // code 组件
- code: {
- seconds: 60,
- startText: "获取验证码",
- changeText: "X秒重新获取",
- endText: "重新获取",
- keepRunning: false,
- uniqueKey: ""
- }
- };
- const CodeInput = {
- // codeInput 组件
- codeInput: {
- adjustPosition: true,
- maxlength: 6,
- dot: false,
- mode: "box",
- hairline: false,
- space: 10,
- value: "",
- focus: false,
- bold: false,
- color: "#606266",
- fontSize: 18,
- size: 35,
- disabledKeyboard: false,
- borderColor: "#c9cacc",
- disabledDot: true
- }
- };
- const Col = {
- // col 组件
- col: {
- span: 12,
- offset: 0,
- justify: "start",
- align: "stretch",
- textAlign: "left"
- }
- };
- const Collapse = {
- // collapse 组件
- collapse: {
- value: null,
- accordion: false,
- border: true
- }
- };
- const CollapseItem = {
- // collapseItem 组件
- collapseItem: {
- title: "",
- value: "",
- label: "",
- disabled: false,
- isLink: true,
- clickable: true,
- border: true,
- align: "left",
- name: "",
- icon: "",
- duration: 300
- }
- };
- const ColumnNotice = {
- // columnNotice 组件
- columnNotice: {
- text: "",
- icon: "volume",
- mode: "",
- color: "#f9ae3d",
- bgColor: "#fdf6ec",
- fontSize: 14,
- speed: 80,
- step: false,
- duration: 1500,
- disableTouch: true
- }
- };
- const CountDown = {
- // u-count-down 计时器组件
- countDown: {
- time: 0,
- format: "HH:mm:ss",
- autoStart: true,
- millisecond: false
- }
- };
- const CountTo = {
- // countTo 组件
- countTo: {
- startVal: 0,
- endVal: 0,
- duration: 2e3,
- autoplay: true,
- decimals: 0,
- useEasing: true,
- decimal: ".",
- color: "#606266",
- fontSize: 22,
- bold: false,
- separator: ""
- }
- };
- const DatetimePicker = {
- // datetimePicker 组件
- datetimePicker: {
- show: false,
- popupMode: "bottom",
- showToolbar: true,
- value: "",
- title: "",
- mode: "datetime",
- maxDate: new Date((/* @__PURE__ */ new Date()).getFullYear() + 10, 0, 1).getTime(),
- minDate: new Date((/* @__PURE__ */ new Date()).getFullYear() - 10, 0, 1).getTime(),
- minHour: 0,
- maxHour: 23,
- minMinute: 0,
- maxMinute: 59,
- filter: null,
- formatter: null,
- loading: false,
- itemHeight: 44,
- cancelText: "取消",
- confirmText: "确认",
- cancelColor: "#909193",
- confirmColor: "#3c9cff",
- visibleItemCount: 5,
- closeOnClickOverlay: false,
- defaultIndex: () => []
- }
- };
- const Divider = {
- // divider组件
- divider: {
- dashed: false,
- hairline: true,
- dot: false,
- textPosition: "center",
- text: "",
- textSize: 14,
- textColor: "#909399",
- lineColor: "#dcdfe6"
- }
- };
- const Empty = {
- // empty组件
- empty: {
- icon: "",
- text: "",
- textColor: "#c0c4cc",
- textSize: 14,
- iconColor: "#c0c4cc",
- iconSize: 90,
- mode: "data",
- width: 160,
- height: 160,
- show: true,
- marginTop: 0
- }
- };
- const Form = {
- // form 组件
- form: {
- model: () => ({}),
- rules: () => ({}),
- errorType: "message",
- borderBottom: true,
- labelPosition: "left",
- labelWidth: 45,
- labelAlign: "left",
- labelStyle: () => ({})
- }
- };
- const GormItem = {
- // formItem 组件
- formItem: {
- label: "",
- prop: "",
- borderBottom: "",
- labelWidth: "",
- rightIcon: "",
- leftIcon: "",
- required: false,
- leftIconStyle: ""
- }
- };
- const Gap = {
- // gap组件
- gap: {
- bgColor: "transparent",
- height: 20,
- marginTop: 0,
- marginBottom: 0,
- customStyle: {}
- }
- };
- const Grid = {
- // grid组件
- grid: {
- col: 3,
- border: false,
- align: "left"
- }
- };
- const GridItem = {
- // grid-item组件
- gridItem: {
- name: null,
- bgColor: "transparent"
- }
- };
- const {
- color: color$3
- } = config;
- const Icon = {
- // icon组件
- icon: {
- name: "",
- color: color$3["u-content-color"],
- size: "16px",
- bold: false,
- index: "",
- hoverClass: "",
- customPrefix: "uicon",
- label: "",
- labelPos: "right",
- labelSize: "15px",
- labelColor: color$3["u-content-color"],
- space: "3px",
- imgMode: "",
- width: "",
- height: "",
- top: 0,
- stop: false
- }
- };
- const Image = {
- // image组件
- image: {
- src: "",
- mode: "aspectFill",
- width: "300",
- height: "225",
- shape: "square",
- radius: 0,
- lazyLoad: true,
- showMenuByLongpress: true,
- loadingIcon: "photo",
- errorIcon: "error-circle",
- showLoading: true,
- showError: true,
- fade: true,
- webp: false,
- duration: 500,
- bgColor: "#f3f4f6"
- }
- };
- const IndexAnchor = {
- // indexAnchor 组件
- indexAnchor: {
- text: "",
- color: "#606266",
- size: 14,
- bgColor: "#dedede",
- height: 32
- }
- };
- const IndexList = {
- // indexList 组件
- indexList: {
- inactiveColor: "#606266",
- activeColor: "#5677fc",
- indexList: () => [],
- sticky: true,
- customNavHeight: 0
- }
- };
- const Input = {
- // index 组件
- input: {
- value: "",
- type: "text",
- fixed: false,
- disabled: false,
- disabledColor: "#f5f7fa",
- clearable: false,
- password: false,
- maxlength: -1,
- placeholder: null,
- placeholderClass: "input-placeholder",
- placeholderStyle: "color: #c0c4cc",
- showWordLimit: false,
- confirmType: "done",
- confirmHold: false,
- holdKeyboard: false,
- focus: false,
- autoBlur: false,
- disableDefaultPadding: false,
- cursor: -1,
- cursorSpacing: 30,
- selectionStart: -1,
- selectionEnd: -1,
- adjustPosition: true,
- inputAlign: "left",
- fontSize: "15px",
- color: "#303133",
- prefixIcon: "",
- prefixIconStyle: "",
- suffixIcon: "",
- suffixIconStyle: "",
- border: "surround",
- readonly: false,
- shape: "square",
- formatter: null
- }
- };
- const Keyboard = {
- // 键盘组件
- keyboard: {
- mode: "number",
- dotDisabled: false,
- tooltip: true,
- showTips: true,
- tips: "",
- showCancel: true,
- showConfirm: true,
- random: false,
- safeAreaInsetBottom: true,
- closeOnClickOverlay: true,
- show: false,
- overlay: true,
- zIndex: 10075,
- cancelText: "取消",
- confirmText: "确定",
- autoChange: false
- }
- };
- const Line = {
- // line组件
- line: {
- color: "#d6d7d9",
- length: "100%",
- direction: "row",
- hairline: true,
- margin: 0,
- dashed: false
- }
- };
- const LineProgress = {
- // lineProgress 组件
- lineProgress: {
- activeColor: "#19be6b",
- inactiveColor: "#ececec",
- percentage: 0,
- showText: true,
- height: 12
- }
- };
- const {
- color: color$2
- } = config;
- const Link = {
- // link超链接组件props参数
- link: {
- color: color$2["u-primary"],
- fontSize: 15,
- underLine: false,
- href: "",
- mpTips: "链接已复制,请在浏览器打开",
- lineColor: "",
- text: ""
- }
- };
- const List = {
- // list 组件
- list: {
- showScrollbar: false,
- lowerThreshold: 50,
- upperThreshold: 0,
- scrollTop: 0,
- offsetAccuracy: 10,
- enableFlex: false,
- pagingEnabled: false,
- scrollable: true,
- scrollIntoView: "",
- scrollWithAnimation: false,
- enableBackToTop: false,
- height: 0,
- width: 0,
- preLoadScreen: 1
- }
- };
- const ListItem = {
- // listItem 组件
- listItem: {
- anchor: ""
- }
- };
- const {
- color: color$1
- } = config;
- const LoadingIcon = {
- // loading-icon加载中图标组件
- loadingIcon: {
- show: true,
- color: color$1["u-tips-color"],
- textColor: color$1["u-tips-color"],
- vertical: false,
- mode: "spinner",
- size: 24,
- textSize: 15,
- text: "",
- timingFunction: "ease-in-out",
- duration: 1200,
- inactiveColor: ""
- }
- };
- const LoadingPage = {
- // loading-page组件
- loadingPage: {
- loadingText: "正在加载",
- image: "",
- loadingMode: "circle",
- loading: false,
- bgColor: "#ffffff",
- color: "#C8C8C8",
- fontSize: 19,
- iconSize: 28,
- loadingColor: "#C8C8C8"
- }
- };
- const Loadmore = {
- // loadmore 组件
- loadmore: {
- status: "loadmore",
- bgColor: "transparent",
- icon: true,
- fontSize: 14,
- iconSize: 17,
- color: "#606266",
- loadingIcon: "spinner",
- loadmoreText: "加载更多",
- loadingText: "正在加载...",
- nomoreText: "没有更多了",
- isDot: false,
- iconColor: "#b7b7b7",
- marginTop: 10,
- marginBottom: 10,
- height: "auto",
- line: false,
- lineColor: "#E6E8EB",
- dashed: false
- }
- };
- const Modal = {
- // modal 组件
- modal: {
- show: false,
- title: "",
- content: "",
- confirmText: "确认",
- cancelText: "取消",
- showConfirmButton: true,
- showCancelButton: false,
- confirmColor: "#2979ff",
- cancelColor: "#606266",
- buttonReverse: false,
- zoom: true,
- asyncClose: false,
- closeOnClickOverlay: false,
- negativeTop: 0,
- width: "650rpx",
- confirmButtonShape: ""
- }
- };
- const color = {
- primary: "#3c9cff",
- info: "#909399",
- default: "#909399",
- warning: "#f9ae3d",
- error: "#f56c6c",
- success: "#5ac725",
- mainColor: "#303133",
- contentColor: "#606266",
- tipsColor: "#909399",
- lightColor: "#c0c4cc",
- borderColor: "#e4e7ed"
- };
- const Navbar = {
- // navbar 组件
- navbar: {
- safeAreaInsetTop: true,
- placeholder: false,
- fixed: true,
- border: false,
- leftIcon: "arrow-left",
- leftText: "",
- rightText: "",
- rightIcon: "",
- title: "",
- bgColor: "#ffffff",
- titleWidth: "400rpx",
- height: "44px",
- leftIconSize: 20,
- leftIconColor: color.mainColor,
- autoBack: false,
- titleStyle: ""
- }
- };
- const NoNetwork = {
- // noNetwork
- noNetwork: {
- tips: "哎呀,网络信号丢失",
- zIndex: "",
- image: "data:image/png;base64,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"
- }
- };
- const NoticeBar = {
- // noticeBar
- noticeBar: {
- text: () => [],
- direction: "row",
- step: false,
- icon: "volume",
- mode: "",
- color: "#f9ae3d",
- bgColor: "#fdf6ec",
- speed: 80,
- fontSize: 14,
- duration: 2e3,
- disableTouch: true,
- url: "",
- linkType: "navigateTo"
- }
- };
- const Notify = {
- // notify组件
- notify: {
- top: 0,
- type: "primary",
- color: "#ffffff",
- bgColor: "",
- message: "",
- duration: 3e3,
- fontSize: 15,
- safeAreaInsetTop: false
- }
- };
- const NumberBox = {
- // 步进器组件
- numberBox: {
- name: "",
- value: 0,
- min: 1,
- max: Number.MAX_SAFE_INTEGER,
- step: 1,
- integer: false,
- disabled: false,
- disabledInput: false,
- asyncChange: false,
- inputWidth: 35,
- showMinus: true,
- showPlus: true,
- decimalLength: null,
- longPress: true,
- color: "#323233",
- buttonSize: 30,
- bgColor: "#EBECEE",
- cursorSpacing: 100,
- disableMinus: false,
- disablePlus: false,
- iconStyle: ""
- }
- };
- const NumberKeyboard = {
- // 数字键盘
- numberKeyboard: {
- mode: "number",
- dotDisabled: false,
- random: false
- }
- };
- const Overlay = {
- // overlay组件
- overlay: {
- show: false,
- zIndex: 10070,
- duration: 300,
- opacity: 0.5
- }
- };
- const Parse = {
- // parse
- parse: {
- copyLink: true,
- errorImg: "",
- lazyLoad: false,
- loadingImg: "",
- pauseVideo: true,
- previewImg: true,
- setTitle: true,
- showImgMenu: true
- }
- };
- const Picker = {
- // picker
- picker: {
- show: false,
- popupMode: "bottom",
- showToolbar: true,
- title: "",
- columns: () => [],
- loading: false,
- itemHeight: 44,
- cancelText: "取消",
- confirmText: "确定",
- cancelColor: "#909193",
- confirmColor: "#3c9cff",
- visibleItemCount: 5,
- keyName: "text",
- closeOnClickOverlay: false,
- defaultIndex: () => [],
- immediateChange: false
- }
- };
- const Popup = {
- // popup组件
- popup: {
- show: false,
- overlay: true,
- mode: "bottom",
- duration: 300,
- closeable: false,
- overlayStyle: () => {
- },
- closeOnClickOverlay: true,
- zIndex: 10075,
- safeAreaInsetBottom: true,
- safeAreaInsetTop: false,
- closeIconPos: "top-right",
- round: 0,
- zoom: true,
- bgColor: "",
- overlayOpacity: 0.5
- }
- };
- const Radio = {
- // radio组件
- radio: {
- name: "",
- shape: "",
- disabled: "",
- labelDisabled: "",
- activeColor: "",
- inactiveColor: "",
- iconSize: "",
- labelSize: "",
- label: "",
- labelColor: "",
- size: "",
- iconColor: "",
- placement: ""
- }
- };
- const RadioGroup = {
- // radio-group组件
- radioGroup: {
- value: "",
- disabled: false,
- shape: "circle",
- activeColor: "#2979ff",
- inactiveColor: "#c8c9cc",
- name: "",
- size: 18,
- placement: "row",
- label: "",
- labelColor: "#303133",
- labelSize: 14,
- labelDisabled: false,
- iconColor: "#ffffff",
- iconSize: 12,
- borderBottom: false,
- iconPlacement: "left"
- }
- };
- const Rate = {
- // rate组件
- rate: {
- value: 1,
- count: 5,
- disabled: false,
- size: 18,
- inactiveColor: "#b2b2b2",
- activeColor: "#FA3534",
- gutter: 4,
- minCount: 1,
- allowHalf: false,
- activeIcon: "star-fill",
- inactiveIcon: "star",
- touchable: true
- }
- };
- const ReadMore = {
- // readMore
- readMore: {
- showHeight: 400,
- toggle: false,
- closeText: "展开阅读全文",
- openText: "收起",
- color: "#2979ff",
- fontSize: 14,
- textIndent: "2em",
- name: ""
- }
- };
- const Row = {
- // row
- row: {
- gutter: 0,
- justify: "start",
- align: "center"
- }
- };
- const RowNotice = {
- // rowNotice
- rowNotice: {
- text: "",
- icon: "volume",
- mode: "",
- color: "#f9ae3d",
- bgColor: "#fdf6ec",
- fontSize: 14,
- speed: 80
- }
- };
- const ScrollList = {
- // scrollList
- scrollList: {
- indicatorWidth: 50,
- indicatorBarWidth: 20,
- indicator: true,
- indicatorColor: "#f2f2f2",
- indicatorActiveColor: "#3c9cff",
- indicatorStyle: ""
- }
- };
- const Search = {
- // search
- search: {
- shape: "round",
- bgColor: "#f2f2f2",
- placeholder: "请输入关键字",
- clearabled: true,
- focus: false,
- showAction: true,
- actionStyle: () => ({}),
- actionText: "搜索",
- inputAlign: "left",
- inputStyle: () => ({}),
- disabled: false,
- borderColor: "transparent",
- searchIconColor: "#909399",
- searchIconSize: 22,
- color: "#606266",
- placeholderColor: "#909399",
- searchIcon: "search",
- margin: "0",
- animation: false,
- value: "",
- maxlength: "-1",
- height: 32,
- label: null
- }
- };
- const Section = {
- // u-section组件
- section: {
- title: "",
- subTitle: "更多",
- right: true,
- fontSize: 15,
- bold: true,
- color: "#303133",
- subColor: "#909399",
- showLine: true,
- lineColor: "",
- arrow: true
- }
- };
- const Skeleton = {
- // skeleton
- skeleton: {
- loading: true,
- animate: true,
- rows: 0,
- rowsWidth: "100%",
- rowsHeight: 18,
- title: true,
- titleWidth: "50%",
- titleHeight: 18,
- avatar: false,
- avatarSize: 32,
- avatarShape: "circle"
- }
- };
- const Slider = {
- // slider组件
- slider: {
- value: 0,
- blockSize: 18,
- min: 0,
- max: 100,
- step: 1,
- activeColor: "#2979ff",
- inactiveColor: "#c0c4cc",
- blockColor: "#ffffff",
- showValue: false,
- disabled: false,
- blockStyle: () => {
- }
- }
- };
- const StatusBar = {
- // statusBar
- statusBar: {
- bgColor: "transparent"
- }
- };
- const Steps = {
- // steps组件
- steps: {
- direction: "row",
- current: 0,
- activeColor: "#3c9cff",
- inactiveColor: "#969799",
- activeIcon: "",
- inactiveIcon: "",
- dot: false
- }
- };
- const StepsItem = {
- // steps-item组件
- stepsItem: {
- title: "",
- desc: "",
- iconSize: 17,
- error: false
- }
- };
- const Sticky = {
- // sticky组件
- sticky: {
- offsetTop: 0,
- customNavHeight: 0,
- disabled: false,
- bgColor: "transparent",
- zIndex: "",
- index: ""
- }
- };
- const Subsection = {
- // subsection组件
- subsection: {
- list: [],
- current: 0,
- activeColor: "#3c9cff",
- inactiveColor: "#303133",
- mode: "button",
- fontSize: 12,
- bold: true,
- bgColor: "#eeeeef",
- keyName: "name"
- }
- };
- const SwipeAction = {
- // swipe-action组件
- swipeAction: {
- autoClose: true
- }
- };
- const SwipeActionItem = {
- // swipeActionItem 组件
- swipeActionItem: {
- show: false,
- name: "",
- disabled: false,
- threshold: 20,
- autoClose: true,
- options: [],
- duration: 300
- }
- };
- const Swiper = {
- // swiper 组件
- swiper: {
- list: () => [],
- indicator: false,
- indicatorActiveColor: "#FFFFFF",
- indicatorInactiveColor: "rgba(255, 255, 255, 0.35)",
- indicatorStyle: "",
- indicatorMode: "line",
- autoplay: true,
- current: 0,
- currentItemId: "",
- interval: 3e3,
- duration: 300,
- circular: false,
- previousMargin: 0,
- nextMargin: 0,
- acceleration: false,
- displayMultipleItems: 1,
- easingFunction: "default",
- keyName: "url",
- imgMode: "aspectFill",
- height: 130,
- bgColor: "#f3f4f6",
- radius: 4,
- loading: false,
- showTitle: false
- }
- };
- const SwipterIndicator = {
- // swiperIndicator 组件
- swiperIndicator: {
- length: 0,
- current: 0,
- indicatorActiveColor: "",
- indicatorInactiveColor: "",
- indicatorMode: "line"
- }
- };
- const Switch = {
- // switch
- switch: {
- loading: false,
- disabled: false,
- size: 25,
- activeColor: "#2979ff",
- inactiveColor: "#ffffff",
- value: false,
- activeValue: true,
- inactiveValue: false,
- asyncChange: false,
- space: 0
- }
- };
- const Tabbar = {
- // tabbar
- tabbar: {
- value: null,
- safeAreaInsetBottom: true,
- border: true,
- zIndex: 1,
- activeColor: "#1989fa",
- inactiveColor: "#7d7e80",
- fixed: true,
- placeholder: true
- }
- };
- const TabbarItem = {
- //
- tabbarItem: {
- name: null,
- icon: "",
- badge: null,
- dot: false,
- text: "",
- badgeStyle: "top: 6px;right:2px;"
- }
- };
- const Tabs = {
- //
- tabs: {
- duration: 300,
- list: () => [],
- lineColor: "#3c9cff",
- activeStyle: () => ({
- color: "#303133"
- }),
- inactiveStyle: () => ({
- color: "#606266"
- }),
- lineWidth: 20,
- lineHeight: 3,
- lineBgSize: "cover",
- itemStyle: () => ({
- height: "44px"
- }),
- scrollable: true,
- current: 0,
- keyName: "name"
- }
- };
- const Tag = {
- // tag 组件
- tag: {
- type: "primary",
- disabled: false,
- size: "medium",
- shape: "square",
- text: "",
- bgColor: "",
- color: "",
- borderColor: "",
- closeColor: "#C6C7CB",
- name: "",
- plainFill: false,
- plain: false,
- closable: false,
- show: true,
- icon: ""
- }
- };
- const Text = {
- // text 组件
- text: {
- type: "",
- show: true,
- text: "",
- prefixIcon: "",
- suffixIcon: "",
- mode: "",
- href: "",
- format: "",
- call: false,
- openType: "",
- bold: false,
- block: false,
- lines: "",
- color: "#303133",
- size: 15,
- iconStyle: () => ({
- fontSize: "15px"
- }),
- decoration: "none",
- margin: 0,
- lineHeight: "",
- align: "left",
- wordWrap: "normal"
- }
- };
- const Textarea = {
- // textarea 组件
- textarea: {
- value: "",
- placeholder: "",
- placeholderClass: "textarea-placeholder",
- placeholderStyle: "color: #c0c4cc",
- height: 70,
- confirmType: "done",
- disabled: false,
- count: false,
- focus: false,
- autoHeight: false,
- fixed: false,
- cursorSpacing: 0,
- cursor: "",
- showConfirmBar: true,
- selectionStart: -1,
- selectionEnd: -1,
- adjustPosition: true,
- disableDefaultPadding: false,
- holdKeyboard: false,
- maxlength: 140,
- border: "surround",
- formatter: null
- }
- };
- const Toast = {
- // toast组件
- toast: {
- zIndex: 10090,
- loading: false,
- text: "",
- icon: "",
- type: "",
- loadingMode: "",
- show: "",
- overlay: false,
- position: "center",
- params: () => {
- },
- duration: 2e3,
- isTab: false,
- url: "",
- callback: null,
- back: false
- }
- };
- const Toolbar = {
- // toolbar 组件
- toolbar: {
- show: true,
- cancelText: "取消",
- confirmText: "确认",
- cancelColor: "#909193",
- confirmColor: "#3c9cff",
- title: ""
- }
- };
- const Tooltip = {
- // tooltip 组件
- tooltip: {
- text: "",
- copyText: "",
- size: 14,
- color: "#606266",
- bgColor: "transparent",
- direction: "top",
- zIndex: 10071,
- showCopy: true,
- buttons: () => [],
- overlay: true,
- showToast: true
- }
- };
- const Transition = {
- // transition动画组件的props
- transition: {
- show: false,
- mode: "fade",
- duration: "300",
- timingFunction: "ease-out"
- }
- };
- const Upload = {
- // upload组件
- upload: {
- accept: "image",
- capture: () => ["album", "camera"],
- compressed: true,
- camera: "back",
- maxDuration: 60,
- uploadIcon: "camera-fill",
- uploadIconColor: "#D3D4D6",
- useBeforeRead: false,
- previewFullImage: true,
- maxCount: 52,
- disabled: false,
- imageMode: "aspectFill",
- name: "",
- sizeType: () => ["original", "compressed"],
- multiple: false,
- deletable: true,
- maxSize: Number.MAX_VALUE,
- fileList: () => [],
- uploadText: "",
- width: 80,
- height: 80,
- previewImage: true
- }
- };
- const defprops = {
- ...ActionSheet,
- ...Album,
- ...Alert,
- ...Avatar,
- ...AvatarGroup,
- ...Backtop,
- ...Badge,
- ...Button,
- ...Calendar,
- ...CarKeyboard,
- ...Cell,
- ...CellGroup,
- ...Checkbox,
- ...CheckboxGroup,
- ...CircleProgress,
- ...Code,
- ...CodeInput,
- ...Col,
- ...Collapse,
- ...CollapseItem,
- ...ColumnNotice,
- ...CountDown,
- ...CountTo,
- ...DatetimePicker,
- ...Divider,
- ...Empty,
- ...Form,
- ...GormItem,
- ...Gap,
- ...Grid,
- ...GridItem,
- ...Icon,
- ...Image,
- ...IndexAnchor,
- ...IndexList,
- ...Input,
- ...Keyboard,
- ...Line,
- ...LineProgress,
- ...Link,
- ...List,
- ...ListItem,
- ...LoadingIcon,
- ...LoadingPage,
- ...Loadmore,
- ...Modal,
- ...Navbar,
- ...NoNetwork,
- ...NoticeBar,
- ...Notify,
- ...NumberBox,
- ...NumberKeyboard,
- ...Overlay,
- ...Parse,
- ...Picker,
- ...Popup,
- ...Radio,
- ...RadioGroup,
- ...Rate,
- ...ReadMore,
- ...Row,
- ...RowNotice,
- ...ScrollList,
- ...Search,
- ...Section,
- ...Skeleton,
- ...Slider,
- ...StatusBar,
- ...Steps,
- ...StepsItem,
- ...Sticky,
- ...Subsection,
- ...SwipeAction,
- ...SwipeActionItem,
- ...Swiper,
- ...SwipterIndicator,
- ...Switch,
- ...Tabbar,
- ...TabbarItem,
- ...Tabs,
- ...Tag,
- ...Text,
- ...Textarea,
- ...Toast,
- ...Toolbar,
- ...Tooltip,
- ...Transition,
- ...Upload
- };
- const zIndex = {
- toast: 10090,
- noNetwork: 10080,
- // popup包含popup,actionsheet,keyboard,picker的值
- popup: 10075,
- mask: 10070,
- navbar: 980,
- topTips: 975,
- sticky: 970,
- indexListSticky: 965
- };
- let platform = "none";
- platform = "vue3";
- platform = "mp";
- platform = "weixin";
- const platform$1 = platform;
- const $u = {
- route,
- date: index.timeFormat,
- // 另名date
- colorGradient: colorGradient$1.colorGradient,
- hexToRgb: colorGradient$1.hexToRgb,
- rgbToHex: colorGradient$1.rgbToHex,
- colorToRgba: colorGradient$1.colorToRgba,
- test,
- type: ["primary", "success", "error", "warning", "info"],
- http: new Request(),
- config,
- // uView配置信息相关,比如版本号
- zIndex,
- debounce,
- throttle,
- mixin,
- mpMixin,
- props: defprops,
- ...index,
- color,
- platform: platform$1
- };
- index$1.$u = $u;
- const install = (Vue) => {
- Vue.config.globalProperties.$u = $u;
- Vue.config.globalProperties.$nextTick = (cb) => {
- cb();
- };
- Vue.mixin(mixin);
- };
- const uviewPlus = {
- install
- };
- const createHook = (lifecycle) => (hook, target = getCurrentInstance()) => {
- !isInSSRComponentSetup && injectHook(lifecycle, hook, target);
- };
- const onShow = /* @__PURE__ */ createHook(ON_SHOW);
- const onLoad = /* @__PURE__ */ createHook(ON_LOAD);
- const onPullDownRefresh = /* @__PURE__ */ createHook(ON_PULL_DOWN_REFRESH);
- //! moment.js
- //! version : 2.30.1
- //! authors : Tim Wood, Iskren Chernev, Moment.js contributors
- //! license : MIT
- //! momentjs.com
- var hookCallback;
- function hooks() {
- return hookCallback.apply(null, arguments);
- }
- function setHookCallback(callback) {
- hookCallback = callback;
- }
- function isArray(input) {
- return input instanceof Array || Object.prototype.toString.call(input) === "[object Array]";
- }
- function isObject(input) {
- return input != null && Object.prototype.toString.call(input) === "[object Object]";
- }
- function hasOwnProp(a, b) {
- return Object.prototype.hasOwnProperty.call(a, b);
- }
- function isObjectEmpty(obj) {
- if (Object.getOwnPropertyNames) {
- return Object.getOwnPropertyNames(obj).length === 0;
- } else {
- var k;
- for (k in obj) {
- if (hasOwnProp(obj, k)) {
- return false;
- }
- }
- return true;
- }
- }
- function isUndefined(input) {
- return input === void 0;
- }
- function isNumber(input) {
- return typeof input === "number" || Object.prototype.toString.call(input) === "[object Number]";
- }
- function isDate(input) {
- return input instanceof Date || Object.prototype.toString.call(input) === "[object Date]";
- }
- function map(arr, fn) {
- var res = [], i, arrLen = arr.length;
- for (i = 0; i < arrLen; ++i) {
- res.push(fn(arr[i], i));
- }
- return res;
- }
- function extend(a, b) {
- for (var i in b) {
- if (hasOwnProp(b, i)) {
- a[i] = b[i];
- }
- }
- if (hasOwnProp(b, "toString")) {
- a.toString = b.toString;
- }
- if (hasOwnProp(b, "valueOf")) {
- a.valueOf = b.valueOf;
- }
- return a;
- }
- function createUTC(input, format2, locale2, strict) {
- return createLocalOrUTC(input, format2, locale2, strict, true).utc();
- }
- function defaultParsingFlags() {
- return {
- empty: false,
- unusedTokens: [],
- unusedInput: [],
- overflow: -2,
- charsLeftOver: 0,
- nullInput: false,
- invalidEra: null,
- invalidMonth: null,
- invalidFormat: false,
- userInvalidated: false,
- iso: false,
- parsedDateParts: [],
- era: null,
- meridiem: null,
- rfc2822: false,
- weekdayMismatch: false
- };
- }
- function getParsingFlags(m) {
- if (m._pf == null) {
- m._pf = defaultParsingFlags();
- }
- return m._pf;
- }
- var some;
- if (Array.prototype.some) {
- some = Array.prototype.some;
- } else {
- some = function(fun) {
- var t2 = Object(this), len = t2.length >>> 0, i;
- for (i = 0; i < len; i++) {
- if (i in t2 && fun.call(this, t2[i], i, t2)) {
- return true;
- }
- }
- return false;
- };
- }
- function isValid(m) {
- var flags = null, parsedParts = false, isNowValid = m._d && !isNaN(m._d.getTime());
- if (isNowValid) {
- flags = getParsingFlags(m);
- parsedParts = some.call(flags.parsedDateParts, function(i) {
- return i != null;
- });
- isNowValid = flags.overflow < 0 && !flags.empty && !flags.invalidEra && !flags.invalidMonth && !flags.invalidWeekday && !flags.weekdayMismatch && !flags.nullInput && !flags.invalidFormat && !flags.userInvalidated && (!flags.meridiem || flags.meridiem && parsedParts);
- if (m._strict) {
- isNowValid = isNowValid && flags.charsLeftOver === 0 && flags.unusedTokens.length === 0 && flags.bigHour === void 0;
- }
- }
- if (Object.isFrozen == null || !Object.isFrozen(m)) {
- m._isValid = isNowValid;
- } else {
- return isNowValid;
- }
- return m._isValid;
- }
- function createInvalid(flags) {
- var m = createUTC(NaN);
- if (flags != null) {
- extend(getParsingFlags(m), flags);
- } else {
- getParsingFlags(m).userInvalidated = true;
- }
- return m;
- }
- var momentProperties = hooks.momentProperties = [], updateInProgress = false;
- function copyConfig(to2, from2) {
- var i, prop, val, momentPropertiesLen = momentProperties.length;
- if (!isUndefined(from2._isAMomentObject)) {
- to2._isAMomentObject = from2._isAMomentObject;
- }
- if (!isUndefined(from2._i)) {
- to2._i = from2._i;
- }
- if (!isUndefined(from2._f)) {
- to2._f = from2._f;
- }
- if (!isUndefined(from2._l)) {
- to2._l = from2._l;
- }
- if (!isUndefined(from2._strict)) {
- to2._strict = from2._strict;
- }
- if (!isUndefined(from2._tzm)) {
- to2._tzm = from2._tzm;
- }
- if (!isUndefined(from2._isUTC)) {
- to2._isUTC = from2._isUTC;
- }
- if (!isUndefined(from2._offset)) {
- to2._offset = from2._offset;
- }
- if (!isUndefined(from2._pf)) {
- to2._pf = getParsingFlags(from2);
- }
- if (!isUndefined(from2._locale)) {
- to2._locale = from2._locale;
- }
- if (momentPropertiesLen > 0) {
- for (i = 0; i < momentPropertiesLen; i++) {
- prop = momentProperties[i];
- val = from2[prop];
- if (!isUndefined(val)) {
- to2[prop] = val;
- }
- }
- }
- return to2;
- }
- function Moment(config2) {
- copyConfig(this, config2);
- this._d = new Date(config2._d != null ? config2._d.getTime() : NaN);
- if (!this.isValid()) {
- this._d = /* @__PURE__ */ new Date(NaN);
- }
- if (updateInProgress === false) {
- updateInProgress = true;
- hooks.updateOffset(this);
- updateInProgress = false;
- }
- }
- function isMoment(obj) {
- return obj instanceof Moment || obj != null && obj._isAMomentObject != null;
- }
- function warn(msg) {
- if (hooks.suppressDeprecationWarnings === false && typeof console !== "undefined" && console.warn) {
- console.warn("Deprecation warning: " + msg);
- }
- }
- function deprecate(msg, fn) {
- var firstTime = true;
- return extend(function() {
- if (hooks.deprecationHandler != null) {
- hooks.deprecationHandler(null, msg);
- }
- if (firstTime) {
- var args = [], arg, i, key, argLen = arguments.length;
- for (i = 0; i < argLen; i++) {
- arg = "";
- if (typeof arguments[i] === "object") {
- arg += "\n[" + i + "] ";
- for (key in arguments[0]) {
- if (hasOwnProp(arguments[0], key)) {
- arg += key + ": " + arguments[0][key] + ", ";
- }
- }
- arg = arg.slice(0, -2);
- } else {
- arg = arguments[i];
- }
- args.push(arg);
- }
- warn(
- msg + "\nArguments: " + Array.prototype.slice.call(args).join("") + "\n" + new Error().stack
- );
- firstTime = false;
- }
- return fn.apply(this, arguments);
- }, fn);
- }
- var deprecations = {};
- function deprecateSimple(name, msg) {
- if (hooks.deprecationHandler != null) {
- hooks.deprecationHandler(name, msg);
- }
- if (!deprecations[name]) {
- warn(msg);
- deprecations[name] = true;
- }
- }
- hooks.suppressDeprecationWarnings = false;
- hooks.deprecationHandler = null;
- function isFunction(input) {
- return typeof Function !== "undefined" && input instanceof Function || Object.prototype.toString.call(input) === "[object Function]";
- }
- function set(config2) {
- var prop, i;
- for (i in config2) {
- if (hasOwnProp(config2, i)) {
- prop = config2[i];
- if (isFunction(prop)) {
- this[i] = prop;
- } else {
- this["_" + i] = prop;
- }
- }
- }
- this._config = config2;
- this._dayOfMonthOrdinalParseLenient = new RegExp(
- (this._dayOfMonthOrdinalParse.source || this._ordinalParse.source) + "|" + /\d{1,2}/.source
- );
- }
- function mergeConfigs(parentConfig, childConfig) {
- var res = extend({}, parentConfig), prop;
- for (prop in childConfig) {
- if (hasOwnProp(childConfig, prop)) {
- if (isObject(parentConfig[prop]) && isObject(childConfig[prop])) {
- res[prop] = {};
- extend(res[prop], parentConfig[prop]);
- extend(res[prop], childConfig[prop]);
- } else if (childConfig[prop] != null) {
- res[prop] = childConfig[prop];
- } else {
- delete res[prop];
- }
- }
- }
- for (prop in parentConfig) {
- if (hasOwnProp(parentConfig, prop) && !hasOwnProp(childConfig, prop) && isObject(parentConfig[prop])) {
- res[prop] = extend({}, res[prop]);
- }
- }
- return res;
- }
- function Locale(config2) {
- if (config2 != null) {
- this.set(config2);
- }
- }
- var keys;
- if (Object.keys) {
- keys = Object.keys;
- } else {
- keys = function(obj) {
- var i, res = [];
- for (i in obj) {
- if (hasOwnProp(obj, i)) {
- res.push(i);
- }
- }
- return res;
- };
- }
- var defaultCalendar = {
- sameDay: "[Today at] LT",
- nextDay: "[Tomorrow at] LT",
- nextWeek: "dddd [at] LT",
- lastDay: "[Yesterday at] LT",
- lastWeek: "[Last] dddd [at] LT",
- sameElse: "L"
- };
- function calendar(key, mom, now2) {
- var output = this._calendar[key] || this._calendar["sameElse"];
- return isFunction(output) ? output.call(mom, now2) : output;
- }
- function zeroFill(number3, targetLength, forceSign) {
- var absNumber = "" + Math.abs(number3), zerosToFill = targetLength - absNumber.length, sign2 = number3 >= 0;
- return (sign2 ? forceSign ? "+" : "" : "-") + Math.pow(10, Math.max(0, zerosToFill)).toString().substr(1) + absNumber;
- }
- var formattingTokens = /(\[[^\[]*\])|(\\)?([Hh]mm(ss)?|Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Qo?|N{1,5}|YYYYYY|YYYYY|YYYY|YY|y{2,4}|yo?|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|kk?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g, localFormattingTokens = /(\[[^\[]*\])|(\\)?(LTS|LT|LL?L?L?|l{1,4})/g, formatFunctions = {}, formatTokenFunctions = {};
- function addFormatToken(token2, padded, ordinal2, callback) {
- var func2 = callback;
- if (typeof callback === "string") {
- func2 = function() {
- return this[callback]();
- };
- }
- if (token2) {
- formatTokenFunctions[token2] = func2;
- }
- if (padded) {
- formatTokenFunctions[padded[0]] = function() {
- return zeroFill(func2.apply(this, arguments), padded[1], padded[2]);
- };
- }
- if (ordinal2) {
- formatTokenFunctions[ordinal2] = function() {
- return this.localeData().ordinal(
- func2.apply(this, arguments),
- token2
- );
- };
- }
- }
- function removeFormattingTokens(input) {
- if (input.match(/\[[\s\S]/)) {
- return input.replace(/^\[|\]$/g, "");
- }
- return input.replace(/\\/g, "");
- }
- function makeFormatFunction(format2) {
- var array3 = format2.match(formattingTokens), i, length;
- for (i = 0, length = array3.length; i < length; i++) {
- if (formatTokenFunctions[array3[i]]) {
- array3[i] = formatTokenFunctions[array3[i]];
- } else {
- array3[i] = removeFormattingTokens(array3[i]);
- }
- }
- return function(mom) {
- var output = "", i2;
- for (i2 = 0; i2 < length; i2++) {
- output += isFunction(array3[i2]) ? array3[i2].call(mom, format2) : array3[i2];
- }
- return output;
- };
- }
- function formatMoment(m, format2) {
- if (!m.isValid()) {
- return m.localeData().invalidDate();
- }
- format2 = expandFormat(format2, m.localeData());
- formatFunctions[format2] = formatFunctions[format2] || makeFormatFunction(format2);
- return formatFunctions[format2](m);
- }
- function expandFormat(format2, locale2) {
- var i = 5;
- function replaceLongDateFormatTokens(input) {
- return locale2.longDateFormat(input) || input;
- }
- localFormattingTokens.lastIndex = 0;
- while (i >= 0 && localFormattingTokens.test(format2)) {
- format2 = format2.replace(
- localFormattingTokens,
- replaceLongDateFormatTokens
- );
- localFormattingTokens.lastIndex = 0;
- i -= 1;
- }
- return format2;
- }
- var defaultLongDateFormat = {
- LTS: "h:mm:ss A",
- LT: "h:mm A",
- L: "MM/DD/YYYY",
- LL: "MMMM D, YYYY",
- LLL: "MMMM D, YYYY h:mm A",
- LLLL: "dddd, MMMM D, YYYY h:mm A"
- };
- function longDateFormat(key) {
- var format2 = this._longDateFormat[key], formatUpper = this._longDateFormat[key.toUpperCase()];
- if (format2 || !formatUpper) {
- return format2;
- }
- this._longDateFormat[key] = formatUpper.match(formattingTokens).map(function(tok) {
- if (tok === "MMMM" || tok === "MM" || tok === "DD" || tok === "dddd") {
- return tok.slice(1);
- }
- return tok;
- }).join("");
- return this._longDateFormat[key];
- }
- var defaultInvalidDate = "Invalid date";
- function invalidDate() {
- return this._invalidDate;
- }
- var defaultOrdinal = "%d", defaultDayOfMonthOrdinalParse = /\d{1,2}/;
- function ordinal(number3) {
- return this._ordinal.replace("%d", number3);
- }
- var defaultRelativeTime = {
- future: "in %s",
- past: "%s ago",
- s: "a few seconds",
- ss: "%d seconds",
- m: "a minute",
- mm: "%d minutes",
- h: "an hour",
- hh: "%d hours",
- d: "a day",
- dd: "%d days",
- w: "a week",
- ww: "%d weeks",
- M: "a month",
- MM: "%d months",
- y: "a year",
- yy: "%d years"
- };
- function relativeTime(number3, withoutSuffix, string2, isFuture) {
- var output = this._relativeTime[string2];
- return isFunction(output) ? output(number3, withoutSuffix, string2, isFuture) : output.replace(/%d/i, number3);
- }
- function pastFuture(diff2, output) {
- var format2 = this._relativeTime[diff2 > 0 ? "future" : "past"];
- return isFunction(format2) ? format2(output) : format2.replace(/%s/i, output);
- }
- var aliases = {
- D: "date",
- dates: "date",
- date: "date",
- d: "day",
- days: "day",
- day: "day",
- e: "weekday",
- weekdays: "weekday",
- weekday: "weekday",
- E: "isoWeekday",
- isoweekdays: "isoWeekday",
- isoweekday: "isoWeekday",
- DDD: "dayOfYear",
- dayofyears: "dayOfYear",
- dayofyear: "dayOfYear",
- h: "hour",
- hours: "hour",
- hour: "hour",
- ms: "millisecond",
- milliseconds: "millisecond",
- millisecond: "millisecond",
- m: "minute",
- minutes: "minute",
- minute: "minute",
- M: "month",
- months: "month",
- month: "month",
- Q: "quarter",
- quarters: "quarter",
- quarter: "quarter",
- s: "second",
- seconds: "second",
- second: "second",
- gg: "weekYear",
- weekyears: "weekYear",
- weekyear: "weekYear",
- GG: "isoWeekYear",
- isoweekyears: "isoWeekYear",
- isoweekyear: "isoWeekYear",
- w: "week",
- weeks: "week",
- week: "week",
- W: "isoWeek",
- isoweeks: "isoWeek",
- isoweek: "isoWeek",
- y: "year",
- years: "year",
- year: "year"
- };
- function normalizeUnits(units) {
- return typeof units === "string" ? aliases[units] || aliases[units.toLowerCase()] : void 0;
- }
- function normalizeObjectUnits(inputObject) {
- var normalizedInput = {}, normalizedProp, prop;
- for (prop in inputObject) {
- if (hasOwnProp(inputObject, prop)) {
- normalizedProp = normalizeUnits(prop);
- if (normalizedProp) {
- normalizedInput[normalizedProp] = inputObject[prop];
- }
- }
- }
- return normalizedInput;
- }
- var priorities = {
- date: 9,
- day: 11,
- weekday: 11,
- isoWeekday: 11,
- dayOfYear: 4,
- hour: 13,
- millisecond: 16,
- minute: 14,
- month: 8,
- quarter: 7,
- second: 15,
- weekYear: 1,
- isoWeekYear: 1,
- week: 5,
- isoWeek: 5,
- year: 1
- };
- function getPrioritizedUnits(unitsObj) {
- var units = [], u;
- for (u in unitsObj) {
- if (hasOwnProp(unitsObj, u)) {
- units.push({ unit: u, priority: priorities[u] });
- }
- }
- units.sort(function(a, b) {
- return a.priority - b.priority;
- });
- return units;
- }
- var match1 = /\d/, match2 = /\d\d/, match3 = /\d{3}/, match4 = /\d{4}/, match6 = /[+-]?\d{6}/, match1to2 = /\d\d?/, match3to4 = /\d\d\d\d?/, match5to6 = /\d\d\d\d\d\d?/, match1to3 = /\d{1,3}/, match1to4 = /\d{1,4}/, match1to6 = /[+-]?\d{1,6}/, matchUnsigned = /\d+/, matchSigned = /[+-]?\d+/, matchOffset = /Z|[+-]\d\d:?\d\d/gi, matchShortOffset = /Z|[+-]\d\d(?::?\d\d)?/gi, matchTimestamp = /[+-]?\d+(\.\d{1,3})?/, matchWord = /[0-9]{0,256}['a-z\u00A0-\u05FF\u0700-\uD7FF\uF900-\uFDCF\uFDF0-\uFF07\uFF10-\uFFEF]{1,256}|[\u0600-\u06FF\/]{1,256}(\s*?[\u0600-\u06FF]{1,256}){1,2}/i, match1to2NoLeadingZero = /^[1-9]\d?/, match1to2HasZero = /^([1-9]\d|\d)/, regexes;
- regexes = {};
- function addRegexToken(token2, regex, strictRegex) {
- regexes[token2] = isFunction(regex) ? regex : function(isStrict, localeData2) {
- return isStrict && strictRegex ? strictRegex : regex;
- };
- }
- function getParseRegexForToken(token2, config2) {
- if (!hasOwnProp(regexes, token2)) {
- return new RegExp(unescapeFormat(token2));
- }
- return regexes[token2](config2._strict, config2._locale);
- }
- function unescapeFormat(s2) {
- return regexEscape(
- s2.replace("\\", "").replace(
- /\\(\[)|\\(\])|\[([^\]\[]*)\]|\\(.)/g,
- function(matched, p1, p2, p3, p4) {
- return p1 || p2 || p3 || p4;
- }
- )
- );
- }
- function regexEscape(s2) {
- return s2.replace(/[-\/\\^$*+?.()|[\]{}]/g, "\\$&");
- }
- function absFloor(number3) {
- if (number3 < 0) {
- return Math.ceil(number3) || 0;
- } else {
- return Math.floor(number3);
- }
- }
- function toInt(argumentForCoercion) {
- var coercedNumber = +argumentForCoercion, value2 = 0;
- if (coercedNumber !== 0 && isFinite(coercedNumber)) {
- value2 = absFloor(coercedNumber);
- }
- return value2;
- }
- var tokens = {};
- function addParseToken(token2, callback) {
- var i, func2 = callback, tokenLen;
- if (typeof token2 === "string") {
- token2 = [token2];
- }
- if (isNumber(callback)) {
- func2 = function(input, array3) {
- array3[callback] = toInt(input);
- };
- }
- tokenLen = token2.length;
- for (i = 0; i < tokenLen; i++) {
- tokens[token2[i]] = func2;
- }
- }
- function addWeekParseToken(token2, callback) {
- addParseToken(token2, function(input, array3, config2, token3) {
- config2._w = config2._w || {};
- callback(input, config2._w, config2, token3);
- });
- }
- function addTimeToArrayFromToken(token2, input, config2) {
- if (input != null && hasOwnProp(tokens, token2)) {
- tokens[token2](input, config2._a, config2, token2);
- }
- }
- function isLeapYear(year) {
- return year % 4 === 0 && year % 100 !== 0 || year % 400 === 0;
- }
- var YEAR = 0, MONTH = 1, DATE = 2, HOUR = 3, MINUTE = 4, SECOND = 5, MILLISECOND = 6, WEEK = 7, WEEKDAY = 8;
- addFormatToken("Y", 0, 0, function() {
- var y = this.year();
- return y <= 9999 ? zeroFill(y, 4) : "+" + y;
- });
- addFormatToken(0, ["YY", 2], 0, function() {
- return this.year() % 100;
- });
- addFormatToken(0, ["YYYY", 4], 0, "year");
- addFormatToken(0, ["YYYYY", 5], 0, "year");
- addFormatToken(0, ["YYYYYY", 6, true], 0, "year");
- addRegexToken("Y", matchSigned);
- addRegexToken("YY", match1to2, match2);
- addRegexToken("YYYY", match1to4, match4);
- addRegexToken("YYYYY", match1to6, match6);
- addRegexToken("YYYYYY", match1to6, match6);
- addParseToken(["YYYYY", "YYYYYY"], YEAR);
- addParseToken("YYYY", function(input, array3) {
- array3[YEAR] = input.length === 2 ? hooks.parseTwoDigitYear(input) : toInt(input);
- });
- addParseToken("YY", function(input, array3) {
- array3[YEAR] = hooks.parseTwoDigitYear(input);
- });
- addParseToken("Y", function(input, array3) {
- array3[YEAR] = parseInt(input, 10);
- });
- function daysInYear(year) {
- return isLeapYear(year) ? 366 : 365;
- }
- hooks.parseTwoDigitYear = function(input) {
- return toInt(input) + (toInt(input) > 68 ? 1900 : 2e3);
- };
- var getSetYear = makeGetSet("FullYear", true);
- function getIsLeapYear() {
- return isLeapYear(this.year());
- }
- function makeGetSet(unit, keepTime) {
- return function(value2) {
- if (value2 != null) {
- set$1(this, unit, value2);
- hooks.updateOffset(this, keepTime);
- return this;
- } else {
- return get(this, unit);
- }
- };
- }
- function get(mom, unit) {
- if (!mom.isValid()) {
- return NaN;
- }
- var d = mom._d, isUTC = mom._isUTC;
- switch (unit) {
- case "Milliseconds":
- return isUTC ? d.getUTCMilliseconds() : d.getMilliseconds();
- case "Seconds":
- return isUTC ? d.getUTCSeconds() : d.getSeconds();
- case "Minutes":
- return isUTC ? d.getUTCMinutes() : d.getMinutes();
- case "Hours":
- return isUTC ? d.getUTCHours() : d.getHours();
- case "Date":
- return isUTC ? d.getUTCDate() : d.getDate();
- case "Day":
- return isUTC ? d.getUTCDay() : d.getDay();
- case "Month":
- return isUTC ? d.getUTCMonth() : d.getMonth();
- case "FullYear":
- return isUTC ? d.getUTCFullYear() : d.getFullYear();
- default:
- return NaN;
- }
- }
- function set$1(mom, unit, value2) {
- var d, isUTC, year, month, date3;
- if (!mom.isValid() || isNaN(value2)) {
- return;
- }
- d = mom._d;
- isUTC = mom._isUTC;
- switch (unit) {
- case "Milliseconds":
- return void (isUTC ? d.setUTCMilliseconds(value2) : d.setMilliseconds(value2));
- case "Seconds":
- return void (isUTC ? d.setUTCSeconds(value2) : d.setSeconds(value2));
- case "Minutes":
- return void (isUTC ? d.setUTCMinutes(value2) : d.setMinutes(value2));
- case "Hours":
- return void (isUTC ? d.setUTCHours(value2) : d.setHours(value2));
- case "Date":
- return void (isUTC ? d.setUTCDate(value2) : d.setDate(value2));
- case "FullYear":
- break;
- default:
- return;
- }
- year = value2;
- month = mom.month();
- date3 = mom.date();
- date3 = date3 === 29 && month === 1 && !isLeapYear(year) ? 28 : date3;
- void (isUTC ? d.setUTCFullYear(year, month, date3) : d.setFullYear(year, month, date3));
- }
- function stringGet(units) {
- units = normalizeUnits(units);
- if (isFunction(this[units])) {
- return this[units]();
- }
- return this;
- }
- function stringSet(units, value2) {
- if (typeof units === "object") {
- units = normalizeObjectUnits(units);
- var prioritized = getPrioritizedUnits(units), i, prioritizedLen = prioritized.length;
- for (i = 0; i < prioritizedLen; i++) {
- this[prioritized[i].unit](units[prioritized[i].unit]);
- }
- } else {
- units = normalizeUnits(units);
- if (isFunction(this[units])) {
- return this[units](value2);
- }
- }
- return this;
- }
- function mod(n2, x) {
- return (n2 % x + x) % x;
- }
- var indexOf;
- if (Array.prototype.indexOf) {
- indexOf = Array.prototype.indexOf;
- } else {
- indexOf = function(o2) {
- var i;
- for (i = 0; i < this.length; ++i) {
- if (this[i] === o2) {
- return i;
- }
- }
- return -1;
- };
- }
- function daysInMonth(year, month) {
- if (isNaN(year) || isNaN(month)) {
- return NaN;
- }
- var modMonth = mod(month, 12);
- year += (month - modMonth) / 12;
- return modMonth === 1 ? isLeapYear(year) ? 29 : 28 : 31 - modMonth % 7 % 2;
- }
- addFormatToken("M", ["MM", 2], "Mo", function() {
- return this.month() + 1;
- });
- addFormatToken("MMM", 0, 0, function(format2) {
- return this.localeData().monthsShort(this, format2);
- });
- addFormatToken("MMMM", 0, 0, function(format2) {
- return this.localeData().months(this, format2);
- });
- addRegexToken("M", match1to2, match1to2NoLeadingZero);
- addRegexToken("MM", match1to2, match2);
- addRegexToken("MMM", function(isStrict, locale2) {
- return locale2.monthsShortRegex(isStrict);
- });
- addRegexToken("MMMM", function(isStrict, locale2) {
- return locale2.monthsRegex(isStrict);
- });
- addParseToken(["M", "MM"], function(input, array3) {
- array3[MONTH] = toInt(input) - 1;
- });
- addParseToken(["MMM", "MMMM"], function(input, array3, config2, token2) {
- var month = config2._locale.monthsParse(input, token2, config2._strict);
- if (month != null) {
- array3[MONTH] = month;
- } else {
- getParsingFlags(config2).invalidMonth = input;
- }
- });
- var defaultLocaleMonths = "January_February_March_April_May_June_July_August_September_October_November_December".split(
- "_"
- ), defaultLocaleMonthsShort = "Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec".split("_"), MONTHS_IN_FORMAT = /D[oD]?(\[[^\[\]]*\]|\s)+MMMM?/, defaultMonthsShortRegex = matchWord, defaultMonthsRegex = matchWord;
- function localeMonths(m, format2) {
- if (!m) {
- return isArray(this._months) ? this._months : this._months["standalone"];
- }
- return isArray(this._months) ? this._months[m.month()] : this._months[(this._months.isFormat || MONTHS_IN_FORMAT).test(format2) ? "format" : "standalone"][m.month()];
- }
- function localeMonthsShort(m, format2) {
- if (!m) {
- return isArray(this._monthsShort) ? this._monthsShort : this._monthsShort["standalone"];
- }
- return isArray(this._monthsShort) ? this._monthsShort[m.month()] : this._monthsShort[MONTHS_IN_FORMAT.test(format2) ? "format" : "standalone"][m.month()];
- }
- function handleStrictParse(monthName, format2, strict) {
- var i, ii, mom, llc = monthName.toLocaleLowerCase();
- if (!this._monthsParse) {
- this._monthsParse = [];
- this._longMonthsParse = [];
- this._shortMonthsParse = [];
- for (i = 0; i < 12; ++i) {
- mom = createUTC([2e3, i]);
- this._shortMonthsParse[i] = this.monthsShort(
- mom,
- ""
- ).toLocaleLowerCase();
- this._longMonthsParse[i] = this.months(mom, "").toLocaleLowerCase();
- }
- }
- if (strict) {
- if (format2 === "MMM") {
- ii = indexOf.call(this._shortMonthsParse, llc);
- return ii !== -1 ? ii : null;
- } else {
- ii = indexOf.call(this._longMonthsParse, llc);
- return ii !== -1 ? ii : null;
- }
- } else {
- if (format2 === "MMM") {
- ii = indexOf.call(this._shortMonthsParse, llc);
- if (ii !== -1) {
- return ii;
- }
- ii = indexOf.call(this._longMonthsParse, llc);
- return ii !== -1 ? ii : null;
- } else {
- ii = indexOf.call(this._longMonthsParse, llc);
- if (ii !== -1) {
- return ii;
- }
- ii = indexOf.call(this._shortMonthsParse, llc);
- return ii !== -1 ? ii : null;
- }
- }
- }
- function localeMonthsParse(monthName, format2, strict) {
- var i, mom, regex;
- if (this._monthsParseExact) {
- return handleStrictParse.call(this, monthName, format2, strict);
- }
- if (!this._monthsParse) {
- this._monthsParse = [];
- this._longMonthsParse = [];
- this._shortMonthsParse = [];
- }
- for (i = 0; i < 12; i++) {
- mom = createUTC([2e3, i]);
- if (strict && !this._longMonthsParse[i]) {
- this._longMonthsParse[i] = new RegExp(
- "^" + this.months(mom, "").replace(".", "") + "$",
- "i"
- );
- this._shortMonthsParse[i] = new RegExp(
- "^" + this.monthsShort(mom, "").replace(".", "") + "$",
- "i"
- );
- }
- if (!strict && !this._monthsParse[i]) {
- regex = "^" + this.months(mom, "") + "|^" + this.monthsShort(mom, "");
- this._monthsParse[i] = new RegExp(regex.replace(".", ""), "i");
- }
- if (strict && format2 === "MMMM" && this._longMonthsParse[i].test(monthName)) {
- return i;
- } else if (strict && format2 === "MMM" && this._shortMonthsParse[i].test(monthName)) {
- return i;
- } else if (!strict && this._monthsParse[i].test(monthName)) {
- return i;
- }
- }
- }
- function setMonth(mom, value2) {
- if (!mom.isValid()) {
- return mom;
- }
- if (typeof value2 === "string") {
- if (/^\d+$/.test(value2)) {
- value2 = toInt(value2);
- } else {
- value2 = mom.localeData().monthsParse(value2);
- if (!isNumber(value2)) {
- return mom;
- }
- }
- }
- var month = value2, date3 = mom.date();
- date3 = date3 < 29 ? date3 : Math.min(date3, daysInMonth(mom.year(), month));
- void (mom._isUTC ? mom._d.setUTCMonth(month, date3) : mom._d.setMonth(month, date3));
- return mom;
- }
- function getSetMonth(value2) {
- if (value2 != null) {
- setMonth(this, value2);
- hooks.updateOffset(this, true);
- return this;
- } else {
- return get(this, "Month");
- }
- }
- function getDaysInMonth() {
- return daysInMonth(this.year(), this.month());
- }
- function monthsShortRegex(isStrict) {
- if (this._monthsParseExact) {
- if (!hasOwnProp(this, "_monthsRegex")) {
- computeMonthsParse.call(this);
- }
- if (isStrict) {
- return this._monthsShortStrictRegex;
- } else {
- return this._monthsShortRegex;
- }
- } else {
- if (!hasOwnProp(this, "_monthsShortRegex")) {
- this._monthsShortRegex = defaultMonthsShortRegex;
- }
- return this._monthsShortStrictRegex && isStrict ? this._monthsShortStrictRegex : this._monthsShortRegex;
- }
- }
- function monthsRegex(isStrict) {
- if (this._monthsParseExact) {
- if (!hasOwnProp(this, "_monthsRegex")) {
- computeMonthsParse.call(this);
- }
- if (isStrict) {
- return this._monthsStrictRegex;
- } else {
- return this._monthsRegex;
- }
- } else {
- if (!hasOwnProp(this, "_monthsRegex")) {
- this._monthsRegex = defaultMonthsRegex;
- }
- return this._monthsStrictRegex && isStrict ? this._monthsStrictRegex : this._monthsRegex;
- }
- }
- function computeMonthsParse() {
- function cmpLenRev(a, b) {
- return b.length - a.length;
- }
- var shortPieces = [], longPieces = [], mixedPieces = [], i, mom, shortP, longP;
- for (i = 0; i < 12; i++) {
- mom = createUTC([2e3, i]);
- shortP = regexEscape(this.monthsShort(mom, ""));
- longP = regexEscape(this.months(mom, ""));
- shortPieces.push(shortP);
- longPieces.push(longP);
- mixedPieces.push(longP);
- mixedPieces.push(shortP);
- }
- shortPieces.sort(cmpLenRev);
- longPieces.sort(cmpLenRev);
- mixedPieces.sort(cmpLenRev);
- this._monthsRegex = new RegExp("^(" + mixedPieces.join("|") + ")", "i");
- this._monthsShortRegex = this._monthsRegex;
- this._monthsStrictRegex = new RegExp(
- "^(" + longPieces.join("|") + ")",
- "i"
- );
- this._monthsShortStrictRegex = new RegExp(
- "^(" + shortPieces.join("|") + ")",
- "i"
- );
- }
- function createDate(y, m, d, h, M, s2, ms) {
- var date3;
- if (y < 100 && y >= 0) {
- date3 = new Date(y + 400, m, d, h, M, s2, ms);
- if (isFinite(date3.getFullYear())) {
- date3.setFullYear(y);
- }
- } else {
- date3 = new Date(y, m, d, h, M, s2, ms);
- }
- return date3;
- }
- function createUTCDate(y) {
- var date3, args;
- if (y < 100 && y >= 0) {
- args = Array.prototype.slice.call(arguments);
- args[0] = y + 400;
- date3 = new Date(Date.UTC.apply(null, args));
- if (isFinite(date3.getUTCFullYear())) {
- date3.setUTCFullYear(y);
- }
- } else {
- date3 = new Date(Date.UTC.apply(null, arguments));
- }
- return date3;
- }
- function firstWeekOffset(year, dow, doy) {
- var fwd = 7 + dow - doy, fwdlw = (7 + createUTCDate(year, 0, fwd).getUTCDay() - dow) % 7;
- return -fwdlw + fwd - 1;
- }
- function dayOfYearFromWeeks(year, week, weekday, dow, doy) {
- var localWeekday = (7 + weekday - dow) % 7, weekOffset = firstWeekOffset(year, dow, doy), dayOfYear = 1 + 7 * (week - 1) + localWeekday + weekOffset, resYear, resDayOfYear;
- if (dayOfYear <= 0) {
- resYear = year - 1;
- resDayOfYear = daysInYear(resYear) + dayOfYear;
- } else if (dayOfYear > daysInYear(year)) {
- resYear = year + 1;
- resDayOfYear = dayOfYear - daysInYear(year);
- } else {
- resYear = year;
- resDayOfYear = dayOfYear;
- }
- return {
- year: resYear,
- dayOfYear: resDayOfYear
- };
- }
- function weekOfYear(mom, dow, doy) {
- var weekOffset = firstWeekOffset(mom.year(), dow, doy), week = Math.floor((mom.dayOfYear() - weekOffset - 1) / 7) + 1, resWeek, resYear;
- if (week < 1) {
- resYear = mom.year() - 1;
- resWeek = week + weeksInYear(resYear, dow, doy);
- } else if (week > weeksInYear(mom.year(), dow, doy)) {
- resWeek = week - weeksInYear(mom.year(), dow, doy);
- resYear = mom.year() + 1;
- } else {
- resYear = mom.year();
- resWeek = week;
- }
- return {
- week: resWeek,
- year: resYear
- };
- }
- function weeksInYear(year, dow, doy) {
- var weekOffset = firstWeekOffset(year, dow, doy), weekOffsetNext = firstWeekOffset(year + 1, dow, doy);
- return (daysInYear(year) - weekOffset + weekOffsetNext) / 7;
- }
- addFormatToken("w", ["ww", 2], "wo", "week");
- addFormatToken("W", ["WW", 2], "Wo", "isoWeek");
- addRegexToken("w", match1to2, match1to2NoLeadingZero);
- addRegexToken("ww", match1to2, match2);
- addRegexToken("W", match1to2, match1to2NoLeadingZero);
- addRegexToken("WW", match1to2, match2);
- addWeekParseToken(
- ["w", "ww", "W", "WW"],
- function(input, week, config2, token2) {
- week[token2.substr(0, 1)] = toInt(input);
- }
- );
- function localeWeek(mom) {
- return weekOfYear(mom, this._week.dow, this._week.doy).week;
- }
- var defaultLocaleWeek = {
- dow: 0,
- // Sunday is the first day of the week.
- doy: 6
- // The week that contains Jan 6th is the first week of the year.
- };
- function localeFirstDayOfWeek() {
- return this._week.dow;
- }
- function localeFirstDayOfYear() {
- return this._week.doy;
- }
- function getSetWeek(input) {
- var week = this.localeData().week(this);
- return input == null ? week : this.add((input - week) * 7, "d");
- }
- function getSetISOWeek(input) {
- var week = weekOfYear(this, 1, 4).week;
- return input == null ? week : this.add((input - week) * 7, "d");
- }
- addFormatToken("d", 0, "do", "day");
- addFormatToken("dd", 0, 0, function(format2) {
- return this.localeData().weekdaysMin(this, format2);
- });
- addFormatToken("ddd", 0, 0, function(format2) {
- return this.localeData().weekdaysShort(this, format2);
- });
- addFormatToken("dddd", 0, 0, function(format2) {
- return this.localeData().weekdays(this, format2);
- });
- addFormatToken("e", 0, 0, "weekday");
- addFormatToken("E", 0, 0, "isoWeekday");
- addRegexToken("d", match1to2);
- addRegexToken("e", match1to2);
- addRegexToken("E", match1to2);
- addRegexToken("dd", function(isStrict, locale2) {
- return locale2.weekdaysMinRegex(isStrict);
- });
- addRegexToken("ddd", function(isStrict, locale2) {
- return locale2.weekdaysShortRegex(isStrict);
- });
- addRegexToken("dddd", function(isStrict, locale2) {
- return locale2.weekdaysRegex(isStrict);
- });
- addWeekParseToken(["dd", "ddd", "dddd"], function(input, week, config2, token2) {
- var weekday = config2._locale.weekdaysParse(input, token2, config2._strict);
- if (weekday != null) {
- week.d = weekday;
- } else {
- getParsingFlags(config2).invalidWeekday = input;
- }
- });
- addWeekParseToken(["d", "e", "E"], function(input, week, config2, token2) {
- week[token2] = toInt(input);
- });
- function parseWeekday(input, locale2) {
- if (typeof input !== "string") {
- return input;
- }
- if (!isNaN(input)) {
- return parseInt(input, 10);
- }
- input = locale2.weekdaysParse(input);
- if (typeof input === "number") {
- return input;
- }
- return null;
- }
- function parseIsoWeekday(input, locale2) {
- if (typeof input === "string") {
- return locale2.weekdaysParse(input) % 7 || 7;
- }
- return isNaN(input) ? null : input;
- }
- function shiftWeekdays(ws, n2) {
- return ws.slice(n2, 7).concat(ws.slice(0, n2));
- }
- var defaultLocaleWeekdays = "Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"), defaultLocaleWeekdaysShort = "Sun_Mon_Tue_Wed_Thu_Fri_Sat".split("_"), defaultLocaleWeekdaysMin = "Su_Mo_Tu_We_Th_Fr_Sa".split("_"), defaultWeekdaysRegex = matchWord, defaultWeekdaysShortRegex = matchWord, defaultWeekdaysMinRegex = matchWord;
- function localeWeekdays(m, format2) {
- var weekdays = isArray(this._weekdays) ? this._weekdays : this._weekdays[m && m !== true && this._weekdays.isFormat.test(format2) ? "format" : "standalone"];
- return m === true ? shiftWeekdays(weekdays, this._week.dow) : m ? weekdays[m.day()] : weekdays;
- }
- function localeWeekdaysShort(m) {
- return m === true ? shiftWeekdays(this._weekdaysShort, this._week.dow) : m ? this._weekdaysShort[m.day()] : this._weekdaysShort;
- }
- function localeWeekdaysMin(m) {
- return m === true ? shiftWeekdays(this._weekdaysMin, this._week.dow) : m ? this._weekdaysMin[m.day()] : this._weekdaysMin;
- }
- function handleStrictParse$1(weekdayName, format2, strict) {
- var i, ii, mom, llc = weekdayName.toLocaleLowerCase();
- if (!this._weekdaysParse) {
- this._weekdaysParse = [];
- this._shortWeekdaysParse = [];
- this._minWeekdaysParse = [];
- for (i = 0; i < 7; ++i) {
- mom = createUTC([2e3, 1]).day(i);
- this._minWeekdaysParse[i] = this.weekdaysMin(
- mom,
- ""
- ).toLocaleLowerCase();
- this._shortWeekdaysParse[i] = this.weekdaysShort(
- mom,
- ""
- ).toLocaleLowerCase();
- this._weekdaysParse[i] = this.weekdays(mom, "").toLocaleLowerCase();
- }
- }
- if (strict) {
- if (format2 === "dddd") {
- ii = indexOf.call(this._weekdaysParse, llc);
- return ii !== -1 ? ii : null;
- } else if (format2 === "ddd") {
- ii = indexOf.call(this._shortWeekdaysParse, llc);
- return ii !== -1 ? ii : null;
- } else {
- ii = indexOf.call(this._minWeekdaysParse, llc);
- return ii !== -1 ? ii : null;
- }
- } else {
- if (format2 === "dddd") {
- ii = indexOf.call(this._weekdaysParse, llc);
- if (ii !== -1) {
- return ii;
- }
- ii = indexOf.call(this._shortWeekdaysParse, llc);
- if (ii !== -1) {
- return ii;
- }
- ii = indexOf.call(this._minWeekdaysParse, llc);
- return ii !== -1 ? ii : null;
- } else if (format2 === "ddd") {
- ii = indexOf.call(this._shortWeekdaysParse, llc);
- if (ii !== -1) {
- return ii;
- }
- ii = indexOf.call(this._weekdaysParse, llc);
- if (ii !== -1) {
- return ii;
- }
- ii = indexOf.call(this._minWeekdaysParse, llc);
- return ii !== -1 ? ii : null;
- } else {
- ii = indexOf.call(this._minWeekdaysParse, llc);
- if (ii !== -1) {
- return ii;
- }
- ii = indexOf.call(this._weekdaysParse, llc);
- if (ii !== -1) {
- return ii;
- }
- ii = indexOf.call(this._shortWeekdaysParse, llc);
- return ii !== -1 ? ii : null;
- }
- }
- }
- function localeWeekdaysParse(weekdayName, format2, strict) {
- var i, mom, regex;
- if (this._weekdaysParseExact) {
- return handleStrictParse$1.call(this, weekdayName, format2, strict);
- }
- if (!this._weekdaysParse) {
- this._weekdaysParse = [];
- this._minWeekdaysParse = [];
- this._shortWeekdaysParse = [];
- this._fullWeekdaysParse = [];
- }
- for (i = 0; i < 7; i++) {
- mom = createUTC([2e3, 1]).day(i);
- if (strict && !this._fullWeekdaysParse[i]) {
- this._fullWeekdaysParse[i] = new RegExp(
- "^" + this.weekdays(mom, "").replace(".", "\\.?") + "$",
- "i"
- );
- this._shortWeekdaysParse[i] = new RegExp(
- "^" + this.weekdaysShort(mom, "").replace(".", "\\.?") + "$",
- "i"
- );
- this._minWeekdaysParse[i] = new RegExp(
- "^" + this.weekdaysMin(mom, "").replace(".", "\\.?") + "$",
- "i"
- );
- }
- if (!this._weekdaysParse[i]) {
- regex = "^" + this.weekdays(mom, "") + "|^" + this.weekdaysShort(mom, "") + "|^" + this.weekdaysMin(mom, "");
- this._weekdaysParse[i] = new RegExp(regex.replace(".", ""), "i");
- }
- if (strict && format2 === "dddd" && this._fullWeekdaysParse[i].test(weekdayName)) {
- return i;
- } else if (strict && format2 === "ddd" && this._shortWeekdaysParse[i].test(weekdayName)) {
- return i;
- } else if (strict && format2 === "dd" && this._minWeekdaysParse[i].test(weekdayName)) {
- return i;
- } else if (!strict && this._weekdaysParse[i].test(weekdayName)) {
- return i;
- }
- }
- }
- function getSetDayOfWeek(input) {
- if (!this.isValid()) {
- return input != null ? this : NaN;
- }
- var day = get(this, "Day");
- if (input != null) {
- input = parseWeekday(input, this.localeData());
- return this.add(input - day, "d");
- } else {
- return day;
- }
- }
- function getSetLocaleDayOfWeek(input) {
- if (!this.isValid()) {
- return input != null ? this : NaN;
- }
- var weekday = (this.day() + 7 - this.localeData()._week.dow) % 7;
- return input == null ? weekday : this.add(input - weekday, "d");
- }
- function getSetISODayOfWeek(input) {
- if (!this.isValid()) {
- return input != null ? this : NaN;
- }
- if (input != null) {
- var weekday = parseIsoWeekday(input, this.localeData());
- return this.day(this.day() % 7 ? weekday : weekday - 7);
- } else {
- return this.day() || 7;
- }
- }
- function weekdaysRegex(isStrict) {
- if (this._weekdaysParseExact) {
- if (!hasOwnProp(this, "_weekdaysRegex")) {
- computeWeekdaysParse.call(this);
- }
- if (isStrict) {
- return this._weekdaysStrictRegex;
- } else {
- return this._weekdaysRegex;
- }
- } else {
- if (!hasOwnProp(this, "_weekdaysRegex")) {
- this._weekdaysRegex = defaultWeekdaysRegex;
- }
- return this._weekdaysStrictRegex && isStrict ? this._weekdaysStrictRegex : this._weekdaysRegex;
- }
- }
- function weekdaysShortRegex(isStrict) {
- if (this._weekdaysParseExact) {
- if (!hasOwnProp(this, "_weekdaysRegex")) {
- computeWeekdaysParse.call(this);
- }
- if (isStrict) {
- return this._weekdaysShortStrictRegex;
- } else {
- return this._weekdaysShortRegex;
- }
- } else {
- if (!hasOwnProp(this, "_weekdaysShortRegex")) {
- this._weekdaysShortRegex = defaultWeekdaysShortRegex;
- }
- return this._weekdaysShortStrictRegex && isStrict ? this._weekdaysShortStrictRegex : this._weekdaysShortRegex;
- }
- }
- function weekdaysMinRegex(isStrict) {
- if (this._weekdaysParseExact) {
- if (!hasOwnProp(this, "_weekdaysRegex")) {
- computeWeekdaysParse.call(this);
- }
- if (isStrict) {
- return this._weekdaysMinStrictRegex;
- } else {
- return this._weekdaysMinRegex;
- }
- } else {
- if (!hasOwnProp(this, "_weekdaysMinRegex")) {
- this._weekdaysMinRegex = defaultWeekdaysMinRegex;
- }
- return this._weekdaysMinStrictRegex && isStrict ? this._weekdaysMinStrictRegex : this._weekdaysMinRegex;
- }
- }
- function computeWeekdaysParse() {
- function cmpLenRev(a, b) {
- return b.length - a.length;
- }
- var minPieces = [], shortPieces = [], longPieces = [], mixedPieces = [], i, mom, minp, shortp, longp;
- for (i = 0; i < 7; i++) {
- mom = createUTC([2e3, 1]).day(i);
- minp = regexEscape(this.weekdaysMin(mom, ""));
- shortp = regexEscape(this.weekdaysShort(mom, ""));
- longp = regexEscape(this.weekdays(mom, ""));
- minPieces.push(minp);
- shortPieces.push(shortp);
- longPieces.push(longp);
- mixedPieces.push(minp);
- mixedPieces.push(shortp);
- mixedPieces.push(longp);
- }
- minPieces.sort(cmpLenRev);
- shortPieces.sort(cmpLenRev);
- longPieces.sort(cmpLenRev);
- mixedPieces.sort(cmpLenRev);
- this._weekdaysRegex = new RegExp("^(" + mixedPieces.join("|") + ")", "i");
- this._weekdaysShortRegex = this._weekdaysRegex;
- this._weekdaysMinRegex = this._weekdaysRegex;
- this._weekdaysStrictRegex = new RegExp(
- "^(" + longPieces.join("|") + ")",
- "i"
- );
- this._weekdaysShortStrictRegex = new RegExp(
- "^(" + shortPieces.join("|") + ")",
- "i"
- );
- this._weekdaysMinStrictRegex = new RegExp(
- "^(" + minPieces.join("|") + ")",
- "i"
- );
- }
- function hFormat() {
- return this.hours() % 12 || 12;
- }
- function kFormat() {
- return this.hours() || 24;
- }
- addFormatToken("H", ["HH", 2], 0, "hour");
- addFormatToken("h", ["hh", 2], 0, hFormat);
- addFormatToken("k", ["kk", 2], 0, kFormat);
- addFormatToken("hmm", 0, 0, function() {
- return "" + hFormat.apply(this) + zeroFill(this.minutes(), 2);
- });
- addFormatToken("hmmss", 0, 0, function() {
- return "" + hFormat.apply(this) + zeroFill(this.minutes(), 2) + zeroFill(this.seconds(), 2);
- });
- addFormatToken("Hmm", 0, 0, function() {
- return "" + this.hours() + zeroFill(this.minutes(), 2);
- });
- addFormatToken("Hmmss", 0, 0, function() {
- return "" + this.hours() + zeroFill(this.minutes(), 2) + zeroFill(this.seconds(), 2);
- });
- function meridiem(token2, lowercase) {
- addFormatToken(token2, 0, 0, function() {
- return this.localeData().meridiem(
- this.hours(),
- this.minutes(),
- lowercase
- );
- });
- }
- meridiem("a", true);
- meridiem("A", false);
- function matchMeridiem(isStrict, locale2) {
- return locale2._meridiemParse;
- }
- addRegexToken("a", matchMeridiem);
- addRegexToken("A", matchMeridiem);
- addRegexToken("H", match1to2, match1to2HasZero);
- addRegexToken("h", match1to2, match1to2NoLeadingZero);
- addRegexToken("k", match1to2, match1to2NoLeadingZero);
- addRegexToken("HH", match1to2, match2);
- addRegexToken("hh", match1to2, match2);
- addRegexToken("kk", match1to2, match2);
- addRegexToken("hmm", match3to4);
- addRegexToken("hmmss", match5to6);
- addRegexToken("Hmm", match3to4);
- addRegexToken("Hmmss", match5to6);
- addParseToken(["H", "HH"], HOUR);
- addParseToken(["k", "kk"], function(input, array3, config2) {
- var kInput = toInt(input);
- array3[HOUR] = kInput === 24 ? 0 : kInput;
- });
- addParseToken(["a", "A"], function(input, array3, config2) {
- config2._isPm = config2._locale.isPM(input);
- config2._meridiem = input;
- });
- addParseToken(["h", "hh"], function(input, array3, config2) {
- array3[HOUR] = toInt(input);
- getParsingFlags(config2).bigHour = true;
- });
- addParseToken("hmm", function(input, array3, config2) {
- var pos = input.length - 2;
- array3[HOUR] = toInt(input.substr(0, pos));
- array3[MINUTE] = toInt(input.substr(pos));
- getParsingFlags(config2).bigHour = true;
- });
- addParseToken("hmmss", function(input, array3, config2) {
- var pos1 = input.length - 4, pos2 = input.length - 2;
- array3[HOUR] = toInt(input.substr(0, pos1));
- array3[MINUTE] = toInt(input.substr(pos1, 2));
- array3[SECOND] = toInt(input.substr(pos2));
- getParsingFlags(config2).bigHour = true;
- });
- addParseToken("Hmm", function(input, array3, config2) {
- var pos = input.length - 2;
- array3[HOUR] = toInt(input.substr(0, pos));
- array3[MINUTE] = toInt(input.substr(pos));
- });
- addParseToken("Hmmss", function(input, array3, config2) {
- var pos1 = input.length - 4, pos2 = input.length - 2;
- array3[HOUR] = toInt(input.substr(0, pos1));
- array3[MINUTE] = toInt(input.substr(pos1, 2));
- array3[SECOND] = toInt(input.substr(pos2));
- });
- function localeIsPM(input) {
- return (input + "").toLowerCase().charAt(0) === "p";
- }
- var defaultLocaleMeridiemParse = /[ap]\.?m?\.?/i, getSetHour = makeGetSet("Hours", true);
- function localeMeridiem(hours2, minutes2, isLower) {
- if (hours2 > 11) {
- return isLower ? "pm" : "PM";
- } else {
- return isLower ? "am" : "AM";
- }
- }
- var baseConfig = {
- calendar: defaultCalendar,
- longDateFormat: defaultLongDateFormat,
- invalidDate: defaultInvalidDate,
- ordinal: defaultOrdinal,
- dayOfMonthOrdinalParse: defaultDayOfMonthOrdinalParse,
- relativeTime: defaultRelativeTime,
- months: defaultLocaleMonths,
- monthsShort: defaultLocaleMonthsShort,
- week: defaultLocaleWeek,
- weekdays: defaultLocaleWeekdays,
- weekdaysMin: defaultLocaleWeekdaysMin,
- weekdaysShort: defaultLocaleWeekdaysShort,
- meridiemParse: defaultLocaleMeridiemParse
- };
- var locales = {}, localeFamilies = {}, globalLocale;
- function commonPrefix(arr1, arr2) {
- var i, minl = Math.min(arr1.length, arr2.length);
- for (i = 0; i < minl; i += 1) {
- if (arr1[i] !== arr2[i]) {
- return i;
- }
- }
- return minl;
- }
- function normalizeLocale(key) {
- return key ? key.toLowerCase().replace("_", "-") : key;
- }
- function chooseLocale(names) {
- var i = 0, j, next, locale2, split;
- while (i < names.length) {
- split = normalizeLocale(names[i]).split("-");
- j = split.length;
- next = normalizeLocale(names[i + 1]);
- next = next ? next.split("-") : null;
- while (j > 0) {
- locale2 = loadLocale(split.slice(0, j).join("-"));
- if (locale2) {
- return locale2;
- }
- if (next && next.length >= j && commonPrefix(split, next) >= j - 1) {
- break;
- }
- j--;
- }
- i++;
- }
- return globalLocale;
- }
- function isLocaleNameSane(name) {
- return !!(name && name.match("^[^/\\\\]*$"));
- }
- function loadLocale(name) {
- var oldLocale = null, aliasedRequire;
- if (locales[name] === void 0 && typeof module !== "undefined" && module && module.exports && isLocaleNameSane(name)) {
- try {
- oldLocale = globalLocale._abbr;
- aliasedRequire = require;
- aliasedRequire("./locale/" + name);
- getSetGlobalLocale(oldLocale);
- } catch (e2) {
- locales[name] = null;
- }
- }
- return locales[name];
- }
- function getSetGlobalLocale(key, values) {
- var data;
- if (key) {
- if (isUndefined(values)) {
- data = getLocale(key);
- } else {
- data = defineLocale(key, values);
- }
- if (data) {
- globalLocale = data;
- } else {
- if (typeof console !== "undefined" && console.warn) {
- console.warn(
- "Locale " + key + " not found. Did you forget to load it?"
- );
- }
- }
- }
- return globalLocale._abbr;
- }
- function defineLocale(name, config2) {
- if (config2 !== null) {
- var locale2, parentConfig = baseConfig;
- config2.abbr = name;
- if (locales[name] != null) {
- deprecateSimple(
- "defineLocaleOverride",
- "use moment.updateLocale(localeName, config) to change an existing locale. moment.defineLocale(localeName, config) should only be used for creating a new locale See http://momentjs.com/guides/#/warnings/define-locale/ for more info."
- );
- parentConfig = locales[name]._config;
- } else if (config2.parentLocale != null) {
- if (locales[config2.parentLocale] != null) {
- parentConfig = locales[config2.parentLocale]._config;
- } else {
- locale2 = loadLocale(config2.parentLocale);
- if (locale2 != null) {
- parentConfig = locale2._config;
- } else {
- if (!localeFamilies[config2.parentLocale]) {
- localeFamilies[config2.parentLocale] = [];
- }
- localeFamilies[config2.parentLocale].push({
- name,
- config: config2
- });
- return null;
- }
- }
- }
- locales[name] = new Locale(mergeConfigs(parentConfig, config2));
- if (localeFamilies[name]) {
- localeFamilies[name].forEach(function(x) {
- defineLocale(x.name, x.config);
- });
- }
- getSetGlobalLocale(name);
- return locales[name];
- } else {
- delete locales[name];
- return null;
- }
- }
- function updateLocale(name, config2) {
- if (config2 != null) {
- var locale2, tmpLocale, parentConfig = baseConfig;
- if (locales[name] != null && locales[name].parentLocale != null) {
- locales[name].set(mergeConfigs(locales[name]._config, config2));
- } else {
- tmpLocale = loadLocale(name);
- if (tmpLocale != null) {
- parentConfig = tmpLocale._config;
- }
- config2 = mergeConfigs(parentConfig, config2);
- if (tmpLocale == null) {
- config2.abbr = name;
- }
- locale2 = new Locale(config2);
- locale2.parentLocale = locales[name];
- locales[name] = locale2;
- }
- getSetGlobalLocale(name);
- } else {
- if (locales[name] != null) {
- if (locales[name].parentLocale != null) {
- locales[name] = locales[name].parentLocale;
- if (name === getSetGlobalLocale()) {
- getSetGlobalLocale(name);
- }
- } else if (locales[name] != null) {
- delete locales[name];
- }
- }
- }
- return locales[name];
- }
- function getLocale(key) {
- var locale2;
- if (key && key._locale && key._locale._abbr) {
- key = key._locale._abbr;
- }
- if (!key) {
- return globalLocale;
- }
- if (!isArray(key)) {
- locale2 = loadLocale(key);
- if (locale2) {
- return locale2;
- }
- key = [key];
- }
- return chooseLocale(key);
- }
- function listLocales() {
- return keys(locales);
- }
- function checkOverflow(m) {
- var overflow, a = m._a;
- if (a && getParsingFlags(m).overflow === -2) {
- overflow = a[MONTH] < 0 || a[MONTH] > 11 ? MONTH : a[DATE] < 1 || a[DATE] > daysInMonth(a[YEAR], a[MONTH]) ? DATE : a[HOUR] < 0 || a[HOUR] > 24 || a[HOUR] === 24 && (a[MINUTE] !== 0 || a[SECOND] !== 0 || a[MILLISECOND] !== 0) ? HOUR : a[MINUTE] < 0 || a[MINUTE] > 59 ? MINUTE : a[SECOND] < 0 || a[SECOND] > 59 ? SECOND : a[MILLISECOND] < 0 || a[MILLISECOND] > 999 ? MILLISECOND : -1;
- if (getParsingFlags(m)._overflowDayOfYear && (overflow < YEAR || overflow > DATE)) {
- overflow = DATE;
- }
- if (getParsingFlags(m)._overflowWeeks && overflow === -1) {
- overflow = WEEK;
- }
- if (getParsingFlags(m)._overflowWeekday && overflow === -1) {
- overflow = WEEKDAY;
- }
- getParsingFlags(m).overflow = overflow;
- }
- return m;
- }
- var extendedIsoRegex = /^\s*((?:[+-]\d{6}|\d{4})-(?:\d\d-\d\d|W\d\d-\d|W\d\d|\d\d\d|\d\d))(?:(T| )(\d\d(?::\d\d(?::\d\d(?:[.,]\d+)?)?)?)([+-]\d\d(?::?\d\d)?|\s*Z)?)?$/, basicIsoRegex = /^\s*((?:[+-]\d{6}|\d{4})(?:\d\d\d\d|W\d\d\d|W\d\d|\d\d\d|\d\d|))(?:(T| )(\d\d(?:\d\d(?:\d\d(?:[.,]\d+)?)?)?)([+-]\d\d(?::?\d\d)?|\s*Z)?)?$/, tzRegex = /Z|[+-]\d\d(?::?\d\d)?/, isoDates = [
- ["YYYYYY-MM-DD", /[+-]\d{6}-\d\d-\d\d/],
- ["YYYY-MM-DD", /\d{4}-\d\d-\d\d/],
- ["GGGG-[W]WW-E", /\d{4}-W\d\d-\d/],
- ["GGGG-[W]WW", /\d{4}-W\d\d/, false],
- ["YYYY-DDD", /\d{4}-\d{3}/],
- ["YYYY-MM", /\d{4}-\d\d/, false],
- ["YYYYYYMMDD", /[+-]\d{10}/],
- ["YYYYMMDD", /\d{8}/],
- ["GGGG[W]WWE", /\d{4}W\d{3}/],
- ["GGGG[W]WW", /\d{4}W\d{2}/, false],
- ["YYYYDDD", /\d{7}/],
- ["YYYYMM", /\d{6}/, false],
- ["YYYY", /\d{4}/, false]
- ], isoTimes = [
- ["HH:mm:ss.SSSS", /\d\d:\d\d:\d\d\.\d+/],
- ["HH:mm:ss,SSSS", /\d\d:\d\d:\d\d,\d+/],
- ["HH:mm:ss", /\d\d:\d\d:\d\d/],
- ["HH:mm", /\d\d:\d\d/],
- ["HHmmss.SSSS", /\d\d\d\d\d\d\.\d+/],
- ["HHmmss,SSSS", /\d\d\d\d\d\d,\d+/],
- ["HHmmss", /\d\d\d\d\d\d/],
- ["HHmm", /\d\d\d\d/],
- ["HH", /\d\d/]
- ], aspNetJsonRegex = /^\/?Date\((-?\d+)/i, rfc2822 = /^(?:(Mon|Tue|Wed|Thu|Fri|Sat|Sun),?\s)?(\d{1,2})\s(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)\s(\d{2,4})\s(\d\d):(\d\d)(?::(\d\d))?\s(?:(UT|GMT|[ECMP][SD]T)|([Zz])|([+-]\d{4}))$/, obsOffsets = {
- UT: 0,
- GMT: 0,
- EDT: -4 * 60,
- EST: -5 * 60,
- CDT: -5 * 60,
- CST: -6 * 60,
- MDT: -6 * 60,
- MST: -7 * 60,
- PDT: -7 * 60,
- PST: -8 * 60
- };
- function configFromISO(config2) {
- var i, l, string2 = config2._i, match = extendedIsoRegex.exec(string2) || basicIsoRegex.exec(string2), allowTime, dateFormat, timeFormat2, tzFormat, isoDatesLen = isoDates.length, isoTimesLen = isoTimes.length;
- if (match) {
- getParsingFlags(config2).iso = true;
- for (i = 0, l = isoDatesLen; i < l; i++) {
- if (isoDates[i][1].exec(match[1])) {
- dateFormat = isoDates[i][0];
- allowTime = isoDates[i][2] !== false;
- break;
- }
- }
- if (dateFormat == null) {
- config2._isValid = false;
- return;
- }
- if (match[3]) {
- for (i = 0, l = isoTimesLen; i < l; i++) {
- if (isoTimes[i][1].exec(match[3])) {
- timeFormat2 = (match[2] || " ") + isoTimes[i][0];
- break;
- }
- }
- if (timeFormat2 == null) {
- config2._isValid = false;
- return;
- }
- }
- if (!allowTime && timeFormat2 != null) {
- config2._isValid = false;
- return;
- }
- if (match[4]) {
- if (tzRegex.exec(match[4])) {
- tzFormat = "Z";
- } else {
- config2._isValid = false;
- return;
- }
- }
- config2._f = dateFormat + (timeFormat2 || "") + (tzFormat || "");
- configFromStringAndFormat(config2);
- } else {
- config2._isValid = false;
- }
- }
- function extractFromRFC2822Strings(yearStr, monthStr, dayStr, hourStr, minuteStr, secondStr) {
- var result = [
- untruncateYear(yearStr),
- defaultLocaleMonthsShort.indexOf(monthStr),
- parseInt(dayStr, 10),
- parseInt(hourStr, 10),
- parseInt(minuteStr, 10)
- ];
- if (secondStr) {
- result.push(parseInt(secondStr, 10));
- }
- return result;
- }
- function untruncateYear(yearStr) {
- var year = parseInt(yearStr, 10);
- if (year <= 49) {
- return 2e3 + year;
- } else if (year <= 999) {
- return 1900 + year;
- }
- return year;
- }
- function preprocessRFC2822(s2) {
- return s2.replace(/\([^()]*\)|[\n\t]/g, " ").replace(/(\s\s+)/g, " ").replace(/^\s\s*/, "").replace(/\s\s*$/, "");
- }
- function checkWeekday(weekdayStr, parsedInput, config2) {
- if (weekdayStr) {
- var weekdayProvided = defaultLocaleWeekdaysShort.indexOf(weekdayStr), weekdayActual = new Date(
- parsedInput[0],
- parsedInput[1],
- parsedInput[2]
- ).getDay();
- if (weekdayProvided !== weekdayActual) {
- getParsingFlags(config2).weekdayMismatch = true;
- config2._isValid = false;
- return false;
- }
- }
- return true;
- }
- function calculateOffset(obsOffset, militaryOffset, numOffset) {
- if (obsOffset) {
- return obsOffsets[obsOffset];
- } else if (militaryOffset) {
- return 0;
- } else {
- var hm = parseInt(numOffset, 10), m = hm % 100, h = (hm - m) / 100;
- return h * 60 + m;
- }
- }
- function configFromRFC2822(config2) {
- var match = rfc2822.exec(preprocessRFC2822(config2._i)), parsedArray;
- if (match) {
- parsedArray = extractFromRFC2822Strings(
- match[4],
- match[3],
- match[2],
- match[5],
- match[6],
- match[7]
- );
- if (!checkWeekday(match[1], parsedArray, config2)) {
- return;
- }
- config2._a = parsedArray;
- config2._tzm = calculateOffset(match[8], match[9], match[10]);
- config2._d = createUTCDate.apply(null, config2._a);
- config2._d.setUTCMinutes(config2._d.getUTCMinutes() - config2._tzm);
- getParsingFlags(config2).rfc2822 = true;
- } else {
- config2._isValid = false;
- }
- }
- function configFromString(config2) {
- var matched = aspNetJsonRegex.exec(config2._i);
- if (matched !== null) {
- config2._d = /* @__PURE__ */ new Date(+matched[1]);
- return;
- }
- configFromISO(config2);
- if (config2._isValid === false) {
- delete config2._isValid;
- } else {
- return;
- }
- configFromRFC2822(config2);
- if (config2._isValid === false) {
- delete config2._isValid;
- } else {
- return;
- }
- if (config2._strict) {
- config2._isValid = false;
- } else {
- hooks.createFromInputFallback(config2);
- }
- }
- hooks.createFromInputFallback = deprecate(
- "value provided is not in a recognized RFC2822 or ISO format. moment construction falls back to js Date(), which is not reliable across all browsers and versions. Non RFC2822/ISO date formats are discouraged. Please refer to http://momentjs.com/guides/#/warnings/js-date/ for more info.",
- function(config2) {
- config2._d = /* @__PURE__ */ new Date(config2._i + (config2._useUTC ? " UTC" : ""));
- }
- );
- function defaults(a, b, c) {
- if (a != null) {
- return a;
- }
- if (b != null) {
- return b;
- }
- return c;
- }
- function currentDateArray(config2) {
- var nowValue = new Date(hooks.now());
- if (config2._useUTC) {
- return [
- nowValue.getUTCFullYear(),
- nowValue.getUTCMonth(),
- nowValue.getUTCDate()
- ];
- }
- return [nowValue.getFullYear(), nowValue.getMonth(), nowValue.getDate()];
- }
- function configFromArray(config2) {
- var i, date3, input = [], currentDate, expectedWeekday, yearToUse;
- if (config2._d) {
- return;
- }
- currentDate = currentDateArray(config2);
- if (config2._w && config2._a[DATE] == null && config2._a[MONTH] == null) {
- dayOfYearFromWeekInfo(config2);
- }
- if (config2._dayOfYear != null) {
- yearToUse = defaults(config2._a[YEAR], currentDate[YEAR]);
- if (config2._dayOfYear > daysInYear(yearToUse) || config2._dayOfYear === 0) {
- getParsingFlags(config2)._overflowDayOfYear = true;
- }
- date3 = createUTCDate(yearToUse, 0, config2._dayOfYear);
- config2._a[MONTH] = date3.getUTCMonth();
- config2._a[DATE] = date3.getUTCDate();
- }
- for (i = 0; i < 3 && config2._a[i] == null; ++i) {
- config2._a[i] = input[i] = currentDate[i];
- }
- for (; i < 7; i++) {
- config2._a[i] = input[i] = config2._a[i] == null ? i === 2 ? 1 : 0 : config2._a[i];
- }
- if (config2._a[HOUR] === 24 && config2._a[MINUTE] === 0 && config2._a[SECOND] === 0 && config2._a[MILLISECOND] === 0) {
- config2._nextDay = true;
- config2._a[HOUR] = 0;
- }
- config2._d = (config2._useUTC ? createUTCDate : createDate).apply(
- null,
- input
- );
- expectedWeekday = config2._useUTC ? config2._d.getUTCDay() : config2._d.getDay();
- if (config2._tzm != null) {
- config2._d.setUTCMinutes(config2._d.getUTCMinutes() - config2._tzm);
- }
- if (config2._nextDay) {
- config2._a[HOUR] = 24;
- }
- if (config2._w && typeof config2._w.d !== "undefined" && config2._w.d !== expectedWeekday) {
- getParsingFlags(config2).weekdayMismatch = true;
- }
- }
- function dayOfYearFromWeekInfo(config2) {
- var w, weekYear, week, weekday, dow, doy, temp, weekdayOverflow, curWeek;
- w = config2._w;
- if (w.GG != null || w.W != null || w.E != null) {
- dow = 1;
- doy = 4;
- weekYear = defaults(
- w.GG,
- config2._a[YEAR],
- weekOfYear(createLocal(), 1, 4).year
- );
- week = defaults(w.W, 1);
- weekday = defaults(w.E, 1);
- if (weekday < 1 || weekday > 7) {
- weekdayOverflow = true;
- }
- } else {
- dow = config2._locale._week.dow;
- doy = config2._locale._week.doy;
- curWeek = weekOfYear(createLocal(), dow, doy);
- weekYear = defaults(w.gg, config2._a[YEAR], curWeek.year);
- week = defaults(w.w, curWeek.week);
- if (w.d != null) {
- weekday = w.d;
- if (weekday < 0 || weekday > 6) {
- weekdayOverflow = true;
- }
- } else if (w.e != null) {
- weekday = w.e + dow;
- if (w.e < 0 || w.e > 6) {
- weekdayOverflow = true;
- }
- } else {
- weekday = dow;
- }
- }
- if (week < 1 || week > weeksInYear(weekYear, dow, doy)) {
- getParsingFlags(config2)._overflowWeeks = true;
- } else if (weekdayOverflow != null) {
- getParsingFlags(config2)._overflowWeekday = true;
- } else {
- temp = dayOfYearFromWeeks(weekYear, week, weekday, dow, doy);
- config2._a[YEAR] = temp.year;
- config2._dayOfYear = temp.dayOfYear;
- }
- }
- hooks.ISO_8601 = function() {
- };
- hooks.RFC_2822 = function() {
- };
- function configFromStringAndFormat(config2) {
- if (config2._f === hooks.ISO_8601) {
- configFromISO(config2);
- return;
- }
- if (config2._f === hooks.RFC_2822) {
- configFromRFC2822(config2);
- return;
- }
- config2._a = [];
- getParsingFlags(config2).empty = true;
- var string2 = "" + config2._i, i, parsedInput, tokens2, token2, skipped, stringLength = string2.length, totalParsedInputLength = 0, era, tokenLen;
- tokens2 = expandFormat(config2._f, config2._locale).match(formattingTokens) || [];
- tokenLen = tokens2.length;
- for (i = 0; i < tokenLen; i++) {
- token2 = tokens2[i];
- parsedInput = (string2.match(getParseRegexForToken(token2, config2)) || [])[0];
- if (parsedInput) {
- skipped = string2.substr(0, string2.indexOf(parsedInput));
- if (skipped.length > 0) {
- getParsingFlags(config2).unusedInput.push(skipped);
- }
- string2 = string2.slice(
- string2.indexOf(parsedInput) + parsedInput.length
- );
- totalParsedInputLength += parsedInput.length;
- }
- if (formatTokenFunctions[token2]) {
- if (parsedInput) {
- getParsingFlags(config2).empty = false;
- } else {
- getParsingFlags(config2).unusedTokens.push(token2);
- }
- addTimeToArrayFromToken(token2, parsedInput, config2);
- } else if (config2._strict && !parsedInput) {
- getParsingFlags(config2).unusedTokens.push(token2);
- }
- }
- getParsingFlags(config2).charsLeftOver = stringLength - totalParsedInputLength;
- if (string2.length > 0) {
- getParsingFlags(config2).unusedInput.push(string2);
- }
- if (config2._a[HOUR] <= 12 && getParsingFlags(config2).bigHour === true && config2._a[HOUR] > 0) {
- getParsingFlags(config2).bigHour = void 0;
- }
- getParsingFlags(config2).parsedDateParts = config2._a.slice(0);
- getParsingFlags(config2).meridiem = config2._meridiem;
- config2._a[HOUR] = meridiemFixWrap(
- config2._locale,
- config2._a[HOUR],
- config2._meridiem
- );
- era = getParsingFlags(config2).era;
- if (era !== null) {
- config2._a[YEAR] = config2._locale.erasConvertYear(era, config2._a[YEAR]);
- }
- configFromArray(config2);
- checkOverflow(config2);
- }
- function meridiemFixWrap(locale2, hour, meridiem2) {
- var isPm;
- if (meridiem2 == null) {
- return hour;
- }
- if (locale2.meridiemHour != null) {
- return locale2.meridiemHour(hour, meridiem2);
- } else if (locale2.isPM != null) {
- isPm = locale2.isPM(meridiem2);
- if (isPm && hour < 12) {
- hour += 12;
- }
- if (!isPm && hour === 12) {
- hour = 0;
- }
- return hour;
- } else {
- return hour;
- }
- }
- function configFromStringAndArray(config2) {
- var tempConfig, bestMoment, scoreToBeat, i, currentScore, validFormatFound, bestFormatIsValid = false, configfLen = config2._f.length;
- if (configfLen === 0) {
- getParsingFlags(config2).invalidFormat = true;
- config2._d = /* @__PURE__ */ new Date(NaN);
- return;
- }
- for (i = 0; i < configfLen; i++) {
- currentScore = 0;
- validFormatFound = false;
- tempConfig = copyConfig({}, config2);
- if (config2._useUTC != null) {
- tempConfig._useUTC = config2._useUTC;
- }
- tempConfig._f = config2._f[i];
- configFromStringAndFormat(tempConfig);
- if (isValid(tempConfig)) {
- validFormatFound = true;
- }
- currentScore += getParsingFlags(tempConfig).charsLeftOver;
- currentScore += getParsingFlags(tempConfig).unusedTokens.length * 10;
- getParsingFlags(tempConfig).score = currentScore;
- if (!bestFormatIsValid) {
- if (scoreToBeat == null || currentScore < scoreToBeat || validFormatFound) {
- scoreToBeat = currentScore;
- bestMoment = tempConfig;
- if (validFormatFound) {
- bestFormatIsValid = true;
- }
- }
- } else {
- if (currentScore < scoreToBeat) {
- scoreToBeat = currentScore;
- bestMoment = tempConfig;
- }
- }
- }
- extend(config2, bestMoment || tempConfig);
- }
- function configFromObject(config2) {
- if (config2._d) {
- return;
- }
- var i = normalizeObjectUnits(config2._i), dayOrDate = i.day === void 0 ? i.date : i.day;
- config2._a = map(
- [i.year, i.month, dayOrDate, i.hour, i.minute, i.second, i.millisecond],
- function(obj) {
- return obj && parseInt(obj, 10);
- }
- );
- configFromArray(config2);
- }
- function createFromConfig(config2) {
- var res = new Moment(checkOverflow(prepareConfig(config2)));
- if (res._nextDay) {
- res.add(1, "d");
- res._nextDay = void 0;
- }
- return res;
- }
- function prepareConfig(config2) {
- var input = config2._i, format2 = config2._f;
- config2._locale = config2._locale || getLocale(config2._l);
- if (input === null || format2 === void 0 && input === "") {
- return createInvalid({ nullInput: true });
- }
- if (typeof input === "string") {
- config2._i = input = config2._locale.preparse(input);
- }
- if (isMoment(input)) {
- return new Moment(checkOverflow(input));
- } else if (isDate(input)) {
- config2._d = input;
- } else if (isArray(format2)) {
- configFromStringAndArray(config2);
- } else if (format2) {
- configFromStringAndFormat(config2);
- } else {
- configFromInput(config2);
- }
- if (!isValid(config2)) {
- config2._d = null;
- }
- return config2;
- }
- function configFromInput(config2) {
- var input = config2._i;
- if (isUndefined(input)) {
- config2._d = new Date(hooks.now());
- } else if (isDate(input)) {
- config2._d = new Date(input.valueOf());
- } else if (typeof input === "string") {
- configFromString(config2);
- } else if (isArray(input)) {
- config2._a = map(input.slice(0), function(obj) {
- return parseInt(obj, 10);
- });
- configFromArray(config2);
- } else if (isObject(input)) {
- configFromObject(config2);
- } else if (isNumber(input)) {
- config2._d = new Date(input);
- } else {
- hooks.createFromInputFallback(config2);
- }
- }
- function createLocalOrUTC(input, format2, locale2, strict, isUTC) {
- var c = {};
- if (format2 === true || format2 === false) {
- strict = format2;
- format2 = void 0;
- }
- if (locale2 === true || locale2 === false) {
- strict = locale2;
- locale2 = void 0;
- }
- if (isObject(input) && isObjectEmpty(input) || isArray(input) && input.length === 0) {
- input = void 0;
- }
- c._isAMomentObject = true;
- c._useUTC = c._isUTC = isUTC;
- c._l = locale2;
- c._i = input;
- c._f = format2;
- c._strict = strict;
- return createFromConfig(c);
- }
- function createLocal(input, format2, locale2, strict) {
- return createLocalOrUTC(input, format2, locale2, strict, false);
- }
- var prototypeMin = deprecate(
- "moment().min is deprecated, use moment.max instead. http://momentjs.com/guides/#/warnings/min-max/",
- function() {
- var other = createLocal.apply(null, arguments);
- if (this.isValid() && other.isValid()) {
- return other < this ? this : other;
- } else {
- return createInvalid();
- }
- }
- ), prototypeMax = deprecate(
- "moment().max is deprecated, use moment.min instead. http://momentjs.com/guides/#/warnings/min-max/",
- function() {
- var other = createLocal.apply(null, arguments);
- if (this.isValid() && other.isValid()) {
- return other > this ? this : other;
- } else {
- return createInvalid();
- }
- }
- );
- function pickBy(fn, moments) {
- var res, i;
- if (moments.length === 1 && isArray(moments[0])) {
- moments = moments[0];
- }
- if (!moments.length) {
- return createLocal();
- }
- res = moments[0];
- for (i = 1; i < moments.length; ++i) {
- if (!moments[i].isValid() || moments[i][fn](res)) {
- res = moments[i];
- }
- }
- return res;
- }
- function min() {
- var args = [].slice.call(arguments, 0);
- return pickBy("isBefore", args);
- }
- function max() {
- var args = [].slice.call(arguments, 0);
- return pickBy("isAfter", args);
- }
- var now = function() {
- return Date.now ? Date.now() : +/* @__PURE__ */ new Date();
- };
- var ordering = [
- "year",
- "quarter",
- "month",
- "week",
- "day",
- "hour",
- "minute",
- "second",
- "millisecond"
- ];
- function isDurationValid(m) {
- var key, unitHasDecimal = false, i, orderLen = ordering.length;
- for (key in m) {
- if (hasOwnProp(m, key) && !(indexOf.call(ordering, key) !== -1 && (m[key] == null || !isNaN(m[key])))) {
- return false;
- }
- }
- for (i = 0; i < orderLen; ++i) {
- if (m[ordering[i]]) {
- if (unitHasDecimal) {
- return false;
- }
- if (parseFloat(m[ordering[i]]) !== toInt(m[ordering[i]])) {
- unitHasDecimal = true;
- }
- }
- }
- return true;
- }
- function isValid$1() {
- return this._isValid;
- }
- function createInvalid$1() {
- return createDuration(NaN);
- }
- function Duration(duration) {
- var normalizedInput = normalizeObjectUnits(duration), years2 = normalizedInput.year || 0, quarters = normalizedInput.quarter || 0, months2 = normalizedInput.month || 0, weeks2 = normalizedInput.week || normalizedInput.isoWeek || 0, days2 = normalizedInput.day || 0, hours2 = normalizedInput.hour || 0, minutes2 = normalizedInput.minute || 0, seconds2 = normalizedInput.second || 0, milliseconds2 = normalizedInput.millisecond || 0;
- this._isValid = isDurationValid(normalizedInput);
- this._milliseconds = +milliseconds2 + seconds2 * 1e3 + // 1000
- minutes2 * 6e4 + // 1000 * 60
- hours2 * 1e3 * 60 * 60;
- this._days = +days2 + weeks2 * 7;
- this._months = +months2 + quarters * 3 + years2 * 12;
- this._data = {};
- this._locale = getLocale();
- this._bubble();
- }
- function isDuration(obj) {
- return obj instanceof Duration;
- }
- function absRound(number3) {
- if (number3 < 0) {
- return Math.round(-1 * number3) * -1;
- } else {
- return Math.round(number3);
- }
- }
- function compareArrays(array1, array22, dontConvert) {
- var len = Math.min(array1.length, array22.length), lengthDiff = Math.abs(array1.length - array22.length), diffs = 0, i;
- for (i = 0; i < len; i++) {
- if (dontConvert && array1[i] !== array22[i] || !dontConvert && toInt(array1[i]) !== toInt(array22[i])) {
- diffs++;
- }
- }
- return diffs + lengthDiff;
- }
- function offset(token2, separator) {
- addFormatToken(token2, 0, 0, function() {
- var offset2 = this.utcOffset(), sign2 = "+";
- if (offset2 < 0) {
- offset2 = -offset2;
- sign2 = "-";
- }
- return sign2 + zeroFill(~~(offset2 / 60), 2) + separator + zeroFill(~~offset2 % 60, 2);
- });
- }
- offset("Z", ":");
- offset("ZZ", "");
- addRegexToken("Z", matchShortOffset);
- addRegexToken("ZZ", matchShortOffset);
- addParseToken(["Z", "ZZ"], function(input, array3, config2) {
- config2._useUTC = true;
- config2._tzm = offsetFromString(matchShortOffset, input);
- });
- var chunkOffset = /([\+\-]|\d\d)/gi;
- function offsetFromString(matcher, string2) {
- var matches = (string2 || "").match(matcher), chunk, parts, minutes2;
- if (matches === null) {
- return null;
- }
- chunk = matches[matches.length - 1] || [];
- parts = (chunk + "").match(chunkOffset) || ["-", 0, 0];
- minutes2 = +(parts[1] * 60) + toInt(parts[2]);
- return minutes2 === 0 ? 0 : parts[0] === "+" ? minutes2 : -minutes2;
- }
- function cloneWithOffset(input, model) {
- var res, diff2;
- if (model._isUTC) {
- res = model.clone();
- diff2 = (isMoment(input) || isDate(input) ? input.valueOf() : createLocal(input).valueOf()) - res.valueOf();
- res._d.setTime(res._d.valueOf() + diff2);
- hooks.updateOffset(res, false);
- return res;
- } else {
- return createLocal(input).local();
- }
- }
- function getDateOffset(m) {
- return -Math.round(m._d.getTimezoneOffset());
- }
- hooks.updateOffset = function() {
- };
- function getSetOffset(input, keepLocalTime, keepMinutes) {
- var offset2 = this._offset || 0, localAdjust;
- if (!this.isValid()) {
- return input != null ? this : NaN;
- }
- if (input != null) {
- if (typeof input === "string") {
- input = offsetFromString(matchShortOffset, input);
- if (input === null) {
- return this;
- }
- } else if (Math.abs(input) < 16 && !keepMinutes) {
- input = input * 60;
- }
- if (!this._isUTC && keepLocalTime) {
- localAdjust = getDateOffset(this);
- }
- this._offset = input;
- this._isUTC = true;
- if (localAdjust != null) {
- this.add(localAdjust, "m");
- }
- if (offset2 !== input) {
- if (!keepLocalTime || this._changeInProgress) {
- addSubtract(
- this,
- createDuration(input - offset2, "m"),
- 1,
- false
- );
- } else if (!this._changeInProgress) {
- this._changeInProgress = true;
- hooks.updateOffset(this, true);
- this._changeInProgress = null;
- }
- }
- return this;
- } else {
- return this._isUTC ? offset2 : getDateOffset(this);
- }
- }
- function getSetZone(input, keepLocalTime) {
- if (input != null) {
- if (typeof input !== "string") {
- input = -input;
- }
- this.utcOffset(input, keepLocalTime);
- return this;
- } else {
- return -this.utcOffset();
- }
- }
- function setOffsetToUTC(keepLocalTime) {
- return this.utcOffset(0, keepLocalTime);
- }
- function setOffsetToLocal(keepLocalTime) {
- if (this._isUTC) {
- this.utcOffset(0, keepLocalTime);
- this._isUTC = false;
- if (keepLocalTime) {
- this.subtract(getDateOffset(this), "m");
- }
- }
- return this;
- }
- function setOffsetToParsedOffset() {
- if (this._tzm != null) {
- this.utcOffset(this._tzm, false, true);
- } else if (typeof this._i === "string") {
- var tZone = offsetFromString(matchOffset, this._i);
- if (tZone != null) {
- this.utcOffset(tZone);
- } else {
- this.utcOffset(0, true);
- }
- }
- return this;
- }
- function hasAlignedHourOffset(input) {
- if (!this.isValid()) {
- return false;
- }
- input = input ? createLocal(input).utcOffset() : 0;
- return (this.utcOffset() - input) % 60 === 0;
- }
- function isDaylightSavingTime() {
- return this.utcOffset() > this.clone().month(0).utcOffset() || this.utcOffset() > this.clone().month(5).utcOffset();
- }
- function isDaylightSavingTimeShifted() {
- if (!isUndefined(this._isDSTShifted)) {
- return this._isDSTShifted;
- }
- var c = {}, other;
- copyConfig(c, this);
- c = prepareConfig(c);
- if (c._a) {
- other = c._isUTC ? createUTC(c._a) : createLocal(c._a);
- this._isDSTShifted = this.isValid() && compareArrays(c._a, other.toArray()) > 0;
- } else {
- this._isDSTShifted = false;
- }
- return this._isDSTShifted;
- }
- function isLocal() {
- return this.isValid() ? !this._isUTC : false;
- }
- function isUtcOffset() {
- return this.isValid() ? this._isUTC : false;
- }
- function isUtc() {
- return this.isValid() ? this._isUTC && this._offset === 0 : false;
- }
- var aspNetRegex = /^(-|\+)?(?:(\d*)[. ])?(\d+):(\d+)(?::(\d+)(\.\d*)?)?$/, isoRegex = /^(-|\+)?P(?:([-+]?[0-9,.]*)Y)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)W)?(?:([-+]?[0-9,.]*)D)?(?:T(?:([-+]?[0-9,.]*)H)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)S)?)?$/;
- function createDuration(input, key) {
- var duration = input, match = null, sign2, ret, diffRes;
- if (isDuration(input)) {
- duration = {
- ms: input._milliseconds,
- d: input._days,
- M: input._months
- };
- } else if (isNumber(input) || !isNaN(+input)) {
- duration = {};
- if (key) {
- duration[key] = +input;
- } else {
- duration.milliseconds = +input;
- }
- } else if (match = aspNetRegex.exec(input)) {
- sign2 = match[1] === "-" ? -1 : 1;
- duration = {
- y: 0,
- d: toInt(match[DATE]) * sign2,
- h: toInt(match[HOUR]) * sign2,
- m: toInt(match[MINUTE]) * sign2,
- s: toInt(match[SECOND]) * sign2,
- ms: toInt(absRound(match[MILLISECOND] * 1e3)) * sign2
- // the millisecond decimal point is included in the match
- };
- } else if (match = isoRegex.exec(input)) {
- sign2 = match[1] === "-" ? -1 : 1;
- duration = {
- y: parseIso(match[2], sign2),
- M: parseIso(match[3], sign2),
- w: parseIso(match[4], sign2),
- d: parseIso(match[5], sign2),
- h: parseIso(match[6], sign2),
- m: parseIso(match[7], sign2),
- s: parseIso(match[8], sign2)
- };
- } else if (duration == null) {
- duration = {};
- } else if (typeof duration === "object" && ("from" in duration || "to" in duration)) {
- diffRes = momentsDifference(
- createLocal(duration.from),
- createLocal(duration.to)
- );
- duration = {};
- duration.ms = diffRes.milliseconds;
- duration.M = diffRes.months;
- }
- ret = new Duration(duration);
- if (isDuration(input) && hasOwnProp(input, "_locale")) {
- ret._locale = input._locale;
- }
- if (isDuration(input) && hasOwnProp(input, "_isValid")) {
- ret._isValid = input._isValid;
- }
- return ret;
- }
- createDuration.fn = Duration.prototype;
- createDuration.invalid = createInvalid$1;
- function parseIso(inp, sign2) {
- var res = inp && parseFloat(inp.replace(",", "."));
- return (isNaN(res) ? 0 : res) * sign2;
- }
- function positiveMomentsDifference(base, other) {
- var res = {};
- res.months = other.month() - base.month() + (other.year() - base.year()) * 12;
- if (base.clone().add(res.months, "M").isAfter(other)) {
- --res.months;
- }
- res.milliseconds = +other - +base.clone().add(res.months, "M");
- return res;
- }
- function momentsDifference(base, other) {
- var res;
- if (!(base.isValid() && other.isValid())) {
- return { milliseconds: 0, months: 0 };
- }
- other = cloneWithOffset(other, base);
- if (base.isBefore(other)) {
- res = positiveMomentsDifference(base, other);
- } else {
- res = positiveMomentsDifference(other, base);
- res.milliseconds = -res.milliseconds;
- res.months = -res.months;
- }
- return res;
- }
- function createAdder(direction, name) {
- return function(val, period) {
- var dur, tmp;
- if (period !== null && !isNaN(+period)) {
- deprecateSimple(
- name,
- "moment()." + name + "(period, number) is deprecated. Please use moment()." + name + "(number, period). See http://momentjs.com/guides/#/warnings/add-inverted-param/ for more info."
- );
- tmp = val;
- val = period;
- period = tmp;
- }
- dur = createDuration(val, period);
- addSubtract(this, dur, direction);
- return this;
- };
- }
- function addSubtract(mom, duration, isAdding, updateOffset) {
- var milliseconds2 = duration._milliseconds, days2 = absRound(duration._days), months2 = absRound(duration._months);
- if (!mom.isValid()) {
- return;
- }
- updateOffset = updateOffset == null ? true : updateOffset;
- if (months2) {
- setMonth(mom, get(mom, "Month") + months2 * isAdding);
- }
- if (days2) {
- set$1(mom, "Date", get(mom, "Date") + days2 * isAdding);
- }
- if (milliseconds2) {
- mom._d.setTime(mom._d.valueOf() + milliseconds2 * isAdding);
- }
- if (updateOffset) {
- hooks.updateOffset(mom, days2 || months2);
- }
- }
- var add = createAdder(1, "add"), subtract = createAdder(-1, "subtract");
- function isString(input) {
- return typeof input === "string" || input instanceof String;
- }
- function isMomentInput(input) {
- return isMoment(input) || isDate(input) || isString(input) || isNumber(input) || isNumberOrStringArray(input) || isMomentInputObject(input) || input === null || input === void 0;
- }
- function isMomentInputObject(input) {
- var objectTest = isObject(input) && !isObjectEmpty(input), propertyTest = false, properties = [
- "years",
- "year",
- "y",
- "months",
- "month",
- "M",
- "days",
- "day",
- "d",
- "dates",
- "date",
- "D",
- "hours",
- "hour",
- "h",
- "minutes",
- "minute",
- "m",
- "seconds",
- "second",
- "s",
- "milliseconds",
- "millisecond",
- "ms"
- ], i, property, propertyLen = properties.length;
- for (i = 0; i < propertyLen; i += 1) {
- property = properties[i];
- propertyTest = propertyTest || hasOwnProp(input, property);
- }
- return objectTest && propertyTest;
- }
- function isNumberOrStringArray(input) {
- var arrayTest = isArray(input), dataTypeTest = false;
- if (arrayTest) {
- dataTypeTest = input.filter(function(item) {
- return !isNumber(item) && isString(input);
- }).length === 0;
- }
- return arrayTest && dataTypeTest;
- }
- function isCalendarSpec(input) {
- var objectTest = isObject(input) && !isObjectEmpty(input), propertyTest = false, properties = [
- "sameDay",
- "nextDay",
- "lastDay",
- "nextWeek",
- "lastWeek",
- "sameElse"
- ], i, property;
- for (i = 0; i < properties.length; i += 1) {
- property = properties[i];
- propertyTest = propertyTest || hasOwnProp(input, property);
- }
- return objectTest && propertyTest;
- }
- function getCalendarFormat(myMoment, now2) {
- var diff2 = myMoment.diff(now2, "days", true);
- return diff2 < -6 ? "sameElse" : diff2 < -1 ? "lastWeek" : diff2 < 0 ? "lastDay" : diff2 < 1 ? "sameDay" : diff2 < 2 ? "nextDay" : diff2 < 7 ? "nextWeek" : "sameElse";
- }
- function calendar$1(time, formats) {
- if (arguments.length === 1) {
- if (!arguments[0]) {
- time = void 0;
- formats = void 0;
- } else if (isMomentInput(arguments[0])) {
- time = arguments[0];
- formats = void 0;
- } else if (isCalendarSpec(arguments[0])) {
- formats = arguments[0];
- time = void 0;
- }
- }
- var now2 = time || createLocal(), sod = cloneWithOffset(now2, this).startOf("day"), format2 = hooks.calendarFormat(this, sod) || "sameElse", output = formats && (isFunction(formats[format2]) ? formats[format2].call(this, now2) : formats[format2]);
- return this.format(
- output || this.localeData().calendar(format2, this, createLocal(now2))
- );
- }
- function clone() {
- return new Moment(this);
- }
- function isAfter(input, units) {
- var localInput = isMoment(input) ? input : createLocal(input);
- if (!(this.isValid() && localInput.isValid())) {
- return false;
- }
- units = normalizeUnits(units) || "millisecond";
- if (units === "millisecond") {
- return this.valueOf() > localInput.valueOf();
- } else {
- return localInput.valueOf() < this.clone().startOf(units).valueOf();
- }
- }
- function isBefore(input, units) {
- var localInput = isMoment(input) ? input : createLocal(input);
- if (!(this.isValid() && localInput.isValid())) {
- return false;
- }
- units = normalizeUnits(units) || "millisecond";
- if (units === "millisecond") {
- return this.valueOf() < localInput.valueOf();
- } else {
- return this.clone().endOf(units).valueOf() < localInput.valueOf();
- }
- }
- function isBetween(from2, to2, units, inclusivity) {
- var localFrom = isMoment(from2) ? from2 : createLocal(from2), localTo = isMoment(to2) ? to2 : createLocal(to2);
- if (!(this.isValid() && localFrom.isValid() && localTo.isValid())) {
- return false;
- }
- inclusivity = inclusivity || "()";
- return (inclusivity[0] === "(" ? this.isAfter(localFrom, units) : !this.isBefore(localFrom, units)) && (inclusivity[1] === ")" ? this.isBefore(localTo, units) : !this.isAfter(localTo, units));
- }
- function isSame(input, units) {
- var localInput = isMoment(input) ? input : createLocal(input), inputMs;
- if (!(this.isValid() && localInput.isValid())) {
- return false;
- }
- units = normalizeUnits(units) || "millisecond";
- if (units === "millisecond") {
- return this.valueOf() === localInput.valueOf();
- } else {
- inputMs = localInput.valueOf();
- return this.clone().startOf(units).valueOf() <= inputMs && inputMs <= this.clone().endOf(units).valueOf();
- }
- }
- function isSameOrAfter(input, units) {
- return this.isSame(input, units) || this.isAfter(input, units);
- }
- function isSameOrBefore(input, units) {
- return this.isSame(input, units) || this.isBefore(input, units);
- }
- function diff(input, units, asFloat) {
- var that, zoneDelta, output;
- if (!this.isValid()) {
- return NaN;
- }
- that = cloneWithOffset(input, this);
- if (!that.isValid()) {
- return NaN;
- }
- zoneDelta = (that.utcOffset() - this.utcOffset()) * 6e4;
- units = normalizeUnits(units);
- switch (units) {
- case "year":
- output = monthDiff(this, that) / 12;
- break;
- case "month":
- output = monthDiff(this, that);
- break;
- case "quarter":
- output = monthDiff(this, that) / 3;
- break;
- case "second":
- output = (this - that) / 1e3;
- break;
- case "minute":
- output = (this - that) / 6e4;
- break;
- case "hour":
- output = (this - that) / 36e5;
- break;
- case "day":
- output = (this - that - zoneDelta) / 864e5;
- break;
- case "week":
- output = (this - that - zoneDelta) / 6048e5;
- break;
- default:
- output = this - that;
- }
- return asFloat ? output : absFloor(output);
- }
- function monthDiff(a, b) {
- if (a.date() < b.date()) {
- return -monthDiff(b, a);
- }
- var wholeMonthDiff = (b.year() - a.year()) * 12 + (b.month() - a.month()), anchor = a.clone().add(wholeMonthDiff, "months"), anchor2, adjust;
- if (b - anchor < 0) {
- anchor2 = a.clone().add(wholeMonthDiff - 1, "months");
- adjust = (b - anchor) / (anchor - anchor2);
- } else {
- anchor2 = a.clone().add(wholeMonthDiff + 1, "months");
- adjust = (b - anchor) / (anchor2 - anchor);
- }
- return -(wholeMonthDiff + adjust) || 0;
- }
- hooks.defaultFormat = "YYYY-MM-DDTHH:mm:ssZ";
- hooks.defaultFormatUtc = "YYYY-MM-DDTHH:mm:ss[Z]";
- function toString() {
- return this.clone().locale("en").format("ddd MMM DD YYYY HH:mm:ss [GMT]ZZ");
- }
- function toISOString(keepOffset) {
- if (!this.isValid()) {
- return null;
- }
- var utc = keepOffset !== true, m = utc ? this.clone().utc() : this;
- if (m.year() < 0 || m.year() > 9999) {
- return formatMoment(
- m,
- utc ? "YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]" : "YYYYYY-MM-DD[T]HH:mm:ss.SSSZ"
- );
- }
- if (isFunction(Date.prototype.toISOString)) {
- if (utc) {
- return this.toDate().toISOString();
- } else {
- return new Date(this.valueOf() + this.utcOffset() * 60 * 1e3).toISOString().replace("Z", formatMoment(m, "Z"));
- }
- }
- return formatMoment(
- m,
- utc ? "YYYY-MM-DD[T]HH:mm:ss.SSS[Z]" : "YYYY-MM-DD[T]HH:mm:ss.SSSZ"
- );
- }
- function inspect() {
- if (!this.isValid()) {
- return "moment.invalid(/* " + this._i + " */)";
- }
- var func2 = "moment", zone = "", prefix, year, datetime, suffix;
- if (!this.isLocal()) {
- func2 = this.utcOffset() === 0 ? "moment.utc" : "moment.parseZone";
- zone = "Z";
- }
- prefix = "[" + func2 + '("]';
- year = 0 <= this.year() && this.year() <= 9999 ? "YYYY" : "YYYYYY";
- datetime = "-MM-DD[T]HH:mm:ss.SSS";
- suffix = zone + '[")]';
- return this.format(prefix + year + datetime + suffix);
- }
- function format$1(inputString) {
- if (!inputString) {
- inputString = this.isUtc() ? hooks.defaultFormatUtc : hooks.defaultFormat;
- }
- var output = formatMoment(this, inputString);
- return this.localeData().postformat(output);
- }
- function from(time, withoutSuffix) {
- if (this.isValid() && (isMoment(time) && time.isValid() || createLocal(time).isValid())) {
- return createDuration({ to: this, from: time }).locale(this.locale()).humanize(!withoutSuffix);
- } else {
- return this.localeData().invalidDate();
- }
- }
- function fromNow(withoutSuffix) {
- return this.from(createLocal(), withoutSuffix);
- }
- function to(time, withoutSuffix) {
- if (this.isValid() && (isMoment(time) && time.isValid() || createLocal(time).isValid())) {
- return createDuration({ from: this, to: time }).locale(this.locale()).humanize(!withoutSuffix);
- } else {
- return this.localeData().invalidDate();
- }
- }
- function toNow(withoutSuffix) {
- return this.to(createLocal(), withoutSuffix);
- }
- function locale(key) {
- var newLocaleData;
- if (key === void 0) {
- return this._locale._abbr;
- } else {
- newLocaleData = getLocale(key);
- if (newLocaleData != null) {
- this._locale = newLocaleData;
- }
- return this;
- }
- }
- var lang = deprecate(
- "moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.",
- function(key) {
- if (key === void 0) {
- return this.localeData();
- } else {
- return this.locale(key);
- }
- }
- );
- function localeData() {
- return this._locale;
- }
- var MS_PER_SECOND = 1e3, MS_PER_MINUTE = 60 * MS_PER_SECOND, MS_PER_HOUR = 60 * MS_PER_MINUTE, MS_PER_400_YEARS = (365 * 400 + 97) * 24 * MS_PER_HOUR;
- function mod$1(dividend, divisor) {
- return (dividend % divisor + divisor) % divisor;
- }
- function localStartOfDate(y, m, d) {
- if (y < 100 && y >= 0) {
- return new Date(y + 400, m, d) - MS_PER_400_YEARS;
- } else {
- return new Date(y, m, d).valueOf();
- }
- }
- function utcStartOfDate(y, m, d) {
- if (y < 100 && y >= 0) {
- return Date.UTC(y + 400, m, d) - MS_PER_400_YEARS;
- } else {
- return Date.UTC(y, m, d);
- }
- }
- function startOf(units) {
- var time, startOfDate;
- units = normalizeUnits(units);
- if (units === void 0 || units === "millisecond" || !this.isValid()) {
- return this;
- }
- startOfDate = this._isUTC ? utcStartOfDate : localStartOfDate;
- switch (units) {
- case "year":
- time = startOfDate(this.year(), 0, 1);
- break;
- case "quarter":
- time = startOfDate(
- this.year(),
- this.month() - this.month() % 3,
- 1
- );
- break;
- case "month":
- time = startOfDate(this.year(), this.month(), 1);
- break;
- case "week":
- time = startOfDate(
- this.year(),
- this.month(),
- this.date() - this.weekday()
- );
- break;
- case "isoWeek":
- time = startOfDate(
- this.year(),
- this.month(),
- this.date() - (this.isoWeekday() - 1)
- );
- break;
- case "day":
- case "date":
- time = startOfDate(this.year(), this.month(), this.date());
- break;
- case "hour":
- time = this._d.valueOf();
- time -= mod$1(
- time + (this._isUTC ? 0 : this.utcOffset() * MS_PER_MINUTE),
- MS_PER_HOUR
- );
- break;
- case "minute":
- time = this._d.valueOf();
- time -= mod$1(time, MS_PER_MINUTE);
- break;
- case "second":
- time = this._d.valueOf();
- time -= mod$1(time, MS_PER_SECOND);
- break;
- }
- this._d.setTime(time);
- hooks.updateOffset(this, true);
- return this;
- }
- function endOf(units) {
- var time, startOfDate;
- units = normalizeUnits(units);
- if (units === void 0 || units === "millisecond" || !this.isValid()) {
- return this;
- }
- startOfDate = this._isUTC ? utcStartOfDate : localStartOfDate;
- switch (units) {
- case "year":
- time = startOfDate(this.year() + 1, 0, 1) - 1;
- break;
- case "quarter":
- time = startOfDate(
- this.year(),
- this.month() - this.month() % 3 + 3,
- 1
- ) - 1;
- break;
- case "month":
- time = startOfDate(this.year(), this.month() + 1, 1) - 1;
- break;
- case "week":
- time = startOfDate(
- this.year(),
- this.month(),
- this.date() - this.weekday() + 7
- ) - 1;
- break;
- case "isoWeek":
- time = startOfDate(
- this.year(),
- this.month(),
- this.date() - (this.isoWeekday() - 1) + 7
- ) - 1;
- break;
- case "day":
- case "date":
- time = startOfDate(this.year(), this.month(), this.date() + 1) - 1;
- break;
- case "hour":
- time = this._d.valueOf();
- time += MS_PER_HOUR - mod$1(
- time + (this._isUTC ? 0 : this.utcOffset() * MS_PER_MINUTE),
- MS_PER_HOUR
- ) - 1;
- break;
- case "minute":
- time = this._d.valueOf();
- time += MS_PER_MINUTE - mod$1(time, MS_PER_MINUTE) - 1;
- break;
- case "second":
- time = this._d.valueOf();
- time += MS_PER_SECOND - mod$1(time, MS_PER_SECOND) - 1;
- break;
- }
- this._d.setTime(time);
- hooks.updateOffset(this, true);
- return this;
- }
- function valueOf() {
- return this._d.valueOf() - (this._offset || 0) * 6e4;
- }
- function unix() {
- return Math.floor(this.valueOf() / 1e3);
- }
- function toDate() {
- return new Date(this.valueOf());
- }
- function toArray() {
- var m = this;
- return [
- m.year(),
- m.month(),
- m.date(),
- m.hour(),
- m.minute(),
- m.second(),
- m.millisecond()
- ];
- }
- function toObject() {
- var m = this;
- return {
- years: m.year(),
- months: m.month(),
- date: m.date(),
- hours: m.hours(),
- minutes: m.minutes(),
- seconds: m.seconds(),
- milliseconds: m.milliseconds()
- };
- }
- function toJSON() {
- return this.isValid() ? this.toISOString() : null;
- }
- function isValid$2() {
- return isValid(this);
- }
- function parsingFlags() {
- return extend({}, getParsingFlags(this));
- }
- function invalidAt() {
- return getParsingFlags(this).overflow;
- }
- function creationData() {
- return {
- input: this._i,
- format: this._f,
- locale: this._locale,
- isUTC: this._isUTC,
- strict: this._strict
- };
- }
- addFormatToken("N", 0, 0, "eraAbbr");
- addFormatToken("NN", 0, 0, "eraAbbr");
- addFormatToken("NNN", 0, 0, "eraAbbr");
- addFormatToken("NNNN", 0, 0, "eraName");
- addFormatToken("NNNNN", 0, 0, "eraNarrow");
- addFormatToken("y", ["y", 1], "yo", "eraYear");
- addFormatToken("y", ["yy", 2], 0, "eraYear");
- addFormatToken("y", ["yyy", 3], 0, "eraYear");
- addFormatToken("y", ["yyyy", 4], 0, "eraYear");
- addRegexToken("N", matchEraAbbr);
- addRegexToken("NN", matchEraAbbr);
- addRegexToken("NNN", matchEraAbbr);
- addRegexToken("NNNN", matchEraName);
- addRegexToken("NNNNN", matchEraNarrow);
- addParseToken(
- ["N", "NN", "NNN", "NNNN", "NNNNN"],
- function(input, array3, config2, token2) {
- var era = config2._locale.erasParse(input, token2, config2._strict);
- if (era) {
- getParsingFlags(config2).era = era;
- } else {
- getParsingFlags(config2).invalidEra = input;
- }
- }
- );
- addRegexToken("y", matchUnsigned);
- addRegexToken("yy", matchUnsigned);
- addRegexToken("yyy", matchUnsigned);
- addRegexToken("yyyy", matchUnsigned);
- addRegexToken("yo", matchEraYearOrdinal);
- addParseToken(["y", "yy", "yyy", "yyyy"], YEAR);
- addParseToken(["yo"], function(input, array3, config2, token2) {
- var match;
- if (config2._locale._eraYearOrdinalRegex) {
- match = input.match(config2._locale._eraYearOrdinalRegex);
- }
- if (config2._locale.eraYearOrdinalParse) {
- array3[YEAR] = config2._locale.eraYearOrdinalParse(input, match);
- } else {
- array3[YEAR] = parseInt(input, 10);
- }
- });
- function localeEras(m, format2) {
- var i, l, date3, eras = this._eras || getLocale("en")._eras;
- for (i = 0, l = eras.length; i < l; ++i) {
- switch (typeof eras[i].since) {
- case "string":
- date3 = hooks(eras[i].since).startOf("day");
- eras[i].since = date3.valueOf();
- break;
- }
- switch (typeof eras[i].until) {
- case "undefined":
- eras[i].until = Infinity;
- break;
- case "string":
- date3 = hooks(eras[i].until).startOf("day").valueOf();
- eras[i].until = date3.valueOf();
- break;
- }
- }
- return eras;
- }
- function localeErasParse(eraName, format2, strict) {
- var i, l, eras = this.eras(), name, abbr, narrow;
- eraName = eraName.toUpperCase();
- for (i = 0, l = eras.length; i < l; ++i) {
- name = eras[i].name.toUpperCase();
- abbr = eras[i].abbr.toUpperCase();
- narrow = eras[i].narrow.toUpperCase();
- if (strict) {
- switch (format2) {
- case "N":
- case "NN":
- case "NNN":
- if (abbr === eraName) {
- return eras[i];
- }
- break;
- case "NNNN":
- if (name === eraName) {
- return eras[i];
- }
- break;
- case "NNNNN":
- if (narrow === eraName) {
- return eras[i];
- }
- break;
- }
- } else if ([name, abbr, narrow].indexOf(eraName) >= 0) {
- return eras[i];
- }
- }
- }
- function localeErasConvertYear(era, year) {
- var dir = era.since <= era.until ? 1 : -1;
- if (year === void 0) {
- return hooks(era.since).year();
- } else {
- return hooks(era.since).year() + (year - era.offset) * dir;
- }
- }
- function getEraName() {
- var i, l, val, eras = this.localeData().eras();
- for (i = 0, l = eras.length; i < l; ++i) {
- val = this.clone().startOf("day").valueOf();
- if (eras[i].since <= val && val <= eras[i].until) {
- return eras[i].name;
- }
- if (eras[i].until <= val && val <= eras[i].since) {
- return eras[i].name;
- }
- }
- return "";
- }
- function getEraNarrow() {
- var i, l, val, eras = this.localeData().eras();
- for (i = 0, l = eras.length; i < l; ++i) {
- val = this.clone().startOf("day").valueOf();
- if (eras[i].since <= val && val <= eras[i].until) {
- return eras[i].narrow;
- }
- if (eras[i].until <= val && val <= eras[i].since) {
- return eras[i].narrow;
- }
- }
- return "";
- }
- function getEraAbbr() {
- var i, l, val, eras = this.localeData().eras();
- for (i = 0, l = eras.length; i < l; ++i) {
- val = this.clone().startOf("day").valueOf();
- if (eras[i].since <= val && val <= eras[i].until) {
- return eras[i].abbr;
- }
- if (eras[i].until <= val && val <= eras[i].since) {
- return eras[i].abbr;
- }
- }
- return "";
- }
- function getEraYear() {
- var i, l, dir, val, eras = this.localeData().eras();
- for (i = 0, l = eras.length; i < l; ++i) {
- dir = eras[i].since <= eras[i].until ? 1 : -1;
- val = this.clone().startOf("day").valueOf();
- if (eras[i].since <= val && val <= eras[i].until || eras[i].until <= val && val <= eras[i].since) {
- return (this.year() - hooks(eras[i].since).year()) * dir + eras[i].offset;
- }
- }
- return this.year();
- }
- function erasNameRegex(isStrict) {
- if (!hasOwnProp(this, "_erasNameRegex")) {
- computeErasParse.call(this);
- }
- return isStrict ? this._erasNameRegex : this._erasRegex;
- }
- function erasAbbrRegex(isStrict) {
- if (!hasOwnProp(this, "_erasAbbrRegex")) {
- computeErasParse.call(this);
- }
- return isStrict ? this._erasAbbrRegex : this._erasRegex;
- }
- function erasNarrowRegex(isStrict) {
- if (!hasOwnProp(this, "_erasNarrowRegex")) {
- computeErasParse.call(this);
- }
- return isStrict ? this._erasNarrowRegex : this._erasRegex;
- }
- function matchEraAbbr(isStrict, locale2) {
- return locale2.erasAbbrRegex(isStrict);
- }
- function matchEraName(isStrict, locale2) {
- return locale2.erasNameRegex(isStrict);
- }
- function matchEraNarrow(isStrict, locale2) {
- return locale2.erasNarrowRegex(isStrict);
- }
- function matchEraYearOrdinal(isStrict, locale2) {
- return locale2._eraYearOrdinalRegex || matchUnsigned;
- }
- function computeErasParse() {
- var abbrPieces = [], namePieces = [], narrowPieces = [], mixedPieces = [], i, l, erasName, erasAbbr, erasNarrow, eras = this.eras();
- for (i = 0, l = eras.length; i < l; ++i) {
- erasName = regexEscape(eras[i].name);
- erasAbbr = regexEscape(eras[i].abbr);
- erasNarrow = regexEscape(eras[i].narrow);
- namePieces.push(erasName);
- abbrPieces.push(erasAbbr);
- narrowPieces.push(erasNarrow);
- mixedPieces.push(erasName);
- mixedPieces.push(erasAbbr);
- mixedPieces.push(erasNarrow);
- }
- this._erasRegex = new RegExp("^(" + mixedPieces.join("|") + ")", "i");
- this._erasNameRegex = new RegExp("^(" + namePieces.join("|") + ")", "i");
- this._erasAbbrRegex = new RegExp("^(" + abbrPieces.join("|") + ")", "i");
- this._erasNarrowRegex = new RegExp(
- "^(" + narrowPieces.join("|") + ")",
- "i"
- );
- }
- addFormatToken(0, ["gg", 2], 0, function() {
- return this.weekYear() % 100;
- });
- addFormatToken(0, ["GG", 2], 0, function() {
- return this.isoWeekYear() % 100;
- });
- function addWeekYearFormatToken(token2, getter) {
- addFormatToken(0, [token2, token2.length], 0, getter);
- }
- addWeekYearFormatToken("gggg", "weekYear");
- addWeekYearFormatToken("ggggg", "weekYear");
- addWeekYearFormatToken("GGGG", "isoWeekYear");
- addWeekYearFormatToken("GGGGG", "isoWeekYear");
- addRegexToken("G", matchSigned);
- addRegexToken("g", matchSigned);
- addRegexToken("GG", match1to2, match2);
- addRegexToken("gg", match1to2, match2);
- addRegexToken("GGGG", match1to4, match4);
- addRegexToken("gggg", match1to4, match4);
- addRegexToken("GGGGG", match1to6, match6);
- addRegexToken("ggggg", match1to6, match6);
- addWeekParseToken(
- ["gggg", "ggggg", "GGGG", "GGGGG"],
- function(input, week, config2, token2) {
- week[token2.substr(0, 2)] = toInt(input);
- }
- );
- addWeekParseToken(["gg", "GG"], function(input, week, config2, token2) {
- week[token2] = hooks.parseTwoDigitYear(input);
- });
- function getSetWeekYear(input) {
- return getSetWeekYearHelper.call(
- this,
- input,
- this.week(),
- this.weekday() + this.localeData()._week.dow,
- this.localeData()._week.dow,
- this.localeData()._week.doy
- );
- }
- function getSetISOWeekYear(input) {
- return getSetWeekYearHelper.call(
- this,
- input,
- this.isoWeek(),
- this.isoWeekday(),
- 1,
- 4
- );
- }
- function getISOWeeksInYear() {
- return weeksInYear(this.year(), 1, 4);
- }
- function getISOWeeksInISOWeekYear() {
- return weeksInYear(this.isoWeekYear(), 1, 4);
- }
- function getWeeksInYear() {
- var weekInfo = this.localeData()._week;
- return weeksInYear(this.year(), weekInfo.dow, weekInfo.doy);
- }
- function getWeeksInWeekYear() {
- var weekInfo = this.localeData()._week;
- return weeksInYear(this.weekYear(), weekInfo.dow, weekInfo.doy);
- }
- function getSetWeekYearHelper(input, week, weekday, dow, doy) {
- var weeksTarget;
- if (input == null) {
- return weekOfYear(this, dow, doy).year;
- } else {
- weeksTarget = weeksInYear(input, dow, doy);
- if (week > weeksTarget) {
- week = weeksTarget;
- }
- return setWeekAll.call(this, input, week, weekday, dow, doy);
- }
- }
- function setWeekAll(weekYear, week, weekday, dow, doy) {
- var dayOfYearData = dayOfYearFromWeeks(weekYear, week, weekday, dow, doy), date3 = createUTCDate(dayOfYearData.year, 0, dayOfYearData.dayOfYear);
- this.year(date3.getUTCFullYear());
- this.month(date3.getUTCMonth());
- this.date(date3.getUTCDate());
- return this;
- }
- addFormatToken("Q", 0, "Qo", "quarter");
- addRegexToken("Q", match1);
- addParseToken("Q", function(input, array3) {
- array3[MONTH] = (toInt(input) - 1) * 3;
- });
- function getSetQuarter(input) {
- return input == null ? Math.ceil((this.month() + 1) / 3) : this.month((input - 1) * 3 + this.month() % 3);
- }
- addFormatToken("D", ["DD", 2], "Do", "date");
- addRegexToken("D", match1to2, match1to2NoLeadingZero);
- addRegexToken("DD", match1to2, match2);
- addRegexToken("Do", function(isStrict, locale2) {
- return isStrict ? locale2._dayOfMonthOrdinalParse || locale2._ordinalParse : locale2._dayOfMonthOrdinalParseLenient;
- });
- addParseToken(["D", "DD"], DATE);
- addParseToken("Do", function(input, array3) {
- array3[DATE] = toInt(input.match(match1to2)[0]);
- });
- var getSetDayOfMonth = makeGetSet("Date", true);
- addFormatToken("DDD", ["DDDD", 3], "DDDo", "dayOfYear");
- addRegexToken("DDD", match1to3);
- addRegexToken("DDDD", match3);
- addParseToken(["DDD", "DDDD"], function(input, array3, config2) {
- config2._dayOfYear = toInt(input);
- });
- function getSetDayOfYear(input) {
- var dayOfYear = Math.round(
- (this.clone().startOf("day") - this.clone().startOf("year")) / 864e5
- ) + 1;
- return input == null ? dayOfYear : this.add(input - dayOfYear, "d");
- }
- addFormatToken("m", ["mm", 2], 0, "minute");
- addRegexToken("m", match1to2, match1to2HasZero);
- addRegexToken("mm", match1to2, match2);
- addParseToken(["m", "mm"], MINUTE);
- var getSetMinute = makeGetSet("Minutes", false);
- addFormatToken("s", ["ss", 2], 0, "second");
- addRegexToken("s", match1to2, match1to2HasZero);
- addRegexToken("ss", match1to2, match2);
- addParseToken(["s", "ss"], SECOND);
- var getSetSecond = makeGetSet("Seconds", false);
- addFormatToken("S", 0, 0, function() {
- return ~~(this.millisecond() / 100);
- });
- addFormatToken(0, ["SS", 2], 0, function() {
- return ~~(this.millisecond() / 10);
- });
- addFormatToken(0, ["SSS", 3], 0, "millisecond");
- addFormatToken(0, ["SSSS", 4], 0, function() {
- return this.millisecond() * 10;
- });
- addFormatToken(0, ["SSSSS", 5], 0, function() {
- return this.millisecond() * 100;
- });
- addFormatToken(0, ["SSSSSS", 6], 0, function() {
- return this.millisecond() * 1e3;
- });
- addFormatToken(0, ["SSSSSSS", 7], 0, function() {
- return this.millisecond() * 1e4;
- });
- addFormatToken(0, ["SSSSSSSS", 8], 0, function() {
- return this.millisecond() * 1e5;
- });
- addFormatToken(0, ["SSSSSSSSS", 9], 0, function() {
- return this.millisecond() * 1e6;
- });
- addRegexToken("S", match1to3, match1);
- addRegexToken("SS", match1to3, match2);
- addRegexToken("SSS", match1to3, match3);
- var token, getSetMillisecond;
- for (token = "SSSS"; token.length <= 9; token += "S") {
- addRegexToken(token, matchUnsigned);
- }
- function parseMs(input, array3) {
- array3[MILLISECOND] = toInt(("0." + input) * 1e3);
- }
- for (token = "S"; token.length <= 9; token += "S") {
- addParseToken(token, parseMs);
- }
- getSetMillisecond = makeGetSet("Milliseconds", false);
- addFormatToken("z", 0, 0, "zoneAbbr");
- addFormatToken("zz", 0, 0, "zoneName");
- function getZoneAbbr() {
- return this._isUTC ? "UTC" : "";
- }
- function getZoneName() {
- return this._isUTC ? "Coordinated Universal Time" : "";
- }
- var proto = Moment.prototype;
- proto.add = add;
- proto.calendar = calendar$1;
- proto.clone = clone;
- proto.diff = diff;
- proto.endOf = endOf;
- proto.format = format$1;
- proto.from = from;
- proto.fromNow = fromNow;
- proto.to = to;
- proto.toNow = toNow;
- proto.get = stringGet;
- proto.invalidAt = invalidAt;
- proto.isAfter = isAfter;
- proto.isBefore = isBefore;
- proto.isBetween = isBetween;
- proto.isSame = isSame;
- proto.isSameOrAfter = isSameOrAfter;
- proto.isSameOrBefore = isSameOrBefore;
- proto.isValid = isValid$2;
- proto.lang = lang;
- proto.locale = locale;
- proto.localeData = localeData;
- proto.max = prototypeMax;
- proto.min = prototypeMin;
- proto.parsingFlags = parsingFlags;
- proto.set = stringSet;
- proto.startOf = startOf;
- proto.subtract = subtract;
- proto.toArray = toArray;
- proto.toObject = toObject;
- proto.toDate = toDate;
- proto.toISOString = toISOString;
- proto.inspect = inspect;
- if (typeof Symbol !== "undefined" && Symbol.for != null) {
- proto[Symbol.for("nodejs.util.inspect.custom")] = function() {
- return "Moment<" + this.format() + ">";
- };
- }
- proto.toJSON = toJSON;
- proto.toString = toString;
- proto.unix = unix;
- proto.valueOf = valueOf;
- proto.creationData = creationData;
- proto.eraName = getEraName;
- proto.eraNarrow = getEraNarrow;
- proto.eraAbbr = getEraAbbr;
- proto.eraYear = getEraYear;
- proto.year = getSetYear;
- proto.isLeapYear = getIsLeapYear;
- proto.weekYear = getSetWeekYear;
- proto.isoWeekYear = getSetISOWeekYear;
- proto.quarter = proto.quarters = getSetQuarter;
- proto.month = getSetMonth;
- proto.daysInMonth = getDaysInMonth;
- proto.week = proto.weeks = getSetWeek;
- proto.isoWeek = proto.isoWeeks = getSetISOWeek;
- proto.weeksInYear = getWeeksInYear;
- proto.weeksInWeekYear = getWeeksInWeekYear;
- proto.isoWeeksInYear = getISOWeeksInYear;
- proto.isoWeeksInISOWeekYear = getISOWeeksInISOWeekYear;
- proto.date = getSetDayOfMonth;
- proto.day = proto.days = getSetDayOfWeek;
- proto.weekday = getSetLocaleDayOfWeek;
- proto.isoWeekday = getSetISODayOfWeek;
- proto.dayOfYear = getSetDayOfYear;
- proto.hour = proto.hours = getSetHour;
- proto.minute = proto.minutes = getSetMinute;
- proto.second = proto.seconds = getSetSecond;
- proto.millisecond = proto.milliseconds = getSetMillisecond;
- proto.utcOffset = getSetOffset;
- proto.utc = setOffsetToUTC;
- proto.local = setOffsetToLocal;
- proto.parseZone = setOffsetToParsedOffset;
- proto.hasAlignedHourOffset = hasAlignedHourOffset;
- proto.isDST = isDaylightSavingTime;
- proto.isLocal = isLocal;
- proto.isUtcOffset = isUtcOffset;
- proto.isUtc = isUtc;
- proto.isUTC = isUtc;
- proto.zoneAbbr = getZoneAbbr;
- proto.zoneName = getZoneName;
- proto.dates = deprecate(
- "dates accessor is deprecated. Use date instead.",
- getSetDayOfMonth
- );
- proto.months = deprecate(
- "months accessor is deprecated. Use month instead",
- getSetMonth
- );
- proto.years = deprecate(
- "years accessor is deprecated. Use year instead",
- getSetYear
- );
- proto.zone = deprecate(
- "moment().zone is deprecated, use moment().utcOffset instead. http://momentjs.com/guides/#/warnings/zone/",
- getSetZone
- );
- proto.isDSTShifted = deprecate(
- "isDSTShifted is deprecated. See http://momentjs.com/guides/#/warnings/dst-shifted/ for more information",
- isDaylightSavingTimeShifted
- );
- function createUnix(input) {
- return createLocal(input * 1e3);
- }
- function createInZone() {
- return createLocal.apply(null, arguments).parseZone();
- }
- function preParsePostFormat(string2) {
- return string2;
- }
- var proto$1 = Locale.prototype;
- proto$1.calendar = calendar;
- proto$1.longDateFormat = longDateFormat;
- proto$1.invalidDate = invalidDate;
- proto$1.ordinal = ordinal;
- proto$1.preparse = preParsePostFormat;
- proto$1.postformat = preParsePostFormat;
- proto$1.relativeTime = relativeTime;
- proto$1.pastFuture = pastFuture;
- proto$1.set = set;
- proto$1.eras = localeEras;
- proto$1.erasParse = localeErasParse;
- proto$1.erasConvertYear = localeErasConvertYear;
- proto$1.erasAbbrRegex = erasAbbrRegex;
- proto$1.erasNameRegex = erasNameRegex;
- proto$1.erasNarrowRegex = erasNarrowRegex;
- proto$1.months = localeMonths;
- proto$1.monthsShort = localeMonthsShort;
- proto$1.monthsParse = localeMonthsParse;
- proto$1.monthsRegex = monthsRegex;
- proto$1.monthsShortRegex = monthsShortRegex;
- proto$1.week = localeWeek;
- proto$1.firstDayOfYear = localeFirstDayOfYear;
- proto$1.firstDayOfWeek = localeFirstDayOfWeek;
- proto$1.weekdays = localeWeekdays;
- proto$1.weekdaysMin = localeWeekdaysMin;
- proto$1.weekdaysShort = localeWeekdaysShort;
- proto$1.weekdaysParse = localeWeekdaysParse;
- proto$1.weekdaysRegex = weekdaysRegex;
- proto$1.weekdaysShortRegex = weekdaysShortRegex;
- proto$1.weekdaysMinRegex = weekdaysMinRegex;
- proto$1.isPM = localeIsPM;
- proto$1.meridiem = localeMeridiem;
- function get$1(format2, index2, field, setter) {
- var locale2 = getLocale(), utc = createUTC().set(setter, index2);
- return locale2[field](utc, format2);
- }
- function listMonthsImpl(format2, index2, field) {
- if (isNumber(format2)) {
- index2 = format2;
- format2 = void 0;
- }
- format2 = format2 || "";
- if (index2 != null) {
- return get$1(format2, index2, field, "month");
- }
- var i, out = [];
- for (i = 0; i < 12; i++) {
- out[i] = get$1(format2, i, field, "month");
- }
- return out;
- }
- function listWeekdaysImpl(localeSorted, format2, index2, field) {
- if (typeof localeSorted === "boolean") {
- if (isNumber(format2)) {
- index2 = format2;
- format2 = void 0;
- }
- format2 = format2 || "";
- } else {
- format2 = localeSorted;
- index2 = format2;
- localeSorted = false;
- if (isNumber(format2)) {
- index2 = format2;
- format2 = void 0;
- }
- format2 = format2 || "";
- }
- var locale2 = getLocale(), shift = localeSorted ? locale2._week.dow : 0, i, out = [];
- if (index2 != null) {
- return get$1(format2, (index2 + shift) % 7, field, "day");
- }
- for (i = 0; i < 7; i++) {
- out[i] = get$1(format2, (i + shift) % 7, field, "day");
- }
- return out;
- }
- function listMonths(format2, index2) {
- return listMonthsImpl(format2, index2, "months");
- }
- function listMonthsShort(format2, index2) {
- return listMonthsImpl(format2, index2, "monthsShort");
- }
- function listWeekdays(localeSorted, format2, index2) {
- return listWeekdaysImpl(localeSorted, format2, index2, "weekdays");
- }
- function listWeekdaysShort(localeSorted, format2, index2) {
- return listWeekdaysImpl(localeSorted, format2, index2, "weekdaysShort");
- }
- function listWeekdaysMin(localeSorted, format2, index2) {
- return listWeekdaysImpl(localeSorted, format2, index2, "weekdaysMin");
- }
- getSetGlobalLocale("en", {
- eras: [
- {
- since: "0001-01-01",
- until: Infinity,
- offset: 1,
- name: "Anno Domini",
- narrow: "AD",
- abbr: "AD"
- },
- {
- since: "0000-12-31",
- until: -Infinity,
- offset: 1,
- name: "Before Christ",
- narrow: "BC",
- abbr: "BC"
- }
- ],
- dayOfMonthOrdinalParse: /\d{1,2}(th|st|nd|rd)/,
- ordinal: function(number3) {
- var b = number3 % 10, output = toInt(number3 % 100 / 10) === 1 ? "th" : b === 1 ? "st" : b === 2 ? "nd" : b === 3 ? "rd" : "th";
- return number3 + output;
- }
- });
- hooks.lang = deprecate(
- "moment.lang is deprecated. Use moment.locale instead.",
- getSetGlobalLocale
- );
- hooks.langData = deprecate(
- "moment.langData is deprecated. Use moment.localeData instead.",
- getLocale
- );
- var mathAbs = Math.abs;
- function abs() {
- var data = this._data;
- this._milliseconds = mathAbs(this._milliseconds);
- this._days = mathAbs(this._days);
- this._months = mathAbs(this._months);
- data.milliseconds = mathAbs(data.milliseconds);
- data.seconds = mathAbs(data.seconds);
- data.minutes = mathAbs(data.minutes);
- data.hours = mathAbs(data.hours);
- data.months = mathAbs(data.months);
- data.years = mathAbs(data.years);
- return this;
- }
- function addSubtract$1(duration, input, value2, direction) {
- var other = createDuration(input, value2);
- duration._milliseconds += direction * other._milliseconds;
- duration._days += direction * other._days;
- duration._months += direction * other._months;
- return duration._bubble();
- }
- function add$1(input, value2) {
- return addSubtract$1(this, input, value2, 1);
- }
- function subtract$1(input, value2) {
- return addSubtract$1(this, input, value2, -1);
- }
- function absCeil(number3) {
- if (number3 < 0) {
- return Math.floor(number3);
- } else {
- return Math.ceil(number3);
- }
- }
- function bubble() {
- var milliseconds2 = this._milliseconds, days2 = this._days, months2 = this._months, data = this._data, seconds2, minutes2, hours2, years2, monthsFromDays;
- if (!(milliseconds2 >= 0 && days2 >= 0 && months2 >= 0 || milliseconds2 <= 0 && days2 <= 0 && months2 <= 0)) {
- milliseconds2 += absCeil(monthsToDays(months2) + days2) * 864e5;
- days2 = 0;
- months2 = 0;
- }
- data.milliseconds = milliseconds2 % 1e3;
- seconds2 = absFloor(milliseconds2 / 1e3);
- data.seconds = seconds2 % 60;
- minutes2 = absFloor(seconds2 / 60);
- data.minutes = minutes2 % 60;
- hours2 = absFloor(minutes2 / 60);
- data.hours = hours2 % 24;
- days2 += absFloor(hours2 / 24);
- monthsFromDays = absFloor(daysToMonths(days2));
- months2 += monthsFromDays;
- days2 -= absCeil(monthsToDays(monthsFromDays));
- years2 = absFloor(months2 / 12);
- months2 %= 12;
- data.days = days2;
- data.months = months2;
- data.years = years2;
- return this;
- }
- function daysToMonths(days2) {
- return days2 * 4800 / 146097;
- }
- function monthsToDays(months2) {
- return months2 * 146097 / 4800;
- }
- function as(units) {
- if (!this.isValid()) {
- return NaN;
- }
- var days2, months2, milliseconds2 = this._milliseconds;
- units = normalizeUnits(units);
- if (units === "month" || units === "quarter" || units === "year") {
- days2 = this._days + milliseconds2 / 864e5;
- months2 = this._months + daysToMonths(days2);
- switch (units) {
- case "month":
- return months2;
- case "quarter":
- return months2 / 3;
- case "year":
- return months2 / 12;
- }
- } else {
- days2 = this._days + Math.round(monthsToDays(this._months));
- switch (units) {
- case "week":
- return days2 / 7 + milliseconds2 / 6048e5;
- case "day":
- return days2 + milliseconds2 / 864e5;
- case "hour":
- return days2 * 24 + milliseconds2 / 36e5;
- case "minute":
- return days2 * 1440 + milliseconds2 / 6e4;
- case "second":
- return days2 * 86400 + milliseconds2 / 1e3;
- case "millisecond":
- return Math.floor(days2 * 864e5) + milliseconds2;
- default:
- throw new Error("Unknown unit " + units);
- }
- }
- }
- function makeAs(alias) {
- return function() {
- return this.as(alias);
- };
- }
- var asMilliseconds = makeAs("ms"), asSeconds = makeAs("s"), asMinutes = makeAs("m"), asHours = makeAs("h"), asDays = makeAs("d"), asWeeks = makeAs("w"), asMonths = makeAs("M"), asQuarters = makeAs("Q"), asYears = makeAs("y"), valueOf$1 = asMilliseconds;
- function clone$1() {
- return createDuration(this);
- }
- function get$2(units) {
- units = normalizeUnits(units);
- return this.isValid() ? this[units + "s"]() : NaN;
- }
- function makeGetter(name) {
- return function() {
- return this.isValid() ? this._data[name] : NaN;
- };
- }
- var milliseconds = makeGetter("milliseconds"), seconds = makeGetter("seconds"), minutes = makeGetter("minutes"), hours = makeGetter("hours"), days = makeGetter("days"), months = makeGetter("months"), years = makeGetter("years");
- function weeks() {
- return absFloor(this.days() / 7);
- }
- var round = Math.round, thresholds = {
- ss: 44,
- // a few seconds to seconds
- s: 45,
- // seconds to minute
- m: 45,
- // minutes to hour
- h: 22,
- // hours to day
- d: 26,
- // days to month/week
- w: null,
- // weeks to month
- M: 11
- // months to year
- };
- function substituteTimeAgo(string2, number3, withoutSuffix, isFuture, locale2) {
- return locale2.relativeTime(number3 || 1, !!withoutSuffix, string2, isFuture);
- }
- function relativeTime$1(posNegDuration, withoutSuffix, thresholds2, locale2) {
- var duration = createDuration(posNegDuration).abs(), seconds2 = round(duration.as("s")), minutes2 = round(duration.as("m")), hours2 = round(duration.as("h")), days2 = round(duration.as("d")), months2 = round(duration.as("M")), weeks2 = round(duration.as("w")), years2 = round(duration.as("y")), a = seconds2 <= thresholds2.ss && ["s", seconds2] || seconds2 < thresholds2.s && ["ss", seconds2] || minutes2 <= 1 && ["m"] || minutes2 < thresholds2.m && ["mm", minutes2] || hours2 <= 1 && ["h"] || hours2 < thresholds2.h && ["hh", hours2] || days2 <= 1 && ["d"] || days2 < thresholds2.d && ["dd", days2];
- if (thresholds2.w != null) {
- a = a || weeks2 <= 1 && ["w"] || weeks2 < thresholds2.w && ["ww", weeks2];
- }
- a = a || months2 <= 1 && ["M"] || months2 < thresholds2.M && ["MM", months2] || years2 <= 1 && ["y"] || ["yy", years2];
- a[2] = withoutSuffix;
- a[3] = +posNegDuration > 0;
- a[4] = locale2;
- return substituteTimeAgo.apply(null, a);
- }
- function getSetRelativeTimeRounding(roundingFunction) {
- if (roundingFunction === void 0) {
- return round;
- }
- if (typeof roundingFunction === "function") {
- round = roundingFunction;
- return true;
- }
- return false;
- }
- function getSetRelativeTimeThreshold(threshold, limit) {
- if (thresholds[threshold] === void 0) {
- return false;
- }
- if (limit === void 0) {
- return thresholds[threshold];
- }
- thresholds[threshold] = limit;
- if (threshold === "s") {
- thresholds.ss = limit - 1;
- }
- return true;
- }
- function humanize(argWithSuffix, argThresholds) {
- if (!this.isValid()) {
- return this.localeData().invalidDate();
- }
- var withSuffix = false, th = thresholds, locale2, output;
- if (typeof argWithSuffix === "object") {
- argThresholds = argWithSuffix;
- argWithSuffix = false;
- }
- if (typeof argWithSuffix === "boolean") {
- withSuffix = argWithSuffix;
- }
- if (typeof argThresholds === "object") {
- th = Object.assign({}, thresholds, argThresholds);
- if (argThresholds.s != null && argThresholds.ss == null) {
- th.ss = argThresholds.s - 1;
- }
- }
- locale2 = this.localeData();
- output = relativeTime$1(this, !withSuffix, th, locale2);
- if (withSuffix) {
- output = locale2.pastFuture(+this, output);
- }
- return locale2.postformat(output);
- }
- var abs$1 = Math.abs;
- function sign(x) {
- return (x > 0) - (x < 0) || +x;
- }
- function toISOString$1() {
- if (!this.isValid()) {
- return this.localeData().invalidDate();
- }
- var seconds2 = abs$1(this._milliseconds) / 1e3, days2 = abs$1(this._days), months2 = abs$1(this._months), minutes2, hours2, years2, s2, total = this.asSeconds(), totalSign, ymSign, daysSign, hmsSign;
- if (!total) {
- return "P0D";
- }
- minutes2 = absFloor(seconds2 / 60);
- hours2 = absFloor(minutes2 / 60);
- seconds2 %= 60;
- minutes2 %= 60;
- years2 = absFloor(months2 / 12);
- months2 %= 12;
- s2 = seconds2 ? seconds2.toFixed(3).replace(/\.?0+$/, "") : "";
- totalSign = total < 0 ? "-" : "";
- ymSign = sign(this._months) !== sign(total) ? "-" : "";
- daysSign = sign(this._days) !== sign(total) ? "-" : "";
- hmsSign = sign(this._milliseconds) !== sign(total) ? "-" : "";
- return totalSign + "P" + (years2 ? ymSign + years2 + "Y" : "") + (months2 ? ymSign + months2 + "M" : "") + (days2 ? daysSign + days2 + "D" : "") + (hours2 || minutes2 || seconds2 ? "T" : "") + (hours2 ? hmsSign + hours2 + "H" : "") + (minutes2 ? hmsSign + minutes2 + "M" : "") + (seconds2 ? hmsSign + s2 + "S" : "");
- }
- var proto$2 = Duration.prototype;
- proto$2.isValid = isValid$1;
- proto$2.abs = abs;
- proto$2.add = add$1;
- proto$2.subtract = subtract$1;
- proto$2.as = as;
- proto$2.asMilliseconds = asMilliseconds;
- proto$2.asSeconds = asSeconds;
- proto$2.asMinutes = asMinutes;
- proto$2.asHours = asHours;
- proto$2.asDays = asDays;
- proto$2.asWeeks = asWeeks;
- proto$2.asMonths = asMonths;
- proto$2.asQuarters = asQuarters;
- proto$2.asYears = asYears;
- proto$2.valueOf = valueOf$1;
- proto$2._bubble = bubble;
- proto$2.clone = clone$1;
- proto$2.get = get$2;
- proto$2.milliseconds = milliseconds;
- proto$2.seconds = seconds;
- proto$2.minutes = minutes;
- proto$2.hours = hours;
- proto$2.days = days;
- proto$2.weeks = weeks;
- proto$2.months = months;
- proto$2.years = years;
- proto$2.humanize = humanize;
- proto$2.toISOString = toISOString$1;
- proto$2.toString = toISOString$1;
- proto$2.toJSON = toISOString$1;
- proto$2.locale = locale;
- proto$2.localeData = localeData;
- proto$2.toIsoString = deprecate(
- "toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)",
- toISOString$1
- );
- proto$2.lang = lang;
- addFormatToken("X", 0, 0, "unix");
- addFormatToken("x", 0, 0, "valueOf");
- addRegexToken("x", matchSigned);
- addRegexToken("X", matchTimestamp);
- addParseToken("X", function(input, array3, config2) {
- config2._d = new Date(parseFloat(input) * 1e3);
- });
- addParseToken("x", function(input, array3, config2) {
- config2._d = new Date(toInt(input));
- });
- //! moment.js
- hooks.version = "2.30.1";
- setHookCallback(createLocal);
- hooks.fn = proto;
- hooks.min = min;
- hooks.max = max;
- hooks.now = now;
- hooks.utc = createUTC;
- hooks.unix = createUnix;
- hooks.months = listMonths;
- hooks.isDate = isDate;
- hooks.locale = getSetGlobalLocale;
- hooks.invalid = createInvalid;
- hooks.duration = createDuration;
- hooks.isMoment = isMoment;
- hooks.weekdays = listWeekdays;
- hooks.parseZone = createInZone;
- hooks.localeData = getLocale;
- hooks.isDuration = isDuration;
- hooks.monthsShort = listMonthsShort;
- hooks.weekdaysMin = listWeekdaysMin;
- hooks.defineLocale = defineLocale;
- hooks.updateLocale = updateLocale;
- hooks.locales = listLocales;
- hooks.weekdaysShort = listWeekdaysShort;
- hooks.normalizeUnits = normalizeUnits;
- hooks.relativeTimeRounding = getSetRelativeTimeRounding;
- hooks.relativeTimeThreshold = getSetRelativeTimeThreshold;
- hooks.calendarFormat = getCalendarFormat;
- hooks.prototype = proto;
- hooks.HTML5_FMT = {
- DATETIME_LOCAL: "YYYY-MM-DDTHH:mm",
- // <input type="datetime-local" />
- DATETIME_LOCAL_SECONDS: "YYYY-MM-DDTHH:mm:ss",
- // <input type="datetime-local" step="1" />
- DATETIME_LOCAL_MS: "YYYY-MM-DDTHH:mm:ss.SSS",
- // <input type="datetime-local" step="0.001" />
- DATE: "YYYY-MM-DD",
- // <input type="date" />
- TIME: "HH:mm",
- // <input type="time" />
- TIME_SECONDS: "HH:mm:ss",
- // <input type="time" step="1" />
- TIME_MS: "HH:mm:ss.SSS",
- // <input type="time" step="0.001" />
- WEEK: "GGGG-[W]WW",
- // <input type="week" />
- MONTH: "YYYY-MM"
- // <input type="month" />
- };
- const props$m = {
- props: {
- // 搜索框形状,round-圆形,square-方形
- shape: {
- type: String,
- default: defprops.search.shape
- },
- // 搜索框背景色,默认值#f2f2f2
- bgColor: {
- type: String,
- default: defprops.search.bgColor
- },
- // 占位提示文字
- placeholder: {
- type: String,
- default: defprops.search.placeholder
- },
- // 是否启用清除控件
- clearabled: {
- type: Boolean,
- default: defprops.search.clearabled
- },
- // 是否自动聚焦
- focus: {
- type: Boolean,
- default: defprops.search.focus
- },
- // 是否在搜索框右侧显示取消按钮
- showAction: {
- type: Boolean,
- default: defprops.search.showAction
- },
- // 右边控件的样式
- actionStyle: {
- type: Object,
- default: defprops.search.actionStyle
- },
- // 取消按钮文字
- actionText: {
- type: String,
- default: defprops.search.actionText
- },
- // 输入框内容对齐方式,可选值为 left|center|right
- inputAlign: {
- type: String,
- default: defprops.search.inputAlign
- },
- // input输入框的样式,可以定义文字颜色,大小等,对象形式
- inputStyle: {
- type: Object,
- default: defprops.search.inputStyle
- },
- // 是否启用输入框
- disabled: {
- type: Boolean,
- default: defprops.search.disabled
- },
- // 边框颜色
- borderColor: {
- type: String,
- default: defprops.search.borderColor
- },
- // 搜索图标的颜色,默认同输入框字体颜色
- searchIconColor: {
- type: String,
- default: defprops.search.searchIconColor
- },
- // 输入框字体颜色
- color: {
- type: String,
- default: defprops.search.color
- },
- // placeholder的颜色
- placeholderColor: {
- type: String,
- default: defprops.search.placeholderColor
- },
- // 左边输入框的图标,可以为uView图标名称或图片路径
- searchIcon: {
- type: String,
- default: defprops.search.searchIcon
- },
- searchIconSize: {
- type: [Number, String],
- default: defprops.search.searchIconSize
- },
- // 组件与其他上下左右元素之间的距离,带单位的字符串形式,如"30px"、"30px 20px"等写法
- margin: {
- type: String,
- default: defprops.search.margin
- },
- // 开启showAction时,是否在input获取焦点时才显示
- animation: {
- type: Boolean,
- default: defprops.search.animation
- },
- // 输入框的初始化内容
- modelValue: {
- type: String,
- default: defprops.search.value
- },
- value: {
- type: String,
- default: defprops.search.value
- },
- // 输入框最大能输入的长度,-1为不限制长度(来自uniapp文档)
- maxlength: {
- type: [String, Number],
- default: defprops.search.maxlength
- },
- // 搜索框高度,单位px
- height: {
- type: [String, Number],
- default: defprops.search.height
- },
- // 搜索框左侧文本
- label: {
- type: [String, Number, null],
- default: defprops.search.label
- }
- }
- };
- const props$l = {
- props: {
- // 头像图片路径(不能为相对路径)
- src: {
- type: String,
- default: defprops.avatar.src
- },
- // 头像形状,circle-圆形,square-方形
- shape: {
- type: String,
- default: defprops.avatar.shape
- },
- // 头像尺寸
- size: {
- type: [String, Number],
- default: defprops.avatar.size
- },
- // 裁剪模式
- mode: {
- type: String,
- default: defprops.avatar.mode
- },
- // 显示的文字
- text: {
- type: String,
- default: defprops.avatar.text
- },
- // 背景色
- bgColor: {
- type: String,
- default: defprops.avatar.bgColor
- },
- // 文字颜色
- color: {
- type: String,
- default: defprops.avatar.color
- },
- // 文字大小
- fontSize: {
- type: [String, Number],
- default: defprops.avatar.fontSize
- },
- // 显示的图标
- icon: {
- type: String,
- default: defprops.avatar.icon
- },
- // 显示小程序头像,只对百度,微信,QQ小程序有效
- mpAvatar: {
- type: Boolean,
- default: defprops.avatar.mpAvatar
- },
- // 是否使用随机背景色
- randomBgColor: {
- type: Boolean,
- default: defprops.avatar.randomBgColor
- },
- // 加载失败的默认头像(组件有内置默认图片)
- defaultUrl: {
- type: String,
- default: defprops.avatar.defaultUrl
- },
- // 如果配置了randomBgColor为true,且配置了此值,则从默认的背景色数组中取出对应索引的颜色值,取值0-19之间
- colorIndex: {
- type: [String, Number],
- // 校验参数规则,索引在0-19之间
- validator(n2) {
- return index$1.$u.test.range(n2, [0, 19]) || n2 === "";
- },
- default: defprops.avatar.colorIndex
- },
- // 组件标识符
- name: {
- type: String,
- default: defprops.avatar.name
- }
- }
- };
- const icons = {
- "uicon-level": "",
- "uicon-column-line": "",
- "uicon-checkbox-mark": "",
- "uicon-folder": "",
- "uicon-movie": "",
- "uicon-star-fill": "",
- "uicon-star": "",
- "uicon-phone-fill": "",
- "uicon-phone": "",
- "uicon-apple-fill": "",
- "uicon-chrome-circle-fill": "",
- "uicon-backspace": "",
- "uicon-attach": "",
- "uicon-cut": "",
- "uicon-empty-car": "",
- "uicon-empty-coupon": "",
- "uicon-empty-address": "",
- "uicon-empty-favor": "",
- "uicon-empty-permission": "",
- "uicon-empty-news": "",
- "uicon-empty-search": "",
- "uicon-github-circle-fill": "",
- "uicon-rmb": "",
- "uicon-person-delete-fill": "",
- "uicon-reload": "",
- "uicon-order": "",
- "uicon-server-man": "",
- "uicon-search": "",
- "uicon-fingerprint": "",
- "uicon-more-dot-fill": "",
- "uicon-scan": "",
- "uicon-share-square": "",
- "uicon-map": "",
- "uicon-map-fill": "",
- "uicon-tags": "",
- "uicon-tags-fill": "",
- "uicon-bookmark-fill": "",
- "uicon-bookmark": "",
- "uicon-eye": "",
- "uicon-eye-fill": "",
- "uicon-mic": "",
- "uicon-mic-off": "",
- "uicon-calendar": "",
- "uicon-calendar-fill": "",
- "uicon-trash": "",
- "uicon-trash-fill": "",
- "uicon-play-left": "",
- "uicon-play-right": "",
- "uicon-minus": "",
- "uicon-plus": "",
- "uicon-info": "",
- "uicon-info-circle": "",
- "uicon-info-circle-fill": "",
- "uicon-question": "",
- "uicon-error": "",
- "uicon-close": "",
- "uicon-checkmark": "",
- "uicon-android-circle-fill": "",
- "uicon-android-fill": "",
- "uicon-ie": "",
- "uicon-IE-circle-fill": "",
- "uicon-google": "",
- "uicon-google-circle-fill": "",
- "uicon-setting-fill": "",
- "uicon-setting": "",
- "uicon-minus-square-fill": "",
- "uicon-plus-square-fill": "",
- "uicon-heart": "",
- "uicon-heart-fill": "",
- "uicon-camera": "",
- "uicon-camera-fill": "",
- "uicon-more-circle": "",
- "uicon-more-circle-fill": "",
- "uicon-chat": "",
- "uicon-chat-fill": "",
- "uicon-bag-fill": "",
- "uicon-bag": "",
- "uicon-error-circle-fill": "",
- "uicon-error-circle": "",
- "uicon-close-circle": "",
- "uicon-close-circle-fill": "",
- "uicon-checkmark-circle": "",
- "uicon-checkmark-circle-fill": "",
- "uicon-question-circle-fill": "",
- "uicon-question-circle": "",
- "uicon-share": "",
- "uicon-share-fill": "",
- "uicon-shopping-cart": "",
- "uicon-shopping-cart-fill": "",
- "uicon-bell": "",
- "uicon-bell-fill": "",
- "uicon-list": "",
- "uicon-list-dot": "",
- "uicon-zhihu": "",
- "uicon-zhihu-circle-fill": "",
- "uicon-zhifubao": "",
- "uicon-zhifubao-circle-fill": "",
- "uicon-weixin-circle-fill": "",
- "uicon-weixin-fill": "",
- "uicon-twitter-circle-fill": "",
- "uicon-twitter": "",
- "uicon-taobao-circle-fill": "",
- "uicon-taobao": "",
- "uicon-weibo-circle-fill": "",
- "uicon-weibo": "",
- "uicon-qq-fill": "",
- "uicon-qq-circle-fill": "",
- "uicon-moments-circel-fill": "",
- "uicon-moments": "",
- "uicon-qzone": "",
- "uicon-qzone-circle-fill": "",
- "uicon-baidu-circle-fill": "",
- "uicon-baidu": "",
- "uicon-facebook-circle-fill": "",
- "uicon-facebook": "",
- "uicon-car": "",
- "uicon-car-fill": "",
- "uicon-warning-fill": "",
- "uicon-warning": "",
- "uicon-clock-fill": "",
- "uicon-clock": "",
- "uicon-edit-pen": "",
- "uicon-edit-pen-fill": "",
- "uicon-email": "",
- "uicon-email-fill": "",
- "uicon-minus-circle": "",
- "uicon-minus-circle-fill": "",
- "uicon-plus-circle": "",
- "uicon-plus-circle-fill": "",
- "uicon-file-text": "",
- "uicon-file-text-fill": "",
- "uicon-pushpin": "",
- "uicon-pushpin-fill": "",
- "uicon-grid": "",
- "uicon-grid-fill": "",
- "uicon-play-circle": "",
- "uicon-play-circle-fill": "",
- "uicon-pause-circle-fill": "",
- "uicon-pause": "",
- "uicon-pause-circle": "",
- "uicon-eye-off": "",
- "uicon-eye-off-outline": "",
- "uicon-gift-fill": "",
- "uicon-gift": "",
- "uicon-rmb-circle-fill": "",
- "uicon-rmb-circle": "",
- "uicon-kefu-ermai": "",
- "uicon-server-fill": "",
- "uicon-coupon-fill": "",
- "uicon-coupon": "",
- "uicon-integral": "",
- "uicon-integral-fill": "",
- "uicon-home-fill": "",
- "uicon-home": "",
- "uicon-hourglass-half-fill": "",
- "uicon-hourglass": "",
- "uicon-account": "",
- "uicon-plus-people-fill": "",
- "uicon-minus-people-fill": "",
- "uicon-account-fill": "",
- "uicon-thumb-down-fill": "",
- "uicon-thumb-down": "",
- "uicon-thumb-up": "",
- "uicon-thumb-up-fill": "",
- "uicon-lock-fill": "",
- "uicon-lock-open": "",
- "uicon-lock-opened-fill": "",
- "uicon-lock": "",
- "uicon-red-packet-fill": "",
- "uicon-photo-fill": "",
- "uicon-photo": "",
- "uicon-volume-off-fill": "",
- "uicon-volume-off": "",
- "uicon-volume-fill": "",
- "uicon-volume": "",
- "uicon-red-packet": "",
- "uicon-download": "",
- "uicon-arrow-up-fill": "",
- "uicon-arrow-down-fill": "",
- "uicon-play-left-fill": "",
- "uicon-play-right-fill": "",
- "uicon-rewind-left-fill": "",
- "uicon-rewind-right-fill": "",
- "uicon-arrow-downward": "",
- "uicon-arrow-leftward": "",
- "uicon-arrow-rightward": "",
- "uicon-arrow-upward": "",
- "uicon-arrow-down": "",
- "uicon-arrow-right": "",
- "uicon-arrow-left": "",
- "uicon-arrow-up": "",
- "uicon-skip-back-left": "",
- "uicon-skip-forward-right": "",
- "uicon-rewind-right": "",
- "uicon-rewind-left": "",
- "uicon-arrow-right-double": "",
- "uicon-arrow-left-double": "",
- "uicon-wifi-off": "",
- "uicon-wifi": "",
- "uicon-empty-data": "",
- "uicon-empty-history": "",
- "uicon-empty-list": "",
- "uicon-empty-page": "",
- "uicon-empty-order": "",
- "uicon-man": "",
- "uicon-woman": "",
- "uicon-man-add": "",
- "uicon-man-add-fill": "",
- "uicon-man-delete": "",
- "uicon-man-delete-fill": "",
- "uicon-zh": "",
- "uicon-en": ""
- };
- const props$k = {
- props: {
- // 图标类名
- name: {
- type: String,
- default: defprops.icon.name
- },
- // 图标颜色,可接受主题色
- color: {
- type: String,
- default: defprops.icon.color
- },
- // 字体大小,单位px
- size: {
- type: [String, Number],
- default: defprops.icon.size
- },
- // 是否显示粗体
- bold: {
- type: Boolean,
- default: defprops.icon.bold
- },
- // 点击图标的时候传递事件出去的index(用于区分点击了哪一个)
- index: {
- type: [String, Number],
- default: defprops.icon.index
- },
- // 触摸图标时的类名
- hoverClass: {
- type: String,
- default: defprops.icon.hoverClass
- },
- // 自定义扩展前缀,方便用户扩展自己的图标库
- customPrefix: {
- type: String,
- default: defprops.icon.customPrefix
- },
- // 图标右边或者下面的文字
- label: {
- type: [String, Number],
- default: defprops.icon.label
- },
- // label的位置,只能右边或者下边
- labelPos: {
- type: String,
- default: defprops.icon.labelPos
- },
- // label的大小
- labelSize: {
- type: [String, Number],
- default: defprops.icon.labelSize
- },
- // label的颜色
- labelColor: {
- type: String,
- default: defprops.icon.labelColor
- },
- // label与图标的距离
- space: {
- type: [String, Number],
- default: defprops.icon.space
- },
- // 图片的mode
- imgMode: {
- type: String,
- default: defprops.icon.imgMode
- },
- // 用于显示图片小图标时,图片的宽度
- width: {
- type: [String, Number],
- default: defprops.icon.width
- },
- // 用于显示图片小图标时,图片的高度
- height: {
- type: [String, Number],
- default: defprops.icon.height
- },
- // 用于解决某些情况下,让图标垂直居中的用途
- top: {
- type: [String, Number],
- default: defprops.icon.top
- },
- // 是否阻止事件传播
- stop: {
- type: Boolean,
- default: defprops.icon.stop
- }
- }
- };
- const props$j = {
- props: {
- // 列表锚点文本内容
- text: {
- type: [String, Number],
- default: defprops.indexAnchor.text
- },
- // 列表锚点文字颜色
- color: {
- type: String,
- default: defprops.indexAnchor.color
- },
- // 列表锚点文字大小,单位默认px
- size: {
- type: [String, Number],
- default: defprops.indexAnchor.size
- },
- // 列表锚点背景颜色
- bgColor: {
- type: String,
- default: defprops.indexAnchor.bgColor
- },
- // 列表锚点高度,单位默认px
- height: {
- type: [String, Number],
- default: defprops.indexAnchor.height
- }
- }
- };
- const props$i = {
- props: {}
- };
- const props$h = {
- props: {
- // 右边锚点非激活的颜色
- inactiveColor: {
- type: String,
- default: defprops.indexList.inactiveColor
- },
- // 右边锚点激活的颜色
- activeColor: {
- type: String,
- default: defprops.indexList.activeColor
- },
- // 索引字符列表,数组形式
- indexList: {
- type: Array,
- default: defprops.indexList.indexList
- },
- // 是否开启锚点自动吸顶
- sticky: {
- type: Boolean,
- default: defprops.indexList.sticky
- },
- // 自定义导航栏的高度
- customNavHeight: {
- type: [String, Number],
- default: defprops.indexList.customNavHeight
- }
- }
- };
- const props$g = {
- props: {
- // 显示的内容,数组
- text: {
- type: [Array, String],
- default: defprops.noticeBar.text
- },
- // 通告滚动模式,row-横向滚动,column-竖向滚动
- direction: {
- type: String,
- default: defprops.noticeBar.direction
- },
- // direction = row时,是否使用步进形式滚动
- step: {
- type: Boolean,
- default: defprops.noticeBar.step
- },
- // 是否显示左侧的音量图标
- icon: {
- type: String,
- default: defprops.noticeBar.icon
- },
- // 通告模式,link-显示右箭头,closable-显示右侧关闭图标
- mode: {
- type: String,
- default: defprops.noticeBar.mode
- },
- // 文字颜色,各图标也会使用文字颜色
- color: {
- type: String,
- default: defprops.noticeBar.color
- },
- // 背景颜色
- bgColor: {
- type: String,
- default: defprops.noticeBar.bgColor
- },
- // 水平滚动时的滚动速度,即每秒滚动多少px(px),这有利于控制文字无论多少时,都能有一个恒定的速度
- speed: {
- type: [String, Number],
- default: defprops.noticeBar.speed
- },
- // 字体大小
- fontSize: {
- type: [String, Number],
- default: defprops.noticeBar.fontSize
- },
- // 滚动一个周期的时间长,单位ms
- duration: {
- type: [String, Number],
- default: defprops.noticeBar.duration
- },
- // 是否禁止用手滑动切换
- // 目前HX2.6.11,只支持App 2.5.5+、H5 2.5.5+、支付宝小程序、字节跳动小程序
- disableTouch: {
- type: Boolean,
- default: defprops.noticeBar.disableTouch
- },
- // 跳转的页面路径
- url: {
- type: String,
- default: defprops.noticeBar.url
- },
- // 页面跳转的类型
- linkType: {
- type: String,
- default: defprops.noticeBar.linkType
- }
- }
- };
- const props$f = {
- props: {
- // 是否虚线
- dashed: {
- type: Boolean,
- default: defprops.divider.dashed
- },
- // 是否细线
- hairline: {
- type: Boolean,
- default: defprops.divider.hairline
- },
- // 是否以点替代文字,优先于text字段起作用
- dot: {
- type: Boolean,
- default: defprops.divider.dot
- },
- // 内容文本的位置,left-左边,center-中间,right-右边
- textPosition: {
- type: String,
- default: defprops.divider.textPosition
- },
- // 文本内容
- text: {
- type: [String, Number],
- default: defprops.divider.text
- },
- // 文本大小
- textSize: {
- type: [String, Number],
- default: defprops.divider.textSize
- },
- // 文本颜色
- textColor: {
- type: String,
- default: defprops.divider.textColor
- },
- // 线条颜色
- lineColor: {
- type: String,
- default: defprops.divider.lineColor
- }
- }
- };
- const props$e = {
- props: {
- // input的label提示语
- label: {
- type: String,
- default: defprops.formItem.label
- },
- // 绑定的值
- prop: {
- type: String,
- default: defprops.formItem.prop
- },
- // 是否显示表单域的下划线边框
- borderBottom: {
- type: [String, Boolean],
- default: defprops.formItem.borderBottom
- },
- // label的宽度,单位px
- labelWidth: {
- type: [String, Number],
- default: defprops.formItem.labelWidth
- },
- // 右侧图标
- rightIcon: {
- type: String,
- default: defprops.formItem.rightIcon
- },
- // 左侧图标
- leftIcon: {
- type: String,
- default: defprops.formItem.leftIcon
- },
- // 是否显示左边的必填星号,只作显示用,具体校验必填的逻辑,请在rules中配置
- required: {
- type: Boolean,
- default: defprops.formItem.required
- },
- leftIconStyle: {
- type: [String, Object],
- default: defprops.formItem.leftIconStyle
- }
- }
- };
- const props$d = {
- props: {
- // 当前form的需要验证字段的集合
- model: {
- type: Object,
- default: defprops.form.model
- },
- // 验证规则
- rules: {
- type: [Object, Function, Array],
- default: defprops.form.rules
- },
- // 有错误时的提示方式,message-提示信息,toast-进行toast提示
- // border-bottom-下边框呈现红色,none-无提示
- errorType: {
- type: String,
- default: defprops.form.errorType
- },
- // 是否显示表单域的下划线边框
- borderBottom: {
- type: Boolean,
- default: defprops.form.borderBottom
- },
- // label的位置,left-左边,top-上边
- labelPosition: {
- type: String,
- default: defprops.form.labelPosition
- },
- // label的宽度,单位px
- labelWidth: {
- type: [String, Number],
- default: defprops.form.labelWidth
- },
- // lable字体的对齐方式
- labelAlign: {
- type: String,
- default: defprops.form.labelAlign
- },
- // lable的样式,对象形式
- labelStyle: {
- type: Object,
- default: defprops.form.labelStyle
- }
- }
- };
- const formatRegExp = /%[sdj%]/g;
- let warning = function warning2() {
- };
- if (typeof process !== "undefined" && process.env && true && typeof window !== "undefined" && typeof document !== "undefined") {
- warning = function warning3(type2, errors) {
- if (typeof console !== "undefined" && console.warn) {
- if (errors.every((e2) => typeof e2 === "string")) {
- console.warn(type2, errors);
- }
- }
- };
- }
- function convertFieldsError(errors) {
- if (!errors || !errors.length)
- return null;
- const fields = {};
- errors.forEach((error2) => {
- const { field } = error2;
- fields[field] = fields[field] || [];
- fields[field].push(error2);
- });
- return fields;
- }
- function format() {
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
- let i = 1;
- const f2 = args[0];
- const len = args.length;
- if (typeof f2 === "function") {
- return f2.apply(null, args.slice(1));
- }
- if (typeof f2 === "string") {
- let str = String(f2).replace(formatRegExp, (x) => {
- if (x === "%%") {
- return "%";
- }
- if (i >= len) {
- return x;
- }
- switch (x) {
- case "%s":
- return String(args[i++]);
- case "%d":
- return Number(args[i++]);
- case "%j":
- try {
- return JSON.stringify(args[i++]);
- } catch (_) {
- return "[Circular]";
- }
- break;
- default:
- return x;
- }
- });
- for (let arg = args[i]; i < len; arg = args[++i]) {
- str += ` ${arg}`;
- }
- return str;
- }
- return f2;
- }
- function isNativeStringType(type2) {
- return type2 === "string" || type2 === "url" || type2 === "hex" || type2 === "email" || type2 === "pattern";
- }
- function isEmptyValue(value2, type2) {
- if (value2 === void 0 || value2 === null) {
- return true;
- }
- if (type2 === "array" && Array.isArray(value2) && !value2.length) {
- return true;
- }
- if (isNativeStringType(type2) && typeof value2 === "string" && !value2) {
- return true;
- }
- return false;
- }
- function asyncParallelArray(arr, func2, callback) {
- const results = [];
- let total = 0;
- const arrLength = arr.length;
- function count(errors) {
- results.push.apply(results, errors);
- total++;
- if (total === arrLength) {
- callback(results);
- }
- }
- arr.forEach((a) => {
- func2(a, count);
- });
- }
- function asyncSerialArray(arr, func2, callback) {
- let index2 = 0;
- const arrLength = arr.length;
- function next(errors) {
- if (errors && errors.length) {
- callback(errors);
- return;
- }
- const original = index2;
- index2 += 1;
- if (original < arrLength) {
- func2(arr[original], next);
- } else {
- callback([]);
- }
- }
- next([]);
- }
- function flattenObjArr(objArr) {
- const ret = [];
- Object.keys(objArr).forEach((k) => {
- ret.push.apply(ret, objArr[k]);
- });
- return ret;
- }
- function asyncMap(objArr, option, func2, callback) {
- if (option.first) {
- const _pending = new Promise((resolve2, reject) => {
- const next = function next2(errors) {
- callback(errors);
- return errors.length ? reject({
- errors,
- fields: convertFieldsError(errors)
- }) : resolve2();
- };
- const flattenArr = flattenObjArr(objArr);
- asyncSerialArray(flattenArr, func2, next);
- });
- _pending.catch((e2) => e2);
- return _pending;
- }
- let firstFields = option.firstFields || [];
- if (firstFields === true) {
- firstFields = Object.keys(objArr);
- }
- const objArrKeys = Object.keys(objArr);
- const objArrLength = objArrKeys.length;
- let total = 0;
- const results = [];
- const pending = new Promise((resolve2, reject) => {
- const next = function next2(errors) {
- results.push.apply(results, errors);
- total++;
- if (total === objArrLength) {
- callback(results);
- return results.length ? reject({
- errors: results,
- fields: convertFieldsError(results)
- }) : resolve2();
- }
- };
- if (!objArrKeys.length) {
- callback(results);
- resolve2();
- }
- objArrKeys.forEach((key) => {
- const arr = objArr[key];
- if (firstFields.indexOf(key) !== -1) {
- asyncSerialArray(arr, func2, next);
- } else {
- asyncParallelArray(arr, func2, next);
- }
- });
- });
- pending.catch((e2) => e2);
- return pending;
- }
- function complementError(rule) {
- return function(oe) {
- if (oe && oe.message) {
- oe.field = oe.field || rule.fullField;
- return oe;
- }
- return {
- message: typeof oe === "function" ? oe() : oe,
- field: oe.field || rule.fullField
- };
- };
- }
- function deepMerge(target, source) {
- if (source) {
- for (const s2 in source) {
- if (source.hasOwnProperty(s2)) {
- const value2 = source[s2];
- if (typeof value2 === "object" && typeof target[s2] === "object") {
- target[s2] = { ...target[s2], ...value2 };
- } else {
- target[s2] = value2;
- }
- }
- }
- }
- return target;
- }
- function required(rule, value2, source, errors, options, type2) {
- if (rule.required && (!source.hasOwnProperty(rule.field) || isEmptyValue(value2, type2 || rule.type))) {
- errors.push(format(options.messages.required, rule.fullField));
- }
- }
- function whitespace(rule, value2, source, errors, options) {
- if (/^\s+$/.test(value2) || value2 === "") {
- errors.push(format(options.messages.whitespace, rule.fullField));
- }
- }
- const pattern = {
- // http://emailregex.com/
- email: /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,
- url: new RegExp(
- "^(?!mailto:)(?:(?:http|https|ftp)://|//)(?:\\S+(?::\\S*)?@)?(?:(?:(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}(?:\\.(?:[0-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))|(?:(?:[a-z\\u00a1-\\uffff0-9]+-*)*[a-z\\u00a1-\\uffff0-9]+)(?:\\.(?:[a-z\\u00a1-\\uffff0-9]+-*)*[a-z\\u00a1-\\uffff0-9]+)*(?:\\.(?:[a-z\\u00a1-\\uffff]{2,})))|localhost)(?::\\d{2,5})?(?:(/|\\?|#)[^\\s]*)?$",
- "i"
- ),
- hex: /^#?([a-f0-9]{6}|[a-f0-9]{3})$/i
- };
- var types = {
- integer: function integer(value2) {
- return /^(-)?\d+$/.test(value2);
- },
- float: function float(value2) {
- return /^(-)?\d+(\.\d+)?$/.test(value2);
- },
- array: function array(value2) {
- return Array.isArray(value2);
- },
- regexp: function regexp(value2) {
- if (value2 instanceof RegExp) {
- return true;
- }
- try {
- return !!new RegExp(value2);
- } catch (e2) {
- return false;
- }
- },
- date: function date(value2) {
- return typeof value2.getTime === "function" && typeof value2.getMonth === "function" && typeof value2.getYear === "function";
- },
- number: function number(value2) {
- if (isNaN(value2)) {
- return false;
- }
- return typeof +value2 === "number";
- },
- object: function object(value2) {
- return typeof value2 === "object" && !types.array(value2);
- },
- method: function method(value2) {
- return typeof value2 === "function";
- },
- email: function email2(value2) {
- return typeof value2 === "string" && !!value2.match(pattern.email) && value2.length < 255;
- },
- url: function url2(value2) {
- return typeof value2 === "string" && !!value2.match(pattern.url);
- },
- hex: function hex(value2) {
- return typeof value2 === "string" && !!value2.match(pattern.hex);
- }
- };
- function type(rule, value2, source, errors, options) {
- if (rule.required && value2 === void 0) {
- required(rule, value2, source, errors, options);
- return;
- }
- const custom = ["integer", "float", "array", "regexp", "object", "method", "email", "number", "date", "url", "hex"];
- const ruleType = rule.type;
- if (custom.indexOf(ruleType) > -1) {
- if (!types[ruleType](value2)) {
- errors.push(format(options.messages.types[ruleType], rule.fullField, rule.type));
- }
- } else if (ruleType && typeof value2 !== rule.type) {
- errors.push(format(options.messages.types[ruleType], rule.fullField, rule.type));
- }
- }
- function range(rule, value2, source, errors, options) {
- const len = typeof rule.len === "number";
- const min2 = typeof rule.min === "number";
- const max2 = typeof rule.max === "number";
- const spRegexp = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g;
- let val = value2;
- let key = null;
- const num = typeof value2 === "number";
- const str = typeof value2 === "string";
- const arr = Array.isArray(value2);
- if (num) {
- key = "number";
- } else if (str) {
- key = "string";
- } else if (arr) {
- key = "array";
- }
- if (!key) {
- return false;
- }
- if (arr) {
- val = value2.length;
- }
- if (str) {
- val = value2.replace(spRegexp, "_").length;
- }
- if (len) {
- if (val !== rule.len) {
- errors.push(format(options.messages[key].len, rule.fullField, rule.len));
- }
- } else if (min2 && !max2 && val < rule.min) {
- errors.push(format(options.messages[key].min, rule.fullField, rule.min));
- } else if (max2 && !min2 && val > rule.max) {
- errors.push(format(options.messages[key].max, rule.fullField, rule.max));
- } else if (min2 && max2 && (val < rule.min || val > rule.max)) {
- errors.push(format(options.messages[key].range, rule.fullField, rule.min, rule.max));
- }
- }
- const ENUM = "enum";
- function enumerable(rule, value2, source, errors, options) {
- rule[ENUM] = Array.isArray(rule[ENUM]) ? rule[ENUM] : [];
- if (rule[ENUM].indexOf(value2) === -1) {
- errors.push(format(options.messages[ENUM], rule.fullField, rule[ENUM].join(", ")));
- }
- }
- function pattern$1(rule, value2, source, errors, options) {
- if (rule.pattern) {
- if (rule.pattern instanceof RegExp) {
- rule.pattern.lastIndex = 0;
- if (!rule.pattern.test(value2)) {
- errors.push(format(options.messages.pattern.mismatch, rule.fullField, value2, rule.pattern));
- }
- } else if (typeof rule.pattern === "string") {
- const _pattern = new RegExp(rule.pattern);
- if (!_pattern.test(value2)) {
- errors.push(format(options.messages.pattern.mismatch, rule.fullField, value2, rule.pattern));
- }
- }
- }
- }
- const rules = {
- required,
- whitespace,
- type,
- range,
- enum: enumerable,
- pattern: pattern$1
- };
- function string(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2, "string") && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options, "string");
- if (!isEmptyValue(value2, "string")) {
- rules.type(rule, value2, source, errors, options);
- rules.range(rule, value2, source, errors, options);
- rules.pattern(rule, value2, source, errors, options);
- if (rule.whitespace === true) {
- rules.whitespace(rule, value2, source, errors, options);
- }
- }
- }
- callback(errors);
- }
- function method2(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2) && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options);
- if (value2 !== void 0) {
- rules.type(rule, value2, source, errors, options);
- }
- }
- callback(errors);
- }
- function number2(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (value2 === "") {
- value2 = void 0;
- }
- if (isEmptyValue(value2) && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options);
- if (value2 !== void 0) {
- rules.type(rule, value2, source, errors, options);
- rules.range(rule, value2, source, errors, options);
- }
- }
- callback(errors);
- }
- function _boolean(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2) && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options);
- if (value2 !== void 0) {
- rules.type(rule, value2, source, errors, options);
- }
- }
- callback(errors);
- }
- function regexp2(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2) && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options);
- if (!isEmptyValue(value2)) {
- rules.type(rule, value2, source, errors, options);
- }
- }
- callback(errors);
- }
- function integer2(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2) && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options);
- if (value2 !== void 0) {
- rules.type(rule, value2, source, errors, options);
- rules.range(rule, value2, source, errors, options);
- }
- }
- callback(errors);
- }
- function floatFn(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2) && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options);
- if (value2 !== void 0) {
- rules.type(rule, value2, source, errors, options);
- rules.range(rule, value2, source, errors, options);
- }
- }
- callback(errors);
- }
- function array2(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2, "array") && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options, "array");
- if (!isEmptyValue(value2, "array")) {
- rules.type(rule, value2, source, errors, options);
- rules.range(rule, value2, source, errors, options);
- }
- }
- callback(errors);
- }
- function object2(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2) && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options);
- if (value2 !== void 0) {
- rules.type(rule, value2, source, errors, options);
- }
- }
- callback(errors);
- }
- const ENUM$1 = "enum";
- function enumerable$1(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2) && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options);
- if (value2 !== void 0) {
- rules[ENUM$1](rule, value2, source, errors, options);
- }
- }
- callback(errors);
- }
- function pattern$2(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2, "string") && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options);
- if (!isEmptyValue(value2, "string")) {
- rules.pattern(rule, value2, source, errors, options);
- }
- }
- callback(errors);
- }
- function date2(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2) && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options);
- if (!isEmptyValue(value2)) {
- let dateObject;
- if (typeof value2 === "number") {
- dateObject = new Date(value2);
- } else {
- dateObject = value2;
- }
- rules.type(rule, dateObject, source, errors, options);
- if (dateObject) {
- rules.range(rule, dateObject.getTime(), source, errors, options);
- }
- }
- }
- callback(errors);
- }
- function required$1(rule, value2, callback, source, options) {
- const errors = [];
- const type2 = Array.isArray(value2) ? "array" : typeof value2;
- rules.required(rule, value2, source, errors, options, type2);
- callback(errors);
- }
- function type$1(rule, value2, callback, source, options) {
- const ruleType = rule.type;
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2, ruleType) && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options, ruleType);
- if (!isEmptyValue(value2, ruleType)) {
- rules.type(rule, value2, source, errors, options);
- }
- }
- callback(errors);
- }
- function any(rule, value2, callback, source, options) {
- const errors = [];
- const validate2 = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate2) {
- if (isEmptyValue(value2) && !rule.required) {
- return callback();
- }
- rules.required(rule, value2, source, errors, options);
- }
- callback(errors);
- }
- const validators = {
- string,
- method: method2,
- number: number2,
- boolean: _boolean,
- regexp: regexp2,
- integer: integer2,
- float: floatFn,
- array: array2,
- object: object2,
- enum: enumerable$1,
- pattern: pattern$2,
- date: date2,
- url: type$1,
- hex: type$1,
- email: type$1,
- required: required$1,
- any
- };
- function newMessages() {
- return {
- default: "Validation error on field %s",
- required: "%s is required",
- enum: "%s must be one of %s",
- whitespace: "%s cannot be empty",
- date: {
- format: "%s date %s is invalid for format %s",
- parse: "%s date could not be parsed, %s is invalid ",
- invalid: "%s date %s is invalid"
- },
- types: {
- string: "%s is not a %s",
- method: "%s is not a %s (function)",
- array: "%s is not an %s",
- object: "%s is not an %s",
- number: "%s is not a %s",
- date: "%s is not a %s",
- boolean: "%s is not a %s",
- integer: "%s is not an %s",
- float: "%s is not a %s",
- regexp: "%s is not a valid %s",
- email: "%s is not a valid %s",
- url: "%s is not a valid %s",
- hex: "%s is not a valid %s"
- },
- string: {
- len: "%s must be exactly %s characters",
- min: "%s must be at least %s characters",
- max: "%s cannot be longer than %s characters",
- range: "%s must be between %s and %s characters"
- },
- number: {
- len: "%s must equal %s",
- min: "%s cannot be less than %s",
- max: "%s cannot be greater than %s",
- range: "%s must be between %s and %s"
- },
- array: {
- len: "%s must be exactly %s in length",
- min: "%s cannot be less than %s in length",
- max: "%s cannot be greater than %s in length",
- range: "%s must be between %s and %s in length"
- },
- pattern: {
- mismatch: "%s value %s does not match pattern %s"
- },
- clone: function clone2() {
- const cloned = JSON.parse(JSON.stringify(this));
- cloned.clone = this.clone;
- return cloned;
- }
- };
- }
- const messages = newMessages();
- function Schema(descriptor) {
- this.rules = null;
- this._messages = messages;
- this.define(descriptor);
- }
- Schema.prototype = {
- messages: function messages2(_messages) {
- if (_messages) {
- this._messages = deepMerge(newMessages(), _messages);
- }
- return this._messages;
- },
- define: function define(rules2) {
- if (!rules2) {
- throw new Error("Cannot configure a schema with no rules");
- }
- if (typeof rules2 !== "object" || Array.isArray(rules2)) {
- throw new Error("Rules must be an object");
- }
- this.rules = {};
- let z;
- let item;
- for (z in rules2) {
- if (rules2.hasOwnProperty(z)) {
- item = rules2[z];
- this.rules[z] = Array.isArray(item) ? item : [item];
- }
- }
- },
- validate: function validate(source_, o2, oc) {
- const _this = this;
- if (o2 === void 0) {
- o2 = {};
- }
- if (oc === void 0) {
- oc = function oc2() {
- };
- }
- let source = source_;
- let options = o2;
- let callback = oc;
- if (typeof options === "function") {
- callback = options;
- options = {};
- }
- if (!this.rules || Object.keys(this.rules).length === 0) {
- if (callback) {
- callback();
- }
- return Promise.resolve();
- }
- function complete(results) {
- let i;
- let errors = [];
- let fields = {};
- function add2(e2) {
- if (Array.isArray(e2)) {
- let _errors;
- errors = (_errors = errors).concat.apply(_errors, e2);
- } else {
- errors.push(e2);
- }
- }
- for (i = 0; i < results.length; i++) {
- add2(results[i]);
- }
- if (!errors.length) {
- errors = null;
- fields = null;
- } else {
- fields = convertFieldsError(errors);
- }
- callback(errors, fields);
- }
- if (options.messages) {
- let messages$1 = this.messages();
- if (messages$1 === messages) {
- messages$1 = newMessages();
- }
- deepMerge(messages$1, options.messages);
- options.messages = messages$1;
- } else {
- options.messages = this.messages();
- }
- let arr;
- let value2;
- const series = {};
- const keys2 = options.keys || Object.keys(this.rules);
- keys2.forEach((z) => {
- arr = _this.rules[z];
- value2 = source[z];
- arr.forEach((r) => {
- let rule = r;
- if (typeof rule.transform === "function") {
- if (source === source_) {
- source = { ...source };
- }
- value2 = source[z] = rule.transform(value2);
- }
- if (typeof rule === "function") {
- rule = {
- validator: rule
- };
- } else {
- rule = { ...rule };
- }
- rule.validator = _this.getValidationMethod(rule);
- rule.field = z;
- rule.fullField = rule.fullField || z;
- rule.type = _this.getType(rule);
- if (!rule.validator) {
- return;
- }
- series[z] = series[z] || [];
- series[z].push({
- rule,
- value: value2,
- source,
- field: z
- });
- });
- });
- const errorFields = {};
- return asyncMap(series, options, (data, doIt) => {
- const { rule } = data;
- let deep = (rule.type === "object" || rule.type === "array") && (typeof rule.fields === "object" || typeof rule.defaultField === "object");
- deep = deep && (rule.required || !rule.required && data.value);
- rule.field = data.field;
- function addFullfield(key, schema) {
- return { ...schema, fullField: `${rule.fullField}.${key}` };
- }
- function cb(e2) {
- if (e2 === void 0) {
- e2 = [];
- }
- let errors = e2;
- if (!Array.isArray(errors)) {
- errors = [errors];
- }
- if (!options.suppressWarning && errors.length) {
- Schema.warning("async-validator:", errors);
- }
- if (errors.length && rule.message) {
- errors = [].concat(rule.message);
- }
- errors = errors.map(complementError(rule));
- if (options.first && errors.length) {
- errorFields[rule.field] = 1;
- return doIt(errors);
- }
- if (!deep) {
- doIt(errors);
- } else {
- if (rule.required && !data.value) {
- if (rule.message) {
- errors = [].concat(rule.message).map(complementError(rule));
- } else if (options.error) {
- errors = [options.error(rule, format(options.messages.required, rule.field))];
- } else {
- errors = [];
- }
- return doIt(errors);
- }
- let fieldsSchema = {};
- if (rule.defaultField) {
- for (const k in data.value) {
- if (data.value.hasOwnProperty(k)) {
- fieldsSchema[k] = rule.defaultField;
- }
- }
- }
- fieldsSchema = { ...fieldsSchema, ...data.rule.fields };
- for (const f2 in fieldsSchema) {
- if (fieldsSchema.hasOwnProperty(f2)) {
- const fieldSchema = Array.isArray(fieldsSchema[f2]) ? fieldsSchema[f2] : [fieldsSchema[f2]];
- fieldsSchema[f2] = fieldSchema.map(addFullfield.bind(null, f2));
- }
- }
- const schema = new Schema(fieldsSchema);
- schema.messages(options.messages);
- if (data.rule.options) {
- data.rule.options.messages = options.messages;
- data.rule.options.error = options.error;
- }
- schema.validate(data.value, data.rule.options || options, (errs) => {
- const finalErrors = [];
- if (errors && errors.length) {
- finalErrors.push.apply(finalErrors, errors);
- }
- if (errs && errs.length) {
- finalErrors.push.apply(finalErrors, errs);
- }
- doIt(finalErrors.length ? finalErrors : null);
- });
- }
- }
- let res;
- if (rule.asyncValidator) {
- res = rule.asyncValidator(rule, data.value, cb, data.source, options);
- } else if (rule.validator) {
- res = rule.validator(rule, data.value, cb, data.source, options);
- if (res === true) {
- cb();
- } else if (res === false) {
- cb(rule.message || `${rule.field} fails`);
- } else if (res instanceof Array) {
- cb(res);
- } else if (res instanceof Error) {
- cb(res.message);
- }
- }
- if (res && res.then) {
- res.then(() => cb(), (e2) => cb(e2));
- }
- }, (results) => {
- complete(results);
- });
- },
- getType: function getType2(rule) {
- if (rule.type === void 0 && rule.pattern instanceof RegExp) {
- rule.type = "pattern";
- }
- if (typeof rule.validator !== "function" && rule.type && !validators.hasOwnProperty(rule.type)) {
- throw new Error(format("Unknown rule type %s", rule.type));
- }
- return rule.type || "string";
- },
- getValidationMethod: function getValidationMethod(rule) {
- if (typeof rule.validator === "function") {
- return rule.validator;
- }
- const keys2 = Object.keys(rule);
- const messageIndex = keys2.indexOf("message");
- if (messageIndex !== -1) {
- keys2.splice(messageIndex, 1);
- }
- if (keys2.length === 1 && keys2[0] === "required") {
- return validators.required;
- }
- return validators[this.getType(rule)] || false;
- }
- };
- Schema.register = function register(type2, validator) {
- if (typeof validator !== "function") {
- throw new Error("Cannot register a validator by type, validator is not a function");
- }
- validators[type2] = validator;
- };
- Schema.warning = warning;
- Schema.messages = messages;
- const props$c = {
- props: {
- // 列表数组,元素可为字符串,如为对象可通过keyName指定目标属性名
- list: {
- type: Array,
- default: defprops.swiper.list
- },
- // 是否显示面板指示器
- indicator: {
- type: Boolean,
- default: defprops.swiper.indicator
- },
- // 指示器非激活颜色
- indicatorActiveColor: {
- type: String,
- default: defprops.swiper.indicatorActiveColor
- },
- // 指示器的激活颜色
- indicatorInactiveColor: {
- type: String,
- default: defprops.swiper.indicatorInactiveColor
- },
- // 指示器样式,可通过bottom,left,right进行定位
- indicatorStyle: {
- type: [String, Object],
- default: defprops.swiper.indicatorStyle
- },
- // 指示器模式,line-线型,dot-点型
- indicatorMode: {
- type: String,
- default: defprops.swiper.indicatorMode
- },
- // 是否自动切换
- autoplay: {
- type: Boolean,
- default: defprops.swiper.autoplay
- },
- // 当前所在滑块的 index
- current: {
- type: [String, Number],
- default: defprops.swiper.current
- },
- // 当前所在滑块的 item-id ,不能与 current 被同时指定
- currentItemId: {
- type: String,
- default: defprops.swiper.currentItemId
- },
- // 滑块自动切换时间间隔
- interval: {
- type: [String, Number],
- default: defprops.swiper.interval
- },
- // 滑块切换过程所需时间
- duration: {
- type: [String, Number],
- default: defprops.swiper.duration
- },
- // 播放到末尾后是否重新回到开头
- circular: {
- type: Boolean,
- default: defprops.swiper.circular
- },
- // 前边距,可用于露出前一项的一小部分,nvue和支付宝不支持
- previousMargin: {
- type: [String, Number],
- default: defprops.swiper.previousMargin
- },
- // 后边距,可用于露出后一项的一小部分,nvue和支付宝不支持
- nextMargin: {
- type: [String, Number],
- default: defprops.swiper.nextMargin
- },
- // 当开启时,会根据滑动速度,连续滑动多屏,支付宝不支持
- acceleration: {
- type: Boolean,
- default: defprops.swiper.acceleration
- },
- // 同时显示的滑块数量,nvue、支付宝小程序不支持
- displayMultipleItems: {
- type: Number,
- default: defprops.swiper.displayMultipleItems
- },
- // 指定swiper切换缓动动画类型,有效值:default、linear、easeInCubic、easeOutCubic、easeInOutCubic
- // 只对微信小程序有效
- easingFunction: {
- type: String,
- default: defprops.swiper.easingFunction
- },
- // list数组中指定对象的目标属性名
- keyName: {
- type: String,
- default: defprops.swiper.keyName
- },
- // 图片的裁剪模式
- imgMode: {
- type: String,
- default: defprops.swiper.imgMode
- },
- // 组件高度
- height: {
- type: [String, Number],
- default: defprops.swiper.height
- },
- // 背景颜色
- bgColor: {
- type: String,
- default: defprops.swiper.bgColor
- },
- // 组件圆角,数值或带单位的字符串
- radius: {
- type: [String, Number],
- default: defprops.swiper.radius
- },
- // 是否加载中
- loading: {
- type: Boolean,
- default: defprops.swiper.loading
- },
- // 是否显示标题,要求数组对象中有title属性
- showTitle: {
- type: Boolean,
- default: defprops.swiper.showTitle
- }
- }
- };
- const props$b = {
- props: {
- // tab的数据
- list: {
- type: Array,
- default: defprops.subsection.list
- },
- // 当前活动的tab的index
- current: {
- type: [String, Number],
- default: defprops.subsection.current
- },
- // 激活的颜色
- activeColor: {
- type: String,
- default: defprops.subsection.activeColor
- },
- // 未激活的颜色
- inactiveColor: {
- type: String,
- default: defprops.subsection.inactiveColor
- },
- // 模式选择,mode=button为按钮形式,mode=subsection时为分段模式
- mode: {
- type: String,
- default: defprops.subsection.mode
- },
- // 字体大小
- fontSize: {
- type: [String, Number],
- default: defprops.subsection.fontSize
- },
- // 激活tab的字体是否加粗
- bold: {
- type: Boolean,
- default: defprops.subsection.bold
- },
- // mode = button时,组件背景颜色
- bgColor: {
- type: String,
- default: defprops.subsection.bgColor
- },
- // 从list元素对象中读取的键名
- keyName: {
- type: String,
- default: defprops.subsection.keyName
- }
- }
- };
- const props$a = {
- props: {
- // 是否显示圆点
- isDot: {
- type: Boolean,
- default: defprops.badge.isDot
- },
- // 显示的内容
- value: {
- type: [Number, String],
- default: defprops.badge.value
- },
- // 显示的内容
- modelValue: {
- type: [Number, String],
- default: defprops.badge.modelValue
- },
- // 是否显示
- show: {
- type: Boolean,
- default: defprops.badge.show
- },
- // 最大值,超过最大值会显示 '{max}+'
- max: {
- type: [Number, String],
- default: defprops.badge.max
- },
- // 主题类型,error|warning|success|primary
- type: {
- type: String,
- default: defprops.badge.type
- },
- // 当数值为 0 时,是否展示 Badge
- showZero: {
- type: Boolean,
- default: defprops.badge.showZero
- },
- // 背景颜色,优先级比type高,如设置,type参数会失效
- bgColor: {
- type: [String, null],
- default: defprops.badge.bgColor
- },
- // 字体颜色
- color: {
- type: [String, null],
- default: defprops.badge.color
- },
- // 徽标形状,circle-四角均为圆角,horn-左下角为直角
- shape: {
- type: String,
- default: defprops.badge.shape
- },
- // 设置数字的显示方式,overflow|ellipsis|limit
- // overflow会根据max字段判断,超出显示`${max}+`
- // ellipsis会根据max判断,超出显示`${max}...`
- // limit会依据1000作为判断条件,超出1000,显示`${value/1000}K`,比如2.2k、3.34w,最多保留2位小数
- numberType: {
- type: String,
- default: defprops.badge.numberType
- },
- // 设置badge的位置偏移,格式为 [x, y],也即设置的为top和right的值,absolute为true时有效
- offset: {
- type: Array,
- default: defprops.badge.offset
- },
- // 是否反转背景和字体颜色
- inverted: {
- type: Boolean,
- default: defprops.badge.inverted
- },
- // 是否绝对定位
- absolute: {
- type: Boolean,
- default: defprops.badge.absolute
- }
- }
- };
- const button = {
- props: {
- lang: String,
- sessionFrom: String,
- sendMessageTitle: String,
- sendMessagePath: String,
- sendMessageImg: String,
- showMessageCard: Boolean,
- appParameter: String,
- formType: String,
- openType: String
- }
- };
- const openType = {
- props: {
- openType: String
- },
- methods: {
- onGetUserInfo(event) {
- this.$emit("getuserinfo", event.detail);
- },
- onContact(event) {
- this.$emit("contact", event.detail);
- },
- onGetPhoneNumber(event) {
- this.$emit("getphonenumber", event.detail);
- },
- onError(event) {
- this.$emit("error", event.detail);
- },
- onLaunchApp(event) {
- this.$emit("launchapp", event.detail);
- },
- onOpenSetting(event) {
- this.$emit("opensetting", event.detail);
- }
- }
- };
- const props$9 = {
- props: {
- // 是否细边框
- hairline: {
- type: Boolean,
- default: defprops.button.hairline
- },
- // 按钮的预置样式,info,primary,error,warning,success
- type: {
- type: String,
- default: defprops.button.type
- },
- // 按钮尺寸,large,normal,small,mini
- size: {
- type: String,
- default: defprops.button.size
- },
- // 按钮形状,circle(两边为半圆),square(带圆角)
- shape: {
- type: String,
- default: defprops.button.shape
- },
- // 按钮是否镂空
- plain: {
- type: Boolean,
- default: defprops.button.plain
- },
- // 是否禁止状态
- disabled: {
- type: Boolean,
- default: defprops.button.disabled
- },
- // 是否加载中
- loading: {
- type: Boolean,
- default: defprops.button.loading
- },
- // 加载中提示文字
- loadingText: {
- type: [String, Number],
- default: defprops.button.loadingText
- },
- // 加载状态图标类型
- loadingMode: {
- type: String,
- default: defprops.button.loadingMode
- },
- // 加载图标大小
- loadingSize: {
- type: [String, Number],
- default: defprops.button.loadingSize
- },
- // 开放能力,具体请看uniapp稳定关于button组件部分说明
- // https://uniapp.dcloud.io/component/button
- openType: {
- type: String,
- default: defprops.button.openType
- },
- // 用于 <form> 组件,点击分别会触发 <form> 组件的 submit/reset 事件
- // 取值为submit(提交表单),reset(重置表单)
- formType: {
- type: String,
- default: defprops.button.formType
- },
- // 打开 APP 时,向 APP 传递的参数,open-type=launchApp时有效
- // 只微信小程序、QQ小程序有效
- appParameter: {
- type: String,
- default: defprops.button.appParameter
- },
- // 指定是否阻止本节点的祖先节点出现点击态,微信小程序有效
- hoverStopPropagation: {
- type: Boolean,
- default: defprops.button.hoverStopPropagation
- },
- // 指定返回用户信息的语言,zh_CN 简体中文,zh_TW 繁体中文,en 英文。只微信小程序有效
- lang: {
- type: String,
- default: defprops.button.lang
- },
- // 会话来源,open-type="contact"时有效。只微信小程序有效
- sessionFrom: {
- type: String,
- default: defprops.button.sessionFrom
- },
- // 会话内消息卡片标题,open-type="contact"时有效
- // 默认当前标题,只微信小程序有效
- sendMessageTitle: {
- type: String,
- default: defprops.button.sendMessageTitle
- },
- // 会话内消息卡片点击跳转小程序路径,open-type="contact"时有效
- // 默认当前分享路径,只微信小程序有效
- sendMessagePath: {
- type: String,
- default: defprops.button.sendMessagePath
- },
- // 会话内消息卡片图片,open-type="contact"时有效
- // 默认当前页面截图,只微信小程序有效
- sendMessageImg: {
- type: String,
- default: defprops.button.sendMessageImg
- },
- // 是否显示会话内消息卡片,设置此参数为 true,用户进入客服会话会在右下角显示"可能要发送的小程序"提示,
- // 用户点击后可以快速发送小程序消息,open-type="contact"时有效
- showMessageCard: {
- type: Boolean,
- default: defprops.button.showMessageCard
- },
- // 额外传参参数,用于小程序的data-xxx属性,通过target.dataset.name获取
- dataName: {
- type: String,
- default: defprops.button.dataName
- },
- // 节流,一定时间内只能触发一次
- throttleTime: {
- type: [String, Number],
- default: defprops.button.throttleTime
- },
- // 按住后多久出现点击态,单位毫秒
- hoverStartTime: {
- type: [String, Number],
- default: defprops.button.hoverStartTime
- },
- // 手指松开后点击态保留时间,单位毫秒
- hoverStayTime: {
- type: [String, Number],
- default: defprops.button.hoverStayTime
- },
- // 按钮文字,之所以通过props传入,是因为slot传入的话
- // nvue中无法控制文字的样式
- text: {
- type: [String, Number],
- default: defprops.button.text
- },
- // 按钮图标
- icon: {
- type: String,
- default: defprops.button.icon
- },
- // 按钮图标
- iconColor: {
- type: String,
- default: defprops.button.icon
- },
- // 按钮颜色,支持传入linear-gradient渐变色
- color: {
- type: String,
- default: defprops.button.color
- }
- }
- };
- const props$8 = {
- props: {
- color: {
- type: String,
- default: defprops.line.color
- },
- // 长度,竖向时表现为高度,横向时表现为长度,可以为百分比,带px单位的值等
- length: {
- type: [String, Number],
- default: defprops.line.length
- },
- // 线条方向,col-竖向,row-横向
- direction: {
- type: String,
- default: defprops.line.direction
- },
- // 是否显示细边框
- hairline: {
- type: Boolean,
- default: defprops.line.hairline
- },
- // 线条与上下左右元素的间距,字符串形式,如"30px"、"20px 30px"
- margin: {
- type: [String, Number],
- default: defprops.line.margin
- },
- // 是否虚线,true-虚线,false-实线
- dashed: {
- type: Boolean,
- default: defprops.line.dashed
- }
- }
- };
- const props$7 = {
- props: {
- // 图片地址,Array<String>|Array<Object>形式
- urls: {
- type: Array,
- default: defprops.album.urls
- },
- // 指定从数组的对象元素中读取哪个属性作为图片地址
- keyName: {
- type: String,
- default: defprops.album.keyName
- },
- // 单图时,图片长边的长度
- singleSize: {
- type: [String, Number],
- default: defprops.album.singleSize
- },
- // 多图时,图片边长
- multipleSize: {
- type: [String, Number],
- default: defprops.album.multipleSize
- },
- // 多图时,图片水平和垂直之间的间隔
- space: {
- type: [String, Number],
- default: defprops.album.space
- },
- // 单图时,图片缩放裁剪的模式
- singleMode: {
- type: String,
- default: defprops.album.singleMode
- },
- // 多图时,图片缩放裁剪的模式
- multipleMode: {
- type: String,
- default: defprops.album.multipleMode
- },
- // 最多展示的图片数量,超出时最后一个位置将会显示剩余图片数量
- maxCount: {
- type: [String, Number],
- default: defprops.album.maxCount
- },
- // 是否可以预览图片
- previewFullImage: {
- type: Boolean,
- default: defprops.album.previewFullImage
- },
- // 每行展示图片数量,如设置,singleSize和multipleSize将会无效
- rowCount: {
- type: [String, Number],
- default: defprops.album.rowCount
- },
- // 超出maxCount时是否显示查看更多的提示
- showMore: {
- type: Boolean,
- default: defprops.album.showMore
- }
- }
- };
- const value = {
- computed: {
- // 经处理后需要显示的值
- value() {
- const {
- text,
- mode,
- format: format2,
- href
- } = this;
- if (mode === "price") {
- if (!/^\d+(\.\d+)?$/.test(text)) {
- index$1.$u.error("金额模式下,text参数需要为金额格式");
- }
- if (index$1.$u.test.func(format2)) {
- return format2(text);
- }
- return index$1.$u.priceFormat(text, 2);
- }
- if (mode === "date") {
- !index$1.$u.test.date(text) && index$1.$u.error("日期模式下,text参数需要为日期或时间戳格式");
- if (index$1.$u.test.func(format2)) {
- return format2(text);
- }
- if (format2) {
- return index$1.$u.timeFormat(text, format2);
- }
- return index$1.$u.timeFormat(text, "yyyy-mm-dd");
- }
- if (mode === "phone") {
- if (index$1.$u.test.func(format2)) {
- return format2(text);
- }
- if (format2 === "encrypt") {
- return `${text.substr(0, 3)}****${text.substr(7)}`;
- }
- return text;
- }
- if (mode === "name") {
- !(typeof text === "string") && index$1.$u.error("姓名模式下,text参数需要为字符串格式");
- if (index$1.$u.test.func(format2)) {
- return format2(text);
- }
- if (format2 === "encrypt") {
- return this.formatName(text);
- }
- return text;
- }
- if (mode === "link") {
- !index$1.$u.test.url(href) && index$1.$u.error("超链接模式下,href参数需要为URL格式");
- return text;
- }
- return text;
- }
- },
- methods: {
- // 默认的姓名脱敏规则
- formatName(name) {
- let value2 = "";
- if (name.length === 2) {
- value2 = name.substr(0, 1) + "*";
- } else if (name.length > 2) {
- let char = "";
- for (let i = 0, len = name.length - 2; i < len; i++) {
- char += "*";
- }
- value2 = name.substr(0, 1) + char + name.substr(-1, 1);
- } else {
- value2 = name;
- }
- return value2;
- }
- }
- };
- const props$6 = {
- props: {
- // 主题颜色
- type: {
- type: String,
- default: defprops.text.type
- },
- // 是否显示
- show: {
- type: Boolean,
- default: defprops.text.show
- },
- // 显示的值
- text: {
- type: [String, Number],
- default: defprops.text.text
- },
- // 前置图标
- prefixIcon: {
- type: String,
- default: defprops.text.prefixIcon
- },
- // 后置图标
- suffixIcon: {
- type: String,
- default: defprops.text.suffixIcon
- },
- // 文本处理的匹配模式
- // text-普通文本,price-价格,phone-手机号,name-姓名,date-日期,link-超链接
- mode: {
- type: String,
- default: defprops.text.mode
- },
- // mode=link下,配置的链接
- href: {
- type: String,
- default: defprops.text.href
- },
- // 格式化规则
- format: {
- type: [String, Function],
- default: defprops.text.format
- },
- // mode=phone时,点击文本是否拨打电话
- call: {
- type: Boolean,
- default: defprops.text.call
- },
- // 小程序的打开方式
- openType: {
- type: String,
- default: defprops.text.openType
- },
- // 是否粗体,默认normal
- bold: {
- type: Boolean,
- default: defprops.text.bold
- },
- // 是否块状
- block: {
- type: Boolean,
- default: defprops.text.block
- },
- // 文本显示的行数,如果设置,超出此行数,将会显示省略号
- lines: {
- type: [String, Number],
- default: defprops.text.lines
- },
- // 文本颜色
- color: {
- type: String,
- default: defprops.text.color
- },
- // 字体大小
- size: {
- type: [String, Number],
- default: defprops.text.size
- },
- // 图标的样式
- iconStyle: {
- type: [Object, String],
- default: defprops.text.iconStyle
- },
- // 文字装饰,下划线,中划线等,可选值 none|underline|line-through
- decoration: {
- tepe: String,
- default: defprops.text.decoration
- },
- // 外边距,对象、字符串,数值形式均可
- margin: {
- type: [Object, String, Number],
- default: defprops.text.margin
- },
- // 文本行高
- lineHeight: {
- type: [String, Number],
- default: defprops.text.lineHeight
- },
- // 文本对齐方式,可选值left|center|right
- align: {
- type: String,
- default: defprops.text.align
- },
- // 文字换行,可选值break-word|normal|anywhere
- wordWrap: {
- type: String,
- default: defprops.text.wordWrap
- }
- }
- };
- const props$5 = {
- props: {
- // 是否展示组件
- show: {
- type: Boolean,
- default: defprops.transition.show
- },
- // 使用的动画模式
- mode: {
- type: String,
- default: defprops.transition.mode
- },
- // 动画的执行时间,单位ms
- duration: {
- type: [String, Number],
- default: defprops.transition.duration
- },
- // 使用的动画过渡函数
- timingFunction: {
- type: String,
- default: defprops.transition.timingFunction
- }
- }
- };
- const getClassNames = (name) => ({
- enter: `u-${name}-enter u-${name}-enter-active`,
- "enter-to": `u-${name}-enter-to u-${name}-enter-active`,
- leave: `u-${name}-leave u-${name}-leave-active`,
- "leave-to": `u-${name}-leave-to u-${name}-leave-active`
- });
- const transition = {
- methods: {
- // 组件被点击发出事件
- clickHandler() {
- this.$emit("click");
- },
- // vue版本的组件进场处理
- async vueEnter() {
- const classNames = getClassNames(this.mode);
- this.status = "enter";
- this.$emit("beforeEnter");
- this.inited = true;
- this.display = true;
- this.classes = classNames.enter;
- await nextTick$1();
- {
- this.$emit("enter");
- this.transitionEnded = false;
- this.$emit("afterEnter");
- this.classes = classNames["enter-to"];
- }
- },
- // 动画离场处理
- async vueLeave() {
- if (!this.display)
- return;
- const classNames = getClassNames(this.mode);
- this.status = "leave";
- this.$emit("beforeLeave");
- this.classes = classNames.leave;
- await nextTick$1();
- {
- this.transitionEnded = false;
- this.$emit("leave");
- setTimeout(this.onTransitionEnd, this.duration);
- this.classes = classNames["leave-to"];
- }
- },
- // 完成过渡后触发
- onTransitionEnd() {
- if (this.transitionEnded)
- return;
- this.transitionEnded = true;
- this.$emit(this.status === "leave" ? "afterLeave" : "afterEnter");
- if (!this.show && this.display) {
- this.display = false;
- this.inited = false;
- }
- }
- }
- };
- const props$4 = {
- props: {
- // 显示的内容,字符串
- text: {
- type: [Array],
- default: defprops.columnNotice.text
- },
- // 是否显示左侧的音量图标
- icon: {
- type: String,
- default: defprops.columnNotice.icon
- },
- // 通告模式,link-显示右箭头,closable-显示右侧关闭图标
- mode: {
- type: String,
- default: defprops.columnNotice.mode
- },
- // 文字颜色,各图标也会使用文字颜色
- color: {
- type: String,
- default: defprops.columnNotice.color
- },
- // 背景颜色
- bgColor: {
- type: String,
- default: defprops.columnNotice.bgColor
- },
- // 字体大小,单位px
- fontSize: {
- type: [String, Number],
- default: defprops.columnNotice.fontSize
- },
- // 水平滚动时的滚动速度,即每秒滚动多少px(px),这有利于控制文字无论多少时,都能有一个恒定的速度
- speed: {
- type: [String, Number],
- default: defprops.columnNotice.speed
- },
- // direction = row时,是否使用步进形式滚动
- step: {
- type: Boolean,
- default: defprops.columnNotice.step
- },
- // 滚动一个周期的时间长,单位ms
- duration: {
- type: [String, Number],
- default: defprops.columnNotice.duration
- },
- // 是否禁止用手滑动切换
- // 目前HX2.6.11,只支持App 2.5.5+、H5 2.5.5+、支付宝小程序、字节跳动小程序
- disableTouch: {
- type: Boolean,
- default: defprops.columnNotice.disableTouch
- }
- }
- };
- const props$3 = {
- props: {
- // 显示的内容,字符串
- text: {
- type: String,
- default: defprops.rowNotice.text
- },
- // 是否显示左侧的音量图标
- icon: {
- type: String,
- default: defprops.rowNotice.icon
- },
- // 通告模式,link-显示右箭头,closable-显示右侧关闭图标
- mode: {
- type: String,
- default: defprops.rowNotice.mode
- },
- // 文字颜色,各图标也会使用文字颜色
- color: {
- type: String,
- default: defprops.rowNotice.color
- },
- // 背景颜色
- bgColor: {
- type: String,
- default: defprops.rowNotice.bgColor
- },
- // 字体大小,单位px
- fontSize: {
- type: [String, Number],
- default: defprops.rowNotice.fontSize
- },
- // 水平滚动时的滚动速度,即每秒滚动多少px(rpx),这有利于控制文字无论多少时,都能有一个恒定的速度
- speed: {
- type: [String, Number],
- default: defprops.rowNotice.speed
- }
- }
- };
- const props$2 = {
- props: {
- // 是否显示组件
- show: {
- type: Boolean,
- default: defprops.loadingIcon.show
- },
- // 颜色
- color: {
- type: String,
- default: defprops.loadingIcon.color
- },
- // 提示文字颜色
- textColor: {
- type: String,
- default: defprops.loadingIcon.textColor
- },
- // 文字和图标是否垂直排列
- vertical: {
- type: Boolean,
- default: defprops.loadingIcon.vertical
- },
- // 模式选择,circle-圆形,spinner-花朵形,semicircle-半圆形
- mode: {
- type: String,
- default: defprops.loadingIcon.mode
- },
- // 图标大小,单位默认px
- size: {
- type: [String, Number],
- default: defprops.loadingIcon.size
- },
- // 文字大小
- textSize: {
- type: [String, Number],
- default: defprops.loadingIcon.textSize
- },
- // 文字内容
- text: {
- type: [String, Number],
- default: defprops.loadingIcon.text
- },
- // 动画模式
- timingFunction: {
- type: String,
- default: defprops.loadingIcon.timingFunction
- },
- // 动画执行周期时间
- duration: {
- type: [String, Number],
- default: defprops.loadingIcon.duration
- },
- // mode=circle时的暗边颜色
- inactiveColor: {
- type: String,
- default: defprops.loadingIcon.inactiveColor
- }
- }
- };
- const props$1 = {
- props: {
- // 轮播的长度
- length: {
- type: [String, Number],
- default: defprops.swiperIndicator.length
- },
- // 当前处于活动状态的轮播的索引
- current: {
- type: [String, Number],
- default: defprops.swiperIndicator.current
- },
- // 指示器非激活颜色
- indicatorActiveColor: {
- type: String,
- default: defprops.swiperIndicator.indicatorActiveColor
- },
- // 指示器的激活颜色
- indicatorInactiveColor: {
- type: String,
- default: defprops.swiperIndicator.indicatorInactiveColor
- },
- // 指示器模式,line-线型,dot-点型
- indicatorMode: {
- type: String,
- default: defprops.swiperIndicator.indicatorMode
- }
- }
- };
- const props = {
- props: {
- // 文字颜色
- color: {
- type: String,
- default: defprops.link.color
- },
- // 字体大小,单位px
- fontSize: {
- type: [String, Number],
- default: defprops.link.fontSize
- },
- // 是否显示下划线
- underLine: {
- type: Boolean,
- default: defprops.link.underLine
- },
- // 要跳转的链接
- href: {
- type: String,
- default: defprops.link.href
- },
- // 小程序中复制到粘贴板的提示语
- mpTips: {
- type: String,
- default: defprops.link.mpTips
- },
- // 下划线颜色
- lineColor: {
- type: String,
- default: defprops.link.lineColor
- },
- // 超链接的问题,不使用slot形式传入,是因为nvue下无法修改颜色
- text: {
- type: String,
- default: defprops.link.text
- }
- }
- };
- exports.Schema = Schema;
- exports._export_sfc = _export_sfc;
- exports.button = button;
- exports.computed = computed;
- exports.createSSRApp = createSSRApp;
- exports.defineComponent = defineComponent;
- exports.e = e;
- exports.f = f;
- exports.getCurrentInstance = getCurrentInstance;
- exports.hooks = hooks;
- exports.icons = icons;
- exports.index = index$1;
- exports.mixin = mixin;
- exports.mpMixin = mpMixin;
- exports.n = n;
- exports.o = o;
- exports.onLoad = onLoad;
- exports.onPullDownRefresh = onPullDownRefresh;
- exports.onShow = onShow;
- exports.openType = openType;
- exports.p = p;
- exports.props = props$m;
- exports.props$1 = props$l;
- exports.props$10 = props$c;
- exports.props$11 = props$b;
- exports.props$12 = props$a;
- exports.props$13 = props$9;
- exports.props$14 = props$8;
- exports.props$15 = props$7;
- exports.props$16 = props$6;
- exports.props$17 = props$5;
- exports.props$18 = props$4;
- exports.props$19 = props$3;
- exports.props$2 = props$k;
- exports.props$20 = props$2;
- exports.props$21 = props$1;
- exports.props$22 = props;
- exports.props$3 = props$j;
- exports.props$4 = props$i;
- exports.props$5 = props$h;
- exports.props$6 = props$g;
- exports.props$7 = props$f;
- exports.props$8 = props$e;
- exports.props$9 = props$d;
- exports.ref = ref;
- exports.resolveComponent = resolveComponent;
- exports.s = s;
- exports.sr = sr;
- exports.t = t;
- exports.transition = transition;
- exports.unref = unref;
- exports.uviewPlus = uviewPlus;
- exports.value = value;
- exports.wx$1 = wx$1;
|