1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404840584068407840884098410841184128413841484158416841784188419842084218422842384248425842684278428842984308431843284338434843584368437843884398440844184428443844484458446844784488449845084518452845384548455845684578458845984608461846284638464846584668467846884698470847184728473847484758476847784788479848084818482848384848485848684878488848984908491849284938494849584968497849884998500850185028503850485058506850785088509851085118512851385148515851685178518851985208521852285238524852585268527852885298530853185328533853485358536853785388539854085418542854385448545854685478548854985508551855285538554855585568557855885598560856185628563856485658566856785688569857085718572857385748575857685778578857985808581858285838584858585868587858885898590859185928593859485958596859785988599860086018602860386048605860686078608860986108611861286138614861586168617861886198620862186228623862486258626862786288629863086318632863386348635863686378638863986408641864286438644864586468647864886498650865186528653865486558656865786588659866086618662866386648665866686678668866986708671867286738674867586768677867886798680868186828683868486858686868786888689869086918692869386948695869686978698869987008701870287038704870587068707870887098710871187128713871487158716871787188719872087218722872387248725872687278728872987308731873287338734873587368737873887398740874187428743874487458746874787488749875087518752875387548755875687578758875987608761876287638764876587668767876887698770877187728773877487758776877787788779878087818782878387848785878687878788878987908791879287938794879587968797879887998800880188028803880488058806880788088809881088118812881388148815881688178818881988208821882288238824882588268827882888298830883188328833883488358836883788388839884088418842884388448845884688478848884988508851885288538854885588568857885888598860886188628863886488658866886788688869887088718872887388748875887688778878887988808881888288838884888588868887888888898890889188928893889488958896889788988899890089018902890389048905890689078908890989108911891289138914891589168917891889198920892189228923892489258926892789288929893089318932893389348935893689378938893989408941894289438944894589468947894889498950895189528953895489558956895789588959896089618962896389648965896689678968896989708971897289738974897589768977897889798980898189828983898489858986898789888989899089918992899389948995899689978998899990009001900290039004900590069007900890099010901190129013901490159016901790189019902090219022902390249025902690279028902990309031903290339034903590369037903890399040904190429043904490459046904790489049905090519052905390549055905690579058905990609061906290639064906590669067906890699070907190729073907490759076907790789079908090819082908390849085908690879088908990909091909290939094909590969097909890999100910191029103910491059106910791089109911091119112911391149115911691179118911991209121912291239124912591269127912891299130913191329133913491359136913791389139914091419142914391449145914691479148914991509151915291539154915591569157915891599160916191629163916491659166916791689169917091719172917391749175917691779178917991809181918291839184918591869187918891899190919191929193919491959196919791989199920092019202920392049205920692079208920992109211921292139214921592169217921892199220922192229223922492259226922792289229923092319232923392349235923692379238923992409241924292439244924592469247924892499250925192529253925492559256925792589259926092619262926392649265926692679268926992709271927292739274927592769277927892799280928192829283928492859286928792889289929092919292929392949295929692979298929993009301930293039304930593069307930893099310931193129313931493159316931793189319932093219322932393249325932693279328932993309331933293339334933593369337933893399340934193429343934493459346934793489349935093519352935393549355935693579358935993609361936293639364936593669367936893699370937193729373937493759376937793789379938093819382938393849385938693879388938993909391939293939394939593969397939893999400940194029403940494059406940794089409941094119412941394149415941694179418941994209421942294239424942594269427942894299430943194329433943494359436943794389439944094419442944394449445944694479448944994509451945294539454945594569457945894599460946194629463946494659466946794689469947094719472947394749475947694779478947994809481948294839484948594869487948894899490949194929493949494959496949794989499950095019502950395049505950695079508950995109511951295139514951595169517951895199520952195229523952495259526952795289529953095319532953395349535953695379538953995409541954295439544954595469547954895499550955195529553955495559556955795589559956095619562956395649565956695679568956995709571957295739574957595769577957895799580958195829583958495859586958795889589959095919592959395949595959695979598959996009601960296039604960596069607960896099610961196129613961496159616961796189619962096219622962396249625962696279628962996309631963296339634963596369637963896399640964196429643964496459646964796489649965096519652965396549655965696579658965996609661966296639664966596669667966896699670967196729673967496759676967796789679968096819682968396849685968696879688968996909691969296939694969596969697969896999700970197029703970497059706970797089709971097119712971397149715971697179718971997209721972297239724972597269727972897299730973197329733973497359736973797389739974097419742974397449745974697479748974997509751975297539754975597569757975897599760976197629763976497659766976797689769977097719772977397749775977697779778977997809781978297839784978597869787978897899790979197929793979497959796979797989799980098019802980398049805980698079808980998109811981298139814981598169817981898199820982198229823982498259826982798289829983098319832983398349835983698379838983998409841984298439844984598469847984898499850985198529853985498559856985798589859986098619862986398649865986698679868986998709871987298739874987598769877987898799880988198829883988498859886988798889889989098919892989398949895989698979898989999009901990299039904990599069907990899099910991199129913991499159916991799189919992099219922992399249925992699279928992999309931993299339934993599369937993899399940994199429943994499459946994799489949995099519952995399549955995699579958995999609961996299639964996599669967996899699970997199729973997499759976997799789979998099819982998399849985998699879988998999909991999299939994999599969997999899991000010001100021000310004100051000610007100081000910010100111001210013100141001510016100171001810019100201002110022100231002410025100261002710028100291003010031100321003310034100351003610037100381003910040100411004210043100441004510046100471004810049100501005110052100531005410055100561005710058100591006010061100621006310064100651006610067100681006910070100711007210073100741007510076100771007810079100801008110082100831008410085100861008710088100891009010091100921009310094100951009610097100981009910100101011010210103101041010510106101071010810109101101011110112101131011410115101161011710118101191012010121101221012310124101251012610127101281012910130101311013210133101341013510136101371013810139101401014110142101431014410145101461014710148101491015010151101521015310154101551015610157101581015910160101611016210163101641016510166101671016810169101701017110172101731017410175101761017710178101791018010181101821018310184101851018610187101881018910190101911019210193101941019510196101971019810199102001020110202102031020410205102061020710208102091021010211102121021310214102151021610217102181021910220102211022210223102241022510226102271022810229102301023110232102331023410235102361023710238102391024010241102421024310244102451024610247102481024910250102511025210253102541025510256102571025810259102601026110262102631026410265102661026710268102691027010271102721027310274102751027610277102781027910280102811028210283102841028510286102871028810289102901029110292102931029410295102961029710298102991030010301103021030310304103051030610307103081030910310103111031210313103141031510316103171031810319103201032110322103231032410325103261032710328103291033010331103321033310334103351033610337103381033910340103411034210343103441034510346103471034810349103501035110352103531035410355103561035710358103591036010361103621036310364103651036610367103681036910370103711037210373103741037510376103771037810379103801038110382103831038410385103861038710388103891039010391103921039310394103951039610397103981039910400104011040210403104041040510406104071040810409104101041110412104131041410415104161041710418104191042010421104221042310424104251042610427104281042910430104311043210433104341043510436104371043810439104401044110442104431044410445104461044710448104491045010451104521045310454104551045610457104581045910460104611046210463104641046510466104671046810469104701047110472104731047410475104761047710478104791048010481104821048310484104851048610487104881048910490104911049210493104941049510496104971049810499105001050110502105031050410505105061050710508105091051010511105121051310514105151051610517105181051910520105211052210523105241052510526105271052810529105301053110532105331053410535105361053710538105391054010541105421054310544105451054610547105481054910550105511055210553105541055510556105571055810559105601056110562105631056410565105661056710568105691057010571105721057310574105751057610577105781057910580105811058210583105841058510586105871058810589105901059110592105931059410595105961059710598105991060010601106021060310604106051060610607106081060910610106111061210613106141061510616106171061810619106201062110622106231062410625106261062710628106291063010631106321063310634106351063610637106381063910640106411064210643106441064510646106471064810649106501065110652106531065410655106561065710658106591066010661106621066310664106651066610667106681066910670106711067210673106741067510676106771067810679106801068110682106831068410685106861068710688106891069010691106921069310694106951069610697106981069910700107011070210703107041070510706107071070810709107101071110712107131071410715107161071710718107191072010721107221072310724107251072610727107281072910730107311073210733107341073510736107371073810739107401074110742107431074410745107461074710748107491075010751107521075310754107551075610757107581075910760107611076210763107641076510766107671076810769107701077110772107731077410775107761077710778107791078010781107821078310784107851078610787107881078910790107911079210793107941079510796107971079810799108001080110802108031080410805108061080710808108091081010811108121081310814108151081610817108181081910820108211082210823108241082510826108271082810829108301083110832108331083410835108361083710838108391084010841108421084310844108451084610847108481084910850108511085210853108541085510856108571085810859108601086110862108631086410865108661086710868108691087010871108721087310874108751087610877108781087910880108811088210883108841088510886108871088810889108901089110892108931089410895108961089710898108991090010901109021090310904109051090610907109081090910910109111091210913109141091510916109171091810919109201092110922109231092410925109261092710928109291093010931109321093310934109351093610937109381093910940109411094210943109441094510946109471094810949109501095110952109531095410955109561095710958109591096010961109621096310964109651096610967109681096910970109711097210973109741097510976109771097810979109801098110982109831098410985109861098710988109891099010991109921099310994109951099610997109981099911000110011100211003110041100511006110071100811009110101101111012110131101411015110161101711018110191102011021110221102311024110251102611027110281102911030110311103211033110341103511036110371103811039110401104111042110431104411045110461104711048110491105011051110521105311054110551105611057110581105911060110611106211063110641106511066110671106811069110701107111072110731107411075110761107711078110791108011081110821108311084110851108611087110881108911090110911109211093110941109511096110971109811099111001110111102111031110411105111061110711108111091111011111111121111311114111151111611117111181111911120111211112211123111241112511126111271112811129111301113111132111331113411135111361113711138111391114011141111421114311144111451114611147111481114911150111511115211153111541115511156111571115811159111601116111162111631116411165111661116711168111691117011171111721117311174111751117611177111781117911180111811118211183111841118511186111871118811189111901119111192111931119411195111961119711198111991120011201112021120311204112051120611207112081120911210112111121211213112141121511216112171121811219112201122111222112231122411225112261122711228112291123011231112321123311234112351123611237112381123911240112411124211243112441124511246112471124811249112501125111252112531125411255112561125711258112591126011261112621126311264112651126611267112681126911270112711127211273112741127511276112771127811279112801128111282112831128411285112861128711288112891129011291112921129311294112951129611297112981129911300113011130211303113041130511306113071130811309113101131111312113131131411315113161131711318113191132011321113221132311324113251132611327113281132911330113311133211333113341133511336113371133811339113401134111342113431134411345113461134711348113491135011351113521135311354113551135611357113581135911360113611136211363113641136511366113671136811369113701137111372113731137411375113761137711378113791138011381113821138311384113851138611387113881138911390113911139211393113941139511396113971139811399114001140111402114031140411405114061140711408114091141011411114121141311414114151141611417114181141911420114211142211423114241142511426114271142811429114301143111432114331143411435114361143711438114391144011441114421144311444114451144611447114481144911450114511145211453114541145511456114571145811459114601146111462114631146411465114661146711468114691147011471114721147311474114751147611477114781147911480114811148211483114841148511486114871148811489114901149111492114931149411495114961149711498114991150011501115021150311504115051150611507115081150911510115111151211513115141151511516115171151811519115201152111522115231152411525115261152711528115291153011531115321153311534115351153611537115381153911540115411154211543115441154511546115471154811549115501155111552115531155411555115561155711558115591156011561115621156311564115651156611567115681156911570115711157211573115741157511576115771157811579115801158111582115831158411585115861158711588115891159011591115921159311594115951159611597115981159911600116011160211603116041160511606116071160811609116101161111612116131161411615116161161711618116191162011621116221162311624116251162611627116281162911630116311163211633116341163511636116371163811639116401164111642116431164411645116461164711648116491165011651116521165311654116551165611657116581165911660116611166211663116641166511666116671166811669116701167111672116731167411675116761167711678116791168011681116821168311684116851168611687116881168911690116911169211693116941169511696116971169811699117001170111702117031170411705117061170711708117091171011711117121171311714117151171611717117181171911720117211172211723117241172511726117271172811729117301173111732117331173411735117361173711738117391174011741117421174311744117451174611747117481174911750117511175211753117541175511756117571175811759117601176111762117631176411765117661176711768117691177011771117721177311774117751177611777117781177911780117811178211783117841178511786117871178811789117901179111792117931179411795117961179711798117991180011801118021180311804118051180611807118081180911810118111181211813118141181511816118171181811819118201182111822118231182411825118261182711828118291183011831118321183311834118351183611837118381183911840118411184211843118441184511846118471184811849118501185111852118531185411855118561185711858118591186011861118621186311864118651186611867118681186911870118711187211873118741187511876118771187811879118801188111882118831188411885118861188711888118891189011891118921189311894118951189611897118981189911900119011190211903119041190511906119071190811909119101191111912119131191411915119161191711918119191192011921119221192311924119251192611927119281192911930119311193211933119341193511936119371193811939119401194111942119431194411945119461194711948119491195011951119521195311954119551195611957119581195911960119611196211963119641196511966119671196811969119701197111972119731197411975119761197711978119791198011981119821198311984119851198611987119881198911990119911199211993119941199511996119971199811999120001200112002120031200412005120061200712008120091201012011120121201312014120151201612017120181201912020120211202212023120241202512026120271202812029120301203112032120331203412035120361203712038120391204012041120421204312044120451204612047120481204912050120511205212053120541205512056120571205812059120601206112062120631206412065120661206712068120691207012071120721207312074120751207612077120781207912080120811208212083120841208512086120871208812089120901209112092120931209412095120961209712098120991210012101121021210312104121051210612107121081210912110121111211212113121141211512116121171211812119121201212112122121231212412125121261212712128121291213012131121321213312134121351213612137121381213912140121411214212143121441214512146121471214812149121501215112152121531215412155121561215712158121591216012161121621216312164121651216612167121681216912170121711217212173121741217512176121771217812179121801218112182121831218412185121861218712188121891219012191121921219312194121951219612197121981219912200122011220212203122041220512206122071220812209122101221112212122131221412215122161221712218122191222012221122221222312224122251222612227122281222912230122311223212233122341223512236122371223812239122401224112242122431224412245122461224712248122491225012251122521225312254122551225612257122581225912260122611226212263122641226512266122671226812269122701227112272122731227412275122761227712278122791228012281122821228312284122851228612287122881228912290122911229212293122941229512296122971229812299123001230112302123031230412305123061230712308123091231012311123121231312314123151231612317123181231912320123211232212323123241232512326123271232812329123301233112332123331233412335123361233712338123391234012341123421234312344123451234612347123481234912350123511235212353123541235512356123571235812359123601236112362123631236412365123661236712368123691237012371123721237312374123751237612377123781237912380123811238212383123841238512386123871238812389123901239112392123931239412395123961239712398123991240012401124021240312404124051240612407124081240912410124111241212413124141241512416124171241812419124201242112422124231242412425124261242712428124291243012431124321243312434124351243612437124381243912440124411244212443124441244512446124471244812449124501245112452124531245412455124561245712458124591246012461124621246312464124651246612467124681246912470124711247212473124741247512476124771247812479124801248112482124831248412485124861248712488124891249012491124921249312494124951249612497124981249912500125011250212503125041250512506125071250812509125101251112512125131251412515125161251712518125191252012521125221252312524125251252612527125281252912530125311253212533125341253512536125371253812539125401254112542125431254412545125461254712548125491255012551125521255312554125551255612557125581255912560125611256212563125641256512566125671256812569125701257112572125731257412575125761257712578125791258012581125821258312584125851258612587125881258912590125911259212593125941259512596125971259812599126001260112602126031260412605126061260712608126091261012611126121261312614126151261612617126181261912620126211262212623126241262512626126271262812629126301263112632126331263412635126361263712638126391264012641126421264312644126451264612647126481264912650126511265212653126541265512656126571265812659126601266112662126631266412665126661266712668126691267012671126721267312674126751267612677126781267912680126811268212683126841268512686126871268812689126901269112692126931269412695126961269712698126991270012701127021270312704127051270612707127081270912710127111271212713127141271512716127171271812719127201272112722127231272412725127261272712728127291273012731127321273312734127351273612737127381273912740127411274212743127441274512746127471274812749127501275112752127531275412755127561275712758127591276012761127621276312764127651276612767127681276912770127711277212773127741277512776127771277812779127801278112782127831278412785127861278712788127891279012791127921279312794127951279612797127981279912800128011280212803128041280512806128071280812809128101281112812128131281412815128161281712818128191282012821128221282312824128251282612827128281282912830128311283212833128341283512836128371283812839128401284112842128431284412845128461284712848128491285012851128521285312854128551285612857128581285912860128611286212863128641286512866128671286812869128701287112872128731287412875128761287712878128791288012881128821288312884128851288612887128881288912890128911289212893128941289512896128971289812899129001290112902129031290412905129061290712908129091291012911129121291312914129151291612917129181291912920129211292212923129241292512926129271292812929129301293112932129331293412935129361293712938129391294012941129421294312944129451294612947129481294912950129511295212953129541295512956129571295812959129601296112962129631296412965129661296712968129691297012971129721297312974129751297612977129781297912980129811298212983129841298512986129871298812989129901299112992129931299412995129961299712998129991300013001130021300313004130051300613007130081300913010130111301213013130141301513016130171301813019130201302113022130231302413025130261302713028130291303013031130321303313034130351303613037130381303913040130411304213043130441304513046130471304813049130501305113052130531305413055130561305713058130591306013061130621306313064130651306613067130681306913070130711307213073130741307513076130771307813079130801308113082130831308413085130861308713088130891309013091130921309313094130951309613097130981309913100131011310213103131041310513106131071310813109131101311113112131131311413115131161311713118131191312013121131221312313124131251312613127131281312913130131311313213133131341313513136131371313813139131401314113142131431314413145131461314713148131491315013151131521315313154131551315613157131581315913160131611316213163131641316513166131671316813169131701317113172131731317413175131761317713178131791318013181131821318313184131851318613187131881318913190131911319213193131941319513196131971319813199132001320113202132031320413205132061320713208132091321013211132121321313214132151321613217132181321913220132211322213223132241322513226132271322813229132301323113232132331323413235132361323713238132391324013241132421324313244132451324613247132481324913250132511325213253132541325513256132571325813259132601326113262132631326413265132661326713268132691327013271132721327313274132751327613277132781327913280132811328213283132841328513286132871328813289132901329113292132931329413295132961329713298132991330013301133021330313304133051330613307133081330913310133111331213313133141331513316133171331813319133201332113322133231332413325133261332713328133291333013331133321333313334133351333613337133381333913340133411334213343133441334513346133471334813349133501335113352133531335413355133561335713358133591336013361133621336313364133651336613367133681336913370133711337213373133741337513376133771337813379133801338113382133831338413385133861338713388133891339013391133921339313394133951339613397133981339913400134011340213403134041340513406134071340813409134101341113412134131341413415134161341713418134191342013421134221342313424134251342613427134281342913430134311343213433134341343513436134371343813439134401344113442134431344413445134461344713448134491345013451134521345313454134551345613457134581345913460134611346213463134641346513466134671346813469134701347113472134731347413475134761347713478134791348013481134821348313484134851348613487134881348913490134911349213493134941349513496134971349813499135001350113502135031350413505135061350713508135091351013511135121351313514135151351613517135181351913520135211352213523135241352513526135271352813529135301353113532135331353413535135361353713538135391354013541135421354313544135451354613547135481354913550135511355213553135541355513556135571355813559135601356113562135631356413565135661356713568135691357013571135721357313574135751357613577135781357913580135811358213583135841358513586135871358813589135901359113592135931359413595135961359713598135991360013601136021360313604136051360613607136081360913610136111361213613136141361513616136171361813619136201362113622136231362413625136261362713628136291363013631136321363313634136351363613637136381363913640136411364213643136441364513646136471364813649136501365113652136531365413655136561365713658136591366013661136621366313664136651366613667136681366913670136711367213673136741367513676136771367813679136801368113682136831368413685136861368713688136891369013691136921369313694136951369613697136981369913700137011370213703137041370513706137071370813709137101371113712137131371413715137161371713718137191372013721137221372313724137251372613727137281372913730137311373213733137341373513736137371373813739137401374113742137431374413745137461374713748137491375013751137521375313754137551375613757137581375913760137611376213763137641376513766137671376813769137701377113772137731377413775137761377713778137791378013781137821378313784137851378613787137881378913790137911379213793137941379513796137971379813799138001380113802138031380413805138061380713808138091381013811138121381313814138151381613817138181381913820138211382213823138241382513826138271382813829138301383113832138331383413835138361383713838138391384013841138421384313844138451384613847138481384913850138511385213853138541385513856138571385813859138601386113862138631386413865138661386713868138691387013871138721387313874138751387613877138781387913880138811388213883138841388513886138871388813889138901389113892138931389413895138961389713898138991390013901139021390313904139051390613907139081390913910139111391213913139141391513916139171391813919139201392113922139231392413925139261392713928139291393013931139321393313934139351393613937139381393913940139411394213943139441394513946139471394813949139501395113952139531395413955139561395713958139591396013961139621396313964139651396613967139681396913970139711397213973139741397513976139771397813979139801398113982139831398413985139861398713988139891399013991139921399313994139951399613997139981399914000140011400214003140041400514006140071400814009140101401114012140131401414015140161401714018140191402014021140221402314024140251402614027140281402914030140311403214033140341403514036140371403814039140401404114042140431404414045140461404714048140491405014051140521405314054140551405614057140581405914060140611406214063140641406514066140671406814069140701407114072140731407414075140761407714078140791408014081140821408314084140851408614087140881408914090140911409214093140941409514096140971409814099141001410114102141031410414105141061410714108141091411014111141121411314114141151411614117141181411914120141211412214123141241412514126141271412814129141301413114132141331413414135141361413714138141391414014141141421414314144141451414614147141481414914150141511415214153141541415514156141571415814159141601416114162141631416414165141661416714168141691417014171141721417314174141751417614177141781417914180141811418214183141841418514186141871418814189141901419114192141931419414195141961419714198141991420014201142021420314204142051420614207142081420914210142111421214213142141421514216142171421814219142201422114222142231422414225142261422714228142291423014231142321423314234142351423614237142381423914240142411424214243142441424514246142471424814249142501425114252142531425414255142561425714258142591426014261142621426314264142651426614267142681426914270142711427214273142741427514276142771427814279142801428114282142831428414285142861428714288142891429014291142921429314294142951429614297142981429914300143011430214303143041430514306143071430814309143101431114312143131431414315143161431714318143191432014321143221432314324143251432614327143281432914330143311433214333143341433514336143371433814339143401434114342143431434414345143461434714348143491435014351143521435314354143551435614357143581435914360143611436214363143641436514366143671436814369143701437114372143731437414375143761437714378143791438014381143821438314384143851438614387143881438914390143911439214393143941439514396143971439814399144001440114402144031440414405144061440714408144091441014411144121441314414144151441614417144181441914420144211442214423144241442514426144271442814429144301443114432144331443414435144361443714438144391444014441144421444314444144451444614447144481444914450144511445214453144541445514456144571445814459144601446114462144631446414465144661446714468144691447014471144721447314474144751447614477144781447914480144811448214483144841448514486144871448814489144901449114492144931449414495144961449714498144991450014501145021450314504145051450614507145081450914510145111451214513145141451514516145171451814519145201452114522145231452414525145261452714528145291453014531145321453314534145351453614537145381453914540145411454214543145441454514546145471454814549145501455114552145531455414555145561455714558145591456014561145621456314564145651456614567145681456914570145711457214573145741457514576145771457814579145801458114582145831458414585145861458714588145891459014591145921459314594145951459614597145981459914600146011460214603146041460514606146071460814609146101461114612146131461414615146161461714618146191462014621146221462314624146251462614627146281462914630146311463214633146341463514636146371463814639146401464114642146431464414645146461464714648146491465014651146521465314654146551465614657146581465914660146611466214663146641466514666146671466814669146701467114672146731467414675146761467714678146791468014681146821468314684146851468614687146881468914690146911469214693146941469514696146971469814699147001470114702147031470414705147061470714708147091471014711147121471314714147151471614717147181471914720147211472214723147241472514726147271472814729147301473114732147331473414735147361473714738147391474014741147421474314744147451474614747147481474914750147511475214753147541475514756147571475814759147601476114762147631476414765147661476714768147691477014771147721477314774147751477614777147781477914780147811478214783147841478514786147871478814789147901479114792147931479414795147961479714798147991480014801148021480314804148051480614807148081480914810148111481214813148141481514816148171481814819148201482114822148231482414825148261482714828148291483014831148321483314834148351483614837148381483914840148411484214843148441484514846148471484814849148501485114852148531485414855148561485714858148591486014861148621486314864148651486614867148681486914870148711487214873148741487514876148771487814879148801488114882148831488414885148861488714888148891489014891148921489314894148951489614897148981489914900149011490214903149041490514906149071490814909149101491114912149131491414915149161491714918149191492014921149221492314924149251492614927149281492914930149311493214933149341493514936149371493814939149401494114942149431494414945149461494714948149491495014951149521495314954149551495614957149581495914960149611496214963149641496514966149671496814969149701497114972149731497414975149761497714978149791498014981149821498314984149851498614987149881498914990149911499214993149941499514996149971499814999150001500115002150031500415005150061500715008150091501015011150121501315014150151501615017150181501915020150211502215023150241502515026150271502815029150301503115032150331503415035150361503715038150391504015041150421504315044150451504615047150481504915050150511505215053150541505515056150571505815059150601506115062150631506415065150661506715068150691507015071150721507315074150751507615077150781507915080150811508215083150841508515086150871508815089150901509115092150931509415095150961509715098150991510015101151021510315104151051510615107151081510915110151111511215113151141511515116151171511815119151201512115122151231512415125151261512715128151291513015131151321513315134151351513615137151381513915140151411514215143151441514515146151471514815149151501515115152151531515415155151561515715158151591516015161151621516315164151651516615167151681516915170151711517215173151741517515176151771517815179151801518115182151831518415185151861518715188151891519015191151921519315194151951519615197151981519915200152011520215203152041520515206152071520815209152101521115212152131521415215152161521715218152191522015221152221522315224152251522615227152281522915230152311523215233152341523515236152371523815239152401524115242152431524415245152461524715248152491525015251152521525315254152551525615257152581525915260152611526215263152641526515266152671526815269152701527115272152731527415275152761527715278152791528015281152821528315284152851528615287152881528915290152911529215293152941529515296152971529815299153001530115302153031530415305153061530715308153091531015311153121531315314153151531615317153181531915320153211532215323153241532515326153271532815329153301533115332153331533415335153361533715338153391534015341153421534315344153451534615347153481534915350153511535215353153541535515356153571535815359153601536115362153631536415365153661536715368153691537015371153721537315374153751537615377153781537915380153811538215383153841538515386153871538815389153901539115392153931539415395153961539715398153991540015401154021540315404154051540615407154081540915410154111541215413154141541515416154171541815419154201542115422154231542415425154261542715428154291543015431154321543315434154351543615437154381543915440154411544215443154441544515446154471544815449154501545115452154531545415455154561545715458154591546015461154621546315464154651546615467154681546915470154711547215473154741547515476154771547815479154801548115482154831548415485154861548715488154891549015491154921549315494154951549615497154981549915500155011550215503155041550515506155071550815509155101551115512155131551415515155161551715518155191552015521155221552315524155251552615527155281552915530155311553215533155341553515536155371553815539155401554115542155431554415545155461554715548155491555015551155521555315554155551555615557155581555915560155611556215563155641556515566155671556815569155701557115572155731557415575155761557715578155791558015581155821558315584155851558615587155881558915590155911559215593155941559515596155971559815599156001560115602156031560415605156061560715608156091561015611156121561315614156151561615617156181561915620156211562215623156241562515626156271562815629156301563115632156331563415635156361563715638156391564015641156421564315644156451564615647156481564915650156511565215653156541565515656156571565815659156601566115662156631566415665156661566715668156691567015671156721567315674156751567615677156781567915680156811568215683156841568515686156871568815689156901569115692156931569415695156961569715698156991570015701157021570315704157051570615707157081570915710157111571215713157141571515716157171571815719157201572115722157231572415725157261572715728157291573015731157321573315734157351573615737157381573915740157411574215743157441574515746157471574815749157501575115752157531575415755157561575715758157591576015761157621576315764157651576615767157681576915770157711577215773157741577515776157771577815779157801578115782157831578415785157861578715788157891579015791157921579315794157951579615797157981579915800158011580215803158041580515806158071580815809158101581115812158131581415815158161581715818158191582015821158221582315824158251582615827158281582915830158311583215833158341583515836158371583815839158401584115842158431584415845158461584715848158491585015851158521585315854158551585615857158581585915860158611586215863158641586515866158671586815869158701587115872158731587415875158761587715878158791588015881158821588315884158851588615887158881588915890158911589215893158941589515896158971589815899159001590115902159031590415905159061590715908159091591015911159121591315914159151591615917159181591915920159211592215923159241592515926159271592815929159301593115932159331593415935159361593715938159391594015941159421594315944159451594615947159481594915950159511595215953159541595515956159571595815959159601596115962159631596415965159661596715968159691597015971159721597315974159751597615977159781597915980159811598215983159841598515986159871598815989159901599115992159931599415995159961599715998159991600016001160021600316004160051600616007160081600916010160111601216013160141601516016160171601816019160201602116022160231602416025160261602716028160291603016031160321603316034160351603616037160381603916040160411604216043160441604516046160471604816049160501605116052160531605416055160561605716058160591606016061160621606316064160651606616067160681606916070160711607216073160741607516076160771607816079160801608116082160831608416085160861608716088160891609016091160921609316094160951609616097160981609916100161011610216103161041610516106161071610816109161101611116112161131611416115161161611716118161191612016121161221612316124161251612616127161281612916130161311613216133161341613516136161371613816139161401614116142161431614416145161461614716148161491615016151161521615316154161551615616157161581615916160161611616216163161641616516166161671616816169161701617116172161731617416175161761617716178161791618016181161821618316184161851618616187161881618916190161911619216193161941619516196161971619816199162001620116202162031620416205162061620716208162091621016211162121621316214162151621616217162181621916220162211622216223162241622516226162271622816229162301623116232162331623416235162361623716238162391624016241162421624316244162451624616247162481624916250162511625216253162541625516256162571625816259162601626116262162631626416265162661626716268162691627016271162721627316274162751627616277162781627916280162811628216283162841628516286162871628816289162901629116292162931629416295162961629716298162991630016301163021630316304163051630616307163081630916310163111631216313163141631516316163171631816319163201632116322163231632416325163261632716328163291633016331163321633316334163351633616337163381633916340163411634216343163441634516346163471634816349163501635116352163531635416355163561635716358163591636016361163621636316364163651636616367163681636916370163711637216373163741637516376163771637816379163801638116382163831638416385163861638716388163891639016391163921639316394163951639616397163981639916400164011640216403164041640516406164071640816409164101641116412164131641416415164161641716418164191642016421164221642316424164251642616427164281642916430164311643216433164341643516436164371643816439164401644116442164431644416445164461644716448164491645016451164521645316454164551645616457164581645916460164611646216463164641646516466164671646816469164701647116472164731647416475164761647716478164791648016481164821648316484164851648616487164881648916490164911649216493164941649516496164971649816499165001650116502165031650416505165061650716508165091651016511165121651316514165151651616517165181651916520165211652216523165241652516526165271652816529165301653116532165331653416535165361653716538165391654016541165421654316544165451654616547165481654916550165511655216553165541655516556165571655816559165601656116562165631656416565165661656716568165691657016571165721657316574165751657616577165781657916580165811658216583165841658516586165871658816589165901659116592165931659416595165961659716598165991660016601166021660316604166051660616607166081660916610166111661216613166141661516616166171661816619166201662116622166231662416625166261662716628166291663016631166321663316634166351663616637166381663916640166411664216643166441664516646166471664816649166501665116652166531665416655166561665716658166591666016661166621666316664166651666616667166681666916670166711667216673166741667516676166771667816679166801668116682166831668416685166861668716688166891669016691166921669316694166951669616697166981669916700167011670216703167041670516706167071670816709167101671116712167131671416715167161671716718167191672016721167221672316724167251672616727167281672916730167311673216733167341673516736167371673816739167401674116742167431674416745167461674716748167491675016751167521675316754167551675616757167581675916760167611676216763167641676516766167671676816769167701677116772167731677416775167761677716778167791678016781167821678316784167851678616787167881678916790167911679216793167941679516796167971679816799168001680116802168031680416805168061680716808168091681016811168121681316814168151681616817168181681916820168211682216823168241682516826168271682816829168301683116832168331683416835168361683716838168391684016841168421684316844168451684616847168481684916850168511685216853168541685516856168571685816859168601686116862168631686416865168661686716868168691687016871168721687316874168751687616877168781687916880168811688216883168841688516886168871688816889168901689116892168931689416895168961689716898168991690016901169021690316904169051690616907169081690916910169111691216913169141691516916169171691816919169201692116922169231692416925169261692716928169291693016931169321693316934169351693616937169381693916940169411694216943169441694516946169471694816949169501695116952169531695416955169561695716958169591696016961169621696316964169651696616967169681696916970169711697216973169741697516976169771697816979169801698116982169831698416985169861698716988169891699016991169921699316994169951699616997169981699917000170011700217003170041700517006170071700817009170101701117012170131701417015170161701717018170191702017021170221702317024170251702617027170281702917030170311703217033170341703517036170371703817039170401704117042170431704417045170461704717048170491705017051170521705317054170551705617057170581705917060170611706217063170641706517066170671706817069170701707117072170731707417075170761707717078170791708017081170821708317084170851708617087170881708917090170911709217093170941709517096170971709817099171001710117102171031710417105171061710717108171091711017111171121711317114171151711617117171181711917120171211712217123171241712517126171271712817129171301713117132171331713417135171361713717138171391714017141171421714317144171451714617147171481714917150171511715217153171541715517156171571715817159171601716117162171631716417165171661716717168171691717017171171721717317174171751717617177171781717917180171811718217183171841718517186171871718817189171901719117192171931719417195171961719717198171991720017201172021720317204172051720617207172081720917210172111721217213172141721517216172171721817219172201722117222172231722417225172261722717228172291723017231172321723317234172351723617237172381723917240172411724217243172441724517246172471724817249172501725117252172531725417255172561725717258172591726017261172621726317264172651726617267172681726917270172711727217273172741727517276172771727817279172801728117282172831728417285172861728717288172891729017291172921729317294172951729617297172981729917300173011730217303173041730517306173071730817309173101731117312173131731417315173161731717318173191732017321173221732317324173251732617327173281732917330173311733217333173341733517336173371733817339173401734117342173431734417345173461734717348173491735017351173521735317354173551735617357173581735917360173611736217363173641736517366173671736817369173701737117372173731737417375173761737717378173791738017381173821738317384173851738617387173881738917390173911739217393173941739517396173971739817399174001740117402174031740417405174061740717408174091741017411174121741317414174151741617417174181741917420174211742217423174241742517426174271742817429174301743117432174331743417435174361743717438174391744017441174421744317444174451744617447174481744917450174511745217453174541745517456174571745817459174601746117462174631746417465174661746717468174691747017471174721747317474174751747617477174781747917480174811748217483174841748517486174871748817489174901749117492174931749417495174961749717498174991750017501175021750317504175051750617507175081750917510175111751217513175141751517516175171751817519175201752117522175231752417525175261752717528175291753017531175321753317534175351753617537175381753917540175411754217543175441754517546175471754817549175501755117552175531755417555175561755717558175591756017561175621756317564175651756617567175681756917570175711757217573175741757517576175771757817579175801758117582175831758417585175861758717588175891759017591175921759317594175951759617597175981759917600176011760217603176041760517606176071760817609176101761117612176131761417615176161761717618176191762017621176221762317624176251762617627176281762917630176311763217633176341763517636176371763817639176401764117642176431764417645176461764717648176491765017651176521765317654176551765617657176581765917660176611766217663176641766517666176671766817669176701767117672176731767417675176761767717678176791768017681176821768317684176851768617687176881768917690176911769217693176941769517696176971769817699177001770117702177031770417705177061770717708177091771017711177121771317714177151771617717177181771917720177211772217723177241772517726177271772817729177301773117732177331773417735177361773717738177391774017741177421774317744177451774617747177481774917750177511775217753177541775517756177571775817759177601776117762177631776417765177661776717768177691777017771177721777317774177751777617777177781777917780177811778217783177841778517786177871778817789177901779117792177931779417795177961779717798177991780017801178021780317804178051780617807178081780917810178111781217813178141781517816178171781817819178201782117822178231782417825178261782717828178291783017831178321783317834178351783617837178381783917840178411784217843178441784517846178471784817849178501785117852178531785417855178561785717858178591786017861178621786317864178651786617867178681786917870178711787217873178741787517876178771787817879178801788117882178831788417885178861788717888178891789017891178921789317894178951789617897178981789917900179011790217903179041790517906179071790817909179101791117912179131791417915179161791717918179191792017921179221792317924179251792617927179281792917930179311793217933179341793517936179371793817939179401794117942179431794417945179461794717948179491795017951179521795317954179551795617957179581795917960179611796217963179641796517966179671796817969179701797117972179731797417975179761797717978179791798017981179821798317984179851798617987179881798917990179911799217993179941799517996179971799817999180001800118002180031800418005180061800718008180091801018011180121801318014180151801618017180181801918020180211802218023180241802518026180271802818029180301803118032180331803418035180361803718038180391804018041180421804318044180451804618047180481804918050180511805218053180541805518056180571805818059180601806118062180631806418065180661806718068180691807018071180721807318074180751807618077180781807918080180811808218083180841808518086180871808818089180901809118092180931809418095180961809718098180991810018101181021810318104181051810618107181081810918110181111811218113181141811518116181171811818119181201812118122181231812418125181261812718128181291813018131181321813318134181351813618137181381813918140181411814218143181441814518146181471814818149181501815118152181531815418155181561815718158181591816018161181621816318164181651816618167181681816918170181711817218173181741817518176181771817818179181801818118182181831818418185181861818718188181891819018191181921819318194181951819618197181981819918200182011820218203182041820518206182071820818209182101821118212182131821418215182161821718218182191822018221182221822318224182251822618227182281822918230182311823218233182341823518236182371823818239182401824118242182431824418245182461824718248182491825018251182521825318254182551825618257182581825918260182611826218263182641826518266182671826818269182701827118272182731827418275182761827718278182791828018281182821828318284182851828618287182881828918290182911829218293182941829518296182971829818299183001830118302183031830418305183061830718308183091831018311183121831318314183151831618317183181831918320183211832218323183241832518326183271832818329183301833118332183331833418335183361833718338183391834018341183421834318344183451834618347183481834918350183511835218353183541835518356183571835818359183601836118362183631836418365183661836718368183691837018371183721837318374183751837618377183781837918380183811838218383183841838518386183871838818389183901839118392183931839418395183961839718398183991840018401184021840318404184051840618407184081840918410184111841218413184141841518416184171841818419184201842118422184231842418425184261842718428184291843018431184321843318434184351843618437184381843918440184411844218443184441844518446184471844818449184501845118452184531845418455184561845718458184591846018461184621846318464184651846618467184681846918470184711847218473184741847518476184771847818479184801848118482184831848418485184861848718488184891849018491184921849318494184951849618497184981849918500185011850218503185041850518506185071850818509185101851118512185131851418515185161851718518185191852018521185221852318524185251852618527185281852918530185311853218533185341853518536185371853818539185401854118542185431854418545185461854718548185491855018551185521855318554185551855618557185581855918560185611856218563185641856518566185671856818569185701857118572185731857418575185761857718578185791858018581185821858318584185851858618587185881858918590185911859218593185941859518596185971859818599186001860118602186031860418605186061860718608186091861018611186121861318614186151861618617186181861918620186211862218623186241862518626186271862818629186301863118632186331863418635186361863718638186391864018641186421864318644186451864618647186481864918650186511865218653186541865518656186571865818659186601866118662186631866418665186661866718668186691867018671186721867318674186751867618677186781867918680186811868218683186841868518686186871868818689186901869118692186931869418695186961869718698186991870018701187021870318704187051870618707187081870918710187111871218713187141871518716187171871818719187201872118722187231872418725187261872718728187291873018731187321873318734187351873618737187381873918740187411874218743187441874518746187471874818749187501875118752187531875418755187561875718758187591876018761187621876318764187651876618767187681876918770187711877218773187741877518776187771877818779187801878118782187831878418785187861878718788187891879018791187921879318794187951879618797187981879918800188011880218803188041880518806188071880818809188101881118812188131881418815188161881718818188191882018821188221882318824188251882618827188281882918830188311883218833188341883518836188371883818839188401884118842188431884418845188461884718848188491885018851188521885318854188551885618857188581885918860188611886218863188641886518866188671886818869188701887118872188731887418875188761887718878188791888018881188821888318884188851888618887188881888918890188911889218893188941889518896188971889818899189001890118902189031890418905189061890718908189091891018911189121891318914189151891618917189181891918920189211892218923189241892518926189271892818929189301893118932189331893418935189361893718938189391894018941189421894318944189451894618947189481894918950189511895218953189541895518956189571895818959189601896118962189631896418965189661896718968189691897018971189721897318974189751897618977189781897918980189811898218983189841898518986189871898818989189901899118992189931899418995189961899718998189991900019001190021900319004190051900619007190081900919010190111901219013190141901519016190171901819019190201902119022190231902419025190261902719028190291903019031190321903319034190351903619037190381903919040190411904219043190441904519046190471904819049190501905119052190531905419055190561905719058190591906019061190621906319064190651906619067190681906919070190711907219073190741907519076190771907819079190801908119082190831908419085190861908719088190891909019091190921909319094190951909619097190981909919100191011910219103191041910519106191071910819109191101911119112191131911419115191161911719118191191912019121191221912319124191251912619127191281912919130191311913219133191341913519136191371913819139191401914119142191431914419145191461914719148191491915019151191521915319154191551915619157191581915919160191611916219163191641916519166191671916819169191701917119172191731917419175191761917719178191791918019181191821918319184191851918619187191881918919190191911919219193191941919519196191971919819199192001920119202192031920419205192061920719208192091921019211192121921319214192151921619217192181921919220192211922219223192241922519226192271922819229192301923119232192331923419235192361923719238192391924019241192421924319244192451924619247192481924919250192511925219253192541925519256192571925819259192601926119262192631926419265192661926719268192691927019271192721927319274192751927619277192781927919280192811928219283192841928519286192871928819289192901929119292192931929419295192961929719298192991930019301193021930319304193051930619307193081930919310193111931219313193141931519316193171931819319193201932119322193231932419325193261932719328193291933019331193321933319334193351933619337193381933919340193411934219343193441934519346193471934819349193501935119352193531935419355193561935719358193591936019361193621936319364193651936619367193681936919370193711937219373193741937519376193771937819379193801938119382193831938419385193861938719388193891939019391193921939319394193951939619397193981939919400194011940219403194041940519406194071940819409194101941119412194131941419415194161941719418194191942019421194221942319424194251942619427194281942919430194311943219433194341943519436194371943819439194401944119442194431944419445194461944719448194491945019451194521945319454194551945619457194581945919460194611946219463194641946519466194671946819469194701947119472194731947419475194761947719478194791948019481194821948319484194851948619487194881948919490194911949219493194941949519496194971949819499195001950119502195031950419505195061950719508195091951019511195121951319514195151951619517195181951919520195211952219523195241952519526195271952819529195301953119532195331953419535195361953719538195391954019541195421954319544195451954619547195481954919550195511955219553195541955519556195571955819559195601956119562195631956419565195661956719568195691957019571195721957319574195751957619577195781957919580195811958219583195841958519586195871958819589195901959119592195931959419595195961959719598195991960019601196021960319604196051960619607196081960919610196111961219613196141961519616196171961819619196201962119622196231962419625196261962719628196291963019631196321963319634196351963619637196381963919640196411964219643196441964519646196471964819649196501965119652196531965419655196561965719658196591966019661196621966319664196651966619667196681966919670196711967219673196741967519676196771967819679196801968119682196831968419685196861968719688196891969019691196921969319694196951969619697196981969919700197011970219703197041970519706197071970819709197101971119712197131971419715197161971719718197191972019721197221972319724197251972619727197281972919730197311973219733197341973519736197371973819739197401974119742197431974419745197461974719748197491975019751197521975319754197551975619757197581975919760197611976219763197641976519766197671976819769197701977119772197731977419775197761977719778197791978019781197821978319784197851978619787197881978919790197911979219793197941979519796197971979819799198001980119802198031980419805198061980719808198091981019811198121981319814198151981619817198181981919820198211982219823198241982519826198271982819829198301983119832198331983419835198361983719838198391984019841198421984319844198451984619847198481984919850198511985219853198541985519856198571985819859198601986119862198631986419865198661986719868198691987019871198721987319874198751987619877198781987919880198811988219883198841988519886198871988819889198901989119892198931989419895198961989719898198991990019901199021990319904199051990619907199081990919910199111991219913199141991519916199171991819919199201992119922199231992419925199261992719928199291993019931199321993319934199351993619937199381993919940199411994219943199441994519946199471994819949199501995119952199531995419955199561995719958199591996019961199621996319964199651996619967199681996919970199711997219973199741997519976199771997819979199801998119982199831998419985199861998719988199891999019991199921999319994199951999619997199981999920000200012000220003200042000520006200072000820009200102001120012200132001420015200162001720018200192002020021200222002320024200252002620027200282002920030200312003220033200342003520036200372003820039200402004120042200432004420045200462004720048200492005020051200522005320054200552005620057200582005920060200612006220063200642006520066200672006820069200702007120072200732007420075200762007720078200792008020081200822008320084200852008620087200882008920090200912009220093200942009520096200972009820099201002010120102201032010420105201062010720108201092011020111201122011320114201152011620117201182011920120201212012220123201242012520126201272012820129201302013120132201332013420135201362013720138201392014020141201422014320144201452014620147201482014920150201512015220153201542015520156201572015820159201602016120162201632016420165201662016720168201692017020171201722017320174201752017620177201782017920180201812018220183201842018520186201872018820189201902019120192201932019420195201962019720198201992020020201202022020320204202052020620207202082020920210202112021220213202142021520216202172021820219202202022120222202232022420225202262022720228202292023020231202322023320234202352023620237202382023920240202412024220243202442024520246202472024820249202502025120252202532025420255202562025720258202592026020261202622026320264202652026620267202682026920270202712027220273202742027520276202772027820279202802028120282202832028420285202862028720288202892029020291202922029320294202952029620297202982029920300203012030220303203042030520306203072030820309203102031120312203132031420315203162031720318203192032020321203222032320324203252032620327203282032920330203312033220333203342033520336203372033820339203402034120342203432034420345203462034720348203492035020351203522035320354203552035620357203582035920360203612036220363203642036520366203672036820369203702037120372203732037420375203762037720378203792038020381203822038320384203852038620387203882038920390203912039220393203942039520396203972039820399204002040120402204032040420405204062040720408204092041020411204122041320414204152041620417204182041920420204212042220423204242042520426204272042820429204302043120432204332043420435204362043720438204392044020441204422044320444204452044620447204482044920450204512045220453204542045520456204572045820459204602046120462204632046420465204662046720468204692047020471204722047320474204752047620477204782047920480204812048220483204842048520486204872048820489204902049120492204932049420495204962049720498204992050020501205022050320504205052050620507205082050920510205112051220513205142051520516205172051820519205202052120522205232052420525205262052720528205292053020531205322053320534205352053620537205382053920540205412054220543205442054520546205472054820549205502055120552205532055420555205562055720558205592056020561205622056320564205652056620567205682056920570205712057220573205742057520576205772057820579205802058120582205832058420585205862058720588205892059020591205922059320594205952059620597205982059920600206012060220603206042060520606206072060820609206102061120612206132061420615206162061720618206192062020621206222062320624206252062620627206282062920630206312063220633206342063520636206372063820639206402064120642206432064420645206462064720648206492065020651206522065320654206552065620657206582065920660206612066220663206642066520666206672066820669206702067120672206732067420675206762067720678206792068020681206822068320684206852068620687206882068920690206912069220693206942069520696206972069820699207002070120702207032070420705207062070720708207092071020711207122071320714207152071620717207182071920720207212072220723207242072520726207272072820729207302073120732207332073420735207362073720738207392074020741207422074320744207452074620747207482074920750207512075220753207542075520756207572075820759207602076120762207632076420765207662076720768207692077020771207722077320774207752077620777207782077920780207812078220783207842078520786207872078820789207902079120792207932079420795207962079720798207992080020801208022080320804208052080620807208082080920810208112081220813208142081520816208172081820819208202082120822208232082420825208262082720828208292083020831208322083320834208352083620837208382083920840208412084220843208442084520846208472084820849208502085120852208532085420855208562085720858208592086020861208622086320864208652086620867208682086920870208712087220873208742087520876208772087820879208802088120882208832088420885208862088720888208892089020891208922089320894208952089620897208982089920900209012090220903209042090520906209072090820909209102091120912209132091420915209162091720918209192092020921209222092320924209252092620927209282092920930209312093220933209342093520936209372093820939209402094120942209432094420945209462094720948209492095020951209522095320954209552095620957209582095920960209612096220963209642096520966209672096820969209702097120972209732097420975209762097720978209792098020981209822098320984209852098620987209882098920990209912099220993209942099520996209972099820999210002100121002210032100421005210062100721008210092101021011210122101321014210152101621017210182101921020210212102221023210242102521026210272102821029210302103121032210332103421035210362103721038210392104021041210422104321044210452104621047210482104921050210512105221053210542105521056210572105821059210602106121062210632106421065210662106721068210692107021071210722107321074210752107621077210782107921080210812108221083210842108521086210872108821089210902109121092210932109421095210962109721098210992110021101211022110321104211052110621107211082110921110211112111221113211142111521116211172111821119211202112121122211232112421125211262112721128211292113021131211322113321134211352113621137211382113921140211412114221143211442114521146211472114821149211502115121152211532115421155211562115721158211592116021161211622116321164211652116621167211682116921170211712117221173211742117521176211772117821179211802118121182211832118421185211862118721188211892119021191211922119321194211952119621197211982119921200212012120221203212042120521206212072120821209212102121121212212132121421215212162121721218212192122021221212222122321224212252122621227212282122921230212312123221233212342123521236212372123821239212402124121242212432124421245212462124721248212492125021251212522125321254212552125621257212582125921260212612126221263212642126521266212672126821269212702127121272212732127421275212762127721278212792128021281212822128321284212852128621287212882128921290212912129221293212942129521296212972129821299213002130121302213032130421305213062130721308213092131021311213122131321314213152131621317213182131921320213212132221323213242132521326213272132821329213302133121332213332133421335213362133721338213392134021341213422134321344213452134621347213482134921350213512135221353213542135521356213572135821359213602136121362213632136421365213662136721368213692137021371213722137321374213752137621377213782137921380213812138221383213842138521386213872138821389213902139121392213932139421395213962139721398213992140021401214022140321404214052140621407214082140921410214112141221413214142141521416214172141821419214202142121422214232142421425214262142721428214292143021431214322143321434214352143621437214382143921440214412144221443214442144521446214472144821449214502145121452214532145421455214562145721458214592146021461214622146321464214652146621467214682146921470214712147221473214742147521476214772147821479214802148121482214832148421485214862148721488214892149021491214922149321494214952149621497214982149921500215012150221503215042150521506215072150821509215102151121512215132151421515215162151721518215192152021521215222152321524215252152621527215282152921530215312153221533215342153521536215372153821539215402154121542215432154421545215462154721548215492155021551215522155321554215552155621557215582155921560215612156221563215642156521566215672156821569215702157121572215732157421575215762157721578215792158021581215822158321584215852158621587215882158921590215912159221593215942159521596215972159821599216002160121602216032160421605216062160721608216092161021611216122161321614216152161621617216182161921620216212162221623216242162521626216272162821629216302163121632216332163421635216362163721638216392164021641216422164321644216452164621647216482164921650216512165221653216542165521656216572165821659216602166121662216632166421665216662166721668216692167021671216722167321674216752167621677216782167921680216812168221683216842168521686216872168821689216902169121692216932169421695216962169721698216992170021701217022170321704217052170621707217082170921710217112171221713217142171521716217172171821719217202172121722217232172421725217262172721728217292173021731217322173321734217352173621737217382173921740217412174221743217442174521746217472174821749217502175121752217532175421755217562175721758217592176021761217622176321764217652176621767217682176921770217712177221773217742177521776217772177821779217802178121782217832178421785217862178721788217892179021791217922179321794217952179621797217982179921800218012180221803218042180521806218072180821809218102181121812218132181421815218162181721818218192182021821218222182321824218252182621827218282182921830218312183221833218342183521836218372183821839218402184121842218432184421845218462184721848218492185021851218522185321854218552185621857218582185921860218612186221863218642186521866218672186821869218702187121872218732187421875218762187721878218792188021881218822188321884218852188621887218882188921890218912189221893218942189521896218972189821899219002190121902219032190421905219062190721908219092191021911219122191321914219152191621917219182191921920219212192221923219242192521926219272192821929219302193121932219332193421935219362193721938219392194021941219422194321944219452194621947219482194921950219512195221953219542195521956219572195821959219602196121962219632196421965219662196721968219692197021971219722197321974219752197621977219782197921980219812198221983219842198521986219872198821989219902199121992219932199421995219962199721998219992200022001220022200322004220052200622007220082200922010220112201222013220142201522016220172201822019220202202122022220232202422025220262202722028220292203022031220322203322034220352203622037220382203922040220412204222043220442204522046220472204822049220502205122052220532205422055220562205722058220592206022061220622206322064220652206622067220682206922070220712207222073220742207522076220772207822079220802208122082220832208422085220862208722088220892209022091220922209322094220952209622097220982209922100221012210222103221042210522106221072210822109221102211122112221132211422115221162211722118221192212022121221222212322124221252212622127221282212922130221312213222133221342213522136221372213822139221402214122142221432214422145221462214722148221492215022151221522215322154221552215622157221582215922160221612216222163221642216522166221672216822169221702217122172221732217422175221762217722178221792218022181221822218322184221852218622187221882218922190221912219222193221942219522196221972219822199222002220122202222032220422205222062220722208222092221022211222122221322214222152221622217222182221922220222212222222223222242222522226222272222822229222302223122232222332223422235222362223722238222392224022241222422224322244222452224622247222482224922250222512225222253222542225522256222572225822259222602226122262222632226422265222662226722268222692227022271222722227322274222752227622277222782227922280222812228222283222842228522286222872228822289222902229122292222932229422295222962229722298222992230022301223022230322304223052230622307223082230922310223112231222313223142231522316223172231822319223202232122322223232232422325223262232722328223292233022331223322233322334223352233622337223382233922340223412234222343223442234522346223472234822349223502235122352223532235422355223562235722358223592236022361223622236322364223652236622367223682236922370223712237222373223742237522376223772237822379223802238122382223832238422385223862238722388223892239022391223922239322394223952239622397223982239922400224012240222403224042240522406224072240822409224102241122412224132241422415224162241722418224192242022421224222242322424224252242622427224282242922430224312243222433224342243522436224372243822439224402244122442224432244422445224462244722448224492245022451224522245322454224552245622457224582245922460224612246222463224642246522466224672246822469224702247122472224732247422475224762247722478224792248022481224822248322484224852248622487224882248922490224912249222493224942249522496224972249822499225002250122502225032250422505225062250722508225092251022511225122251322514225152251622517225182251922520225212252222523225242252522526225272252822529225302253122532225332253422535225362253722538225392254022541225422254322544225452254622547225482254922550225512255222553225542255522556225572255822559225602256122562225632256422565225662256722568225692257022571225722257322574225752257622577225782257922580225812258222583225842258522586225872258822589225902259122592225932259422595225962259722598225992260022601226022260322604226052260622607226082260922610226112261222613226142261522616226172261822619226202262122622226232262422625226262262722628226292263022631226322263322634226352263622637226382263922640226412264222643226442264522646226472264822649226502265122652226532265422655226562265722658226592266022661226622266322664226652266622667226682266922670226712267222673226742267522676226772267822679226802268122682226832268422685226862268722688226892269022691226922269322694226952269622697226982269922700227012270222703227042270522706227072270822709227102271122712227132271422715227162271722718227192272022721227222272322724227252272622727227282272922730227312273222733227342273522736227372273822739227402274122742227432274422745227462274722748227492275022751227522275322754227552275622757227582275922760227612276222763227642276522766227672276822769227702277122772227732277422775227762277722778227792278022781227822278322784227852278622787227882278922790227912279222793227942279522796227972279822799228002280122802228032280422805228062280722808228092281022811228122281322814228152281622817228182281922820228212282222823228242282522826228272282822829228302283122832228332283422835228362283722838228392284022841228422284322844228452284622847228482284922850228512285222853228542285522856228572285822859228602286122862228632286422865228662286722868228692287022871228722287322874228752287622877228782287922880228812288222883228842288522886228872288822889228902289122892228932289422895228962289722898228992290022901229022290322904229052290622907229082290922910229112291222913229142291522916229172291822919229202292122922229232292422925229262292722928229292293022931229322293322934229352293622937229382293922940229412294222943229442294522946229472294822949229502295122952229532295422955229562295722958229592296022961229622296322964229652296622967229682296922970229712297222973229742297522976229772297822979229802298122982229832298422985229862298722988229892299022991229922299322994229952299622997229982299923000230012300223003230042300523006230072300823009230102301123012230132301423015230162301723018230192302023021230222302323024230252302623027230282302923030230312303223033230342303523036230372303823039230402304123042230432304423045230462304723048230492305023051230522305323054230552305623057230582305923060230612306223063230642306523066230672306823069230702307123072230732307423075230762307723078230792308023081230822308323084230852308623087230882308923090230912309223093230942309523096230972309823099231002310123102231032310423105231062310723108231092311023111231122311323114231152311623117231182311923120231212312223123231242312523126231272312823129231302313123132231332313423135231362313723138231392314023141231422314323144231452314623147231482314923150231512315223153231542315523156231572315823159231602316123162231632316423165231662316723168231692317023171231722317323174231752317623177231782317923180231812318223183231842318523186231872318823189231902319123192231932319423195231962319723198231992320023201232022320323204232052320623207232082320923210232112321223213232142321523216232172321823219232202322123222232232322423225232262322723228232292323023231232322323323234232352323623237232382323923240232412324223243232442324523246232472324823249232502325123252232532325423255232562325723258232592326023261232622326323264232652326623267232682326923270232712327223273232742327523276232772327823279232802328123282232832328423285232862328723288232892329023291232922329323294232952329623297232982329923300233012330223303233042330523306233072330823309233102331123312233132331423315233162331723318233192332023321233222332323324233252332623327233282332923330233312333223333233342333523336233372333823339233402334123342233432334423345233462334723348233492335023351233522335323354233552335623357233582335923360233612336223363233642336523366233672336823369233702337123372233732337423375233762337723378233792338023381233822338323384233852338623387233882338923390233912339223393233942339523396233972339823399234002340123402234032340423405234062340723408234092341023411234122341323414234152341623417234182341923420234212342223423234242342523426234272342823429234302343123432234332343423435234362343723438234392344023441234422344323444234452344623447234482344923450234512345223453234542345523456234572345823459234602346123462234632346423465234662346723468234692347023471234722347323474234752347623477234782347923480234812348223483234842348523486234872348823489234902349123492234932349423495234962349723498234992350023501235022350323504235052350623507235082350923510235112351223513235142351523516235172351823519235202352123522235232352423525235262352723528235292353023531235322353323534235352353623537235382353923540235412354223543235442354523546235472354823549235502355123552235532355423555235562355723558235592356023561235622356323564235652356623567235682356923570235712357223573235742357523576235772357823579235802358123582235832358423585235862358723588235892359023591235922359323594235952359623597235982359923600236012360223603236042360523606236072360823609236102361123612236132361423615236162361723618236192362023621236222362323624236252362623627236282362923630236312363223633236342363523636236372363823639236402364123642236432364423645236462364723648236492365023651236522365323654236552365623657236582365923660236612366223663236642366523666236672366823669236702367123672236732367423675236762367723678236792368023681236822368323684236852368623687236882368923690236912369223693236942369523696236972369823699237002370123702237032370423705237062370723708237092371023711237122371323714237152371623717237182371923720237212372223723237242372523726237272372823729237302373123732237332373423735237362373723738237392374023741237422374323744237452374623747237482374923750237512375223753237542375523756237572375823759237602376123762237632376423765237662376723768237692377023771237722377323774237752377623777237782377923780237812378223783237842378523786237872378823789237902379123792237932379423795237962379723798237992380023801238022380323804238052380623807238082380923810238112381223813238142381523816238172381823819238202382123822238232382423825238262382723828238292383023831238322383323834238352383623837238382383923840238412384223843238442384523846238472384823849238502385123852238532385423855238562385723858238592386023861238622386323864238652386623867238682386923870238712387223873238742387523876238772387823879238802388123882238832388423885238862388723888238892389023891238922389323894238952389623897238982389923900239012390223903239042390523906239072390823909239102391123912239132391423915239162391723918239192392023921239222392323924239252392623927239282392923930239312393223933239342393523936239372393823939239402394123942239432394423945239462394723948239492395023951239522395323954239552395623957239582395923960239612396223963239642396523966239672396823969239702397123972239732397423975239762397723978239792398023981239822398323984239852398623987239882398923990239912399223993239942399523996239972399823999240002400124002240032400424005240062400724008240092401024011240122401324014240152401624017240182401924020240212402224023240242402524026240272402824029240302403124032240332403424035240362403724038240392404024041240422404324044240452404624047240482404924050240512405224053240542405524056240572405824059240602406124062240632406424065240662406724068240692407024071240722407324074240752407624077240782407924080240812408224083240842408524086240872408824089240902409124092240932409424095240962409724098240992410024101241022410324104241052410624107241082410924110241112411224113241142411524116241172411824119241202412124122241232412424125241262412724128241292413024131241322413324134241352413624137241382413924140241412414224143241442414524146241472414824149241502415124152241532415424155241562415724158241592416024161241622416324164241652416624167241682416924170241712417224173241742417524176241772417824179241802418124182241832418424185241862418724188241892419024191241922419324194241952419624197241982419924200242012420224203242042420524206242072420824209242102421124212242132421424215242162421724218242192422024221242222422324224242252422624227242282422924230242312423224233242342423524236242372423824239242402424124242242432424424245242462424724248242492425024251242522425324254242552425624257242582425924260242612426224263242642426524266242672426824269242702427124272242732427424275242762427724278242792428024281242822428324284242852428624287242882428924290242912429224293242942429524296242972429824299243002430124302243032430424305243062430724308243092431024311243122431324314243152431624317243182431924320243212432224323243242432524326243272432824329243302433124332243332433424335243362433724338243392434024341243422434324344243452434624347243482434924350243512435224353243542435524356243572435824359243602436124362243632436424365243662436724368243692437024371243722437324374243752437624377243782437924380243812438224383243842438524386243872438824389243902439124392243932439424395243962439724398243992440024401244022440324404244052440624407244082440924410244112441224413244142441524416244172441824419244202442124422244232442424425244262442724428244292443024431244322443324434244352443624437244382443924440244412444224443244442444524446244472444824449244502445124452244532445424455244562445724458244592446024461244622446324464244652446624467244682446924470244712447224473244742447524476244772447824479244802448124482244832448424485244862448724488244892449024491244922449324494244952449624497244982449924500245012450224503245042450524506245072450824509245102451124512245132451424515245162451724518245192452024521245222452324524245252452624527245282452924530245312453224533245342453524536245372453824539245402454124542245432454424545245462454724548245492455024551245522455324554245552455624557245582455924560245612456224563245642456524566245672456824569245702457124572245732457424575245762457724578245792458024581245822458324584245852458624587245882458924590245912459224593245942459524596245972459824599246002460124602246032460424605246062460724608246092461024611246122461324614246152461624617246182461924620246212462224623246242462524626246272462824629246302463124632246332463424635246362463724638246392464024641246422464324644246452464624647246482464924650246512465224653246542465524656246572465824659246602466124662246632466424665246662466724668246692467024671246722467324674246752467624677246782467924680246812468224683246842468524686246872468824689246902469124692246932469424695246962469724698246992470024701247022470324704247052470624707247082470924710247112471224713247142471524716247172471824719247202472124722247232472424725247262472724728247292473024731247322473324734247352473624737247382473924740247412474224743247442474524746247472474824749247502475124752247532475424755247562475724758247592476024761247622476324764247652476624767247682476924770247712477224773247742477524776247772477824779247802478124782247832478424785247862478724788247892479024791247922479324794247952479624797247982479924800248012480224803248042480524806248072480824809248102481124812248132481424815248162481724818248192482024821248222482324824248252482624827248282482924830248312483224833248342483524836248372483824839248402484124842248432484424845248462484724848248492485024851248522485324854248552485624857248582485924860248612486224863248642486524866248672486824869248702487124872248732487424875248762487724878248792488024881248822488324884248852488624887248882488924890248912489224893248942489524896248972489824899249002490124902249032490424905249062490724908249092491024911249122491324914249152491624917249182491924920249212492224923249242492524926249272492824929249302493124932249332493424935249362493724938249392494024941249422494324944249452494624947249482494924950249512495224953249542495524956249572495824959249602496124962249632496424965249662496724968249692497024971249722497324974249752497624977249782497924980249812498224983249842498524986249872498824989249902499124992249932499424995249962499724998249992500025001250022500325004250052500625007250082500925010250112501225013250142501525016250172501825019250202502125022250232502425025250262502725028250292503025031250322503325034250352503625037250382503925040250412504225043250442504525046250472504825049250502505125052250532505425055250562505725058250592506025061250622506325064250652506625067250682506925070250712507225073250742507525076250772507825079250802508125082250832508425085250862508725088250892509025091250922509325094250952509625097250982509925100251012510225103251042510525106251072510825109251102511125112251132511425115251162511725118251192512025121251222512325124251252512625127251282512925130251312513225133251342513525136251372513825139251402514125142251432514425145251462514725148251492515025151251522515325154251552515625157251582515925160251612516225163251642516525166251672516825169251702517125172251732517425175251762517725178251792518025181251822518325184251852518625187251882518925190251912519225193251942519525196251972519825199252002520125202252032520425205252062520725208252092521025211252122521325214252152521625217252182521925220252212522225223252242522525226252272522825229252302523125232252332523425235252362523725238252392524025241252422524325244252452524625247252482524925250252512525225253252542525525256252572525825259252602526125262252632526425265252662526725268252692527025271252722527325274252752527625277252782527925280252812528225283252842528525286252872528825289252902529125292252932529425295252962529725298252992530025301253022530325304253052530625307253082530925310253112531225313253142531525316253172531825319253202532125322253232532425325253262532725328253292533025331253322533325334253352533625337253382533925340253412534225343253442534525346253472534825349253502535125352253532535425355253562535725358253592536025361253622536325364253652536625367253682536925370253712537225373253742537525376253772537825379253802538125382253832538425385253862538725388253892539025391253922539325394253952539625397253982539925400254012540225403254042540525406254072540825409254102541125412254132541425415254162541725418254192542025421254222542325424254252542625427254282542925430254312543225433254342543525436254372543825439254402544125442254432544425445254462544725448254492545025451254522545325454254552545625457254582545925460254612546225463254642546525466254672546825469254702547125472254732547425475254762547725478254792548025481254822548325484254852548625487254882548925490254912549225493254942549525496254972549825499255002550125502255032550425505255062550725508255092551025511255122551325514255152551625517255182551925520255212552225523255242552525526255272552825529255302553125532255332553425535255362553725538255392554025541255422554325544255452554625547255482554925550255512555225553255542555525556255572555825559255602556125562255632556425565255662556725568255692557025571255722557325574255752557625577255782557925580255812558225583255842558525586255872558825589255902559125592255932559425595255962559725598255992560025601256022560325604256052560625607256082560925610256112561225613256142561525616256172561825619256202562125622256232562425625256262562725628256292563025631256322563325634256352563625637256382563925640256412564225643256442564525646256472564825649256502565125652256532565425655256562565725658256592566025661256622566325664256652566625667256682566925670256712567225673256742567525676256772567825679256802568125682256832568425685256862568725688256892569025691256922569325694256952569625697256982569925700257012570225703257042570525706257072570825709257102571125712257132571425715257162571725718257192572025721257222572325724257252572625727257282572925730257312573225733257342573525736257372573825739257402574125742257432574425745257462574725748257492575025751257522575325754257552575625757257582575925760257612576225763257642576525766257672576825769257702577125772257732577425775257762577725778257792578025781257822578325784257852578625787257882578925790257912579225793257942579525796257972579825799258002580125802258032580425805258062580725808258092581025811258122581325814258152581625817258182581925820258212582225823258242582525826258272582825829258302583125832258332583425835258362583725838258392584025841258422584325844258452584625847258482584925850258512585225853258542585525856258572585825859258602586125862258632586425865258662586725868258692587025871258722587325874258752587625877258782587925880258812588225883258842588525886258872588825889258902589125892258932589425895258962589725898258992590025901259022590325904259052590625907259082590925910259112591225913259142591525916259172591825919259202592125922259232592425925259262592725928259292593025931259322593325934259352593625937259382593925940259412594225943259442594525946259472594825949259502595125952259532595425955259562595725958259592596025961259622596325964259652596625967259682596925970259712597225973259742597525976259772597825979259802598125982259832598425985259862598725988259892599025991259922599325994259952599625997259982599926000260012600226003260042600526006260072600826009260102601126012260132601426015260162601726018260192602026021260222602326024260252602626027260282602926030260312603226033260342603526036260372603826039260402604126042260432604426045260462604726048260492605026051260522605326054260552605626057260582605926060260612606226063260642606526066260672606826069260702607126072260732607426075260762607726078260792608026081260822608326084260852608626087260882608926090260912609226093260942609526096260972609826099261002610126102261032610426105261062610726108261092611026111261122611326114261152611626117261182611926120261212612226123261242612526126261272612826129261302613126132261332613426135261362613726138261392614026141261422614326144261452614626147261482614926150261512615226153261542615526156261572615826159261602616126162261632616426165261662616726168261692617026171261722617326174261752617626177261782617926180261812618226183261842618526186261872618826189261902619126192261932619426195261962619726198261992620026201262022620326204262052620626207262082620926210262112621226213262142621526216262172621826219262202622126222262232622426225262262622726228262292623026231262322623326234262352623626237262382623926240262412624226243262442624526246262472624826249262502625126252262532625426255262562625726258262592626026261262622626326264262652626626267262682626926270262712627226273262742627526276262772627826279262802628126282262832628426285262862628726288262892629026291262922629326294262952629626297262982629926300263012630226303263042630526306263072630826309263102631126312263132631426315263162631726318263192632026321263222632326324263252632626327263282632926330263312633226333263342633526336263372633826339263402634126342263432634426345263462634726348263492635026351263522635326354263552635626357263582635926360263612636226363263642636526366263672636826369263702637126372263732637426375263762637726378263792638026381263822638326384263852638626387263882638926390263912639226393263942639526396263972639826399264002640126402264032640426405264062640726408264092641026411264122641326414264152641626417264182641926420264212642226423264242642526426264272642826429264302643126432264332643426435264362643726438264392644026441264422644326444264452644626447264482644926450264512645226453264542645526456264572645826459264602646126462264632646426465264662646726468264692647026471264722647326474264752647626477264782647926480264812648226483264842648526486264872648826489264902649126492264932649426495264962649726498264992650026501265022650326504265052650626507265082650926510265112651226513265142651526516265172651826519265202652126522265232652426525265262652726528265292653026531265322653326534265352653626537265382653926540265412654226543265442654526546265472654826549265502655126552265532655426555265562655726558265592656026561265622656326564265652656626567265682656926570265712657226573265742657526576265772657826579265802658126582265832658426585265862658726588265892659026591265922659326594265952659626597265982659926600266012660226603266042660526606266072660826609266102661126612266132661426615266162661726618266192662026621266222662326624266252662626627266282662926630266312663226633266342663526636266372663826639266402664126642266432664426645266462664726648266492665026651266522665326654266552665626657266582665926660266612666226663266642666526666266672666826669266702667126672266732667426675266762667726678266792668026681266822668326684266852668626687266882668926690266912669226693266942669526696266972669826699267002670126702267032670426705267062670726708267092671026711267122671326714267152671626717267182671926720267212672226723267242672526726267272672826729267302673126732267332673426735267362673726738267392674026741267422674326744267452674626747267482674926750267512675226753267542675526756267572675826759267602676126762267632676426765267662676726768267692677026771267722677326774267752677626777267782677926780267812678226783267842678526786267872678826789267902679126792267932679426795267962679726798267992680026801268022680326804268052680626807268082680926810268112681226813268142681526816268172681826819268202682126822268232682426825268262682726828268292683026831268322683326834268352683626837268382683926840268412684226843268442684526846268472684826849268502685126852268532685426855268562685726858268592686026861268622686326864268652686626867268682686926870268712687226873268742687526876268772687826879268802688126882268832688426885268862688726888268892689026891268922689326894268952689626897268982689926900269012690226903269042690526906269072690826909269102691126912269132691426915269162691726918269192692026921269222692326924269252692626927269282692926930269312693226933269342693526936269372693826939269402694126942269432694426945269462694726948269492695026951269522695326954269552695626957269582695926960269612696226963269642696526966269672696826969269702697126972269732697426975269762697726978269792698026981269822698326984269852698626987269882698926990269912699226993269942699526996269972699826999270002700127002270032700427005270062700727008270092701027011270122701327014270152701627017270182701927020270212702227023270242702527026270272702827029270302703127032270332703427035270362703727038270392704027041270422704327044270452704627047270482704927050270512705227053270542705527056270572705827059270602706127062270632706427065270662706727068270692707027071270722707327074270752707627077270782707927080270812708227083270842708527086270872708827089270902709127092270932709427095270962709727098270992710027101271022710327104271052710627107271082710927110271112711227113271142711527116271172711827119271202712127122271232712427125271262712727128271292713027131271322713327134271352713627137271382713927140271412714227143271442714527146271472714827149271502715127152271532715427155271562715727158271592716027161271622716327164271652716627167271682716927170271712717227173271742717527176271772717827179271802718127182271832718427185271862718727188271892719027191271922719327194271952719627197271982719927200272012720227203272042720527206272072720827209272102721127212272132721427215272162721727218272192722027221272222722327224272252722627227272282722927230272312723227233272342723527236272372723827239272402724127242272432724427245272462724727248272492725027251272522725327254272552725627257272582725927260272612726227263272642726527266272672726827269272702727127272272732727427275272762727727278272792728027281272822728327284272852728627287272882728927290272912729227293272942729527296272972729827299273002730127302273032730427305273062730727308273092731027311273122731327314273152731627317273182731927320273212732227323273242732527326273272732827329273302733127332273332733427335273362733727338273392734027341273422734327344273452734627347273482734927350273512735227353273542735527356273572735827359273602736127362273632736427365273662736727368273692737027371273722737327374273752737627377273782737927380273812738227383273842738527386273872738827389273902739127392273932739427395273962739727398273992740027401274022740327404274052740627407274082740927410274112741227413274142741527416274172741827419274202742127422274232742427425274262742727428274292743027431274322743327434274352743627437274382743927440274412744227443274442744527446274472744827449274502745127452274532745427455274562745727458274592746027461274622746327464274652746627467274682746927470274712747227473274742747527476274772747827479274802748127482274832748427485274862748727488274892749027491274922749327494274952749627497274982749927500275012750227503275042750527506275072750827509275102751127512275132751427515275162751727518275192752027521275222752327524275252752627527275282752927530275312753227533275342753527536275372753827539275402754127542275432754427545275462754727548275492755027551275522755327554275552755627557275582755927560275612756227563275642756527566275672756827569275702757127572275732757427575275762757727578275792758027581275822758327584275852758627587275882758927590275912759227593275942759527596275972759827599276002760127602276032760427605276062760727608276092761027611276122761327614276152761627617276182761927620276212762227623276242762527626276272762827629276302763127632276332763427635276362763727638276392764027641276422764327644276452764627647276482764927650276512765227653276542765527656276572765827659276602766127662276632766427665276662766727668276692767027671276722767327674276752767627677276782767927680276812768227683276842768527686276872768827689276902769127692276932769427695276962769727698276992770027701277022770327704277052770627707277082770927710277112771227713277142771527716277172771827719277202772127722277232772427725277262772727728277292773027731277322773327734277352773627737277382773927740277412774227743277442774527746277472774827749277502775127752277532775427755277562775727758277592776027761277622776327764277652776627767277682776927770277712777227773277742777527776277772777827779277802778127782277832778427785277862778727788277892779027791277922779327794277952779627797277982779927800278012780227803278042780527806278072780827809278102781127812278132781427815278162781727818278192782027821278222782327824278252782627827278282782927830278312783227833278342783527836278372783827839278402784127842278432784427845278462784727848278492785027851278522785327854278552785627857278582785927860278612786227863278642786527866278672786827869278702787127872278732787427875278762787727878278792788027881278822788327884278852788627887278882788927890278912789227893278942789527896278972789827899279002790127902279032790427905279062790727908279092791027911279122791327914279152791627917279182791927920279212792227923279242792527926279272792827929279302793127932279332793427935279362793727938279392794027941279422794327944279452794627947279482794927950279512795227953279542795527956279572795827959279602796127962279632796427965279662796727968279692797027971279722797327974279752797627977279782797927980279812798227983279842798527986279872798827989279902799127992279932799427995279962799727998279992800028001280022800328004280052800628007280082800928010280112801228013280142801528016280172801828019280202802128022280232802428025280262802728028280292803028031280322803328034280352803628037280382803928040280412804228043280442804528046280472804828049280502805128052280532805428055280562805728058280592806028061280622806328064280652806628067280682806928070280712807228073280742807528076280772807828079280802808128082280832808428085280862808728088280892809028091280922809328094280952809628097280982809928100281012810228103281042810528106281072810828109281102811128112281132811428115281162811728118281192812028121281222812328124281252812628127281282812928130281312813228133281342813528136281372813828139281402814128142281432814428145281462814728148281492815028151281522815328154281552815628157281582815928160281612816228163281642816528166281672816828169281702817128172281732817428175281762817728178281792818028181281822818328184281852818628187281882818928190281912819228193281942819528196281972819828199282002820128202282032820428205282062820728208282092821028211282122821328214282152821628217282182821928220282212822228223282242822528226282272822828229282302823128232282332823428235282362823728238282392824028241282422824328244282452824628247282482824928250282512825228253282542825528256282572825828259282602826128262282632826428265282662826728268282692827028271282722827328274282752827628277282782827928280282812828228283282842828528286282872828828289282902829128292282932829428295282962829728298282992830028301283022830328304283052830628307283082830928310283112831228313283142831528316283172831828319283202832128322283232832428325283262832728328283292833028331283322833328334283352833628337283382833928340283412834228343283442834528346283472834828349283502835128352283532835428355283562835728358283592836028361283622836328364283652836628367283682836928370283712837228373283742837528376283772837828379283802838128382283832838428385283862838728388283892839028391283922839328394283952839628397283982839928400284012840228403284042840528406284072840828409284102841128412284132841428415284162841728418284192842028421284222842328424284252842628427284282842928430284312843228433284342843528436284372843828439284402844128442284432844428445284462844728448284492845028451284522845328454284552845628457284582845928460284612846228463284642846528466284672846828469284702847128472284732847428475284762847728478284792848028481284822848328484284852848628487284882848928490284912849228493284942849528496284972849828499285002850128502285032850428505285062850728508285092851028511285122851328514285152851628517285182851928520285212852228523285242852528526285272852828529285302853128532285332853428535285362853728538285392854028541285422854328544285452854628547285482854928550285512855228553285542855528556285572855828559285602856128562285632856428565285662856728568285692857028571285722857328574285752857628577285782857928580285812858228583285842858528586285872858828589285902859128592285932859428595285962859728598285992860028601286022860328604286052860628607286082860928610286112861228613286142861528616286172861828619286202862128622286232862428625286262862728628286292863028631286322863328634286352863628637286382863928640286412864228643286442864528646286472864828649286502865128652286532865428655286562865728658286592866028661286622866328664286652866628667286682866928670286712867228673286742867528676286772867828679286802868128682286832868428685286862868728688286892869028691286922869328694286952869628697286982869928700287012870228703287042870528706287072870828709287102871128712287132871428715287162871728718287192872028721287222872328724287252872628727287282872928730287312873228733287342873528736287372873828739287402874128742287432874428745287462874728748287492875028751287522875328754287552875628757287582875928760287612876228763287642876528766287672876828769287702877128772287732877428775287762877728778287792878028781287822878328784287852878628787287882878928790287912879228793287942879528796287972879828799288002880128802288032880428805288062880728808288092881028811288122881328814288152881628817288182881928820288212882228823288242882528826288272882828829288302883128832288332883428835288362883728838288392884028841288422884328844288452884628847288482884928850288512885228853288542885528856288572885828859288602886128862288632886428865288662886728868288692887028871288722887328874288752887628877288782887928880288812888228883288842888528886288872888828889288902889128892288932889428895288962889728898288992890028901289022890328904289052890628907289082890928910289112891228913289142891528916289172891828919289202892128922289232892428925289262892728928289292893028931289322893328934289352893628937289382893928940289412894228943289442894528946289472894828949289502895128952289532895428955289562895728958289592896028961289622896328964289652896628967289682896928970289712897228973289742897528976289772897828979289802898128982289832898428985289862898728988289892899028991289922899328994289952899628997289982899929000290012900229003290042900529006290072900829009290102901129012290132901429015290162901729018290192902029021290222902329024290252902629027290282902929030290312903229033290342903529036290372903829039290402904129042290432904429045290462904729048290492905029051290522905329054290552905629057290582905929060290612906229063290642906529066290672906829069290702907129072290732907429075290762907729078290792908029081290822908329084290852908629087290882908929090290912909229093290942909529096290972909829099291002910129102291032910429105291062910729108291092911029111291122911329114291152911629117291182911929120291212912229123291242912529126291272912829129291302913129132291332913429135291362913729138291392914029141291422914329144291452914629147291482914929150291512915229153291542915529156291572915829159291602916129162291632916429165291662916729168291692917029171291722917329174291752917629177291782917929180291812918229183291842918529186291872918829189291902919129192291932919429195291962919729198291992920029201292022920329204292052920629207292082920929210292112921229213292142921529216292172921829219292202922129222292232922429225292262922729228292292923029231292322923329234292352923629237292382923929240292412924229243292442924529246292472924829249292502925129252292532925429255292562925729258292592926029261292622926329264292652926629267292682926929270292712927229273292742927529276292772927829279292802928129282292832928429285292862928729288292892929029291292922929329294292952929629297292982929929300293012930229303293042930529306293072930829309293102931129312293132931429315293162931729318293192932029321293222932329324293252932629327293282932929330293312933229333293342933529336293372933829339293402934129342293432934429345293462934729348293492935029351293522935329354293552935629357293582935929360293612936229363293642936529366293672936829369293702937129372293732937429375293762937729378293792938029381293822938329384293852938629387293882938929390293912939229393293942939529396293972939829399294002940129402294032940429405294062940729408294092941029411294122941329414294152941629417294182941929420294212942229423294242942529426294272942829429294302943129432294332943429435294362943729438294392944029441294422944329444294452944629447294482944929450294512945229453294542945529456294572945829459294602946129462294632946429465294662946729468294692947029471294722947329474294752947629477294782947929480294812948229483294842948529486294872948829489294902949129492294932949429495294962949729498294992950029501295022950329504295052950629507295082950929510295112951229513295142951529516295172951829519295202952129522295232952429525295262952729528295292953029531295322953329534295352953629537295382953929540295412954229543295442954529546295472954829549295502955129552295532955429555295562955729558295592956029561295622956329564295652956629567295682956929570295712957229573295742957529576295772957829579295802958129582295832958429585295862958729588295892959029591295922959329594295952959629597295982959929600296012960229603296042960529606296072960829609296102961129612296132961429615296162961729618296192962029621296222962329624296252962629627296282962929630296312963229633296342963529636296372963829639296402964129642296432964429645296462964729648296492965029651296522965329654296552965629657296582965929660296612966229663296642966529666296672966829669296702967129672296732967429675296762967729678296792968029681296822968329684296852968629687296882968929690296912969229693296942969529696296972969829699297002970129702297032970429705297062970729708297092971029711297122971329714297152971629717297182971929720297212972229723297242972529726297272972829729297302973129732297332973429735297362973729738297392974029741297422974329744297452974629747297482974929750297512975229753297542975529756297572975829759297602976129762297632976429765297662976729768297692977029771297722977329774297752977629777297782977929780297812978229783297842978529786297872978829789297902979129792297932979429795297962979729798297992980029801298022980329804298052980629807298082980929810298112981229813298142981529816298172981829819298202982129822298232982429825298262982729828298292983029831298322983329834298352983629837298382983929840298412984229843298442984529846298472984829849298502985129852298532985429855298562985729858298592986029861298622986329864298652986629867298682986929870298712987229873298742987529876298772987829879298802988129882298832988429885298862988729888298892989029891298922989329894298952989629897298982989929900299012990229903299042990529906299072990829909299102991129912299132991429915299162991729918299192992029921299222992329924299252992629927299282992929930299312993229933299342993529936299372993829939299402994129942299432994429945299462994729948299492995029951299522995329954299552995629957299582995929960299612996229963299642996529966299672996829969299702997129972299732997429975299762997729978299792998029981299822998329984299852998629987299882998929990299912999229993299942999529996299972999829999300003000130002300033000430005300063000730008300093001030011300123001330014300153001630017300183001930020300213002230023300243002530026300273002830029300303003130032300333003430035300363003730038300393004030041300423004330044300453004630047300483004930050300513005230053300543005530056300573005830059300603006130062300633006430065300663006730068300693007030071300723007330074300753007630077300783007930080300813008230083300843008530086300873008830089300903009130092300933009430095300963009730098300993010030101301023010330104301053010630107301083010930110301113011230113301143011530116301173011830119301203012130122301233012430125301263012730128301293013030131301323013330134301353013630137301383013930140301413014230143301443014530146301473014830149301503015130152301533015430155301563015730158301593016030161301623016330164301653016630167301683016930170301713017230173301743017530176301773017830179301803018130182301833018430185301863018730188301893019030191301923019330194301953019630197301983019930200302013020230203302043020530206302073020830209302103021130212302133021430215302163021730218302193022030221302223022330224302253022630227302283022930230302313023230233302343023530236302373023830239302403024130242302433024430245302463024730248302493025030251302523025330254302553025630257302583025930260302613026230263302643026530266302673026830269302703027130272302733027430275302763027730278302793028030281302823028330284302853028630287302883028930290302913029230293302943029530296302973029830299303003030130302303033030430305303063030730308303093031030311303123031330314303153031630317303183031930320303213032230323303243032530326303273032830329303303033130332303333033430335303363033730338303393034030341303423034330344303453034630347303483034930350303513035230353303543035530356303573035830359303603036130362303633036430365303663036730368303693037030371303723037330374303753037630377303783037930380303813038230383303843038530386303873038830389303903039130392303933039430395303963039730398303993040030401304023040330404304053040630407304083040930410304113041230413304143041530416304173041830419304203042130422304233042430425304263042730428304293043030431304323043330434304353043630437304383043930440304413044230443304443044530446304473044830449304503045130452304533045430455304563045730458304593046030461304623046330464304653046630467304683046930470304713047230473304743047530476304773047830479304803048130482304833048430485304863048730488304893049030491304923049330494304953049630497304983049930500305013050230503305043050530506305073050830509305103051130512305133051430515305163051730518305193052030521305223052330524305253052630527305283052930530305313053230533305343053530536305373053830539305403054130542305433054430545305463054730548305493055030551305523055330554305553055630557305583055930560305613056230563305643056530566305673056830569305703057130572305733057430575305763057730578305793058030581305823058330584305853058630587305883058930590305913059230593305943059530596305973059830599306003060130602306033060430605306063060730608306093061030611306123061330614306153061630617306183061930620306213062230623306243062530626306273062830629306303063130632306333063430635306363063730638306393064030641306423064330644306453064630647306483064930650306513065230653306543065530656306573065830659306603066130662306633066430665306663066730668306693067030671306723067330674306753067630677306783067930680306813068230683306843068530686306873068830689306903069130692306933069430695306963069730698306993070030701307023070330704307053070630707307083070930710307113071230713307143071530716307173071830719307203072130722307233072430725307263072730728307293073030731307323073330734307353073630737307383073930740307413074230743307443074530746307473074830749307503075130752307533075430755307563075730758307593076030761307623076330764307653076630767307683076930770307713077230773307743077530776307773077830779307803078130782307833078430785307863078730788307893079030791307923079330794307953079630797307983079930800308013080230803308043080530806308073080830809308103081130812308133081430815308163081730818308193082030821308223082330824308253082630827308283082930830308313083230833308343083530836308373083830839308403084130842308433084430845308463084730848308493085030851308523085330854308553085630857308583085930860308613086230863308643086530866308673086830869308703087130872308733087430875308763087730878308793088030881308823088330884308853088630887308883088930890308913089230893308943089530896308973089830899309003090130902309033090430905309063090730908309093091030911309123091330914309153091630917309183091930920309213092230923309243092530926309273092830929309303093130932309333093430935309363093730938309393094030941309423094330944309453094630947309483094930950309513095230953309543095530956309573095830959309603096130962309633096430965309663096730968309693097030971309723097330974309753097630977309783097930980309813098230983309843098530986309873098830989309903099130992309933099430995309963099730998309993100031001310023100331004310053100631007310083100931010310113101231013310143101531016310173101831019310203102131022310233102431025310263102731028310293103031031310323103331034310353103631037310383103931040310413104231043310443104531046310473104831049310503105131052310533105431055310563105731058310593106031061310623106331064310653106631067310683106931070310713107231073310743107531076310773107831079310803108131082310833108431085310863108731088310893109031091310923109331094310953109631097310983109931100311013110231103311043110531106311073110831109311103111131112311133111431115311163111731118311193112031121311223112331124311253112631127311283112931130311313113231133311343113531136311373113831139311403114131142311433114431145311463114731148311493115031151311523115331154311553115631157311583115931160311613116231163311643116531166311673116831169311703117131172311733117431175311763117731178311793118031181311823118331184311853118631187311883118931190311913119231193311943119531196311973119831199312003120131202312033120431205312063120731208312093121031211312123121331214312153121631217312183121931220312213122231223312243122531226312273122831229312303123131232312333123431235312363123731238312393124031241312423124331244312453124631247312483124931250312513125231253312543125531256312573125831259312603126131262312633126431265312663126731268312693127031271312723127331274312753127631277312783127931280312813128231283312843128531286312873128831289312903129131292312933129431295312963129731298312993130031301313023130331304313053130631307313083130931310313113131231313313143131531316313173131831319313203132131322313233132431325313263132731328313293133031331313323133331334313353133631337313383133931340313413134231343313443134531346313473134831349313503135131352313533135431355313563135731358313593136031361313623136331364313653136631367313683136931370313713137231373313743137531376313773137831379313803138131382313833138431385313863138731388313893139031391313923139331394313953139631397313983139931400314013140231403314043140531406314073140831409314103141131412314133141431415314163141731418314193142031421314223142331424314253142631427314283142931430314313143231433314343143531436314373143831439314403144131442314433144431445314463144731448314493145031451314523145331454314553145631457314583145931460314613146231463314643146531466314673146831469314703147131472314733147431475314763147731478314793148031481314823148331484314853148631487314883148931490314913149231493314943149531496314973149831499315003150131502315033150431505315063150731508315093151031511315123151331514315153151631517315183151931520315213152231523315243152531526315273152831529315303153131532315333153431535315363153731538315393154031541315423154331544315453154631547315483154931550315513155231553315543155531556315573155831559315603156131562315633156431565315663156731568315693157031571315723157331574315753157631577315783157931580315813158231583315843158531586315873158831589315903159131592315933159431595315963159731598315993160031601316023160331604316053160631607316083160931610316113161231613316143161531616316173161831619316203162131622316233162431625316263162731628316293163031631316323163331634316353163631637316383163931640316413164231643316443164531646316473164831649316503165131652316533165431655316563165731658316593166031661316623166331664316653166631667316683166931670316713167231673316743167531676316773167831679316803168131682316833168431685316863168731688316893169031691316923169331694316953169631697316983169931700317013170231703317043170531706317073170831709317103171131712317133171431715317163171731718317193172031721317223172331724317253172631727317283172931730317313173231733317343173531736317373173831739317403174131742317433174431745317463174731748317493175031751317523175331754317553175631757317583175931760317613176231763317643176531766317673176831769317703177131772317733177431775317763177731778317793178031781317823178331784317853178631787317883178931790317913179231793317943179531796317973179831799318003180131802318033180431805318063180731808318093181031811318123181331814318153181631817318183181931820318213182231823318243182531826318273182831829318303183131832318333183431835318363183731838318393184031841318423184331844318453184631847318483184931850318513185231853318543185531856318573185831859318603186131862318633186431865318663186731868318693187031871318723187331874318753187631877318783187931880318813188231883318843188531886318873188831889318903189131892318933189431895318963189731898318993190031901319023190331904319053190631907319083190931910319113191231913319143191531916319173191831919319203192131922319233192431925319263192731928319293193031931319323193331934319353193631937319383193931940319413194231943319443194531946319473194831949319503195131952319533195431955319563195731958319593196031961319623196331964319653196631967319683196931970319713197231973319743197531976319773197831979319803198131982319833198431985319863198731988319893199031991319923199331994319953199631997319983199932000320013200232003320043200532006320073200832009320103201132012320133201432015320163201732018320193202032021320223202332024320253202632027320283202932030320313203232033320343203532036320373203832039320403204132042320433204432045320463204732048320493205032051320523205332054320553205632057320583205932060320613206232063320643206532066320673206832069320703207132072320733207432075320763207732078320793208032081320823208332084320853208632087320883208932090320913209232093320943209532096320973209832099321003210132102321033210432105321063210732108321093211032111321123211332114321153211632117321183211932120321213212232123321243212532126321273212832129321303213132132321333213432135321363213732138321393214032141321423214332144321453214632147321483214932150321513215232153321543215532156321573215832159321603216132162321633216432165321663216732168321693217032171321723217332174321753217632177321783217932180321813218232183321843218532186321873218832189321903219132192321933219432195321963219732198321993220032201322023220332204322053220632207322083220932210322113221232213322143221532216322173221832219322203222132222322233222432225322263222732228322293223032231322323223332234322353223632237322383223932240322413224232243322443224532246322473224832249322503225132252322533225432255322563225732258322593226032261322623226332264322653226632267322683226932270322713227232273322743227532276322773227832279322803228132282322833228432285322863228732288322893229032291322923229332294322953229632297322983229932300323013230232303323043230532306323073230832309323103231132312323133231432315323163231732318323193232032321323223232332324323253232632327323283232932330323313233232333323343233532336323373233832339323403234132342323433234432345323463234732348323493235032351323523235332354323553235632357323583235932360323613236232363323643236532366323673236832369323703237132372323733237432375323763237732378323793238032381323823238332384323853238632387323883238932390323913239232393323943239532396323973239832399324003240132402324033240432405324063240732408324093241032411324123241332414324153241632417324183241932420324213242232423324243242532426324273242832429324303243132432324333243432435324363243732438324393244032441324423244332444324453244632447324483244932450324513245232453324543245532456324573245832459324603246132462324633246432465324663246732468324693247032471324723247332474324753247632477324783247932480324813248232483324843248532486324873248832489324903249132492324933249432495324963249732498324993250032501325023250332504325053250632507325083250932510325113251232513325143251532516325173251832519325203252132522325233252432525325263252732528325293253032531325323253332534325353253632537325383253932540325413254232543325443254532546325473254832549325503255132552325533255432555325563255732558325593256032561325623256332564325653256632567325683256932570325713257232573325743257532576325773257832579325803258132582325833258432585325863258732588325893259032591325923259332594325953259632597325983259932600326013260232603326043260532606326073260832609326103261132612326133261432615326163261732618326193262032621326223262332624326253262632627326283262932630326313263232633326343263532636326373263832639326403264132642326433264432645326463264732648326493265032651326523265332654326553265632657326583265932660326613266232663326643266532666326673266832669326703267132672326733267432675326763267732678326793268032681326823268332684326853268632687326883268932690326913269232693326943269532696326973269832699327003270132702327033270432705327063270732708327093271032711327123271332714327153271632717327183271932720327213272232723327243272532726327273272832729327303273132732327333273432735327363273732738327393274032741327423274332744327453274632747327483274932750327513275232753327543275532756327573275832759327603276132762327633276432765327663276732768327693277032771327723277332774327753277632777327783277932780327813278232783327843278532786327873278832789327903279132792327933279432795327963279732798327993280032801328023280332804328053280632807328083280932810328113281232813328143281532816328173281832819328203282132822328233282432825328263282732828328293283032831328323283332834328353283632837328383283932840328413284232843328443284532846328473284832849328503285132852328533285432855328563285732858328593286032861328623286332864328653286632867328683286932870328713287232873328743287532876328773287832879328803288132882328833288432885328863288732888328893289032891328923289332894328953289632897328983289932900329013290232903329043290532906329073290832909329103291132912329133291432915329163291732918329193292032921329223292332924329253292632927329283292932930329313293232933329343293532936329373293832939329403294132942329433294432945329463294732948329493295032951329523295332954329553295632957329583295932960329613296232963329643296532966329673296832969329703297132972329733297432975329763297732978329793298032981329823298332984329853298632987329883298932990329913299232993329943299532996329973299832999330003300133002330033300433005330063300733008330093301033011330123301333014330153301633017330183301933020330213302233023330243302533026330273302833029330303303133032330333303433035330363303733038330393304033041330423304333044330453304633047330483304933050330513305233053330543305533056330573305833059330603306133062330633306433065330663306733068330693307033071330723307333074330753307633077330783307933080330813308233083330843308533086330873308833089330903309133092330933309433095330963309733098330993310033101331023310333104331053310633107331083310933110331113311233113331143311533116331173311833119331203312133122331233312433125331263312733128331293313033131331323313333134331353313633137331383313933140331413314233143331443314533146331473314833149331503315133152331533315433155331563315733158331593316033161331623316333164331653316633167331683316933170331713317233173331743317533176331773317833179331803318133182331833318433185331863318733188331893319033191331923319333194331953319633197331983319933200332013320233203332043320533206332073320833209332103321133212332133321433215332163321733218332193322033221332223322333224332253322633227332283322933230332313323233233332343323533236332373323833239332403324133242332433324433245332463324733248332493325033251332523325333254332553325633257332583325933260332613326233263332643326533266332673326833269332703327133272332733327433275332763327733278332793328033281332823328333284332853328633287332883328933290332913329233293332943329533296332973329833299333003330133302333033330433305333063330733308333093331033311333123331333314333153331633317333183331933320333213332233323333243332533326333273332833329333303333133332333333333433335333363333733338333393334033341333423334333344333453334633347333483334933350333513335233353333543335533356333573335833359333603336133362333633336433365333663336733368333693337033371333723337333374333753337633377333783337933380333813338233383333843338533386333873338833389333903339133392333933339433395333963339733398333993340033401334023340333404334053340633407334083340933410334113341233413334143341533416334173341833419334203342133422334233342433425334263342733428334293343033431334323343333434334353343633437334383343933440334413344233443334443344533446334473344833449334503345133452334533345433455334563345733458334593346033461334623346333464334653346633467334683346933470334713347233473334743347533476334773347833479334803348133482334833348433485334863348733488334893349033491334923349333494334953349633497334983349933500335013350233503335043350533506335073350833509335103351133512335133351433515335163351733518335193352033521335223352333524335253352633527335283352933530335313353233533335343353533536335373353833539335403354133542335433354433545335463354733548335493355033551335523355333554335553355633557335583355933560335613356233563335643356533566335673356833569335703357133572335733357433575335763357733578335793358033581335823358333584335853358633587335883358933590335913359233593335943359533596335973359833599336003360133602336033360433605336063360733608336093361033611336123361333614336153361633617336183361933620336213362233623336243362533626336273362833629336303363133632336333363433635336363363733638336393364033641336423364333644336453364633647336483364933650336513365233653336543365533656336573365833659336603366133662336633366433665336663366733668336693367033671336723367333674336753367633677336783367933680336813368233683336843368533686336873368833689336903369133692336933369433695336963369733698336993370033701337023370333704337053370633707337083370933710337113371233713337143371533716337173371833719337203372133722337233372433725337263372733728337293373033731337323373333734337353373633737337383373933740337413374233743337443374533746337473374833749337503375133752337533375433755337563375733758337593376033761337623376333764337653376633767337683376933770337713377233773337743377533776337773377833779337803378133782337833378433785337863378733788337893379033791337923379333794337953379633797337983379933800338013380233803338043380533806338073380833809338103381133812338133381433815338163381733818338193382033821338223382333824338253382633827338283382933830338313383233833338343383533836338373383833839338403384133842338433384433845338463384733848338493385033851338523385333854338553385633857338583385933860338613386233863338643386533866338673386833869338703387133872338733387433875338763387733878338793388033881338823388333884338853388633887338883388933890338913389233893338943389533896338973389833899339003390133902339033390433905339063390733908339093391033911339123391333914339153391633917339183391933920339213392233923339243392533926339273392833929339303393133932339333393433935339363393733938339393394033941339423394333944339453394633947339483394933950339513395233953339543395533956339573395833959339603396133962339633396433965339663396733968339693397033971339723397333974339753397633977339783397933980339813398233983339843398533986339873398833989339903399133992339933399433995339963399733998339993400034001340023400334004340053400634007340083400934010340113401234013340143401534016340173401834019340203402134022340233402434025340263402734028340293403034031340323403334034340353403634037340383403934040340413404234043340443404534046340473404834049340503405134052340533405434055340563405734058340593406034061340623406334064340653406634067340683406934070340713407234073340743407534076340773407834079340803408134082340833408434085340863408734088340893409034091340923409334094340953409634097340983409934100341013410234103341043410534106341073410834109341103411134112341133411434115341163411734118341193412034121341223412334124341253412634127341283412934130341313413234133341343413534136341373413834139341403414134142341433414434145341463414734148341493415034151341523415334154341553415634157341583415934160341613416234163341643416534166341673416834169341703417134172341733417434175341763417734178341793418034181341823418334184341853418634187341883418934190341913419234193341943419534196341973419834199342003420134202342033420434205342063420734208342093421034211342123421334214342153421634217342183421934220342213422234223342243422534226342273422834229342303423134232342333423434235342363423734238342393424034241342423424334244342453424634247342483424934250342513425234253342543425534256342573425834259342603426134262342633426434265342663426734268342693427034271342723427334274342753427634277342783427934280342813428234283342843428534286342873428834289342903429134292342933429434295342963429734298342993430034301343023430334304343053430634307343083430934310343113431234313343143431534316343173431834319343203432134322343233432434325343263432734328343293433034331343323433334334343353433634337343383433934340343413434234343343443434534346343473434834349343503435134352343533435434355343563435734358343593436034361343623436334364343653436634367343683436934370343713437234373343743437534376343773437834379343803438134382343833438434385343863438734388343893439034391343923439334394343953439634397343983439934400344013440234403344043440534406344073440834409344103441134412344133441434415344163441734418344193442034421344223442334424344253442634427344283442934430344313443234433344343443534436344373443834439344403444134442344433444434445344463444734448344493445034451344523445334454344553445634457344583445934460344613446234463344643446534466344673446834469344703447134472344733447434475344763447734478344793448034481344823448334484344853448634487344883448934490344913449234493344943449534496344973449834499345003450134502345033450434505345063450734508345093451034511345123451334514345153451634517345183451934520345213452234523345243452534526345273452834529345303453134532345333453434535345363453734538345393454034541345423454334544345453454634547345483454934550345513455234553345543455534556345573455834559345603456134562345633456434565345663456734568345693457034571345723457334574345753457634577345783457934580345813458234583345843458534586345873458834589345903459134592345933459434595345963459734598345993460034601346023460334604346053460634607346083460934610346113461234613346143461534616346173461834619346203462134622346233462434625346263462734628346293463034631346323463334634346353463634637346383463934640346413464234643346443464534646346473464834649346503465134652346533465434655346563465734658346593466034661346623466334664346653466634667346683466934670346713467234673346743467534676346773467834679346803468134682346833468434685346863468734688346893469034691346923469334694346953469634697346983469934700347013470234703347043470534706347073470834709347103471134712347133471434715347163471734718347193472034721347223472334724347253472634727347283472934730347313473234733347343473534736347373473834739347403474134742347433474434745347463474734748347493475034751347523475334754347553475634757347583475934760347613476234763347643476534766347673476834769347703477134772347733477434775347763477734778347793478034781347823478334784347853478634787347883478934790347913479234793347943479534796347973479834799348003480134802348033480434805348063480734808348093481034811348123481334814348153481634817348183481934820348213482234823348243482534826348273482834829348303483134832348333483434835348363483734838348393484034841348423484334844348453484634847348483484934850348513485234853348543485534856348573485834859348603486134862348633486434865348663486734868348693487034871348723487334874348753487634877348783487934880348813488234883348843488534886348873488834889348903489134892348933489434895348963489734898348993490034901349023490334904349053490634907349083490934910349113491234913349143491534916349173491834919349203492134922349233492434925349263492734928349293493034931349323493334934349353493634937349383493934940349413494234943349443494534946349473494834949349503495134952349533495434955349563495734958349593496034961349623496334964349653496634967349683496934970349713497234973349743497534976349773497834979349803498134982349833498434985349863498734988349893499034991349923499334994349953499634997349983499935000350013500235003350043500535006350073500835009350103501135012350133501435015350163501735018350193502035021350223502335024350253502635027350283502935030350313503235033350343503535036350373503835039350403504135042350433504435045350463504735048350493505035051350523505335054350553505635057350583505935060350613506235063350643506535066350673506835069350703507135072350733507435075350763507735078350793508035081350823508335084350853508635087350883508935090350913509235093350943509535096350973509835099351003510135102351033510435105351063510735108351093511035111351123511335114351153511635117351183511935120351213512235123351243512535126351273512835129351303513135132351333513435135351363513735138351393514035141351423514335144351453514635147351483514935150351513515235153351543515535156351573515835159351603516135162351633516435165351663516735168351693517035171351723517335174351753517635177351783517935180351813518235183351843518535186351873518835189351903519135192351933519435195351963519735198351993520035201352023520335204352053520635207352083520935210352113521235213352143521535216352173521835219352203522135222352233522435225352263522735228352293523035231352323523335234352353523635237352383523935240352413524235243352443524535246352473524835249352503525135252352533525435255352563525735258352593526035261352623526335264352653526635267352683526935270352713527235273352743527535276352773527835279352803528135282352833528435285352863528735288352893529035291352923529335294352953529635297352983529935300353013530235303353043530535306353073530835309353103531135312353133531435315353163531735318353193532035321353223532335324353253532635327353283532935330353313533235333353343533535336353373533835339353403534135342353433534435345353463534735348353493535035351353523535335354353553535635357353583535935360353613536235363353643536535366353673536835369353703537135372353733537435375353763537735378353793538035381353823538335384353853538635387353883538935390353913539235393353943539535396353973539835399354003540135402354033540435405354063540735408354093541035411354123541335414354153541635417354183541935420354213542235423354243542535426354273542835429354303543135432354333543435435354363543735438354393544035441354423544335444354453544635447354483544935450354513545235453354543545535456354573545835459354603546135462354633546435465354663546735468354693547035471354723547335474354753547635477354783547935480354813548235483354843548535486354873548835489354903549135492354933549435495354963549735498354993550035501355023550335504355053550635507355083550935510355113551235513355143551535516355173551835519355203552135522355233552435525355263552735528355293553035531355323553335534355353553635537355383553935540355413554235543355443554535546355473554835549355503555135552355533555435555355563555735558355593556035561355623556335564355653556635567355683556935570355713557235573355743557535576355773557835579355803558135582355833558435585355863558735588355893559035591355923559335594355953559635597355983559935600356013560235603356043560535606356073560835609356103561135612356133561435615356163561735618356193562035621356223562335624356253562635627356283562935630356313563235633356343563535636356373563835639356403564135642356433564435645356463564735648356493565035651356523565335654356553565635657356583565935660356613566235663356643566535666356673566835669356703567135672356733567435675356763567735678356793568035681356823568335684356853568635687356883568935690356913569235693356943569535696356973569835699357003570135702357033570435705357063570735708357093571035711357123571335714357153571635717357183571935720357213572235723357243572535726357273572835729357303573135732357333573435735357363573735738357393574035741357423574335744357453574635747357483574935750357513575235753357543575535756357573575835759357603576135762357633576435765357663576735768357693577035771357723577335774357753577635777357783577935780357813578235783357843578535786357873578835789357903579135792357933579435795357963579735798357993580035801358023580335804358053580635807358083580935810358113581235813358143581535816358173581835819358203582135822358233582435825358263582735828358293583035831358323583335834358353583635837358383583935840358413584235843358443584535846358473584835849358503585135852358533585435855358563585735858358593586035861358623586335864358653586635867358683586935870358713587235873358743587535876358773587835879358803588135882358833588435885358863588735888358893589035891358923589335894358953589635897358983589935900359013590235903359043590535906359073590835909359103591135912359133591435915359163591735918359193592035921359223592335924359253592635927359283592935930359313593235933359343593535936359373593835939359403594135942359433594435945359463594735948359493595035951359523595335954359553595635957359583595935960359613596235963359643596535966359673596835969359703597135972359733597435975359763597735978359793598035981359823598335984359853598635987359883598935990359913599235993359943599535996359973599835999360003600136002360033600436005360063600736008360093601036011360123601336014360153601636017360183601936020360213602236023360243602536026360273602836029360303603136032360333603436035360363603736038360393604036041360423604336044360453604636047360483604936050360513605236053360543605536056360573605836059360603606136062360633606436065360663606736068360693607036071360723607336074360753607636077360783607936080360813608236083360843608536086360873608836089360903609136092360933609436095360963609736098360993610036101361023610336104361053610636107361083610936110361113611236113361143611536116361173611836119361203612136122361233612436125361263612736128361293613036131361323613336134361353613636137361383613936140361413614236143361443614536146361473614836149361503615136152361533615436155361563615736158361593616036161361623616336164361653616636167361683616936170361713617236173361743617536176361773617836179361803618136182361833618436185361863618736188361893619036191361923619336194361953619636197361983619936200362013620236203362043620536206362073620836209362103621136212362133621436215362163621736218362193622036221362223622336224362253622636227362283622936230362313623236233362343623536236362373623836239362403624136242362433624436245362463624736248362493625036251362523625336254362553625636257362583625936260362613626236263362643626536266362673626836269362703627136272362733627436275362763627736278362793628036281362823628336284362853628636287362883628936290362913629236293362943629536296362973629836299363003630136302363033630436305363063630736308363093631036311363123631336314363153631636317363183631936320363213632236323363243632536326363273632836329363303633136332363333633436335363363633736338363393634036341363423634336344363453634636347363483634936350363513635236353363543635536356363573635836359363603636136362363633636436365363663636736368363693637036371363723637336374363753637636377363783637936380363813638236383363843638536386363873638836389363903639136392363933639436395363963639736398363993640036401364023640336404364053640636407364083640936410364113641236413364143641536416364173641836419364203642136422364233642436425364263642736428364293643036431364323643336434364353643636437364383643936440364413644236443364443644536446364473644836449364503645136452364533645436455364563645736458364593646036461364623646336464364653646636467364683646936470364713647236473364743647536476364773647836479364803648136482364833648436485364863648736488364893649036491364923649336494364953649636497364983649936500365013650236503365043650536506365073650836509365103651136512365133651436515365163651736518365193652036521365223652336524365253652636527365283652936530365313653236533365343653536536365373653836539365403654136542365433654436545365463654736548365493655036551365523655336554365553655636557365583655936560365613656236563365643656536566365673656836569365703657136572365733657436575365763657736578365793658036581365823658336584365853658636587365883658936590365913659236593365943659536596365973659836599366003660136602366033660436605366063660736608366093661036611366123661336614366153661636617366183661936620366213662236623366243662536626366273662836629366303663136632366333663436635366363663736638366393664036641366423664336644366453664636647366483664936650366513665236653366543665536656366573665836659366603666136662366633666436665366663666736668366693667036671366723667336674366753667636677366783667936680366813668236683366843668536686366873668836689366903669136692366933669436695366963669736698366993670036701367023670336704367053670636707367083670936710367113671236713367143671536716367173671836719367203672136722367233672436725367263672736728367293673036731367323673336734367353673636737367383673936740367413674236743367443674536746367473674836749367503675136752367533675436755367563675736758367593676036761367623676336764367653676636767367683676936770367713677236773367743677536776367773677836779367803678136782367833678436785367863678736788367893679036791367923679336794367953679636797367983679936800368013680236803368043680536806368073680836809368103681136812368133681436815368163681736818368193682036821368223682336824368253682636827368283682936830368313683236833368343683536836368373683836839368403684136842368433684436845368463684736848368493685036851368523685336854368553685636857368583685936860368613686236863368643686536866368673686836869368703687136872368733687436875368763687736878368793688036881368823688336884368853688636887368883688936890368913689236893368943689536896368973689836899369003690136902369033690436905369063690736908369093691036911369123691336914369153691636917369183691936920369213692236923369243692536926369273692836929369303693136932369333693436935369363693736938369393694036941369423694336944369453694636947369483694936950369513695236953369543695536956369573695836959369603696136962369633696436965369663696736968369693697036971369723697336974369753697636977369783697936980369813698236983369843698536986369873698836989369903699136992369933699436995369963699736998369993700037001370023700337004370053700637007370083700937010370113701237013370143701537016370173701837019370203702137022370233702437025370263702737028370293703037031370323703337034370353703637037370383703937040370413704237043370443704537046370473704837049370503705137052370533705437055370563705737058370593706037061370623706337064370653706637067370683706937070370713707237073370743707537076370773707837079370803708137082370833708437085370863708737088370893709037091370923709337094370953709637097370983709937100371013710237103371043710537106371073710837109371103711137112371133711437115371163711737118371193712037121371223712337124371253712637127371283712937130371313713237133371343713537136371373713837139371403714137142371433714437145371463714737148371493715037151371523715337154371553715637157371583715937160371613716237163371643716537166371673716837169371703717137172371733717437175371763717737178371793718037181371823718337184371853718637187371883718937190371913719237193371943719537196371973719837199372003720137202372033720437205372063720737208372093721037211372123721337214372153721637217372183721937220372213722237223372243722537226372273722837229372303723137232372333723437235372363723737238372393724037241372423724337244372453724637247372483724937250372513725237253372543725537256372573725837259372603726137262372633726437265372663726737268372693727037271372723727337274372753727637277372783727937280372813728237283372843728537286372873728837289372903729137292372933729437295372963729737298372993730037301373023730337304373053730637307373083730937310373113731237313373143731537316373173731837319373203732137322373233732437325373263732737328373293733037331373323733337334373353733637337373383733937340373413734237343373443734537346373473734837349373503735137352373533735437355373563735737358373593736037361373623736337364373653736637367373683736937370373713737237373373743737537376373773737837379373803738137382373833738437385373863738737388373893739037391373923739337394373953739637397373983739937400374013740237403374043740537406374073740837409374103741137412374133741437415374163741737418374193742037421374223742337424374253742637427374283742937430374313743237433374343743537436374373743837439374403744137442374433744437445374463744737448374493745037451374523745337454374553745637457374583745937460374613746237463374643746537466374673746837469374703747137472374733747437475374763747737478374793748037481374823748337484374853748637487374883748937490374913749237493374943749537496374973749837499375003750137502375033750437505375063750737508375093751037511375123751337514375153751637517375183751937520375213752237523375243752537526375273752837529375303753137532375333753437535375363753737538375393754037541375423754337544375453754637547375483754937550375513755237553375543755537556375573755837559375603756137562375633756437565375663756737568375693757037571375723757337574375753757637577375783757937580375813758237583375843758537586375873758837589375903759137592375933759437595375963759737598375993760037601376023760337604376053760637607376083760937610376113761237613376143761537616376173761837619376203762137622376233762437625376263762737628376293763037631376323763337634376353763637637376383763937640376413764237643376443764537646376473764837649376503765137652376533765437655376563765737658376593766037661376623766337664376653766637667376683766937670376713767237673376743767537676376773767837679376803768137682376833768437685376863768737688376893769037691376923769337694376953769637697376983769937700377013770237703377043770537706377073770837709377103771137712377133771437715377163771737718377193772037721377223772337724377253772637727377283772937730377313773237733377343773537736377373773837739377403774137742377433774437745377463774737748377493775037751377523775337754377553775637757377583775937760377613776237763377643776537766377673776837769377703777137772377733777437775377763777737778377793778037781377823778337784377853778637787377883778937790377913779237793377943779537796377973779837799378003780137802378033780437805378063780737808378093781037811378123781337814378153781637817378183781937820378213782237823378243782537826378273782837829378303783137832378333783437835378363783737838378393784037841378423784337844378453784637847378483784937850378513785237853378543785537856378573785837859378603786137862378633786437865378663786737868378693787037871378723787337874378753787637877378783787937880378813788237883378843788537886378873788837889378903789137892378933789437895378963789737898378993790037901379023790337904379053790637907379083790937910379113791237913379143791537916379173791837919379203792137922379233792437925379263792737928379293793037931379323793337934379353793637937379383793937940379413794237943379443794537946379473794837949379503795137952379533795437955379563795737958379593796037961379623796337964379653796637967379683796937970379713797237973379743797537976379773797837979379803798137982379833798437985379863798737988379893799037991379923799337994379953799637997379983799938000380013800238003380043800538006380073800838009380103801138012380133801438015380163801738018380193802038021380223802338024380253802638027380283802938030380313803238033380343803538036380373803838039380403804138042380433804438045380463804738048380493805038051380523805338054380553805638057380583805938060380613806238063380643806538066380673806838069380703807138072380733807438075380763807738078380793808038081380823808338084380853808638087380883808938090380913809238093380943809538096380973809838099381003810138102381033810438105381063810738108381093811038111381123811338114381153811638117381183811938120381213812238123381243812538126381273812838129381303813138132381333813438135381363813738138381393814038141381423814338144381453814638147381483814938150381513815238153381543815538156381573815838159381603816138162381633816438165381663816738168381693817038171381723817338174381753817638177381783817938180381813818238183381843818538186381873818838189381903819138192381933819438195381963819738198381993820038201382023820338204382053820638207382083820938210382113821238213382143821538216382173821838219382203822138222382233822438225382263822738228382293823038231382323823338234382353823638237382383823938240382413824238243382443824538246382473824838249382503825138252382533825438255382563825738258382593826038261382623826338264382653826638267382683826938270382713827238273382743827538276382773827838279382803828138282382833828438285382863828738288382893829038291382923829338294382953829638297382983829938300383013830238303383043830538306383073830838309383103831138312383133831438315383163831738318383193832038321383223832338324383253832638327383283832938330383313833238333383343833538336383373833838339383403834138342383433834438345383463834738348383493835038351383523835338354383553835638357383583835938360383613836238363383643836538366383673836838369383703837138372383733837438375383763837738378383793838038381383823838338384383853838638387383883838938390383913839238393383943839538396383973839838399384003840138402384033840438405384063840738408384093841038411384123841338414384153841638417384183841938420384213842238423384243842538426384273842838429384303843138432384333843438435384363843738438384393844038441384423844338444384453844638447384483844938450384513845238453384543845538456384573845838459384603846138462384633846438465384663846738468384693847038471384723847338474384753847638477384783847938480384813848238483384843848538486384873848838489384903849138492384933849438495384963849738498384993850038501385023850338504385053850638507385083850938510385113851238513385143851538516385173851838519385203852138522385233852438525385263852738528385293853038531385323853338534385353853638537385383853938540385413854238543385443854538546385473854838549385503855138552385533855438555385563855738558385593856038561385623856338564385653856638567385683856938570385713857238573385743857538576385773857838579385803858138582385833858438585385863858738588385893859038591385923859338594385953859638597385983859938600386013860238603386043860538606386073860838609386103861138612386133861438615386163861738618386193862038621386223862338624386253862638627386283862938630386313863238633386343863538636386373863838639386403864138642386433864438645386463864738648386493865038651386523865338654386553865638657386583865938660386613866238663386643866538666386673866838669386703867138672386733867438675386763867738678386793868038681386823868338684386853868638687386883868938690386913869238693386943869538696386973869838699387003870138702387033870438705387063870738708387093871038711387123871338714387153871638717387183871938720387213872238723387243872538726387273872838729387303873138732387333873438735387363873738738387393874038741387423874338744387453874638747387483874938750387513875238753387543875538756387573875838759387603876138762387633876438765387663876738768387693877038771387723877338774387753877638777387783877938780387813878238783387843878538786387873878838789387903879138792387933879438795387963879738798387993880038801388023880338804388053880638807388083880938810388113881238813388143881538816388173881838819388203882138822388233882438825388263882738828388293883038831388323883338834388353883638837388383883938840388413884238843388443884538846388473884838849388503885138852388533885438855388563885738858388593886038861388623886338864388653886638867388683886938870388713887238873388743887538876388773887838879388803888138882388833888438885388863888738888388893889038891388923889338894388953889638897388983889938900389013890238903389043890538906389073890838909389103891138912389133891438915389163891738918389193892038921389223892338924389253892638927389283892938930389313893238933389343893538936389373893838939389403894138942389433894438945389463894738948389493895038951389523895338954389553895638957389583895938960389613896238963389643896538966389673896838969389703897138972389733897438975389763897738978389793898038981389823898338984389853898638987389883898938990389913899238993389943899538996389973899838999390003900139002390033900439005390063900739008390093901039011390123901339014390153901639017390183901939020390213902239023390243902539026390273902839029390303903139032390333903439035390363903739038390393904039041390423904339044390453904639047390483904939050390513905239053390543905539056390573905839059390603906139062390633906439065390663906739068390693907039071390723907339074390753907639077390783907939080390813908239083390843908539086390873908839089390903909139092390933909439095390963909739098390993910039101391023910339104391053910639107391083910939110391113911239113391143911539116391173911839119391203912139122391233912439125391263912739128391293913039131391323913339134391353913639137391383913939140391413914239143391443914539146391473914839149391503915139152391533915439155391563915739158391593916039161391623916339164391653916639167391683916939170391713917239173391743917539176391773917839179391803918139182391833918439185391863918739188391893919039191391923919339194391953919639197391983919939200392013920239203392043920539206392073920839209392103921139212392133921439215392163921739218392193922039221392223922339224392253922639227392283922939230392313923239233392343923539236392373923839239392403924139242392433924439245392463924739248392493925039251392523925339254392553925639257392583925939260392613926239263392643926539266392673926839269392703927139272392733927439275392763927739278392793928039281392823928339284392853928639287392883928939290392913929239293392943929539296392973929839299393003930139302393033930439305393063930739308393093931039311393123931339314393153931639317393183931939320393213932239323393243932539326393273932839329393303933139332393333933439335393363933739338393393934039341393423934339344393453934639347393483934939350393513935239353393543935539356393573935839359393603936139362393633936439365393663936739368393693937039371393723937339374393753937639377393783937939380393813938239383393843938539386393873938839389393903939139392393933939439395393963939739398393993940039401394023940339404394053940639407394083940939410394113941239413394143941539416394173941839419394203942139422394233942439425394263942739428394293943039431394323943339434394353943639437394383943939440394413944239443394443944539446394473944839449394503945139452394533945439455394563945739458394593946039461394623946339464394653946639467394683946939470394713947239473394743947539476394773947839479394803948139482394833948439485394863948739488394893949039491394923949339494394953949639497394983949939500395013950239503395043950539506395073950839509395103951139512395133951439515395163951739518395193952039521395223952339524395253952639527395283952939530395313953239533395343953539536395373953839539395403954139542395433954439545395463954739548395493955039551395523955339554395553955639557395583955939560395613956239563395643956539566395673956839569395703957139572395733957439575395763957739578395793958039581395823958339584395853958639587395883958939590395913959239593395943959539596395973959839599396003960139602396033960439605396063960739608396093961039611396123961339614396153961639617396183961939620396213962239623396243962539626396273962839629396303963139632396333963439635396363963739638396393964039641396423964339644396453964639647396483964939650396513965239653396543965539656396573965839659396603966139662396633966439665396663966739668396693967039671396723967339674396753967639677396783967939680396813968239683396843968539686396873968839689396903969139692396933969439695396963969739698396993970039701397023970339704397053970639707397083970939710397113971239713397143971539716397173971839719397203972139722397233972439725397263972739728397293973039731397323973339734397353973639737397383973939740397413974239743397443974539746397473974839749397503975139752397533975439755397563975739758397593976039761397623976339764397653976639767397683976939770397713977239773397743977539776397773977839779397803978139782397833978439785397863978739788397893979039791397923979339794397953979639797397983979939800398013980239803398043980539806398073980839809398103981139812398133981439815398163981739818398193982039821398223982339824398253982639827398283982939830398313983239833398343983539836398373983839839398403984139842398433984439845398463984739848398493985039851398523985339854398553985639857398583985939860398613986239863398643986539866398673986839869398703987139872398733987439875398763987739878398793988039881398823988339884398853988639887398883988939890398913989239893398943989539896398973989839899399003990139902399033990439905399063990739908399093991039911399123991339914399153991639917399183991939920399213992239923399243992539926399273992839929399303993139932399333993439935399363993739938399393994039941399423994339944399453994639947399483994939950399513995239953399543995539956399573995839959399603996139962399633996439965399663996739968399693997039971399723997339974399753997639977399783997939980399813998239983399843998539986399873998839989399903999139992399933999439995399963999739998399994000040001400024000340004400054000640007400084000940010400114001240013400144001540016400174001840019400204002140022400234002440025400264002740028400294003040031400324003340034400354003640037400384003940040400414004240043400444004540046400474004840049400504005140052400534005440055400564005740058400594006040061400624006340064400654006640067400684006940070400714007240073400744007540076400774007840079400804008140082400834008440085400864008740088400894009040091400924009340094400954009640097400984009940100401014010240103401044010540106401074010840109401104011140112401134011440115401164011740118401194012040121401224012340124401254012640127401284012940130401314013240133401344013540136401374013840139401404014140142401434014440145401464014740148401494015040151401524015340154401554015640157401584015940160401614016240163401644016540166401674016840169401704017140172401734017440175401764017740178401794018040181401824018340184401854018640187401884018940190401914019240193401944019540196401974019840199402004020140202402034020440205402064020740208402094021040211402124021340214402154021640217402184021940220402214022240223402244022540226402274022840229402304023140232402334023440235402364023740238402394024040241402424024340244402454024640247402484024940250402514025240253402544025540256402574025840259402604026140262402634026440265402664026740268402694027040271402724027340274402754027640277402784027940280402814028240283402844028540286402874028840289402904029140292402934029440295402964029740298402994030040301403024030340304403054030640307403084030940310403114031240313403144031540316403174031840319403204032140322403234032440325403264032740328403294033040331403324033340334403354033640337403384033940340403414034240343403444034540346403474034840349403504035140352403534035440355403564035740358403594036040361403624036340364403654036640367403684036940370403714037240373403744037540376403774037840379403804038140382403834038440385403864038740388403894039040391403924039340394403954039640397403984039940400404014040240403404044040540406404074040840409404104041140412404134041440415404164041740418404194042040421404224042340424404254042640427404284042940430404314043240433404344043540436404374043840439404404044140442404434044440445404464044740448404494045040451404524045340454404554045640457404584045940460404614046240463404644046540466404674046840469404704047140472404734047440475404764047740478404794048040481404824048340484404854048640487404884048940490404914049240493404944049540496404974049840499405004050140502405034050440505405064050740508405094051040511405124051340514405154051640517405184051940520405214052240523405244052540526405274052840529405304053140532405334053440535405364053740538405394054040541405424054340544405454054640547405484054940550405514055240553405544055540556405574055840559405604056140562405634056440565405664056740568405694057040571405724057340574405754057640577405784057940580405814058240583405844058540586405874058840589405904059140592405934059440595405964059740598405994060040601406024060340604406054060640607406084060940610406114061240613406144061540616406174061840619406204062140622406234062440625406264062740628406294063040631406324063340634406354063640637406384063940640406414064240643406444064540646406474064840649406504065140652406534065440655406564065740658406594066040661406624066340664406654066640667406684066940670406714067240673406744067540676406774067840679406804068140682406834068440685406864068740688406894069040691406924069340694406954069640697406984069940700407014070240703407044070540706407074070840709407104071140712407134071440715407164071740718407194072040721407224072340724407254072640727407284072940730407314073240733407344073540736407374073840739407404074140742407434074440745407464074740748407494075040751407524075340754407554075640757407584075940760407614076240763407644076540766407674076840769407704077140772407734077440775407764077740778407794078040781407824078340784407854078640787407884078940790407914079240793407944079540796407974079840799408004080140802408034080440805408064080740808408094081040811408124081340814408154081640817408184081940820408214082240823408244082540826408274082840829408304083140832408334083440835408364083740838408394084040841408424084340844408454084640847408484084940850408514085240853408544085540856408574085840859408604086140862408634086440865408664086740868408694087040871408724087340874408754087640877408784087940880408814088240883408844088540886408874088840889408904089140892408934089440895408964089740898408994090040901409024090340904409054090640907409084090940910409114091240913409144091540916409174091840919409204092140922409234092440925409264092740928409294093040931409324093340934409354093640937409384093940940409414094240943409444094540946409474094840949409504095140952409534095440955409564095740958409594096040961409624096340964409654096640967409684096940970409714097240973409744097540976409774097840979409804098140982409834098440985409864098740988409894099040991409924099340994409954099640997409984099941000410014100241003410044100541006410074100841009410104101141012410134101441015410164101741018410194102041021410224102341024410254102641027410284102941030410314103241033410344103541036410374103841039410404104141042410434104441045410464104741048410494105041051410524105341054410554105641057410584105941060410614106241063410644106541066410674106841069410704107141072410734107441075410764107741078410794108041081410824108341084410854108641087410884108941090410914109241093410944109541096410974109841099411004110141102411034110441105411064110741108411094111041111411124111341114411154111641117411184111941120411214112241123411244112541126411274112841129411304113141132411334113441135411364113741138411394114041141411424114341144411454114641147411484114941150411514115241153411544115541156411574115841159411604116141162411634116441165411664116741168411694117041171411724117341174411754117641177411784117941180411814118241183411844118541186411874118841189411904119141192411934119441195411964119741198411994120041201412024120341204412054120641207412084120941210412114121241213412144121541216412174121841219412204122141222412234122441225412264122741228412294123041231412324123341234412354123641237412384123941240412414124241243412444124541246412474124841249412504125141252412534125441255412564125741258412594126041261412624126341264412654126641267412684126941270412714127241273412744127541276412774127841279412804128141282412834128441285412864128741288412894129041291412924129341294412954129641297412984129941300413014130241303413044130541306413074130841309413104131141312413134131441315413164131741318413194132041321413224132341324413254132641327413284132941330413314133241333413344133541336413374133841339413404134141342413434134441345413464134741348413494135041351413524135341354413554135641357413584135941360413614136241363413644136541366413674136841369413704137141372413734137441375413764137741378413794138041381413824138341384413854138641387413884138941390413914139241393413944139541396413974139841399414004140141402414034140441405414064140741408414094141041411414124141341414414154141641417414184141941420414214142241423414244142541426414274142841429414304143141432414334143441435414364143741438414394144041441414424144341444414454144641447414484144941450414514145241453414544145541456414574145841459414604146141462414634146441465414664146741468414694147041471414724147341474414754147641477414784147941480414814148241483414844148541486414874148841489414904149141492414934149441495414964149741498414994150041501415024150341504415054150641507415084150941510415114151241513415144151541516415174151841519415204152141522415234152441525415264152741528415294153041531415324153341534415354153641537415384153941540415414154241543415444154541546415474154841549415504155141552415534155441555415564155741558415594156041561415624156341564415654156641567415684156941570415714157241573415744157541576415774157841579415804158141582415834158441585415864158741588415894159041591415924159341594415954159641597415984159941600416014160241603416044160541606416074160841609416104161141612416134161441615416164161741618416194162041621416224162341624416254162641627416284162941630416314163241633416344163541636416374163841639416404164141642416434164441645416464164741648416494165041651416524165341654416554165641657416584165941660416614166241663416644166541666416674166841669416704167141672416734167441675416764167741678416794168041681416824168341684416854168641687416884168941690416914169241693416944169541696416974169841699417004170141702417034170441705417064170741708417094171041711417124171341714417154171641717417184171941720417214172241723417244172541726417274172841729417304173141732417334173441735417364173741738417394174041741417424174341744417454174641747417484174941750417514175241753417544175541756417574175841759417604176141762417634176441765417664176741768417694177041771417724177341774417754177641777417784177941780417814178241783417844178541786417874178841789417904179141792417934179441795417964179741798417994180041801418024180341804418054180641807418084180941810418114181241813418144181541816418174181841819418204182141822418234182441825418264182741828418294183041831418324183341834418354183641837418384183941840418414184241843418444184541846418474184841849418504185141852418534185441855418564185741858418594186041861418624186341864418654186641867418684186941870418714187241873418744187541876418774187841879418804188141882418834188441885418864188741888418894189041891418924189341894418954189641897418984189941900419014190241903419044190541906419074190841909419104191141912419134191441915419164191741918419194192041921419224192341924419254192641927419284192941930419314193241933419344193541936419374193841939419404194141942419434194441945419464194741948419494195041951419524195341954419554195641957419584195941960419614196241963419644196541966419674196841969419704197141972419734197441975419764197741978419794198041981419824198341984419854198641987419884198941990419914199241993419944199541996419974199841999420004200142002420034200442005420064200742008420094201042011420124201342014420154201642017420184201942020420214202242023420244202542026420274202842029420304203142032420334203442035420364203742038420394204042041420424204342044420454204642047420484204942050420514205242053420544205542056420574205842059420604206142062420634206442065420664206742068420694207042071420724207342074420754207642077420784207942080420814208242083420844208542086420874208842089420904209142092420934209442095420964209742098420994210042101421024210342104421054210642107421084210942110421114211242113421144211542116421174211842119421204212142122421234212442125421264212742128421294213042131421324213342134421354213642137421384213942140421414214242143421444214542146421474214842149421504215142152421534215442155421564215742158421594216042161421624216342164421654216642167421684216942170421714217242173421744217542176421774217842179421804218142182421834218442185421864218742188421894219042191421924219342194421954219642197421984219942200422014220242203422044220542206422074220842209422104221142212422134221442215422164221742218422194222042221422224222342224422254222642227422284222942230422314223242233422344223542236422374223842239422404224142242422434224442245422464224742248422494225042251422524225342254422554225642257422584225942260422614226242263422644226542266422674226842269422704227142272422734227442275422764227742278422794228042281422824228342284422854228642287422884228942290422914229242293422944229542296422974229842299423004230142302423034230442305423064230742308423094231042311423124231342314423154231642317423184231942320423214232242323423244232542326423274232842329423304233142332423334233442335423364233742338423394234042341423424234342344423454234642347423484234942350423514235242353423544235542356423574235842359423604236142362423634236442365423664236742368423694237042371423724237342374423754237642377423784237942380423814238242383423844238542386423874238842389423904239142392423934239442395423964239742398423994240042401424024240342404424054240642407424084240942410424114241242413424144241542416424174241842419424204242142422424234242442425424264242742428424294243042431424324243342434424354243642437424384243942440424414244242443424444244542446424474244842449424504245142452424534245442455424564245742458424594246042461424624246342464424654246642467424684246942470424714247242473424744247542476424774247842479424804248142482424834248442485424864248742488424894249042491424924249342494424954249642497424984249942500425014250242503425044250542506425074250842509425104251142512425134251442515425164251742518425194252042521425224252342524425254252642527425284252942530425314253242533425344253542536425374253842539425404254142542425434254442545425464254742548425494255042551425524255342554425554255642557425584255942560425614256242563425644256542566425674256842569425704257142572425734257442575425764257742578425794258042581425824258342584425854258642587425884258942590425914259242593425944259542596425974259842599426004260142602426034260442605426064260742608426094261042611426124261342614426154261642617426184261942620426214262242623426244262542626426274262842629426304263142632426334263442635426364263742638426394264042641426424264342644426454264642647426484264942650426514265242653426544265542656426574265842659426604266142662426634266442665426664266742668426694267042671426724267342674426754267642677426784267942680426814268242683426844268542686426874268842689426904269142692426934269442695426964269742698426994270042701427024270342704427054270642707427084270942710427114271242713427144271542716427174271842719427204272142722427234272442725427264272742728427294273042731427324273342734427354273642737427384273942740427414274242743427444274542746427474274842749427504275142752427534275442755427564275742758427594276042761427624276342764427654276642767427684276942770427714277242773427744277542776427774277842779427804278142782427834278442785427864278742788427894279042791427924279342794427954279642797427984279942800428014280242803428044280542806428074280842809428104281142812428134281442815428164281742818428194282042821428224282342824428254282642827428284282942830428314283242833428344283542836428374283842839428404284142842428434284442845428464284742848428494285042851428524285342854428554285642857428584285942860428614286242863428644286542866428674286842869428704287142872428734287442875428764287742878428794288042881428824288342884428854288642887428884288942890428914289242893428944289542896428974289842899429004290142902429034290442905429064290742908429094291042911429124291342914429154291642917429184291942920429214292242923429244292542926429274292842929429304293142932429334293442935429364293742938429394294042941429424294342944429454294642947429484294942950429514295242953429544295542956429574295842959429604296142962429634296442965429664296742968429694297042971429724297342974429754297642977429784297942980429814298242983429844298542986429874298842989429904299142992429934299442995429964299742998429994300043001430024300343004430054300643007430084300943010430114301243013430144301543016430174301843019430204302143022430234302443025430264302743028430294303043031430324303343034430354303643037430384303943040430414304243043430444304543046430474304843049430504305143052430534305443055430564305743058430594306043061430624306343064430654306643067430684306943070430714307243073430744307543076430774307843079430804308143082430834308443085430864308743088430894309043091430924309343094430954309643097430984309943100431014310243103431044310543106431074310843109431104311143112431134311443115431164311743118431194312043121431224312343124431254312643127431284312943130431314313243133431344313543136431374313843139431404314143142431434314443145431464314743148431494315043151431524315343154431554315643157431584315943160431614316243163431644316543166431674316843169431704317143172431734317443175431764317743178431794318043181431824318343184431854318643187431884318943190431914319243193431944319543196431974319843199432004320143202432034320443205432064320743208432094321043211432124321343214432154321643217432184321943220432214322243223432244322543226432274322843229432304323143232432334323443235432364323743238432394324043241432424324343244432454324643247432484324943250432514325243253432544325543256432574325843259432604326143262432634326443265432664326743268432694327043271432724327343274432754327643277432784327943280432814328243283432844328543286432874328843289432904329143292432934329443295432964329743298432994330043301433024330343304433054330643307433084330943310433114331243313433144331543316433174331843319433204332143322433234332443325433264332743328433294333043331433324333343334433354333643337433384333943340433414334243343433444334543346433474334843349433504335143352433534335443355433564335743358433594336043361433624336343364433654336643367433684336943370433714337243373433744337543376433774337843379433804338143382433834338443385433864338743388433894339043391433924339343394433954339643397433984339943400434014340243403434044340543406434074340843409434104341143412434134341443415434164341743418434194342043421434224342343424434254342643427434284342943430434314343243433434344343543436434374343843439434404344143442434434344443445434464344743448434494345043451434524345343454434554345643457434584345943460434614346243463434644346543466434674346843469434704347143472434734347443475434764347743478434794348043481434824348343484434854348643487434884348943490434914349243493434944349543496434974349843499435004350143502435034350443505435064350743508435094351043511435124351343514435154351643517435184351943520435214352243523435244352543526435274352843529435304353143532435334353443535435364353743538435394354043541435424354343544435454354643547435484354943550435514355243553435544355543556435574355843559435604356143562435634356443565435664356743568435694357043571435724357343574435754357643577435784357943580435814358243583435844358543586435874358843589435904359143592435934359443595435964359743598435994360043601436024360343604436054360643607436084360943610436114361243613436144361543616436174361843619436204362143622436234362443625436264362743628436294363043631436324363343634436354363643637436384363943640436414364243643436444364543646436474364843649436504365143652436534365443655436564365743658436594366043661436624366343664436654366643667436684366943670436714367243673436744367543676436774367843679436804368143682436834368443685436864368743688436894369043691436924369343694436954369643697436984369943700437014370243703437044370543706437074370843709437104371143712437134371443715437164371743718437194372043721437224372343724437254372643727437284372943730437314373243733437344373543736437374373843739437404374143742437434374443745437464374743748437494375043751437524375343754437554375643757437584375943760437614376243763437644376543766437674376843769437704377143772437734377443775437764377743778437794378043781437824378343784437854378643787437884378943790437914379243793437944379543796437974379843799438004380143802438034380443805438064380743808438094381043811438124381343814438154381643817438184381943820438214382243823438244382543826438274382843829438304383143832438334383443835438364383743838438394384043841438424384343844438454384643847438484384943850438514385243853438544385543856438574385843859438604386143862438634386443865438664386743868438694387043871438724387343874438754387643877438784387943880438814388243883438844388543886438874388843889438904389143892438934389443895438964389743898438994390043901439024390343904439054390643907439084390943910439114391243913439144391543916439174391843919439204392143922439234392443925439264392743928439294393043931439324393343934439354393643937439384393943940439414394243943439444394543946439474394843949439504395143952439534395443955439564395743958439594396043961439624396343964439654396643967439684396943970439714397243973439744397543976439774397843979439804398143982439834398443985439864398743988439894399043991439924399343994439954399643997439984399944000440014400244003440044400544006440074400844009440104401144012440134401444015440164401744018440194402044021440224402344024440254402644027440284402944030440314403244033440344403544036440374403844039440404404144042440434404444045440464404744048440494405044051440524405344054440554405644057440584405944060440614406244063440644406544066440674406844069440704407144072440734407444075440764407744078440794408044081440824408344084440854408644087440884408944090440914409244093440944409544096440974409844099441004410144102441034410444105441064410744108441094411044111441124411344114441154411644117441184411944120441214412244123441244412544126441274412844129441304413144132441334413444135441364413744138441394414044141441424414344144441454414644147441484414944150441514415244153441544415544156441574415844159441604416144162441634416444165441664416744168441694417044171441724417344174441754417644177441784417944180441814418244183441844418544186441874418844189441904419144192441934419444195441964419744198441994420044201442024420344204442054420644207442084420944210442114421244213442144421544216442174421844219442204422144222442234422444225442264422744228442294423044231442324423344234442354423644237442384423944240442414424244243442444424544246442474424844249442504425144252442534425444255442564425744258442594426044261442624426344264442654426644267442684426944270442714427244273442744427544276442774427844279442804428144282442834428444285442864428744288442894429044291442924429344294442954429644297442984429944300443014430244303443044430544306443074430844309443104431144312443134431444315443164431744318443194432044321443224432344324443254432644327443284432944330443314433244333443344433544336443374433844339443404434144342443434434444345443464434744348443494435044351443524435344354443554435644357443584435944360443614436244363443644436544366443674436844369443704437144372443734437444375443764437744378443794438044381443824438344384443854438644387443884438944390443914439244393443944439544396443974439844399444004440144402444034440444405444064440744408444094441044411444124441344414444154441644417444184441944420444214442244423444244442544426444274442844429444304443144432444334443444435444364443744438444394444044441444424444344444444454444644447444484444944450444514445244453444544445544456444574445844459444604446144462444634446444465444664446744468444694447044471444724447344474444754447644477444784447944480444814448244483444844448544486444874448844489444904449144492444934449444495444964449744498444994450044501445024450344504445054450644507445084450944510445114451244513445144451544516445174451844519445204452144522445234452444525445264452744528445294453044531445324453344534445354453644537445384453944540445414454244543445444454544546445474454844549445504455144552445534455444555445564455744558445594456044561445624456344564445654456644567445684456944570445714457244573445744457544576445774457844579445804458144582445834458444585445864458744588445894459044591445924459344594445954459644597445984459944600446014460244603446044460544606446074460844609446104461144612446134461444615446164461744618446194462044621446224462344624446254462644627446284462944630446314463244633446344463544636446374463844639446404464144642446434464444645446464464744648446494465044651446524465344654446554465644657446584465944660446614466244663446644466544666446674466844669446704467144672446734467444675446764467744678446794468044681446824468344684446854468644687446884468944690446914469244693446944469544696446974469844699447004470144702447034470444705447064470744708447094471044711447124471344714447154471644717447184471944720447214472244723447244472544726447274472844729447304473144732447334473444735447364473744738447394474044741447424474344744447454474644747447484474944750447514475244753447544475544756447574475844759447604476144762447634476444765447664476744768447694477044771447724477344774447754477644777447784477944780447814478244783447844478544786447874478844789447904479144792447934479444795447964479744798447994480044801448024480344804448054480644807448084480944810448114481244813448144481544816448174481844819448204482144822448234482444825448264482744828448294483044831448324483344834448354483644837448384483944840448414484244843448444484544846448474484844849448504485144852448534485444855448564485744858448594486044861448624486344864448654486644867448684486944870448714487244873448744487544876448774487844879448804488144882448834488444885448864488744888448894489044891448924489344894448954489644897448984489944900449014490244903449044490544906449074490844909449104491144912449134491444915449164491744918449194492044921449224492344924449254492644927449284492944930449314493244933449344493544936449374493844939449404494144942449434494444945449464494744948449494495044951449524495344954449554495644957449584495944960449614496244963449644496544966449674496844969449704497144972449734497444975449764497744978449794498044981449824498344984449854498644987449884498944990449914499244993449944499544996449974499844999450004500145002450034500445005450064500745008450094501045011450124501345014450154501645017450184501945020450214502245023450244502545026450274502845029450304503145032450334503445035450364503745038450394504045041450424504345044450454504645047450484504945050450514505245053450544505545056450574505845059450604506145062450634506445065450664506745068450694507045071450724507345074450754507645077450784507945080450814508245083450844508545086450874508845089450904509145092450934509445095450964509745098450994510045101451024510345104451054510645107451084510945110451114511245113451144511545116451174511845119451204512145122451234512445125451264512745128451294513045131451324513345134451354513645137451384513945140451414514245143451444514545146451474514845149451504515145152451534515445155451564515745158451594516045161451624516345164451654516645167451684516945170451714517245173451744517545176451774517845179451804518145182451834518445185451864518745188451894519045191451924519345194451954519645197451984519945200452014520245203452044520545206452074520845209452104521145212452134521445215452164521745218452194522045221452224522345224452254522645227452284522945230452314523245233452344523545236452374523845239452404524145242452434524445245452464524745248452494525045251452524525345254452554525645257452584525945260452614526245263452644526545266452674526845269452704527145272452734527445275452764527745278452794528045281452824528345284452854528645287452884528945290452914529245293452944529545296452974529845299453004530145302453034530445305453064530745308453094531045311453124531345314453154531645317453184531945320453214532245323453244532545326453274532845329453304533145332453334533445335453364533745338453394534045341453424534345344453454534645347453484534945350453514535245353453544535545356453574535845359453604536145362453634536445365453664536745368453694537045371453724537345374453754537645377453784537945380453814538245383453844538545386453874538845389453904539145392453934539445395453964539745398453994540045401454024540345404454054540645407454084540945410454114541245413454144541545416454174541845419454204542145422454234542445425454264542745428454294543045431454324543345434454354543645437454384543945440454414544245443454444544545446454474544845449454504545145452454534545445455454564545745458454594546045461454624546345464454654546645467454684546945470454714547245473454744547545476454774547845479454804548145482454834548445485454864548745488454894549045491454924549345494454954549645497454984549945500455014550245503455044550545506455074550845509455104551145512455134551445515455164551745518455194552045521455224552345524455254552645527455284552945530455314553245533455344553545536455374553845539455404554145542455434554445545455464554745548455494555045551455524555345554455554555645557455584555945560455614556245563455644556545566455674556845569455704557145572455734557445575455764557745578455794558045581455824558345584455854558645587455884558945590455914559245593455944559545596455974559845599456004560145602456034560445605456064560745608456094561045611456124561345614456154561645617456184561945620456214562245623456244562545626456274562845629456304563145632456334563445635456364563745638456394564045641456424564345644456454564645647456484564945650456514565245653456544565545656456574565845659456604566145662456634566445665456664566745668456694567045671456724567345674456754567645677456784567945680456814568245683456844568545686456874568845689456904569145692456934569445695456964569745698456994570045701457024570345704457054570645707457084570945710457114571245713457144571545716457174571845719457204572145722457234572445725457264572745728457294573045731457324573345734457354573645737457384573945740457414574245743457444574545746457474574845749457504575145752457534575445755457564575745758457594576045761457624576345764457654576645767457684576945770457714577245773457744577545776457774577845779457804578145782457834578445785457864578745788457894579045791457924579345794457954579645797457984579945800458014580245803458044580545806458074580845809458104581145812458134581445815458164581745818458194582045821458224582345824458254582645827458284582945830458314583245833458344583545836458374583845839458404584145842458434584445845458464584745848458494585045851458524585345854458554585645857458584585945860458614586245863458644586545866458674586845869458704587145872458734587445875458764587745878458794588045881458824588345884458854588645887458884588945890458914589245893458944589545896458974589845899459004590145902459034590445905459064590745908459094591045911459124591345914459154591645917459184591945920459214592245923459244592545926459274592845929459304593145932459334593445935459364593745938459394594045941459424594345944459454594645947459484594945950459514595245953459544595545956459574595845959459604596145962459634596445965459664596745968459694597045971459724597345974459754597645977459784597945980459814598245983459844598545986459874598845989459904599145992459934599445995459964599745998459994600046001460024600346004460054600646007460084600946010460114601246013460144601546016460174601846019460204602146022460234602446025460264602746028460294603046031460324603346034460354603646037460384603946040460414604246043460444604546046460474604846049460504605146052460534605446055460564605746058460594606046061460624606346064460654606646067460684606946070460714607246073460744607546076460774607846079460804608146082460834608446085460864608746088460894609046091460924609346094460954609646097460984609946100461014610246103461044610546106461074610846109461104611146112461134611446115461164611746118461194612046121461224612346124461254612646127461284612946130461314613246133461344613546136461374613846139461404614146142461434614446145461464614746148461494615046151461524615346154461554615646157461584615946160461614616246163461644616546166461674616846169461704617146172461734617446175461764617746178461794618046181461824618346184461854618646187461884618946190461914619246193461944619546196461974619846199462004620146202462034620446205462064620746208462094621046211462124621346214462154621646217462184621946220462214622246223462244622546226462274622846229462304623146232462334623446235462364623746238462394624046241462424624346244462454624646247462484624946250462514625246253462544625546256462574625846259462604626146262462634626446265462664626746268462694627046271462724627346274462754627646277462784627946280462814628246283462844628546286462874628846289462904629146292462934629446295462964629746298462994630046301463024630346304463054630646307463084630946310463114631246313463144631546316463174631846319463204632146322463234632446325463264632746328463294633046331463324633346334463354633646337463384633946340463414634246343463444634546346463474634846349463504635146352463534635446355463564635746358463594636046361463624636346364463654636646367463684636946370463714637246373463744637546376463774637846379463804638146382463834638446385463864638746388463894639046391463924639346394463954639646397463984639946400464014640246403464044640546406464074640846409464104641146412464134641446415464164641746418464194642046421464224642346424464254642646427464284642946430464314643246433464344643546436464374643846439464404644146442464434644446445464464644746448464494645046451464524645346454464554645646457464584645946460464614646246463464644646546466464674646846469464704647146472464734647446475464764647746478464794648046481464824648346484464854648646487464884648946490464914649246493464944649546496464974649846499465004650146502465034650446505465064650746508465094651046511465124651346514465154651646517465184651946520465214652246523465244652546526465274652846529465304653146532465334653446535465364653746538465394654046541465424654346544465454654646547465484654946550465514655246553465544655546556465574655846559465604656146562465634656446565465664656746568465694657046571465724657346574465754657646577465784657946580465814658246583465844658546586465874658846589465904659146592465934659446595465964659746598465994660046601466024660346604466054660646607466084660946610466114661246613466144661546616466174661846619466204662146622466234662446625466264662746628466294663046631466324663346634466354663646637466384663946640466414664246643466444664546646466474664846649466504665146652466534665446655466564665746658466594666046661466624666346664466654666646667466684666946670466714667246673466744667546676466774667846679466804668146682466834668446685466864668746688466894669046691466924669346694466954669646697466984669946700467014670246703467044670546706467074670846709467104671146712467134671446715467164671746718467194672046721467224672346724467254672646727467284672946730467314673246733467344673546736467374673846739467404674146742467434674446745467464674746748467494675046751467524675346754467554675646757467584675946760467614676246763467644676546766467674676846769467704677146772467734677446775467764677746778467794678046781467824678346784467854678646787467884678946790467914679246793467944679546796467974679846799468004680146802468034680446805468064680746808468094681046811468124681346814468154681646817468184681946820468214682246823468244682546826468274682846829468304683146832468334683446835468364683746838468394684046841468424684346844468454684646847468484684946850468514685246853468544685546856468574685846859468604686146862468634686446865468664686746868468694687046871468724687346874468754687646877468784687946880468814688246883468844688546886468874688846889468904689146892468934689446895468964689746898468994690046901469024690346904469054690646907469084690946910469114691246913469144691546916469174691846919469204692146922469234692446925469264692746928469294693046931469324693346934469354693646937469384693946940469414694246943469444694546946469474694846949469504695146952469534695446955469564695746958469594696046961469624696346964469654696646967469684696946970469714697246973469744697546976469774697846979469804698146982469834698446985469864698746988469894699046991469924699346994469954699646997469984699947000470014700247003470044700547006470074700847009470104701147012470134701447015470164701747018470194702047021470224702347024470254702647027470284702947030470314703247033470344703547036470374703847039470404704147042470434704447045470464704747048470494705047051470524705347054470554705647057470584705947060470614706247063470644706547066470674706847069470704707147072470734707447075470764707747078470794708047081470824708347084470854708647087470884708947090470914709247093470944709547096470974709847099471004710147102471034710447105471064710747108471094711047111471124711347114471154711647117471184711947120471214712247123471244712547126471274712847129471304713147132471334713447135471364713747138471394714047141471424714347144471454714647147471484714947150471514715247153471544715547156471574715847159471604716147162471634716447165471664716747168471694717047171471724717347174471754717647177471784717947180471814718247183471844718547186471874718847189471904719147192471934719447195471964719747198471994720047201472024720347204472054720647207472084720947210472114721247213472144721547216472174721847219472204722147222472234722447225472264722747228472294723047231472324723347234472354723647237472384723947240472414724247243472444724547246472474724847249472504725147252472534725447255472564725747258472594726047261472624726347264472654726647267472684726947270472714727247273472744727547276472774727847279472804728147282472834728447285472864728747288472894729047291472924729347294472954729647297472984729947300473014730247303473044730547306473074730847309473104731147312473134731447315473164731747318473194732047321473224732347324473254732647327473284732947330473314733247333473344733547336473374733847339473404734147342473434734447345473464734747348473494735047351473524735347354473554735647357473584735947360473614736247363473644736547366473674736847369473704737147372473734737447375473764737747378473794738047381473824738347384473854738647387473884738947390473914739247393473944739547396473974739847399474004740147402474034740447405474064740747408474094741047411474124741347414474154741647417474184741947420474214742247423474244742547426474274742847429474304743147432474334743447435474364743747438474394744047441474424744347444474454744647447474484744947450474514745247453474544745547456474574745847459474604746147462474634746447465474664746747468474694747047471474724747347474474754747647477474784747947480474814748247483474844748547486474874748847489474904749147492474934749447495474964749747498474994750047501475024750347504475054750647507475084750947510475114751247513475144751547516475174751847519475204752147522475234752447525475264752747528475294753047531475324753347534475354753647537475384753947540475414754247543475444754547546475474754847549475504755147552475534755447555475564755747558475594756047561475624756347564475654756647567475684756947570475714757247573475744757547576475774757847579475804758147582475834758447585475864758747588475894759047591475924759347594475954759647597475984759947600476014760247603476044760547606476074760847609476104761147612476134761447615476164761747618476194762047621476224762347624476254762647627476284762947630476314763247633476344763547636476374763847639476404764147642476434764447645476464764747648476494765047651476524765347654476554765647657476584765947660476614766247663476644766547666476674766847669476704767147672476734767447675476764767747678476794768047681476824768347684476854768647687476884768947690476914769247693476944769547696476974769847699477004770147702477034770447705477064770747708477094771047711477124771347714477154771647717477184771947720477214772247723477244772547726477274772847729477304773147732477334773447735477364773747738477394774047741477424774347744477454774647747477484774947750477514775247753477544775547756477574775847759477604776147762477634776447765477664776747768477694777047771477724777347774477754777647777477784777947780477814778247783477844778547786477874778847789477904779147792477934779447795477964779747798477994780047801478024780347804478054780647807478084780947810478114781247813478144781547816478174781847819478204782147822478234782447825478264782747828478294783047831478324783347834478354783647837478384783947840478414784247843478444784547846478474784847849478504785147852478534785447855478564785747858478594786047861478624786347864478654786647867478684786947870478714787247873478744787547876478774787847879478804788147882478834788447885478864788747888478894789047891478924789347894478954789647897478984789947900479014790247903479044790547906479074790847909479104791147912479134791447915479164791747918479194792047921479224792347924479254792647927479284792947930479314793247933479344793547936479374793847939479404794147942479434794447945479464794747948479494795047951479524795347954479554795647957479584795947960479614796247963479644796547966479674796847969479704797147972479734797447975479764797747978479794798047981479824798347984479854798647987479884798947990479914799247993479944799547996479974799847999480004800148002480034800448005480064800748008480094801048011480124801348014480154801648017480184801948020480214802248023480244802548026480274802848029480304803148032480334803448035480364803748038480394804048041480424804348044480454804648047480484804948050480514805248053480544805548056480574805848059480604806148062480634806448065480664806748068480694807048071480724807348074480754807648077480784807948080480814808248083480844808548086480874808848089480904809148092480934809448095480964809748098480994810048101481024810348104481054810648107481084810948110481114811248113481144811548116481174811848119481204812148122481234812448125481264812748128481294813048131481324813348134481354813648137481384813948140481414814248143481444814548146481474814848149481504815148152481534815448155481564815748158481594816048161481624816348164481654816648167481684816948170481714817248173481744817548176481774817848179481804818148182481834818448185481864818748188481894819048191481924819348194481954819648197481984819948200482014820248203482044820548206482074820848209482104821148212482134821448215482164821748218482194822048221482224822348224482254822648227482284822948230482314823248233482344823548236482374823848239482404824148242482434824448245482464824748248482494825048251482524825348254482554825648257482584825948260482614826248263482644826548266482674826848269482704827148272482734827448275482764827748278482794828048281482824828348284482854828648287482884828948290482914829248293482944829548296482974829848299483004830148302483034830448305483064830748308483094831048311483124831348314483154831648317483184831948320483214832248323483244832548326483274832848329483304833148332483334833448335483364833748338483394834048341483424834348344483454834648347483484834948350483514835248353483544835548356483574835848359483604836148362483634836448365483664836748368483694837048371483724837348374483754837648377483784837948380483814838248383483844838548386483874838848389483904839148392483934839448395483964839748398483994840048401484024840348404484054840648407484084840948410484114841248413484144841548416484174841848419484204842148422484234842448425484264842748428484294843048431484324843348434484354843648437484384843948440484414844248443484444844548446484474844848449484504845148452484534845448455484564845748458484594846048461484624846348464484654846648467484684846948470484714847248473484744847548476484774847848479484804848148482484834848448485484864848748488484894849048491484924849348494484954849648497484984849948500485014850248503485044850548506485074850848509485104851148512485134851448515485164851748518485194852048521485224852348524485254852648527485284852948530485314853248533485344853548536485374853848539485404854148542485434854448545485464854748548485494855048551485524855348554485554855648557485584855948560485614856248563485644856548566485674856848569485704857148572485734857448575485764857748578485794858048581485824858348584485854858648587485884858948590485914859248593485944859548596485974859848599486004860148602486034860448605486064860748608486094861048611486124861348614486154861648617486184861948620486214862248623486244862548626486274862848629486304863148632486334863448635486364863748638486394864048641486424864348644486454864648647486484864948650486514865248653486544865548656486574865848659486604866148662486634866448665486664866748668486694867048671486724867348674486754867648677486784867948680486814868248683486844868548686486874868848689486904869148692486934869448695486964869748698486994870048701487024870348704487054870648707487084870948710487114871248713487144871548716487174871848719487204872148722487234872448725487264872748728487294873048731487324873348734487354873648737487384873948740487414874248743487444874548746487474874848749487504875148752487534875448755487564875748758487594876048761487624876348764487654876648767487684876948770487714877248773487744877548776487774877848779487804878148782487834878448785487864878748788487894879048791487924879348794487954879648797487984879948800488014880248803488044880548806488074880848809488104881148812488134881448815488164881748818488194882048821488224882348824488254882648827488284882948830488314883248833488344883548836488374883848839488404884148842488434884448845488464884748848488494885048851488524885348854488554885648857488584885948860488614886248863488644886548866488674886848869488704887148872488734887448875488764887748878488794888048881488824888348884488854888648887488884888948890488914889248893488944889548896488974889848899489004890148902489034890448905489064890748908489094891048911489124891348914489154891648917489184891948920489214892248923489244892548926489274892848929489304893148932489334893448935489364893748938489394894048941489424894348944489454894648947489484894948950489514895248953489544895548956489574895848959489604896148962489634896448965489664896748968489694897048971489724897348974489754897648977489784897948980489814898248983489844898548986489874898848989489904899148992489934899448995489964899748998489994900049001490024900349004490054900649007490084900949010490114901249013490144901549016490174901849019490204902149022490234902449025490264902749028490294903049031490324903349034490354903649037490384903949040490414904249043490444904549046490474904849049490504905149052490534905449055490564905749058490594906049061490624906349064490654906649067490684906949070490714907249073490744907549076490774907849079490804908149082490834908449085490864908749088490894909049091490924909349094490954909649097490984909949100491014910249103491044910549106491074910849109491104911149112491134911449115491164911749118491194912049121491224912349124491254912649127491284912949130491314913249133491344913549136491374913849139491404914149142491434914449145491464914749148491494915049151491524915349154491554915649157491584915949160491614916249163491644916549166491674916849169491704917149172491734917449175491764917749178491794918049181491824918349184491854918649187491884918949190491914919249193491944919549196491974919849199492004920149202492034920449205492064920749208492094921049211492124921349214492154921649217492184921949220492214922249223492244922549226492274922849229492304923149232492334923449235492364923749238492394924049241492424924349244492454924649247492484924949250492514925249253492544925549256492574925849259492604926149262492634926449265492664926749268492694927049271492724927349274492754927649277492784927949280492814928249283492844928549286492874928849289492904929149292492934929449295492964929749298492994930049301493024930349304493054930649307493084930949310493114931249313493144931549316493174931849319493204932149322493234932449325493264932749328493294933049331493324933349334493354933649337493384933949340493414934249343493444934549346493474934849349493504935149352493534935449355493564935749358493594936049361493624936349364493654936649367493684936949370493714937249373493744937549376493774937849379493804938149382493834938449385493864938749388493894939049391493924939349394493954939649397493984939949400494014940249403494044940549406494074940849409494104941149412494134941449415494164941749418494194942049421494224942349424494254942649427494284942949430494314943249433494344943549436494374943849439494404944149442494434944449445494464944749448494494945049451494524945349454494554945649457494584945949460494614946249463494644946549466494674946849469494704947149472494734947449475494764947749478494794948049481494824948349484494854948649487494884948949490494914949249493494944949549496494974949849499495004950149502495034950449505495064950749508495094951049511495124951349514495154951649517495184951949520495214952249523495244952549526495274952849529495304953149532495334953449535495364953749538495394954049541495424954349544495454954649547495484954949550495514955249553495544955549556495574955849559495604956149562495634956449565495664956749568495694957049571495724957349574495754957649577495784957949580495814958249583495844958549586495874958849589495904959149592495934959449595495964959749598495994960049601496024960349604496054960649607496084960949610496114961249613496144961549616496174961849619496204962149622496234962449625496264962749628496294963049631496324963349634496354963649637496384963949640496414964249643496444964549646496474964849649496504965149652496534965449655496564965749658496594966049661496624966349664496654966649667496684966949670496714967249673496744967549676496774967849679496804968149682496834968449685496864968749688496894969049691496924969349694496954969649697496984969949700497014970249703497044970549706497074970849709497104971149712497134971449715497164971749718497194972049721497224972349724497254972649727497284972949730497314973249733497344973549736497374973849739497404974149742497434974449745497464974749748497494975049751497524975349754497554975649757497584975949760497614976249763497644976549766497674976849769497704977149772497734977449775497764977749778497794978049781497824978349784497854978649787497884978949790497914979249793497944979549796497974979849799498004980149802498034980449805498064980749808498094981049811498124981349814498154981649817498184981949820498214982249823498244982549826498274982849829498304983149832498334983449835498364983749838498394984049841498424984349844498454984649847498484984949850498514985249853498544985549856498574985849859498604986149862498634986449865498664986749868498694987049871498724987349874498754987649877498784987949880498814988249883498844988549886498874988849889498904989149892498934989449895498964989749898498994990049901499024990349904499054990649907499084990949910499114991249913499144991549916499174991849919499204992149922499234992449925499264992749928499294993049931499324993349934499354993649937499384993949940499414994249943499444994549946499474994849949499504995149952499534995449955499564995749958499594996049961499624996349964499654996649967499684996949970499714997249973499744997549976499774997849979499804998149982499834998449985499864998749988499894999049991499924999349994499954999649997499984999950000500015000250003500045000550006500075000850009500105001150012500135001450015500165001750018500195002050021500225002350024500255002650027500285002950030500315003250033500345003550036500375003850039500405004150042500435004450045500465004750048500495005050051500525005350054500555005650057500585005950060500615006250063500645006550066500675006850069500705007150072500735007450075500765007750078500795008050081500825008350084500855008650087500885008950090500915009250093500945009550096500975009850099501005010150102501035010450105501065010750108501095011050111501125011350114501155011650117501185011950120501215012250123501245012550126501275012850129501305013150132501335013450135501365013750138501395014050141501425014350144501455014650147501485014950150501515015250153501545015550156501575015850159501605016150162501635016450165501665016750168501695017050171501725017350174501755017650177501785017950180501815018250183501845018550186501875018850189501905019150192501935019450195501965019750198501995020050201502025020350204502055020650207502085020950210502115021250213502145021550216502175021850219502205022150222502235022450225502265022750228502295023050231502325023350234502355023650237502385023950240502415024250243502445024550246502475024850249502505025150252502535025450255502565025750258502595026050261502625026350264502655026650267502685026950270502715027250273502745027550276502775027850279502805028150282502835028450285502865028750288502895029050291502925029350294502955029650297502985029950300503015030250303503045030550306503075030850309503105031150312503135031450315503165031750318503195032050321503225032350324503255032650327503285032950330503315033250333503345033550336503375033850339503405034150342503435034450345503465034750348503495035050351503525035350354503555035650357503585035950360503615036250363503645036550366503675036850369503705037150372503735037450375503765037750378503795038050381503825038350384503855038650387503885038950390503915039250393503945039550396503975039850399504005040150402504035040450405504065040750408504095041050411504125041350414504155041650417504185041950420504215042250423504245042550426504275042850429504305043150432504335043450435504365043750438504395044050441504425044350444504455044650447504485044950450504515045250453504545045550456504575045850459504605046150462504635046450465504665046750468504695047050471504725047350474504755047650477504785047950480504815048250483504845048550486504875048850489504905049150492504935049450495504965049750498504995050050501505025050350504505055050650507505085050950510505115051250513505145051550516505175051850519505205052150522505235052450525505265052750528505295053050531505325053350534505355053650537505385053950540505415054250543505445054550546505475054850549505505055150552505535055450555505565055750558505595056050561505625056350564505655056650567505685056950570505715057250573505745057550576505775057850579505805058150582505835058450585505865058750588505895059050591505925059350594505955059650597505985059950600506015060250603506045060550606506075060850609506105061150612506135061450615506165061750618506195062050621506225062350624506255062650627506285062950630506315063250633506345063550636506375063850639506405064150642506435064450645506465064750648506495065050651506525065350654506555065650657506585065950660506615066250663506645066550666506675066850669506705067150672506735067450675506765067750678506795068050681506825068350684506855068650687506885068950690506915069250693506945069550696506975069850699507005070150702507035070450705507065070750708507095071050711507125071350714507155071650717507185071950720507215072250723507245072550726507275072850729507305073150732507335073450735507365073750738507395074050741507425074350744507455074650747507485074950750507515075250753507545075550756507575075850759507605076150762507635076450765507665076750768507695077050771507725077350774507755077650777507785077950780507815078250783507845078550786507875078850789507905079150792507935079450795507965079750798507995080050801508025080350804508055080650807508085080950810508115081250813508145081550816508175081850819508205082150822508235082450825508265082750828508295083050831508325083350834508355083650837508385083950840508415084250843508445084550846508475084850849508505085150852508535085450855508565085750858508595086050861508625086350864508655086650867508685086950870508715087250873508745087550876508775087850879508805088150882508835088450885508865088750888508895089050891508925089350894508955089650897508985089950900509015090250903509045090550906509075090850909509105091150912509135091450915509165091750918509195092050921509225092350924509255092650927509285092950930509315093250933509345093550936509375093850939509405094150942509435094450945509465094750948509495095050951509525095350954509555095650957509585095950960509615096250963509645096550966509675096850969509705097150972509735097450975509765097750978509795098050981509825098350984509855098650987509885098950990509915099250993509945099550996509975099850999510005100151002510035100451005510065100751008510095101051011510125101351014510155101651017510185101951020510215102251023510245102551026510275102851029510305103151032510335103451035510365103751038510395104051041510425104351044510455104651047510485104951050510515105251053510545105551056510575105851059510605106151062510635106451065510665106751068510695107051071510725107351074510755107651077510785107951080510815108251083510845108551086510875108851089510905109151092510935109451095510965109751098510995110051101511025110351104511055110651107511085110951110511115111251113511145111551116511175111851119511205112151122511235112451125511265112751128511295113051131511325113351134511355113651137511385113951140511415114251143511445114551146511475114851149511505115151152511535115451155511565115751158511595116051161511625116351164511655116651167511685116951170511715117251173511745117551176511775117851179511805118151182511835118451185511865118751188511895119051191511925119351194511955119651197511985119951200512015120251203512045120551206512075120851209512105121151212512135121451215512165121751218512195122051221512225122351224512255122651227512285122951230512315123251233512345123551236512375123851239512405124151242512435124451245512465124751248512495125051251512525125351254512555125651257512585125951260512615126251263512645126551266512675126851269512705127151272512735127451275512765127751278512795128051281512825128351284512855128651287512885128951290512915129251293512945129551296512975129851299513005130151302513035130451305513065130751308513095131051311513125131351314513155131651317513185131951320513215132251323513245132551326513275132851329513305133151332513335133451335513365133751338513395134051341513425134351344513455134651347513485134951350513515135251353513545135551356513575135851359513605136151362513635136451365513665136751368513695137051371513725137351374513755137651377513785137951380513815138251383513845138551386513875138851389513905139151392513935139451395513965139751398513995140051401514025140351404514055140651407514085140951410514115141251413514145141551416514175141851419514205142151422514235142451425514265142751428514295143051431514325143351434514355143651437514385143951440514415144251443514445144551446514475144851449514505145151452514535145451455514565145751458514595146051461514625146351464514655146651467514685146951470514715147251473514745147551476514775147851479514805148151482514835148451485514865148751488514895149051491514925149351494514955149651497514985149951500515015150251503515045150551506515075150851509515105151151512515135151451515515165151751518515195152051521515225152351524515255152651527515285152951530515315153251533515345153551536515375153851539515405154151542515435154451545515465154751548515495155051551515525155351554515555155651557515585155951560515615156251563515645156551566515675156851569515705157151572515735157451575515765157751578515795158051581515825158351584515855158651587515885158951590515915159251593515945159551596515975159851599516005160151602516035160451605516065160751608516095161051611516125161351614516155161651617516185161951620516215162251623516245162551626516275162851629516305163151632516335163451635516365163751638516395164051641516425164351644516455164651647516485164951650516515165251653516545165551656516575165851659516605166151662516635166451665516665166751668516695167051671516725167351674516755167651677516785167951680516815168251683516845168551686516875168851689516905169151692516935169451695516965169751698516995170051701517025170351704517055170651707517085170951710517115171251713517145171551716517175171851719517205172151722517235172451725517265172751728517295173051731517325173351734517355173651737517385173951740517415174251743517445174551746517475174851749517505175151752517535175451755517565175751758517595176051761517625176351764517655176651767517685176951770517715177251773517745177551776517775177851779517805178151782517835178451785517865178751788517895179051791517925179351794517955179651797517985179951800518015180251803518045180551806518075180851809518105181151812518135181451815518165181751818518195182051821518225182351824518255182651827518285182951830518315183251833518345183551836518375183851839518405184151842518435184451845518465184751848518495185051851518525185351854518555185651857518585185951860518615186251863518645186551866518675186851869518705187151872518735187451875518765187751878518795188051881518825188351884518855188651887518885188951890518915189251893518945189551896518975189851899519005190151902519035190451905519065190751908519095191051911519125191351914519155191651917519185191951920519215192251923519245192551926519275192851929519305193151932519335193451935519365193751938519395194051941519425194351944519455194651947519485194951950519515195251953519545195551956519575195851959519605196151962519635196451965519665196751968519695197051971519725197351974519755197651977519785197951980519815198251983519845198551986519875198851989519905199151992519935199451995519965199751998519995200052001520025200352004520055200652007520085200952010520115201252013520145201552016520175201852019520205202152022520235202452025520265202752028520295203052031520325203352034520355203652037520385203952040520415204252043520445204552046520475204852049520505205152052520535205452055520565205752058520595206052061520625206352064520655206652067520685206952070520715207252073520745207552076520775207852079520805208152082520835208452085520865208752088520895209052091520925209352094520955209652097520985209952100521015210252103521045210552106521075210852109521105211152112521135211452115521165211752118521195212052121521225212352124521255212652127521285212952130521315213252133521345213552136521375213852139521405214152142521435214452145521465214752148521495215052151521525215352154521555215652157521585215952160521615216252163521645216552166521675216852169521705217152172521735217452175521765217752178521795218052181521825218352184521855218652187521885218952190521915219252193521945219552196521975219852199522005220152202522035220452205522065220752208522095221052211522125221352214522155221652217522185221952220522215222252223522245222552226522275222852229522305223152232522335223452235522365223752238522395224052241522425224352244522455224652247522485224952250522515225252253522545225552256522575225852259522605226152262522635226452265522665226752268522695227052271522725227352274522755227652277522785227952280522815228252283522845228552286522875228852289522905229152292522935229452295522965229752298522995230052301523025230352304523055230652307523085230952310523115231252313523145231552316523175231852319523205232152322523235232452325523265232752328523295233052331523325233352334523355233652337523385233952340523415234252343523445234552346523475234852349523505235152352523535235452355523565235752358523595236052361523625236352364523655236652367523685236952370523715237252373523745237552376523775237852379523805238152382523835238452385523865238752388523895239052391523925239352394523955239652397523985239952400524015240252403524045240552406524075240852409524105241152412524135241452415524165241752418524195242052421524225242352424524255242652427524285242952430524315243252433524345243552436524375243852439524405244152442524435244452445524465244752448524495245052451524525245352454524555245652457524585245952460524615246252463524645246552466524675246852469524705247152472524735247452475524765247752478524795248052481524825248352484524855248652487524885248952490524915249252493524945249552496524975249852499525005250152502525035250452505525065250752508525095251052511525125251352514525155251652517525185251952520525215252252523525245252552526525275252852529525305253152532525335253452535525365253752538525395254052541525425254352544525455254652547525485254952550525515255252553525545255552556525575255852559525605256152562525635256452565525665256752568525695257052571525725257352574525755257652577525785257952580525815258252583525845258552586525875258852589525905259152592525935259452595525965259752598525995260052601526025260352604526055260652607526085260952610526115261252613526145261552616526175261852619526205262152622526235262452625526265262752628526295263052631526325263352634526355263652637526385263952640526415264252643526445264552646526475264852649526505265152652526535265452655526565265752658526595266052661526625266352664526655266652667526685266952670526715267252673526745267552676526775267852679526805268152682526835268452685526865268752688526895269052691526925269352694526955269652697526985269952700527015270252703527045270552706527075270852709527105271152712527135271452715527165271752718527195272052721527225272352724527255272652727527285272952730527315273252733527345273552736527375273852739527405274152742527435274452745527465274752748527495275052751527525275352754527555275652757527585275952760527615276252763527645276552766527675276852769527705277152772527735277452775527765277752778527795278052781527825278352784527855278652787527885278952790527915279252793527945279552796527975279852799528005280152802528035280452805528065280752808528095281052811528125281352814528155281652817528185281952820528215282252823528245282552826528275282852829528305283152832528335283452835528365283752838528395284052841528425284352844528455284652847528485284952850528515285252853528545285552856528575285852859528605286152862528635286452865528665286752868528695287052871528725287352874528755287652877528785287952880528815288252883528845288552886528875288852889528905289152892528935289452895528965289752898528995290052901529025290352904529055290652907529085290952910529115291252913529145291552916529175291852919529205292152922529235292452925529265292752928529295293052931529325293352934529355293652937529385293952940529415294252943529445294552946529475294852949529505295152952529535295452955529565295752958529595296052961529625296352964529655296652967529685296952970529715297252973529745297552976529775297852979529805298152982529835298452985529865298752988529895299052991529925299352994529955299652997529985299953000530015300253003530045300553006530075300853009530105301153012530135301453015530165301753018530195302053021530225302353024530255302653027530285302953030530315303253033530345303553036530375303853039530405304153042530435304453045530465304753048530495305053051530525305353054530555305653057530585305953060530615306253063530645306553066530675306853069530705307153072530735307453075530765307753078530795308053081530825308353084530855308653087530885308953090530915309253093530945309553096530975309853099531005310153102531035310453105531065310753108531095311053111531125311353114531155311653117531185311953120531215312253123531245312553126531275312853129531305313153132531335313453135531365313753138531395314053141531425314353144531455314653147531485314953150531515315253153531545315553156531575315853159531605316153162531635316453165531665316753168531695317053171531725317353174531755317653177531785317953180531815318253183531845318553186531875318853189531905319153192531935319453195531965319753198531995320053201532025320353204532055320653207532085320953210532115321253213532145321553216532175321853219532205322153222532235322453225532265322753228532295323053231532325323353234532355323653237532385323953240532415324253243532445324553246532475324853249532505325153252532535325453255532565325753258532595326053261532625326353264532655326653267532685326953270532715327253273532745327553276532775327853279532805328153282532835328453285532865328753288532895329053291532925329353294532955329653297532985329953300533015330253303533045330553306533075330853309533105331153312533135331453315533165331753318533195332053321533225332353324533255332653327533285332953330533315333253333533345333553336533375333853339533405334153342533435334453345533465334753348533495335053351533525335353354533555335653357533585335953360533615336253363533645336553366533675336853369533705337153372533735337453375533765337753378533795338053381533825338353384533855338653387533885338953390533915339253393533945339553396533975339853399534005340153402534035340453405534065340753408534095341053411534125341353414534155341653417534185341953420534215342253423534245342553426534275342853429534305343153432534335343453435534365343753438534395344053441534425344353444534455344653447534485344953450534515345253453534545345553456534575345853459534605346153462534635346453465534665346753468534695347053471534725347353474534755347653477534785347953480534815348253483534845348553486534875348853489534905349153492534935349453495534965349753498534995350053501535025350353504535055350653507535085350953510535115351253513535145351553516535175351853519535205352153522535235352453525535265352753528535295353053531535325353353534535355353653537535385353953540535415354253543535445354553546535475354853549535505355153552535535355453555535565355753558535595356053561535625356353564535655356653567535685356953570535715357253573535745357553576535775357853579535805358153582535835358453585535865358753588535895359053591535925359353594535955359653597535985359953600536015360253603536045360553606536075360853609536105361153612536135361453615536165361753618536195362053621536225362353624536255362653627536285362953630536315363253633536345363553636536375363853639536405364153642536435364453645536465364753648536495365053651536525365353654536555365653657536585365953660536615366253663536645366553666536675366853669536705367153672536735367453675536765367753678536795368053681536825368353684536855368653687536885368953690536915369253693536945369553696536975369853699537005370153702537035370453705537065370753708537095371053711537125371353714537155371653717537185371953720537215372253723537245372553726537275372853729537305373153732537335373453735537365373753738537395374053741537425374353744537455374653747537485374953750537515375253753537545375553756537575375853759537605376153762537635376453765537665376753768537695377053771537725377353774537755377653777537785377953780537815378253783537845378553786537875378853789537905379153792537935379453795537965379753798537995380053801538025380353804538055380653807538085380953810538115381253813538145381553816538175381853819538205382153822538235382453825538265382753828538295383053831538325383353834538355383653837538385383953840538415384253843538445384553846538475384853849538505385153852538535385453855538565385753858538595386053861538625386353864538655386653867538685386953870538715387253873538745387553876538775387853879538805388153882538835388453885538865388753888538895389053891538925389353894538955389653897538985389953900539015390253903539045390553906539075390853909539105391153912539135391453915539165391753918539195392053921539225392353924539255392653927539285392953930539315393253933539345393553936539375393853939539405394153942539435394453945539465394753948539495395053951539525395353954539555395653957539585395953960539615396253963539645396553966539675396853969539705397153972539735397453975539765397753978539795398053981539825398353984539855398653987539885398953990539915399253993539945399553996539975399853999540005400154002540035400454005540065400754008540095401054011540125401354014540155401654017540185401954020540215402254023540245402554026540275402854029540305403154032540335403454035540365403754038540395404054041540425404354044540455404654047540485404954050540515405254053540545405554056540575405854059540605406154062540635406454065540665406754068540695407054071540725407354074540755407654077540785407954080540815408254083540845408554086540875408854089540905409154092540935409454095540965409754098540995410054101541025410354104541055410654107541085410954110541115411254113541145411554116541175411854119541205412154122541235412454125541265412754128541295413054131541325413354134541355413654137541385413954140541415414254143541445414554146541475414854149541505415154152541535415454155541565415754158541595416054161541625416354164541655416654167541685416954170541715417254173541745417554176541775417854179541805418154182541835418454185541865418754188541895419054191541925419354194541955419654197541985419954200542015420254203542045420554206542075420854209542105421154212542135421454215542165421754218542195422054221542225422354224542255422654227542285422954230542315423254233542345423554236542375423854239542405424154242542435424454245542465424754248542495425054251542525425354254542555425654257542585425954260542615426254263542645426554266542675426854269542705427154272542735427454275542765427754278542795428054281542825428354284542855428654287542885428954290542915429254293542945429554296542975429854299543005430154302543035430454305543065430754308543095431054311543125431354314543155431654317543185431954320543215432254323543245432554326543275432854329543305433154332543335433454335543365433754338543395434054341543425434354344543455434654347543485434954350543515435254353543545435554356543575435854359543605436154362543635436454365543665436754368543695437054371543725437354374543755437654377543785437954380543815438254383543845438554386543875438854389543905439154392543935439454395543965439754398543995440054401544025440354404544055440654407544085440954410544115441254413544145441554416544175441854419544205442154422544235442454425544265442754428544295443054431544325443354434544355443654437544385443954440544415444254443544445444554446544475444854449544505445154452544535445454455544565445754458544595446054461544625446354464544655446654467544685446954470544715447254473544745447554476544775447854479544805448154482544835448454485544865448754488544895449054491544925449354494544955449654497544985449954500545015450254503545045450554506545075450854509545105451154512545135451454515545165451754518545195452054521545225452354524545255452654527545285452954530545315453254533545345453554536545375453854539545405454154542545435454454545545465454754548545495455054551545525455354554545555455654557545585455954560545615456254563545645456554566545675456854569545705457154572545735457454575545765457754578545795458054581545825458354584545855458654587545885458954590545915459254593545945459554596545975459854599546005460154602546035460454605546065460754608546095461054611546125461354614546155461654617546185461954620546215462254623546245462554626546275462854629546305463154632546335463454635546365463754638546395464054641546425464354644546455464654647546485464954650546515465254653546545465554656546575465854659546605466154662546635466454665546665466754668546695467054671546725467354674546755467654677546785467954680546815468254683546845468554686546875468854689546905469154692546935469454695546965469754698546995470054701547025470354704547055470654707547085470954710547115471254713547145471554716547175471854719547205472154722547235472454725547265472754728547295473054731547325473354734547355473654737547385473954740547415474254743547445474554746547475474854749547505475154752547535475454755547565475754758547595476054761547625476354764547655476654767547685476954770547715477254773547745477554776547775477854779547805478154782547835478454785547865478754788547895479054791547925479354794547955479654797547985479954800548015480254803548045480554806548075480854809548105481154812548135481454815548165481754818548195482054821548225482354824548255482654827548285482954830548315483254833548345483554836548375483854839548405484154842548435484454845548465484754848548495485054851548525485354854548555485654857548585485954860548615486254863548645486554866548675486854869548705487154872548735487454875548765487754878548795488054881548825488354884548855488654887548885488954890548915489254893548945489554896548975489854899549005490154902549035490454905549065490754908549095491054911549125491354914549155491654917549185491954920549215492254923549245492554926549275492854929549305493154932549335493454935549365493754938549395494054941549425494354944549455494654947549485494954950549515495254953549545495554956549575495854959549605496154962549635496454965549665496754968549695497054971549725497354974549755497654977549785497954980549815498254983549845498554986549875498854989549905499154992549935499454995549965499754998549995500055001550025500355004550055500655007550085500955010550115501255013550145501555016550175501855019550205502155022550235502455025550265502755028550295503055031550325503355034550355503655037550385503955040550415504255043550445504555046550475504855049550505505155052550535505455055550565505755058550595506055061550625506355064550655506655067550685506955070550715507255073550745507555076550775507855079550805508155082550835508455085550865508755088550895509055091550925509355094550955509655097550985509955100551015510255103551045510555106551075510855109551105511155112551135511455115551165511755118551195512055121551225512355124551255512655127551285512955130551315513255133551345513555136551375513855139551405514155142551435514455145551465514755148551495515055151551525515355154551555515655157551585515955160551615516255163551645516555166551675516855169551705517155172551735517455175551765517755178551795518055181551825518355184551855518655187551885518955190551915519255193551945519555196551975519855199552005520155202552035520455205552065520755208552095521055211552125521355214552155521655217552185521955220552215522255223552245522555226552275522855229552305523155232552335523455235552365523755238552395524055241552425524355244552455524655247552485524955250552515525255253552545525555256552575525855259552605526155262552635526455265552665526755268552695527055271552725527355274552755527655277552785527955280552815528255283552845528555286552875528855289552905529155292552935529455295552965529755298552995530055301553025530355304553055530655307553085530955310553115531255313553145531555316553175531855319553205532155322553235532455325553265532755328553295533055331553325533355334553355533655337553385533955340553415534255343553445534555346553475534855349553505535155352553535535455355553565535755358553595536055361553625536355364553655536655367553685536955370553715537255373553745537555376553775537855379553805538155382553835538455385553865538755388553895539055391553925539355394553955539655397553985539955400554015540255403554045540555406554075540855409554105541155412554135541455415554165541755418554195542055421554225542355424554255542655427554285542955430554315543255433554345543555436554375543855439554405544155442554435544455445554465544755448554495545055451554525545355454554555545655457554585545955460554615546255463554645546555466554675546855469554705547155472554735547455475554765547755478554795548055481554825548355484554855548655487554885548955490554915549255493554945549555496554975549855499555005550155502555035550455505555065550755508555095551055511555125551355514555155551655517555185551955520555215552255523555245552555526555275552855529555305553155532555335553455535555365553755538555395554055541555425554355544555455554655547555485554955550555515555255553555545555555556555575555855559555605556155562555635556455565555665556755568555695557055571555725557355574555755557655577555785557955580555815558255583555845558555586555875558855589555905559155592555935559455595555965559755598555995560055601556025560355604556055560655607556085560955610556115561255613556145561555616556175561855619556205562155622556235562455625556265562755628556295563055631556325563355634556355563655637556385563955640556415564255643556445564555646556475564855649556505565155652556535565455655556565565755658556595566055661556625566355664556655566655667556685566955670556715567255673556745567555676556775567855679556805568155682556835568455685556865568755688556895569055691556925569355694556955569655697556985569955700557015570255703557045570555706557075570855709557105571155712557135571455715557165571755718557195572055721557225572355724557255572655727557285572955730557315573255733557345573555736557375573855739557405574155742557435574455745557465574755748557495575055751557525575355754557555575655757557585575955760557615576255763557645576555766557675576855769557705577155772557735577455775557765577755778557795578055781557825578355784557855578655787557885578955790557915579255793557945579555796557975579855799558005580155802558035580455805558065580755808558095581055811558125581355814558155581655817558185581955820558215582255823558245582555826558275582855829558305583155832558335583455835558365583755838558395584055841558425584355844558455584655847558485584955850558515585255853558545585555856558575585855859558605586155862558635586455865558665586755868558695587055871558725587355874558755587655877558785587955880558815588255883558845588555886558875588855889558905589155892558935589455895558965589755898558995590055901559025590355904559055590655907559085590955910559115591255913559145591555916559175591855919559205592155922559235592455925559265592755928559295593055931559325593355934559355593655937559385593955940559415594255943559445594555946559475594855949559505595155952559535595455955559565595755958559595596055961559625596355964559655596655967559685596955970559715597255973559745597555976559775597855979559805598155982559835598455985559865598755988559895599055991559925599355994559955599655997559985599956000560015600256003560045600556006560075600856009560105601156012560135601456015560165601756018560195602056021560225602356024560255602656027560285602956030560315603256033560345603556036560375603856039560405604156042560435604456045560465604756048560495605056051560525605356054560555605656057560585605956060560615606256063560645606556066560675606856069560705607156072560735607456075560765607756078560795608056081560825608356084560855608656087560885608956090560915609256093560945609556096560975609856099561005610156102561035610456105561065610756108561095611056111561125611356114561155611656117561185611956120561215612256123561245612556126561275612856129561305613156132561335613456135561365613756138561395614056141561425614356144561455614656147561485614956150561515615256153561545615556156561575615856159561605616156162561635616456165561665616756168561695617056171561725617356174561755617656177561785617956180561815618256183561845618556186561875618856189561905619156192561935619456195561965619756198561995620056201562025620356204562055620656207562085620956210562115621256213562145621556216562175621856219562205622156222562235622456225562265622756228562295623056231562325623356234562355623656237562385623956240562415624256243562445624556246562475624856249562505625156252562535625456255562565625756258562595626056261562625626356264562655626656267562685626956270562715627256273562745627556276562775627856279562805628156282562835628456285562865628756288562895629056291562925629356294562955629656297562985629956300563015630256303563045630556306563075630856309563105631156312563135631456315563165631756318563195632056321563225632356324563255632656327563285632956330563315633256333563345633556336563375633856339563405634156342563435634456345563465634756348563495635056351563525635356354563555635656357563585635956360563615636256363563645636556366563675636856369563705637156372563735637456375563765637756378563795638056381563825638356384563855638656387563885638956390563915639256393563945639556396563975639856399564005640156402564035640456405564065640756408564095641056411564125641356414564155641656417564185641956420564215642256423564245642556426564275642856429564305643156432564335643456435564365643756438564395644056441564425644356444564455644656447564485644956450564515645256453564545645556456564575645856459564605646156462564635646456465564665646756468564695647056471564725647356474564755647656477564785647956480564815648256483564845648556486564875648856489564905649156492564935649456495564965649756498564995650056501565025650356504565055650656507565085650956510565115651256513565145651556516565175651856519565205652156522565235652456525565265652756528565295653056531565325653356534565355653656537565385653956540565415654256543565445654556546565475654856549565505655156552565535655456555565565655756558565595656056561565625656356564565655656656567565685656956570565715657256573565745657556576565775657856579565805658156582565835658456585565865658756588565895659056591565925659356594565955659656597565985659956600566015660256603566045660556606566075660856609566105661156612566135661456615566165661756618566195662056621566225662356624566255662656627566285662956630566315663256633566345663556636566375663856639566405664156642566435664456645566465664756648566495665056651566525665356654566555665656657566585665956660566615666256663566645666556666566675666856669566705667156672566735667456675566765667756678566795668056681566825668356684566855668656687566885668956690566915669256693566945669556696566975669856699567005670156702567035670456705567065670756708567095671056711567125671356714567155671656717567185671956720567215672256723567245672556726567275672856729567305673156732567335673456735567365673756738567395674056741567425674356744567455674656747567485674956750567515675256753567545675556756567575675856759567605676156762567635676456765567665676756768567695677056771567725677356774567755677656777567785677956780567815678256783567845678556786567875678856789567905679156792567935679456795567965679756798567995680056801568025680356804568055680656807568085680956810568115681256813568145681556816568175681856819568205682156822568235682456825568265682756828568295683056831568325683356834568355683656837568385683956840568415684256843568445684556846568475684856849568505685156852568535685456855568565685756858568595686056861568625686356864568655686656867568685686956870568715687256873568745687556876568775687856879568805688156882568835688456885568865688756888568895689056891568925689356894568955689656897568985689956900569015690256903569045690556906569075690856909569105691156912569135691456915569165691756918569195692056921569225692356924569255692656927569285692956930569315693256933569345693556936569375693856939569405694156942569435694456945569465694756948569495695056951569525695356954569555695656957569585695956960569615696256963569645696556966569675696856969569705697156972569735697456975569765697756978569795698056981569825698356984569855698656987569885698956990569915699256993569945699556996569975699856999570005700157002570035700457005570065700757008570095701057011570125701357014570155701657017570185701957020570215702257023570245702557026570275702857029570305703157032570335703457035570365703757038570395704057041570425704357044570455704657047570485704957050570515705257053570545705557056570575705857059570605706157062570635706457065570665706757068570695707057071570725707357074570755707657077570785707957080570815708257083570845708557086570875708857089570905709157092570935709457095570965709757098570995710057101571025710357104571055710657107571085710957110571115711257113571145711557116571175711857119571205712157122571235712457125571265712757128571295713057131571325713357134571355713657137571385713957140571415714257143571445714557146571475714857149571505715157152571535715457155571565715757158571595716057161571625716357164571655716657167571685716957170571715717257173571745717557176571775717857179571805718157182571835718457185571865718757188571895719057191571925719357194571955719657197571985719957200572015720257203572045720557206572075720857209572105721157212572135721457215572165721757218572195722057221572225722357224572255722657227572285722957230572315723257233572345723557236572375723857239572405724157242572435724457245572465724757248572495725057251572525725357254572555725657257572585725957260572615726257263572645726557266572675726857269572705727157272572735727457275572765727757278572795728057281572825728357284572855728657287572885728957290572915729257293572945729557296572975729857299573005730157302573035730457305573065730757308573095731057311573125731357314573155731657317573185731957320573215732257323573245732557326573275732857329573305733157332573335733457335573365733757338573395734057341573425734357344573455734657347573485734957350573515735257353573545735557356573575735857359573605736157362573635736457365573665736757368573695737057371573725737357374573755737657377573785737957380573815738257383573845738557386573875738857389573905739157392573935739457395573965739757398573995740057401574025740357404574055740657407574085740957410574115741257413574145741557416574175741857419574205742157422574235742457425574265742757428574295743057431574325743357434574355743657437574385743957440574415744257443574445744557446574475744857449574505745157452574535745457455574565745757458574595746057461574625746357464574655746657467574685746957470574715747257473574745747557476574775747857479574805748157482574835748457485574865748757488574895749057491574925749357494574955749657497574985749957500575015750257503575045750557506575075750857509575105751157512575135751457515575165751757518575195752057521575225752357524575255752657527575285752957530575315753257533575345753557536575375753857539575405754157542575435754457545575465754757548575495755057551575525755357554575555755657557575585755957560575615756257563575645756557566575675756857569575705757157572575735757457575575765757757578575795758057581575825758357584575855758657587575885758957590575915759257593575945759557596575975759857599576005760157602576035760457605576065760757608576095761057611576125761357614576155761657617576185761957620576215762257623576245762557626576275762857629576305763157632576335763457635576365763757638576395764057641576425764357644576455764657647576485764957650576515765257653576545765557656576575765857659576605766157662576635766457665576665766757668576695767057671576725767357674576755767657677576785767957680576815768257683576845768557686576875768857689576905769157692576935769457695576965769757698576995770057701577025770357704577055770657707577085770957710577115771257713577145771557716577175771857719577205772157722577235772457725577265772757728577295773057731577325773357734577355773657737577385773957740577415774257743577445774557746577475774857749577505775157752577535775457755577565775757758577595776057761577625776357764577655776657767577685776957770577715777257773577745777557776577775777857779577805778157782577835778457785577865778757788577895779057791577925779357794577955779657797577985779957800578015780257803578045780557806578075780857809578105781157812578135781457815578165781757818578195782057821578225782357824578255782657827578285782957830578315783257833578345783557836578375783857839578405784157842578435784457845578465784757848578495785057851578525785357854578555785657857578585785957860578615786257863578645786557866578675786857869578705787157872578735787457875578765787757878578795788057881578825788357884578855788657887578885788957890578915789257893578945789557896578975789857899579005790157902579035790457905579065790757908579095791057911579125791357914579155791657917579185791957920579215792257923579245792557926579275792857929579305793157932579335793457935579365793757938579395794057941579425794357944579455794657947579485794957950579515795257953579545795557956579575795857959579605796157962579635796457965579665796757968579695797057971579725797357974579755797657977579785797957980579815798257983579845798557986579875798857989579905799157992579935799457995579965799757998579995800058001580025800358004580055800658007580085800958010580115801258013580145801558016580175801858019580205802158022580235802458025580265802758028580295803058031580325803358034580355803658037580385803958040580415804258043580445804558046580475804858049580505805158052580535805458055580565805758058580595806058061580625806358064580655806658067580685806958070580715807258073580745807558076580775807858079580805808158082580835808458085580865808758088580895809058091580925809358094580955809658097580985809958100581015810258103581045810558106581075810858109581105811158112581135811458115581165811758118581195812058121581225812358124581255812658127581285812958130581315813258133581345813558136581375813858139581405814158142581435814458145581465814758148581495815058151581525815358154581555815658157581585815958160581615816258163581645816558166581675816858169581705817158172581735817458175581765817758178581795818058181581825818358184581855818658187581885818958190581915819258193581945819558196581975819858199582005820158202582035820458205582065820758208582095821058211582125821358214582155821658217582185821958220582215822258223582245822558226582275822858229582305823158232582335823458235582365823758238582395824058241582425824358244582455824658247582485824958250582515825258253582545825558256582575825858259582605826158262582635826458265582665826758268582695827058271582725827358274582755827658277582785827958280582815828258283582845828558286582875828858289582905829158292582935829458295582965829758298582995830058301583025830358304583055830658307583085830958310583115831258313583145831558316583175831858319583205832158322583235832458325583265832758328583295833058331583325833358334583355833658337583385833958340583415834258343583445834558346583475834858349583505835158352583535835458355583565835758358583595836058361583625836358364583655836658367583685836958370583715837258373583745837558376583775837858379583805838158382583835838458385583865838758388583895839058391583925839358394583955839658397583985839958400584015840258403584045840558406584075840858409584105841158412584135841458415584165841758418584195842058421584225842358424584255842658427584285842958430584315843258433584345843558436584375843858439584405844158442584435844458445584465844758448584495845058451584525845358454584555845658457584585845958460584615846258463584645846558466584675846858469584705847158472584735847458475584765847758478584795848058481584825848358484584855848658487584885848958490584915849258493584945849558496584975849858499585005850158502585035850458505585065850758508585095851058511585125851358514585155851658517585185851958520585215852258523585245852558526585275852858529585305853158532585335853458535585365853758538585395854058541585425854358544585455854658547585485854958550585515855258553585545855558556585575855858559585605856158562585635856458565585665856758568585695857058571585725857358574585755857658577585785857958580585815858258583585845858558586585875858858589585905859158592585935859458595585965859758598585995860058601586025860358604586055860658607586085860958610586115861258613586145861558616586175861858619586205862158622586235862458625586265862758628586295863058631586325863358634586355863658637586385863958640586415864258643586445864558646586475864858649586505865158652586535865458655586565865758658586595866058661586625866358664586655866658667586685866958670586715867258673586745867558676586775867858679586805868158682586835868458685586865868758688586895869058691586925869358694586955869658697586985869958700587015870258703587045870558706587075870858709587105871158712587135871458715587165871758718587195872058721587225872358724587255872658727587285872958730587315873258733587345873558736587375873858739587405874158742587435874458745587465874758748587495875058751587525875358754587555875658757587585875958760587615876258763587645876558766587675876858769587705877158772587735877458775587765877758778587795878058781587825878358784587855878658787587885878958790587915879258793587945879558796587975879858799588005880158802588035880458805588065880758808588095881058811588125881358814588155881658817588185881958820588215882258823588245882558826588275882858829588305883158832588335883458835588365883758838588395884058841588425884358844588455884658847588485884958850588515885258853588545885558856588575885858859588605886158862588635886458865588665886758868588695887058871588725887358874588755887658877588785887958880588815888258883588845888558886588875888858889588905889158892588935889458895588965889758898588995890058901589025890358904589055890658907589085890958910589115891258913589145891558916589175891858919589205892158922589235892458925589265892758928589295893058931589325893358934589355893658937589385893958940589415894258943589445894558946589475894858949589505895158952589535895458955589565895758958589595896058961589625896358964589655896658967589685896958970589715897258973589745897558976589775897858979589805898158982589835898458985589865898758988589895899058991589925899358994589955899658997589985899959000590015900259003590045900559006590075900859009590105901159012590135901459015590165901759018590195902059021590225902359024590255902659027590285902959030590315903259033590345903559036590375903859039590405904159042590435904459045590465904759048590495905059051590525905359054590555905659057590585905959060590615906259063590645906559066590675906859069590705907159072590735907459075590765907759078590795908059081590825908359084590855908659087590885908959090590915909259093590945909559096590975909859099591005910159102591035910459105591065910759108591095911059111591125911359114591155911659117591185911959120591215912259123591245912559126591275912859129591305913159132591335913459135591365913759138591395914059141591425914359144591455914659147591485914959150591515915259153591545915559156591575915859159591605916159162591635916459165591665916759168591695917059171591725917359174591755917659177591785917959180591815918259183591845918559186591875918859189591905919159192591935919459195591965919759198591995920059201592025920359204592055920659207592085920959210592115921259213592145921559216592175921859219592205922159222592235922459225592265922759228592295923059231592325923359234592355923659237592385923959240592415924259243592445924559246592475924859249592505925159252592535925459255592565925759258592595926059261592625926359264592655926659267592685926959270592715927259273592745927559276592775927859279592805928159282592835928459285592865928759288592895929059291592925929359294592955929659297592985929959300593015930259303593045930559306593075930859309593105931159312593135931459315593165931759318593195932059321593225932359324593255932659327593285932959330593315933259333593345933559336593375933859339593405934159342593435934459345593465934759348593495935059351593525935359354593555935659357593585935959360593615936259363593645936559366593675936859369593705937159372593735937459375593765937759378593795938059381593825938359384593855938659387593885938959390593915939259393593945939559396593975939859399594005940159402594035940459405594065940759408594095941059411594125941359414594155941659417594185941959420594215942259423594245942559426594275942859429594305943159432594335943459435594365943759438594395944059441594425944359444594455944659447594485944959450594515945259453594545945559456594575945859459594605946159462594635946459465594665946759468594695947059471594725947359474594755947659477594785947959480594815948259483594845948559486594875948859489594905949159492594935949459495594965949759498594995950059501595025950359504595055950659507595085950959510595115951259513595145951559516595175951859519595205952159522595235952459525595265952759528595295953059531595325953359534595355953659537595385953959540595415954259543595445954559546595475954859549595505955159552595535955459555595565955759558595595956059561595625956359564595655956659567595685956959570595715957259573595745957559576595775957859579595805958159582595835958459585595865958759588595895959059591595925959359594595955959659597595985959959600596015960259603596045960559606596075960859609596105961159612596135961459615596165961759618596195962059621596225962359624596255962659627596285962959630596315963259633596345963559636596375963859639596405964159642596435964459645596465964759648596495965059651596525965359654596555965659657596585965959660596615966259663596645966559666596675966859669596705967159672596735967459675596765967759678596795968059681596825968359684596855968659687596885968959690596915969259693596945969559696596975969859699597005970159702597035970459705597065970759708597095971059711597125971359714597155971659717597185971959720597215972259723597245972559726597275972859729597305973159732597335973459735597365973759738597395974059741597425974359744597455974659747597485974959750597515975259753597545975559756597575975859759597605976159762597635976459765597665976759768597695977059771597725977359774597755977659777597785977959780597815978259783597845978559786597875978859789597905979159792597935979459795597965979759798597995980059801598025980359804598055980659807598085980959810598115981259813598145981559816598175981859819598205982159822598235982459825598265982759828598295983059831598325983359834598355983659837598385983959840598415984259843598445984559846598475984859849598505985159852598535985459855598565985759858598595986059861598625986359864598655986659867598685986959870598715987259873598745987559876598775987859879598805988159882598835988459885598865988759888598895989059891598925989359894598955989659897598985989959900599015990259903599045990559906599075990859909599105991159912599135991459915599165991759918599195992059921599225992359924599255992659927599285992959930599315993259933599345993559936599375993859939599405994159942599435994459945599465994759948599495995059951599525995359954599555995659957599585995959960599615996259963599645996559966599675996859969599705997159972599735997459975599765997759978599795998059981599825998359984599855998659987599885998959990599915999259993599945999559996599975999859999600006000160002600036000460005600066000760008600096001060011600126001360014600156001660017600186001960020600216002260023600246002560026600276002860029600306003160032600336003460035600366003760038600396004060041600426004360044600456004660047600486004960050600516005260053600546005560056600576005860059600606006160062600636006460065600666006760068600696007060071600726007360074600756007660077600786007960080600816008260083600846008560086600876008860089600906009160092600936009460095600966009760098600996010060101601026010360104601056010660107601086010960110601116011260113601146011560116601176011860119601206012160122601236012460125601266012760128601296013060131601326013360134601356013660137601386013960140601416014260143601446014560146601476014860149601506015160152601536015460155601566015760158601596016060161601626016360164601656016660167601686016960170601716017260173601746017560176601776017860179601806018160182601836018460185601866018760188601896019060191601926019360194601956019660197601986019960200602016020260203602046020560206602076020860209602106021160212602136021460215602166021760218602196022060221602226022360224602256022660227602286022960230602316023260233602346023560236602376023860239602406024160242602436024460245602466024760248602496025060251602526025360254602556025660257602586025960260602616026260263602646026560266602676026860269602706027160272602736027460275602766027760278602796028060281602826028360284602856028660287602886028960290602916029260293602946029560296602976029860299603006030160302603036030460305603066030760308603096031060311603126031360314603156031660317603186031960320603216032260323603246032560326603276032860329603306033160332603336033460335603366033760338603396034060341603426034360344603456034660347603486034960350603516035260353603546035560356603576035860359603606036160362603636036460365603666036760368603696037060371603726037360374603756037660377603786037960380603816038260383603846038560386603876038860389603906039160392603936039460395603966039760398603996040060401604026040360404604056040660407604086040960410604116041260413604146041560416604176041860419604206042160422604236042460425604266042760428604296043060431604326043360434604356043660437604386043960440604416044260443604446044560446604476044860449604506045160452604536045460455604566045760458604596046060461604626046360464604656046660467604686046960470604716047260473604746047560476604776047860479604806048160482604836048460485604866048760488604896049060491604926049360494604956049660497604986049960500605016050260503605046050560506605076050860509605106051160512605136051460515605166051760518605196052060521605226052360524605256052660527605286052960530605316053260533605346053560536605376053860539605406054160542605436054460545605466054760548605496055060551605526055360554605556055660557605586055960560605616056260563605646056560566605676056860569605706057160572605736057460575605766057760578605796058060581605826058360584605856058660587605886058960590605916059260593605946059560596605976059860599606006060160602606036060460605606066060760608606096061060611606126061360614606156061660617606186061960620606216062260623606246062560626606276062860629606306063160632606336063460635606366063760638606396064060641606426064360644606456064660647606486064960650606516065260653606546065560656606576065860659606606066160662606636066460665606666066760668606696067060671606726067360674606756067660677606786067960680606816068260683606846068560686606876068860689606906069160692606936069460695606966069760698606996070060701607026070360704607056070660707607086070960710607116071260713607146071560716607176071860719607206072160722607236072460725607266072760728607296073060731607326073360734607356073660737607386073960740607416074260743607446074560746607476074860749607506075160752607536075460755607566075760758607596076060761607626076360764607656076660767607686076960770607716077260773607746077560776607776077860779607806078160782607836078460785607866078760788607896079060791607926079360794607956079660797607986079960800608016080260803608046080560806608076080860809608106081160812608136081460815608166081760818608196082060821608226082360824608256082660827608286082960830608316083260833608346083560836608376083860839608406084160842608436084460845608466084760848608496085060851608526085360854608556085660857608586085960860608616086260863608646086560866608676086860869608706087160872608736087460875608766087760878608796088060881608826088360884608856088660887608886088960890608916089260893608946089560896608976089860899609006090160902609036090460905609066090760908609096091060911609126091360914609156091660917609186091960920609216092260923609246092560926609276092860929609306093160932609336093460935609366093760938609396094060941609426094360944609456094660947609486094960950609516095260953609546095560956609576095860959609606096160962609636096460965609666096760968609696097060971609726097360974609756097660977609786097960980609816098260983609846098560986609876098860989609906099160992609936099460995609966099760998609996100061001610026100361004610056100661007610086100961010610116101261013610146101561016610176101861019610206102161022610236102461025610266102761028610296103061031610326103361034610356103661037610386103961040610416104261043610446104561046610476104861049610506105161052610536105461055610566105761058610596106061061610626106361064610656106661067610686106961070610716107261073610746107561076610776107861079610806108161082610836108461085610866108761088610896109061091610926109361094610956109661097610986109961100611016110261103611046110561106611076110861109611106111161112611136111461115611166111761118611196112061121611226112361124611256112661127611286112961130611316113261133611346113561136611376113861139611406114161142611436114461145611466114761148611496115061151611526115361154611556115661157611586115961160611616116261163611646116561166611676116861169611706117161172611736117461175611766117761178611796118061181611826118361184611856118661187611886118961190611916119261193611946119561196611976119861199612006120161202612036120461205612066120761208612096121061211612126121361214612156121661217612186121961220612216122261223612246122561226612276122861229612306123161232612336123461235612366123761238612396124061241612426124361244612456124661247612486124961250612516125261253612546125561256612576125861259612606126161262612636126461265612666126761268612696127061271612726127361274612756127661277612786127961280612816128261283612846128561286612876128861289612906129161292612936129461295612966129761298612996130061301613026130361304613056130661307613086130961310613116131261313613146131561316613176131861319613206132161322613236132461325613266132761328613296133061331613326133361334613356133661337613386133961340613416134261343613446134561346613476134861349613506135161352613536135461355613566135761358613596136061361613626136361364613656136661367613686136961370613716137261373613746137561376613776137861379613806138161382613836138461385613866138761388613896139061391613926139361394613956139661397613986139961400614016140261403614046140561406614076140861409614106141161412614136141461415614166141761418614196142061421614226142361424614256142661427614286142961430614316143261433614346143561436614376143861439614406144161442614436144461445614466144761448614496145061451614526145361454614556145661457614586145961460614616146261463614646146561466614676146861469614706147161472614736147461475614766147761478614796148061481614826148361484614856148661487614886148961490614916149261493614946149561496614976149861499615006150161502615036150461505615066150761508615096151061511615126151361514615156151661517615186151961520615216152261523615246152561526615276152861529615306153161532615336153461535615366153761538615396154061541615426154361544615456154661547615486154961550615516155261553615546155561556615576155861559615606156161562615636156461565615666156761568615696157061571615726157361574615756157661577615786157961580615816158261583615846158561586615876158861589615906159161592615936159461595615966159761598615996160061601616026160361604616056160661607616086160961610616116161261613616146161561616616176161861619616206162161622616236162461625616266162761628616296163061631616326163361634616356163661637616386163961640616416164261643616446164561646616476164861649616506165161652616536165461655616566165761658616596166061661616626166361664616656166661667616686166961670616716167261673616746167561676616776167861679616806168161682616836168461685616866168761688616896169061691616926169361694616956169661697616986169961700617016170261703617046170561706617076170861709617106171161712617136171461715617166171761718617196172061721617226172361724617256172661727617286172961730617316173261733617346173561736617376173861739617406174161742617436174461745617466174761748617496175061751617526175361754617556175661757617586175961760617616176261763617646176561766617676176861769617706177161772617736177461775617766177761778617796178061781617826178361784617856178661787617886178961790617916179261793617946179561796617976179861799618006180161802618036180461805618066180761808618096181061811618126181361814618156181661817618186181961820618216182261823618246182561826618276182861829618306183161832618336183461835618366183761838618396184061841618426184361844618456184661847618486184961850618516185261853618546185561856618576185861859618606186161862618636186461865618666186761868618696187061871618726187361874618756187661877618786187961880618816188261883618846188561886618876188861889618906189161892618936189461895618966189761898618996190061901619026190361904619056190661907619086190961910619116191261913619146191561916619176191861919619206192161922619236192461925619266192761928619296193061931619326193361934619356193661937619386193961940619416194261943619446194561946619476194861949619506195161952619536195461955619566195761958619596196061961619626196361964619656196661967619686196961970619716197261973619746197561976619776197861979619806198161982619836198461985619866198761988619896199061991619926199361994619956199661997619986199962000620016200262003620046200562006620076200862009620106201162012620136201462015620166201762018620196202062021620226202362024620256202662027620286202962030620316203262033620346203562036620376203862039620406204162042620436204462045620466204762048620496205062051620526205362054620556205662057620586205962060620616206262063620646206562066620676206862069620706207162072620736207462075620766207762078620796208062081620826208362084620856208662087620886208962090620916209262093620946209562096620976209862099621006210162102621036210462105621066210762108621096211062111621126211362114621156211662117621186211962120621216212262123621246212562126621276212862129621306213162132621336213462135621366213762138621396214062141621426214362144621456214662147621486214962150621516215262153621546215562156621576215862159621606216162162621636216462165621666216762168621696217062171621726217362174621756217662177621786217962180621816218262183621846218562186621876218862189621906219162192621936219462195621966219762198621996220062201622026220362204622056220662207622086220962210622116221262213622146221562216622176221862219622206222162222622236222462225622266222762228622296223062231622326223362234622356223662237622386223962240622416224262243622446224562246622476224862249622506225162252622536225462255622566225762258622596226062261622626226362264622656226662267622686226962270622716227262273622746227562276622776227862279622806228162282622836228462285622866228762288622896229062291622926229362294622956229662297622986229962300623016230262303623046230562306623076230862309623106231162312623136231462315623166231762318623196232062321623226232362324623256232662327623286232962330623316233262333623346233562336623376233862339623406234162342623436234462345623466234762348623496235062351623526235362354623556235662357623586235962360623616236262363623646236562366623676236862369623706237162372623736237462375623766237762378623796238062381623826238362384623856238662387623886238962390623916239262393623946239562396623976239862399624006240162402624036240462405624066240762408624096241062411624126241362414624156241662417624186241962420624216242262423624246242562426624276242862429624306243162432624336243462435624366243762438624396244062441624426244362444624456244662447624486244962450624516245262453624546245562456624576245862459624606246162462624636246462465624666246762468624696247062471624726247362474624756247662477624786247962480624816248262483624846248562486624876248862489624906249162492624936249462495624966249762498624996250062501625026250362504625056250662507625086250962510625116251262513625146251562516625176251862519625206252162522625236252462525625266252762528625296253062531625326253362534625356253662537625386253962540625416254262543625446254562546625476254862549625506255162552625536255462555625566255762558625596256062561625626256362564625656256662567625686256962570625716257262573625746257562576625776257862579625806258162582625836258462585625866258762588625896259062591625926259362594625956259662597625986259962600626016260262603626046260562606626076260862609626106261162612626136261462615626166261762618626196262062621626226262362624626256262662627626286262962630626316263262633626346263562636626376263862639626406264162642626436264462645626466264762648626496265062651626526265362654626556265662657626586265962660626616266262663626646266562666626676266862669626706267162672626736267462675626766267762678626796268062681626826268362684626856268662687626886268962690626916269262693626946269562696626976269862699627006270162702627036270462705627066270762708627096271062711627126271362714627156271662717627186271962720627216272262723627246272562726627276272862729627306273162732627336273462735627366273762738627396274062741627426274362744627456274662747627486274962750627516275262753627546275562756627576275862759627606276162762627636276462765627666276762768627696277062771627726277362774627756277662777627786277962780627816278262783627846278562786627876278862789627906279162792627936279462795627966279762798627996280062801628026280362804628056280662807628086280962810628116281262813628146281562816628176281862819628206282162822628236282462825628266282762828628296283062831628326283362834628356283662837628386283962840628416284262843628446284562846628476284862849628506285162852628536285462855628566285762858628596286062861628626286362864628656286662867628686286962870628716287262873628746287562876628776287862879628806288162882628836288462885628866288762888628896289062891628926289362894628956289662897628986289962900629016290262903629046290562906629076290862909629106291162912629136291462915629166291762918629196292062921629226292362924629256292662927629286292962930629316293262933629346293562936629376293862939629406294162942629436294462945629466294762948629496295062951629526295362954629556295662957629586295962960629616296262963629646296562966629676296862969629706297162972629736297462975629766297762978629796298062981629826298362984629856298662987629886298962990629916299262993629946299562996629976299862999630006300163002630036300463005630066300763008630096301063011630126301363014630156301663017630186301963020630216302263023630246302563026630276302863029630306303163032630336303463035630366303763038630396304063041630426304363044630456304663047630486304963050630516305263053630546305563056630576305863059630606306163062630636306463065630666306763068630696307063071630726307363074630756307663077630786307963080630816308263083630846308563086630876308863089630906309163092630936309463095630966309763098630996310063101631026310363104631056310663107631086310963110631116311263113631146311563116631176311863119631206312163122631236312463125631266312763128631296313063131631326313363134631356313663137631386313963140631416314263143631446314563146631476314863149631506315163152631536315463155631566315763158631596316063161631626316363164631656316663167631686316963170631716317263173631746317563176631776317863179631806318163182631836318463185631866318763188631896319063191631926319363194631956319663197631986319963200632016320263203632046320563206632076320863209632106321163212632136321463215632166321763218632196322063221632226322363224632256322663227632286322963230632316323263233632346323563236632376323863239632406324163242632436324463245632466324763248632496325063251632526325363254632556325663257632586325963260632616326263263632646326563266632676326863269632706327163272632736327463275632766327763278632796328063281632826328363284632856328663287632886328963290632916329263293632946329563296632976329863299633006330163302633036330463305633066330763308633096331063311633126331363314633156331663317633186331963320633216332263323633246332563326633276332863329633306333163332633336333463335633366333763338633396334063341633426334363344633456334663347633486334963350633516335263353633546335563356633576335863359633606336163362633636336463365633666336763368633696337063371633726337363374633756337663377633786337963380633816338263383633846338563386633876338863389633906339163392633936339463395633966339763398633996340063401634026340363404634056340663407634086340963410634116341263413634146341563416634176341863419634206342163422634236342463425634266342763428634296343063431634326343363434634356343663437634386343963440634416344263443634446344563446634476344863449634506345163452634536345463455634566345763458634596346063461634626346363464634656346663467634686346963470634716347263473634746347563476634776347863479634806348163482634836348463485634866348763488634896349063491634926349363494634956349663497634986349963500635016350263503635046350563506635076350863509635106351163512635136351463515635166351763518635196352063521635226352363524635256352663527635286352963530635316353263533635346353563536635376353863539635406354163542635436354463545635466354763548635496355063551635526355363554635556355663557635586355963560635616356263563635646356563566635676356863569635706357163572635736357463575635766357763578635796358063581635826358363584635856358663587635886358963590635916359263593635946359563596635976359863599636006360163602636036360463605636066360763608636096361063611636126361363614636156361663617636186361963620636216362263623636246362563626636276362863629636306363163632636336363463635636366363763638636396364063641636426364363644636456364663647636486364963650636516365263653636546365563656636576365863659636606366163662636636366463665636666366763668636696367063671636726367363674636756367663677636786367963680636816368263683636846368563686636876368863689636906369163692636936369463695636966369763698636996370063701637026370363704637056370663707637086370963710637116371263713637146371563716637176371863719637206372163722637236372463725637266372763728637296373063731637326373363734637356373663737637386373963740637416374263743637446374563746637476374863749637506375163752637536375463755637566375763758637596376063761637626376363764637656376663767637686376963770637716377263773637746377563776637776377863779637806378163782637836378463785637866378763788637896379063791637926379363794637956379663797637986379963800638016380263803638046380563806638076380863809638106381163812638136381463815638166381763818638196382063821638226382363824638256382663827638286382963830638316383263833638346383563836638376383863839638406384163842638436384463845638466384763848638496385063851638526385363854638556385663857638586385963860638616386263863638646386563866638676386863869638706387163872638736387463875638766387763878638796388063881638826388363884638856388663887638886388963890638916389263893638946389563896638976389863899639006390163902639036390463905639066390763908639096391063911639126391363914639156391663917639186391963920639216392263923639246392563926639276392863929639306393163932639336393463935639366393763938639396394063941639426394363944639456394663947639486394963950639516395263953639546395563956639576395863959639606396163962639636396463965639666396763968639696397063971639726397363974639756397663977639786397963980639816398263983639846398563986639876398863989639906399163992639936399463995639966399763998639996400064001640026400364004640056400664007640086400964010640116401264013640146401564016640176401864019640206402164022640236402464025640266402764028640296403064031640326403364034640356403664037640386403964040640416404264043640446404564046640476404864049640506405164052640536405464055640566405764058640596406064061640626406364064640656406664067640686406964070640716407264073640746407564076640776407864079640806408164082640836408464085640866408764088640896409064091640926409364094640956409664097640986409964100641016410264103641046410564106641076410864109641106411164112641136411464115641166411764118641196412064121641226412364124641256412664127641286412964130641316413264133641346413564136641376413864139641406414164142641436414464145641466414764148641496415064151641526415364154641556415664157641586415964160641616416264163641646416564166641676416864169641706417164172641736417464175641766417764178641796418064181641826418364184641856418664187641886418964190641916419264193641946419564196641976419864199642006420164202642036420464205642066420764208642096421064211642126421364214642156421664217642186421964220642216422264223642246422564226642276422864229642306423164232642336423464235642366423764238642396424064241642426424364244642456424664247642486424964250642516425264253642546425564256642576425864259642606426164262642636426464265642666426764268642696427064271642726427364274642756427664277642786427964280642816428264283642846428564286642876428864289642906429164292642936429464295642966429764298642996430064301643026430364304643056430664307643086430964310643116431264313643146431564316643176431864319643206432164322643236432464325643266432764328643296433064331643326433364334643356433664337643386433964340643416434264343643446434564346643476434864349643506435164352643536435464355643566435764358643596436064361643626436364364643656436664367643686436964370643716437264373643746437564376643776437864379643806438164382643836438464385643866438764388643896439064391643926439364394643956439664397643986439964400644016440264403644046440564406644076440864409644106441164412644136441464415644166441764418644196442064421644226442364424644256442664427644286442964430644316443264433644346443564436644376443864439644406444164442644436444464445644466444764448644496445064451644526445364454644556445664457644586445964460644616446264463644646446564466644676446864469644706447164472644736447464475644766447764478644796448064481644826448364484644856448664487644886448964490644916449264493644946449564496644976449864499645006450164502645036450464505645066450764508645096451064511645126451364514645156451664517645186451964520645216452264523645246452564526645276452864529645306453164532645336453464535645366453764538645396454064541645426454364544645456454664547645486454964550645516455264553645546455564556645576455864559645606456164562645636456464565645666456764568645696457064571645726457364574645756457664577645786457964580645816458264583645846458564586645876458864589645906459164592645936459464595645966459764598645996460064601646026460364604646056460664607646086460964610646116461264613646146461564616646176461864619646206462164622646236462464625646266462764628646296463064631646326463364634646356463664637646386463964640646416464264643646446464564646646476464864649646506465164652646536465464655646566465764658646596466064661646626466364664646656466664667646686466964670646716467264673646746467564676646776467864679646806468164682646836468464685646866468764688646896469064691646926469364694646956469664697646986469964700647016470264703647046470564706647076470864709647106471164712647136471464715647166471764718647196472064721647226472364724647256472664727647286472964730647316473264733647346473564736647376473864739647406474164742647436474464745647466474764748647496475064751647526475364754647556475664757647586475964760647616476264763647646476564766647676476864769647706477164772647736477464775647766477764778647796478064781647826478364784647856478664787647886478964790647916479264793647946479564796647976479864799648006480164802648036480464805648066480764808648096481064811648126481364814648156481664817648186481964820648216482264823648246482564826648276482864829648306483164832648336483464835648366483764838648396484064841648426484364844648456484664847648486484964850648516485264853648546485564856648576485864859648606486164862648636486464865648666486764868648696487064871648726487364874648756487664877648786487964880648816488264883648846488564886648876488864889648906489164892648936489464895648966489764898648996490064901649026490364904649056490664907649086490964910649116491264913649146491564916649176491864919649206492164922649236492464925649266492764928649296493064931649326493364934649356493664937649386493964940649416494264943649446494564946649476494864949649506495164952649536495464955649566495764958649596496064961649626496364964649656496664967649686496964970649716497264973649746497564976649776497864979649806498164982649836498464985649866498764988649896499064991649926499364994649956499664997649986499965000650016500265003650046500565006650076500865009650106501165012650136501465015650166501765018650196502065021650226502365024650256502665027650286502965030650316503265033650346503565036650376503865039650406504165042650436504465045650466504765048650496505065051650526505365054650556505665057650586505965060650616506265063650646506565066650676506865069650706507165072650736507465075650766507765078650796508065081650826508365084650856508665087650886508965090650916509265093650946509565096650976509865099651006510165102651036510465105651066510765108651096511065111651126511365114651156511665117651186511965120651216512265123651246512565126651276512865129651306513165132651336513465135651366513765138651396514065141651426514365144651456514665147651486514965150651516515265153651546515565156651576515865159651606516165162651636516465165651666516765168651696517065171651726517365174651756517665177651786517965180651816518265183651846518565186651876518865189651906519165192651936519465195651966519765198651996520065201652026520365204652056520665207652086520965210652116521265213652146521565216652176521865219652206522165222652236522465225652266522765228652296523065231652326523365234652356523665237652386523965240652416524265243652446524565246652476524865249652506525165252652536525465255652566525765258652596526065261652626526365264652656526665267652686526965270652716527265273652746527565276652776527865279652806528165282652836528465285652866528765288652896529065291652926529365294652956529665297652986529965300653016530265303653046530565306653076530865309653106531165312653136531465315653166531765318653196532065321653226532365324653256532665327653286532965330653316533265333653346533565336653376533865339653406534165342653436534465345653466534765348653496535065351653526535365354653556535665357653586535965360653616536265363653646536565366653676536865369653706537165372653736537465375653766537765378653796538065381653826538365384653856538665387653886538965390653916539265393653946539565396653976539865399654006540165402654036540465405654066540765408654096541065411654126541365414654156541665417654186541965420654216542265423654246542565426654276542865429654306543165432654336543465435654366543765438654396544065441654426544365444654456544665447654486544965450654516545265453654546545565456654576545865459654606546165462654636546465465654666546765468654696547065471654726547365474654756547665477654786547965480654816548265483654846548565486654876548865489654906549165492654936549465495654966549765498654996550065501655026550365504655056550665507655086550965510655116551265513655146551565516655176551865519655206552165522655236552465525655266552765528655296553065531655326553365534655356553665537655386553965540655416554265543655446554565546655476554865549655506555165552655536555465555655566555765558655596556065561655626556365564655656556665567655686556965570655716557265573655746557565576655776557865579655806558165582655836558465585655866558765588655896559065591655926559365594655956559665597655986559965600656016560265603656046560565606656076560865609656106561165612656136561465615656166561765618656196562065621656226562365624656256562665627656286562965630656316563265633656346563565636656376563865639656406564165642656436564465645656466564765648656496565065651656526565365654656556565665657656586565965660656616566265663656646566565666656676566865669656706567165672656736567465675656766567765678656796568065681656826568365684656856568665687656886568965690656916569265693656946569565696656976569865699657006570165702657036570465705657066570765708657096571065711657126571365714657156571665717657186571965720657216572265723657246572565726657276572865729657306573165732657336573465735657366573765738657396574065741657426574365744657456574665747657486574965750657516575265753657546575565756657576575865759657606576165762657636576465765657666576765768657696577065771657726577365774657756577665777657786577965780657816578265783657846578565786657876578865789657906579165792657936579465795657966579765798657996580065801658026580365804658056580665807658086580965810658116581265813658146581565816658176581865819658206582165822658236582465825658266582765828658296583065831658326583365834658356583665837658386583965840658416584265843658446584565846658476584865849658506585165852658536585465855658566585765858658596586065861658626586365864658656586665867658686586965870658716587265873658746587565876658776587865879658806588165882658836588465885658866588765888658896589065891658926589365894658956589665897658986589965900659016590265903659046590565906659076590865909659106591165912659136591465915659166591765918659196592065921659226592365924659256592665927659286592965930659316593265933659346593565936659376593865939659406594165942659436594465945659466594765948659496595065951659526595365954659556595665957659586595965960659616596265963659646596565966659676596865969659706597165972659736597465975659766597765978659796598065981659826598365984659856598665987659886598965990659916599265993659946599565996659976599865999660006600166002660036600466005660066600766008660096601066011660126601366014660156601666017660186601966020660216602266023660246602566026660276602866029660306603166032660336603466035660366603766038660396604066041660426604366044660456604666047660486604966050660516605266053660546605566056660576605866059660606606166062660636606466065660666606766068660696607066071660726607366074660756607666077660786607966080660816608266083660846608566086660876608866089660906609166092660936609466095660966609766098660996610066101661026610366104661056610666107661086610966110661116611266113661146611566116661176611866119661206612166122661236612466125661266612766128661296613066131661326613366134661356613666137661386613966140661416614266143661446614566146661476614866149661506615166152661536615466155661566615766158661596616066161661626616366164661656616666167661686616966170661716617266173661746617566176661776617866179661806618166182661836618466185661866618766188661896619066191661926619366194661956619666197661986619966200662016620266203662046620566206662076620866209662106621166212662136621466215662166621766218662196622066221662226622366224662256622666227662286622966230662316623266233662346623566236662376623866239662406624166242662436624466245662466624766248662496625066251662526625366254662556625666257662586625966260662616626266263662646626566266662676626866269662706627166272662736627466275662766627766278662796628066281662826628366284662856628666287662886628966290662916629266293662946629566296662976629866299663006630166302663036630466305663066630766308663096631066311663126631366314663156631666317663186631966320663216632266323663246632566326663276632866329663306633166332663336633466335663366633766338663396634066341663426634366344663456634666347663486634966350663516635266353663546635566356663576635866359663606636166362663636636466365663666636766368663696637066371663726637366374663756637666377663786637966380663816638266383663846638566386663876638866389663906639166392663936639466395663966639766398663996640066401664026640366404664056640666407664086640966410664116641266413664146641566416664176641866419664206642166422664236642466425664266642766428664296643066431664326643366434664356643666437664386643966440664416644266443664446644566446664476644866449664506645166452664536645466455664566645766458664596646066461664626646366464664656646666467664686646966470664716647266473664746647566476664776647866479664806648166482664836648466485664866648766488664896649066491664926649366494664956649666497664986649966500665016650266503665046650566506665076650866509665106651166512665136651466515665166651766518665196652066521665226652366524665256652666527665286652966530665316653266533665346653566536665376653866539665406654166542665436654466545665466654766548665496655066551665526655366554665556655666557665586655966560665616656266563665646656566566665676656866569665706657166572665736657466575665766657766578665796658066581665826658366584665856658666587665886658966590665916659266593665946659566596665976659866599666006660166602666036660466605666066660766608666096661066611666126661366614666156661666617666186661966620666216662266623666246662566626666276662866629666306663166632666336663466635666366663766638666396664066641666426664366644666456664666647666486664966650666516665266653666546665566656666576665866659666606666166662666636666466665666666666766668666696667066671666726667366674666756667666677666786667966680666816668266683666846668566686666876668866689666906669166692666936669466695666966669766698666996670066701667026670366704667056670666707667086670966710667116671266713667146671566716667176671866719667206672166722667236672466725667266672766728667296673066731667326673366734667356673666737667386673966740667416674266743667446674566746667476674866749667506675166752667536675466755667566675766758667596676066761667626676366764667656676666767667686676966770667716677266773667746677566776667776677866779667806678166782667836678466785667866678766788667896679066791667926679366794667956679666797667986679966800668016680266803668046680566806668076680866809668106681166812668136681466815668166681766818668196682066821668226682366824668256682666827668286682966830668316683266833668346683566836668376683866839668406684166842668436684466845668466684766848668496685066851668526685366854668556685666857668586685966860668616686266863668646686566866668676686866869668706687166872668736687466875668766687766878668796688066881668826688366884668856688666887668886688966890668916689266893668946689566896668976689866899669006690166902669036690466905669066690766908669096691066911669126691366914669156691666917669186691966920669216692266923669246692566926669276692866929669306693166932669336693466935669366693766938669396694066941669426694366944669456694666947669486694966950669516695266953669546695566956669576695866959669606696166962669636696466965669666696766968669696697066971669726697366974669756697666977669786697966980669816698266983669846698566986669876698866989669906699166992669936699466995669966699766998669996700067001670026700367004670056700667007670086700967010670116701267013670146701567016670176701867019670206702167022670236702467025670266702767028670296703067031670326703367034670356703667037670386703967040670416704267043670446704567046670476704867049670506705167052670536705467055670566705767058670596706067061670626706367064670656706667067670686706967070670716707267073670746707567076670776707867079670806708167082670836708467085670866708767088670896709067091670926709367094670956709667097670986709967100671016710267103671046710567106671076710867109671106711167112671136711467115671166711767118671196712067121671226712367124671256712667127671286712967130671316713267133671346713567136671376713867139671406714167142671436714467145671466714767148671496715067151671526715367154671556715667157671586715967160671616716267163671646716567166671676716867169671706717167172671736717467175671766717767178671796718067181671826718367184671856718667187671886718967190671916719267193671946719567196671976719867199672006720167202672036720467205672066720767208672096721067211672126721367214672156721667217672186721967220672216722267223672246722567226672276722867229672306723167232672336723467235672366723767238672396724067241672426724367244672456724667247672486724967250672516725267253672546725567256672576725867259672606726167262672636726467265672666726767268672696727067271672726727367274672756727667277672786727967280672816728267283672846728567286672876728867289672906729167292672936729467295672966729767298672996730067301673026730367304673056730667307673086730967310673116731267313673146731567316673176731867319673206732167322673236732467325673266732767328673296733067331673326733367334673356733667337673386733967340673416734267343673446734567346673476734867349673506735167352673536735467355673566735767358673596736067361673626736367364673656736667367673686736967370673716737267373673746737567376673776737867379673806738167382673836738467385673866738767388673896739067391673926739367394673956739667397673986739967400674016740267403674046740567406674076740867409674106741167412674136741467415674166741767418674196742067421674226742367424674256742667427674286742967430674316743267433674346743567436674376743867439674406744167442674436744467445674466744767448674496745067451674526745367454674556745667457674586745967460674616746267463674646746567466674676746867469674706747167472674736747467475674766747767478674796748067481674826748367484674856748667487674886748967490674916749267493674946749567496674976749867499675006750167502675036750467505675066750767508675096751067511675126751367514675156751667517675186751967520675216752267523675246752567526675276752867529675306753167532675336753467535675366753767538675396754067541675426754367544675456754667547675486754967550675516755267553675546755567556675576755867559675606756167562675636756467565675666756767568675696757067571675726757367574675756757667577675786757967580675816758267583675846758567586675876758867589675906759167592675936759467595675966759767598675996760067601676026760367604676056760667607676086760967610676116761267613676146761567616676176761867619676206762167622676236762467625676266762767628676296763067631676326763367634676356763667637676386763967640676416764267643676446764567646676476764867649676506765167652676536765467655676566765767658676596766067661676626766367664676656766667667676686766967670676716767267673676746767567676676776767867679676806768167682676836768467685676866768767688676896769067691676926769367694676956769667697676986769967700677016770267703677046770567706677076770867709677106771167712677136771467715677166771767718677196772067721677226772367724677256772667727677286772967730677316773267733677346773567736677376773867739677406774167742677436774467745677466774767748677496775067751677526775367754677556775667757677586775967760677616776267763677646776567766677676776867769677706777167772677736777467775677766777767778677796778067781677826778367784677856778667787677886778967790677916779267793677946779567796677976779867799678006780167802678036780467805678066780767808678096781067811678126781367814678156781667817678186781967820678216782267823678246782567826678276782867829678306783167832678336783467835678366783767838678396784067841678426784367844678456784667847678486784967850678516785267853678546785567856678576785867859678606786167862678636786467865678666786767868678696787067871678726787367874678756787667877678786787967880678816788267883678846788567886678876788867889678906789167892678936789467895678966789767898678996790067901679026790367904679056790667907679086790967910679116791267913679146791567916679176791867919679206792167922679236792467925679266792767928679296793067931679326793367934679356793667937679386793967940679416794267943679446794567946679476794867949679506795167952679536795467955679566795767958679596796067961679626796367964679656796667967679686796967970679716797267973679746797567976679776797867979679806798167982679836798467985679866798767988679896799067991679926799367994679956799667997679986799968000680016800268003680046800568006680076800868009680106801168012680136801468015680166801768018680196802068021680226802368024680256802668027680286802968030680316803268033680346803568036680376803868039680406804168042680436804468045680466804768048680496805068051680526805368054680556805668057680586805968060680616806268063680646806568066680676806868069680706807168072680736807468075680766807768078680796808068081680826808368084680856808668087680886808968090680916809268093680946809568096680976809868099681006810168102681036810468105681066810768108681096811068111681126811368114681156811668117681186811968120681216812268123681246812568126681276812868129681306813168132681336813468135681366813768138681396814068141681426814368144681456814668147681486814968150681516815268153681546815568156681576815868159681606816168162681636816468165681666816768168681696817068171681726817368174681756817668177681786817968180681816818268183681846818568186681876818868189681906819168192681936819468195681966819768198681996820068201682026820368204682056820668207682086820968210682116821268213682146821568216682176821868219682206822168222682236822468225682266822768228682296823068231682326823368234682356823668237682386823968240682416824268243682446824568246682476824868249682506825168252682536825468255682566825768258682596826068261682626826368264682656826668267682686826968270682716827268273682746827568276682776827868279682806828168282682836828468285682866828768288682896829068291682926829368294682956829668297682986829968300683016830268303683046830568306683076830868309683106831168312683136831468315683166831768318683196832068321683226832368324683256832668327683286832968330683316833268333683346833568336683376833868339683406834168342683436834468345683466834768348683496835068351683526835368354683556835668357683586835968360683616836268363683646836568366683676836868369683706837168372683736837468375683766837768378683796838068381683826838368384683856838668387683886838968390683916839268393683946839568396683976839868399684006840168402684036840468405684066840768408684096841068411684126841368414684156841668417684186841968420684216842268423684246842568426684276842868429684306843168432684336843468435684366843768438684396844068441684426844368444684456844668447684486844968450684516845268453684546845568456684576845868459684606846168462684636846468465684666846768468684696847068471684726847368474684756847668477684786847968480684816848268483684846848568486684876848868489684906849168492684936849468495684966849768498684996850068501685026850368504685056850668507685086850968510685116851268513685146851568516685176851868519685206852168522685236852468525685266852768528685296853068531685326853368534685356853668537685386853968540685416854268543685446854568546685476854868549685506855168552685536855468555685566855768558685596856068561685626856368564685656856668567685686856968570685716857268573685746857568576685776857868579685806858168582685836858468585685866858768588685896859068591685926859368594685956859668597685986859968600686016860268603686046860568606686076860868609686106861168612686136861468615686166861768618686196862068621686226862368624686256862668627686286862968630686316863268633686346863568636686376863868639686406864168642686436864468645686466864768648686496865068651686526865368654686556865668657686586865968660686616866268663686646866568666686676866868669686706867168672686736867468675686766867768678686796868068681686826868368684686856868668687686886868968690686916869268693686946869568696686976869868699687006870168702687036870468705687066870768708687096871068711687126871368714687156871668717687186871968720687216872268723687246872568726687276872868729687306873168732687336873468735687366873768738687396874068741687426874368744687456874668747687486874968750687516875268753687546875568756687576875868759687606876168762687636876468765687666876768768687696877068771687726877368774687756877668777687786877968780687816878268783687846878568786687876878868789687906879168792687936879468795687966879768798687996880068801688026880368804688056880668807688086880968810688116881268813688146881568816688176881868819688206882168822688236882468825688266882768828688296883068831688326883368834688356883668837688386883968840688416884268843688446884568846688476884868849688506885168852688536885468855688566885768858688596886068861688626886368864688656886668867688686886968870688716887268873688746887568876688776887868879688806888168882688836888468885688866888768888688896889068891688926889368894688956889668897688986889968900689016890268903689046890568906689076890868909689106891168912689136891468915689166891768918689196892068921689226892368924689256892668927689286892968930689316893268933689346893568936689376893868939689406894168942689436894468945689466894768948689496895068951689526895368954689556895668957689586895968960689616896268963689646896568966689676896868969689706897168972689736897468975689766897768978689796898068981689826898368984689856898668987689886898968990689916899268993689946899568996689976899868999690006900169002690036900469005690066900769008690096901069011690126901369014690156901669017690186901969020690216902269023690246902569026690276902869029690306903169032690336903469035690366903769038690396904069041690426904369044690456904669047690486904969050690516905269053690546905569056690576905869059690606906169062690636906469065690666906769068690696907069071690726907369074690756907669077690786907969080690816908269083690846908569086690876908869089690906909169092690936909469095690966909769098690996910069101691026910369104691056910669107691086910969110691116911269113691146911569116691176911869119691206912169122691236912469125691266912769128691296913069131691326913369134691356913669137691386913969140691416914269143691446914569146691476914869149691506915169152691536915469155691566915769158691596916069161691626916369164691656916669167691686916969170691716917269173691746917569176691776917869179691806918169182691836918469185691866918769188691896919069191691926919369194691956919669197691986919969200692016920269203692046920569206692076920869209692106921169212692136921469215692166921769218692196922069221692226922369224692256922669227692286922969230692316923269233692346923569236692376923869239692406924169242692436924469245692466924769248692496925069251692526925369254692556925669257692586925969260692616926269263692646926569266692676926869269692706927169272692736927469275692766927769278692796928069281692826928369284692856928669287692886928969290692916929269293692946929569296692976929869299693006930169302693036930469305693066930769308693096931069311693126931369314693156931669317693186931969320693216932269323693246932569326693276932869329693306933169332693336933469335693366933769338693396934069341693426934369344693456934669347693486934969350693516935269353693546935569356693576935869359693606936169362693636936469365693666936769368693696937069371693726937369374693756937669377693786937969380693816938269383693846938569386693876938869389693906939169392693936939469395693966939769398693996940069401694026940369404694056940669407694086940969410694116941269413694146941569416694176941869419694206942169422694236942469425694266942769428694296943069431694326943369434694356943669437694386943969440694416944269443694446944569446694476944869449694506945169452694536945469455694566945769458694596946069461694626946369464694656946669467694686946969470694716947269473694746947569476694776947869479694806948169482694836948469485694866948769488694896949069491694926949369494694956949669497694986949969500695016950269503695046950569506695076950869509695106951169512695136951469515695166951769518695196952069521695226952369524695256952669527695286952969530695316953269533695346953569536695376953869539695406954169542695436954469545695466954769548695496955069551695526955369554695556955669557695586955969560695616956269563695646956569566695676956869569695706957169572695736957469575695766957769578695796958069581695826958369584695856958669587695886958969590695916959269593695946959569596695976959869599696006960169602696036960469605696066960769608696096961069611696126961369614696156961669617696186961969620696216962269623696246962569626696276962869629696306963169632696336963469635696366963769638696396964069641696426964369644696456964669647696486964969650696516965269653696546965569656696576965869659696606966169662696636966469665696666966769668696696967069671696726967369674696756967669677696786967969680696816968269683696846968569686696876968869689696906969169692696936969469695696966969769698696996970069701697026970369704697056970669707697086970969710697116971269713697146971569716697176971869719697206972169722697236972469725697266972769728697296973069731697326973369734697356973669737697386973969740697416974269743697446974569746697476974869749697506975169752697536975469755697566975769758697596976069761697626976369764697656976669767697686976969770697716977269773697746977569776697776977869779697806978169782697836978469785697866978769788697896979069791697926979369794697956979669797697986979969800698016980269803698046980569806698076980869809698106981169812698136981469815698166981769818698196982069821698226982369824698256982669827698286982969830698316983269833698346983569836698376983869839698406984169842698436984469845698466984769848698496985069851698526985369854698556985669857698586985969860698616986269863698646986569866698676986869869698706987169872698736987469875698766987769878698796988069881698826988369884698856988669887698886988969890698916989269893698946989569896698976989869899699006990169902699036990469905699066990769908699096991069911699126991369914699156991669917699186991969920699216992269923699246992569926699276992869929699306993169932699336993469935699366993769938699396994069941699426994369944699456994669947699486994969950699516995269953699546995569956699576995869959699606996169962699636996469965699666996769968699696997069971699726997369974699756997669977699786997969980699816998269983699846998569986699876998869989699906999169992699936999469995699966999769998699997000070001700027000370004700057000670007700087000970010700117001270013700147001570016700177001870019700207002170022700237002470025700267002770028700297003070031700327003370034700357003670037700387003970040700417004270043700447004570046700477004870049700507005170052700537005470055700567005770058700597006070061700627006370064700657006670067700687006970070700717007270073700747007570076700777007870079700807008170082700837008470085700867008770088700897009070091700927009370094700957009670097700987009970100701017010270103701047010570106701077010870109701107011170112701137011470115701167011770118701197012070121701227012370124701257012670127701287012970130701317013270133701347013570136701377013870139701407014170142701437014470145701467014770148701497015070151701527015370154701557015670157701587015970160701617016270163701647016570166701677016870169701707017170172701737017470175701767017770178701797018070181701827018370184701857018670187701887018970190701917019270193701947019570196701977019870199702007020170202702037020470205702067020770208702097021070211702127021370214702157021670217702187021970220702217022270223702247022570226702277022870229702307023170232702337023470235702367023770238702397024070241702427024370244702457024670247702487024970250702517025270253702547025570256702577025870259702607026170262702637026470265702667026770268702697027070271702727027370274702757027670277702787027970280702817028270283702847028570286702877028870289702907029170292702937029470295702967029770298702997030070301703027030370304703057030670307703087030970310703117031270313703147031570316703177031870319703207032170322703237032470325703267032770328703297033070331703327033370334703357033670337703387033970340703417034270343703447034570346703477034870349703507035170352703537035470355703567035770358703597036070361703627036370364703657036670367703687036970370703717037270373703747037570376703777037870379703807038170382703837038470385703867038770388703897039070391703927039370394703957039670397703987039970400704017040270403704047040570406704077040870409704107041170412704137041470415704167041770418704197042070421704227042370424704257042670427704287042970430704317043270433704347043570436704377043870439704407044170442704437044470445704467044770448704497045070451704527045370454704557045670457704587045970460704617046270463704647046570466704677046870469704707047170472704737047470475704767047770478704797048070481704827048370484704857048670487704887048970490704917049270493704947049570496704977049870499705007050170502705037050470505705067050770508705097051070511705127051370514705157051670517705187051970520705217052270523705247052570526705277052870529705307053170532705337053470535705367053770538705397054070541705427054370544705457054670547705487054970550705517055270553705547055570556705577055870559705607056170562705637056470565705667056770568705697057070571705727057370574705757057670577705787057970580705817058270583705847058570586705877058870589705907059170592705937059470595705967059770598705997060070601706027060370604706057060670607706087060970610706117061270613706147061570616706177061870619706207062170622706237062470625706267062770628706297063070631706327063370634706357063670637706387063970640706417064270643706447064570646706477064870649706507065170652706537065470655706567065770658706597066070661706627066370664706657066670667706687066970670706717067270673706747067570676706777067870679706807068170682706837068470685706867068770688706897069070691706927069370694706957069670697706987069970700707017070270703707047070570706707077070870709707107071170712707137071470715707167071770718707197072070721707227072370724707257072670727707287072970730707317073270733707347073570736707377073870739707407074170742707437074470745707467074770748707497075070751707527075370754707557075670757707587075970760707617076270763707647076570766707677076870769707707077170772707737077470775707767077770778707797078070781707827078370784707857078670787707887078970790707917079270793707947079570796707977079870799708007080170802708037080470805708067080770808708097081070811708127081370814708157081670817708187081970820708217082270823708247082570826708277082870829708307083170832708337083470835708367083770838708397084070841708427084370844708457084670847708487084970850708517085270853708547085570856708577085870859708607086170862708637086470865708667086770868708697087070871708727087370874708757087670877708787087970880708817088270883708847088570886708877088870889708907089170892708937089470895708967089770898708997090070901709027090370904709057090670907709087090970910709117091270913709147091570916709177091870919709207092170922709237092470925709267092770928709297093070931709327093370934709357093670937709387093970940709417094270943709447094570946709477094870949709507095170952709537095470955709567095770958709597096070961709627096370964709657096670967709687096970970709717097270973709747097570976709777097870979709807098170982709837098470985709867098770988709897099070991709927099370994709957099670997709987099971000710017100271003710047100571006710077100871009710107101171012710137101471015710167101771018710197102071021710227102371024710257102671027710287102971030710317103271033710347103571036710377103871039710407104171042710437104471045710467104771048710497105071051710527105371054710557105671057710587105971060710617106271063710647106571066710677106871069710707107171072710737107471075710767107771078710797108071081710827108371084710857108671087710887108971090710917109271093710947109571096710977109871099711007110171102711037110471105711067110771108711097111071111711127111371114711157111671117711187111971120711217112271123711247112571126711277112871129711307113171132711337113471135711367113771138711397114071141711427114371144711457114671147711487114971150711517115271153711547115571156711577115871159711607116171162711637116471165711667116771168711697117071171711727117371174711757117671177711787117971180711817118271183711847118571186711877118871189711907119171192711937119471195711967119771198711997120071201712027120371204712057120671207712087120971210712117121271213712147121571216712177121871219712207122171222712237122471225712267122771228712297123071231712327123371234712357123671237712387123971240712417124271243712447124571246712477124871249712507125171252712537125471255712567125771258712597126071261712627126371264712657126671267712687126971270712717127271273712747127571276712777127871279712807128171282712837128471285712867128771288712897129071291712927129371294712957129671297712987129971300713017130271303713047130571306713077130871309713107131171312713137131471315713167131771318713197132071321713227132371324713257132671327713287132971330713317133271333713347133571336713377133871339713407134171342713437134471345713467134771348713497135071351713527135371354713557135671357713587135971360713617136271363713647136571366713677136871369713707137171372713737137471375713767137771378713797138071381713827138371384713857138671387713887138971390713917139271393713947139571396713977139871399714007140171402714037140471405714067140771408714097141071411714127141371414714157141671417714187141971420714217142271423714247142571426714277142871429714307143171432714337143471435714367143771438714397144071441714427144371444714457144671447714487144971450714517145271453714547145571456714577145871459714607146171462714637146471465714667146771468714697147071471714727147371474714757147671477714787147971480714817148271483714847148571486714877148871489714907149171492714937149471495714967149771498714997150071501715027150371504715057150671507715087150971510715117151271513715147151571516715177151871519715207152171522715237152471525715267152771528715297153071531715327153371534715357153671537715387153971540715417154271543715447154571546715477154871549715507155171552715537155471555715567155771558715597156071561715627156371564715657156671567715687156971570715717157271573715747157571576715777157871579715807158171582715837158471585715867158771588715897159071591715927159371594715957159671597715987159971600716017160271603716047160571606716077160871609716107161171612716137161471615716167161771618716197162071621716227162371624716257162671627716287162971630716317163271633716347163571636716377163871639716407164171642716437164471645716467164771648716497165071651716527165371654716557165671657716587165971660716617166271663716647166571666716677166871669716707167171672716737167471675716767167771678716797168071681716827168371684716857168671687716887168971690716917169271693716947169571696716977169871699717007170171702717037170471705717067170771708717097171071711717127171371714717157171671717717187171971720717217172271723717247172571726717277172871729717307173171732717337173471735717367173771738717397174071741717427174371744717457174671747717487174971750717517175271753717547175571756717577175871759717607176171762717637176471765717667176771768717697177071771717727177371774717757177671777717787177971780717817178271783717847178571786717877178871789717907179171792717937179471795717967179771798717997180071801718027180371804718057180671807718087180971810718117181271813718147181571816718177181871819718207182171822718237182471825718267182771828718297183071831718327183371834718357183671837718387183971840718417184271843718447184571846718477184871849718507185171852718537185471855718567185771858718597186071861718627186371864718657186671867718687186971870718717187271873718747187571876718777187871879718807188171882718837188471885718867188771888718897189071891718927189371894718957189671897718987189971900719017190271903719047190571906719077190871909719107191171912719137191471915719167191771918719197192071921719227192371924719257192671927719287192971930719317193271933719347193571936719377193871939719407194171942719437194471945719467194771948719497195071951719527195371954719557195671957719587195971960719617196271963719647196571966719677196871969719707197171972719737197471975719767197771978719797198071981719827198371984719857198671987719887198971990719917199271993719947199571996719977199871999720007200172002720037200472005720067200772008720097201072011720127201372014720157201672017720187201972020720217202272023720247202572026720277202872029720307203172032720337203472035720367203772038720397204072041720427204372044720457204672047720487204972050720517205272053720547205572056720577205872059720607206172062720637206472065720667206772068720697207072071720727207372074720757207672077720787207972080720817208272083720847208572086720877208872089720907209172092720937209472095720967209772098720997210072101721027210372104721057210672107721087210972110721117211272113721147211572116721177211872119721207212172122721237212472125721267212772128721297213072131721327213372134721357213672137721387213972140721417214272143721447214572146721477214872149721507215172152721537215472155721567215772158721597216072161721627216372164721657216672167721687216972170721717217272173721747217572176721777217872179721807218172182721837218472185721867218772188721897219072191721927219372194721957219672197721987219972200722017220272203722047220572206722077220872209722107221172212722137221472215722167221772218722197222072221722227222372224722257222672227722287222972230722317223272233722347223572236722377223872239722407224172242722437224472245722467224772248722497225072251722527225372254722557225672257722587225972260722617226272263722647226572266722677226872269722707227172272722737227472275722767227772278722797228072281722827228372284722857228672287722887228972290722917229272293722947229572296722977229872299723007230172302723037230472305723067230772308723097231072311723127231372314723157231672317723187231972320723217232272323723247232572326723277232872329723307233172332723337233472335723367233772338723397234072341723427234372344723457234672347723487234972350723517235272353723547235572356723577235872359723607236172362723637236472365723667236772368723697237072371723727237372374723757237672377723787237972380723817238272383723847238572386723877238872389723907239172392723937239472395723967239772398723997240072401724027240372404724057240672407724087240972410724117241272413724147241572416724177241872419724207242172422724237242472425724267242772428724297243072431724327243372434724357243672437724387243972440724417244272443724447244572446724477244872449724507245172452724537245472455724567245772458724597246072461724627246372464724657246672467724687246972470724717247272473724747247572476724777247872479724807248172482724837248472485724867248772488724897249072491724927249372494724957249672497724987249972500725017250272503725047250572506725077250872509725107251172512725137251472515725167251772518725197252072521725227252372524725257252672527725287252972530725317253272533725347253572536725377253872539725407254172542725437254472545725467254772548725497255072551725527255372554725557255672557725587255972560725617256272563725647256572566725677256872569725707257172572725737257472575725767257772578725797258072581725827258372584725857258672587725887258972590725917259272593725947259572596725977259872599726007260172602726037260472605726067260772608726097261072611726127261372614726157261672617726187261972620726217262272623726247262572626726277262872629726307263172632726337263472635726367263772638726397264072641726427264372644726457264672647726487264972650726517265272653726547265572656726577265872659726607266172662726637266472665726667266772668726697267072671726727267372674726757267672677726787267972680726817268272683726847268572686726877268872689726907269172692726937269472695726967269772698726997270072701727027270372704727057270672707727087270972710727117271272713727147271572716727177271872719727207272172722727237272472725727267272772728727297273072731727327273372734727357273672737727387273972740727417274272743727447274572746727477274872749727507275172752727537275472755727567275772758727597276072761727627276372764727657276672767727687276972770727717277272773727747277572776727777277872779727807278172782727837278472785727867278772788727897279072791727927279372794727957279672797727987279972800728017280272803728047280572806728077280872809728107281172812728137281472815728167281772818728197282072821728227282372824728257282672827728287282972830728317283272833728347283572836728377283872839728407284172842728437284472845728467284772848728497285072851728527285372854728557285672857728587285972860728617286272863728647286572866728677286872869728707287172872728737287472875728767287772878728797288072881728827288372884728857288672887728887288972890728917289272893728947289572896728977289872899729007290172902729037290472905729067290772908729097291072911729127291372914729157291672917729187291972920729217292272923729247292572926729277292872929729307293172932729337293472935729367293772938729397294072941729427294372944729457294672947729487294972950729517295272953729547295572956729577295872959729607296172962729637296472965729667296772968729697297072971729727297372974729757297672977729787297972980729817298272983729847298572986729877298872989729907299172992729937299472995729967299772998729997300073001730027300373004730057300673007730087300973010730117301273013730147301573016730177301873019730207302173022730237302473025730267302773028730297303073031730327303373034730357303673037730387303973040730417304273043730447304573046730477304873049730507305173052730537305473055730567305773058730597306073061730627306373064730657306673067730687306973070730717307273073730747307573076730777307873079730807308173082730837308473085730867308773088730897309073091730927309373094730957309673097730987309973100731017310273103731047310573106731077310873109731107311173112731137311473115731167311773118731197312073121731227312373124731257312673127731287312973130731317313273133731347313573136731377313873139731407314173142731437314473145731467314773148731497315073151731527315373154731557315673157731587315973160731617316273163731647316573166731677316873169731707317173172731737317473175731767317773178731797318073181731827318373184731857318673187731887318973190731917319273193731947319573196731977319873199732007320173202732037320473205732067320773208732097321073211732127321373214732157321673217732187321973220732217322273223732247322573226732277322873229732307323173232732337323473235732367323773238732397324073241732427324373244732457324673247732487324973250732517325273253732547325573256732577325873259732607326173262732637326473265732667326773268732697327073271732727327373274732757327673277732787327973280732817328273283732847328573286732877328873289732907329173292732937329473295732967329773298732997330073301733027330373304733057330673307733087330973310733117331273313733147331573316733177331873319733207332173322733237332473325733267332773328733297333073331733327333373334733357333673337733387333973340733417334273343733447334573346733477334873349733507335173352733537335473355733567335773358733597336073361733627336373364733657336673367733687336973370733717337273373733747337573376733777337873379733807338173382733837338473385733867338773388733897339073391733927339373394733957339673397733987339973400734017340273403734047340573406734077340873409734107341173412734137341473415734167341773418734197342073421734227342373424734257342673427734287342973430734317343273433734347343573436734377343873439734407344173442734437344473445734467344773448734497345073451734527345373454734557345673457734587345973460734617346273463734647346573466734677346873469734707347173472734737347473475734767347773478734797348073481734827348373484734857348673487734887348973490734917349273493734947349573496734977349873499735007350173502735037350473505735067350773508735097351073511735127351373514735157351673517735187351973520735217352273523735247352573526735277352873529735307353173532735337353473535735367353773538735397354073541735427354373544735457354673547735487354973550735517355273553735547355573556735577355873559735607356173562735637356473565735667356773568735697357073571735727357373574735757357673577735787357973580735817358273583735847358573586735877358873589735907359173592735937359473595735967359773598735997360073601736027360373604736057360673607736087360973610736117361273613736147361573616736177361873619736207362173622736237362473625736267362773628736297363073631736327363373634736357363673637736387363973640736417364273643736447364573646736477364873649736507365173652736537365473655736567365773658736597366073661736627366373664736657366673667736687366973670736717367273673736747367573676736777367873679736807368173682736837368473685736867368773688736897369073691736927369373694736957369673697736987369973700737017370273703737047370573706737077370873709737107371173712737137371473715737167371773718737197372073721737227372373724737257372673727737287372973730737317373273733737347373573736737377373873739737407374173742737437374473745737467374773748737497375073751737527375373754737557375673757737587375973760737617376273763737647376573766737677376873769737707377173772737737377473775737767377773778737797378073781737827378373784737857378673787737887378973790737917379273793737947379573796737977379873799738007380173802738037380473805738067380773808738097381073811738127381373814738157381673817738187381973820738217382273823738247382573826738277382873829738307383173832738337383473835738367383773838738397384073841738427384373844738457384673847738487384973850738517385273853738547385573856738577385873859738607386173862738637386473865738667386773868738697387073871738727387373874738757387673877738787387973880738817388273883738847388573886738877388873889738907389173892738937389473895738967389773898738997390073901739027390373904739057390673907739087390973910739117391273913739147391573916739177391873919739207392173922739237392473925739267392773928739297393073931739327393373934739357393673937739387393973940739417394273943739447394573946739477394873949739507395173952739537395473955739567395773958739597396073961739627396373964739657396673967739687396973970739717397273973739747397573976739777397873979739807398173982739837398473985739867398773988739897399073991739927399373994739957399673997739987399974000740017400274003740047400574006740077400874009740107401174012740137401474015740167401774018740197402074021740227402374024740257402674027740287402974030740317403274033740347403574036740377403874039740407404174042740437404474045740467404774048740497405074051740527405374054740557405674057740587405974060740617406274063740647406574066740677406874069740707407174072740737407474075740767407774078740797408074081740827408374084740857408674087740887408974090740917409274093740947409574096740977409874099741007410174102741037410474105741067410774108741097411074111741127411374114741157411674117741187411974120741217412274123741247412574126741277412874129741307413174132741337413474135741367413774138741397414074141741427414374144741457414674147741487414974150741517415274153741547415574156741577415874159741607416174162741637416474165741667416774168741697417074171741727417374174741757417674177741787417974180741817418274183741847418574186741877418874189741907419174192741937419474195741967419774198741997420074201742027420374204742057420674207742087420974210742117421274213742147421574216742177421874219742207422174222742237422474225742267422774228742297423074231742327423374234742357423674237742387423974240742417424274243742447424574246742477424874249742507425174252742537425474255742567425774258742597426074261742627426374264742657426674267742687426974270742717427274273742747427574276742777427874279742807428174282742837428474285742867428774288742897429074291742927429374294742957429674297742987429974300743017430274303743047430574306743077430874309743107431174312743137431474315743167431774318743197432074321743227432374324743257432674327743287432974330743317433274333743347433574336743377433874339743407434174342743437434474345743467434774348743497435074351743527435374354743557435674357743587435974360743617436274363743647436574366743677436874369743707437174372743737437474375743767437774378743797438074381743827438374384743857438674387743887438974390743917439274393743947439574396743977439874399744007440174402744037440474405744067440774408744097441074411744127441374414744157441674417744187441974420744217442274423744247442574426744277442874429744307443174432744337443474435744367443774438744397444074441744427444374444744457444674447744487444974450744517445274453744547445574456744577445874459744607446174462744637446474465744667446774468744697447074471744727447374474744757447674477744787447974480744817448274483744847448574486744877448874489744907449174492744937449474495744967449774498744997450074501745027450374504745057450674507745087450974510745117451274513745147451574516745177451874519745207452174522745237452474525745267452774528745297453074531745327453374534745357453674537745387453974540745417454274543745447454574546745477454874549745507455174552745537455474555745567455774558745597456074561745627456374564745657456674567745687456974570745717457274573745747457574576745777457874579745807458174582745837458474585745867458774588745897459074591745927459374594745957459674597745987459974600746017460274603746047460574606746077460874609746107461174612746137461474615746167461774618746197462074621746227462374624746257462674627746287462974630746317463274633746347463574636746377463874639746407464174642746437464474645746467464774648746497465074651746527465374654746557465674657746587465974660746617466274663746647466574666746677466874669746707467174672746737467474675746767467774678746797468074681746827468374684746857468674687746887468974690746917469274693746947469574696746977469874699747007470174702747037470474705747067470774708747097471074711747127471374714747157471674717747187471974720747217472274723747247472574726747277472874729747307473174732747337473474735747367473774738747397474074741747427474374744747457474674747747487474974750747517475274753747547475574756747577475874759747607476174762747637476474765747667476774768747697477074771747727477374774747757477674777747787477974780747817478274783747847478574786747877478874789747907479174792747937479474795747967479774798747997480074801748027480374804748057480674807748087480974810748117481274813748147481574816748177481874819748207482174822748237482474825748267482774828748297483074831748327483374834748357483674837748387483974840748417484274843748447484574846748477484874849748507485174852748537485474855748567485774858748597486074861748627486374864748657486674867748687486974870748717487274873748747487574876748777487874879748807488174882748837488474885748867488774888748897489074891748927489374894748957489674897748987489974900749017490274903749047490574906749077490874909749107491174912749137491474915749167491774918749197492074921749227492374924749257492674927749287492974930749317493274933749347493574936749377493874939749407494174942749437494474945749467494774948749497495074951749527495374954749557495674957749587495974960749617496274963749647496574966749677496874969749707497174972749737497474975749767497774978749797498074981749827498374984749857498674987749887498974990749917499274993749947499574996749977499874999750007500175002750037500475005750067500775008750097501075011750127501375014750157501675017750187501975020750217502275023750247502575026750277502875029750307503175032750337503475035750367503775038750397504075041750427504375044750457504675047750487504975050750517505275053750547505575056750577505875059750607506175062750637506475065750667506775068750697507075071750727507375074750757507675077750787507975080750817508275083750847508575086750877508875089750907509175092750937509475095750967509775098750997510075101 |
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // object to store loaded chunks
- /******/ // "0" means "already loaded"
- /******/ var installedChunks = {
- /******/ 0: 0
- /******/ };
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/ // This file contains only the entry chunk.
- /******/ // The chunk loading function for additional chunks
- /******/ __webpack_require__.e = function requireEnsure(chunkId) {
- /******/ var promises = [];
- /******/
- /******/
- /******/ // require() chunk loading for javascript
- /******/
- /******/ // "0" is the signal for "already loaded"
- /******/ if(installedChunks[chunkId] !== 0) {
- /******/ var chunk = require("./" + ({"1":"components/add-address-dialog","2":"components/book-card","3":"components/breadcrumb","4":"components/bxh","5":"components/card","6":"components/carousel","7":"components/category-filter","8":"components/category-no-data","9":"components/custom-el-slider","10":"components/custom-el-slider-button","11":"components/custom-el-slider-marker","12":"components/design-form-dialog","13":"components/download-dialog","14":"components/export-dialog","15":"components/form-dialog","16":"components/image-list","17":"components/image-upload","18":"components/login-dialog","19":"components/pagination","20":"components/pc-article","21":"components/pc-global-form","22":"components/pc-switch","23":"components/pc-title","24":"components/pdf-html","25":"components/price-to-img","26":"components/product-builder-dialog-select-addr","27":"components/product-builder-step-mixin","28":"components/product-builder-step1","29":"components/product-builder-step2","30":"components/product-builder-step3","31":"components/product-left","32":"components/product-quote","33":"components/product-right","34":"components/project","35":"components/project-dialog","36":"components/reset-password-dialog","37":"components/reset-password-mail","38":"components/row-card","39":"components/sub-nav","40":"components/subscription","41":"components/tab-nav","42":"components/table-change-table","43":"components/table-mail-table","44":"components/table-new-price-table","45":"components/table-param-table","46":"components/table-stock-table","47":"components/table-total-table","48":"components/table-unit-table","49":"components/tinymce","50":"components/tinymce-components-editor-image","51":"components/tinymce-dynamic-load-script","52":"components/tinymce-plugins","53":"components/tinymce-toolbar","54":"components/zoom","55":"pages/3D/_id","56":"pages/aboutus","57":"pages/category/_firstCategory/_secondCategory/_thirdCategory/index","58":"pages/category/_firstCategory/_secondCategory/index","59":"pages/category/_firstCategory/index","60":"pages/category/index","61":"pages/category/searchResult/index","62":"pages/design/_id","63":"pages/home/EDMS","64":"pages/home/FAQs","65":"pages/home/api","66":"pages/home/catalogue","67":"pages/home/compareList","68":"pages/home/contact","69":"pages/home/contactPromoCollection","70":"pages/home/contactus","71":"pages/home/currentFlyer/index","72":"pages/home/downloadCenter","73":"pages/home/loyaltyProgram","74":"pages/home/myDetail/components/orderDetailPart","75":"pages/home/myDetail/enquiryDetail","76":"pages/home/myDetail/index","77":"pages/home/myDetail/orderDetail","78":"pages/home/newsLetter","79":"pages/home/privacyPolicy","80":"pages/home/projects","81":"pages/home/refundReturns","82":"pages/home/termsConditions","83":"pages/home/video","84":"pages/index","85":"pages/news/_newsName","86":"pages/orderShare/_uid/_aid/_id","87":"pages/pdf/_id","88":"pages/product-builder/_code","89":"pages/product-record/_code","90":"pages/product/_code","91":"pages/product/index","92":"pages/render/_id","93":"pages/setNewPassword"}[chunkId]||chunkId) + ".js");
- /******/ var moreModules = chunk.modules, chunkIds = chunk.ids;
- /******/ for(var moduleId in moreModules) {
- /******/ modules[moduleId] = moreModules[moduleId];
- /******/ }
- /******/ for(var i = 0; i < chunkIds.length; i++)
- /******/ installedChunks[chunkIds[i]] = 0;
- /******/ }
- /******/ return Promise.all(promises);
- /******/ };
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/_nuxt/";
- /******/
- /******/ // uncaught error handler for webpack runtime
- /******/ __webpack_require__.oe = function(err) {
- /******/ process.nextTick(function() {
- /******/ throw err; // catch this error by using import().catch()
- /******/ });
- /******/ };
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 57);
- /******/ })
- /************************************************************************/
- /******/ ([
- /* 0 */
- /***/ (function(module, exports) {
- module.exports = require("vue");
- /***/ }),
- /* 1 */
- /***/ (function(module, exports) {
- module.exports = require("crypto-js");
- /***/ }),
- /* 2 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent(
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier /* server only */,
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options =
- typeof scriptExports === 'function' ? scriptExports.options : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) {
- // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () {
- injectStyles.call(
- this,
- (options.functional ? this.parent : this).$root.$options.shadowRoot
- )
- }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functional component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection(h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing ? [].concat(existing, hook) : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /* 3 */
- /***/ (function(module, exports) {
- module.exports = require("ufo");
- /***/ }),
- /* 4 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.isMac = exports.isEmpty = exports.isEqual = exports.arrayEquals = exports.looseEqual = exports.capitalize = exports.kebabCase = exports.autoprefixer = exports.isFirefox = exports.isEdge = exports.isIE = exports.coerceTruthyValueToArray = exports.arrayFind = exports.arrayFindIndex = exports.escapeRegexpString = exports.valueEquals = exports.generateId = exports.getValueByPath = undefined;
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- exports.noop = noop;
- exports.hasOwn = hasOwn;
- exports.toObject = toObject;
- exports.getPropByPath = getPropByPath;
- exports.rafThrottle = rafThrottle;
- exports.objToArray = objToArray;
- var _vue = __webpack_require__(0);
- var _vue2 = _interopRequireDefault(_vue);
- var _types = __webpack_require__(34);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var hasOwnProperty = Object.prototype.hasOwnProperty;
- function noop() {};
- function hasOwn(obj, key) {
- return hasOwnProperty.call(obj, key);
- };
- function extend(to, _from) {
- for (var key in _from) {
- to[key] = _from[key];
- }
- return to;
- };
- function toObject(arr) {
- var res = {};
- for (var i = 0; i < arr.length; i++) {
- if (arr[i]) {
- extend(res, arr[i]);
- }
- }
- return res;
- };
- var getValueByPath = exports.getValueByPath = function getValueByPath(object, prop) {
- prop = prop || '';
- var paths = prop.split('.');
- var current = object;
- var result = null;
- for (var i = 0, j = paths.length; i < j; i++) {
- var path = paths[i];
- if (!current) break;
- if (i === j - 1) {
- result = current[path];
- break;
- }
- current = current[path];
- }
- return result;
- };
- function getPropByPath(obj, path, strict) {
- var tempObj = obj;
- path = path.replace(/\[(\w+)\]/g, '.$1');
- path = path.replace(/^\./, '');
- var keyArr = path.split('.');
- var i = 0;
- for (var len = keyArr.length; i < len - 1; ++i) {
- if (!tempObj && !strict) break;
- var key = keyArr[i];
- if (key in tempObj) {
- tempObj = tempObj[key];
- } else {
- if (strict) {
- throw new Error('please transfer a valid prop path to form item!');
- }
- break;
- }
- }
- return {
- o: tempObj,
- k: keyArr[i],
- v: tempObj ? tempObj[keyArr[i]] : null
- };
- };
- var generateId = exports.generateId = function generateId() {
- return Math.floor(Math.random() * 10000);
- };
- var valueEquals = exports.valueEquals = function valueEquals(a, b) {
- // see: https://stackoverflow.com/questions/3115982/how-to-check-if-two-arrays-are-equal-with-javascript
- if (a === b) return true;
- if (!(a instanceof Array)) return false;
- if (!(b instanceof Array)) return false;
- if (a.length !== b.length) return false;
- for (var i = 0; i !== a.length; ++i) {
- if (a[i] !== b[i]) return false;
- }
- return true;
- };
- var escapeRegexpString = exports.escapeRegexpString = function escapeRegexpString() {
- var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
- return String(value).replace(/[|\\{}()[\]^$+*?.]/g, '\\$&');
- };
- // TODO: use native Array.find, Array.findIndex when IE support is dropped
- var arrayFindIndex = exports.arrayFindIndex = function arrayFindIndex(arr, pred) {
- for (var i = 0; i !== arr.length; ++i) {
- if (pred(arr[i])) {
- return i;
- }
- }
- return -1;
- };
- var arrayFind = exports.arrayFind = function arrayFind(arr, pred) {
- var idx = arrayFindIndex(arr, pred);
- return idx !== -1 ? arr[idx] : undefined;
- };
- // coerce truthy value to array
- var coerceTruthyValueToArray = exports.coerceTruthyValueToArray = function coerceTruthyValueToArray(val) {
- if (Array.isArray(val)) {
- return val;
- } else if (val) {
- return [val];
- } else {
- return [];
- }
- };
- var isIE = exports.isIE = function isIE() {
- return !_vue2.default.prototype.$isServer && !isNaN(Number(document.documentMode));
- };
- var isEdge = exports.isEdge = function isEdge() {
- return !_vue2.default.prototype.$isServer && navigator.userAgent.indexOf('Edge') > -1;
- };
- var isFirefox = exports.isFirefox = function isFirefox() {
- return !_vue2.default.prototype.$isServer && !!window.navigator.userAgent.match(/firefox/i);
- };
- var autoprefixer = exports.autoprefixer = function autoprefixer(style) {
- if ((typeof style === 'undefined' ? 'undefined' : _typeof(style)) !== 'object') return style;
- var rules = ['transform', 'transition', 'animation'];
- var prefixes = ['ms-', 'webkit-'];
- rules.forEach(function (rule) {
- var value = style[rule];
- if (rule && value) {
- prefixes.forEach(function (prefix) {
- style[prefix + rule] = value;
- });
- }
- });
- return style;
- };
- var kebabCase = exports.kebabCase = function kebabCase(str) {
- var hyphenateRE = /([^-])([A-Z])/g;
- return str.replace(hyphenateRE, '$1-$2').replace(hyphenateRE, '$1-$2').toLowerCase();
- };
- var capitalize = exports.capitalize = function capitalize(str) {
- if (!(0, _types.isString)(str)) return str;
- return str.charAt(0).toUpperCase() + str.slice(1);
- };
- var looseEqual = exports.looseEqual = function looseEqual(a, b) {
- var isObjectA = (0, _types.isObject)(a);
- var isObjectB = (0, _types.isObject)(b);
- if (isObjectA && isObjectB) {
- return JSON.stringify(a) === JSON.stringify(b);
- } else if (!isObjectA && !isObjectB) {
- return String(a) === String(b);
- } else {
- return false;
- }
- };
- var arrayEquals = exports.arrayEquals = function arrayEquals(arrayA, arrayB) {
- arrayA = arrayA || [];
- arrayB = arrayB || [];
- if (arrayA.length !== arrayB.length) {
- return false;
- }
- for (var i = 0; i < arrayA.length; i++) {
- if (!looseEqual(arrayA[i], arrayB[i])) {
- return false;
- }
- }
- return true;
- };
- var isEqual = exports.isEqual = function isEqual(value1, value2) {
- if (Array.isArray(value1) && Array.isArray(value2)) {
- return arrayEquals(value1, value2);
- }
- return looseEqual(value1, value2);
- };
- var isEmpty = exports.isEmpty = function isEmpty(val) {
- // null or undefined
- if (val == null) return true;
- if (typeof val === 'boolean') return false;
- if (typeof val === 'number') return !val;
- if (val instanceof Error) return val.message === '';
- switch (Object.prototype.toString.call(val)) {
- // String or Array
- case '[object String]':
- case '[object Array]':
- return !val.length;
- // Map or Set or File
- case '[object File]':
- case '[object Map]':
- case '[object Set]':
- {
- return !val.size;
- }
- // Plain Object
- case '[object Object]':
- {
- return !Object.keys(val).length;
- }
- }
- return false;
- };
- function rafThrottle(fn) {
- var locked = false;
- return function () {
- var _this = this;
- for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
- if (locked) return;
- locked = true;
- window.requestAnimationFrame(function (_) {
- fn.apply(_this, args);
- locked = false;
- });
- };
- }
- function objToArray(obj) {
- if (Array.isArray(obj)) {
- return obj;
- }
- return isEmpty(obj) ? [] : [obj];
- }
- var isMac = exports.isMac = function isMac() {
- return !_vue2.default.prototype.$isServer && /macintosh|mac os x/i.test(navigator.userAgent);
- };
- /***/ }),
- /* 5 */
- /***/ (function(module, exports) {
- module.exports = require("vuex");
- /***/ }),
- /* 6 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.isInContainer = exports.getScrollContainer = exports.isScroll = exports.getStyle = exports.once = exports.off = exports.on = undefined;
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; /* istanbul ignore next */
- exports.hasClass = hasClass;
- exports.addClass = addClass;
- exports.removeClass = removeClass;
- exports.setStyle = setStyle;
- var _vue = __webpack_require__(0);
- var _vue2 = _interopRequireDefault(_vue);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var isServer = _vue2.default.prototype.$isServer;
- var SPECIAL_CHARS_REGEXP = /([\:\-\_]+(.))/g;
- var MOZ_HACK_REGEXP = /^moz([A-Z])/;
- var ieVersion = isServer ? 0 : Number(document.documentMode);
- /* istanbul ignore next */
- var trim = function trim(string) {
- return (string || '').replace(/^[\s\uFEFF]+|[\s\uFEFF]+$/g, '');
- };
- /* istanbul ignore next */
- var camelCase = function camelCase(name) {
- return name.replace(SPECIAL_CHARS_REGEXP, function (_, separator, letter, offset) {
- return offset ? letter.toUpperCase() : letter;
- }).replace(MOZ_HACK_REGEXP, 'Moz$1');
- };
- /* istanbul ignore next */
- var on = exports.on = function () {
- if (!isServer && document.addEventListener) {
- return function (element, event, handler) {
- if (element && event && handler) {
- element.addEventListener(event, handler, false);
- }
- };
- } else {
- return function (element, event, handler) {
- if (element && event && handler) {
- element.attachEvent('on' + event, handler);
- }
- };
- }
- }();
- /* istanbul ignore next */
- var off = exports.off = function () {
- if (!isServer && document.removeEventListener) {
- return function (element, event, handler) {
- if (element && event) {
- element.removeEventListener(event, handler, false);
- }
- };
- } else {
- return function (element, event, handler) {
- if (element && event) {
- element.detachEvent('on' + event, handler);
- }
- };
- }
- }();
- /* istanbul ignore next */
- var once = exports.once = function once(el, event, fn) {
- var listener = function listener() {
- if (fn) {
- fn.apply(this, arguments);
- }
- off(el, event, listener);
- };
- on(el, event, listener);
- };
- /* istanbul ignore next */
- function hasClass(el, cls) {
- if (!el || !cls) return false;
- if (cls.indexOf(' ') !== -1) throw new Error('className should not contain space.');
- if (el.classList) {
- return el.classList.contains(cls);
- } else {
- return (' ' + el.className + ' ').indexOf(' ' + cls + ' ') > -1;
- }
- };
- /* istanbul ignore next */
- function addClass(el, cls) {
- if (!el) return;
- var curClass = el.className;
- var classes = (cls || '').split(' ');
- for (var i = 0, j = classes.length; i < j; i++) {
- var clsName = classes[i];
- if (!clsName) continue;
- if (el.classList) {
- el.classList.add(clsName);
- } else if (!hasClass(el, clsName)) {
- curClass += ' ' + clsName;
- }
- }
- if (!el.classList) {
- el.setAttribute('class', curClass);
- }
- };
- /* istanbul ignore next */
- function removeClass(el, cls) {
- if (!el || !cls) return;
- var classes = cls.split(' ');
- var curClass = ' ' + el.className + ' ';
- for (var i = 0, j = classes.length; i < j; i++) {
- var clsName = classes[i];
- if (!clsName) continue;
- if (el.classList) {
- el.classList.remove(clsName);
- } else if (hasClass(el, clsName)) {
- curClass = curClass.replace(' ' + clsName + ' ', ' ');
- }
- }
- if (!el.classList) {
- el.setAttribute('class', trim(curClass));
- }
- };
- /* istanbul ignore next */
- var getStyle = exports.getStyle = ieVersion < 9 ? function (element, styleName) {
- if (isServer) return;
- if (!element || !styleName) return null;
- styleName = camelCase(styleName);
- if (styleName === 'float') {
- styleName = 'styleFloat';
- }
- try {
- switch (styleName) {
- case 'opacity':
- try {
- return element.filters.item('alpha').opacity / 100;
- } catch (e) {
- return 1.0;
- }
- default:
- return element.style[styleName] || element.currentStyle ? element.currentStyle[styleName] : null;
- }
- } catch (e) {
- return element.style[styleName];
- }
- } : function (element, styleName) {
- if (isServer) return;
- if (!element || !styleName) return null;
- styleName = camelCase(styleName);
- if (styleName === 'float') {
- styleName = 'cssFloat';
- }
- try {
- var computed = document.defaultView.getComputedStyle(element, '');
- return element.style[styleName] || computed ? computed[styleName] : null;
- } catch (e) {
- return element.style[styleName];
- }
- };
- /* istanbul ignore next */
- function setStyle(element, styleName, value) {
- if (!element || !styleName) return;
- if ((typeof styleName === 'undefined' ? 'undefined' : _typeof(styleName)) === 'object') {
- for (var prop in styleName) {
- if (styleName.hasOwnProperty(prop)) {
- setStyle(element, prop, styleName[prop]);
- }
- }
- } else {
- styleName = camelCase(styleName);
- if (styleName === 'opacity' && ieVersion < 9) {
- element.style.filter = isNaN(value) ? '' : 'alpha(opacity=' + value * 100 + ')';
- } else {
- element.style[styleName] = value;
- }
- }
- };
- var isScroll = exports.isScroll = function isScroll(el, vertical) {
- if (isServer) return;
- var determinedDirection = vertical !== null && vertical !== undefined;
- var overflow = determinedDirection ? vertical ? getStyle(el, 'overflow-y') : getStyle(el, 'overflow-x') : getStyle(el, 'overflow');
- return overflow.match(/(scroll|auto|overlay)/);
- };
- var getScrollContainer = exports.getScrollContainer = function getScrollContainer(el, vertical) {
- if (isServer) return;
- var parent = el;
- while (parent) {
- if ([window, document, document.documentElement].includes(parent)) {
- return window;
- }
- if (isScroll(parent, vertical)) {
- return parent;
- }
- parent = parent.parentNode;
- }
- return parent;
- };
- var isInContainer = exports.isInContainer = function isInContainer(el, container) {
- if (isServer || !el || !container) return false;
- var elRect = el.getBoundingClientRect();
- var containerRect = void 0;
- if ([window, document, document.documentElement, null, undefined].includes(container)) {
- containerRect = {
- top: 0,
- right: window.innerWidth,
- bottom: window.innerHeight,
- left: 0
- };
- } else {
- containerRect = container.getBoundingClientRect();
- }
- return elRect.top < containerRect.bottom && elRect.bottom > containerRect.top && elRect.right > containerRect.left && elRect.left < containerRect.right;
- };
- /***/ }),
- /* 7 */
- /***/ (function(module, exports, __webpack_require__) {
- /* WEBPACK VAR INJECTION */(function(URL) {module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 46);
- /******/ })
- /************************************************************************/
- /******/ ([
- /* 0 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(60);
- /***/ }),
- /* 1 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(6);
- /***/ }),
- /* 2 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(4);
- /***/ }),
- /* 3 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(8);
- /***/ }),
- /* 4 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(18);
- /***/ }),
- /* 5 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(12);
- /***/ }),
- /* 6 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(0);
- /***/ }),
- /* 7 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(13);
- /***/ }),
- /* 8 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(20);
- /***/ }),
- /* 9 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(36);
- /***/ }),
- /* 10 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(37);
- /***/ }),
- /* 11 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(35);
- /***/ }),
- /* 12 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(17);
- /***/ }),
- /* 13 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(66);
- /***/ }),
- /* 14 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(38);
- /***/ }),
- /* 15 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(21);
- /***/ }),
- /* 16 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(34);
- /***/ }),
- /* 17 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(22);
- /***/ }),
- /* 18 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(23);
- /***/ }),
- /* 19 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(14);
- /***/ }),
- /* 20 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(33);
- /***/ }),
- /* 21 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(68);
- /***/ }),
- /* 22 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(69);
- /***/ }),
- /* 23 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(24);
- /***/ }),
- /* 24 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(40);
- /***/ }),
- /* 25 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(70);
- /***/ }),
- /* 26 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(71);
- /***/ }),
- /* 27 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(25);
- /***/ }),
- /* 28 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(72);
- /***/ }),
- /* 29 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(73);
- /***/ }),
- /* 30 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(43);
- /***/ }),
- /* 31 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(19);
- /***/ }),
- /* 32 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(74);
- /***/ }),
- /* 33 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(75);
- /***/ }),
- /* 34 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(76);
- /***/ }),
- /* 35 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(26);
- /***/ }),
- /* 36 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(39);
- /***/ }),
- /* 37 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(77);
- /***/ }),
- /* 38 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(78);
- /***/ }),
- /* 39 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(79);
- /***/ }),
- /* 40 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(80);
- /***/ }),
- /* 41 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(81);
- /***/ }),
- /* 42 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(82);
- /***/ }),
- /* 43 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(83);
- /***/ }),
- /* 44 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(44);
- /***/ }),
- /* 45 */
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(84);
- /***/ }),
- /* 46 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(47);
- /***/ }),
- /* 47 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/pagination/src/pager.vue?vue&type=template&id=7274f267&
- var pagervue_type_template_id_7274f267_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "ul",
- { staticClass: "el-pager", on: { click: _vm.onPagerClick } },
- [
- _vm.pageCount > 0
- ? _c(
- "li",
- {
- staticClass: "number",
- class: { active: _vm.currentPage === 1, disabled: _vm.disabled }
- },
- [_vm._v("1")]
- )
- : _vm._e(),
- _vm.showPrevMore
- ? _c("li", {
- staticClass: "el-icon more btn-quickprev",
- class: [_vm.quickprevIconClass, { disabled: _vm.disabled }],
- on: {
- mouseenter: function($event) {
- _vm.onMouseenter("left")
- },
- mouseleave: function($event) {
- _vm.quickprevIconClass = "el-icon-more"
- }
- }
- })
- : _vm._e(),
- _vm._l(_vm.pagers, function(pager) {
- return _c(
- "li",
- {
- key: pager,
- staticClass: "number",
- class: { active: _vm.currentPage === pager, disabled: _vm.disabled }
- },
- [_vm._v(_vm._s(pager))]
- )
- }),
- _vm.showNextMore
- ? _c("li", {
- staticClass: "el-icon more btn-quicknext",
- class: [_vm.quicknextIconClass, { disabled: _vm.disabled }],
- on: {
- mouseenter: function($event) {
- _vm.onMouseenter("right")
- },
- mouseleave: function($event) {
- _vm.quicknextIconClass = "el-icon-more"
- }
- }
- })
- : _vm._e(),
- _vm.pageCount > 1
- ? _c(
- "li",
- {
- staticClass: "number",
- class: {
- active: _vm.currentPage === _vm.pageCount,
- disabled: _vm.disabled
- }
- },
- [_vm._v(_vm._s(_vm.pageCount))]
- )
- : _vm._e()
- ],
- 2
- )
- }
- var staticRenderFns = []
- pagervue_type_template_id_7274f267_render._withStripped = true
- // CONCATENATED MODULE: ./packages/pagination/src/pager.vue?vue&type=template&id=7274f267&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/pagination/src/pager.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var pagervue_type_script_lang_js_ = ({
- name: 'ElPager',
- props: {
- currentPage: Number,
- pageCount: Number,
- pagerCount: Number,
- disabled: Boolean
- },
- watch: {
- showPrevMore: function showPrevMore(val) {
- if (!val) this.quickprevIconClass = 'el-icon-more';
- },
- showNextMore: function showNextMore(val) {
- if (!val) this.quicknextIconClass = 'el-icon-more';
- }
- },
- methods: {
- onPagerClick: function onPagerClick(event) {
- var target = event.target;
- if (target.tagName === 'UL' || this.disabled) {
- return;
- }
- var newPage = Number(event.target.textContent);
- var pageCount = this.pageCount;
- var currentPage = this.currentPage;
- var pagerCountOffset = this.pagerCount - 2;
- if (target.className.indexOf('more') !== -1) {
- if (target.className.indexOf('quickprev') !== -1) {
- newPage = currentPage - pagerCountOffset;
- } else if (target.className.indexOf('quicknext') !== -1) {
- newPage = currentPage + pagerCountOffset;
- }
- }
- /* istanbul ignore if */
- if (!isNaN(newPage)) {
- if (newPage < 1) {
- newPage = 1;
- }
- if (newPage > pageCount) {
- newPage = pageCount;
- }
- }
- if (newPage !== currentPage) {
- this.$emit('change', newPage);
- }
- },
- onMouseenter: function onMouseenter(direction) {
- if (this.disabled) return;
- if (direction === 'left') {
- this.quickprevIconClass = 'el-icon-d-arrow-left';
- } else {
- this.quicknextIconClass = 'el-icon-d-arrow-right';
- }
- }
- },
- computed: {
- pagers: function pagers() {
- var pagerCount = this.pagerCount;
- var halfPagerCount = (pagerCount - 1) / 2;
- var currentPage = Number(this.currentPage);
- var pageCount = Number(this.pageCount);
- var showPrevMore = false;
- var showNextMore = false;
- if (pageCount > pagerCount) {
- if (currentPage > pagerCount - halfPagerCount) {
- showPrevMore = true;
- }
- if (currentPage < pageCount - halfPagerCount) {
- showNextMore = true;
- }
- }
- var array = [];
- if (showPrevMore && !showNextMore) {
- var startPage = pageCount - (pagerCount - 2);
- for (var i = startPage; i < pageCount; i++) {
- array.push(i);
- }
- } else if (!showPrevMore && showNextMore) {
- for (var _i = 2; _i < pagerCount; _i++) {
- array.push(_i);
- }
- } else if (showPrevMore && showNextMore) {
- var offset = Math.floor(pagerCount / 2) - 1;
- for (var _i2 = currentPage - offset; _i2 <= currentPage + offset; _i2++) {
- array.push(_i2);
- }
- } else {
- for (var _i3 = 2; _i3 < pageCount; _i3++) {
- array.push(_i3);
- }
- }
- this.showPrevMore = showPrevMore;
- this.showNextMore = showNextMore;
- return array;
- }
- },
- data: function data() {
- return {
- current: null,
- showPrevMore: false,
- showNextMore: false,
- quicknextIconClass: 'el-icon-more',
- quickprevIconClass: 'el-icon-more'
- };
- }
- });
- // CONCATENATED MODULE: ./packages/pagination/src/pager.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_pagervue_type_script_lang_js_ = (pagervue_type_script_lang_js_);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- // CONCATENATED MODULE: ./packages/pagination/src/pager.vue
- /* normalize component */
- var component = normalizeComponent(
- src_pagervue_type_script_lang_js_,
- pagervue_type_template_id_7274f267_render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/pagination/src/pager.vue"
- /* harmony default export */ var pager = (component.exports);
- // EXTERNAL MODULE: external "element-ui/lib/select"
- var select_ = __webpack_require__(37);
- var select_default = /*#__PURE__*/__webpack_require__.n(select_);
- // EXTERNAL MODULE: external "element-ui/lib/option"
- var option_ = __webpack_require__(38);
- var option_default = /*#__PURE__*/__webpack_require__.n(option_);
- // EXTERNAL MODULE: external "element-ui/lib/input"
- var input_ = __webpack_require__(8);
- var input_default = /*#__PURE__*/__webpack_require__.n(input_);
- // EXTERNAL MODULE: external "element-ui/lib/mixins/locale"
- var locale_ = __webpack_require__(4);
- var locale_default = /*#__PURE__*/__webpack_require__.n(locale_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/util"
- var util_ = __webpack_require__(2);
- // CONCATENATED MODULE: ./packages/pagination/src/pagination.js
- /* harmony default export */ var pagination = ({
- name: 'ElPagination',
- props: {
- pageSize: {
- type: Number,
- default: 10
- },
- small: Boolean,
- total: Number,
- pageCount: Number,
- pagerCount: {
- type: Number,
- validator: function validator(value) {
- return (value | 0) === value && value > 4 && value < 22 && value % 2 === 1;
- },
- default: 7
- },
- currentPage: {
- type: Number,
- default: 1
- },
- layout: {
- default: 'prev, pager, next, jumper, ->, total'
- },
- pageSizes: {
- type: Array,
- default: function _default() {
- return [10, 20, 30, 40, 50, 100];
- }
- },
- popperClass: String,
- prevText: String,
- nextText: String,
- background: Boolean,
- disabled: Boolean,
- hideOnSinglePage: Boolean
- },
- data: function data() {
- return {
- internalCurrentPage: 1,
- internalPageSize: 0,
- lastEmittedPage: -1,
- userChangePageSize: false
- };
- },
- render: function render(h) {
- var layout = this.layout;
- if (!layout) return null;
- if (this.hideOnSinglePage && (!this.internalPageCount || this.internalPageCount === 1)) return null;
- var template = h('div', { 'class': ['el-pagination', {
- 'is-background': this.background,
- 'el-pagination--small': this.small
- }] });
- var TEMPLATE_MAP = {
- prev: h('prev'),
- jumper: h('jumper'),
- pager: h('pager', {
- attrs: { currentPage: this.internalCurrentPage, pageCount: this.internalPageCount, pagerCount: this.pagerCount, disabled: this.disabled },
- on: {
- 'change': this.handleCurrentChange
- }
- }),
- next: h('next'),
- sizes: h('sizes', {
- attrs: { pageSizes: this.pageSizes }
- }),
- slot: h('slot', [this.$slots.default ? this.$slots.default : '']),
- total: h('total')
- };
- var components = layout.split(',').map(function (item) {
- return item.trim();
- });
- var rightWrapper = h('div', { 'class': 'el-pagination__rightwrapper' });
- var haveRightWrapper = false;
- template.children = template.children || [];
- rightWrapper.children = rightWrapper.children || [];
- components.forEach(function (compo) {
- if (compo === '->') {
- haveRightWrapper = true;
- return;
- }
- if (!haveRightWrapper) {
- template.children.push(TEMPLATE_MAP[compo]);
- } else {
- rightWrapper.children.push(TEMPLATE_MAP[compo]);
- }
- });
- if (haveRightWrapper) {
- template.children.unshift(rightWrapper);
- }
- return template;
- },
- components: {
- Prev: {
- render: function render(h) {
- return h(
- 'button',
- {
- attrs: {
- type: 'button',
- disabled: this.$parent.disabled || this.$parent.internalCurrentPage <= 1
- },
- 'class': 'btn-prev', on: {
- 'click': this.$parent.prev
- }
- },
- [this.$parent.prevText ? h('span', [this.$parent.prevText]) : h('i', { 'class': 'el-icon el-icon-arrow-left' })]
- );
- }
- },
- Next: {
- render: function render(h) {
- return h(
- 'button',
- {
- attrs: {
- type: 'button',
- disabled: this.$parent.disabled || this.$parent.internalCurrentPage === this.$parent.internalPageCount || this.$parent.internalPageCount === 0
- },
- 'class': 'btn-next', on: {
- 'click': this.$parent.next
- }
- },
- [this.$parent.nextText ? h('span', [this.$parent.nextText]) : h('i', { 'class': 'el-icon el-icon-arrow-right' })]
- );
- }
- },
- Sizes: {
- mixins: [locale_default.a],
- props: {
- pageSizes: Array
- },
- watch: {
- pageSizes: {
- immediate: true,
- handler: function handler(newVal, oldVal) {
- if (Object(util_["valueEquals"])(newVal, oldVal)) return;
- if (Array.isArray(newVal)) {
- this.$parent.internalPageSize = newVal.indexOf(this.$parent.pageSize) > -1 ? this.$parent.pageSize : this.pageSizes[0];
- }
- }
- }
- },
- render: function render(h) {
- var _this = this;
- return h(
- 'span',
- { 'class': 'el-pagination__sizes' },
- [h(
- 'el-select',
- {
- attrs: {
- value: this.$parent.internalPageSize,
- popperClass: this.$parent.popperClass || '',
- size: 'mini',
- disabled: this.$parent.disabled },
- on: {
- 'input': this.handleChange
- }
- },
- [this.pageSizes.map(function (item) {
- return h('el-option', {
- attrs: {
- value: item,
- label: item + _this.t('el.pagination.pagesize') }
- });
- })]
- )]
- );
- },
- components: {
- ElSelect: select_default.a,
- ElOption: option_default.a
- },
- methods: {
- handleChange: function handleChange(val) {
- if (val !== this.$parent.internalPageSize) {
- this.$parent.internalPageSize = val = parseInt(val, 10);
- this.$parent.userChangePageSize = true;
- this.$parent.$emit('update:pageSize', val);
- this.$parent.$emit('size-change', val);
- }
- }
- }
- },
- Jumper: {
- mixins: [locale_default.a],
- components: { ElInput: input_default.a },
- data: function data() {
- return {
- userInput: null
- };
- },
- watch: {
- '$parent.internalCurrentPage': function $parentInternalCurrentPage() {
- this.userInput = null;
- }
- },
- methods: {
- handleKeyup: function handleKeyup(_ref) {
- var keyCode = _ref.keyCode,
- target = _ref.target;
- // Chrome, Safari, Firefox triggers change event on Enter
- // Hack for IE: https://github.com/ElemeFE/element/issues/11710
- // Drop this method when we no longer supports IE
- if (keyCode === 13) {
- this.handleChange(target.value);
- }
- },
- handleInput: function handleInput(value) {
- this.userInput = value;
- },
- handleChange: function handleChange(value) {
- this.$parent.internalCurrentPage = this.$parent.getValidCurrentPage(value);
- this.$parent.emitChange();
- this.userInput = null;
- }
- },
- render: function render(h) {
- return h(
- 'span',
- { 'class': 'el-pagination__jump' },
- [this.t('el.pagination.goto'), h('el-input', {
- 'class': 'el-pagination__editor is-in-pagination',
- attrs: { min: 1,
- max: this.$parent.internalPageCount,
- value: this.userInput !== null ? this.userInput : this.$parent.internalCurrentPage,
- type: 'number',
- disabled: this.$parent.disabled
- },
- nativeOn: {
- 'keyup': this.handleKeyup
- },
- on: {
- 'input': this.handleInput,
- 'change': this.handleChange
- }
- }), this.t('el.pagination.pageClassifier')]
- );
- }
- },
- Total: {
- mixins: [locale_default.a],
- render: function render(h) {
- return typeof this.$parent.total === 'number' ? h(
- 'span',
- { 'class': 'el-pagination__total' },
- [this.t('el.pagination.total', { total: this.$parent.total })]
- ) : '';
- }
- },
- Pager: pager
- },
- methods: {
- handleCurrentChange: function handleCurrentChange(val) {
- this.internalCurrentPage = this.getValidCurrentPage(val);
- this.userChangePageSize = true;
- this.emitChange();
- },
- prev: function prev() {
- if (this.disabled) return;
- var newVal = this.internalCurrentPage - 1;
- this.internalCurrentPage = this.getValidCurrentPage(newVal);
- this.$emit('prev-click', this.internalCurrentPage);
- this.emitChange();
- },
- next: function next() {
- if (this.disabled) return;
- var newVal = this.internalCurrentPage + 1;
- this.internalCurrentPage = this.getValidCurrentPage(newVal);
- this.$emit('next-click', this.internalCurrentPage);
- this.emitChange();
- },
- getValidCurrentPage: function getValidCurrentPage(value) {
- value = parseInt(value, 10);
- var havePageCount = typeof this.internalPageCount === 'number';
- var resetValue = void 0;
- if (!havePageCount) {
- if (isNaN(value) || value < 1) resetValue = 1;
- } else {
- if (value < 1) {
- resetValue = 1;
- } else if (value > this.internalPageCount) {
- resetValue = this.internalPageCount;
- }
- }
- if (resetValue === undefined && isNaN(value)) {
- resetValue = 1;
- } else if (resetValue === 0) {
- resetValue = 1;
- }
- return resetValue === undefined ? value : resetValue;
- },
- emitChange: function emitChange() {
- var _this2 = this;
- this.$nextTick(function () {
- if (_this2.internalCurrentPage !== _this2.lastEmittedPage || _this2.userChangePageSize) {
- _this2.$emit('current-change', _this2.internalCurrentPage);
- _this2.lastEmittedPage = _this2.internalCurrentPage;
- _this2.userChangePageSize = false;
- }
- });
- }
- },
- computed: {
- internalPageCount: function internalPageCount() {
- if (typeof this.total === 'number') {
- return Math.max(1, Math.ceil(this.total / this.internalPageSize));
- } else if (typeof this.pageCount === 'number') {
- return Math.max(1, this.pageCount);
- }
- return null;
- }
- },
- watch: {
- currentPage: {
- immediate: true,
- handler: function handler(val) {
- this.internalCurrentPage = this.getValidCurrentPage(val);
- }
- },
- pageSize: {
- immediate: true,
- handler: function handler(val) {
- this.internalPageSize = isNaN(val) ? 10 : val;
- }
- },
- internalCurrentPage: {
- immediate: true,
- handler: function handler(newVal) {
- this.$emit('update:currentPage', newVal);
- this.lastEmittedPage = -1;
- }
- },
- internalPageCount: function internalPageCount(newVal) {
- /* istanbul ignore if */
- var oldPage = this.internalCurrentPage;
- if (newVal > 0 && oldPage === 0) {
- this.internalCurrentPage = 1;
- } else if (oldPage > newVal) {
- this.internalCurrentPage = newVal === 0 ? 1 : newVal;
- this.userChangePageSize && this.emitChange();
- }
- this.userChangePageSize = false;
- }
- }
- });
- // CONCATENATED MODULE: ./packages/pagination/index.js
- /* istanbul ignore next */
- pagination.install = function (Vue) {
- Vue.component(pagination.name, pagination);
- };
- /* harmony default export */ var packages_pagination = (pagination);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dialog/src/component.vue?vue&type=template&id=60140e62&
- var componentvue_type_template_id_60140e62_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- {
- attrs: { name: "dialog-fade" },
- on: { "after-enter": _vm.afterEnter, "after-leave": _vm.afterLeave }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-dialog__wrapper",
- on: {
- click: function($event) {
- if ($event.target !== $event.currentTarget) {
- return null
- }
- return _vm.handleWrapperClick($event)
- }
- }
- },
- [
- _c(
- "div",
- {
- key: _vm.key,
- ref: "dialog",
- class: [
- "el-dialog",
- {
- "is-fullscreen": _vm.fullscreen,
- "el-dialog--center": _vm.center
- },
- _vm.customClass
- ],
- style: _vm.style,
- attrs: {
- role: "dialog",
- "aria-modal": "true",
- "aria-label": _vm.title || "dialog"
- }
- },
- [
- _c(
- "div",
- { staticClass: "el-dialog__header" },
- [
- _vm._t("title", [
- _c("span", { staticClass: "el-dialog__title" }, [
- _vm._v(_vm._s(_vm.title))
- ])
- ]),
- _vm.showClose
- ? _c(
- "button",
- {
- staticClass: "el-dialog__headerbtn",
- attrs: { type: "button", "aria-label": "Close" },
- on: { click: _vm.handleClose }
- },
- [
- _c("i", {
- staticClass:
- "el-dialog__close el-icon el-icon-close"
- })
- ]
- )
- : _vm._e()
- ],
- 2
- ),
- _vm.rendered
- ? _c(
- "div",
- { staticClass: "el-dialog__body" },
- [_vm._t("default")],
- 2
- )
- : _vm._e(),
- _vm.$slots.footer
- ? _c(
- "div",
- { staticClass: "el-dialog__footer" },
- [_vm._t("footer")],
- 2
- )
- : _vm._e()
- ]
- )
- ]
- )
- ]
- )
- }
- var componentvue_type_template_id_60140e62_staticRenderFns = []
- componentvue_type_template_id_60140e62_render._withStripped = true
- // CONCATENATED MODULE: ./packages/dialog/src/component.vue?vue&type=template&id=60140e62&
- // EXTERNAL MODULE: external "element-ui/lib/utils/popup"
- var popup_ = __webpack_require__(11);
- var popup_default = /*#__PURE__*/__webpack_require__.n(popup_);
- // EXTERNAL MODULE: external "element-ui/lib/mixins/migrating"
- var migrating_ = __webpack_require__(9);
- var migrating_default = /*#__PURE__*/__webpack_require__.n(migrating_);
- // EXTERNAL MODULE: external "element-ui/lib/mixins/emitter"
- var emitter_ = __webpack_require__(3);
- var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dialog/src/component.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var componentvue_type_script_lang_js_ = ({
- name: 'ElDialog',
- mixins: [popup_default.a, emitter_default.a, migrating_default.a],
- props: {
- title: {
- type: String,
- default: ''
- },
- modal: {
- type: Boolean,
- default: true
- },
- modalAppendToBody: {
- type: Boolean,
- default: true
- },
- appendToBody: {
- type: Boolean,
- default: false
- },
- lockScroll: {
- type: Boolean,
- default: true
- },
- closeOnClickModal: {
- type: Boolean,
- default: true
- },
- closeOnPressEscape: {
- type: Boolean,
- default: true
- },
- showClose: {
- type: Boolean,
- default: true
- },
- width: String,
- fullscreen: Boolean,
- customClass: {
- type: String,
- default: ''
- },
- top: {
- type: String,
- default: '15vh'
- },
- beforeClose: Function,
- center: {
- type: Boolean,
- default: false
- },
- destroyOnClose: Boolean
- },
- data: function data() {
- return {
- closed: false,
- key: 0
- };
- },
- watch: {
- visible: function visible(val) {
- var _this = this;
- if (val) {
- this.closed = false;
- this.$emit('open');
- this.$el.addEventListener('scroll', this.updatePopper);
- this.$nextTick(function () {
- _this.$refs.dialog.scrollTop = 0;
- });
- if (this.appendToBody) {
- document.body.appendChild(this.$el);
- }
- } else {
- this.$el.removeEventListener('scroll', this.updatePopper);
- if (!this.closed) this.$emit('close');
- if (this.destroyOnClose) {
- this.$nextTick(function () {
- _this.key++;
- });
- }
- }
- }
- },
- computed: {
- style: function style() {
- var style = {};
- if (!this.fullscreen) {
- style.marginTop = this.top;
- if (this.width) {
- style.width = this.width;
- }
- }
- return style;
- }
- },
- methods: {
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'size': 'size is removed.'
- }
- };
- },
- handleWrapperClick: function handleWrapperClick() {
- if (!this.closeOnClickModal) return;
- this.handleClose();
- },
- handleClose: function handleClose() {
- if (typeof this.beforeClose === 'function') {
- this.beforeClose(this.hide);
- } else {
- this.hide();
- }
- },
- hide: function hide(cancel) {
- if (cancel !== false) {
- this.$emit('update:visible', false);
- this.$emit('close');
- this.closed = true;
- }
- },
- updatePopper: function updatePopper() {
- this.broadcast('ElSelectDropdown', 'updatePopper');
- this.broadcast('ElDropdownMenu', 'updatePopper');
- },
- afterEnter: function afterEnter() {
- this.$emit('opened');
- },
- afterLeave: function afterLeave() {
- this.$emit('closed');
- }
- },
- mounted: function mounted() {
- if (this.visible) {
- this.rendered = true;
- this.open();
- if (this.appendToBody) {
- document.body.appendChild(this.$el);
- }
- }
- },
- destroyed: function destroyed() {
- // if appendToBody is true, remove DOM node after destroy
- if (this.appendToBody && this.$el && this.$el.parentNode) {
- this.$el.parentNode.removeChild(this.$el);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/dialog/src/component.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_componentvue_type_script_lang_js_ = (componentvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/dialog/src/component.vue
- /* normalize component */
- var component_component = normalizeComponent(
- src_componentvue_type_script_lang_js_,
- componentvue_type_template_id_60140e62_render,
- componentvue_type_template_id_60140e62_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var component_api; }
- component_component.options.__file = "packages/dialog/src/component.vue"
- /* harmony default export */ var src_component = (component_component.exports);
- // CONCATENATED MODULE: ./packages/dialog/index.js
- /* istanbul ignore next */
- src_component.install = function (Vue) {
- Vue.component(src_component.name, src_component);
- };
- /* harmony default export */ var dialog = (src_component);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete.vue?vue&type=template&id=152f2ee6&
- var autocompletevue_type_template_id_152f2ee6_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: _vm.close,
- expression: "close"
- }
- ],
- staticClass: "el-autocomplete",
- attrs: {
- "aria-haspopup": "listbox",
- role: "combobox",
- "aria-expanded": _vm.suggestionVisible,
- "aria-owns": _vm.id
- }
- },
- [
- _c(
- "el-input",
- _vm._b(
- {
- ref: "input",
- on: {
- input: _vm.handleInput,
- change: _vm.handleChange,
- focus: _vm.handleFocus,
- blur: _vm.handleBlur,
- clear: _vm.handleClear
- },
- nativeOn: {
- keydown: [
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "up", 38, $event.key, [
- "Up",
- "ArrowUp"
- ])
- ) {
- return null
- }
- $event.preventDefault()
- _vm.highlight(_vm.highlightedIndex - 1)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "down", 40, $event.key, [
- "Down",
- "ArrowDown"
- ])
- ) {
- return null
- }
- $event.preventDefault()
- _vm.highlight(_vm.highlightedIndex + 1)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")
- ) {
- return null
- }
- return _vm.handleKeyEnter($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "tab", 9, $event.key, "Tab")
- ) {
- return null
- }
- return _vm.close($event)
- }
- ]
- }
- },
- "el-input",
- [_vm.$props, _vm.$attrs],
- false
- ),
- [
- _vm.$slots.prepend
- ? _c("template", { slot: "prepend" }, [_vm._t("prepend")], 2)
- : _vm._e(),
- _vm.$slots.append
- ? _c("template", { slot: "append" }, [_vm._t("append")], 2)
- : _vm._e(),
- _vm.$slots.prefix
- ? _c("template", { slot: "prefix" }, [_vm._t("prefix")], 2)
- : _vm._e(),
- _vm.$slots.suffix
- ? _c("template", { slot: "suffix" }, [_vm._t("suffix")], 2)
- : _vm._e()
- ],
- 2
- ),
- _c(
- "el-autocomplete-suggestions",
- {
- ref: "suggestions",
- class: [_vm.popperClass ? _vm.popperClass : ""],
- attrs: {
- "visible-arrow": "",
- "popper-options": _vm.popperOptions,
- "append-to-body": _vm.popperAppendToBody,
- placement: _vm.placement,
- id: _vm.id
- }
- },
- _vm._l(_vm.suggestions, function(item, index) {
- return _c(
- "li",
- {
- key: index,
- class: { highlighted: _vm.highlightedIndex === index },
- attrs: {
- id: _vm.id + "-item-" + index,
- role: "option",
- "aria-selected": _vm.highlightedIndex === index
- },
- on: {
- click: function($event) {
- _vm.select(item)
- }
- }
- },
- [
- _vm._t(
- "default",
- [
- _vm._v("\n " + _vm._s(item[_vm.valueKey]) + "\n ")
- ],
- { item: item }
- )
- ],
- 2
- )
- }),
- 0
- )
- ],
- 1
- )
- }
- var autocompletevue_type_template_id_152f2ee6_staticRenderFns = []
- autocompletevue_type_template_id_152f2ee6_render._withStripped = true
- // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue?vue&type=template&id=152f2ee6&
- // EXTERNAL MODULE: external "throttle-debounce/debounce"
- var debounce_ = __webpack_require__(17);
- var debounce_default = /*#__PURE__*/__webpack_require__.n(debounce_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/clickoutside"
- var clickoutside_ = __webpack_require__(10);
- var clickoutside_default = /*#__PURE__*/__webpack_require__.n(clickoutside_);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=template&id=cd10dcf0&
- var autocomplete_suggestionsvue_type_template_id_cd10dcf0_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.showPopper,
- expression: "showPopper"
- }
- ],
- staticClass: "el-autocomplete-suggestion el-popper",
- class: {
- "is-loading": !_vm.parent.hideLoading && _vm.parent.loading
- },
- style: { width: _vm.dropdownWidth },
- attrs: { role: "region" }
- },
- [
- _c(
- "el-scrollbar",
- {
- attrs: {
- tag: "ul",
- "wrap-class": "el-autocomplete-suggestion__wrap",
- "view-class": "el-autocomplete-suggestion__list"
- }
- },
- [
- !_vm.parent.hideLoading && _vm.parent.loading
- ? _c("li", [_c("i", { staticClass: "el-icon-loading" })])
- : _vm._t("default")
- ],
- 2
- )
- ],
- 1
- )
- ]
- )
- }
- var autocomplete_suggestionsvue_type_template_id_cd10dcf0_staticRenderFns = []
- autocomplete_suggestionsvue_type_template_id_cd10dcf0_render._withStripped = true
- // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=template&id=cd10dcf0&
- // EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper"
- var vue_popper_ = __webpack_require__(5);
- var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_);
- // EXTERNAL MODULE: external "element-ui/lib/scrollbar"
- var scrollbar_ = __webpack_require__(18);
- var scrollbar_default = /*#__PURE__*/__webpack_require__.n(scrollbar_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var autocomplete_suggestionsvue_type_script_lang_js_ = ({
- components: { ElScrollbar: scrollbar_default.a },
- mixins: [vue_popper_default.a, emitter_default.a],
- componentName: 'ElAutocompleteSuggestions',
- data: function data() {
- return {
- parent: this.$parent,
- dropdownWidth: ''
- };
- },
- props: {
- options: {
- default: function _default() {
- return {
- gpuAcceleration: false
- };
- }
- },
- id: String
- },
- methods: {
- select: function select(item) {
- this.dispatch('ElAutocomplete', 'item-click', item);
- }
- },
- updated: function updated() {
- var _this = this;
- this.$nextTick(function (_) {
- _this.popperJS && _this.updatePopper();
- });
- },
- mounted: function mounted() {
- this.$parent.popperElm = this.popperElm = this.$el;
- this.referenceElm = this.$parent.$refs.input.$refs.input || this.$parent.$refs.input.$refs.textarea;
- this.referenceList = this.$el.querySelector('.el-autocomplete-suggestion__list');
- this.referenceList.setAttribute('role', 'listbox');
- this.referenceList.setAttribute('id', this.id);
- },
- created: function created() {
- var _this2 = this;
- this.$on('visible', function (val, inputWidth) {
- _this2.dropdownWidth = inputWidth + 'px';
- _this2.showPopper = val;
- });
- }
- });
- // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_autocomplete_suggestionsvue_type_script_lang_js_ = (autocomplete_suggestionsvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue
- /* normalize component */
- var autocomplete_suggestions_component = normalizeComponent(
- src_autocomplete_suggestionsvue_type_script_lang_js_,
- autocomplete_suggestionsvue_type_template_id_cd10dcf0_render,
- autocomplete_suggestionsvue_type_template_id_cd10dcf0_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var autocomplete_suggestions_api; }
- autocomplete_suggestions_component.options.__file = "packages/autocomplete/src/autocomplete-suggestions.vue"
- /* harmony default export */ var autocomplete_suggestions = (autocomplete_suggestions_component.exports);
- // EXTERNAL MODULE: external "element-ui/lib/mixins/focus"
- var focus_ = __webpack_require__(23);
- var focus_default = /*#__PURE__*/__webpack_require__.n(focus_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var autocompletevue_type_script_lang_js_ = ({
- name: 'ElAutocomplete',
- mixins: [emitter_default.a, focus_default()('input'), migrating_default.a],
- inheritAttrs: false,
- componentName: 'ElAutocomplete',
- components: {
- ElInput: input_default.a,
- ElAutocompleteSuggestions: autocomplete_suggestions
- },
- directives: { Clickoutside: clickoutside_default.a },
- props: {
- valueKey: {
- type: String,
- default: 'value'
- },
- popperClass: String,
- popperOptions: Object,
- placeholder: String,
- clearable: {
- type: Boolean,
- default: false
- },
- disabled: Boolean,
- name: String,
- size: String,
- value: String,
- maxlength: Number,
- minlength: Number,
- autofocus: Boolean,
- fetchSuggestions: Function,
- triggerOnFocus: {
- type: Boolean,
- default: true
- },
- customItem: String,
- selectWhenUnmatched: {
- type: Boolean,
- default: false
- },
- prefixIcon: String,
- suffixIcon: String,
- label: String,
- debounce: {
- type: Number,
- default: 300
- },
- placement: {
- type: String,
- default: 'bottom-start'
- },
- hideLoading: Boolean,
- popperAppendToBody: {
- type: Boolean,
- default: true
- },
- highlightFirstItem: {
- type: Boolean,
- default: false
- }
- },
- data: function data() {
- return {
- activated: false,
- suggestions: [],
- loading: false,
- highlightedIndex: -1,
- suggestionDisabled: false
- };
- },
- computed: {
- suggestionVisible: function suggestionVisible() {
- var suggestions = this.suggestions;
- var isValidData = Array.isArray(suggestions) && suggestions.length > 0;
- return (isValidData || this.loading) && this.activated;
- },
- id: function id() {
- return 'el-autocomplete-' + Object(util_["generateId"])();
- }
- },
- watch: {
- suggestionVisible: function suggestionVisible(val) {
- var $input = this.getInput();
- if ($input) {
- this.broadcast('ElAutocompleteSuggestions', 'visible', [val, $input.offsetWidth]);
- }
- }
- },
- methods: {
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'custom-item': 'custom-item is removed, use scoped slot instead.',
- 'props': 'props is removed, use value-key instead.'
- }
- };
- },
- getData: function getData(queryString) {
- var _this = this;
- if (this.suggestionDisabled) {
- return;
- }
- this.loading = true;
- this.fetchSuggestions(queryString, function (suggestions) {
- _this.loading = false;
- if (_this.suggestionDisabled) {
- return;
- }
- if (Array.isArray(suggestions)) {
- _this.suggestions = suggestions;
- _this.highlightedIndex = _this.highlightFirstItem ? 0 : -1;
- } else {
- console.error('[Element Error][Autocomplete]autocomplete suggestions must be an array');
- }
- });
- },
- handleInput: function handleInput(value) {
- this.$emit('input', value);
- this.suggestionDisabled = false;
- if (!this.triggerOnFocus && !value) {
- this.suggestionDisabled = true;
- this.suggestions = [];
- return;
- }
- this.debouncedGetData(value);
- },
- handleChange: function handleChange(value) {
- this.$emit('change', value);
- },
- handleFocus: function handleFocus(event) {
- this.activated = true;
- this.$emit('focus', event);
- if (this.triggerOnFocus) {
- this.debouncedGetData(this.value);
- }
- },
- handleBlur: function handleBlur(event) {
- this.$emit('blur', event);
- },
- handleClear: function handleClear() {
- this.activated = false;
- this.$emit('clear');
- },
- close: function close(e) {
- this.activated = false;
- },
- handleKeyEnter: function handleKeyEnter(e) {
- var _this2 = this;
- if (this.suggestionVisible && this.highlightedIndex >= 0 && this.highlightedIndex < this.suggestions.length) {
- e.preventDefault();
- this.select(this.suggestions[this.highlightedIndex]);
- } else if (this.selectWhenUnmatched) {
- this.$emit('select', { value: this.value });
- this.$nextTick(function (_) {
- _this2.suggestions = [];
- _this2.highlightedIndex = -1;
- });
- }
- },
- select: function select(item) {
- var _this3 = this;
- this.$emit('input', item[this.valueKey]);
- this.$emit('select', item);
- this.$nextTick(function (_) {
- _this3.suggestions = [];
- _this3.highlightedIndex = -1;
- });
- },
- highlight: function highlight(index) {
- if (!this.suggestionVisible || this.loading) {
- return;
- }
- if (index < 0) {
- this.highlightedIndex = -1;
- return;
- }
- if (index >= this.suggestions.length) {
- index = this.suggestions.length - 1;
- }
- var suggestion = this.$refs.suggestions.$el.querySelector('.el-autocomplete-suggestion__wrap');
- var suggestionList = suggestion.querySelectorAll('.el-autocomplete-suggestion__list li');
- var highlightItem = suggestionList[index];
- var scrollTop = suggestion.scrollTop;
- var offsetTop = highlightItem.offsetTop;
- if (offsetTop + highlightItem.scrollHeight > scrollTop + suggestion.clientHeight) {
- suggestion.scrollTop += highlightItem.scrollHeight;
- }
- if (offsetTop < scrollTop) {
- suggestion.scrollTop -= highlightItem.scrollHeight;
- }
- this.highlightedIndex = index;
- var $input = this.getInput();
- $input.setAttribute('aria-activedescendant', this.id + '-item-' + this.highlightedIndex);
- },
- getInput: function getInput() {
- return this.$refs.input.getInput();
- }
- },
- mounted: function mounted() {
- var _this4 = this;
- this.debouncedGetData = debounce_default()(this.debounce, this.getData);
- this.$on('item-click', function (item) {
- _this4.select(item);
- });
- var $input = this.getInput();
- $input.setAttribute('role', 'textbox');
- $input.setAttribute('aria-autocomplete', 'list');
- $input.setAttribute('aria-controls', 'id');
- $input.setAttribute('aria-activedescendant', this.id + '-item-' + this.highlightedIndex);
- },
- beforeDestroy: function beforeDestroy() {
- this.$refs.suggestions.$destroy();
- }
- });
- // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_autocompletevue_type_script_lang_js_ = (autocompletevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue
- /* normalize component */
- var autocomplete_component = normalizeComponent(
- src_autocompletevue_type_script_lang_js_,
- autocompletevue_type_template_id_152f2ee6_render,
- autocompletevue_type_template_id_152f2ee6_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var autocomplete_api; }
- autocomplete_component.options.__file = "packages/autocomplete/src/autocomplete.vue"
- /* harmony default export */ var autocomplete = (autocomplete_component.exports);
- // CONCATENATED MODULE: ./packages/autocomplete/index.js
- /* istanbul ignore next */
- autocomplete.install = function (Vue) {
- Vue.component(autocomplete.name, autocomplete);
- };
- /* harmony default export */ var packages_autocomplete = (autocomplete);
- // EXTERNAL MODULE: external "element-ui/lib/button"
- var button_ = __webpack_require__(13);
- var button_default = /*#__PURE__*/__webpack_require__.n(button_);
- // EXTERNAL MODULE: external "element-ui/lib/button-group"
- var button_group_ = __webpack_require__(29);
- var button_group_default = /*#__PURE__*/__webpack_require__.n(button_group_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown.vue?vue&type=script&lang=js&
- /* harmony default export */ var dropdownvue_type_script_lang_js_ = ({
- name: 'ElDropdown',
- componentName: 'ElDropdown',
- mixins: [emitter_default.a, migrating_default.a],
- directives: { Clickoutside: clickoutside_default.a },
- components: {
- ElButton: button_default.a,
- ElButtonGroup: button_group_default.a
- },
- provide: function provide() {
- return {
- dropdown: this
- };
- },
- props: {
- trigger: {
- type: String,
- default: 'hover'
- },
- type: String,
- size: {
- type: String,
- default: ''
- },
- splitButton: Boolean,
- hideOnClick: {
- type: Boolean,
- default: true
- },
- placement: {
- type: String,
- default: 'bottom-end'
- },
- visibleArrow: {
- default: true
- },
- showTimeout: {
- type: Number,
- default: 250
- },
- hideTimeout: {
- type: Number,
- default: 150
- },
- tabindex: {
- type: Number,
- default: 0
- },
- disabled: {
- type: Boolean,
- default: false
- }
- },
- data: function data() {
- return {
- timeout: null,
- visible: false,
- triggerElm: null,
- menuItems: null,
- menuItemsArray: null,
- dropdownElm: null,
- focusing: false,
- listId: 'dropdown-menu-' + Object(util_["generateId"])()
- };
- },
- computed: {
- dropdownSize: function dropdownSize() {
- return this.size || (this.$ELEMENT || {}).size;
- }
- },
- mounted: function mounted() {
- this.$on('menu-item-click', this.handleMenuItemClick);
- },
- watch: {
- visible: function visible(val) {
- this.broadcast('ElDropdownMenu', 'visible', val);
- this.$emit('visible-change', val);
- },
- focusing: function focusing(val) {
- var selfDefine = this.$el.querySelector('.el-dropdown-selfdefine');
- if (selfDefine) {
- // 自定义
- if (val) {
- selfDefine.className += ' focusing';
- } else {
- selfDefine.className = selfDefine.className.replace('focusing', '');
- }
- }
- }
- },
- methods: {
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'menu-align': 'menu-align is renamed to placement.'
- }
- };
- },
- show: function show() {
- var _this = this;
- if (this.disabled) return;
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- _this.visible = true;
- }, this.trigger === 'click' ? 0 : this.showTimeout);
- },
- hide: function hide() {
- var _this2 = this;
- if (this.disabled) return;
- this.removeTabindex();
- if (this.tabindex >= 0) {
- this.resetTabindex(this.triggerElm);
- }
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- _this2.visible = false;
- }, this.trigger === 'click' ? 0 : this.hideTimeout);
- },
- handleClick: function handleClick() {
- if (this.disabled) return;
- if (this.visible) {
- this.hide();
- } else {
- this.show();
- }
- },
- handleTriggerKeyDown: function handleTriggerKeyDown(ev) {
- var keyCode = ev.keyCode;
- if ([38, 40].indexOf(keyCode) > -1) {
- // up/down
- this.removeTabindex();
- this.resetTabindex(this.menuItems[0]);
- this.menuItems[0].focus();
- ev.preventDefault();
- ev.stopPropagation();
- } else if (keyCode === 13) {
- // space enter选中
- this.handleClick();
- } else if ([9, 27].indexOf(keyCode) > -1) {
- // tab || esc
- this.hide();
- }
- },
- handleItemKeyDown: function handleItemKeyDown(ev) {
- var keyCode = ev.keyCode;
- var target = ev.target;
- var currentIndex = this.menuItemsArray.indexOf(target);
- var max = this.menuItemsArray.length - 1;
- var nextIndex = void 0;
- if ([38, 40].indexOf(keyCode) > -1) {
- // up/down
- if (keyCode === 38) {
- // up
- nextIndex = currentIndex !== 0 ? currentIndex - 1 : 0;
- } else {
- // down
- nextIndex = currentIndex < max ? currentIndex + 1 : max;
- }
- this.removeTabindex();
- this.resetTabindex(this.menuItems[nextIndex]);
- this.menuItems[nextIndex].focus();
- ev.preventDefault();
- ev.stopPropagation();
- } else if (keyCode === 13) {
- // enter选中
- this.triggerElmFocus();
- target.click();
- if (this.hideOnClick) {
- // click关闭
- this.visible = false;
- }
- } else if ([9, 27].indexOf(keyCode) > -1) {
- // tab // esc
- this.hide();
- this.triggerElmFocus();
- }
- },
- resetTabindex: function resetTabindex(ele) {
- // 下次tab时组件聚焦元素
- this.removeTabindex();
- ele.setAttribute('tabindex', '0'); // 下次期望的聚焦元素
- },
- removeTabindex: function removeTabindex() {
- this.triggerElm.setAttribute('tabindex', '-1');
- this.menuItemsArray.forEach(function (item) {
- item.setAttribute('tabindex', '-1');
- });
- },
- initAria: function initAria() {
- this.dropdownElm.setAttribute('id', this.listId);
- this.triggerElm.setAttribute('aria-haspopup', 'list');
- this.triggerElm.setAttribute('aria-controls', this.listId);
- if (!this.splitButton) {
- // 自定义
- this.triggerElm.setAttribute('role', 'button');
- this.triggerElm.setAttribute('tabindex', this.tabindex);
- this.triggerElm.setAttribute('class', (this.triggerElm.getAttribute('class') || '') + ' el-dropdown-selfdefine'); // 控制
- }
- },
- initEvent: function initEvent() {
- var _this3 = this;
- var trigger = this.trigger,
- show = this.show,
- hide = this.hide,
- handleClick = this.handleClick,
- splitButton = this.splitButton,
- handleTriggerKeyDown = this.handleTriggerKeyDown,
- handleItemKeyDown = this.handleItemKeyDown;
- this.triggerElm = splitButton ? this.$refs.trigger.$el : this.$slots.default[0].elm;
- var dropdownElm = this.dropdownElm;
- this.triggerElm.addEventListener('keydown', handleTriggerKeyDown); // triggerElm keydown
- dropdownElm.addEventListener('keydown', handleItemKeyDown, true); // item keydown
- // 控制自定义元素的样式
- if (!splitButton) {
- this.triggerElm.addEventListener('focus', function () {
- _this3.focusing = true;
- });
- this.triggerElm.addEventListener('blur', function () {
- _this3.focusing = false;
- });
- this.triggerElm.addEventListener('click', function () {
- _this3.focusing = false;
- });
- }
- if (trigger === 'hover') {
- this.triggerElm.addEventListener('mouseenter', show);
- this.triggerElm.addEventListener('mouseleave', hide);
- dropdownElm.addEventListener('mouseenter', show);
- dropdownElm.addEventListener('mouseleave', hide);
- } else if (trigger === 'click') {
- this.triggerElm.addEventListener('click', handleClick);
- }
- },
- handleMenuItemClick: function handleMenuItemClick(command, instance) {
- if (this.hideOnClick) {
- this.visible = false;
- }
- this.$emit('command', command, instance);
- },
- triggerElmFocus: function triggerElmFocus() {
- this.triggerElm.focus && this.triggerElm.focus();
- },
- initDomOperation: function initDomOperation() {
- this.dropdownElm = this.popperElm;
- this.menuItems = this.dropdownElm.querySelectorAll("[tabindex='-1']");
- this.menuItemsArray = [].slice.call(this.menuItems);
- this.initEvent();
- this.initAria();
- }
- },
- render: function render(h) {
- var _this4 = this;
- var hide = this.hide,
- splitButton = this.splitButton,
- type = this.type,
- dropdownSize = this.dropdownSize,
- disabled = this.disabled;
- var handleMainButtonClick = function handleMainButtonClick(event) {
- _this4.$emit('click', event);
- hide();
- };
- var triggerElm = null;
- if (splitButton) {
- triggerElm = h('el-button-group', [h(
- 'el-button',
- {
- attrs: { type: type, size: dropdownSize, disabled: disabled },
- nativeOn: {
- 'click': handleMainButtonClick
- }
- },
- [this.$slots.default]
- ), h(
- 'el-button',
- { ref: 'trigger', attrs: { type: type, size: dropdownSize, disabled: disabled },
- 'class': 'el-dropdown__caret-button' },
- [h('i', { 'class': 'el-dropdown__icon el-icon-arrow-down' })]
- )]);
- } else {
- triggerElm = this.$slots.default;
- var vnodeData = triggerElm[0].data || {};
- var _vnodeData$attrs = vnodeData.attrs,
- attrs = _vnodeData$attrs === undefined ? {} : _vnodeData$attrs;
- if (disabled && !attrs.disabled) {
- attrs.disabled = true;
- vnodeData.attrs = attrs;
- }
- }
- var menuElm = disabled ? null : this.$slots.dropdown;
- return h(
- 'div',
- { 'class': 'el-dropdown', directives: [{
- name: 'clickoutside',
- value: hide
- }],
- attrs: { 'aria-disabled': disabled }
- },
- [triggerElm, menuElm]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/dropdown/src/dropdown.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_dropdownvue_type_script_lang_js_ = (dropdownvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/dropdown/src/dropdown.vue
- var dropdown_render, dropdown_staticRenderFns
- /* normalize component */
- var dropdown_component = normalizeComponent(
- src_dropdownvue_type_script_lang_js_,
- dropdown_render,
- dropdown_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var dropdown_api; }
- dropdown_component.options.__file = "packages/dropdown/src/dropdown.vue"
- /* harmony default export */ var dropdown = (dropdown_component.exports);
- // CONCATENATED MODULE: ./packages/dropdown/index.js
- /* istanbul ignore next */
- dropdown.install = function (Vue) {
- Vue.component(dropdown.name, dropdown);
- };
- /* harmony default export */ var packages_dropdown = (dropdown);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=0da6b714&
- var dropdown_menuvue_type_template_id_0da6b714_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } },
- [
- _c(
- "ul",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.showPopper,
- expression: "showPopper"
- }
- ],
- staticClass: "el-dropdown-menu el-popper",
- class: [_vm.size && "el-dropdown-menu--" + _vm.size]
- },
- [_vm._t("default")],
- 2
- )
- ]
- )
- }
- var dropdown_menuvue_type_template_id_0da6b714_staticRenderFns = []
- dropdown_menuvue_type_template_id_0da6b714_render._withStripped = true
- // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=0da6b714&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var dropdown_menuvue_type_script_lang_js_ = ({
- name: 'ElDropdownMenu',
- componentName: 'ElDropdownMenu',
- mixins: [vue_popper_default.a],
- props: {
- visibleArrow: {
- type: Boolean,
- default: true
- },
- arrowOffset: {
- type: Number,
- default: 0
- }
- },
- data: function data() {
- return {
- size: this.dropdown.dropdownSize
- };
- },
- inject: ['dropdown'],
- created: function created() {
- var _this = this;
- this.$on('updatePopper', function () {
- if (_this.showPopper) _this.updatePopper();
- });
- this.$on('visible', function (val) {
- _this.showPopper = val;
- });
- },
- mounted: function mounted() {
- this.dropdown.popperElm = this.popperElm = this.$el;
- this.referenceElm = this.dropdown.$el;
- // compatible with 2.6 new v-slot syntax
- // issue link https://github.com/ElemeFE/element/issues/14345
- this.dropdown.initDomOperation();
- },
- watch: {
- 'dropdown.placement': {
- immediate: true,
- handler: function handler(val) {
- this.currentPlacement = val;
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_dropdown_menuvue_type_script_lang_js_ = (dropdown_menuvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue
- /* normalize component */
- var dropdown_menu_component = normalizeComponent(
- src_dropdown_menuvue_type_script_lang_js_,
- dropdown_menuvue_type_template_id_0da6b714_render,
- dropdown_menuvue_type_template_id_0da6b714_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var dropdown_menu_api; }
- dropdown_menu_component.options.__file = "packages/dropdown/src/dropdown-menu.vue"
- /* harmony default export */ var dropdown_menu = (dropdown_menu_component.exports);
- // CONCATENATED MODULE: ./packages/dropdown-menu/index.js
- /* istanbul ignore next */
- dropdown_menu.install = function (Vue) {
- Vue.component(dropdown_menu.name, dropdown_menu);
- };
- /* harmony default export */ var packages_dropdown_menu = (dropdown_menu);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-item.vue?vue&type=template&id=6359102a&
- var dropdown_itemvue_type_template_id_6359102a_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "li",
- {
- staticClass: "el-dropdown-menu__item",
- class: {
- "is-disabled": _vm.disabled,
- "el-dropdown-menu__item--divided": _vm.divided
- },
- attrs: {
- "aria-disabled": _vm.disabled,
- tabindex: _vm.disabled ? null : -1
- },
- on: { click: _vm.handleClick }
- },
- [_vm.icon ? _c("i", { class: _vm.icon }) : _vm._e(), _vm._t("default")],
- 2
- )
- }
- var dropdown_itemvue_type_template_id_6359102a_staticRenderFns = []
- dropdown_itemvue_type_template_id_6359102a_render._withStripped = true
- // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue?vue&type=template&id=6359102a&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-item.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var dropdown_itemvue_type_script_lang_js_ = ({
- name: 'ElDropdownItem',
- mixins: [emitter_default.a],
- props: {
- command: {},
- disabled: Boolean,
- divided: Boolean,
- icon: String
- },
- methods: {
- handleClick: function handleClick(e) {
- this.dispatch('ElDropdown', 'menu-item-click', [this.command, this]);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_dropdown_itemvue_type_script_lang_js_ = (dropdown_itemvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue
- /* normalize component */
- var dropdown_item_component = normalizeComponent(
- src_dropdown_itemvue_type_script_lang_js_,
- dropdown_itemvue_type_template_id_6359102a_render,
- dropdown_itemvue_type_template_id_6359102a_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var dropdown_item_api; }
- dropdown_item_component.options.__file = "packages/dropdown/src/dropdown-item.vue"
- /* harmony default export */ var dropdown_item = (dropdown_item_component.exports);
- // CONCATENATED MODULE: ./packages/dropdown-item/index.js
- /* istanbul ignore next */
- dropdown_item.install = function (Vue) {
- Vue.component(dropdown_item.name, dropdown_item);
- };
- /* harmony default export */ var packages_dropdown_item = (dropdown_item);
- // CONCATENATED MODULE: ./src/utils/aria-utils.js
- var aria = aria || {};
- aria.Utils = aria.Utils || {};
- /**
- * @desc Set focus on descendant nodes until the first focusable element is
- * found.
- * @param element
- * DOM node for which to find the first focusable descendant.
- * @returns
- * true if a focusable element is found and focus is set.
- */
- aria.Utils.focusFirstDescendant = function (element) {
- for (var i = 0; i < element.childNodes.length; i++) {
- var child = element.childNodes[i];
- if (aria.Utils.attemptFocus(child) || aria.Utils.focusFirstDescendant(child)) {
- return true;
- }
- }
- return false;
- };
- /**
- * @desc Find the last descendant node that is focusable.
- * @param element
- * DOM node for which to find the last focusable descendant.
- * @returns
- * true if a focusable element is found and focus is set.
- */
- aria.Utils.focusLastDescendant = function (element) {
- for (var i = element.childNodes.length - 1; i >= 0; i--) {
- var child = element.childNodes[i];
- if (aria.Utils.attemptFocus(child) || aria.Utils.focusLastDescendant(child)) {
- return true;
- }
- }
- return false;
- };
- /**
- * @desc Set Attempt to set focus on the current node.
- * @param element
- * The node to attempt to focus on.
- * @returns
- * true if element is focused.
- */
- aria.Utils.attemptFocus = function (element) {
- if (!aria.Utils.isFocusable(element)) {
- return false;
- }
- aria.Utils.IgnoreUtilFocusChanges = true;
- try {
- element.focus();
- } catch (e) {}
- aria.Utils.IgnoreUtilFocusChanges = false;
- return document.activeElement === element;
- };
- aria.Utils.isFocusable = function (element) {
- if (element.tabIndex > 0 || element.tabIndex === 0 && element.getAttribute('tabIndex') !== null) {
- return true;
- }
- if (element.disabled) {
- return false;
- }
- switch (element.nodeName) {
- case 'A':
- return !!element.href && element.rel !== 'ignore';
- case 'INPUT':
- return element.type !== 'hidden' && element.type !== 'file';
- case 'BUTTON':
- case 'SELECT':
- case 'TEXTAREA':
- return true;
- default:
- return false;
- }
- };
- /**
- * 触发一个事件
- * mouseenter, mouseleave, mouseover, keyup, change, click 等
- * @param {Element} elm
- * @param {String} name
- * @param {*} opts
- */
- aria.Utils.triggerEvent = function (elm, name) {
- var eventName = void 0;
- if (/^mouse|click/.test(name)) {
- eventName = 'MouseEvents';
- } else if (/^key/.test(name)) {
- eventName = 'KeyboardEvent';
- } else {
- eventName = 'HTMLEvents';
- }
- var evt = document.createEvent(eventName);
- for (var _len = arguments.length, opts = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {
- opts[_key - 2] = arguments[_key];
- }
- evt.initEvent.apply(evt, [name].concat(opts));
- elm.dispatchEvent ? elm.dispatchEvent(evt) : elm.fireEvent('on' + name, evt);
- return elm;
- };
- aria.Utils.keys = {
- tab: 9,
- enter: 13,
- space: 32,
- left: 37,
- up: 38,
- right: 39,
- down: 40,
- esc: 27
- };
- /* harmony default export */ var aria_utils = (aria.Utils);
- // CONCATENATED MODULE: ./src/utils/menu/aria-submenu.js
- var SubMenu = function SubMenu(parent, domNode) {
- this.domNode = domNode;
- this.parent = parent;
- this.subMenuItems = [];
- this.subIndex = 0;
- this.init();
- };
- SubMenu.prototype.init = function () {
- this.subMenuItems = this.domNode.querySelectorAll('li');
- this.addListeners();
- };
- SubMenu.prototype.gotoSubIndex = function (idx) {
- if (idx === this.subMenuItems.length) {
- idx = 0;
- } else if (idx < 0) {
- idx = this.subMenuItems.length - 1;
- }
- this.subMenuItems[idx].focus();
- this.subIndex = idx;
- };
- SubMenu.prototype.addListeners = function () {
- var _this = this;
- var keys = aria_utils.keys;
- var parentNode = this.parent.domNode;
- Array.prototype.forEach.call(this.subMenuItems, function (el) {
- el.addEventListener('keydown', function (event) {
- var prevDef = false;
- switch (event.keyCode) {
- case keys.down:
- _this.gotoSubIndex(_this.subIndex + 1);
- prevDef = true;
- break;
- case keys.up:
- _this.gotoSubIndex(_this.subIndex - 1);
- prevDef = true;
- break;
- case keys.tab:
- aria_utils.triggerEvent(parentNode, 'mouseleave');
- break;
- case keys.enter:
- case keys.space:
- prevDef = true;
- event.currentTarget.click();
- break;
- }
- if (prevDef) {
- event.preventDefault();
- event.stopPropagation();
- }
- return false;
- });
- });
- };
- /* harmony default export */ var aria_submenu = (SubMenu);
- // CONCATENATED MODULE: ./src/utils/menu/aria-menuitem.js
- var MenuItem = function MenuItem(domNode) {
- this.domNode = domNode;
- this.submenu = null;
- this.init();
- };
- MenuItem.prototype.init = function () {
- this.domNode.setAttribute('tabindex', '0');
- var menuChild = this.domNode.querySelector('.el-menu');
- if (menuChild) {
- this.submenu = new aria_submenu(this, menuChild);
- }
- this.addListeners();
- };
- MenuItem.prototype.addListeners = function () {
- var _this = this;
- var keys = aria_utils.keys;
- this.domNode.addEventListener('keydown', function (event) {
- var prevDef = false;
- switch (event.keyCode) {
- case keys.down:
- aria_utils.triggerEvent(event.currentTarget, 'mouseenter');
- _this.submenu && _this.submenu.gotoSubIndex(0);
- prevDef = true;
- break;
- case keys.up:
- aria_utils.triggerEvent(event.currentTarget, 'mouseenter');
- _this.submenu && _this.submenu.gotoSubIndex(_this.submenu.subMenuItems.length - 1);
- prevDef = true;
- break;
- case keys.tab:
- aria_utils.triggerEvent(event.currentTarget, 'mouseleave');
- break;
- case keys.enter:
- case keys.space:
- prevDef = true;
- event.currentTarget.click();
- break;
- }
- if (prevDef) {
- event.preventDefault();
- }
- });
- };
- /* harmony default export */ var aria_menuitem = (MenuItem);
- // CONCATENATED MODULE: ./src/utils/menu/aria-menubar.js
- var Menu = function Menu(domNode) {
- this.domNode = domNode;
- this.init();
- };
- Menu.prototype.init = function () {
- var menuChildren = this.domNode.childNodes;
- [].filter.call(menuChildren, function (child) {
- return child.nodeType === 1;
- }).forEach(function (child) {
- new aria_menuitem(child); // eslint-disable-line
- });
- };
- /* harmony default export */ var aria_menubar = (Menu);
- // EXTERNAL MODULE: external "element-ui/lib/utils/dom"
- var dom_ = __webpack_require__(1);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu.vue?vue&type=script&lang=js&
- /* harmony default export */ var menuvue_type_script_lang_js_ = ({
- name: 'ElMenu',
- render: function render(h) {
- var component = h(
- 'ul',
- {
- attrs: {
- role: 'menubar'
- },
- key: +this.collapse,
- style: { backgroundColor: this.backgroundColor || '' },
- 'class': {
- 'el-menu--horizontal': this.mode === 'horizontal',
- 'el-menu--collapse': this.collapse,
- "el-menu": true
- }
- },
- [this.$slots.default]
- );
- if (this.collapseTransition) {
- return h('el-menu-collapse-transition', [component]);
- } else {
- return component;
- }
- },
- componentName: 'ElMenu',
- mixins: [emitter_default.a, migrating_default.a],
- provide: function provide() {
- return {
- rootMenu: this
- };
- },
- components: {
- 'el-menu-collapse-transition': {
- functional: true,
- render: function render(createElement, context) {
- var data = {
- props: {
- mode: 'out-in'
- },
- on: {
- beforeEnter: function beforeEnter(el) {
- el.style.opacity = 0.2;
- },
- enter: function enter(el) {
- Object(dom_["addClass"])(el, 'el-opacity-transition');
- el.style.opacity = 1;
- },
- afterEnter: function afterEnter(el) {
- Object(dom_["removeClass"])(el, 'el-opacity-transition');
- el.style.opacity = '';
- },
- beforeLeave: function beforeLeave(el) {
- if (!el.dataset) el.dataset = {};
- if (Object(dom_["hasClass"])(el, 'el-menu--collapse')) {
- Object(dom_["removeClass"])(el, 'el-menu--collapse');
- el.dataset.oldOverflow = el.style.overflow;
- el.dataset.scrollWidth = el.clientWidth;
- Object(dom_["addClass"])(el, 'el-menu--collapse');
- } else {
- Object(dom_["addClass"])(el, 'el-menu--collapse');
- el.dataset.oldOverflow = el.style.overflow;
- el.dataset.scrollWidth = el.clientWidth;
- Object(dom_["removeClass"])(el, 'el-menu--collapse');
- }
- el.style.width = el.scrollWidth + 'px';
- el.style.overflow = 'hidden';
- },
- leave: function leave(el) {
- Object(dom_["addClass"])(el, 'horizontal-collapse-transition');
- el.style.width = el.dataset.scrollWidth + 'px';
- }
- }
- };
- return createElement('transition', data, context.children);
- }
- }
- },
- props: {
- mode: {
- type: String,
- default: 'vertical'
- },
- defaultActive: {
- type: String,
- default: ''
- },
- defaultOpeneds: Array,
- uniqueOpened: Boolean,
- router: Boolean,
- menuTrigger: {
- type: String,
- default: 'hover'
- },
- collapse: Boolean,
- backgroundColor: String,
- textColor: String,
- activeTextColor: String,
- collapseTransition: {
- type: Boolean,
- default: true
- }
- },
- data: function data() {
- return {
- activeIndex: this.defaultActive,
- openedMenus: this.defaultOpeneds && !this.collapse ? this.defaultOpeneds.slice(0) : [],
- items: {},
- submenus: {}
- };
- },
- computed: {
- hoverBackground: function hoverBackground() {
- return this.backgroundColor ? this.mixColor(this.backgroundColor, 0.2) : '';
- },
- isMenuPopup: function isMenuPopup() {
- return this.mode === 'horizontal' || this.mode === 'vertical' && this.collapse;
- }
- },
- watch: {
- defaultActive: function defaultActive(value) {
- if (!this.items[value]) {
- this.activeIndex = null;
- }
- this.updateActiveIndex(value);
- },
- defaultOpeneds: function defaultOpeneds(value) {
- if (!this.collapse) {
- this.openedMenus = value;
- }
- },
- collapse: function collapse(value) {
- if (value) this.openedMenus = [];
- this.broadcast('ElSubmenu', 'toggle-collapse', value);
- }
- },
- methods: {
- updateActiveIndex: function updateActiveIndex(val) {
- var item = this.items[val] || this.items[this.activeIndex] || this.items[this.defaultActive];
- if (item) {
- this.activeIndex = item.index;
- this.initOpenedMenu();
- } else {
- this.activeIndex = null;
- }
- },
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'theme': 'theme is removed.'
- }
- };
- },
- getColorChannels: function getColorChannels(color) {
- color = color.replace('#', '');
- if (/^[0-9a-fA-F]{3}$/.test(color)) {
- color = color.split('');
- for (var i = 2; i >= 0; i--) {
- color.splice(i, 0, color[i]);
- }
- color = color.join('');
- }
- if (/^[0-9a-fA-F]{6}$/.test(color)) {
- return {
- red: parseInt(color.slice(0, 2), 16),
- green: parseInt(color.slice(2, 4), 16),
- blue: parseInt(color.slice(4, 6), 16)
- };
- } else {
- return {
- red: 255,
- green: 255,
- blue: 255
- };
- }
- },
- mixColor: function mixColor(color, percent) {
- var _getColorChannels = this.getColorChannels(color),
- red = _getColorChannels.red,
- green = _getColorChannels.green,
- blue = _getColorChannels.blue;
- if (percent > 0) {
- // shade given color
- red *= 1 - percent;
- green *= 1 - percent;
- blue *= 1 - percent;
- } else {
- // tint given color
- red += (255 - red) * percent;
- green += (255 - green) * percent;
- blue += (255 - blue) * percent;
- }
- return 'rgb(' + Math.round(red) + ', ' + Math.round(green) + ', ' + Math.round(blue) + ')';
- },
- addItem: function addItem(item) {
- this.$set(this.items, item.index, item);
- },
- removeItem: function removeItem(item) {
- delete this.items[item.index];
- },
- addSubmenu: function addSubmenu(item) {
- this.$set(this.submenus, item.index, item);
- },
- removeSubmenu: function removeSubmenu(item) {
- delete this.submenus[item.index];
- },
- openMenu: function openMenu(index, indexPath) {
- var openedMenus = this.openedMenus;
- if (openedMenus.indexOf(index) !== -1) return;
- // 将不在该菜单路径下的其余菜单收起
- // collapse all menu that are not under current menu item
- if (this.uniqueOpened) {
- this.openedMenus = openedMenus.filter(function (index) {
- return indexPath.indexOf(index) !== -1;
- });
- }
- this.openedMenus.push(index);
- },
- closeMenu: function closeMenu(index) {
- var i = this.openedMenus.indexOf(index);
- if (i !== -1) {
- this.openedMenus.splice(i, 1);
- }
- },
- handleSubmenuClick: function handleSubmenuClick(submenu) {
- var index = submenu.index,
- indexPath = submenu.indexPath;
- var isOpened = this.openedMenus.indexOf(index) !== -1;
- if (isOpened) {
- this.closeMenu(index);
- this.$emit('close', index, indexPath);
- } else {
- this.openMenu(index, indexPath);
- this.$emit('open', index, indexPath);
- }
- },
- handleItemClick: function handleItemClick(item) {
- var _this = this;
- var index = item.index,
- indexPath = item.indexPath;
- var oldActiveIndex = this.activeIndex;
- var hasIndex = item.index !== null;
- if (hasIndex) {
- this.activeIndex = item.index;
- }
- this.$emit('select', index, indexPath, item);
- if (this.mode === 'horizontal' || this.collapse) {
- this.openedMenus = [];
- }
- if (this.router && hasIndex) {
- this.routeToItem(item, function (error) {
- _this.activeIndex = oldActiveIndex;
- if (error) {
- // vue-router 3.1.0+ push/replace cause NavigationDuplicated error
- // https://github.com/ElemeFE/element/issues/17044
- if (error.name === 'NavigationDuplicated') return;
- console.error(error);
- }
- });
- }
- },
- // 初始化展开菜单
- // initialize opened menu
- initOpenedMenu: function initOpenedMenu() {
- var _this2 = this;
- var index = this.activeIndex;
- var activeItem = this.items[index];
- if (!activeItem || this.mode === 'horizontal' || this.collapse) return;
- var indexPath = activeItem.indexPath;
- // 展开该菜单项的路径上所有子菜单
- // expand all submenus of the menu item
- indexPath.forEach(function (index) {
- var submenu = _this2.submenus[index];
- submenu && _this2.openMenu(index, submenu.indexPath);
- });
- },
- routeToItem: function routeToItem(item, onError) {
- var route = item.route || item.index;
- try {
- this.$router.push(route, function () {}, onError);
- } catch (e) {
- console.error(e);
- }
- },
- open: function open(index) {
- var _this3 = this;
- var indexPath = this.submenus[index.toString()].indexPath;
- indexPath.forEach(function (i) {
- return _this3.openMenu(i, indexPath);
- });
- },
- close: function close(index) {
- this.closeMenu(index);
- }
- },
- mounted: function mounted() {
- this.initOpenedMenu();
- this.$on('item-click', this.handleItemClick);
- this.$on('submenu-click', this.handleSubmenuClick);
- if (this.mode === 'horizontal') {
- new aria_menubar(this.$el); // eslint-disable-line
- }
- this.$watch('items', this.updateActiveIndex);
- }
- });
- // CONCATENATED MODULE: ./packages/menu/src/menu.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_menuvue_type_script_lang_js_ = (menuvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/menu/src/menu.vue
- var menu_render, menu_staticRenderFns
- /* normalize component */
- var menu_component = normalizeComponent(
- src_menuvue_type_script_lang_js_,
- menu_render,
- menu_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var menu_api; }
- menu_component.options.__file = "packages/menu/src/menu.vue"
- /* harmony default export */ var src_menu = (menu_component.exports);
- // CONCATENATED MODULE: ./packages/menu/index.js
- /* istanbul ignore next */
- src_menu.install = function (Vue) {
- Vue.component(src_menu.name, src_menu);
- };
- /* harmony default export */ var packages_menu = (src_menu);
- // EXTERNAL MODULE: external "element-ui/lib/transitions/collapse-transition"
- var collapse_transition_ = __webpack_require__(21);
- var collapse_transition_default = /*#__PURE__*/__webpack_require__.n(collapse_transition_);
- // CONCATENATED MODULE: ./packages/menu/src/menu-mixin.js
- /* harmony default export */ var menu_mixin = ({
- inject: ['rootMenu'],
- computed: {
- indexPath: function indexPath() {
- var path = [this.index];
- var parent = this.$parent;
- while (parent.$options.componentName !== 'ElMenu') {
- if (parent.index) {
- path.unshift(parent.index);
- }
- parent = parent.$parent;
- }
- return path;
- },
- parentMenu: function parentMenu() {
- var parent = this.$parent;
- while (parent && ['ElMenu', 'ElSubmenu'].indexOf(parent.$options.componentName) === -1) {
- parent = parent.$parent;
- }
- return parent;
- },
- paddingStyle: function paddingStyle() {
- if (this.rootMenu.mode !== 'vertical') return {};
- var padding = 20;
- var parent = this.$parent;
- if (this.rootMenu.collapse) {
- padding = 20;
- } else {
- while (parent && parent.$options.componentName !== 'ElMenu') {
- if (parent.$options.componentName === 'ElSubmenu') {
- padding += 20;
- }
- parent = parent.$parent;
- }
- }
- return { paddingLeft: padding + 'px' };
- }
- }
- });
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/submenu.vue?vue&type=script&lang=js&
- var poperMixins = {
- props: {
- transformOrigin: {
- type: [Boolean, String],
- default: false
- },
- offset: vue_popper_default.a.props.offset,
- boundariesPadding: vue_popper_default.a.props.boundariesPadding,
- popperOptions: vue_popper_default.a.props.popperOptions
- },
- data: vue_popper_default.a.data,
- methods: vue_popper_default.a.methods,
- beforeDestroy: vue_popper_default.a.beforeDestroy,
- deactivated: vue_popper_default.a.deactivated
- };
- /* harmony default export */ var submenuvue_type_script_lang_js_ = ({
- name: 'ElSubmenu',
- componentName: 'ElSubmenu',
- mixins: [menu_mixin, emitter_default.a, poperMixins],
- components: { ElCollapseTransition: collapse_transition_default.a },
- props: {
- index: {
- type: String,
- required: true
- },
- showTimeout: {
- type: Number,
- default: 300
- },
- hideTimeout: {
- type: Number,
- default: 300
- },
- popperClass: String,
- disabled: Boolean,
- popperAppendToBody: {
- type: Boolean,
- default: undefined
- }
- },
- data: function data() {
- return {
- popperJS: null,
- timeout: null,
- items: {},
- submenus: {},
- mouseInChild: false
- };
- },
- watch: {
- opened: function opened(val) {
- var _this = this;
- if (this.isMenuPopup) {
- this.$nextTick(function (_) {
- _this.updatePopper();
- });
- }
- }
- },
- computed: {
- // popper option
- appendToBody: function appendToBody() {
- return this.popperAppendToBody === undefined ? this.isFirstLevel : this.popperAppendToBody;
- },
- menuTransitionName: function menuTransitionName() {
- return this.rootMenu.collapse ? 'el-zoom-in-left' : 'el-zoom-in-top';
- },
- opened: function opened() {
- return this.rootMenu.openedMenus.indexOf(this.index) > -1;
- },
- active: function active() {
- var isActive = false;
- var submenus = this.submenus;
- var items = this.items;
- Object.keys(items).forEach(function (index) {
- if (items[index].active) {
- isActive = true;
- }
- });
- Object.keys(submenus).forEach(function (index) {
- if (submenus[index].active) {
- isActive = true;
- }
- });
- return isActive;
- },
- hoverBackground: function hoverBackground() {
- return this.rootMenu.hoverBackground;
- },
- backgroundColor: function backgroundColor() {
- return this.rootMenu.backgroundColor || '';
- },
- activeTextColor: function activeTextColor() {
- return this.rootMenu.activeTextColor || '';
- },
- textColor: function textColor() {
- return this.rootMenu.textColor || '';
- },
- mode: function mode() {
- return this.rootMenu.mode;
- },
- isMenuPopup: function isMenuPopup() {
- return this.rootMenu.isMenuPopup;
- },
- titleStyle: function titleStyle() {
- if (this.mode !== 'horizontal') {
- return {
- color: this.textColor
- };
- }
- return {
- borderBottomColor: this.active ? this.rootMenu.activeTextColor ? this.activeTextColor : '' : 'transparent',
- color: this.active ? this.activeTextColor : this.textColor
- };
- },
- isFirstLevel: function isFirstLevel() {
- var isFirstLevel = true;
- var parent = this.$parent;
- while (parent && parent !== this.rootMenu) {
- if (['ElSubmenu', 'ElMenuItemGroup'].indexOf(parent.$options.componentName) > -1) {
- isFirstLevel = false;
- break;
- } else {
- parent = parent.$parent;
- }
- }
- return isFirstLevel;
- }
- },
- methods: {
- handleCollapseToggle: function handleCollapseToggle(value) {
- if (value) {
- this.initPopper();
- } else {
- this.doDestroy();
- }
- },
- addItem: function addItem(item) {
- this.$set(this.items, item.index, item);
- },
- removeItem: function removeItem(item) {
- delete this.items[item.index];
- },
- addSubmenu: function addSubmenu(item) {
- this.$set(this.submenus, item.index, item);
- },
- removeSubmenu: function removeSubmenu(item) {
- delete this.submenus[item.index];
- },
- handleClick: function handleClick() {
- var rootMenu = this.rootMenu,
- disabled = this.disabled;
- if (rootMenu.menuTrigger === 'hover' && rootMenu.mode === 'horizontal' || rootMenu.collapse && rootMenu.mode === 'vertical' || disabled) {
- return;
- }
- this.dispatch('ElMenu', 'submenu-click', this);
- },
- handleMouseenter: function handleMouseenter(event) {
- var _this2 = this;
- var showTimeout = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.showTimeout;
- if (!('ActiveXObject' in window) && event.type === 'focus' && !event.relatedTarget) {
- return;
- }
- var rootMenu = this.rootMenu,
- disabled = this.disabled;
- if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical' || disabled) {
- return;
- }
- this.dispatch('ElSubmenu', 'mouse-enter-child');
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- _this2.rootMenu.openMenu(_this2.index, _this2.indexPath);
- }, showTimeout);
- if (this.appendToBody) {
- this.$parent.$el.dispatchEvent(new MouseEvent('mouseenter'));
- }
- },
- handleMouseleave: function handleMouseleave() {
- var _this3 = this;
- var deepDispatch = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- var rootMenu = this.rootMenu;
- if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical') {
- return;
- }
- this.dispatch('ElSubmenu', 'mouse-leave-child');
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- !_this3.mouseInChild && _this3.rootMenu.closeMenu(_this3.index);
- }, this.hideTimeout);
- if (this.appendToBody && deepDispatch) {
- if (this.$parent.$options.name === 'ElSubmenu') {
- this.$parent.handleMouseleave(true);
- }
- }
- },
- handleTitleMouseenter: function handleTitleMouseenter() {
- if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return;
- var title = this.$refs['submenu-title'];
- title && (title.style.backgroundColor = this.rootMenu.hoverBackground);
- },
- handleTitleMouseleave: function handleTitleMouseleave() {
- if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return;
- var title = this.$refs['submenu-title'];
- title && (title.style.backgroundColor = this.rootMenu.backgroundColor || '');
- },
- updatePlacement: function updatePlacement() {
- this.currentPlacement = this.mode === 'horizontal' && this.isFirstLevel ? 'bottom-start' : 'right-start';
- },
- initPopper: function initPopper() {
- this.referenceElm = this.$el;
- this.popperElm = this.$refs.menu;
- this.updatePlacement();
- }
- },
- created: function created() {
- var _this4 = this;
- this.$on('toggle-collapse', this.handleCollapseToggle);
- this.$on('mouse-enter-child', function () {
- _this4.mouseInChild = true;
- clearTimeout(_this4.timeout);
- });
- this.$on('mouse-leave-child', function () {
- _this4.mouseInChild = false;
- clearTimeout(_this4.timeout);
- });
- },
- mounted: function mounted() {
- this.parentMenu.addSubmenu(this);
- this.rootMenu.addSubmenu(this);
- this.initPopper();
- },
- beforeDestroy: function beforeDestroy() {
- this.parentMenu.removeSubmenu(this);
- this.rootMenu.removeSubmenu(this);
- },
- render: function render(h) {
- var _this5 = this;
- var active = this.active,
- opened = this.opened,
- paddingStyle = this.paddingStyle,
- titleStyle = this.titleStyle,
- backgroundColor = this.backgroundColor,
- rootMenu = this.rootMenu,
- currentPlacement = this.currentPlacement,
- menuTransitionName = this.menuTransitionName,
- mode = this.mode,
- disabled = this.disabled,
- popperClass = this.popperClass,
- $slots = this.$slots,
- isFirstLevel = this.isFirstLevel;
- var popupMenu = h(
- 'transition',
- {
- attrs: { name: menuTransitionName }
- },
- [h(
- 'div',
- {
- ref: 'menu',
- directives: [{
- name: 'show',
- value: opened
- }],
- 'class': ['el-menu--' + mode, popperClass],
- on: {
- 'mouseenter': function mouseenter($event) {
- return _this5.handleMouseenter($event, 100);
- },
- 'mouseleave': function mouseleave() {
- return _this5.handleMouseleave(true);
- },
- 'focus': function focus($event) {
- return _this5.handleMouseenter($event, 100);
- }
- }
- },
- [h(
- 'ul',
- {
- attrs: {
- role: 'menu'
- },
- 'class': ['el-menu el-menu--popup', 'el-menu--popup-' + currentPlacement],
- style: { backgroundColor: rootMenu.backgroundColor || '' } },
- [$slots.default]
- )]
- )]
- );
- var inlineMenu = h('el-collapse-transition', [h(
- 'ul',
- {
- attrs: {
- role: 'menu'
- },
- 'class': 'el-menu el-menu--inline',
- directives: [{
- name: 'show',
- value: opened
- }],
- style: { backgroundColor: rootMenu.backgroundColor || '' } },
- [$slots.default]
- )]);
- var submenuTitleIcon = rootMenu.mode === 'horizontal' && isFirstLevel || rootMenu.mode === 'vertical' && !rootMenu.collapse ? 'el-icon-arrow-down' : 'el-icon-arrow-right';
- return h(
- 'li',
- {
- 'class': {
- 'el-submenu': true,
- 'is-active': active,
- 'is-opened': opened,
- 'is-disabled': disabled
- },
- attrs: { role: 'menuitem',
- 'aria-haspopup': 'true',
- 'aria-expanded': opened
- },
- on: {
- 'mouseenter': this.handleMouseenter,
- 'mouseleave': function mouseleave() {
- return _this5.handleMouseleave(false);
- },
- 'focus': this.handleMouseenter
- }
- },
- [h(
- 'div',
- {
- 'class': 'el-submenu__title',
- ref: 'submenu-title',
- on: {
- 'click': this.handleClick,
- 'mouseenter': this.handleTitleMouseenter,
- 'mouseleave': this.handleTitleMouseleave
- },
- style: [paddingStyle, titleStyle, { backgroundColor: backgroundColor }]
- },
- [$slots.title, h('i', { 'class': ['el-submenu__icon-arrow', submenuTitleIcon] })]
- ), this.isMenuPopup ? popupMenu : inlineMenu]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/menu/src/submenu.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_submenuvue_type_script_lang_js_ = (submenuvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/menu/src/submenu.vue
- var submenu_render, submenu_staticRenderFns
- /* normalize component */
- var submenu_component = normalizeComponent(
- src_submenuvue_type_script_lang_js_,
- submenu_render,
- submenu_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var submenu_api; }
- submenu_component.options.__file = "packages/menu/src/submenu.vue"
- /* harmony default export */ var submenu = (submenu_component.exports);
- // CONCATENATED MODULE: ./packages/submenu/index.js
- /* istanbul ignore next */
- submenu.install = function (Vue) {
- Vue.component(submenu.name, submenu);
- };
- /* harmony default export */ var packages_submenu = (submenu);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item.vue?vue&type=template&id=2a5dbfea&
- var menu_itemvue_type_template_id_2a5dbfea_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "li",
- {
- staticClass: "el-menu-item",
- class: {
- "is-active": _vm.active,
- "is-disabled": _vm.disabled
- },
- style: [
- _vm.paddingStyle,
- _vm.itemStyle,
- { backgroundColor: _vm.backgroundColor }
- ],
- attrs: { role: "menuitem", tabindex: "-1" },
- on: {
- click: _vm.handleClick,
- mouseenter: _vm.onMouseEnter,
- focus: _vm.onMouseEnter,
- blur: _vm.onMouseLeave,
- mouseleave: _vm.onMouseLeave
- }
- },
- [
- _vm.parentMenu.$options.componentName === "ElMenu" &&
- _vm.rootMenu.collapse &&
- _vm.$slots.title
- ? _c("el-tooltip", { attrs: { effect: "dark", placement: "right" } }, [
- _c(
- "div",
- { attrs: { slot: "content" }, slot: "content" },
- [_vm._t("title")],
- 2
- ),
- _c(
- "div",
- {
- staticStyle: {
- position: "absolute",
- left: "0",
- top: "0",
- height: "100%",
- width: "100%",
- display: "inline-block",
- "box-sizing": "border-box",
- padding: "0 20px"
- }
- },
- [_vm._t("default")],
- 2
- )
- ])
- : [_vm._t("default"), _vm._t("title")]
- ],
- 2
- )
- }
- var menu_itemvue_type_template_id_2a5dbfea_staticRenderFns = []
- menu_itemvue_type_template_id_2a5dbfea_render._withStripped = true
- // CONCATENATED MODULE: ./packages/menu/src/menu-item.vue?vue&type=template&id=2a5dbfea&
- // EXTERNAL MODULE: external "element-ui/lib/tooltip"
- var tooltip_ = __webpack_require__(26);
- var tooltip_default = /*#__PURE__*/__webpack_require__.n(tooltip_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var menu_itemvue_type_script_lang_js_ = ({
- name: 'ElMenuItem',
- componentName: 'ElMenuItem',
- mixins: [menu_mixin, emitter_default.a],
- components: { ElTooltip: tooltip_default.a },
- props: {
- index: {
- default: null,
- validator: function validator(val) {
- return typeof val === 'string' || val === null;
- }
- },
- route: [String, Object],
- disabled: Boolean
- },
- computed: {
- active: function active() {
- return this.index === this.rootMenu.activeIndex;
- },
- hoverBackground: function hoverBackground() {
- return this.rootMenu.hoverBackground;
- },
- backgroundColor: function backgroundColor() {
- return this.rootMenu.backgroundColor || '';
- },
- activeTextColor: function activeTextColor() {
- return this.rootMenu.activeTextColor || '';
- },
- textColor: function textColor() {
- return this.rootMenu.textColor || '';
- },
- mode: function mode() {
- return this.rootMenu.mode;
- },
- itemStyle: function itemStyle() {
- var style = {
- color: this.active ? this.activeTextColor : this.textColor
- };
- if (this.mode === 'horizontal' && !this.isNested) {
- style.borderBottomColor = this.active ? this.rootMenu.activeTextColor ? this.activeTextColor : '' : 'transparent';
- }
- return style;
- },
- isNested: function isNested() {
- return this.parentMenu !== this.rootMenu;
- }
- },
- methods: {
- onMouseEnter: function onMouseEnter() {
- if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return;
- this.$el.style.backgroundColor = this.hoverBackground;
- },
- onMouseLeave: function onMouseLeave() {
- if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return;
- this.$el.style.backgroundColor = this.backgroundColor;
- },
- handleClick: function handleClick() {
- if (!this.disabled) {
- this.dispatch('ElMenu', 'item-click', this);
- this.$emit('click', this);
- }
- }
- },
- mounted: function mounted() {
- this.parentMenu.addItem(this);
- this.rootMenu.addItem(this);
- },
- beforeDestroy: function beforeDestroy() {
- this.parentMenu.removeItem(this);
- this.rootMenu.removeItem(this);
- }
- });
- // CONCATENATED MODULE: ./packages/menu/src/menu-item.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_menu_itemvue_type_script_lang_js_ = (menu_itemvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/menu/src/menu-item.vue
- /* normalize component */
- var menu_item_component = normalizeComponent(
- src_menu_itemvue_type_script_lang_js_,
- menu_itemvue_type_template_id_2a5dbfea_render,
- menu_itemvue_type_template_id_2a5dbfea_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var menu_item_api; }
- menu_item_component.options.__file = "packages/menu/src/menu-item.vue"
- /* harmony default export */ var menu_item = (menu_item_component.exports);
- // CONCATENATED MODULE: ./packages/menu-item/index.js
- /* istanbul ignore next */
- menu_item.install = function (Vue) {
- Vue.component(menu_item.name, menu_item);
- };
- /* harmony default export */ var packages_menu_item = (menu_item);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item-group.vue?vue&type=template&id=543b7bdc&
- var menu_item_groupvue_type_template_id_543b7bdc_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("li", { staticClass: "el-menu-item-group" }, [
- _c(
- "div",
- {
- staticClass: "el-menu-item-group__title",
- style: { paddingLeft: _vm.levelPadding + "px" }
- },
- [!_vm.$slots.title ? [_vm._v(_vm._s(_vm.title))] : _vm._t("title")],
- 2
- ),
- _c("ul", [_vm._t("default")], 2)
- ])
- }
- var menu_item_groupvue_type_template_id_543b7bdc_staticRenderFns = []
- menu_item_groupvue_type_template_id_543b7bdc_render._withStripped = true
- // CONCATENATED MODULE: ./packages/menu/src/menu-item-group.vue?vue&type=template&id=543b7bdc&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item-group.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var menu_item_groupvue_type_script_lang_js_ = ({
- name: 'ElMenuItemGroup',
- componentName: 'ElMenuItemGroup',
- inject: ['rootMenu'],
- props: {
- title: {
- type: String
- }
- },
- data: function data() {
- return {
- paddingLeft: 20
- };
- },
- computed: {
- levelPadding: function levelPadding() {
- var padding = 20;
- var parent = this.$parent;
- if (this.rootMenu.collapse) return 20;
- while (parent && parent.$options.componentName !== 'ElMenu') {
- if (parent.$options.componentName === 'ElSubmenu') {
- padding += 20;
- }
- parent = parent.$parent;
- }
- return padding;
- }
- }
- });
- // CONCATENATED MODULE: ./packages/menu/src/menu-item-group.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_menu_item_groupvue_type_script_lang_js_ = (menu_item_groupvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/menu/src/menu-item-group.vue
- /* normalize component */
- var menu_item_group_component = normalizeComponent(
- src_menu_item_groupvue_type_script_lang_js_,
- menu_item_groupvue_type_template_id_543b7bdc_render,
- menu_item_groupvue_type_template_id_543b7bdc_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var menu_item_group_api; }
- menu_item_group_component.options.__file = "packages/menu/src/menu-item-group.vue"
- /* harmony default export */ var menu_item_group = (menu_item_group_component.exports);
- // CONCATENATED MODULE: ./packages/menu-item-group/index.js
- /* istanbul ignore next */
- menu_item_group.install = function (Vue) {
- Vue.component(menu_item_group.name, menu_item_group);
- };
- /* harmony default export */ var packages_menu_item_group = (menu_item_group);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/input/src/input.vue?vue&type=template&id=343dd774&
- var inputvue_type_template_id_343dd774_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- class: [
- _vm.type === "textarea" ? "el-textarea" : "el-input",
- _vm.inputSize ? "el-input--" + _vm.inputSize : "",
- {
- "is-disabled": _vm.inputDisabled,
- "is-exceed": _vm.inputExceed,
- "el-input-group": _vm.$slots.prepend || _vm.$slots.append,
- "el-input-group--append": _vm.$slots.append,
- "el-input-group--prepend": _vm.$slots.prepend,
- "el-input--prefix": _vm.$slots.prefix || _vm.prefixIcon,
- "el-input--suffix":
- _vm.$slots.suffix ||
- _vm.suffixIcon ||
- _vm.clearable ||
- _vm.showPassword
- }
- ],
- on: {
- mouseenter: function($event) {
- _vm.hovering = true
- },
- mouseleave: function($event) {
- _vm.hovering = false
- }
- }
- },
- [
- _vm.type !== "textarea"
- ? [
- _vm.$slots.prepend
- ? _c(
- "div",
- { staticClass: "el-input-group__prepend" },
- [_vm._t("prepend")],
- 2
- )
- : _vm._e(),
- _vm.type !== "textarea"
- ? _c(
- "input",
- _vm._b(
- {
- ref: "input",
- staticClass: "el-input__inner",
- attrs: {
- tabindex: _vm.tabindex,
- type: _vm.showPassword
- ? _vm.passwordVisible
- ? "text"
- : "password"
- : _vm.type,
- disabled: _vm.inputDisabled,
- readonly: _vm.readonly,
- autocomplete: _vm.autoComplete || _vm.autocomplete,
- "aria-label": _vm.label
- },
- on: {
- compositionstart: _vm.handleCompositionStart,
- compositionupdate: _vm.handleCompositionUpdate,
- compositionend: _vm.handleCompositionEnd,
- input: _vm.handleInput,
- focus: _vm.handleFocus,
- blur: _vm.handleBlur,
- change: _vm.handleChange
- }
- },
- "input",
- _vm.$attrs,
- false
- )
- )
- : _vm._e(),
- _vm.$slots.prefix || _vm.prefixIcon
- ? _c(
- "span",
- { staticClass: "el-input__prefix" },
- [
- _vm._t("prefix"),
- _vm.prefixIcon
- ? _c("i", {
- staticClass: "el-input__icon",
- class: _vm.prefixIcon
- })
- : _vm._e()
- ],
- 2
- )
- : _vm._e(),
- _vm.getSuffixVisible()
- ? _c("span", { staticClass: "el-input__suffix" }, [
- _c(
- "span",
- { staticClass: "el-input__suffix-inner" },
- [
- !_vm.showClear ||
- !_vm.showPwdVisible ||
- !_vm.isWordLimitVisible
- ? [
- _vm._t("suffix"),
- _vm.suffixIcon
- ? _c("i", {
- staticClass: "el-input__icon",
- class: _vm.suffixIcon
- })
- : _vm._e()
- ]
- : _vm._e(),
- _vm.showClear
- ? _c("i", {
- staticClass:
- "el-input__icon el-icon-circle-close el-input__clear",
- on: {
- mousedown: function($event) {
- $event.preventDefault()
- },
- click: _vm.clear
- }
- })
- : _vm._e(),
- _vm.showPwdVisible
- ? _c("i", {
- staticClass:
- "el-input__icon el-icon-view el-input__clear",
- on: { click: _vm.handlePasswordVisible }
- })
- : _vm._e(),
- _vm.isWordLimitVisible
- ? _c("span", { staticClass: "el-input__count" }, [
- _c(
- "span",
- { staticClass: "el-input__count-inner" },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.textLength) +
- "/" +
- _vm._s(_vm.upperLimit) +
- "\n "
- )
- ]
- )
- ])
- : _vm._e()
- ],
- 2
- ),
- _vm.validateState
- ? _c("i", {
- staticClass: "el-input__icon",
- class: ["el-input__validateIcon", _vm.validateIcon]
- })
- : _vm._e()
- ])
- : _vm._e(),
- _vm.$slots.append
- ? _c(
- "div",
- { staticClass: "el-input-group__append" },
- [_vm._t("append")],
- 2
- )
- : _vm._e()
- ]
- : _c(
- "textarea",
- _vm._b(
- {
- ref: "textarea",
- staticClass: "el-textarea__inner",
- style: _vm.textareaStyle,
- attrs: {
- tabindex: _vm.tabindex,
- disabled: _vm.inputDisabled,
- readonly: _vm.readonly,
- autocomplete: _vm.autoComplete || _vm.autocomplete,
- "aria-label": _vm.label
- },
- on: {
- compositionstart: _vm.handleCompositionStart,
- compositionupdate: _vm.handleCompositionUpdate,
- compositionend: _vm.handleCompositionEnd,
- input: _vm.handleInput,
- focus: _vm.handleFocus,
- blur: _vm.handleBlur,
- change: _vm.handleChange
- }
- },
- "textarea",
- _vm.$attrs,
- false
- )
- ),
- _vm.isWordLimitVisible && _vm.type === "textarea"
- ? _c("span", { staticClass: "el-input__count" }, [
- _vm._v(_vm._s(_vm.textLength) + "/" + _vm._s(_vm.upperLimit))
- ])
- : _vm._e()
- ],
- 2
- )
- }
- var inputvue_type_template_id_343dd774_staticRenderFns = []
- inputvue_type_template_id_343dd774_render._withStripped = true
- // CONCATENATED MODULE: ./packages/input/src/input.vue?vue&type=template&id=343dd774&
- // CONCATENATED MODULE: ./packages/input/src/calcTextareaHeight.js
- var hiddenTextarea = void 0;
- var HIDDEN_STYLE = '\n height:0 !important;\n visibility:hidden !important;\n overflow:hidden !important;\n position:absolute !important;\n z-index:-1000 !important;\n top:0 !important;\n right:0 !important\n';
- var CONTEXT_STYLE = ['letter-spacing', 'line-height', 'padding-top', 'padding-bottom', 'font-family', 'font-weight', 'font-size', 'text-rendering', 'text-transform', 'width', 'text-indent', 'padding-left', 'padding-right', 'border-width', 'box-sizing'];
- function calculateNodeStyling(targetElement) {
- var style = window.getComputedStyle(targetElement);
- var boxSizing = style.getPropertyValue('box-sizing');
- var paddingSize = parseFloat(style.getPropertyValue('padding-bottom')) + parseFloat(style.getPropertyValue('padding-top'));
- var borderSize = parseFloat(style.getPropertyValue('border-bottom-width')) + parseFloat(style.getPropertyValue('border-top-width'));
- var contextStyle = CONTEXT_STYLE.map(function (name) {
- return name + ':' + style.getPropertyValue(name);
- }).join(';');
- return { contextStyle: contextStyle, paddingSize: paddingSize, borderSize: borderSize, boxSizing: boxSizing };
- }
- function calcTextareaHeight(targetElement) {
- var minRows = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
- var maxRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;
- if (!hiddenTextarea) {
- hiddenTextarea = document.createElement('textarea');
- document.body.appendChild(hiddenTextarea);
- }
- var _calculateNodeStyling = calculateNodeStyling(targetElement),
- paddingSize = _calculateNodeStyling.paddingSize,
- borderSize = _calculateNodeStyling.borderSize,
- boxSizing = _calculateNodeStyling.boxSizing,
- contextStyle = _calculateNodeStyling.contextStyle;
- hiddenTextarea.setAttribute('style', contextStyle + ';' + HIDDEN_STYLE);
- hiddenTextarea.value = targetElement.value || targetElement.placeholder || '';
- var height = hiddenTextarea.scrollHeight;
- var result = {};
- if (boxSizing === 'border-box') {
- height = height + borderSize;
- } else if (boxSizing === 'content-box') {
- height = height - paddingSize;
- }
- hiddenTextarea.value = '';
- var singleRowHeight = hiddenTextarea.scrollHeight - paddingSize;
- if (minRows !== null) {
- var minHeight = singleRowHeight * minRows;
- if (boxSizing === 'border-box') {
- minHeight = minHeight + paddingSize + borderSize;
- }
- height = Math.max(minHeight, height);
- result.minHeight = minHeight + 'px';
- }
- if (maxRows !== null) {
- var maxHeight = singleRowHeight * maxRows;
- if (boxSizing === 'border-box') {
- maxHeight = maxHeight + paddingSize + borderSize;
- }
- height = Math.min(maxHeight, height);
- }
- result.height = height + 'px';
- hiddenTextarea.parentNode && hiddenTextarea.parentNode.removeChild(hiddenTextarea);
- hiddenTextarea = null;
- return result;
- };
- // EXTERNAL MODULE: external "element-ui/lib/utils/merge"
- var merge_ = __webpack_require__(7);
- var merge_default = /*#__PURE__*/__webpack_require__.n(merge_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/shared"
- var shared_ = __webpack_require__(19);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/input/src/input.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var inputvue_type_script_lang_js_ = ({
- name: 'ElInput',
- componentName: 'ElInput',
- mixins: [emitter_default.a, migrating_default.a],
- inheritAttrs: false,
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- data: function data() {
- return {
- textareaCalcStyle: {},
- hovering: false,
- focused: false,
- isComposing: false,
- passwordVisible: false
- };
- },
- props: {
- value: [String, Number],
- size: String,
- resize: String,
- form: String,
- disabled: Boolean,
- readonly: Boolean,
- type: {
- type: String,
- default: 'text'
- },
- autosize: {
- type: [Boolean, Object],
- default: false
- },
- autocomplete: {
- type: String,
- default: 'off'
- },
- /** @Deprecated in next major version */
- autoComplete: {
- type: String,
- validator: function validator(val) {
- false && false;
- return true;
- }
- },
- validateEvent: {
- type: Boolean,
- default: true
- },
- suffixIcon: String,
- prefixIcon: String,
- label: String,
- clearable: {
- type: Boolean,
- default: false
- },
- showPassword: {
- type: Boolean,
- default: false
- },
- showWordLimit: {
- type: Boolean,
- default: false
- },
- tabindex: String
- },
- computed: {
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- validateState: function validateState() {
- return this.elFormItem ? this.elFormItem.validateState : '';
- },
- needStatusIcon: function needStatusIcon() {
- return this.elForm ? this.elForm.statusIcon : false;
- },
- validateIcon: function validateIcon() {
- return {
- validating: 'el-icon-loading',
- success: 'el-icon-circle-check',
- error: 'el-icon-circle-close'
- }[this.validateState];
- },
- textareaStyle: function textareaStyle() {
- return merge_default()({}, this.textareaCalcStyle, { resize: this.resize });
- },
- inputSize: function inputSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- inputDisabled: function inputDisabled() {
- return this.disabled || (this.elForm || {}).disabled;
- },
- nativeInputValue: function nativeInputValue() {
- return this.value === null || this.value === undefined ? '' : String(this.value);
- },
- showClear: function showClear() {
- return this.clearable && !this.inputDisabled && !this.readonly && this.nativeInputValue && (this.focused || this.hovering);
- },
- showPwdVisible: function showPwdVisible() {
- return this.showPassword && !this.inputDisabled && !this.readonly && (!!this.nativeInputValue || this.focused);
- },
- isWordLimitVisible: function isWordLimitVisible() {
- return this.showWordLimit && this.$attrs.maxlength && (this.type === 'text' || this.type === 'textarea') && !this.inputDisabled && !this.readonly && !this.showPassword;
- },
- upperLimit: function upperLimit() {
- return this.$attrs.maxlength;
- },
- textLength: function textLength() {
- if (typeof this.value === 'number') {
- return String(this.value).length;
- }
- return (this.value || '').length;
- },
- inputExceed: function inputExceed() {
- // show exceed style if length of initial value greater then maxlength
- return this.isWordLimitVisible && this.textLength > this.upperLimit;
- }
- },
- watch: {
- value: function value(val) {
- this.$nextTick(this.resizeTextarea);
- if (this.validateEvent) {
- this.dispatch('ElFormItem', 'el.form.change', [val]);
- }
- },
- // native input value is set explicitly
- // do not use v-model / :value in template
- // see: https://github.com/ElemeFE/element/issues/14521
- nativeInputValue: function nativeInputValue() {
- this.setNativeInputValue();
- },
- // when change between <input> and <textarea>,
- // update DOM dependent value and styles
- // https://github.com/ElemeFE/element/issues/14857
- type: function type() {
- var _this = this;
- this.$nextTick(function () {
- _this.setNativeInputValue();
- _this.resizeTextarea();
- _this.updateIconOffset();
- });
- }
- },
- methods: {
- focus: function focus() {
- this.getInput().focus();
- },
- blur: function blur() {
- this.getInput().blur();
- },
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'icon': 'icon is removed, use suffix-icon / prefix-icon instead.',
- 'on-icon-click': 'on-icon-click is removed.'
- },
- events: {
- 'click': 'click is removed.'
- }
- };
- },
- handleBlur: function handleBlur(event) {
- this.focused = false;
- this.$emit('blur', event);
- if (this.validateEvent) {
- this.dispatch('ElFormItem', 'el.form.blur', [this.value]);
- }
- },
- select: function select() {
- this.getInput().select();
- },
- resizeTextarea: function resizeTextarea() {
- if (this.$isServer) return;
- var autosize = this.autosize,
- type = this.type;
- if (type !== 'textarea') return;
- if (!autosize) {
- this.textareaCalcStyle = {
- minHeight: calcTextareaHeight(this.$refs.textarea).minHeight
- };
- return;
- }
- var minRows = autosize.minRows;
- var maxRows = autosize.maxRows;
- this.textareaCalcStyle = calcTextareaHeight(this.$refs.textarea, minRows, maxRows);
- },
- setNativeInputValue: function setNativeInputValue() {
- var input = this.getInput();
- if (!input) return;
- if (input.value === this.nativeInputValue) return;
- input.value = this.nativeInputValue;
- },
- handleFocus: function handleFocus(event) {
- this.focused = true;
- this.$emit('focus', event);
- },
- handleCompositionStart: function handleCompositionStart(event) {
- this.$emit('compositionstart', event);
- this.isComposing = true;
- },
- handleCompositionUpdate: function handleCompositionUpdate(event) {
- this.$emit('compositionupdate', event);
- var text = event.target.value;
- var lastCharacter = text[text.length - 1] || '';
- this.isComposing = !Object(shared_["isKorean"])(lastCharacter);
- },
- handleCompositionEnd: function handleCompositionEnd(event) {
- this.$emit('compositionend', event);
- if (this.isComposing) {
- this.isComposing = false;
- this.handleInput(event);
- }
- },
- handleInput: function handleInput(event) {
- // should not emit input during composition
- // see: https://github.com/ElemeFE/element/issues/10516
- if (this.isComposing) return;
- // hack for https://github.com/ElemeFE/element/issues/8548
- // should remove the following line when we don't support IE
- if (event.target.value === this.nativeInputValue) return;
- this.$emit('input', event.target.value);
- // ensure native input value is controlled
- // see: https://github.com/ElemeFE/element/issues/12850
- this.$nextTick(this.setNativeInputValue);
- },
- handleChange: function handleChange(event) {
- this.$emit('change', event.target.value);
- },
- calcIconOffset: function calcIconOffset(place) {
- var elList = [].slice.call(this.$el.querySelectorAll('.el-input__' + place) || []);
- if (!elList.length) return;
- var el = null;
- for (var i = 0; i < elList.length; i++) {
- if (elList[i].parentNode === this.$el) {
- el = elList[i];
- break;
- }
- }
- if (!el) return;
- var pendantMap = {
- suffix: 'append',
- prefix: 'prepend'
- };
- var pendant = pendantMap[place];
- if (this.$slots[pendant]) {
- el.style.transform = 'translateX(' + (place === 'suffix' ? '-' : '') + this.$el.querySelector('.el-input-group__' + pendant).offsetWidth + 'px)';
- } else {
- el.removeAttribute('style');
- }
- },
- updateIconOffset: function updateIconOffset() {
- this.calcIconOffset('prefix');
- this.calcIconOffset('suffix');
- },
- clear: function clear() {
- this.$emit('input', '');
- this.$emit('change', '');
- this.$emit('clear');
- },
- handlePasswordVisible: function handlePasswordVisible() {
- var _this2 = this;
- this.passwordVisible = !this.passwordVisible;
- this.$nextTick(function () {
- _this2.focus();
- });
- },
- getInput: function getInput() {
- return this.$refs.input || this.$refs.textarea;
- },
- getSuffixVisible: function getSuffixVisible() {
- return this.$slots.suffix || this.suffixIcon || this.showClear || this.showPassword || this.isWordLimitVisible || this.validateState && this.needStatusIcon;
- }
- },
- created: function created() {
- this.$on('inputSelect', this.select);
- },
- mounted: function mounted() {
- this.setNativeInputValue();
- this.resizeTextarea();
- this.updateIconOffset();
- },
- updated: function updated() {
- this.$nextTick(this.updateIconOffset);
- }
- });
- // CONCATENATED MODULE: ./packages/input/src/input.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_inputvue_type_script_lang_js_ = (inputvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/input/src/input.vue
- /* normalize component */
- var input_component = normalizeComponent(
- src_inputvue_type_script_lang_js_,
- inputvue_type_template_id_343dd774_render,
- inputvue_type_template_id_343dd774_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var input_api; }
- input_component.options.__file = "packages/input/src/input.vue"
- /* harmony default export */ var src_input = (input_component.exports);
- // CONCATENATED MODULE: ./packages/input/index.js
- /* istanbul ignore next */
- src_input.install = function (Vue) {
- Vue.component(src_input.name, src_input);
- };
- /* harmony default export */ var packages_input = (src_input);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/input-number/src/input-number.vue?vue&type=template&id=42f8cf66&
- var input_numbervue_type_template_id_42f8cf66_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- class: [
- "el-input-number",
- _vm.inputNumberSize ? "el-input-number--" + _vm.inputNumberSize : "",
- { "is-disabled": _vm.inputNumberDisabled },
- { "is-without-controls": !_vm.controls },
- { "is-controls-right": _vm.controlsAtRight }
- ],
- on: {
- dragstart: function($event) {
- $event.preventDefault()
- }
- }
- },
- [
- _vm.controls
- ? _c(
- "span",
- {
- directives: [
- {
- name: "repeat-click",
- rawName: "v-repeat-click",
- value: _vm.decrease,
- expression: "decrease"
- }
- ],
- staticClass: "el-input-number__decrease",
- class: { "is-disabled": _vm.minDisabled },
- attrs: { role: "button" },
- on: {
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")
- ) {
- return null
- }
- return _vm.decrease($event)
- }
- }
- },
- [
- _c("i", {
- class:
- "el-icon-" + (_vm.controlsAtRight ? "arrow-down" : "minus")
- })
- ]
- )
- : _vm._e(),
- _vm.controls
- ? _c(
- "span",
- {
- directives: [
- {
- name: "repeat-click",
- rawName: "v-repeat-click",
- value: _vm.increase,
- expression: "increase"
- }
- ],
- staticClass: "el-input-number__increase",
- class: { "is-disabled": _vm.maxDisabled },
- attrs: { role: "button" },
- on: {
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")
- ) {
- return null
- }
- return _vm.increase($event)
- }
- }
- },
- [
- _c("i", {
- class: "el-icon-" + (_vm.controlsAtRight ? "arrow-up" : "plus")
- })
- ]
- )
- : _vm._e(),
- _c("el-input", {
- ref: "input",
- attrs: {
- value: _vm.displayValue,
- placeholder: _vm.placeholder,
- disabled: _vm.inputNumberDisabled,
- size: _vm.inputNumberSize,
- max: _vm.max,
- min: _vm.min,
- name: _vm.name,
- label: _vm.label
- },
- on: {
- blur: _vm.handleBlur,
- focus: _vm.handleFocus,
- input: _vm.handleInput,
- change: _vm.handleInputChange
- },
- nativeOn: {
- keydown: [
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "up", 38, $event.key, ["Up", "ArrowUp"])
- ) {
- return null
- }
- $event.preventDefault()
- return _vm.increase($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "down", 40, $event.key, [
- "Down",
- "ArrowDown"
- ])
- ) {
- return null
- }
- $event.preventDefault()
- return _vm.decrease($event)
- }
- ]
- }
- })
- ],
- 1
- )
- }
- var input_numbervue_type_template_id_42f8cf66_staticRenderFns = []
- input_numbervue_type_template_id_42f8cf66_render._withStripped = true
- // CONCATENATED MODULE: ./packages/input-number/src/input-number.vue?vue&type=template&id=42f8cf66&
- // CONCATENATED MODULE: ./src/directives/repeat-click.js
- /* harmony default export */ var repeat_click = ({
- bind: function bind(el, binding, vnode) {
- var interval = null;
- var startTime = void 0;
- var maxIntervals = Object(util_["isMac"])() ? 100 : 200;
- var handler = function handler() {
- return vnode.context[binding.expression].apply();
- };
- var clear = function clear() {
- if (Date.now() - startTime < maxIntervals) {
- handler();
- }
- clearInterval(interval);
- interval = null;
- };
- Object(dom_["on"])(el, 'mousedown', function (e) {
- if (e.button !== 0) return;
- startTime = Date.now();
- Object(dom_["once"])(document, 'mouseup', clear);
- clearInterval(interval);
- interval = setInterval(handler, maxIntervals);
- });
- }
- });
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/input-number/src/input-number.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var input_numbervue_type_script_lang_js_ = ({
- name: 'ElInputNumber',
- mixins: [focus_default()('input')],
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- directives: {
- repeatClick: repeat_click
- },
- components: {
- ElInput: input_default.a
- },
- props: {
- step: {
- type: Number,
- default: 1
- },
- stepStrictly: {
- type: Boolean,
- default: false
- },
- max: {
- type: Number,
- default: Infinity
- },
- min: {
- type: Number,
- default: -Infinity
- },
- value: {},
- disabled: Boolean,
- size: String,
- controls: {
- type: Boolean,
- default: true
- },
- controlsPosition: {
- type: String,
- default: ''
- },
- name: String,
- label: String,
- placeholder: String,
- precision: {
- type: Number,
- validator: function validator(val) {
- return val >= 0 && val === parseInt(val, 10);
- }
- }
- },
- data: function data() {
- return {
- currentValue: 0,
- userInput: null
- };
- },
- watch: {
- value: {
- immediate: true,
- handler: function handler(value) {
- var newVal = value === undefined ? value : Number(value);
- if (newVal !== undefined) {
- if (isNaN(newVal)) {
- return;
- }
- if (this.stepStrictly) {
- var stepPrecision = this.getPrecision(this.step);
- var precisionFactor = Math.pow(10, stepPrecision);
- newVal = Math.round(newVal / this.step) * precisionFactor * this.step / precisionFactor;
- }
- if (this.precision !== undefined) {
- newVal = this.toPrecision(newVal, this.precision);
- }
- }
- if (newVal >= this.max) newVal = this.max;
- if (newVal <= this.min) newVal = this.min;
- this.currentValue = newVal;
- this.userInput = null;
- this.$emit('input', newVal);
- }
- }
- },
- computed: {
- minDisabled: function minDisabled() {
- return this._decrease(this.value, this.step) < this.min;
- },
- maxDisabled: function maxDisabled() {
- return this._increase(this.value, this.step) > this.max;
- },
- numPrecision: function numPrecision() {
- var value = this.value,
- step = this.step,
- getPrecision = this.getPrecision,
- precision = this.precision;
- var stepPrecision = getPrecision(step);
- if (precision !== undefined) {
- if (stepPrecision > precision) {
- console.warn('[Element Warn][InputNumber]precision should not be less than the decimal places of step');
- }
- return precision;
- } else {
- return Math.max(getPrecision(value), stepPrecision);
- }
- },
- controlsAtRight: function controlsAtRight() {
- return this.controls && this.controlsPosition === 'right';
- },
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- inputNumberSize: function inputNumberSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- inputNumberDisabled: function inputNumberDisabled() {
- return this.disabled || !!(this.elForm || {}).disabled;
- },
- displayValue: function displayValue() {
- if (this.userInput !== null) {
- return this.userInput;
- }
- var currentValue = this.currentValue;
- if (typeof currentValue === 'number') {
- if (this.stepStrictly) {
- var stepPrecision = this.getPrecision(this.step);
- var precisionFactor = Math.pow(10, stepPrecision);
- currentValue = Math.round(currentValue / this.step) * precisionFactor * this.step / precisionFactor;
- }
- if (this.precision !== undefined) {
- currentValue = currentValue.toFixed(this.precision);
- }
- }
- return currentValue;
- }
- },
- methods: {
- toPrecision: function toPrecision(num, precision) {
- if (precision === undefined) precision = this.numPrecision;
- return parseFloat(Math.round(num * Math.pow(10, precision)) / Math.pow(10, precision));
- },
- getPrecision: function getPrecision(value) {
- if (value === undefined) return 0;
- var valueString = value.toString();
- var dotPosition = valueString.indexOf('.');
- var precision = 0;
- if (dotPosition !== -1) {
- precision = valueString.length - dotPosition - 1;
- }
- return precision;
- },
- _increase: function _increase(val, step) {
- if (typeof val !== 'number' && val !== undefined) return this.currentValue;
- var precisionFactor = Math.pow(10, this.numPrecision);
- // Solve the accuracy problem of JS decimal calculation by converting the value to integer.
- return this.toPrecision((precisionFactor * val + precisionFactor * step) / precisionFactor);
- },
- _decrease: function _decrease(val, step) {
- if (typeof val !== 'number' && val !== undefined) return this.currentValue;
- var precisionFactor = Math.pow(10, this.numPrecision);
- return this.toPrecision((precisionFactor * val - precisionFactor * step) / precisionFactor);
- },
- increase: function increase() {
- if (this.inputNumberDisabled || this.maxDisabled) return;
- var value = this.value || 0;
- var newVal = this._increase(value, this.step);
- this.setCurrentValue(newVal);
- },
- decrease: function decrease() {
- if (this.inputNumberDisabled || this.minDisabled) return;
- var value = this.value || 0;
- var newVal = this._decrease(value, this.step);
- this.setCurrentValue(newVal);
- },
- handleBlur: function handleBlur(event) {
- this.$emit('blur', event);
- },
- handleFocus: function handleFocus(event) {
- this.$emit('focus', event);
- },
- setCurrentValue: function setCurrentValue(newVal) {
- var oldVal = this.currentValue;
- if (typeof newVal === 'number' && this.precision !== undefined) {
- newVal = this.toPrecision(newVal, this.precision);
- }
- if (newVal >= this.max) newVal = this.max;
- if (newVal <= this.min) newVal = this.min;
- if (oldVal === newVal) return;
- this.userInput = null;
- this.$emit('input', newVal);
- this.$emit('change', newVal, oldVal);
- this.currentValue = newVal;
- },
- handleInput: function handleInput(value) {
- this.userInput = value;
- },
- handleInputChange: function handleInputChange(value) {
- var newVal = value === '' ? undefined : Number(value);
- if (!isNaN(newVal) || value === '') {
- this.setCurrentValue(newVal);
- }
- this.userInput = null;
- },
- select: function select() {
- this.$refs.input.select();
- }
- },
- mounted: function mounted() {
- var innerInput = this.$refs.input.$refs.input;
- innerInput.setAttribute('role', 'spinbutton');
- innerInput.setAttribute('aria-valuemax', this.max);
- innerInput.setAttribute('aria-valuemin', this.min);
- innerInput.setAttribute('aria-valuenow', this.currentValue);
- innerInput.setAttribute('aria-disabled', this.inputNumberDisabled);
- },
- updated: function updated() {
- if (!this.$refs || !this.$refs.input) return;
- var innerInput = this.$refs.input.$refs.input;
- innerInput.setAttribute('aria-valuenow', this.currentValue);
- }
- });
- // CONCATENATED MODULE: ./packages/input-number/src/input-number.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_input_numbervue_type_script_lang_js_ = (input_numbervue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/input-number/src/input-number.vue
- /* normalize component */
- var input_number_component = normalizeComponent(
- src_input_numbervue_type_script_lang_js_,
- input_numbervue_type_template_id_42f8cf66_render,
- input_numbervue_type_template_id_42f8cf66_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var input_number_api; }
- input_number_component.options.__file = "packages/input-number/src/input-number.vue"
- /* harmony default export */ var input_number = (input_number_component.exports);
- // CONCATENATED MODULE: ./packages/input-number/index.js
- /* istanbul ignore next */
- input_number.install = function (Vue) {
- Vue.component(input_number.name, input_number);
- };
- /* harmony default export */ var packages_input_number = (input_number);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio.vue?vue&type=template&id=69cd6268&
- var radiovue_type_template_id_69cd6268_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "label",
- {
- staticClass: "el-radio",
- class: [
- _vm.border && _vm.radioSize ? "el-radio--" + _vm.radioSize : "",
- { "is-disabled": _vm.isDisabled },
- { "is-focus": _vm.focus },
- { "is-bordered": _vm.border },
- { "is-checked": _vm.model === _vm.label }
- ],
- attrs: {
- role: "radio",
- "aria-checked": _vm.model === _vm.label,
- "aria-disabled": _vm.isDisabled,
- tabindex: _vm.tabIndex
- },
- on: {
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "space", 32, $event.key, [" ", "Spacebar"])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.model = _vm.isDisabled ? _vm.model : _vm.label
- }
- }
- },
- [
- _c(
- "span",
- {
- staticClass: "el-radio__input",
- class: {
- "is-disabled": _vm.isDisabled,
- "is-checked": _vm.model === _vm.label
- }
- },
- [
- _c("span", { staticClass: "el-radio__inner" }),
- _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model",
- value: _vm.model,
- expression: "model"
- }
- ],
- ref: "radio",
- staticClass: "el-radio__original",
- attrs: {
- type: "radio",
- "aria-hidden": "true",
- name: _vm.name,
- disabled: _vm.isDisabled,
- tabindex: "-1",
- autocomplete: "off"
- },
- domProps: {
- value: _vm.label,
- checked: _vm._q(_vm.model, _vm.label)
- },
- on: {
- focus: function($event) {
- _vm.focus = true
- },
- blur: function($event) {
- _vm.focus = false
- },
- change: [
- function($event) {
- _vm.model = _vm.label
- },
- _vm.handleChange
- ]
- }
- })
- ]
- ),
- _c(
- "span",
- {
- staticClass: "el-radio__label",
- on: {
- keydown: function($event) {
- $event.stopPropagation()
- }
- }
- },
- [
- _vm._t("default"),
- !_vm.$slots.default ? [_vm._v(_vm._s(_vm.label))] : _vm._e()
- ],
- 2
- )
- ]
- )
- }
- var radiovue_type_template_id_69cd6268_staticRenderFns = []
- radiovue_type_template_id_69cd6268_render._withStripped = true
- // CONCATENATED MODULE: ./packages/radio/src/radio.vue?vue&type=template&id=69cd6268&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var radiovue_type_script_lang_js_ = ({
- name: 'ElRadio',
- mixins: [emitter_default.a],
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- componentName: 'ElRadio',
- props: {
- value: {},
- label: {},
- disabled: Boolean,
- name: String,
- border: Boolean,
- size: String
- },
- data: function data() {
- return {
- focus: false
- };
- },
- computed: {
- isGroup: function isGroup() {
- var parent = this.$parent;
- while (parent) {
- if (parent.$options.componentName !== 'ElRadioGroup') {
- parent = parent.$parent;
- } else {
- this._radioGroup = parent;
- return true;
- }
- }
- return false;
- },
- model: {
- get: function get() {
- return this.isGroup ? this._radioGroup.value : this.value;
- },
- set: function set(val) {
- if (this.isGroup) {
- this.dispatch('ElRadioGroup', 'input', [val]);
- } else {
- this.$emit('input', val);
- }
- this.$refs.radio && (this.$refs.radio.checked = this.model === this.label);
- }
- },
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- radioSize: function radioSize() {
- var temRadioSize = this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- return this.isGroup ? this._radioGroup.radioGroupSize || temRadioSize : temRadioSize;
- },
- isDisabled: function isDisabled() {
- return this.isGroup ? this._radioGroup.disabled || this.disabled || (this.elForm || {}).disabled : this.disabled || (this.elForm || {}).disabled;
- },
- tabIndex: function tabIndex() {
- return this.isDisabled || this.isGroup && this.model !== this.label ? -1 : 0;
- }
- },
- methods: {
- handleChange: function handleChange() {
- var _this = this;
- this.$nextTick(function () {
- _this.$emit('change', _this.model);
- _this.isGroup && _this.dispatch('ElRadioGroup', 'handleChange', _this.model);
- });
- }
- }
- });
- // CONCATENATED MODULE: ./packages/radio/src/radio.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_radiovue_type_script_lang_js_ = (radiovue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/radio/src/radio.vue
- /* normalize component */
- var radio_component = normalizeComponent(
- src_radiovue_type_script_lang_js_,
- radiovue_type_template_id_69cd6268_render,
- radiovue_type_template_id_69cd6268_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var radio_api; }
- radio_component.options.__file = "packages/radio/src/radio.vue"
- /* harmony default export */ var src_radio = (radio_component.exports);
- // CONCATENATED MODULE: ./packages/radio/index.js
- /* istanbul ignore next */
- src_radio.install = function (Vue) {
- Vue.component(src_radio.name, src_radio);
- };
- /* harmony default export */ var packages_radio = (src_radio);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio-group.vue?vue&type=template&id=818a704c&
- var radio_groupvue_type_template_id_818a704c_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- _vm._elTag,
- {
- tag: "component",
- staticClass: "el-radio-group",
- attrs: { role: "radiogroup" },
- on: { keydown: _vm.handleKeydown }
- },
- [_vm._t("default")],
- 2
- )
- }
- var radio_groupvue_type_template_id_818a704c_staticRenderFns = []
- radio_groupvue_type_template_id_818a704c_render._withStripped = true
- // CONCATENATED MODULE: ./packages/radio/src/radio-group.vue?vue&type=template&id=818a704c&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio-group.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var keyCode = Object.freeze({
- LEFT: 37,
- UP: 38,
- RIGHT: 39,
- DOWN: 40
- });
- /* harmony default export */ var radio_groupvue_type_script_lang_js_ = ({
- name: 'ElRadioGroup',
- componentName: 'ElRadioGroup',
- inject: {
- elFormItem: {
- default: ''
- }
- },
- mixins: [emitter_default.a],
- props: {
- value: {},
- size: String,
- fill: String,
- textColor: String,
- disabled: Boolean
- },
- computed: {
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- _elTag: function _elTag() {
- var tag = (this.$vnode.data || {}).tag;
- if (!tag || tag === 'component') tag = 'div';
- return tag;
- },
- radioGroupSize: function radioGroupSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- }
- },
- created: function created() {
- var _this = this;
- this.$on('handleChange', function (value) {
- _this.$emit('change', value);
- });
- },
- mounted: function mounted() {
- // 当radioGroup没有默认选项时,第一个可以选中Tab导航
- var radios = this.$el.querySelectorAll('[type=radio]');
- var firstLabel = this.$el.querySelectorAll('[role=radio]')[0];
- if (![].some.call(radios, function (radio) {
- return radio.checked;
- }) && firstLabel) {
- firstLabel.tabIndex = 0;
- }
- },
- methods: {
- handleKeydown: function handleKeydown(e) {
- // 左右上下按键 可以在radio组内切换不同选项
- var target = e.target;
- var className = target.nodeName === 'INPUT' ? '[type=radio]' : '[role=radio]';
- var radios = this.$el.querySelectorAll(className);
- var length = radios.length;
- var index = [].indexOf.call(radios, target);
- var roleRadios = this.$el.querySelectorAll('[role=radio]');
- switch (e.keyCode) {
- case keyCode.LEFT:
- case keyCode.UP:
- e.stopPropagation();
- e.preventDefault();
- if (index === 0) {
- roleRadios[length - 1].click();
- roleRadios[length - 1].focus();
- } else {
- roleRadios[index - 1].click();
- roleRadios[index - 1].focus();
- }
- break;
- case keyCode.RIGHT:
- case keyCode.DOWN:
- if (index === length - 1) {
- e.stopPropagation();
- e.preventDefault();
- roleRadios[0].click();
- roleRadios[0].focus();
- } else {
- roleRadios[index + 1].click();
- roleRadios[index + 1].focus();
- }
- break;
- default:
- break;
- }
- }
- },
- watch: {
- value: function value(_value) {
- this.dispatch('ElFormItem', 'el.form.change', [this.value]);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/radio/src/radio-group.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_radio_groupvue_type_script_lang_js_ = (radio_groupvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/radio/src/radio-group.vue
- /* normalize component */
- var radio_group_component = normalizeComponent(
- src_radio_groupvue_type_script_lang_js_,
- radio_groupvue_type_template_id_818a704c_render,
- radio_groupvue_type_template_id_818a704c_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var radio_group_api; }
- radio_group_component.options.__file = "packages/radio/src/radio-group.vue"
- /* harmony default export */ var radio_group = (radio_group_component.exports);
- // CONCATENATED MODULE: ./packages/radio-group/index.js
- /* istanbul ignore next */
- radio_group.install = function (Vue) {
- Vue.component(radio_group.name, radio_group);
- };
- /* harmony default export */ var packages_radio_group = (radio_group);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio-button.vue?vue&type=template&id=18a77a32&
- var radio_buttonvue_type_template_id_18a77a32_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "label",
- {
- staticClass: "el-radio-button",
- class: [
- _vm.size ? "el-radio-button--" + _vm.size : "",
- { "is-active": _vm.value === _vm.label },
- { "is-disabled": _vm.isDisabled },
- { "is-focus": _vm.focus }
- ],
- attrs: {
- role: "radio",
- "aria-checked": _vm.value === _vm.label,
- "aria-disabled": _vm.isDisabled,
- tabindex: _vm.tabIndex
- },
- on: {
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "space", 32, $event.key, [" ", "Spacebar"])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.value = _vm.isDisabled ? _vm.value : _vm.label
- }
- }
- },
- [
- _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model",
- value: _vm.value,
- expression: "value"
- }
- ],
- staticClass: "el-radio-button__orig-radio",
- attrs: {
- type: "radio",
- name: _vm.name,
- disabled: _vm.isDisabled,
- tabindex: "-1",
- autocomplete: "off"
- },
- domProps: { value: _vm.label, checked: _vm._q(_vm.value, _vm.label) },
- on: {
- change: [
- function($event) {
- _vm.value = _vm.label
- },
- _vm.handleChange
- ],
- focus: function($event) {
- _vm.focus = true
- },
- blur: function($event) {
- _vm.focus = false
- }
- }
- }),
- _c(
- "span",
- {
- staticClass: "el-radio-button__inner",
- style: _vm.value === _vm.label ? _vm.activeStyle : null,
- on: {
- keydown: function($event) {
- $event.stopPropagation()
- }
- }
- },
- [
- _vm._t("default"),
- !_vm.$slots.default ? [_vm._v(_vm._s(_vm.label))] : _vm._e()
- ],
- 2
- )
- ]
- )
- }
- var radio_buttonvue_type_template_id_18a77a32_staticRenderFns = []
- radio_buttonvue_type_template_id_18a77a32_render._withStripped = true
- // CONCATENATED MODULE: ./packages/radio/src/radio-button.vue?vue&type=template&id=18a77a32&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio-button.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var radio_buttonvue_type_script_lang_js_ = ({
- name: 'ElRadioButton',
- mixins: [emitter_default.a],
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- props: {
- label: {},
- disabled: Boolean,
- name: String
- },
- data: function data() {
- return {
- focus: false
- };
- },
- computed: {
- value: {
- get: function get() {
- return this._radioGroup.value;
- },
- set: function set(value) {
- this._radioGroup.$emit('input', value);
- }
- },
- _radioGroup: function _radioGroup() {
- var parent = this.$parent;
- while (parent) {
- if (parent.$options.componentName !== 'ElRadioGroup') {
- parent = parent.$parent;
- } else {
- return parent;
- }
- }
- return false;
- },
- activeStyle: function activeStyle() {
- return {
- backgroundColor: this._radioGroup.fill || '',
- borderColor: this._radioGroup.fill || '',
- boxShadow: this._radioGroup.fill ? '-1px 0 0 0 ' + this._radioGroup.fill : '',
- color: this._radioGroup.textColor || ''
- };
- },
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- size: function size() {
- return this._radioGroup.radioGroupSize || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- isDisabled: function isDisabled() {
- return this.disabled || this._radioGroup.disabled || (this.elForm || {}).disabled;
- },
- tabIndex: function tabIndex() {
- return this.isDisabled || this._radioGroup && this.value !== this.label ? -1 : 0;
- }
- },
- methods: {
- handleChange: function handleChange() {
- var _this = this;
- this.$nextTick(function () {
- _this.dispatch('ElRadioGroup', 'handleChange', _this.value);
- });
- }
- }
- });
- // CONCATENATED MODULE: ./packages/radio/src/radio-button.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_radio_buttonvue_type_script_lang_js_ = (radio_buttonvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/radio/src/radio-button.vue
- /* normalize component */
- var radio_button_component = normalizeComponent(
- src_radio_buttonvue_type_script_lang_js_,
- radio_buttonvue_type_template_id_18a77a32_render,
- radio_buttonvue_type_template_id_18a77a32_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var radio_button_api; }
- radio_button_component.options.__file = "packages/radio/src/radio-button.vue"
- /* harmony default export */ var radio_button = (radio_button_component.exports);
- // CONCATENATED MODULE: ./packages/radio-button/index.js
- /* istanbul ignore next */
- radio_button.install = function (Vue) {
- Vue.component(radio_button.name, radio_button);
- };
- /* harmony default export */ var packages_radio_button = (radio_button);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox.vue?vue&type=template&id=d0387074&
- var checkboxvue_type_template_id_d0387074_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "label",
- {
- staticClass: "el-checkbox",
- class: [
- _vm.border && _vm.checkboxSize
- ? "el-checkbox--" + _vm.checkboxSize
- : "",
- { "is-disabled": _vm.isDisabled },
- { "is-bordered": _vm.border },
- { "is-checked": _vm.isChecked }
- ],
- attrs: { id: _vm.id }
- },
- [
- _c(
- "span",
- {
- staticClass: "el-checkbox__input",
- class: {
- "is-disabled": _vm.isDisabled,
- "is-checked": _vm.isChecked,
- "is-indeterminate": _vm.indeterminate,
- "is-focus": _vm.focus
- },
- attrs: {
- tabindex: _vm.indeterminate ? 0 : false,
- role: _vm.indeterminate ? "checkbox" : false,
- "aria-checked": _vm.indeterminate ? "mixed" : false
- }
- },
- [
- _c("span", { staticClass: "el-checkbox__inner" }),
- _vm.trueLabel || _vm.falseLabel
- ? _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model",
- value: _vm.model,
- expression: "model"
- }
- ],
- staticClass: "el-checkbox__original",
- attrs: {
- type: "checkbox",
- "aria-hidden": _vm.indeterminate ? "true" : "false",
- name: _vm.name,
- disabled: _vm.isDisabled,
- "true-value": _vm.trueLabel,
- "false-value": _vm.falseLabel
- },
- domProps: {
- checked: Array.isArray(_vm.model)
- ? _vm._i(_vm.model, null) > -1
- : _vm._q(_vm.model, _vm.trueLabel)
- },
- on: {
- change: [
- function($event) {
- var $$a = _vm.model,
- $$el = $event.target,
- $$c = $$el.checked ? _vm.trueLabel : _vm.falseLabel
- if (Array.isArray($$a)) {
- var $$v = null,
- $$i = _vm._i($$a, $$v)
- if ($$el.checked) {
- $$i < 0 && (_vm.model = $$a.concat([$$v]))
- } else {
- $$i > -1 &&
- (_vm.model = $$a
- .slice(0, $$i)
- .concat($$a.slice($$i + 1)))
- }
- } else {
- _vm.model = $$c
- }
- },
- _vm.handleChange
- ],
- focus: function($event) {
- _vm.focus = true
- },
- blur: function($event) {
- _vm.focus = false
- }
- }
- })
- : _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model",
- value: _vm.model,
- expression: "model"
- }
- ],
- staticClass: "el-checkbox__original",
- attrs: {
- type: "checkbox",
- "aria-hidden": _vm.indeterminate ? "true" : "false",
- disabled: _vm.isDisabled,
- name: _vm.name
- },
- domProps: {
- value: _vm.label,
- checked: Array.isArray(_vm.model)
- ? _vm._i(_vm.model, _vm.label) > -1
- : _vm.model
- },
- on: {
- change: [
- function($event) {
- var $$a = _vm.model,
- $$el = $event.target,
- $$c = $$el.checked ? true : false
- if (Array.isArray($$a)) {
- var $$v = _vm.label,
- $$i = _vm._i($$a, $$v)
- if ($$el.checked) {
- $$i < 0 && (_vm.model = $$a.concat([$$v]))
- } else {
- $$i > -1 &&
- (_vm.model = $$a
- .slice(0, $$i)
- .concat($$a.slice($$i + 1)))
- }
- } else {
- _vm.model = $$c
- }
- },
- _vm.handleChange
- ],
- focus: function($event) {
- _vm.focus = true
- },
- blur: function($event) {
- _vm.focus = false
- }
- }
- })
- ]
- ),
- _vm.$slots.default || _vm.label
- ? _c(
- "span",
- { staticClass: "el-checkbox__label" },
- [
- _vm._t("default"),
- !_vm.$slots.default ? [_vm._v(_vm._s(_vm.label))] : _vm._e()
- ],
- 2
- )
- : _vm._e()
- ]
- )
- }
- var checkboxvue_type_template_id_d0387074_staticRenderFns = []
- checkboxvue_type_template_id_d0387074_render._withStripped = true
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue?vue&type=template&id=d0387074&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var checkboxvue_type_script_lang_js_ = ({
- name: 'ElCheckbox',
- mixins: [emitter_default.a],
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- componentName: 'ElCheckbox',
- data: function data() {
- return {
- selfModel: false,
- focus: false,
- isLimitExceeded: false
- };
- },
- computed: {
- model: {
- get: function get() {
- return this.isGroup ? this.store : this.value !== undefined ? this.value : this.selfModel;
- },
- set: function set(val) {
- if (this.isGroup) {
- this.isLimitExceeded = false;
- this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (this.isLimitExceeded = true);
- this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (this.isLimitExceeded = true);
- this.isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]);
- } else {
- this.$emit('input', val);
- this.selfModel = val;
- }
- }
- },
- isChecked: function isChecked() {
- if ({}.toString.call(this.model) === '[object Boolean]') {
- return this.model;
- } else if (Array.isArray(this.model)) {
- return this.model.indexOf(this.label) > -1;
- } else if (this.model !== null && this.model !== undefined) {
- return this.model === this.trueLabel;
- }
- },
- isGroup: function isGroup() {
- var parent = this.$parent;
- while (parent) {
- if (parent.$options.componentName !== 'ElCheckboxGroup') {
- parent = parent.$parent;
- } else {
- this._checkboxGroup = parent;
- return true;
- }
- }
- return false;
- },
- store: function store() {
- return this._checkboxGroup ? this._checkboxGroup.value : this.value;
- },
- /* used to make the isDisabled judgment under max/min props */
- isLimitDisabled: function isLimitDisabled() {
- var _checkboxGroup = this._checkboxGroup,
- max = _checkboxGroup.max,
- min = _checkboxGroup.min;
- return !!(max || min) && this.model.length >= max && !this.isChecked || this.model.length <= min && this.isChecked;
- },
- isDisabled: function isDisabled() {
- return this.isGroup ? this._checkboxGroup.disabled || this.disabled || (this.elForm || {}).disabled || this.isLimitDisabled : this.disabled || (this.elForm || {}).disabled;
- },
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- checkboxSize: function checkboxSize() {
- var temCheckboxSize = this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- return this.isGroup ? this._checkboxGroup.checkboxGroupSize || temCheckboxSize : temCheckboxSize;
- }
- },
- props: {
- value: {},
- label: {},
- indeterminate: Boolean,
- disabled: Boolean,
- checked: Boolean,
- name: String,
- trueLabel: [String, Number],
- falseLabel: [String, Number],
- id: String, /* 当indeterminate为真时,为controls提供相关连的checkbox的id,表明元素间的控制关系*/
- controls: String, /* 当indeterminate为真时,为controls提供相关连的checkbox的id,表明元素间的控制关系*/
- border: Boolean,
- size: String
- },
- methods: {
- addToStore: function addToStore() {
- if (Array.isArray(this.model) && this.model.indexOf(this.label) === -1) {
- this.model.push(this.label);
- } else {
- this.model = this.trueLabel || true;
- }
- },
- handleChange: function handleChange(ev) {
- var _this = this;
- if (this.isLimitExceeded) return;
- var value = void 0;
- if (ev.target.checked) {
- value = this.trueLabel === undefined ? true : this.trueLabel;
- } else {
- value = this.falseLabel === undefined ? false : this.falseLabel;
- }
- this.$emit('change', value, ev);
- this.$nextTick(function () {
- if (_this.isGroup) {
- _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]);
- }
- });
- }
- },
- created: function created() {
- this.checked && this.addToStore();
- },
- mounted: function mounted() {
- // 为indeterminate元素 添加aria-controls 属性
- if (this.indeterminate) {
- this.$el.setAttribute('aria-controls', this.controls);
- }
- },
- watch: {
- value: function value(_value) {
- this.dispatch('ElFormItem', 'el.form.change', _value);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_checkboxvue_type_script_lang_js_ = (checkboxvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue
- /* normalize component */
- var checkbox_component = normalizeComponent(
- src_checkboxvue_type_script_lang_js_,
- checkboxvue_type_template_id_d0387074_render,
- checkboxvue_type_template_id_d0387074_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var checkbox_api; }
- checkbox_component.options.__file = "packages/checkbox/src/checkbox.vue"
- /* harmony default export */ var src_checkbox = (checkbox_component.exports);
- // CONCATENATED MODULE: ./packages/checkbox/index.js
- /* istanbul ignore next */
- src_checkbox.install = function (Vue) {
- Vue.component(src_checkbox.name, src_checkbox);
- };
- /* harmony default export */ var packages_checkbox = (src_checkbox);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-button.vue?vue&type=template&id=478e906e&
- var checkbox_buttonvue_type_template_id_478e906e_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "label",
- {
- staticClass: "el-checkbox-button",
- class: [
- _vm.size ? "el-checkbox-button--" + _vm.size : "",
- { "is-disabled": _vm.isDisabled },
- { "is-checked": _vm.isChecked },
- { "is-focus": _vm.focus }
- ],
- attrs: {
- role: "checkbox",
- "aria-checked": _vm.isChecked,
- "aria-disabled": _vm.isDisabled
- }
- },
- [
- _vm.trueLabel || _vm.falseLabel
- ? _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model",
- value: _vm.model,
- expression: "model"
- }
- ],
- staticClass: "el-checkbox-button__original",
- attrs: {
- type: "checkbox",
- name: _vm.name,
- disabled: _vm.isDisabled,
- "true-value": _vm.trueLabel,
- "false-value": _vm.falseLabel
- },
- domProps: {
- checked: Array.isArray(_vm.model)
- ? _vm._i(_vm.model, null) > -1
- : _vm._q(_vm.model, _vm.trueLabel)
- },
- on: {
- change: [
- function($event) {
- var $$a = _vm.model,
- $$el = $event.target,
- $$c = $$el.checked ? _vm.trueLabel : _vm.falseLabel
- if (Array.isArray($$a)) {
- var $$v = null,
- $$i = _vm._i($$a, $$v)
- if ($$el.checked) {
- $$i < 0 && (_vm.model = $$a.concat([$$v]))
- } else {
- $$i > -1 &&
- (_vm.model = $$a
- .slice(0, $$i)
- .concat($$a.slice($$i + 1)))
- }
- } else {
- _vm.model = $$c
- }
- },
- _vm.handleChange
- ],
- focus: function($event) {
- _vm.focus = true
- },
- blur: function($event) {
- _vm.focus = false
- }
- }
- })
- : _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model",
- value: _vm.model,
- expression: "model"
- }
- ],
- staticClass: "el-checkbox-button__original",
- attrs: {
- type: "checkbox",
- name: _vm.name,
- disabled: _vm.isDisabled
- },
- domProps: {
- value: _vm.label,
- checked: Array.isArray(_vm.model)
- ? _vm._i(_vm.model, _vm.label) > -1
- : _vm.model
- },
- on: {
- change: [
- function($event) {
- var $$a = _vm.model,
- $$el = $event.target,
- $$c = $$el.checked ? true : false
- if (Array.isArray($$a)) {
- var $$v = _vm.label,
- $$i = _vm._i($$a, $$v)
- if ($$el.checked) {
- $$i < 0 && (_vm.model = $$a.concat([$$v]))
- } else {
- $$i > -1 &&
- (_vm.model = $$a
- .slice(0, $$i)
- .concat($$a.slice($$i + 1)))
- }
- } else {
- _vm.model = $$c
- }
- },
- _vm.handleChange
- ],
- focus: function($event) {
- _vm.focus = true
- },
- blur: function($event) {
- _vm.focus = false
- }
- }
- }),
- _vm.$slots.default || _vm.label
- ? _c(
- "span",
- {
- staticClass: "el-checkbox-button__inner",
- style: _vm.isChecked ? _vm.activeStyle : null
- },
- [_vm._t("default", [_vm._v(_vm._s(_vm.label))])],
- 2
- )
- : _vm._e()
- ]
- )
- }
- var checkbox_buttonvue_type_template_id_478e906e_staticRenderFns = []
- checkbox_buttonvue_type_template_id_478e906e_render._withStripped = true
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-button.vue?vue&type=template&id=478e906e&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-button.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var checkbox_buttonvue_type_script_lang_js_ = ({
- name: 'ElCheckboxButton',
- mixins: [emitter_default.a],
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- data: function data() {
- return {
- selfModel: false,
- focus: false,
- isLimitExceeded: false
- };
- },
- props: {
- value: {},
- label: {},
- disabled: Boolean,
- checked: Boolean,
- name: String,
- trueLabel: [String, Number],
- falseLabel: [String, Number]
- },
- computed: {
- model: {
- get: function get() {
- return this._checkboxGroup ? this.store : this.value !== undefined ? this.value : this.selfModel;
- },
- set: function set(val) {
- if (this._checkboxGroup) {
- this.isLimitExceeded = false;
- this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (this.isLimitExceeded = true);
- this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (this.isLimitExceeded = true);
- this.isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]);
- } else if (this.value !== undefined) {
- this.$emit('input', val);
- } else {
- this.selfModel = val;
- }
- }
- },
- isChecked: function isChecked() {
- if ({}.toString.call(this.model) === '[object Boolean]') {
- return this.model;
- } else if (Array.isArray(this.model)) {
- return this.model.indexOf(this.label) > -1;
- } else if (this.model !== null && this.model !== undefined) {
- return this.model === this.trueLabel;
- }
- },
- _checkboxGroup: function _checkboxGroup() {
- var parent = this.$parent;
- while (parent) {
- if (parent.$options.componentName !== 'ElCheckboxGroup') {
- parent = parent.$parent;
- } else {
- return parent;
- }
- }
- return false;
- },
- store: function store() {
- return this._checkboxGroup ? this._checkboxGroup.value : this.value;
- },
- activeStyle: function activeStyle() {
- return {
- backgroundColor: this._checkboxGroup.fill || '',
- borderColor: this._checkboxGroup.fill || '',
- color: this._checkboxGroup.textColor || '',
- 'box-shadow': '-1px 0 0 0 ' + this._checkboxGroup.fill
- };
- },
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- size: function size() {
- return this._checkboxGroup.checkboxGroupSize || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- /* used to make the isDisabled judgment under max/min props */
- isLimitDisabled: function isLimitDisabled() {
- var _checkboxGroup2 = this._checkboxGroup,
- max = _checkboxGroup2.max,
- min = _checkboxGroup2.min;
- return !!(max || min) && this.model.length >= max && !this.isChecked || this.model.length <= min && this.isChecked;
- },
- isDisabled: function isDisabled() {
- return this._checkboxGroup ? this._checkboxGroup.disabled || this.disabled || (this.elForm || {}).disabled || this.isLimitDisabled : this.disabled || (this.elForm || {}).disabled;
- }
- },
- methods: {
- addToStore: function addToStore() {
- if (Array.isArray(this.model) && this.model.indexOf(this.label) === -1) {
- this.model.push(this.label);
- } else {
- this.model = this.trueLabel || true;
- }
- },
- handleChange: function handleChange(ev) {
- var _this = this;
- if (this.isLimitExceeded) return;
- var value = void 0;
- if (ev.target.checked) {
- value = this.trueLabel === undefined ? true : this.trueLabel;
- } else {
- value = this.falseLabel === undefined ? false : this.falseLabel;
- }
- this.$emit('change', value, ev);
- this.$nextTick(function () {
- if (_this._checkboxGroup) {
- _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]);
- }
- });
- }
- },
- created: function created() {
- this.checked && this.addToStore();
- }
- });
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-button.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_checkbox_buttonvue_type_script_lang_js_ = (checkbox_buttonvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-button.vue
- /* normalize component */
- var checkbox_button_component = normalizeComponent(
- src_checkbox_buttonvue_type_script_lang_js_,
- checkbox_buttonvue_type_template_id_478e906e_render,
- checkbox_buttonvue_type_template_id_478e906e_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var checkbox_button_api; }
- checkbox_button_component.options.__file = "packages/checkbox/src/checkbox-button.vue"
- /* harmony default export */ var checkbox_button = (checkbox_button_component.exports);
- // CONCATENATED MODULE: ./packages/checkbox-button/index.js
- /* istanbul ignore next */
- checkbox_button.install = function (Vue) {
- Vue.component(checkbox_button.name, checkbox_button);
- };
- /* harmony default export */ var packages_checkbox_button = (checkbox_button);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-group.vue?vue&type=template&id=7289a290&
- var checkbox_groupvue_type_template_id_7289a290_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-checkbox-group",
- attrs: { role: "group", "aria-label": "checkbox-group" }
- },
- [_vm._t("default")],
- 2
- )
- }
- var checkbox_groupvue_type_template_id_7289a290_staticRenderFns = []
- checkbox_groupvue_type_template_id_7289a290_render._withStripped = true
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue?vue&type=template&id=7289a290&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-group.vue?vue&type=script&lang=js&
- /* harmony default export */ var checkbox_groupvue_type_script_lang_js_ = ({
- name: 'ElCheckboxGroup',
- componentName: 'ElCheckboxGroup',
- mixins: [emitter_default.a],
- inject: {
- elFormItem: {
- default: ''
- }
- },
- props: {
- value: {},
- disabled: Boolean,
- min: Number,
- max: Number,
- size: String,
- fill: String,
- textColor: String
- },
- computed: {
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- checkboxGroupSize: function checkboxGroupSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- }
- },
- watch: {
- value: function value(_value) {
- this.dispatch('ElFormItem', 'el.form.change', [_value]);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_checkbox_groupvue_type_script_lang_js_ = (checkbox_groupvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue
- /* normalize component */
- var checkbox_group_component = normalizeComponent(
- src_checkbox_groupvue_type_script_lang_js_,
- checkbox_groupvue_type_template_id_7289a290_render,
- checkbox_groupvue_type_template_id_7289a290_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var checkbox_group_api; }
- checkbox_group_component.options.__file = "packages/checkbox/src/checkbox-group.vue"
- /* harmony default export */ var checkbox_group = (checkbox_group_component.exports);
- // CONCATENATED MODULE: ./packages/checkbox-group/index.js
- /* istanbul ignore next */
- checkbox_group.install = function (Vue) {
- Vue.component(checkbox_group.name, checkbox_group);
- };
- /* harmony default export */ var packages_checkbox_group = (checkbox_group);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/switch/src/component.vue?vue&type=template&id=2dcd8fbb&
- var componentvue_type_template_id_2dcd8fbb_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-switch",
- class: { "is-disabled": _vm.switchDisabled, "is-checked": _vm.checked },
- attrs: {
- role: "switch",
- "aria-checked": _vm.checked,
- "aria-disabled": _vm.switchDisabled
- },
- on: {
- click: function($event) {
- $event.preventDefault()
- return _vm.switchValue($event)
- }
- }
- },
- [
- _c("input", {
- ref: "input",
- staticClass: "el-switch__input",
- attrs: {
- type: "checkbox",
- id: _vm.id,
- name: _vm.name,
- "true-value": _vm.activeValue,
- "false-value": _vm.inactiveValue,
- disabled: _vm.switchDisabled
- },
- on: {
- change: _vm.handleChange,
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")
- ) {
- return null
- }
- return _vm.switchValue($event)
- }
- }
- }),
- _vm.inactiveIconClass || _vm.inactiveText
- ? _c(
- "span",
- {
- class: [
- "el-switch__label",
- "el-switch__label--left",
- !_vm.checked ? "is-active" : ""
- ]
- },
- [
- _vm.inactiveIconClass
- ? _c("i", { class: [_vm.inactiveIconClass] })
- : _vm._e(),
- !_vm.inactiveIconClass && _vm.inactiveText
- ? _c("span", { attrs: { "aria-hidden": _vm.checked } }, [
- _vm._v(_vm._s(_vm.inactiveText))
- ])
- : _vm._e()
- ]
- )
- : _vm._e(),
- _c("span", {
- ref: "core",
- staticClass: "el-switch__core",
- style: { width: _vm.coreWidth + "px" }
- }),
- _vm.activeIconClass || _vm.activeText
- ? _c(
- "span",
- {
- class: [
- "el-switch__label",
- "el-switch__label--right",
- _vm.checked ? "is-active" : ""
- ]
- },
- [
- _vm.activeIconClass
- ? _c("i", { class: [_vm.activeIconClass] })
- : _vm._e(),
- !_vm.activeIconClass && _vm.activeText
- ? _c("span", { attrs: { "aria-hidden": !_vm.checked } }, [
- _vm._v(_vm._s(_vm.activeText))
- ])
- : _vm._e()
- ]
- )
- : _vm._e()
- ]
- )
- }
- var componentvue_type_template_id_2dcd8fbb_staticRenderFns = []
- componentvue_type_template_id_2dcd8fbb_render._withStripped = true
- // CONCATENATED MODULE: ./packages/switch/src/component.vue?vue&type=template&id=2dcd8fbb&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/switch/src/component.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var switch_src_componentvue_type_script_lang_js_ = ({
- name: 'ElSwitch',
- mixins: [focus_default()('input'), migrating_default.a, emitter_default.a],
- inject: {
- elForm: {
- default: ''
- }
- },
- props: {
- value: {
- type: [Boolean, String, Number],
- default: false
- },
- disabled: {
- type: Boolean,
- default: false
- },
- width: {
- type: Number,
- default: 40
- },
- activeIconClass: {
- type: String,
- default: ''
- },
- inactiveIconClass: {
- type: String,
- default: ''
- },
- activeText: String,
- inactiveText: String,
- activeColor: {
- type: String,
- default: ''
- },
- inactiveColor: {
- type: String,
- default: ''
- },
- activeValue: {
- type: [Boolean, String, Number],
- default: true
- },
- inactiveValue: {
- type: [Boolean, String, Number],
- default: false
- },
- name: {
- type: String,
- default: ''
- },
- validateEvent: {
- type: Boolean,
- default: true
- },
- id: String
- },
- data: function data() {
- return {
- coreWidth: this.width
- };
- },
- created: function created() {
- if (!~[this.activeValue, this.inactiveValue].indexOf(this.value)) {
- this.$emit('input', this.inactiveValue);
- }
- },
- computed: {
- checked: function checked() {
- return this.value === this.activeValue;
- },
- switchDisabled: function switchDisabled() {
- return this.disabled || (this.elForm || {}).disabled;
- }
- },
- watch: {
- checked: function checked() {
- this.$refs.input.checked = this.checked;
- if (this.activeColor || this.inactiveColor) {
- this.setBackgroundColor();
- }
- if (this.validateEvent) {
- this.dispatch('ElFormItem', 'el.form.change', [this.value]);
- }
- }
- },
- methods: {
- handleChange: function handleChange(event) {
- var _this = this;
- var val = this.checked ? this.inactiveValue : this.activeValue;
- this.$emit('input', val);
- this.$emit('change', val);
- this.$nextTick(function () {
- // set input's checked property
- // in case parent refuses to change component's value
- if (_this.$refs.input) {
- _this.$refs.input.checked = _this.checked;
- }
- });
- },
- setBackgroundColor: function setBackgroundColor() {
- var newColor = this.checked ? this.activeColor : this.inactiveColor;
- this.$refs.core.style.borderColor = newColor;
- this.$refs.core.style.backgroundColor = newColor;
- },
- switchValue: function switchValue() {
- !this.switchDisabled && this.handleChange();
- },
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'on-color': 'on-color is renamed to active-color.',
- 'off-color': 'off-color is renamed to inactive-color.',
- 'on-text': 'on-text is renamed to active-text.',
- 'off-text': 'off-text is renamed to inactive-text.',
- 'on-value': 'on-value is renamed to active-value.',
- 'off-value': 'off-value is renamed to inactive-value.',
- 'on-icon-class': 'on-icon-class is renamed to active-icon-class.',
- 'off-icon-class': 'off-icon-class is renamed to inactive-icon-class.'
- }
- };
- }
- },
- mounted: function mounted() {
- /* istanbul ignore if */
- this.coreWidth = this.width || 40;
- if (this.activeColor || this.inactiveColor) {
- this.setBackgroundColor();
- }
- this.$refs.input.checked = this.checked;
- }
- });
- // CONCATENATED MODULE: ./packages/switch/src/component.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_switch_src_componentvue_type_script_lang_js_ = (switch_src_componentvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/switch/src/component.vue
- /* normalize component */
- var src_component_component = normalizeComponent(
- packages_switch_src_componentvue_type_script_lang_js_,
- componentvue_type_template_id_2dcd8fbb_render,
- componentvue_type_template_id_2dcd8fbb_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var src_component_api; }
- src_component_component.options.__file = "packages/switch/src/component.vue"
- /* harmony default export */ var switch_src_component = (src_component_component.exports);
- // CONCATENATED MODULE: ./packages/switch/index.js
- /* istanbul ignore next */
- switch_src_component.install = function (Vue) {
- Vue.component(switch_src_component.name, switch_src_component);
- };
- /* harmony default export */ var packages_switch = (switch_src_component);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select.vue?vue&type=template&id=0e4aade6&
- var selectvue_type_template_id_0e4aade6_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: _vm.handleClose,
- expression: "handleClose"
- }
- ],
- staticClass: "el-select",
- class: [_vm.selectSize ? "el-select--" + _vm.selectSize : ""],
- on: {
- click: function($event) {
- $event.stopPropagation()
- return _vm.toggleMenu($event)
- }
- }
- },
- [
- _vm.multiple
- ? _c(
- "div",
- {
- ref: "tags",
- staticClass: "el-select__tags",
- style: { "max-width": _vm.inputWidth - 32 + "px", width: "100%" }
- },
- [
- _vm.collapseTags && _vm.selected.length
- ? _c(
- "span",
- [
- _c(
- "el-tag",
- {
- attrs: {
- closable: !_vm.selectDisabled,
- size: _vm.collapseTagSize,
- hit: _vm.selected[0].hitState,
- type: "info",
- "disable-transitions": ""
- },
- on: {
- close: function($event) {
- _vm.deleteTag($event, _vm.selected[0])
- }
- }
- },
- [
- _c("span", { staticClass: "el-select__tags-text" }, [
- _vm._v(_vm._s(_vm.selected[0].currentLabel))
- ])
- ]
- ),
- _vm.selected.length > 1
- ? _c(
- "el-tag",
- {
- attrs: {
- closable: false,
- size: _vm.collapseTagSize,
- type: "info",
- "disable-transitions": ""
- }
- },
- [
- _c(
- "span",
- { staticClass: "el-select__tags-text" },
- [_vm._v("+ " + _vm._s(_vm.selected.length - 1))]
- )
- ]
- )
- : _vm._e()
- ],
- 1
- )
- : _vm._e(),
- !_vm.collapseTags
- ? _c(
- "transition-group",
- { on: { "after-leave": _vm.resetInputHeight } },
- _vm._l(_vm.selected, function(item) {
- return _c(
- "el-tag",
- {
- key: _vm.getValueKey(item),
- attrs: {
- closable: !_vm.selectDisabled,
- size: _vm.collapseTagSize,
- hit: item.hitState,
- type: "info",
- "disable-transitions": ""
- },
- on: {
- close: function($event) {
- _vm.deleteTag($event, item)
- }
- }
- },
- [
- _c("span", { staticClass: "el-select__tags-text" }, [
- _vm._v(_vm._s(item.currentLabel))
- ])
- ]
- )
- }),
- 1
- )
- : _vm._e(),
- _vm.filterable
- ? _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model",
- value: _vm.query,
- expression: "query"
- }
- ],
- ref: "input",
- staticClass: "el-select__input",
- class: [_vm.selectSize ? "is-" + _vm.selectSize : ""],
- style: {
- "flex-grow": "1",
- width: _vm.inputLength / (_vm.inputWidth - 32) + "%",
- "max-width": _vm.inputWidth - 42 + "px"
- },
- attrs: {
- type: "text",
- disabled: _vm.selectDisabled,
- autocomplete: _vm.autoComplete || _vm.autocomplete
- },
- domProps: { value: _vm.query },
- on: {
- focus: _vm.handleFocus,
- blur: function($event) {
- _vm.softFocus = false
- },
- keyup: _vm.managePlaceholder,
- keydown: [
- _vm.resetInputState,
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "down", 40, $event.key, [
- "Down",
- "ArrowDown"
- ])
- ) {
- return null
- }
- $event.preventDefault()
- _vm.handleNavigate("next")
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "up", 38, $event.key, [
- "Up",
- "ArrowUp"
- ])
- ) {
- return null
- }
- $event.preventDefault()
- _vm.handleNavigate("prev")
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k(
- $event.keyCode,
- "enter",
- 13,
- $event.key,
- "Enter"
- )
- ) {
- return null
- }
- $event.preventDefault()
- return _vm.selectOption($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "esc", 27, $event.key, [
- "Esc",
- "Escape"
- ])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.visible = false
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k(
- $event.keyCode,
- "delete",
- [8, 46],
- $event.key,
- ["Backspace", "Delete", "Del"]
- )
- ) {
- return null
- }
- return _vm.deletePrevTag($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "tab", 9, $event.key, "Tab")
- ) {
- return null
- }
- _vm.visible = false
- }
- ],
- compositionstart: _vm.handleComposition,
- compositionupdate: _vm.handleComposition,
- compositionend: _vm.handleComposition,
- input: [
- function($event) {
- if ($event.target.composing) {
- return
- }
- _vm.query = $event.target.value
- },
- _vm.debouncedQueryChange
- ]
- }
- })
- : _vm._e()
- ],
- 1
- )
- : _vm._e(),
- _c(
- "el-input",
- {
- ref: "reference",
- class: { "is-focus": _vm.visible },
- attrs: {
- type: "text",
- placeholder: _vm.currentPlaceholder,
- name: _vm.name,
- id: _vm.id,
- autocomplete: _vm.autoComplete || _vm.autocomplete,
- size: _vm.selectSize,
- disabled: _vm.selectDisabled,
- readonly: _vm.readonly,
- "validate-event": false,
- tabindex: _vm.multiple && _vm.filterable ? "-1" : null
- },
- on: {
- focus: _vm.handleFocus,
- blur: _vm.handleBlur,
- input: _vm.debouncedOnInputChange,
- compositionstart: _vm.handleComposition,
- compositionupdate: _vm.handleComposition,
- compositionend: _vm.handleComposition
- },
- nativeOn: {
- keydown: [
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "down", 40, $event.key, [
- "Down",
- "ArrowDown"
- ])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.handleNavigate("next")
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "up", 38, $event.key, [
- "Up",
- "ArrowUp"
- ])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.handleNavigate("prev")
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")
- ) {
- return null
- }
- $event.preventDefault()
- return _vm.selectOption($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "esc", 27, $event.key, [
- "Esc",
- "Escape"
- ])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.visible = false
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "tab", 9, $event.key, "Tab")
- ) {
- return null
- }
- _vm.visible = false
- }
- ],
- mouseenter: function($event) {
- _vm.inputHovering = true
- },
- mouseleave: function($event) {
- _vm.inputHovering = false
- }
- },
- model: {
- value: _vm.selectedLabel,
- callback: function($$v) {
- _vm.selectedLabel = $$v
- },
- expression: "selectedLabel"
- }
- },
- [
- _vm.$slots.prefix
- ? _c("template", { slot: "prefix" }, [_vm._t("prefix")], 2)
- : _vm._e(),
- _c("template", { slot: "suffix" }, [
- _c("i", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: !_vm.showClose,
- expression: "!showClose"
- }
- ],
- class: [
- "el-select__caret",
- "el-input__icon",
- "el-icon-" + _vm.iconClass
- ]
- }),
- _vm.showClose
- ? _c("i", {
- staticClass:
- "el-select__caret el-input__icon el-icon-circle-close",
- on: { click: _vm.handleClearClick }
- })
- : _vm._e()
- ])
- ],
- 2
- ),
- _c(
- "transition",
- {
- attrs: { name: "el-zoom-in-top" },
- on: {
- "before-enter": _vm.handleMenuEnter,
- "after-leave": _vm.doDestroy
- }
- },
- [
- _c(
- "el-select-menu",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible && _vm.emptyText !== false,
- expression: "visible && emptyText !== false"
- }
- ],
- ref: "popper",
- attrs: { "append-to-body": _vm.popperAppendToBody }
- },
- [
- _c(
- "el-scrollbar",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.options.length > 0 && !_vm.loading,
- expression: "options.length > 0 && !loading"
- }
- ],
- ref: "scrollbar",
- class: {
- "is-empty":
- !_vm.allowCreate &&
- _vm.query &&
- _vm.filteredOptionsCount === 0
- },
- attrs: {
- tag: "ul",
- "wrap-class": "el-select-dropdown__wrap",
- "view-class": "el-select-dropdown__list"
- }
- },
- [
- _vm.showNewOption
- ? _c("el-option", {
- attrs: { value: _vm.query, created: "" }
- })
- : _vm._e(),
- _vm._t("default")
- ],
- 2
- ),
- _vm.emptyText &&
- (!_vm.allowCreate ||
- _vm.loading ||
- (_vm.allowCreate && _vm.options.length === 0))
- ? [
- _vm.$slots.empty
- ? _vm._t("empty")
- : _c("p", { staticClass: "el-select-dropdown__empty" }, [
- _vm._v(
- "\n " +
- _vm._s(_vm.emptyText) +
- "\n "
- )
- ])
- ]
- : _vm._e()
- ],
- 2
- )
- ],
- 1
- )
- ],
- 1
- )
- }
- var selectvue_type_template_id_0e4aade6_staticRenderFns = []
- selectvue_type_template_id_0e4aade6_render._withStripped = true
- // CONCATENATED MODULE: ./packages/select/src/select.vue?vue&type=template&id=0e4aade6&
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select-dropdown.vue?vue&type=template&id=06828748&
- var select_dropdownvue_type_template_id_06828748_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-select-dropdown el-popper",
- class: [{ "is-multiple": _vm.$parent.multiple }, _vm.popperClass],
- style: { minWidth: _vm.minWidth }
- },
- [_vm._t("default")],
- 2
- )
- }
- var select_dropdownvue_type_template_id_06828748_staticRenderFns = []
- select_dropdownvue_type_template_id_06828748_render._withStripped = true
- // CONCATENATED MODULE: ./packages/select/src/select-dropdown.vue?vue&type=template&id=06828748&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select-dropdown.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var select_dropdownvue_type_script_lang_js_ = ({
- name: 'ElSelectDropdown',
- componentName: 'ElSelectDropdown',
- mixins: [vue_popper_default.a],
- props: {
- placement: {
- default: 'bottom-start'
- },
- boundariesPadding: {
- default: 0
- },
- popperOptions: {
- default: function _default() {
- return {
- gpuAcceleration: false
- };
- }
- },
- visibleArrow: {
- default: true
- },
- appendToBody: {
- type: Boolean,
- default: true
- }
- },
- data: function data() {
- return {
- minWidth: ''
- };
- },
- computed: {
- popperClass: function popperClass() {
- return this.$parent.popperClass;
- }
- },
- watch: {
- '$parent.inputWidth': function $parentInputWidth() {
- this.minWidth = this.$parent.$el.getBoundingClientRect().width + 'px';
- }
- },
- mounted: function mounted() {
- var _this = this;
- this.referenceElm = this.$parent.$refs.reference.$el;
- this.$parent.popperElm = this.popperElm = this.$el;
- this.$on('updatePopper', function () {
- if (_this.$parent.visible) _this.updatePopper();
- });
- this.$on('destroyPopper', this.destroyPopper);
- }
- });
- // CONCATENATED MODULE: ./packages/select/src/select-dropdown.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_select_dropdownvue_type_script_lang_js_ = (select_dropdownvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/select/src/select-dropdown.vue
- /* normalize component */
- var select_dropdown_component = normalizeComponent(
- src_select_dropdownvue_type_script_lang_js_,
- select_dropdownvue_type_template_id_06828748_render,
- select_dropdownvue_type_template_id_06828748_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var select_dropdown_api; }
- select_dropdown_component.options.__file = "packages/select/src/select-dropdown.vue"
- /* harmony default export */ var select_dropdown = (select_dropdown_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option.vue?vue&type=template&id=7a44c642&
- var optionvue_type_template_id_7a44c642_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "li",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-select-dropdown__item",
- class: {
- selected: _vm.itemSelected,
- "is-disabled": _vm.disabled || _vm.groupDisabled || _vm.limitReached,
- hover: _vm.hover
- },
- on: {
- mouseenter: _vm.hoverItem,
- click: function($event) {
- $event.stopPropagation()
- return _vm.selectOptionClick($event)
- }
- }
- },
- [_vm._t("default", [_c("span", [_vm._v(_vm._s(_vm.currentLabel))])])],
- 2
- )
- }
- var optionvue_type_template_id_7a44c642_staticRenderFns = []
- optionvue_type_template_id_7a44c642_render._withStripped = true
- // CONCATENATED MODULE: ./packages/select/src/option.vue?vue&type=template&id=7a44c642&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option.vue?vue&type=script&lang=js&
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var optionvue_type_script_lang_js_ = ({
- mixins: [emitter_default.a],
- name: 'ElOption',
- componentName: 'ElOption',
- inject: ['select'],
- props: {
- value: {
- required: true
- },
- label: [String, Number],
- created: Boolean,
- disabled: {
- type: Boolean,
- default: false
- }
- },
- data: function data() {
- return {
- index: -1,
- groupDisabled: false,
- visible: true,
- hitState: false,
- hover: false
- };
- },
- computed: {
- isObject: function isObject() {
- return Object.prototype.toString.call(this.value).toLowerCase() === '[object object]';
- },
- currentLabel: function currentLabel() {
- return this.label || (this.isObject ? '' : this.value);
- },
- currentValue: function currentValue() {
- return this.value || this.label || '';
- },
- itemSelected: function itemSelected() {
- if (!this.select.multiple) {
- return this.isEqual(this.value, this.select.value);
- } else {
- return this.contains(this.select.value, this.value);
- }
- },
- limitReached: function limitReached() {
- if (this.select.multiple) {
- return !this.itemSelected && (this.select.value || []).length >= this.select.multipleLimit && this.select.multipleLimit > 0;
- } else {
- return false;
- }
- }
- },
- watch: {
- currentLabel: function currentLabel() {
- if (!this.created && !this.select.remote) this.dispatch('ElSelect', 'setSelected');
- },
- value: function value(val, oldVal) {
- var _select = this.select,
- remote = _select.remote,
- valueKey = _select.valueKey;
- if (!this.created && !remote) {
- if (valueKey && (typeof val === 'undefined' ? 'undefined' : _typeof(val)) === 'object' && (typeof oldVal === 'undefined' ? 'undefined' : _typeof(oldVal)) === 'object' && val[valueKey] === oldVal[valueKey]) {
- return;
- }
- this.dispatch('ElSelect', 'setSelected');
- }
- }
- },
- methods: {
- isEqual: function isEqual(a, b) {
- if (!this.isObject) {
- return a === b;
- } else {
- var valueKey = this.select.valueKey;
- return Object(util_["getValueByPath"])(a, valueKey) === Object(util_["getValueByPath"])(b, valueKey);
- }
- },
- contains: function contains() {
- var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- var target = arguments[1];
- if (!this.isObject) {
- return arr && arr.indexOf(target) > -1;
- } else {
- var valueKey = this.select.valueKey;
- return arr && arr.some(function (item) {
- return Object(util_["getValueByPath"])(item, valueKey) === Object(util_["getValueByPath"])(target, valueKey);
- });
- }
- },
- handleGroupDisabled: function handleGroupDisabled(val) {
- this.groupDisabled = val;
- },
- hoverItem: function hoverItem() {
- if (!this.disabled && !this.groupDisabled) {
- this.select.hoverIndex = this.select.options.indexOf(this);
- }
- },
- selectOptionClick: function selectOptionClick() {
- if (this.disabled !== true && this.groupDisabled !== true) {
- this.dispatch('ElSelect', 'handleOptionClick', [this, true]);
- }
- },
- queryChange: function queryChange(query) {
- this.visible = new RegExp(Object(util_["escapeRegexpString"])(query), 'i').test(this.currentLabel) || this.created;
- if (!this.visible) {
- this.select.filteredOptionsCount--;
- }
- }
- },
- created: function created() {
- this.select.options.push(this);
- this.select.cachedOptions.push(this);
- this.select.optionsCount++;
- this.select.filteredOptionsCount++;
- this.$on('queryChange', this.queryChange);
- this.$on('handleGroupDisabled', this.handleGroupDisabled);
- },
- beforeDestroy: function beforeDestroy() {
- var _select2 = this.select,
- selected = _select2.selected,
- multiple = _select2.multiple;
- var selectedOptions = multiple ? selected : [selected];
- var index = this.select.cachedOptions.indexOf(this);
- var selectedIndex = selectedOptions.indexOf(this);
- // if option is not selected, remove it from cache
- if (index > -1 && selectedIndex < 0) {
- this.select.cachedOptions.splice(index, 1);
- }
- this.select.onOptionDestroy(this.select.options.indexOf(this));
- }
- });
- // CONCATENATED MODULE: ./packages/select/src/option.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_optionvue_type_script_lang_js_ = (optionvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/select/src/option.vue
- /* normalize component */
- var option_component = normalizeComponent(
- src_optionvue_type_script_lang_js_,
- optionvue_type_template_id_7a44c642_render,
- optionvue_type_template_id_7a44c642_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var option_api; }
- option_component.options.__file = "packages/select/src/option.vue"
- /* harmony default export */ var src_option = (option_component.exports);
- // EXTERNAL MODULE: external "element-ui/lib/tag"
- var tag_ = __webpack_require__(30);
- var tag_default = /*#__PURE__*/__webpack_require__.n(tag_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/resize-event"
- var resize_event_ = __webpack_require__(15);
- // EXTERNAL MODULE: external "element-ui/lib/utils/scroll-into-view"
- var scroll_into_view_ = __webpack_require__(27);
- var scroll_into_view_default = /*#__PURE__*/__webpack_require__.n(scroll_into_view_);
- // CONCATENATED MODULE: ./packages/select/src/navigation-mixin.js
- /* harmony default export */ var navigation_mixin = ({
- data: function data() {
- return {
- hoverOption: -1
- };
- },
- computed: {
- optionsAllDisabled: function optionsAllDisabled() {
- return this.options.filter(function (option) {
- return option.visible;
- }).every(function (option) {
- return option.disabled;
- });
- }
- },
- watch: {
- hoverIndex: function hoverIndex(val) {
- var _this = this;
- if (typeof val === 'number' && val > -1) {
- this.hoverOption = this.options[val] || {};
- }
- this.options.forEach(function (option) {
- option.hover = _this.hoverOption === option;
- });
- }
- },
- methods: {
- navigateOptions: function navigateOptions(direction) {
- var _this2 = this;
- if (!this.visible) {
- this.visible = true;
- return;
- }
- if (this.options.length === 0 || this.filteredOptionsCount === 0) return;
- if (!this.optionsAllDisabled) {
- if (direction === 'next') {
- this.hoverIndex++;
- if (this.hoverIndex === this.options.length) {
- this.hoverIndex = 0;
- }
- } else if (direction === 'prev') {
- this.hoverIndex--;
- if (this.hoverIndex < 0) {
- this.hoverIndex = this.options.length - 1;
- }
- }
- var option = this.options[this.hoverIndex];
- if (option.disabled === true || option.groupDisabled === true || !option.visible) {
- this.navigateOptions(direction);
- }
- this.$nextTick(function () {
- return _this2.scrollToOption(_this2.hoverOption);
- });
- }
- }
- }
- });
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var selectvue_type_script_lang_js_ = ({
- mixins: [emitter_default.a, locale_default.a, focus_default()('reference'), navigation_mixin],
- name: 'ElSelect',
- componentName: 'ElSelect',
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- provide: function provide() {
- return {
- 'select': this
- };
- },
- computed: {
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- readonly: function readonly() {
- return !this.filterable || this.multiple || !Object(util_["isIE"])() && !Object(util_["isEdge"])() && !this.visible;
- },
- showClose: function showClose() {
- var hasValue = this.multiple ? Array.isArray(this.value) && this.value.length > 0 : this.value !== undefined && this.value !== null && this.value !== '';
- var criteria = this.clearable && !this.selectDisabled && this.inputHovering && hasValue;
- return criteria;
- },
- iconClass: function iconClass() {
- return this.remote && this.filterable ? '' : this.visible ? 'arrow-up is-reverse' : 'arrow-up';
- },
- debounce: function debounce() {
- return this.remote ? 300 : 0;
- },
- emptyText: function emptyText() {
- if (this.loading) {
- return this.loadingText || this.t('el.select.loading');
- } else {
- if (this.remote && this.query === '' && this.options.length === 0) return false;
- if (this.filterable && this.query && this.options.length > 0 && this.filteredOptionsCount === 0) {
- return this.noMatchText || this.t('el.select.noMatch');
- }
- if (this.options.length === 0) {
- return this.noDataText || this.t('el.select.noData');
- }
- }
- return null;
- },
- showNewOption: function showNewOption() {
- var _this = this;
- var hasExistingOption = this.options.filter(function (option) {
- return !option.created;
- }).some(function (option) {
- return option.currentLabel === _this.query;
- });
- return this.filterable && this.allowCreate && this.query !== '' && !hasExistingOption;
- },
- selectSize: function selectSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- selectDisabled: function selectDisabled() {
- return this.disabled || (this.elForm || {}).disabled;
- },
- collapseTagSize: function collapseTagSize() {
- return ['small', 'mini'].indexOf(this.selectSize) > -1 ? 'mini' : 'small';
- },
- propPlaceholder: function propPlaceholder() {
- return typeof this.placeholder !== 'undefined' ? this.placeholder : this.t('el.select.placeholder');
- }
- },
- components: {
- ElInput: input_default.a,
- ElSelectMenu: select_dropdown,
- ElOption: src_option,
- ElTag: tag_default.a,
- ElScrollbar: scrollbar_default.a
- },
- directives: { Clickoutside: clickoutside_default.a },
- props: {
- name: String,
- id: String,
- value: {
- required: true
- },
- autocomplete: {
- type: String,
- default: 'off'
- },
- /** @Deprecated in next major version */
- autoComplete: {
- type: String,
- validator: function validator(val) {
- false && false;
- return true;
- }
- },
- automaticDropdown: Boolean,
- size: String,
- disabled: Boolean,
- clearable: Boolean,
- filterable: Boolean,
- allowCreate: Boolean,
- loading: Boolean,
- popperClass: String,
- remote: Boolean,
- loadingText: String,
- noMatchText: String,
- noDataText: String,
- remoteMethod: Function,
- filterMethod: Function,
- multiple: Boolean,
- multipleLimit: {
- type: Number,
- default: 0
- },
- placeholder: {
- type: String,
- required: false
- },
- defaultFirstOption: Boolean,
- reserveKeyword: Boolean,
- valueKey: {
- type: String,
- default: 'value'
- },
- collapseTags: Boolean,
- popperAppendToBody: {
- type: Boolean,
- default: true
- }
- },
- data: function data() {
- return {
- options: [],
- cachedOptions: [],
- createdLabel: null,
- createdSelected: false,
- selected: this.multiple ? [] : {},
- inputLength: 20,
- inputWidth: 0,
- initialInputHeight: 0,
- cachedPlaceHolder: '',
- optionsCount: 0,
- filteredOptionsCount: 0,
- visible: false,
- softFocus: false,
- selectedLabel: '',
- hoverIndex: -1,
- query: '',
- previousQuery: null,
- inputHovering: false,
- currentPlaceholder: '',
- menuVisibleOnFocus: false,
- isOnComposition: false,
- isSilentBlur: false
- };
- },
- watch: {
- selectDisabled: function selectDisabled() {
- var _this2 = this;
- this.$nextTick(function () {
- _this2.resetInputHeight();
- });
- },
- propPlaceholder: function propPlaceholder(val) {
- this.cachedPlaceHolder = this.currentPlaceholder = val;
- },
- value: function value(val, oldVal) {
- if (this.multiple) {
- this.resetInputHeight();
- if (val && val.length > 0 || this.$refs.input && this.query !== '') {
- this.currentPlaceholder = '';
- } else {
- this.currentPlaceholder = this.cachedPlaceHolder;
- }
- if (this.filterable && !this.reserveKeyword) {
- this.query = '';
- this.handleQueryChange(this.query);
- }
- }
- this.setSelected();
- if (this.filterable && !this.multiple) {
- this.inputLength = 20;
- }
- if (!Object(util_["valueEquals"])(val, oldVal)) {
- this.dispatch('ElFormItem', 'el.form.change', val);
- }
- },
- visible: function visible(val) {
- var _this3 = this;
- if (!val) {
- this.broadcast('ElSelectDropdown', 'destroyPopper');
- if (this.$refs.input) {
- this.$refs.input.blur();
- }
- this.query = '';
- this.previousQuery = null;
- this.selectedLabel = '';
- this.inputLength = 20;
- this.menuVisibleOnFocus = false;
- this.resetHoverIndex();
- this.$nextTick(function () {
- if (_this3.$refs.input && _this3.$refs.input.value === '' && _this3.selected.length === 0) {
- _this3.currentPlaceholder = _this3.cachedPlaceHolder;
- }
- });
- if (!this.multiple) {
- if (this.selected) {
- if (this.filterable && this.allowCreate && this.createdSelected && this.createdLabel) {
- this.selectedLabel = this.createdLabel;
- } else {
- this.selectedLabel = this.selected.currentLabel;
- }
- if (this.filterable) this.query = this.selectedLabel;
- }
- if (this.filterable) {
- this.currentPlaceholder = this.cachedPlaceHolder;
- }
- }
- } else {
- this.broadcast('ElSelectDropdown', 'updatePopper');
- if (this.filterable) {
- this.query = this.remote ? '' : this.selectedLabel;
- this.handleQueryChange(this.query);
- if (this.multiple) {
- this.$refs.input.focus();
- } else {
- if (!this.remote) {
- this.broadcast('ElOption', 'queryChange', '');
- this.broadcast('ElOptionGroup', 'queryChange');
- }
- if (this.selectedLabel) {
- this.currentPlaceholder = this.selectedLabel;
- this.selectedLabel = '';
- }
- }
- }
- }
- this.$emit('visible-change', val);
- },
- options: function options() {
- var _this4 = this;
- if (this.$isServer) return;
- this.$nextTick(function () {
- _this4.broadcast('ElSelectDropdown', 'updatePopper');
- });
- if (this.multiple) {
- this.resetInputHeight();
- }
- var inputs = this.$el.querySelectorAll('input');
- if ([].indexOf.call(inputs, document.activeElement) === -1) {
- this.setSelected();
- }
- if (this.defaultFirstOption && (this.filterable || this.remote) && this.filteredOptionsCount) {
- this.checkDefaultFirstOption();
- }
- }
- },
- methods: {
- handleNavigate: function handleNavigate(direction) {
- if (this.isOnComposition) return;
- this.navigateOptions(direction);
- },
- handleComposition: function handleComposition(event) {
- var _this5 = this;
- var text = event.target.value;
- if (event.type === 'compositionend') {
- this.isOnComposition = false;
- this.$nextTick(function (_) {
- return _this5.handleQueryChange(text);
- });
- } else {
- var lastCharacter = text[text.length - 1] || '';
- this.isOnComposition = !Object(shared_["isKorean"])(lastCharacter);
- }
- },
- handleQueryChange: function handleQueryChange(val) {
- var _this6 = this;
- if (this.previousQuery === val || this.isOnComposition) return;
- if (this.previousQuery === null && (typeof this.filterMethod === 'function' || typeof this.remoteMethod === 'function')) {
- this.previousQuery = val;
- return;
- }
- this.previousQuery = val;
- this.$nextTick(function () {
- if (_this6.visible) _this6.broadcast('ElSelectDropdown', 'updatePopper');
- });
- this.hoverIndex = -1;
- if (this.multiple && this.filterable) {
- this.$nextTick(function () {
- var length = _this6.$refs.input.value.length * 15 + 20;
- _this6.inputLength = _this6.collapseTags ? Math.min(50, length) : length;
- _this6.managePlaceholder();
- _this6.resetInputHeight();
- });
- }
- if (this.remote && typeof this.remoteMethod === 'function') {
- this.hoverIndex = -1;
- this.remoteMethod(val);
- } else if (typeof this.filterMethod === 'function') {
- this.filterMethod(val);
- this.broadcast('ElOptionGroup', 'queryChange');
- } else {
- this.filteredOptionsCount = this.optionsCount;
- this.broadcast('ElOption', 'queryChange', val);
- this.broadcast('ElOptionGroup', 'queryChange');
- }
- if (this.defaultFirstOption && (this.filterable || this.remote) && this.filteredOptionsCount) {
- this.checkDefaultFirstOption();
- }
- },
- scrollToOption: function scrollToOption(option) {
- var target = Array.isArray(option) && option[0] ? option[0].$el : option.$el;
- if (this.$refs.popper && target) {
- var menu = this.$refs.popper.$el.querySelector('.el-select-dropdown__wrap');
- scroll_into_view_default()(menu, target);
- }
- this.$refs.scrollbar && this.$refs.scrollbar.handleScroll();
- },
- handleMenuEnter: function handleMenuEnter() {
- var _this7 = this;
- this.$nextTick(function () {
- return _this7.scrollToOption(_this7.selected);
- });
- },
- emitChange: function emitChange(val) {
- if (!Object(util_["valueEquals"])(this.value, val)) {
- this.$emit('change', val);
- }
- },
- getOption: function getOption(value) {
- var option = void 0;
- var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
- var isNull = Object.prototype.toString.call(value).toLowerCase() === '[object null]';
- var isUndefined = Object.prototype.toString.call(value).toLowerCase() === '[object undefined]';
- for (var i = this.cachedOptions.length - 1; i >= 0; i--) {
- var cachedOption = this.cachedOptions[i];
- var isEqual = isObject ? Object(util_["getValueByPath"])(cachedOption.value, this.valueKey) === Object(util_["getValueByPath"])(value, this.valueKey) : cachedOption.value === value;
- if (isEqual) {
- option = cachedOption;
- break;
- }
- }
- if (option) return option;
- var label = !isObject && !isNull && !isUndefined ? String(value) : '';
- var newOption = {
- value: value,
- currentLabel: label
- };
- if (this.multiple) {
- newOption.hitState = false;
- }
- return newOption;
- },
- setSelected: function setSelected() {
- var _this8 = this;
- if (!this.multiple) {
- var option = this.getOption(this.value);
- if (option.created) {
- this.createdLabel = option.currentLabel;
- this.createdSelected = true;
- } else {
- this.createdSelected = false;
- }
- this.selectedLabel = option.currentLabel;
- this.selected = option;
- if (this.filterable) this.query = this.selectedLabel;
- return;
- }
- var result = [];
- if (Array.isArray(this.value)) {
- this.value.forEach(function (value) {
- result.push(_this8.getOption(value));
- });
- }
- this.selected = result;
- this.$nextTick(function () {
- _this8.resetInputHeight();
- });
- },
- handleFocus: function handleFocus(event) {
- if (!this.softFocus) {
- if (this.automaticDropdown || this.filterable) {
- if (this.filterable && !this.visible) {
- this.menuVisibleOnFocus = true;
- }
- this.visible = true;
- }
- this.$emit('focus', event);
- } else {
- this.softFocus = false;
- }
- },
- blur: function blur() {
- this.visible = false;
- this.$refs.reference.blur();
- },
- handleBlur: function handleBlur(event) {
- var _this9 = this;
- setTimeout(function () {
- if (_this9.isSilentBlur) {
- _this9.isSilentBlur = false;
- } else {
- _this9.$emit('blur', event);
- }
- }, 50);
- this.softFocus = false;
- },
- handleClearClick: function handleClearClick(event) {
- this.deleteSelected(event);
- },
- doDestroy: function doDestroy() {
- this.$refs.popper && this.$refs.popper.doDestroy();
- },
- handleClose: function handleClose() {
- this.visible = false;
- },
- toggleLastOptionHitState: function toggleLastOptionHitState(hit) {
- if (!Array.isArray(this.selected)) return;
- var option = this.selected[this.selected.length - 1];
- if (!option) return;
- if (hit === true || hit === false) {
- option.hitState = hit;
- return hit;
- }
- option.hitState = !option.hitState;
- return option.hitState;
- },
- deletePrevTag: function deletePrevTag(e) {
- if (e.target.value.length <= 0 && !this.toggleLastOptionHitState()) {
- var value = this.value.slice();
- value.pop();
- this.$emit('input', value);
- this.emitChange(value);
- }
- },
- managePlaceholder: function managePlaceholder() {
- if (this.currentPlaceholder !== '') {
- this.currentPlaceholder = this.$refs.input.value ? '' : this.cachedPlaceHolder;
- }
- },
- resetInputState: function resetInputState(e) {
- if (e.keyCode !== 8) this.toggleLastOptionHitState(false);
- this.inputLength = this.$refs.input.value.length * 15 + 20;
- this.resetInputHeight();
- },
- resetInputHeight: function resetInputHeight() {
- var _this10 = this;
- if (this.collapseTags && !this.filterable) return;
- this.$nextTick(function () {
- if (!_this10.$refs.reference) return;
- var inputChildNodes = _this10.$refs.reference.$el.childNodes;
- var input = [].filter.call(inputChildNodes, function (item) {
- return item.tagName === 'INPUT';
- })[0];
- var tags = _this10.$refs.tags;
- var tagsHeight = tags ? Math.round(tags.getBoundingClientRect().height) : 0;
- var sizeInMap = _this10.initialInputHeight || 40;
- input.style.height = _this10.selected.length === 0 ? sizeInMap + 'px' : Math.max(tags ? tagsHeight + (tagsHeight > sizeInMap ? 6 : 0) : 0, sizeInMap) + 'px';
- if (_this10.visible && _this10.emptyText !== false) {
- _this10.broadcast('ElSelectDropdown', 'updatePopper');
- }
- });
- },
- resetHoverIndex: function resetHoverIndex() {
- var _this11 = this;
- setTimeout(function () {
- if (!_this11.multiple) {
- _this11.hoverIndex = _this11.options.indexOf(_this11.selected);
- } else {
- if (_this11.selected.length > 0) {
- _this11.hoverIndex = Math.min.apply(null, _this11.selected.map(function (item) {
- return _this11.options.indexOf(item);
- }));
- } else {
- _this11.hoverIndex = -1;
- }
- }
- }, 300);
- },
- handleOptionSelect: function handleOptionSelect(option, byClick) {
- var _this12 = this;
- if (this.multiple) {
- var value = (this.value || []).slice();
- var optionIndex = this.getValueIndex(value, option.value);
- if (optionIndex > -1) {
- value.splice(optionIndex, 1);
- } else if (this.multipleLimit <= 0 || value.length < this.multipleLimit) {
- value.push(option.value);
- }
- this.$emit('input', value);
- this.emitChange(value);
- if (option.created) {
- this.query = '';
- this.handleQueryChange('');
- this.inputLength = 20;
- }
- if (this.filterable) this.$refs.input.focus();
- } else {
- this.$emit('input', option.value);
- this.emitChange(option.value);
- this.visible = false;
- }
- this.isSilentBlur = byClick;
- this.setSoftFocus();
- if (this.visible) return;
- this.$nextTick(function () {
- _this12.scrollToOption(option);
- });
- },
- setSoftFocus: function setSoftFocus() {
- this.softFocus = true;
- var input = this.$refs.input || this.$refs.reference;
- if (input) {
- input.focus();
- }
- },
- getValueIndex: function getValueIndex() {
- var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- var value = arguments[1];
- var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
- if (!isObject) {
- return arr.indexOf(value);
- } else {
- var valueKey = this.valueKey;
- var index = -1;
- arr.some(function (item, i) {
- if (Object(util_["getValueByPath"])(item, valueKey) === Object(util_["getValueByPath"])(value, valueKey)) {
- index = i;
- return true;
- }
- return false;
- });
- return index;
- }
- },
- toggleMenu: function toggleMenu() {
- if (!this.selectDisabled) {
- if (this.menuVisibleOnFocus) {
- this.menuVisibleOnFocus = false;
- } else {
- this.visible = !this.visible;
- }
- if (this.visible) {
- (this.$refs.input || this.$refs.reference).focus();
- }
- }
- },
- selectOption: function selectOption() {
- if (!this.visible) {
- this.toggleMenu();
- } else {
- if (this.options[this.hoverIndex]) {
- this.handleOptionSelect(this.options[this.hoverIndex]);
- }
- }
- },
- deleteSelected: function deleteSelected(event) {
- event.stopPropagation();
- var value = this.multiple ? [] : '';
- this.$emit('input', value);
- this.emitChange(value);
- this.visible = false;
- this.$emit('clear');
- },
- deleteTag: function deleteTag(event, tag) {
- var index = this.selected.indexOf(tag);
- if (index > -1 && !this.selectDisabled) {
- var value = this.value.slice();
- value.splice(index, 1);
- this.$emit('input', value);
- this.emitChange(value);
- this.$emit('remove-tag', tag.value);
- }
- event.stopPropagation();
- },
- onInputChange: function onInputChange() {
- if (this.filterable && this.query !== this.selectedLabel) {
- this.query = this.selectedLabel;
- this.handleQueryChange(this.query);
- }
- },
- onOptionDestroy: function onOptionDestroy(index) {
- if (index > -1) {
- this.optionsCount--;
- this.filteredOptionsCount--;
- this.options.splice(index, 1);
- }
- },
- resetInputWidth: function resetInputWidth() {
- this.inputWidth = this.$refs.reference.$el.getBoundingClientRect().width;
- },
- handleResize: function handleResize() {
- this.resetInputWidth();
- if (this.multiple) this.resetInputHeight();
- },
- checkDefaultFirstOption: function checkDefaultFirstOption() {
- this.hoverIndex = -1;
- // highlight the created option
- var hasCreated = false;
- for (var i = this.options.length - 1; i >= 0; i--) {
- if (this.options[i].created) {
- hasCreated = true;
- this.hoverIndex = i;
- break;
- }
- }
- if (hasCreated) return;
- for (var _i = 0; _i !== this.options.length; ++_i) {
- var option = this.options[_i];
- if (this.query) {
- // highlight first options that passes the filter
- if (!option.disabled && !option.groupDisabled && option.visible) {
- this.hoverIndex = _i;
- break;
- }
- } else {
- // highlight currently selected option
- if (option.itemSelected) {
- this.hoverIndex = _i;
- break;
- }
- }
- }
- },
- getValueKey: function getValueKey(item) {
- if (Object.prototype.toString.call(item.value).toLowerCase() !== '[object object]') {
- return item.value;
- } else {
- return Object(util_["getValueByPath"])(item.value, this.valueKey);
- }
- }
- },
- created: function created() {
- var _this13 = this;
- this.cachedPlaceHolder = this.currentPlaceholder = this.propPlaceholder;
- if (this.multiple && !Array.isArray(this.value)) {
- this.$emit('input', []);
- }
- if (!this.multiple && Array.isArray(this.value)) {
- this.$emit('input', '');
- }
- this.debouncedOnInputChange = debounce_default()(this.debounce, function () {
- _this13.onInputChange();
- });
- this.debouncedQueryChange = debounce_default()(this.debounce, function (e) {
- _this13.handleQueryChange(e.target.value);
- });
- this.$on('handleOptionClick', this.handleOptionSelect);
- this.$on('setSelected', this.setSelected);
- },
- mounted: function mounted() {
- var _this14 = this;
- if (this.multiple && Array.isArray(this.value) && this.value.length > 0) {
- this.currentPlaceholder = '';
- }
- Object(resize_event_["addResizeListener"])(this.$el, this.handleResize);
- var reference = this.$refs.reference;
- if (reference && reference.$el) {
- var sizeMap = {
- medium: 36,
- small: 32,
- mini: 28
- };
- var input = reference.$el.querySelector('input');
- this.initialInputHeight = input.getBoundingClientRect().height || sizeMap[this.selectSize];
- }
- if (this.remote && this.multiple) {
- this.resetInputHeight();
- }
- this.$nextTick(function () {
- if (reference && reference.$el) {
- _this14.inputWidth = reference.$el.getBoundingClientRect().width;
- }
- });
- this.setSelected();
- },
- beforeDestroy: function beforeDestroy() {
- if (this.$el && this.handleResize) Object(resize_event_["removeResizeListener"])(this.$el, this.handleResize);
- }
- });
- // CONCATENATED MODULE: ./packages/select/src/select.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_selectvue_type_script_lang_js_ = (selectvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/select/src/select.vue
- /* normalize component */
- var select_component = normalizeComponent(
- src_selectvue_type_script_lang_js_,
- selectvue_type_template_id_0e4aade6_render,
- selectvue_type_template_id_0e4aade6_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var select_api; }
- select_component.options.__file = "packages/select/src/select.vue"
- /* harmony default export */ var src_select = (select_component.exports);
- // CONCATENATED MODULE: ./packages/select/index.js
- /* istanbul ignore next */
- src_select.install = function (Vue) {
- Vue.component(src_select.name, src_select);
- };
- /* harmony default export */ var packages_select = (src_select);
- // CONCATENATED MODULE: ./packages/option/index.js
- /* istanbul ignore next */
- src_option.install = function (Vue) {
- Vue.component(src_option.name, src_option);
- };
- /* harmony default export */ var packages_option = (src_option);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option-group.vue?vue&type=template&id=6685e5de&
- var option_groupvue_type_template_id_6685e5de_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "ul",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-select-group__wrap"
- },
- [
- _c("li", { staticClass: "el-select-group__title" }, [
- _vm._v(_vm._s(_vm.label))
- ]),
- _c("li", [
- _c("ul", { staticClass: "el-select-group" }, [_vm._t("default")], 2)
- ])
- ]
- )
- }
- var option_groupvue_type_template_id_6685e5de_staticRenderFns = []
- option_groupvue_type_template_id_6685e5de_render._withStripped = true
- // CONCATENATED MODULE: ./packages/select/src/option-group.vue?vue&type=template&id=6685e5de&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option-group.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var option_groupvue_type_script_lang_js_ = ({
- mixins: [emitter_default.a],
- name: 'ElOptionGroup',
- componentName: 'ElOptionGroup',
- props: {
- label: String,
- disabled: {
- type: Boolean,
- default: false
- }
- },
- data: function data() {
- return {
- visible: true
- };
- },
- watch: {
- disabled: function disabled(val) {
- this.broadcast('ElOption', 'handleGroupDisabled', val);
- }
- },
- methods: {
- queryChange: function queryChange() {
- this.visible = this.$children && Array.isArray(this.$children) && this.$children.some(function (option) {
- return option.visible === true;
- });
- }
- },
- created: function created() {
- this.$on('queryChange', this.queryChange);
- },
- mounted: function mounted() {
- if (this.disabled) {
- this.broadcast('ElOption', 'handleGroupDisabled', this.disabled);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/select/src/option-group.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_option_groupvue_type_script_lang_js_ = (option_groupvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/select/src/option-group.vue
- /* normalize component */
- var option_group_component = normalizeComponent(
- src_option_groupvue_type_script_lang_js_,
- option_groupvue_type_template_id_6685e5de_render,
- option_groupvue_type_template_id_6685e5de_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var option_group_api; }
- option_group_component.options.__file = "packages/select/src/option-group.vue"
- /* harmony default export */ var option_group = (option_group_component.exports);
- // CONCATENATED MODULE: ./packages/option-group/index.js
- /* istanbul ignore next */
- option_group.install = function (Vue) {
- Vue.component(option_group.name, option_group);
- };
- /* harmony default export */ var packages_option_group = (option_group);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button.vue?vue&type=template&id=ca859fb4&
- var buttonvue_type_template_id_ca859fb4_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "button",
- {
- staticClass: "el-button",
- class: [
- _vm.type ? "el-button--" + _vm.type : "",
- _vm.buttonSize ? "el-button--" + _vm.buttonSize : "",
- {
- "is-disabled": _vm.buttonDisabled,
- "is-loading": _vm.loading,
- "is-plain": _vm.plain,
- "is-round": _vm.round,
- "is-circle": _vm.circle
- }
- ],
- attrs: {
- disabled: _vm.buttonDisabled || _vm.loading,
- autofocus: _vm.autofocus,
- type: _vm.nativeType
- },
- on: { click: _vm.handleClick }
- },
- [
- _vm.loading ? _c("i", { staticClass: "el-icon-loading" }) : _vm._e(),
- _vm.icon && !_vm.loading ? _c("i", { class: _vm.icon }) : _vm._e(),
- _vm.$slots.default ? _c("span", [_vm._t("default")], 2) : _vm._e()
- ]
- )
- }
- var buttonvue_type_template_id_ca859fb4_staticRenderFns = []
- buttonvue_type_template_id_ca859fb4_render._withStripped = true
- // CONCATENATED MODULE: ./packages/button/src/button.vue?vue&type=template&id=ca859fb4&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var buttonvue_type_script_lang_js_ = ({
- name: 'ElButton',
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- props: {
- type: {
- type: String,
- default: 'default'
- },
- size: String,
- icon: {
- type: String,
- default: ''
- },
- nativeType: {
- type: String,
- default: 'button'
- },
- loading: Boolean,
- disabled: Boolean,
- plain: Boolean,
- autofocus: Boolean,
- round: Boolean,
- circle: Boolean
- },
- computed: {
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- buttonSize: function buttonSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- buttonDisabled: function buttonDisabled() {
- return this.$options.propsData.hasOwnProperty('disabled') ? this.disabled : (this.elForm || {}).disabled;
- }
- },
- methods: {
- handleClick: function handleClick(evt) {
- this.$emit('click', evt);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/button/src/button.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_buttonvue_type_script_lang_js_ = (buttonvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/button/src/button.vue
- /* normalize component */
- var button_component = normalizeComponent(
- src_buttonvue_type_script_lang_js_,
- buttonvue_type_template_id_ca859fb4_render,
- buttonvue_type_template_id_ca859fb4_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var button_api; }
- button_component.options.__file = "packages/button/src/button.vue"
- /* harmony default export */ var src_button = (button_component.exports);
- // CONCATENATED MODULE: ./packages/button/index.js
- /* istanbul ignore next */
- src_button.install = function (Vue) {
- Vue.component(src_button.name, src_button);
- };
- /* harmony default export */ var packages_button = (src_button);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button-group.vue?vue&type=template&id=3d8661d0&
- var button_groupvue_type_template_id_3d8661d0_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("div", { staticClass: "el-button-group" }, [_vm._t("default")], 2)
- }
- var button_groupvue_type_template_id_3d8661d0_staticRenderFns = []
- button_groupvue_type_template_id_3d8661d0_render._withStripped = true
- // CONCATENATED MODULE: ./packages/button/src/button-group.vue?vue&type=template&id=3d8661d0&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button-group.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- /* harmony default export */ var button_groupvue_type_script_lang_js_ = ({
- name: 'ElButtonGroup'
- });
- // CONCATENATED MODULE: ./packages/button/src/button-group.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_button_groupvue_type_script_lang_js_ = (button_groupvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/button/src/button-group.vue
- /* normalize component */
- var button_group_component = normalizeComponent(
- src_button_groupvue_type_script_lang_js_,
- button_groupvue_type_template_id_3d8661d0_render,
- button_groupvue_type_template_id_3d8661d0_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var button_group_api; }
- button_group_component.options.__file = "packages/button/src/button-group.vue"
- /* harmony default export */ var button_group = (button_group_component.exports);
- // CONCATENATED MODULE: ./packages/button-group/index.js
- /* istanbul ignore next */
- button_group.install = function (Vue) {
- Vue.component(button_group.name, button_group);
- };
- /* harmony default export */ var packages_button_group = (button_group);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/table/src/table.vue?vue&type=template&id=493fe34e&
- var tablevue_type_template_id_493fe34e_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-table",
- class: [
- {
- "el-table--fit": _vm.fit,
- "el-table--striped": _vm.stripe,
- "el-table--border": _vm.border || _vm.isGroup,
- "el-table--hidden": _vm.isHidden,
- "el-table--group": _vm.isGroup,
- "el-table--fluid-height": _vm.maxHeight,
- "el-table--scrollable-x": _vm.layout.scrollX,
- "el-table--scrollable-y": _vm.layout.scrollY,
- "el-table--enable-row-hover": !_vm.store.states.isComplex,
- "el-table--enable-row-transition":
- (_vm.store.states.data || []).length !== 0 &&
- (_vm.store.states.data || []).length < 100
- },
- _vm.tableSize ? "el-table--" + _vm.tableSize : ""
- ],
- on: {
- mouseleave: function($event) {
- _vm.handleMouseLeave($event)
- }
- }
- },
- [
- _c(
- "div",
- { ref: "hiddenColumns", staticClass: "hidden-columns" },
- [_vm._t("default")],
- 2
- ),
- _vm.showHeader
- ? _c(
- "div",
- {
- directives: [
- {
- name: "mousewheel",
- rawName: "v-mousewheel",
- value: _vm.handleHeaderFooterMousewheel,
- expression: "handleHeaderFooterMousewheel"
- }
- ],
- ref: "headerWrapper",
- staticClass: "el-table__header-wrapper"
- },
- [
- _c("table-header", {
- ref: "tableHeader",
- style: {
- width: _vm.layout.bodyWidth ? _vm.layout.bodyWidth + "px" : ""
- },
- attrs: {
- store: _vm.store,
- border: _vm.border,
- "default-sort": _vm.defaultSort
- }
- })
- ],
- 1
- )
- : _vm._e(),
- _c(
- "div",
- {
- ref: "bodyWrapper",
- staticClass: "el-table__body-wrapper",
- class: [
- _vm.layout.scrollX
- ? "is-scrolling-" + _vm.scrollPosition
- : "is-scrolling-none"
- ],
- style: [_vm.bodyHeight]
- },
- [
- _c("table-body", {
- style: {
- width: _vm.bodyWidth
- },
- attrs: {
- context: _vm.context,
- store: _vm.store,
- stripe: _vm.stripe,
- "row-class-name": _vm.rowClassName,
- "row-style": _vm.rowStyle,
- highlight: _vm.highlightCurrentRow
- }
- }),
- !_vm.data || _vm.data.length === 0
- ? _c(
- "div",
- {
- ref: "emptyBlock",
- staticClass: "el-table__empty-block",
- style: _vm.emptyBlockStyle
- },
- [
- _c(
- "span",
- { staticClass: "el-table__empty-text" },
- [
- _vm._t("empty", [
- _vm._v(
- _vm._s(_vm.emptyText || _vm.t("el.table.emptyText"))
- )
- ])
- ],
- 2
- )
- ]
- )
- : _vm._e(),
- _vm.$slots.append
- ? _c(
- "div",
- {
- ref: "appendWrapper",
- staticClass: "el-table__append-wrapper"
- },
- [_vm._t("append")],
- 2
- )
- : _vm._e()
- ],
- 1
- ),
- _vm.showSummary
- ? _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.data && _vm.data.length > 0,
- expression: "data && data.length > 0"
- },
- {
- name: "mousewheel",
- rawName: "v-mousewheel",
- value: _vm.handleHeaderFooterMousewheel,
- expression: "handleHeaderFooterMousewheel"
- }
- ],
- ref: "footerWrapper",
- staticClass: "el-table__footer-wrapper"
- },
- [
- _c("table-footer", {
- style: {
- width: _vm.layout.bodyWidth ? _vm.layout.bodyWidth + "px" : ""
- },
- attrs: {
- store: _vm.store,
- border: _vm.border,
- "sum-text": _vm.sumText || _vm.t("el.table.sumText"),
- "summary-method": _vm.summaryMethod,
- "default-sort": _vm.defaultSort
- }
- })
- ],
- 1
- )
- : _vm._e(),
- _vm.fixedColumns.length > 0
- ? _c(
- "div",
- {
- directives: [
- {
- name: "mousewheel",
- rawName: "v-mousewheel",
- value: _vm.handleFixedMousewheel,
- expression: "handleFixedMousewheel"
- }
- ],
- ref: "fixedWrapper",
- staticClass: "el-table__fixed",
- style: [
- {
- width: _vm.layout.fixedWidth
- ? _vm.layout.fixedWidth + "px"
- : ""
- },
- _vm.fixedHeight
- ]
- },
- [
- _vm.showHeader
- ? _c(
- "div",
- {
- ref: "fixedHeaderWrapper",
- staticClass: "el-table__fixed-header-wrapper"
- },
- [
- _c("table-header", {
- ref: "fixedTableHeader",
- style: {
- width: _vm.bodyWidth
- },
- attrs: {
- fixed: "left",
- border: _vm.border,
- store: _vm.store
- }
- })
- ],
- 1
- )
- : _vm._e(),
- _c(
- "div",
- {
- ref: "fixedBodyWrapper",
- staticClass: "el-table__fixed-body-wrapper",
- style: [
- {
- top: _vm.layout.headerHeight + "px"
- },
- _vm.fixedBodyHeight
- ]
- },
- [
- _c("table-body", {
- style: {
- width: _vm.bodyWidth
- },
- attrs: {
- fixed: "left",
- store: _vm.store,
- stripe: _vm.stripe,
- highlight: _vm.highlightCurrentRow,
- "row-class-name": _vm.rowClassName,
- "row-style": _vm.rowStyle
- }
- }),
- _vm.$slots.append
- ? _c("div", {
- staticClass: "el-table__append-gutter",
- style: { height: _vm.layout.appendHeight + "px" }
- })
- : _vm._e()
- ],
- 1
- ),
- _vm.showSummary
- ? _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.data && _vm.data.length > 0,
- expression: "data && data.length > 0"
- }
- ],
- ref: "fixedFooterWrapper",
- staticClass: "el-table__fixed-footer-wrapper"
- },
- [
- _c("table-footer", {
- style: {
- width: _vm.bodyWidth
- },
- attrs: {
- fixed: "left",
- border: _vm.border,
- "sum-text": _vm.sumText || _vm.t("el.table.sumText"),
- "summary-method": _vm.summaryMethod,
- store: _vm.store
- }
- })
- ],
- 1
- )
- : _vm._e()
- ]
- )
- : _vm._e(),
- _vm.rightFixedColumns.length > 0
- ? _c(
- "div",
- {
- directives: [
- {
- name: "mousewheel",
- rawName: "v-mousewheel",
- value: _vm.handleFixedMousewheel,
- expression: "handleFixedMousewheel"
- }
- ],
- ref: "rightFixedWrapper",
- staticClass: "el-table__fixed-right",
- style: [
- {
- width: _vm.layout.rightFixedWidth
- ? _vm.layout.rightFixedWidth + "px"
- : "",
- right: _vm.layout.scrollY
- ? (_vm.border
- ? _vm.layout.gutterWidth
- : _vm.layout.gutterWidth || 0) + "px"
- : ""
- },
- _vm.fixedHeight
- ]
- },
- [
- _vm.showHeader
- ? _c(
- "div",
- {
- ref: "rightFixedHeaderWrapper",
- staticClass: "el-table__fixed-header-wrapper"
- },
- [
- _c("table-header", {
- ref: "rightFixedTableHeader",
- style: {
- width: _vm.bodyWidth
- },
- attrs: {
- fixed: "right",
- border: _vm.border,
- store: _vm.store
- }
- })
- ],
- 1
- )
- : _vm._e(),
- _c(
- "div",
- {
- ref: "rightFixedBodyWrapper",
- staticClass: "el-table__fixed-body-wrapper",
- style: [
- {
- top: _vm.layout.headerHeight + "px"
- },
- _vm.fixedBodyHeight
- ]
- },
- [
- _c("table-body", {
- style: {
- width: _vm.bodyWidth
- },
- attrs: {
- fixed: "right",
- store: _vm.store,
- stripe: _vm.stripe,
- "row-class-name": _vm.rowClassName,
- "row-style": _vm.rowStyle,
- highlight: _vm.highlightCurrentRow
- }
- }),
- _vm.$slots.append
- ? _c("div", {
- staticClass: "el-table__append-gutter",
- style: { height: _vm.layout.appendHeight + "px" }
- })
- : _vm._e()
- ],
- 1
- ),
- _vm.showSummary
- ? _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.data && _vm.data.length > 0,
- expression: "data && data.length > 0"
- }
- ],
- ref: "rightFixedFooterWrapper",
- staticClass: "el-table__fixed-footer-wrapper"
- },
- [
- _c("table-footer", {
- style: {
- width: _vm.bodyWidth
- },
- attrs: {
- fixed: "right",
- border: _vm.border,
- "sum-text": _vm.sumText || _vm.t("el.table.sumText"),
- "summary-method": _vm.summaryMethod,
- store: _vm.store
- }
- })
- ],
- 1
- )
- : _vm._e()
- ]
- )
- : _vm._e(),
- _vm.rightFixedColumns.length > 0
- ? _c("div", {
- ref: "rightFixedPatch",
- staticClass: "el-table__fixed-right-patch",
- style: {
- width: _vm.layout.scrollY ? _vm.layout.gutterWidth + "px" : "0",
- height: _vm.layout.headerHeight + "px"
- }
- })
- : _vm._e(),
- _c("div", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.resizeProxyVisible,
- expression: "resizeProxyVisible"
- }
- ],
- ref: "resizeProxy",
- staticClass: "el-table__column-resize-proxy"
- })
- ]
- )
- }
- var tablevue_type_template_id_493fe34e_staticRenderFns = []
- tablevue_type_template_id_493fe34e_render._withStripped = true
- // CONCATENATED MODULE: ./packages/table/src/table.vue?vue&type=template&id=493fe34e&
- // EXTERNAL MODULE: external "element-ui/lib/checkbox"
- var checkbox_ = __webpack_require__(14);
- var checkbox_default = /*#__PURE__*/__webpack_require__.n(checkbox_);
- // EXTERNAL MODULE: external "throttle-debounce"
- var external_throttle_debounce_ = __webpack_require__(36);
- // EXTERNAL MODULE: external "normalize-wheel"
- var external_normalize_wheel_ = __webpack_require__(39);
- var external_normalize_wheel_default = /*#__PURE__*/__webpack_require__.n(external_normalize_wheel_);
- // CONCATENATED MODULE: ./src/directives/mousewheel.js
- var isFirefox = typeof navigator !== 'undefined' && navigator.userAgent.toLowerCase().indexOf('firefox') > -1;
- var mousewheel_mousewheel = function mousewheel(element, callback) {
- if (element && element.addEventListener) {
- element.addEventListener(isFirefox ? 'DOMMouseScroll' : 'mousewheel', function (event) {
- var normalized = external_normalize_wheel_default()(event);
- callback && callback.apply(this, [event, normalized]);
- });
- }
- };
- /* harmony default export */ var directives_mousewheel = ({
- bind: function bind(el, binding) {
- mousewheel_mousewheel(el, binding.value);
- }
- });
- // EXTERNAL MODULE: external "vue"
- var external_vue_ = __webpack_require__(6);
- var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_);
- // CONCATENATED MODULE: ./packages/table/src/util.js
- var util_typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- var getCell = function getCell(event) {
- var cell = event.target;
- while (cell && cell.tagName.toUpperCase() !== 'HTML') {
- if (cell.tagName.toUpperCase() === 'TD') {
- return cell;
- }
- cell = cell.parentNode;
- }
- return null;
- };
- var util_isObject = function isObject(obj) {
- return obj !== null && (typeof obj === 'undefined' ? 'undefined' : util_typeof(obj)) === 'object';
- };
- var util_orderBy = function orderBy(array, sortKey, reverse, sortMethod, sortBy) {
- if (!sortKey && !sortMethod && (!sortBy || Array.isArray(sortBy) && !sortBy.length)) {
- return array;
- }
- if (typeof reverse === 'string') {
- reverse = reverse === 'descending' ? -1 : 1;
- } else {
- reverse = reverse && reverse < 0 ? -1 : 1;
- }
- var getKey = sortMethod ? null : function (value, index) {
- if (sortBy) {
- if (!Array.isArray(sortBy)) {
- sortBy = [sortBy];
- }
- return sortBy.map(function (by) {
- if (typeof by === 'string') {
- return Object(util_["getValueByPath"])(value, by);
- } else {
- return by(value, index, array);
- }
- });
- }
- if (sortKey !== '$key') {
- if (util_isObject(value) && '$value' in value) value = value.$value;
- }
- return [util_isObject(value) ? Object(util_["getValueByPath"])(value, sortKey) : value];
- };
- var compare = function compare(a, b) {
- if (sortMethod) {
- return sortMethod(a.value, b.value);
- }
- for (var i = 0, len = a.key.length; i < len; i++) {
- if (a.key[i] < b.key[i]) {
- return -1;
- }
- if (a.key[i] > b.key[i]) {
- return 1;
- }
- }
- return 0;
- };
- return array.map(function (value, index) {
- return {
- value: value,
- index: index,
- key: getKey ? getKey(value, index) : null
- };
- }).sort(function (a, b) {
- var order = compare(a, b);
- if (!order) {
- // make stable https://en.wikipedia.org/wiki/Sorting_algorithm#Stability
- order = a.index - b.index;
- }
- return order * reverse;
- }).map(function (item) {
- return item.value;
- });
- };
- var getColumnById = function getColumnById(table, columnId) {
- var column = null;
- table.columns.forEach(function (item) {
- if (item.id === columnId) {
- column = item;
- }
- });
- return column;
- };
- var getColumnByKey = function getColumnByKey(table, columnKey) {
- var column = null;
- for (var i = 0; i < table.columns.length; i++) {
- var item = table.columns[i];
- if (item.columnKey === columnKey) {
- column = item;
- break;
- }
- }
- return column;
- };
- var getColumnByCell = function getColumnByCell(table, cell) {
- var matches = (cell.className || '').match(/el-table_[^\s]+/gm);
- if (matches) {
- return getColumnById(table, matches[0]);
- }
- return null;
- };
- var getRowIdentity = function getRowIdentity(row, rowKey) {
- if (!row) throw new Error('row is required when get row identity');
- if (typeof rowKey === 'string') {
- if (rowKey.indexOf('.') < 0) {
- return row[rowKey];
- }
- var key = rowKey.split('.');
- var current = row;
- for (var i = 0; i < key.length; i++) {
- current = current[key[i]];
- }
- return current;
- } else if (typeof rowKey === 'function') {
- return rowKey.call(null, row);
- }
- };
- var getKeysMap = function getKeysMap(array, rowKey) {
- var arrayMap = {};
- (array || []).forEach(function (row, index) {
- arrayMap[getRowIdentity(row, rowKey)] = { row: row, index: index };
- });
- return arrayMap;
- };
- function hasOwn(obj, key) {
- return Object.prototype.hasOwnProperty.call(obj, key);
- }
- function mergeOptions(defaults, config) {
- var options = {};
- var key = void 0;
- for (key in defaults) {
- options[key] = defaults[key];
- }
- for (key in config) {
- if (hasOwn(config, key)) {
- var value = config[key];
- if (typeof value !== 'undefined') {
- options[key] = value;
- }
- }
- }
- return options;
- }
- function parseWidth(width) {
- if (width !== undefined) {
- width = parseInt(width, 10);
- if (isNaN(width)) {
- width = null;
- }
- }
- return width;
- }
- function parseMinWidth(minWidth) {
- if (typeof minWidth !== 'undefined') {
- minWidth = parseWidth(minWidth);
- if (isNaN(minWidth)) {
- minWidth = 80;
- }
- }
- return minWidth;
- };
- function parseHeight(height) {
- if (typeof height === 'number') {
- return height;
- }
- if (typeof height === 'string') {
- if (/^\d+(?:px)?$/.test(height)) {
- return parseInt(height, 10);
- } else {
- return height;
- }
- }
- return null;
- }
- // https://github.com/reduxjs/redux/blob/master/src/compose.js
- function compose() {
- for (var _len = arguments.length, funcs = Array(_len), _key = 0; _key < _len; _key++) {
- funcs[_key] = arguments[_key];
- }
- if (funcs.length === 0) {
- return function (arg) {
- return arg;
- };
- }
- if (funcs.length === 1) {
- return funcs[0];
- }
- return funcs.reduce(function (a, b) {
- return function () {
- return a(b.apply(undefined, arguments));
- };
- });
- }
- function toggleRowStatus(statusArr, row, newVal) {
- var changed = false;
- var index = statusArr.indexOf(row);
- var included = index !== -1;
- var addRow = function addRow() {
- statusArr.push(row);
- changed = true;
- };
- var removeRow = function removeRow() {
- statusArr.splice(index, 1);
- changed = true;
- };
- if (typeof newVal === 'boolean') {
- if (newVal && !included) {
- addRow();
- } else if (!newVal && included) {
- removeRow();
- }
- } else {
- if (included) {
- removeRow();
- } else {
- addRow();
- }
- }
- return changed;
- }
- function walkTreeNode(root, cb) {
- var childrenKey = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'children';
- var lazyKey = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'hasChildren';
- var isNil = function isNil(array) {
- return !(Array.isArray(array) && array.length);
- };
- function _walker(parent, children, level) {
- cb(parent, children, level);
- children.forEach(function (item) {
- if (item[lazyKey]) {
- cb(item, null, level + 1);
- return;
- }
- var children = item[childrenKey];
- if (!isNil(children)) {
- _walker(item, children, level + 1);
- }
- });
- }
- root.forEach(function (item) {
- if (item[lazyKey]) {
- cb(item, null, 0);
- return;
- }
- var children = item[childrenKey];
- if (!isNil(children)) {
- _walker(item, children, 0);
- }
- });
- }
- var objectEquals = function objectEquals(objectA, objectB) {
- // 取对象a和b的属性名
- var aProps = Object.getOwnPropertyNames(objectA);
- var bProps = Object.getOwnPropertyNames(objectB);
- // 判断属性名的length是否一致
- if (aProps.length !== bProps.length) {
- return false;
- }
- // 循环取出属性名,再判断属性值是否一致
- for (var i = 0; i < aProps.length; i++) {
- var propName = aProps[i];
- if (objectA[propName] !== objectB[propName]) {
- return false;
- }
- }
- return true;
- };
- // CONCATENATED MODULE: ./packages/table/src/store/expand.js
- /* harmony default export */ var expand = ({
- data: function data() {
- return {
- states: {
- defaultExpandAll: false,
- expandRows: []
- }
- };
- },
- methods: {
- updateExpandRows: function updateExpandRows() {
- var _states = this.states,
- _states$data = _states.data,
- data = _states$data === undefined ? [] : _states$data,
- rowKey = _states.rowKey,
- defaultExpandAll = _states.defaultExpandAll,
- expandRows = _states.expandRows;
- if (defaultExpandAll) {
- this.states.expandRows = data.slice();
- } else if (rowKey) {
- // TODO:这里的代码可以优化
- var expandRowsMap = getKeysMap(expandRows, rowKey);
- this.states.expandRows = data.reduce(function (prev, row) {
- var rowId = getRowIdentity(row, rowKey);
- var rowInfo = expandRowsMap[rowId];
- if (rowInfo) {
- prev.push(row);
- }
- return prev;
- }, []);
- } else {
- this.states.expandRows = [];
- }
- },
- toggleRowExpansion: function toggleRowExpansion(row, expanded) {
- var changed = toggleRowStatus(this.states.expandRows, row, expanded);
- if (changed) {
- this.table.$emit('expand-change', row, this.states.expandRows.slice());
- this.scheduleLayout();
- }
- },
- setExpandRowKeys: function setExpandRowKeys(rowKeys) {
- this.assertRowKey();
- // TODO:这里的代码可以优化
- var _states2 = this.states,
- data = _states2.data,
- rowKey = _states2.rowKey;
- var keysMap = getKeysMap(data, rowKey);
- this.states.expandRows = rowKeys.reduce(function (prev, cur) {
- var info = keysMap[cur];
- if (info) {
- prev.push(info.row);
- }
- return prev;
- }, []);
- },
- isRowExpanded: function isRowExpanded(row) {
- var _states3 = this.states,
- _states3$expandRows = _states3.expandRows,
- expandRows = _states3$expandRows === undefined ? [] : _states3$expandRows,
- rowKey = _states3.rowKey;
- if (rowKey) {
- var expandMap = getKeysMap(expandRows, rowKey);
- return !!expandMap[getRowIdentity(row, rowKey)];
- }
- return expandRows.indexOf(row) !== -1;
- }
- }
- });
- // CONCATENATED MODULE: ./packages/table/src/store/current.js
- /* harmony default export */ var store_current = ({
- data: function data() {
- return {
- states: {
- // 不可响应的,设置 currentRowKey 时,data 不一定存在,也许无法算出正确的 currentRow
- // 把该值缓存一下,当用户点击修改 currentRow 时,把该值重置为 null
- _currentRowKey: null,
- currentRow: null
- }
- };
- },
- methods: {
- setCurrentRowKey: function setCurrentRowKey(key) {
- this.assertRowKey();
- this.states._currentRowKey = key;
- this.setCurrentRowByKey(key);
- },
- restoreCurrentRowKey: function restoreCurrentRowKey() {
- this.states._currentRowKey = null;
- },
- setCurrentRowByKey: function setCurrentRowByKey(key) {
- var states = this.states;
- var _states$data = states.data,
- data = _states$data === undefined ? [] : _states$data,
- rowKey = states.rowKey;
- var currentRow = null;
- if (rowKey) {
- currentRow = Object(util_["arrayFind"])(data, function (item) {
- return getRowIdentity(item, rowKey) === key;
- });
- }
- states.currentRow = currentRow;
- },
- updateCurrentRow: function updateCurrentRow(currentRow) {
- var states = this.states,
- table = this.table;
- var oldCurrentRow = states.currentRow;
- if (currentRow && currentRow !== oldCurrentRow) {
- states.currentRow = currentRow;
- table.$emit('current-change', currentRow, oldCurrentRow);
- return;
- }
- if (!currentRow && oldCurrentRow) {
- states.currentRow = null;
- table.$emit('current-change', null, oldCurrentRow);
- }
- },
- updateCurrentRowData: function updateCurrentRowData() {
- var states = this.states,
- table = this.table;
- var rowKey = states.rowKey,
- _currentRowKey = states._currentRowKey;
- // data 为 null 时,解构时的默认值会被忽略
- var data = states.data || [];
- var oldCurrentRow = states.currentRow;
- // 当 currentRow 不在 data 中时尝试更新数据
- if (data.indexOf(oldCurrentRow) === -1 && oldCurrentRow) {
- if (rowKey) {
- var currentRowKey = getRowIdentity(oldCurrentRow, rowKey);
- this.setCurrentRowByKey(currentRowKey);
- } else {
- states.currentRow = null;
- }
- if (states.currentRow === null) {
- table.$emit('current-change', null, oldCurrentRow);
- }
- } else if (_currentRowKey) {
- // 把初始时下设置的 rowKey 转化成 rowData
- this.setCurrentRowByKey(_currentRowKey);
- this.restoreCurrentRowKey();
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/table/src/store/tree.js
- var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- /* harmony default export */ var tree = ({
- data: function data() {
- return {
- states: {
- // defaultExpandAll 存在于 expand.js 中,这里不重复添加
- // 在展开行中,expandRowKeys 会被转化成 expandRows,expandRowKeys 这个属性只是记录了 TreeTable 行的展开
- // TODO: 拆分为独立的 TreeTable,统一用法
- expandRowKeys: [],
- treeData: {},
- indent: 16,
- lazy: false,
- lazyTreeNodeMap: {},
- lazyColumnIdentifier: 'hasChildren',
- childrenColumnName: 'children'
- }
- };
- },
- computed: {
- // 嵌入型的数据,watch 无法是检测到变化 https://github.com/ElemeFE/element/issues/14998
- // TODO: 使用 computed 解决该问题,是否会造成性能问题?
- // @return { id: { level, children } }
- normalizedData: function normalizedData() {
- if (!this.states.rowKey) return {};
- var data = this.states.data || [];
- return this.normalize(data);
- },
- // @return { id: { children } }
- // 针对懒加载的情形,不处理嵌套数据
- normalizedLazyNode: function normalizedLazyNode() {
- var _states = this.states,
- rowKey = _states.rowKey,
- lazyTreeNodeMap = _states.lazyTreeNodeMap,
- lazyColumnIdentifier = _states.lazyColumnIdentifier;
- var keys = Object.keys(lazyTreeNodeMap);
- var res = {};
- if (!keys.length) return res;
- keys.forEach(function (key) {
- if (lazyTreeNodeMap[key].length) {
- var item = { children: [] };
- lazyTreeNodeMap[key].forEach(function (row) {
- var currentRowKey = getRowIdentity(row, rowKey);
- item.children.push(currentRowKey);
- if (row[lazyColumnIdentifier] && !res[currentRowKey]) {
- res[currentRowKey] = { children: [] };
- }
- });
- res[key] = item;
- }
- });
- return res;
- }
- },
- watch: {
- normalizedData: 'updateTreeData',
- normalizedLazyNode: 'updateTreeData'
- },
- methods: {
- normalize: function normalize(data) {
- var _states2 = this.states,
- childrenColumnName = _states2.childrenColumnName,
- lazyColumnIdentifier = _states2.lazyColumnIdentifier,
- rowKey = _states2.rowKey,
- lazy = _states2.lazy;
- var res = {};
- walkTreeNode(data, function (parent, children, level) {
- var parentId = getRowIdentity(parent, rowKey);
- if (Array.isArray(children)) {
- res[parentId] = {
- children: children.map(function (row) {
- return getRowIdentity(row, rowKey);
- }),
- level: level
- };
- } else if (lazy) {
- // 当 children 不存在且 lazy 为 true,该节点即为懒加载的节点
- res[parentId] = {
- children: [],
- lazy: true,
- level: level
- };
- }
- }, childrenColumnName, lazyColumnIdentifier);
- return res;
- },
- updateTreeData: function updateTreeData() {
- var nested = this.normalizedData;
- var normalizedLazyNode = this.normalizedLazyNode;
- var keys = Object.keys(nested);
- var newTreeData = {};
- if (keys.length) {
- var _states3 = this.states,
- oldTreeData = _states3.treeData,
- defaultExpandAll = _states3.defaultExpandAll,
- expandRowKeys = _states3.expandRowKeys,
- lazy = _states3.lazy;
- var rootLazyRowKeys = [];
- var getExpanded = function getExpanded(oldValue, key) {
- var included = defaultExpandAll || expandRowKeys && expandRowKeys.indexOf(key) !== -1;
- return !!(oldValue && oldValue.expanded || included);
- };
- // 合并 expanded 与 display,确保数据刷新后,状态不变
- keys.forEach(function (key) {
- var oldValue = oldTreeData[key];
- var newValue = _extends({}, nested[key]);
- newValue.expanded = getExpanded(oldValue, key);
- if (newValue.lazy) {
- var _ref = oldValue || {},
- _ref$loaded = _ref.loaded,
- loaded = _ref$loaded === undefined ? false : _ref$loaded,
- _ref$loading = _ref.loading,
- loading = _ref$loading === undefined ? false : _ref$loading;
- newValue.loaded = !!loaded;
- newValue.loading = !!loading;
- rootLazyRowKeys.push(key);
- }
- newTreeData[key] = newValue;
- });
- // 根据懒加载数据更新 treeData
- var lazyKeys = Object.keys(normalizedLazyNode);
- if (lazy && lazyKeys.length && rootLazyRowKeys.length) {
- lazyKeys.forEach(function (key) {
- var oldValue = oldTreeData[key];
- var lazyNodeChildren = normalizedLazyNode[key].children;
- if (rootLazyRowKeys.indexOf(key) !== -1) {
- // 懒加载的 root 节点,更新一下原有的数据,原来的 children 一定是空数组
- if (newTreeData[key].children.length !== 0) {
- throw new Error('[ElTable]children must be an empty array.');
- }
- newTreeData[key].children = lazyNodeChildren;
- } else {
- var _ref2 = oldValue || {},
- _ref2$loaded = _ref2.loaded,
- loaded = _ref2$loaded === undefined ? false : _ref2$loaded,
- _ref2$loading = _ref2.loading,
- loading = _ref2$loading === undefined ? false : _ref2$loading;
- newTreeData[key] = {
- lazy: true,
- loaded: !!loaded,
- loading: !!loading,
- expanded: getExpanded(oldValue, key),
- children: lazyNodeChildren,
- level: ''
- };
- }
- });
- }
- }
- this.states.treeData = newTreeData;
- this.updateTableScrollY();
- },
- updateTreeExpandKeys: function updateTreeExpandKeys(value) {
- this.states.expandRowKeys = value;
- this.updateTreeData();
- },
- toggleTreeExpansion: function toggleTreeExpansion(row, expanded) {
- this.assertRowKey();
- var _states4 = this.states,
- rowKey = _states4.rowKey,
- treeData = _states4.treeData;
- var id = getRowIdentity(row, rowKey);
- var data = id && treeData[id];
- if (id && data && 'expanded' in data) {
- var oldExpanded = data.expanded;
- expanded = typeof expanded === 'undefined' ? !data.expanded : expanded;
- treeData[id].expanded = expanded;
- if (oldExpanded !== expanded) {
- this.table.$emit('expand-change', row, expanded);
- }
- this.updateTableScrollY();
- }
- },
- loadOrToggle: function loadOrToggle(row) {
- this.assertRowKey();
- var _states5 = this.states,
- lazy = _states5.lazy,
- treeData = _states5.treeData,
- rowKey = _states5.rowKey;
- var id = getRowIdentity(row, rowKey);
- var data = treeData[id];
- if (lazy && data && 'loaded' in data && !data.loaded) {
- this.loadData(row, id, data);
- } else {
- this.toggleTreeExpansion(row);
- }
- },
- loadData: function loadData(row, key, treeNode) {
- var _this = this;
- var load = this.table.load;
- var rawTreeData = this.states.treeData;
- if (load && !rawTreeData[key].loaded) {
- rawTreeData[key].loading = true;
- load(row, treeNode, function (data) {
- if (!Array.isArray(data)) {
- throw new Error('[ElTable] data must be an array');
- }
- var _states6 = _this.states,
- lazyTreeNodeMap = _states6.lazyTreeNodeMap,
- treeData = _states6.treeData;
- treeData[key].loading = false;
- treeData[key].loaded = true;
- treeData[key].expanded = true;
- if (data.length) {
- _this.$set(lazyTreeNodeMap, key, data);
- }
- _this.table.$emit('expand-change', row, true);
- });
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/table/src/store/watcher.js
- var watcher_sortData = function sortData(data, states) {
- var sortingColumn = states.sortingColumn;
- if (!sortingColumn || typeof sortingColumn.sortable === 'string') {
- return data;
- }
- return util_orderBy(data, states.sortProp, states.sortOrder, sortingColumn.sortMethod, sortingColumn.sortBy);
- };
- var doFlattenColumns = function doFlattenColumns(columns) {
- var result = [];
- columns.forEach(function (column) {
- if (column.children) {
- result.push.apply(result, doFlattenColumns(column.children));
- } else {
- result.push(column);
- }
- });
- return result;
- };
- /* harmony default export */ var watcher = (external_vue_default.a.extend({
- data: function data() {
- return {
- states: {
- // 3.0 版本后要求必须设置该属性
- rowKey: null,
- // 渲染的数据来源,是对 table 中的 data 过滤排序后的结果
- data: [],
- // 是否包含固定列
- isComplex: false,
- // 列
- _columns: [], // 不可响应的
- originColumns: [],
- columns: [],
- fixedColumns: [],
- rightFixedColumns: [],
- leafColumns: [],
- fixedLeafColumns: [],
- rightFixedLeafColumns: [],
- leafColumnsLength: 0,
- fixedLeafColumnsLength: 0,
- rightFixedLeafColumnsLength: 0,
- // 选择
- isAllSelected: false,
- selection: [],
- reserveSelection: false,
- selectOnIndeterminate: false,
- selectable: null,
- // 过滤
- filters: {}, // 不可响应的
- filteredData: null,
- // 排序
- sortingColumn: null,
- sortProp: null,
- sortOrder: null,
- hoverRow: null
- }
- };
- },
- mixins: [expand, store_current, tree],
- methods: {
- // 检查 rowKey 是否存在
- assertRowKey: function assertRowKey() {
- var rowKey = this.states.rowKey;
- if (!rowKey) throw new Error('[ElTable] prop row-key is required');
- },
- // 更新列
- updateColumns: function updateColumns() {
- var states = this.states;
- var _columns = states._columns || [];
- states.fixedColumns = _columns.filter(function (column) {
- return column.fixed === true || column.fixed === 'left';
- });
- states.rightFixedColumns = _columns.filter(function (column) {
- return column.fixed === 'right';
- });
- if (states.fixedColumns.length > 0 && _columns[0] && _columns[0].type === 'selection' && !_columns[0].fixed) {
- _columns[0].fixed = true;
- states.fixedColumns.unshift(_columns[0]);
- }
- var notFixedColumns = _columns.filter(function (column) {
- return !column.fixed;
- });
- states.originColumns = [].concat(states.fixedColumns).concat(notFixedColumns).concat(states.rightFixedColumns);
- var leafColumns = doFlattenColumns(notFixedColumns);
- var fixedLeafColumns = doFlattenColumns(states.fixedColumns);
- var rightFixedLeafColumns = doFlattenColumns(states.rightFixedColumns);
- states.leafColumnsLength = leafColumns.length;
- states.fixedLeafColumnsLength = fixedLeafColumns.length;
- states.rightFixedLeafColumnsLength = rightFixedLeafColumns.length;
- states.columns = [].concat(fixedLeafColumns).concat(leafColumns).concat(rightFixedLeafColumns);
- states.isComplex = states.fixedColumns.length > 0 || states.rightFixedColumns.length > 0;
- },
- // 更新 DOM
- scheduleLayout: function scheduleLayout(needUpdateColumns) {
- if (needUpdateColumns) {
- this.updateColumns();
- }
- this.table.debouncedUpdateLayout();
- },
- // 选择
- isSelected: function isSelected(row) {
- var _states$selection = this.states.selection,
- selection = _states$selection === undefined ? [] : _states$selection;
- return selection.indexOf(row) > -1;
- },
- clearSelection: function clearSelection() {
- var states = this.states;
- states.isAllSelected = false;
- var oldSelection = states.selection;
- if (oldSelection.length) {
- states.selection = [];
- this.table.$emit('selection-change', []);
- }
- },
- cleanSelection: function cleanSelection() {
- var states = this.states;
- var data = states.data,
- rowKey = states.rowKey,
- selection = states.selection;
- var deleted = void 0;
- if (rowKey) {
- deleted = [];
- var selectedMap = getKeysMap(selection, rowKey);
- var dataMap = getKeysMap(data, rowKey);
- for (var key in selectedMap) {
- if (selectedMap.hasOwnProperty(key) && !dataMap[key]) {
- deleted.push(selectedMap[key].row);
- }
- }
- } else {
- deleted = selection.filter(function (item) {
- return data.indexOf(item) === -1;
- });
- }
- if (deleted.length) {
- var newSelection = selection.filter(function (item) {
- return deleted.indexOf(item) === -1;
- });
- states.selection = newSelection;
- this.table.$emit('selection-change', newSelection.slice());
- }
- },
- toggleRowSelection: function toggleRowSelection(row, selected) {
- var emitChange = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
- var changed = toggleRowStatus(this.states.selection, row, selected);
- if (changed) {
- var newSelection = (this.states.selection || []).slice();
- // 调用 API 修改选中值,不触发 select 事件
- if (emitChange) {
- this.table.$emit('select', newSelection, row);
- }
- this.table.$emit('selection-change', newSelection);
- }
- },
- _toggleAllSelection: function _toggleAllSelection() {
- var states = this.states;
- var _states$data = states.data,
- data = _states$data === undefined ? [] : _states$data,
- selection = states.selection;
- // when only some rows are selected (but not all), select or deselect all of them
- // depending on the value of selectOnIndeterminate
- var value = states.selectOnIndeterminate ? !states.isAllSelected : !(states.isAllSelected || selection.length);
- states.isAllSelected = value;
- var selectionChanged = false;
- data.forEach(function (row, index) {
- if (states.selectable) {
- if (states.selectable.call(null, row, index) && toggleRowStatus(selection, row, value)) {
- selectionChanged = true;
- }
- } else {
- if (toggleRowStatus(selection, row, value)) {
- selectionChanged = true;
- }
- }
- });
- if (selectionChanged) {
- this.table.$emit('selection-change', selection ? selection.slice() : []);
- }
- this.table.$emit('select-all', selection);
- },
- updateSelectionByRowKey: function updateSelectionByRowKey() {
- var states = this.states;
- var selection = states.selection,
- rowKey = states.rowKey,
- data = states.data;
- var selectedMap = getKeysMap(selection, rowKey);
- data.forEach(function (row) {
- var rowId = getRowIdentity(row, rowKey);
- var rowInfo = selectedMap[rowId];
- if (rowInfo) {
- selection[rowInfo.index] = row;
- }
- });
- },
- updateAllSelected: function updateAllSelected() {
- var states = this.states;
- var selection = states.selection,
- rowKey = states.rowKey,
- selectable = states.selectable;
- // data 为 null 时,解构时的默认值会被忽略
- var data = states.data || [];
- if (data.length === 0) {
- states.isAllSelected = false;
- return;
- }
- var selectedMap = void 0;
- if (rowKey) {
- selectedMap = getKeysMap(selection, rowKey);
- }
- var isSelected = function isSelected(row) {
- if (selectedMap) {
- return !!selectedMap[getRowIdentity(row, rowKey)];
- } else {
- return selection.indexOf(row) !== -1;
- }
- };
- var isAllSelected = true;
- var selectedCount = 0;
- for (var i = 0, j = data.length; i < j; i++) {
- var item = data[i];
- var isRowSelectable = selectable && selectable.call(null, item, i);
- if (!isSelected(item)) {
- if (!selectable || isRowSelectable) {
- isAllSelected = false;
- break;
- }
- } else {
- selectedCount++;
- }
- }
- if (selectedCount === 0) isAllSelected = false;
- states.isAllSelected = isAllSelected;
- },
- // 过滤与排序
- updateFilters: function updateFilters(columns, values) {
- if (!Array.isArray(columns)) {
- columns = [columns];
- }
- var states = this.states;
- var filters = {};
- columns.forEach(function (col) {
- states.filters[col.id] = values;
- filters[col.columnKey || col.id] = values;
- });
- return filters;
- },
- updateSort: function updateSort(column, prop, order) {
- if (this.states.sortingColumn && this.states.sortingColumn !== column) {
- this.states.sortingColumn.order = null;
- }
- this.states.sortingColumn = column;
- this.states.sortProp = prop;
- this.states.sortOrder = order;
- },
- execFilter: function execFilter() {
- var _this = this;
- var states = this.states;
- var _data = states._data,
- filters = states.filters;
- var data = _data;
- Object.keys(filters).forEach(function (columnId) {
- var values = states.filters[columnId];
- if (!values || values.length === 0) return;
- var column = getColumnById(_this.states, columnId);
- if (column && column.filterMethod) {
- data = data.filter(function (row) {
- return values.some(function (value) {
- return column.filterMethod.call(null, value, row, column);
- });
- });
- }
- });
- states.filteredData = data;
- },
- execSort: function execSort() {
- var states = this.states;
- states.data = watcher_sortData(states.filteredData, states);
- },
- // 根据 filters 与 sort 去过滤 data
- execQuery: function execQuery(ignore) {
- if (!(ignore && ignore.filter)) {
- this.execFilter();
- }
- this.execSort();
- },
- clearFilter: function clearFilter(columnKeys) {
- var states = this.states;
- var _table$$refs = this.table.$refs,
- tableHeader = _table$$refs.tableHeader,
- fixedTableHeader = _table$$refs.fixedTableHeader,
- rightFixedTableHeader = _table$$refs.rightFixedTableHeader;
- var panels = {};
- if (tableHeader) panels = merge_default()(panels, tableHeader.filterPanels);
- if (fixedTableHeader) panels = merge_default()(panels, fixedTableHeader.filterPanels);
- if (rightFixedTableHeader) panels = merge_default()(panels, rightFixedTableHeader.filterPanels);
- var keys = Object.keys(panels);
- if (!keys.length) return;
- if (typeof columnKeys === 'string') {
- columnKeys = [columnKeys];
- }
- if (Array.isArray(columnKeys)) {
- var columns = columnKeys.map(function (key) {
- return getColumnByKey(states, key);
- });
- keys.forEach(function (key) {
- var column = columns.find(function (col) {
- return col.id === key;
- });
- if (column) {
- // TODO: 优化这里的代码
- panels[key].filteredValue = [];
- }
- });
- this.commit('filterChange', {
- column: columns,
- values: [],
- silent: true,
- multi: true
- });
- } else {
- keys.forEach(function (key) {
- // TODO: 优化这里的代码
- panels[key].filteredValue = [];
- });
- states.filters = {};
- this.commit('filterChange', {
- column: {},
- values: [],
- silent: true
- });
- }
- },
- clearSort: function clearSort() {
- var states = this.states;
- if (!states.sortingColumn) return;
- this.updateSort(null, null, null);
- this.commit('changeSortCondition', {
- silent: true
- });
- },
- // 适配层,expand-row-keys 在 Expand 与 TreeTable 中都有使用
- setExpandRowKeysAdapter: function setExpandRowKeysAdapter(val) {
- // 这里会触发额外的计算,但为了兼容性,暂时这么做
- this.setExpandRowKeys(val);
- this.updateTreeExpandKeys(val);
- },
- // 展开行与 TreeTable 都要使用
- toggleRowExpansionAdapter: function toggleRowExpansionAdapter(row, expanded) {
- var hasExpandColumn = this.states.columns.some(function (_ref) {
- var type = _ref.type;
- return type === 'expand';
- });
- if (hasExpandColumn) {
- this.toggleRowExpansion(row, expanded);
- } else {
- this.toggleTreeExpansion(row, expanded);
- }
- }
- }
- }));
- // CONCATENATED MODULE: ./packages/table/src/store/index.js
- watcher.prototype.mutations = {
- setData: function setData(states, data) {
- var dataInstanceChanged = states._data !== data;
- states._data = data;
- this.execQuery();
- // 数据变化,更新部分数据。
- // 没有使用 computed,而是手动更新部分数据 https://github.com/vuejs/vue/issues/6660#issuecomment-331417140
- this.updateCurrentRowData();
- this.updateExpandRows();
- if (states.reserveSelection) {
- this.assertRowKey();
- this.updateSelectionByRowKey();
- } else {
- if (dataInstanceChanged) {
- this.clearSelection();
- } else {
- this.cleanSelection();
- }
- }
- this.updateAllSelected();
- this.updateTableScrollY();
- },
- insertColumn: function insertColumn(states, column, index, parent) {
- var array = states._columns;
- if (parent) {
- array = parent.children;
- if (!array) array = parent.children = [];
- }
- if (typeof index !== 'undefined') {
- array.splice(index, 0, column);
- } else {
- array.push(column);
- }
- if (column.type === 'selection') {
- states.selectable = column.selectable;
- states.reserveSelection = column.reserveSelection;
- }
- if (this.table.$ready) {
- this.updateColumns(); // hack for dynamics insert column
- this.scheduleLayout();
- }
- },
- removeColumn: function removeColumn(states, column, parent) {
- var array = states._columns;
- if (parent) {
- array = parent.children;
- if (!array) array = parent.children = [];
- }
- if (array) {
- array.splice(array.indexOf(column), 1);
- }
- if (this.table.$ready) {
- this.updateColumns(); // hack for dynamics remove column
- this.scheduleLayout();
- }
- },
- sort: function sort(states, options) {
- var prop = options.prop,
- order = options.order,
- init = options.init;
- if (prop) {
- var column = Object(util_["arrayFind"])(states.columns, function (column) {
- return column.property === prop;
- });
- if (column) {
- column.order = order;
- this.updateSort(column, prop, order);
- this.commit('changeSortCondition', { init: init });
- }
- }
- },
- changeSortCondition: function changeSortCondition(states, options) {
- // 修复 pr https://github.com/ElemeFE/element/pull/15012 导致的 bug
- var column = states.sortingColumn,
- prop = states.sortProp,
- order = states.sortOrder;
- if (order === null) {
- states.sortingColumn = null;
- states.sortProp = null;
- }
- var ingore = { filter: true };
- this.execQuery(ingore);
- if (!options || !(options.silent || options.init)) {
- this.table.$emit('sort-change', {
- column: column,
- prop: prop,
- order: order
- });
- }
- this.updateTableScrollY();
- },
- filterChange: function filterChange(states, options) {
- var column = options.column,
- values = options.values,
- silent = options.silent;
- var newFilters = this.updateFilters(column, values);
- this.execQuery();
- if (!silent) {
- this.table.$emit('filter-change', newFilters);
- }
- this.updateTableScrollY();
- },
- toggleAllSelection: function toggleAllSelection() {
- this.toggleAllSelection();
- },
- rowSelectedChanged: function rowSelectedChanged(states, row) {
- this.toggleRowSelection(row);
- this.updateAllSelected();
- },
- setHoverRow: function setHoverRow(states, row) {
- states.hoverRow = row;
- },
- setCurrentRow: function setCurrentRow(states, row) {
- this.updateCurrentRow(row);
- }
- };
- watcher.prototype.commit = function (name) {
- var mutations = this.mutations;
- if (mutations[name]) {
- for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
- args[_key - 1] = arguments[_key];
- }
- mutations[name].apply(this, [this.states].concat(args));
- } else {
- throw new Error('Action not found: ' + name);
- }
- };
- watcher.prototype.updateTableScrollY = function () {
- external_vue_default.a.nextTick(this.table.updateScrollY);
- };
- /* harmony default export */ var src_store = (watcher);
- // CONCATENATED MODULE: ./packages/table/src/store/helper.js
- function createStore(table) {
- var initialState = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
- if (!table) {
- throw new Error('Table is required.');
- }
- var store = new src_store();
- store.table = table;
- // fix https://github.com/ElemeFE/element/issues/14075
- // related pr https://github.com/ElemeFE/element/pull/14146
- store.toggleAllSelection = debounce_default()(10, store._toggleAllSelection);
- Object.keys(initialState).forEach(function (key) {
- store.states[key] = initialState[key];
- });
- return store;
- }
- function mapStates(mapper) {
- var res = {};
- Object.keys(mapper).forEach(function (key) {
- var value = mapper[key];
- var fn = void 0;
- if (typeof value === 'string') {
- fn = function fn() {
- return this.store.states[value];
- };
- } else if (typeof value === 'function') {
- fn = function fn() {
- return value.call(this, this.store.states);
- };
- } else {
- console.error('invalid value type');
- }
- if (fn) {
- res[key] = fn;
- }
- });
- return res;
- };
- // EXTERNAL MODULE: external "element-ui/lib/utils/scrollbar-width"
- var scrollbar_width_ = __webpack_require__(31);
- var scrollbar_width_default = /*#__PURE__*/__webpack_require__.n(scrollbar_width_);
- // CONCATENATED MODULE: ./packages/table/src/table-layout.js
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- var table_layout_TableLayout = function () {
- function TableLayout(options) {
- _classCallCheck(this, TableLayout);
- this.observers = [];
- this.table = null;
- this.store = null;
- this.columns = null;
- this.fit = true;
- this.showHeader = true;
- this.height = null;
- this.scrollX = false;
- this.scrollY = false;
- this.bodyWidth = null;
- this.fixedWidth = null;
- this.rightFixedWidth = null;
- this.tableHeight = null;
- this.headerHeight = 44; // Table Header Height
- this.appendHeight = 0; // Append Slot Height
- this.footerHeight = 44; // Table Footer Height
- this.viewportHeight = null; // Table Height - Scroll Bar Height
- this.bodyHeight = null; // Table Height - Table Header Height
- this.fixedBodyHeight = null; // Table Height - Table Header Height - Scroll Bar Height
- this.gutterWidth = scrollbar_width_default()();
- for (var name in options) {
- if (options.hasOwnProperty(name)) {
- this[name] = options[name];
- }
- }
- if (!this.table) {
- throw new Error('table is required for Table Layout');
- }
- if (!this.store) {
- throw new Error('store is required for Table Layout');
- }
- }
- TableLayout.prototype.updateScrollY = function updateScrollY() {
- var height = this.height;
- if (height === null) return false;
- var bodyWrapper = this.table.bodyWrapper;
- if (this.table.$el && bodyWrapper) {
- var body = bodyWrapper.querySelector('.el-table__body');
- var prevScrollY = this.scrollY;
- var scrollY = body.offsetHeight > this.bodyHeight;
- this.scrollY = scrollY;
- return prevScrollY !== scrollY;
- }
- return false;
- };
- TableLayout.prototype.setHeight = function setHeight(value) {
- var _this = this;
- var prop = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'height';
- if (external_vue_default.a.prototype.$isServer) return;
- var el = this.table.$el;
- value = parseHeight(value);
- this.height = value;
- if (!el && (value || value === 0)) return external_vue_default.a.nextTick(function () {
- return _this.setHeight(value, prop);
- });
- if (typeof value === 'number') {
- el.style[prop] = value + 'px';
- this.updateElsHeight();
- } else if (typeof value === 'string') {
- el.style[prop] = value;
- this.updateElsHeight();
- }
- };
- TableLayout.prototype.setMaxHeight = function setMaxHeight(value) {
- this.setHeight(value, 'max-height');
- };
- TableLayout.prototype.getFlattenColumns = function getFlattenColumns() {
- var flattenColumns = [];
- var columns = this.table.columns;
- columns.forEach(function (column) {
- if (column.isColumnGroup) {
- flattenColumns.push.apply(flattenColumns, column.columns);
- } else {
- flattenColumns.push(column);
- }
- });
- return flattenColumns;
- };
- TableLayout.prototype.updateElsHeight = function updateElsHeight() {
- var _this2 = this;
- if (!this.table.$ready) return external_vue_default.a.nextTick(function () {
- return _this2.updateElsHeight();
- });
- var _table$$refs = this.table.$refs,
- headerWrapper = _table$$refs.headerWrapper,
- appendWrapper = _table$$refs.appendWrapper,
- footerWrapper = _table$$refs.footerWrapper;
- this.appendHeight = appendWrapper ? appendWrapper.offsetHeight : 0;
- if (this.showHeader && !headerWrapper) return;
- // fix issue (https://github.com/ElemeFE/element/pull/16956)
- var headerTrElm = headerWrapper ? headerWrapper.querySelector('.el-table__header tr') : null;
- var noneHeader = this.headerDisplayNone(headerTrElm);
- var headerHeight = this.headerHeight = !this.showHeader ? 0 : headerWrapper.offsetHeight;
- if (this.showHeader && !noneHeader && headerWrapper.offsetWidth > 0 && (this.table.columns || []).length > 0 && headerHeight < 2) {
- return external_vue_default.a.nextTick(function () {
- return _this2.updateElsHeight();
- });
- }
- var tableHeight = this.tableHeight = this.table.$el.clientHeight;
- var footerHeight = this.footerHeight = footerWrapper ? footerWrapper.offsetHeight : 0;
- if (this.height !== null) {
- this.bodyHeight = tableHeight - headerHeight - footerHeight + (footerWrapper ? 1 : 0);
- }
- this.fixedBodyHeight = this.scrollX ? this.bodyHeight - this.gutterWidth : this.bodyHeight;
- var noData = !(this.store.states.data && this.store.states.data.length);
- this.viewportHeight = this.scrollX ? tableHeight - (noData ? 0 : this.gutterWidth) : tableHeight;
- this.updateScrollY();
- this.notifyObservers('scrollable');
- };
- TableLayout.prototype.headerDisplayNone = function headerDisplayNone(elm) {
- if (!elm) return true;
- var headerChild = elm;
- while (headerChild.tagName !== 'DIV') {
- if (getComputedStyle(headerChild).display === 'none') {
- return true;
- }
- headerChild = headerChild.parentElement;
- }
- return false;
- };
- TableLayout.prototype.updateColumnsWidth = function updateColumnsWidth() {
- if (external_vue_default.a.prototype.$isServer) return;
- var fit = this.fit;
- var bodyWidth = this.table.$el.clientWidth;
- var bodyMinWidth = 0;
- var flattenColumns = this.getFlattenColumns();
- var flexColumns = flattenColumns.filter(function (column) {
- return typeof column.width !== 'number';
- });
- flattenColumns.forEach(function (column) {
- // Clean those columns whose width changed from flex to unflex
- if (typeof column.width === 'number' && column.realWidth) column.realWidth = null;
- });
- if (flexColumns.length > 0 && fit) {
- flattenColumns.forEach(function (column) {
- bodyMinWidth += column.width || column.minWidth || 80;
- });
- var scrollYWidth = this.scrollY ? this.gutterWidth : 0;
- if (bodyMinWidth <= bodyWidth - scrollYWidth) {
- // DON'T HAVE SCROLL BAR
- this.scrollX = false;
- var totalFlexWidth = bodyWidth - scrollYWidth - bodyMinWidth;
- if (flexColumns.length === 1) {
- flexColumns[0].realWidth = (flexColumns[0].minWidth || 80) + totalFlexWidth;
- } else {
- var allColumnsWidth = flexColumns.reduce(function (prev, column) {
- return prev + (column.minWidth || 80);
- }, 0);
- var flexWidthPerPixel = totalFlexWidth / allColumnsWidth;
- var noneFirstWidth = 0;
- flexColumns.forEach(function (column, index) {
- if (index === 0) return;
- var flexWidth = Math.floor((column.minWidth || 80) * flexWidthPerPixel);
- noneFirstWidth += flexWidth;
- column.realWidth = (column.minWidth || 80) + flexWidth;
- });
- flexColumns[0].realWidth = (flexColumns[0].minWidth || 80) + totalFlexWidth - noneFirstWidth;
- }
- } else {
- // HAVE HORIZONTAL SCROLL BAR
- this.scrollX = true;
- flexColumns.forEach(function (column) {
- column.realWidth = column.minWidth;
- });
- }
- this.bodyWidth = Math.max(bodyMinWidth, bodyWidth);
- this.table.resizeState.width = this.bodyWidth;
- } else {
- flattenColumns.forEach(function (column) {
- if (!column.width && !column.minWidth) {
- column.realWidth = 80;
- } else {
- column.realWidth = column.width || column.minWidth;
- }
- bodyMinWidth += column.realWidth;
- });
- this.scrollX = bodyMinWidth > bodyWidth;
- this.bodyWidth = bodyMinWidth;
- }
- var fixedColumns = this.store.states.fixedColumns;
- if (fixedColumns.length > 0) {
- var fixedWidth = 0;
- fixedColumns.forEach(function (column) {
- fixedWidth += column.realWidth || column.width;
- });
- this.fixedWidth = fixedWidth;
- }
- var rightFixedColumns = this.store.states.rightFixedColumns;
- if (rightFixedColumns.length > 0) {
- var rightFixedWidth = 0;
- rightFixedColumns.forEach(function (column) {
- rightFixedWidth += column.realWidth || column.width;
- });
- this.rightFixedWidth = rightFixedWidth;
- }
- this.notifyObservers('columns');
- };
- TableLayout.prototype.addObserver = function addObserver(observer) {
- this.observers.push(observer);
- };
- TableLayout.prototype.removeObserver = function removeObserver(observer) {
- var index = this.observers.indexOf(observer);
- if (index !== -1) {
- this.observers.splice(index, 1);
- }
- };
- TableLayout.prototype.notifyObservers = function notifyObservers(event) {
- var _this3 = this;
- var observers = this.observers;
- observers.forEach(function (observer) {
- switch (event) {
- case 'columns':
- observer.onColumnsChange(_this3);
- break;
- case 'scrollable':
- observer.onScrollableChange(_this3);
- break;
- default:
- throw new Error('Table Layout don\'t have event ' + event + '.');
- }
- });
- };
- return TableLayout;
- }();
- /* harmony default export */ var table_layout = (table_layout_TableLayout);
- // CONCATENATED MODULE: ./packages/table/src/layout-observer.js
- /* harmony default export */ var layout_observer = ({
- created: function created() {
- this.tableLayout.addObserver(this);
- },
- destroyed: function destroyed() {
- this.tableLayout.removeObserver(this);
- },
- computed: {
- tableLayout: function tableLayout() {
- var layout = this.layout;
- if (!layout && this.table) {
- layout = this.table.layout;
- }
- if (!layout) {
- throw new Error('Can not find table layout.');
- }
- return layout;
- }
- },
- mounted: function mounted() {
- this.onColumnsChange(this.tableLayout);
- this.onScrollableChange(this.tableLayout);
- },
- updated: function updated() {
- if (this.__updated__) return;
- this.onColumnsChange(this.tableLayout);
- this.onScrollableChange(this.tableLayout);
- this.__updated__ = true;
- },
- methods: {
- onColumnsChange: function onColumnsChange(layout) {
- var cols = this.$el.querySelectorAll('colgroup > col');
- if (!cols.length) return;
- var flattenColumns = layout.getFlattenColumns();
- var columnsMap = {};
- flattenColumns.forEach(function (column) {
- columnsMap[column.id] = column;
- });
- for (var i = 0, j = cols.length; i < j; i++) {
- var col = cols[i];
- var name = col.getAttribute('name');
- var column = columnsMap[name];
- if (column) {
- col.setAttribute('width', column.realWidth || column.width);
- }
- }
- },
- onScrollableChange: function onScrollableChange(layout) {
- var cols = this.$el.querySelectorAll('colgroup > col[name=gutter]');
- for (var i = 0, j = cols.length; i < j; i++) {
- var col = cols[i];
- col.setAttribute('width', layout.scrollY ? layout.gutterWidth : '0');
- }
- var ths = this.$el.querySelectorAll('th.gutter');
- for (var _i = 0, _j = ths.length; _i < _j; _i++) {
- var th = ths[_i];
- th.style.width = layout.scrollY ? layout.gutterWidth + 'px' : '0';
- th.style.display = layout.scrollY ? '' : 'none';
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/table/src/table-row.js
- var table_row_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- /* harmony default export */ var table_row = ({
- name: 'ElTableRow',
- props: ['columns', 'row', 'index', 'isSelected', 'isExpanded', 'store', 'context', 'firstDefaultColumnIndex', 'treeRowData', 'treeIndent', 'columnsHidden', 'getSpan', 'getColspanRealWidth', 'getCellStyle', 'getCellClass', 'handleCellMouseLeave', 'handleCellMouseEnter', 'fixed'],
- components: {
- ElCheckbox: checkbox_default.a
- },
- render: function render() {
- var _this = this;
- var h = arguments[0];
- var columns = this.columns,
- row = this.row,
- $index = this.index,
- store = this.store,
- context = this.context,
- firstDefaultColumnIndex = this.firstDefaultColumnIndex,
- treeRowData = this.treeRowData,
- treeIndent = this.treeIndent,
- _columnsHidden = this.columnsHidden,
- columnsHidden = _columnsHidden === undefined ? [] : _columnsHidden,
- isSelected = this.isSelected,
- isExpanded = this.isExpanded;
- return h('tr', [columns.map(function (column, cellIndex) {
- var _getSpan = _this.getSpan(row, column, $index, cellIndex),
- rowspan = _getSpan.rowspan,
- colspan = _getSpan.colspan;
- if (!rowspan || !colspan) {
- return null;
- }
- var columnData = table_row_extends({}, column);
- columnData.realWidth = _this.getColspanRealWidth(columns, colspan, cellIndex);
- var data = {
- store: store,
- isSelected: isSelected,
- isExpanded: isExpanded,
- _self: context,
- column: columnData,
- row: row,
- $index: $index
- };
- if (cellIndex === firstDefaultColumnIndex && treeRowData) {
- data.treeNode = {
- indent: treeRowData.level * treeIndent,
- level: treeRowData.level
- };
- if (typeof treeRowData.expanded === 'boolean') {
- data.treeNode.expanded = treeRowData.expanded;
- // 表明是懒加载
- if ('loading' in treeRowData) {
- data.treeNode.loading = treeRowData.loading;
- }
- if ('noLazyChildren' in treeRowData) {
- data.treeNode.noLazyChildren = treeRowData.noLazyChildren;
- }
- }
- }
- return h(
- 'td',
- {
- style: _this.getCellStyle($index, cellIndex, row, column),
- 'class': _this.getCellClass($index, cellIndex, row, column),
- attrs: { rowspan: rowspan,
- colspan: colspan
- },
- on: {
- 'mouseenter': function mouseenter($event) {
- return _this.handleCellMouseEnter($event, row);
- },
- 'mouseleave': _this.handleCellMouseLeave
- }
- },
- [column.renderCell.call(_this._renderProxy, _this.$createElement, data, columnsHidden[cellIndex])]
- );
- })]);
- }
- });
- // CONCATENATED MODULE: ./packages/table/src/table-body.js
- var table_body_typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- var table_body_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- /* harmony default export */ var table_body = ({
- name: 'ElTableBody',
- mixins: [layout_observer],
- components: {
- ElCheckbox: checkbox_default.a,
- ElTooltip: tooltip_default.a,
- TableRow: table_row
- },
- props: {
- store: {
- required: true
- },
- stripe: Boolean,
- context: {},
- rowClassName: [String, Function],
- rowStyle: [Object, Function],
- fixed: String,
- highlight: Boolean
- },
- render: function render(h) {
- var _this = this;
- var data = this.data || [];
- return h(
- 'table',
- {
- 'class': 'el-table__body',
- attrs: { cellspacing: '0',
- cellpadding: '0',
- border: '0' }
- },
- [h('colgroup', [this.columns.map(function (column) {
- return h('col', {
- attrs: { name: column.id },
- key: column.id });
- })]), h('tbody', [data.reduce(function (acc, row) {
- return acc.concat(_this.wrappedRowRender(row, acc.length));
- }, []), h('el-tooltip', {
- attrs: { effect: this.table.tooltipEffect, placement: 'top', content: this.tooltipContent },
- ref: 'tooltip' })])]
- );
- },
- computed: table_body_extends({
- table: function table() {
- return this.$parent;
- }
- }, mapStates({
- data: 'data',
- columns: 'columns',
- treeIndent: 'indent',
- leftFixedLeafCount: 'fixedLeafColumnsLength',
- rightFixedLeafCount: 'rightFixedLeafColumnsLength',
- columnsCount: function columnsCount(states) {
- return states.columns.length;
- },
- leftFixedCount: function leftFixedCount(states) {
- return states.fixedColumns.length;
- },
- rightFixedCount: function rightFixedCount(states) {
- return states.rightFixedColumns.length;
- },
- hasExpandColumn: function hasExpandColumn(states) {
- return states.columns.some(function (_ref) {
- var type = _ref.type;
- return type === 'expand';
- });
- }
- }), {
- columnsHidden: function columnsHidden() {
- var _this2 = this;
- return this.columns.map(function (column, index) {
- return _this2.isColumnHidden(index);
- });
- },
- firstDefaultColumnIndex: function firstDefaultColumnIndex() {
- return Object(util_["arrayFindIndex"])(this.columns, function (_ref2) {
- var type = _ref2.type;
- return type === 'default';
- });
- }
- }),
- watch: {
- // don't trigger getter of currentRow in getCellClass. see https://jsfiddle.net/oe2b4hqt/
- // update DOM manually. see https://github.com/ElemeFE/element/pull/13954/files#diff-9b450c00d0a9dec0ffad5a3176972e40
- 'store.states.hoverRow': function storeStatesHoverRow(newVal, oldVal) {
- var _this3 = this;
- if (!this.store.states.isComplex || this.$isServer) return;
- var raf = window.requestAnimationFrame;
- if (!raf) {
- raf = function raf(fn) {
- return setTimeout(fn, 16);
- };
- }
- raf(function () {
- var rows = _this3.$el.querySelectorAll('.el-table__row');
- var oldRow = rows[oldVal];
- var newRow = rows[newVal];
- if (oldRow) {
- Object(dom_["removeClass"])(oldRow, 'hover-row');
- }
- if (newRow) {
- Object(dom_["addClass"])(newRow, 'hover-row');
- }
- });
- }
- },
- data: function data() {
- return {
- tooltipContent: ''
- };
- },
- created: function created() {
- this.activateTooltip = debounce_default()(50, function (tooltip) {
- return tooltip.handleShowPopper();
- });
- },
- methods: {
- getKeyOfRow: function getKeyOfRow(row, index) {
- var rowKey = this.table.rowKey;
- if (rowKey) {
- return getRowIdentity(row, rowKey);
- }
- return index;
- },
- isColumnHidden: function isColumnHidden(index) {
- if (this.fixed === true || this.fixed === 'left') {
- return index >= this.leftFixedLeafCount;
- } else if (this.fixed === 'right') {
- return index < this.columnsCount - this.rightFixedLeafCount;
- } else {
- return index < this.leftFixedLeafCount || index >= this.columnsCount - this.rightFixedLeafCount;
- }
- },
- getSpan: function getSpan(row, column, rowIndex, columnIndex) {
- var rowspan = 1;
- var colspan = 1;
- var fn = this.table.spanMethod;
- if (typeof fn === 'function') {
- var result = fn({
- row: row,
- column: column,
- rowIndex: rowIndex,
- columnIndex: columnIndex
- });
- if (Array.isArray(result)) {
- rowspan = result[0];
- colspan = result[1];
- } else if ((typeof result === 'undefined' ? 'undefined' : table_body_typeof(result)) === 'object') {
- rowspan = result.rowspan;
- colspan = result.colspan;
- }
- }
- return { rowspan: rowspan, colspan: colspan };
- },
- getRowStyle: function getRowStyle(row, rowIndex) {
- var rowStyle = this.table.rowStyle;
- if (typeof rowStyle === 'function') {
- return rowStyle.call(null, {
- row: row,
- rowIndex: rowIndex
- });
- }
- return rowStyle || null;
- },
- getRowClass: function getRowClass(row, rowIndex) {
- var selection = this.store.states.selection;
- var classes = ['el-table__row'];
- if (this.table.highlightCurrentRow && row === this.store.states.currentRow) {
- classes.push('current-row');
- }
- if (this.table.highlightSelectionRow) {
- for (var i = 0; i < selection.length; i++) {
- if (objectEquals(row, selection[i])) {
- classes.push('selection-row');
- }
- };
- }
- if (this.stripe && rowIndex % 2 === 1) {
- classes.push('el-table__row--striped');
- }
- var rowClassName = this.table.rowClassName;
- if (typeof rowClassName === 'string') {
- classes.push(rowClassName);
- } else if (typeof rowClassName === 'function') {
- classes.push(rowClassName.call(null, {
- row: row,
- rowIndex: rowIndex
- }));
- }
- if (this.store.states.expandRows.indexOf(row) > -1) {
- classes.push('expanded');
- }
- return classes;
- },
- getCellStyle: function getCellStyle(rowIndex, columnIndex, row, column) {
- var cellStyle = this.table.cellStyle;
- if (typeof cellStyle === 'function') {
- return cellStyle.call(null, {
- rowIndex: rowIndex,
- columnIndex: columnIndex,
- row: row,
- column: column
- });
- }
- return cellStyle;
- },
- getCellClass: function getCellClass(rowIndex, columnIndex, row, column) {
- var classes = [column.id, column.align, column.className];
- if (this.isColumnHidden(columnIndex)) {
- classes.push('is-hidden');
- }
- var cellClassName = this.table.cellClassName;
- if (typeof cellClassName === 'string') {
- classes.push(cellClassName);
- } else if (typeof cellClassName === 'function') {
- classes.push(cellClassName.call(null, {
- rowIndex: rowIndex,
- columnIndex: columnIndex,
- row: row,
- column: column
- }));
- }
- classes.push('el-table__cell');
- return classes.join(' ');
- },
- getColspanRealWidth: function getColspanRealWidth(columns, colspan, index) {
- if (colspan < 1) {
- return columns[index].realWidth;
- }
- var widthArr = columns.map(function (_ref3) {
- var realWidth = _ref3.realWidth;
- return realWidth;
- }).slice(index, index + colspan);
- return widthArr.reduce(function (acc, width) {
- return acc + width;
- }, -1);
- },
- handleCellMouseEnter: function handleCellMouseEnter(event, row) {
- var table = this.table;
- var cell = getCell(event);
- if (cell) {
- var column = getColumnByCell(table, cell);
- var hoverState = table.hoverState = { cell: cell, column: column, row: row };
- table.$emit('cell-mouse-enter', hoverState.row, hoverState.column, hoverState.cell, event);
- }
- // 判断是否text-overflow, 如果是就显示tooltip
- var cellChild = event.target.querySelector('.cell');
- if (!(Object(dom_["hasClass"])(cellChild, 'el-tooltip') && cellChild.childNodes.length)) {
- return;
- }
- // use range width instead of scrollWidth to determine whether the text is overflowing
- // to address a potential FireFox bug: https://bugzilla.mozilla.org/show_bug.cgi?id=1074543#c3
- var range = document.createRange();
- range.setStart(cellChild, 0);
- range.setEnd(cellChild, cellChild.childNodes.length);
- var rangeWidth = range.getBoundingClientRect().width;
- var padding = (parseInt(Object(dom_["getStyle"])(cellChild, 'paddingLeft'), 10) || 0) + (parseInt(Object(dom_["getStyle"])(cellChild, 'paddingRight'), 10) || 0);
- if ((rangeWidth + padding > cellChild.offsetWidth || cellChild.scrollWidth > cellChild.offsetWidth) && this.$refs.tooltip) {
- var tooltip = this.$refs.tooltip;
- // TODO 会引起整个 Table 的重新渲染,需要优化
- this.tooltipContent = cell.innerText || cell.textContent;
- tooltip.referenceElm = cell;
- tooltip.$refs.popper && (tooltip.$refs.popper.style.display = 'none');
- tooltip.doDestroy();
- tooltip.setExpectedState(true);
- this.activateTooltip(tooltip);
- }
- },
- handleCellMouseLeave: function handleCellMouseLeave(event) {
- var tooltip = this.$refs.tooltip;
- if (tooltip) {
- tooltip.setExpectedState(false);
- tooltip.handleClosePopper();
- }
- var cell = getCell(event);
- if (!cell) return;
- var oldHoverState = this.table.hoverState || {};
- this.table.$emit('cell-mouse-leave', oldHoverState.row, oldHoverState.column, oldHoverState.cell, event);
- },
- handleMouseEnter: debounce_default()(30, function (index) {
- this.store.commit('setHoverRow', index);
- }),
- handleMouseLeave: debounce_default()(30, function () {
- this.store.commit('setHoverRow', null);
- }),
- handleContextMenu: function handleContextMenu(event, row) {
- this.handleEvent(event, row, 'contextmenu');
- },
- handleDoubleClick: function handleDoubleClick(event, row) {
- this.handleEvent(event, row, 'dblclick');
- },
- handleClick: function handleClick(event, row) {
- this.store.commit('setCurrentRow', row);
- this.handleEvent(event, row, 'click');
- },
- handleEvent: function handleEvent(event, row, name) {
- var table = this.table;
- var cell = getCell(event);
- var column = void 0;
- if (cell) {
- column = getColumnByCell(table, cell);
- if (column) {
- table.$emit('cell-' + name, row, column, cell, event);
- }
- }
- table.$emit('row-' + name, row, column, event);
- },
- rowRender: function rowRender(row, $index, treeRowData) {
- var _this4 = this;
- var h = this.$createElement;
- var treeIndent = this.treeIndent,
- columns = this.columns,
- firstDefaultColumnIndex = this.firstDefaultColumnIndex;
- var rowClasses = this.getRowClass(row, $index);
- var display = true;
- if (treeRowData) {
- rowClasses.push('el-table__row--level-' + treeRowData.level);
- display = treeRowData.display;
- }
- // 指令 v-show 会覆盖 row-style 中 display
- // 使用 :style 代替 v-show https://github.com/ElemeFE/element/issues/16995
- var displayStyle = display ? null : {
- display: 'none'
- };
- return h(table_row, {
- style: [displayStyle, this.getRowStyle(row, $index)],
- 'class': rowClasses,
- key: this.getKeyOfRow(row, $index),
- nativeOn: {
- 'dblclick': function dblclick($event) {
- return _this4.handleDoubleClick($event, row);
- },
- 'click': function click($event) {
- return _this4.handleClick($event, row);
- },
- 'contextmenu': function contextmenu($event) {
- return _this4.handleContextMenu($event, row);
- },
- 'mouseenter': function mouseenter(_) {
- return _this4.handleMouseEnter($index);
- },
- 'mouseleave': this.handleMouseLeave
- },
- attrs: {
- columns: columns,
- row: row,
- index: $index,
- store: this.store,
- context: this.context || this.table.$vnode.context,
- firstDefaultColumnIndex: firstDefaultColumnIndex,
- treeRowData: treeRowData,
- treeIndent: treeIndent,
- columnsHidden: this.columnsHidden,
- getSpan: this.getSpan,
- getColspanRealWidth: this.getColspanRealWidth,
- getCellStyle: this.getCellStyle,
- getCellClass: this.getCellClass,
- handleCellMouseEnter: this.handleCellMouseEnter,
- handleCellMouseLeave: this.handleCellMouseLeave,
- isSelected: this.store.isSelected(row),
- isExpanded: this.store.states.expandRows.indexOf(row) > -1,
- fixed: this.fixed
- }
- });
- },
- wrappedRowRender: function wrappedRowRender(row, $index) {
- var _this5 = this;
- var h = this.$createElement;
- var store = this.store;
- var isRowExpanded = store.isRowExpanded,
- assertRowKey = store.assertRowKey;
- var _store$states = store.states,
- treeData = _store$states.treeData,
- lazyTreeNodeMap = _store$states.lazyTreeNodeMap,
- childrenColumnName = _store$states.childrenColumnName,
- rowKey = _store$states.rowKey;
- if (this.hasExpandColumn && isRowExpanded(row)) {
- var renderExpanded = this.table.renderExpanded;
- var tr = this.rowRender(row, $index);
- if (!renderExpanded) {
- console.error('[Element Error]renderExpanded is required.');
- return tr;
- }
- // 使用二维数组,避免修改 $index
- return [[tr, h(
- 'tr',
- { key: 'expanded-row__' + tr.key },
- [h(
- 'td',
- {
- attrs: { colspan: this.columnsCount },
- 'class': 'el-table__cell el-table__expanded-cell' },
- [renderExpanded(this.$createElement, { row: row, $index: $index, store: this.store })]
- )]
- )]];
- } else if (Object.keys(treeData).length) {
- assertRowKey();
- // TreeTable 时,rowKey 必须由用户设定,不使用 getKeyOfRow 计算
- // 在调用 rowRender 函数时,仍然会计算 rowKey,不太好的操作
- var key = getRowIdentity(row, rowKey);
- var cur = treeData[key];
- var treeRowData = null;
- if (cur) {
- treeRowData = {
- expanded: cur.expanded,
- level: cur.level,
- display: true
- };
- if (typeof cur.lazy === 'boolean') {
- if (typeof cur.loaded === 'boolean' && cur.loaded) {
- treeRowData.noLazyChildren = !(cur.children && cur.children.length);
- }
- treeRowData.loading = cur.loading;
- }
- }
- var tmp = [this.rowRender(row, $index, treeRowData)];
- // 渲染嵌套数据
- if (cur) {
- // currentRow 记录的是 index,所以还需主动增加 TreeTable 的 index
- var i = 0;
- var traverse = function traverse(children, parent) {
- if (!(children && children.length && parent)) return;
- children.forEach(function (node) {
- // 父节点的 display 状态影响子节点的显示状态
- var innerTreeRowData = {
- display: parent.display && parent.expanded,
- level: parent.level + 1
- };
- var childKey = getRowIdentity(node, rowKey);
- if (childKey === undefined || childKey === null) {
- throw new Error('for nested data item, row-key is required.');
- }
- cur = table_body_extends({}, treeData[childKey]);
- // 对于当前节点,分成有无子节点两种情况。
- // 如果包含子节点的,设置 expanded 属性。
- // 对于它子节点的 display 属性由它本身的 expanded 与 display 共同决定。
- if (cur) {
- innerTreeRowData.expanded = cur.expanded;
- // 懒加载的某些节点,level 未知
- cur.level = cur.level || innerTreeRowData.level;
- cur.display = !!(cur.expanded && innerTreeRowData.display);
- if (typeof cur.lazy === 'boolean') {
- if (typeof cur.loaded === 'boolean' && cur.loaded) {
- innerTreeRowData.noLazyChildren = !(cur.children && cur.children.length);
- }
- innerTreeRowData.loading = cur.loading;
- }
- }
- i++;
- tmp.push(_this5.rowRender(node, $index + i, innerTreeRowData));
- if (cur) {
- var _nodes = lazyTreeNodeMap[childKey] || node[childrenColumnName];
- traverse(_nodes, cur);
- }
- });
- };
- // 对于 root 节点,display 一定为 true
- cur.display = true;
- var nodes = lazyTreeNodeMap[key] || row[childrenColumnName];
- traverse(nodes, cur);
- }
- return tmp;
- } else {
- return this.rowRender(row, $index);
- }
- }
- }
- });
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/table/src/filter-panel.vue?vue&type=template&id=7f2c919f&
- var filter_panelvue_type_template_id_7f2c919f_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("transition", { attrs: { name: "el-zoom-in-top" } }, [
- _vm.multiple
- ? _c(
- "div",
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: _vm.handleOutsideClick,
- expression: "handleOutsideClick"
- },
- {
- name: "show",
- rawName: "v-show",
- value: _vm.showPopper,
- expression: "showPopper"
- }
- ],
- staticClass: "el-table-filter"
- },
- [
- _c(
- "div",
- { staticClass: "el-table-filter__content" },
- [
- _c(
- "el-scrollbar",
- { attrs: { "wrap-class": "el-table-filter__wrap" } },
- [
- _c(
- "el-checkbox-group",
- {
- staticClass: "el-table-filter__checkbox-group",
- model: {
- value: _vm.filteredValue,
- callback: function($$v) {
- _vm.filteredValue = $$v
- },
- expression: "filteredValue"
- }
- },
- _vm._l(_vm.filters, function(filter) {
- return _c(
- "el-checkbox",
- { key: filter.value, attrs: { label: filter.value } },
- [_vm._v(_vm._s(filter.text))]
- )
- }),
- 1
- )
- ],
- 1
- )
- ],
- 1
- ),
- _c("div", { staticClass: "el-table-filter__bottom" }, [
- _c(
- "button",
- {
- class: { "is-disabled": _vm.filteredValue.length === 0 },
- attrs: { disabled: _vm.filteredValue.length === 0 },
- on: { click: _vm.handleConfirm }
- },
- [_vm._v(_vm._s(_vm.t("el.table.confirmFilter")))]
- ),
- _c("button", { on: { click: _vm.handleReset } }, [
- _vm._v(_vm._s(_vm.t("el.table.resetFilter")))
- ])
- ])
- ]
- )
- : _c(
- "div",
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: _vm.handleOutsideClick,
- expression: "handleOutsideClick"
- },
- {
- name: "show",
- rawName: "v-show",
- value: _vm.showPopper,
- expression: "showPopper"
- }
- ],
- staticClass: "el-table-filter"
- },
- [
- _c(
- "ul",
- { staticClass: "el-table-filter__list" },
- [
- _c(
- "li",
- {
- staticClass: "el-table-filter__list-item",
- class: {
- "is-active":
- _vm.filterValue === undefined ||
- _vm.filterValue === null
- },
- on: {
- click: function($event) {
- _vm.handleSelect(null)
- }
- }
- },
- [_vm._v(_vm._s(_vm.t("el.table.clearFilter")))]
- ),
- _vm._l(_vm.filters, function(filter) {
- return _c(
- "li",
- {
- key: filter.value,
- staticClass: "el-table-filter__list-item",
- class: { "is-active": _vm.isActive(filter) },
- attrs: { label: filter.value },
- on: {
- click: function($event) {
- _vm.handleSelect(filter.value)
- }
- }
- },
- [_vm._v(_vm._s(filter.text))]
- )
- })
- ],
- 2
- )
- ]
- )
- ])
- }
- var filter_panelvue_type_template_id_7f2c919f_staticRenderFns = []
- filter_panelvue_type_template_id_7f2c919f_render._withStripped = true
- // CONCATENATED MODULE: ./packages/table/src/filter-panel.vue?vue&type=template&id=7f2c919f&
- // CONCATENATED MODULE: ./packages/table/src/dropdown.js
- var dropdowns = [];
- !external_vue_default.a.prototype.$isServer && document.addEventListener('click', function (event) {
- dropdowns.forEach(function (dropdown) {
- var target = event.target;
- if (!dropdown || !dropdown.$el) return;
- if (target === dropdown.$el || dropdown.$el.contains(target)) {
- return;
- }
- dropdown.handleOutsideClick && dropdown.handleOutsideClick(event);
- });
- });
- /* harmony default export */ var src_dropdown = ({
- open: function open(instance) {
- if (instance) {
- dropdowns.push(instance);
- }
- },
- close: function close(instance) {
- var index = dropdowns.indexOf(instance);
- if (index !== -1) {
- dropdowns.splice(instance, 1);
- }
- }
- });
- // EXTERNAL MODULE: external "element-ui/lib/checkbox-group"
- var checkbox_group_ = __webpack_require__(32);
- var checkbox_group_default = /*#__PURE__*/__webpack_require__.n(checkbox_group_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/table/src/filter-panel.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var filter_panelvue_type_script_lang_js_ = ({
- name: 'ElTableFilterPanel',
- mixins: [vue_popper_default.a, locale_default.a],
- directives: {
- Clickoutside: clickoutside_default.a
- },
- components: {
- ElCheckbox: checkbox_default.a,
- ElCheckboxGroup: checkbox_group_default.a,
- ElScrollbar: scrollbar_default.a
- },
- props: {
- placement: {
- type: String,
- default: 'bottom-end'
- }
- },
- methods: {
- isActive: function isActive(filter) {
- return filter.value === this.filterValue;
- },
- handleOutsideClick: function handleOutsideClick() {
- var _this = this;
- setTimeout(function () {
- _this.showPopper = false;
- }, 16);
- },
- handleConfirm: function handleConfirm() {
- this.confirmFilter(this.filteredValue);
- this.handleOutsideClick();
- },
- handleReset: function handleReset() {
- this.filteredValue = [];
- this.confirmFilter(this.filteredValue);
- this.handleOutsideClick();
- },
- handleSelect: function handleSelect(filterValue) {
- this.filterValue = filterValue;
- if (typeof filterValue !== 'undefined' && filterValue !== null) {
- this.confirmFilter(this.filteredValue);
- } else {
- this.confirmFilter([]);
- }
- this.handleOutsideClick();
- },
- confirmFilter: function confirmFilter(filteredValue) {
- this.table.store.commit('filterChange', {
- column: this.column,
- values: filteredValue
- });
- this.table.store.updateAllSelected();
- }
- },
- data: function data() {
- return {
- table: null,
- cell: null,
- column: null
- };
- },
- computed: {
- filters: function filters() {
- return this.column && this.column.filters;
- },
- filterValue: {
- get: function get() {
- return (this.column.filteredValue || [])[0];
- },
- set: function set(value) {
- if (this.filteredValue) {
- if (typeof value !== 'undefined' && value !== null) {
- this.filteredValue.splice(0, 1, value);
- } else {
- this.filteredValue.splice(0, 1);
- }
- }
- }
- },
- filteredValue: {
- get: function get() {
- if (this.column) {
- return this.column.filteredValue || [];
- }
- return [];
- },
- set: function set(value) {
- if (this.column) {
- this.column.filteredValue = value;
- }
- }
- },
- multiple: function multiple() {
- if (this.column) {
- return this.column.filterMultiple;
- }
- return true;
- }
- },
- mounted: function mounted() {
- var _this2 = this;
- this.popperElm = this.$el;
- this.referenceElm = this.cell;
- this.table.bodyWrapper.addEventListener('scroll', function () {
- _this2.updatePopper();
- });
- this.$watch('showPopper', function (value) {
- if (_this2.column) _this2.column.filterOpened = value;
- if (value) {
- src_dropdown.open(_this2);
- } else {
- src_dropdown.close(_this2);
- }
- });
- },
- watch: {
- showPopper: function showPopper(val) {
- if (val === true && parseInt(this.popperJS._popper.style.zIndex, 10) < popup_["PopupManager"].zIndex) {
- this.popperJS._popper.style.zIndex = popup_["PopupManager"].nextZIndex();
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/table/src/filter-panel.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_filter_panelvue_type_script_lang_js_ = (filter_panelvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/table/src/filter-panel.vue
- /* normalize component */
- var filter_panel_component = normalizeComponent(
- src_filter_panelvue_type_script_lang_js_,
- filter_panelvue_type_template_id_7f2c919f_render,
- filter_panelvue_type_template_id_7f2c919f_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var filter_panel_api; }
- filter_panel_component.options.__file = "packages/table/src/filter-panel.vue"
- /* harmony default export */ var filter_panel = (filter_panel_component.exports);
- // CONCATENATED MODULE: ./packages/table/src/table-header.js
- var table_header_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- var getAllColumns = function getAllColumns(columns) {
- var result = [];
- columns.forEach(function (column) {
- if (column.children) {
- result.push(column);
- result.push.apply(result, getAllColumns(column.children));
- } else {
- result.push(column);
- }
- });
- return result;
- };
- var convertToRows = function convertToRows(originColumns) {
- var maxLevel = 1;
- var traverse = function traverse(column, parent) {
- if (parent) {
- column.level = parent.level + 1;
- if (maxLevel < column.level) {
- maxLevel = column.level;
- }
- }
- if (column.children) {
- var colSpan = 0;
- column.children.forEach(function (subColumn) {
- traverse(subColumn, column);
- colSpan += subColumn.colSpan;
- });
- column.colSpan = colSpan;
- } else {
- column.colSpan = 1;
- }
- };
- originColumns.forEach(function (column) {
- column.level = 1;
- traverse(column);
- });
- var rows = [];
- for (var i = 0; i < maxLevel; i++) {
- rows.push([]);
- }
- var allColumns = getAllColumns(originColumns);
- allColumns.forEach(function (column) {
- if (!column.children) {
- column.rowSpan = maxLevel - column.level + 1;
- } else {
- column.rowSpan = 1;
- }
- rows[column.level - 1].push(column);
- });
- return rows;
- };
- /* harmony default export */ var table_header = ({
- name: 'ElTableHeader',
- mixins: [layout_observer],
- render: function render(h) {
- var _this = this;
- var originColumns = this.store.states.originColumns;
- var columnRows = convertToRows(originColumns, this.columns);
- // 是否拥有多级表头
- var isGroup = columnRows.length > 1;
- if (isGroup) this.$parent.isGroup = true;
- return h(
- 'table',
- {
- 'class': 'el-table__header',
- attrs: { cellspacing: '0',
- cellpadding: '0',
- border: '0' }
- },
- [h('colgroup', [this.columns.map(function (column) {
- return h('col', {
- attrs: { name: column.id },
- key: column.id });
- }), this.hasGutter ? h('col', {
- attrs: { name: 'gutter' }
- }) : '']), h(
- 'thead',
- { 'class': [{ 'is-group': isGroup, 'has-gutter': this.hasGutter }] },
- [this._l(columnRows, function (columns, rowIndex) {
- return h(
- 'tr',
- {
- style: _this.getHeaderRowStyle(rowIndex),
- 'class': _this.getHeaderRowClass(rowIndex)
- },
- [columns.map(function (column, cellIndex) {
- return h(
- 'th',
- {
- attrs: {
- colspan: column.colSpan,
- rowspan: column.rowSpan
- },
- on: {
- 'mousemove': function mousemove($event) {
- return _this.handleMouseMove($event, column);
- },
- 'mouseout': _this.handleMouseOut,
- 'mousedown': function mousedown($event) {
- return _this.handleMouseDown($event, column);
- },
- 'click': function click($event) {
- return _this.handleHeaderClick($event, column);
- },
- 'contextmenu': function contextmenu($event) {
- return _this.handleHeaderContextMenu($event, column);
- }
- },
- style: _this.getHeaderCellStyle(rowIndex, cellIndex, columns, column),
- 'class': _this.getHeaderCellClass(rowIndex, cellIndex, columns, column),
- key: column.id },
- [h(
- 'div',
- { 'class': ['cell', column.filteredValue && column.filteredValue.length > 0 ? 'highlight' : '', column.labelClassName] },
- [column.renderHeader ? column.renderHeader.call(_this._renderProxy, h, { column: column, $index: cellIndex, store: _this.store, _self: _this.$parent.$vnode.context }) : column.label, column.sortable ? h(
- 'span',
- {
- 'class': 'caret-wrapper',
- on: {
- 'click': function click($event) {
- return _this.handleSortClick($event, column);
- }
- }
- },
- [h('i', { 'class': 'sort-caret ascending',
- on: {
- 'click': function click($event) {
- return _this.handleSortClick($event, column, 'ascending');
- }
- }
- }), h('i', { 'class': 'sort-caret descending',
- on: {
- 'click': function click($event) {
- return _this.handleSortClick($event, column, 'descending');
- }
- }
- })]
- ) : '', column.filterable ? h(
- 'span',
- {
- 'class': 'el-table__column-filter-trigger',
- on: {
- 'click': function click($event) {
- return _this.handleFilterClick($event, column);
- }
- }
- },
- [h('i', { 'class': ['el-icon-arrow-down', column.filterOpened ? 'el-icon-arrow-up' : ''] })]
- ) : '']
- )]
- );
- }), _this.hasGutter ? h('th', { 'class': 'el-table__cell gutter' }) : '']
- );
- })]
- )]
- );
- },
- props: {
- fixed: String,
- store: {
- required: true
- },
- border: Boolean,
- defaultSort: {
- type: Object,
- default: function _default() {
- return {
- prop: '',
- order: ''
- };
- }
- }
- },
- components: {
- ElCheckbox: checkbox_default.a
- },
- computed: table_header_extends({
- table: function table() {
- return this.$parent;
- },
- hasGutter: function hasGutter() {
- return !this.fixed && this.tableLayout.gutterWidth;
- }
- }, mapStates({
- columns: 'columns',
- isAllSelected: 'isAllSelected',
- leftFixedLeafCount: 'fixedLeafColumnsLength',
- rightFixedLeafCount: 'rightFixedLeafColumnsLength',
- columnsCount: function columnsCount(states) {
- return states.columns.length;
- },
- leftFixedCount: function leftFixedCount(states) {
- return states.fixedColumns.length;
- },
- rightFixedCount: function rightFixedCount(states) {
- return states.rightFixedColumns.length;
- }
- })),
- created: function created() {
- this.filterPanels = {};
- },
- mounted: function mounted() {
- var _this2 = this;
- // nextTick 是有必要的 https://github.com/ElemeFE/element/pull/11311
- this.$nextTick(function () {
- var _defaultSort = _this2.defaultSort,
- prop = _defaultSort.prop,
- order = _defaultSort.order;
- var init = true;
- _this2.store.commit('sort', { prop: prop, order: order, init: init });
- });
- },
- beforeDestroy: function beforeDestroy() {
- var panels = this.filterPanels;
- for (var prop in panels) {
- if (panels.hasOwnProperty(prop) && panels[prop]) {
- panels[prop].$destroy(true);
- }
- }
- },
- methods: {
- isCellHidden: function isCellHidden(index, columns) {
- var start = 0;
- for (var i = 0; i < index; i++) {
- start += columns[i].colSpan;
- }
- var after = start + columns[index].colSpan - 1;
- if (this.fixed === true || this.fixed === 'left') {
- return after >= this.leftFixedLeafCount;
- } else if (this.fixed === 'right') {
- return start < this.columnsCount - this.rightFixedLeafCount;
- } else {
- return after < this.leftFixedLeafCount || start >= this.columnsCount - this.rightFixedLeafCount;
- }
- },
- getHeaderRowStyle: function getHeaderRowStyle(rowIndex) {
- var headerRowStyle = this.table.headerRowStyle;
- if (typeof headerRowStyle === 'function') {
- return headerRowStyle.call(null, { rowIndex: rowIndex });
- }
- return headerRowStyle;
- },
- getHeaderRowClass: function getHeaderRowClass(rowIndex) {
- var classes = [];
- var headerRowClassName = this.table.headerRowClassName;
- if (typeof headerRowClassName === 'string') {
- classes.push(headerRowClassName);
- } else if (typeof headerRowClassName === 'function') {
- classes.push(headerRowClassName.call(null, { rowIndex: rowIndex }));
- }
- return classes.join(' ');
- },
- getHeaderCellStyle: function getHeaderCellStyle(rowIndex, columnIndex, row, column) {
- var headerCellStyle = this.table.headerCellStyle;
- if (typeof headerCellStyle === 'function') {
- return headerCellStyle.call(null, {
- rowIndex: rowIndex,
- columnIndex: columnIndex,
- row: row,
- column: column
- });
- }
- return headerCellStyle;
- },
- getHeaderCellClass: function getHeaderCellClass(rowIndex, columnIndex, row, column) {
- var classes = [column.id, column.order, column.headerAlign, column.className, column.labelClassName];
- if (rowIndex === 0 && this.isCellHidden(columnIndex, row)) {
- classes.push('is-hidden');
- }
- if (!column.children) {
- classes.push('is-leaf');
- }
- if (column.sortable) {
- classes.push('is-sortable');
- }
- var headerCellClassName = this.table.headerCellClassName;
- if (typeof headerCellClassName === 'string') {
- classes.push(headerCellClassName);
- } else if (typeof headerCellClassName === 'function') {
- classes.push(headerCellClassName.call(null, {
- rowIndex: rowIndex,
- columnIndex: columnIndex,
- row: row,
- column: column
- }));
- }
- classes.push('el-table__cell');
- return classes.join(' ');
- },
- toggleAllSelection: function toggleAllSelection() {
- this.store.commit('toggleAllSelection');
- },
- handleFilterClick: function handleFilterClick(event, column) {
- event.stopPropagation();
- var target = event.target;
- var cell = target.tagName === 'TH' ? target : target.parentNode;
- if (Object(dom_["hasClass"])(cell, 'noclick')) return;
- cell = cell.querySelector('.el-table__column-filter-trigger') || cell;
- var table = this.$parent;
- var filterPanel = this.filterPanels[column.id];
- if (filterPanel && column.filterOpened) {
- filterPanel.showPopper = false;
- return;
- }
- if (!filterPanel) {
- filterPanel = new external_vue_default.a(filter_panel);
- this.filterPanels[column.id] = filterPanel;
- if (column.filterPlacement) {
- filterPanel.placement = column.filterPlacement;
- }
- filterPanel.table = table;
- filterPanel.cell = cell;
- filterPanel.column = column;
- !this.$isServer && filterPanel.$mount(document.createElement('div'));
- }
- setTimeout(function () {
- filterPanel.showPopper = true;
- }, 16);
- },
- handleHeaderClick: function handleHeaderClick(event, column) {
- if (!column.filters && column.sortable) {
- this.handleSortClick(event, column);
- } else if (column.filterable && !column.sortable) {
- this.handleFilterClick(event, column);
- }
- this.$parent.$emit('header-click', column, event);
- },
- handleHeaderContextMenu: function handleHeaderContextMenu(event, column) {
- this.$parent.$emit('header-contextmenu', column, event);
- },
- handleMouseDown: function handleMouseDown(event, column) {
- var _this3 = this;
- if (this.$isServer) return;
- if (column.children && column.children.length > 0) return;
- /* istanbul ignore if */
- if (this.draggingColumn && this.border) {
- this.dragging = true;
- this.$parent.resizeProxyVisible = true;
- var table = this.$parent;
- var tableEl = table.$el;
- var tableLeft = tableEl.getBoundingClientRect().left;
- var columnEl = this.$el.querySelector('th.' + column.id);
- var columnRect = columnEl.getBoundingClientRect();
- var minLeft = columnRect.left - tableLeft + 30;
- Object(dom_["addClass"])(columnEl, 'noclick');
- this.dragState = {
- startMouseLeft: event.clientX,
- startLeft: columnRect.right - tableLeft,
- startColumnLeft: columnRect.left - tableLeft,
- tableLeft: tableLeft
- };
- var resizeProxy = table.$refs.resizeProxy;
- resizeProxy.style.left = this.dragState.startLeft + 'px';
- document.onselectstart = function () {
- return false;
- };
- document.ondragstart = function () {
- return false;
- };
- var handleMouseMove = function handleMouseMove(event) {
- var deltaLeft = event.clientX - _this3.dragState.startMouseLeft;
- var proxyLeft = _this3.dragState.startLeft + deltaLeft;
- resizeProxy.style.left = Math.max(minLeft, proxyLeft) + 'px';
- };
- var handleMouseUp = function handleMouseUp() {
- if (_this3.dragging) {
- var _dragState = _this3.dragState,
- startColumnLeft = _dragState.startColumnLeft,
- startLeft = _dragState.startLeft;
- var finalLeft = parseInt(resizeProxy.style.left, 10);
- var columnWidth = finalLeft - startColumnLeft;
- column.width = column.realWidth = columnWidth;
- table.$emit('header-dragend', column.width, startLeft - startColumnLeft, column, event);
- _this3.store.scheduleLayout();
- document.body.style.cursor = '';
- _this3.dragging = false;
- _this3.draggingColumn = null;
- _this3.dragState = {};
- table.resizeProxyVisible = false;
- }
- document.removeEventListener('mousemove', handleMouseMove);
- document.removeEventListener('mouseup', handleMouseUp);
- document.onselectstart = null;
- document.ondragstart = null;
- setTimeout(function () {
- Object(dom_["removeClass"])(columnEl, 'noclick');
- }, 0);
- };
- document.addEventListener('mousemove', handleMouseMove);
- document.addEventListener('mouseup', handleMouseUp);
- }
- },
- handleMouseMove: function handleMouseMove(event, column) {
- if (column.children && column.children.length > 0) return;
- var target = event.target;
- while (target && target.tagName !== 'TH') {
- target = target.parentNode;
- }
- if (!column || !column.resizable) return;
- if (!this.dragging && this.border) {
- var rect = target.getBoundingClientRect();
- var bodyStyle = document.body.style;
- if (rect.width > 12 && rect.right - event.pageX < 8) {
- bodyStyle.cursor = 'col-resize';
- if (Object(dom_["hasClass"])(target, 'is-sortable')) {
- target.style.cursor = 'col-resize';
- }
- this.draggingColumn = column;
- } else if (!this.dragging) {
- bodyStyle.cursor = '';
- if (Object(dom_["hasClass"])(target, 'is-sortable')) {
- target.style.cursor = 'pointer';
- }
- this.draggingColumn = null;
- }
- }
- },
- handleMouseOut: function handleMouseOut() {
- if (this.$isServer) return;
- document.body.style.cursor = '';
- },
- toggleOrder: function toggleOrder(_ref) {
- var order = _ref.order,
- sortOrders = _ref.sortOrders;
- if (order === '') return sortOrders[0];
- var index = sortOrders.indexOf(order || null);
- return sortOrders[index > sortOrders.length - 2 ? 0 : index + 1];
- },
- handleSortClick: function handleSortClick(event, column, givenOrder) {
- event.stopPropagation();
- var order = column.order === givenOrder ? null : givenOrder || this.toggleOrder(column);
- var target = event.target;
- while (target && target.tagName !== 'TH') {
- target = target.parentNode;
- }
- if (target && target.tagName === 'TH') {
- if (Object(dom_["hasClass"])(target, 'noclick')) {
- Object(dom_["removeClass"])(target, 'noclick');
- return;
- }
- }
- if (!column.sortable) return;
- var states = this.store.states;
- var sortProp = states.sortProp;
- var sortOrder = void 0;
- var sortingColumn = states.sortingColumn;
- if (sortingColumn !== column || sortingColumn === column && sortingColumn.order === null) {
- if (sortingColumn) {
- sortingColumn.order = null;
- }
- states.sortingColumn = column;
- sortProp = column.property;
- }
- if (!order) {
- sortOrder = column.order = null;
- } else {
- sortOrder = column.order = order;
- }
- states.sortProp = sortProp;
- states.sortOrder = sortOrder;
- this.store.commit('changeSortCondition');
- }
- },
- data: function data() {
- return {
- draggingColumn: null,
- dragging: false,
- dragState: {}
- };
- }
- });
- // CONCATENATED MODULE: ./packages/table/src/table-footer.js
- var table_footer_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- /* harmony default export */ var table_footer = ({
- name: 'ElTableFooter',
- mixins: [layout_observer],
- render: function render(h) {
- var _this = this;
- var sums = [];
- if (this.summaryMethod) {
- sums = this.summaryMethod({ columns: this.columns, data: this.store.states.data });
- } else {
- this.columns.forEach(function (column, index) {
- if (index === 0) {
- sums[index] = _this.sumText;
- return;
- }
- var values = _this.store.states.data.map(function (item) {
- return Number(item[column.property]);
- });
- var precisions = [];
- var notNumber = true;
- values.forEach(function (value) {
- if (!isNaN(value)) {
- notNumber = false;
- var decimal = ('' + value).split('.')[1];
- precisions.push(decimal ? decimal.length : 0);
- }
- });
- var precision = Math.max.apply(null, precisions);
- if (!notNumber) {
- sums[index] = values.reduce(function (prev, curr) {
- var value = Number(curr);
- if (!isNaN(value)) {
- return parseFloat((prev + curr).toFixed(Math.min(precision, 20)));
- } else {
- return prev;
- }
- }, 0);
- } else {
- sums[index] = '';
- }
- });
- }
- return h(
- 'table',
- {
- 'class': 'el-table__footer',
- attrs: { cellspacing: '0',
- cellpadding: '0',
- border: '0' }
- },
- [h('colgroup', [this.columns.map(function (column) {
- return h('col', {
- attrs: { name: column.id },
- key: column.id });
- }), this.hasGutter ? h('col', {
- attrs: { name: 'gutter' }
- }) : '']), h(
- 'tbody',
- { 'class': [{ 'has-gutter': this.hasGutter }] },
- [h('tr', [this.columns.map(function (column, cellIndex) {
- return h(
- 'td',
- {
- key: cellIndex,
- attrs: { colspan: column.colSpan,
- rowspan: column.rowSpan
- },
- 'class': [].concat(_this.getRowClasses(column, cellIndex), ['el-table__cell']) },
- [h(
- 'div',
- { 'class': ['cell', column.labelClassName] },
- [sums[cellIndex]]
- )]
- );
- }), this.hasGutter ? h('th', { 'class': 'el-table__cell gutter' }) : ''])]
- )]
- );
- },
- props: {
- fixed: String,
- store: {
- required: true
- },
- summaryMethod: Function,
- sumText: String,
- border: Boolean,
- defaultSort: {
- type: Object,
- default: function _default() {
- return {
- prop: '',
- order: ''
- };
- }
- }
- },
- computed: table_footer_extends({
- table: function table() {
- return this.$parent;
- },
- hasGutter: function hasGutter() {
- return !this.fixed && this.tableLayout.gutterWidth;
- }
- }, mapStates({
- columns: 'columns',
- isAllSelected: 'isAllSelected',
- leftFixedLeafCount: 'fixedLeafColumnsLength',
- rightFixedLeafCount: 'rightFixedLeafColumnsLength',
- columnsCount: function columnsCount(states) {
- return states.columns.length;
- },
- leftFixedCount: function leftFixedCount(states) {
- return states.fixedColumns.length;
- },
- rightFixedCount: function rightFixedCount(states) {
- return states.rightFixedColumns.length;
- }
- })),
- methods: {
- isCellHidden: function isCellHidden(index, columns, column) {
- if (this.fixed === true || this.fixed === 'left') {
- return index >= this.leftFixedLeafCount;
- } else if (this.fixed === 'right') {
- var before = 0;
- for (var i = 0; i < index; i++) {
- before += columns[i].colSpan;
- }
- return before < this.columnsCount - this.rightFixedLeafCount;
- } else if (!this.fixed && column.fixed) {
- // hide cell when footer instance is not fixed and column is fixed
- return true;
- } else {
- return index < this.leftFixedCount || index >= this.columnsCount - this.rightFixedCount;
- }
- },
- getRowClasses: function getRowClasses(column, cellIndex) {
- var classes = [column.id, column.align, column.labelClassName];
- if (column.className) {
- classes.push(column.className);
- }
- if (this.isCellHidden(cellIndex, this.columns, column)) {
- classes.push('is-hidden');
- }
- if (!column.children) {
- classes.push('is-leaf');
- }
- return classes;
- }
- }
- });
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/table/src/table.vue?vue&type=script&lang=js&
- var tablevue_type_script_lang_js_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var tableIdSeed = 1;
- /* harmony default export */ var tablevue_type_script_lang_js_ = ({
- name: 'ElTable',
- mixins: [locale_default.a, migrating_default.a],
- directives: {
- Mousewheel: directives_mousewheel
- },
- props: {
- data: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- size: String,
- width: [String, Number],
- height: [String, Number],
- maxHeight: [String, Number],
- fit: {
- type: Boolean,
- default: true
- },
- stripe: Boolean,
- border: Boolean,
- rowKey: [String, Function],
- context: {},
- showHeader: {
- type: Boolean,
- default: true
- },
- showSummary: Boolean,
- sumText: String,
- summaryMethod: Function,
- rowClassName: [String, Function],
- rowStyle: [Object, Function],
- cellClassName: [String, Function],
- cellStyle: [Object, Function],
- headerRowClassName: [String, Function],
- headerRowStyle: [Object, Function],
- headerCellClassName: [String, Function],
- headerCellStyle: [Object, Function],
- highlightCurrentRow: Boolean,
- highlightSelectionRow: {
- type: Boolean,
- default: false
- },
- currentRowKey: [String, Number],
- emptyText: String,
- expandRowKeys: Array,
- defaultExpandAll: Boolean,
- defaultSort: Object,
- tooltipEffect: String,
- spanMethod: Function,
- selectOnIndeterminate: {
- type: Boolean,
- default: true
- },
- indent: {
- type: Number,
- default: 16
- },
- treeProps: {
- type: Object,
- default: function _default() {
- return {
- hasChildren: 'hasChildren',
- children: 'children'
- };
- }
- },
- lazy: Boolean,
- load: Function
- },
- components: {
- TableHeader: table_header,
- TableFooter: table_footer,
- TableBody: table_body,
- ElCheckbox: checkbox_default.a
- },
- methods: {
- getMigratingConfig: function getMigratingConfig() {
- return {
- events: {
- expand: 'expand is renamed to expand-change'
- }
- };
- },
- setCurrentRow: function setCurrentRow(row) {
- this.store.commit('setCurrentRow', row);
- },
- toggleRowSelection: function toggleRowSelection(row, selected) {
- this.store.toggleRowSelection(row, selected, false);
- this.store.updateAllSelected();
- },
- toggleRowExpansion: function toggleRowExpansion(row, expanded) {
- this.store.toggleRowExpansionAdapter(row, expanded);
- },
- clearSelection: function clearSelection() {
- this.store.clearSelection();
- },
- clearFilter: function clearFilter(columnKeys) {
- this.store.clearFilter(columnKeys);
- },
- clearSort: function clearSort() {
- this.store.clearSort();
- },
- handleMouseLeave: function handleMouseLeave() {
- this.store.commit('setHoverRow', null);
- if (this.hoverState) this.hoverState = null;
- },
- updateScrollY: function updateScrollY() {
- var changed = this.layout.updateScrollY();
- if (changed) {
- this.layout.notifyObservers('scrollable');
- this.layout.updateColumnsWidth();
- }
- },
- handleFixedMousewheel: function handleFixedMousewheel(event, data) {
- var bodyWrapper = this.bodyWrapper;
- if (Math.abs(data.spinY) > 0) {
- var currentScrollTop = bodyWrapper.scrollTop;
- if (data.pixelY < 0 && currentScrollTop !== 0) {
- event.preventDefault();
- }
- if (data.pixelY > 0 && bodyWrapper.scrollHeight - bodyWrapper.clientHeight > currentScrollTop) {
- event.preventDefault();
- }
- bodyWrapper.scrollTop += Math.ceil(data.pixelY / 5);
- } else {
- bodyWrapper.scrollLeft += Math.ceil(data.pixelX / 5);
- }
- },
- handleHeaderFooterMousewheel: function handleHeaderFooterMousewheel(event, data) {
- var pixelX = data.pixelX,
- pixelY = data.pixelY;
- if (Math.abs(pixelX) >= Math.abs(pixelY)) {
- this.bodyWrapper.scrollLeft += data.pixelX / 5;
- }
- },
- // TODO 使用 CSS transform
- syncPostion: function syncPostion() {
- var _bodyWrapper = this.bodyWrapper,
- scrollLeft = _bodyWrapper.scrollLeft,
- scrollTop = _bodyWrapper.scrollTop,
- offsetWidth = _bodyWrapper.offsetWidth,
- scrollWidth = _bodyWrapper.scrollWidth;
- var _$refs = this.$refs,
- headerWrapper = _$refs.headerWrapper,
- footerWrapper = _$refs.footerWrapper,
- fixedBodyWrapper = _$refs.fixedBodyWrapper,
- rightFixedBodyWrapper = _$refs.rightFixedBodyWrapper;
- if (headerWrapper) headerWrapper.scrollLeft = scrollLeft;
- if (footerWrapper) footerWrapper.scrollLeft = scrollLeft;
- if (fixedBodyWrapper) fixedBodyWrapper.scrollTop = scrollTop;
- if (rightFixedBodyWrapper) rightFixedBodyWrapper.scrollTop = scrollTop;
- var maxScrollLeftPosition = scrollWidth - offsetWidth - 1;
- if (scrollLeft >= maxScrollLeftPosition) {
- this.scrollPosition = 'right';
- } else if (scrollLeft === 0) {
- this.scrollPosition = 'left';
- } else {
- this.scrollPosition = 'middle';
- }
- },
- throttleSyncPostion: Object(external_throttle_debounce_["throttle"])(16, function () {
- this.syncPostion();
- }),
- onScroll: function onScroll(evt) {
- var raf = window.requestAnimationFrame;
- if (!raf) {
- this.throttleSyncPostion();
- } else {
- raf(this.syncPostion);
- }
- },
- bindEvents: function bindEvents() {
- this.bodyWrapper.addEventListener('scroll', this.onScroll, { passive: true });
- if (this.fit) {
- Object(resize_event_["addResizeListener"])(this.$el, this.resizeListener);
- }
- },
- unbindEvents: function unbindEvents() {
- this.bodyWrapper.removeEventListener('scroll', this.onScroll, { passive: true });
- if (this.fit) {
- Object(resize_event_["removeResizeListener"])(this.$el, this.resizeListener);
- }
- },
- resizeListener: function resizeListener() {
- if (!this.$ready) return;
- var shouldUpdateLayout = false;
- var el = this.$el;
- var _resizeState = this.resizeState,
- oldWidth = _resizeState.width,
- oldHeight = _resizeState.height;
- var width = el.offsetWidth;
- if (oldWidth !== width) {
- shouldUpdateLayout = true;
- }
- var height = el.offsetHeight;
- if ((this.height || this.shouldUpdateHeight) && oldHeight !== height) {
- shouldUpdateLayout = true;
- }
- if (shouldUpdateLayout) {
- this.resizeState.width = width;
- this.resizeState.height = height;
- this.doLayout();
- }
- },
- doLayout: function doLayout() {
- if (this.shouldUpdateHeight) {
- this.layout.updateElsHeight();
- }
- this.layout.updateColumnsWidth();
- },
- sort: function sort(prop, order) {
- this.store.commit('sort', { prop: prop, order: order });
- },
- toggleAllSelection: function toggleAllSelection() {
- this.store.commit('toggleAllSelection');
- }
- },
- computed: tablevue_type_script_lang_js_extends({
- tableSize: function tableSize() {
- return this.size || (this.$ELEMENT || {}).size;
- },
- bodyWrapper: function bodyWrapper() {
- return this.$refs.bodyWrapper;
- },
- shouldUpdateHeight: function shouldUpdateHeight() {
- return this.height || this.maxHeight || this.fixedColumns.length > 0 || this.rightFixedColumns.length > 0;
- },
- bodyWidth: function bodyWidth() {
- var _layout = this.layout,
- bodyWidth = _layout.bodyWidth,
- scrollY = _layout.scrollY,
- gutterWidth = _layout.gutterWidth;
- return bodyWidth ? bodyWidth - (scrollY ? gutterWidth : 0) + 'px' : '';
- },
- bodyHeight: function bodyHeight() {
- var _layout2 = this.layout,
- _layout2$headerHeight = _layout2.headerHeight,
- headerHeight = _layout2$headerHeight === undefined ? 0 : _layout2$headerHeight,
- bodyHeight = _layout2.bodyHeight,
- _layout2$footerHeight = _layout2.footerHeight,
- footerHeight = _layout2$footerHeight === undefined ? 0 : _layout2$footerHeight;
- if (this.height) {
- return {
- height: bodyHeight ? bodyHeight + 'px' : ''
- };
- } else if (this.maxHeight) {
- var maxHeight = parseHeight(this.maxHeight);
- if (typeof maxHeight === 'number') {
- return {
- 'max-height': maxHeight - footerHeight - (this.showHeader ? headerHeight : 0) + 'px'
- };
- }
- }
- return {};
- },
- fixedBodyHeight: function fixedBodyHeight() {
- if (this.height) {
- return {
- height: this.layout.fixedBodyHeight ? this.layout.fixedBodyHeight + 'px' : ''
- };
- } else if (this.maxHeight) {
- var maxHeight = parseHeight(this.maxHeight);
- if (typeof maxHeight === 'number') {
- maxHeight = this.layout.scrollX ? maxHeight - this.layout.gutterWidth : maxHeight;
- if (this.showHeader) {
- maxHeight -= this.layout.headerHeight;
- }
- maxHeight -= this.layout.footerHeight;
- return {
- 'max-height': maxHeight + 'px'
- };
- }
- }
- return {};
- },
- fixedHeight: function fixedHeight() {
- if (this.maxHeight) {
- if (this.showSummary) {
- return {
- bottom: 0
- };
- }
- return {
- bottom: this.layout.scrollX && this.data.length ? this.layout.gutterWidth + 'px' : ''
- };
- } else {
- if (this.showSummary) {
- return {
- height: this.layout.tableHeight ? this.layout.tableHeight + 'px' : ''
- };
- }
- return {
- height: this.layout.viewportHeight ? this.layout.viewportHeight + 'px' : ''
- };
- }
- },
- emptyBlockStyle: function emptyBlockStyle() {
- if (this.data && this.data.length) return null;
- var height = '100%';
- if (this.layout.appendHeight) {
- height = 'calc(100% - ' + this.layout.appendHeight + 'px)';
- }
- return {
- width: this.bodyWidth,
- height: height
- };
- }
- }, mapStates({
- selection: 'selection',
- columns: 'columns',
- tableData: 'data',
- fixedColumns: 'fixedColumns',
- rightFixedColumns: 'rightFixedColumns'
- })),
- watch: {
- height: {
- immediate: true,
- handler: function handler(value) {
- this.layout.setHeight(value);
- }
- },
- maxHeight: {
- immediate: true,
- handler: function handler(value) {
- this.layout.setMaxHeight(value);
- }
- },
- currentRowKey: {
- immediate: true,
- handler: function handler(value) {
- if (!this.rowKey) return;
- this.store.setCurrentRowKey(value);
- }
- },
- data: {
- immediate: true,
- handler: function handler(value) {
- this.store.commit('setData', value);
- }
- },
- expandRowKeys: {
- immediate: true,
- handler: function handler(newVal) {
- if (newVal) {
- this.store.setExpandRowKeysAdapter(newVal);
- }
- }
- }
- },
- created: function created() {
- var _this = this;
- this.tableId = 'el-table_' + tableIdSeed++;
- this.debouncedUpdateLayout = Object(external_throttle_debounce_["debounce"])(50, function () {
- return _this.doLayout();
- });
- },
- mounted: function mounted() {
- var _this2 = this;
- this.bindEvents();
- this.store.updateColumns();
- this.doLayout();
- this.resizeState = {
- width: this.$el.offsetWidth,
- height: this.$el.offsetHeight
- };
- // init filters
- this.store.states.columns.forEach(function (column) {
- if (column.filteredValue && column.filteredValue.length) {
- _this2.store.commit('filterChange', {
- column: column,
- values: column.filteredValue,
- silent: true
- });
- }
- });
- this.$ready = true;
- },
- destroyed: function destroyed() {
- this.unbindEvents();
- },
- data: function data() {
- var _treeProps = this.treeProps,
- _treeProps$hasChildre = _treeProps.hasChildren,
- hasChildren = _treeProps$hasChildre === undefined ? 'hasChildren' : _treeProps$hasChildre,
- _treeProps$children = _treeProps.children,
- children = _treeProps$children === undefined ? 'children' : _treeProps$children;
- this.store = createStore(this, {
- rowKey: this.rowKey,
- defaultExpandAll: this.defaultExpandAll,
- selectOnIndeterminate: this.selectOnIndeterminate,
- // TreeTable 的相关配置
- indent: this.indent,
- lazy: this.lazy,
- lazyColumnIdentifier: hasChildren,
- childrenColumnName: children
- });
- var layout = new table_layout({
- store: this.store,
- table: this,
- fit: this.fit,
- showHeader: this.showHeader
- });
- return {
- layout: layout,
- isHidden: false,
- renderExpanded: null,
- resizeProxyVisible: false,
- resizeState: {
- width: null,
- height: null
- },
- // 是否拥有多级表头
- isGroup: false,
- scrollPosition: 'left'
- };
- }
- });
- // CONCATENATED MODULE: ./packages/table/src/table.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_tablevue_type_script_lang_js_ = (tablevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/table/src/table.vue
- /* normalize component */
- var table_component = normalizeComponent(
- src_tablevue_type_script_lang_js_,
- tablevue_type_template_id_493fe34e_render,
- tablevue_type_template_id_493fe34e_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var table_api; }
- table_component.options.__file = "packages/table/src/table.vue"
- /* harmony default export */ var src_table = (table_component.exports);
- // CONCATENATED MODULE: ./packages/table/index.js
- /* istanbul ignore next */
- src_table.install = function (Vue) {
- Vue.component(src_table.name, src_table);
- };
- /* harmony default export */ var packages_table = (src_table);
- // CONCATENATED MODULE: ./packages/table/src/config.js
- var cellStarts = {
- default: {
- order: ''
- },
- selection: {
- width: 48,
- minWidth: 48,
- realWidth: 48,
- order: '',
- className: 'el-table-column--selection'
- },
- expand: {
- width: 48,
- minWidth: 48,
- realWidth: 48,
- order: ''
- },
- index: {
- width: 48,
- minWidth: 48,
- realWidth: 48,
- order: ''
- }
- };
- // 这些选项不应该被覆盖
- var cellForced = {
- selection: {
- renderHeader: function renderHeader(h, _ref) {
- var store = _ref.store;
- return h('el-checkbox', {
- attrs: {
- disabled: store.states.data && store.states.data.length === 0,
- indeterminate: store.states.selection.length > 0 && !this.isAllSelected,
- value: this.isAllSelected },
- on: {
- 'input': this.toggleAllSelection
- }
- });
- },
- renderCell: function renderCell(h, _ref2) {
- var row = _ref2.row,
- column = _ref2.column,
- isSelected = _ref2.isSelected,
- store = _ref2.store,
- $index = _ref2.$index;
- return h('el-checkbox', {
- nativeOn: {
- 'click': function click(event) {
- return event.stopPropagation();
- }
- },
- attrs: {
- value: isSelected,
- disabled: column.selectable ? !column.selectable.call(null, row, $index) : false
- },
- on: {
- 'input': function input() {
- store.commit('rowSelectedChanged', row);
- }
- }
- });
- },
- sortable: false,
- resizable: false
- },
- index: {
- renderHeader: function renderHeader(h, _ref3) {
- var column = _ref3.column;
- return column.label || '#';
- },
- renderCell: function renderCell(h, _ref4) {
- var $index = _ref4.$index,
- column = _ref4.column;
- var i = $index + 1;
- var index = column.index;
- if (typeof index === 'number') {
- i = $index + index;
- } else if (typeof index === 'function') {
- i = index($index);
- }
- return h('div', [i]);
- },
- sortable: false
- },
- expand: {
- renderHeader: function renderHeader(h, _ref5) {
- var column = _ref5.column;
- return column.label || '';
- },
- renderCell: function renderCell(h, _ref6) {
- var row = _ref6.row,
- store = _ref6.store,
- isExpanded = _ref6.isExpanded;
- var classes = ['el-table__expand-icon'];
- if (isExpanded) {
- classes.push('el-table__expand-icon--expanded');
- }
- var callback = function callback(e) {
- e.stopPropagation();
- store.toggleRowExpansion(row);
- };
- return h(
- 'div',
- { 'class': classes,
- on: {
- 'click': callback
- }
- },
- [h('i', { 'class': 'el-icon el-icon-arrow-right' })]
- );
- },
- sortable: false,
- resizable: false,
- className: 'el-table__expand-column'
- }
- };
- function defaultRenderCell(h, _ref7) {
- var row = _ref7.row,
- column = _ref7.column,
- $index = _ref7.$index;
- var property = column.property;
- var value = property && Object(util_["getPropByPath"])(row, property).v;
- if (column && column.formatter) {
- return column.formatter(row, column, value, $index);
- }
- return value;
- }
- function treeCellPrefix(h, _ref8) {
- var row = _ref8.row,
- treeNode = _ref8.treeNode,
- store = _ref8.store;
- if (!treeNode) return null;
- var ele = [];
- var callback = function callback(e) {
- e.stopPropagation();
- store.loadOrToggle(row);
- };
- if (treeNode.indent) {
- ele.push(h('span', { 'class': 'el-table__indent', style: { 'padding-left': treeNode.indent + 'px' } }));
- }
- if (typeof treeNode.expanded === 'boolean' && !treeNode.noLazyChildren) {
- var expandClasses = ['el-table__expand-icon', treeNode.expanded ? 'el-table__expand-icon--expanded' : ''];
- var iconClasses = ['el-icon-arrow-right'];
- if (treeNode.loading) {
- iconClasses = ['el-icon-loading'];
- }
- ele.push(h(
- 'div',
- { 'class': expandClasses,
- on: {
- 'click': callback
- }
- },
- [h('i', { 'class': iconClasses })]
- ));
- } else {
- ele.push(h('span', { 'class': 'el-table__placeholder' }));
- }
- return ele;
- }
- // CONCATENATED MODULE: ./packages/table/src/table-column.js
- var table_column_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- var columnIdSeed = 1;
- /* harmony default export */ var table_column = ({
- name: 'ElTableColumn',
- props: {
- type: {
- type: String,
- default: 'default'
- },
- label: String,
- className: String,
- labelClassName: String,
- property: String,
- prop: String,
- width: {},
- minWidth: {},
- renderHeader: Function,
- sortable: {
- type: [Boolean, String],
- default: false
- },
- sortMethod: Function,
- sortBy: [String, Function, Array],
- resizable: {
- type: Boolean,
- default: true
- },
- columnKey: String,
- align: String,
- headerAlign: String,
- showTooltipWhenOverflow: Boolean,
- showOverflowTooltip: Boolean,
- fixed: [Boolean, String],
- formatter: Function,
- selectable: Function,
- reserveSelection: Boolean,
- filterMethod: Function,
- filteredValue: Array,
- filters: Array,
- filterPlacement: String,
- filterMultiple: {
- type: Boolean,
- default: true
- },
- index: [Number, Function],
- sortOrders: {
- type: Array,
- default: function _default() {
- return ['ascending', 'descending', null];
- },
- validator: function validator(val) {
- return val.every(function (order) {
- return ['ascending', 'descending', null].indexOf(order) > -1;
- });
- }
- }
- },
- data: function data() {
- return {
- isSubColumn: false,
- columns: []
- };
- },
- computed: {
- owner: function owner() {
- var parent = this.$parent;
- while (parent && !parent.tableId) {
- parent = parent.$parent;
- }
- return parent;
- },
- columnOrTableParent: function columnOrTableParent() {
- var parent = this.$parent;
- while (parent && !parent.tableId && !parent.columnId) {
- parent = parent.$parent;
- }
- return parent;
- },
- realWidth: function realWidth() {
- return parseWidth(this.width);
- },
- realMinWidth: function realMinWidth() {
- return parseMinWidth(this.minWidth);
- },
- realAlign: function realAlign() {
- return this.align ? 'is-' + this.align : null;
- },
- realHeaderAlign: function realHeaderAlign() {
- return this.headerAlign ? 'is-' + this.headerAlign : this.realAlign;
- }
- },
- methods: {
- getPropsData: function getPropsData() {
- var _this = this;
- for (var _len = arguments.length, props = Array(_len), _key = 0; _key < _len; _key++) {
- props[_key] = arguments[_key];
- }
- return props.reduce(function (prev, cur) {
- if (Array.isArray(cur)) {
- cur.forEach(function (key) {
- prev[key] = _this[key];
- });
- }
- return prev;
- }, {});
- },
- getColumnElIndex: function getColumnElIndex(children, child) {
- return [].indexOf.call(children, child);
- },
- setColumnWidth: function setColumnWidth(column) {
- if (this.realWidth) {
- column.width = this.realWidth;
- }
- if (this.realMinWidth) {
- column.minWidth = this.realMinWidth;
- }
- if (!column.minWidth) {
- column.minWidth = 80;
- }
- column.realWidth = column.width === undefined ? column.minWidth : column.width;
- return column;
- },
- setColumnForcedProps: function setColumnForcedProps(column) {
- // 对于特定类型的 column,某些属性不允许设置
- var type = column.type;
- var source = cellForced[type] || {};
- Object.keys(source).forEach(function (prop) {
- var value = source[prop];
- if (value !== undefined) {
- column[prop] = prop === 'className' ? column[prop] + ' ' + value : value;
- }
- });
- return column;
- },
- setColumnRenders: function setColumnRenders(column) {
- var _this2 = this;
- var h = this.$createElement;
- // renderHeader 属性不推荐使用。
- if (this.renderHeader) {
- console.warn('[Element Warn][TableColumn]Comparing to render-header, scoped-slot header is easier to use. We recommend users to use scoped-slot header.');
- } else if (column.type !== 'selection') {
- column.renderHeader = function (h, scope) {
- var renderHeader = _this2.$scopedSlots.header;
- return renderHeader ? renderHeader(scope) : column.label;
- };
- }
- var originRenderCell = column.renderCell;
- // TODO: 这里的实现调整
- if (column.type === 'expand') {
- // 对于展开行,renderCell 不允许配置的。在上一步中已经设置过,这里需要简单封装一下。
- column.renderCell = function (h, data) {
- return h(
- 'div',
- { 'class': 'cell' },
- [originRenderCell(h, data)]
- );
- };
- this.owner.renderExpanded = function (h, data) {
- return _this2.$scopedSlots.default ? _this2.$scopedSlots.default(data) : _this2.$slots.default;
- };
- } else {
- originRenderCell = originRenderCell || defaultRenderCell;
- // 对 renderCell 进行包装
- column.renderCell = function (h, data) {
- var children = null;
- if (_this2.$scopedSlots.default) {
- children = _this2.$scopedSlots.default(data);
- } else {
- children = originRenderCell(h, data);
- }
- var prefix = treeCellPrefix(h, data);
- var props = {
- class: 'cell',
- style: {}
- };
- if (column.showOverflowTooltip) {
- props.class += ' el-tooltip';
- props.style = { width: (data.column.realWidth || data.column.width) - 1 + 'px' };
- }
- return h(
- 'div',
- props,
- [prefix, children]
- );
- };
- }
- return column;
- },
- registerNormalWatchers: function registerNormalWatchers() {
- var _this3 = this;
- var props = ['label', 'property', 'filters', 'filterMultiple', 'sortable', 'index', 'formatter', 'className', 'labelClassName', 'showOverflowTooltip'];
- // 一些属性具有别名
- var aliases = {
- prop: 'property',
- realAlign: 'align',
- realHeaderAlign: 'headerAlign',
- realWidth: 'width'
- };
- var allAliases = props.reduce(function (prev, cur) {
- prev[cur] = cur;
- return prev;
- }, aliases);
- Object.keys(allAliases).forEach(function (key) {
- var columnKey = aliases[key];
- _this3.$watch(key, function (newVal) {
- _this3.columnConfig[columnKey] = newVal;
- });
- });
- },
- registerComplexWatchers: function registerComplexWatchers() {
- var _this4 = this;
- var props = ['fixed'];
- var aliases = {
- realWidth: 'width',
- realMinWidth: 'minWidth'
- };
- var allAliases = props.reduce(function (prev, cur) {
- prev[cur] = cur;
- return prev;
- }, aliases);
- Object.keys(allAliases).forEach(function (key) {
- var columnKey = aliases[key];
- _this4.$watch(key, function (newVal) {
- _this4.columnConfig[columnKey] = newVal;
- var updateColumns = columnKey === 'fixed';
- _this4.owner.store.scheduleLayout(updateColumns);
- });
- });
- }
- },
- components: {
- ElCheckbox: checkbox_default.a
- },
- beforeCreate: function beforeCreate() {
- this.row = {};
- this.column = {};
- this.$index = 0;
- this.columnId = '';
- },
- created: function created() {
- var parent = this.columnOrTableParent;
- this.isSubColumn = this.owner !== parent;
- this.columnId = (parent.tableId || parent.columnId) + '_column_' + columnIdSeed++;
- var type = this.type || 'default';
- var sortable = this.sortable === '' ? true : this.sortable;
- var defaults = table_column_extends({}, cellStarts[type], {
- id: this.columnId,
- type: type,
- property: this.prop || this.property,
- align: this.realAlign,
- headerAlign: this.realHeaderAlign,
- showOverflowTooltip: this.showOverflowTooltip || this.showTooltipWhenOverflow,
- // filter 相关属性
- filterable: this.filters || this.filterMethod,
- filteredValue: [],
- filterPlacement: '',
- isColumnGroup: false,
- filterOpened: false,
- // sort 相关属性
- sortable: sortable,
- // index 列
- index: this.index
- });
- var basicProps = ['columnKey', 'label', 'className', 'labelClassName', 'type', 'renderHeader', 'formatter', 'fixed', 'resizable'];
- var sortProps = ['sortMethod', 'sortBy', 'sortOrders'];
- var selectProps = ['selectable', 'reserveSelection'];
- var filterProps = ['filterMethod', 'filters', 'filterMultiple', 'filterOpened', 'filteredValue', 'filterPlacement'];
- var column = this.getPropsData(basicProps, sortProps, selectProps, filterProps);
- column = mergeOptions(defaults, column);
- // 注意 compose 中函数执行的顺序是从右到左
- var chains = compose(this.setColumnRenders, this.setColumnWidth, this.setColumnForcedProps);
- column = chains(column);
- this.columnConfig = column;
- // 注册 watcher
- this.registerNormalWatchers();
- this.registerComplexWatchers();
- },
- mounted: function mounted() {
- var owner = this.owner;
- var parent = this.columnOrTableParent;
- var children = this.isSubColumn ? parent.$el.children : parent.$refs.hiddenColumns.children;
- var columnIndex = this.getColumnElIndex(children, this.$el);
- owner.store.commit('insertColumn', this.columnConfig, columnIndex, this.isSubColumn ? parent.columnConfig : null);
- },
- destroyed: function destroyed() {
- if (!this.$parent) return;
- var parent = this.$parent;
- this.owner.store.commit('removeColumn', this.columnConfig, this.isSubColumn ? parent.columnConfig : null);
- },
- render: function render(h) {
- // slots 也要渲染,需要计算合并表头
- return h('div', this.$slots.default);
- }
- });
- // CONCATENATED MODULE: ./packages/table-column/index.js
- /* istanbul ignore next */
- table_column.install = function (Vue) {
- Vue.component(table_column.name, table_column);
- };
- /* harmony default export */ var packages_table_column = (table_column);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/picker.vue?vue&type=template&id=79ae069f&
- var pickervue_type_template_id_79ae069f_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return !_vm.ranged
- ? _c(
- "el-input",
- _vm._b(
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: _vm.handleClose,
- expression: "handleClose"
- }
- ],
- ref: "reference",
- staticClass: "el-date-editor",
- class: "el-date-editor--" + _vm.type,
- attrs: {
- readonly:
- !_vm.editable ||
- _vm.readonly ||
- _vm.type === "dates" ||
- _vm.type === "week" ||
- _vm.type === "years" ||
- _vm.type === "months",
- disabled: _vm.pickerDisabled,
- size: _vm.pickerSize,
- name: _vm.name,
- placeholder: _vm.placeholder,
- value: _vm.displayValue,
- validateEvent: false
- },
- on: {
- focus: _vm.handleFocus,
- input: function(value) {
- return (_vm.userInput = value)
- },
- change: _vm.handleChange
- },
- nativeOn: {
- keydown: function($event) {
- return _vm.handleKeydown($event)
- },
- mouseenter: function($event) {
- return _vm.handleMouseEnter($event)
- },
- mouseleave: function($event) {
- _vm.showClose = false
- }
- }
- },
- "el-input",
- _vm.firstInputId,
- false
- ),
- [
- _c("i", {
- staticClass: "el-input__icon",
- class: _vm.triggerClass,
- attrs: { slot: "prefix" },
- on: { click: _vm.handleFocus },
- slot: "prefix"
- }),
- _vm.haveTrigger
- ? _c("i", {
- staticClass: "el-input__icon",
- class: [_vm.showClose ? "" + _vm.clearIcon : ""],
- attrs: { slot: "suffix" },
- on: { click: _vm.handleClickIcon },
- slot: "suffix"
- })
- : _vm._e()
- ]
- )
- : _c(
- "div",
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: _vm.handleClose,
- expression: "handleClose"
- }
- ],
- ref: "reference",
- staticClass: "el-date-editor el-range-editor el-input__inner",
- class: [
- "el-date-editor--" + _vm.type,
- _vm.pickerSize ? "el-range-editor--" + _vm.pickerSize : "",
- _vm.pickerDisabled ? "is-disabled" : "",
- _vm.pickerVisible ? "is-active" : ""
- ],
- on: {
- click: _vm.handleRangeClick,
- mouseenter: _vm.handleMouseEnter,
- mouseleave: function($event) {
- _vm.showClose = false
- },
- keydown: _vm.handleKeydown
- }
- },
- [
- _c("i", {
- class: ["el-input__icon", "el-range__icon", _vm.triggerClass]
- }),
- _c(
- "input",
- _vm._b(
- {
- staticClass: "el-range-input",
- attrs: {
- autocomplete: "off",
- placeholder: _vm.startPlaceholder,
- disabled: _vm.pickerDisabled,
- readonly: !_vm.editable || _vm.readonly,
- name: _vm.name && _vm.name[0]
- },
- domProps: { value: _vm.displayValue && _vm.displayValue[0] },
- on: {
- input: _vm.handleStartInput,
- change: _vm.handleStartChange,
- focus: _vm.handleFocus
- }
- },
- "input",
- _vm.firstInputId,
- false
- )
- ),
- _vm._t("range-separator", [
- _c("span", { staticClass: "el-range-separator" }, [
- _vm._v(_vm._s(_vm.rangeSeparator))
- ])
- ]),
- _c(
- "input",
- _vm._b(
- {
- staticClass: "el-range-input",
- attrs: {
- autocomplete: "off",
- placeholder: _vm.endPlaceholder,
- disabled: _vm.pickerDisabled,
- readonly: !_vm.editable || _vm.readonly,
- name: _vm.name && _vm.name[1]
- },
- domProps: { value: _vm.displayValue && _vm.displayValue[1] },
- on: {
- input: _vm.handleEndInput,
- change: _vm.handleEndChange,
- focus: _vm.handleFocus
- }
- },
- "input",
- _vm.secondInputId,
- false
- )
- ),
- _vm.haveTrigger
- ? _c("i", {
- staticClass: "el-input__icon el-range__close-icon",
- class: [_vm.showClose ? "" + _vm.clearIcon : ""],
- on: { click: _vm.handleClickIcon }
- })
- : _vm._e()
- ],
- 2
- )
- }
- var pickervue_type_template_id_79ae069f_staticRenderFns = []
- pickervue_type_template_id_79ae069f_render._withStripped = true
- // CONCATENATED MODULE: ./packages/date-picker/src/picker.vue?vue&type=template&id=79ae069f&
- // EXTERNAL MODULE: external "element-ui/lib/utils/date-util"
- var date_util_ = __webpack_require__(0);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/picker.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var NewPopper = {
- props: {
- appendToBody: vue_popper_default.a.props.appendToBody,
- offset: vue_popper_default.a.props.offset,
- boundariesPadding: vue_popper_default.a.props.boundariesPadding,
- arrowOffset: vue_popper_default.a.props.arrowOffset,
- transformOrigin: vue_popper_default.a.props.transformOrigin
- },
- methods: vue_popper_default.a.methods,
- data: function data() {
- return merge_default()({ visibleArrow: true }, vue_popper_default.a.data);
- },
- beforeDestroy: vue_popper_default.a.beforeDestroy
- };
- var DEFAULT_FORMATS = {
- date: 'yyyy-MM-dd',
- month: 'yyyy-MM',
- months: 'yyyy-MM',
- datetime: 'yyyy-MM-dd HH:mm:ss',
- time: 'HH:mm:ss',
- week: 'yyyywWW',
- timerange: 'HH:mm:ss',
- daterange: 'yyyy-MM-dd',
- monthrange: 'yyyy-MM',
- datetimerange: 'yyyy-MM-dd HH:mm:ss',
- year: 'yyyy',
- years: 'yyyy'
- };
- var HAVE_TRIGGER_TYPES = ['date', 'datetime', 'time', 'time-select', 'week', 'month', 'year', 'daterange', 'monthrange', 'timerange', 'datetimerange', 'dates', 'months', 'years'];
- var pickervue_type_script_lang_js_DATE_FORMATTER = function DATE_FORMATTER(value, format) {
- if (format === 'timestamp') return value.getTime();
- return Object(date_util_["formatDate"])(value, format);
- };
- var pickervue_type_script_lang_js_DATE_PARSER = function DATE_PARSER(text, format) {
- if (format === 'timestamp') return new Date(Number(text));
- return Object(date_util_["parseDate"])(text, format);
- };
- var RANGE_FORMATTER = function RANGE_FORMATTER(value, format) {
- if (Array.isArray(value) && value.length === 2) {
- var start = value[0];
- var end = value[1];
- if (start && end) {
- return [pickervue_type_script_lang_js_DATE_FORMATTER(start, format), pickervue_type_script_lang_js_DATE_FORMATTER(end, format)];
- }
- }
- return '';
- };
- var RANGE_PARSER = function RANGE_PARSER(array, format, separator) {
- if (!Array.isArray(array)) {
- array = array.split(separator);
- }
- if (array.length === 2) {
- var range1 = array[0];
- var range2 = array[1];
- return [pickervue_type_script_lang_js_DATE_PARSER(range1, format), pickervue_type_script_lang_js_DATE_PARSER(range2, format)];
- }
- return [];
- };
- var TYPE_VALUE_RESOLVER_MAP = {
- default: {
- formatter: function formatter(value) {
- if (!value) return '';
- return '' + value;
- },
- parser: function parser(text) {
- if (text === undefined || text === '') return null;
- return text;
- }
- },
- week: {
- formatter: function formatter(value, format) {
- var week = Object(date_util_["getWeekNumber"])(value);
- var month = value.getMonth();
- var trueDate = new Date(value);
- if (week === 1 && month === 11) {
- trueDate.setHours(0, 0, 0, 0);
- trueDate.setDate(trueDate.getDate() + 3 - (trueDate.getDay() + 6) % 7);
- }
- var date = Object(date_util_["formatDate"])(trueDate, format);
- date = /WW/.test(date) ? date.replace(/WW/, week < 10 ? '0' + week : week) : date.replace(/W/, week);
- return date;
- },
- parser: function parser(text, format) {
- // parse as if a normal date
- return TYPE_VALUE_RESOLVER_MAP.date.parser(text, format);
- }
- },
- date: {
- formatter: pickervue_type_script_lang_js_DATE_FORMATTER,
- parser: pickervue_type_script_lang_js_DATE_PARSER
- },
- datetime: {
- formatter: pickervue_type_script_lang_js_DATE_FORMATTER,
- parser: pickervue_type_script_lang_js_DATE_PARSER
- },
- daterange: {
- formatter: RANGE_FORMATTER,
- parser: RANGE_PARSER
- },
- monthrange: {
- formatter: RANGE_FORMATTER,
- parser: RANGE_PARSER
- },
- datetimerange: {
- formatter: RANGE_FORMATTER,
- parser: RANGE_PARSER
- },
- timerange: {
- formatter: RANGE_FORMATTER,
- parser: RANGE_PARSER
- },
- time: {
- formatter: pickervue_type_script_lang_js_DATE_FORMATTER,
- parser: pickervue_type_script_lang_js_DATE_PARSER
- },
- month: {
- formatter: pickervue_type_script_lang_js_DATE_FORMATTER,
- parser: pickervue_type_script_lang_js_DATE_PARSER
- },
- year: {
- formatter: pickervue_type_script_lang_js_DATE_FORMATTER,
- parser: pickervue_type_script_lang_js_DATE_PARSER
- },
- number: {
- formatter: function formatter(value) {
- if (!value) return '';
- return '' + value;
- },
- parser: function parser(text) {
- var result = Number(text);
- if (!isNaN(text)) {
- return result;
- } else {
- return null;
- }
- }
- },
- dates: {
- formatter: function formatter(value, format) {
- return value.map(function (date) {
- return pickervue_type_script_lang_js_DATE_FORMATTER(date, format);
- });
- },
- parser: function parser(value, format) {
- return (typeof value === 'string' ? value.split(', ') : value).map(function (date) {
- return date instanceof Date ? date : pickervue_type_script_lang_js_DATE_PARSER(date, format);
- });
- }
- },
- months: {
- formatter: function formatter(value, format) {
- return value.map(function (date) {
- return pickervue_type_script_lang_js_DATE_FORMATTER(date, format);
- });
- },
- parser: function parser(value, format) {
- return (typeof value === 'string' ? value.split(', ') : value).map(function (date) {
- return date instanceof Date ? date : pickervue_type_script_lang_js_DATE_PARSER(date, format);
- });
- }
- },
- years: {
- formatter: function formatter(value, format) {
- return value.map(function (date) {
- return pickervue_type_script_lang_js_DATE_FORMATTER(date, format);
- });
- },
- parser: function parser(value, format) {
- return (typeof value === 'string' ? value.split(', ') : value).map(function (date) {
- return date instanceof Date ? date : pickervue_type_script_lang_js_DATE_PARSER(date, format);
- });
- }
- }
- };
- var PLACEMENT_MAP = {
- left: 'bottom-start',
- center: 'bottom',
- right: 'bottom-end'
- };
- var parseAsFormatAndType = function parseAsFormatAndType(value, customFormat, type) {
- var rangeSeparator = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : '-';
- if (!value) return null;
- var parser = (TYPE_VALUE_RESOLVER_MAP[type] || TYPE_VALUE_RESOLVER_MAP['default']).parser;
- var format = customFormat || DEFAULT_FORMATS[type];
- return parser(value, format, rangeSeparator);
- };
- var formatAsFormatAndType = function formatAsFormatAndType(value, customFormat, type) {
- if (!value) return null;
- var formatter = (TYPE_VALUE_RESOLVER_MAP[type] || TYPE_VALUE_RESOLVER_MAP['default']).formatter;
- var format = customFormat || DEFAULT_FORMATS[type];
- return formatter(value, format);
- };
- /*
- * Considers:
- * 1. Date object
- * 2. date string
- * 3. array of 1 or 2
- */
- var valueEquals = function valueEquals(a, b) {
- // considers Date object and string
- var dateEquals = function dateEquals(a, b) {
- var aIsDate = a instanceof Date;
- var bIsDate = b instanceof Date;
- if (aIsDate && bIsDate) {
- return a.getTime() === b.getTime();
- }
- if (!aIsDate && !bIsDate) {
- return a === b;
- }
- return false;
- };
- var aIsArray = a instanceof Array;
- var bIsArray = b instanceof Array;
- if (aIsArray && bIsArray) {
- if (a.length !== b.length) {
- return false;
- }
- return a.every(function (item, index) {
- return dateEquals(item, b[index]);
- });
- }
- if (!aIsArray && !bIsArray) {
- return dateEquals(a, b);
- }
- return false;
- };
- var isString = function isString(val) {
- return typeof val === 'string' || val instanceof String;
- };
- var pickervue_type_script_lang_js_validator = function validator(val) {
- // either: String, Array of String, null / undefined
- return val === null || val === undefined || isString(val) || Array.isArray(val) && val.length === 2 && val.every(isString);
- };
- /* harmony default export */ var pickervue_type_script_lang_js_ = ({
- mixins: [emitter_default.a, NewPopper],
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- props: {
- size: String,
- format: String,
- valueFormat: String,
- readonly: Boolean,
- placeholder: String,
- startPlaceholder: String,
- endPlaceholder: String,
- prefixIcon: String,
- clearIcon: {
- type: String,
- default: 'el-icon-circle-close'
- },
- name: {
- default: '',
- validator: pickervue_type_script_lang_js_validator
- },
- disabled: Boolean,
- clearable: {
- type: Boolean,
- default: true
- },
- id: {
- default: '',
- validator: pickervue_type_script_lang_js_validator
- },
- popperClass: String,
- editable: {
- type: Boolean,
- default: true
- },
- align: {
- type: String,
- default: 'left'
- },
- value: {},
- defaultValue: {},
- defaultTime: {},
- rangeSeparator: {
- default: '-'
- },
- pickerOptions: {},
- unlinkPanels: Boolean,
- validateEvent: {
- type: Boolean,
- default: true
- }
- },
- components: { ElInput: input_default.a },
- directives: { Clickoutside: clickoutside_default.a },
- data: function data() {
- return {
- pickerVisible: false,
- showClose: false,
- userInput: null,
- valueOnOpen: null, // value when picker opens, used to determine whether to emit change
- unwatchPickerOptions: null
- };
- },
- watch: {
- pickerVisible: function pickerVisible(val) {
- if (this.readonly || this.pickerDisabled) return;
- if (val) {
- this.showPicker();
- this.valueOnOpen = Array.isArray(this.value) ? [].concat(this.value) : this.value;
- } else {
- this.hidePicker();
- this.emitChange(this.value);
- this.userInput = null;
- if (this.validateEvent) {
- this.dispatch('ElFormItem', 'el.form.blur');
- }
- this.$emit('blur', this);
- this.blur();
- }
- },
- parsedValue: {
- immediate: true,
- handler: function handler(val) {
- if (this.picker) {
- this.picker.value = val;
- }
- }
- },
- defaultValue: function defaultValue(val) {
- // NOTE: should eventually move to jsx style picker + panel ?
- if (this.picker) {
- this.picker.defaultValue = val;
- }
- },
- value: function value(val, oldVal) {
- if (!valueEquals(val, oldVal) && !this.pickerVisible && this.validateEvent) {
- this.dispatch('ElFormItem', 'el.form.change', val);
- }
- }
- },
- computed: {
- ranged: function ranged() {
- return this.type.indexOf('range') > -1;
- },
- reference: function reference() {
- var reference = this.$refs.reference;
- return reference.$el || reference;
- },
- refInput: function refInput() {
- if (this.reference) {
- return [].slice.call(this.reference.querySelectorAll('input'));
- }
- return [];
- },
- valueIsEmpty: function valueIsEmpty() {
- var val = this.value;
- if (Array.isArray(val)) {
- for (var i = 0, len = val.length; i < len; i++) {
- if (val[i]) {
- return false;
- }
- }
- } else {
- if (val) {
- return false;
- }
- }
- return true;
- },
- triggerClass: function triggerClass() {
- return this.prefixIcon || (this.type.indexOf('time') !== -1 ? 'el-icon-time' : 'el-icon-date');
- },
- selectionMode: function selectionMode() {
- if (this.type === 'week') {
- return 'week';
- } else if (this.type === 'month') {
- return 'month';
- } else if (this.type === 'year') {
- return 'year';
- } else if (this.type === 'dates') {
- return 'dates';
- } else if (this.type === 'months') {
- return 'months';
- } else if (this.type === 'years') {
- return 'years';
- }
- return 'day';
- },
- haveTrigger: function haveTrigger() {
- if (typeof this.showTrigger !== 'undefined') {
- return this.showTrigger;
- }
- return HAVE_TRIGGER_TYPES.indexOf(this.type) !== -1;
- },
- displayValue: function displayValue() {
- var formattedValue = formatAsFormatAndType(this.parsedValue, this.format, this.type, this.rangeSeparator);
- if (Array.isArray(this.userInput)) {
- return [this.userInput[0] || formattedValue && formattedValue[0] || '', this.userInput[1] || formattedValue && formattedValue[1] || ''];
- } else if (this.userInput !== null) {
- return this.userInput;
- } else if (formattedValue) {
- return this.type === 'dates' || this.type === 'years' || this.type === 'months' ? formattedValue.join(', ') : formattedValue;
- } else {
- return '';
- }
- },
- parsedValue: function parsedValue() {
- if (!this.value) return this.value; // component value is not set
- if (this.type === 'time-select') return this.value; // time-select does not require parsing, this might change in next major version
- var valueIsDateObject = Object(date_util_["isDateObject"])(this.value) || Array.isArray(this.value) && this.value.every(date_util_["isDateObject"]);
- if (valueIsDateObject) {
- return this.value;
- }
- if (this.valueFormat) {
- return parseAsFormatAndType(this.value, this.valueFormat, this.type, this.rangeSeparator) || this.value;
- }
- // NOTE: deal with common but incorrect usage, should remove in next major version
- // user might provide string / timestamp without value-format, coerce them into date (or array of date)
- return Array.isArray(this.value) ? this.value.map(function (val) {
- return new Date(val);
- }) : new Date(this.value);
- },
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- pickerSize: function pickerSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- pickerDisabled: function pickerDisabled() {
- return this.disabled || (this.elForm || {}).disabled;
- },
- firstInputId: function firstInputId() {
- var obj = {};
- var id = void 0;
- if (this.ranged) {
- id = this.id && this.id[0];
- } else {
- id = this.id;
- }
- if (id) obj.id = id;
- return obj;
- },
- secondInputId: function secondInputId() {
- var obj = {};
- var id = void 0;
- if (this.ranged) {
- id = this.id && this.id[1];
- }
- if (id) obj.id = id;
- return obj;
- }
- },
- created: function created() {
- // vue-popper
- this.popperOptions = {
- boundariesPadding: 0,
- gpuAcceleration: false
- };
- this.placement = PLACEMENT_MAP[this.align] || PLACEMENT_MAP.left;
- this.$on('fieldReset', this.handleFieldReset);
- },
- methods: {
- focus: function focus() {
- if (!this.ranged) {
- this.$refs.reference.focus();
- } else {
- this.handleFocus();
- }
- },
- blur: function blur() {
- this.refInput.forEach(function (input) {
- return input.blur();
- });
- },
- // {parse, formatTo} Value deals maps component value with internal Date
- parseValue: function parseValue(value) {
- var isParsed = Object(date_util_["isDateObject"])(value) || Array.isArray(value) && value.every(date_util_["isDateObject"]);
- if (this.valueFormat && !isParsed) {
- return parseAsFormatAndType(value, this.valueFormat, this.type, this.rangeSeparator) || value;
- } else {
- return value;
- }
- },
- formatToValue: function formatToValue(date) {
- var isFormattable = Object(date_util_["isDateObject"])(date) || Array.isArray(date) && date.every(date_util_["isDateObject"]);
- if (this.valueFormat && isFormattable) {
- return formatAsFormatAndType(date, this.valueFormat, this.type, this.rangeSeparator);
- } else {
- return date;
- }
- },
- // {parse, formatTo} String deals with user input
- parseString: function parseString(value) {
- var type = Array.isArray(value) ? this.type : this.type.replace('range', '');
- return parseAsFormatAndType(value, this.format, type);
- },
- formatToString: function formatToString(value) {
- var type = Array.isArray(value) ? this.type : this.type.replace('range', '');
- return formatAsFormatAndType(value, this.format, type);
- },
- handleMouseEnter: function handleMouseEnter() {
- if (this.readonly || this.pickerDisabled) return;
- if (!this.valueIsEmpty && this.clearable) {
- this.showClose = true;
- }
- },
- handleChange: function handleChange() {
- if (this.userInput) {
- var value = this.parseString(this.displayValue);
- if (value) {
- this.picker.value = value;
- if (this.isValidValue(value)) {
- this.emitInput(value);
- this.userInput = null;
- }
- }
- }
- if (this.userInput === '') {
- this.emitInput(null);
- this.emitChange(null);
- this.userInput = null;
- }
- },
- handleStartInput: function handleStartInput(event) {
- if (this.userInput) {
- this.userInput = [event.target.value, this.userInput[1]];
- } else {
- this.userInput = [event.target.value, null];
- }
- },
- handleEndInput: function handleEndInput(event) {
- if (this.userInput) {
- this.userInput = [this.userInput[0], event.target.value];
- } else {
- this.userInput = [null, event.target.value];
- }
- },
- handleStartChange: function handleStartChange(event) {
- var value = this.parseString(this.userInput && this.userInput[0]);
- if (value) {
- this.userInput = [this.formatToString(value), this.displayValue[1]];
- var newValue = [value, this.picker.value && this.picker.value[1]];
- this.picker.value = newValue;
- if (this.isValidValue(newValue)) {
- this.emitInput(newValue);
- this.userInput = null;
- }
- }
- },
- handleEndChange: function handleEndChange(event) {
- var value = this.parseString(this.userInput && this.userInput[1]);
- if (value) {
- this.userInput = [this.displayValue[0], this.formatToString(value)];
- var newValue = [this.picker.value && this.picker.value[0], value];
- this.picker.value = newValue;
- if (this.isValidValue(newValue)) {
- this.emitInput(newValue);
- this.userInput = null;
- }
- }
- },
- handleClickIcon: function handleClickIcon(event) {
- if (this.readonly || this.pickerDisabled) return;
- if (this.showClose) {
- this.valueOnOpen = this.value;
- event.stopPropagation();
- this.emitInput(null);
- this.emitChange(null);
- this.showClose = false;
- if (this.picker && typeof this.picker.handleClear === 'function') {
- this.picker.handleClear();
- }
- } else {
- this.pickerVisible = !this.pickerVisible;
- }
- },
- handleClose: function handleClose() {
- if (!this.pickerVisible) return;
- this.pickerVisible = false;
- if (this.type === 'dates' || this.type === 'years' || this.type === 'months') {
- // restore to former value
- var oldValue = parseAsFormatAndType(this.valueOnOpen, this.valueFormat, this.type, this.rangeSeparator) || this.valueOnOpen;
- this.emitInput(oldValue);
- }
- },
- handleFieldReset: function handleFieldReset(initialValue) {
- this.userInput = initialValue === '' ? null : initialValue;
- },
- handleFocus: function handleFocus() {
- var type = this.type;
- if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) {
- this.pickerVisible = true;
- }
- this.$emit('focus', this);
- },
- handleKeydown: function handleKeydown(event) {
- var _this = this;
- var keyCode = event.keyCode;
- // ESC
- if (keyCode === 27) {
- this.pickerVisible = false;
- event.stopPropagation();
- return;
- }
- // Tab
- if (keyCode === 9) {
- if (!this.ranged) {
- this.handleChange();
- this.pickerVisible = this.picker.visible = false;
- this.blur();
- event.stopPropagation();
- } else {
- // user may change focus between two input
- setTimeout(function () {
- if (_this.refInput.indexOf(document.activeElement) === -1) {
- _this.pickerVisible = false;
- _this.blur();
- event.stopPropagation();
- }
- }, 0);
- }
- return;
- }
- // Enter
- if (keyCode === 13) {
- if (this.userInput === '' || this.isValidValue(this.parseString(this.displayValue))) {
- this.handleChange();
- this.pickerVisible = this.picker.visible = false;
- this.blur();
- }
- event.stopPropagation();
- return;
- }
- // if user is typing, do not let picker handle key input
- if (this.userInput) {
- event.stopPropagation();
- return;
- }
- // delegate other keys to panel
- if (this.picker && this.picker.handleKeydown) {
- this.picker.handleKeydown(event);
- }
- },
- handleRangeClick: function handleRangeClick() {
- var type = this.type;
- if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) {
- this.pickerVisible = true;
- }
- this.$emit('focus', this);
- },
- hidePicker: function hidePicker() {
- if (this.picker) {
- this.picker.resetView && this.picker.resetView();
- this.pickerVisible = this.picker.visible = false;
- this.destroyPopper();
- }
- },
- showPicker: function showPicker() {
- var _this2 = this;
- if (this.$isServer) return;
- if (!this.picker) {
- this.mountPicker();
- }
- this.pickerVisible = this.picker.visible = true;
- this.updatePopper();
- this.picker.value = this.parsedValue;
- this.picker.resetView && this.picker.resetView();
- this.$nextTick(function () {
- _this2.picker.adjustSpinners && _this2.picker.adjustSpinners();
- });
- },
- mountPicker: function mountPicker() {
- var _this3 = this;
- this.picker = new external_vue_default.a(this.panel).$mount();
- this.picker.defaultValue = this.defaultValue;
- this.picker.defaultTime = this.defaultTime;
- this.picker.popperClass = this.popperClass;
- this.popperElm = this.picker.$el;
- this.picker.width = this.reference.getBoundingClientRect().width;
- this.picker.showTime = this.type === 'datetime' || this.type === 'datetimerange';
- this.picker.selectionMode = this.selectionMode;
- this.picker.unlinkPanels = this.unlinkPanels;
- this.picker.arrowControl = this.arrowControl || this.timeArrowControl || false;
- this.$watch('format', function (format) {
- _this3.picker.format = format;
- });
- var updateOptions = function updateOptions() {
- var options = _this3.pickerOptions;
- if (options && options.selectableRange) {
- var ranges = options.selectableRange;
- var parser = TYPE_VALUE_RESOLVER_MAP.datetimerange.parser;
- var format = DEFAULT_FORMATS.timerange;
- ranges = Array.isArray(ranges) ? ranges : [ranges];
- _this3.picker.selectableRange = ranges.map(function (range) {
- return parser(range, format, _this3.rangeSeparator);
- });
- }
- for (var option in options) {
- if (options.hasOwnProperty(option) &&
- // 忽略 time-picker 的该配置项
- option !== 'selectableRange') {
- _this3.picker[option] = options[option];
- }
- }
- // main format must prevail over undocumented pickerOptions.format
- if (_this3.format) {
- _this3.picker.format = _this3.format;
- }
- };
- updateOptions();
- this.unwatchPickerOptions = this.$watch('pickerOptions', function () {
- return updateOptions();
- }, { deep: true });
- this.$el.appendChild(this.picker.$el);
- this.picker.resetView && this.picker.resetView();
- this.picker.$on('dodestroy', this.doDestroy);
- this.picker.$on('pick', function () {
- var date = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
- var visible = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
- _this3.userInput = null;
- _this3.pickerVisible = _this3.picker.visible = visible;
- _this3.emitInput(date);
- _this3.picker.resetView && _this3.picker.resetView();
- });
- this.picker.$on('select-range', function (start, end, pos) {
- if (_this3.refInput.length === 0) return;
- if (!pos || pos === 'min') {
- _this3.refInput[0].setSelectionRange(start, end);
- _this3.refInput[0].focus();
- } else if (pos === 'max') {
- _this3.refInput[1].setSelectionRange(start, end);
- _this3.refInput[1].focus();
- }
- });
- },
- unmountPicker: function unmountPicker() {
- if (this.picker) {
- this.picker.$destroy();
- this.picker.$off();
- if (typeof this.unwatchPickerOptions === 'function') {
- this.unwatchPickerOptions();
- }
- this.picker.$el.parentNode.removeChild(this.picker.$el);
- }
- },
- emitChange: function emitChange(val) {
- // determine user real change only
- if (!valueEquals(val, this.valueOnOpen)) {
- this.$emit('change', val);
- this.valueOnOpen = val;
- if (this.validateEvent) {
- this.dispatch('ElFormItem', 'el.form.change', val);
- }
- }
- },
- emitInput: function emitInput(val) {
- var formatted = this.formatToValue(val);
- if (!valueEquals(this.value, formatted)) {
- this.$emit('input', formatted);
- }
- },
- isValidValue: function isValidValue(value) {
- if (!this.picker) {
- this.mountPicker();
- }
- if (this.picker.isValidValue) {
- return value && this.picker.isValidValue(value);
- } else {
- return true;
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/date-picker/src/picker.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_pickervue_type_script_lang_js_ = (pickervue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/date-picker/src/picker.vue
- /* normalize component */
- var picker_component = normalizeComponent(
- src_pickervue_type_script_lang_js_,
- pickervue_type_template_id_79ae069f_render,
- pickervue_type_template_id_79ae069f_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var picker_api; }
- picker_component.options.__file = "packages/date-picker/src/picker.vue"
- /* harmony default export */ var picker = (picker_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date.vue?vue&type=template&id=2440d4ea&
- var datevue_type_template_id_2440d4ea_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- {
- attrs: { name: "el-zoom-in-top" },
- on: { "after-enter": _vm.handleEnter, "after-leave": _vm.handleLeave }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-picker-panel el-date-picker el-popper",
- class: [
- {
- "has-sidebar": _vm.$slots.sidebar || _vm.shortcuts,
- "has-time": _vm.showTime
- },
- _vm.popperClass
- ]
- },
- [
- _c(
- "div",
- { staticClass: "el-picker-panel__body-wrapper" },
- [
- _vm._t("sidebar"),
- _vm.shortcuts
- ? _c(
- "div",
- { staticClass: "el-picker-panel__sidebar" },
- _vm._l(_vm.shortcuts, function(shortcut, key) {
- return _c(
- "button",
- {
- key: key,
- staticClass: "el-picker-panel__shortcut",
- attrs: { type: "button" },
- on: {
- click: function($event) {
- _vm.handleShortcutClick(shortcut)
- }
- }
- },
- [_vm._v(_vm._s(shortcut.text))]
- )
- }),
- 0
- )
- : _vm._e(),
- _c("div", { staticClass: "el-picker-panel__body" }, [
- _vm.showTime
- ? _c("div", { staticClass: "el-date-picker__time-header" }, [
- _c(
- "span",
- { staticClass: "el-date-picker__editor-wrap" },
- [
- _c("el-input", {
- attrs: {
- placeholder: _vm.t("el.datepicker.selectDate"),
- value: _vm.visibleDate,
- size: "small"
- },
- on: {
- input: function(val) {
- return (_vm.userInputDate = val)
- },
- change: _vm.handleVisibleDateChange
- }
- })
- ],
- 1
- ),
- _c(
- "span",
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: _vm.handleTimePickClose,
- expression: "handleTimePickClose"
- }
- ],
- staticClass: "el-date-picker__editor-wrap"
- },
- [
- _c("el-input", {
- ref: "input",
- attrs: {
- placeholder: _vm.t("el.datepicker.selectTime"),
- value: _vm.visibleTime,
- size: "small"
- },
- on: {
- focus: function($event) {
- _vm.timePickerVisible = true
- },
- input: function(val) {
- return (_vm.userInputTime = val)
- },
- change: _vm.handleVisibleTimeChange
- }
- }),
- _c("time-picker", {
- ref: "timepicker",
- attrs: {
- "time-arrow-control": _vm.arrowControl,
- visible: _vm.timePickerVisible
- },
- on: {
- pick: _vm.handleTimePick,
- mounted: _vm.proxyTimePickerDataProperties
- }
- })
- ],
- 1
- )
- ])
- : _vm._e(),
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.currentView !== "time",
- expression: "currentView !== 'time'"
- }
- ],
- staticClass: "el-date-picker__header",
- class: {
- "el-date-picker__header--bordered":
- _vm.currentView === "year" ||
- _vm.currentView === "month"
- }
- },
- [
- _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-date-picker__prev-btn el-icon-d-arrow-left",
- attrs: {
- type: "button",
- "aria-label": _vm.t("el.datepicker.prevYear")
- },
- on: { click: _vm.prevYear }
- }),
- _c("button", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.currentView === "date",
- expression: "currentView === 'date'"
- }
- ],
- staticClass:
- "el-picker-panel__icon-btn el-date-picker__prev-btn el-icon-arrow-left",
- attrs: {
- type: "button",
- "aria-label": _vm.t("el.datepicker.prevMonth")
- },
- on: { click: _vm.prevMonth }
- }),
- _c(
- "span",
- {
- staticClass: "el-date-picker__header-label",
- attrs: { role: "button" },
- on: { click: _vm.showYearPicker }
- },
- [_vm._v(_vm._s(_vm.yearLabel))]
- ),
- _c(
- "span",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.currentView === "date",
- expression: "currentView === 'date'"
- }
- ],
- staticClass: "el-date-picker__header-label",
- class: { active: _vm.currentView === "month" },
- attrs: { role: "button" },
- on: { click: _vm.showMonthPicker }
- },
- [
- _vm._v(
- _vm._s(_vm.t("el.datepicker.month" + (_vm.month + 1)))
- )
- ]
- ),
- _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-date-picker__next-btn el-icon-d-arrow-right",
- attrs: {
- type: "button",
- "aria-label": _vm.t("el.datepicker.nextYear")
- },
- on: { click: _vm.nextYear }
- }),
- _c("button", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.currentView === "date",
- expression: "currentView === 'date'"
- }
- ],
- staticClass:
- "el-picker-panel__icon-btn el-date-picker__next-btn el-icon-arrow-right",
- attrs: {
- type: "button",
- "aria-label": _vm.t("el.datepicker.nextMonth")
- },
- on: { click: _vm.nextMonth }
- })
- ]
- ),
- _c(
- "div",
- { staticClass: "el-picker-panel__content" },
- [
- _c("date-table", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.currentView === "date",
- expression: "currentView === 'date'"
- }
- ],
- attrs: {
- "selection-mode": _vm.selectionMode,
- "first-day-of-week": _vm.firstDayOfWeek,
- value: _vm.value,
- "default-value": _vm.defaultValue
- ? new Date(_vm.defaultValue)
- : null,
- date: _vm.date,
- "cell-class-name": _vm.cellClassName,
- "disabled-date": _vm.disabledDate
- },
- on: { pick: _vm.handleDatePick }
- }),
- _c("year-table", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.currentView === "year",
- expression: "currentView === 'year'"
- }
- ],
- attrs: {
- "selection-mode": _vm.selectionMode,
- value: _vm.value,
- "default-value": _vm.defaultValue
- ? new Date(_vm.defaultValue)
- : null,
- date: _vm.date,
- "disabled-date": _vm.disabledDate
- },
- on: { pick: _vm.handleYearPick }
- }),
- _c("month-table", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.currentView === "month",
- expression: "currentView === 'month'"
- }
- ],
- attrs: {
- "selection-mode": _vm.selectionMode,
- value: _vm.value,
- "default-value": _vm.defaultValue
- ? new Date(_vm.defaultValue)
- : null,
- date: _vm.date,
- "disabled-date": _vm.disabledDate
- },
- on: { pick: _vm.handleMonthPick }
- })
- ],
- 1
- )
- ])
- ],
- 2
- ),
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value:
- _vm.footerVisible &&
- (_vm.currentView === "date" ||
- _vm.currentView === "month" ||
- _vm.currentView === "year"),
- expression:
- "footerVisible && (currentView === 'date' || currentView === 'month' || currentView === 'year')"
- }
- ],
- staticClass: "el-picker-panel__footer"
- },
- [
- _c(
- "el-button",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value:
- _vm.selectionMode !== "dates" &&
- _vm.selectionMode !== "months" &&
- _vm.selectionMode !== "years",
- expression:
- "selectionMode !== 'dates' && selectionMode !== 'months' && selectionMode !== 'years'"
- }
- ],
- staticClass: "el-picker-panel__link-btn",
- attrs: { size: "mini", type: "text" },
- on: { click: _vm.changeToNow }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.t("el.datepicker.now")) +
- "\n "
- )
- ]
- ),
- _c(
- "el-button",
- {
- staticClass: "el-picker-panel__link-btn",
- attrs: { plain: "", size: "mini" },
- on: { click: _vm.confirm }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.t("el.datepicker.confirm")) +
- "\n "
- )
- ]
- )
- ],
- 1
- )
- ]
- )
- ]
- )
- }
- var datevue_type_template_id_2440d4ea_staticRenderFns = []
- datevue_type_template_id_2440d4ea_render._withStripped = true
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/date.vue?vue&type=template&id=2440d4ea&
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time.vue?vue&type=template&id=3d939089&
- var timevue_type_template_id_3d939089_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- {
- attrs: { name: "el-zoom-in-top" },
- on: {
- "after-leave": function($event) {
- _vm.$emit("dodestroy")
- }
- }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-time-panel el-popper",
- class: _vm.popperClass
- },
- [
- _c(
- "div",
- {
- staticClass: "el-time-panel__content",
- class: { "has-seconds": _vm.showSeconds }
- },
- [
- _c("time-spinner", {
- ref: "spinner",
- attrs: {
- "arrow-control": _vm.useArrow,
- "show-seconds": _vm.showSeconds,
- "am-pm-mode": _vm.amPmMode,
- date: _vm.date
- },
- on: {
- change: _vm.handleChange,
- "select-range": _vm.setSelectionRange
- }
- })
- ],
- 1
- ),
- _c("div", { staticClass: "el-time-panel__footer" }, [
- _c(
- "button",
- {
- staticClass: "el-time-panel__btn cancel",
- attrs: { type: "button" },
- on: { click: _vm.handleCancel }
- },
- [_vm._v(_vm._s(_vm.t("el.datepicker.cancel")))]
- ),
- _c(
- "button",
- {
- staticClass: "el-time-panel__btn",
- class: { confirm: !_vm.disabled },
- attrs: { type: "button" },
- on: {
- click: function($event) {
- _vm.handleConfirm()
- }
- }
- },
- [_vm._v(_vm._s(_vm.t("el.datepicker.confirm")))]
- )
- ])
- ]
- )
- ]
- )
- }
- var timevue_type_template_id_3d939089_staticRenderFns = []
- timevue_type_template_id_3d939089_render._withStripped = true
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/time.vue?vue&type=template&id=3d939089&
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/time-spinner.vue?vue&type=template&id=1facadeb&
- var time_spinnervue_type_template_id_1facadeb_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-time-spinner",
- class: { "has-seconds": _vm.showSeconds }
- },
- [
- !_vm.arrowControl
- ? [
- _c(
- "el-scrollbar",
- {
- ref: "hours",
- staticClass: "el-time-spinner__wrapper",
- attrs: {
- "wrap-style": "max-height: inherit;",
- "view-class": "el-time-spinner__list",
- noresize: "",
- tag: "ul"
- },
- nativeOn: {
- mouseenter: function($event) {
- _vm.emitSelectRange("hours")
- },
- mousemove: function($event) {
- _vm.adjustCurrentSpinner("hours")
- }
- }
- },
- _vm._l(_vm.hoursList, function(disabled, hour) {
- return _c(
- "li",
- {
- key: hour,
- staticClass: "el-time-spinner__item",
- class: { active: hour === _vm.hours, disabled: disabled },
- on: {
- click: function($event) {
- _vm.handleClick("hours", {
- value: hour,
- disabled: disabled
- })
- }
- }
- },
- [
- _vm._v(
- _vm._s(
- ("0" + (_vm.amPmMode ? hour % 12 || 12 : hour)).slice(
- -2
- )
- ) + _vm._s(_vm.amPm(hour))
- )
- ]
- )
- }),
- 0
- ),
- _c(
- "el-scrollbar",
- {
- ref: "minutes",
- staticClass: "el-time-spinner__wrapper",
- attrs: {
- "wrap-style": "max-height: inherit;",
- "view-class": "el-time-spinner__list",
- noresize: "",
- tag: "ul"
- },
- nativeOn: {
- mouseenter: function($event) {
- _vm.emitSelectRange("minutes")
- },
- mousemove: function($event) {
- _vm.adjustCurrentSpinner("minutes")
- }
- }
- },
- _vm._l(_vm.minutesList, function(enabled, key) {
- return _c(
- "li",
- {
- key: key,
- staticClass: "el-time-spinner__item",
- class: { active: key === _vm.minutes, disabled: !enabled },
- on: {
- click: function($event) {
- _vm.handleClick("minutes", {
- value: key,
- disabled: false
- })
- }
- }
- },
- [_vm._v(_vm._s(("0" + key).slice(-2)))]
- )
- }),
- 0
- ),
- _c(
- "el-scrollbar",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.showSeconds,
- expression: "showSeconds"
- }
- ],
- ref: "seconds",
- staticClass: "el-time-spinner__wrapper",
- attrs: {
- "wrap-style": "max-height: inherit;",
- "view-class": "el-time-spinner__list",
- noresize: "",
- tag: "ul"
- },
- nativeOn: {
- mouseenter: function($event) {
- _vm.emitSelectRange("seconds")
- },
- mousemove: function($event) {
- _vm.adjustCurrentSpinner("seconds")
- }
- }
- },
- _vm._l(60, function(second, key) {
- return _c(
- "li",
- {
- key: key,
- staticClass: "el-time-spinner__item",
- class: { active: key === _vm.seconds },
- on: {
- click: function($event) {
- _vm.handleClick("seconds", {
- value: key,
- disabled: false
- })
- }
- }
- },
- [_vm._v(_vm._s(("0" + key).slice(-2)))]
- )
- }),
- 0
- )
- ]
- : _vm._e(),
- _vm.arrowControl
- ? [
- _c(
- "div",
- {
- staticClass: "el-time-spinner__wrapper is-arrow",
- on: {
- mouseenter: function($event) {
- _vm.emitSelectRange("hours")
- }
- }
- },
- [
- _c("i", {
- directives: [
- {
- name: "repeat-click",
- rawName: "v-repeat-click",
- value: _vm.decrease,
- expression: "decrease"
- }
- ],
- staticClass: "el-time-spinner__arrow el-icon-arrow-up"
- }),
- _c("i", {
- directives: [
- {
- name: "repeat-click",
- rawName: "v-repeat-click",
- value: _vm.increase,
- expression: "increase"
- }
- ],
- staticClass: "el-time-spinner__arrow el-icon-arrow-down"
- }),
- _c(
- "ul",
- { ref: "hours", staticClass: "el-time-spinner__list" },
- _vm._l(_vm.arrowHourList, function(hour, key) {
- return _c(
- "li",
- {
- key: key,
- staticClass: "el-time-spinner__item",
- class: {
- active: hour === _vm.hours,
- disabled: _vm.hoursList[hour]
- }
- },
- [
- _vm._v(
- _vm._s(
- hour === undefined
- ? ""
- : (
- "0" + (_vm.amPmMode ? hour % 12 || 12 : hour)
- ).slice(-2) + _vm.amPm(hour)
- )
- )
- ]
- )
- }),
- 0
- )
- ]
- ),
- _c(
- "div",
- {
- staticClass: "el-time-spinner__wrapper is-arrow",
- on: {
- mouseenter: function($event) {
- _vm.emitSelectRange("minutes")
- }
- }
- },
- [
- _c("i", {
- directives: [
- {
- name: "repeat-click",
- rawName: "v-repeat-click",
- value: _vm.decrease,
- expression: "decrease"
- }
- ],
- staticClass: "el-time-spinner__arrow el-icon-arrow-up"
- }),
- _c("i", {
- directives: [
- {
- name: "repeat-click",
- rawName: "v-repeat-click",
- value: _vm.increase,
- expression: "increase"
- }
- ],
- staticClass: "el-time-spinner__arrow el-icon-arrow-down"
- }),
- _c(
- "ul",
- { ref: "minutes", staticClass: "el-time-spinner__list" },
- _vm._l(_vm.arrowMinuteList, function(minute, key) {
- return _c(
- "li",
- {
- key: key,
- staticClass: "el-time-spinner__item",
- class: { active: minute === _vm.minutes }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(
- minute === undefined
- ? ""
- : ("0" + minute).slice(-2)
- ) +
- "\n "
- )
- ]
- )
- }),
- 0
- )
- ]
- ),
- _vm.showSeconds
- ? _c(
- "div",
- {
- staticClass: "el-time-spinner__wrapper is-arrow",
- on: {
- mouseenter: function($event) {
- _vm.emitSelectRange("seconds")
- }
- }
- },
- [
- _c("i", {
- directives: [
- {
- name: "repeat-click",
- rawName: "v-repeat-click",
- value: _vm.decrease,
- expression: "decrease"
- }
- ],
- staticClass: "el-time-spinner__arrow el-icon-arrow-up"
- }),
- _c("i", {
- directives: [
- {
- name: "repeat-click",
- rawName: "v-repeat-click",
- value: _vm.increase,
- expression: "increase"
- }
- ],
- staticClass: "el-time-spinner__arrow el-icon-arrow-down"
- }),
- _c(
- "ul",
- { ref: "seconds", staticClass: "el-time-spinner__list" },
- _vm._l(_vm.arrowSecondList, function(second, key) {
- return _c(
- "li",
- {
- key: key,
- staticClass: "el-time-spinner__item",
- class: { active: second === _vm.seconds }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(
- second === undefined
- ? ""
- : ("0" + second).slice(-2)
- ) +
- "\n "
- )
- ]
- )
- }),
- 0
- )
- ]
- )
- : _vm._e()
- ]
- : _vm._e()
- ],
- 2
- )
- }
- var time_spinnervue_type_template_id_1facadeb_staticRenderFns = []
- time_spinnervue_type_template_id_1facadeb_render._withStripped = true
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/time-spinner.vue?vue&type=template&id=1facadeb&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/time-spinner.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var time_spinnervue_type_script_lang_js_ = ({
- components: { ElScrollbar: scrollbar_default.a },
- directives: {
- repeatClick: repeat_click
- },
- props: {
- date: {},
- defaultValue: {}, // reserved for future use
- showSeconds: {
- type: Boolean,
- default: true
- },
- arrowControl: Boolean,
- amPmMode: {
- type: String,
- default: '' // 'a': am/pm; 'A': AM/PM
- }
- },
- computed: {
- hours: function hours() {
- return this.date.getHours();
- },
- minutes: function minutes() {
- return this.date.getMinutes();
- },
- seconds: function seconds() {
- return this.date.getSeconds();
- },
- hoursList: function hoursList() {
- return Object(date_util_["getRangeHours"])(this.selectableRange);
- },
- minutesList: function minutesList() {
- return Object(date_util_["getRangeMinutes"])(this.selectableRange, this.hours);
- },
- arrowHourList: function arrowHourList() {
- var hours = this.hours;
- return [hours > 0 ? hours - 1 : undefined, hours, hours < 23 ? hours + 1 : undefined];
- },
- arrowMinuteList: function arrowMinuteList() {
- var minutes = this.minutes;
- return [minutes > 0 ? minutes - 1 : undefined, minutes, minutes < 59 ? minutes + 1 : undefined];
- },
- arrowSecondList: function arrowSecondList() {
- var seconds = this.seconds;
- return [seconds > 0 ? seconds - 1 : undefined, seconds, seconds < 59 ? seconds + 1 : undefined];
- }
- },
- data: function data() {
- return {
- selectableRange: [],
- currentScrollbar: null
- };
- },
- mounted: function mounted() {
- var _this = this;
- this.$nextTick(function () {
- !_this.arrowControl && _this.bindScrollEvent();
- });
- },
- methods: {
- increase: function increase() {
- this.scrollDown(1);
- },
- decrease: function decrease() {
- this.scrollDown(-1);
- },
- modifyDateField: function modifyDateField(type, value) {
- switch (type) {
- case 'hours':
- this.$emit('change', Object(date_util_["modifyTime"])(this.date, value, this.minutes, this.seconds));break;
- case 'minutes':
- this.$emit('change', Object(date_util_["modifyTime"])(this.date, this.hours, value, this.seconds));break;
- case 'seconds':
- this.$emit('change', Object(date_util_["modifyTime"])(this.date, this.hours, this.minutes, value));break;
- }
- },
- handleClick: function handleClick(type, _ref) {
- var value = _ref.value,
- disabled = _ref.disabled;
- if (!disabled) {
- this.modifyDateField(type, value);
- this.emitSelectRange(type);
- this.adjustSpinner(type, value);
- }
- },
- emitSelectRange: function emitSelectRange(type) {
- if (type === 'hours') {
- this.$emit('select-range', 0, 2);
- } else if (type === 'minutes') {
- this.$emit('select-range', 3, 5);
- } else if (type === 'seconds') {
- this.$emit('select-range', 6, 8);
- }
- this.currentScrollbar = type;
- },
- bindScrollEvent: function bindScrollEvent() {
- var _this2 = this;
- var bindFunction = function bindFunction(type) {
- _this2.$refs[type].wrap.onscroll = function (e) {
- // TODO: scroll is emitted when set scrollTop programatically
- // should find better solutions in the future!
- _this2.handleScroll(type, e);
- };
- };
- bindFunction('hours');
- bindFunction('minutes');
- bindFunction('seconds');
- },
- handleScroll: function handleScroll(type) {
- var value = Math.min(Math.round((this.$refs[type].wrap.scrollTop - (this.scrollBarHeight(type) * 0.5 - 10) / this.typeItemHeight(type) + 3) / this.typeItemHeight(type)), type === 'hours' ? 23 : 59);
- this.modifyDateField(type, value);
- },
- // NOTE: used by datetime / date-range panel
- // renamed from adjustScrollTop
- // should try to refactory it
- adjustSpinners: function adjustSpinners() {
- this.adjustSpinner('hours', this.hours);
- this.adjustSpinner('minutes', this.minutes);
- this.adjustSpinner('seconds', this.seconds);
- },
- adjustCurrentSpinner: function adjustCurrentSpinner(type) {
- this.adjustSpinner(type, this[type]);
- },
- adjustSpinner: function adjustSpinner(type, value) {
- if (this.arrowControl) return;
- var el = this.$refs[type].wrap;
- if (el) {
- el.scrollTop = Math.max(0, value * this.typeItemHeight(type));
- }
- },
- scrollDown: function scrollDown(step) {
- var _this3 = this;
- if (!this.currentScrollbar) {
- this.emitSelectRange('hours');
- }
- var label = this.currentScrollbar;
- var hoursList = this.hoursList;
- var now = this[label];
- if (this.currentScrollbar === 'hours') {
- var total = Math.abs(step);
- step = step > 0 ? 1 : -1;
- var length = hoursList.length;
- while (length-- && total) {
- now = (now + step + hoursList.length) % hoursList.length;
- if (hoursList[now]) {
- continue;
- }
- total--;
- }
- if (hoursList[now]) return;
- } else {
- now = (now + step + 60) % 60;
- }
- this.modifyDateField(label, now);
- this.adjustSpinner(label, now);
- this.$nextTick(function () {
- return _this3.emitSelectRange(_this3.currentScrollbar);
- });
- },
- amPm: function amPm(hour) {
- var shouldShowAmPm = this.amPmMode.toLowerCase() === 'a';
- if (!shouldShowAmPm) return '';
- var isCapital = this.amPmMode === 'A';
- var content = hour < 12 ? ' am' : ' pm';
- if (isCapital) content = content.toUpperCase();
- return content;
- },
- typeItemHeight: function typeItemHeight(type) {
- return this.$refs[type].$el.querySelector('li').offsetHeight;
- },
- scrollBarHeight: function scrollBarHeight(type) {
- return this.$refs[type].$el.offsetHeight;
- }
- }
- });
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/time-spinner.vue?vue&type=script&lang=js&
- /* harmony default export */ var basic_time_spinnervue_type_script_lang_js_ = (time_spinnervue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/time-spinner.vue
- /* normalize component */
- var time_spinner_component = normalizeComponent(
- basic_time_spinnervue_type_script_lang_js_,
- time_spinnervue_type_template_id_1facadeb_render,
- time_spinnervue_type_template_id_1facadeb_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var time_spinner_api; }
- time_spinner_component.options.__file = "packages/date-picker/src/basic/time-spinner.vue"
- /* harmony default export */ var time_spinner = (time_spinner_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var timevue_type_script_lang_js_ = ({
- mixins: [locale_default.a],
- components: {
- TimeSpinner: time_spinner
- },
- props: {
- visible: Boolean,
- timeArrowControl: Boolean
- },
- watch: {
- visible: function visible(val) {
- var _this = this;
- if (val) {
- this.oldValue = this.value;
- this.$nextTick(function () {
- return _this.$refs.spinner.emitSelectRange('hours');
- });
- } else {
- this.needInitAdjust = true;
- }
- },
- value: function value(newVal) {
- var _this2 = this;
- var date = void 0;
- if (newVal instanceof Date) {
- date = Object(date_util_["limitTimeRange"])(newVal, this.selectableRange, this.format);
- } else if (!newVal) {
- date = this.defaultValue ? new Date(this.defaultValue) : new Date();
- }
- this.date = date;
- if (this.visible && this.needInitAdjust) {
- this.$nextTick(function (_) {
- return _this2.adjustSpinners();
- });
- this.needInitAdjust = false;
- }
- },
- selectableRange: function selectableRange(val) {
- this.$refs.spinner.selectableRange = val;
- },
- defaultValue: function defaultValue(val) {
- if (!Object(date_util_["isDate"])(this.value)) {
- this.date = val ? new Date(val) : new Date();
- }
- }
- },
- data: function data() {
- return {
- popperClass: '',
- format: 'HH:mm:ss',
- value: '',
- defaultValue: null,
- date: new Date(),
- oldValue: new Date(),
- selectableRange: [],
- selectionRange: [0, 2],
- disabled: false,
- arrowControl: false,
- needInitAdjust: true
- };
- },
- computed: {
- showSeconds: function showSeconds() {
- return (this.format || '').indexOf('ss') !== -1;
- },
- useArrow: function useArrow() {
- return this.arrowControl || this.timeArrowControl || false;
- },
- amPmMode: function amPmMode() {
- if ((this.format || '').indexOf('A') !== -1) return 'A';
- if ((this.format || '').indexOf('a') !== -1) return 'a';
- return '';
- }
- },
- methods: {
- handleCancel: function handleCancel() {
- this.$emit('pick', this.oldValue, false);
- },
- handleChange: function handleChange(date) {
- // this.visible avoids edge cases, when use scrolls during panel closing animation
- if (this.visible) {
- this.date = Object(date_util_["clearMilliseconds"])(date);
- // if date is out of range, do not emit
- if (this.isValidValue(this.date)) {
- this.$emit('pick', this.date, true);
- }
- }
- },
- setSelectionRange: function setSelectionRange(start, end) {
- this.$emit('select-range', start, end);
- this.selectionRange = [start, end];
- },
- handleConfirm: function handleConfirm() {
- var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- var first = arguments[1];
- if (first) return;
- var date = Object(date_util_["clearMilliseconds"])(Object(date_util_["limitTimeRange"])(this.date, this.selectableRange, this.format));
- this.$emit('pick', date, visible, first);
- },
- handleKeydown: function handleKeydown(event) {
- var keyCode = event.keyCode;
- var mapping = { 38: -1, 40: 1, 37: -1, 39: 1 };
- // Left or Right
- if (keyCode === 37 || keyCode === 39) {
- var step = mapping[keyCode];
- this.changeSelectionRange(step);
- event.preventDefault();
- return;
- }
- // Up or Down
- if (keyCode === 38 || keyCode === 40) {
- var _step = mapping[keyCode];
- this.$refs.spinner.scrollDown(_step);
- event.preventDefault();
- return;
- }
- },
- isValidValue: function isValidValue(date) {
- return Object(date_util_["timeWithinRange"])(date, this.selectableRange, this.format);
- },
- adjustSpinners: function adjustSpinners() {
- return this.$refs.spinner.adjustSpinners();
- },
- changeSelectionRange: function changeSelectionRange(step) {
- var list = [0, 3].concat(this.showSeconds ? [6] : []);
- var mapping = ['hours', 'minutes'].concat(this.showSeconds ? ['seconds'] : []);
- var index = list.indexOf(this.selectionRange[0]);
- var next = (index + step + list.length) % list.length;
- this.$refs.spinner.emitSelectRange(mapping[next]);
- }
- },
- mounted: function mounted() {
- var _this3 = this;
- this.$nextTick(function () {
- return _this3.handleConfirm(true, true);
- });
- this.$emit('mounted');
- }
- });
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/time.vue?vue&type=script&lang=js&
- /* harmony default export */ var panel_timevue_type_script_lang_js_ = (timevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/time.vue
- /* normalize component */
- var time_component = normalizeComponent(
- panel_timevue_type_script_lang_js_,
- timevue_type_template_id_3d939089_render,
- timevue_type_template_id_3d939089_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var time_api; }
- time_component.options.__file = "packages/date-picker/src/panel/time.vue"
- /* harmony default export */ var panel_time = (time_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/year-table.vue?vue&type=template&id=c86ab5e0&
- var year_tablevue_type_template_id_c86ab5e0_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "table",
- { staticClass: "el-year-table", on: { click: _vm.handleYearTableClick } },
- [
- _c("tbody", [
- _c("tr", [
- _c(
- "td",
- {
- staticClass: "available",
- class: _vm.getCellStyle(_vm.startYear + 0)
- },
- [_c("a", { staticClass: "cell" }, [_vm._v(_vm._s(_vm.startYear))])]
- ),
- _c(
- "td",
- {
- staticClass: "available",
- class: _vm.getCellStyle(_vm.startYear + 1)
- },
- [
- _c("a", { staticClass: "cell" }, [
- _vm._v(_vm._s(_vm.startYear + 1))
- ])
- ]
- ),
- _c(
- "td",
- {
- staticClass: "available",
- class: _vm.getCellStyle(_vm.startYear + 2)
- },
- [
- _c("a", { staticClass: "cell" }, [
- _vm._v(_vm._s(_vm.startYear + 2))
- ])
- ]
- ),
- _c(
- "td",
- {
- staticClass: "available",
- class: _vm.getCellStyle(_vm.startYear + 3)
- },
- [
- _c("a", { staticClass: "cell" }, [
- _vm._v(_vm._s(_vm.startYear + 3))
- ])
- ]
- )
- ]),
- _c("tr", [
- _c(
- "td",
- {
- staticClass: "available",
- class: _vm.getCellStyle(_vm.startYear + 4)
- },
- [
- _c("a", { staticClass: "cell" }, [
- _vm._v(_vm._s(_vm.startYear + 4))
- ])
- ]
- ),
- _c(
- "td",
- {
- staticClass: "available",
- class: _vm.getCellStyle(_vm.startYear + 5)
- },
- [
- _c("a", { staticClass: "cell" }, [
- _vm._v(_vm._s(_vm.startYear + 5))
- ])
- ]
- ),
- _c(
- "td",
- {
- staticClass: "available",
- class: _vm.getCellStyle(_vm.startYear + 6)
- },
- [
- _c("a", { staticClass: "cell" }, [
- _vm._v(_vm._s(_vm.startYear + 6))
- ])
- ]
- ),
- _c(
- "td",
- {
- staticClass: "available",
- class: _vm.getCellStyle(_vm.startYear + 7)
- },
- [
- _c("a", { staticClass: "cell" }, [
- _vm._v(_vm._s(_vm.startYear + 7))
- ])
- ]
- )
- ]),
- _c("tr", [
- _c(
- "td",
- {
- staticClass: "available",
- class: _vm.getCellStyle(_vm.startYear + 8)
- },
- [
- _c("a", { staticClass: "cell" }, [
- _vm._v(_vm._s(_vm.startYear + 8))
- ])
- ]
- ),
- _c(
- "td",
- {
- staticClass: "available",
- class: _vm.getCellStyle(_vm.startYear + 9)
- },
- [
- _c("a", { staticClass: "cell" }, [
- _vm._v(_vm._s(_vm.startYear + 9))
- ])
- ]
- ),
- _c("td"),
- _c("td")
- ])
- ])
- ]
- )
- }
- var year_tablevue_type_template_id_c86ab5e0_staticRenderFns = []
- year_tablevue_type_template_id_c86ab5e0_render._withStripped = true
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/year-table.vue?vue&type=template&id=c86ab5e0&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/year-table.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var year_tablevue_type_script_lang_js_datesInYear = function datesInYear(year) {
- var numOfDays = Object(date_util_["getDayCountOfYear"])(year);
- var firstDay = new Date(year, 0, 1);
- return Object(date_util_["range"])(numOfDays).map(function (n) {
- return Object(date_util_["nextDate"])(firstDay, n);
- });
- };
- /* harmony default export */ var year_tablevue_type_script_lang_js_ = ({
- props: {
- disabledDate: {},
- value: {},
- defaultValue: {
- validator: function validator(val) {
- // null or valid Date Object
- return val === null || val instanceof Date && Object(date_util_["isDate"])(val);
- }
- },
- date: {},
- selectionMode: {}
- },
- computed: {
- startYear: function startYear() {
- return Math.floor(this.date.getFullYear() / 10) * 10;
- }
- },
- methods: {
- getCellStyle: function getCellStyle(year) {
- var style = {};
- var today = new Date();
- style.disabled = typeof this.disabledDate === 'function' ? year_tablevue_type_script_lang_js_datesInYear(year).every(this.disabledDate) : false;
- style.current = Object(util_["arrayFindIndex"])(Object(util_["coerceTruthyValueToArray"])(this.value), function (date) {
- return date.getFullYear() === year;
- }) >= 0;
- style.today = today.getFullYear() === year;
- style.default = this.defaultValue && this.defaultValue.getFullYear() === year;
- return style;
- },
- handleYearTableClick: function handleYearTableClick(event) {
- var target = event.target;
- if (target.tagName === 'A') {
- if (Object(dom_["hasClass"])(target.parentNode, 'disabled')) return;
- var year = target.textContent || target.innerText;
- if (this.selectionMode === 'years') {
- var value = this.value || [];
- var idx = Object(util_["arrayFindIndex"])(value, function (date) {
- return date.getFullYear() === Number(year);
- });
- var newValue = idx > -1 ? [].concat(value.slice(0, idx), value.slice(idx + 1)) : [].concat(value, [new Date(year)]);
- this.$emit('pick', newValue);
- } else {
- this.$emit('pick', Number(year));
- }
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/year-table.vue?vue&type=script&lang=js&
- /* harmony default export */ var basic_year_tablevue_type_script_lang_js_ = (year_tablevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/year-table.vue
- /* normalize component */
- var year_table_component = normalizeComponent(
- basic_year_tablevue_type_script_lang_js_,
- year_tablevue_type_template_id_c86ab5e0_render,
- year_tablevue_type_template_id_c86ab5e0_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var year_table_api; }
- year_table_component.options.__file = "packages/date-picker/src/basic/year-table.vue"
- /* harmony default export */ var year_table = (year_table_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/month-table.vue?vue&type=template&id=654d4f42&
- var month_tablevue_type_template_id_654d4f42_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "table",
- {
- staticClass: "el-month-table",
- on: { click: _vm.handleMonthTableClick, mousemove: _vm.handleMouseMove }
- },
- [
- _c(
- "tbody",
- _vm._l(_vm.rows, function(row, key) {
- return _c(
- "tr",
- { key: key },
- _vm._l(row, function(cell, key) {
- return _c("td", { key: key, class: _vm.getCellStyle(cell) }, [
- _c("div", [
- _c("a", { staticClass: "cell" }, [
- _vm._v(
- _vm._s(
- _vm.t("el.datepicker.months." + _vm.months[cell.text])
- )
- )
- ])
- ])
- ])
- }),
- 0
- )
- }),
- 0
- )
- ]
- )
- }
- var month_tablevue_type_template_id_654d4f42_staticRenderFns = []
- month_tablevue_type_template_id_654d4f42_render._withStripped = true
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/month-table.vue?vue&type=template&id=654d4f42&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/month-table.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var month_tablevue_type_script_lang_js_datesInMonth = function datesInMonth(year, month) {
- var numOfDays = Object(date_util_["getDayCountOfMonth"])(year, month);
- var firstDay = new Date(year, month, 1);
- return Object(date_util_["range"])(numOfDays).map(function (n) {
- return Object(date_util_["nextDate"])(firstDay, n);
- });
- };
- var clearDate = function clearDate(date) {
- return new Date(date.getFullYear(), date.getMonth());
- };
- var getMonthTimestamp = function getMonthTimestamp(time) {
- if (typeof time === 'number' || typeof time === 'string') {
- return clearDate(new Date(time)).getTime();
- } else if (time instanceof Date) {
- return clearDate(time).getTime();
- } else {
- return NaN;
- }
- };
- // remove the first element that satisfies `pred` from arr
- // return a new array if modification occurs
- // return the original array otherwise
- var month_tablevue_type_script_lang_js_removeFromArray = function removeFromArray(arr, pred) {
- var idx = typeof pred === 'function' ? Object(util_["arrayFindIndex"])(arr, pred) : arr.indexOf(pred);
- return idx >= 0 ? [].concat(arr.slice(0, idx), arr.slice(idx + 1)) : arr;
- };
- /* harmony default export */ var month_tablevue_type_script_lang_js_ = ({
- props: {
- disabledDate: {},
- value: {},
- selectionMode: {
- default: 'month'
- },
- minDate: {},
- maxDate: {},
- defaultValue: {
- validator: function validator(val) {
- // null or valid Date Object
- return val === null || Object(date_util_["isDate"])(val) || Array.isArray(val) && val.every(date_util_["isDate"]);
- }
- },
- date: {},
- rangeState: {
- default: function _default() {
- return {
- endDate: null,
- selecting: false
- };
- }
- }
- },
- mixins: [locale_default.a],
- watch: {
- 'rangeState.endDate': function rangeStateEndDate(newVal) {
- this.markRange(this.minDate, newVal);
- },
- minDate: function minDate(newVal, oldVal) {
- if (getMonthTimestamp(newVal) !== getMonthTimestamp(oldVal)) {
- this.markRange(this.minDate, this.maxDate);
- }
- },
- maxDate: function maxDate(newVal, oldVal) {
- if (getMonthTimestamp(newVal) !== getMonthTimestamp(oldVal)) {
- this.markRange(this.minDate, this.maxDate);
- }
- }
- },
- data: function data() {
- return {
- months: ['jan', 'feb', 'mar', 'apr', 'may', 'jun', 'jul', 'aug', 'sep', 'oct', 'nov', 'dec'],
- tableRows: [[], [], []],
- lastRow: null,
- lastColumn: null
- };
- },
- methods: {
- cellMatchesDate: function cellMatchesDate(cell, date) {
- var value = new Date(date);
- return this.date.getFullYear() === value.getFullYear() && Number(cell.text) === value.getMonth();
- },
- getCellStyle: function getCellStyle(cell) {
- var _this = this;
- var style = {};
- var year = this.date.getFullYear();
- var today = new Date();
- var month = cell.text;
- var defaultValue = this.defaultValue ? Array.isArray(this.defaultValue) ? this.defaultValue : [this.defaultValue] : [];
- style.disabled = typeof this.disabledDate === 'function' ? month_tablevue_type_script_lang_js_datesInMonth(year, month).every(this.disabledDate) : false;
- style.current = Object(util_["arrayFindIndex"])(Object(util_["coerceTruthyValueToArray"])(this.value), function (date) {
- return date.getFullYear() === year && date.getMonth() === month;
- }) >= 0;
- style.today = today.getFullYear() === year && today.getMonth() === month;
- style.default = defaultValue.some(function (date) {
- return _this.cellMatchesDate(cell, date);
- });
- if (cell.inRange) {
- style['in-range'] = true;
- if (cell.start) {
- style['start-date'] = true;
- }
- if (cell.end) {
- style['end-date'] = true;
- }
- }
- return style;
- },
- getMonthOfCell: function getMonthOfCell(month) {
- var year = this.date.getFullYear();
- return new Date(year, month, 1);
- },
- markRange: function markRange(minDate, maxDate) {
- minDate = getMonthTimestamp(minDate);
- maxDate = getMonthTimestamp(maxDate) || minDate;
- var _ref = [Math.min(minDate, maxDate), Math.max(minDate, maxDate)];
- minDate = _ref[0];
- maxDate = _ref[1];
- var rows = this.rows;
- for (var i = 0, k = rows.length; i < k; i++) {
- var row = rows[i];
- for (var j = 0, l = row.length; j < l; j++) {
- var cell = row[j];
- var index = i * 4 + j;
- var time = new Date(this.date.getFullYear(), index).getTime();
- cell.inRange = minDate && time >= minDate && time <= maxDate;
- cell.start = minDate && time === minDate;
- cell.end = maxDate && time === maxDate;
- }
- }
- },
- handleMouseMove: function handleMouseMove(event) {
- if (!this.rangeState.selecting) return;
- var target = event.target;
- if (target.tagName === 'A') {
- target = target.parentNode.parentNode;
- }
- if (target.tagName === 'DIV') {
- target = target.parentNode;
- }
- if (target.tagName !== 'TD') return;
- var row = target.parentNode.rowIndex;
- var column = target.cellIndex;
- // can not select disabled date
- if (this.rows[row][column].disabled) return;
- // only update rangeState when mouse moves to a new cell
- // this avoids frequent Date object creation and improves performance
- if (row !== this.lastRow || column !== this.lastColumn) {
- this.lastRow = row;
- this.lastColumn = column;
- this.$emit('changerange', {
- minDate: this.minDate,
- maxDate: this.maxDate,
- rangeState: {
- selecting: true,
- endDate: this.getMonthOfCell(row * 4 + column)
- }
- });
- }
- },
- handleMonthTableClick: function handleMonthTableClick(event) {
- var target = event.target;
- if (target.tagName === 'A') {
- target = target.parentNode.parentNode;
- }
- if (target.tagName === 'DIV') {
- target = target.parentNode;
- }
- if (target.tagName !== 'TD') return;
- if (Object(dom_["hasClass"])(target, 'disabled')) return;
- var column = target.cellIndex;
- var row = target.parentNode.rowIndex;
- var month = row * 4 + column;
- var newDate = this.getMonthOfCell(month);
- if (this.selectionMode === 'range') {
- if (!this.rangeState.selecting) {
- this.$emit('pick', { minDate: newDate, maxDate: null });
- this.rangeState.selecting = true;
- } else {
- if (newDate >= this.minDate) {
- this.$emit('pick', { minDate: this.minDate, maxDate: newDate });
- } else {
- this.$emit('pick', { minDate: newDate, maxDate: this.minDate });
- }
- this.rangeState.selecting = false;
- }
- } else if (this.selectionMode === 'months') {
- var value = this.value || [];
- var year = this.date.getFullYear();
- var newValue = Object(util_["arrayFindIndex"])(value, function (date) {
- return date.getFullYear() === year && date.getMonth() === month;
- }) >= 0 ? month_tablevue_type_script_lang_js_removeFromArray(value, function (date) {
- return date.getTime() === newDate.getTime();
- }) : [].concat(value, [newDate]);
- this.$emit('pick', newValue);
- } else {
- this.$emit('pick', month);
- }
- }
- },
- computed: {
- rows: function rows() {
- var _this2 = this;
- // TODO: refactory rows / getCellClasses
- var rows = this.tableRows;
- var disabledDate = this.disabledDate;
- var selectedDate = [];
- var now = getMonthTimestamp(new Date());
- for (var i = 0; i < 3; i++) {
- var row = rows[i];
- var _loop = function _loop(j) {
- var cell = row[j];
- if (!cell) {
- cell = { row: i, column: j, type: 'normal', inRange: false, start: false, end: false };
- }
- cell.type = 'normal';
- var index = i * 4 + j;
- var time = new Date(_this2.date.getFullYear(), index).getTime();
- cell.inRange = time >= getMonthTimestamp(_this2.minDate) && time <= getMonthTimestamp(_this2.maxDate);
- cell.start = _this2.minDate && time === getMonthTimestamp(_this2.minDate);
- cell.end = _this2.maxDate && time === getMonthTimestamp(_this2.maxDate);
- var isToday = time === now;
- if (isToday) {
- cell.type = 'today';
- }
- cell.text = index;
- var cellDate = new Date(time);
- cell.disabled = typeof disabledDate === 'function' && disabledDate(cellDate);
- cell.selected = Object(util_["arrayFind"])(selectedDate, function (date) {
- return date.getTime() === cellDate.getTime();
- });
- _this2.$set(row, j, cell);
- };
- for (var j = 0; j < 4; j++) {
- _loop(j);
- }
- }
- return rows;
- }
- }
- });
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/month-table.vue?vue&type=script&lang=js&
- /* harmony default export */ var basic_month_tablevue_type_script_lang_js_ = (month_tablevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/month-table.vue
- /* normalize component */
- var month_table_component = normalizeComponent(
- basic_month_tablevue_type_script_lang_js_,
- month_tablevue_type_template_id_654d4f42_render,
- month_tablevue_type_template_id_654d4f42_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var month_table_api; }
- month_table_component.options.__file = "packages/date-picker/src/basic/month-table.vue"
- /* harmony default export */ var month_table = (month_table_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/date-table.vue?vue&type=template&id=5d1f3341&
- var date_tablevue_type_template_id_5d1f3341_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "table",
- {
- staticClass: "el-date-table",
- class: { "is-week-mode": _vm.selectionMode === "week" },
- attrs: { cellspacing: "0", cellpadding: "0" },
- on: { click: _vm.handleClick, mousemove: _vm.handleMouseMove }
- },
- [
- _c(
- "tbody",
- [
- _c(
- "tr",
- [
- _vm.showWeekNumber
- ? _c("th", [_vm._v(_vm._s(_vm.t("el.datepicker.week")))])
- : _vm._e(),
- _vm._l(_vm.WEEKS, function(week, key) {
- return _c("th", { key: key }, [
- _vm._v(_vm._s(_vm.t("el.datepicker.weeks." + week)))
- ])
- })
- ],
- 2
- ),
- _vm._l(_vm.rows, function(row, key) {
- return _c(
- "tr",
- {
- key: key,
- staticClass: "el-date-table__row",
- class: { current: _vm.isWeekActive(row[1]) }
- },
- _vm._l(row, function(cell, key) {
- return _c("td", { key: key, class: _vm.getCellClasses(cell) }, [
- _c("div", [
- _c("span", [
- _vm._v("\n " + _vm._s(cell.text) + "\n ")
- ])
- ])
- ])
- }),
- 0
- )
- })
- ],
- 2
- )
- ]
- )
- }
- var date_tablevue_type_template_id_5d1f3341_staticRenderFns = []
- date_tablevue_type_template_id_5d1f3341_render._withStripped = true
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/date-table.vue?vue&type=template&id=5d1f3341&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/date-table.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var _WEEKS = ['sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat'];
- var date_tablevue_type_script_lang_js_getDateTimestamp = function getDateTimestamp(time) {
- if (typeof time === 'number' || typeof time === 'string') {
- return Object(date_util_["clearTime"])(new Date(time)).getTime();
- } else if (time instanceof Date) {
- return Object(date_util_["clearTime"])(time).getTime();
- } else {
- return NaN;
- }
- };
- // remove the first element that satisfies `pred` from arr
- // return a new array if modification occurs
- // return the original array otherwise
- var date_tablevue_type_script_lang_js_removeFromArray = function removeFromArray(arr, pred) {
- var idx = typeof pred === 'function' ? Object(util_["arrayFindIndex"])(arr, pred) : arr.indexOf(pred);
- return idx >= 0 ? [].concat(arr.slice(0, idx), arr.slice(idx + 1)) : arr;
- };
- /* harmony default export */ var date_tablevue_type_script_lang_js_ = ({
- mixins: [locale_default.a],
- props: {
- firstDayOfWeek: {
- default: 7,
- type: Number,
- validator: function validator(val) {
- return val >= 1 && val <= 7;
- }
- },
- value: {},
- defaultValue: {
- validator: function validator(val) {
- // either: null, valid Date object, Array of valid Date objects
- return val === null || Object(date_util_["isDate"])(val) || Array.isArray(val) && val.every(date_util_["isDate"]);
- }
- },
- date: {},
- selectionMode: {
- default: 'day'
- },
- showWeekNumber: {
- type: Boolean,
- default: false
- },
- disabledDate: {},
- cellClassName: {},
- minDate: {},
- maxDate: {},
- rangeState: {
- default: function _default() {
- return {
- endDate: null,
- selecting: false
- };
- }
- }
- },
- computed: {
- offsetDay: function offsetDay() {
- var week = this.firstDayOfWeek;
- // 周日为界限,左右偏移的天数,3217654 例如周一就是 -1,目的是调整前两行日期的位置
- return week > 3 ? 7 - week : -week;
- },
- WEEKS: function WEEKS() {
- var week = this.firstDayOfWeek;
- return _WEEKS.concat(_WEEKS).slice(week, week + 7);
- },
- year: function year() {
- return this.date.getFullYear();
- },
- month: function month() {
- return this.date.getMonth();
- },
- startDate: function startDate() {
- return Object(date_util_["getStartDateOfMonth"])(this.year, this.month);
- },
- rows: function rows() {
- var _this = this;
- // TODO: refactory rows / getCellClasses
- var date = new Date(this.year, this.month, 1);
- var day = Object(date_util_["getFirstDayOfMonth"])(date); // day of first day
- var dateCountOfMonth = Object(date_util_["getDayCountOfMonth"])(date.getFullYear(), date.getMonth());
- var dateCountOfLastMonth = Object(date_util_["getDayCountOfMonth"])(date.getFullYear(), date.getMonth() === 0 ? 11 : date.getMonth() - 1);
- day = day === 0 ? 7 : day;
- var offset = this.offsetDay;
- var rows = this.tableRows;
- var count = 1;
- var startDate = this.startDate;
- var disabledDate = this.disabledDate;
- var cellClassName = this.cellClassName;
- var selectedDate = this.selectionMode === 'dates' ? Object(util_["coerceTruthyValueToArray"])(this.value) : [];
- var now = date_tablevue_type_script_lang_js_getDateTimestamp(new Date());
- for (var i = 0; i < 6; i++) {
- var row = rows[i];
- if (this.showWeekNumber) {
- if (!row[0]) {
- row[0] = { type: 'week', text: Object(date_util_["getWeekNumber"])(Object(date_util_["nextDate"])(startDate, i * 7 + 1)) };
- }
- }
- var _loop = function _loop(j) {
- var cell = row[_this.showWeekNumber ? j + 1 : j];
- if (!cell) {
- cell = { row: i, column: j, type: 'normal', inRange: false, start: false, end: false };
- }
- cell.type = 'normal';
- var index = i * 7 + j;
- var time = Object(date_util_["nextDate"])(startDate, index - offset).getTime();
- cell.inRange = time >= date_tablevue_type_script_lang_js_getDateTimestamp(_this.minDate) && time <= date_tablevue_type_script_lang_js_getDateTimestamp(_this.maxDate);
- cell.start = _this.minDate && time === date_tablevue_type_script_lang_js_getDateTimestamp(_this.minDate);
- cell.end = _this.maxDate && time === date_tablevue_type_script_lang_js_getDateTimestamp(_this.maxDate);
- var isToday = time === now;
- if (isToday) {
- cell.type = 'today';
- }
- if (i >= 0 && i <= 1) {
- var numberOfDaysFromPreviousMonth = day + offset < 0 ? 7 + day + offset : day + offset;
- if (j + i * 7 >= numberOfDaysFromPreviousMonth) {
- cell.text = count++;
- } else {
- cell.text = dateCountOfLastMonth - (numberOfDaysFromPreviousMonth - j % 7) + 1 + i * 7;
- cell.type = 'prev-month';
- }
- } else {
- if (count <= dateCountOfMonth) {
- cell.text = count++;
- } else {
- cell.text = count++ - dateCountOfMonth;
- cell.type = 'next-month';
- }
- }
- var cellDate = new Date(time);
- cell.disabled = typeof disabledDate === 'function' && disabledDate(cellDate);
- cell.selected = Object(util_["arrayFind"])(selectedDate, function (date) {
- return date.getTime() === cellDate.getTime();
- });
- cell.customClass = typeof cellClassName === 'function' && cellClassName(cellDate);
- _this.$set(row, _this.showWeekNumber ? j + 1 : j, cell);
- };
- for (var j = 0; j < 7; j++) {
- _loop(j);
- }
- if (this.selectionMode === 'week') {
- var start = this.showWeekNumber ? 1 : 0;
- var end = this.showWeekNumber ? 7 : 6;
- var isWeekActive = this.isWeekActive(row[start + 1]);
- row[start].inRange = isWeekActive;
- row[start].start = isWeekActive;
- row[end].inRange = isWeekActive;
- row[end].end = isWeekActive;
- }
- }
- return rows;
- }
- },
- watch: {
- 'rangeState.endDate': function rangeStateEndDate(newVal) {
- this.markRange(this.minDate, newVal);
- },
- minDate: function minDate(newVal, oldVal) {
- if (date_tablevue_type_script_lang_js_getDateTimestamp(newVal) !== date_tablevue_type_script_lang_js_getDateTimestamp(oldVal)) {
- this.markRange(this.minDate, this.maxDate);
- }
- },
- maxDate: function maxDate(newVal, oldVal) {
- if (date_tablevue_type_script_lang_js_getDateTimestamp(newVal) !== date_tablevue_type_script_lang_js_getDateTimestamp(oldVal)) {
- this.markRange(this.minDate, this.maxDate);
- }
- }
- },
- data: function data() {
- return {
- tableRows: [[], [], [], [], [], []],
- lastRow: null,
- lastColumn: null
- };
- },
- methods: {
- cellMatchesDate: function cellMatchesDate(cell, date) {
- var value = new Date(date);
- return this.year === value.getFullYear() && this.month === value.getMonth() && Number(cell.text) === value.getDate();
- },
- getCellClasses: function getCellClasses(cell) {
- var _this2 = this;
- var selectionMode = this.selectionMode;
- var defaultValue = this.defaultValue ? Array.isArray(this.defaultValue) ? this.defaultValue : [this.defaultValue] : [];
- var classes = [];
- if ((cell.type === 'normal' || cell.type === 'today') && !cell.disabled) {
- classes.push('available');
- if (cell.type === 'today') {
- classes.push('today');
- }
- } else {
- classes.push(cell.type);
- }
- if (cell.type === 'normal' && defaultValue.some(function (date) {
- return _this2.cellMatchesDate(cell, date);
- })) {
- classes.push('default');
- }
- if (selectionMode === 'day' && (cell.type === 'normal' || cell.type === 'today') && this.cellMatchesDate(cell, this.value)) {
- classes.push('current');
- }
- if (cell.inRange && (cell.type === 'normal' || cell.type === 'today' || this.selectionMode === 'week')) {
- classes.push('in-range');
- if (cell.start) {
- classes.push('start-date');
- }
- if (cell.end) {
- classes.push('end-date');
- }
- }
- if (cell.disabled) {
- classes.push('disabled');
- }
- if (cell.selected) {
- classes.push('selected');
- }
- if (cell.customClass) {
- classes.push(cell.customClass);
- }
- return classes.join(' ');
- },
- getDateOfCell: function getDateOfCell(row, column) {
- var offsetFromStart = row * 7 + (column - (this.showWeekNumber ? 1 : 0)) - this.offsetDay;
- return Object(date_util_["nextDate"])(this.startDate, offsetFromStart);
- },
- isWeekActive: function isWeekActive(cell) {
- if (this.selectionMode !== 'week') return false;
- var newDate = new Date(this.year, this.month, 1);
- var year = newDate.getFullYear();
- var month = newDate.getMonth();
- if (cell.type === 'prev-month') {
- newDate.setMonth(month === 0 ? 11 : month - 1);
- newDate.setFullYear(month === 0 ? year - 1 : year);
- }
- if (cell.type === 'next-month') {
- newDate.setMonth(month === 11 ? 0 : month + 1);
- newDate.setFullYear(month === 11 ? year + 1 : year);
- }
- newDate.setDate(parseInt(cell.text, 10));
- if (Object(date_util_["isDate"])(this.value)) {
- var dayOffset = (this.value.getDay() - this.firstDayOfWeek + 7) % 7 - 1;
- var weekDate = Object(date_util_["prevDate"])(this.value, dayOffset);
- return weekDate.getTime() === newDate.getTime();
- }
- return false;
- },
- markRange: function markRange(minDate, maxDate) {
- minDate = date_tablevue_type_script_lang_js_getDateTimestamp(minDate);
- maxDate = date_tablevue_type_script_lang_js_getDateTimestamp(maxDate) || minDate;
- var _ref = [Math.min(minDate, maxDate), Math.max(minDate, maxDate)];
- minDate = _ref[0];
- maxDate = _ref[1];
- var startDate = this.startDate;
- var rows = this.rows;
- for (var i = 0, k = rows.length; i < k; i++) {
- var row = rows[i];
- for (var j = 0, l = row.length; j < l; j++) {
- if (this.showWeekNumber && j === 0) continue;
- var _cell = row[j];
- var index = i * 7 + j + (this.showWeekNumber ? -1 : 0);
- var time = Object(date_util_["nextDate"])(startDate, index - this.offsetDay).getTime();
- _cell.inRange = minDate && time >= minDate && time <= maxDate;
- _cell.start = minDate && time === minDate;
- _cell.end = maxDate && time === maxDate;
- }
- }
- },
- handleMouseMove: function handleMouseMove(event) {
- if (!this.rangeState.selecting) return;
- var target = event.target;
- if (target.tagName === 'SPAN') {
- target = target.parentNode.parentNode;
- }
- if (target.tagName === 'DIV') {
- target = target.parentNode;
- }
- if (target.tagName !== 'TD') return;
- var row = target.parentNode.rowIndex - 1;
- var column = target.cellIndex;
- // can not select disabled date
- if (this.rows[row][column].disabled) return;
- // only update rangeState when mouse moves to a new cell
- // this avoids frequent Date object creation and improves performance
- if (row !== this.lastRow || column !== this.lastColumn) {
- this.lastRow = row;
- this.lastColumn = column;
- this.$emit('changerange', {
- minDate: this.minDate,
- maxDate: this.maxDate,
- rangeState: {
- selecting: true,
- endDate: this.getDateOfCell(row, column)
- }
- });
- }
- },
- handleClick: function handleClick(event) {
- var target = event.target;
- if (target.tagName === 'SPAN') {
- target = target.parentNode.parentNode;
- }
- if (target.tagName === 'DIV') {
- target = target.parentNode;
- }
- if (target.tagName !== 'TD') return;
- var row = target.parentNode.rowIndex - 1;
- var column = this.selectionMode === 'week' ? 1 : target.cellIndex;
- var cell = this.rows[row][column];
- if (cell.disabled || cell.type === 'week') return;
- var newDate = this.getDateOfCell(row, column);
- if (this.selectionMode === 'range') {
- if (!this.rangeState.selecting) {
- this.$emit('pick', { minDate: newDate, maxDate: null });
- this.rangeState.selecting = true;
- } else {
- if (newDate >= this.minDate) {
- this.$emit('pick', { minDate: this.minDate, maxDate: newDate });
- } else {
- this.$emit('pick', { minDate: newDate, maxDate: this.minDate });
- }
- this.rangeState.selecting = false;
- }
- } else if (this.selectionMode === 'day') {
- this.$emit('pick', newDate);
- } else if (this.selectionMode === 'week') {
- var weekNumber = Object(date_util_["getWeekNumber"])(newDate);
- var value = newDate.getFullYear() + 'w' + weekNumber;
- this.$emit('pick', {
- year: newDate.getFullYear(),
- week: weekNumber,
- value: value,
- date: newDate
- });
- } else if (this.selectionMode === 'dates') {
- var _value = this.value || [];
- var newValue = cell.selected ? date_tablevue_type_script_lang_js_removeFromArray(_value, function (date) {
- return date.getTime() === newDate.getTime();
- }) : [].concat(_value, [newDate]);
- this.$emit('pick', newValue);
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/date-table.vue?vue&type=script&lang=js&
- /* harmony default export */ var basic_date_tablevue_type_script_lang_js_ = (date_tablevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/date-picker/src/basic/date-table.vue
- /* normalize component */
- var date_table_component = normalizeComponent(
- basic_date_tablevue_type_script_lang_js_,
- date_tablevue_type_template_id_5d1f3341_render,
- date_tablevue_type_template_id_5d1f3341_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var date_table_api; }
- date_table_component.options.__file = "packages/date-picker/src/basic/date-table.vue"
- /* harmony default export */ var date_table = (date_table_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var datevue_type_script_lang_js_ = ({
- mixins: [locale_default.a],
- directives: { Clickoutside: clickoutside_default.a },
- watch: {
- showTime: function showTime(val) {
- var _this = this;
- /* istanbul ignore if */
- if (!val) return;
- this.$nextTick(function (_) {
- var inputElm = _this.$refs.input.$el;
- if (inputElm) {
- _this.pickerWidth = inputElm.getBoundingClientRect().width + 10;
- }
- });
- },
- value: function value(val) {
- if (this.selectionMode === 'dates' && this.value) return;
- if (this.selectionMode === 'months' && this.value) return;
- if (this.selectionMode === 'years' && this.value) return;
- if (Object(date_util_["isDate"])(val)) {
- this.date = new Date(val);
- } else {
- this.date = this.getDefaultValue();
- }
- },
- defaultValue: function defaultValue(val) {
- if (!Object(date_util_["isDate"])(this.value)) {
- this.date = val ? new Date(val) : new Date();
- }
- },
- timePickerVisible: function timePickerVisible(val) {
- var _this2 = this;
- if (val) this.$nextTick(function () {
- return _this2.$refs.timepicker.adjustSpinners();
- });
- },
- selectionMode: function selectionMode(newVal) {
- if (newVal === 'month') {
- /* istanbul ignore next */
- if (this.currentView !== 'year' || this.currentView !== 'month') {
- this.currentView = 'month';
- }
- } else if (newVal === 'dates') {
- this.currentView = 'date';
- } else if (newVal === 'years') {
- this.currentView = 'year';
- } else if (newVal === 'months') {
- this.currentView = 'month';
- }
- }
- },
- methods: {
- proxyTimePickerDataProperties: function proxyTimePickerDataProperties() {
- var _this3 = this;
- var format = function format(timeFormat) {
- _this3.$refs.timepicker.format = timeFormat;
- };
- var value = function value(_value) {
- _this3.$refs.timepicker.value = _value;
- };
- var date = function date(_date) {
- _this3.$refs.timepicker.date = _date;
- };
- var selectableRange = function selectableRange(_selectableRange) {
- _this3.$refs.timepicker.selectableRange = _selectableRange;
- };
- this.$watch('value', value);
- this.$watch('date', date);
- this.$watch('selectableRange', selectableRange);
- format(this.timeFormat);
- value(this.value);
- date(this.date);
- selectableRange(this.selectableRange);
- },
- handleClear: function handleClear() {
- this.date = this.getDefaultValue();
- this.$emit('pick', null);
- },
- emit: function emit(value) {
- var _this4 = this;
- for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
- args[_key - 1] = arguments[_key];
- }
- if (!value) {
- this.$emit.apply(this, ['pick', value].concat(args));
- } else if (Array.isArray(value)) {
- var dates = value.map(function (date) {
- return _this4.showTime ? Object(date_util_["clearMilliseconds"])(date) : Object(date_util_["clearTime"])(date);
- });
- this.$emit.apply(this, ['pick', dates].concat(args));
- } else {
- this.$emit.apply(this, ['pick', this.showTime ? Object(date_util_["clearMilliseconds"])(value) : Object(date_util_["clearTime"])(value)].concat(args));
- }
- this.userInputDate = null;
- this.userInputTime = null;
- },
- // resetDate() {
- // this.date = new Date(this.date);
- // },
- showMonthPicker: function showMonthPicker() {
- this.currentView = 'month';
- },
- showYearPicker: function showYearPicker() {
- this.currentView = 'year';
- },
- // XXX: 没用到
- // handleLabelClick() {
- // if (this.currentView === 'date') {
- // this.showMonthPicker();
- // } else if (this.currentView === 'month') {
- // this.showYearPicker();
- // }
- // },
- prevMonth: function prevMonth() {
- this.date = Object(date_util_["prevMonth"])(this.date);
- },
- nextMonth: function nextMonth() {
- this.date = Object(date_util_["nextMonth"])(this.date);
- },
- prevYear: function prevYear() {
- if (this.currentView === 'year') {
- this.date = Object(date_util_["prevYear"])(this.date, 10);
- } else {
- this.date = Object(date_util_["prevYear"])(this.date);
- }
- },
- nextYear: function nextYear() {
- if (this.currentView === 'year') {
- this.date = Object(date_util_["nextYear"])(this.date, 10);
- } else {
- this.date = Object(date_util_["nextYear"])(this.date);
- }
- },
- handleShortcutClick: function handleShortcutClick(shortcut) {
- if (shortcut.onClick) {
- shortcut.onClick(this);
- }
- },
- handleTimePick: function handleTimePick(value, visible, first) {
- if (Object(date_util_["isDate"])(value)) {
- var newDate = this.value ? Object(date_util_["modifyTime"])(this.value, value.getHours(), value.getMinutes(), value.getSeconds()) : Object(date_util_["modifyWithTimeString"])(this.getDefaultValue(), this.defaultTime);
- this.date = newDate;
- this.emit(this.date, true);
- } else {
- this.emit(value, true);
- }
- if (!first) {
- this.timePickerVisible = visible;
- }
- },
- handleTimePickClose: function handleTimePickClose() {
- this.timePickerVisible = false;
- },
- handleMonthPick: function handleMonthPick(month) {
- if (this.selectionMode === 'month') {
- this.date = Object(date_util_["modifyDate"])(this.date, this.year, month, 1);
- this.emit(this.date);
- } else if (this.selectionMode === 'months') {
- this.emit(month, true);
- } else {
- this.date = Object(date_util_["changeYearMonthAndClampDate"])(this.date, this.year, month);
- // TODO: should emit intermediate value ??
- // this.emit(this.date);
- this.currentView = 'date';
- }
- },
- handleDatePick: function handleDatePick(value) {
- if (this.selectionMode === 'day') {
- var newDate = this.value ? Object(date_util_["modifyDate"])(this.value, value.getFullYear(), value.getMonth(), value.getDate()) : Object(date_util_["modifyWithTimeString"])(value, this.defaultTime);
- // change default time while out of selectableRange
- if (!this.checkDateWithinRange(newDate)) {
- newDate = Object(date_util_["modifyDate"])(this.selectableRange[0][0], value.getFullYear(), value.getMonth(), value.getDate());
- }
- this.date = newDate;
- this.emit(this.date, this.showTime);
- } else if (this.selectionMode === 'week') {
- this.emit(value.date);
- } else if (this.selectionMode === 'dates') {
- this.emit(value, true); // set false to keep panel open
- }
- },
- handleYearPick: function handleYearPick(year) {
- if (this.selectionMode === 'year') {
- this.date = Object(date_util_["modifyDate"])(this.date, year, 0, 1);
- this.emit(this.date);
- } else if (this.selectionMode === 'years') {
- this.emit(year, true);
- } else {
- this.date = Object(date_util_["changeYearMonthAndClampDate"])(this.date, year, this.month);
- // TODO: should emit intermediate value ??
- // this.emit(this.date, true);
- this.currentView = 'month';
- }
- },
- changeToNow: function changeToNow() {
- // NOTE: not a permanent solution
- // consider disable "now" button in the future
- if ((!this.disabledDate || !this.disabledDate(new Date())) && this.checkDateWithinRange(new Date())) {
- this.date = new Date();
- this.emit(this.date);
- }
- },
- confirm: function confirm() {
- if (this.selectionMode === 'dates' || this.selectionMode === 'months' || this.selectionMode === 'years') {
- this.emit(this.value);
- } else {
- // value were emitted in handle{Date,Time}Pick, nothing to update here
- // deal with the scenario where: user opens the picker, then confirm without doing anything
- var value = this.value ? this.value : Object(date_util_["modifyWithTimeString"])(this.getDefaultValue(), this.defaultTime);
- this.date = new Date(value); // refresh date
- this.emit(value);
- }
- },
- resetView: function resetView() {
- if (this.selectionMode === 'month' || this.selectionMode === 'months') {
- this.currentView = 'month';
- } else if (this.selectionMode === 'year' || this.selectionMode === 'years') {
- this.currentView = 'year';
- } else {
- this.currentView = 'date';
- }
- },
- handleEnter: function handleEnter() {
- document.body.addEventListener('keydown', this.handleKeydown);
- },
- handleLeave: function handleLeave() {
- this.$emit('dodestroy');
- document.body.removeEventListener('keydown', this.handleKeydown);
- },
- handleKeydown: function handleKeydown(event) {
- var keyCode = event.keyCode;
- var list = [38, 40, 37, 39];
- if (this.visible && !this.timePickerVisible) {
- if (list.indexOf(keyCode) !== -1) {
- this.handleKeyControl(keyCode);
- event.stopPropagation();
- event.preventDefault();
- }
- if (keyCode === 13 && this.userInputDate === null && this.userInputTime === null) {
- // Enter
- this.emit(this.date, false);
- }
- }
- },
- handleKeyControl: function handleKeyControl(keyCode) {
- var mapping = {
- 'year': {
- 38: -4, 40: 4, 37: -1, 39: 1, offset: function offset(date, step) {
- return date.setFullYear(date.getFullYear() + step);
- }
- },
- 'month': {
- 38: -4, 40: 4, 37: -1, 39: 1, offset: function offset(date, step) {
- return date.setMonth(date.getMonth() + step);
- }
- },
- 'week': {
- 38: -1, 40: 1, 37: -1, 39: 1, offset: function offset(date, step) {
- return date.setDate(date.getDate() + step * 7);
- }
- },
- 'day': {
- 38: -7, 40: 7, 37: -1, 39: 1, offset: function offset(date, step) {
- return date.setDate(date.getDate() + step);
- }
- }
- };
- var mode = this.selectionMode;
- var year = 3.1536e10;
- var now = this.date.getTime();
- var newDate = new Date(this.date.getTime());
- while (Math.abs(now - newDate.getTime()) <= year) {
- var map = mapping[mode];
- map.offset(newDate, map[keyCode]);
- if (typeof this.disabledDate === 'function' && this.disabledDate(newDate)) {
- continue;
- }
- this.date = newDate;
- this.$emit('pick', newDate, true);
- break;
- }
- },
- handleVisibleTimeChange: function handleVisibleTimeChange(value) {
- var time = Object(date_util_["parseDate"])(value, this.timeFormat);
- if (time && this.checkDateWithinRange(time)) {
- this.date = Object(date_util_["modifyDate"])(time, this.year, this.month, this.monthDate);
- this.userInputTime = null;
- this.$refs.timepicker.value = this.date;
- this.timePickerVisible = false;
- this.emit(this.date, true);
- }
- },
- handleVisibleDateChange: function handleVisibleDateChange(value) {
- var date = Object(date_util_["parseDate"])(value, this.dateFormat);
- if (date) {
- if (typeof this.disabledDate === 'function' && this.disabledDate(date)) {
- return;
- }
- this.date = Object(date_util_["modifyTime"])(date, this.date.getHours(), this.date.getMinutes(), this.date.getSeconds());
- this.userInputDate = null;
- this.resetView();
- this.emit(this.date, true);
- }
- },
- isValidValue: function isValidValue(value) {
- return value && !isNaN(value) && (typeof this.disabledDate === 'function' ? !this.disabledDate(value) : true) && this.checkDateWithinRange(value);
- },
- getDefaultValue: function getDefaultValue() {
- // if default-value is set, return it
- // otherwise, return now (the moment this method gets called)
- return this.defaultValue ? new Date(this.defaultValue) : new Date();
- },
- checkDateWithinRange: function checkDateWithinRange(date) {
- return this.selectableRange.length > 0 ? Object(date_util_["timeWithinRange"])(date, this.selectableRange, this.format || 'HH:mm:ss') : true;
- }
- },
- components: {
- TimePicker: panel_time, YearTable: year_table, MonthTable: month_table, DateTable: date_table, ElInput: input_default.a, ElButton: button_default.a
- },
- data: function data() {
- return {
- popperClass: '',
- date: new Date(),
- value: '',
- defaultValue: null, // use getDefaultValue() for time computation
- defaultTime: null,
- showTime: false,
- selectionMode: 'day',
- shortcuts: '',
- visible: false,
- currentView: 'date',
- disabledDate: '',
- cellClassName: '',
- selectableRange: [],
- firstDayOfWeek: 7,
- showWeekNumber: false,
- timePickerVisible: false,
- format: '',
- arrowControl: false,
- userInputDate: null,
- userInputTime: null
- };
- },
- computed: {
- year: function year() {
- return this.date.getFullYear();
- },
- month: function month() {
- return this.date.getMonth();
- },
- week: function week() {
- return Object(date_util_["getWeekNumber"])(this.date);
- },
- monthDate: function monthDate() {
- return this.date.getDate();
- },
- footerVisible: function footerVisible() {
- return this.showTime || this.selectionMode === 'dates' || this.selectionMode === 'months' || this.selectionMode === 'years';
- },
- visibleTime: function visibleTime() {
- if (this.userInputTime !== null) {
- return this.userInputTime;
- } else {
- return Object(date_util_["formatDate"])(this.value || this.defaultValue, this.timeFormat);
- }
- },
- visibleDate: function visibleDate() {
- if (this.userInputDate !== null) {
- return this.userInputDate;
- } else {
- return Object(date_util_["formatDate"])(this.value || this.defaultValue, this.dateFormat);
- }
- },
- yearLabel: function yearLabel() {
- var yearTranslation = this.t('el.datepicker.year');
- if (this.currentView === 'year') {
- var startYear = Math.floor(this.year / 10) * 10;
- if (yearTranslation) {
- return startYear + ' ' + yearTranslation + ' - ' + (startYear + 9) + ' ' + yearTranslation;
- }
- return startYear + ' - ' + (startYear + 9);
- }
- return this.year + ' ' + yearTranslation;
- },
- timeFormat: function timeFormat() {
- if (this.format) {
- return Object(date_util_["extractTimeFormat"])(this.format);
- } else {
- return 'HH:mm:ss';
- }
- },
- dateFormat: function dateFormat() {
- if (this.format) {
- return Object(date_util_["extractDateFormat"])(this.format);
- } else {
- return 'yyyy-MM-dd';
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/date.vue?vue&type=script&lang=js&
- /* harmony default export */ var panel_datevue_type_script_lang_js_ = (datevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/date.vue
- /* normalize component */
- var date_component = normalizeComponent(
- panel_datevue_type_script_lang_js_,
- datevue_type_template_id_2440d4ea_render,
- datevue_type_template_id_2440d4ea_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var date_api; }
- date_component.options.__file = "packages/date-picker/src/panel/date.vue"
- /* harmony default export */ var panel_date = (date_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date-range.vue?vue&type=template&id=2652849a&
- var date_rangevue_type_template_id_2652849a_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- {
- attrs: { name: "el-zoom-in-top" },
- on: {
- "after-leave": function($event) {
- _vm.$emit("dodestroy")
- }
- }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-picker-panel el-date-range-picker el-popper",
- class: [
- {
- "has-sidebar": _vm.$slots.sidebar || _vm.shortcuts,
- "has-time": _vm.showTime
- },
- _vm.popperClass
- ]
- },
- [
- _c(
- "div",
- { staticClass: "el-picker-panel__body-wrapper" },
- [
- _vm._t("sidebar"),
- _vm.shortcuts
- ? _c(
- "div",
- { staticClass: "el-picker-panel__sidebar" },
- _vm._l(_vm.shortcuts, function(shortcut, key) {
- return _c(
- "button",
- {
- key: key,
- staticClass: "el-picker-panel__shortcut",
- attrs: { type: "button" },
- on: {
- click: function($event) {
- _vm.handleShortcutClick(shortcut)
- }
- }
- },
- [_vm._v(_vm._s(shortcut.text))]
- )
- }),
- 0
- )
- : _vm._e(),
- _c("div", { staticClass: "el-picker-panel__body" }, [
- _vm.showTime
- ? _c(
- "div",
- { staticClass: "el-date-range-picker__time-header" },
- [
- _c(
- "span",
- { staticClass: "el-date-range-picker__editors-wrap" },
- [
- _c(
- "span",
- {
- staticClass:
- "el-date-range-picker__time-picker-wrap"
- },
- [
- _c("el-input", {
- ref: "minInput",
- staticClass: "el-date-range-picker__editor",
- attrs: {
- size: "small",
- disabled: _vm.rangeState.selecting,
- placeholder: _vm.t(
- "el.datepicker.startDate"
- ),
- value: _vm.minVisibleDate
- },
- on: {
- input: function(val) {
- return _vm.handleDateInput(val, "min")
- },
- change: function(val) {
- return _vm.handleDateChange(val, "min")
- }
- }
- })
- ],
- 1
- ),
- _c(
- "span",
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: _vm.handleMinTimeClose,
- expression: "handleMinTimeClose"
- }
- ],
- staticClass:
- "el-date-range-picker__time-picker-wrap"
- },
- [
- _c("el-input", {
- staticClass: "el-date-range-picker__editor",
- attrs: {
- size: "small",
- disabled: _vm.rangeState.selecting,
- placeholder: _vm.t(
- "el.datepicker.startTime"
- ),
- value: _vm.minVisibleTime
- },
- on: {
- focus: function($event) {
- _vm.minTimePickerVisible = true
- },
- input: function(val) {
- return _vm.handleTimeInput(val, "min")
- },
- change: function(val) {
- return _vm.handleTimeChange(val, "min")
- }
- }
- }),
- _c("time-picker", {
- ref: "minTimePicker",
- attrs: {
- "time-arrow-control": _vm.arrowControl,
- visible: _vm.minTimePickerVisible
- },
- on: {
- pick: _vm.handleMinTimePick,
- mounted: function($event) {
- _vm.$refs.minTimePicker.format =
- _vm.timeFormat
- }
- }
- })
- ],
- 1
- )
- ]
- ),
- _c("span", { staticClass: "el-icon-arrow-right" }),
- _c(
- "span",
- {
- staticClass:
- "el-date-range-picker__editors-wrap is-right"
- },
- [
- _c(
- "span",
- {
- staticClass:
- "el-date-range-picker__time-picker-wrap"
- },
- [
- _c("el-input", {
- staticClass: "el-date-range-picker__editor",
- attrs: {
- size: "small",
- disabled: _vm.rangeState.selecting,
- placeholder: _vm.t("el.datepicker.endDate"),
- value: _vm.maxVisibleDate,
- readonly: !_vm.minDate
- },
- on: {
- input: function(val) {
- return _vm.handleDateInput(val, "max")
- },
- change: function(val) {
- return _vm.handleDateChange(val, "max")
- }
- }
- })
- ],
- 1
- ),
- _c(
- "span",
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: _vm.handleMaxTimeClose,
- expression: "handleMaxTimeClose"
- }
- ],
- staticClass:
- "el-date-range-picker__time-picker-wrap"
- },
- [
- _c("el-input", {
- staticClass: "el-date-range-picker__editor",
- attrs: {
- size: "small",
- disabled: _vm.rangeState.selecting,
- placeholder: _vm.t("el.datepicker.endTime"),
- value: _vm.maxVisibleTime,
- readonly: !_vm.minDate
- },
- on: {
- focus: function($event) {
- _vm.minDate &&
- (_vm.maxTimePickerVisible = true)
- },
- input: function(val) {
- return _vm.handleTimeInput(val, "max")
- },
- change: function(val) {
- return _vm.handleTimeChange(val, "max")
- }
- }
- }),
- _c("time-picker", {
- ref: "maxTimePicker",
- attrs: {
- "time-arrow-control": _vm.arrowControl,
- visible: _vm.maxTimePickerVisible
- },
- on: {
- pick: _vm.handleMaxTimePick,
- mounted: function($event) {
- _vm.$refs.maxTimePicker.format =
- _vm.timeFormat
- }
- }
- })
- ],
- 1
- )
- ]
- )
- ]
- )
- : _vm._e(),
- _c(
- "div",
- {
- staticClass:
- "el-picker-panel__content el-date-range-picker__content is-left"
- },
- [
- _c("div", { staticClass: "el-date-range-picker__header" }, [
- _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-d-arrow-left",
- attrs: { type: "button" },
- on: { click: _vm.leftPrevYear }
- }),
- _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-arrow-left",
- attrs: { type: "button" },
- on: { click: _vm.leftPrevMonth }
- }),
- _vm.unlinkPanels
- ? _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-d-arrow-right",
- class: { "is-disabled": !_vm.enableYearArrow },
- attrs: {
- type: "button",
- disabled: !_vm.enableYearArrow
- },
- on: { click: _vm.leftNextYear }
- })
- : _vm._e(),
- _vm.unlinkPanels
- ? _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-arrow-right",
- class: { "is-disabled": !_vm.enableMonthArrow },
- attrs: {
- type: "button",
- disabled: !_vm.enableMonthArrow
- },
- on: { click: _vm.leftNextMonth }
- })
- : _vm._e(),
- _c("div", [_vm._v(_vm._s(_vm.leftLabel))])
- ]),
- _c("date-table", {
- attrs: {
- "selection-mode": "range",
- date: _vm.leftDate,
- "default-value": _vm.defaultValue,
- "min-date": _vm.minDate,
- "max-date": _vm.maxDate,
- "range-state": _vm.rangeState,
- "disabled-date": _vm.disabledDate,
- "cell-class-name": _vm.cellClassName,
- "first-day-of-week": _vm.firstDayOfWeek
- },
- on: {
- changerange: _vm.handleChangeRange,
- pick: _vm.handleRangePick
- }
- })
- ],
- 1
- ),
- _c(
- "div",
- {
- staticClass:
- "el-picker-panel__content el-date-range-picker__content is-right"
- },
- [
- _c("div", { staticClass: "el-date-range-picker__header" }, [
- _vm.unlinkPanels
- ? _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-d-arrow-left",
- class: { "is-disabled": !_vm.enableYearArrow },
- attrs: {
- type: "button",
- disabled: !_vm.enableYearArrow
- },
- on: { click: _vm.rightPrevYear }
- })
- : _vm._e(),
- _vm.unlinkPanels
- ? _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-arrow-left",
- class: { "is-disabled": !_vm.enableMonthArrow },
- attrs: {
- type: "button",
- disabled: !_vm.enableMonthArrow
- },
- on: { click: _vm.rightPrevMonth }
- })
- : _vm._e(),
- _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-d-arrow-right",
- attrs: { type: "button" },
- on: { click: _vm.rightNextYear }
- }),
- _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-arrow-right",
- attrs: { type: "button" },
- on: { click: _vm.rightNextMonth }
- }),
- _c("div", [_vm._v(_vm._s(_vm.rightLabel))])
- ]),
- _c("date-table", {
- attrs: {
- "selection-mode": "range",
- date: _vm.rightDate,
- "default-value": _vm.defaultValue,
- "min-date": _vm.minDate,
- "max-date": _vm.maxDate,
- "range-state": _vm.rangeState,
- "disabled-date": _vm.disabledDate,
- "cell-class-name": _vm.cellClassName,
- "first-day-of-week": _vm.firstDayOfWeek
- },
- on: {
- changerange: _vm.handleChangeRange,
- pick: _vm.handleRangePick
- }
- })
- ],
- 1
- )
- ])
- ],
- 2
- ),
- _vm.showTime
- ? _c(
- "div",
- { staticClass: "el-picker-panel__footer" },
- [
- _c(
- "el-button",
- {
- staticClass: "el-picker-panel__link-btn",
- attrs: { size: "mini", type: "text" },
- on: { click: _vm.handleClear }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.t("el.datepicker.clear")) +
- "\n "
- )
- ]
- ),
- _c(
- "el-button",
- {
- staticClass: "el-picker-panel__link-btn",
- attrs: {
- plain: "",
- size: "mini",
- disabled: _vm.btnDisabled
- },
- on: {
- click: function($event) {
- _vm.handleConfirm(false)
- }
- }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.t("el.datepicker.confirm")) +
- "\n "
- )
- ]
- )
- ],
- 1
- )
- : _vm._e()
- ]
- )
- ]
- )
- }
- var date_rangevue_type_template_id_2652849a_staticRenderFns = []
- date_rangevue_type_template_id_2652849a_render._withStripped = true
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/date-range.vue?vue&type=template&id=2652849a&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date-range.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var date_rangevue_type_script_lang_js_calcDefaultValue = function calcDefaultValue(defaultValue) {
- if (Array.isArray(defaultValue)) {
- return [new Date(defaultValue[0]), new Date(defaultValue[1])];
- } else if (defaultValue) {
- return [new Date(defaultValue), Object(date_util_["nextDate"])(new Date(defaultValue), 1)];
- } else {
- return [new Date(), Object(date_util_["nextDate"])(new Date(), 1)];
- }
- };
- /* harmony default export */ var date_rangevue_type_script_lang_js_ = ({
- mixins: [locale_default.a],
- directives: { Clickoutside: clickoutside_default.a },
- computed: {
- btnDisabled: function btnDisabled() {
- return !(this.minDate && this.maxDate && !this.selecting && this.isValidValue([this.minDate, this.maxDate]));
- },
- leftLabel: function leftLabel() {
- return this.leftDate.getFullYear() + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + (this.leftDate.getMonth() + 1));
- },
- rightLabel: function rightLabel() {
- return this.rightDate.getFullYear() + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + (this.rightDate.getMonth() + 1));
- },
- leftYear: function leftYear() {
- return this.leftDate.getFullYear();
- },
- leftMonth: function leftMonth() {
- return this.leftDate.getMonth();
- },
- leftMonthDate: function leftMonthDate() {
- return this.leftDate.getDate();
- },
- rightYear: function rightYear() {
- return this.rightDate.getFullYear();
- },
- rightMonth: function rightMonth() {
- return this.rightDate.getMonth();
- },
- rightMonthDate: function rightMonthDate() {
- return this.rightDate.getDate();
- },
- minVisibleDate: function minVisibleDate() {
- if (this.dateUserInput.min !== null) return this.dateUserInput.min;
- if (this.minDate) return Object(date_util_["formatDate"])(this.minDate, this.dateFormat);
- return '';
- },
- maxVisibleDate: function maxVisibleDate() {
- if (this.dateUserInput.max !== null) return this.dateUserInput.max;
- if (this.maxDate || this.minDate) return Object(date_util_["formatDate"])(this.maxDate || this.minDate, this.dateFormat);
- return '';
- },
- minVisibleTime: function minVisibleTime() {
- if (this.timeUserInput.min !== null) return this.timeUserInput.min;
- if (this.minDate) return Object(date_util_["formatDate"])(this.minDate, this.timeFormat);
- return '';
- },
- maxVisibleTime: function maxVisibleTime() {
- if (this.timeUserInput.max !== null) return this.timeUserInput.max;
- if (this.maxDate || this.minDate) return Object(date_util_["formatDate"])(this.maxDate || this.minDate, this.timeFormat);
- return '';
- },
- timeFormat: function timeFormat() {
- if (this.format) {
- return Object(date_util_["extractTimeFormat"])(this.format);
- } else {
- return 'HH:mm:ss';
- }
- },
- dateFormat: function dateFormat() {
- if (this.format) {
- return Object(date_util_["extractDateFormat"])(this.format);
- } else {
- return 'yyyy-MM-dd';
- }
- },
- enableMonthArrow: function enableMonthArrow() {
- var nextMonth = (this.leftMonth + 1) % 12;
- var yearOffset = this.leftMonth + 1 >= 12 ? 1 : 0;
- return this.unlinkPanels && new Date(this.leftYear + yearOffset, nextMonth) < new Date(this.rightYear, this.rightMonth);
- },
- enableYearArrow: function enableYearArrow() {
- return this.unlinkPanels && this.rightYear * 12 + this.rightMonth - (this.leftYear * 12 + this.leftMonth + 1) >= 12;
- }
- },
- data: function data() {
- return {
- popperClass: '',
- value: [],
- defaultValue: null,
- defaultTime: null,
- minDate: '',
- maxDate: '',
- leftDate: new Date(),
- rightDate: Object(date_util_["nextMonth"])(new Date()),
- rangeState: {
- endDate: null,
- selecting: false,
- row: null,
- column: null
- },
- showTime: false,
- shortcuts: '',
- visible: '',
- disabledDate: '',
- cellClassName: '',
- firstDayOfWeek: 7,
- minTimePickerVisible: false,
- maxTimePickerVisible: false,
- format: '',
- arrowControl: false,
- unlinkPanels: false,
- dateUserInput: {
- min: null,
- max: null
- },
- timeUserInput: {
- min: null,
- max: null
- }
- };
- },
- watch: {
- minDate: function minDate(val) {
- var _this = this;
- this.dateUserInput.min = null;
- this.timeUserInput.min = null;
- this.$nextTick(function () {
- if (_this.$refs.maxTimePicker && _this.maxDate && _this.maxDate < _this.minDate) {
- var format = 'HH:mm:ss';
- _this.$refs.maxTimePicker.selectableRange = [[Object(date_util_["parseDate"])(Object(date_util_["formatDate"])(_this.minDate, format), format), Object(date_util_["parseDate"])('23:59:59', format)]];
- }
- });
- if (val && this.$refs.minTimePicker) {
- this.$refs.minTimePicker.date = val;
- this.$refs.minTimePicker.value = val;
- }
- },
- maxDate: function maxDate(val) {
- this.dateUserInput.max = null;
- this.timeUserInput.max = null;
- if (val && this.$refs.maxTimePicker) {
- this.$refs.maxTimePicker.date = val;
- this.$refs.maxTimePicker.value = val;
- }
- },
- minTimePickerVisible: function minTimePickerVisible(val) {
- var _this2 = this;
- if (val) {
- this.$nextTick(function () {
- _this2.$refs.minTimePicker.date = _this2.minDate;
- _this2.$refs.minTimePicker.value = _this2.minDate;
- _this2.$refs.minTimePicker.adjustSpinners();
- });
- }
- },
- maxTimePickerVisible: function maxTimePickerVisible(val) {
- var _this3 = this;
- if (val) {
- this.$nextTick(function () {
- _this3.$refs.maxTimePicker.date = _this3.maxDate;
- _this3.$refs.maxTimePicker.value = _this3.maxDate;
- _this3.$refs.maxTimePicker.adjustSpinners();
- });
- }
- },
- value: function value(newVal) {
- if (!newVal) {
- this.minDate = null;
- this.maxDate = null;
- } else if (Array.isArray(newVal)) {
- this.minDate = Object(date_util_["isDate"])(newVal[0]) ? new Date(newVal[0]) : null;
- this.maxDate = Object(date_util_["isDate"])(newVal[1]) ? new Date(newVal[1]) : null;
- if (this.minDate) {
- this.leftDate = this.minDate;
- if (this.unlinkPanels && this.maxDate) {
- var minDateYear = this.minDate.getFullYear();
- var minDateMonth = this.minDate.getMonth();
- var maxDateYear = this.maxDate.getFullYear();
- var maxDateMonth = this.maxDate.getMonth();
- this.rightDate = minDateYear === maxDateYear && minDateMonth === maxDateMonth ? Object(date_util_["nextMonth"])(this.maxDate) : this.maxDate;
- } else {
- this.rightDate = Object(date_util_["nextMonth"])(this.leftDate);
- }
- } else {
- this.leftDate = date_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0];
- this.rightDate = Object(date_util_["nextMonth"])(this.leftDate);
- }
- }
- },
- defaultValue: function defaultValue(val) {
- if (!Array.isArray(this.value)) {
- var _calcDefaultValue = date_rangevue_type_script_lang_js_calcDefaultValue(val),
- left = _calcDefaultValue[0],
- right = _calcDefaultValue[1];
- this.leftDate = left;
- this.rightDate = val && val[1] && this.unlinkPanels ? right : Object(date_util_["nextMonth"])(this.leftDate);
- }
- }
- },
- methods: {
- handleClear: function handleClear() {
- this.minDate = null;
- this.maxDate = null;
- this.leftDate = date_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0];
- this.rightDate = Object(date_util_["nextMonth"])(this.leftDate);
- this.$emit('pick', null);
- },
- handleChangeRange: function handleChangeRange(val) {
- this.minDate = val.minDate;
- this.maxDate = val.maxDate;
- this.rangeState = val.rangeState;
- },
- handleDateInput: function handleDateInput(value, type) {
- this.dateUserInput[type] = value;
- if (value.length !== this.dateFormat.length) return;
- var parsedValue = Object(date_util_["parseDate"])(value, this.dateFormat);
- if (parsedValue) {
- if (typeof this.disabledDate === 'function' && this.disabledDate(new Date(parsedValue))) {
- return;
- }
- if (type === 'min') {
- this.minDate = Object(date_util_["modifyDate"])(this.minDate || new Date(), parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate());
- this.leftDate = new Date(parsedValue);
- if (!this.unlinkPanels) {
- this.rightDate = Object(date_util_["nextMonth"])(this.leftDate);
- }
- } else {
- this.maxDate = Object(date_util_["modifyDate"])(this.maxDate || new Date(), parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate());
- this.rightDate = new Date(parsedValue);
- if (!this.unlinkPanels) {
- this.leftDate = Object(date_util_["prevMonth"])(parsedValue);
- }
- }
- }
- },
- handleDateChange: function handleDateChange(value, type) {
- var parsedValue = Object(date_util_["parseDate"])(value, this.dateFormat);
- if (parsedValue) {
- if (type === 'min') {
- this.minDate = Object(date_util_["modifyDate"])(this.minDate, parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate());
- if (this.minDate > this.maxDate) {
- this.maxDate = this.minDate;
- }
- } else {
- this.maxDate = Object(date_util_["modifyDate"])(this.maxDate, parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate());
- if (this.maxDate < this.minDate) {
- this.minDate = this.maxDate;
- }
- }
- }
- },
- handleTimeInput: function handleTimeInput(value, type) {
- var _this4 = this;
- this.timeUserInput[type] = value;
- if (value.length !== this.timeFormat.length) return;
- var parsedValue = Object(date_util_["parseDate"])(value, this.timeFormat);
- if (parsedValue) {
- if (type === 'min') {
- this.minDate = Object(date_util_["modifyTime"])(this.minDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds());
- this.$nextTick(function (_) {
- return _this4.$refs.minTimePicker.adjustSpinners();
- });
- } else {
- this.maxDate = Object(date_util_["modifyTime"])(this.maxDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds());
- this.$nextTick(function (_) {
- return _this4.$refs.maxTimePicker.adjustSpinners();
- });
- }
- }
- },
- handleTimeChange: function handleTimeChange(value, type) {
- var parsedValue = Object(date_util_["parseDate"])(value, this.timeFormat);
- if (parsedValue) {
- if (type === 'min') {
- this.minDate = Object(date_util_["modifyTime"])(this.minDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds());
- if (this.minDate > this.maxDate) {
- this.maxDate = this.minDate;
- }
- this.$refs.minTimePicker.value = this.minDate;
- this.minTimePickerVisible = false;
- } else {
- this.maxDate = Object(date_util_["modifyTime"])(this.maxDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds());
- if (this.maxDate < this.minDate) {
- this.minDate = this.maxDate;
- }
- this.$refs.maxTimePicker.value = this.minDate;
- this.maxTimePickerVisible = false;
- }
- }
- },
- handleRangePick: function handleRangePick(val) {
- var _this5 = this;
- var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
- var defaultTime = this.defaultTime || [];
- var minDate = Object(date_util_["modifyWithTimeString"])(val.minDate, defaultTime[0]);
- var maxDate = Object(date_util_["modifyWithTimeString"])(val.maxDate, defaultTime[1]);
- if (this.maxDate === maxDate && this.minDate === minDate) {
- return;
- }
- this.onPick && this.onPick(val);
- this.maxDate = maxDate;
- this.minDate = minDate;
- // workaround for https://github.com/ElemeFE/element/issues/7539, should remove this block when we don't have to care about Chromium 55 - 57
- setTimeout(function () {
- _this5.maxDate = maxDate;
- _this5.minDate = minDate;
- }, 10);
- if (!close || this.showTime) return;
- this.handleConfirm();
- },
- handleShortcutClick: function handleShortcutClick(shortcut) {
- if (shortcut.onClick) {
- shortcut.onClick(this);
- }
- },
- handleMinTimePick: function handleMinTimePick(value, visible, first) {
- this.minDate = this.minDate || new Date();
- if (value) {
- this.minDate = Object(date_util_["modifyTime"])(this.minDate, value.getHours(), value.getMinutes(), value.getSeconds());
- }
- if (!first) {
- this.minTimePickerVisible = visible;
- }
- if (!this.maxDate || this.maxDate && this.maxDate.getTime() < this.minDate.getTime()) {
- this.maxDate = new Date(this.minDate);
- }
- },
- handleMinTimeClose: function handleMinTimeClose() {
- this.minTimePickerVisible = false;
- },
- handleMaxTimePick: function handleMaxTimePick(value, visible, first) {
- if (this.maxDate && value) {
- this.maxDate = Object(date_util_["modifyTime"])(this.maxDate, value.getHours(), value.getMinutes(), value.getSeconds());
- }
- if (!first) {
- this.maxTimePickerVisible = visible;
- }
- if (this.maxDate && this.minDate && this.minDate.getTime() > this.maxDate.getTime()) {
- this.minDate = new Date(this.maxDate);
- }
- },
- handleMaxTimeClose: function handleMaxTimeClose() {
- this.maxTimePickerVisible = false;
- },
- // leftPrev*, rightNext* need to take care of `unlinkPanels`
- leftPrevYear: function leftPrevYear() {
- this.leftDate = Object(date_util_["prevYear"])(this.leftDate);
- if (!this.unlinkPanels) {
- this.rightDate = Object(date_util_["nextMonth"])(this.leftDate);
- }
- },
- leftPrevMonth: function leftPrevMonth() {
- this.leftDate = Object(date_util_["prevMonth"])(this.leftDate);
- if (!this.unlinkPanels) {
- this.rightDate = Object(date_util_["nextMonth"])(this.leftDate);
- }
- },
- rightNextYear: function rightNextYear() {
- if (!this.unlinkPanels) {
- this.leftDate = Object(date_util_["nextYear"])(this.leftDate);
- this.rightDate = Object(date_util_["nextMonth"])(this.leftDate);
- } else {
- this.rightDate = Object(date_util_["nextYear"])(this.rightDate);
- }
- },
- rightNextMonth: function rightNextMonth() {
- if (!this.unlinkPanels) {
- this.leftDate = Object(date_util_["nextMonth"])(this.leftDate);
- this.rightDate = Object(date_util_["nextMonth"])(this.leftDate);
- } else {
- this.rightDate = Object(date_util_["nextMonth"])(this.rightDate);
- }
- },
- // leftNext*, rightPrev* are called when `unlinkPanels` is true
- leftNextYear: function leftNextYear() {
- this.leftDate = Object(date_util_["nextYear"])(this.leftDate);
- },
- leftNextMonth: function leftNextMonth() {
- this.leftDate = Object(date_util_["nextMonth"])(this.leftDate);
- },
- rightPrevYear: function rightPrevYear() {
- this.rightDate = Object(date_util_["prevYear"])(this.rightDate);
- },
- rightPrevMonth: function rightPrevMonth() {
- this.rightDate = Object(date_util_["prevMonth"])(this.rightDate);
- },
- handleConfirm: function handleConfirm() {
- var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- if (this.isValidValue([this.minDate, this.maxDate])) {
- this.$emit('pick', [this.minDate, this.maxDate], visible);
- }
- },
- isValidValue: function isValidValue(value) {
- return Array.isArray(value) && value && value[0] && value[1] && Object(date_util_["isDate"])(value[0]) && Object(date_util_["isDate"])(value[1]) && value[0].getTime() <= value[1].getTime() && (typeof this.disabledDate === 'function' ? !this.disabledDate(value[0]) && !this.disabledDate(value[1]) : true);
- },
- resetView: function resetView() {
- // NOTE: this is a hack to reset {min, max}Date on picker open.
- // TODO: correct way of doing so is to refactor {min, max}Date to be dependent on value and internal selection state
- // an alternative would be resetView whenever picker becomes visible, should also investigate date-panel's resetView
- if (this.minDate && this.maxDate == null) this.rangeState.selecting = false;
- this.minDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[0]) : null;
- this.maxDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[1]) : null;
- }
- },
- components: { TimePicker: panel_time, DateTable: date_table, ElInput: input_default.a, ElButton: button_default.a }
- });
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/date-range.vue?vue&type=script&lang=js&
- /* harmony default export */ var panel_date_rangevue_type_script_lang_js_ = (date_rangevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/date-range.vue
- /* normalize component */
- var date_range_component = normalizeComponent(
- panel_date_rangevue_type_script_lang_js_,
- date_rangevue_type_template_id_2652849a_render,
- date_rangevue_type_template_id_2652849a_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var date_range_api; }
- date_range_component.options.__file = "packages/date-picker/src/panel/date-range.vue"
- /* harmony default export */ var date_range = (date_range_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/month-range.vue?vue&type=template&id=f2645fb8&
- var month_rangevue_type_template_id_f2645fb8_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- {
- attrs: { name: "el-zoom-in-top" },
- on: {
- "after-leave": function($event) {
- _vm.$emit("dodestroy")
- }
- }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-picker-panel el-date-range-picker el-popper",
- class: [
- {
- "has-sidebar": _vm.$slots.sidebar || _vm.shortcuts
- },
- _vm.popperClass
- ]
- },
- [
- _c(
- "div",
- { staticClass: "el-picker-panel__body-wrapper" },
- [
- _vm._t("sidebar"),
- _vm.shortcuts
- ? _c(
- "div",
- { staticClass: "el-picker-panel__sidebar" },
- _vm._l(_vm.shortcuts, function(shortcut, key) {
- return _c(
- "button",
- {
- key: key,
- staticClass: "el-picker-panel__shortcut",
- attrs: { type: "button" },
- on: {
- click: function($event) {
- _vm.handleShortcutClick(shortcut)
- }
- }
- },
- [_vm._v(_vm._s(shortcut.text))]
- )
- }),
- 0
- )
- : _vm._e(),
- _c("div", { staticClass: "el-picker-panel__body" }, [
- _c(
- "div",
- {
- staticClass:
- "el-picker-panel__content el-date-range-picker__content is-left"
- },
- [
- _c("div", { staticClass: "el-date-range-picker__header" }, [
- _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-d-arrow-left",
- attrs: { type: "button" },
- on: { click: _vm.leftPrevYear }
- }),
- _vm.unlinkPanels
- ? _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-d-arrow-right",
- class: { "is-disabled": !_vm.enableYearArrow },
- attrs: {
- type: "button",
- disabled: !_vm.enableYearArrow
- },
- on: { click: _vm.leftNextYear }
- })
- : _vm._e(),
- _c("div", [_vm._v(_vm._s(_vm.leftLabel))])
- ]),
- _c("month-table", {
- attrs: {
- "selection-mode": "range",
- date: _vm.leftDate,
- "default-value": _vm.defaultValue,
- "min-date": _vm.minDate,
- "max-date": _vm.maxDate,
- "range-state": _vm.rangeState,
- "disabled-date": _vm.disabledDate
- },
- on: {
- changerange: _vm.handleChangeRange,
- pick: _vm.handleRangePick
- }
- })
- ],
- 1
- ),
- _c(
- "div",
- {
- staticClass:
- "el-picker-panel__content el-date-range-picker__content is-right"
- },
- [
- _c("div", { staticClass: "el-date-range-picker__header" }, [
- _vm.unlinkPanels
- ? _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-d-arrow-left",
- class: { "is-disabled": !_vm.enableYearArrow },
- attrs: {
- type: "button",
- disabled: !_vm.enableYearArrow
- },
- on: { click: _vm.rightPrevYear }
- })
- : _vm._e(),
- _c("button", {
- staticClass:
- "el-picker-panel__icon-btn el-icon-d-arrow-right",
- attrs: { type: "button" },
- on: { click: _vm.rightNextYear }
- }),
- _c("div", [_vm._v(_vm._s(_vm.rightLabel))])
- ]),
- _c("month-table", {
- attrs: {
- "selection-mode": "range",
- date: _vm.rightDate,
- "default-value": _vm.defaultValue,
- "min-date": _vm.minDate,
- "max-date": _vm.maxDate,
- "range-state": _vm.rangeState,
- "disabled-date": _vm.disabledDate
- },
- on: {
- changerange: _vm.handleChangeRange,
- pick: _vm.handleRangePick
- }
- })
- ],
- 1
- )
- ])
- ],
- 2
- )
- ]
- )
- ]
- )
- }
- var month_rangevue_type_template_id_f2645fb8_staticRenderFns = []
- month_rangevue_type_template_id_f2645fb8_render._withStripped = true
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/month-range.vue?vue&type=template&id=f2645fb8&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/month-range.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var month_rangevue_type_script_lang_js_calcDefaultValue = function calcDefaultValue(defaultValue) {
- if (Array.isArray(defaultValue)) {
- return [new Date(defaultValue[0]), new Date(defaultValue[1])];
- } else if (defaultValue) {
- return [new Date(defaultValue), Object(date_util_["nextMonth"])(new Date(defaultValue))];
- } else {
- return [new Date(), Object(date_util_["nextMonth"])(new Date())];
- }
- };
- /* harmony default export */ var month_rangevue_type_script_lang_js_ = ({
- mixins: [locale_default.a],
- directives: { Clickoutside: clickoutside_default.a },
- computed: {
- btnDisabled: function btnDisabled() {
- return !(this.minDate && this.maxDate && !this.selecting && this.isValidValue([this.minDate, this.maxDate]));
- },
- leftLabel: function leftLabel() {
- return this.leftDate.getFullYear() + ' ' + this.t('el.datepicker.year');
- },
- rightLabel: function rightLabel() {
- return this.rightDate.getFullYear() + ' ' + this.t('el.datepicker.year');
- },
- leftYear: function leftYear() {
- return this.leftDate.getFullYear();
- },
- rightYear: function rightYear() {
- return this.rightDate.getFullYear() === this.leftDate.getFullYear() ? this.leftDate.getFullYear() + 1 : this.rightDate.getFullYear();
- },
- enableYearArrow: function enableYearArrow() {
- return this.unlinkPanels && this.rightYear > this.leftYear + 1;
- }
- },
- data: function data() {
- return {
- popperClass: '',
- value: [],
- defaultValue: null,
- defaultTime: null,
- minDate: '',
- maxDate: '',
- leftDate: new Date(),
- rightDate: Object(date_util_["nextYear"])(new Date()),
- rangeState: {
- endDate: null,
- selecting: false,
- row: null,
- column: null
- },
- shortcuts: '',
- visible: '',
- disabledDate: '',
- format: '',
- arrowControl: false,
- unlinkPanels: false
- };
- },
- watch: {
- value: function value(newVal) {
- if (!newVal) {
- this.minDate = null;
- this.maxDate = null;
- } else if (Array.isArray(newVal)) {
- this.minDate = Object(date_util_["isDate"])(newVal[0]) ? new Date(newVal[0]) : null;
- this.maxDate = Object(date_util_["isDate"])(newVal[1]) ? new Date(newVal[1]) : null;
- if (this.minDate) {
- this.leftDate = this.minDate;
- if (this.unlinkPanels && this.maxDate) {
- var minDateYear = this.minDate.getFullYear();
- var maxDateYear = this.maxDate.getFullYear();
- this.rightDate = minDateYear === maxDateYear ? Object(date_util_["nextYear"])(this.maxDate) : this.maxDate;
- } else {
- this.rightDate = Object(date_util_["nextYear"])(this.leftDate);
- }
- } else {
- this.leftDate = month_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0];
- this.rightDate = Object(date_util_["nextYear"])(this.leftDate);
- }
- }
- },
- defaultValue: function defaultValue(val) {
- if (!Array.isArray(this.value)) {
- var _calcDefaultValue = month_rangevue_type_script_lang_js_calcDefaultValue(val),
- left = _calcDefaultValue[0],
- right = _calcDefaultValue[1];
- this.leftDate = left;
- this.rightDate = val && val[1] && left.getFullYear() !== right.getFullYear() && this.unlinkPanels ? right : Object(date_util_["nextYear"])(this.leftDate);
- }
- }
- },
- methods: {
- handleClear: function handleClear() {
- this.minDate = null;
- this.maxDate = null;
- this.leftDate = month_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0];
- this.rightDate = Object(date_util_["nextYear"])(this.leftDate);
- this.$emit('pick', null);
- },
- handleChangeRange: function handleChangeRange(val) {
- this.minDate = val.minDate;
- this.maxDate = val.maxDate;
- this.rangeState = val.rangeState;
- },
- handleRangePick: function handleRangePick(val) {
- var _this = this;
- var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
- var defaultTime = this.defaultTime || [];
- var minDate = Object(date_util_["modifyWithTimeString"])(val.minDate, defaultTime[0]);
- var maxDate = Object(date_util_["modifyWithTimeString"])(val.maxDate, defaultTime[1]);
- if (this.maxDate === maxDate && this.minDate === minDate) {
- return;
- }
- this.onPick && this.onPick(val);
- this.maxDate = maxDate;
- this.minDate = minDate;
- // workaround for https://github.com/ElemeFE/element/issues/7539, should remove this block when we don't have to care about Chromium 55 - 57
- setTimeout(function () {
- _this.maxDate = maxDate;
- _this.minDate = minDate;
- }, 10);
- if (!close) return;
- this.handleConfirm();
- },
- handleShortcutClick: function handleShortcutClick(shortcut) {
- if (shortcut.onClick) {
- shortcut.onClick(this);
- }
- },
- // leftPrev*, rightNext* need to take care of `unlinkPanels`
- leftPrevYear: function leftPrevYear() {
- this.leftDate = Object(date_util_["prevYear"])(this.leftDate);
- if (!this.unlinkPanels) {
- this.rightDate = Object(date_util_["prevYear"])(this.rightDate);
- }
- },
- rightNextYear: function rightNextYear() {
- if (!this.unlinkPanels) {
- this.leftDate = Object(date_util_["nextYear"])(this.leftDate);
- }
- this.rightDate = Object(date_util_["nextYear"])(this.rightDate);
- },
- // leftNext*, rightPrev* are called when `unlinkPanels` is true
- leftNextYear: function leftNextYear() {
- this.leftDate = Object(date_util_["nextYear"])(this.leftDate);
- },
- rightPrevYear: function rightPrevYear() {
- this.rightDate = Object(date_util_["prevYear"])(this.rightDate);
- },
- handleConfirm: function handleConfirm() {
- var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- if (this.isValidValue([this.minDate, this.maxDate])) {
- this.$emit('pick', [this.minDate, this.maxDate], visible);
- }
- },
- isValidValue: function isValidValue(value) {
- return Array.isArray(value) && value && value[0] && value[1] && Object(date_util_["isDate"])(value[0]) && Object(date_util_["isDate"])(value[1]) && value[0].getTime() <= value[1].getTime() && (typeof this.disabledDate === 'function' ? !this.disabledDate(value[0]) && !this.disabledDate(value[1]) : true);
- },
- resetView: function resetView() {
- // NOTE: this is a hack to reset {min, max}Date on picker open.
- // TODO: correct way of doing so is to refactor {min, max}Date to be dependent on value and internal selection state
- // an alternative would be resetView whenever picker becomes visible, should also investigate date-panel's resetView
- this.minDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[0]) : null;
- this.maxDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[1]) : null;
- }
- },
- components: { MonthTable: month_table, ElInput: input_default.a, ElButton: button_default.a }
- });
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/month-range.vue?vue&type=script&lang=js&
- /* harmony default export */ var panel_month_rangevue_type_script_lang_js_ = (month_rangevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/month-range.vue
- /* normalize component */
- var month_range_component = normalizeComponent(
- panel_month_rangevue_type_script_lang_js_,
- month_rangevue_type_template_id_f2645fb8_render,
- month_rangevue_type_template_id_f2645fb8_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var month_range_api; }
- month_range_component.options.__file = "packages/date-picker/src/panel/month-range.vue"
- /* harmony default export */ var month_range = (month_range_component.exports);
- // CONCATENATED MODULE: ./packages/date-picker/src/picker/date-picker.js
- var date_picker_getPanel = function getPanel(type) {
- if (type === 'daterange' || type === 'datetimerange') {
- return date_range;
- } else if (type === 'monthrange') {
- return month_range;
- }
- return panel_date;
- };
- /* harmony default export */ var date_picker = ({
- mixins: [picker],
- name: 'ElDatePicker',
- props: {
- type: {
- type: String,
- default: 'date'
- },
- timeArrowControl: Boolean
- },
- watch: {
- type: function type(_type) {
- if (this.picker) {
- this.unmountPicker();
- this.panel = date_picker_getPanel(_type);
- this.mountPicker();
- } else {
- this.panel = date_picker_getPanel(_type);
- }
- }
- },
- created: function created() {
- this.panel = date_picker_getPanel(this.type);
- }
- });
- // CONCATENATED MODULE: ./packages/date-picker/index.js
- /* istanbul ignore next */
- date_picker.install = function install(Vue) {
- Vue.component(date_picker.name, date_picker);
- };
- /* harmony default export */ var packages_date_picker = (date_picker);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time-select.vue?vue&type=template&id=51ab9320&
- var time_selectvue_type_template_id_51ab9320_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- {
- attrs: { name: "el-zoom-in-top" },
- on: {
- "before-enter": _vm.handleMenuEnter,
- "after-leave": function($event) {
- _vm.$emit("dodestroy")
- }
- }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- ref: "popper",
- staticClass: "el-picker-panel time-select el-popper",
- class: _vm.popperClass,
- style: { width: _vm.width + "px" }
- },
- [
- _c(
- "el-scrollbar",
- {
- attrs: { noresize: "", "wrap-class": "el-picker-panel__content" }
- },
- _vm._l(_vm.items, function(item) {
- return _c(
- "div",
- {
- key: item.value,
- staticClass: "time-select-item",
- class: {
- selected: _vm.value === item.value,
- disabled: item.disabled,
- default: item.value === _vm.defaultValue
- },
- attrs: { disabled: item.disabled },
- on: {
- click: function($event) {
- _vm.handleClick(item)
- }
- }
- },
- [_vm._v(_vm._s(item.value))]
- )
- }),
- 0
- )
- ],
- 1
- )
- ]
- )
- }
- var time_selectvue_type_template_id_51ab9320_staticRenderFns = []
- time_selectvue_type_template_id_51ab9320_render._withStripped = true
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-select.vue?vue&type=template&id=51ab9320&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time-select.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var parseTime = function parseTime(time) {
- var values = (time || '').split(':');
- if (values.length >= 2) {
- var hours = parseInt(values[0], 10);
- var minutes = parseInt(values[1], 10);
- return {
- hours: hours,
- minutes: minutes
- };
- }
- /* istanbul ignore next */
- return null;
- };
- var compareTime = function compareTime(time1, time2) {
- var value1 = parseTime(time1);
- var value2 = parseTime(time2);
- var minutes1 = value1.minutes + value1.hours * 60;
- var minutes2 = value2.minutes + value2.hours * 60;
- if (minutes1 === minutes2) {
- return 0;
- }
- return minutes1 > minutes2 ? 1 : -1;
- };
- var formatTime = function formatTime(time) {
- return (time.hours < 10 ? '0' + time.hours : time.hours) + ':' + (time.minutes < 10 ? '0' + time.minutes : time.minutes);
- };
- var nextTime = function nextTime(time, step) {
- var timeValue = parseTime(time);
- var stepValue = parseTime(step);
- var next = {
- hours: timeValue.hours,
- minutes: timeValue.minutes
- };
- next.minutes += stepValue.minutes;
- next.hours += stepValue.hours;
- next.hours += Math.floor(next.minutes / 60);
- next.minutes = next.minutes % 60;
- return formatTime(next);
- };
- /* harmony default export */ var time_selectvue_type_script_lang_js_ = ({
- components: { ElScrollbar: scrollbar_default.a },
- watch: {
- value: function value(val) {
- var _this = this;
- if (!val) return;
- this.$nextTick(function () {
- return _this.scrollToOption();
- });
- }
- },
- methods: {
- handleClick: function handleClick(item) {
- if (!item.disabled) {
- this.$emit('pick', item.value);
- }
- },
- handleClear: function handleClear() {
- this.$emit('pick', null);
- },
- scrollToOption: function scrollToOption() {
- var selector = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '.selected';
- var menu = this.$refs.popper.querySelector('.el-picker-panel__content');
- scroll_into_view_default()(menu, menu.querySelector(selector));
- },
- handleMenuEnter: function handleMenuEnter() {
- var _this2 = this;
- var selected = this.items.map(function (item) {
- return item.value;
- }).indexOf(this.value) !== -1;
- var hasDefault = this.items.map(function (item) {
- return item.value;
- }).indexOf(this.defaultValue) !== -1;
- var option = selected && '.selected' || hasDefault && '.default' || '.time-select-item:not(.disabled)';
- this.$nextTick(function () {
- return _this2.scrollToOption(option);
- });
- },
- scrollDown: function scrollDown(step) {
- var items = this.items;
- var length = items.length;
- var total = items.length;
- var index = items.map(function (item) {
- return item.value;
- }).indexOf(this.value);
- while (total--) {
- index = (index + step + length) % length;
- if (!items[index].disabled) {
- this.$emit('pick', items[index].value, true);
- return;
- }
- }
- },
- isValidValue: function isValidValue(date) {
- return this.items.filter(function (item) {
- return !item.disabled;
- }).map(function (item) {
- return item.value;
- }).indexOf(date) !== -1;
- },
- handleKeydown: function handleKeydown(event) {
- var keyCode = event.keyCode;
- if (keyCode === 38 || keyCode === 40) {
- var mapping = { 40: 1, 38: -1 };
- var offset = mapping[keyCode.toString()];
- this.scrollDown(offset);
- event.stopPropagation();
- return;
- }
- }
- },
- data: function data() {
- return {
- popperClass: '',
- start: '09:00',
- end: '18:00',
- step: '00:30',
- value: '',
- defaultValue: '',
- visible: false,
- minTime: '',
- maxTime: '',
- width: 0
- };
- },
- computed: {
- items: function items() {
- var start = this.start;
- var end = this.end;
- var step = this.step;
- var result = [];
- if (start && end && step) {
- var current = start;
- while (compareTime(current, end) <= 0) {
- result.push({
- value: current,
- disabled: compareTime(current, this.minTime || '-1:-1') <= 0 || compareTime(current, this.maxTime || '100:100') >= 0
- });
- current = nextTime(current, step);
- }
- }
- return result;
- }
- }
- });
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-select.vue?vue&type=script&lang=js&
- /* harmony default export */ var panel_time_selectvue_type_script_lang_js_ = (time_selectvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-select.vue
- /* normalize component */
- var time_select_component = normalizeComponent(
- panel_time_selectvue_type_script_lang_js_,
- time_selectvue_type_template_id_51ab9320_render,
- time_selectvue_type_template_id_51ab9320_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var time_select_api; }
- time_select_component.options.__file = "packages/date-picker/src/panel/time-select.vue"
- /* harmony default export */ var time_select = (time_select_component.exports);
- // CONCATENATED MODULE: ./packages/date-picker/src/picker/time-select.js
- /* harmony default export */ var picker_time_select = ({
- mixins: [picker],
- name: 'ElTimeSelect',
- componentName: 'ElTimeSelect',
- props: {
- type: {
- type: String,
- default: 'time-select'
- }
- },
- beforeCreate: function beforeCreate() {
- this.panel = time_select;
- }
- });
- // CONCATENATED MODULE: ./packages/time-select/index.js
- /* istanbul ignore next */
- picker_time_select.install = function (Vue) {
- Vue.component(picker_time_select.name, picker_time_select);
- };
- /* harmony default export */ var packages_time_select = (picker_time_select);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time-range.vue?vue&type=template&id=fb28660e&
- var time_rangevue_type_template_id_fb28660e_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- {
- attrs: { name: "el-zoom-in-top" },
- on: {
- "after-leave": function($event) {
- _vm.$emit("dodestroy")
- }
- }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-time-range-picker el-picker-panel el-popper",
- class: _vm.popperClass
- },
- [
- _c("div", { staticClass: "el-time-range-picker__content" }, [
- _c("div", { staticClass: "el-time-range-picker__cell" }, [
- _c("div", { staticClass: "el-time-range-picker__header" }, [
- _vm._v(_vm._s(_vm.t("el.datepicker.startTime")))
- ]),
- _c(
- "div",
- {
- staticClass:
- "el-time-range-picker__body el-time-panel__content",
- class: {
- "has-seconds": _vm.showSeconds,
- "is-arrow": _vm.arrowControl
- }
- },
- [
- _c("time-spinner", {
- ref: "minSpinner",
- attrs: {
- "show-seconds": _vm.showSeconds,
- "am-pm-mode": _vm.amPmMode,
- "arrow-control": _vm.arrowControl,
- date: _vm.minDate
- },
- on: {
- change: _vm.handleMinChange,
- "select-range": _vm.setMinSelectionRange
- }
- })
- ],
- 1
- )
- ]),
- _c("div", { staticClass: "el-time-range-picker__cell" }, [
- _c("div", { staticClass: "el-time-range-picker__header" }, [
- _vm._v(_vm._s(_vm.t("el.datepicker.endTime")))
- ]),
- _c(
- "div",
- {
- staticClass:
- "el-time-range-picker__body el-time-panel__content",
- class: {
- "has-seconds": _vm.showSeconds,
- "is-arrow": _vm.arrowControl
- }
- },
- [
- _c("time-spinner", {
- ref: "maxSpinner",
- attrs: {
- "show-seconds": _vm.showSeconds,
- "am-pm-mode": _vm.amPmMode,
- "arrow-control": _vm.arrowControl,
- date: _vm.maxDate
- },
- on: {
- change: _vm.handleMaxChange,
- "select-range": _vm.setMaxSelectionRange
- }
- })
- ],
- 1
- )
- ])
- ]),
- _c("div", { staticClass: "el-time-panel__footer" }, [
- _c(
- "button",
- {
- staticClass: "el-time-panel__btn cancel",
- attrs: { type: "button" },
- on: {
- click: function($event) {
- _vm.handleCancel()
- }
- }
- },
- [_vm._v(_vm._s(_vm.t("el.datepicker.cancel")))]
- ),
- _c(
- "button",
- {
- staticClass: "el-time-panel__btn confirm",
- attrs: { type: "button", disabled: _vm.btnDisabled },
- on: {
- click: function($event) {
- _vm.handleConfirm()
- }
- }
- },
- [_vm._v(_vm._s(_vm.t("el.datepicker.confirm")))]
- )
- ])
- ]
- )
- ]
- )
- }
- var time_rangevue_type_template_id_fb28660e_staticRenderFns = []
- time_rangevue_type_template_id_fb28660e_render._withStripped = true
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-range.vue?vue&type=template&id=fb28660e&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time-range.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var MIN_TIME = Object(date_util_["parseDate"])('00:00:00', 'HH:mm:ss');
- var MAX_TIME = Object(date_util_["parseDate"])('23:59:59', 'HH:mm:ss');
- var time_rangevue_type_script_lang_js_minTimeOfDay = function minTimeOfDay(date) {
- return Object(date_util_["modifyDate"])(MIN_TIME, date.getFullYear(), date.getMonth(), date.getDate());
- };
- var time_rangevue_type_script_lang_js_maxTimeOfDay = function maxTimeOfDay(date) {
- return Object(date_util_["modifyDate"])(MAX_TIME, date.getFullYear(), date.getMonth(), date.getDate());
- };
- // increase time by amount of milliseconds, but within the range of day
- var advanceTime = function advanceTime(date, amount) {
- return new Date(Math.min(date.getTime() + amount, time_rangevue_type_script_lang_js_maxTimeOfDay(date).getTime()));
- };
- /* harmony default export */ var time_rangevue_type_script_lang_js_ = ({
- mixins: [locale_default.a],
- components: { TimeSpinner: time_spinner },
- computed: {
- showSeconds: function showSeconds() {
- return (this.format || '').indexOf('ss') !== -1;
- },
- offset: function offset() {
- return this.showSeconds ? 11 : 8;
- },
- spinner: function spinner() {
- return this.selectionRange[0] < this.offset ? this.$refs.minSpinner : this.$refs.maxSpinner;
- },
- btnDisabled: function btnDisabled() {
- return this.minDate.getTime() > this.maxDate.getTime();
- },
- amPmMode: function amPmMode() {
- if ((this.format || '').indexOf('A') !== -1) return 'A';
- if ((this.format || '').indexOf('a') !== -1) return 'a';
- return '';
- }
- },
- data: function data() {
- return {
- popperClass: '',
- minDate: new Date(),
- maxDate: new Date(),
- value: [],
- oldValue: [new Date(), new Date()],
- defaultValue: null,
- format: 'HH:mm:ss',
- visible: false,
- selectionRange: [0, 2],
- arrowControl: false
- };
- },
- watch: {
- value: function value(_value) {
- if (Array.isArray(_value)) {
- this.minDate = new Date(_value[0]);
- this.maxDate = new Date(_value[1]);
- } else {
- if (Array.isArray(this.defaultValue)) {
- this.minDate = new Date(this.defaultValue[0]);
- this.maxDate = new Date(this.defaultValue[1]);
- } else if (this.defaultValue) {
- this.minDate = new Date(this.defaultValue);
- this.maxDate = advanceTime(new Date(this.defaultValue), 60 * 60 * 1000);
- } else {
- this.minDate = new Date();
- this.maxDate = advanceTime(new Date(), 60 * 60 * 1000);
- }
- }
- },
- visible: function visible(val) {
- var _this = this;
- if (val) {
- this.oldValue = this.value;
- this.$nextTick(function () {
- return _this.$refs.minSpinner.emitSelectRange('hours');
- });
- }
- }
- },
- methods: {
- handleClear: function handleClear() {
- this.$emit('pick', null);
- },
- handleCancel: function handleCancel() {
- this.$emit('pick', this.oldValue);
- },
- handleMinChange: function handleMinChange(date) {
- this.minDate = Object(date_util_["clearMilliseconds"])(date);
- this.handleChange();
- },
- handleMaxChange: function handleMaxChange(date) {
- this.maxDate = Object(date_util_["clearMilliseconds"])(date);
- this.handleChange();
- },
- handleChange: function handleChange() {
- if (this.isValidValue([this.minDate, this.maxDate])) {
- this.$refs.minSpinner.selectableRange = [[time_rangevue_type_script_lang_js_minTimeOfDay(this.minDate), this.maxDate]];
- this.$refs.maxSpinner.selectableRange = [[this.minDate, time_rangevue_type_script_lang_js_maxTimeOfDay(this.maxDate)]];
- this.$emit('pick', [this.minDate, this.maxDate], true);
- }
- },
- setMinSelectionRange: function setMinSelectionRange(start, end) {
- this.$emit('select-range', start, end, 'min');
- this.selectionRange = [start, end];
- },
- setMaxSelectionRange: function setMaxSelectionRange(start, end) {
- this.$emit('select-range', start, end, 'max');
- this.selectionRange = [start + this.offset, end + this.offset];
- },
- handleConfirm: function handleConfirm() {
- var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- var minSelectableRange = this.$refs.minSpinner.selectableRange;
- var maxSelectableRange = this.$refs.maxSpinner.selectableRange;
- this.minDate = Object(date_util_["limitTimeRange"])(this.minDate, minSelectableRange, this.format);
- this.maxDate = Object(date_util_["limitTimeRange"])(this.maxDate, maxSelectableRange, this.format);
- this.$emit('pick', [this.minDate, this.maxDate], visible);
- },
- adjustSpinners: function adjustSpinners() {
- this.$refs.minSpinner.adjustSpinners();
- this.$refs.maxSpinner.adjustSpinners();
- },
- changeSelectionRange: function changeSelectionRange(step) {
- var list = this.showSeconds ? [0, 3, 6, 11, 14, 17] : [0, 3, 8, 11];
- var mapping = ['hours', 'minutes'].concat(this.showSeconds ? ['seconds'] : []);
- var index = list.indexOf(this.selectionRange[0]);
- var next = (index + step + list.length) % list.length;
- var half = list.length / 2;
- if (next < half) {
- this.$refs.minSpinner.emitSelectRange(mapping[next]);
- } else {
- this.$refs.maxSpinner.emitSelectRange(mapping[next - half]);
- }
- },
- isValidValue: function isValidValue(date) {
- return Array.isArray(date) && Object(date_util_["timeWithinRange"])(this.minDate, this.$refs.minSpinner.selectableRange) && Object(date_util_["timeWithinRange"])(this.maxDate, this.$refs.maxSpinner.selectableRange);
- },
- handleKeydown: function handleKeydown(event) {
- var keyCode = event.keyCode;
- var mapping = { 38: -1, 40: 1, 37: -1, 39: 1 };
- // Left or Right
- if (keyCode === 37 || keyCode === 39) {
- var step = mapping[keyCode];
- this.changeSelectionRange(step);
- event.preventDefault();
- return;
- }
- // Up or Down
- if (keyCode === 38 || keyCode === 40) {
- var _step = mapping[keyCode];
- this.spinner.scrollDown(_step);
- event.preventDefault();
- return;
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-range.vue?vue&type=script&lang=js&
- /* harmony default export */ var panel_time_rangevue_type_script_lang_js_ = (time_rangevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-range.vue
- /* normalize component */
- var time_range_component = normalizeComponent(
- panel_time_rangevue_type_script_lang_js_,
- time_rangevue_type_template_id_fb28660e_render,
- time_rangevue_type_template_id_fb28660e_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var time_range_api; }
- time_range_component.options.__file = "packages/date-picker/src/panel/time-range.vue"
- /* harmony default export */ var time_range = (time_range_component.exports);
- // CONCATENATED MODULE: ./packages/date-picker/src/picker/time-picker.js
- /* harmony default export */ var time_picker = ({
- mixins: [picker],
- name: 'ElTimePicker',
- props: {
- isRange: Boolean,
- arrowControl: Boolean
- },
- data: function data() {
- return {
- type: ''
- };
- },
- watch: {
- isRange: function isRange(_isRange) {
- if (this.picker) {
- this.unmountPicker();
- this.type = _isRange ? 'timerange' : 'time';
- this.panel = _isRange ? time_range : panel_time;
- this.mountPicker();
- } else {
- this.type = _isRange ? 'timerange' : 'time';
- this.panel = _isRange ? time_range : panel_time;
- }
- }
- },
- created: function created() {
- this.type = this.isRange ? 'timerange' : 'time';
- this.panel = this.isRange ? time_range : panel_time;
- }
- });
- // CONCATENATED MODULE: ./packages/time-picker/index.js
- /* istanbul ignore next */
- time_picker.install = function (Vue) {
- Vue.component(time_picker.name, time_picker);
- };
- /* harmony default export */ var packages_time_picker = (time_picker);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/popover/src/main.vue?vue&type=template&id=52060272&
- var mainvue_type_template_id_52060272_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "span",
- [
- _c(
- "transition",
- {
- attrs: { name: _vm.transition },
- on: {
- "after-enter": _vm.handleAfterEnter,
- "after-leave": _vm.handleAfterLeave
- }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: !_vm.disabled && _vm.showPopper,
- expression: "!disabled && showPopper"
- }
- ],
- ref: "popper",
- staticClass: "el-popover el-popper",
- class: [_vm.popperClass, _vm.content && "el-popover--plain"],
- style: { width: _vm.width + "px" },
- attrs: {
- role: "tooltip",
- id: _vm.tooltipId,
- "aria-hidden":
- _vm.disabled || !_vm.showPopper ? "true" : "false"
- }
- },
- [
- _vm.title
- ? _c("div", {
- staticClass: "el-popover__title",
- domProps: { textContent: _vm._s(_vm.title) }
- })
- : _vm._e(),
- _vm._t("default", [_vm._v(_vm._s(_vm.content))])
- ],
- 2
- )
- ]
- ),
- _c(
- "span",
- { ref: "wrapper", staticClass: "el-popover__reference-wrapper" },
- [_vm._t("reference")],
- 2
- )
- ],
- 1
- )
- }
- var mainvue_type_template_id_52060272_staticRenderFns = []
- mainvue_type_template_id_52060272_render._withStripped = true
- // CONCATENATED MODULE: ./packages/popover/src/main.vue?vue&type=template&id=52060272&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/popover/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var mainvue_type_script_lang_js_ = ({
- name: 'ElPopover',
- mixins: [vue_popper_default.a],
- props: {
- trigger: {
- type: String,
- default: 'click',
- validator: function validator(value) {
- return ['click', 'focus', 'hover', 'manual'].indexOf(value) > -1;
- }
- },
- openDelay: {
- type: Number,
- default: 0
- },
- closeDelay: {
- type: Number,
- default: 200
- },
- title: String,
- disabled: Boolean,
- content: String,
- reference: {},
- popperClass: String,
- width: {},
- visibleArrow: {
- default: true
- },
- arrowOffset: {
- type: Number,
- default: 0
- },
- transition: {
- type: String,
- default: 'fade-in-linear'
- },
- tabindex: {
- type: Number,
- default: 0
- }
- },
- computed: {
- tooltipId: function tooltipId() {
- return 'el-popover-' + Object(util_["generateId"])();
- }
- },
- watch: {
- showPopper: function showPopper(val) {
- if (this.disabled) {
- return;
- }
- val ? this.$emit('show') : this.$emit('hide');
- }
- },
- mounted: function mounted() {
- var _this = this;
- var reference = this.referenceElm = this.reference || this.$refs.reference;
- var popper = this.popper || this.$refs.popper;
- if (!reference && this.$refs.wrapper.children) {
- reference = this.referenceElm = this.$refs.wrapper.children[0];
- }
- // 可访问性
- if (reference) {
- Object(dom_["addClass"])(reference, 'el-popover__reference');
- reference.setAttribute('aria-describedby', this.tooltipId);
- reference.setAttribute('tabindex', this.tabindex); // tab序列
- popper.setAttribute('tabindex', 0);
- if (this.trigger !== 'click') {
- Object(dom_["on"])(reference, 'focusin', function () {
- _this.handleFocus();
- var instance = reference.__vue__;
- if (instance && typeof instance.focus === 'function') {
- instance.focus();
- }
- });
- Object(dom_["on"])(popper, 'focusin', this.handleFocus);
- Object(dom_["on"])(reference, 'focusout', this.handleBlur);
- Object(dom_["on"])(popper, 'focusout', this.handleBlur);
- }
- Object(dom_["on"])(reference, 'keydown', this.handleKeydown);
- Object(dom_["on"])(reference, 'click', this.handleClick);
- }
- if (this.trigger === 'click') {
- Object(dom_["on"])(reference, 'click', this.doToggle);
- Object(dom_["on"])(document, 'click', this.handleDocumentClick);
- } else if (this.trigger === 'hover') {
- Object(dom_["on"])(reference, 'mouseenter', this.handleMouseEnter);
- Object(dom_["on"])(popper, 'mouseenter', this.handleMouseEnter);
- Object(dom_["on"])(reference, 'mouseleave', this.handleMouseLeave);
- Object(dom_["on"])(popper, 'mouseleave', this.handleMouseLeave);
- } else if (this.trigger === 'focus') {
- if (this.tabindex < 0) {
- console.warn('[Element Warn][Popover]a negative taindex means that the element cannot be focused by tab key');
- }
- if (reference.querySelector('input, textarea')) {
- Object(dom_["on"])(reference, 'focusin', this.doShow);
- Object(dom_["on"])(reference, 'focusout', this.doClose);
- } else {
- Object(dom_["on"])(reference, 'mousedown', this.doShow);
- Object(dom_["on"])(reference, 'mouseup', this.doClose);
- }
- }
- },
- beforeDestroy: function beforeDestroy() {
- this.cleanup();
- },
- deactivated: function deactivated() {
- this.cleanup();
- },
- methods: {
- doToggle: function doToggle() {
- this.showPopper = !this.showPopper;
- },
- doShow: function doShow() {
- this.showPopper = true;
- },
- doClose: function doClose() {
- this.showPopper = false;
- },
- handleFocus: function handleFocus() {
- Object(dom_["addClass"])(this.referenceElm, 'focusing');
- if (this.trigger === 'click' || this.trigger === 'focus') this.showPopper = true;
- },
- handleClick: function handleClick() {
- Object(dom_["removeClass"])(this.referenceElm, 'focusing');
- },
- handleBlur: function handleBlur() {
- Object(dom_["removeClass"])(this.referenceElm, 'focusing');
- if (this.trigger === 'click' || this.trigger === 'focus') this.showPopper = false;
- },
- handleMouseEnter: function handleMouseEnter() {
- var _this2 = this;
- clearTimeout(this._timer);
- if (this.openDelay) {
- this._timer = setTimeout(function () {
- _this2.showPopper = true;
- }, this.openDelay);
- } else {
- this.showPopper = true;
- }
- },
- handleKeydown: function handleKeydown(ev) {
- if (ev.keyCode === 27 && this.trigger !== 'manual') {
- // esc
- this.doClose();
- }
- },
- handleMouseLeave: function handleMouseLeave() {
- var _this3 = this;
- clearTimeout(this._timer);
- if (this.closeDelay) {
- this._timer = setTimeout(function () {
- _this3.showPopper = false;
- }, this.closeDelay);
- } else {
- this.showPopper = false;
- }
- },
- handleDocumentClick: function handleDocumentClick(e) {
- var reference = this.reference || this.$refs.reference;
- var popper = this.popper || this.$refs.popper;
- if (!reference && this.$refs.wrapper.children) {
- reference = this.referenceElm = this.$refs.wrapper.children[0];
- }
- if (!this.$el || !reference || this.$el.contains(e.target) || reference.contains(e.target) || !popper || popper.contains(e.target)) return;
- this.showPopper = false;
- },
- handleAfterEnter: function handleAfterEnter() {
- this.$emit('after-enter');
- },
- handleAfterLeave: function handleAfterLeave() {
- this.$emit('after-leave');
- this.doDestroy();
- },
- cleanup: function cleanup() {
- if (this.openDelay || this.closeDelay) {
- clearTimeout(this._timer);
- }
- }
- },
- destroyed: function destroyed() {
- var reference = this.reference;
- Object(dom_["off"])(reference, 'click', this.doToggle);
- Object(dom_["off"])(reference, 'mouseup', this.doClose);
- Object(dom_["off"])(reference, 'mousedown', this.doShow);
- Object(dom_["off"])(reference, 'focusin', this.doShow);
- Object(dom_["off"])(reference, 'focusout', this.doClose);
- Object(dom_["off"])(reference, 'mousedown', this.doShow);
- Object(dom_["off"])(reference, 'mouseup', this.doClose);
- Object(dom_["off"])(reference, 'mouseleave', this.handleMouseLeave);
- Object(dom_["off"])(reference, 'mouseenter', this.handleMouseEnter);
- Object(dom_["off"])(document, 'click', this.handleDocumentClick);
- }
- });
- // CONCATENATED MODULE: ./packages/popover/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/popover/src/main.vue
- /* normalize component */
- var main_component = normalizeComponent(
- src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_52060272_render,
- mainvue_type_template_id_52060272_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var main_api; }
- main_component.options.__file = "packages/popover/src/main.vue"
- /* harmony default export */ var main = (main_component.exports);
- // CONCATENATED MODULE: ./packages/popover/src/directive.js
- var getReference = function getReference(el, binding, vnode) {
- var _ref = binding.expression ? binding.value : binding.arg;
- var popper = vnode.context.$refs[_ref];
- if (popper) {
- if (Array.isArray(popper)) {
- popper[0].$refs.reference = el;
- } else {
- popper.$refs.reference = el;
- }
- }
- };
- /* harmony default export */ var directive = ({
- bind: function bind(el, binding, vnode) {
- getReference(el, binding, vnode);
- },
- inserted: function inserted(el, binding, vnode) {
- getReference(el, binding, vnode);
- }
- });
- // CONCATENATED MODULE: ./packages/popover/index.js
- external_vue_default.a.directive('popover', directive);
- /* istanbul ignore next */
- main.install = function (Vue) {
- Vue.directive('popover', directive);
- Vue.component(main.name, main);
- };
- main.directive = directive;
- /* harmony default export */ var popover = (main);
- // CONCATENATED MODULE: ./packages/tooltip/src/main.js
- /* harmony default export */ var src_main = ({
- name: 'ElTooltip',
- mixins: [vue_popper_default.a],
- props: {
- openDelay: {
- type: Number,
- default: 0
- },
- disabled: Boolean,
- manual: Boolean,
- effect: {
- type: String,
- default: 'dark'
- },
- arrowOffset: {
- type: Number,
- default: 0
- },
- popperClass: String,
- content: String,
- visibleArrow: {
- default: true
- },
- transition: {
- type: String,
- default: 'el-fade-in-linear'
- },
- popperOptions: {
- default: function _default() {
- return {
- boundariesPadding: 10,
- gpuAcceleration: false
- };
- }
- },
- enterable: {
- type: Boolean,
- default: true
- },
- hideAfter: {
- type: Number,
- default: 0
- },
- tabindex: {
- type: Number,
- default: 0
- }
- },
- data: function data() {
- return {
- tooltipId: 'el-tooltip-' + Object(util_["generateId"])(),
- timeoutPending: null,
- focusing: false
- };
- },
- beforeCreate: function beforeCreate() {
- var _this = this;
- if (this.$isServer) return;
- this.popperVM = new external_vue_default.a({
- data: { node: '' },
- render: function render(h) {
- return this.node;
- }
- }).$mount();
- this.debounceClose = debounce_default()(200, function () {
- return _this.handleClosePopper();
- });
- },
- render: function render(h) {
- var _this2 = this;
- if (this.popperVM) {
- this.popperVM.node = h(
- 'transition',
- {
- attrs: {
- name: this.transition
- },
- on: {
- 'afterLeave': this.doDestroy
- }
- },
- [h(
- 'div',
- {
- on: {
- 'mouseleave': function mouseleave() {
- _this2.setExpectedState(false);_this2.debounceClose();
- },
- 'mouseenter': function mouseenter() {
- _this2.setExpectedState(true);
- }
- },
- ref: 'popper',
- attrs: { role: 'tooltip',
- id: this.tooltipId,
- 'aria-hidden': this.disabled || !this.showPopper ? 'true' : 'false'
- },
- directives: [{
- name: 'show',
- value: !this.disabled && this.showPopper
- }],
- 'class': ['el-tooltip__popper', 'is-' + this.effect, this.popperClass] },
- [this.$slots.content || this.content]
- )]
- );
- }
- var firstElement = this.getFirstElement();
- if (!firstElement) return null;
- var data = firstElement.data = firstElement.data || {};
- data.staticClass = this.addTooltipClass(data.staticClass);
- return firstElement;
- },
- mounted: function mounted() {
- var _this3 = this;
- this.referenceElm = this.$el;
- if (this.$el.nodeType === 1) {
- this.$el.setAttribute('aria-describedby', this.tooltipId);
- this.$el.setAttribute('tabindex', this.tabindex);
- Object(dom_["on"])(this.referenceElm, 'mouseenter', this.show);
- Object(dom_["on"])(this.referenceElm, 'mouseleave', this.hide);
- Object(dom_["on"])(this.referenceElm, 'focus', function () {
- if (!_this3.$slots.default || !_this3.$slots.default.length) {
- _this3.handleFocus();
- return;
- }
- var instance = _this3.$slots.default[0].componentInstance;
- if (instance && instance.focus) {
- instance.focus();
- } else {
- _this3.handleFocus();
- }
- });
- Object(dom_["on"])(this.referenceElm, 'blur', this.handleBlur);
- Object(dom_["on"])(this.referenceElm, 'click', this.removeFocusing);
- }
- // fix issue https://github.com/ElemeFE/element/issues/14424
- if (this.value && this.popperVM) {
- this.popperVM.$nextTick(function () {
- if (_this3.value) {
- _this3.updatePopper();
- }
- });
- }
- },
- watch: {
- focusing: function focusing(val) {
- if (val) {
- Object(dom_["addClass"])(this.referenceElm, 'focusing');
- } else {
- Object(dom_["removeClass"])(this.referenceElm, 'focusing');
- }
- }
- },
- methods: {
- show: function show() {
- this.setExpectedState(true);
- this.handleShowPopper();
- },
- hide: function hide() {
- this.setExpectedState(false);
- this.debounceClose();
- },
- handleFocus: function handleFocus() {
- this.focusing = true;
- this.show();
- },
- handleBlur: function handleBlur() {
- this.focusing = false;
- this.hide();
- },
- removeFocusing: function removeFocusing() {
- this.focusing = false;
- },
- addTooltipClass: function addTooltipClass(prev) {
- if (!prev) {
- return 'el-tooltip';
- } else {
- return 'el-tooltip ' + prev.replace('el-tooltip', '');
- }
- },
- handleShowPopper: function handleShowPopper() {
- var _this4 = this;
- if (!this.expectedState || this.manual) return;
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- _this4.showPopper = true;
- }, this.openDelay);
- if (this.hideAfter > 0) {
- this.timeoutPending = setTimeout(function () {
- _this4.showPopper = false;
- }, this.hideAfter);
- }
- },
- handleClosePopper: function handleClosePopper() {
- if (this.enterable && this.expectedState || this.manual) return;
- clearTimeout(this.timeout);
- if (this.timeoutPending) {
- clearTimeout(this.timeoutPending);
- }
- this.showPopper = false;
- if (this.disabled) {
- this.doDestroy();
- }
- },
- setExpectedState: function setExpectedState(expectedState) {
- if (expectedState === false) {
- clearTimeout(this.timeoutPending);
- }
- this.expectedState = expectedState;
- },
- getFirstElement: function getFirstElement() {
- var slots = this.$slots.default;
- if (!Array.isArray(slots)) return null;
- var element = null;
- for (var index = 0; index < slots.length; index++) {
- if (slots[index] && slots[index].tag) {
- element = slots[index];
- break;
- };
- }
- return element;
- }
- },
- beforeDestroy: function beforeDestroy() {
- this.popperVM && this.popperVM.$destroy();
- },
- destroyed: function destroyed() {
- var reference = this.referenceElm;
- if (reference.nodeType === 1) {
- Object(dom_["off"])(reference, 'mouseenter', this.show);
- Object(dom_["off"])(reference, 'mouseleave', this.hide);
- Object(dom_["off"])(reference, 'focus', this.handleFocus);
- Object(dom_["off"])(reference, 'blur', this.handleBlur);
- Object(dom_["off"])(reference, 'click', this.removeFocusing);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/tooltip/index.js
- /* istanbul ignore next */
- src_main.install = function (Vue) {
- Vue.component(src_main.name, src_main);
- };
- /* harmony default export */ var packages_tooltip = (src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/message-box/src/main.vue?vue&type=template&id=6b29b012&
- var mainvue_type_template_id_6b29b012_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("transition", { attrs: { name: "msgbox-fade" } }, [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-message-box__wrapper",
- attrs: {
- tabindex: "-1",
- role: "dialog",
- "aria-modal": "true",
- "aria-label": _vm.title || "dialog"
- },
- on: {
- click: function($event) {
- if ($event.target !== $event.currentTarget) {
- return null
- }
- return _vm.handleWrapperClick($event)
- }
- }
- },
- [
- _c(
- "div",
- {
- staticClass: "el-message-box",
- class: [_vm.customClass, _vm.center && "el-message-box--center"]
- },
- [
- _vm.title !== null
- ? _c("div", { staticClass: "el-message-box__header" }, [
- _c("div", { staticClass: "el-message-box__title" }, [
- _vm.icon && _vm.center
- ? _c("div", {
- class: ["el-message-box__status", _vm.icon]
- })
- : _vm._e(),
- _c("span", [_vm._v(_vm._s(_vm.title))])
- ]),
- _vm.showClose
- ? _c(
- "button",
- {
- staticClass: "el-message-box__headerbtn",
- attrs: { type: "button", "aria-label": "Close" },
- on: {
- click: function($event) {
- _vm.handleAction(
- _vm.distinguishCancelAndClose
- ? "close"
- : "cancel"
- )
- },
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k(
- $event.keyCode,
- "enter",
- 13,
- $event.key,
- "Enter"
- )
- ) {
- return null
- }
- _vm.handleAction(
- _vm.distinguishCancelAndClose
- ? "close"
- : "cancel"
- )
- }
- }
- },
- [
- _c("i", {
- staticClass: "el-message-box__close el-icon-close"
- })
- ]
- )
- : _vm._e()
- ])
- : _vm._e(),
- _c("div", { staticClass: "el-message-box__content" }, [
- _c("div", { staticClass: "el-message-box__container" }, [
- _vm.icon && !_vm.center && _vm.message !== ""
- ? _c("div", { class: ["el-message-box__status", _vm.icon] })
- : _vm._e(),
- _vm.message !== ""
- ? _c(
- "div",
- { staticClass: "el-message-box__message" },
- [
- _vm._t("default", [
- !_vm.dangerouslyUseHTMLString
- ? _c("p", [_vm._v(_vm._s(_vm.message))])
- : _c("p", {
- domProps: { innerHTML: _vm._s(_vm.message) }
- })
- ])
- ],
- 2
- )
- : _vm._e()
- ]),
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.showInput,
- expression: "showInput"
- }
- ],
- staticClass: "el-message-box__input"
- },
- [
- _c("el-input", {
- ref: "input",
- attrs: {
- type: _vm.inputType,
- placeholder: _vm.inputPlaceholder
- },
- nativeOn: {
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k(
- $event.keyCode,
- "enter",
- 13,
- $event.key,
- "Enter"
- )
- ) {
- return null
- }
- return _vm.handleInputEnter($event)
- }
- },
- model: {
- value: _vm.inputValue,
- callback: function($$v) {
- _vm.inputValue = $$v
- },
- expression: "inputValue"
- }
- }),
- _c(
- "div",
- {
- staticClass: "el-message-box__errormsg",
- style: {
- visibility: !!_vm.editorErrorMessage
- ? "visible"
- : "hidden"
- }
- },
- [_vm._v(_vm._s(_vm.editorErrorMessage))]
- )
- ],
- 1
- )
- ]),
- _c(
- "div",
- { staticClass: "el-message-box__btns" },
- [
- _vm.showCancelButton
- ? _c(
- "el-button",
- {
- class: [_vm.cancelButtonClasses],
- attrs: {
- loading: _vm.cancelButtonLoading,
- round: _vm.roundButton,
- size: "small"
- },
- on: {
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k(
- $event.keyCode,
- "enter",
- 13,
- $event.key,
- "Enter"
- )
- ) {
- return null
- }
- _vm.handleAction("cancel")
- }
- },
- nativeOn: {
- click: function($event) {
- _vm.handleAction("cancel")
- }
- }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(
- _vm.cancelButtonText ||
- _vm.t("el.messagebox.cancel")
- ) +
- "\n "
- )
- ]
- )
- : _vm._e(),
- _c(
- "el-button",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.showConfirmButton,
- expression: "showConfirmButton"
- }
- ],
- ref: "confirm",
- class: [_vm.confirmButtonClasses],
- attrs: {
- loading: _vm.confirmButtonLoading,
- round: _vm.roundButton,
- size: "small"
- },
- on: {
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k(
- $event.keyCode,
- "enter",
- 13,
- $event.key,
- "Enter"
- )
- ) {
- return null
- }
- _vm.handleAction("confirm")
- }
- },
- nativeOn: {
- click: function($event) {
- _vm.handleAction("confirm")
- }
- }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(
- _vm.confirmButtonText ||
- _vm.t("el.messagebox.confirm")
- ) +
- "\n "
- )
- ]
- )
- ],
- 1
- )
- ]
- )
- ]
- )
- ])
- }
- var mainvue_type_template_id_6b29b012_staticRenderFns = []
- mainvue_type_template_id_6b29b012_render._withStripped = true
- // CONCATENATED MODULE: ./packages/message-box/src/main.vue?vue&type=template&id=6b29b012&
- // EXTERNAL MODULE: external "element-ui/lib/locale"
- var lib_locale_ = __webpack_require__(12);
- var lib_locale_default = /*#__PURE__*/__webpack_require__.n(lib_locale_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/aria-dialog"
- var aria_dialog_ = __webpack_require__(40);
- var aria_dialog_default = /*#__PURE__*/__webpack_require__.n(aria_dialog_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/message-box/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var messageBox = void 0;
- var typeMap = {
- success: 'success',
- info: 'info',
- warning: 'warning',
- error: 'error'
- };
- /* harmony default export */ var message_box_src_mainvue_type_script_lang_js_ = ({
- mixins: [popup_default.a, locale_default.a],
- props: {
- modal: {
- default: true
- },
- lockScroll: {
- default: true
- },
- showClose: {
- type: Boolean,
- default: true
- },
- closeOnClickModal: {
- default: true
- },
- closeOnPressEscape: {
- default: true
- },
- closeOnHashChange: {
- default: true
- },
- center: {
- default: false,
- type: Boolean
- },
- roundButton: {
- default: false,
- type: Boolean
- }
- },
- components: {
- ElInput: input_default.a,
- ElButton: button_default.a
- },
- computed: {
- icon: function icon() {
- var type = this.type,
- iconClass = this.iconClass;
- return iconClass || (type && typeMap[type] ? 'el-icon-' + typeMap[type] : '');
- },
- confirmButtonClasses: function confirmButtonClasses() {
- return 'el-button--primary ' + this.confirmButtonClass;
- },
- cancelButtonClasses: function cancelButtonClasses() {
- return '' + this.cancelButtonClass;
- }
- },
- methods: {
- getSafeClose: function getSafeClose() {
- var _this = this;
- var currentId = this.uid;
- return function () {
- _this.$nextTick(function () {
- if (currentId === _this.uid) _this.doClose();
- });
- };
- },
- doClose: function doClose() {
- var _this2 = this;
- if (!this.visible) return;
- this.visible = false;
- this._closing = true;
- this.onClose && this.onClose();
- messageBox.closeDialog(); // 解绑
- if (this.lockScroll) {
- setTimeout(this.restoreBodyStyle, 200);
- }
- this.opened = false;
- this.doAfterClose();
- setTimeout(function () {
- if (_this2.action) _this2.callback(_this2.action, _this2);
- });
- },
- handleWrapperClick: function handleWrapperClick() {
- if (this.closeOnClickModal) {
- this.handleAction(this.distinguishCancelAndClose ? 'close' : 'cancel');
- }
- },
- handleInputEnter: function handleInputEnter() {
- if (this.inputType !== 'textarea') {
- return this.handleAction('confirm');
- }
- },
- handleAction: function handleAction(action) {
- if (this.$type === 'prompt' && action === 'confirm' && !this.validate()) {
- return;
- }
- this.action = action;
- if (typeof this.beforeClose === 'function') {
- this.close = this.getSafeClose();
- this.beforeClose(action, this, this.close);
- } else {
- this.doClose();
- }
- },
- validate: function validate() {
- if (this.$type === 'prompt') {
- var inputPattern = this.inputPattern;
- if (inputPattern && !inputPattern.test(this.inputValue || '')) {
- this.editorErrorMessage = this.inputErrorMessage || Object(lib_locale_["t"])('el.messagebox.error');
- Object(dom_["addClass"])(this.getInputElement(), 'invalid');
- return false;
- }
- var inputValidator = this.inputValidator;
- if (typeof inputValidator === 'function') {
- var validateResult = inputValidator(this.inputValue);
- if (validateResult === false) {
- this.editorErrorMessage = this.inputErrorMessage || Object(lib_locale_["t"])('el.messagebox.error');
- Object(dom_["addClass"])(this.getInputElement(), 'invalid');
- return false;
- }
- if (typeof validateResult === 'string') {
- this.editorErrorMessage = validateResult;
- Object(dom_["addClass"])(this.getInputElement(), 'invalid');
- return false;
- }
- }
- }
- this.editorErrorMessage = '';
- Object(dom_["removeClass"])(this.getInputElement(), 'invalid');
- return true;
- },
- getFirstFocus: function getFirstFocus() {
- var btn = this.$el.querySelector('.el-message-box__btns .el-button');
- var title = this.$el.querySelector('.el-message-box__btns .el-message-box__title');
- return btn || title;
- },
- getInputElement: function getInputElement() {
- var inputRefs = this.$refs.input.$refs;
- return inputRefs.input || inputRefs.textarea;
- },
- handleClose: function handleClose() {
- this.handleAction('close');
- }
- },
- watch: {
- inputValue: {
- immediate: true,
- handler: function handler(val) {
- var _this3 = this;
- this.$nextTick(function (_) {
- if (_this3.$type === 'prompt' && val !== null) {
- _this3.validate();
- }
- });
- }
- },
- visible: function visible(val) {
- var _this4 = this;
- if (val) {
- this.uid++;
- if (this.$type === 'alert' || this.$type === 'confirm') {
- this.$nextTick(function () {
- _this4.$refs.confirm.$el.focus();
- });
- }
- this.focusAfterClosed = document.activeElement;
- messageBox = new aria_dialog_default.a(this.$el, this.focusAfterClosed, this.getFirstFocus());
- }
- // prompt
- if (this.$type !== 'prompt') return;
- if (val) {
- setTimeout(function () {
- if (_this4.$refs.input && _this4.$refs.input.$el) {
- _this4.getInputElement().focus();
- }
- }, 500);
- } else {
- this.editorErrorMessage = '';
- Object(dom_["removeClass"])(this.getInputElement(), 'invalid');
- }
- }
- },
- mounted: function mounted() {
- var _this5 = this;
- this.$nextTick(function () {
- if (_this5.closeOnHashChange) {
- window.addEventListener('hashchange', _this5.close);
- }
- });
- },
- beforeDestroy: function beforeDestroy() {
- if (this.closeOnHashChange) {
- window.removeEventListener('hashchange', this.close);
- }
- setTimeout(function () {
- messageBox.closeDialog();
- });
- },
- data: function data() {
- return {
- uid: 1,
- title: undefined,
- message: '',
- type: '',
- iconClass: '',
- customClass: '',
- showInput: false,
- inputValue: null,
- inputPlaceholder: '',
- inputType: 'text',
- inputPattern: null,
- inputValidator: null,
- inputErrorMessage: '',
- showConfirmButton: true,
- showCancelButton: false,
- action: '',
- confirmButtonText: '',
- cancelButtonText: '',
- confirmButtonLoading: false,
- cancelButtonLoading: false,
- confirmButtonClass: '',
- confirmButtonDisabled: false,
- cancelButtonClass: '',
- editorErrorMessage: null,
- callback: null,
- dangerouslyUseHTMLString: false,
- focusAfterClosed: null,
- isOnComposition: false,
- distinguishCancelAndClose: false
- };
- }
- });
- // CONCATENATED MODULE: ./packages/message-box/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_message_box_src_mainvue_type_script_lang_js_ = (message_box_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/message-box/src/main.vue
- /* normalize component */
- var src_main_component = normalizeComponent(
- packages_message_box_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_6b29b012_render,
- mainvue_type_template_id_6b29b012_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var src_main_api; }
- src_main_component.options.__file = "packages/message-box/src/main.vue"
- /* harmony default export */ var message_box_src_main = (src_main_component.exports);
- // EXTERNAL MODULE: external "element-ui/lib/utils/vdom"
- var vdom_ = __webpack_require__(22);
- // CONCATENATED MODULE: ./packages/message-box/src/main.js
- var main_typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- var main_defaults = {
- title: null,
- message: '',
- type: '',
- iconClass: '',
- showInput: false,
- showClose: true,
- modalFade: true,
- lockScroll: true,
- closeOnClickModal: true,
- closeOnPressEscape: true,
- closeOnHashChange: true,
- inputValue: null,
- inputPlaceholder: '',
- inputType: 'text',
- inputPattern: null,
- inputValidator: null,
- inputErrorMessage: '',
- showConfirmButton: true,
- showCancelButton: false,
- confirmButtonPosition: 'right',
- confirmButtonHighlight: false,
- cancelButtonHighlight: false,
- confirmButtonText: '',
- cancelButtonText: '',
- confirmButtonClass: '',
- cancelButtonClass: '',
- customClass: '',
- beforeClose: null,
- dangerouslyUseHTMLString: false,
- center: false,
- roundButton: false,
- distinguishCancelAndClose: false
- };
- var MessageBoxConstructor = external_vue_default.a.extend(message_box_src_main);
- var currentMsg = void 0,
- main_instance = void 0;
- var msgQueue = [];
- var defaultCallback = function defaultCallback(action) {
- if (currentMsg) {
- var callback = currentMsg.callback;
- if (typeof callback === 'function') {
- if (main_instance.showInput) {
- callback(main_instance.inputValue, action);
- } else {
- callback(action);
- }
- }
- if (currentMsg.resolve) {
- if (action === 'confirm') {
- if (main_instance.showInput) {
- currentMsg.resolve({ value: main_instance.inputValue, action: action });
- } else {
- currentMsg.resolve(action);
- }
- } else if (currentMsg.reject && (action === 'cancel' || action === 'close')) {
- currentMsg.reject(action);
- }
- }
- }
- };
- var initInstance = function initInstance() {
- main_instance = new MessageBoxConstructor({
- el: document.createElement('div')
- });
- main_instance.callback = defaultCallback;
- };
- var main_showNextMsg = function showNextMsg() {
- if (!main_instance) {
- initInstance();
- }
- main_instance.action = '';
- if (!main_instance.visible || main_instance.closeTimer) {
- if (msgQueue.length > 0) {
- currentMsg = msgQueue.shift();
- var options = currentMsg.options;
- for (var prop in options) {
- if (options.hasOwnProperty(prop)) {
- main_instance[prop] = options[prop];
- }
- }
- if (options.callback === undefined) {
- main_instance.callback = defaultCallback;
- }
- var oldCb = main_instance.callback;
- main_instance.callback = function (action, instance) {
- oldCb(action, instance);
- showNextMsg();
- };
- if (Object(vdom_["isVNode"])(main_instance.message)) {
- main_instance.$slots.default = [main_instance.message];
- main_instance.message = null;
- } else {
- delete main_instance.$slots.default;
- }
- ['modal', 'showClose', 'closeOnClickModal', 'closeOnPressEscape', 'closeOnHashChange'].forEach(function (prop) {
- if (main_instance[prop] === undefined) {
- main_instance[prop] = true;
- }
- });
- document.body.appendChild(main_instance.$el);
- external_vue_default.a.nextTick(function () {
- main_instance.visible = true;
- });
- }
- }
- };
- var main_MessageBox = function MessageBox(options, callback) {
- if (external_vue_default.a.prototype.$isServer) return;
- if (typeof options === 'string' || Object(vdom_["isVNode"])(options)) {
- options = {
- message: options
- };
- if (typeof arguments[1] === 'string') {
- options.title = arguments[1];
- }
- } else if (options.callback && !callback) {
- callback = options.callback;
- }
- if (typeof Promise !== 'undefined') {
- return new Promise(function (resolve, reject) {
- // eslint-disable-line
- msgQueue.push({
- options: merge_default()({}, main_defaults, MessageBox.defaults, options),
- callback: callback,
- resolve: resolve,
- reject: reject
- });
- main_showNextMsg();
- });
- } else {
- msgQueue.push({
- options: merge_default()({}, main_defaults, MessageBox.defaults, options),
- callback: callback
- });
- main_showNextMsg();
- }
- };
- main_MessageBox.setDefaults = function (defaults) {
- main_MessageBox.defaults = defaults;
- };
- main_MessageBox.alert = function (message, title, options) {
- if ((typeof title === 'undefined' ? 'undefined' : main_typeof(title)) === 'object') {
- options = title;
- title = '';
- } else if (title === undefined) {
- title = '';
- }
- return main_MessageBox(merge_default()({
- title: title,
- message: message,
- $type: 'alert',
- closeOnPressEscape: false,
- closeOnClickModal: false
- }, options));
- };
- main_MessageBox.confirm = function (message, title, options) {
- if ((typeof title === 'undefined' ? 'undefined' : main_typeof(title)) === 'object') {
- options = title;
- title = '';
- } else if (title === undefined) {
- title = '';
- }
- return main_MessageBox(merge_default()({
- title: title,
- message: message,
- $type: 'confirm',
- showCancelButton: true
- }, options));
- };
- main_MessageBox.prompt = function (message, title, options) {
- if ((typeof title === 'undefined' ? 'undefined' : main_typeof(title)) === 'object') {
- options = title;
- title = '';
- } else if (title === undefined) {
- title = '';
- }
- return main_MessageBox(merge_default()({
- title: title,
- message: message,
- showCancelButton: true,
- showInput: true,
- $type: 'prompt'
- }, options));
- };
- main_MessageBox.close = function () {
- main_instance.doClose();
- main_instance.visible = false;
- msgQueue = [];
- currentMsg = null;
- };
- /* harmony default export */ var packages_message_box_src_main = (main_MessageBox);
- // CONCATENATED MODULE: ./packages/message-box/index.js
- /* harmony default export */ var message_box = (packages_message_box_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb.vue?vue&type=template&id=4b464c06&
- var breadcrumbvue_type_template_id_4b464c06_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-breadcrumb",
- attrs: { "aria-label": "Breadcrumb", role: "navigation" }
- },
- [_vm._t("default")],
- 2
- )
- }
- var breadcrumbvue_type_template_id_4b464c06_staticRenderFns = []
- breadcrumbvue_type_template_id_4b464c06_render._withStripped = true
- // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb.vue?vue&type=template&id=4b464c06&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- /* harmony default export */ var breadcrumbvue_type_script_lang_js_ = ({
- name: 'ElBreadcrumb',
- props: {
- separator: {
- type: String,
- default: '/'
- },
- separatorClass: {
- type: String,
- default: ''
- }
- },
- provide: function provide() {
- return {
- elBreadcrumb: this
- };
- },
- mounted: function mounted() {
- var items = this.$el.querySelectorAll('.el-breadcrumb__item');
- if (items.length) {
- items[items.length - 1].setAttribute('aria-current', 'page');
- }
- }
- });
- // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_breadcrumbvue_type_script_lang_js_ = (breadcrumbvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb.vue
- /* normalize component */
- var breadcrumb_component = normalizeComponent(
- src_breadcrumbvue_type_script_lang_js_,
- breadcrumbvue_type_template_id_4b464c06_render,
- breadcrumbvue_type_template_id_4b464c06_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var breadcrumb_api; }
- breadcrumb_component.options.__file = "packages/breadcrumb/src/breadcrumb.vue"
- /* harmony default export */ var breadcrumb = (breadcrumb_component.exports);
- // CONCATENATED MODULE: ./packages/breadcrumb/index.js
- /* istanbul ignore next */
- breadcrumb.install = function (Vue) {
- Vue.component(breadcrumb.name, breadcrumb);
- };
- /* harmony default export */ var packages_breadcrumb = (breadcrumb);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=template&id=fcf9eaac&
- var breadcrumb_itemvue_type_template_id_fcf9eaac_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("span", { staticClass: "el-breadcrumb__item" }, [
- _c(
- "span",
- {
- ref: "link",
- class: ["el-breadcrumb__inner", _vm.to ? "is-link" : ""],
- attrs: { role: "link" }
- },
- [_vm._t("default")],
- 2
- ),
- _vm.separatorClass
- ? _c("i", {
- staticClass: "el-breadcrumb__separator",
- class: _vm.separatorClass
- })
- : _c(
- "span",
- {
- staticClass: "el-breadcrumb__separator",
- attrs: { role: "presentation" }
- },
- [_vm._v(_vm._s(_vm.separator))]
- )
- ])
- }
- var breadcrumb_itemvue_type_template_id_fcf9eaac_staticRenderFns = []
- breadcrumb_itemvue_type_template_id_fcf9eaac_render._withStripped = true
- // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=template&id=fcf9eaac&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var breadcrumb_itemvue_type_script_lang_js_ = ({
- name: 'ElBreadcrumbItem',
- props: {
- to: {},
- replace: Boolean
- },
- data: function data() {
- return {
- separator: '',
- separatorClass: ''
- };
- },
- inject: ['elBreadcrumb'],
- mounted: function mounted() {
- var _this = this;
- this.separator = this.elBreadcrumb.separator;
- this.separatorClass = this.elBreadcrumb.separatorClass;
- var link = this.$refs.link;
- link.setAttribute('role', 'link');
- link.addEventListener('click', function (_) {
- var to = _this.to,
- $router = _this.$router;
- if (!to || !$router) return;
- _this.replace ? $router.replace(to) : $router.push(to);
- });
- }
- });
- // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_breadcrumb_itemvue_type_script_lang_js_ = (breadcrumb_itemvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb-item.vue
- /* normalize component */
- var breadcrumb_item_component = normalizeComponent(
- src_breadcrumb_itemvue_type_script_lang_js_,
- breadcrumb_itemvue_type_template_id_fcf9eaac_render,
- breadcrumb_itemvue_type_template_id_fcf9eaac_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var breadcrumb_item_api; }
- breadcrumb_item_component.options.__file = "packages/breadcrumb/src/breadcrumb-item.vue"
- /* harmony default export */ var breadcrumb_item = (breadcrumb_item_component.exports);
- // CONCATENATED MODULE: ./packages/breadcrumb-item/index.js
- /* istanbul ignore next */
- breadcrumb_item.install = function (Vue) {
- Vue.component(breadcrumb_item.name, breadcrumb_item);
- };
- /* harmony default export */ var packages_breadcrumb_item = (breadcrumb_item);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/form.vue?vue&type=template&id=a1b5ff34&
- var formvue_type_template_id_a1b5ff34_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "form",
- {
- staticClass: "el-form",
- class: [
- _vm.labelPosition ? "el-form--label-" + _vm.labelPosition : "",
- { "el-form--inline": _vm.inline }
- ]
- },
- [_vm._t("default")],
- 2
- )
- }
- var formvue_type_template_id_a1b5ff34_staticRenderFns = []
- formvue_type_template_id_a1b5ff34_render._withStripped = true
- // CONCATENATED MODULE: ./packages/form/src/form.vue?vue&type=template&id=a1b5ff34&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/form.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var formvue_type_script_lang_js_ = ({
- name: 'ElForm',
- componentName: 'ElForm',
- provide: function provide() {
- return {
- elForm: this
- };
- },
- props: {
- model: Object,
- rules: Object,
- labelPosition: String,
- labelWidth: String,
- labelSuffix: {
- type: String,
- default: ''
- },
- inline: Boolean,
- inlineMessage: Boolean,
- statusIcon: Boolean,
- showMessage: {
- type: Boolean,
- default: true
- },
- size: String,
- disabled: Boolean,
- validateOnRuleChange: {
- type: Boolean,
- default: true
- },
- hideRequiredAsterisk: {
- type: Boolean,
- default: false
- }
- },
- watch: {
- rules: function rules() {
- // remove then add event listeners on form-item after form rules change
- this.fields.forEach(function (field) {
- field.removeValidateEvents();
- field.addValidateEvents();
- });
- if (this.validateOnRuleChange) {
- this.validate(function () {});
- }
- }
- },
- computed: {
- autoLabelWidth: function autoLabelWidth() {
- if (!this.potentialLabelWidthArr.length) return 0;
- var max = Math.max.apply(Math, this.potentialLabelWidthArr);
- return max ? max + 'px' : '';
- }
- },
- data: function data() {
- return {
- fields: [],
- potentialLabelWidthArr: [] // use this array to calculate auto width
- };
- },
- created: function created() {
- var _this = this;
- this.$on('el.form.addField', function (field) {
- if (field) {
- _this.fields.push(field);
- }
- });
- /* istanbul ignore next */
- this.$on('el.form.removeField', function (field) {
- if (field.prop) {
- _this.fields.splice(_this.fields.indexOf(field), 1);
- }
- });
- },
- methods: {
- resetFields: function resetFields() {
- if (!this.model) {
- console.warn('[Element Warn][Form]model is required for resetFields to work.');
- return;
- }
- this.fields.forEach(function (field) {
- field.resetField();
- });
- },
- clearValidate: function clearValidate() {
- var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- var fields = props.length ? typeof props === 'string' ? this.fields.filter(function (field) {
- return props === field.prop;
- }) : this.fields.filter(function (field) {
- return props.indexOf(field.prop) > -1;
- }) : this.fields;
- fields.forEach(function (field) {
- field.clearValidate();
- });
- },
- validate: function validate(callback) {
- var _this2 = this;
- if (!this.model) {
- console.warn('[Element Warn][Form]model is required for validate to work!');
- return;
- }
- var promise = void 0;
- // if no callback, return promise
- if (typeof callback !== 'function' && window.Promise) {
- promise = new window.Promise(function (resolve, reject) {
- callback = function callback(valid, invalidFields) {
- valid ? resolve(valid) : reject(invalidFields);
- };
- });
- }
- var valid = true;
- var count = 0;
- // 如果需要验证的fields为空,调用验证时立刻返回callback
- if (this.fields.length === 0 && callback) {
- callback(true);
- }
- var invalidFields = {};
- this.fields.forEach(function (field) {
- field.validate('', function (message, field) {
- if (message) {
- valid = false;
- }
- invalidFields = merge_default()({}, invalidFields, field);
- if (typeof callback === 'function' && ++count === _this2.fields.length) {
- callback(valid, invalidFields);
- }
- });
- });
- if (promise) {
- return promise;
- }
- },
- validateField: function validateField(props, cb) {
- props = [].concat(props);
- var fields = this.fields.filter(function (field) {
- return props.indexOf(field.prop) !== -1;
- });
- if (!fields.length) {
- console.warn('[Element Warn]please pass correct props!');
- return;
- }
- fields.forEach(function (field) {
- field.validate('', cb);
- });
- },
- getLabelWidthIndex: function getLabelWidthIndex(width) {
- var index = this.potentialLabelWidthArr.indexOf(width);
- // it's impossible
- if (index === -1) {
- throw new Error('[ElementForm]unpected width ', width);
- }
- return index;
- },
- registerLabelWidth: function registerLabelWidth(val, oldVal) {
- if (val && oldVal) {
- var index = this.getLabelWidthIndex(oldVal);
- this.potentialLabelWidthArr.splice(index, 1, val);
- } else if (val) {
- this.potentialLabelWidthArr.push(val);
- }
- },
- deregisterLabelWidth: function deregisterLabelWidth(val) {
- var index = this.getLabelWidthIndex(val);
- this.potentialLabelWidthArr.splice(index, 1);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/form/src/form.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_formvue_type_script_lang_js_ = (formvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/form/src/form.vue
- /* normalize component */
- var form_component = normalizeComponent(
- src_formvue_type_script_lang_js_,
- formvue_type_template_id_a1b5ff34_render,
- formvue_type_template_id_a1b5ff34_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var form_api; }
- form_component.options.__file = "packages/form/src/form.vue"
- /* harmony default export */ var src_form = (form_component.exports);
- // CONCATENATED MODULE: ./packages/form/index.js
- /* istanbul ignore next */
- src_form.install = function (Vue) {
- Vue.component(src_form.name, src_form);
- };
- /* harmony default export */ var packages_form = (src_form);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/form-item.vue?vue&type=template&id=b6f3db6c&
- var form_itemvue_type_template_id_b6f3db6c_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-form-item",
- class: [
- {
- "el-form-item--feedback": _vm.elForm && _vm.elForm.statusIcon,
- "is-error": _vm.validateState === "error",
- "is-validating": _vm.validateState === "validating",
- "is-success": _vm.validateState === "success",
- "is-required": _vm.isRequired || _vm.required,
- "is-no-asterisk": _vm.elForm && _vm.elForm.hideRequiredAsterisk
- },
- _vm.sizeClass ? "el-form-item--" + _vm.sizeClass : ""
- ]
- },
- [
- _c(
- "label-wrap",
- {
- attrs: {
- "is-auto-width": _vm.labelStyle && _vm.labelStyle.width === "auto",
- "update-all": _vm.form.labelWidth === "auto"
- }
- },
- [
- _vm.label || _vm.$slots.label
- ? _c(
- "label",
- {
- staticClass: "el-form-item__label",
- style: _vm.labelStyle,
- attrs: { for: _vm.labelFor }
- },
- [
- _vm._t("label", [
- _vm._v(_vm._s(_vm.label + _vm.form.labelSuffix))
- ])
- ],
- 2
- )
- : _vm._e()
- ]
- ),
- _c(
- "div",
- { staticClass: "el-form-item__content", style: _vm.contentStyle },
- [
- _vm._t("default"),
- _c(
- "transition",
- { attrs: { name: "el-zoom-in-top" } },
- [
- _vm.validateState === "error" &&
- _vm.showMessage &&
- _vm.form.showMessage
- ? _vm._t(
- "error",
- [
- _c(
- "div",
- {
- staticClass: "el-form-item__error",
- class: {
- "el-form-item__error--inline":
- typeof _vm.inlineMessage === "boolean"
- ? _vm.inlineMessage
- : (_vm.elForm && _vm.elForm.inlineMessage) ||
- false
- }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.validateMessage) +
- "\n "
- )
- ]
- )
- ],
- { error: _vm.validateMessage }
- )
- : _vm._e()
- ],
- 2
- )
- ],
- 2
- )
- ],
- 1
- )
- }
- var form_itemvue_type_template_id_b6f3db6c_staticRenderFns = []
- form_itemvue_type_template_id_b6f3db6c_render._withStripped = true
- // CONCATENATED MODULE: ./packages/form/src/form-item.vue?vue&type=template&id=b6f3db6c&
- // EXTERNAL MODULE: external "async-validator"
- var external_async_validator_ = __webpack_require__(41);
- var external_async_validator_default = /*#__PURE__*/__webpack_require__.n(external_async_validator_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/label-wrap.vue?vue&type=script&lang=js&
- /* harmony default export */ var label_wrapvue_type_script_lang_js_ = ({
- props: {
- isAutoWidth: Boolean,
- updateAll: Boolean
- },
- inject: ['elForm', 'elFormItem'],
- render: function render() {
- var h = arguments[0];
- var slots = this.$slots.default;
- if (!slots) return null;
- if (this.isAutoWidth) {
- var autoLabelWidth = this.elForm.autoLabelWidth;
- var style = {};
- if (autoLabelWidth && autoLabelWidth !== 'auto') {
- var marginLeft = parseInt(autoLabelWidth, 10) - this.computedWidth;
- if (marginLeft) {
- style.marginLeft = marginLeft + 'px';
- }
- }
- return h(
- 'div',
- { 'class': 'el-form-item__label-wrap', style: style },
- [slots]
- );
- } else {
- return slots[0];
- }
- },
- methods: {
- getLabelWidth: function getLabelWidth() {
- if (this.$el && this.$el.firstElementChild) {
- var computedWidth = window.getComputedStyle(this.$el.firstElementChild).width;
- return Math.ceil(parseFloat(computedWidth));
- } else {
- return 0;
- }
- },
- updateLabelWidth: function updateLabelWidth() {
- var action = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'update';
- if (this.$slots.default && this.isAutoWidth && this.$el.firstElementChild) {
- if (action === 'update') {
- this.computedWidth = this.getLabelWidth();
- } else if (action === 'remove') {
- this.elForm.deregisterLabelWidth(this.computedWidth);
- }
- }
- }
- },
- watch: {
- computedWidth: function computedWidth(val, oldVal) {
- if (this.updateAll) {
- this.elForm.registerLabelWidth(val, oldVal);
- this.elFormItem.updateComputedLabelWidth(val);
- }
- }
- },
- data: function data() {
- return {
- computedWidth: 0
- };
- },
- mounted: function mounted() {
- this.updateLabelWidth('update');
- },
- updated: function updated() {
- this.updateLabelWidth('update');
- },
- beforeDestroy: function beforeDestroy() {
- this.updateLabelWidth('remove');
- }
- });
- // CONCATENATED MODULE: ./packages/form/src/label-wrap.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_label_wrapvue_type_script_lang_js_ = (label_wrapvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/form/src/label-wrap.vue
- var label_wrap_render, label_wrap_staticRenderFns
- /* normalize component */
- var label_wrap_component = normalizeComponent(
- src_label_wrapvue_type_script_lang_js_,
- label_wrap_render,
- label_wrap_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var label_wrap_api; }
- label_wrap_component.options.__file = "packages/form/src/label-wrap.vue"
- /* harmony default export */ var label_wrap = (label_wrap_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/form-item.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var form_itemvue_type_script_lang_js_ = ({
- name: 'ElFormItem',
- componentName: 'ElFormItem',
- mixins: [emitter_default.a],
- provide: function provide() {
- return {
- elFormItem: this
- };
- },
- inject: ['elForm'],
- props: {
- label: String,
- labelWidth: String,
- prop: String,
- required: {
- type: Boolean,
- default: undefined
- },
- rules: [Object, Array],
- error: String,
- validateStatus: String,
- for: String,
- inlineMessage: {
- type: [String, Boolean],
- default: ''
- },
- showMessage: {
- type: Boolean,
- default: true
- },
- size: String
- },
- components: {
- // use this component to calculate auto width
- LabelWrap: label_wrap
- },
- watch: {
- error: {
- immediate: true,
- handler: function handler(value) {
- this.validateMessage = value;
- this.validateState = value ? 'error' : '';
- }
- },
- validateStatus: function validateStatus(value) {
- this.validateState = value;
- },
- rules: function rules(value) {
- if ((!value || value.length === 0) && this.required === undefined) {
- this.clearValidate();
- }
- }
- },
- computed: {
- labelFor: function labelFor() {
- return this.for || this.prop;
- },
- labelStyle: function labelStyle() {
- var ret = {};
- if (this.form.labelPosition === 'top') return ret;
- var labelWidth = this.labelWidth || this.form.labelWidth;
- if (labelWidth) {
- ret.width = labelWidth;
- }
- return ret;
- },
- contentStyle: function contentStyle() {
- var ret = {};
- var label = this.label;
- if (this.form.labelPosition === 'top' || this.form.inline) return ret;
- if (!label && !this.labelWidth && this.isNested) return ret;
- var labelWidth = this.labelWidth || this.form.labelWidth;
- if (labelWidth === 'auto') {
- if (this.labelWidth === 'auto') {
- ret.marginLeft = this.computedLabelWidth;
- } else if (this.form.labelWidth === 'auto') {
- ret.marginLeft = this.elForm.autoLabelWidth;
- }
- } else {
- ret.marginLeft = labelWidth;
- }
- return ret;
- },
- form: function form() {
- var parent = this.$parent;
- var parentName = parent.$options.componentName;
- while (parentName !== 'ElForm') {
- if (parentName === 'ElFormItem') {
- this.isNested = true;
- }
- parent = parent.$parent;
- parentName = parent.$options.componentName;
- }
- return parent;
- },
- fieldValue: function fieldValue() {
- var model = this.form.model;
- if (!model || !this.prop) {
- return;
- }
- var path = this.prop;
- if (path.indexOf(':') !== -1) {
- path = path.replace(/:/, '.');
- }
- return Object(util_["getPropByPath"])(model, path, true).v;
- },
- isRequired: function isRequired() {
- var rules = this.getRules();
- var isRequired = false;
- if (rules && rules.length) {
- rules.every(function (rule) {
- if (rule.required) {
- isRequired = true;
- return false;
- }
- return true;
- });
- }
- return isRequired;
- },
- _formSize: function _formSize() {
- return this.elForm.size;
- },
- elFormItemSize: function elFormItemSize() {
- return this.size || this._formSize;
- },
- sizeClass: function sizeClass() {
- return this.elFormItemSize || (this.$ELEMENT || {}).size;
- }
- },
- data: function data() {
- return {
- validateState: '',
- validateMessage: '',
- validateDisabled: false,
- validator: {},
- isNested: false,
- computedLabelWidth: ''
- };
- },
- methods: {
- validate: function validate(trigger) {
- var _this = this;
- var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : util_["noop"];
- this.validateDisabled = false;
- var rules = this.getFilteredRule(trigger);
- if ((!rules || rules.length === 0) && this.required === undefined) {
- callback();
- return true;
- }
- this.validateState = 'validating';
- var descriptor = {};
- if (rules && rules.length > 0) {
- rules.forEach(function (rule) {
- delete rule.trigger;
- });
- }
- descriptor[this.prop] = rules;
- var validator = new external_async_validator_default.a(descriptor);
- var model = {};
- model[this.prop] = this.fieldValue;
- validator.validate(model, { firstFields: true }, function (errors, invalidFields) {
- _this.validateState = !errors ? 'success' : 'error';
- _this.validateMessage = errors ? errors[0].message : '';
- callback(_this.validateMessage, invalidFields);
- _this.elForm && _this.elForm.$emit('validate', _this.prop, !errors, _this.validateMessage || null);
- });
- },
- clearValidate: function clearValidate() {
- this.validateState = '';
- this.validateMessage = '';
- this.validateDisabled = false;
- },
- resetField: function resetField() {
- var _this2 = this;
- this.validateState = '';
- this.validateMessage = '';
- var model = this.form.model;
- var value = this.fieldValue;
- var path = this.prop;
- if (path.indexOf(':') !== -1) {
- path = path.replace(/:/, '.');
- }
- var prop = Object(util_["getPropByPath"])(model, path, true);
- this.validateDisabled = true;
- if (Array.isArray(value)) {
- prop.o[prop.k] = [].concat(this.initialValue);
- } else {
- prop.o[prop.k] = this.initialValue;
- }
- // reset validateDisabled after onFieldChange triggered
- this.$nextTick(function () {
- _this2.validateDisabled = false;
- });
- this.broadcast('ElTimeSelect', 'fieldReset', this.initialValue);
- },
- getRules: function getRules() {
- var formRules = this.form.rules;
- var selfRules = this.rules;
- var requiredRule = this.required !== undefined ? { required: !!this.required } : [];
- var prop = Object(util_["getPropByPath"])(formRules, this.prop || '');
- formRules = formRules ? prop.o[this.prop || ''] || prop.v : [];
- return [].concat(selfRules || formRules || []).concat(requiredRule);
- },
- getFilteredRule: function getFilteredRule(trigger) {
- var rules = this.getRules();
- return rules.filter(function (rule) {
- if (!rule.trigger || trigger === '') return true;
- if (Array.isArray(rule.trigger)) {
- return rule.trigger.indexOf(trigger) > -1;
- } else {
- return rule.trigger === trigger;
- }
- }).map(function (rule) {
- return merge_default()({}, rule);
- });
- },
- onFieldBlur: function onFieldBlur() {
- this.validate('blur');
- },
- onFieldChange: function onFieldChange() {
- if (this.validateDisabled) {
- this.validateDisabled = false;
- return;
- }
- this.validate('change');
- },
- updateComputedLabelWidth: function updateComputedLabelWidth(width) {
- this.computedLabelWidth = width ? width + 'px' : '';
- },
- addValidateEvents: function addValidateEvents() {
- var rules = this.getRules();
- if (rules.length || this.required !== undefined) {
- this.$on('el.form.blur', this.onFieldBlur);
- this.$on('el.form.change', this.onFieldChange);
- }
- },
- removeValidateEvents: function removeValidateEvents() {
- this.$off();
- }
- },
- mounted: function mounted() {
- if (this.prop) {
- this.dispatch('ElForm', 'el.form.addField', [this]);
- var initialValue = this.fieldValue;
- if (Array.isArray(initialValue)) {
- initialValue = [].concat(initialValue);
- }
- Object.defineProperty(this, 'initialValue', {
- value: initialValue
- });
- this.addValidateEvents();
- }
- },
- beforeDestroy: function beforeDestroy() {
- this.dispatch('ElForm', 'el.form.removeField', [this]);
- }
- });
- // CONCATENATED MODULE: ./packages/form/src/form-item.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_form_itemvue_type_script_lang_js_ = (form_itemvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/form/src/form-item.vue
- /* normalize component */
- var form_item_component = normalizeComponent(
- src_form_itemvue_type_script_lang_js_,
- form_itemvue_type_template_id_b6f3db6c_render,
- form_itemvue_type_template_id_b6f3db6c_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var form_item_api; }
- form_item_component.options.__file = "packages/form/src/form-item.vue"
- /* harmony default export */ var form_item = (form_item_component.exports);
- // CONCATENATED MODULE: ./packages/form-item/index.js
- /* istanbul ignore next */
- form_item.install = function (Vue) {
- Vue.component(form_item.name, form_item);
- };
- /* harmony default export */ var packages_form_item = (form_item);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-bar.vue?vue&type=template&id=2031f33a&
- var tab_barvue_type_template_id_2031f33a_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("div", {
- staticClass: "el-tabs__active-bar",
- class: "is-" + _vm.rootTabs.tabPosition,
- style: _vm.barStyle
- })
- }
- var tab_barvue_type_template_id_2031f33a_staticRenderFns = []
- tab_barvue_type_template_id_2031f33a_render._withStripped = true
- // CONCATENATED MODULE: ./packages/tabs/src/tab-bar.vue?vue&type=template&id=2031f33a&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-bar.vue?vue&type=script&lang=js&
- //
- //
- //
- /* harmony default export */ var tab_barvue_type_script_lang_js_ = ({
- name: 'TabBar',
- props: {
- tabs: Array
- },
- inject: ['rootTabs'],
- computed: {
- barStyle: {
- get: function get() {
- var _this = this;
- var style = {};
- var offset = 0;
- var tabSize = 0;
- var sizeName = ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'width' : 'height';
- var sizeDir = sizeName === 'width' ? 'x' : 'y';
- var firstUpperCase = function firstUpperCase(str) {
- return str.toLowerCase().replace(/( |^)[a-z]/g, function (L) {
- return L.toUpperCase();
- });
- };
- this.tabs.every(function (tab, index) {
- var $el = Object(util_["arrayFind"])(_this.$parent.$refs.tabs || [], function (t) {
- return t.id.replace('tab-', '') === tab.paneName;
- });
- if (!$el) {
- return false;
- }
- if (!tab.active) {
- offset += $el['client' + firstUpperCase(sizeName)];
- return true;
- } else {
- tabSize = $el['client' + firstUpperCase(sizeName)];
- var tabStyles = window.getComputedStyle($el);
- if (sizeName === 'width' && _this.tabs.length > 1) {
- tabSize -= parseFloat(tabStyles.paddingLeft) + parseFloat(tabStyles.paddingRight);
- }
- if (sizeName === 'width') {
- offset += parseFloat(tabStyles.paddingLeft);
- }
- return false;
- }
- });
- var transform = 'translate' + firstUpperCase(sizeDir) + '(' + offset + 'px)';
- style[sizeName] = tabSize + 'px';
- style.transform = transform;
- style.msTransform = transform;
- style.webkitTransform = transform;
- return style;
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/tabs/src/tab-bar.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_tab_barvue_type_script_lang_js_ = (tab_barvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/tabs/src/tab-bar.vue
- /* normalize component */
- var tab_bar_component = normalizeComponent(
- src_tab_barvue_type_script_lang_js_,
- tab_barvue_type_template_id_2031f33a_render,
- tab_barvue_type_template_id_2031f33a_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var tab_bar_api; }
- tab_bar_component.options.__file = "packages/tabs/src/tab-bar.vue"
- /* harmony default export */ var tab_bar = (tab_bar_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-nav.vue?vue&type=script&lang=js&
- function noop() {}
- var tab_navvue_type_script_lang_js_firstUpperCase = function firstUpperCase(str) {
- return str.toLowerCase().replace(/( |^)[a-z]/g, function (L) {
- return L.toUpperCase();
- });
- };
- /* harmony default export */ var tab_navvue_type_script_lang_js_ = ({
- name: 'TabNav',
- components: {
- TabBar: tab_bar
- },
- inject: ['rootTabs'],
- props: {
- panes: Array,
- currentName: String,
- editable: Boolean,
- onTabClick: {
- type: Function,
- default: noop
- },
- onTabRemove: {
- type: Function,
- default: noop
- },
- type: String,
- stretch: Boolean
- },
- data: function data() {
- return {
- scrollable: false,
- navOffset: 0,
- isFocus: false,
- focusable: true
- };
- },
- computed: {
- navStyle: function navStyle() {
- var dir = ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'X' : 'Y';
- return {
- transform: 'translate' + dir + '(-' + this.navOffset + 'px)'
- };
- },
- sizeName: function sizeName() {
- return ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'width' : 'height';
- }
- },
- methods: {
- scrollPrev: function scrollPrev() {
- var containerSize = this.$refs.navScroll['offset' + tab_navvue_type_script_lang_js_firstUpperCase(this.sizeName)];
- var currentOffset = this.navOffset;
- if (!currentOffset) return;
- var newOffset = currentOffset > containerSize ? currentOffset - containerSize : 0;
- this.navOffset = newOffset;
- },
- scrollNext: function scrollNext() {
- var navSize = this.$refs.nav['offset' + tab_navvue_type_script_lang_js_firstUpperCase(this.sizeName)];
- var containerSize = this.$refs.navScroll['offset' + tab_navvue_type_script_lang_js_firstUpperCase(this.sizeName)];
- var currentOffset = this.navOffset;
- if (navSize - currentOffset <= containerSize) return;
- var newOffset = navSize - currentOffset > containerSize * 2 ? currentOffset + containerSize : navSize - containerSize;
- this.navOffset = newOffset;
- },
- scrollToActiveTab: function scrollToActiveTab() {
- if (!this.scrollable) return;
- var nav = this.$refs.nav;
- var activeTab = this.$el.querySelector('.is-active');
- if (!activeTab) return;
- var navScroll = this.$refs.navScroll;
- var isHorizontal = ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1;
- var activeTabBounding = activeTab.getBoundingClientRect();
- var navScrollBounding = navScroll.getBoundingClientRect();
- var maxOffset = isHorizontal ? nav.offsetWidth - navScrollBounding.width : nav.offsetHeight - navScrollBounding.height;
- var currentOffset = this.navOffset;
- var newOffset = currentOffset;
- if (isHorizontal) {
- if (activeTabBounding.left < navScrollBounding.left) {
- newOffset = currentOffset - (navScrollBounding.left - activeTabBounding.left);
- }
- if (activeTabBounding.right > navScrollBounding.right) {
- newOffset = currentOffset + activeTabBounding.right - navScrollBounding.right;
- }
- } else {
- if (activeTabBounding.top < navScrollBounding.top) {
- newOffset = currentOffset - (navScrollBounding.top - activeTabBounding.top);
- }
- if (activeTabBounding.bottom > navScrollBounding.bottom) {
- newOffset = currentOffset + (activeTabBounding.bottom - navScrollBounding.bottom);
- }
- }
- newOffset = Math.max(newOffset, 0);
- this.navOffset = Math.min(newOffset, maxOffset);
- },
- update: function update() {
- if (!this.$refs.nav) return;
- var sizeName = this.sizeName;
- var navSize = this.$refs.nav['offset' + tab_navvue_type_script_lang_js_firstUpperCase(sizeName)];
- var containerSize = this.$refs.navScroll['offset' + tab_navvue_type_script_lang_js_firstUpperCase(sizeName)];
- var currentOffset = this.navOffset;
- if (containerSize < navSize) {
- var _currentOffset = this.navOffset;
- this.scrollable = this.scrollable || {};
- this.scrollable.prev = _currentOffset;
- this.scrollable.next = _currentOffset + containerSize < navSize;
- if (navSize - _currentOffset < containerSize) {
- this.navOffset = navSize - containerSize;
- }
- } else {
- this.scrollable = false;
- if (currentOffset > 0) {
- this.navOffset = 0;
- }
- }
- },
- changeTab: function changeTab(e) {
- var keyCode = e.keyCode;
- var nextIndex = void 0;
- var currentIndex = void 0,
- tabList = void 0;
- if ([37, 38, 39, 40].indexOf(keyCode) !== -1) {
- // 左右上下键更换tab
- tabList = e.currentTarget.querySelectorAll('[role=tab]');
- currentIndex = Array.prototype.indexOf.call(tabList, e.target);
- } else {
- return;
- }
- if (keyCode === 37 || keyCode === 38) {
- // left
- if (currentIndex === 0) {
- // first
- nextIndex = tabList.length - 1;
- } else {
- nextIndex = currentIndex - 1;
- }
- } else {
- // right
- if (currentIndex < tabList.length - 1) {
- // not last
- nextIndex = currentIndex + 1;
- } else {
- nextIndex = 0;
- }
- }
- tabList[nextIndex].focus(); // 改变焦点元素
- tabList[nextIndex].click(); // 选中下一个tab
- this.setFocus();
- },
- setFocus: function setFocus() {
- if (this.focusable) {
- this.isFocus = true;
- }
- },
- removeFocus: function removeFocus() {
- this.isFocus = false;
- },
- visibilityChangeHandler: function visibilityChangeHandler() {
- var _this = this;
- var visibility = document.visibilityState;
- if (visibility === 'hidden') {
- this.focusable = false;
- } else if (visibility === 'visible') {
- setTimeout(function () {
- _this.focusable = true;
- }, 50);
- }
- },
- windowBlurHandler: function windowBlurHandler() {
- this.focusable = false;
- },
- windowFocusHandler: function windowFocusHandler() {
- var _this2 = this;
- setTimeout(function () {
- _this2.focusable = true;
- }, 50);
- }
- },
- updated: function updated() {
- this.update();
- },
- render: function render(h) {
- var _this3 = this;
- var type = this.type,
- panes = this.panes,
- editable = this.editable,
- stretch = this.stretch,
- onTabClick = this.onTabClick,
- onTabRemove = this.onTabRemove,
- navStyle = this.navStyle,
- scrollable = this.scrollable,
- scrollNext = this.scrollNext,
- scrollPrev = this.scrollPrev,
- changeTab = this.changeTab,
- setFocus = this.setFocus,
- removeFocus = this.removeFocus;
- var scrollBtn = scrollable ? [h(
- 'span',
- { 'class': ['el-tabs__nav-prev', scrollable.prev ? '' : 'is-disabled'], on: {
- 'click': scrollPrev
- }
- },
- [h('i', { 'class': 'el-icon-arrow-left' })]
- ), h(
- 'span',
- { 'class': ['el-tabs__nav-next', scrollable.next ? '' : 'is-disabled'], on: {
- 'click': scrollNext
- }
- },
- [h('i', { 'class': 'el-icon-arrow-right' })]
- )] : null;
- var tabs = this._l(panes, function (pane, index) {
- var _ref;
- var tabName = pane.name || pane.index || index;
- var closable = pane.isClosable || editable;
- pane.index = '' + index;
- var btnClose = closable ? h('span', { 'class': 'el-icon-close', on: {
- 'click': function click(ev) {
- onTabRemove(pane, ev);
- }
- }
- }) : null;
- var tabLabelContent = pane.$slots.label || pane.label;
- var tabindex = pane.active ? 0 : -1;
- return h(
- 'div',
- {
- 'class': (_ref = {
- 'el-tabs__item': true
- }, _ref['is-' + _this3.rootTabs.tabPosition] = true, _ref['is-active'] = pane.active, _ref['is-disabled'] = pane.disabled, _ref['is-closable'] = closable, _ref['is-focus'] = _this3.isFocus, _ref),
- attrs: { id: 'tab-' + tabName,
- 'aria-controls': 'pane-' + tabName,
- role: 'tab',
- 'aria-selected': pane.active,
- tabindex: tabindex
- },
- key: 'tab-' + tabName, ref: 'tabs', refInFor: true,
- on: {
- 'focus': function focus() {
- setFocus();
- },
- 'blur': function blur() {
- removeFocus();
- },
- 'click': function click(ev) {
- removeFocus();onTabClick(pane, tabName, ev);
- },
- 'keydown': function keydown(ev) {
- if (closable && (ev.keyCode === 46 || ev.keyCode === 8)) {
- onTabRemove(pane, ev);
- }
- }
- }
- },
- [tabLabelContent, btnClose]
- );
- });
- return h(
- 'div',
- { 'class': ['el-tabs__nav-wrap', scrollable ? 'is-scrollable' : '', 'is-' + this.rootTabs.tabPosition] },
- [scrollBtn, h(
- 'div',
- { 'class': ['el-tabs__nav-scroll'], ref: 'navScroll' },
- [h(
- 'div',
- {
- 'class': ['el-tabs__nav', 'is-' + this.rootTabs.tabPosition, stretch && ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'is-stretch' : ''],
- ref: 'nav',
- style: navStyle,
- attrs: { role: 'tablist'
- },
- on: {
- 'keydown': changeTab
- }
- },
- [!type ? h('tab-bar', {
- attrs: { tabs: panes }
- }) : null, tabs]
- )]
- )]
- );
- },
- mounted: function mounted() {
- var _this4 = this;
- Object(resize_event_["addResizeListener"])(this.$el, this.update);
- document.addEventListener('visibilitychange', this.visibilityChangeHandler);
- window.addEventListener('blur', this.windowBlurHandler);
- window.addEventListener('focus', this.windowFocusHandler);
- setTimeout(function () {
- _this4.scrollToActiveTab();
- }, 0);
- },
- beforeDestroy: function beforeDestroy() {
- if (this.$el && this.update) Object(resize_event_["removeResizeListener"])(this.$el, this.update);
- document.removeEventListener('visibilitychange', this.visibilityChangeHandler);
- window.removeEventListener('blur', this.windowBlurHandler);
- window.removeEventListener('focus', this.windowFocusHandler);
- }
- });
- // CONCATENATED MODULE: ./packages/tabs/src/tab-nav.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_tab_navvue_type_script_lang_js_ = (tab_navvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/tabs/src/tab-nav.vue
- var tab_nav_render, tab_nav_staticRenderFns
- /* normalize component */
- var tab_nav_component = normalizeComponent(
- src_tab_navvue_type_script_lang_js_,
- tab_nav_render,
- tab_nav_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var tab_nav_api; }
- tab_nav_component.options.__file = "packages/tabs/src/tab-nav.vue"
- /* harmony default export */ var tab_nav = (tab_nav_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tabs.vue?vue&type=script&lang=js&
- /* harmony default export */ var tabsvue_type_script_lang_js_ = ({
- name: 'ElTabs',
- components: {
- TabNav: tab_nav
- },
- props: {
- type: String,
- activeName: String,
- closable: Boolean,
- addable: Boolean,
- value: {},
- editable: Boolean,
- tabPosition: {
- type: String,
- default: 'top'
- },
- beforeLeave: Function,
- stretch: Boolean
- },
- provide: function provide() {
- return {
- rootTabs: this
- };
- },
- data: function data() {
- return {
- currentName: this.value || this.activeName,
- panes: []
- };
- },
- watch: {
- activeName: function activeName(value) {
- this.setCurrentName(value);
- },
- value: function value(_value) {
- this.setCurrentName(_value);
- },
- currentName: function currentName(value) {
- var _this = this;
- if (this.$refs.nav) {
- this.$nextTick(function () {
- _this.$refs.nav.$nextTick(function (_) {
- _this.$refs.nav.scrollToActiveTab();
- });
- });
- }
- }
- },
- methods: {
- calcPaneInstances: function calcPaneInstances() {
- var _this2 = this;
- var isForceUpdate = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- if (this.$slots.default) {
- var paneSlots = this.$slots.default.filter(function (vnode) {
- return vnode.tag && vnode.componentOptions && vnode.componentOptions.Ctor.options.name === 'ElTabPane';
- });
- // update indeed
- var panes = paneSlots.map(function (_ref) {
- var componentInstance = _ref.componentInstance;
- return componentInstance;
- });
- var panesChanged = !(panes.length === this.panes.length && panes.every(function (pane, index) {
- return pane === _this2.panes[index];
- }));
- if (isForceUpdate || panesChanged) {
- this.panes = panes;
- }
- } else if (this.panes.length !== 0) {
- this.panes = [];
- }
- },
- handleTabClick: function handleTabClick(tab, tabName, event) {
- if (tab.disabled) return;
- this.setCurrentName(tabName);
- this.$emit('tab-click', tab, event);
- },
- handleTabRemove: function handleTabRemove(pane, ev) {
- if (pane.disabled) return;
- ev.stopPropagation();
- this.$emit('edit', pane.name, 'remove');
- this.$emit('tab-remove', pane.name);
- },
- handleTabAdd: function handleTabAdd() {
- this.$emit('edit', null, 'add');
- this.$emit('tab-add');
- },
- setCurrentName: function setCurrentName(value) {
- var _this3 = this;
- var changeCurrentName = function changeCurrentName() {
- _this3.currentName = value;
- _this3.$emit('input', value);
- };
- if (this.currentName !== value && this.beforeLeave) {
- var before = this.beforeLeave(value, this.currentName);
- if (before && before.then) {
- before.then(function () {
- changeCurrentName();
- _this3.$refs.nav && _this3.$refs.nav.removeFocus();
- }, function () {
- // https://github.com/ElemeFE/element/pull/14816
- // ignore promise rejection in `before-leave` hook
- });
- } else if (before !== false) {
- changeCurrentName();
- }
- } else {
- changeCurrentName();
- }
- }
- },
- render: function render(h) {
- var _ref2;
- var type = this.type,
- handleTabClick = this.handleTabClick,
- handleTabRemove = this.handleTabRemove,
- handleTabAdd = this.handleTabAdd,
- currentName = this.currentName,
- panes = this.panes,
- editable = this.editable,
- addable = this.addable,
- tabPosition = this.tabPosition,
- stretch = this.stretch;
- var newButton = editable || addable ? h(
- 'span',
- {
- 'class': 'el-tabs__new-tab',
- on: {
- 'click': handleTabAdd,
- 'keydown': function keydown(ev) {
- if (ev.keyCode === 13) {
- handleTabAdd();
- }
- }
- },
- attrs: {
- tabindex: '0'
- }
- },
- [h('i', { 'class': 'el-icon-plus' })]
- ) : null;
- var navData = {
- props: {
- currentName: currentName,
- onTabClick: handleTabClick,
- onTabRemove: handleTabRemove,
- editable: editable,
- type: type,
- panes: panes,
- stretch: stretch
- },
- ref: 'nav'
- };
- var header = h(
- 'div',
- { 'class': ['el-tabs__header', 'is-' + tabPosition] },
- [newButton, h('tab-nav', navData)]
- );
- var panels = h(
- 'div',
- { 'class': 'el-tabs__content' },
- [this.$slots.default]
- );
- return h(
- 'div',
- { 'class': (_ref2 = {
- 'el-tabs': true,
- 'el-tabs--card': type === 'card'
- }, _ref2['el-tabs--' + tabPosition] = true, _ref2['el-tabs--border-card'] = type === 'border-card', _ref2) },
- [tabPosition !== 'bottom' ? [header, panels] : [panels, header]]
- );
- },
- created: function created() {
- if (!this.currentName) {
- this.setCurrentName('0');
- }
- this.$on('tab-nav-update', this.calcPaneInstances.bind(null, true));
- },
- mounted: function mounted() {
- this.calcPaneInstances();
- },
- updated: function updated() {
- this.calcPaneInstances();
- }
- });
- // CONCATENATED MODULE: ./packages/tabs/src/tabs.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_tabsvue_type_script_lang_js_ = (tabsvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/tabs/src/tabs.vue
- var tabs_render, tabs_staticRenderFns
- /* normalize component */
- var tabs_component = normalizeComponent(
- src_tabsvue_type_script_lang_js_,
- tabs_render,
- tabs_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var tabs_api; }
- tabs_component.options.__file = "packages/tabs/src/tabs.vue"
- /* harmony default export */ var tabs = (tabs_component.exports);
- // CONCATENATED MODULE: ./packages/tabs/index.js
- /* istanbul ignore next */
- tabs.install = function (Vue) {
- Vue.component(tabs.name, tabs);
- };
- /* harmony default export */ var packages_tabs = (tabs);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-pane.vue?vue&type=template&id=9145a070&
- var tab_panevue_type_template_id_9145a070_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return !_vm.lazy || _vm.loaded || _vm.active
- ? _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.active,
- expression: "active"
- }
- ],
- staticClass: "el-tab-pane",
- attrs: {
- role: "tabpanel",
- "aria-hidden": !_vm.active,
- id: "pane-" + _vm.paneName,
- "aria-labelledby": "tab-" + _vm.paneName
- }
- },
- [_vm._t("default")],
- 2
- )
- : _vm._e()
- }
- var tab_panevue_type_template_id_9145a070_staticRenderFns = []
- tab_panevue_type_template_id_9145a070_render._withStripped = true
- // CONCATENATED MODULE: ./packages/tabs/src/tab-pane.vue?vue&type=template&id=9145a070&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-pane.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var tab_panevue_type_script_lang_js_ = ({
- name: 'ElTabPane',
- componentName: 'ElTabPane',
- props: {
- label: String,
- labelContent: Function,
- name: String,
- closable: Boolean,
- disabled: Boolean,
- lazy: Boolean
- },
- data: function data() {
- return {
- index: null,
- loaded: false
- };
- },
- computed: {
- isClosable: function isClosable() {
- return this.closable || this.$parent.closable;
- },
- active: function active() {
- var active = this.$parent.currentName === (this.name || this.index);
- if (active) {
- this.loaded = true;
- }
- return active;
- },
- paneName: function paneName() {
- return this.name || this.index;
- }
- },
- updated: function updated() {
- this.$parent.$emit('tab-nav-update');
- }
- });
- // CONCATENATED MODULE: ./packages/tabs/src/tab-pane.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_tab_panevue_type_script_lang_js_ = (tab_panevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/tabs/src/tab-pane.vue
- /* normalize component */
- var tab_pane_component = normalizeComponent(
- src_tab_panevue_type_script_lang_js_,
- tab_panevue_type_template_id_9145a070_render,
- tab_panevue_type_template_id_9145a070_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var tab_pane_api; }
- tab_pane_component.options.__file = "packages/tabs/src/tab-pane.vue"
- /* harmony default export */ var tab_pane = (tab_pane_component.exports);
- // CONCATENATED MODULE: ./packages/tab-pane/index.js
- /* istanbul ignore next */
- tab_pane.install = function (Vue) {
- Vue.component(tab_pane.name, tab_pane);
- };
- /* harmony default export */ var packages_tab_pane = (tab_pane);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tag/src/tag.vue?vue&type=script&lang=js&
- /* harmony default export */ var tagvue_type_script_lang_js_ = ({
- name: 'ElTag',
- props: {
- text: String,
- closable: Boolean,
- type: String,
- hit: Boolean,
- disableTransitions: Boolean,
- color: String,
- size: String,
- effect: {
- type: String,
- default: 'light',
- validator: function validator(val) {
- return ['dark', 'light', 'plain'].indexOf(val) !== -1;
- }
- }
- },
- methods: {
- handleClose: function handleClose(event) {
- event.stopPropagation();
- this.$emit('close', event);
- },
- handleClick: function handleClick(event) {
- this.$emit('click', event);
- }
- },
- computed: {
- tagSize: function tagSize() {
- return this.size || (this.$ELEMENT || {}).size;
- }
- },
- render: function render(h) {
- var type = this.type,
- tagSize = this.tagSize,
- hit = this.hit,
- effect = this.effect;
- var classes = ['el-tag', type ? 'el-tag--' + type : '', tagSize ? 'el-tag--' + tagSize : '', effect ? 'el-tag--' + effect : '', hit && 'is-hit'];
- var tagEl = h(
- 'span',
- {
- 'class': classes,
- style: { backgroundColor: this.color },
- on: {
- 'click': this.handleClick
- }
- },
- [this.$slots.default, this.closable && h('i', { 'class': 'el-tag__close el-icon-close', on: {
- 'click': this.handleClose
- }
- })]
- );
- return this.disableTransitions ? tagEl : h(
- 'transition',
- {
- attrs: { name: 'el-zoom-in-center' }
- },
- [tagEl]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/tag/src/tag.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_tagvue_type_script_lang_js_ = (tagvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/tag/src/tag.vue
- var tag_render, tag_staticRenderFns
- /* normalize component */
- var tag_component = normalizeComponent(
- src_tagvue_type_script_lang_js_,
- tag_render,
- tag_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var tag_api; }
- tag_component.options.__file = "packages/tag/src/tag.vue"
- /* harmony default export */ var src_tag = (tag_component.exports);
- // CONCATENATED MODULE: ./packages/tag/index.js
- /* istanbul ignore next */
- src_tag.install = function (Vue) {
- Vue.component(src_tag.name, src_tag);
- };
- /* harmony default export */ var packages_tag = (src_tag);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/tree/src/tree.vue?vue&type=template&id=547575a6&
- var treevue_type_template_id_547575a6_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-tree",
- class: {
- "el-tree--highlight-current": _vm.highlightCurrent,
- "is-dragging": !!_vm.dragState.draggingNode,
- "is-drop-not-allow": !_vm.dragState.allowDrop,
- "is-drop-inner": _vm.dragState.dropType === "inner"
- },
- attrs: { role: "tree" }
- },
- [
- _vm._l(_vm.root.childNodes, function(child) {
- return _c("el-tree-node", {
- key: _vm.getNodeKey(child),
- attrs: {
- node: child,
- props: _vm.props,
- "render-after-expand": _vm.renderAfterExpand,
- "show-checkbox": _vm.showCheckbox,
- "render-content": _vm.renderContent
- },
- on: { "node-expand": _vm.handleNodeExpand }
- })
- }),
- _vm.isEmpty
- ? _c("div", { staticClass: "el-tree__empty-block" }, [
- _c("span", { staticClass: "el-tree__empty-text" }, [
- _vm._v(_vm._s(_vm.emptyText))
- ])
- ])
- : _vm._e(),
- _c("div", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.dragState.showDropIndicator,
- expression: "dragState.showDropIndicator"
- }
- ],
- ref: "dropIndicator",
- staticClass: "el-tree__drop-indicator"
- })
- ],
- 2
- )
- }
- var treevue_type_template_id_547575a6_staticRenderFns = []
- treevue_type_template_id_547575a6_render._withStripped = true
- // CONCATENATED MODULE: ./packages/tree/src/tree.vue?vue&type=template&id=547575a6&
- // CONCATENATED MODULE: ./packages/tree/src/model/util.js
- var NODE_KEY = '$treeNodeId';
- var markNodeData = function markNodeData(node, data) {
- if (!data || data[NODE_KEY]) return;
- Object.defineProperty(data, NODE_KEY, {
- value: node.id,
- enumerable: false,
- configurable: false,
- writable: false
- });
- };
- var util_getNodeKey = function getNodeKey(key, data) {
- if (!key) return data[NODE_KEY];
- return data[key];
- };
- var findNearestComponent = function findNearestComponent(element, componentName) {
- var target = element;
- while (target && target.tagName !== 'BODY') {
- if (target.__vue__ && target.__vue__.$options.name === componentName) {
- return target.__vue__;
- }
- target = target.parentNode;
- }
- return null;
- };
- // CONCATENATED MODULE: ./packages/tree/src/model/node.js
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
- function node_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- var getChildState = function getChildState(node) {
- var all = true;
- var none = true;
- var allWithoutDisable = true;
- for (var i = 0, j = node.length; i < j; i++) {
- var n = node[i];
- if (n.checked !== true || n.indeterminate) {
- all = false;
- if (!n.disabled) {
- allWithoutDisable = false;
- }
- }
- if (n.checked !== false || n.indeterminate) {
- none = false;
- }
- }
- return { all: all, none: none, allWithoutDisable: allWithoutDisable, half: !all && !none };
- };
- var reInitChecked = function reInitChecked(node) {
- if (node.childNodes.length === 0 || node.loading) return;
- var _getChildState = getChildState(node.childNodes),
- all = _getChildState.all,
- none = _getChildState.none,
- half = _getChildState.half;
- if (all) {
- node.checked = true;
- node.indeterminate = false;
- } else if (half) {
- node.checked = false;
- node.indeterminate = true;
- } else if (none) {
- node.checked = false;
- node.indeterminate = false;
- }
- var parent = node.parent;
- if (!parent || parent.level === 0) return;
- if (!node.store.checkStrictly) {
- reInitChecked(parent);
- }
- };
- var getPropertyFromData = function getPropertyFromData(node, prop) {
- var props = node.store.props;
- var data = node.data || {};
- var config = props[prop];
- if (typeof config === 'function') {
- return config(data, node);
- } else if (typeof config === 'string') {
- return data[config];
- } else if (typeof config === 'undefined') {
- var dataProp = data[prop];
- return dataProp === undefined ? '' : dataProp;
- }
- };
- var nodeIdSeed = 0;
- var node_Node = function () {
- function Node(options) {
- node_classCallCheck(this, Node);
- this.id = nodeIdSeed++;
- this.text = null;
- this.checked = false;
- this.indeterminate = false;
- this.data = null;
- this.expanded = false;
- this.parent = null;
- this.visible = true;
- this.isCurrent = false;
- for (var name in options) {
- if (options.hasOwnProperty(name)) {
- this[name] = options[name];
- }
- }
- // internal
- this.level = 0;
- this.loaded = false;
- this.childNodes = [];
- this.loading = false;
- if (this.parent) {
- this.level = this.parent.level + 1;
- }
- var store = this.store;
- if (!store) {
- throw new Error('[Node]store is required!');
- }
- store.registerNode(this);
- var props = store.props;
- if (props && typeof props.isLeaf !== 'undefined') {
- var isLeaf = getPropertyFromData(this, 'isLeaf');
- if (typeof isLeaf === 'boolean') {
- this.isLeafByUser = isLeaf;
- }
- }
- if (store.lazy !== true && this.data) {
- this.setData(this.data);
- if (store.defaultExpandAll) {
- this.expanded = true;
- }
- } else if (this.level > 0 && store.lazy && store.defaultExpandAll) {
- this.expand();
- }
- if (!Array.isArray(this.data)) {
- markNodeData(this, this.data);
- }
- if (!this.data) return;
- var defaultExpandedKeys = store.defaultExpandedKeys;
- var key = store.key;
- if (key && defaultExpandedKeys && defaultExpandedKeys.indexOf(this.key) !== -1) {
- this.expand(null, store.autoExpandParent);
- }
- if (key && store.currentNodeKey !== undefined && this.key === store.currentNodeKey) {
- store.currentNode = this;
- store.currentNode.isCurrent = true;
- }
- if (store.lazy) {
- store._initDefaultCheckedNode(this);
- }
- this.updateLeafState();
- }
- Node.prototype.setData = function setData(data) {
- if (!Array.isArray(data)) {
- markNodeData(this, data);
- }
- this.data = data;
- this.childNodes = [];
- var children = void 0;
- if (this.level === 0 && this.data instanceof Array) {
- children = this.data;
- } else {
- children = getPropertyFromData(this, 'children') || [];
- }
- for (var i = 0, j = children.length; i < j; i++) {
- this.insertChild({ data: children[i] });
- }
- };
- Node.prototype.contains = function contains(target) {
- var deep = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
- var walk = function walk(parent) {
- var children = parent.childNodes || [];
- var result = false;
- for (var i = 0, j = children.length; i < j; i++) {
- var child = children[i];
- if (child === target || deep && walk(child)) {
- result = true;
- break;
- }
- }
- return result;
- };
- return walk(this);
- };
- Node.prototype.remove = function remove() {
- var parent = this.parent;
- if (parent) {
- parent.removeChild(this);
- }
- };
- Node.prototype.insertChild = function insertChild(child, index, batch) {
- if (!child) throw new Error('insertChild error: child is required.');
- if (!(child instanceof Node)) {
- if (!batch) {
- var children = this.getChildren(true) || [];
- if (children.indexOf(child.data) === -1) {
- if (typeof index === 'undefined' || index < 0) {
- children.push(child.data);
- } else {
- children.splice(index, 0, child.data);
- }
- }
- }
- merge_default()(child, {
- parent: this,
- store: this.store
- });
- child = new Node(child);
- }
- child.level = this.level + 1;
- if (typeof index === 'undefined' || index < 0) {
- this.childNodes.push(child);
- } else {
- this.childNodes.splice(index, 0, child);
- }
- this.updateLeafState();
- };
- Node.prototype.insertBefore = function insertBefore(child, ref) {
- var index = void 0;
- if (ref) {
- index = this.childNodes.indexOf(ref);
- }
- this.insertChild(child, index);
- };
- Node.prototype.insertAfter = function insertAfter(child, ref) {
- var index = void 0;
- if (ref) {
- index = this.childNodes.indexOf(ref);
- if (index !== -1) index += 1;
- }
- this.insertChild(child, index);
- };
- Node.prototype.removeChild = function removeChild(child) {
- var children = this.getChildren() || [];
- var dataIndex = children.indexOf(child.data);
- if (dataIndex > -1) {
- children.splice(dataIndex, 1);
- }
- var index = this.childNodes.indexOf(child);
- if (index > -1) {
- this.store && this.store.deregisterNode(child);
- child.parent = null;
- this.childNodes.splice(index, 1);
- }
- this.updateLeafState();
- };
- Node.prototype.removeChildByData = function removeChildByData(data) {
- var targetNode = null;
- for (var i = 0; i < this.childNodes.length; i++) {
- if (this.childNodes[i].data === data) {
- targetNode = this.childNodes[i];
- break;
- }
- }
- if (targetNode) {
- this.removeChild(targetNode);
- }
- };
- Node.prototype.expand = function expand(callback, expandParent) {
- var _this = this;
- var done = function done() {
- if (expandParent) {
- var parent = _this.parent;
- while (parent.level > 0) {
- parent.expanded = true;
- parent = parent.parent;
- }
- }
- _this.expanded = true;
- if (callback) callback();
- };
- if (this.shouldLoadData()) {
- this.loadData(function (data) {
- if (data instanceof Array) {
- if (_this.checked) {
- _this.setChecked(true, true);
- } else if (!_this.store.checkStrictly) {
- reInitChecked(_this);
- }
- done();
- }
- });
- } else {
- done();
- }
- };
- Node.prototype.doCreateChildren = function doCreateChildren(array) {
- var _this2 = this;
- var defaultProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
- array.forEach(function (item) {
- _this2.insertChild(merge_default()({ data: item }, defaultProps), undefined, true);
- });
- };
- Node.prototype.collapse = function collapse() {
- this.expanded = false;
- };
- Node.prototype.shouldLoadData = function shouldLoadData() {
- return this.store.lazy === true && this.store.load && !this.loaded;
- };
- Node.prototype.updateLeafState = function updateLeafState() {
- if (this.store.lazy === true && this.loaded !== true && typeof this.isLeafByUser !== 'undefined') {
- this.isLeaf = this.isLeafByUser;
- return;
- }
- var childNodes = this.childNodes;
- if (!this.store.lazy || this.store.lazy === true && this.loaded === true) {
- this.isLeaf = !childNodes || childNodes.length === 0;
- return;
- }
- this.isLeaf = false;
- };
- Node.prototype.setChecked = function setChecked(value, deep, recursion, passValue) {
- var _this3 = this;
- this.indeterminate = value === 'half';
- this.checked = value === true;
- if (this.store.checkStrictly) return;
- if (!(this.shouldLoadData() && !this.store.checkDescendants)) {
- var _getChildState2 = getChildState(this.childNodes),
- all = _getChildState2.all,
- allWithoutDisable = _getChildState2.allWithoutDisable;
- if (!this.isLeaf && !all && allWithoutDisable) {
- this.checked = false;
- value = false;
- }
- var handleDescendants = function handleDescendants() {
- if (deep) {
- var childNodes = _this3.childNodes;
- for (var i = 0, j = childNodes.length; i < j; i++) {
- var child = childNodes[i];
- passValue = passValue || value !== false;
- var isCheck = child.disabled ? child.checked : passValue;
- child.setChecked(isCheck, deep, true, passValue);
- }
- var _getChildState3 = getChildState(childNodes),
- half = _getChildState3.half,
- _all = _getChildState3.all;
- if (!_all) {
- _this3.checked = _all;
- _this3.indeterminate = half;
- }
- }
- };
- if (this.shouldLoadData()) {
- // Only work on lazy load data.
- this.loadData(function () {
- handleDescendants();
- reInitChecked(_this3);
- }, {
- checked: value !== false
- });
- return;
- } else {
- handleDescendants();
- }
- }
- var parent = this.parent;
- if (!parent || parent.level === 0) return;
- if (!recursion) {
- reInitChecked(parent);
- }
- };
- Node.prototype.getChildren = function getChildren() {
- var forceInit = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- // this is data
- if (this.level === 0) return this.data;
- var data = this.data;
- if (!data) return null;
- var props = this.store.props;
- var children = 'children';
- if (props) {
- children = props.children || 'children';
- }
- if (data[children] === undefined) {
- data[children] = null;
- }
- if (forceInit && !data[children]) {
- data[children] = [];
- }
- return data[children];
- };
- Node.prototype.updateChildren = function updateChildren() {
- var _this4 = this;
- var newData = this.getChildren() || [];
- var oldData = this.childNodes.map(function (node) {
- return node.data;
- });
- var newDataMap = {};
- var newNodes = [];
- newData.forEach(function (item, index) {
- var key = item[NODE_KEY];
- var isNodeExists = !!key && Object(util_["arrayFindIndex"])(oldData, function (data) {
- return data[NODE_KEY] === key;
- }) >= 0;
- if (isNodeExists) {
- newDataMap[key] = { index: index, data: item };
- } else {
- newNodes.push({ index: index, data: item });
- }
- });
- if (!this.store.lazy) {
- oldData.forEach(function (item) {
- if (!newDataMap[item[NODE_KEY]]) _this4.removeChildByData(item);
- });
- }
- newNodes.forEach(function (_ref) {
- var index = _ref.index,
- data = _ref.data;
- _this4.insertChild({ data: data }, index);
- });
- this.updateLeafState();
- };
- Node.prototype.loadData = function loadData(callback) {
- var _this5 = this;
- var defaultProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
- if (this.store.lazy === true && this.store.load && !this.loaded && (!this.loading || Object.keys(defaultProps).length)) {
- this.loading = true;
- var resolve = function resolve(children) {
- _this5.childNodes = [];
- _this5.doCreateChildren(children, defaultProps);
- _this5.loaded = true;
- _this5.loading = false;
- _this5.updateLeafState();
- if (callback) {
- callback.call(_this5, children);
- }
- };
- this.store.load(this, resolve);
- } else {
- if (callback) {
- callback.call(this);
- }
- }
- };
- _createClass(Node, [{
- key: 'label',
- get: function get() {
- return getPropertyFromData(this, 'label');
- }
- }, {
- key: 'key',
- get: function get() {
- var nodeKey = this.store.key;
- if (this.data) return this.data[nodeKey];
- return null;
- }
- }, {
- key: 'disabled',
- get: function get() {
- return getPropertyFromData(this, 'disabled');
- }
- }, {
- key: 'nextSibling',
- get: function get() {
- var parent = this.parent;
- if (parent) {
- var index = parent.childNodes.indexOf(this);
- if (index > -1) {
- return parent.childNodes[index + 1];
- }
- }
- return null;
- }
- }, {
- key: 'previousSibling',
- get: function get() {
- var parent = this.parent;
- if (parent) {
- var index = parent.childNodes.indexOf(this);
- if (index > -1) {
- return index > 0 ? parent.childNodes[index - 1] : null;
- }
- }
- return null;
- }
- }]);
- return Node;
- }();
- /* harmony default export */ var model_node = (node_Node);
- // CONCATENATED MODULE: ./packages/tree/src/model/tree-store.js
- var tree_store_typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- function tree_store_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- var tree_store_TreeStore = function () {
- function TreeStore(options) {
- var _this = this;
- tree_store_classCallCheck(this, TreeStore);
- this.currentNode = null;
- this.currentNodeKey = null;
- for (var option in options) {
- if (options.hasOwnProperty(option)) {
- this[option] = options[option];
- }
- }
- this.nodesMap = {};
- this.root = new model_node({
- data: this.data,
- store: this
- });
- if (this.lazy && this.load) {
- var loadFn = this.load;
- loadFn(this.root, function (data) {
- _this.root.doCreateChildren(data);
- _this._initDefaultCheckedNodes();
- });
- } else {
- this._initDefaultCheckedNodes();
- }
- }
- TreeStore.prototype.filter = function filter(value) {
- var filterNodeMethod = this.filterNodeMethod;
- var lazy = this.lazy;
- var traverse = function traverse(node) {
- var childNodes = node.root ? node.root.childNodes : node.childNodes;
- childNodes.forEach(function (child) {
- child.visible = filterNodeMethod.call(child, value, child.data, child);
- traverse(child);
- });
- if (!node.visible && childNodes.length) {
- var allHidden = true;
- allHidden = !childNodes.some(function (child) {
- return child.visible;
- });
- if (node.root) {
- node.root.visible = allHidden === false;
- } else {
- node.visible = allHidden === false;
- }
- }
- if (!value) return;
- if (node.visible && !node.isLeaf && !lazy) node.expand();
- };
- traverse(this);
- };
- TreeStore.prototype.setData = function setData(newVal) {
- var instanceChanged = newVal !== this.root.data;
- if (instanceChanged) {
- this.root.setData(newVal);
- this._initDefaultCheckedNodes();
- } else {
- this.root.updateChildren();
- }
- };
- TreeStore.prototype.getNode = function getNode(data) {
- if (data instanceof model_node) return data;
- var key = (typeof data === 'undefined' ? 'undefined' : tree_store_typeof(data)) !== 'object' ? data : util_getNodeKey(this.key, data);
- return this.nodesMap[key] || null;
- };
- TreeStore.prototype.insertBefore = function insertBefore(data, refData) {
- var refNode = this.getNode(refData);
- refNode.parent.insertBefore({ data: data }, refNode);
- };
- TreeStore.prototype.insertAfter = function insertAfter(data, refData) {
- var refNode = this.getNode(refData);
- refNode.parent.insertAfter({ data: data }, refNode);
- };
- TreeStore.prototype.remove = function remove(data) {
- var node = this.getNode(data);
- if (node && node.parent) {
- if (node === this.currentNode) {
- this.currentNode = null;
- }
- node.parent.removeChild(node);
- }
- };
- TreeStore.prototype.append = function append(data, parentData) {
- var parentNode = parentData ? this.getNode(parentData) : this.root;
- if (parentNode) {
- parentNode.insertChild({ data: data });
- }
- };
- TreeStore.prototype._initDefaultCheckedNodes = function _initDefaultCheckedNodes() {
- var _this2 = this;
- var defaultCheckedKeys = this.defaultCheckedKeys || [];
- var nodesMap = this.nodesMap;
- defaultCheckedKeys.forEach(function (checkedKey) {
- var node = nodesMap[checkedKey];
- if (node) {
- node.setChecked(true, !_this2.checkStrictly);
- }
- });
- };
- TreeStore.prototype._initDefaultCheckedNode = function _initDefaultCheckedNode(node) {
- var defaultCheckedKeys = this.defaultCheckedKeys || [];
- if (defaultCheckedKeys.indexOf(node.key) !== -1) {
- node.setChecked(true, !this.checkStrictly);
- }
- };
- TreeStore.prototype.setDefaultCheckedKey = function setDefaultCheckedKey(newVal) {
- if (newVal !== this.defaultCheckedKeys) {
- this.defaultCheckedKeys = newVal;
- this._initDefaultCheckedNodes();
- }
- };
- TreeStore.prototype.registerNode = function registerNode(node) {
- var key = this.key;
- if (!key || !node || !node.data) return;
- var nodeKey = node.key;
- if (nodeKey !== undefined) this.nodesMap[node.key] = node;
- };
- TreeStore.prototype.deregisterNode = function deregisterNode(node) {
- var _this3 = this;
- var key = this.key;
- if (!key || !node || !node.data) return;
- node.childNodes.forEach(function (child) {
- _this3.deregisterNode(child);
- });
- delete this.nodesMap[node.key];
- };
- TreeStore.prototype.getCheckedNodes = function getCheckedNodes() {
- var leafOnly = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- var includeHalfChecked = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
- var checkedNodes = [];
- var traverse = function traverse(node) {
- var childNodes = node.root ? node.root.childNodes : node.childNodes;
- childNodes.forEach(function (child) {
- if ((child.checked || includeHalfChecked && child.indeterminate) && (!leafOnly || leafOnly && child.isLeaf)) {
- checkedNodes.push(child.data);
- }
- traverse(child);
- });
- };
- traverse(this);
- return checkedNodes;
- };
- TreeStore.prototype.getCheckedKeys = function getCheckedKeys() {
- var _this4 = this;
- var leafOnly = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- return this.getCheckedNodes(leafOnly).map(function (data) {
- return (data || {})[_this4.key];
- });
- };
- TreeStore.prototype.getHalfCheckedNodes = function getHalfCheckedNodes() {
- var nodes = [];
- var traverse = function traverse(node) {
- var childNodes = node.root ? node.root.childNodes : node.childNodes;
- childNodes.forEach(function (child) {
- if (child.indeterminate) {
- nodes.push(child.data);
- }
- traverse(child);
- });
- };
- traverse(this);
- return nodes;
- };
- TreeStore.prototype.getHalfCheckedKeys = function getHalfCheckedKeys() {
- var _this5 = this;
- return this.getHalfCheckedNodes().map(function (data) {
- return (data || {})[_this5.key];
- });
- };
- TreeStore.prototype._getAllNodes = function _getAllNodes() {
- var allNodes = [];
- var nodesMap = this.nodesMap;
- for (var nodeKey in nodesMap) {
- if (nodesMap.hasOwnProperty(nodeKey)) {
- allNodes.push(nodesMap[nodeKey]);
- }
- }
- return allNodes;
- };
- TreeStore.prototype.updateChildren = function updateChildren(key, data) {
- var node = this.nodesMap[key];
- if (!node) return;
- var childNodes = node.childNodes;
- for (var i = childNodes.length - 1; i >= 0; i--) {
- var child = childNodes[i];
- this.remove(child.data);
- }
- for (var _i = 0, j = data.length; _i < j; _i++) {
- var _child = data[_i];
- this.append(_child, node.data);
- }
- };
- TreeStore.prototype._setCheckedKeys = function _setCheckedKeys(key) {
- var leafOnly = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
- var checkedKeys = arguments[2];
- var allNodes = this._getAllNodes().sort(function (a, b) {
- return b.level - a.level;
- });
- var cache = Object.create(null);
- var keys = Object.keys(checkedKeys);
- allNodes.forEach(function (node) {
- return node.setChecked(false, false);
- });
- for (var i = 0, j = allNodes.length; i < j; i++) {
- var node = allNodes[i];
- var nodeKey = node.data[key].toString();
- var checked = keys.indexOf(nodeKey) > -1;
- if (!checked) {
- if (node.checked && !cache[nodeKey]) {
- node.setChecked(false, false);
- }
- continue;
- }
- var parent = node.parent;
- while (parent && parent.level > 0) {
- cache[parent.data[key]] = true;
- parent = parent.parent;
- }
- if (node.isLeaf || this.checkStrictly) {
- node.setChecked(true, false);
- continue;
- }
- node.setChecked(true, true);
- if (leafOnly) {
- (function () {
- node.setChecked(false, false);
- var traverse = function traverse(node) {
- var childNodes = node.childNodes;
- childNodes.forEach(function (child) {
- if (!child.isLeaf) {
- child.setChecked(false, false);
- }
- traverse(child);
- });
- };
- traverse(node);
- })();
- }
- }
- };
- TreeStore.prototype.setCheckedNodes = function setCheckedNodes(array) {
- var leafOnly = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
- var key = this.key;
- var checkedKeys = {};
- array.forEach(function (item) {
- checkedKeys[(item || {})[key]] = true;
- });
- this._setCheckedKeys(key, leafOnly, checkedKeys);
- };
- TreeStore.prototype.setCheckedKeys = function setCheckedKeys(keys) {
- var leafOnly = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
- this.defaultCheckedKeys = keys;
- var key = this.key;
- var checkedKeys = {};
- keys.forEach(function (key) {
- checkedKeys[key] = true;
- });
- this._setCheckedKeys(key, leafOnly, checkedKeys);
- };
- TreeStore.prototype.setDefaultExpandedKeys = function setDefaultExpandedKeys(keys) {
- var _this6 = this;
- keys = keys || [];
- this.defaultExpandedKeys = keys;
- keys.forEach(function (key) {
- var node = _this6.getNode(key);
- if (node) node.expand(null, _this6.autoExpandParent);
- });
- };
- TreeStore.prototype.setChecked = function setChecked(data, checked, deep) {
- var node = this.getNode(data);
- if (node) {
- node.setChecked(!!checked, deep);
- }
- };
- TreeStore.prototype.getCurrentNode = function getCurrentNode() {
- return this.currentNode;
- };
- TreeStore.prototype.setCurrentNode = function setCurrentNode(currentNode) {
- var prevCurrentNode = this.currentNode;
- if (prevCurrentNode) {
- prevCurrentNode.isCurrent = false;
- }
- this.currentNode = currentNode;
- this.currentNode.isCurrent = true;
- };
- TreeStore.prototype.setUserCurrentNode = function setUserCurrentNode(node) {
- var key = node[this.key];
- var currNode = this.nodesMap[key];
- this.setCurrentNode(currNode);
- };
- TreeStore.prototype.setCurrentNodeKey = function setCurrentNodeKey(key) {
- if (key === null || key === undefined) {
- this.currentNode && (this.currentNode.isCurrent = false);
- this.currentNode = null;
- return;
- }
- var node = this.getNode(key);
- if (node) {
- this.setCurrentNode(node);
- }
- };
- return TreeStore;
- }();
- /* harmony default export */ var tree_store = (tree_store_TreeStore);
- ;
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/tree/src/tree-node.vue?vue&type=template&id=3ba3ef0e&
- var tree_nodevue_type_template_id_3ba3ef0e_render = function() {
- var this$1 = this
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.node.visible,
- expression: "node.visible"
- }
- ],
- ref: "node",
- staticClass: "el-tree-node",
- class: {
- "is-expanded": _vm.expanded,
- "is-current": _vm.node.isCurrent,
- "is-hidden": !_vm.node.visible,
- "is-focusable": !_vm.node.disabled,
- "is-checked": !_vm.node.disabled && _vm.node.checked
- },
- attrs: {
- role: "treeitem",
- tabindex: "-1",
- "aria-expanded": _vm.expanded,
- "aria-disabled": _vm.node.disabled,
- "aria-checked": _vm.node.checked,
- draggable: _vm.tree.draggable
- },
- on: {
- click: function($event) {
- $event.stopPropagation()
- return _vm.handleClick($event)
- },
- contextmenu: function($event) {
- return this$1.handleContextMenu($event)
- },
- dragstart: function($event) {
- $event.stopPropagation()
- return _vm.handleDragStart($event)
- },
- dragover: function($event) {
- $event.stopPropagation()
- return _vm.handleDragOver($event)
- },
- dragend: function($event) {
- $event.stopPropagation()
- return _vm.handleDragEnd($event)
- },
- drop: function($event) {
- $event.stopPropagation()
- return _vm.handleDrop($event)
- }
- }
- },
- [
- _c(
- "div",
- {
- staticClass: "el-tree-node__content",
- style: {
- "padding-left": (_vm.node.level - 1) * _vm.tree.indent + "px"
- }
- },
- [
- _c("span", {
- class: [
- {
- "is-leaf": _vm.node.isLeaf,
- expanded: !_vm.node.isLeaf && _vm.expanded
- },
- "el-tree-node__expand-icon",
- _vm.tree.iconClass ? _vm.tree.iconClass : "el-icon-caret-right"
- ],
- on: {
- click: function($event) {
- $event.stopPropagation()
- return _vm.handleExpandIconClick($event)
- }
- }
- }),
- _vm.showCheckbox
- ? _c("el-checkbox", {
- attrs: {
- indeterminate: _vm.node.indeterminate,
- disabled: !!_vm.node.disabled
- },
- on: { change: _vm.handleCheckChange },
- nativeOn: {
- click: function($event) {
- $event.stopPropagation()
- }
- },
- model: {
- value: _vm.node.checked,
- callback: function($$v) {
- _vm.$set(_vm.node, "checked", $$v)
- },
- expression: "node.checked"
- }
- })
- : _vm._e(),
- _vm.node.loading
- ? _c("span", {
- staticClass: "el-tree-node__loading-icon el-icon-loading"
- })
- : _vm._e(),
- _c("node-content", { attrs: { node: _vm.node } })
- ],
- 1
- ),
- _c("el-collapse-transition", [
- !_vm.renderAfterExpand || _vm.childNodeRendered
- ? _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.expanded,
- expression: "expanded"
- }
- ],
- staticClass: "el-tree-node__children",
- attrs: { role: "group", "aria-expanded": _vm.expanded }
- },
- _vm._l(_vm.node.childNodes, function(child) {
- return _c("el-tree-node", {
- key: _vm.getNodeKey(child),
- attrs: {
- "render-content": _vm.renderContent,
- "render-after-expand": _vm.renderAfterExpand,
- "show-checkbox": _vm.showCheckbox,
- node: child
- },
- on: { "node-expand": _vm.handleChildNodeExpand }
- })
- }),
- 1
- )
- : _vm._e()
- ])
- ],
- 1
- )
- }
- var tree_nodevue_type_template_id_3ba3ef0e_staticRenderFns = []
- tree_nodevue_type_template_id_3ba3ef0e_render._withStripped = true
- // CONCATENATED MODULE: ./packages/tree/src/tree-node.vue?vue&type=template&id=3ba3ef0e&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tree/src/tree-node.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var tree_nodevue_type_script_lang_js_ = ({
- name: 'ElTreeNode',
- componentName: 'ElTreeNode',
- mixins: [emitter_default.a],
- props: {
- node: {
- default: function _default() {
- return {};
- }
- },
- props: {},
- renderContent: Function,
- renderAfterExpand: {
- type: Boolean,
- default: true
- },
- showCheckbox: {
- type: Boolean,
- default: false
- }
- },
- components: {
- ElCollapseTransition: collapse_transition_default.a,
- ElCheckbox: checkbox_default.a,
- NodeContent: {
- props: {
- node: {
- required: true
- }
- },
- render: function render(h) {
- var parent = this.$parent;
- var tree = parent.tree;
- var node = this.node;
- var data = node.data,
- store = node.store;
- return parent.renderContent ? parent.renderContent.call(parent._renderProxy, h, { _self: tree.$vnode.context, node: node, data: data, store: store }) : tree.$scopedSlots.default ? tree.$scopedSlots.default({ node: node, data: data }) : h(
- 'span',
- { 'class': 'el-tree-node__label' },
- [node.label]
- );
- }
- }
- },
- data: function data() {
- return {
- tree: null,
- expanded: false,
- childNodeRendered: false,
- oldChecked: null,
- oldIndeterminate: null
- };
- },
- watch: {
- 'node.indeterminate': function nodeIndeterminate(val) {
- this.handleSelectChange(this.node.checked, val);
- },
- 'node.checked': function nodeChecked(val) {
- this.handleSelectChange(val, this.node.indeterminate);
- },
- 'node.expanded': function nodeExpanded(val) {
- var _this = this;
- this.$nextTick(function () {
- return _this.expanded = val;
- });
- if (val) {
- this.childNodeRendered = true;
- }
- }
- },
- methods: {
- getNodeKey: function getNodeKey(node) {
- return util_getNodeKey(this.tree.nodeKey, node.data);
- },
- handleSelectChange: function handleSelectChange(checked, indeterminate) {
- if (this.oldChecked !== checked && this.oldIndeterminate !== indeterminate) {
- this.tree.$emit('check-change', this.node.data, checked, indeterminate);
- }
- this.oldChecked = checked;
- this.indeterminate = indeterminate;
- },
- handleClick: function handleClick() {
- var store = this.tree.store;
- store.setCurrentNode(this.node);
- this.tree.$emit('current-change', store.currentNode ? store.currentNode.data : null, store.currentNode);
- this.tree.currentNode = this;
- if (this.tree.expandOnClickNode) {
- this.handleExpandIconClick();
- }
- if (this.tree.checkOnClickNode && !this.node.disabled) {
- this.handleCheckChange(null, {
- target: { checked: !this.node.checked }
- });
- }
- this.tree.$emit('node-click', this.node.data, this.node, this);
- },
- handleContextMenu: function handleContextMenu(event) {
- if (this.tree._events['node-contextmenu'] && this.tree._events['node-contextmenu'].length > 0) {
- event.stopPropagation();
- event.preventDefault();
- }
- this.tree.$emit('node-contextmenu', event, this.node.data, this.node, this);
- },
- handleExpandIconClick: function handleExpandIconClick() {
- if (this.node.isLeaf) return;
- if (this.expanded) {
- this.tree.$emit('node-collapse', this.node.data, this.node, this);
- this.node.collapse();
- } else {
- this.node.expand();
- this.$emit('node-expand', this.node.data, this.node, this);
- }
- },
- handleCheckChange: function handleCheckChange(value, ev) {
- var _this2 = this;
- this.node.setChecked(ev.target.checked, !this.tree.checkStrictly);
- this.$nextTick(function () {
- var store = _this2.tree.store;
- _this2.tree.$emit('check', _this2.node.data, {
- checkedNodes: store.getCheckedNodes(),
- checkedKeys: store.getCheckedKeys(),
- halfCheckedNodes: store.getHalfCheckedNodes(),
- halfCheckedKeys: store.getHalfCheckedKeys()
- });
- });
- },
- handleChildNodeExpand: function handleChildNodeExpand(nodeData, node, instance) {
- this.broadcast('ElTreeNode', 'tree-node-expand', node);
- this.tree.$emit('node-expand', nodeData, node, instance);
- },
- handleDragStart: function handleDragStart(event) {
- if (!this.tree.draggable) return;
- this.tree.$emit('tree-node-drag-start', event, this);
- },
- handleDragOver: function handleDragOver(event) {
- if (!this.tree.draggable) return;
- this.tree.$emit('tree-node-drag-over', event, this);
- event.preventDefault();
- },
- handleDrop: function handleDrop(event) {
- event.preventDefault();
- },
- handleDragEnd: function handleDragEnd(event) {
- if (!this.tree.draggable) return;
- this.tree.$emit('tree-node-drag-end', event, this);
- }
- },
- created: function created() {
- var _this3 = this;
- var parent = this.$parent;
- if (parent.isTree) {
- this.tree = parent;
- } else {
- this.tree = parent.tree;
- }
- var tree = this.tree;
- if (!tree) {
- console.warn('Can not find node\'s tree.');
- }
- var props = tree.props || {};
- var childrenKey = props['children'] || 'children';
- this.$watch('node.data.' + childrenKey, function () {
- _this3.node.updateChildren();
- });
- if (this.node.expanded) {
- this.expanded = true;
- this.childNodeRendered = true;
- }
- if (this.tree.accordion) {
- this.$on('tree-node-expand', function (node) {
- if (_this3.node !== node) {
- _this3.node.collapse();
- }
- });
- }
- }
- });
- // CONCATENATED MODULE: ./packages/tree/src/tree-node.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_tree_nodevue_type_script_lang_js_ = (tree_nodevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/tree/src/tree-node.vue
- /* normalize component */
- var tree_node_component = normalizeComponent(
- src_tree_nodevue_type_script_lang_js_,
- tree_nodevue_type_template_id_3ba3ef0e_render,
- tree_nodevue_type_template_id_3ba3ef0e_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var tree_node_api; }
- tree_node_component.options.__file = "packages/tree/src/tree-node.vue"
- /* harmony default export */ var tree_node = (tree_node_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tree/src/tree.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var treevue_type_script_lang_js_ = ({
- name: 'ElTree',
- mixins: [emitter_default.a],
- components: {
- ElTreeNode: tree_node
- },
- data: function data() {
- return {
- store: null,
- root: null,
- currentNode: null,
- treeItems: null,
- checkboxItems: [],
- dragState: {
- showDropIndicator: false,
- draggingNode: null,
- dropNode: null,
- allowDrop: true
- }
- };
- },
- props: {
- data: {
- type: Array
- },
- emptyText: {
- type: String,
- default: function _default() {
- return Object(lib_locale_["t"])('el.tree.emptyText');
- }
- },
- renderAfterExpand: {
- type: Boolean,
- default: true
- },
- nodeKey: String,
- checkStrictly: Boolean,
- defaultExpandAll: Boolean,
- expandOnClickNode: {
- type: Boolean,
- default: true
- },
- checkOnClickNode: Boolean,
- checkDescendants: {
- type: Boolean,
- default: false
- },
- autoExpandParent: {
- type: Boolean,
- default: true
- },
- defaultCheckedKeys: Array,
- defaultExpandedKeys: Array,
- currentNodeKey: [String, Number],
- renderContent: Function,
- showCheckbox: {
- type: Boolean,
- default: false
- },
- draggable: {
- type: Boolean,
- default: false
- },
- allowDrag: Function,
- allowDrop: Function,
- props: {
- default: function _default() {
- return {
- children: 'children',
- label: 'label',
- disabled: 'disabled'
- };
- }
- },
- lazy: {
- type: Boolean,
- default: false
- },
- highlightCurrent: Boolean,
- load: Function,
- filterNodeMethod: Function,
- accordion: Boolean,
- indent: {
- type: Number,
- default: 18
- },
- iconClass: String
- },
- computed: {
- children: {
- set: function set(value) {
- this.data = value;
- },
- get: function get() {
- return this.data;
- }
- },
- treeItemArray: function treeItemArray() {
- return Array.prototype.slice.call(this.treeItems);
- },
- isEmpty: function isEmpty() {
- var childNodes = this.root.childNodes;
- return !childNodes || childNodes.length === 0 || childNodes.every(function (_ref) {
- var visible = _ref.visible;
- return !visible;
- });
- }
- },
- watch: {
- defaultCheckedKeys: function defaultCheckedKeys(newVal) {
- this.store.setDefaultCheckedKey(newVal);
- },
- defaultExpandedKeys: function defaultExpandedKeys(newVal) {
- this.store.defaultExpandedKeys = newVal;
- this.store.setDefaultExpandedKeys(newVal);
- },
- data: function data(newVal) {
- this.store.setData(newVal);
- },
- checkboxItems: function checkboxItems(val) {
- Array.prototype.forEach.call(val, function (checkbox) {
- checkbox.setAttribute('tabindex', -1);
- });
- },
- checkStrictly: function checkStrictly(newVal) {
- this.store.checkStrictly = newVal;
- }
- },
- methods: {
- filter: function filter(value) {
- if (!this.filterNodeMethod) throw new Error('[Tree] filterNodeMethod is required when filter');
- this.store.filter(value);
- },
- getNodeKey: function getNodeKey(node) {
- return util_getNodeKey(this.nodeKey, node.data);
- },
- getNodePath: function getNodePath(data) {
- if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in getNodePath');
- var node = this.store.getNode(data);
- if (!node) return [];
- var path = [node.data];
- var parent = node.parent;
- while (parent && parent !== this.root) {
- path.push(parent.data);
- parent = parent.parent;
- }
- return path.reverse();
- },
- getCheckedNodes: function getCheckedNodes(leafOnly, includeHalfChecked) {
- return this.store.getCheckedNodes(leafOnly, includeHalfChecked);
- },
- getCheckedKeys: function getCheckedKeys(leafOnly) {
- return this.store.getCheckedKeys(leafOnly);
- },
- getCurrentNode: function getCurrentNode() {
- var currentNode = this.store.getCurrentNode();
- return currentNode ? currentNode.data : null;
- },
- getCurrentKey: function getCurrentKey() {
- if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in getCurrentKey');
- var currentNode = this.getCurrentNode();
- return currentNode ? currentNode[this.nodeKey] : null;
- },
- setCheckedNodes: function setCheckedNodes(nodes, leafOnly) {
- if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCheckedNodes');
- this.store.setCheckedNodes(nodes, leafOnly);
- },
- setCheckedKeys: function setCheckedKeys(keys, leafOnly) {
- if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCheckedKeys');
- this.store.setCheckedKeys(keys, leafOnly);
- },
- setChecked: function setChecked(data, checked, deep) {
- this.store.setChecked(data, checked, deep);
- },
- getHalfCheckedNodes: function getHalfCheckedNodes() {
- return this.store.getHalfCheckedNodes();
- },
- getHalfCheckedKeys: function getHalfCheckedKeys() {
- return this.store.getHalfCheckedKeys();
- },
- setCurrentNode: function setCurrentNode(node) {
- if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCurrentNode');
- this.store.setUserCurrentNode(node);
- },
- setCurrentKey: function setCurrentKey(key) {
- if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCurrentKey');
- this.store.setCurrentNodeKey(key);
- },
- getNode: function getNode(data) {
- return this.store.getNode(data);
- },
- remove: function remove(data) {
- this.store.remove(data);
- },
- append: function append(data, parentNode) {
- this.store.append(data, parentNode);
- },
- insertBefore: function insertBefore(data, refNode) {
- this.store.insertBefore(data, refNode);
- },
- insertAfter: function insertAfter(data, refNode) {
- this.store.insertAfter(data, refNode);
- },
- handleNodeExpand: function handleNodeExpand(nodeData, node, instance) {
- this.broadcast('ElTreeNode', 'tree-node-expand', node);
- this.$emit('node-expand', nodeData, node, instance);
- },
- updateKeyChildren: function updateKeyChildren(key, data) {
- if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in updateKeyChild');
- this.store.updateChildren(key, data);
- },
- initTabIndex: function initTabIndex() {
- this.treeItems = this.$el.querySelectorAll('.is-focusable[role=treeitem]');
- this.checkboxItems = this.$el.querySelectorAll('input[type=checkbox]');
- var checkedItem = this.$el.querySelectorAll('.is-checked[role=treeitem]');
- if (checkedItem.length) {
- checkedItem[0].setAttribute('tabindex', 0);
- return;
- }
- this.treeItems[0] && this.treeItems[0].setAttribute('tabindex', 0);
- },
- handleKeydown: function handleKeydown(ev) {
- var currentItem = ev.target;
- if (currentItem.className.indexOf('el-tree-node') === -1) return;
- var keyCode = ev.keyCode;
- this.treeItems = this.$el.querySelectorAll('.is-focusable[role=treeitem]');
- var currentIndex = this.treeItemArray.indexOf(currentItem);
- var nextIndex = void 0;
- if ([38, 40].indexOf(keyCode) > -1) {
- // up、down
- ev.preventDefault();
- if (keyCode === 38) {
- // up
- nextIndex = currentIndex !== 0 ? currentIndex - 1 : 0;
- } else {
- nextIndex = currentIndex < this.treeItemArray.length - 1 ? currentIndex + 1 : 0;
- }
- this.treeItemArray[nextIndex].focus(); // 选中
- }
- if ([37, 39].indexOf(keyCode) > -1) {
- // left、right 展开
- ev.preventDefault();
- currentItem.click(); // 选中
- }
- var hasInput = currentItem.querySelector('[type="checkbox"]');
- if ([13, 32].indexOf(keyCode) > -1 && hasInput) {
- // space enter选中checkbox
- ev.preventDefault();
- hasInput.click();
- }
- }
- },
- created: function created() {
- var _this = this;
- this.isTree = true;
- this.store = new tree_store({
- key: this.nodeKey,
- data: this.data,
- lazy: this.lazy,
- props: this.props,
- load: this.load,
- currentNodeKey: this.currentNodeKey,
- checkStrictly: this.checkStrictly,
- checkDescendants: this.checkDescendants,
- defaultCheckedKeys: this.defaultCheckedKeys,
- defaultExpandedKeys: this.defaultExpandedKeys,
- autoExpandParent: this.autoExpandParent,
- defaultExpandAll: this.defaultExpandAll,
- filterNodeMethod: this.filterNodeMethod
- });
- this.root = this.store.root;
- var dragState = this.dragState;
- this.$on('tree-node-drag-start', function (event, treeNode) {
- if (typeof _this.allowDrag === 'function' && !_this.allowDrag(treeNode.node)) {
- event.preventDefault();
- return false;
- }
- event.dataTransfer.effectAllowed = 'move';
- // wrap in try catch to address IE's error when first param is 'text/plain'
- try {
- // setData is required for draggable to work in FireFox
- // the content has to be '' so dragging a node out of the tree won't open a new tab in FireFox
- event.dataTransfer.setData('text/plain', '');
- } catch (e) {}
- dragState.draggingNode = treeNode;
- _this.$emit('node-drag-start', treeNode.node, event);
- });
- this.$on('tree-node-drag-over', function (event, treeNode) {
- var dropNode = findNearestComponent(event.target, 'ElTreeNode');
- var oldDropNode = dragState.dropNode;
- if (oldDropNode && oldDropNode !== dropNode) {
- Object(dom_["removeClass"])(oldDropNode.$el, 'is-drop-inner');
- }
- var draggingNode = dragState.draggingNode;
- if (!draggingNode || !dropNode) return;
- var dropPrev = true;
- var dropInner = true;
- var dropNext = true;
- var userAllowDropInner = true;
- if (typeof _this.allowDrop === 'function') {
- dropPrev = _this.allowDrop(draggingNode.node, dropNode.node, 'prev');
- userAllowDropInner = dropInner = _this.allowDrop(draggingNode.node, dropNode.node, 'inner');
- dropNext = _this.allowDrop(draggingNode.node, dropNode.node, 'next');
- }
- event.dataTransfer.dropEffect = dropInner ? 'move' : 'none';
- if ((dropPrev || dropInner || dropNext) && oldDropNode !== dropNode) {
- if (oldDropNode) {
- _this.$emit('node-drag-leave', draggingNode.node, oldDropNode.node, event);
- }
- _this.$emit('node-drag-enter', draggingNode.node, dropNode.node, event);
- }
- if (dropPrev || dropInner || dropNext) {
- dragState.dropNode = dropNode;
- }
- if (dropNode.node.nextSibling === draggingNode.node) {
- dropNext = false;
- }
- if (dropNode.node.previousSibling === draggingNode.node) {
- dropPrev = false;
- }
- if (dropNode.node.contains(draggingNode.node, false)) {
- dropInner = false;
- }
- if (draggingNode.node === dropNode.node || draggingNode.node.contains(dropNode.node)) {
- dropPrev = false;
- dropInner = false;
- dropNext = false;
- }
- var targetPosition = dropNode.$el.getBoundingClientRect();
- var treePosition = _this.$el.getBoundingClientRect();
- var dropType = void 0;
- var prevPercent = dropPrev ? dropInner ? 0.25 : dropNext ? 0.45 : 1 : -1;
- var nextPercent = dropNext ? dropInner ? 0.75 : dropPrev ? 0.55 : 0 : 1;
- var indicatorTop = -9999;
- var distance = event.clientY - targetPosition.top;
- if (distance < targetPosition.height * prevPercent) {
- dropType = 'before';
- } else if (distance > targetPosition.height * nextPercent) {
- dropType = 'after';
- } else if (dropInner) {
- dropType = 'inner';
- } else {
- dropType = 'none';
- }
- var iconPosition = dropNode.$el.querySelector('.el-tree-node__expand-icon').getBoundingClientRect();
- var dropIndicator = _this.$refs.dropIndicator;
- if (dropType === 'before') {
- indicatorTop = iconPosition.top - treePosition.top;
- } else if (dropType === 'after') {
- indicatorTop = iconPosition.bottom - treePosition.top;
- }
- dropIndicator.style.top = indicatorTop + 'px';
- dropIndicator.style.left = iconPosition.right - treePosition.left + 'px';
- if (dropType === 'inner') {
- Object(dom_["addClass"])(dropNode.$el, 'is-drop-inner');
- } else {
- Object(dom_["removeClass"])(dropNode.$el, 'is-drop-inner');
- }
- dragState.showDropIndicator = dropType === 'before' || dropType === 'after';
- dragState.allowDrop = dragState.showDropIndicator || userAllowDropInner;
- dragState.dropType = dropType;
- _this.$emit('node-drag-over', draggingNode.node, dropNode.node, event);
- });
- this.$on('tree-node-drag-end', function (event) {
- var draggingNode = dragState.draggingNode,
- dropType = dragState.dropType,
- dropNode = dragState.dropNode;
- event.preventDefault();
- event.dataTransfer.dropEffect = 'move';
- if (draggingNode && dropNode) {
- var draggingNodeCopy = { data: draggingNode.node.data };
- if (dropType !== 'none') {
- draggingNode.node.remove();
- }
- if (dropType === 'before') {
- dropNode.node.parent.insertBefore(draggingNodeCopy, dropNode.node);
- } else if (dropType === 'after') {
- dropNode.node.parent.insertAfter(draggingNodeCopy, dropNode.node);
- } else if (dropType === 'inner') {
- dropNode.node.insertChild(draggingNodeCopy);
- }
- if (dropType !== 'none') {
- _this.store.registerNode(draggingNodeCopy);
- }
- Object(dom_["removeClass"])(dropNode.$el, 'is-drop-inner');
- _this.$emit('node-drag-end', draggingNode.node, dropNode.node, dropType, event);
- if (dropType !== 'none') {
- _this.$emit('node-drop', draggingNode.node, dropNode.node, dropType, event);
- }
- }
- if (draggingNode && !dropNode) {
- _this.$emit('node-drag-end', draggingNode.node, null, dropType, event);
- }
- dragState.showDropIndicator = false;
- dragState.draggingNode = null;
- dragState.dropNode = null;
- dragState.allowDrop = true;
- });
- },
- mounted: function mounted() {
- this.initTabIndex();
- this.$el.addEventListener('keydown', this.handleKeydown);
- },
- updated: function updated() {
- this.treeItems = this.$el.querySelectorAll('[role=treeitem]');
- this.checkboxItems = this.$el.querySelectorAll('input[type=checkbox]');
- }
- });
- // CONCATENATED MODULE: ./packages/tree/src/tree.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_treevue_type_script_lang_js_ = (treevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/tree/src/tree.vue
- /* normalize component */
- var tree_component = normalizeComponent(
- src_treevue_type_script_lang_js_,
- treevue_type_template_id_547575a6_render,
- treevue_type_template_id_547575a6_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var tree_api; }
- tree_component.options.__file = "packages/tree/src/tree.vue"
- /* harmony default export */ var src_tree = (tree_component.exports);
- // CONCATENATED MODULE: ./packages/tree/index.js
- /* istanbul ignore next */
- src_tree.install = function (Vue) {
- Vue.component(src_tree.name, src_tree);
- };
- /* harmony default export */ var packages_tree = (src_tree);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/alert/src/main.vue?vue&type=template&id=6e53341b&
- var mainvue_type_template_id_6e53341b_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("transition", { attrs: { name: "el-alert-fade" } }, [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-alert",
- class: [
- _vm.typeClass,
- _vm.center ? "is-center" : "",
- "is-" + _vm.effect
- ],
- attrs: { role: "alert" }
- },
- [
- _vm.showIcon
- ? _c("i", {
- staticClass: "el-alert__icon",
- class: [_vm.iconClass, _vm.isBigIcon]
- })
- : _vm._e(),
- _c("div", { staticClass: "el-alert__content" }, [
- _vm.title || _vm.$slots.title
- ? _c(
- "span",
- { staticClass: "el-alert__title", class: [_vm.isBoldTitle] },
- [_vm._t("title", [_vm._v(_vm._s(_vm.title))])],
- 2
- )
- : _vm._e(),
- _vm.$slots.default && !_vm.description
- ? _c(
- "p",
- { staticClass: "el-alert__description" },
- [_vm._t("default")],
- 2
- )
- : _vm._e(),
- _vm.description && !_vm.$slots.default
- ? _c("p", { staticClass: "el-alert__description" }, [
- _vm._v(_vm._s(_vm.description))
- ])
- : _vm._e(),
- _c(
- "i",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.closable,
- expression: "closable"
- }
- ],
- staticClass: "el-alert__closebtn",
- class: {
- "is-customed": _vm.closeText !== "",
- "el-icon-close": _vm.closeText === ""
- },
- on: {
- click: function($event) {
- _vm.close()
- }
- }
- },
- [_vm._v(_vm._s(_vm.closeText))]
- )
- ])
- ]
- )
- ])
- }
- var mainvue_type_template_id_6e53341b_staticRenderFns = []
- mainvue_type_template_id_6e53341b_render._withStripped = true
- // CONCATENATED MODULE: ./packages/alert/src/main.vue?vue&type=template&id=6e53341b&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/alert/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var TYPE_CLASSES_MAP = {
- 'success': 'el-icon-success',
- 'warning': 'el-icon-warning',
- 'error': 'el-icon-error'
- };
- /* harmony default export */ var alert_src_mainvue_type_script_lang_js_ = ({
- name: 'ElAlert',
- props: {
- title: {
- type: String,
- default: ''
- },
- description: {
- type: String,
- default: ''
- },
- type: {
- type: String,
- default: 'info'
- },
- closable: {
- type: Boolean,
- default: true
- },
- closeText: {
- type: String,
- default: ''
- },
- showIcon: Boolean,
- center: Boolean,
- effect: {
- type: String,
- default: 'light',
- validator: function validator(value) {
- return ['light', 'dark'].indexOf(value) !== -1;
- }
- }
- },
- data: function data() {
- return {
- visible: true
- };
- },
- methods: {
- close: function close() {
- this.visible = false;
- this.$emit('close');
- }
- },
- computed: {
- typeClass: function typeClass() {
- return 'el-alert--' + this.type;
- },
- iconClass: function iconClass() {
- return TYPE_CLASSES_MAP[this.type] || 'el-icon-info';
- },
- isBigIcon: function isBigIcon() {
- return this.description || this.$slots.default ? 'is-big' : '';
- },
- isBoldTitle: function isBoldTitle() {
- return this.description || this.$slots.default ? 'is-bold' : '';
- }
- }
- });
- // CONCATENATED MODULE: ./packages/alert/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_alert_src_mainvue_type_script_lang_js_ = (alert_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/alert/src/main.vue
- /* normalize component */
- var alert_src_main_component = normalizeComponent(
- packages_alert_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_6e53341b_render,
- mainvue_type_template_id_6e53341b_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var alert_src_main_api; }
- alert_src_main_component.options.__file = "packages/alert/src/main.vue"
- /* harmony default export */ var alert_src_main = (alert_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/alert/index.js
- /* istanbul ignore next */
- alert_src_main.install = function (Vue) {
- Vue.component(alert_src_main.name, alert_src_main);
- };
- /* harmony default export */ var packages_alert = (alert_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/notification/src/main.vue?vue&type=template&id=43dbc3d8&
- var mainvue_type_template_id_43dbc3d8_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("transition", { attrs: { name: "el-notification-fade" } }, [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- class: ["el-notification", _vm.customClass, _vm.horizontalClass],
- style: _vm.positionStyle,
- attrs: { role: "alert" },
- on: {
- mouseenter: function($event) {
- _vm.clearTimer()
- },
- mouseleave: function($event) {
- _vm.startTimer()
- },
- click: _vm.click
- }
- },
- [
- _vm.type || _vm.iconClass
- ? _c("i", {
- staticClass: "el-notification__icon",
- class: [_vm.typeClass, _vm.iconClass]
- })
- : _vm._e(),
- _c(
- "div",
- {
- staticClass: "el-notification__group",
- class: { "is-with-icon": _vm.typeClass || _vm.iconClass }
- },
- [
- _c("h2", {
- staticClass: "el-notification__title",
- domProps: { textContent: _vm._s(_vm.title) }
- }),
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.message,
- expression: "message"
- }
- ],
- staticClass: "el-notification__content"
- },
- [
- _vm._t("default", [
- !_vm.dangerouslyUseHTMLString
- ? _c("p", [_vm._v(_vm._s(_vm.message))])
- : _c("p", { domProps: { innerHTML: _vm._s(_vm.message) } })
- ])
- ],
- 2
- ),
- _vm.showClose
- ? _c("div", {
- staticClass: "el-notification__closeBtn el-icon-close",
- on: {
- click: function($event) {
- $event.stopPropagation()
- return _vm.close($event)
- }
- }
- })
- : _vm._e()
- ]
- )
- ]
- )
- ])
- }
- var mainvue_type_template_id_43dbc3d8_staticRenderFns = []
- mainvue_type_template_id_43dbc3d8_render._withStripped = true
- // CONCATENATED MODULE: ./packages/notification/src/main.vue?vue&type=template&id=43dbc3d8&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/notification/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var mainvue_type_script_lang_js_typeMap = {
- success: 'success',
- info: 'info',
- warning: 'warning',
- error: 'error'
- };
- /* harmony default export */ var notification_src_mainvue_type_script_lang_js_ = ({
- data: function data() {
- return {
- visible: false,
- title: '',
- message: '',
- duration: 4500,
- type: '',
- showClose: true,
- customClass: '',
- iconClass: '',
- onClose: null,
- onClick: null,
- closed: false,
- verticalOffset: 0,
- timer: null,
- dangerouslyUseHTMLString: false,
- position: 'top-right'
- };
- },
- computed: {
- typeClass: function typeClass() {
- return this.type && mainvue_type_script_lang_js_typeMap[this.type] ? 'el-icon-' + mainvue_type_script_lang_js_typeMap[this.type] : '';
- },
- horizontalClass: function horizontalClass() {
- return this.position.indexOf('right') > -1 ? 'right' : 'left';
- },
- verticalProperty: function verticalProperty() {
- return (/^top-/.test(this.position) ? 'top' : 'bottom'
- );
- },
- positionStyle: function positionStyle() {
- var _ref;
- return _ref = {}, _ref[this.verticalProperty] = this.verticalOffset + 'px', _ref;
- }
- },
- watch: {
- closed: function closed(newVal) {
- if (newVal) {
- this.visible = false;
- this.$el.addEventListener('transitionend', this.destroyElement);
- }
- }
- },
- methods: {
- destroyElement: function destroyElement() {
- this.$el.removeEventListener('transitionend', this.destroyElement);
- this.$destroy(true);
- this.$el.parentNode.removeChild(this.$el);
- },
- click: function click() {
- if (typeof this.onClick === 'function') {
- this.onClick();
- }
- },
- close: function close() {
- this.closed = true;
- if (typeof this.onClose === 'function') {
- this.onClose();
- }
- },
- clearTimer: function clearTimer() {
- clearTimeout(this.timer);
- },
- startTimer: function startTimer() {
- var _this = this;
- if (this.duration > 0) {
- this.timer = setTimeout(function () {
- if (!_this.closed) {
- _this.close();
- }
- }, this.duration);
- }
- },
- keydown: function keydown(e) {
- if (e.keyCode === 46 || e.keyCode === 8) {
- this.clearTimer(); // detele 取消倒计时
- } else if (e.keyCode === 27) {
- // esc关闭消息
- if (!this.closed) {
- this.close();
- }
- } else {
- this.startTimer(); // 恢复倒计时
- }
- }
- },
- mounted: function mounted() {
- var _this2 = this;
- if (this.duration > 0) {
- this.timer = setTimeout(function () {
- if (!_this2.closed) {
- _this2.close();
- }
- }, this.duration);
- }
- document.addEventListener('keydown', this.keydown);
- },
- beforeDestroy: function beforeDestroy() {
- document.removeEventListener('keydown', this.keydown);
- }
- });
- // CONCATENATED MODULE: ./packages/notification/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_notification_src_mainvue_type_script_lang_js_ = (notification_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/notification/src/main.vue
- /* normalize component */
- var notification_src_main_component = normalizeComponent(
- packages_notification_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_43dbc3d8_render,
- mainvue_type_template_id_43dbc3d8_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var notification_src_main_api; }
- notification_src_main_component.options.__file = "packages/notification/src/main.vue"
- /* harmony default export */ var notification_src_main = (notification_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/notification/src/main.js
- var NotificationConstructor = external_vue_default.a.extend(notification_src_main);
- var src_main_instance = void 0;
- var instances = [];
- var seed = 1;
- var main_Notification = function Notification(options) {
- if (external_vue_default.a.prototype.$isServer) return;
- options = merge_default()({}, options);
- var userOnClose = options.onClose;
- var id = 'notification_' + seed++;
- var position = options.position || 'top-right';
- options.onClose = function () {
- Notification.close(id, userOnClose);
- };
- src_main_instance = new NotificationConstructor({
- data: options
- });
- if (Object(vdom_["isVNode"])(options.message)) {
- src_main_instance.$slots.default = [options.message];
- options.message = 'REPLACED_BY_VNODE';
- }
- src_main_instance.id = id;
- src_main_instance.$mount();
- document.body.appendChild(src_main_instance.$el);
- src_main_instance.visible = true;
- src_main_instance.dom = src_main_instance.$el;
- src_main_instance.dom.style.zIndex = popup_["PopupManager"].nextZIndex();
- var verticalOffset = options.offset || 0;
- instances.filter(function (item) {
- return item.position === position;
- }).forEach(function (item) {
- verticalOffset += item.$el.offsetHeight + 16;
- });
- verticalOffset += 16;
- src_main_instance.verticalOffset = verticalOffset;
- instances.push(src_main_instance);
- return src_main_instance;
- };
- ['success', 'warning', 'info', 'error'].forEach(function (type) {
- main_Notification[type] = function (options) {
- if (typeof options === 'string' || Object(vdom_["isVNode"])(options)) {
- options = {
- message: options
- };
- }
- options.type = type;
- return main_Notification(options);
- };
- });
- main_Notification.close = function (id, userOnClose) {
- var index = -1;
- var len = instances.length;
- var instance = instances.filter(function (instance, i) {
- if (instance.id === id) {
- index = i;
- return true;
- }
- return false;
- })[0];
- if (!instance) return;
- if (typeof userOnClose === 'function') {
- userOnClose(instance);
- }
- instances.splice(index, 1);
- if (len <= 1) return;
- var position = instance.position;
- var removedHeight = instance.dom.offsetHeight;
- for (var i = index; i < len - 1; i++) {
- if (instances[i].position === position) {
- instances[i].dom.style[instance.verticalProperty] = parseInt(instances[i].dom.style[instance.verticalProperty], 10) - removedHeight - 16 + 'px';
- }
- }
- };
- main_Notification.closeAll = function () {
- for (var i = instances.length - 1; i >= 0; i--) {
- instances[i].close();
- }
- };
- /* harmony default export */ var packages_notification_src_main = (main_Notification);
- // CONCATENATED MODULE: ./packages/notification/index.js
- /* harmony default export */ var notification = (packages_notification_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/slider/src/main.vue?vue&type=template&id=32708644&
- var mainvue_type_template_id_32708644_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-slider",
- class: {
- "is-vertical": _vm.vertical,
- "el-slider--with-input": _vm.showInput
- },
- attrs: {
- role: "slider",
- "aria-valuemin": _vm.min,
- "aria-valuemax": _vm.max,
- "aria-orientation": _vm.vertical ? "vertical" : "horizontal",
- "aria-disabled": _vm.sliderDisabled
- }
- },
- [
- _vm.showInput && !_vm.range
- ? _c("el-input-number", {
- ref: "input",
- staticClass: "el-slider__input",
- attrs: {
- step: _vm.step,
- disabled: _vm.sliderDisabled,
- controls: _vm.showInputControls,
- min: _vm.min,
- max: _vm.max,
- debounce: _vm.debounce,
- size: _vm.inputSize
- },
- on: { change: _vm.emitChange },
- model: {
- value: _vm.firstValue,
- callback: function($$v) {
- _vm.firstValue = $$v
- },
- expression: "firstValue"
- }
- })
- : _vm._e(),
- _c(
- "div",
- {
- ref: "slider",
- staticClass: "el-slider__runway",
- class: { "show-input": _vm.showInput, disabled: _vm.sliderDisabled },
- style: _vm.runwayStyle,
- on: { click: _vm.onSliderClick }
- },
- [
- _c("div", { staticClass: "el-slider__bar", style: _vm.barStyle }),
- _c("slider-button", {
- ref: "button1",
- attrs: {
- vertical: _vm.vertical,
- "tooltip-class": _vm.tooltipClass
- },
- model: {
- value: _vm.firstValue,
- callback: function($$v) {
- _vm.firstValue = $$v
- },
- expression: "firstValue"
- }
- }),
- _vm.range
- ? _c("slider-button", {
- ref: "button2",
- attrs: {
- vertical: _vm.vertical,
- "tooltip-class": _vm.tooltipClass
- },
- model: {
- value: _vm.secondValue,
- callback: function($$v) {
- _vm.secondValue = $$v
- },
- expression: "secondValue"
- }
- })
- : _vm._e(),
- _vm._l(_vm.stops, function(item, key) {
- return _vm.showStops
- ? _c("div", {
- key: key,
- staticClass: "el-slider__stop",
- style: _vm.getStopStyle(item)
- })
- : _vm._e()
- }),
- _vm.markList.length > 0
- ? [
- _c(
- "div",
- _vm._l(_vm.markList, function(item, key) {
- return _c("div", {
- key: key,
- staticClass: "el-slider__stop el-slider__marks-stop",
- style: _vm.getStopStyle(item.position)
- })
- }),
- 0
- ),
- _c(
- "div",
- { staticClass: "el-slider__marks" },
- _vm._l(_vm.markList, function(item, key) {
- return _c("slider-marker", {
- key: key,
- style: _vm.getStopStyle(item.position),
- attrs: { mark: item.mark }
- })
- }),
- 1
- )
- ]
- : _vm._e()
- ],
- 2
- )
- ],
- 1
- )
- }
- var mainvue_type_template_id_32708644_staticRenderFns = []
- mainvue_type_template_id_32708644_render._withStripped = true
- // CONCATENATED MODULE: ./packages/slider/src/main.vue?vue&type=template&id=32708644&
- // EXTERNAL MODULE: external "element-ui/lib/input-number"
- var input_number_ = __webpack_require__(42);
- var input_number_default = /*#__PURE__*/__webpack_require__.n(input_number_);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/slider/src/button.vue?vue&type=template&id=e72d2ad2&
- var buttonvue_type_template_id_e72d2ad2_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- ref: "button",
- staticClass: "el-slider__button-wrapper",
- class: { hover: _vm.hovering, dragging: _vm.dragging },
- style: _vm.wrapperStyle,
- attrs: { tabindex: "0" },
- on: {
- mouseenter: _vm.handleMouseEnter,
- mouseleave: _vm.handleMouseLeave,
- mousedown: _vm.onButtonDown,
- touchstart: _vm.onButtonDown,
- focus: _vm.handleMouseEnter,
- blur: _vm.handleMouseLeave,
- keydown: [
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "left", 37, $event.key, [
- "Left",
- "ArrowLeft"
- ])
- ) {
- return null
- }
- if ("button" in $event && $event.button !== 0) {
- return null
- }
- return _vm.onLeftKeyDown($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "right", 39, $event.key, [
- "Right",
- "ArrowRight"
- ])
- ) {
- return null
- }
- if ("button" in $event && $event.button !== 2) {
- return null
- }
- return _vm.onRightKeyDown($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "down", 40, $event.key, [
- "Down",
- "ArrowDown"
- ])
- ) {
- return null
- }
- $event.preventDefault()
- return _vm.onLeftKeyDown($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "up", 38, $event.key, ["Up", "ArrowUp"])
- ) {
- return null
- }
- $event.preventDefault()
- return _vm.onRightKeyDown($event)
- }
- ]
- }
- },
- [
- _c(
- "el-tooltip",
- {
- ref: "tooltip",
- attrs: {
- placement: "top",
- "popper-class": _vm.tooltipClass,
- disabled: !_vm.showTooltip
- }
- },
- [
- _c("span", { attrs: { slot: "content" }, slot: "content" }, [
- _vm._v(_vm._s(_vm.formatValue))
- ]),
- _c("div", {
- staticClass: "el-slider__button",
- class: { hover: _vm.hovering, dragging: _vm.dragging }
- })
- ]
- )
- ],
- 1
- )
- }
- var buttonvue_type_template_id_e72d2ad2_staticRenderFns = []
- buttonvue_type_template_id_e72d2ad2_render._withStripped = true
- // CONCATENATED MODULE: ./packages/slider/src/button.vue?vue&type=template&id=e72d2ad2&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/slider/src/button.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var slider_src_buttonvue_type_script_lang_js_ = ({
- name: 'ElSliderButton',
- components: {
- ElTooltip: tooltip_default.a
- },
- props: {
- value: {
- type: Number,
- default: 0
- },
- vertical: {
- type: Boolean,
- default: false
- },
- tooltipClass: String
- },
- data: function data() {
- return {
- hovering: false,
- dragging: false,
- isClick: false,
- startX: 0,
- currentX: 0,
- startY: 0,
- currentY: 0,
- startPosition: 0,
- newPosition: null,
- oldValue: this.value
- };
- },
- computed: {
- disabled: function disabled() {
- return this.$parent.sliderDisabled;
- },
- max: function max() {
- return this.$parent.max;
- },
- min: function min() {
- return this.$parent.min;
- },
- step: function step() {
- return this.$parent.step;
- },
- showTooltip: function showTooltip() {
- return this.$parent.showTooltip;
- },
- precision: function precision() {
- return this.$parent.precision;
- },
- currentPosition: function currentPosition() {
- return (this.value - this.min) / (this.max - this.min) * 100 + '%';
- },
- enableFormat: function enableFormat() {
- return this.$parent.formatTooltip instanceof Function;
- },
- formatValue: function formatValue() {
- return this.enableFormat && this.$parent.formatTooltip(this.value) || this.value;
- },
- wrapperStyle: function wrapperStyle() {
- return this.vertical ? { bottom: this.currentPosition } : { left: this.currentPosition };
- }
- },
- watch: {
- dragging: function dragging(val) {
- this.$parent.dragging = val;
- }
- },
- methods: {
- displayTooltip: function displayTooltip() {
- this.$refs.tooltip && (this.$refs.tooltip.showPopper = true);
- },
- hideTooltip: function hideTooltip() {
- this.$refs.tooltip && (this.$refs.tooltip.showPopper = false);
- },
- handleMouseEnter: function handleMouseEnter() {
- this.hovering = true;
- this.displayTooltip();
- },
- handleMouseLeave: function handleMouseLeave() {
- this.hovering = false;
- this.hideTooltip();
- },
- onButtonDown: function onButtonDown(event) {
- if (this.disabled) return;
- event.preventDefault();
- this.onDragStart(event);
- window.addEventListener('mousemove', this.onDragging);
- window.addEventListener('touchmove', this.onDragging);
- window.addEventListener('mouseup', this.onDragEnd);
- window.addEventListener('touchend', this.onDragEnd);
- window.addEventListener('contextmenu', this.onDragEnd);
- },
- onLeftKeyDown: function onLeftKeyDown() {
- if (this.disabled) return;
- this.newPosition = parseFloat(this.currentPosition) - this.step / (this.max - this.min) * 100;
- this.setPosition(this.newPosition);
- this.$parent.emitChange();
- },
- onRightKeyDown: function onRightKeyDown() {
- if (this.disabled) return;
- this.newPosition = parseFloat(this.currentPosition) + this.step / (this.max - this.min) * 100;
- this.setPosition(this.newPosition);
- this.$parent.emitChange();
- },
- onDragStart: function onDragStart(event) {
- this.dragging = true;
- this.isClick = true;
- if (event.type === 'touchstart') {
- event.clientY = event.touches[0].clientY;
- event.clientX = event.touches[0].clientX;
- }
- if (this.vertical) {
- this.startY = event.clientY;
- } else {
- this.startX = event.clientX;
- }
- this.startPosition = parseFloat(this.currentPosition);
- this.newPosition = this.startPosition;
- },
- onDragging: function onDragging(event) {
- if (this.dragging) {
- this.isClick = false;
- this.displayTooltip();
- this.$parent.resetSize();
- var diff = 0;
- if (event.type === 'touchmove') {
- event.clientY = event.touches[0].clientY;
- event.clientX = event.touches[0].clientX;
- }
- if (this.vertical) {
- this.currentY = event.clientY;
- diff = (this.startY - this.currentY) / this.$parent.sliderSize * 100;
- } else {
- this.currentX = event.clientX;
- diff = (this.currentX - this.startX) / this.$parent.sliderSize * 100;
- }
- this.newPosition = this.startPosition + diff;
- this.setPosition(this.newPosition);
- }
- },
- onDragEnd: function onDragEnd() {
- var _this = this;
- if (this.dragging) {
- /*
- * 防止在 mouseup 后立即触发 click,导致滑块有几率产生一小段位移
- * 不使用 preventDefault 是因为 mouseup 和 click 没有注册在同一个 DOM 上
- */
- setTimeout(function () {
- _this.dragging = false;
- _this.hideTooltip();
- if (!_this.isClick) {
- _this.setPosition(_this.newPosition);
- _this.$parent.emitChange();
- }
- }, 0);
- window.removeEventListener('mousemove', this.onDragging);
- window.removeEventListener('touchmove', this.onDragging);
- window.removeEventListener('mouseup', this.onDragEnd);
- window.removeEventListener('touchend', this.onDragEnd);
- window.removeEventListener('contextmenu', this.onDragEnd);
- }
- },
- setPosition: function setPosition(newPosition) {
- var _this2 = this;
- if (newPosition === null || isNaN(newPosition)) return;
- if (newPosition < 0) {
- newPosition = 0;
- } else if (newPosition > 100) {
- newPosition = 100;
- }
- var lengthPerStep = 100 / ((this.max - this.min) / this.step);
- var steps = Math.round(newPosition / lengthPerStep);
- var value = steps * lengthPerStep * (this.max - this.min) * 0.01 + this.min;
- value = parseFloat(value.toFixed(this.precision));
- this.$emit('input', value);
- this.$nextTick(function () {
- _this2.displayTooltip();
- _this2.$refs.tooltip && _this2.$refs.tooltip.updatePopper();
- });
- if (!this.dragging && this.value !== this.oldValue) {
- this.oldValue = this.value;
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/slider/src/button.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_slider_src_buttonvue_type_script_lang_js_ = (slider_src_buttonvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/slider/src/button.vue
- /* normalize component */
- var src_button_component = normalizeComponent(
- packages_slider_src_buttonvue_type_script_lang_js_,
- buttonvue_type_template_id_e72d2ad2_render,
- buttonvue_type_template_id_e72d2ad2_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var src_button_api; }
- src_button_component.options.__file = "packages/slider/src/button.vue"
- /* harmony default export */ var slider_src_button = (src_button_component.exports);
- // CONCATENATED MODULE: ./packages/slider/src/marker.js
- /* harmony default export */ var marker = ({
- name: 'ElMarker',
- props: {
- mark: {
- type: [String, Object]
- }
- },
- render: function render() {
- var h = arguments[0];
- var label = typeof this.mark === 'string' ? this.mark : this.mark.label;
- return h(
- 'div',
- { 'class': 'el-slider__marks-text', style: this.mark.style || {} },
- [label]
- );
- }
- });
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/slider/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var slider_src_mainvue_type_script_lang_js_ = ({
- name: 'ElSlider',
- mixins: [emitter_default.a],
- inject: {
- elForm: {
- default: ''
- }
- },
- props: {
- min: {
- type: Number,
- default: 0
- },
- max: {
- type: Number,
- default: 100
- },
- step: {
- type: Number,
- default: 1
- },
- value: {
- type: [Number, Array],
- default: 0
- },
- showInput: {
- type: Boolean,
- default: false
- },
- showInputControls: {
- type: Boolean,
- default: true
- },
- inputSize: {
- type: String,
- default: 'small'
- },
- showStops: {
- type: Boolean,
- default: false
- },
- showTooltip: {
- type: Boolean,
- default: true
- },
- formatTooltip: Function,
- disabled: {
- type: Boolean,
- default: false
- },
- range: {
- type: Boolean,
- default: false
- },
- vertical: {
- type: Boolean,
- default: false
- },
- height: {
- type: String
- },
- debounce: {
- type: Number,
- default: 300
- },
- label: {
- type: String
- },
- tooltipClass: String,
- marks: Object
- },
- components: {
- ElInputNumber: input_number_default.a,
- SliderButton: slider_src_button,
- SliderMarker: marker
- },
- data: function data() {
- return {
- firstValue: null,
- secondValue: null,
- oldValue: null,
- dragging: false,
- sliderSize: 1
- };
- },
- watch: {
- value: function value(val, oldVal) {
- if (this.dragging || Array.isArray(val) && Array.isArray(oldVal) && val.every(function (item, index) {
- return item === oldVal[index];
- })) {
- return;
- }
- this.setValues();
- },
- dragging: function dragging(val) {
- if (!val) {
- this.setValues();
- }
- },
- firstValue: function firstValue(val) {
- if (this.range) {
- this.$emit('input', [this.minValue, this.maxValue]);
- } else {
- this.$emit('input', val);
- }
- },
- secondValue: function secondValue() {
- if (this.range) {
- this.$emit('input', [this.minValue, this.maxValue]);
- }
- },
- min: function min() {
- this.setValues();
- },
- max: function max() {
- this.setValues();
- }
- },
- methods: {
- valueChanged: function valueChanged() {
- var _this = this;
- if (this.range) {
- return ![this.minValue, this.maxValue].every(function (item, index) {
- return item === _this.oldValue[index];
- });
- } else {
- return this.value !== this.oldValue;
- }
- },
- setValues: function setValues() {
- if (this.min > this.max) {
- console.error('[Element Error][Slider]min should not be greater than max.');
- return;
- }
- var val = this.value;
- if (this.range && Array.isArray(val)) {
- if (val[1] < this.min) {
- this.$emit('input', [this.min, this.min]);
- } else if (val[0] > this.max) {
- this.$emit('input', [this.max, this.max]);
- } else if (val[0] < this.min) {
- this.$emit('input', [this.min, val[1]]);
- } else if (val[1] > this.max) {
- this.$emit('input', [val[0], this.max]);
- } else {
- this.firstValue = val[0];
- this.secondValue = val[1];
- if (this.valueChanged()) {
- this.dispatch('ElFormItem', 'el.form.change', [this.minValue, this.maxValue]);
- this.oldValue = val.slice();
- }
- }
- } else if (!this.range && typeof val === 'number' && !isNaN(val)) {
- if (val < this.min) {
- this.$emit('input', this.min);
- } else if (val > this.max) {
- this.$emit('input', this.max);
- } else {
- this.firstValue = val;
- if (this.valueChanged()) {
- this.dispatch('ElFormItem', 'el.form.change', val);
- this.oldValue = val;
- }
- }
- }
- },
- setPosition: function setPosition(percent) {
- var targetValue = this.min + percent * (this.max - this.min) / 100;
- if (!this.range) {
- this.$refs.button1.setPosition(percent);
- return;
- }
- var button = void 0;
- if (Math.abs(this.minValue - targetValue) < Math.abs(this.maxValue - targetValue)) {
- button = this.firstValue < this.secondValue ? 'button1' : 'button2';
- } else {
- button = this.firstValue > this.secondValue ? 'button1' : 'button2';
- }
- this.$refs[button].setPosition(percent);
- },
- onSliderClick: function onSliderClick(event) {
- if (this.sliderDisabled || this.dragging) return;
- this.resetSize();
- if (this.vertical) {
- var sliderOffsetBottom = this.$refs.slider.getBoundingClientRect().bottom;
- this.setPosition((sliderOffsetBottom - event.clientY) / this.sliderSize * 100);
- } else {
- var sliderOffsetLeft = this.$refs.slider.getBoundingClientRect().left;
- this.setPosition((event.clientX - sliderOffsetLeft) / this.sliderSize * 100);
- }
- this.emitChange();
- },
- resetSize: function resetSize() {
- if (this.$refs.slider) {
- this.sliderSize = this.$refs.slider['client' + (this.vertical ? 'Height' : 'Width')];
- }
- },
- emitChange: function emitChange() {
- var _this2 = this;
- this.$nextTick(function () {
- _this2.$emit('change', _this2.range ? [_this2.minValue, _this2.maxValue] : _this2.value);
- });
- },
- getStopStyle: function getStopStyle(position) {
- return this.vertical ? { 'bottom': position + '%' } : { 'left': position + '%' };
- }
- },
- computed: {
- stops: function stops() {
- var _this3 = this;
- if (!this.showStops || this.min > this.max) return [];
- if (this.step === 0) {
- false && false;
- return [];
- }
- var stopCount = (this.max - this.min) / this.step;
- var stepWidth = 100 * this.step / (this.max - this.min);
- var result = [];
- for (var i = 1; i < stopCount; i++) {
- result.push(i * stepWidth);
- }
- if (this.range) {
- return result.filter(function (step) {
- return step < 100 * (_this3.minValue - _this3.min) / (_this3.max - _this3.min) || step > 100 * (_this3.maxValue - _this3.min) / (_this3.max - _this3.min);
- });
- } else {
- return result.filter(function (step) {
- return step > 100 * (_this3.firstValue - _this3.min) / (_this3.max - _this3.min);
- });
- }
- },
- markList: function markList() {
- var _this4 = this;
- if (!this.marks) {
- return [];
- }
- var marksKeys = Object.keys(this.marks);
- return marksKeys.map(parseFloat).sort(function (a, b) {
- return a - b;
- }).filter(function (point) {
- return point <= _this4.max && point >= _this4.min;
- }).map(function (point) {
- return {
- point: point,
- position: (point - _this4.min) * 100 / (_this4.max - _this4.min),
- mark: _this4.marks[point]
- };
- });
- },
- minValue: function minValue() {
- return Math.min(this.firstValue, this.secondValue);
- },
- maxValue: function maxValue() {
- return Math.max(this.firstValue, this.secondValue);
- },
- barSize: function barSize() {
- return this.range ? 100 * (this.maxValue - this.minValue) / (this.max - this.min) + '%' : 100 * (this.firstValue - this.min) / (this.max - this.min) + '%';
- },
- barStart: function barStart() {
- return this.range ? 100 * (this.minValue - this.min) / (this.max - this.min) + '%' : '0%';
- },
- precision: function precision() {
- var precisions = [this.min, this.max, this.step].map(function (item) {
- var decimal = ('' + item).split('.')[1];
- return decimal ? decimal.length : 0;
- });
- return Math.max.apply(null, precisions);
- },
- runwayStyle: function runwayStyle() {
- return this.vertical ? { height: this.height } : {};
- },
- barStyle: function barStyle() {
- return this.vertical ? {
- height: this.barSize,
- bottom: this.barStart
- } : {
- width: this.barSize,
- left: this.barStart
- };
- },
- sliderDisabled: function sliderDisabled() {
- return this.disabled || (this.elForm || {}).disabled;
- }
- },
- mounted: function mounted() {
- var valuetext = void 0;
- if (this.range) {
- if (Array.isArray(this.value)) {
- this.firstValue = Math.max(this.min, this.value[0]);
- this.secondValue = Math.min(this.max, this.value[1]);
- } else {
- this.firstValue = this.min;
- this.secondValue = this.max;
- }
- this.oldValue = [this.firstValue, this.secondValue];
- valuetext = this.firstValue + '-' + this.secondValue;
- } else {
- if (typeof this.value !== 'number' || isNaN(this.value)) {
- this.firstValue = this.min;
- } else {
- this.firstValue = Math.min(this.max, Math.max(this.min, this.value));
- }
- this.oldValue = this.firstValue;
- valuetext = this.firstValue;
- }
- this.$el.setAttribute('aria-valuetext', valuetext);
- // label screen reader
- this.$el.setAttribute('aria-label', this.label ? this.label : 'slider between ' + this.min + ' and ' + this.max);
- this.resetSize();
- window.addEventListener('resize', this.resetSize);
- },
- beforeDestroy: function beforeDestroy() {
- window.removeEventListener('resize', this.resetSize);
- }
- });
- // CONCATENATED MODULE: ./packages/slider/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_slider_src_mainvue_type_script_lang_js_ = (slider_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/slider/src/main.vue
- /* normalize component */
- var slider_src_main_component = normalizeComponent(
- packages_slider_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_32708644_render,
- mainvue_type_template_id_32708644_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var slider_src_main_api; }
- slider_src_main_component.options.__file = "packages/slider/src/main.vue"
- /* harmony default export */ var slider_src_main = (slider_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/slider/index.js
- /* istanbul ignore next */
- slider_src_main.install = function (Vue) {
- Vue.component(slider_src_main.name, slider_src_main);
- };
- /* harmony default export */ var slider = (slider_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/loading/src/loading.vue?vue&type=template&id=eee0a7ac&
- var loadingvue_type_template_id_eee0a7ac_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- {
- attrs: { name: "el-loading-fade" },
- on: { "after-leave": _vm.handleAfterLeave }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-loading-mask",
- class: [_vm.customClass, { "is-fullscreen": _vm.fullscreen }],
- style: { backgroundColor: _vm.background || "" }
- },
- [
- _c("div", { staticClass: "el-loading-spinner" }, [
- !_vm.spinner
- ? _c(
- "svg",
- {
- staticClass: "circular",
- attrs: { viewBox: "25 25 50 50" }
- },
- [
- _c("circle", {
- staticClass: "path",
- attrs: { cx: "50", cy: "50", r: "20", fill: "none" }
- })
- ]
- )
- : _c("i", { class: _vm.spinner }),
- _vm.text
- ? _c("p", { staticClass: "el-loading-text" }, [
- _vm._v(_vm._s(_vm.text))
- ])
- : _vm._e()
- ])
- ]
- )
- ]
- )
- }
- var loadingvue_type_template_id_eee0a7ac_staticRenderFns = []
- loadingvue_type_template_id_eee0a7ac_render._withStripped = true
- // CONCATENATED MODULE: ./packages/loading/src/loading.vue?vue&type=template&id=eee0a7ac&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/loading/src/loading.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var loadingvue_type_script_lang_js_ = ({
- data: function data() {
- return {
- text: null,
- spinner: null,
- background: null,
- fullscreen: true,
- visible: false,
- customClass: ''
- };
- },
- methods: {
- handleAfterLeave: function handleAfterLeave() {
- this.$emit('after-leave');
- },
- setText: function setText(text) {
- this.text = text;
- }
- }
- });
- // CONCATENATED MODULE: ./packages/loading/src/loading.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_loadingvue_type_script_lang_js_ = (loadingvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/loading/src/loading.vue
- /* normalize component */
- var loading_component = normalizeComponent(
- src_loadingvue_type_script_lang_js_,
- loadingvue_type_template_id_eee0a7ac_render,
- loadingvue_type_template_id_eee0a7ac_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var loading_api; }
- loading_component.options.__file = "packages/loading/src/loading.vue"
- /* harmony default export */ var loading = (loading_component.exports);
- // EXTERNAL MODULE: external "element-ui/lib/utils/after-leave"
- var after_leave_ = __webpack_require__(33);
- var after_leave_default = /*#__PURE__*/__webpack_require__.n(after_leave_);
- // CONCATENATED MODULE: ./packages/loading/src/directive.js
- var Mask = external_vue_default.a.extend(loading);
- var loadingDirective = {};
- loadingDirective.install = function (Vue) {
- if (Vue.prototype.$isServer) return;
- var toggleLoading = function toggleLoading(el, binding) {
- if (binding.value) {
- Vue.nextTick(function () {
- if (binding.modifiers.fullscreen) {
- el.originalPosition = Object(dom_["getStyle"])(document.body, 'position');
- el.originalOverflow = Object(dom_["getStyle"])(document.body, 'overflow');
- el.maskStyle.zIndex = popup_["PopupManager"].nextZIndex();
- Object(dom_["addClass"])(el.mask, 'is-fullscreen');
- insertDom(document.body, el, binding);
- } else {
- Object(dom_["removeClass"])(el.mask, 'is-fullscreen');
- if (binding.modifiers.body) {
- el.originalPosition = Object(dom_["getStyle"])(document.body, 'position');
- ['top', 'left'].forEach(function (property) {
- var scroll = property === 'top' ? 'scrollTop' : 'scrollLeft';
- el.maskStyle[property] = el.getBoundingClientRect()[property] + document.body[scroll] + document.documentElement[scroll] - parseInt(Object(dom_["getStyle"])(document.body, 'margin-' + property), 10) + 'px';
- });
- ['height', 'width'].forEach(function (property) {
- el.maskStyle[property] = el.getBoundingClientRect()[property] + 'px';
- });
- insertDom(document.body, el, binding);
- } else {
- el.originalPosition = Object(dom_["getStyle"])(el, 'position');
- insertDom(el, el, binding);
- }
- }
- });
- } else {
- after_leave_default()(el.instance, function (_) {
- if (!el.instance.hiding) return;
- el.domVisible = false;
- var target = binding.modifiers.fullscreen || binding.modifiers.body ? document.body : el;
- Object(dom_["removeClass"])(target, 'el-loading-parent--relative');
- Object(dom_["removeClass"])(target, 'el-loading-parent--hidden');
- el.instance.hiding = false;
- }, 300, true);
- el.instance.visible = false;
- el.instance.hiding = true;
- }
- };
- var insertDom = function insertDom(parent, el, binding) {
- if (!el.domVisible && Object(dom_["getStyle"])(el, 'display') !== 'none' && Object(dom_["getStyle"])(el, 'visibility') !== 'hidden') {
- Object.keys(el.maskStyle).forEach(function (property) {
- el.mask.style[property] = el.maskStyle[property];
- });
- if (el.originalPosition !== 'absolute' && el.originalPosition !== 'fixed' && el.originalPosition !== 'sticky') {
- Object(dom_["addClass"])(parent, 'el-loading-parent--relative');
- }
- if (binding.modifiers.fullscreen && binding.modifiers.lock) {
- Object(dom_["addClass"])(parent, 'el-loading-parent--hidden');
- }
- el.domVisible = true;
- parent.appendChild(el.mask);
- Vue.nextTick(function () {
- if (el.instance.hiding) {
- el.instance.$emit('after-leave');
- } else {
- el.instance.visible = true;
- }
- });
- el.domInserted = true;
- } else if (el.domVisible && el.instance.hiding === true) {
- el.instance.visible = true;
- el.instance.hiding = false;
- }
- };
- Vue.directive('loading', {
- bind: function bind(el, binding, vnode) {
- var textExr = el.getAttribute('element-loading-text');
- var spinnerExr = el.getAttribute('element-loading-spinner');
- var backgroundExr = el.getAttribute('element-loading-background');
- var customClassExr = el.getAttribute('element-loading-custom-class');
- var vm = vnode.context;
- var mask = new Mask({
- el: document.createElement('div'),
- data: {
- text: vm && vm[textExr] || textExr,
- spinner: vm && vm[spinnerExr] || spinnerExr,
- background: vm && vm[backgroundExr] || backgroundExr,
- customClass: vm && vm[customClassExr] || customClassExr,
- fullscreen: !!binding.modifiers.fullscreen
- }
- });
- el.instance = mask;
- el.mask = mask.$el;
- el.maskStyle = {};
- binding.value && toggleLoading(el, binding);
- },
- update: function update(el, binding) {
- el.instance.setText(el.getAttribute('element-loading-text'));
- if (binding.oldValue !== binding.value) {
- toggleLoading(el, binding);
- }
- },
- unbind: function unbind(el, binding) {
- if (el.domInserted) {
- el.mask && el.mask.parentNode && el.mask.parentNode.removeChild(el.mask);
- toggleLoading(el, { value: false, modifiers: binding.modifiers });
- }
- el.instance && el.instance.$destroy();
- }
- });
- };
- /* harmony default export */ var src_directive = (loadingDirective);
- // CONCATENATED MODULE: ./packages/loading/src/index.js
- var LoadingConstructor = external_vue_default.a.extend(loading);
- var src_defaults = {
- text: null,
- fullscreen: true,
- body: false,
- lock: false,
- customClass: ''
- };
- var fullscreenLoading = void 0;
- LoadingConstructor.prototype.originalPosition = '';
- LoadingConstructor.prototype.originalOverflow = '';
- LoadingConstructor.prototype.close = function () {
- var _this = this;
- if (this.fullscreen) {
- fullscreenLoading = undefined;
- }
- after_leave_default()(this, function (_) {
- var target = _this.fullscreen || _this.body ? document.body : _this.target;
- Object(dom_["removeClass"])(target, 'el-loading-parent--relative');
- Object(dom_["removeClass"])(target, 'el-loading-parent--hidden');
- if (_this.$el && _this.$el.parentNode) {
- _this.$el.parentNode.removeChild(_this.$el);
- }
- _this.$destroy();
- }, 300);
- this.visible = false;
- };
- var src_addStyle = function addStyle(options, parent, instance) {
- var maskStyle = {};
- if (options.fullscreen) {
- instance.originalPosition = Object(dom_["getStyle"])(document.body, 'position');
- instance.originalOverflow = Object(dom_["getStyle"])(document.body, 'overflow');
- maskStyle.zIndex = popup_["PopupManager"].nextZIndex();
- } else if (options.body) {
- instance.originalPosition = Object(dom_["getStyle"])(document.body, 'position');
- ['top', 'left'].forEach(function (property) {
- var scroll = property === 'top' ? 'scrollTop' : 'scrollLeft';
- maskStyle[property] = options.target.getBoundingClientRect()[property] + document.body[scroll] + document.documentElement[scroll] + 'px';
- });
- ['height', 'width'].forEach(function (property) {
- maskStyle[property] = options.target.getBoundingClientRect()[property] + 'px';
- });
- } else {
- instance.originalPosition = Object(dom_["getStyle"])(parent, 'position');
- }
- Object.keys(maskStyle).forEach(function (property) {
- instance.$el.style[property] = maskStyle[property];
- });
- };
- var src_Loading = function Loading() {
- var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
- if (external_vue_default.a.prototype.$isServer) return;
- options = merge_default()({}, src_defaults, options);
- if (typeof options.target === 'string') {
- options.target = document.querySelector(options.target);
- }
- options.target = options.target || document.body;
- if (options.target !== document.body) {
- options.fullscreen = false;
- } else {
- options.body = true;
- }
- if (options.fullscreen && fullscreenLoading) {
- return fullscreenLoading;
- }
- var parent = options.body ? document.body : options.target;
- var instance = new LoadingConstructor({
- el: document.createElement('div'),
- data: options
- });
- src_addStyle(options, parent, instance);
- if (instance.originalPosition !== 'absolute' && instance.originalPosition !== 'fixed' && instance.originalPosition !== 'sticky') {
- Object(dom_["addClass"])(parent, 'el-loading-parent--relative');
- }
- if (options.fullscreen && options.lock) {
- Object(dom_["addClass"])(parent, 'el-loading-parent--hidden');
- }
- parent.appendChild(instance.$el);
- external_vue_default.a.nextTick(function () {
- instance.visible = true;
- });
- if (options.fullscreen) {
- fullscreenLoading = instance;
- }
- return instance;
- };
- /* harmony default export */ var src = (src_Loading);
- // CONCATENATED MODULE: ./packages/loading/index.js
- /* harmony default export */ var packages_loading = ({
- install: function install(Vue) {
- Vue.use(src_directive);
- Vue.prototype.$loading = src;
- },
- directive: src_directive,
- service: src
- });
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/icon/src/icon.vue?vue&type=template&id=cb3fe7f4&
- var iconvue_type_template_id_cb3fe7f4_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("i", { class: "el-icon-" + _vm.name })
- }
- var iconvue_type_template_id_cb3fe7f4_staticRenderFns = []
- iconvue_type_template_id_cb3fe7f4_render._withStripped = true
- // CONCATENATED MODULE: ./packages/icon/src/icon.vue?vue&type=template&id=cb3fe7f4&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/icon/src/icon.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- /* harmony default export */ var iconvue_type_script_lang_js_ = ({
- name: 'ElIcon',
- props: {
- name: String
- }
- });
- // CONCATENATED MODULE: ./packages/icon/src/icon.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_iconvue_type_script_lang_js_ = (iconvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/icon/src/icon.vue
- /* normalize component */
- var icon_component = normalizeComponent(
- src_iconvue_type_script_lang_js_,
- iconvue_type_template_id_cb3fe7f4_render,
- iconvue_type_template_id_cb3fe7f4_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var icon_api; }
- icon_component.options.__file = "packages/icon/src/icon.vue"
- /* harmony default export */ var icon = (icon_component.exports);
- // CONCATENATED MODULE: ./packages/icon/index.js
- /* istanbul ignore next */
- icon.install = function (Vue) {
- Vue.component(icon.name, icon);
- };
- /* harmony default export */ var packages_icon = (icon);
- // CONCATENATED MODULE: ./packages/row/src/row.js
- /* harmony default export */ var src_row = ({
- name: 'ElRow',
- componentName: 'ElRow',
- props: {
- tag: {
- type: String,
- default: 'div'
- },
- gutter: Number,
- type: String,
- justify: {
- type: String,
- default: 'start'
- },
- align: String
- },
- computed: {
- style: function style() {
- var ret = {};
- if (this.gutter) {
- ret.marginLeft = '-' + this.gutter / 2 + 'px';
- ret.marginRight = ret.marginLeft;
- }
- return ret;
- }
- },
- render: function render(h) {
- return h(this.tag, {
- class: ['el-row', this.justify !== 'start' ? 'is-justify-' + this.justify : '', this.align ? 'is-align-' + this.align : '', { 'el-row--flex': this.type === 'flex' }],
- style: this.style
- }, this.$slots.default);
- }
- });
- // CONCATENATED MODULE: ./packages/row/index.js
- /* istanbul ignore next */
- src_row.install = function (Vue) {
- Vue.component(src_row.name, src_row);
- };
- /* harmony default export */ var packages_row = (src_row);
- // CONCATENATED MODULE: ./packages/col/src/col.js
- var col_typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- /* harmony default export */ var col = ({
- name: 'ElCol',
- props: {
- span: {
- type: Number,
- default: 24
- },
- tag: {
- type: String,
- default: 'div'
- },
- offset: Number,
- pull: Number,
- push: Number,
- xs: [Number, Object],
- sm: [Number, Object],
- md: [Number, Object],
- lg: [Number, Object],
- xl: [Number, Object]
- },
- computed: {
- gutter: function gutter() {
- var parent = this.$parent;
- while (parent && parent.$options.componentName !== 'ElRow') {
- parent = parent.$parent;
- }
- return parent ? parent.gutter : 0;
- }
- },
- render: function render(h) {
- var _this = this;
- var classList = [];
- var style = {};
- if (this.gutter) {
- style.paddingLeft = this.gutter / 2 + 'px';
- style.paddingRight = style.paddingLeft;
- }
- ['span', 'offset', 'pull', 'push'].forEach(function (prop) {
- if (_this[prop] || _this[prop] === 0) {
- classList.push(prop !== 'span' ? 'el-col-' + prop + '-' + _this[prop] : 'el-col-' + _this[prop]);
- }
- });
- ['xs', 'sm', 'md', 'lg', 'xl'].forEach(function (size) {
- if (typeof _this[size] === 'number') {
- classList.push('el-col-' + size + '-' + _this[size]);
- } else if (col_typeof(_this[size]) === 'object') {
- var props = _this[size];
- Object.keys(props).forEach(function (prop) {
- classList.push(prop !== 'span' ? 'el-col-' + size + '-' + prop + '-' + props[prop] : 'el-col-' + size + '-' + props[prop]);
- });
- }
- });
- return h(this.tag, {
- class: ['el-col', classList],
- style: style
- }, this.$slots.default);
- }
- });
- // CONCATENATED MODULE: ./packages/col/index.js
- /* istanbul ignore next */
- col.install = function (Vue) {
- Vue.component(col.name, col);
- };
- /* harmony default export */ var packages_col = (col);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/upload-list.vue?vue&type=template&id=173fedf5&
- var upload_listvue_type_template_id_173fedf5_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition-group",
- {
- class: [
- "el-upload-list",
- "el-upload-list--" + _vm.listType,
- { "is-disabled": _vm.disabled }
- ],
- attrs: { tag: "ul", name: "el-list" }
- },
- _vm._l(_vm.files, function(file) {
- return _c(
- "li",
- {
- key: file.uid,
- class: [
- "el-upload-list__item",
- "is-" + file.status,
- _vm.focusing ? "focusing" : ""
- ],
- attrs: { tabindex: "0" },
- on: {
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "delete", [8, 46], $event.key, [
- "Backspace",
- "Delete",
- "Del"
- ])
- ) {
- return null
- }
- !_vm.disabled && _vm.$emit("remove", file)
- },
- focus: function($event) {
- _vm.focusing = true
- },
- blur: function($event) {
- _vm.focusing = false
- },
- click: function($event) {
- _vm.focusing = false
- }
- }
- },
- [
- _vm._t(
- "default",
- [
- file.status !== "uploading" &&
- ["picture-card", "picture"].indexOf(_vm.listType) > -1
- ? _c("img", {
- staticClass: "el-upload-list__item-thumbnail",
- attrs: { src: file.url, alt: "" }
- })
- : _vm._e(),
- _c(
- "a",
- {
- staticClass: "el-upload-list__item-name",
- on: {
- click: function($event) {
- _vm.handleClick(file)
- }
- }
- },
- [
- _c("i", { staticClass: "el-icon-document" }),
- _vm._v(_vm._s(file.name) + "\n ")
- ]
- ),
- _c(
- "label",
- { staticClass: "el-upload-list__item-status-label" },
- [
- _c("i", {
- class: {
- "el-icon-upload-success": true,
- "el-icon-circle-check": _vm.listType === "text",
- "el-icon-check":
- ["picture-card", "picture"].indexOf(_vm.listType) > -1
- }
- })
- ]
- ),
- !_vm.disabled
- ? _c("i", {
- staticClass: "el-icon-close",
- on: {
- click: function($event) {
- _vm.$emit("remove", file)
- }
- }
- })
- : _vm._e(),
- !_vm.disabled
- ? _c("i", { staticClass: "el-icon-close-tip" }, [
- _vm._v(_vm._s(_vm.t("el.upload.deleteTip")))
- ])
- : _vm._e(),
- file.status === "uploading"
- ? _c("el-progress", {
- attrs: {
- type: _vm.listType === "picture-card" ? "circle" : "line",
- "stroke-width": _vm.listType === "picture-card" ? 6 : 2,
- percentage: _vm.parsePercentage(file.percentage)
- }
- })
- : _vm._e(),
- _vm.listType === "picture-card"
- ? _c("span", { staticClass: "el-upload-list__item-actions" }, [
- _vm.handlePreview && _vm.listType === "picture-card"
- ? _c(
- "span",
- {
- staticClass: "el-upload-list__item-preview",
- on: {
- click: function($event) {
- _vm.handlePreview(file)
- }
- }
- },
- [_c("i", { staticClass: "el-icon-zoom-in" })]
- )
- : _vm._e(),
- !_vm.disabled
- ? _c(
- "span",
- {
- staticClass: "el-upload-list__item-delete",
- on: {
- click: function($event) {
- _vm.$emit("remove", file)
- }
- }
- },
- [_c("i", { staticClass: "el-icon-delete" })]
- )
- : _vm._e()
- ])
- : _vm._e()
- ],
- { file: file }
- )
- ],
- 2
- )
- }),
- 0
- )
- }
- var upload_listvue_type_template_id_173fedf5_staticRenderFns = []
- upload_listvue_type_template_id_173fedf5_render._withStripped = true
- // CONCATENATED MODULE: ./packages/upload/src/upload-list.vue?vue&type=template&id=173fedf5&
- // EXTERNAL MODULE: external "element-ui/lib/progress"
- var progress_ = __webpack_require__(34);
- var progress_default = /*#__PURE__*/__webpack_require__.n(progress_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/upload-list.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var upload_listvue_type_script_lang_js_ = ({
- name: 'ElUploadList',
- mixins: [locale_default.a],
- data: function data() {
- return {
- focusing: false
- };
- },
- components: { ElProgress: progress_default.a },
- props: {
- files: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- disabled: {
- type: Boolean,
- default: false
- },
- handlePreview: Function,
- listType: String
- },
- methods: {
- parsePercentage: function parsePercentage(val) {
- return parseInt(val, 10);
- },
- handleClick: function handleClick(file) {
- this.handlePreview && this.handlePreview(file);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/upload/src/upload-list.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_upload_listvue_type_script_lang_js_ = (upload_listvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/upload/src/upload-list.vue
- /* normalize component */
- var upload_list_component = normalizeComponent(
- src_upload_listvue_type_script_lang_js_,
- upload_listvue_type_template_id_173fedf5_render,
- upload_listvue_type_template_id_173fedf5_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var upload_list_api; }
- upload_list_component.options.__file = "packages/upload/src/upload-list.vue"
- /* harmony default export */ var upload_list = (upload_list_component.exports);
- // EXTERNAL MODULE: external "babel-helper-vue-jsx-merge-props"
- var external_babel_helper_vue_jsx_merge_props_ = __webpack_require__(24);
- var external_babel_helper_vue_jsx_merge_props_default = /*#__PURE__*/__webpack_require__.n(external_babel_helper_vue_jsx_merge_props_);
- // CONCATENATED MODULE: ./packages/upload/src/ajax.js
- function getError(action, option, xhr) {
- var msg = void 0;
- if (xhr.response) {
- msg = '' + (xhr.response.error || xhr.response);
- } else if (xhr.responseText) {
- msg = '' + xhr.responseText;
- } else {
- msg = 'fail to post ' + action + ' ' + xhr.status;
- }
- var err = new Error(msg);
- err.status = xhr.status;
- err.method = 'post';
- err.url = action;
- return err;
- }
- function getBody(xhr) {
- var text = xhr.responseText || xhr.response;
- if (!text) {
- return text;
- }
- try {
- return JSON.parse(text);
- } catch (e) {
- return text;
- }
- }
- function upload(option) {
- if (typeof XMLHttpRequest === 'undefined') {
- return;
- }
- var xhr = new XMLHttpRequest();
- var action = option.action;
- if (xhr.upload) {
- xhr.upload.onprogress = function progress(e) {
- if (e.total > 0) {
- e.percent = e.loaded / e.total * 100;
- }
- option.onProgress(e);
- };
- }
- var formData = new FormData();
- if (option.data) {
- Object.keys(option.data).forEach(function (key) {
- formData.append(key, option.data[key]);
- });
- }
- formData.append(option.filename, option.file, option.file.name);
- xhr.onerror = function error(e) {
- option.onError(e);
- };
- xhr.onload = function onload() {
- if (xhr.status < 200 || xhr.status >= 300) {
- return option.onError(getError(action, option, xhr));
- }
- option.onSuccess(getBody(xhr));
- };
- xhr.open('post', action, true);
- if (option.withCredentials && 'withCredentials' in xhr) {
- xhr.withCredentials = true;
- }
- var headers = option.headers || {};
- for (var item in headers) {
- if (headers.hasOwnProperty(item) && headers[item] !== null) {
- xhr.setRequestHeader(item, headers[item]);
- }
- }
- xhr.send(formData);
- return xhr;
- }
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/upload-dragger.vue?vue&type=template&id=7ebbf219&
- var upload_draggervue_type_template_id_7ebbf219_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-upload-dragger",
- class: {
- "is-dragover": _vm.dragover
- },
- on: {
- drop: function($event) {
- $event.preventDefault()
- return _vm.onDrop($event)
- },
- dragover: function($event) {
- $event.preventDefault()
- return _vm.onDragover($event)
- },
- dragleave: function($event) {
- $event.preventDefault()
- _vm.dragover = false
- }
- }
- },
- [_vm._t("default")],
- 2
- )
- }
- var upload_draggervue_type_template_id_7ebbf219_staticRenderFns = []
- upload_draggervue_type_template_id_7ebbf219_render._withStripped = true
- // CONCATENATED MODULE: ./packages/upload/src/upload-dragger.vue?vue&type=template&id=7ebbf219&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/upload-dragger.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var upload_draggervue_type_script_lang_js_ = ({
- name: 'ElUploadDrag',
- props: {
- disabled: Boolean
- },
- inject: {
- uploader: {
- default: ''
- }
- },
- data: function data() {
- return {
- dragover: false
- };
- },
- methods: {
- onDragover: function onDragover() {
- if (!this.disabled) {
- this.dragover = true;
- }
- },
- onDrop: function onDrop(e) {
- if (this.disabled || !this.uploader) return;
- var accept = this.uploader.accept;
- this.dragover = false;
- if (!accept) {
- this.$emit('file', e.dataTransfer.files);
- return;
- }
- this.$emit('file', [].slice.call(e.dataTransfer.files).filter(function (file) {
- var type = file.type,
- name = file.name;
- var extension = name.indexOf('.') > -1 ? '.' + name.split('.').pop() : '';
- var baseType = type.replace(/\/.*$/, '');
- return accept.split(',').map(function (type) {
- return type.trim();
- }).filter(function (type) {
- return type;
- }).some(function (acceptedType) {
- if (/\..+$/.test(acceptedType)) {
- return extension === acceptedType;
- }
- if (/\/\*$/.test(acceptedType)) {
- return baseType === acceptedType.replace(/\/\*$/, '');
- }
- if (/^[^\/]+\/[^\/]+$/.test(acceptedType)) {
- return type === acceptedType;
- }
- return false;
- });
- }));
- }
- }
- });
- // CONCATENATED MODULE: ./packages/upload/src/upload-dragger.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_upload_draggervue_type_script_lang_js_ = (upload_draggervue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/upload/src/upload-dragger.vue
- /* normalize component */
- var upload_dragger_component = normalizeComponent(
- src_upload_draggervue_type_script_lang_js_,
- upload_draggervue_type_template_id_7ebbf219_render,
- upload_draggervue_type_template_id_7ebbf219_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var upload_dragger_api; }
- upload_dragger_component.options.__file = "packages/upload/src/upload-dragger.vue"
- /* harmony default export */ var upload_dragger = (upload_dragger_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/upload.vue?vue&type=script&lang=js&
- /* harmony default export */ var uploadvue_type_script_lang_js_ = ({
- inject: ['uploader'],
- components: {
- UploadDragger: upload_dragger
- },
- props: {
- type: String,
- action: {
- type: String,
- required: true
- },
- name: {
- type: String,
- default: 'file'
- },
- data: Object,
- headers: Object,
- withCredentials: Boolean,
- multiple: Boolean,
- accept: String,
- onStart: Function,
- onProgress: Function,
- onSuccess: Function,
- onError: Function,
- beforeUpload: Function,
- drag: Boolean,
- onPreview: {
- type: Function,
- default: function _default() {}
- },
- onRemove: {
- type: Function,
- default: function _default() {}
- },
- fileList: Array,
- autoUpload: Boolean,
- listType: String,
- httpRequest: {
- type: Function,
- default: upload
- },
- disabled: Boolean,
- limit: Number,
- onExceed: Function
- },
- data: function data() {
- return {
- mouseover: false,
- reqs: {}
- };
- },
- methods: {
- isImage: function isImage(str) {
- return str.indexOf('image') !== -1;
- },
- handleChange: function handleChange(ev) {
- var files = ev.target.files;
- if (!files) return;
- this.uploadFiles(files);
- },
- uploadFiles: function uploadFiles(files) {
- var _this = this;
- if (this.limit && this.fileList.length + files.length > this.limit) {
- this.onExceed && this.onExceed(files, this.fileList);
- return;
- }
- var postFiles = Array.prototype.slice.call(files);
- if (!this.multiple) {
- postFiles = postFiles.slice(0, 1);
- }
- if (postFiles.length === 0) {
- return;
- }
- postFiles.forEach(function (rawFile) {
- _this.onStart(rawFile);
- if (_this.autoUpload) _this.upload(rawFile);
- });
- },
- upload: function upload(rawFile) {
- var _this2 = this;
- this.$refs.input.value = null;
- if (!this.beforeUpload) {
- return this.post(rawFile);
- }
- var before = this.beforeUpload(rawFile);
- if (before && before.then) {
- before.then(function (processedFile) {
- var fileType = Object.prototype.toString.call(processedFile);
- if (fileType === '[object File]' || fileType === '[object Blob]') {
- if (fileType === '[object Blob]') {
- processedFile = new File([processedFile], rawFile.name, {
- type: rawFile.type
- });
- }
- for (var p in rawFile) {
- if (rawFile.hasOwnProperty(p)) {
- processedFile[p] = rawFile[p];
- }
- }
- _this2.post(processedFile);
- } else {
- _this2.post(rawFile);
- }
- }, function () {
- _this2.onRemove(null, rawFile);
- });
- } else if (before !== false) {
- this.post(rawFile);
- } else {
- this.onRemove(null, rawFile);
- }
- },
- abort: function abort(file) {
- var reqs = this.reqs;
- if (file) {
- var uid = file;
- if (file.uid) uid = file.uid;
- if (reqs[uid]) {
- reqs[uid].abort();
- }
- } else {
- Object.keys(reqs).forEach(function (uid) {
- if (reqs[uid]) reqs[uid].abort();
- delete reqs[uid];
- });
- }
- },
- post: function post(rawFile) {
- var _this3 = this;
- var uid = rawFile.uid;
- var options = {
- headers: this.headers,
- withCredentials: this.withCredentials,
- file: rawFile,
- data: this.data,
- filename: this.name,
- action: this.action,
- onProgress: function onProgress(e) {
- _this3.onProgress(e, rawFile);
- },
- onSuccess: function onSuccess(res) {
- _this3.onSuccess(res, rawFile);
- delete _this3.reqs[uid];
- },
- onError: function onError(err) {
- _this3.onError(err, rawFile);
- delete _this3.reqs[uid];
- }
- };
- var req = this.httpRequest(options);
- this.reqs[uid] = req;
- if (req && req.then) {
- req.then(options.onSuccess, options.onError);
- }
- },
- handleClick: function handleClick() {
- if (!this.disabled) {
- this.$refs.input.value = null;
- this.$refs.input.click();
- }
- },
- handleKeydown: function handleKeydown(e) {
- if (e.target !== e.currentTarget) return;
- if (e.keyCode === 13 || e.keyCode === 32) {
- this.handleClick();
- }
- }
- },
- render: function render(h) {
- var handleClick = this.handleClick,
- drag = this.drag,
- name = this.name,
- handleChange = this.handleChange,
- multiple = this.multiple,
- accept = this.accept,
- listType = this.listType,
- uploadFiles = this.uploadFiles,
- disabled = this.disabled,
- handleKeydown = this.handleKeydown;
- var data = {
- class: {
- 'el-upload': true
- },
- on: {
- click: handleClick,
- keydown: handleKeydown
- }
- };
- data.class['el-upload--' + listType] = true;
- return h(
- 'div',
- external_babel_helper_vue_jsx_merge_props_default()([data, {
- attrs: { tabindex: '0' }
- }]),
- [drag ? h(
- 'upload-dragger',
- {
- attrs: { disabled: disabled },
- on: {
- 'file': uploadFiles
- }
- },
- [this.$slots.default]
- ) : this.$slots.default, h('input', { 'class': 'el-upload__input', attrs: { type: 'file', name: name, multiple: multiple, accept: accept },
- ref: 'input', on: {
- 'change': handleChange
- }
- })]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/upload/src/upload.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_uploadvue_type_script_lang_js_ = (uploadvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/upload/src/upload.vue
- var upload_render, upload_staticRenderFns
- /* normalize component */
- var upload_component = normalizeComponent(
- src_uploadvue_type_script_lang_js_,
- upload_render,
- upload_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var upload_api; }
- upload_component.options.__file = "packages/upload/src/upload.vue"
- /* harmony default export */ var src_upload = (upload_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/index.vue?vue&type=script&lang=js&
- function srcvue_type_script_lang_js_noop() {}
- /* harmony default export */ var srcvue_type_script_lang_js_ = ({
- name: 'ElUpload',
- mixins: [migrating_default.a],
- components: {
- ElProgress: progress_default.a,
- UploadList: upload_list,
- Upload: src_upload
- },
- provide: function provide() {
- return {
- uploader: this
- };
- },
- inject: {
- elForm: {
- default: ''
- }
- },
- props: {
- action: {
- type: String,
- required: true
- },
- headers: {
- type: Object,
- default: function _default() {
- return {};
- }
- },
- data: Object,
- multiple: Boolean,
- name: {
- type: String,
- default: 'file'
- },
- drag: Boolean,
- dragger: Boolean,
- withCredentials: Boolean,
- showFileList: {
- type: Boolean,
- default: true
- },
- accept: String,
- type: {
- type: String,
- default: 'select'
- },
- beforeUpload: Function,
- beforeRemove: Function,
- onRemove: {
- type: Function,
- default: srcvue_type_script_lang_js_noop
- },
- onChange: {
- type: Function,
- default: srcvue_type_script_lang_js_noop
- },
- onPreview: {
- type: Function
- },
- onSuccess: {
- type: Function,
- default: srcvue_type_script_lang_js_noop
- },
- onProgress: {
- type: Function,
- default: srcvue_type_script_lang_js_noop
- },
- onError: {
- type: Function,
- default: srcvue_type_script_lang_js_noop
- },
- fileList: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- autoUpload: {
- type: Boolean,
- default: true
- },
- listType: {
- type: String,
- default: 'text' // text,picture,picture-card
- },
- httpRequest: Function,
- disabled: Boolean,
- limit: Number,
- onExceed: {
- type: Function,
- default: srcvue_type_script_lang_js_noop
- }
- },
- data: function data() {
- return {
- uploadFiles: [],
- dragOver: false,
- draging: false,
- tempIndex: 1
- };
- },
- computed: {
- uploadDisabled: function uploadDisabled() {
- return this.disabled || (this.elForm || {}).disabled;
- }
- },
- watch: {
- listType: function listType(type) {
- if (type === 'picture-card' || type === 'picture') {
- this.uploadFiles = this.uploadFiles.map(function (file) {
- if (!file.url && file.raw) {
- try {
- file.url = URL.createObjectURL(file.raw);
- } catch (err) {
- console.error('[Element Error][Upload]', err);
- }
- }
- return file;
- });
- }
- },
- fileList: {
- immediate: true,
- handler: function handler(fileList) {
- var _this = this;
- this.uploadFiles = fileList.map(function (item) {
- item.uid = item.uid || Date.now() + _this.tempIndex++;
- item.status = item.status || 'success';
- return item;
- });
- }
- }
- },
- methods: {
- handleStart: function handleStart(rawFile) {
- rawFile.uid = Date.now() + this.tempIndex++;
- var file = {
- status: 'ready',
- name: rawFile.name,
- size: rawFile.size,
- percentage: 0,
- uid: rawFile.uid,
- raw: rawFile
- };
- if (this.listType === 'picture-card' || this.listType === 'picture') {
- try {
- file.url = URL.createObjectURL(rawFile);
- } catch (err) {
- console.error('[Element Error][Upload]', err);
- return;
- }
- }
- this.uploadFiles.push(file);
- this.onChange(file, this.uploadFiles);
- },
- handleProgress: function handleProgress(ev, rawFile) {
- var file = this.getFile(rawFile);
- this.onProgress(ev, file, this.uploadFiles);
- file.status = 'uploading';
- file.percentage = ev.percent || 0;
- },
- handleSuccess: function handleSuccess(res, rawFile) {
- var file = this.getFile(rawFile);
- if (file) {
- file.status = 'success';
- file.response = res;
- this.onSuccess(res, file, this.uploadFiles);
- this.onChange(file, this.uploadFiles);
- }
- },
- handleError: function handleError(err, rawFile) {
- var file = this.getFile(rawFile);
- var fileList = this.uploadFiles;
- file.status = 'fail';
- fileList.splice(fileList.indexOf(file), 1);
- this.onError(err, file, this.uploadFiles);
- this.onChange(file, this.uploadFiles);
- },
- handleRemove: function handleRemove(file, raw) {
- var _this2 = this;
- if (raw) {
- file = this.getFile(raw);
- }
- var doRemove = function doRemove() {
- _this2.abort(file);
- var fileList = _this2.uploadFiles;
- fileList.splice(fileList.indexOf(file), 1);
- _this2.onRemove(file, fileList);
- };
- if (!this.beforeRemove) {
- doRemove();
- } else if (typeof this.beforeRemove === 'function') {
- var before = this.beforeRemove(file, this.uploadFiles);
- if (before && before.then) {
- before.then(function () {
- doRemove();
- }, srcvue_type_script_lang_js_noop);
- } else if (before !== false) {
- doRemove();
- }
- }
- },
- getFile: function getFile(rawFile) {
- var fileList = this.uploadFiles;
- var target = void 0;
- fileList.every(function (item) {
- target = rawFile.uid === item.uid ? item : null;
- return !target;
- });
- return target;
- },
- abort: function abort(file) {
- this.$refs['upload-inner'].abort(file);
- },
- clearFiles: function clearFiles() {
- this.uploadFiles = [];
- },
- submit: function submit() {
- var _this3 = this;
- this.uploadFiles.filter(function (file) {
- return file.status === 'ready';
- }).forEach(function (file) {
- _this3.$refs['upload-inner'].upload(file.raw);
- });
- },
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'default-file-list': 'default-file-list is renamed to file-list.',
- 'show-upload-list': 'show-upload-list is renamed to show-file-list.',
- 'thumbnail-mode': 'thumbnail-mode has been deprecated, you can implement the same effect according to this case: http://element.eleme.io/#/zh-CN/component/upload#yong-hu-tou-xiang-shang-chuan'
- }
- };
- }
- },
- beforeDestroy: function beforeDestroy() {
- this.uploadFiles.forEach(function (file) {
- if (file.url && file.url.indexOf('blob:') === 0) {
- URL.revokeObjectURL(file.url);
- }
- });
- },
- render: function render(h) {
- var _this4 = this;
- var uploadList = void 0;
- if (this.showFileList) {
- uploadList = h(
- upload_list,
- {
- attrs: {
- disabled: this.uploadDisabled,
- listType: this.listType,
- files: this.uploadFiles,
- handlePreview: this.onPreview },
- on: {
- 'remove': this.handleRemove
- }
- },
- [function (props) {
- if (_this4.$scopedSlots.file) {
- return _this4.$scopedSlots.file({
- file: props.file
- });
- }
- }]
- );
- }
- var uploadData = {
- props: {
- type: this.type,
- drag: this.drag,
- action: this.action,
- multiple: this.multiple,
- 'before-upload': this.beforeUpload,
- 'with-credentials': this.withCredentials,
- headers: this.headers,
- name: this.name,
- data: this.data,
- accept: this.accept,
- fileList: this.uploadFiles,
- autoUpload: this.autoUpload,
- listType: this.listType,
- disabled: this.uploadDisabled,
- limit: this.limit,
- 'on-exceed': this.onExceed,
- 'on-start': this.handleStart,
- 'on-progress': this.handleProgress,
- 'on-success': this.handleSuccess,
- 'on-error': this.handleError,
- 'on-preview': this.onPreview,
- 'on-remove': this.handleRemove,
- 'http-request': this.httpRequest
- },
- ref: 'upload-inner'
- };
- var trigger = this.$slots.trigger || this.$slots.default;
- var uploadComponent = h(
- 'upload',
- uploadData,
- [trigger]
- );
- return h('div', [this.listType === 'picture-card' ? uploadList : '', this.$slots.trigger ? [uploadComponent, this.$slots.default] : uploadComponent, this.$slots.tip, this.listType !== 'picture-card' ? uploadList : '']);
- }
- });
- // CONCATENATED MODULE: ./packages/upload/src/index.vue?vue&type=script&lang=js&
- /* harmony default export */ var upload_srcvue_type_script_lang_js_ = (srcvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/upload/src/index.vue
- var src_render, src_staticRenderFns
- /* normalize component */
- var upload_src_component = normalizeComponent(
- upload_srcvue_type_script_lang_js_,
- src_render,
- src_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var src_api; }
- upload_src_component.options.__file = "packages/upload/src/index.vue"
- /* harmony default export */ var upload_src = (upload_src_component.exports);
- // CONCATENATED MODULE: ./packages/upload/index.js
- /* istanbul ignore next */
- upload_src.install = function (Vue) {
- Vue.component(upload_src.name, upload_src);
- };
- /* harmony default export */ var packages_upload = (upload_src);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/progress/src/progress.vue?vue&type=template&id=229ee406&
- var progressvue_type_template_id_229ee406_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-progress",
- class: [
- "el-progress--" + _vm.type,
- _vm.status ? "is-" + _vm.status : "",
- {
- "el-progress--without-text": !_vm.showText,
- "el-progress--text-inside": _vm.textInside
- }
- ],
- attrs: {
- role: "progressbar",
- "aria-valuenow": _vm.percentage,
- "aria-valuemin": "0",
- "aria-valuemax": "100"
- }
- },
- [
- _vm.type === "line"
- ? _c("div", { staticClass: "el-progress-bar" }, [
- _c(
- "div",
- {
- staticClass: "el-progress-bar__outer",
- style: {
- height: _vm.strokeWidth + "px",
- backgroundColor: _vm.defineBackColor
- }
- },
- [
- _c(
- "div",
- {
- staticClass: "el-progress-bar__inner",
- style: _vm.barStyle
- },
- [
- _vm.showText && _vm.textInside
- ? _c(
- "div",
- {
- staticClass: "el-progress-bar__innerText",
- style: { color: _vm.textColor }
- },
- [_vm._v(_vm._s(_vm.content))]
- )
- : _vm._e()
- ]
- )
- ]
- )
- ])
- : _c(
- "div",
- {
- staticClass: "el-progress-circle",
- style: { height: _vm.width + "px", width: _vm.width + "px" }
- },
- [
- _c("svg", { attrs: { viewBox: "0 0 100 100" } }, [
- _c("path", {
- staticClass: "el-progress-circle__track",
- style: _vm.trailPathStyle,
- attrs: {
- d: _vm.trackPath,
- stroke: _vm.defineBackColor,
- "stroke-width": _vm.relativeStrokeWidth,
- fill: "none"
- }
- }),
- _c("path", {
- staticClass: "el-progress-circle__path",
- style: _vm.circlePathStyle,
- attrs: {
- d: _vm.trackPath,
- stroke: _vm.stroke,
- fill: "none",
- "stroke-linecap": _vm.strokeLinecap,
- "stroke-width": _vm.percentage ? _vm.relativeStrokeWidth : 0
- }
- })
- ])
- ]
- ),
- _vm.showText && !_vm.textInside
- ? _c(
- "div",
- {
- staticClass: "el-progress__text",
- style: {
- fontSize: _vm.progressTextSize + "px",
- color: _vm.textColor
- }
- },
- [
- !_vm.status
- ? [_vm._v(_vm._s(_vm.content))]
- : _c("i", { class: _vm.iconClass })
- ],
- 2
- )
- : _vm._e()
- ]
- )
- }
- var progressvue_type_template_id_229ee406_staticRenderFns = []
- progressvue_type_template_id_229ee406_render._withStripped = true
- // CONCATENATED MODULE: ./packages/progress/src/progress.vue?vue&type=template&id=229ee406&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/progress/src/progress.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var progressvue_type_script_lang_js_ = ({
- name: 'ElProgress',
- props: {
- type: {
- type: String,
- default: 'line',
- validator: function validator(val) {
- return ['line', 'circle', 'dashboard'].indexOf(val) > -1;
- }
- },
- percentage: {
- type: Number,
- default: 0,
- required: true,
- validator: function validator(val) {
- return val >= 0 && val <= 100;
- }
- },
- status: {
- type: String,
- validator: function validator(val) {
- return ['success', 'exception', 'warning'].indexOf(val) > -1;
- }
- },
- strokeWidth: {
- type: Number,
- default: 6
- },
- strokeLinecap: {
- type: String,
- default: 'round'
- },
- textInside: {
- type: Boolean,
- default: false
- },
- width: {
- type: Number,
- default: 126
- },
- showText: {
- type: Boolean,
- default: true
- },
- color: {
- type: [String, Array, Function],
- default: ''
- },
- defineBackColor: {
- type: [String, Array, Function],
- default: '#ebeef5'
- },
- textColor: {
- type: [String, Array, Function],
- default: '#606266'
- },
- format: Function
- },
- computed: {
- barStyle: function barStyle() {
- var style = {};
- style.width = this.percentage + '%';
- style.backgroundColor = this.getCurrentColor(this.percentage);
- return style;
- },
- relativeStrokeWidth: function relativeStrokeWidth() {
- return (this.strokeWidth / this.width * 100).toFixed(1);
- },
- radius: function radius() {
- if (this.type === 'circle' || this.type === 'dashboard') {
- return parseInt(50 - parseFloat(this.relativeStrokeWidth) / 2, 10);
- } else {
- return 0;
- }
- },
- trackPath: function trackPath() {
- var radius = this.radius;
- var isDashboard = this.type === 'dashboard';
- return '\n M 50 50\n m 0 ' + (isDashboard ? '' : '-') + radius + '\n a ' + radius + ' ' + radius + ' 0 1 1 0 ' + (isDashboard ? '-' : '') + radius * 2 + '\n a ' + radius + ' ' + radius + ' 0 1 1 0 ' + (isDashboard ? '' : '-') + radius * 2 + '\n ';
- },
- perimeter: function perimeter() {
- return 2 * Math.PI * this.radius;
- },
- rate: function rate() {
- return this.type === 'dashboard' ? 0.75 : 1;
- },
- strokeDashoffset: function strokeDashoffset() {
- var offset = -1 * this.perimeter * (1 - this.rate) / 2;
- return offset + 'px';
- },
- trailPathStyle: function trailPathStyle() {
- return {
- strokeDasharray: this.perimeter * this.rate + 'px, ' + this.perimeter + 'px',
- strokeDashoffset: this.strokeDashoffset
- };
- },
- circlePathStyle: function circlePathStyle() {
- return {
- strokeDasharray: this.perimeter * this.rate * (this.percentage / 100) + 'px, ' + this.perimeter + 'px',
- strokeDashoffset: this.strokeDashoffset,
- transition: 'stroke-dasharray 0.6s ease 0s, stroke 0.6s ease'
- };
- },
- stroke: function stroke() {
- var ret = void 0;
- if (this.color) {
- ret = this.getCurrentColor(this.percentage);
- } else {
- switch (this.status) {
- case 'success':
- ret = '#13ce66';
- break;
- case 'exception':
- ret = '#ff4949';
- break;
- case 'warning':
- ret = '#e6a23c';
- break;
- default:
- ret = '#20a0ff';
- }
- }
- return ret;
- },
- iconClass: function iconClass() {
- if (this.status === 'warning') {
- return 'el-icon-warning';
- }
- if (this.type === 'line') {
- return this.status === 'success' ? 'el-icon-circle-check' : 'el-icon-circle-close';
- } else {
- return this.status === 'success' ? 'el-icon-check' : 'el-icon-close';
- }
- },
- progressTextSize: function progressTextSize() {
- return this.type === 'line' ? 12 + this.strokeWidth * 0.4 : this.width * 0.111111 + 2;
- },
- content: function content() {
- if (typeof this.format === 'function') {
- return this.format(this.percentage) || '';
- } else {
- return this.percentage + '%';
- }
- }
- },
- methods: {
- getCurrentColor: function getCurrentColor(percentage) {
- if (typeof this.color === 'function') {
- return this.color(percentage);
- } else if (typeof this.color === 'string') {
- return this.color;
- } else {
- return this.getLevelColor(percentage);
- }
- },
- getLevelColor: function getLevelColor(percentage) {
- var colorArray = this.getColorArray().sort(function (a, b) {
- return a.percentage - b.percentage;
- });
- for (var i = 0; i < colorArray.length; i++) {
- if (colorArray[i].percentage > percentage) {
- return colorArray[i].color;
- }
- }
- return colorArray[colorArray.length - 1].color;
- },
- getColorArray: function getColorArray() {
- var color = this.color;
- var span = 100 / color.length;
- return color.map(function (seriesColor, index) {
- if (typeof seriesColor === 'string') {
- return {
- color: seriesColor,
- percentage: (index + 1) * span
- };
- }
- return seriesColor;
- });
- }
- }
- });
- // CONCATENATED MODULE: ./packages/progress/src/progress.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_progressvue_type_script_lang_js_ = (progressvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/progress/src/progress.vue
- /* normalize component */
- var progress_component = normalizeComponent(
- src_progressvue_type_script_lang_js_,
- progressvue_type_template_id_229ee406_render,
- progressvue_type_template_id_229ee406_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var progress_api; }
- progress_component.options.__file = "packages/progress/src/progress.vue"
- /* harmony default export */ var progress = (progress_component.exports);
- // CONCATENATED MODULE: ./packages/progress/index.js
- /* istanbul ignore next */
- progress.install = function (Vue) {
- Vue.component(progress.name, progress);
- };
- /* harmony default export */ var packages_progress = (progress);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/spinner/src/spinner.vue?vue&type=template&id=697b8538&
- var spinnervue_type_template_id_697b8538_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("span", { staticClass: "el-spinner" }, [
- _c(
- "svg",
- {
- staticClass: "el-spinner-inner",
- style: { width: _vm.radius / 2 + "px", height: _vm.radius / 2 + "px" },
- attrs: { viewBox: "0 0 50 50" }
- },
- [
- _c("circle", {
- staticClass: "path",
- attrs: {
- cx: "25",
- cy: "25",
- r: "20",
- fill: "none",
- stroke: _vm.strokeColor,
- "stroke-width": _vm.strokeWidth
- }
- })
- ]
- )
- ])
- }
- var spinnervue_type_template_id_697b8538_staticRenderFns = []
- spinnervue_type_template_id_697b8538_render._withStripped = true
- // CONCATENATED MODULE: ./packages/spinner/src/spinner.vue?vue&type=template&id=697b8538&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/spinner/src/spinner.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var spinnervue_type_script_lang_js_ = ({
- name: 'ElSpinner',
- props: {
- type: String,
- radius: {
- type: Number,
- default: 100
- },
- strokeWidth: {
- type: Number,
- default: 5
- },
- strokeColor: {
- type: String,
- default: '#efefef'
- }
- }
- });
- // CONCATENATED MODULE: ./packages/spinner/src/spinner.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_spinnervue_type_script_lang_js_ = (spinnervue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/spinner/src/spinner.vue
- /* normalize component */
- var spinner_component = normalizeComponent(
- src_spinnervue_type_script_lang_js_,
- spinnervue_type_template_id_697b8538_render,
- spinnervue_type_template_id_697b8538_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var spinner_api; }
- spinner_component.options.__file = "packages/spinner/src/spinner.vue"
- /* harmony default export */ var spinner = (spinner_component.exports);
- // CONCATENATED MODULE: ./packages/spinner/index.js
- /* istanbul ignore next */
- spinner.install = function (Vue) {
- Vue.component(spinner.name, spinner);
- };
- /* harmony default export */ var packages_spinner = (spinner);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/message/src/main.vue?vue&type=template&id=455b9f60&
- var mainvue_type_template_id_455b9f60_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- {
- attrs: { name: "el-message-fade" },
- on: { "after-leave": _vm.handleAfterLeave }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- class: [
- "el-message",
- _vm.type && !_vm.iconClass ? "el-message--" + _vm.type : "",
- _vm.center ? "is-center" : "",
- _vm.showClose ? "is-closable" : "",
- _vm.customClass
- ],
- style: _vm.positionStyle,
- attrs: { role: "alert" },
- on: { mouseenter: _vm.clearTimer, mouseleave: _vm.startTimer }
- },
- [
- _vm.iconClass
- ? _c("i", { class: _vm.iconClass })
- : _c("i", { class: _vm.typeClass }),
- _vm._t("default", [
- !_vm.dangerouslyUseHTMLString
- ? _c("p", { staticClass: "el-message__content" }, [
- _vm._v(_vm._s(_vm.message))
- ])
- : _c("p", {
- staticClass: "el-message__content",
- domProps: { innerHTML: _vm._s(_vm.message) }
- })
- ]),
- _vm.showClose
- ? _c("i", {
- staticClass: "el-message__closeBtn el-icon-close",
- on: { click: _vm.close }
- })
- : _vm._e()
- ],
- 2
- )
- ]
- )
- }
- var mainvue_type_template_id_455b9f60_staticRenderFns = []
- mainvue_type_template_id_455b9f60_render._withStripped = true
- // CONCATENATED MODULE: ./packages/message/src/main.vue?vue&type=template&id=455b9f60&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/message/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var src_mainvue_type_script_lang_js_typeMap = {
- success: 'success',
- info: 'info',
- warning: 'warning',
- error: 'error'
- };
- /* harmony default export */ var message_src_mainvue_type_script_lang_js_ = ({
- data: function data() {
- return {
- visible: false,
- message: '',
- duration: 3000,
- type: 'info',
- iconClass: '',
- customClass: '',
- onClose: null,
- showClose: false,
- closed: false,
- verticalOffset: 20,
- timer: null,
- dangerouslyUseHTMLString: false,
- center: false
- };
- },
- computed: {
- typeClass: function typeClass() {
- return this.type && !this.iconClass ? 'el-message__icon el-icon-' + src_mainvue_type_script_lang_js_typeMap[this.type] : '';
- },
- positionStyle: function positionStyle() {
- return {
- 'top': this.verticalOffset + 'px'
- };
- }
- },
- watch: {
- closed: function closed(newVal) {
- if (newVal) {
- this.visible = false;
- }
- }
- },
- methods: {
- handleAfterLeave: function handleAfterLeave() {
- this.$destroy(true);
- this.$el.parentNode.removeChild(this.$el);
- },
- close: function close() {
- this.closed = true;
- if (typeof this.onClose === 'function') {
- this.onClose(this);
- }
- },
- clearTimer: function clearTimer() {
- clearTimeout(this.timer);
- },
- startTimer: function startTimer() {
- var _this = this;
- if (this.duration > 0) {
- this.timer = setTimeout(function () {
- if (!_this.closed) {
- _this.close();
- }
- }, this.duration);
- }
- },
- keydown: function keydown(e) {
- if (e.keyCode === 27) {
- // esc关闭消息
- if (!this.closed) {
- this.close();
- }
- }
- }
- },
- mounted: function mounted() {
- this.startTimer();
- document.addEventListener('keydown', this.keydown);
- },
- beforeDestroy: function beforeDestroy() {
- document.removeEventListener('keydown', this.keydown);
- }
- });
- // CONCATENATED MODULE: ./packages/message/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_message_src_mainvue_type_script_lang_js_ = (message_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/message/src/main.vue
- /* normalize component */
- var message_src_main_component = normalizeComponent(
- packages_message_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_455b9f60_render,
- mainvue_type_template_id_455b9f60_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var message_src_main_api; }
- message_src_main_component.options.__file = "packages/message/src/main.vue"
- /* harmony default export */ var message_src_main = (message_src_main_component.exports);
- // EXTERNAL MODULE: external "element-ui/lib/utils/types"
- var types_ = __webpack_require__(16);
- // CONCATENATED MODULE: ./packages/message/src/main.js
- var main_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- var MessageConstructor = external_vue_default.a.extend(message_src_main);
- var message_src_main_instance = void 0;
- var main_instances = [];
- var main_seed = 1;
- var main_Message = function Message(options) {
- if (external_vue_default.a.prototype.$isServer) return;
- options = options || {};
- if (typeof options === 'string') {
- options = {
- message: options
- };
- }
- var userOnClose = options.onClose;
- var id = 'message_' + main_seed++;
- options.onClose = function () {
- Message.close(id, userOnClose);
- };
- message_src_main_instance = new MessageConstructor({
- data: options
- });
- message_src_main_instance.id = id;
- if (Object(vdom_["isVNode"])(message_src_main_instance.message)) {
- message_src_main_instance.$slots.default = [message_src_main_instance.message];
- message_src_main_instance.message = null;
- }
- message_src_main_instance.$mount();
- document.body.appendChild(message_src_main_instance.$el);
- var verticalOffset = options.offset || 20;
- main_instances.forEach(function (item) {
- verticalOffset += item.$el.offsetHeight + 16;
- });
- message_src_main_instance.verticalOffset = verticalOffset;
- message_src_main_instance.visible = true;
- message_src_main_instance.$el.style.zIndex = popup_["PopupManager"].nextZIndex();
- main_instances.push(message_src_main_instance);
- return message_src_main_instance;
- };
- ['success', 'warning', 'info', 'error'].forEach(function (type) {
- main_Message[type] = function (options) {
- if (Object(types_["isObject"])(options) && !Object(vdom_["isVNode"])(options)) {
- return main_Message(main_extends({}, options, {
- type: type
- }));
- }
- return main_Message({
- type: type,
- message: options
- });
- };
- });
- main_Message.close = function (id, userOnClose) {
- var len = main_instances.length;
- var index = -1;
- var removedHeight = void 0;
- for (var i = 0; i < len; i++) {
- if (id === main_instances[i].id) {
- removedHeight = main_instances[i].$el.offsetHeight;
- index = i;
- if (typeof userOnClose === 'function') {
- userOnClose(main_instances[i]);
- }
- main_instances.splice(i, 1);
- break;
- }
- }
- if (len <= 1 || index === -1 || index > main_instances.length - 1) return;
- for (var _i = index; _i < len - 1; _i++) {
- var dom = main_instances[_i].$el;
- dom.style['top'] = parseInt(dom.style['top'], 10) - removedHeight - 16 + 'px';
- }
- };
- main_Message.closeAll = function () {
- for (var i = main_instances.length - 1; i >= 0; i--) {
- main_instances[i].close();
- }
- };
- /* harmony default export */ var packages_message_src_main = (main_Message);
- // CONCATENATED MODULE: ./packages/message/index.js
- /* harmony default export */ var packages_message = (packages_message_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/badge/src/main.vue?vue&type=template&id=7ccb6598&
- var mainvue_type_template_id_7ccb6598_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- { staticClass: "el-badge" },
- [
- _vm._t("default"),
- _c("transition", { attrs: { name: "el-zoom-in-center" } }, [
- _c("sup", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value:
- !_vm.hidden && (_vm.content || _vm.content === 0 || _vm.isDot),
- expression: "!hidden && (content || content === 0 || isDot)"
- }
- ],
- staticClass: "el-badge__content",
- class: [
- _vm.type ? "el-badge__content--" + _vm.type : null,
- {
- "is-fixed": _vm.$slots.default,
- "is-dot": _vm.isDot
- }
- ],
- domProps: { textContent: _vm._s(_vm.content) }
- })
- ])
- ],
- 2
- )
- }
- var mainvue_type_template_id_7ccb6598_staticRenderFns = []
- mainvue_type_template_id_7ccb6598_render._withStripped = true
- // CONCATENATED MODULE: ./packages/badge/src/main.vue?vue&type=template&id=7ccb6598&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/badge/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var badge_src_mainvue_type_script_lang_js_ = ({
- name: 'ElBadge',
- props: {
- value: [String, Number],
- max: Number,
- isDot: Boolean,
- hidden: Boolean,
- type: {
- type: String,
- validator: function validator(val) {
- return ['primary', 'success', 'warning', 'info', 'danger'].indexOf(val) > -1;
- }
- }
- },
- computed: {
- content: function content() {
- if (this.isDot) return;
- var value = this.value;
- var max = this.max;
- if (typeof value === 'number' && typeof max === 'number') {
- return max < value ? max + '+' : value;
- }
- return value;
- }
- }
- });
- // CONCATENATED MODULE: ./packages/badge/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_badge_src_mainvue_type_script_lang_js_ = (badge_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/badge/src/main.vue
- /* normalize component */
- var badge_src_main_component = normalizeComponent(
- packages_badge_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_7ccb6598_render,
- mainvue_type_template_id_7ccb6598_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var badge_src_main_api; }
- badge_src_main_component.options.__file = "packages/badge/src/main.vue"
- /* harmony default export */ var badge_src_main = (badge_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/badge/index.js
- /* istanbul ignore next */
- badge_src_main.install = function (Vue) {
- Vue.component(badge_src_main.name, badge_src_main);
- };
- /* harmony default export */ var badge = (badge_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/card/src/main.vue?vue&type=template&id=59a4a40f&
- var mainvue_type_template_id_59a4a40f_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-card",
- class: _vm.shadow ? "is-" + _vm.shadow + "-shadow" : "is-always-shadow"
- },
- [
- _vm.$slots.header || _vm.header
- ? _c(
- "div",
- { staticClass: "el-card__header" },
- [_vm._t("header", [_vm._v(_vm._s(_vm.header))])],
- 2
- )
- : _vm._e(),
- _c(
- "div",
- { staticClass: "el-card__body", style: _vm.bodyStyle },
- [_vm._t("default")],
- 2
- )
- ]
- )
- }
- var mainvue_type_template_id_59a4a40f_staticRenderFns = []
- mainvue_type_template_id_59a4a40f_render._withStripped = true
- // CONCATENATED MODULE: ./packages/card/src/main.vue?vue&type=template&id=59a4a40f&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/card/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var card_src_mainvue_type_script_lang_js_ = ({
- name: 'ElCard',
- props: {
- header: {},
- bodyStyle: {},
- shadow: {
- type: String
- }
- }
- });
- // CONCATENATED MODULE: ./packages/card/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_card_src_mainvue_type_script_lang_js_ = (card_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/card/src/main.vue
- /* normalize component */
- var card_src_main_component = normalizeComponent(
- packages_card_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_59a4a40f_render,
- mainvue_type_template_id_59a4a40f_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var card_src_main_api; }
- card_src_main_component.options.__file = "packages/card/src/main.vue"
- /* harmony default export */ var card_src_main = (card_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/card/index.js
- /* istanbul ignore next */
- card_src_main.install = function (Vue) {
- Vue.component(card_src_main.name, card_src_main);
- };
- /* harmony default export */ var card = (card_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/rate/src/main.vue?vue&type=template&id=ada57782&
- var mainvue_type_template_id_ada57782_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-rate",
- attrs: {
- role: "slider",
- "aria-valuenow": _vm.currentValue,
- "aria-valuetext": _vm.text,
- "aria-valuemin": "0",
- "aria-valuemax": _vm.max,
- tabindex: "0"
- },
- on: { keydown: _vm.handleKey }
- },
- [
- _vm._l(_vm.max, function(item, key) {
- return _c(
- "span",
- {
- key: key,
- staticClass: "el-rate__item",
- style: { cursor: _vm.rateDisabled ? "auto" : "pointer" },
- on: {
- mousemove: function($event) {
- _vm.setCurrentValue(item, $event)
- },
- mouseleave: _vm.resetCurrentValue,
- click: function($event) {
- _vm.selectValue(item)
- }
- }
- },
- [
- _c(
- "i",
- {
- staticClass: "el-rate__icon",
- class: [
- _vm.classes[item - 1],
- { hover: _vm.hoverIndex === item }
- ],
- style: _vm.getIconStyle(item)
- },
- [
- _vm.showDecimalIcon(item)
- ? _c("i", {
- staticClass: "el-rate__decimal",
- class: _vm.decimalIconClass,
- style: _vm.decimalStyle
- })
- : _vm._e()
- ]
- )
- ]
- )
- }),
- _vm.showText || _vm.showScore
- ? _c(
- "span",
- { staticClass: "el-rate__text", style: { color: _vm.textColor } },
- [_vm._v(_vm._s(_vm.text))]
- )
- : _vm._e()
- ],
- 2
- )
- }
- var mainvue_type_template_id_ada57782_staticRenderFns = []
- mainvue_type_template_id_ada57782_render._withStripped = true
- // CONCATENATED MODULE: ./packages/rate/src/main.vue?vue&type=template&id=ada57782&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/rate/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var rate_src_mainvue_type_script_lang_js_ = ({
- name: 'ElRate',
- mixins: [migrating_default.a],
- inject: {
- elForm: {
- default: ''
- }
- },
- data: function data() {
- return {
- pointerAtLeftHalf: true,
- currentValue: this.value,
- hoverIndex: -1
- };
- },
- props: {
- value: {
- type: Number,
- default: 0
- },
- lowThreshold: {
- type: Number,
- default: 2
- },
- highThreshold: {
- type: Number,
- default: 4
- },
- max: {
- type: Number,
- default: 5
- },
- colors: {
- type: [Array, Object],
- default: function _default() {
- return ['#F7BA2A', '#F7BA2A', '#F7BA2A'];
- }
- },
- voidColor: {
- type: String,
- default: '#C6D1DE'
- },
- disabledVoidColor: {
- type: String,
- default: '#EFF2F7'
- },
- iconClasses: {
- type: [Array, Object],
- default: function _default() {
- return ['el-icon-star-on', 'el-icon-star-on', 'el-icon-star-on'];
- }
- },
- voidIconClass: {
- type: String,
- default: 'el-icon-star-off'
- },
- disabledVoidIconClass: {
- type: String,
- default: 'el-icon-star-on'
- },
- disabled: {
- type: Boolean,
- default: false
- },
- allowHalf: {
- type: Boolean,
- default: false
- },
- showText: {
- type: Boolean,
- default: false
- },
- showScore: {
- type: Boolean,
- default: false
- },
- textColor: {
- type: String,
- default: '#1f2d3d'
- },
- texts: {
- type: Array,
- default: function _default() {
- return ['极差', '失望', '一般', '满意', '惊喜'];
- }
- },
- scoreTemplate: {
- type: String,
- default: '{value}'
- }
- },
- computed: {
- text: function text() {
- var result = '';
- if (this.showScore) {
- result = this.scoreTemplate.replace(/\{\s*value\s*\}/, this.rateDisabled ? this.value : this.currentValue);
- } else if (this.showText) {
- result = this.texts[Math.ceil(this.currentValue) - 1];
- }
- return result;
- },
- decimalStyle: function decimalStyle() {
- var width = '';
- if (this.rateDisabled) {
- width = this.valueDecimal + '%';
- } else if (this.allowHalf) {
- width = '50%';
- }
- return {
- color: this.activeColor,
- width: width
- };
- },
- valueDecimal: function valueDecimal() {
- return this.value * 100 - Math.floor(this.value) * 100;
- },
- classMap: function classMap() {
- var _ref;
- return Array.isArray(this.iconClasses) ? (_ref = {}, _ref[this.lowThreshold] = this.iconClasses[0], _ref[this.highThreshold] = { value: this.iconClasses[1], excluded: true }, _ref[this.max] = this.iconClasses[2], _ref) : this.iconClasses;
- },
- decimalIconClass: function decimalIconClass() {
- return this.getValueFromMap(this.value, this.classMap);
- },
- voidClass: function voidClass() {
- return this.rateDisabled ? this.disabledVoidIconClass : this.voidIconClass;
- },
- activeClass: function activeClass() {
- return this.getValueFromMap(this.currentValue, this.classMap);
- },
- colorMap: function colorMap() {
- var _ref2;
- return Array.isArray(this.colors) ? (_ref2 = {}, _ref2[this.lowThreshold] = this.colors[0], _ref2[this.highThreshold] = { value: this.colors[1], excluded: true }, _ref2[this.max] = this.colors[2], _ref2) : this.colors;
- },
- activeColor: function activeColor() {
- return this.getValueFromMap(this.currentValue, this.colorMap);
- },
- classes: function classes() {
- var result = [];
- var i = 0;
- var threshold = this.currentValue;
- if (this.allowHalf && this.currentValue !== Math.floor(this.currentValue)) {
- threshold--;
- }
- for (; i < threshold; i++) {
- result.push(this.activeClass);
- }
- for (; i < this.max; i++) {
- result.push(this.voidClass);
- }
- return result;
- },
- rateDisabled: function rateDisabled() {
- return this.disabled || (this.elForm || {}).disabled;
- }
- },
- watch: {
- value: function value(val) {
- this.currentValue = val;
- this.pointerAtLeftHalf = this.value !== Math.floor(this.value);
- }
- },
- methods: {
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'text-template': 'text-template is renamed to score-template.'
- }
- };
- },
- getValueFromMap: function getValueFromMap(value, map) {
- var matchedKeys = Object.keys(map).filter(function (key) {
- var val = map[key];
- var excluded = Object(types_["isObject"])(val) ? val.excluded : false;
- return excluded ? value < key : value <= key;
- }).sort(function (a, b) {
- return a - b;
- });
- var matchedValue = map[matchedKeys[0]];
- return Object(types_["isObject"])(matchedValue) ? matchedValue.value : matchedValue || '';
- },
- showDecimalIcon: function showDecimalIcon(item) {
- var showWhenDisabled = this.rateDisabled && this.valueDecimal > 0 && item - 1 < this.value && item > this.value;
- /* istanbul ignore next */
- var showWhenAllowHalf = this.allowHalf && this.pointerAtLeftHalf && item - 0.5 <= this.currentValue && item > this.currentValue;
- return showWhenDisabled || showWhenAllowHalf;
- },
- getIconStyle: function getIconStyle(item) {
- var voidColor = this.rateDisabled ? this.disabledVoidColor : this.voidColor;
- return {
- color: item <= this.currentValue ? this.activeColor : voidColor
- };
- },
- selectValue: function selectValue(value) {
- if (this.rateDisabled) {
- return;
- }
- if (this.allowHalf && this.pointerAtLeftHalf) {
- this.$emit('input', this.currentValue);
- this.$emit('change', this.currentValue);
- } else {
- this.$emit('input', value);
- this.$emit('change', value);
- }
- },
- handleKey: function handleKey(e) {
- if (this.rateDisabled) {
- return;
- }
- var currentValue = this.currentValue;
- var keyCode = e.keyCode;
- if (keyCode === 38 || keyCode === 39) {
- // left / down
- if (this.allowHalf) {
- currentValue += 0.5;
- } else {
- currentValue += 1;
- }
- e.stopPropagation();
- e.preventDefault();
- } else if (keyCode === 37 || keyCode === 40) {
- if (this.allowHalf) {
- currentValue -= 0.5;
- } else {
- currentValue -= 1;
- }
- e.stopPropagation();
- e.preventDefault();
- }
- currentValue = currentValue < 0 ? 0 : currentValue;
- currentValue = currentValue > this.max ? this.max : currentValue;
- this.$emit('input', currentValue);
- this.$emit('change', currentValue);
- },
- setCurrentValue: function setCurrentValue(value, event) {
- if (this.rateDisabled) {
- return;
- }
- /* istanbul ignore if */
- if (this.allowHalf) {
- var target = event.target;
- if (Object(dom_["hasClass"])(target, 'el-rate__item')) {
- target = target.querySelector('.el-rate__icon');
- }
- if (Object(dom_["hasClass"])(target, 'el-rate__decimal')) {
- target = target.parentNode;
- }
- this.pointerAtLeftHalf = event.offsetX * 2 <= target.clientWidth;
- this.currentValue = this.pointerAtLeftHalf ? value - 0.5 : value;
- } else {
- this.currentValue = value;
- }
- this.hoverIndex = value;
- },
- resetCurrentValue: function resetCurrentValue() {
- if (this.rateDisabled) {
- return;
- }
- if (this.allowHalf) {
- this.pointerAtLeftHalf = this.value !== Math.floor(this.value);
- }
- this.currentValue = this.value;
- this.hoverIndex = -1;
- }
- },
- created: function created() {
- if (!this.value) {
- this.$emit('input', 0);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/rate/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_rate_src_mainvue_type_script_lang_js_ = (rate_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/rate/src/main.vue
- /* normalize component */
- var rate_src_main_component = normalizeComponent(
- packages_rate_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_ada57782_render,
- mainvue_type_template_id_ada57782_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var rate_src_main_api; }
- rate_src_main_component.options.__file = "packages/rate/src/main.vue"
- /* harmony default export */ var rate_src_main = (rate_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/rate/index.js
- /* istanbul ignore next */
- rate_src_main.install = function (Vue) {
- Vue.component(rate_src_main.name, rate_src_main);
- };
- /* harmony default export */ var packages_rate = (rate_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/steps/src/steps.vue?vue&type=template&id=3c6b6dc0&
- var stepsvue_type_template_id_3c6b6dc0_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-steps",
- class: [
- !_vm.simple && "el-steps--" + _vm.direction,
- _vm.simple && "el-steps--simple"
- ]
- },
- [_vm._t("default")],
- 2
- )
- }
- var stepsvue_type_template_id_3c6b6dc0_staticRenderFns = []
- stepsvue_type_template_id_3c6b6dc0_render._withStripped = true
- // CONCATENATED MODULE: ./packages/steps/src/steps.vue?vue&type=template&id=3c6b6dc0&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/steps/src/steps.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var stepsvue_type_script_lang_js_ = ({
- name: 'ElSteps',
- mixins: [migrating_default.a],
- props: {
- space: [Number, String],
- active: Number,
- direction: {
- type: String,
- default: 'horizontal'
- },
- alignCenter: Boolean,
- simple: Boolean,
- finishStatus: {
- type: String,
- default: 'finish'
- },
- processStatus: {
- type: String,
- default: 'process'
- }
- },
- data: function data() {
- return {
- steps: [],
- stepOffset: 0
- };
- },
- methods: {
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'center': 'center is removed.'
- }
- };
- }
- },
- watch: {
- active: function active(newVal, oldVal) {
- this.$emit('change', newVal, oldVal);
- },
- steps: function steps(_steps) {
- _steps.forEach(function (child, index) {
- child.index = index;
- });
- }
- }
- });
- // CONCATENATED MODULE: ./packages/steps/src/steps.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_stepsvue_type_script_lang_js_ = (stepsvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/steps/src/steps.vue
- /* normalize component */
- var steps_component = normalizeComponent(
- src_stepsvue_type_script_lang_js_,
- stepsvue_type_template_id_3c6b6dc0_render,
- stepsvue_type_template_id_3c6b6dc0_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var steps_api; }
- steps_component.options.__file = "packages/steps/src/steps.vue"
- /* harmony default export */ var steps = (steps_component.exports);
- // CONCATENATED MODULE: ./packages/steps/index.js
- /* istanbul ignore next */
- steps.install = function (Vue) {
- Vue.component(steps.name, steps);
- };
- /* harmony default export */ var packages_steps = (steps);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/steps/src/step.vue?vue&type=template&id=f414a87a&
- var stepvue_type_template_id_f414a87a_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-step",
- class: [
- !_vm.isSimple && "is-" + _vm.$parent.direction,
- _vm.isSimple && "is-simple",
- _vm.isLast && !_vm.space && !_vm.isCenter && "is-flex",
- _vm.isCenter && !_vm.isVertical && !_vm.isSimple && "is-center"
- ],
- style: _vm.style
- },
- [
- _c(
- "div",
- { staticClass: "el-step__head", class: "is-" + _vm.currentStatus },
- [
- _c(
- "div",
- {
- staticClass: "el-step__line",
- style: _vm.isLast
- ? ""
- : { marginRight: _vm.$parent.stepOffset + "px" }
- },
- [
- _c("i", {
- staticClass: "el-step__line-inner",
- style: _vm.lineStyle
- })
- ]
- ),
- _c(
- "div",
- {
- staticClass: "el-step__icon",
- class: "is-" + (_vm.icon ? "icon" : "text")
- },
- [
- _vm.currentStatus !== "success" && _vm.currentStatus !== "error"
- ? _vm._t("icon", [
- _vm.icon
- ? _c("i", {
- staticClass: "el-step__icon-inner",
- class: [_vm.icon]
- })
- : _vm._e(),
- !_vm.icon && !_vm.isSimple
- ? _c("div", { staticClass: "el-step__icon-inner" }, [
- _vm._v(_vm._s(_vm.index + 1))
- ])
- : _vm._e()
- ])
- : _c("i", {
- staticClass: "el-step__icon-inner is-status",
- class: [
- "el-icon-" +
- (_vm.currentStatus === "success" ? "check" : "close")
- ]
- })
- ],
- 2
- )
- ]
- ),
- _c("div", { staticClass: "el-step__main" }, [
- _c(
- "div",
- {
- ref: "title",
- staticClass: "el-step__title",
- class: ["is-" + _vm.currentStatus]
- },
- [_vm._t("title", [_vm._v(_vm._s(_vm.title))])],
- 2
- ),
- _vm.isSimple
- ? _c("div", { staticClass: "el-step__arrow" })
- : _c(
- "div",
- {
- staticClass: "el-step__description",
- class: ["is-" + _vm.currentStatus]
- },
- [_vm._t("description", [_vm._v(_vm._s(_vm.description))])],
- 2
- )
- ])
- ]
- )
- }
- var stepvue_type_template_id_f414a87a_staticRenderFns = []
- stepvue_type_template_id_f414a87a_render._withStripped = true
- // CONCATENATED MODULE: ./packages/steps/src/step.vue?vue&type=template&id=f414a87a&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/steps/src/step.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var stepvue_type_script_lang_js_ = ({
- name: 'ElStep',
- props: {
- title: String,
- icon: String,
- description: String,
- status: String
- },
- data: function data() {
- return {
- index: -1,
- lineStyle: {},
- internalStatus: ''
- };
- },
- beforeCreate: function beforeCreate() {
- this.$parent.steps.push(this);
- },
- beforeDestroy: function beforeDestroy() {
- var steps = this.$parent.steps;
- var index = steps.indexOf(this);
- if (index >= 0) {
- steps.splice(index, 1);
- }
- },
- computed: {
- currentStatus: function currentStatus() {
- return this.status || this.internalStatus;
- },
- prevStatus: function prevStatus() {
- var prevStep = this.$parent.steps[this.index - 1];
- return prevStep ? prevStep.currentStatus : 'wait';
- },
- isCenter: function isCenter() {
- return this.$parent.alignCenter;
- },
- isVertical: function isVertical() {
- return this.$parent.direction === 'vertical';
- },
- isSimple: function isSimple() {
- return this.$parent.simple;
- },
- isLast: function isLast() {
- var parent = this.$parent;
- return parent.steps[parent.steps.length - 1] === this;
- },
- stepsCount: function stepsCount() {
- return this.$parent.steps.length;
- },
- space: function space() {
- var isSimple = this.isSimple,
- space = this.$parent.space;
- return isSimple ? '' : space;
- },
- style: function style() {
- var style = {};
- var parent = this.$parent;
- var len = parent.steps.length;
- var space = typeof this.space === 'number' ? this.space + 'px' : this.space ? this.space : 100 / (len - (this.isCenter ? 0 : 1)) + '%';
- style.flexBasis = space;
- if (this.isVertical) return style;
- if (this.isLast) {
- style.maxWidth = 100 / this.stepsCount + '%';
- } else {
- style.marginRight = -this.$parent.stepOffset + 'px';
- }
- return style;
- }
- },
- methods: {
- updateStatus: function updateStatus(val) {
- var prevChild = this.$parent.$children[this.index - 1];
- if (val > this.index) {
- this.internalStatus = this.$parent.finishStatus;
- } else if (val === this.index && this.prevStatus !== 'error') {
- this.internalStatus = this.$parent.processStatus;
- } else {
- this.internalStatus = 'wait';
- }
- if (prevChild) prevChild.calcProgress(this.internalStatus);
- },
- calcProgress: function calcProgress(status) {
- var step = 100;
- var style = {};
- style.transitionDelay = 150 * this.index + 'ms';
- if (status === this.$parent.processStatus) {
- step = this.currentStatus !== 'error' ? 0 : 0;
- } else if (status === 'wait') {
- step = 0;
- style.transitionDelay = -150 * this.index + 'ms';
- }
- style.borderWidth = step && !this.isSimple ? '1px' : 0;
- this.$parent.direction === 'vertical' ? style.height = step + '%' : style.width = step + '%';
- this.lineStyle = style;
- }
- },
- mounted: function mounted() {
- var _this = this;
- var unwatch = this.$watch('index', function (val) {
- _this.$watch('$parent.active', _this.updateStatus, { immediate: true });
- _this.$watch('$parent.processStatus', function () {
- var activeIndex = _this.$parent.active;
- _this.updateStatus(activeIndex);
- }, { immediate: true });
- unwatch();
- });
- }
- });
- // CONCATENATED MODULE: ./packages/steps/src/step.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_stepvue_type_script_lang_js_ = (stepvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/steps/src/step.vue
- /* normalize component */
- var step_component = normalizeComponent(
- src_stepvue_type_script_lang_js_,
- stepvue_type_template_id_f414a87a_render,
- stepvue_type_template_id_f414a87a_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var step_api; }
- step_component.options.__file = "packages/steps/src/step.vue"
- /* harmony default export */ var step = (step_component.exports);
- // CONCATENATED MODULE: ./packages/step/index.js
- /* istanbul ignore next */
- step.install = function (Vue) {
- Vue.component(step.name, step);
- };
- /* harmony default export */ var packages_step = (step);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/main.vue?vue&type=template&id=5d5d1482&
- var mainvue_type_template_id_5d5d1482_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- class: _vm.carouselClasses,
- on: {
- mouseenter: function($event) {
- $event.stopPropagation()
- return _vm.handleMouseEnter($event)
- },
- mouseleave: function($event) {
- $event.stopPropagation()
- return _vm.handleMouseLeave($event)
- }
- }
- },
- [
- _c(
- "div",
- {
- staticClass: "el-carousel__container",
- style: { height: _vm.height }
- },
- [
- _vm.arrowDisplay
- ? _c("transition", { attrs: { name: "carousel-arrow-left" } }, [
- _c(
- "button",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value:
- (_vm.arrow === "always" || _vm.hover) &&
- (_vm.loop || _vm.activeIndex > 0),
- expression:
- "(arrow === 'always' || hover) && (loop || activeIndex > 0)"
- }
- ],
- staticClass: "el-carousel__arrow el-carousel__arrow--left",
- attrs: { type: "button" },
- on: {
- mouseenter: function($event) {
- _vm.handleButtonEnter("left")
- },
- mouseleave: _vm.handleButtonLeave,
- click: function($event) {
- $event.stopPropagation()
- _vm.throttledArrowClick(_vm.activeIndex - 1)
- }
- }
- },
- [_c("i", { staticClass: "el-icon-arrow-left" })]
- )
- ])
- : _vm._e(),
- _vm.arrowDisplay
- ? _c("transition", { attrs: { name: "carousel-arrow-right" } }, [
- _c(
- "button",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value:
- (_vm.arrow === "always" || _vm.hover) &&
- (_vm.loop || _vm.activeIndex < _vm.items.length - 1),
- expression:
- "(arrow === 'always' || hover) && (loop || activeIndex < items.length - 1)"
- }
- ],
- staticClass: "el-carousel__arrow el-carousel__arrow--right",
- attrs: { type: "button" },
- on: {
- mouseenter: function($event) {
- _vm.handleButtonEnter("right")
- },
- mouseleave: _vm.handleButtonLeave,
- click: function($event) {
- $event.stopPropagation()
- _vm.throttledArrowClick(_vm.activeIndex + 1)
- }
- }
- },
- [_c("i", { staticClass: "el-icon-arrow-right" })]
- )
- ])
- : _vm._e(),
- _vm._t("default")
- ],
- 2
- ),
- _vm.indicatorPosition !== "none"
- ? _c(
- "ul",
- { class: _vm.indicatorsClasses },
- _vm._l(_vm.items, function(item, index) {
- return _c(
- "li",
- {
- key: index,
- class: [
- "el-carousel__indicator",
- "el-carousel__indicator--" + _vm.direction,
- { "is-active": index === _vm.activeIndex }
- ],
- on: {
- mouseenter: function($event) {
- _vm.throttledIndicatorHover(index)
- },
- click: function($event) {
- $event.stopPropagation()
- _vm.handleIndicatorClick(index)
- }
- }
- },
- [
- _c("button", { staticClass: "el-carousel__button" }, [
- _vm.hasLabel
- ? _c("span", [_vm._v(_vm._s(item.label))])
- : _vm._e()
- ])
- ]
- )
- }),
- 0
- )
- : _vm._e()
- ]
- )
- }
- var mainvue_type_template_id_5d5d1482_staticRenderFns = []
- mainvue_type_template_id_5d5d1482_render._withStripped = true
- // CONCATENATED MODULE: ./packages/carousel/src/main.vue?vue&type=template&id=5d5d1482&
- // EXTERNAL MODULE: external "throttle-debounce/throttle"
- var throttle_ = __webpack_require__(25);
- var throttle_default = /*#__PURE__*/__webpack_require__.n(throttle_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var carousel_src_mainvue_type_script_lang_js_ = ({
- name: 'ElCarousel',
- props: {
- initialIndex: {
- type: Number,
- default: 0
- },
- height: String,
- trigger: {
- type: String,
- default: 'hover'
- },
- autoplay: {
- type: Boolean,
- default: true
- },
- interval: {
- type: Number,
- default: 3000
- },
- indicatorPosition: String,
- indicator: {
- type: Boolean,
- default: true
- },
- arrow: {
- type: String,
- default: 'hover'
- },
- type: String,
- loop: {
- type: Boolean,
- default: true
- },
- direction: {
- type: String,
- default: 'horizontal',
- validator: function validator(val) {
- return ['horizontal', 'vertical'].indexOf(val) !== -1;
- }
- }
- },
- data: function data() {
- return {
- items: [],
- activeIndex: -1,
- containerWidth: 0,
- timer: null,
- hover: false
- };
- },
- computed: {
- arrowDisplay: function arrowDisplay() {
- return this.arrow !== 'never' && this.direction !== 'vertical';
- },
- hasLabel: function hasLabel() {
- return this.items.some(function (item) {
- return item.label.toString().length > 0;
- });
- },
- carouselClasses: function carouselClasses() {
- var classes = ['el-carousel', 'el-carousel--' + this.direction];
- if (this.type === 'card') {
- classes.push('el-carousel--card');
- }
- return classes;
- },
- indicatorsClasses: function indicatorsClasses() {
- var classes = ['el-carousel__indicators', 'el-carousel__indicators--' + this.direction];
- if (this.hasLabel) {
- classes.push('el-carousel__indicators--labels');
- }
- if (this.indicatorPosition === 'outside' || this.type === 'card') {
- classes.push('el-carousel__indicators--outside');
- }
- return classes;
- }
- },
- watch: {
- items: function items(val) {
- if (val.length > 0) this.setActiveItem(this.initialIndex);
- },
- activeIndex: function activeIndex(val, oldVal) {
- this.resetItemPosition(oldVal);
- if (oldVal > -1) {
- this.$emit('change', val, oldVal);
- }
- },
- autoplay: function autoplay(val) {
- val ? this.startTimer() : this.pauseTimer();
- },
- loop: function loop() {
- this.setActiveItem(this.activeIndex);
- },
- interval: function interval() {
- this.pauseTimer();
- this.startTimer();
- }
- },
- methods: {
- handleMouseEnter: function handleMouseEnter() {
- this.hover = true;
- this.pauseTimer();
- },
- handleMouseLeave: function handleMouseLeave() {
- this.hover = false;
- this.startTimer();
- },
- itemInStage: function itemInStage(item, index) {
- var length = this.items.length;
- if (index === length - 1 && item.inStage && this.items[0].active || item.inStage && this.items[index + 1] && this.items[index + 1].active) {
- return 'left';
- } else if (index === 0 && item.inStage && this.items[length - 1].active || item.inStage && this.items[index - 1] && this.items[index - 1].active) {
- return 'right';
- }
- return false;
- },
- handleButtonEnter: function handleButtonEnter(arrow) {
- var _this = this;
- if (this.direction === 'vertical') return;
- this.items.forEach(function (item, index) {
- if (arrow === _this.itemInStage(item, index)) {
- item.hover = true;
- }
- });
- },
- handleButtonLeave: function handleButtonLeave() {
- if (this.direction === 'vertical') return;
- this.items.forEach(function (item) {
- item.hover = false;
- });
- },
- updateItems: function updateItems() {
- this.items = this.$children.filter(function (child) {
- return child.$options.name === 'ElCarouselItem';
- });
- },
- resetItemPosition: function resetItemPosition(oldIndex) {
- var _this2 = this;
- this.items.forEach(function (item, index) {
- item.translateItem(index, _this2.activeIndex, oldIndex);
- });
- },
- playSlides: function playSlides() {
- if (this.activeIndex < this.items.length - 1) {
- this.activeIndex++;
- } else if (this.loop) {
- this.activeIndex = 0;
- }
- },
- pauseTimer: function pauseTimer() {
- if (this.timer) {
- clearInterval(this.timer);
- this.timer = null;
- }
- },
- startTimer: function startTimer() {
- if (this.interval <= 0 || !this.autoplay || this.timer) return;
- this.timer = setInterval(this.playSlides, this.interval);
- },
- resetTimer: function resetTimer() {
- this.pauseTimer();
- this.startTimer();
- },
- setActiveItem: function setActiveItem(index) {
- if (typeof index === 'string') {
- var filteredItems = this.items.filter(function (item) {
- return item.name === index;
- });
- if (filteredItems.length > 0) {
- index = this.items.indexOf(filteredItems[0]);
- }
- }
- index = Number(index);
- if (isNaN(index) || index !== Math.floor(index)) {
- console.warn('[Element Warn][Carousel]index must be an integer.');
- return;
- }
- var length = this.items.length;
- var oldIndex = this.activeIndex;
- if (index < 0) {
- this.activeIndex = this.loop ? length - 1 : 0;
- } else if (index >= length) {
- this.activeIndex = this.loop ? 0 : length - 1;
- } else {
- this.activeIndex = index;
- }
- if (oldIndex === this.activeIndex) {
- this.resetItemPosition(oldIndex);
- }
- this.resetTimer();
- },
- prev: function prev() {
- this.setActiveItem(this.activeIndex - 1);
- },
- next: function next() {
- this.setActiveItem(this.activeIndex + 1);
- },
- handleIndicatorClick: function handleIndicatorClick(index) {
- this.activeIndex = index;
- },
- handleIndicatorHover: function handleIndicatorHover(index) {
- if (this.trigger === 'hover' && index !== this.activeIndex) {
- this.activeIndex = index;
- }
- }
- },
- created: function created() {
- var _this3 = this;
- this.throttledArrowClick = throttle_default()(300, true, function (index) {
- _this3.setActiveItem(index);
- });
- this.throttledIndicatorHover = throttle_default()(300, function (index) {
- _this3.handleIndicatorHover(index);
- });
- },
- mounted: function mounted() {
- var _this4 = this;
- this.updateItems();
- this.$nextTick(function () {
- Object(resize_event_["addResizeListener"])(_this4.$el, _this4.resetItemPosition);
- if (_this4.initialIndex < _this4.items.length && _this4.initialIndex >= 0) {
- _this4.activeIndex = _this4.initialIndex;
- }
- _this4.startTimer();
- });
- },
- beforeDestroy: function beforeDestroy() {
- if (this.$el) Object(resize_event_["removeResizeListener"])(this.$el, this.resetItemPosition);
- this.pauseTimer();
- }
- });
- // CONCATENATED MODULE: ./packages/carousel/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_carousel_src_mainvue_type_script_lang_js_ = (carousel_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/carousel/src/main.vue
- /* normalize component */
- var carousel_src_main_component = normalizeComponent(
- packages_carousel_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_5d5d1482_render,
- mainvue_type_template_id_5d5d1482_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var carousel_src_main_api; }
- carousel_src_main_component.options.__file = "packages/carousel/src/main.vue"
- /* harmony default export */ var carousel_src_main = (carousel_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/carousel/index.js
- /* istanbul ignore next */
- carousel_src_main.install = function (Vue) {
- Vue.component(carousel_src_main.name, carousel_src_main);
- };
- /* harmony default export */ var carousel = (carousel_src_main);
- // CONCATENATED MODULE: ./packages/scrollbar/src/util.js
- var BAR_MAP = {
- vertical: {
- offset: 'offsetHeight',
- scroll: 'scrollTop',
- scrollSize: 'scrollHeight',
- size: 'height',
- key: 'vertical',
- axis: 'Y',
- client: 'clientY',
- direction: 'top'
- },
- horizontal: {
- offset: 'offsetWidth',
- scroll: 'scrollLeft',
- scrollSize: 'scrollWidth',
- size: 'width',
- key: 'horizontal',
- axis: 'X',
- client: 'clientX',
- direction: 'left'
- }
- };
- function renderThumbStyle(_ref) {
- var move = _ref.move,
- size = _ref.size,
- bar = _ref.bar;
- var style = {};
- var translate = 'translate' + bar.axis + '(' + move + '%)';
- style[bar.size] = size;
- style.transform = translate;
- style.msTransform = translate;
- style.webkitTransform = translate;
- return style;
- };
- // CONCATENATED MODULE: ./packages/scrollbar/src/bar.js
- /* istanbul ignore next */
- /* harmony default export */ var src_bar = ({
- name: 'Bar',
- props: {
- vertical: Boolean,
- size: String,
- move: Number
- },
- computed: {
- bar: function bar() {
- return BAR_MAP[this.vertical ? 'vertical' : 'horizontal'];
- },
- wrap: function wrap() {
- return this.$parent.wrap;
- }
- },
- render: function render(h) {
- var size = this.size,
- move = this.move,
- bar = this.bar;
- return h(
- 'div',
- {
- 'class': ['el-scrollbar__bar', 'is-' + bar.key],
- on: {
- 'mousedown': this.clickTrackHandler
- }
- },
- [h('div', {
- ref: 'thumb',
- 'class': 'el-scrollbar__thumb',
- on: {
- 'mousedown': this.clickThumbHandler
- },
- style: renderThumbStyle({ size: size, move: move, bar: bar }) })]
- );
- },
- methods: {
- clickThumbHandler: function clickThumbHandler(e) {
- // prevent click event of right button
- if (e.ctrlKey || e.button === 2) {
- return;
- }
- this.startDrag(e);
- this[this.bar.axis] = e.currentTarget[this.bar.offset] - (e[this.bar.client] - e.currentTarget.getBoundingClientRect()[this.bar.direction]);
- },
- clickTrackHandler: function clickTrackHandler(e) {
- var offset = Math.abs(e.target.getBoundingClientRect()[this.bar.direction] - e[this.bar.client]);
- var thumbHalf = this.$refs.thumb[this.bar.offset] / 2;
- var thumbPositionPercentage = (offset - thumbHalf) * 100 / this.$el[this.bar.offset];
- this.wrap[this.bar.scroll] = thumbPositionPercentage * this.wrap[this.bar.scrollSize] / 100;
- },
- startDrag: function startDrag(e) {
- e.stopImmediatePropagation();
- this.cursorDown = true;
- Object(dom_["on"])(document, 'mousemove', this.mouseMoveDocumentHandler);
- Object(dom_["on"])(document, 'mouseup', this.mouseUpDocumentHandler);
- document.onselectstart = function () {
- return false;
- };
- },
- mouseMoveDocumentHandler: function mouseMoveDocumentHandler(e) {
- if (this.cursorDown === false) return;
- var prevPage = this[this.bar.axis];
- if (!prevPage) return;
- var offset = (this.$el.getBoundingClientRect()[this.bar.direction] - e[this.bar.client]) * -1;
- var thumbClickPosition = this.$refs.thumb[this.bar.offset] - prevPage;
- var thumbPositionPercentage = (offset - thumbClickPosition) * 100 / this.$el[this.bar.offset];
- this.wrap[this.bar.scroll] = thumbPositionPercentage * this.wrap[this.bar.scrollSize] / 100;
- },
- mouseUpDocumentHandler: function mouseUpDocumentHandler(e) {
- this.cursorDown = false;
- this[this.bar.axis] = 0;
- Object(dom_["off"])(document, 'mousemove', this.mouseMoveDocumentHandler);
- document.onselectstart = null;
- }
- },
- destroyed: function destroyed() {
- Object(dom_["off"])(document, 'mouseup', this.mouseUpDocumentHandler);
- }
- });
- // CONCATENATED MODULE: ./packages/scrollbar/src/main.js
- // reference https://github.com/noeldelgado/gemini-scrollbar/blob/master/index.js
- /* istanbul ignore next */
- /* harmony default export */ var scrollbar_src_main = ({
- name: 'ElScrollbar',
- components: { Bar: src_bar },
- props: {
- native: Boolean,
- wrapStyle: {},
- wrapClass: {},
- viewClass: {},
- viewStyle: {},
- noresize: Boolean, // 如果 container 尺寸不会发生变化,最好设置它可以优化性能
- tag: {
- type: String,
- default: 'div'
- }
- },
- data: function data() {
- return {
- sizeWidth: '0',
- sizeHeight: '0',
- moveX: 0,
- moveY: 0
- };
- },
- computed: {
- wrap: function wrap() {
- return this.$refs.wrap;
- }
- },
- render: function render(h) {
- var gutter = scrollbar_width_default()();
- var style = this.wrapStyle;
- if (gutter) {
- var gutterWith = '-' + gutter + 'px';
- var gutterStyle = 'margin-bottom: ' + gutterWith + '; margin-right: ' + gutterWith + ';';
- if (Array.isArray(this.wrapStyle)) {
- style = Object(util_["toObject"])(this.wrapStyle);
- style.marginRight = style.marginBottom = gutterWith;
- } else if (typeof this.wrapStyle === 'string') {
- style += gutterStyle;
- } else {
- style = gutterStyle;
- }
- }
- var view = h(this.tag, {
- class: ['el-scrollbar__view', this.viewClass],
- style: this.viewStyle,
- ref: 'resize'
- }, this.$slots.default);
- var wrap = h(
- 'div',
- {
- ref: 'wrap',
- style: style,
- on: {
- 'scroll': this.handleScroll
- },
- 'class': [this.wrapClass, 'el-scrollbar__wrap', gutter ? '' : 'el-scrollbar__wrap--hidden-default'] },
- [[view]]
- );
- var nodes = void 0;
- if (!this.native) {
- nodes = [wrap, h(src_bar, {
- attrs: {
- move: this.moveX,
- size: this.sizeWidth }
- }), h(src_bar, {
- attrs: {
- vertical: true,
- move: this.moveY,
- size: this.sizeHeight }
- })];
- } else {
- nodes = [h(
- 'div',
- {
- ref: 'wrap',
- 'class': [this.wrapClass, 'el-scrollbar__wrap'],
- style: style },
- [[view]]
- )];
- }
- return h('div', { class: 'el-scrollbar' }, nodes);
- },
- methods: {
- handleScroll: function handleScroll() {
- var wrap = this.wrap;
- this.moveY = wrap.scrollTop * 100 / wrap.clientHeight;
- this.moveX = wrap.scrollLeft * 100 / wrap.clientWidth;
- },
- update: function update() {
- var heightPercentage = void 0,
- widthPercentage = void 0;
- var wrap = this.wrap;
- if (!wrap) return;
- heightPercentage = wrap.clientHeight * 100 / wrap.scrollHeight;
- widthPercentage = wrap.clientWidth * 100 / wrap.scrollWidth;
- this.sizeHeight = heightPercentage < 100 ? heightPercentage + '%' : '';
- this.sizeWidth = widthPercentage < 100 ? widthPercentage + '%' : '';
- }
- },
- mounted: function mounted() {
- if (this.native) return;
- this.$nextTick(this.update);
- !this.noresize && Object(resize_event_["addResizeListener"])(this.$refs.resize, this.update);
- },
- beforeDestroy: function beforeDestroy() {
- if (this.native) return;
- !this.noresize && Object(resize_event_["removeResizeListener"])(this.$refs.resize, this.update);
- }
- });
- // CONCATENATED MODULE: ./packages/scrollbar/index.js
- /* istanbul ignore next */
- scrollbar_src_main.install = function (Vue) {
- Vue.component(scrollbar_src_main.name, scrollbar_src_main);
- };
- /* harmony default export */ var scrollbar = (scrollbar_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/item.vue?vue&type=template&id=1801ae19&
- var itemvue_type_template_id_1801ae19_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.ready,
- expression: "ready"
- }
- ],
- staticClass: "el-carousel__item",
- class: {
- "is-active": _vm.active,
- "el-carousel__item--card": _vm.$parent.type === "card",
- "is-in-stage": _vm.inStage,
- "is-hover": _vm.hover,
- "is-animating": _vm.animating
- },
- style: _vm.itemStyle,
- on: { click: _vm.handleItemClick }
- },
- [
- _vm.$parent.type === "card"
- ? _c("div", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: !_vm.active,
- expression: "!active"
- }
- ],
- staticClass: "el-carousel__mask"
- })
- : _vm._e(),
- _vm._t("default")
- ],
- 2
- )
- }
- var itemvue_type_template_id_1801ae19_staticRenderFns = []
- itemvue_type_template_id_1801ae19_render._withStripped = true
- // CONCATENATED MODULE: ./packages/carousel/src/item.vue?vue&type=template&id=1801ae19&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/item.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var CARD_SCALE = 0.83;
- /* harmony default export */ var itemvue_type_script_lang_js_ = ({
- name: 'ElCarouselItem',
- props: {
- name: String,
- label: {
- type: [String, Number],
- default: ''
- }
- },
- data: function data() {
- return {
- hover: false,
- translate: 0,
- scale: 1,
- active: false,
- ready: false,
- inStage: false,
- animating: false
- };
- },
- methods: {
- processIndex: function processIndex(index, activeIndex, length) {
- if (activeIndex === 0 && index === length - 1) {
- return -1;
- } else if (activeIndex === length - 1 && index === 0) {
- return length;
- } else if (index < activeIndex - 1 && activeIndex - index >= length / 2) {
- return length + 1;
- } else if (index > activeIndex + 1 && index - activeIndex >= length / 2) {
- return -2;
- }
- return index;
- },
- calcCardTranslate: function calcCardTranslate(index, activeIndex) {
- var parentWidth = this.$parent.$el.offsetWidth;
- if (this.inStage) {
- return parentWidth * ((2 - CARD_SCALE) * (index - activeIndex) + 1) / 4;
- } else if (index < activeIndex) {
- return -(1 + CARD_SCALE) * parentWidth / 4;
- } else {
- return (3 + CARD_SCALE) * parentWidth / 4;
- }
- },
- calcTranslate: function calcTranslate(index, activeIndex, isVertical) {
- var distance = this.$parent.$el[isVertical ? 'offsetHeight' : 'offsetWidth'];
- return distance * (index - activeIndex);
- },
- translateItem: function translateItem(index, activeIndex, oldIndex) {
- var parentType = this.$parent.type;
- var parentDirection = this.parentDirection;
- var length = this.$parent.items.length;
- if (parentType !== 'card' && oldIndex !== undefined) {
- this.animating = index === activeIndex || index === oldIndex;
- }
- if (index !== activeIndex && length > 2 && this.$parent.loop) {
- index = this.processIndex(index, activeIndex, length);
- }
- if (parentType === 'card') {
- if (parentDirection === 'vertical') {
- console.warn('[Element Warn][Carousel]vertical direction is not supported in card mode');
- }
- this.inStage = Math.round(Math.abs(index - activeIndex)) <= 1;
- this.active = index === activeIndex;
- this.translate = this.calcCardTranslate(index, activeIndex);
- this.scale = this.active ? 1 : CARD_SCALE;
- } else {
- this.active = index === activeIndex;
- var isVertical = parentDirection === 'vertical';
- this.translate = this.calcTranslate(index, activeIndex, isVertical);
- this.scale = 1;
- }
- this.ready = true;
- },
- handleItemClick: function handleItemClick() {
- var parent = this.$parent;
- if (parent && parent.type === 'card') {
- var index = parent.items.indexOf(this);
- parent.setActiveItem(index);
- }
- }
- },
- computed: {
- parentDirection: function parentDirection() {
- return this.$parent.direction;
- },
- itemStyle: function itemStyle() {
- var translateType = this.parentDirection === 'vertical' ? 'translateY' : 'translateX';
- var value = translateType + '(' + this.translate + 'px) scale(' + this.scale + ')';
- var style = {
- transform: value
- };
- return Object(util_["autoprefixer"])(style);
- }
- },
- created: function created() {
- this.$parent && this.$parent.updateItems();
- },
- destroyed: function destroyed() {
- this.$parent && this.$parent.updateItems();
- }
- });
- // CONCATENATED MODULE: ./packages/carousel/src/item.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_itemvue_type_script_lang_js_ = (itemvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/carousel/src/item.vue
- /* normalize component */
- var item_component = normalizeComponent(
- src_itemvue_type_script_lang_js_,
- itemvue_type_template_id_1801ae19_render,
- itemvue_type_template_id_1801ae19_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var item_api; }
- item_component.options.__file = "packages/carousel/src/item.vue"
- /* harmony default export */ var src_item = (item_component.exports);
- // CONCATENATED MODULE: ./packages/carousel-item/index.js
- /* istanbul ignore next */
- src_item.install = function (Vue) {
- Vue.component(src_item.name, src_item);
- };
- /* harmony default export */ var carousel_item = (src_item);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse.vue?vue&type=template&id=461d57f4&
- var collapsevue_type_template_id_461d57f4_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-collapse",
- attrs: { role: "tablist", "aria-multiselectable": "true" }
- },
- [_vm._t("default")],
- 2
- )
- }
- var collapsevue_type_template_id_461d57f4_staticRenderFns = []
- collapsevue_type_template_id_461d57f4_render._withStripped = true
- // CONCATENATED MODULE: ./packages/collapse/src/collapse.vue?vue&type=template&id=461d57f4&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- /* harmony default export */ var collapsevue_type_script_lang_js_ = ({
- name: 'ElCollapse',
- componentName: 'ElCollapse',
- props: {
- accordion: Boolean,
- value: {
- type: [Array, String, Number],
- default: function _default() {
- return [];
- }
- }
- },
- data: function data() {
- return {
- activeNames: [].concat(this.value)
- };
- },
- provide: function provide() {
- return {
- collapse: this
- };
- },
- watch: {
- value: function value(_value) {
- this.activeNames = [].concat(_value);
- }
- },
- methods: {
- setActiveNames: function setActiveNames(activeNames) {
- activeNames = [].concat(activeNames);
- var value = this.accordion ? activeNames[0] : activeNames;
- this.activeNames = activeNames;
- this.$emit('input', value);
- this.$emit('change', value);
- },
- handleItemClick: function handleItemClick(item) {
- if (this.accordion) {
- this.setActiveNames((this.activeNames[0] || this.activeNames[0] === 0) && this.activeNames[0] === item.name ? '' : item.name);
- } else {
- var activeNames = this.activeNames.slice(0);
- var index = activeNames.indexOf(item.name);
- if (index > -1) {
- activeNames.splice(index, 1);
- } else {
- activeNames.push(item.name);
- }
- this.setActiveNames(activeNames);
- }
- }
- },
- created: function created() {
- this.$on('item-click', this.handleItemClick);
- }
- });
- // CONCATENATED MODULE: ./packages/collapse/src/collapse.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_collapsevue_type_script_lang_js_ = (collapsevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/collapse/src/collapse.vue
- /* normalize component */
- var collapse_component = normalizeComponent(
- src_collapsevue_type_script_lang_js_,
- collapsevue_type_template_id_461d57f4_render,
- collapsevue_type_template_id_461d57f4_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var collapse_api; }
- collapse_component.options.__file = "packages/collapse/src/collapse.vue"
- /* harmony default export */ var collapse = (collapse_component.exports);
- // CONCATENATED MODULE: ./packages/collapse/index.js
- /* istanbul ignore next */
- collapse.install = function (Vue) {
- Vue.component(collapse.name, collapse);
- };
- /* harmony default export */ var packages_collapse = (collapse);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse-item.vue?vue&type=template&id=2d05faac&
- var collapse_itemvue_type_template_id_2d05faac_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-collapse-item",
- class: { "is-active": _vm.isActive, "is-disabled": _vm.disabled }
- },
- [
- _c(
- "div",
- {
- attrs: {
- role: "tab",
- "aria-expanded": _vm.isActive,
- "aria-controls": "el-collapse-content-" + _vm.id,
- "aria-describedby": "el-collapse-content-" + _vm.id
- }
- },
- [
- _c(
- "div",
- {
- staticClass: "el-collapse-item__header",
- class: {
- focusing: _vm.focusing,
- "is-active": _vm.isActive
- },
- attrs: {
- role: "button",
- id: "el-collapse-head-" + _vm.id,
- tabindex: _vm.disabled ? undefined : 0
- },
- on: {
- click: _vm.handleHeaderClick,
- keyup: function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "space", 32, $event.key, [
- " ",
- "Spacebar"
- ]) &&
- _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")
- ) {
- return null
- }
- $event.stopPropagation()
- return _vm.handleEnterClick($event)
- },
- focus: _vm.handleFocus,
- blur: function($event) {
- _vm.focusing = false
- }
- }
- },
- [
- _vm._t("title", [_vm._v(_vm._s(_vm.title))]),
- _c("i", {
- staticClass: "el-collapse-item__arrow el-icon-arrow-right",
- class: { "is-active": _vm.isActive }
- })
- ],
- 2
- )
- ]
- ),
- _c("el-collapse-transition", [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.isActive,
- expression: "isActive"
- }
- ],
- staticClass: "el-collapse-item__wrap",
- attrs: {
- role: "tabpanel",
- "aria-hidden": !_vm.isActive,
- "aria-labelledby": "el-collapse-head-" + _vm.id,
- id: "el-collapse-content-" + _vm.id
- }
- },
- [
- _c(
- "div",
- { staticClass: "el-collapse-item__content" },
- [_vm._t("default")],
- 2
- )
- ]
- )
- ])
- ],
- 1
- )
- }
- var collapse_itemvue_type_template_id_2d05faac_staticRenderFns = []
- collapse_itemvue_type_template_id_2d05faac_render._withStripped = true
- // CONCATENATED MODULE: ./packages/collapse/src/collapse-item.vue?vue&type=template&id=2d05faac&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse-item.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var collapse_itemvue_type_script_lang_js_ = ({
- name: 'ElCollapseItem',
- componentName: 'ElCollapseItem',
- mixins: [emitter_default.a],
- components: { ElCollapseTransition: collapse_transition_default.a },
- data: function data() {
- return {
- contentWrapStyle: {
- height: 'auto',
- display: 'block'
- },
- contentHeight: 0,
- focusing: false,
- isClick: false,
- id: Object(util_["generateId"])()
- };
- },
- inject: ['collapse'],
- props: {
- title: String,
- name: {
- type: [String, Number],
- default: function _default() {
- return this._uid;
- }
- },
- disabled: Boolean
- },
- computed: {
- isActive: function isActive() {
- return this.collapse.activeNames.indexOf(this.name) > -1;
- }
- },
- methods: {
- handleFocus: function handleFocus() {
- var _this = this;
- setTimeout(function () {
- if (!_this.isClick) {
- _this.focusing = true;
- } else {
- _this.isClick = false;
- }
- }, 50);
- },
- handleHeaderClick: function handleHeaderClick() {
- if (this.disabled) return;
- this.dispatch('ElCollapse', 'item-click', this);
- this.focusing = false;
- this.isClick = true;
- },
- handleEnterClick: function handleEnterClick() {
- this.dispatch('ElCollapse', 'item-click', this);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/collapse/src/collapse-item.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_collapse_itemvue_type_script_lang_js_ = (collapse_itemvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/collapse/src/collapse-item.vue
- /* normalize component */
- var collapse_item_component = normalizeComponent(
- src_collapse_itemvue_type_script_lang_js_,
- collapse_itemvue_type_template_id_2d05faac_render,
- collapse_itemvue_type_template_id_2d05faac_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var collapse_item_api; }
- collapse_item_component.options.__file = "packages/collapse/src/collapse-item.vue"
- /* harmony default export */ var collapse_item = (collapse_item_component.exports);
- // CONCATENATED MODULE: ./packages/collapse-item/index.js
- /* istanbul ignore next */
- collapse_item.install = function (Vue) {
- Vue.component(collapse_item.name, collapse_item);
- };
- /* harmony default export */ var packages_collapse_item = (collapse_item);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader/src/cascader.vue?vue&type=template&id=032537a6&
- var cascadervue_type_template_id_032537a6_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: function() {
- return _vm.toggleDropDownVisible(false)
- },
- expression: "() => toggleDropDownVisible(false)"
- }
- ],
- ref: "reference",
- class: [
- "el-cascader",
- _vm.realSize && "el-cascader--" + _vm.realSize,
- { "is-disabled": _vm.isDisabled }
- ],
- on: {
- mouseenter: function($event) {
- _vm.inputHover = true
- },
- mouseleave: function($event) {
- _vm.inputHover = false
- },
- click: function() {
- return _vm.toggleDropDownVisible(_vm.readonly ? undefined : true)
- },
- keydown: _vm.handleKeyDown
- }
- },
- [
- _c(
- "el-input",
- {
- ref: "input",
- class: { "is-focus": _vm.dropDownVisible },
- attrs: {
- size: _vm.realSize,
- placeholder: _vm.placeholder,
- readonly: _vm.readonly,
- disabled: _vm.isDisabled,
- "validate-event": false
- },
- on: {
- focus: _vm.handleFocus,
- blur: _vm.handleBlur,
- input: _vm.handleInput
- },
- model: {
- value: _vm.multiple ? _vm.presentText : _vm.inputValue,
- callback: function($$v) {
- _vm.multiple ? _vm.presentText : (_vm.inputValue = $$v)
- },
- expression: "multiple ? presentText : inputValue"
- }
- },
- [
- _c("template", { slot: "suffix" }, [
- _vm.clearBtnVisible
- ? _c("i", {
- key: "clear",
- staticClass: "el-input__icon el-icon-circle-close",
- on: {
- click: function($event) {
- $event.stopPropagation()
- return _vm.handleClear($event)
- }
- }
- })
- : _c("i", {
- key: "arrow-down",
- class: [
- "el-input__icon",
- "el-icon-arrow-down",
- _vm.dropDownVisible && "is-reverse"
- ],
- on: {
- click: function($event) {
- $event.stopPropagation()
- _vm.toggleDropDownVisible()
- }
- }
- })
- ])
- ],
- 2
- ),
- _vm.multiple
- ? _c(
- "div",
- { staticClass: "el-cascader__tags" },
- [
- _vm._l(_vm.presentTags, function(tag) {
- return _c(
- "el-tag",
- {
- key: tag.key,
- attrs: {
- type: "info",
- size: _vm.tagSize,
- hit: tag.hitState,
- closable: tag.closable,
- "disable-transitions": ""
- },
- on: {
- close: function($event) {
- _vm.deleteTag(tag)
- }
- }
- },
- [_c("span", [_vm._v(_vm._s(tag.text))])]
- )
- }),
- _vm.filterable && !_vm.isDisabled
- ? _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model.trim",
- value: _vm.inputValue,
- expression: "inputValue",
- modifiers: { trim: true }
- }
- ],
- staticClass: "el-cascader__search-input",
- attrs: {
- type: "text",
- placeholder: _vm.presentTags.length ? "" : _vm.placeholder
- },
- domProps: { value: _vm.inputValue },
- on: {
- input: [
- function($event) {
- if ($event.target.composing) {
- return
- }
- _vm.inputValue = $event.target.value.trim()
- },
- function(e) {
- return _vm.handleInput(_vm.inputValue, e)
- }
- ],
- click: function($event) {
- $event.stopPropagation()
- _vm.toggleDropDownVisible(true)
- },
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k(
- $event.keyCode,
- "delete",
- [8, 46],
- $event.key,
- ["Backspace", "Delete", "Del"]
- )
- ) {
- return null
- }
- return _vm.handleDelete($event)
- },
- blur: function($event) {
- _vm.$forceUpdate()
- }
- }
- })
- : _vm._e()
- ],
- 2
- )
- : _vm._e(),
- _c(
- "transition",
- {
- attrs: { name: "el-zoom-in-top" },
- on: { "after-leave": _vm.handleDropdownLeave }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.dropDownVisible,
- expression: "dropDownVisible"
- }
- ],
- ref: "popper",
- class: ["el-popper", "el-cascader__dropdown", _vm.popperClass]
- },
- [
- _c("el-cascader-panel", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: !_vm.filtering,
- expression: "!filtering"
- }
- ],
- ref: "panel",
- attrs: {
- options: _vm.options,
- props: _vm.config,
- border: false,
- "render-label": _vm.$scopedSlots.default
- },
- on: {
- "expand-change": _vm.handleExpandChange,
- close: function($event) {
- _vm.toggleDropDownVisible(false)
- }
- },
- model: {
- value: _vm.checkedValue,
- callback: function($$v) {
- _vm.checkedValue = $$v
- },
- expression: "checkedValue"
- }
- }),
- _vm.filterable
- ? _c(
- "el-scrollbar",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.filtering,
- expression: "filtering"
- }
- ],
- ref: "suggestionPanel",
- staticClass: "el-cascader__suggestion-panel",
- attrs: {
- tag: "ul",
- "view-class": "el-cascader__suggestion-list"
- },
- nativeOn: {
- keydown: function($event) {
- return _vm.handleSuggestionKeyDown($event)
- }
- }
- },
- [
- _vm.suggestions.length
- ? _vm._l(_vm.suggestions, function(item, index) {
- return _c(
- "li",
- {
- key: item.uid,
- class: [
- "el-cascader__suggestion-item",
- item.checked && "is-checked"
- ],
- attrs: { tabindex: -1 },
- on: {
- click: function($event) {
- _vm.handleSuggestionClick(index)
- }
- }
- },
- [
- _c("span", [_vm._v(_vm._s(item.text))]),
- item.checked
- ? _c("i", { staticClass: "el-icon-check" })
- : _vm._e()
- ]
- )
- })
- : _vm._t("empty", [
- _c(
- "li",
- { staticClass: "el-cascader__empty-text" },
- [_vm._v(_vm._s(_vm.t("el.cascader.noMatch")))]
- )
- ])
- ],
- 2
- )
- : _vm._e()
- ],
- 1
- )
- ]
- )
- ],
- 1
- )
- }
- var cascadervue_type_template_id_032537a6_staticRenderFns = []
- cascadervue_type_template_id_032537a6_render._withStripped = true
- // CONCATENATED MODULE: ./packages/cascader/src/cascader.vue?vue&type=template&id=032537a6&
- // EXTERNAL MODULE: external "element-ui/lib/cascader-panel"
- var cascader_panel_ = __webpack_require__(43);
- var cascader_panel_default = /*#__PURE__*/__webpack_require__.n(cascader_panel_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/aria-utils"
- var aria_utils_ = __webpack_require__(35);
- var aria_utils_default = /*#__PURE__*/__webpack_require__.n(aria_utils_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader/src/cascader.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var KeyCode = aria_utils_default.a.keys;
- var MigratingProps = {
- expandTrigger: {
- newProp: 'expandTrigger',
- type: String
- },
- changeOnSelect: {
- newProp: 'checkStrictly',
- type: Boolean
- },
- hoverThreshold: {
- newProp: 'hoverThreshold',
- type: Number
- }
- };
- var PopperMixin = {
- props: {
- placement: {
- type: String,
- default: 'bottom-start'
- },
- appendToBody: vue_popper_default.a.props.appendToBody,
- visibleArrow: {
- type: Boolean,
- default: true
- },
- arrowOffset: vue_popper_default.a.props.arrowOffset,
- offset: vue_popper_default.a.props.offset,
- boundariesPadding: vue_popper_default.a.props.boundariesPadding,
- popperOptions: vue_popper_default.a.props.popperOptions,
- transformOrigin: vue_popper_default.a.props.transformOrigin
- },
- methods: vue_popper_default.a.methods,
- data: vue_popper_default.a.data,
- beforeDestroy: vue_popper_default.a.beforeDestroy
- };
- var InputSizeMap = {
- medium: 36,
- small: 32,
- mini: 28
- };
- /* harmony default export */ var cascadervue_type_script_lang_js_ = ({
- name: 'ElCascader',
- directives: { Clickoutside: clickoutside_default.a },
- mixins: [PopperMixin, emitter_default.a, locale_default.a, migrating_default.a],
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- components: {
- ElInput: input_default.a,
- ElTag: tag_default.a,
- ElScrollbar: scrollbar_default.a,
- ElCascaderPanel: cascader_panel_default.a
- },
- props: {
- value: {},
- options: Array,
- props: Object,
- size: String,
- placeholder: {
- type: String,
- default: function _default() {
- return Object(lib_locale_["t"])('el.cascader.placeholder');
- }
- },
- disabled: Boolean,
- clearable: Boolean,
- filterable: Boolean,
- filterMethod: Function,
- separator: {
- type: String,
- default: ' / '
- },
- showAllLevels: {
- type: Boolean,
- default: true
- },
- collapseTags: Boolean,
- debounce: {
- type: Number,
- default: 300
- },
- beforeFilter: {
- type: Function,
- default: function _default() {
- return function () {};
- }
- },
- popperClass: String
- },
- data: function data() {
- return {
- dropDownVisible: false,
- checkedValue: this.value,
- inputHover: false,
- inputValue: null,
- presentText: null,
- presentTags: [],
- checkedNodes: [],
- filtering: false,
- suggestions: [],
- inputInitialHeight: 0,
- pressDeleteCount: 0
- };
- },
- computed: {
- realSize: function realSize() {
- var _elFormItemSize = (this.elFormItem || {}).elFormItemSize;
- return this.size || _elFormItemSize || (this.$ELEMENT || {}).size;
- },
- tagSize: function tagSize() {
- return ['small', 'mini'].indexOf(this.realSize) > -1 ? 'mini' : 'small';
- },
- isDisabled: function isDisabled() {
- return this.disabled || (this.elForm || {}).disabled;
- },
- config: function config() {
- var config = this.props || {};
- var $attrs = this.$attrs;
- Object.keys(MigratingProps).forEach(function (oldProp) {
- var _MigratingProps$oldPr = MigratingProps[oldProp],
- newProp = _MigratingProps$oldPr.newProp,
- type = _MigratingProps$oldPr.type;
- var oldValue = $attrs[oldProp] || $attrs[Object(util_["kebabCase"])(oldProp)];
- if (Object(shared_["isDef"])(oldProp) && !Object(shared_["isDef"])(config[newProp])) {
- if (type === Boolean && oldValue === '') {
- oldValue = true;
- }
- config[newProp] = oldValue;
- }
- });
- return config;
- },
- multiple: function multiple() {
- return this.config.multiple;
- },
- leafOnly: function leafOnly() {
- return !this.config.checkStrictly;
- },
- readonly: function readonly() {
- return !this.filterable || this.multiple;
- },
- clearBtnVisible: function clearBtnVisible() {
- if (!this.clearable || this.isDisabled || this.filtering || !this.inputHover) {
- return false;
- }
- return this.multiple ? !!this.checkedNodes.filter(function (node) {
- return !node.isDisabled;
- }).length : !!this.presentText;
- },
- panel: function panel() {
- return this.$refs.panel;
- }
- },
- watch: {
- disabled: function disabled() {
- this.computePresentContent();
- },
- value: function value(val) {
- if (!Object(util_["isEqual"])(val, this.checkedValue)) {
- this.checkedValue = val;
- this.computePresentContent();
- }
- },
- checkedValue: function checkedValue(val) {
- var value = this.value,
- dropDownVisible = this.dropDownVisible;
- var _config = this.config,
- checkStrictly = _config.checkStrictly,
- multiple = _config.multiple;
- if (!Object(util_["isEqual"])(val, value) || Object(types_["isUndefined"])(value)) {
- this.computePresentContent();
- // hide dropdown when single mode
- if (!multiple && !checkStrictly && dropDownVisible) {
- this.toggleDropDownVisible(false);
- }
- this.$emit('input', val);
- this.$emit('change', val);
- this.dispatch('ElFormItem', 'el.form.change', [val]);
- }
- },
- options: {
- handler: function handler() {
- this.$nextTick(this.computePresentContent);
- },
- deep: true
- },
- presentText: function presentText(val) {
- this.inputValue = val;
- },
- presentTags: function presentTags(val, oldVal) {
- if (this.multiple && (val.length || oldVal.length)) {
- this.$nextTick(this.updateStyle);
- }
- },
- filtering: function filtering(val) {
- this.$nextTick(this.updatePopper);
- }
- },
- mounted: function mounted() {
- var _this = this;
- var input = this.$refs.input;
- if (input && input.$el) {
- this.inputInitialHeight = input.$el.offsetHeight || InputSizeMap[this.realSize] || 40;
- }
- if (!this.isEmptyValue(this.value)) {
- this.computePresentContent();
- }
- this.filterHandler = debounce_default()(this.debounce, function () {
- var inputValue = _this.inputValue;
- if (!inputValue) {
- _this.filtering = false;
- return;
- }
- var before = _this.beforeFilter(inputValue);
- if (before && before.then) {
- before.then(_this.getSuggestions);
- } else if (before !== false) {
- _this.getSuggestions();
- } else {
- _this.filtering = false;
- }
- });
- Object(resize_event_["addResizeListener"])(this.$el, this.updateStyle);
- },
- beforeDestroy: function beforeDestroy() {
- Object(resize_event_["removeResizeListener"])(this.$el, this.updateStyle);
- },
- methods: {
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'expand-trigger': 'expand-trigger is removed, use `props.expandTrigger` instead.',
- 'change-on-select': 'change-on-select is removed, use `props.checkStrictly` instead.',
- 'hover-threshold': 'hover-threshold is removed, use `props.hoverThreshold` instead'
- },
- events: {
- 'active-item-change': 'active-item-change is renamed to expand-change'
- }
- };
- },
- toggleDropDownVisible: function toggleDropDownVisible(visible) {
- var _this2 = this;
- if (this.isDisabled) return;
- var dropDownVisible = this.dropDownVisible;
- var input = this.$refs.input;
- visible = Object(shared_["isDef"])(visible) ? visible : !dropDownVisible;
- if (visible !== dropDownVisible) {
- this.dropDownVisible = visible;
- if (visible) {
- this.$nextTick(function () {
- _this2.updatePopper();
- _this2.panel.scrollIntoView();
- });
- }
- input.$refs.input.setAttribute('aria-expanded', visible);
- this.$emit('visible-change', visible);
- }
- },
- handleDropdownLeave: function handleDropdownLeave() {
- this.filtering = false;
- this.inputValue = this.presentText;
- this.doDestroy();
- },
- handleKeyDown: function handleKeyDown(event) {
- switch (event.keyCode) {
- case KeyCode.enter:
- this.toggleDropDownVisible();
- break;
- case KeyCode.down:
- this.toggleDropDownVisible(true);
- this.focusFirstNode();
- event.preventDefault();
- break;
- case KeyCode.esc:
- case KeyCode.tab:
- this.toggleDropDownVisible(false);
- break;
- }
- },
- handleFocus: function handleFocus(e) {
- this.$emit('focus', e);
- },
- handleBlur: function handleBlur(e) {
- this.$emit('blur', e);
- },
- handleInput: function handleInput(val, event) {
- !this.dropDownVisible && this.toggleDropDownVisible(true);
- if (event && event.isComposing) return;
- if (val) {
- this.filterHandler();
- } else {
- this.filtering = false;
- }
- },
- handleClear: function handleClear() {
- this.presentText = '';
- this.panel.clearCheckedNodes();
- },
- handleExpandChange: function handleExpandChange(value) {
- this.$nextTick(this.updatePopper.bind(this));
- this.$emit('expand-change', value);
- this.$emit('active-item-change', value); // Deprecated
- },
- focusFirstNode: function focusFirstNode() {
- var _this3 = this;
- this.$nextTick(function () {
- var filtering = _this3.filtering;
- var _$refs = _this3.$refs,
- popper = _$refs.popper,
- suggestionPanel = _$refs.suggestionPanel;
- var firstNode = null;
- if (filtering && suggestionPanel) {
- firstNode = suggestionPanel.$el.querySelector('.el-cascader__suggestion-item');
- } else {
- var firstMenu = popper.querySelector('.el-cascader-menu');
- firstNode = firstMenu.querySelector('.el-cascader-node[tabindex="-1"]');
- }
- if (firstNode) {
- firstNode.focus();
- !filtering && firstNode.click();
- }
- });
- },
- computePresentContent: function computePresentContent() {
- var _this4 = this;
- // nextTick is required, because checked nodes may not change right now
- this.$nextTick(function () {
- if (_this4.config.multiple) {
- _this4.computePresentTags();
- _this4.presentText = _this4.presentTags.length ? ' ' : null;
- } else {
- _this4.computePresentText();
- }
- });
- },
- isEmptyValue: function isEmptyValue(val) {
- var multiple = this.multiple;
- var emitPath = this.panel.config.emitPath;
- if (multiple || emitPath) {
- return Object(util_["isEmpty"])(val);
- }
- return false;
- },
- computePresentText: function computePresentText() {
- var checkedValue = this.checkedValue,
- config = this.config;
- if (!this.isEmptyValue(checkedValue)) {
- var node = this.panel.getNodeByValue(checkedValue);
- if (node && (config.checkStrictly || node.isLeaf)) {
- this.presentText = node.getText(this.showAllLevels, this.separator);
- return;
- }
- }
- this.presentText = null;
- },
- computePresentTags: function computePresentTags() {
- var isDisabled = this.isDisabled,
- leafOnly = this.leafOnly,
- showAllLevels = this.showAllLevels,
- separator = this.separator,
- collapseTags = this.collapseTags;
- var checkedNodes = this.getCheckedNodes(leafOnly);
- var tags = [];
- var genTag = function genTag(node) {
- return {
- node: node,
- key: node.uid,
- text: node.getText(showAllLevels, separator),
- hitState: false,
- closable: !isDisabled && !node.isDisabled
- };
- };
- if (checkedNodes.length) {
- var first = checkedNodes[0],
- rest = checkedNodes.slice(1);
- var restCount = rest.length;
- tags.push(genTag(first));
- if (restCount) {
- if (collapseTags) {
- tags.push({
- key: -1,
- text: '+ ' + restCount,
- closable: false
- });
- } else {
- rest.forEach(function (node) {
- return tags.push(genTag(node));
- });
- }
- }
- }
- this.checkedNodes = checkedNodes;
- this.presentTags = tags;
- },
- getSuggestions: function getSuggestions() {
- var _this5 = this;
- var filterMethod = this.filterMethod;
- if (!Object(types_["isFunction"])(filterMethod)) {
- filterMethod = function filterMethod(node, keyword) {
- return node.text.includes(keyword);
- };
- }
- var suggestions = this.panel.getFlattedNodes(this.leafOnly).filter(function (node) {
- if (node.isDisabled) return false;
- node.text = node.getText(_this5.showAllLevels, _this5.separator) || '';
- return filterMethod(node, _this5.inputValue);
- });
- if (this.multiple) {
- this.presentTags.forEach(function (tag) {
- tag.hitState = false;
- });
- } else {
- suggestions.forEach(function (node) {
- node.checked = Object(util_["isEqual"])(_this5.checkedValue, node.getValueByOption());
- });
- }
- this.filtering = true;
- this.suggestions = suggestions;
- this.$nextTick(this.updatePopper);
- },
- handleSuggestionKeyDown: function handleSuggestionKeyDown(event) {
- var keyCode = event.keyCode,
- target = event.target;
- switch (keyCode) {
- case KeyCode.enter:
- target.click();
- break;
- case KeyCode.up:
- var prev = target.previousElementSibling;
- prev && prev.focus();
- break;
- case KeyCode.down:
- var next = target.nextElementSibling;
- next && next.focus();
- break;
- case KeyCode.esc:
- case KeyCode.tab:
- this.toggleDropDownVisible(false);
- break;
- }
- },
- handleDelete: function handleDelete() {
- var inputValue = this.inputValue,
- pressDeleteCount = this.pressDeleteCount,
- presentTags = this.presentTags;
- var lastIndex = presentTags.length - 1;
- var lastTag = presentTags[lastIndex];
- this.pressDeleteCount = inputValue ? 0 : pressDeleteCount + 1;
- if (!lastTag) return;
- if (this.pressDeleteCount) {
- if (lastTag.hitState) {
- this.deleteTag(lastTag);
- } else {
- lastTag.hitState = true;
- }
- }
- },
- handleSuggestionClick: function handleSuggestionClick(index) {
- var multiple = this.multiple;
- var targetNode = this.suggestions[index];
- if (multiple) {
- var checked = targetNode.checked;
- targetNode.doCheck(!checked);
- this.panel.calculateMultiCheckedValue();
- } else {
- this.checkedValue = targetNode.getValueByOption();
- this.toggleDropDownVisible(false);
- }
- },
- deleteTag: function deleteTag(tag) {
- var checkedValue = this.checkedValue;
- var current = tag.node.getValueByOption();
- var val = checkedValue.find(function (n) {
- return Object(util_["isEqual"])(n, current);
- });
- this.checkedValue = checkedValue.filter(function (n) {
- return !Object(util_["isEqual"])(n, current);
- });
- this.$emit('remove-tag', val);
- },
- updateStyle: function updateStyle() {
- var $el = this.$el,
- inputInitialHeight = this.inputInitialHeight;
- if (this.$isServer || !$el) return;
- var suggestionPanel = this.$refs.suggestionPanel;
- var inputInner = $el.querySelector('.el-input__inner');
- if (!inputInner) return;
- var tags = $el.querySelector('.el-cascader__tags');
- var suggestionPanelEl = null;
- if (suggestionPanel && (suggestionPanelEl = suggestionPanel.$el)) {
- var suggestionList = suggestionPanelEl.querySelector('.el-cascader__suggestion-list');
- suggestionList.style.minWidth = inputInner.offsetWidth + 'px';
- }
- if (tags) {
- var offsetHeight = Math.round(tags.getBoundingClientRect().height);
- var height = Math.max(offsetHeight + 6, inputInitialHeight) + 'px';
- inputInner.style.height = height;
- if (this.dropDownVisible) {
- this.updatePopper();
- }
- }
- },
- /**
- * public methods
- */
- getCheckedNodes: function getCheckedNodes(leafOnly) {
- return this.panel.getCheckedNodes(leafOnly);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/cascader/src/cascader.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_cascadervue_type_script_lang_js_ = (cascadervue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/cascader/src/cascader.vue
- /* normalize component */
- var cascader_component = normalizeComponent(
- src_cascadervue_type_script_lang_js_,
- cascadervue_type_template_id_032537a6_render,
- cascadervue_type_template_id_032537a6_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var cascader_api; }
- cascader_component.options.__file = "packages/cascader/src/cascader.vue"
- /* harmony default export */ var cascader = (cascader_component.exports);
- // CONCATENATED MODULE: ./packages/cascader/index.js
- /* istanbul ignore next */
- cascader.install = function (Vue) {
- Vue.component(cascader.name, cascader);
- };
- /* harmony default export */ var packages_cascader = (cascader);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/main.vue?vue&type=template&id=55c8ade7&
- var mainvue_type_template_id_55c8ade7_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: _vm.hide,
- expression: "hide"
- }
- ],
- class: [
- "el-color-picker",
- _vm.colorDisabled ? "is-disabled" : "",
- _vm.colorSize ? "el-color-picker--" + _vm.colorSize : ""
- ]
- },
- [
- _vm.colorDisabled
- ? _c("div", { staticClass: "el-color-picker__mask" })
- : _vm._e(),
- _c(
- "div",
- {
- staticClass: "el-color-picker__trigger",
- on: { click: _vm.handleTrigger }
- },
- [
- _c(
- "span",
- {
- staticClass: "el-color-picker__color",
- class: { "is-alpha": _vm.showAlpha }
- },
- [
- _c("span", {
- staticClass: "el-color-picker__color-inner",
- style: {
- backgroundColor: _vm.displayedColor
- }
- }),
- !_vm.value && !_vm.showPanelColor
- ? _c("span", {
- staticClass: "el-color-picker__empty el-icon-close"
- })
- : _vm._e()
- ]
- ),
- _c("span", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.value || _vm.showPanelColor,
- expression: "value || showPanelColor"
- }
- ],
- staticClass: "el-color-picker__icon el-icon-arrow-down"
- })
- ]
- ),
- _c("picker-dropdown", {
- ref: "dropdown",
- class: ["el-color-picker__panel", _vm.popperClass || ""],
- attrs: {
- color: _vm.color,
- "show-alpha": _vm.showAlpha,
- predefine: _vm.predefine
- },
- on: { pick: _vm.confirmValue, clear: _vm.clearValue },
- model: {
- value: _vm.showPicker,
- callback: function($$v) {
- _vm.showPicker = $$v
- },
- expression: "showPicker"
- }
- })
- ],
- 1
- )
- }
- var mainvue_type_template_id_55c8ade7_staticRenderFns = []
- mainvue_type_template_id_55c8ade7_render._withStripped = true
- // CONCATENATED MODULE: ./packages/color-picker/src/main.vue?vue&type=template&id=55c8ade7&
- // CONCATENATED MODULE: ./packages/color-picker/src/color.js
- var color_typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- function color_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- var hsv2hsl = function hsv2hsl(hue, sat, val) {
- return [hue, sat * val / ((hue = (2 - sat) * val) < 1 ? hue : 2 - hue) || 0, hue / 2];
- };
- // Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1
- // <http://stackoverflow.com/questions/7422072/javascript-how-to-detect-number-as-a-decimal-including-1-0>
- var isOnePointZero = function isOnePointZero(n) {
- return typeof n === 'string' && n.indexOf('.') !== -1 && parseFloat(n) === 1;
- };
- var isPercentage = function isPercentage(n) {
- return typeof n === 'string' && n.indexOf('%') !== -1;
- };
- // Take input from [0, n] and return it as [0, 1]
- var bound01 = function bound01(value, max) {
- if (isOnePointZero(value)) value = '100%';
- var processPercent = isPercentage(value);
- value = Math.min(max, Math.max(0, parseFloat(value)));
- // Automatically convert percentage into number
- if (processPercent) {
- value = parseInt(value * max, 10) / 100;
- }
- // Handle floating point rounding errors
- if (Math.abs(value - max) < 0.000001) {
- return 1;
- }
- // Convert into [0, 1] range if it isn't already
- return value % max / parseFloat(max);
- };
- var INT_HEX_MAP = { 10: 'A', 11: 'B', 12: 'C', 13: 'D', 14: 'E', 15: 'F' };
- var toHex = function toHex(_ref) {
- var r = _ref.r,
- g = _ref.g,
- b = _ref.b;
- var hexOne = function hexOne(value) {
- value = Math.min(Math.round(value), 255);
- var high = Math.floor(value / 16);
- var low = value % 16;
- return '' + (INT_HEX_MAP[high] || high) + (INT_HEX_MAP[low] || low);
- };
- if (isNaN(r) || isNaN(g) || isNaN(b)) return '';
- return '#' + hexOne(r) + hexOne(g) + hexOne(b);
- };
- var HEX_INT_MAP = { A: 10, B: 11, C: 12, D: 13, E: 14, F: 15 };
- var parseHexChannel = function parseHexChannel(hex) {
- if (hex.length === 2) {
- return (HEX_INT_MAP[hex[0].toUpperCase()] || +hex[0]) * 16 + (HEX_INT_MAP[hex[1].toUpperCase()] || +hex[1]);
- }
- return HEX_INT_MAP[hex[1].toUpperCase()] || +hex[1];
- };
- var hsl2hsv = function hsl2hsv(hue, sat, light) {
- sat = sat / 100;
- light = light / 100;
- var smin = sat;
- var lmin = Math.max(light, 0.01);
- var sv = void 0;
- var v = void 0;
- light *= 2;
- sat *= light <= 1 ? light : 2 - light;
- smin *= lmin <= 1 ? lmin : 2 - lmin;
- v = (light + sat) / 2;
- sv = light === 0 ? 2 * smin / (lmin + smin) : 2 * sat / (light + sat);
- return {
- h: hue,
- s: sv * 100,
- v: v * 100
- };
- };
- // `rgbToHsv`
- // Converts an RGB color value to HSV
- // *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1]
- // *Returns:* { h, s, v } in [0,1]
- var rgb2hsv = function rgb2hsv(r, g, b) {
- r = bound01(r, 255);
- g = bound01(g, 255);
- b = bound01(b, 255);
- var max = Math.max(r, g, b);
- var min = Math.min(r, g, b);
- var h = void 0,
- s = void 0;
- var v = max;
- var d = max - min;
- s = max === 0 ? 0 : d / max;
- if (max === min) {
- h = 0; // achromatic
- } else {
- switch (max) {
- case r:
- h = (g - b) / d + (g < b ? 6 : 0);
- break;
- case g:
- h = (b - r) / d + 2;
- break;
- case b:
- h = (r - g) / d + 4;
- break;
- }
- h /= 6;
- }
- return { h: h * 360, s: s * 100, v: v * 100 };
- };
- // `hsvToRgb`
- // Converts an HSV color value to RGB.
- // *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100]
- // *Returns:* { r, g, b } in the set [0, 255]
- var hsv2rgb = function hsv2rgb(h, s, v) {
- h = bound01(h, 360) * 6;
- s = bound01(s, 100);
- v = bound01(v, 100);
- var i = Math.floor(h);
- var f = h - i;
- var p = v * (1 - s);
- var q = v * (1 - f * s);
- var t = v * (1 - (1 - f) * s);
- var mod = i % 6;
- var r = [v, q, p, p, t, v][mod];
- var g = [t, v, v, q, p, p][mod];
- var b = [p, p, t, v, v, q][mod];
- return {
- r: Math.round(r * 255),
- g: Math.round(g * 255),
- b: Math.round(b * 255)
- };
- };
- var Color = function () {
- function Color(options) {
- color_classCallCheck(this, Color);
- this._hue = 0;
- this._saturation = 100;
- this._value = 100;
- this._alpha = 100;
- this.enableAlpha = false;
- this.format = 'hex';
- this.value = '';
- options = options || {};
- for (var option in options) {
- if (options.hasOwnProperty(option)) {
- this[option] = options[option];
- }
- }
- this.doOnChange();
- }
- Color.prototype.set = function set(prop, value) {
- if (arguments.length === 1 && (typeof prop === 'undefined' ? 'undefined' : color_typeof(prop)) === 'object') {
- for (var p in prop) {
- if (prop.hasOwnProperty(p)) {
- this.set(p, prop[p]);
- }
- }
- return;
- }
- this['_' + prop] = value;
- this.doOnChange();
- };
- Color.prototype.get = function get(prop) {
- return this['_' + prop];
- };
- Color.prototype.toRgb = function toRgb() {
- return hsv2rgb(this._hue, this._saturation, this._value);
- };
- Color.prototype.fromString = function fromString(value) {
- var _this = this;
- if (!value) {
- this._hue = 0;
- this._saturation = 100;
- this._value = 100;
- this.doOnChange();
- return;
- }
- var fromHSV = function fromHSV(h, s, v) {
- _this._hue = Math.max(0, Math.min(360, h));
- _this._saturation = Math.max(0, Math.min(100, s));
- _this._value = Math.max(0, Math.min(100, v));
- _this.doOnChange();
- };
- if (value.indexOf('hsl') !== -1) {
- var parts = value.replace(/hsla|hsl|\(|\)/gm, '').split(/\s|,/g).filter(function (val) {
- return val !== '';
- }).map(function (val, index) {
- return index > 2 ? parseFloat(val) : parseInt(val, 10);
- });
- if (parts.length === 4) {
- this._alpha = Math.floor(parseFloat(parts[3]) * 100);
- } else if (parts.length === 3) {
- this._alpha = 100;
- }
- if (parts.length >= 3) {
- var _hsl2hsv = hsl2hsv(parts[0], parts[1], parts[2]),
- h = _hsl2hsv.h,
- s = _hsl2hsv.s,
- v = _hsl2hsv.v;
- fromHSV(h, s, v);
- }
- } else if (value.indexOf('hsv') !== -1) {
- var _parts = value.replace(/hsva|hsv|\(|\)/gm, '').split(/\s|,/g).filter(function (val) {
- return val !== '';
- }).map(function (val, index) {
- return index > 2 ? parseFloat(val) : parseInt(val, 10);
- });
- if (_parts.length === 4) {
- this._alpha = Math.floor(parseFloat(_parts[3]) * 100);
- } else if (_parts.length === 3) {
- this._alpha = 100;
- }
- if (_parts.length >= 3) {
- fromHSV(_parts[0], _parts[1], _parts[2]);
- }
- } else if (value.indexOf('rgb') !== -1) {
- var _parts2 = value.replace(/rgba|rgb|\(|\)/gm, '').split(/\s|,/g).filter(function (val) {
- return val !== '';
- }).map(function (val, index) {
- return index > 2 ? parseFloat(val) : parseInt(val, 10);
- });
- if (_parts2.length === 4) {
- this._alpha = Math.floor(parseFloat(_parts2[3]) * 100);
- } else if (_parts2.length === 3) {
- this._alpha = 100;
- }
- if (_parts2.length >= 3) {
- var _rgb2hsv = rgb2hsv(_parts2[0], _parts2[1], _parts2[2]),
- _h = _rgb2hsv.h,
- _s = _rgb2hsv.s,
- _v = _rgb2hsv.v;
- fromHSV(_h, _s, _v);
- }
- } else if (value.indexOf('#') !== -1) {
- var hex = value.replace('#', '').trim();
- if (!/^(?:[0-9a-fA-F]{3}){1,2}|[0-9a-fA-F]{8}$/.test(hex)) return;
- var r = void 0,
- g = void 0,
- b = void 0;
- if (hex.length === 3) {
- r = parseHexChannel(hex[0] + hex[0]);
- g = parseHexChannel(hex[1] + hex[1]);
- b = parseHexChannel(hex[2] + hex[2]);
- } else if (hex.length === 6 || hex.length === 8) {
- r = parseHexChannel(hex.substring(0, 2));
- g = parseHexChannel(hex.substring(2, 4));
- b = parseHexChannel(hex.substring(4, 6));
- }
- if (hex.length === 8) {
- this._alpha = Math.floor(parseHexChannel(hex.substring(6)) / 255 * 100);
- } else if (hex.length === 3 || hex.length === 6) {
- this._alpha = 100;
- }
- var _rgb2hsv2 = rgb2hsv(r, g, b),
- _h2 = _rgb2hsv2.h,
- _s2 = _rgb2hsv2.s,
- _v2 = _rgb2hsv2.v;
- fromHSV(_h2, _s2, _v2);
- }
- };
- Color.prototype.compare = function compare(color) {
- return Math.abs(color._hue - this._hue) < 2 && Math.abs(color._saturation - this._saturation) < 1 && Math.abs(color._value - this._value) < 1 && Math.abs(color._alpha - this._alpha) < 1;
- };
- Color.prototype.doOnChange = function doOnChange() {
- var _hue = this._hue,
- _saturation = this._saturation,
- _value = this._value,
- _alpha = this._alpha,
- format = this.format;
- if (this.enableAlpha) {
- switch (format) {
- case 'hsl':
- var hsl = hsv2hsl(_hue, _saturation / 100, _value / 100);
- this.value = 'hsla(' + _hue + ', ' + Math.round(hsl[1] * 100) + '%, ' + Math.round(hsl[2] * 100) + '%, ' + _alpha / 100 + ')';
- break;
- case 'hsv':
- this.value = 'hsva(' + _hue + ', ' + Math.round(_saturation) + '%, ' + Math.round(_value) + '%, ' + _alpha / 100 + ')';
- break;
- default:
- var _hsv2rgb = hsv2rgb(_hue, _saturation, _value),
- r = _hsv2rgb.r,
- g = _hsv2rgb.g,
- b = _hsv2rgb.b;
- this.value = 'rgba(' + r + ', ' + g + ', ' + b + ', ' + _alpha / 100 + ')';
- }
- } else {
- switch (format) {
- case 'hsl':
- var _hsl = hsv2hsl(_hue, _saturation / 100, _value / 100);
- this.value = 'hsl(' + _hue + ', ' + Math.round(_hsl[1] * 100) + '%, ' + Math.round(_hsl[2] * 100) + '%)';
- break;
- case 'hsv':
- this.value = 'hsv(' + _hue + ', ' + Math.round(_saturation) + '%, ' + Math.round(_value) + '%)';
- break;
- case 'rgb':
- var _hsv2rgb2 = hsv2rgb(_hue, _saturation, _value),
- _r = _hsv2rgb2.r,
- _g = _hsv2rgb2.g,
- _b = _hsv2rgb2.b;
- this.value = 'rgb(' + _r + ', ' + _g + ', ' + _b + ')';
- break;
- default:
- this.value = toHex(hsv2rgb(_hue, _saturation, _value));
- }
- }
- };
- return Color;
- }();
- /* harmony default export */ var src_color = (Color);
- ;
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/picker-dropdown.vue?vue&type=template&id=06601625&
- var picker_dropdownvue_type_template_id_06601625_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.showPopper,
- expression: "showPopper"
- }
- ],
- staticClass: "el-color-dropdown"
- },
- [
- _c(
- "div",
- { staticClass: "el-color-dropdown__main-wrapper" },
- [
- _c("hue-slider", {
- ref: "hue",
- staticStyle: { float: "right" },
- attrs: { color: _vm.color, vertical: "" }
- }),
- _c("sv-panel", { ref: "sl", attrs: { color: _vm.color } })
- ],
- 1
- ),
- _vm.showAlpha
- ? _c("alpha-slider", { ref: "alpha", attrs: { color: _vm.color } })
- : _vm._e(),
- _vm.predefine
- ? _c("predefine", {
- attrs: { color: _vm.color, colors: _vm.predefine }
- })
- : _vm._e(),
- _c(
- "div",
- { staticClass: "el-color-dropdown__btns" },
- [
- _c(
- "span",
- { staticClass: "el-color-dropdown__value" },
- [
- _c("el-input", {
- attrs: { "validate-event": false, size: "mini" },
- on: { blur: _vm.handleConfirm },
- nativeOn: {
- keyup: function($event) {
- if (
- !("button" in $event) &&
- _vm._k(
- $event.keyCode,
- "enter",
- 13,
- $event.key,
- "Enter"
- )
- ) {
- return null
- }
- return _vm.handleConfirm($event)
- }
- },
- model: {
- value: _vm.customInput,
- callback: function($$v) {
- _vm.customInput = $$v
- },
- expression: "customInput"
- }
- })
- ],
- 1
- ),
- _c(
- "el-button",
- {
- staticClass: "el-color-dropdown__link-btn",
- attrs: { size: "mini", type: "text" },
- on: {
- click: function($event) {
- _vm.$emit("clear")
- }
- }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.t("el.colorpicker.clear")) +
- "\n "
- )
- ]
- ),
- _c(
- "el-button",
- {
- staticClass: "el-color-dropdown__btn",
- attrs: { plain: "", size: "mini" },
- on: { click: _vm.confirmValue }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.t("el.colorpicker.confirm")) +
- "\n "
- )
- ]
- )
- ],
- 1
- )
- ],
- 1
- )
- ]
- )
- }
- var picker_dropdownvue_type_template_id_06601625_staticRenderFns = []
- picker_dropdownvue_type_template_id_06601625_render._withStripped = true
- // CONCATENATED MODULE: ./packages/color-picker/src/components/picker-dropdown.vue?vue&type=template&id=06601625&
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/sv-panel.vue?vue&type=template&id=d8583596&
- var sv_panelvue_type_template_id_d8583596_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-color-svpanel",
- style: {
- backgroundColor: _vm.background
- }
- },
- [
- _c("div", { staticClass: "el-color-svpanel__white" }),
- _c("div", { staticClass: "el-color-svpanel__black" }),
- _c(
- "div",
- {
- staticClass: "el-color-svpanel__cursor",
- style: {
- top: _vm.cursorTop + "px",
- left: _vm.cursorLeft + "px"
- }
- },
- [_c("div")]
- )
- ]
- )
- }
- var sv_panelvue_type_template_id_d8583596_staticRenderFns = []
- sv_panelvue_type_template_id_d8583596_render._withStripped = true
- // CONCATENATED MODULE: ./packages/color-picker/src/components/sv-panel.vue?vue&type=template&id=d8583596&
- // CONCATENATED MODULE: ./packages/color-picker/src/draggable.js
- var isDragging = false;
- /* harmony default export */ var draggable = (function (element, options) {
- if (external_vue_default.a.prototype.$isServer) return;
- var moveFn = function moveFn(event) {
- if (options.drag) {
- options.drag(event);
- }
- };
- var upFn = function upFn(event) {
- document.removeEventListener('mousemove', moveFn);
- document.removeEventListener('mouseup', upFn);
- document.onselectstart = null;
- document.ondragstart = null;
- isDragging = false;
- if (options.end) {
- options.end(event);
- }
- };
- element.addEventListener('mousedown', function (event) {
- if (isDragging) return;
- document.onselectstart = function () {
- return false;
- };
- document.ondragstart = function () {
- return false;
- };
- document.addEventListener('mousemove', moveFn);
- document.addEventListener('mouseup', upFn);
- isDragging = true;
- if (options.start) {
- options.start(event);
- }
- });
- });
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/sv-panel.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var sv_panelvue_type_script_lang_js_ = ({
- name: 'el-sl-panel',
- props: {
- color: {
- required: true
- }
- },
- computed: {
- colorValue: function colorValue() {
- var hue = this.color.get('hue');
- var value = this.color.get('value');
- return { hue: hue, value: value };
- }
- },
- watch: {
- colorValue: function colorValue() {
- this.update();
- }
- },
- methods: {
- update: function update() {
- var saturation = this.color.get('saturation');
- var value = this.color.get('value');
- var el = this.$el;
- var width = el.clientWidth,
- height = el.clientHeight;
- this.cursorLeft = saturation * width / 100;
- this.cursorTop = (100 - value) * height / 100;
- this.background = 'hsl(' + this.color.get('hue') + ', 100%, 50%)';
- },
- handleDrag: function handleDrag(event) {
- var el = this.$el;
- var rect = el.getBoundingClientRect();
- var left = event.clientX - rect.left;
- var top = event.clientY - rect.top;
- left = Math.max(0, left);
- left = Math.min(left, rect.width);
- top = Math.max(0, top);
- top = Math.min(top, rect.height);
- this.cursorLeft = left;
- this.cursorTop = top;
- this.color.set({
- saturation: left / rect.width * 100,
- value: 100 - top / rect.height * 100
- });
- }
- },
- mounted: function mounted() {
- var _this = this;
- draggable(this.$el, {
- drag: function drag(event) {
- _this.handleDrag(event);
- },
- end: function end(event) {
- _this.handleDrag(event);
- }
- });
- this.update();
- },
- data: function data() {
- return {
- cursorTop: 0,
- cursorLeft: 0,
- background: 'hsl(0, 100%, 50%)'
- };
- }
- });
- // CONCATENATED MODULE: ./packages/color-picker/src/components/sv-panel.vue?vue&type=script&lang=js&
- /* harmony default export */ var components_sv_panelvue_type_script_lang_js_ = (sv_panelvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/color-picker/src/components/sv-panel.vue
- /* normalize component */
- var sv_panel_component = normalizeComponent(
- components_sv_panelvue_type_script_lang_js_,
- sv_panelvue_type_template_id_d8583596_render,
- sv_panelvue_type_template_id_d8583596_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var sv_panel_api; }
- sv_panel_component.options.__file = "packages/color-picker/src/components/sv-panel.vue"
- /* harmony default export */ var sv_panel = (sv_panel_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/hue-slider.vue?vue&type=template&id=5cdc43b1&
- var hue_slidervue_type_template_id_5cdc43b1_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-color-hue-slider",
- class: { "is-vertical": _vm.vertical }
- },
- [
- _c("div", {
- ref: "bar",
- staticClass: "el-color-hue-slider__bar",
- on: { click: _vm.handleClick }
- }),
- _c("div", {
- ref: "thumb",
- staticClass: "el-color-hue-slider__thumb",
- style: {
- left: _vm.thumbLeft + "px",
- top: _vm.thumbTop + "px"
- }
- })
- ]
- )
- }
- var hue_slidervue_type_template_id_5cdc43b1_staticRenderFns = []
- hue_slidervue_type_template_id_5cdc43b1_render._withStripped = true
- // CONCATENATED MODULE: ./packages/color-picker/src/components/hue-slider.vue?vue&type=template&id=5cdc43b1&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/hue-slider.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var hue_slidervue_type_script_lang_js_ = ({
- name: 'el-color-hue-slider',
- props: {
- color: {
- required: true
- },
- vertical: Boolean
- },
- data: function data() {
- return {
- thumbLeft: 0,
- thumbTop: 0
- };
- },
- computed: {
- hueValue: function hueValue() {
- var hue = this.color.get('hue');
- return hue;
- }
- },
- watch: {
- hueValue: function hueValue() {
- this.update();
- }
- },
- methods: {
- handleClick: function handleClick(event) {
- var thumb = this.$refs.thumb;
- var target = event.target;
- if (target !== thumb) {
- this.handleDrag(event);
- }
- },
- handleDrag: function handleDrag(event) {
- var rect = this.$el.getBoundingClientRect();
- var thumb = this.$refs.thumb;
- var hue = void 0;
- if (!this.vertical) {
- var left = event.clientX - rect.left;
- left = Math.min(left, rect.width - thumb.offsetWidth / 2);
- left = Math.max(thumb.offsetWidth / 2, left);
- hue = Math.round((left - thumb.offsetWidth / 2) / (rect.width - thumb.offsetWidth) * 360);
- } else {
- var top = event.clientY - rect.top;
- top = Math.min(top, rect.height - thumb.offsetHeight / 2);
- top = Math.max(thumb.offsetHeight / 2, top);
- hue = Math.round((top - thumb.offsetHeight / 2) / (rect.height - thumb.offsetHeight) * 360);
- }
- this.color.set('hue', hue);
- },
- getThumbLeft: function getThumbLeft() {
- if (this.vertical) return 0;
- var el = this.$el;
- var hue = this.color.get('hue');
- if (!el) return 0;
- var thumb = this.$refs.thumb;
- return Math.round(hue * (el.offsetWidth - thumb.offsetWidth / 2) / 360);
- },
- getThumbTop: function getThumbTop() {
- if (!this.vertical) return 0;
- var el = this.$el;
- var hue = this.color.get('hue');
- if (!el) return 0;
- var thumb = this.$refs.thumb;
- return Math.round(hue * (el.offsetHeight - thumb.offsetHeight / 2) / 360);
- },
- update: function update() {
- this.thumbLeft = this.getThumbLeft();
- this.thumbTop = this.getThumbTop();
- }
- },
- mounted: function mounted() {
- var _this = this;
- var _$refs = this.$refs,
- bar = _$refs.bar,
- thumb = _$refs.thumb;
- var dragConfig = {
- drag: function drag(event) {
- _this.handleDrag(event);
- },
- end: function end(event) {
- _this.handleDrag(event);
- }
- };
- draggable(bar, dragConfig);
- draggable(thumb, dragConfig);
- this.update();
- }
- });
- // CONCATENATED MODULE: ./packages/color-picker/src/components/hue-slider.vue?vue&type=script&lang=js&
- /* harmony default export */ var components_hue_slidervue_type_script_lang_js_ = (hue_slidervue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/color-picker/src/components/hue-slider.vue
- /* normalize component */
- var hue_slider_component = normalizeComponent(
- components_hue_slidervue_type_script_lang_js_,
- hue_slidervue_type_template_id_5cdc43b1_render,
- hue_slidervue_type_template_id_5cdc43b1_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var hue_slider_api; }
- hue_slider_component.options.__file = "packages/color-picker/src/components/hue-slider.vue"
- /* harmony default export */ var hue_slider = (hue_slider_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/alpha-slider.vue?vue&type=template&id=068c66cb&
- var alpha_slidervue_type_template_id_068c66cb_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-color-alpha-slider",
- class: { "is-vertical": _vm.vertical }
- },
- [
- _c("div", {
- ref: "bar",
- staticClass: "el-color-alpha-slider__bar",
- style: {
- background: _vm.background
- },
- on: { click: _vm.handleClick }
- }),
- _c("div", {
- ref: "thumb",
- staticClass: "el-color-alpha-slider__thumb",
- style: {
- left: _vm.thumbLeft + "px",
- top: _vm.thumbTop + "px"
- }
- })
- ]
- )
- }
- var alpha_slidervue_type_template_id_068c66cb_staticRenderFns = []
- alpha_slidervue_type_template_id_068c66cb_render._withStripped = true
- // CONCATENATED MODULE: ./packages/color-picker/src/components/alpha-slider.vue?vue&type=template&id=068c66cb&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/alpha-slider.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var alpha_slidervue_type_script_lang_js_ = ({
- name: 'el-color-alpha-slider',
- props: {
- color: {
- required: true
- },
- vertical: Boolean
- },
- watch: {
- 'color._alpha': function color_alpha() {
- this.update();
- },
- 'color.value': function colorValue() {
- this.update();
- }
- },
- methods: {
- handleClick: function handleClick(event) {
- var thumb = this.$refs.thumb;
- var target = event.target;
- if (target !== thumb) {
- this.handleDrag(event);
- }
- },
- handleDrag: function handleDrag(event) {
- var rect = this.$el.getBoundingClientRect();
- var thumb = this.$refs.thumb;
- if (!this.vertical) {
- var left = event.clientX - rect.left;
- left = Math.max(thumb.offsetWidth / 2, left);
- left = Math.min(left, rect.width - thumb.offsetWidth / 2);
- this.color.set('alpha', Math.round((left - thumb.offsetWidth / 2) / (rect.width - thumb.offsetWidth) * 100));
- } else {
- var top = event.clientY - rect.top;
- top = Math.max(thumb.offsetHeight / 2, top);
- top = Math.min(top, rect.height - thumb.offsetHeight / 2);
- this.color.set('alpha', Math.round((top - thumb.offsetHeight / 2) / (rect.height - thumb.offsetHeight) * 100));
- }
- },
- getThumbLeft: function getThumbLeft() {
- if (this.vertical) return 0;
- var el = this.$el;
- var alpha = this.color._alpha;
- if (!el) return 0;
- var thumb = this.$refs.thumb;
- return Math.round(alpha * (el.offsetWidth - thumb.offsetWidth / 2) / 100);
- },
- getThumbTop: function getThumbTop() {
- if (!this.vertical) return 0;
- var el = this.$el;
- var alpha = this.color._alpha;
- if (!el) return 0;
- var thumb = this.$refs.thumb;
- return Math.round(alpha * (el.offsetHeight - thumb.offsetHeight / 2) / 100);
- },
- getBackground: function getBackground() {
- if (this.color && this.color.value) {
- var _color$toRgb = this.color.toRgb(),
- r = _color$toRgb.r,
- g = _color$toRgb.g,
- b = _color$toRgb.b;
- return 'linear-gradient(to right, rgba(' + r + ', ' + g + ', ' + b + ', 0) 0%, rgba(' + r + ', ' + g + ', ' + b + ', 1) 100%)';
- }
- return null;
- },
- update: function update() {
- this.thumbLeft = this.getThumbLeft();
- this.thumbTop = this.getThumbTop();
- this.background = this.getBackground();
- }
- },
- data: function data() {
- return {
- thumbLeft: 0,
- thumbTop: 0,
- background: null
- };
- },
- mounted: function mounted() {
- var _this = this;
- var _$refs = this.$refs,
- bar = _$refs.bar,
- thumb = _$refs.thumb;
- var dragConfig = {
- drag: function drag(event) {
- _this.handleDrag(event);
- },
- end: function end(event) {
- _this.handleDrag(event);
- }
- };
- draggable(bar, dragConfig);
- draggable(thumb, dragConfig);
- this.update();
- }
- });
- // CONCATENATED MODULE: ./packages/color-picker/src/components/alpha-slider.vue?vue&type=script&lang=js&
- /* harmony default export */ var components_alpha_slidervue_type_script_lang_js_ = (alpha_slidervue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/color-picker/src/components/alpha-slider.vue
- /* normalize component */
- var alpha_slider_component = normalizeComponent(
- components_alpha_slidervue_type_script_lang_js_,
- alpha_slidervue_type_template_id_068c66cb_render,
- alpha_slidervue_type_template_id_068c66cb_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var alpha_slider_api; }
- alpha_slider_component.options.__file = "packages/color-picker/src/components/alpha-slider.vue"
- /* harmony default export */ var alpha_slider = (alpha_slider_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/predefine.vue?vue&type=template&id=06e03093&
- var predefinevue_type_template_id_06e03093_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("div", { staticClass: "el-color-predefine" }, [
- _c(
- "div",
- { staticClass: "el-color-predefine__colors" },
- _vm._l(_vm.rgbaColors, function(item, index) {
- return _c(
- "div",
- {
- key: _vm.colors[index],
- staticClass: "el-color-predefine__color-selector",
- class: { selected: item.selected, "is-alpha": item._alpha < 100 },
- on: {
- click: function($event) {
- _vm.handleSelect(index)
- }
- }
- },
- [_c("div", { style: { "background-color": item.value } })]
- )
- }),
- 0
- )
- ])
- }
- var predefinevue_type_template_id_06e03093_staticRenderFns = []
- predefinevue_type_template_id_06e03093_render._withStripped = true
- // CONCATENATED MODULE: ./packages/color-picker/src/components/predefine.vue?vue&type=template&id=06e03093&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/predefine.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var predefinevue_type_script_lang_js_ = ({
- props: {
- colors: { type: Array, required: true },
- color: { required: true }
- },
- data: function data() {
- return {
- rgbaColors: this.parseColors(this.colors, this.color)
- };
- },
- methods: {
- handleSelect: function handleSelect(index) {
- this.color.fromString(this.colors[index]);
- },
- parseColors: function parseColors(colors, color) {
- return colors.map(function (value) {
- var c = new src_color();
- c.enableAlpha = true;
- c.format = 'rgba';
- c.fromString(value);
- c.selected = c.value === color.value;
- return c;
- });
- }
- },
- watch: {
- '$parent.currentColor': function $parentCurrentColor(val) {
- var color = new src_color();
- color.fromString(val);
- this.rgbaColors.forEach(function (item) {
- item.selected = color.compare(item);
- });
- },
- colors: function colors(newVal) {
- this.rgbaColors = this.parseColors(newVal, this.color);
- },
- color: function color(newVal) {
- this.rgbaColors = this.parseColors(this.colors, newVal);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/color-picker/src/components/predefine.vue?vue&type=script&lang=js&
- /* harmony default export */ var components_predefinevue_type_script_lang_js_ = (predefinevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/color-picker/src/components/predefine.vue
- /* normalize component */
- var predefine_component = normalizeComponent(
- components_predefinevue_type_script_lang_js_,
- predefinevue_type_template_id_06e03093_render,
- predefinevue_type_template_id_06e03093_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var predefine_api; }
- predefine_component.options.__file = "packages/color-picker/src/components/predefine.vue"
- /* harmony default export */ var predefine = (predefine_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/picker-dropdown.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var picker_dropdownvue_type_script_lang_js_ = ({
- name: 'el-color-picker-dropdown',
- mixins: [vue_popper_default.a, locale_default.a],
- components: {
- SvPanel: sv_panel,
- HueSlider: hue_slider,
- AlphaSlider: alpha_slider,
- ElInput: input_default.a,
- ElButton: button_default.a,
- Predefine: predefine
- },
- props: {
- color: {
- required: true
- },
- showAlpha: Boolean,
- predefine: Array
- },
- data: function data() {
- return {
- customInput: ''
- };
- },
- computed: {
- currentColor: function currentColor() {
- var parent = this.$parent;
- return !parent.value && !parent.showPanelColor ? '' : parent.color.value;
- }
- },
- methods: {
- confirmValue: function confirmValue() {
- this.$emit('pick');
- },
- handleConfirm: function handleConfirm() {
- this.color.fromString(this.customInput);
- }
- },
- mounted: function mounted() {
- this.$parent.popperElm = this.popperElm = this.$el;
- this.referenceElm = this.$parent.$el;
- },
- watch: {
- showPopper: function showPopper(val) {
- var _this = this;
- if (val === true) {
- this.$nextTick(function () {
- var _$refs = _this.$refs,
- sl = _$refs.sl,
- hue = _$refs.hue,
- alpha = _$refs.alpha;
- sl && sl.update();
- hue && hue.update();
- alpha && alpha.update();
- });
- }
- },
- currentColor: {
- immediate: true,
- handler: function handler(val) {
- this.customInput = val;
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/color-picker/src/components/picker-dropdown.vue?vue&type=script&lang=js&
- /* harmony default export */ var components_picker_dropdownvue_type_script_lang_js_ = (picker_dropdownvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/color-picker/src/components/picker-dropdown.vue
- /* normalize component */
- var picker_dropdown_component = normalizeComponent(
- components_picker_dropdownvue_type_script_lang_js_,
- picker_dropdownvue_type_template_id_06601625_render,
- picker_dropdownvue_type_template_id_06601625_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var picker_dropdown_api; }
- picker_dropdown_component.options.__file = "packages/color-picker/src/components/picker-dropdown.vue"
- /* harmony default export */ var picker_dropdown = (picker_dropdown_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var color_picker_src_mainvue_type_script_lang_js_ = ({
- name: 'ElColorPicker',
- mixins: [emitter_default.a],
- props: {
- value: String,
- showAlpha: Boolean,
- colorFormat: String,
- disabled: Boolean,
- size: String,
- popperClass: String,
- predefine: Array
- },
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- directives: { Clickoutside: clickoutside_default.a },
- computed: {
- displayedColor: function displayedColor() {
- if (!this.value && !this.showPanelColor) {
- return 'transparent';
- }
- return this.displayedRgb(this.color, this.showAlpha);
- },
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- colorSize: function colorSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- colorDisabled: function colorDisabled() {
- return this.disabled || (this.elForm || {}).disabled;
- }
- },
- watch: {
- value: function value(val) {
- if (!val) {
- this.showPanelColor = false;
- } else if (val && val !== this.color.value) {
- this.color.fromString(val);
- }
- },
- color: {
- deep: true,
- handler: function handler() {
- this.showPanelColor = true;
- }
- },
- displayedColor: function displayedColor(val) {
- if (!this.showPicker) return;
- var currentValueColor = new src_color({
- enableAlpha: this.showAlpha,
- format: this.colorFormat
- });
- currentValueColor.fromString(this.value);
- var currentValueColorRgb = this.displayedRgb(currentValueColor, this.showAlpha);
- if (val !== currentValueColorRgb) {
- this.$emit('active-change', val);
- }
- }
- },
- methods: {
- handleTrigger: function handleTrigger() {
- if (this.colorDisabled) return;
- this.showPicker = !this.showPicker;
- },
- confirmValue: function confirmValue() {
- var value = this.color.value;
- this.$emit('input', value);
- this.$emit('change', value);
- this.dispatch('ElFormItem', 'el.form.change', value);
- this.showPicker = false;
- },
- clearValue: function clearValue() {
- this.$emit('input', null);
- this.$emit('change', null);
- if (this.value !== null) {
- this.dispatch('ElFormItem', 'el.form.change', null);
- }
- this.showPanelColor = false;
- this.showPicker = false;
- this.resetColor();
- },
- hide: function hide() {
- this.showPicker = false;
- this.resetColor();
- },
- resetColor: function resetColor() {
- var _this = this;
- this.$nextTick(function (_) {
- if (_this.value) {
- _this.color.fromString(_this.value);
- } else {
- _this.showPanelColor = false;
- }
- });
- },
- displayedRgb: function displayedRgb(color, showAlpha) {
- if (!(color instanceof src_color)) {
- throw Error('color should be instance of Color Class');
- }
- var _color$toRgb = color.toRgb(),
- r = _color$toRgb.r,
- g = _color$toRgb.g,
- b = _color$toRgb.b;
- return showAlpha ? 'rgba(' + r + ', ' + g + ', ' + b + ', ' + color.get('alpha') / 100 + ')' : 'rgb(' + r + ', ' + g + ', ' + b + ')';
- }
- },
- mounted: function mounted() {
- var value = this.value;
- if (value) {
- this.color.fromString(value);
- }
- this.popperElm = this.$refs.dropdown.$el;
- },
- data: function data() {
- var color = new src_color({
- enableAlpha: this.showAlpha,
- format: this.colorFormat
- });
- return {
- color: color,
- showPicker: false,
- showPanelColor: false
- };
- },
- components: {
- PickerDropdown: picker_dropdown
- }
- });
- // CONCATENATED MODULE: ./packages/color-picker/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_color_picker_src_mainvue_type_script_lang_js_ = (color_picker_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/color-picker/src/main.vue
- /* normalize component */
- var color_picker_src_main_component = normalizeComponent(
- packages_color_picker_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_55c8ade7_render,
- mainvue_type_template_id_55c8ade7_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var color_picker_src_main_api; }
- color_picker_src_main_component.options.__file = "packages/color-picker/src/main.vue"
- /* harmony default export */ var color_picker_src_main = (color_picker_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/color-picker/index.js
- /* istanbul ignore next */
- color_picker_src_main.install = function (Vue) {
- Vue.component(color_picker_src_main.name, color_picker_src_main);
- };
- /* harmony default export */ var color_picker = (color_picker_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/transfer/src/main.vue?vue&type=template&id=5c654dd8&
- var mainvue_type_template_id_5c654dd8_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- { staticClass: "el-transfer" },
- [
- _c(
- "transfer-panel",
- _vm._b(
- {
- ref: "leftPanel",
- attrs: {
- data: _vm.sourceData,
- title: _vm.titles[0] || _vm.t("el.transfer.titles.0"),
- "default-checked": _vm.leftDefaultChecked,
- placeholder:
- _vm.filterPlaceholder || _vm.t("el.transfer.filterPlaceholder")
- },
- on: { "checked-change": _vm.onSourceCheckedChange }
- },
- "transfer-panel",
- _vm.$props,
- false
- ),
- [_vm._t("left-footer")],
- 2
- ),
- _c(
- "div",
- { staticClass: "el-transfer__buttons" },
- [
- _c(
- "el-button",
- {
- class: [
- "el-transfer__button",
- _vm.hasButtonTexts ? "is-with-texts" : ""
- ],
- attrs: {
- type: "primary",
- disabled: _vm.rightChecked.length === 0
- },
- nativeOn: {
- click: function($event) {
- return _vm.addToLeft($event)
- }
- }
- },
- [
- _c("i", { staticClass: "el-icon-arrow-left" }),
- _vm.buttonTexts[0] !== undefined
- ? _c("span", [_vm._v(_vm._s(_vm.buttonTexts[0]))])
- : _vm._e()
- ]
- ),
- _c(
- "el-button",
- {
- class: [
- "el-transfer__button",
- _vm.hasButtonTexts ? "is-with-texts" : ""
- ],
- attrs: {
- type: "primary",
- disabled: _vm.leftChecked.length === 0
- },
- nativeOn: {
- click: function($event) {
- return _vm.addToRight($event)
- }
- }
- },
- [
- _vm.buttonTexts[1] !== undefined
- ? _c("span", [_vm._v(_vm._s(_vm.buttonTexts[1]))])
- : _vm._e(),
- _c("i", { staticClass: "el-icon-arrow-right" })
- ]
- )
- ],
- 1
- ),
- _c(
- "transfer-panel",
- _vm._b(
- {
- ref: "rightPanel",
- attrs: {
- data: _vm.targetData,
- title: _vm.titles[1] || _vm.t("el.transfer.titles.1"),
- "default-checked": _vm.rightDefaultChecked,
- placeholder:
- _vm.filterPlaceholder || _vm.t("el.transfer.filterPlaceholder")
- },
- on: { "checked-change": _vm.onTargetCheckedChange }
- },
- "transfer-panel",
- _vm.$props,
- false
- ),
- [_vm._t("right-footer")],
- 2
- )
- ],
- 1
- )
- }
- var mainvue_type_template_id_5c654dd8_staticRenderFns = []
- mainvue_type_template_id_5c654dd8_render._withStripped = true
- // CONCATENATED MODULE: ./packages/transfer/src/main.vue?vue&type=template&id=5c654dd8&
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/transfer/src/transfer-panel.vue?vue&type=template&id=2ddab8bd&
- var transfer_panelvue_type_template_id_2ddab8bd_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("div", { staticClass: "el-transfer-panel" }, [
- _c(
- "p",
- { staticClass: "el-transfer-panel__header" },
- [
- _c(
- "el-checkbox",
- {
- attrs: { indeterminate: _vm.isIndeterminate },
- on: { change: _vm.handleAllCheckedChange },
- model: {
- value: _vm.allChecked,
- callback: function($$v) {
- _vm.allChecked = $$v
- },
- expression: "allChecked"
- }
- },
- [
- _vm._v("\n " + _vm._s(_vm.title) + "\n "),
- _c("span", [_vm._v(_vm._s(_vm.checkedSummary))])
- ]
- )
- ],
- 1
- ),
- _c(
- "div",
- {
- class: [
- "el-transfer-panel__body",
- _vm.hasFooter ? "is-with-footer" : ""
- ]
- },
- [
- _vm.filterable
- ? _c(
- "el-input",
- {
- staticClass: "el-transfer-panel__filter",
- attrs: { size: "small", placeholder: _vm.placeholder },
- nativeOn: {
- mouseenter: function($event) {
- _vm.inputHover = true
- },
- mouseleave: function($event) {
- _vm.inputHover = false
- }
- },
- model: {
- value: _vm.query,
- callback: function($$v) {
- _vm.query = $$v
- },
- expression: "query"
- }
- },
- [
- _c("i", {
- class: ["el-input__icon", "el-icon-" + _vm.inputIcon],
- attrs: { slot: "prefix" },
- on: { click: _vm.clearQuery },
- slot: "prefix"
- })
- ]
- )
- : _vm._e(),
- _c(
- "el-checkbox-group",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: !_vm.hasNoMatch && _vm.data.length > 0,
- expression: "!hasNoMatch && data.length > 0"
- }
- ],
- staticClass: "el-transfer-panel__list",
- class: { "is-filterable": _vm.filterable },
- model: {
- value: _vm.checked,
- callback: function($$v) {
- _vm.checked = $$v
- },
- expression: "checked"
- }
- },
- _vm._l(_vm.filteredData, function(item) {
- return _c(
- "el-checkbox",
- {
- key: item[_vm.keyProp],
- staticClass: "el-transfer-panel__item",
- attrs: {
- label: item[_vm.keyProp],
- disabled: item[_vm.disabledProp]
- }
- },
- [_c("option-content", { attrs: { option: item } })],
- 1
- )
- }),
- 1
- ),
- _c(
- "p",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.hasNoMatch,
- expression: "hasNoMatch"
- }
- ],
- staticClass: "el-transfer-panel__empty"
- },
- [_vm._v(_vm._s(_vm.t("el.transfer.noMatch")))]
- ),
- _c(
- "p",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.data.length === 0 && !_vm.hasNoMatch,
- expression: "data.length === 0 && !hasNoMatch"
- }
- ],
- staticClass: "el-transfer-panel__empty"
- },
- [_vm._v(_vm._s(_vm.t("el.transfer.noData")))]
- )
- ],
- 1
- ),
- _vm.hasFooter
- ? _c(
- "p",
- { staticClass: "el-transfer-panel__footer" },
- [_vm._t("default")],
- 2
- )
- : _vm._e()
- ])
- }
- var transfer_panelvue_type_template_id_2ddab8bd_staticRenderFns = []
- transfer_panelvue_type_template_id_2ddab8bd_render._withStripped = true
- // CONCATENATED MODULE: ./packages/transfer/src/transfer-panel.vue?vue&type=template&id=2ddab8bd&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/transfer/src/transfer-panel.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var transfer_panelvue_type_script_lang_js_ = ({
- mixins: [locale_default.a],
- name: 'ElTransferPanel',
- componentName: 'ElTransferPanel',
- components: {
- ElCheckboxGroup: checkbox_group_default.a,
- ElCheckbox: checkbox_default.a,
- ElInput: input_default.a,
- OptionContent: {
- props: {
- option: Object
- },
- render: function render(h) {
- var getParent = function getParent(vm) {
- if (vm.$options.componentName === 'ElTransferPanel') {
- return vm;
- } else if (vm.$parent) {
- return getParent(vm.$parent);
- } else {
- return vm;
- }
- };
- var panel = getParent(this);
- var transfer = panel.$parent || panel;
- return panel.renderContent ? panel.renderContent(h, this.option) : transfer.$scopedSlots.default ? transfer.$scopedSlots.default({ option: this.option }) : h('span', [this.option[panel.labelProp] || this.option[panel.keyProp]]);
- }
- }
- },
- props: {
- data: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- renderContent: Function,
- placeholder: String,
- title: String,
- filterable: Boolean,
- format: Object,
- filterMethod: Function,
- defaultChecked: Array,
- props: Object
- },
- data: function data() {
- return {
- checked: [],
- allChecked: false,
- query: '',
- inputHover: false,
- checkChangeByUser: true
- };
- },
- watch: {
- checked: function checked(val, oldVal) {
- this.updateAllChecked();
- if (this.checkChangeByUser) {
- var movedKeys = val.concat(oldVal).filter(function (v) {
- return val.indexOf(v) === -1 || oldVal.indexOf(v) === -1;
- });
- this.$emit('checked-change', val, movedKeys);
- } else {
- this.$emit('checked-change', val);
- this.checkChangeByUser = true;
- }
- },
- data: function data() {
- var _this = this;
- var checked = [];
- var filteredDataKeys = this.filteredData.map(function (item) {
- return item[_this.keyProp];
- });
- this.checked.forEach(function (item) {
- if (filteredDataKeys.indexOf(item) > -1) {
- checked.push(item);
- }
- });
- this.checkChangeByUser = false;
- this.checked = checked;
- },
- checkableData: function checkableData() {
- this.updateAllChecked();
- },
- defaultChecked: {
- immediate: true,
- handler: function handler(val, oldVal) {
- var _this2 = this;
- if (oldVal && val.length === oldVal.length && val.every(function (item) {
- return oldVal.indexOf(item) > -1;
- })) return;
- var checked = [];
- var checkableDataKeys = this.checkableData.map(function (item) {
- return item[_this2.keyProp];
- });
- val.forEach(function (item) {
- if (checkableDataKeys.indexOf(item) > -1) {
- checked.push(item);
- }
- });
- this.checkChangeByUser = false;
- this.checked = checked;
- }
- }
- },
- computed: {
- filteredData: function filteredData() {
- var _this3 = this;
- return this.data.filter(function (item) {
- if (typeof _this3.filterMethod === 'function') {
- return _this3.filterMethod(_this3.query, item);
- } else {
- var label = item[_this3.labelProp] || item[_this3.keyProp].toString();
- return label.toLowerCase().indexOf(_this3.query.toLowerCase()) > -1;
- }
- });
- },
- checkableData: function checkableData() {
- var _this4 = this;
- return this.filteredData.filter(function (item) {
- return !item[_this4.disabledProp];
- });
- },
- checkedSummary: function checkedSummary() {
- var checkedLength = this.checked.length;
- var dataLength = this.data.length;
- var _format = this.format,
- noChecked = _format.noChecked,
- hasChecked = _format.hasChecked;
- if (noChecked && hasChecked) {
- return checkedLength > 0 ? hasChecked.replace(/\${checked}/g, checkedLength).replace(/\${total}/g, dataLength) : noChecked.replace(/\${total}/g, dataLength);
- } else {
- return checkedLength + '/' + dataLength;
- }
- },
- isIndeterminate: function isIndeterminate() {
- var checkedLength = this.checked.length;
- return checkedLength > 0 && checkedLength < this.checkableData.length;
- },
- hasNoMatch: function hasNoMatch() {
- return this.query.length > 0 && this.filteredData.length === 0;
- },
- inputIcon: function inputIcon() {
- return this.query.length > 0 && this.inputHover ? 'circle-close' : 'search';
- },
- labelProp: function labelProp() {
- return this.props.label || 'label';
- },
- keyProp: function keyProp() {
- return this.props.key || 'key';
- },
- disabledProp: function disabledProp() {
- return this.props.disabled || 'disabled';
- },
- hasFooter: function hasFooter() {
- return !!this.$slots.default;
- }
- },
- methods: {
- updateAllChecked: function updateAllChecked() {
- var _this5 = this;
- var checkableDataKeys = this.checkableData.map(function (item) {
- return item[_this5.keyProp];
- });
- this.allChecked = checkableDataKeys.length > 0 && checkableDataKeys.every(function (item) {
- return _this5.checked.indexOf(item) > -1;
- });
- },
- handleAllCheckedChange: function handleAllCheckedChange(value) {
- var _this6 = this;
- this.checked = value ? this.checkableData.map(function (item) {
- return item[_this6.keyProp];
- }) : [];
- },
- clearQuery: function clearQuery() {
- if (this.inputIcon === 'circle-close') {
- this.query = '';
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/transfer/src/transfer-panel.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_transfer_panelvue_type_script_lang_js_ = (transfer_panelvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/transfer/src/transfer-panel.vue
- /* normalize component */
- var transfer_panel_component = normalizeComponent(
- src_transfer_panelvue_type_script_lang_js_,
- transfer_panelvue_type_template_id_2ddab8bd_render,
- transfer_panelvue_type_template_id_2ddab8bd_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var transfer_panel_api; }
- transfer_panel_component.options.__file = "packages/transfer/src/transfer-panel.vue"
- /* harmony default export */ var transfer_panel = (transfer_panel_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/transfer/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var transfer_src_mainvue_type_script_lang_js_ = ({
- name: 'ElTransfer',
- mixins: [emitter_default.a, locale_default.a, migrating_default.a],
- components: {
- TransferPanel: transfer_panel,
- ElButton: button_default.a
- },
- props: {
- data: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- titles: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- buttonTexts: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- filterPlaceholder: {
- type: String,
- default: ''
- },
- filterMethod: Function,
- leftDefaultChecked: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- rightDefaultChecked: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- renderContent: Function,
- value: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- format: {
- type: Object,
- default: function _default() {
- return {};
- }
- },
- filterable: Boolean,
- props: {
- type: Object,
- default: function _default() {
- return {
- label: 'label',
- key: 'key',
- disabled: 'disabled'
- };
- }
- },
- targetOrder: {
- type: String,
- default: 'original'
- }
- },
- data: function data() {
- return {
- leftChecked: [],
- rightChecked: []
- };
- },
- computed: {
- dataObj: function dataObj() {
- var key = this.props.key;
- return this.data.reduce(function (o, cur) {
- return (o[cur[key]] = cur) && o;
- }, {});
- },
- sourceData: function sourceData() {
- var _this = this;
- return this.data.filter(function (item) {
- return _this.value.indexOf(item[_this.props.key]) === -1;
- });
- },
- targetData: function targetData() {
- var _this2 = this;
- if (this.targetOrder === 'original') {
- return this.data.filter(function (item) {
- return _this2.value.indexOf(item[_this2.props.key]) > -1;
- });
- } else {
- return this.value.reduce(function (arr, cur) {
- var val = _this2.dataObj[cur];
- if (val) {
- arr.push(val);
- }
- return arr;
- }, []);
- }
- },
- hasButtonTexts: function hasButtonTexts() {
- return this.buttonTexts.length === 2;
- }
- },
- watch: {
- value: function value(val) {
- this.dispatch('ElFormItem', 'el.form.change', val);
- }
- },
- methods: {
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'footer-format': 'footer-format is renamed to format.'
- }
- };
- },
- onSourceCheckedChange: function onSourceCheckedChange(val, movedKeys) {
- this.leftChecked = val;
- if (movedKeys === undefined) return;
- this.$emit('left-check-change', val, movedKeys);
- },
- onTargetCheckedChange: function onTargetCheckedChange(val, movedKeys) {
- this.rightChecked = val;
- if (movedKeys === undefined) return;
- this.$emit('right-check-change', val, movedKeys);
- },
- addToLeft: function addToLeft() {
- var currentValue = this.value.slice();
- this.rightChecked.forEach(function (item) {
- var index = currentValue.indexOf(item);
- if (index > -1) {
- currentValue.splice(index, 1);
- }
- });
- this.$emit('input', currentValue);
- this.$emit('change', currentValue, 'left', this.rightChecked);
- },
- addToRight: function addToRight() {
- var _this3 = this;
- var currentValue = this.value.slice();
- var itemsToBeMoved = [];
- var key = this.props.key;
- this.data.forEach(function (item) {
- var itemKey = item[key];
- if (_this3.leftChecked.indexOf(itemKey) > -1 && _this3.value.indexOf(itemKey) === -1) {
- itemsToBeMoved.push(itemKey);
- }
- });
- currentValue = this.targetOrder === 'unshift' ? itemsToBeMoved.concat(currentValue) : currentValue.concat(itemsToBeMoved);
- this.$emit('input', currentValue);
- this.$emit('change', currentValue, 'right', this.leftChecked);
- },
- clearQuery: function clearQuery(which) {
- if (which === 'left') {
- this.$refs.leftPanel.query = '';
- } else if (which === 'right') {
- this.$refs.rightPanel.query = '';
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/transfer/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_transfer_src_mainvue_type_script_lang_js_ = (transfer_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/transfer/src/main.vue
- /* normalize component */
- var transfer_src_main_component = normalizeComponent(
- packages_transfer_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_5c654dd8_render,
- mainvue_type_template_id_5c654dd8_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var transfer_src_main_api; }
- transfer_src_main_component.options.__file = "packages/transfer/src/main.vue"
- /* harmony default export */ var transfer_src_main = (transfer_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/transfer/index.js
- /* istanbul ignore next */
- transfer_src_main.install = function (Vue) {
- Vue.component(transfer_src_main.name, transfer_src_main);
- };
- /* harmony default export */ var transfer = (transfer_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/container/src/main.vue?vue&type=template&id=5bf181d4&
- var mainvue_type_template_id_5bf181d4_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "section",
- { staticClass: "el-container", class: { "is-vertical": _vm.isVertical } },
- [_vm._t("default")],
- 2
- )
- }
- var mainvue_type_template_id_5bf181d4_staticRenderFns = []
- mainvue_type_template_id_5bf181d4_render._withStripped = true
- // CONCATENATED MODULE: ./packages/container/src/main.vue?vue&type=template&id=5bf181d4&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/container/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var container_src_mainvue_type_script_lang_js_ = ({
- name: 'ElContainer',
- componentName: 'ElContainer',
- props: {
- direction: String
- },
- computed: {
- isVertical: function isVertical() {
- if (this.direction === 'vertical') {
- return true;
- } else if (this.direction === 'horizontal') {
- return false;
- }
- return this.$slots && this.$slots.default ? this.$slots.default.some(function (vnode) {
- var tag = vnode.componentOptions && vnode.componentOptions.tag;
- return tag === 'el-header' || tag === 'el-footer';
- }) : false;
- }
- }
- });
- // CONCATENATED MODULE: ./packages/container/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_container_src_mainvue_type_script_lang_js_ = (container_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/container/src/main.vue
- /* normalize component */
- var container_src_main_component = normalizeComponent(
- packages_container_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_5bf181d4_render,
- mainvue_type_template_id_5bf181d4_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var container_src_main_api; }
- container_src_main_component.options.__file = "packages/container/src/main.vue"
- /* harmony default export */ var container_src_main = (container_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/container/index.js
- /* istanbul ignore next */
- container_src_main.install = function (Vue) {
- Vue.component(container_src_main.name, container_src_main);
- };
- /* harmony default export */ var packages_container = (container_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/header/src/main.vue?vue&type=template&id=2b296ab2&
- var mainvue_type_template_id_2b296ab2_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "header",
- { staticClass: "el-header", style: { height: _vm.height } },
- [_vm._t("default")],
- 2
- )
- }
- var mainvue_type_template_id_2b296ab2_staticRenderFns = []
- mainvue_type_template_id_2b296ab2_render._withStripped = true
- // CONCATENATED MODULE: ./packages/header/src/main.vue?vue&type=template&id=2b296ab2&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/header/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var header_src_mainvue_type_script_lang_js_ = ({
- name: 'ElHeader',
- componentName: 'ElHeader',
- props: {
- height: {
- type: String,
- default: '60px'
- }
- }
- });
- // CONCATENATED MODULE: ./packages/header/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_header_src_mainvue_type_script_lang_js_ = (header_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/header/src/main.vue
- /* normalize component */
- var header_src_main_component = normalizeComponent(
- packages_header_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_2b296ab2_render,
- mainvue_type_template_id_2b296ab2_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var header_src_main_api; }
- header_src_main_component.options.__file = "packages/header/src/main.vue"
- /* harmony default export */ var header_src_main = (header_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/header/index.js
- /* istanbul ignore next */
- header_src_main.install = function (Vue) {
- Vue.component(header_src_main.name, header_src_main);
- };
- /* harmony default export */ var header = (header_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/aside/src/main.vue?vue&type=template&id=03411dbf&
- var mainvue_type_template_id_03411dbf_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "aside",
- { staticClass: "el-aside", style: { width: _vm.width } },
- [_vm._t("default")],
- 2
- )
- }
- var mainvue_type_template_id_03411dbf_staticRenderFns = []
- mainvue_type_template_id_03411dbf_render._withStripped = true
- // CONCATENATED MODULE: ./packages/aside/src/main.vue?vue&type=template&id=03411dbf&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/aside/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var aside_src_mainvue_type_script_lang_js_ = ({
- name: 'ElAside',
- componentName: 'ElAside',
- props: {
- width: {
- type: String,
- default: '300px'
- }
- }
- });
- // CONCATENATED MODULE: ./packages/aside/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_aside_src_mainvue_type_script_lang_js_ = (aside_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/aside/src/main.vue
- /* normalize component */
- var aside_src_main_component = normalizeComponent(
- packages_aside_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_03411dbf_render,
- mainvue_type_template_id_03411dbf_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var aside_src_main_api; }
- aside_src_main_component.options.__file = "packages/aside/src/main.vue"
- /* harmony default export */ var aside_src_main = (aside_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/aside/index.js
- /* istanbul ignore next */
- aside_src_main.install = function (Vue) {
- Vue.component(aside_src_main.name, aside_src_main);
- };
- /* harmony default export */ var aside = (aside_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/main/src/main.vue?vue&type=template&id=2a3a7406&
- var mainvue_type_template_id_2a3a7406_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("main", { staticClass: "el-main" }, [_vm._t("default")], 2)
- }
- var mainvue_type_template_id_2a3a7406_staticRenderFns = []
- mainvue_type_template_id_2a3a7406_render._withStripped = true
- // CONCATENATED MODULE: ./packages/main/src/main.vue?vue&type=template&id=2a3a7406&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/main/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var main_src_mainvue_type_script_lang_js_ = ({
- name: 'ElMain',
- componentName: 'ElMain'
- });
- // CONCATENATED MODULE: ./packages/main/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_main_src_mainvue_type_script_lang_js_ = (main_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/main/src/main.vue
- /* normalize component */
- var main_src_main_component = normalizeComponent(
- packages_main_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_2a3a7406_render,
- mainvue_type_template_id_2a3a7406_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var main_src_main_api; }
- main_src_main_component.options.__file = "packages/main/src/main.vue"
- /* harmony default export */ var main_src_main = (main_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/main/index.js
- /* istanbul ignore next */
- main_src_main.install = function (Vue) {
- Vue.component(main_src_main.name, main_src_main);
- };
- /* harmony default export */ var packages_main = (main_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/footer/src/main.vue?vue&type=template&id=80210338&
- var mainvue_type_template_id_80210338_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "footer",
- { staticClass: "el-footer", style: { height: _vm.height } },
- [_vm._t("default")],
- 2
- )
- }
- var mainvue_type_template_id_80210338_staticRenderFns = []
- mainvue_type_template_id_80210338_render._withStripped = true
- // CONCATENATED MODULE: ./packages/footer/src/main.vue?vue&type=template&id=80210338&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/footer/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var footer_src_mainvue_type_script_lang_js_ = ({
- name: 'ElFooter',
- componentName: 'ElFooter',
- props: {
- height: {
- type: String,
- default: '60px'
- }
- }
- });
- // CONCATENATED MODULE: ./packages/footer/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_footer_src_mainvue_type_script_lang_js_ = (footer_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/footer/src/main.vue
- /* normalize component */
- var footer_src_main_component = normalizeComponent(
- packages_footer_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_80210338_render,
- mainvue_type_template_id_80210338_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var footer_src_main_api; }
- footer_src_main_component.options.__file = "packages/footer/src/main.vue"
- /* harmony default export */ var footer_src_main = (footer_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/footer/index.js
- /* istanbul ignore next */
- footer_src_main.install = function (Vue) {
- Vue.component(footer_src_main.name, footer_src_main);
- };
- /* harmony default export */ var footer = (footer_src_main);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/timeline/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var timeline_src_mainvue_type_script_lang_js_ = ({
- name: 'ElTimeline',
- props: {
- reverse: {
- type: Boolean,
- default: false
- }
- },
- provide: function provide() {
- return {
- timeline: this
- };
- },
- render: function render() {
- var h = arguments[0];
- var reverse = this.reverse;
- var classes = {
- 'el-timeline': true,
- 'is-reverse': reverse
- };
- var slots = this.$slots.default || [];
- if (reverse) {
- slots = slots.reverse();
- }
- return h(
- 'ul',
- { 'class': classes },
- [slots]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/timeline/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_timeline_src_mainvue_type_script_lang_js_ = (timeline_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/timeline/src/main.vue
- var main_render, main_staticRenderFns
- /* normalize component */
- var timeline_src_main_component = normalizeComponent(
- packages_timeline_src_mainvue_type_script_lang_js_,
- main_render,
- main_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var timeline_src_main_api; }
- timeline_src_main_component.options.__file = "packages/timeline/src/main.vue"
- /* harmony default export */ var timeline_src_main = (timeline_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/timeline/index.js
- /* istanbul ignore next */
- timeline_src_main.install = function (Vue) {
- Vue.component(timeline_src_main.name, timeline_src_main);
- };
- /* harmony default export */ var timeline = (timeline_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/timeline/src/item.vue?vue&type=template&id=61a69e50&
- var itemvue_type_template_id_61a69e50_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("li", { staticClass: "el-timeline-item" }, [
- _c("div", { staticClass: "el-timeline-item__tail" }),
- !_vm.$slots.dot
- ? _c(
- "div",
- {
- staticClass: "el-timeline-item__node",
- class: [
- "el-timeline-item__node--" + (_vm.size || ""),
- "el-timeline-item__node--" + (_vm.type || "")
- ],
- style: {
- backgroundColor: _vm.color
- }
- },
- [
- _vm.icon
- ? _c("i", {
- staticClass: "el-timeline-item__icon",
- class: _vm.icon
- })
- : _vm._e()
- ]
- )
- : _vm._e(),
- _vm.$slots.dot
- ? _c("div", { staticClass: "el-timeline-item__dot" }, [_vm._t("dot")], 2)
- : _vm._e(),
- _c("div", { staticClass: "el-timeline-item__wrapper" }, [
- !_vm.hideTimestamp && _vm.placement === "top"
- ? _c("div", { staticClass: "el-timeline-item__timestamp is-top" }, [
- _vm._v("\n " + _vm._s(_vm.timestamp) + "\n ")
- ])
- : _vm._e(),
- _c(
- "div",
- { staticClass: "el-timeline-item__content" },
- [_vm._t("default")],
- 2
- ),
- !_vm.hideTimestamp && _vm.placement === "bottom"
- ? _c("div", { staticClass: "el-timeline-item__timestamp is-bottom" }, [
- _vm._v("\n " + _vm._s(_vm.timestamp) + "\n ")
- ])
- : _vm._e()
- ])
- ])
- }
- var itemvue_type_template_id_61a69e50_staticRenderFns = []
- itemvue_type_template_id_61a69e50_render._withStripped = true
- // CONCATENATED MODULE: ./packages/timeline/src/item.vue?vue&type=template&id=61a69e50&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/timeline/src/item.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var timeline_src_itemvue_type_script_lang_js_ = ({
- name: 'ElTimelineItem',
- inject: ['timeline'],
- props: {
- timestamp: String,
- hideTimestamp: {
- type: Boolean,
- default: false
- },
- placement: {
- type: String,
- default: 'bottom'
- },
- type: String,
- color: String,
- size: {
- type: String,
- default: 'normal'
- },
- icon: String
- }
- });
- // CONCATENATED MODULE: ./packages/timeline/src/item.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_timeline_src_itemvue_type_script_lang_js_ = (timeline_src_itemvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/timeline/src/item.vue
- /* normalize component */
- var src_item_component = normalizeComponent(
- packages_timeline_src_itemvue_type_script_lang_js_,
- itemvue_type_template_id_61a69e50_render,
- itemvue_type_template_id_61a69e50_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var src_item_api; }
- src_item_component.options.__file = "packages/timeline/src/item.vue"
- /* harmony default export */ var timeline_src_item = (src_item_component.exports);
- // CONCATENATED MODULE: ./packages/timeline-item/index.js
- /* istanbul ignore next */
- timeline_src_item.install = function (Vue) {
- Vue.component(timeline_src_item.name, timeline_src_item);
- };
- /* harmony default export */ var timeline_item = (timeline_src_item);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/link/src/main.vue?vue&type=template&id=01cf3b65&
- var mainvue_type_template_id_01cf3b65_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "a",
- _vm._b(
- {
- class: [
- "el-link",
- _vm.type ? "el-link--" + _vm.type : "",
- _vm.disabled && "is-disabled",
- _vm.underline && !_vm.disabled && "is-underline"
- ],
- attrs: { href: _vm.disabled ? null : _vm.href },
- on: { click: _vm.handleClick }
- },
- "a",
- _vm.$attrs,
- false
- ),
- [
- _vm.icon ? _c("i", { class: _vm.icon }) : _vm._e(),
- _vm.$slots.default
- ? _c("span", { staticClass: "el-link--inner" }, [_vm._t("default")], 2)
- : _vm._e(),
- _vm.$slots.icon ? [_vm.$slots.icon ? _vm._t("icon") : _vm._e()] : _vm._e()
- ],
- 2
- )
- }
- var mainvue_type_template_id_01cf3b65_staticRenderFns = []
- mainvue_type_template_id_01cf3b65_render._withStripped = true
- // CONCATENATED MODULE: ./packages/link/src/main.vue?vue&type=template&id=01cf3b65&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/link/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var link_src_mainvue_type_script_lang_js_ = ({
- name: 'ElLink',
- props: {
- type: {
- type: String,
- default: 'default'
- },
- underline: {
- type: Boolean,
- default: true
- },
- disabled: Boolean,
- href: String,
- icon: String
- },
- methods: {
- handleClick: function handleClick(event) {
- if (!this.disabled) {
- if (!this.href) {
- this.$emit('click', event);
- }
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/link/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_link_src_mainvue_type_script_lang_js_ = (link_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/link/src/main.vue
- /* normalize component */
- var link_src_main_component = normalizeComponent(
- packages_link_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_01cf3b65_render,
- mainvue_type_template_id_01cf3b65_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var link_src_main_api; }
- link_src_main_component.options.__file = "packages/link/src/main.vue"
- /* harmony default export */ var link_src_main = (link_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/link/index.js
- /* istanbul ignore next */
- link_src_main.install = function (Vue) {
- Vue.component(link_src_main.name, link_src_main);
- };
- /* harmony default export */ var packages_link = (link_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/divider/src/main.vue?vue&type=template&id=7fa02a7e&functional=true&
- var mainvue_type_template_id_7fa02a7e_functional_true_render = function(_h, _vm) {
- var _c = _vm._c
- return _c(
- "div",
- _vm._g(
- _vm._b(
- {
- class: [
- _vm.data.staticClass,
- "el-divider",
- "el-divider--" + _vm.props.direction
- ]
- },
- "div",
- _vm.data.attrs,
- false
- ),
- _vm.listeners
- ),
- [
- _vm.slots().default && _vm.props.direction !== "vertical"
- ? _c(
- "div",
- { class: ["el-divider__text", "is-" + _vm.props.contentPosition] },
- [_vm._t("default")],
- 2
- )
- : _vm._e()
- ]
- )
- }
- var mainvue_type_template_id_7fa02a7e_functional_true_staticRenderFns = []
- mainvue_type_template_id_7fa02a7e_functional_true_render._withStripped = true
- // CONCATENATED MODULE: ./packages/divider/src/main.vue?vue&type=template&id=7fa02a7e&functional=true&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/divider/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var divider_src_mainvue_type_script_lang_js_ = ({
- name: 'ElDivider',
- props: {
- direction: {
- type: String,
- default: 'horizontal',
- validator: function validator(val) {
- return ['horizontal', 'vertical'].indexOf(val) !== -1;
- }
- },
- contentPosition: {
- type: String,
- default: 'center',
- validator: function validator(val) {
- return ['left', 'center', 'right'].indexOf(val) !== -1;
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/divider/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_divider_src_mainvue_type_script_lang_js_ = (divider_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/divider/src/main.vue
- /* normalize component */
- var divider_src_main_component = normalizeComponent(
- packages_divider_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_7fa02a7e_functional_true_render,
- mainvue_type_template_id_7fa02a7e_functional_true_staticRenderFns,
- true,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var divider_src_main_api; }
- divider_src_main_component.options.__file = "packages/divider/src/main.vue"
- /* harmony default export */ var divider_src_main = (divider_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/divider/index.js
- /* istanbul ignore next */
- divider_src_main.install = function (Vue) {
- Vue.component(divider_src_main.name, divider_src_main);
- };
- /* harmony default export */ var divider = (divider_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/image/src/main.vue?vue&type=template&id=44d84a7c&
- var mainvue_type_template_id_44d84a7c_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- { staticClass: "el-image" },
- [
- _vm.loading
- ? _vm._t("placeholder", [
- _c("div", { staticClass: "el-image__placeholder" })
- ])
- : _vm.error
- ? _vm._t("error", [
- _c("div", { staticClass: "el-image__error" }, [
- _vm._v(_vm._s(_vm.t("el.image.error")))
- ])
- ])
- : _c(
- "img",
- _vm._g(
- _vm._b(
- {
- staticClass: "el-image__inner",
- class: {
- "el-image__inner--center": _vm.alignCenter,
- "el-image__preview": _vm.preview
- },
- style: _vm.imageStyle,
- attrs: { src: _vm.src },
- on: { click: _vm.clickHandler }
- },
- "img",
- _vm.$attrs,
- false
- ),
- _vm.$listeners
- )
- ),
- _vm.preview
- ? [
- _vm.showViewer
- ? _c("image-viewer", {
- attrs: {
- "z-index": _vm.zIndex,
- "initial-index": _vm.imageIndex,
- "on-close": _vm.closeViewer,
- "url-list": _vm.previewSrcList
- }
- })
- : _vm._e()
- ]
- : _vm._e()
- ],
- 2
- )
- }
- var mainvue_type_template_id_44d84a7c_staticRenderFns = []
- mainvue_type_template_id_44d84a7c_render._withStripped = true
- // CONCATENATED MODULE: ./packages/image/src/main.vue?vue&type=template&id=44d84a7c&
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/image/src/image-viewer.vue?vue&type=template&id=5e73b307&
- var image_viewervue_type_template_id_5e73b307_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("transition", { attrs: { name: "viewer-fade" } }, [
- _c(
- "div",
- {
- ref: "el-image-viewer__wrapper",
- staticClass: "el-image-viewer__wrapper",
- style: { "z-index": _vm.viewerZIndex },
- attrs: { tabindex: "-1" }
- },
- [
- _c("div", {
- staticClass: "el-image-viewer__mask",
- on: {
- click: function($event) {
- if ($event.target !== $event.currentTarget) {
- return null
- }
- return _vm.handleMaskClick($event)
- }
- }
- }),
- _c(
- "span",
- {
- staticClass: "el-image-viewer__btn el-image-viewer__close",
- on: { click: _vm.hide }
- },
- [_c("i", { staticClass: "el-icon-close" })]
- ),
- !_vm.isSingle
- ? [
- _c(
- "span",
- {
- staticClass: "el-image-viewer__btn el-image-viewer__prev",
- class: { "is-disabled": !_vm.infinite && _vm.isFirst },
- on: { click: _vm.prev }
- },
- [_c("i", { staticClass: "el-icon-arrow-left" })]
- ),
- _c(
- "span",
- {
- staticClass: "el-image-viewer__btn el-image-viewer__next",
- class: { "is-disabled": !_vm.infinite && _vm.isLast },
- on: { click: _vm.next }
- },
- [_c("i", { staticClass: "el-icon-arrow-right" })]
- )
- ]
- : _vm._e(),
- _c(
- "div",
- { staticClass: "el-image-viewer__btn el-image-viewer__actions" },
- [
- _c("div", { staticClass: "el-image-viewer__actions__inner" }, [
- _c("i", {
- staticClass: "el-icon-zoom-out",
- on: {
- click: function($event) {
- _vm.handleActions("zoomOut")
- }
- }
- }),
- _c("i", {
- staticClass: "el-icon-zoom-in",
- on: {
- click: function($event) {
- _vm.handleActions("zoomIn")
- }
- }
- }),
- _c("i", { staticClass: "el-image-viewer__actions__divider" }),
- _c("i", { class: _vm.mode.icon, on: { click: _vm.toggleMode } }),
- _c("i", { staticClass: "el-image-viewer__actions__divider" }),
- _c("i", {
- staticClass: "el-icon-refresh-left",
- on: {
- click: function($event) {
- _vm.handleActions("anticlocelise")
- }
- }
- }),
- _c("i", {
- staticClass: "el-icon-refresh-right",
- on: {
- click: function($event) {
- _vm.handleActions("clocelise")
- }
- }
- })
- ])
- ]
- ),
- _c(
- "div",
- { staticClass: "el-image-viewer__canvas" },
- _vm._l(_vm.urlList, function(url, i) {
- return i === _vm.index
- ? _c("img", {
- key: url,
- ref: "img",
- refInFor: true,
- staticClass: "el-image-viewer__img",
- style: _vm.imgStyle,
- attrs: { src: _vm.currentImg },
- on: {
- load: _vm.handleImgLoad,
- error: _vm.handleImgError,
- mousedown: _vm.handleMouseDown
- }
- })
- : _vm._e()
- }),
- 0
- )
- ],
- 2
- )
- ])
- }
- var image_viewervue_type_template_id_5e73b307_staticRenderFns = []
- image_viewervue_type_template_id_5e73b307_render._withStripped = true
- // CONCATENATED MODULE: ./packages/image/src/image-viewer.vue?vue&type=template&id=5e73b307&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/image/src/image-viewer.vue?vue&type=script&lang=js&
- var image_viewervue_type_script_lang_js_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var Mode = {
- CONTAIN: {
- name: 'contain',
- icon: 'el-icon-full-screen'
- },
- ORIGINAL: {
- name: 'original',
- icon: 'el-icon-c-scale-to-original'
- }
- };
- var mousewheelEventName = Object(util_["isFirefox"])() ? 'DOMMouseScroll' : 'mousewheel';
- /* harmony default export */ var image_viewervue_type_script_lang_js_ = ({
- name: 'elImageViewer',
- props: {
- urlList: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- zIndex: {
- type: Number,
- default: 2000
- },
- onSwitch: {
- type: Function,
- default: function _default() {}
- },
- onClose: {
- type: Function,
- default: function _default() {}
- },
- initialIndex: {
- type: Number,
- default: 0
- },
- appendToBody: {
- type: Boolean,
- default: true
- },
- maskClosable: {
- type: Boolean,
- default: true
- }
- },
- data: function data() {
- return {
- index: this.initialIndex,
- isShow: false,
- infinite: true,
- loading: false,
- mode: Mode.CONTAIN,
- transform: {
- scale: 1,
- deg: 0,
- offsetX: 0,
- offsetY: 0,
- enableTransition: false
- }
- };
- },
- computed: {
- isSingle: function isSingle() {
- return this.urlList.length <= 1;
- },
- isFirst: function isFirst() {
- return this.index === 0;
- },
- isLast: function isLast() {
- return this.index === this.urlList.length - 1;
- },
- currentImg: function currentImg() {
- return this.urlList[this.index];
- },
- imgStyle: function imgStyle() {
- var _transform = this.transform,
- scale = _transform.scale,
- deg = _transform.deg,
- offsetX = _transform.offsetX,
- offsetY = _transform.offsetY,
- enableTransition = _transform.enableTransition;
- var style = {
- transform: 'scale(' + scale + ') rotate(' + deg + 'deg)',
- transition: enableTransition ? 'transform .3s' : '',
- 'margin-left': offsetX + 'px',
- 'margin-top': offsetY + 'px'
- };
- if (this.mode === Mode.CONTAIN) {
- style.maxWidth = style.maxHeight = '100%';
- }
- return style;
- },
- viewerZIndex: function viewerZIndex() {
- var nextZIndex = popup_["PopupManager"].nextZIndex();
- return this.zIndex > nextZIndex ? this.zIndex : nextZIndex;
- }
- },
- watch: {
- index: {
- handler: function handler(val) {
- this.reset();
- this.onSwitch(val);
- }
- },
- currentImg: function currentImg(val) {
- var _this = this;
- this.$nextTick(function (_) {
- var $img = _this.$refs.img[0];
- if (!$img.complete) {
- _this.loading = true;
- }
- });
- }
- },
- methods: {
- hide: function hide() {
- this.deviceSupportUninstall();
- this.onClose();
- },
- deviceSupportInstall: function deviceSupportInstall() {
- var _this2 = this;
- this._keyDownHandler = function (e) {
- e.stopPropagation();
- var keyCode = e.keyCode;
- switch (keyCode) {
- // ESC
- case 27:
- _this2.hide();
- break;
- // SPACE
- case 32:
- _this2.toggleMode();
- break;
- // LEFT_ARROW
- case 37:
- _this2.prev();
- break;
- // UP_ARROW
- case 38:
- _this2.handleActions('zoomIn');
- break;
- // RIGHT_ARROW
- case 39:
- _this2.next();
- break;
- // DOWN_ARROW
- case 40:
- _this2.handleActions('zoomOut');
- break;
- }
- };
- this._mouseWheelHandler = Object(util_["rafThrottle"])(function (e) {
- var delta = e.wheelDelta ? e.wheelDelta : -e.detail;
- if (delta > 0) {
- _this2.handleActions('zoomIn', {
- zoomRate: 0.015,
- enableTransition: false
- });
- } else {
- _this2.handleActions('zoomOut', {
- zoomRate: 0.015,
- enableTransition: false
- });
- }
- });
- Object(dom_["on"])(document, 'keydown', this._keyDownHandler);
- Object(dom_["on"])(document, mousewheelEventName, this._mouseWheelHandler);
- },
- deviceSupportUninstall: function deviceSupportUninstall() {
- Object(dom_["off"])(document, 'keydown', this._keyDownHandler);
- Object(dom_["off"])(document, mousewheelEventName, this._mouseWheelHandler);
- this._keyDownHandler = null;
- this._mouseWheelHandler = null;
- },
- handleImgLoad: function handleImgLoad(e) {
- this.loading = false;
- },
- handleImgError: function handleImgError(e) {
- this.loading = false;
- e.target.alt = '加载失败';
- },
- handleMouseDown: function handleMouseDown(e) {
- var _this3 = this;
- if (this.loading || e.button !== 0) return;
- var _transform2 = this.transform,
- offsetX = _transform2.offsetX,
- offsetY = _transform2.offsetY;
- var startX = e.pageX;
- var startY = e.pageY;
- this._dragHandler = Object(util_["rafThrottle"])(function (ev) {
- _this3.transform.offsetX = offsetX + ev.pageX - startX;
- _this3.transform.offsetY = offsetY + ev.pageY - startY;
- });
- Object(dom_["on"])(document, 'mousemove', this._dragHandler);
- Object(dom_["on"])(document, 'mouseup', function (ev) {
- Object(dom_["off"])(document, 'mousemove', _this3._dragHandler);
- });
- e.preventDefault();
- },
- handleMaskClick: function handleMaskClick() {
- if (this.maskClosable) {
- this.hide();
- }
- },
- reset: function reset() {
- this.transform = {
- scale: 1,
- deg: 0,
- offsetX: 0,
- offsetY: 0,
- enableTransition: false
- };
- },
- toggleMode: function toggleMode() {
- if (this.loading) return;
- var modeNames = Object.keys(Mode);
- var modeValues = Object.values(Mode);
- var index = modeValues.indexOf(this.mode);
- var nextIndex = (index + 1) % modeNames.length;
- this.mode = Mode[modeNames[nextIndex]];
- this.reset();
- },
- prev: function prev() {
- if (this.isFirst && !this.infinite) return;
- var len = this.urlList.length;
- this.index = (this.index - 1 + len) % len;
- },
- next: function next() {
- if (this.isLast && !this.infinite) return;
- var len = this.urlList.length;
- this.index = (this.index + 1) % len;
- },
- handleActions: function handleActions(action) {
- var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
- if (this.loading) return;
- var _zoomRate$rotateDeg$e = image_viewervue_type_script_lang_js_extends({
- zoomRate: 0.2,
- rotateDeg: 90,
- enableTransition: true
- }, options),
- zoomRate = _zoomRate$rotateDeg$e.zoomRate,
- rotateDeg = _zoomRate$rotateDeg$e.rotateDeg,
- enableTransition = _zoomRate$rotateDeg$e.enableTransition;
- var transform = this.transform;
- switch (action) {
- case 'zoomOut':
- if (transform.scale > 0.2) {
- transform.scale = parseFloat((transform.scale - zoomRate).toFixed(3));
- }
- break;
- case 'zoomIn':
- transform.scale = parseFloat((transform.scale + zoomRate).toFixed(3));
- break;
- case 'clocelise':
- transform.deg += rotateDeg;
- break;
- case 'anticlocelise':
- transform.deg -= rotateDeg;
- break;
- }
- transform.enableTransition = enableTransition;
- }
- },
- mounted: function mounted() {
- this.deviceSupportInstall();
- if (this.appendToBody) {
- document.body.appendChild(this.$el);
- }
- // add tabindex then wrapper can be focusable via Javascript
- // focus wrapper so arrow key can't cause inner scroll behavior underneath
- this.$refs['el-image-viewer__wrapper'].focus();
- },
- destroyed: function destroyed() {
- // if appendToBody is true, remove DOM node after destroy
- if (this.appendToBody && this.$el && this.$el.parentNode) {
- this.$el.parentNode.removeChild(this.$el);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/image/src/image-viewer.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_image_viewervue_type_script_lang_js_ = (image_viewervue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/image/src/image-viewer.vue
- /* normalize component */
- var image_viewer_component = normalizeComponent(
- src_image_viewervue_type_script_lang_js_,
- image_viewervue_type_template_id_5e73b307_render,
- image_viewervue_type_template_id_5e73b307_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var image_viewer_api; }
- image_viewer_component.options.__file = "packages/image/src/image-viewer.vue"
- /* harmony default export */ var image_viewer = (image_viewer_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/image/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var isSupportObjectFit = function isSupportObjectFit() {
- return document.documentElement.style.objectFit !== undefined;
- };
- var ObjectFit = {
- NONE: 'none',
- CONTAIN: 'contain',
- COVER: 'cover',
- FILL: 'fill',
- SCALE_DOWN: 'scale-down'
- };
- var prevOverflow = '';
- /* harmony default export */ var image_src_mainvue_type_script_lang_js_ = ({
- name: 'ElImage',
- mixins: [locale_default.a],
- inheritAttrs: false,
- components: {
- ImageViewer: image_viewer
- },
- props: {
- src: String,
- fit: String,
- lazy: Boolean,
- scrollContainer: {},
- previewSrcList: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- zIndex: {
- type: Number,
- default: 2000
- },
- initialIndex: Number
- },
- data: function data() {
- return {
- loading: true,
- error: false,
- show: !this.lazy,
- imageWidth: 0,
- imageHeight: 0,
- showViewer: false
- };
- },
- computed: {
- imageStyle: function imageStyle() {
- var fit = this.fit;
- if (!this.$isServer && fit) {
- return isSupportObjectFit() ? { 'object-fit': fit } : this.getImageStyle(fit);
- }
- return {};
- },
- alignCenter: function alignCenter() {
- return !this.$isServer && !isSupportObjectFit() && this.fit !== ObjectFit.FILL;
- },
- preview: function preview() {
- var previewSrcList = this.previewSrcList;
- return Array.isArray(previewSrcList) && previewSrcList.length > 0;
- },
- imageIndex: function imageIndex() {
- var previewIndex = 0;
- var initialIndex = this.initialIndex;
- if (initialIndex >= 0) {
- previewIndex = initialIndex;
- return previewIndex;
- }
- var srcIndex = this.previewSrcList.indexOf(this.src);
- if (srcIndex >= 0) {
- previewIndex = srcIndex;
- return previewIndex;
- }
- return previewIndex;
- }
- },
- watch: {
- src: function src(val) {
- this.show && this.loadImage();
- },
- show: function show(val) {
- val && this.loadImage();
- }
- },
- mounted: function mounted() {
- if (this.lazy) {
- this.addLazyLoadListener();
- } else {
- this.loadImage();
- }
- },
- beforeDestroy: function beforeDestroy() {
- this.lazy && this.removeLazyLoadListener();
- },
- methods: {
- loadImage: function loadImage() {
- var _this = this;
- if (this.$isServer) return;
- // reset status
- this.loading = true;
- this.error = false;
- var img = new Image();
- img.onload = function (e) {
- return _this.handleLoad(e, img);
- };
- img.onerror = this.handleError.bind(this);
- // bind html attrs
- // so it can behave consistently
- Object.keys(this.$attrs).forEach(function (key) {
- var value = _this.$attrs[key];
- img.setAttribute(key, value);
- });
- img.src = this.src;
- },
- handleLoad: function handleLoad(e, img) {
- this.imageWidth = img.width;
- this.imageHeight = img.height;
- this.loading = false;
- this.error = false;
- },
- handleError: function handleError(e) {
- this.loading = false;
- this.error = true;
- this.$emit('error', e);
- },
- handleLazyLoad: function handleLazyLoad() {
- if (Object(dom_["isInContainer"])(this.$el, this._scrollContainer)) {
- this.show = true;
- this.removeLazyLoadListener();
- }
- },
- addLazyLoadListener: function addLazyLoadListener() {
- if (this.$isServer) return;
- var scrollContainer = this.scrollContainer;
- var _scrollContainer = null;
- if (Object(types_["isHtmlElement"])(scrollContainer)) {
- _scrollContainer = scrollContainer;
- } else if (Object(types_["isString"])(scrollContainer)) {
- _scrollContainer = document.querySelector(scrollContainer);
- } else {
- _scrollContainer = Object(dom_["getScrollContainer"])(this.$el);
- }
- if (_scrollContainer) {
- this._scrollContainer = _scrollContainer;
- this._lazyLoadHandler = throttle_default()(200, this.handleLazyLoad);
- Object(dom_["on"])(_scrollContainer, 'scroll', this._lazyLoadHandler);
- this.handleLazyLoad();
- }
- },
- removeLazyLoadListener: function removeLazyLoadListener() {
- var _scrollContainer = this._scrollContainer,
- _lazyLoadHandler = this._lazyLoadHandler;
- if (this.$isServer || !_scrollContainer || !_lazyLoadHandler) return;
- Object(dom_["off"])(_scrollContainer, 'scroll', _lazyLoadHandler);
- this._scrollContainer = null;
- this._lazyLoadHandler = null;
- },
- /**
- * simulate object-fit behavior to compatible with IE11 and other browsers which not support object-fit
- */
- getImageStyle: function getImageStyle(fit) {
- var imageWidth = this.imageWidth,
- imageHeight = this.imageHeight;
- var _$el = this.$el,
- containerWidth = _$el.clientWidth,
- containerHeight = _$el.clientHeight;
- if (!imageWidth || !imageHeight || !containerWidth || !containerHeight) return {};
- var imageAspectRatio = imageWidth / imageHeight;
- var containerAspectRatio = containerWidth / containerHeight;
- if (fit === ObjectFit.SCALE_DOWN) {
- var isSmaller = imageWidth < containerWidth && imageHeight < containerHeight;
- fit = isSmaller ? ObjectFit.NONE : ObjectFit.CONTAIN;
- }
- switch (fit) {
- case ObjectFit.NONE:
- return { width: 'auto', height: 'auto' };
- case ObjectFit.CONTAIN:
- return imageAspectRatio < containerAspectRatio ? { width: 'auto' } : { height: 'auto' };
- case ObjectFit.COVER:
- return imageAspectRatio < containerAspectRatio ? { height: 'auto' } : { width: 'auto' };
- default:
- return {};
- }
- },
- clickHandler: function clickHandler() {
- // don't show viewer when preview is false
- if (!this.preview) {
- return;
- }
- // prevent body scroll
- prevOverflow = document.body.style.overflow;
- document.body.style.overflow = 'hidden';
- this.showViewer = true;
- },
- closeViewer: function closeViewer() {
- document.body.style.overflow = prevOverflow;
- this.showViewer = false;
- }
- }
- });
- // CONCATENATED MODULE: ./packages/image/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_image_src_mainvue_type_script_lang_js_ = (image_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/image/src/main.vue
- /* normalize component */
- var image_src_main_component = normalizeComponent(
- packages_image_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_44d84a7c_render,
- mainvue_type_template_id_44d84a7c_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var image_src_main_api; }
- image_src_main_component.options.__file = "packages/image/src/main.vue"
- /* harmony default export */ var image_src_main = (image_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/image/index.js
- /* istanbul ignore next */
- image_src_main.install = function (Vue) {
- Vue.component(image_src_main.name, image_src_main);
- };
- /* harmony default export */ var packages_image = (image_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/calendar/src/main.vue?vue&type=template&id=6d9756be&
- var mainvue_type_template_id_6d9756be_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("div", { staticClass: "el-calendar" }, [
- _c("div", { staticClass: "el-calendar__header" }, [
- _c("div", { staticClass: "el-calendar__title" }, [
- _vm._v("\n " + _vm._s(_vm.i18nDate) + "\n ")
- ]),
- _vm.validatedRange.length === 0
- ? _c(
- "div",
- { staticClass: "el-calendar__button-group" },
- [
- _c(
- "el-button-group",
- [
- _c(
- "el-button",
- {
- attrs: { type: "plain", size: "mini" },
- on: {
- click: function($event) {
- _vm.selectDate("prev-month")
- }
- }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.t("el.datepicker.prevMonth")) +
- "\n "
- )
- ]
- ),
- _c(
- "el-button",
- {
- attrs: { type: "plain", size: "mini" },
- on: {
- click: function($event) {
- _vm.selectDate("today")
- }
- }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.t("el.datepicker.today")) +
- "\n "
- )
- ]
- ),
- _c(
- "el-button",
- {
- attrs: { type: "plain", size: "mini" },
- on: {
- click: function($event) {
- _vm.selectDate("next-month")
- }
- }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.t("el.datepicker.nextMonth")) +
- "\n "
- )
- ]
- )
- ],
- 1
- )
- ],
- 1
- )
- : _vm._e()
- ]),
- _vm.validatedRange.length === 0
- ? _c(
- "div",
- { key: "no-range", staticClass: "el-calendar__body" },
- [
- _c("date-table", {
- attrs: {
- date: _vm.date,
- "selected-day": _vm.realSelectedDay,
- "first-day-of-week": _vm.realFirstDayOfWeek
- },
- on: { pick: _vm.pickDay }
- })
- ],
- 1
- )
- : _c(
- "div",
- { key: "has-range", staticClass: "el-calendar__body" },
- _vm._l(_vm.validatedRange, function(range, index) {
- return _c("date-table", {
- key: index,
- attrs: {
- date: range[0],
- "selected-day": _vm.realSelectedDay,
- range: range,
- "hide-header": index !== 0,
- "first-day-of-week": _vm.realFirstDayOfWeek
- },
- on: { pick: _vm.pickDay }
- })
- }),
- 1
- )
- ])
- }
- var mainvue_type_template_id_6d9756be_staticRenderFns = []
- mainvue_type_template_id_6d9756be_render._withStripped = true
- // CONCATENATED MODULE: ./packages/calendar/src/main.vue?vue&type=template&id=6d9756be&
- // EXTERNAL MODULE: external "element-ui/lib/utils/date"
- var date_ = __webpack_require__(20);
- var date_default = /*#__PURE__*/__webpack_require__.n(date_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/calendar/src/date-table.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_date_tablevue_type_script_lang_js_ = ({
- props: {
- selectedDay: String, // formated date yyyy-MM-dd
- range: {
- type: Array,
- validator: function validator(val) {
- if (!(val && val.length)) return true;
- var start = val[0],
- end = val[1];
- return Object(date_util_["validateRangeInOneMonth"])(start, end);
- }
- },
- date: Date,
- hideHeader: Boolean,
- firstDayOfWeek: Number
- },
- inject: ['elCalendar'],
- methods: {
- toNestedArr: function toNestedArr(days) {
- return Object(date_util_["range"])(days.length / 7).map(function (_, index) {
- var start = index * 7;
- return days.slice(start, start + 7);
- });
- },
- getFormateDate: function getFormateDate(day, type) {
- if (!day || ['prev', 'current', 'next'].indexOf(type) === -1) {
- throw new Error('invalid day or type');
- }
- var prefix = this.curMonthDatePrefix;
- if (type === 'prev') {
- prefix = this.prevMonthDatePrefix;
- } else if (type === 'next') {
- prefix = this.nextMonthDatePrefix;
- }
- day = ('00' + day).slice(-2);
- return prefix + '-' + day;
- },
- getCellClass: function getCellClass(_ref) {
- var text = _ref.text,
- type = _ref.type;
- var classes = [type];
- if (type === 'current') {
- var date = this.getFormateDate(text, type);
- if (date === this.selectedDay) {
- classes.push('is-selected');
- }
- if (date === this.formatedToday) {
- classes.push('is-today');
- }
- }
- return classes;
- },
- pickDay: function pickDay(_ref2) {
- var text = _ref2.text,
- type = _ref2.type;
- var date = this.getFormateDate(text, type);
- this.$emit('pick', date);
- },
- cellRenderProxy: function cellRenderProxy(_ref3) {
- var text = _ref3.text,
- type = _ref3.type;
- var h = this.$createElement;
- var render = this.elCalendar.$scopedSlots.dateCell;
- if (!render) return h('span', [text]);
- var day = this.getFormateDate(text, type);
- var date = new Date(day);
- var data = {
- isSelected: this.selectedDay === day,
- type: type + '-month',
- day: day
- };
- return render({ date: date, data: data });
- }
- },
- computed: {
- WEEK_DAYS: function WEEK_DAYS() {
- return Object(date_util_["getI18nSettings"])().dayNames;
- },
- prevMonthDatePrefix: function prevMonthDatePrefix() {
- var temp = new Date(this.date.getTime());
- temp.setDate(0);
- return date_default.a.format(temp, 'yyyy-MM');
- },
- curMonthDatePrefix: function curMonthDatePrefix() {
- return date_default.a.format(this.date, 'yyyy-MM');
- },
- nextMonthDatePrefix: function nextMonthDatePrefix() {
- var temp = new Date(this.date.getFullYear(), this.date.getMonth() + 1, 1);
- return date_default.a.format(temp, 'yyyy-MM');
- },
- formatedToday: function formatedToday() {
- return this.elCalendar.formatedToday;
- },
- isInRange: function isInRange() {
- return this.range && this.range.length;
- },
- rows: function rows() {
- var days = [];
- // if range exists, should render days in range.
- if (this.isInRange) {
- var _range = this.range,
- start = _range[0],
- end = _range[1];
- var currentMonthRange = Object(date_util_["range"])(end.getDate() - start.getDate() + 1).map(function (_, index) {
- return {
- text: start.getDate() + index,
- type: 'current'
- };
- });
- var remaining = currentMonthRange.length % 7;
- remaining = remaining === 0 ? 0 : 7 - remaining;
- var nextMonthRange = Object(date_util_["range"])(remaining).map(function (_, index) {
- return {
- text: index + 1,
- type: 'next'
- };
- });
- days = currentMonthRange.concat(nextMonthRange);
- } else {
- var date = this.date;
- var firstDay = Object(date_util_["getFirstDayOfMonth"])(date);
- firstDay = firstDay === 0 ? 7 : firstDay;
- var firstDayOfWeek = typeof this.firstDayOfWeek === 'number' ? this.firstDayOfWeek : 1;
- var offset = (7 + firstDay - firstDayOfWeek) % 7;
- var prevMonthDays = Object(date_util_["getPrevMonthLastDays"])(date, offset).map(function (day) {
- return {
- text: day,
- type: 'prev'
- };
- });
- var currentMonthDays = Object(date_util_["getMonthDays"])(date).map(function (day) {
- return {
- text: day,
- type: 'current'
- };
- });
- days = [].concat(prevMonthDays, currentMonthDays);
- var nextMonthDays = Object(date_util_["range"])(42 - days.length).map(function (_, index) {
- return {
- text: index + 1,
- type: 'next'
- };
- });
- days = days.concat(nextMonthDays);
- }
- return this.toNestedArr(days);
- },
- weekDays: function weekDays() {
- var start = this.firstDayOfWeek;
- var WEEK_DAYS = this.WEEK_DAYS;
- if (typeof start !== 'number' || start === 0) {
- return WEEK_DAYS.slice();
- } else {
- return WEEK_DAYS.slice(start).concat(WEEK_DAYS.slice(0, start));
- }
- }
- },
- render: function render() {
- var _this = this;
- var h = arguments[0];
- var thead = this.hideHeader ? null : h('thead', [this.weekDays.map(function (day) {
- return h(
- 'th',
- { key: day },
- [day]
- );
- })]);
- return h(
- 'table',
- {
- 'class': {
- 'el-calendar-table': true,
- 'is-range': this.isInRange
- },
- attrs: { cellspacing: '0',
- cellpadding: '0' }
- },
- [thead, h('tbody', [this.rows.map(function (row, index) {
- return h(
- 'tr',
- {
- 'class': {
- 'el-calendar-table__row': true,
- 'el-calendar-table__row--hide-border': index === 0 && _this.hideHeader
- },
- key: index },
- [row.map(function (cell, key) {
- return h(
- 'td',
- { key: key,
- 'class': _this.getCellClass(cell),
- on: {
- 'click': _this.pickDay.bind(_this, cell)
- }
- },
- [h(
- 'div',
- { 'class': 'el-calendar-day' },
- [_this.cellRenderProxy(cell)]
- )]
- );
- })]
- );
- })])]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/calendar/src/date-table.vue?vue&type=script&lang=js&
- /* harmony default export */ var calendar_src_date_tablevue_type_script_lang_js_ = (src_date_tablevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/calendar/src/date-table.vue
- var date_table_render, date_table_staticRenderFns
- /* normalize component */
- var src_date_table_component = normalizeComponent(
- calendar_src_date_tablevue_type_script_lang_js_,
- date_table_render,
- date_table_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var src_date_table_api; }
- src_date_table_component.options.__file = "packages/calendar/src/date-table.vue"
- /* harmony default export */ var src_date_table = (src_date_table_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/calendar/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var validTypes = ['prev-month', 'today', 'next-month'];
- var weekDays = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];
- var oneDay = 86400000;
- /* harmony default export */ var calendar_src_mainvue_type_script_lang_js_ = ({
- name: 'ElCalendar',
- mixins: [locale_default.a],
- components: {
- DateTable: src_date_table,
- ElButton: button_default.a,
- ElButtonGroup: button_group_default.a
- },
- props: {
- value: [Date, String, Number],
- range: {
- type: Array,
- validator: function validator(range) {
- if (Array.isArray(range)) {
- return range.length === 2 && range.every(function (item) {
- return typeof item === 'string' || typeof item === 'number' || item instanceof Date;
- });
- } else {
- return true;
- }
- }
- },
- firstDayOfWeek: {
- type: Number,
- default: 1
- }
- },
- provide: function provide() {
- return {
- elCalendar: this
- };
- },
- methods: {
- pickDay: function pickDay(day) {
- this.realSelectedDay = day;
- },
- selectDate: function selectDate(type) {
- if (validTypes.indexOf(type) === -1) {
- throw new Error('invalid type ' + type);
- }
- var day = '';
- if (type === 'prev-month') {
- day = this.prevMonthDatePrefix + '-01';
- } else if (type === 'next-month') {
- day = this.nextMonthDatePrefix + '-01';
- } else {
- day = this.formatedToday;
- }
- if (day === this.formatedDate) return;
- this.pickDay(day);
- },
- toDate: function toDate(val) {
- if (!val) {
- throw new Error('invalid val');
- }
- return val instanceof Date ? val : new Date(val);
- },
- rangeValidator: function rangeValidator(date, isStart) {
- var firstDayOfWeek = this.realFirstDayOfWeek;
- var expected = isStart ? firstDayOfWeek : firstDayOfWeek === 0 ? 6 : firstDayOfWeek - 1;
- var message = (isStart ? 'start' : 'end') + ' of range should be ' + weekDays[expected] + '.';
- if (date.getDay() !== expected) {
- console.warn('[ElementCalendar]', message, 'Invalid range will be ignored.');
- return false;
- }
- return true;
- }
- },
- computed: {
- prevMonthDatePrefix: function prevMonthDatePrefix() {
- var temp = new Date(this.date.getTime());
- temp.setDate(0);
- return date_default.a.format(temp, 'yyyy-MM');
- },
- curMonthDatePrefix: function curMonthDatePrefix() {
- return date_default.a.format(this.date, 'yyyy-MM');
- },
- nextMonthDatePrefix: function nextMonthDatePrefix() {
- var temp = new Date(this.date.getFullYear(), this.date.getMonth() + 1, 1);
- return date_default.a.format(temp, 'yyyy-MM');
- },
- formatedDate: function formatedDate() {
- return date_default.a.format(this.date, 'yyyy-MM-dd');
- },
- i18nDate: function i18nDate() {
- var year = this.date.getFullYear();
- var month = this.date.getMonth() + 1;
- return year + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + month);
- },
- formatedToday: function formatedToday() {
- return date_default.a.format(this.now, 'yyyy-MM-dd');
- },
- realSelectedDay: {
- get: function get() {
- if (!this.value) return this.selectedDay;
- return this.formatedDate;
- },
- set: function set(val) {
- this.selectedDay = val;
- var date = new Date(val);
- this.$emit('input', date);
- }
- },
- date: function date() {
- if (!this.value) {
- if (this.realSelectedDay) {
- var d = this.selectedDay.split('-');
- return new Date(d[0], d[1] - 1, d[2]);
- } else if (this.validatedRange.length) {
- return this.validatedRange[0][0];
- }
- return this.now;
- } else {
- return this.toDate(this.value);
- }
- },
- // if range is valid, we get a two-digit array
- validatedRange: function validatedRange() {
- var _this = this;
- var range = this.range;
- if (!range) return [];
- range = range.reduce(function (prev, val, index) {
- var date = _this.toDate(val);
- if (_this.rangeValidator(date, index === 0)) {
- prev = prev.concat(date);
- }
- return prev;
- }, []);
- if (range.length === 2) {
- var _range = range,
- start = _range[0],
- end = _range[1];
- if (start > end) {
- console.warn('[ElementCalendar]end time should be greater than start time');
- return [];
- }
- // start time and end time in one month
- if (Object(date_util_["validateRangeInOneMonth"])(start, end)) {
- return [[start, end]];
- }
- var data = [];
- var startDay = new Date(start.getFullYear(), start.getMonth() + 1, 1);
- var lastDay = this.toDate(startDay.getTime() - oneDay);
- if (!Object(date_util_["validateRangeInOneMonth"])(startDay, end)) {
- console.warn('[ElementCalendar]start time and end time interval must not exceed two months');
- return [];
- }
- // 第一个月的时间范围
- data.push([start, lastDay]);
- // 下一月的时间范围,需要计算一下该月的第一个周起始日
- var firstDayOfWeek = this.realFirstDayOfWeek;
- var nextMontFirstDay = startDay.getDay();
- var interval = 0;
- if (nextMontFirstDay !== firstDayOfWeek) {
- if (firstDayOfWeek === 0) {
- interval = 7 - nextMontFirstDay;
- } else {
- interval = firstDayOfWeek - nextMontFirstDay;
- interval = interval > 0 ? interval : 7 + interval;
- }
- }
- startDay = this.toDate(startDay.getTime() + interval * oneDay);
- if (startDay.getDate() < end.getDate()) {
- data.push([startDay, end]);
- }
- return data;
- }
- return [];
- },
- realFirstDayOfWeek: function realFirstDayOfWeek() {
- if (this.firstDayOfWeek < 1 || this.firstDayOfWeek > 6) {
- return 0;
- }
- return Math.floor(this.firstDayOfWeek);
- }
- },
- data: function data() {
- return {
- selectedDay: '',
- now: new Date()
- };
- }
- });
- // CONCATENATED MODULE: ./packages/calendar/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_calendar_src_mainvue_type_script_lang_js_ = (calendar_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/calendar/src/main.vue
- /* normalize component */
- var calendar_src_main_component = normalizeComponent(
- packages_calendar_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_6d9756be_render,
- mainvue_type_template_id_6d9756be_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var calendar_src_main_api; }
- calendar_src_main_component.options.__file = "packages/calendar/src/main.vue"
- /* harmony default export */ var calendar_src_main = (calendar_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/calendar/index.js
- /* istanbul ignore next */
- calendar_src_main.install = function (Vue) {
- Vue.component(calendar_src_main.name, calendar_src_main);
- };
- /* harmony default export */ var calendar = (calendar_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/backtop/src/main.vue?vue&type=template&id=257dd4a9&
- var mainvue_type_template_id_257dd4a9_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("transition", { attrs: { name: "el-fade-in" } }, [
- _vm.visible
- ? _c(
- "div",
- {
- staticClass: "el-backtop",
- style: {
- right: _vm.styleRight,
- bottom: _vm.styleBottom
- },
- on: {
- click: function($event) {
- $event.stopPropagation()
- return _vm.handleClick($event)
- }
- }
- },
- [
- _vm._t("default", [_c("el-icon", { attrs: { name: "caret-top" } })])
- ],
- 2
- )
- : _vm._e()
- ])
- }
- var mainvue_type_template_id_257dd4a9_staticRenderFns = []
- mainvue_type_template_id_257dd4a9_render._withStripped = true
- // CONCATENATED MODULE: ./packages/backtop/src/main.vue?vue&type=template&id=257dd4a9&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/backtop/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var cubic = function cubic(value) {
- return Math.pow(value, 3);
- };
- var easeInOutCubic = function easeInOutCubic(value) {
- return value < 0.5 ? cubic(value * 2) / 2 : 1 - cubic((1 - value) * 2) / 2;
- };
- /* harmony default export */ var backtop_src_mainvue_type_script_lang_js_ = ({
- name: 'ElBacktop',
- props: {
- visibilityHeight: {
- type: Number,
- default: 200
- },
- target: [String],
- right: {
- type: Number,
- default: 40
- },
- bottom: {
- type: Number,
- default: 40
- }
- },
- data: function data() {
- return {
- el: null,
- container: null,
- visible: false
- };
- },
- computed: {
- styleBottom: function styleBottom() {
- return this.bottom + 'px';
- },
- styleRight: function styleRight() {
- return this.right + 'px';
- }
- },
- mounted: function mounted() {
- this.init();
- this.throttledScrollHandler = throttle_default()(300, this.onScroll);
- this.container.addEventListener('scroll', this.throttledScrollHandler);
- },
- methods: {
- init: function init() {
- this.container = document;
- this.el = document.documentElement;
- if (this.target) {
- this.el = document.querySelector(this.target);
- if (!this.el) {
- throw new Error('target is not existed: ' + this.target);
- }
- this.container = this.el;
- }
- },
- onScroll: function onScroll() {
- var scrollTop = this.el.scrollTop;
- this.visible = scrollTop >= this.visibilityHeight;
- },
- handleClick: function handleClick(e) {
- this.scrollToTop();
- this.$emit('click', e);
- },
- scrollToTop: function scrollToTop() {
- var el = this.el;
- var beginTime = Date.now();
- var beginValue = el.scrollTop;
- var rAF = window.requestAnimationFrame || function (func) {
- return setTimeout(func, 16);
- };
- var frameFunc = function frameFunc() {
- var progress = (Date.now() - beginTime) / 500;
- if (progress < 1) {
- el.scrollTop = beginValue * (1 - easeInOutCubic(progress));
- rAF(frameFunc);
- } else {
- el.scrollTop = 0;
- }
- };
- rAF(frameFunc);
- }
- },
- beforeDestroy: function beforeDestroy() {
- this.container.removeEventListener('scroll', this.throttledScrollHandler);
- }
- });
- // CONCATENATED MODULE: ./packages/backtop/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_backtop_src_mainvue_type_script_lang_js_ = (backtop_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/backtop/src/main.vue
- /* normalize component */
- var backtop_src_main_component = normalizeComponent(
- packages_backtop_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_257dd4a9_render,
- mainvue_type_template_id_257dd4a9_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var backtop_src_main_api; }
- backtop_src_main_component.options.__file = "packages/backtop/src/main.vue"
- /* harmony default export */ var backtop_src_main = (backtop_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/backtop/index.js
- /* istanbul ignore next */
- backtop_src_main.install = function (Vue) {
- Vue.component(backtop_src_main.name, backtop_src_main);
- };
- /* harmony default export */ var backtop = (backtop_src_main);
- // CONCATENATED MODULE: ./packages/infinite-scroll/src/main.js
- var getStyleComputedProperty = function getStyleComputedProperty(element, property) {
- if (element === window) {
- element = document.documentElement;
- }
- if (element.nodeType !== 1) {
- return [];
- }
- // NOTE: 1 DOM access here
- var css = window.getComputedStyle(element, null);
- return property ? css[property] : css;
- };
- var entries = function entries(obj) {
- return Object.keys(obj || {}).map(function (key) {
- return [key, obj[key]];
- });
- };
- var getPositionSize = function getPositionSize(el, prop) {
- return el === window || el === document ? document.documentElement[prop] : el[prop];
- };
- var getOffsetHeight = function getOffsetHeight(el) {
- return getPositionSize(el, 'offsetHeight');
- };
- var getClientHeight = function getClientHeight(el) {
- return getPositionSize(el, 'clientHeight');
- };
- var scope = 'ElInfiniteScroll';
- var attributes = {
- delay: {
- type: Number,
- default: 200
- },
- distance: {
- type: Number,
- default: 0
- },
- disabled: {
- type: Boolean,
- default: false
- },
- immediate: {
- type: Boolean,
- default: true
- }
- };
- var main_getScrollOptions = function getScrollOptions(el, vm) {
- if (!Object(types_["isHtmlElement"])(el)) return {};
- return entries(attributes).reduce(function (map, _ref) {
- var key = _ref[0],
- option = _ref[1];
- var type = option.type,
- defaultValue = option.default;
- var value = el.getAttribute('infinite-scroll-' + key);
- value = Object(types_["isUndefined"])(vm[value]) ? value : vm[value];
- switch (type) {
- case Number:
- value = Number(value);
- value = Number.isNaN(value) ? defaultValue : value;
- break;
- case Boolean:
- value = Object(types_["isDefined"])(value) ? value === 'false' ? false : Boolean(value) : defaultValue;
- break;
- default:
- value = type(value);
- }
- map[key] = value;
- return map;
- }, {});
- };
- var getElementTop = function getElementTop(el) {
- return el.getBoundingClientRect().top;
- };
- var main_handleScroll = function handleScroll(cb) {
- var _scope = this[scope],
- el = _scope.el,
- vm = _scope.vm,
- container = _scope.container,
- observer = _scope.observer;
- var _getScrollOptions = main_getScrollOptions(el, vm),
- distance = _getScrollOptions.distance,
- disabled = _getScrollOptions.disabled;
- if (disabled) return;
- var containerInfo = container.getBoundingClientRect();
- if (!containerInfo.width && !containerInfo.height) return;
- var shouldTrigger = false;
- if (container === el) {
- // be aware of difference between clientHeight & offsetHeight & window.getComputedStyle().height
- var scrollBottom = container.scrollTop + getClientHeight(container);
- shouldTrigger = container.scrollHeight - scrollBottom <= distance;
- } else {
- var heightBelowTop = getOffsetHeight(el) + getElementTop(el) - getElementTop(container);
- var offsetHeight = getOffsetHeight(container);
- var borderBottom = Number.parseFloat(getStyleComputedProperty(container, 'borderBottomWidth'));
- shouldTrigger = heightBelowTop - offsetHeight + borderBottom <= distance;
- }
- if (shouldTrigger && Object(types_["isFunction"])(cb)) {
- cb.call(vm);
- } else if (observer) {
- observer.disconnect();
- this[scope].observer = null;
- }
- };
- /* harmony default export */ var infinite_scroll_src_main = ({
- name: 'InfiniteScroll',
- inserted: function inserted(el, binding, vnode) {
- var cb = binding.value;
- var vm = vnode.context;
- // only include vertical scroll
- var container = Object(dom_["getScrollContainer"])(el, true);
- var _getScrollOptions2 = main_getScrollOptions(el, vm),
- delay = _getScrollOptions2.delay,
- immediate = _getScrollOptions2.immediate;
- var onScroll = debounce_default()(delay, main_handleScroll.bind(el, cb));
- el[scope] = { el: el, vm: vm, container: container, onScroll: onScroll };
- if (container) {
- container.addEventListener('scroll', onScroll);
- if (immediate) {
- var observer = el[scope].observer = new MutationObserver(onScroll);
- observer.observe(container, { childList: true, subtree: true });
- onScroll();
- }
- }
- },
- unbind: function unbind(el) {
- var _el$scope = el[scope],
- container = _el$scope.container,
- onScroll = _el$scope.onScroll;
- if (container) {
- container.removeEventListener('scroll', onScroll);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/infinite-scroll/index.js
- /* istanbul ignore next */
- infinite_scroll_src_main.install = function (Vue) {
- Vue.directive(infinite_scroll_src_main.name, infinite_scroll_src_main);
- };
- /* harmony default export */ var infinite_scroll = (infinite_scroll_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/page-header/src/main.vue?vue&type=template&id=5070954c&
- var mainvue_type_template_id_5070954c_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("div", { staticClass: "el-page-header" }, [
- _c(
- "div",
- {
- staticClass: "el-page-header__left",
- on: {
- click: function($event) {
- _vm.$emit("back")
- }
- }
- },
- [
- _c("i", { staticClass: "el-icon-back" }),
- _c(
- "div",
- { staticClass: "el-page-header__title" },
- [_vm._t("title", [_vm._v(_vm._s(_vm.title))])],
- 2
- )
- ]
- ),
- _c(
- "div",
- { staticClass: "el-page-header__content" },
- [_vm._t("content", [_vm._v(_vm._s(_vm.content))])],
- 2
- )
- ])
- }
- var mainvue_type_template_id_5070954c_staticRenderFns = []
- mainvue_type_template_id_5070954c_render._withStripped = true
- // CONCATENATED MODULE: ./packages/page-header/src/main.vue?vue&type=template&id=5070954c&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/page-header/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var page_header_src_mainvue_type_script_lang_js_ = ({
- name: 'ElPageHeader',
- props: {
- title: {
- type: String,
- default: function _default() {
- return Object(lib_locale_["t"])('el.pageHeader.title');
- }
- },
- content: String
- }
- });
- // CONCATENATED MODULE: ./packages/page-header/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_page_header_src_mainvue_type_script_lang_js_ = (page_header_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/page-header/src/main.vue
- /* normalize component */
- var page_header_src_main_component = normalizeComponent(
- packages_page_header_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_5070954c_render,
- mainvue_type_template_id_5070954c_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var page_header_src_main_api; }
- page_header_src_main_component.options.__file = "packages/page-header/src/main.vue"
- /* harmony default export */ var page_header_src_main = (page_header_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/page-header/index.js
- /* istanbul ignore next */
- page_header_src_main.install = function (Vue) {
- Vue.component(page_header_src_main.name, page_header_src_main);
- };
- /* harmony default export */ var page_header = (page_header_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-panel.vue?vue&type=template&id=34932346&
- var cascader_panelvue_type_template_id_34932346_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- class: ["el-cascader-panel", _vm.border && "is-bordered"],
- on: { keydown: _vm.handleKeyDown }
- },
- _vm._l(_vm.menus, function(menu, index) {
- return _c("cascader-menu", {
- key: index,
- ref: "menu",
- refInFor: true,
- attrs: { index: index, nodes: menu }
- })
- }),
- 1
- )
- }
- var cascader_panelvue_type_template_id_34932346_staticRenderFns = []
- cascader_panelvue_type_template_id_34932346_render._withStripped = true
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue?vue&type=template&id=34932346&
- // EXTERNAL MODULE: external "element-ui/lib/radio"
- var radio_ = __webpack_require__(44);
- var radio_default = /*#__PURE__*/__webpack_require__.n(radio_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-node.vue?vue&type=script&lang=js&
- var stopPropagation = function stopPropagation(e) {
- return e.stopPropagation();
- };
- /* harmony default export */ var cascader_nodevue_type_script_lang_js_ = ({
- inject: ['panel'],
- components: {
- ElCheckbox: checkbox_default.a,
- ElRadio: radio_default.a
- },
- props: {
- node: {
- required: true
- },
- nodeId: String
- },
- computed: {
- config: function config() {
- return this.panel.config;
- },
- isLeaf: function isLeaf() {
- return this.node.isLeaf;
- },
- isDisabled: function isDisabled() {
- return this.node.isDisabled;
- },
- checkedValue: function checkedValue() {
- return this.panel.checkedValue;
- },
- isChecked: function isChecked() {
- return this.node.isSameNode(this.checkedValue);
- },
- inActivePath: function inActivePath() {
- return this.isInPath(this.panel.activePath);
- },
- inCheckedPath: function inCheckedPath() {
- var _this = this;
- if (!this.config.checkStrictly) return false;
- return this.panel.checkedNodePaths.some(function (checkedPath) {
- return _this.isInPath(checkedPath);
- });
- },
- value: function value() {
- return this.node.getValueByOption();
- }
- },
- methods: {
- handleExpand: function handleExpand() {
- var _this2 = this;
- var panel = this.panel,
- node = this.node,
- isDisabled = this.isDisabled,
- config = this.config;
- var multiple = config.multiple,
- checkStrictly = config.checkStrictly;
- if (!checkStrictly && isDisabled || node.loading) return;
- if (config.lazy && !node.loaded) {
- panel.lazyLoad(node, function () {
- // do not use cached leaf value here, invoke this.isLeaf to get new value.
- var isLeaf = _this2.isLeaf;
- if (!isLeaf) _this2.handleExpand();
- if (multiple) {
- // if leaf sync checked state, else clear checked state
- var checked = isLeaf ? node.checked : false;
- _this2.handleMultiCheckChange(checked);
- }
- });
- } else {
- panel.handleExpand(node);
- }
- },
- handleCheckChange: function handleCheckChange() {
- var panel = this.panel,
- value = this.value,
- node = this.node;
- panel.handleCheckChange(value);
- panel.handleExpand(node);
- },
- handleMultiCheckChange: function handleMultiCheckChange(checked) {
- this.node.doCheck(checked);
- this.panel.calculateMultiCheckedValue();
- },
- isInPath: function isInPath(pathNodes) {
- var node = this.node;
- var selectedPathNode = pathNodes[node.level - 1] || {};
- return selectedPathNode.uid === node.uid;
- },
- renderPrefix: function renderPrefix(h) {
- var isLeaf = this.isLeaf,
- isChecked = this.isChecked,
- config = this.config;
- var checkStrictly = config.checkStrictly,
- multiple = config.multiple;
- if (multiple) {
- return this.renderCheckbox(h);
- } else if (checkStrictly) {
- return this.renderRadio(h);
- } else if (isLeaf && isChecked) {
- return this.renderCheckIcon(h);
- }
- return null;
- },
- renderPostfix: function renderPostfix(h) {
- var node = this.node,
- isLeaf = this.isLeaf;
- if (node.loading) {
- return this.renderLoadingIcon(h);
- } else if (!isLeaf) {
- return this.renderExpandIcon(h);
- }
- return null;
- },
- renderCheckbox: function renderCheckbox(h) {
- var node = this.node,
- config = this.config,
- isDisabled = this.isDisabled;
- var events = {
- on: { change: this.handleMultiCheckChange },
- nativeOn: {}
- };
- if (config.checkStrictly) {
- // when every node is selectable, click event should not trigger expand event.
- events.nativeOn.click = stopPropagation;
- }
- return h('el-checkbox', external_babel_helper_vue_jsx_merge_props_default()([{
- attrs: {
- value: node.checked,
- indeterminate: node.indeterminate,
- disabled: isDisabled
- }
- }, events]));
- },
- renderRadio: function renderRadio(h) {
- var checkedValue = this.checkedValue,
- value = this.value,
- isDisabled = this.isDisabled;
- // to keep same reference if value cause radio's checked state is calculated by reference comparision;
- if (Object(util_["isEqual"])(value, checkedValue)) {
- value = checkedValue;
- }
- return h(
- 'el-radio',
- {
- attrs: {
- value: checkedValue,
- label: value,
- disabled: isDisabled
- },
- on: {
- 'change': this.handleCheckChange
- },
- nativeOn: {
- 'click': stopPropagation
- }
- },
- [h('span')]
- );
- },
- renderCheckIcon: function renderCheckIcon(h) {
- return h('i', { 'class': 'el-icon-check el-cascader-node__prefix' });
- },
- renderLoadingIcon: function renderLoadingIcon(h) {
- return h('i', { 'class': 'el-icon-loading el-cascader-node__postfix' });
- },
- renderExpandIcon: function renderExpandIcon(h) {
- return h('i', { 'class': 'el-icon-arrow-right el-cascader-node__postfix' });
- },
- renderContent: function renderContent(h) {
- var panel = this.panel,
- node = this.node;
- var render = panel.renderLabelFn;
- var vnode = render ? render({ node: node, data: node.data }) : null;
- return h(
- 'span',
- { 'class': 'el-cascader-node__label' },
- [vnode || node.label]
- );
- }
- },
- render: function render(h) {
- var _this3 = this;
- var inActivePath = this.inActivePath,
- inCheckedPath = this.inCheckedPath,
- isChecked = this.isChecked,
- isLeaf = this.isLeaf,
- isDisabled = this.isDisabled,
- config = this.config,
- nodeId = this.nodeId;
- var expandTrigger = config.expandTrigger,
- checkStrictly = config.checkStrictly,
- multiple = config.multiple;
- var disabled = !checkStrictly && isDisabled;
- var events = { on: {} };
- if (expandTrigger === 'click') {
- events.on.click = this.handleExpand;
- } else {
- events.on.mouseenter = function (e) {
- _this3.handleExpand();
- _this3.$emit('expand', e);
- };
- events.on.focus = function (e) {
- _this3.handleExpand();
- _this3.$emit('expand', e);
- };
- }
- if (isLeaf && !isDisabled && !checkStrictly && !multiple) {
- events.on.click = this.handleCheckChange;
- }
- return h(
- 'li',
- external_babel_helper_vue_jsx_merge_props_default()([{
- attrs: {
- role: 'menuitem',
- id: nodeId,
- 'aria-expanded': inActivePath,
- tabindex: disabled ? null : -1
- },
- 'class': {
- 'el-cascader-node': true,
- 'is-selectable': checkStrictly,
- 'in-active-path': inActivePath,
- 'in-checked-path': inCheckedPath,
- 'is-active': isChecked,
- 'is-disabled': disabled
- }
- }, events]),
- [this.renderPrefix(h), this.renderContent(h), this.renderPostfix(h)]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-node.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_cascader_nodevue_type_script_lang_js_ = (cascader_nodevue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-node.vue
- var cascader_node_render, cascader_node_staticRenderFns
- /* normalize component */
- var cascader_node_component = normalizeComponent(
- src_cascader_nodevue_type_script_lang_js_,
- cascader_node_render,
- cascader_node_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var cascader_node_api; }
- cascader_node_component.options.__file = "packages/cascader-panel/src/cascader-node.vue"
- /* harmony default export */ var cascader_node = (cascader_node_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-menu.vue?vue&type=script&lang=js&
- /* harmony default export */ var cascader_menuvue_type_script_lang_js_ = ({
- name: 'ElCascaderMenu',
- mixins: [locale_default.a],
- inject: ['panel'],
- components: {
- ElScrollbar: scrollbar_default.a,
- CascaderNode: cascader_node
- },
- props: {
- nodes: {
- type: Array,
- required: true
- },
- index: Number
- },
- data: function data() {
- return {
- activeNode: null,
- hoverTimer: null,
- id: Object(util_["generateId"])()
- };
- },
- computed: {
- isEmpty: function isEmpty() {
- return !this.nodes.length;
- },
- menuId: function menuId() {
- return 'cascader-menu-' + this.id + '-' + this.index;
- }
- },
- methods: {
- handleExpand: function handleExpand(e) {
- this.activeNode = e.target;
- },
- handleMouseMove: function handleMouseMove(e) {
- var activeNode = this.activeNode,
- hoverTimer = this.hoverTimer;
- var hoverZone = this.$refs.hoverZone;
- if (!activeNode || !hoverZone) return;
- if (activeNode.contains(e.target)) {
- clearTimeout(hoverTimer);
- var _$el$getBoundingClien = this.$el.getBoundingClientRect(),
- left = _$el$getBoundingClien.left;
- var startX = e.clientX - left;
- var _$el = this.$el,
- offsetWidth = _$el.offsetWidth,
- offsetHeight = _$el.offsetHeight;
- var top = activeNode.offsetTop;
- var bottom = top + activeNode.offsetHeight;
- hoverZone.innerHTML = '\n <path style="pointer-events: auto;" fill="transparent" d="M' + startX + ' ' + top + ' L' + offsetWidth + ' 0 V' + top + ' Z" />\n <path style="pointer-events: auto;" fill="transparent" d="M' + startX + ' ' + bottom + ' L' + offsetWidth + ' ' + offsetHeight + ' V' + bottom + ' Z" />\n ';
- } else if (!hoverTimer) {
- this.hoverTimer = setTimeout(this.clearHoverZone, this.panel.config.hoverThreshold);
- }
- },
- clearHoverZone: function clearHoverZone() {
- var hoverZone = this.$refs.hoverZone;
- if (!hoverZone) return;
- hoverZone.innerHTML = '';
- },
- renderEmptyText: function renderEmptyText(h) {
- return h(
- 'div',
- { 'class': 'el-cascader-menu__empty-text' },
- [this.t('el.cascader.noData')]
- );
- },
- renderNodeList: function renderNodeList(h) {
- var menuId = this.menuId;
- var isHoverMenu = this.panel.isHoverMenu;
- var events = { on: {} };
- if (isHoverMenu) {
- events.on.expand = this.handleExpand;
- }
- var nodes = this.nodes.map(function (node, index) {
- var hasChildren = node.hasChildren;
- return h('cascader-node', external_babel_helper_vue_jsx_merge_props_default()([{
- key: node.uid,
- attrs: { node: node,
- 'node-id': menuId + '-' + index,
- 'aria-haspopup': hasChildren,
- 'aria-owns': hasChildren ? menuId : null
- }
- }, events]));
- });
- return [].concat(nodes, [isHoverMenu ? h('svg', { ref: 'hoverZone', 'class': 'el-cascader-menu__hover-zone' }) : null]);
- }
- },
- render: function render(h) {
- var isEmpty = this.isEmpty,
- menuId = this.menuId;
- var events = { nativeOn: {} };
- // optimize hover to expand experience (#8010)
- if (this.panel.isHoverMenu) {
- events.nativeOn.mousemove = this.handleMouseMove;
- // events.nativeOn.mouseleave = this.clearHoverZone;
- }
- return h(
- 'el-scrollbar',
- external_babel_helper_vue_jsx_merge_props_default()([{
- attrs: {
- tag: 'ul',
- role: 'menu',
- id: menuId,
- 'wrap-class': 'el-cascader-menu__wrap',
- 'view-class': {
- 'el-cascader-menu__list': true,
- 'is-empty': isEmpty
- }
- },
- 'class': 'el-cascader-menu' }, events]),
- [isEmpty ? this.renderEmptyText(h) : this.renderNodeList(h)]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-menu.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_cascader_menuvue_type_script_lang_js_ = (cascader_menuvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-menu.vue
- var cascader_menu_render, cascader_menu_staticRenderFns
- /* normalize component */
- var cascader_menu_component = normalizeComponent(
- src_cascader_menuvue_type_script_lang_js_,
- cascader_menu_render,
- cascader_menu_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var cascader_menu_api; }
- cascader_menu_component.options.__file = "packages/cascader-panel/src/cascader-menu.vue"
- /* harmony default export */ var cascader_menu = (cascader_menu_component.exports);
- // CONCATENATED MODULE: ./packages/cascader-panel/src/node.js
- var node_createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
- function src_node_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- var uid = 0;
- var src_node_Node = function () {
- function Node(data, config, parentNode) {
- src_node_classCallCheck(this, Node);
- this.data = data;
- this.config = config;
- this.parent = parentNode || null;
- this.level = !this.parent ? 1 : this.parent.level + 1;
- this.uid = uid++;
- this.initState();
- this.initChildren();
- }
- Node.prototype.initState = function initState() {
- var _config = this.config,
- valueKey = _config.value,
- labelKey = _config.label;
- this.value = this.data[valueKey];
- this.label = this.data[labelKey];
- this.pathNodes = this.calculatePathNodes();
- this.path = this.pathNodes.map(function (node) {
- return node.value;
- });
- this.pathLabels = this.pathNodes.map(function (node) {
- return node.label;
- });
- // lazy load
- this.loading = false;
- this.loaded = false;
- };
- Node.prototype.initChildren = function initChildren() {
- var _this = this;
- var config = this.config;
- var childrenKey = config.children;
- var childrenData = this.data[childrenKey];
- this.hasChildren = Array.isArray(childrenData);
- this.children = (childrenData || []).map(function (child) {
- return new Node(child, config, _this);
- });
- };
- Node.prototype.calculatePathNodes = function calculatePathNodes() {
- var nodes = [this];
- var parent = this.parent;
- while (parent) {
- nodes.unshift(parent);
- parent = parent.parent;
- }
- return nodes;
- };
- Node.prototype.getPath = function getPath() {
- return this.path;
- };
- Node.prototype.getValue = function getValue() {
- return this.value;
- };
- Node.prototype.getValueByOption = function getValueByOption() {
- return this.config.emitPath ? this.getPath() : this.getValue();
- };
- Node.prototype.getText = function getText(allLevels, separator) {
- return allLevels ? this.pathLabels.join(separator) : this.label;
- };
- Node.prototype.isSameNode = function isSameNode(checkedValue) {
- var value = this.getValueByOption();
- return this.config.multiple && Array.isArray(checkedValue) ? checkedValue.some(function (val) {
- return Object(util_["isEqual"])(val, value);
- }) : Object(util_["isEqual"])(checkedValue, value);
- };
- Node.prototype.broadcast = function broadcast(event) {
- for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
- args[_key - 1] = arguments[_key];
- }
- var handlerName = 'onParent' + Object(util_["capitalize"])(event);
- this.children.forEach(function (child) {
- if (child) {
- // bottom up
- child.broadcast.apply(child, [event].concat(args));
- child[handlerName] && child[handlerName].apply(child, args);
- }
- });
- };
- Node.prototype.emit = function emit(event) {
- var parent = this.parent;
- var handlerName = 'onChild' + Object(util_["capitalize"])(event);
- if (parent) {
- for (var _len2 = arguments.length, args = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
- args[_key2 - 1] = arguments[_key2];
- }
- parent[handlerName] && parent[handlerName].apply(parent, args);
- parent.emit.apply(parent, [event].concat(args));
- }
- };
- Node.prototype.onParentCheck = function onParentCheck(checked) {
- if (!this.isDisabled) {
- this.setCheckState(checked);
- }
- };
- Node.prototype.onChildCheck = function onChildCheck() {
- var children = this.children;
- var validChildren = children.filter(function (child) {
- return !child.isDisabled;
- });
- var checked = validChildren.length ? validChildren.every(function (child) {
- return child.checked;
- }) : false;
- this.setCheckState(checked);
- };
- Node.prototype.setCheckState = function setCheckState(checked) {
- var totalNum = this.children.length;
- var checkedNum = this.children.reduce(function (c, p) {
- var num = p.checked ? 1 : p.indeterminate ? 0.5 : 0;
- return c + num;
- }, 0);
- this.checked = checked;
- this.indeterminate = checkedNum !== totalNum && checkedNum > 0;
- };
- Node.prototype.syncCheckState = function syncCheckState(checkedValue) {
- var value = this.getValueByOption();
- var checked = this.isSameNode(checkedValue, value);
- this.doCheck(checked);
- };
- Node.prototype.doCheck = function doCheck(checked) {
- if (this.checked !== checked) {
- if (this.config.checkStrictly) {
- this.checked = checked;
- } else {
- // bottom up to unify the calculation of the indeterminate state
- this.broadcast('check', checked);
- this.setCheckState(checked);
- this.emit('check');
- }
- }
- };
- node_createClass(Node, [{
- key: 'isDisabled',
- get: function get() {
- var data = this.data,
- parent = this.parent,
- config = this.config;
- var disabledKey = config.disabled;
- var checkStrictly = config.checkStrictly;
- return data[disabledKey] || !checkStrictly && parent && parent.isDisabled;
- }
- }, {
- key: 'isLeaf',
- get: function get() {
- var data = this.data,
- loaded = this.loaded,
- hasChildren = this.hasChildren,
- children = this.children;
- var _config2 = this.config,
- lazy = _config2.lazy,
- leafKey = _config2.leaf;
- if (lazy) {
- var isLeaf = Object(shared_["isDef"])(data[leafKey]) ? data[leafKey] : loaded ? !children.length : false;
- this.hasChildren = !isLeaf;
- return isLeaf;
- }
- return !hasChildren;
- }
- }]);
- return Node;
- }();
- /* harmony default export */ var src_node = (src_node_Node);
- // CONCATENATED MODULE: ./packages/cascader-panel/src/store.js
- function store_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- var flatNodes = function flatNodes(data, leafOnly) {
- return data.reduce(function (res, node) {
- if (node.isLeaf) {
- res.push(node);
- } else {
- !leafOnly && res.push(node);
- res = res.concat(flatNodes(node.children, leafOnly));
- }
- return res;
- }, []);
- };
- var store_Store = function () {
- function Store(data, config) {
- store_classCallCheck(this, Store);
- this.config = config;
- this.initNodes(data);
- }
- Store.prototype.initNodes = function initNodes(data) {
- var _this = this;
- data = Object(util_["coerceTruthyValueToArray"])(data);
- this.nodes = data.map(function (nodeData) {
- return new src_node(nodeData, _this.config);
- });
- this.flattedNodes = this.getFlattedNodes(false, false);
- this.leafNodes = this.getFlattedNodes(true, false);
- };
- Store.prototype.appendNode = function appendNode(nodeData, parentNode) {
- var node = new src_node(nodeData, this.config, parentNode);
- var children = parentNode ? parentNode.children : this.nodes;
- children.push(node);
- };
- Store.prototype.appendNodes = function appendNodes(nodeDataList, parentNode) {
- var _this2 = this;
- nodeDataList = Object(util_["coerceTruthyValueToArray"])(nodeDataList);
- nodeDataList.forEach(function (nodeData) {
- return _this2.appendNode(nodeData, parentNode);
- });
- };
- Store.prototype.getNodes = function getNodes() {
- return this.nodes;
- };
- Store.prototype.getFlattedNodes = function getFlattedNodes(leafOnly) {
- var cached = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
- var cachedNodes = leafOnly ? this.leafNodes : this.flattedNodes;
- return cached ? cachedNodes : flatNodes(this.nodes, leafOnly);
- };
- Store.prototype.getNodeByValue = function getNodeByValue(value) {
- var nodes = this.getFlattedNodes(false, !this.config.lazy).filter(function (node) {
- return Object(util_["valueEquals"])(node.path, value) || node.value === value;
- });
- return nodes && nodes.length ? nodes[0] : null;
- };
- return Store;
- }();
- /* harmony default export */ var cascader_panel_src_store = (store_Store);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-panel.vue?vue&type=script&lang=js&
- var cascader_panelvue_type_script_lang_js_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var cascader_panelvue_type_script_lang_js_KeyCode = aria_utils_default.a.keys;
- var DefaultProps = {
- expandTrigger: 'click', // or hover
- multiple: false,
- checkStrictly: false, // whether all nodes can be selected
- emitPath: true, // wether to emit an array of all levels value in which node is located
- lazy: false,
- lazyLoad: util_["noop"],
- value: 'value',
- label: 'label',
- children: 'children',
- leaf: 'leaf',
- disabled: 'disabled',
- hoverThreshold: 500
- };
- var cascader_panelvue_type_script_lang_js_isLeaf = function isLeaf(el) {
- return !el.getAttribute('aria-owns');
- };
- var getSibling = function getSibling(el, distance) {
- var parentNode = el.parentNode;
- if (parentNode) {
- var siblings = parentNode.querySelectorAll('.el-cascader-node[tabindex="-1"]');
- var index = Array.prototype.indexOf.call(siblings, el);
- return siblings[index + distance] || null;
- }
- return null;
- };
- var getMenuIndex = function getMenuIndex(el, distance) {
- if (!el) return;
- var pieces = el.id.split('-');
- return Number(pieces[pieces.length - 2]);
- };
- var focusNode = function focusNode(el) {
- if (!el) return;
- el.focus();
- !cascader_panelvue_type_script_lang_js_isLeaf(el) && el.click();
- };
- var checkNode = function checkNode(el) {
- if (!el) return;
- var input = el.querySelector('input');
- if (input) {
- input.click();
- } else if (cascader_panelvue_type_script_lang_js_isLeaf(el)) {
- el.click();
- }
- };
- /* harmony default export */ var cascader_panelvue_type_script_lang_js_ = ({
- name: 'ElCascaderPanel',
- components: {
- CascaderMenu: cascader_menu
- },
- props: {
- value: {},
- options: Array,
- props: Object,
- border: {
- type: Boolean,
- default: true
- },
- renderLabel: Function
- },
- provide: function provide() {
- return {
- panel: this
- };
- },
- data: function data() {
- return {
- checkedValue: null,
- checkedNodePaths: [],
- store: [],
- menus: [],
- activePath: [],
- loadCount: 0
- };
- },
- computed: {
- config: function config() {
- return merge_default()(cascader_panelvue_type_script_lang_js_extends({}, DefaultProps), this.props || {});
- },
- multiple: function multiple() {
- return this.config.multiple;
- },
- checkStrictly: function checkStrictly() {
- return this.config.checkStrictly;
- },
- leafOnly: function leafOnly() {
- return !this.checkStrictly;
- },
- isHoverMenu: function isHoverMenu() {
- return this.config.expandTrigger === 'hover';
- },
- renderLabelFn: function renderLabelFn() {
- return this.renderLabel || this.$scopedSlots.default;
- }
- },
- watch: {
- value: function value() {
- this.syncCheckedValue();
- this.checkStrictly && this.calculateCheckedNodePaths();
- },
- options: {
- handler: function handler() {
- this.initStore();
- },
- immediate: true,
- deep: true
- },
- checkedValue: function checkedValue(val) {
- if (!Object(util_["isEqual"])(val, this.value)) {
- this.checkStrictly && this.calculateCheckedNodePaths();
- this.$emit('input', val);
- this.$emit('change', val);
- }
- }
- },
- mounted: function mounted() {
- if (!this.isEmptyValue(this.value)) {
- this.syncCheckedValue();
- }
- },
- methods: {
- initStore: function initStore() {
- var config = this.config,
- options = this.options;
- if (config.lazy && Object(util_["isEmpty"])(options)) {
- this.lazyLoad();
- } else {
- this.store = new cascader_panel_src_store(options, config);
- this.menus = [this.store.getNodes()];
- this.syncMenuState();
- }
- },
- syncCheckedValue: function syncCheckedValue() {
- var value = this.value,
- checkedValue = this.checkedValue;
- if (!Object(util_["isEqual"])(value, checkedValue)) {
- this.activePath = [];
- this.checkedValue = value;
- this.syncMenuState();
- }
- },
- syncMenuState: function syncMenuState() {
- var multiple = this.multiple,
- checkStrictly = this.checkStrictly;
- this.syncActivePath();
- multiple && this.syncMultiCheckState();
- checkStrictly && this.calculateCheckedNodePaths();
- this.$nextTick(this.scrollIntoView);
- },
- syncMultiCheckState: function syncMultiCheckState() {
- var _this = this;
- var nodes = this.getFlattedNodes(this.leafOnly);
- nodes.forEach(function (node) {
- node.syncCheckState(_this.checkedValue);
- });
- },
- isEmptyValue: function isEmptyValue(val) {
- var multiple = this.multiple,
- config = this.config;
- var emitPath = config.emitPath;
- if (multiple || emitPath) {
- return Object(util_["isEmpty"])(val);
- }
- return false;
- },
- syncActivePath: function syncActivePath() {
- var _this2 = this;
- var store = this.store,
- multiple = this.multiple,
- activePath = this.activePath,
- checkedValue = this.checkedValue;
- if (!Object(util_["isEmpty"])(activePath)) {
- var nodes = activePath.map(function (node) {
- return _this2.getNodeByValue(node.getValue());
- });
- this.expandNodes(nodes);
- } else if (!this.isEmptyValue(checkedValue)) {
- var value = multiple ? checkedValue[0] : checkedValue;
- var checkedNode = this.getNodeByValue(value) || {};
- var _nodes = (checkedNode.pathNodes || []).slice(0, -1);
- this.expandNodes(_nodes);
- } else {
- this.activePath = [];
- this.menus = [store.getNodes()];
- }
- },
- expandNodes: function expandNodes(nodes) {
- var _this3 = this;
- nodes.forEach(function (node) {
- return _this3.handleExpand(node, true /* silent */);
- });
- },
- calculateCheckedNodePaths: function calculateCheckedNodePaths() {
- var _this4 = this;
- var checkedValue = this.checkedValue,
- multiple = this.multiple;
- var checkedValues = multiple ? Object(util_["coerceTruthyValueToArray"])(checkedValue) : [checkedValue];
- this.checkedNodePaths = checkedValues.map(function (v) {
- var checkedNode = _this4.getNodeByValue(v);
- return checkedNode ? checkedNode.pathNodes : [];
- });
- },
- handleKeyDown: function handleKeyDown(e) {
- var target = e.target,
- keyCode = e.keyCode;
- switch (keyCode) {
- case cascader_panelvue_type_script_lang_js_KeyCode.up:
- var prev = getSibling(target, -1);
- focusNode(prev);
- break;
- case cascader_panelvue_type_script_lang_js_KeyCode.down:
- var next = getSibling(target, 1);
- focusNode(next);
- break;
- case cascader_panelvue_type_script_lang_js_KeyCode.left:
- var preMenu = this.$refs.menu[getMenuIndex(target) - 1];
- if (preMenu) {
- var expandedNode = preMenu.$el.querySelector('.el-cascader-node[aria-expanded="true"]');
- focusNode(expandedNode);
- }
- break;
- case cascader_panelvue_type_script_lang_js_KeyCode.right:
- var nextMenu = this.$refs.menu[getMenuIndex(target) + 1];
- if (nextMenu) {
- var firstNode = nextMenu.$el.querySelector('.el-cascader-node[tabindex="-1"]');
- focusNode(firstNode);
- }
- break;
- case cascader_panelvue_type_script_lang_js_KeyCode.enter:
- checkNode(target);
- break;
- case cascader_panelvue_type_script_lang_js_KeyCode.esc:
- case cascader_panelvue_type_script_lang_js_KeyCode.tab:
- this.$emit('close');
- break;
- default:
- return;
- }
- },
- handleExpand: function handleExpand(node, silent) {
- var activePath = this.activePath;
- var level = node.level;
- var path = activePath.slice(0, level - 1);
- var menus = this.menus.slice(0, level);
- if (!node.isLeaf) {
- path.push(node);
- menus.push(node.children);
- }
- this.activePath = path;
- this.menus = menus;
- if (!silent) {
- var pathValues = path.map(function (node) {
- return node.getValue();
- });
- var activePathValues = activePath.map(function (node) {
- return node.getValue();
- });
- if (!Object(util_["valueEquals"])(pathValues, activePathValues)) {
- this.$emit('active-item-change', pathValues); // Deprecated
- this.$emit('expand-change', pathValues);
- }
- }
- },
- handleCheckChange: function handleCheckChange(value) {
- this.checkedValue = value;
- },
- lazyLoad: function lazyLoad(node, onFullfiled) {
- var _this5 = this;
- var config = this.config;
- if (!node) {
- node = node || { root: true, level: 0 };
- this.store = new cascader_panel_src_store([], config);
- this.menus = [this.store.getNodes()];
- }
- node.loading = true;
- var resolve = function resolve(dataList) {
- var parent = node.root ? null : node;
- dataList && dataList.length && _this5.store.appendNodes(dataList, parent);
- node.loading = false;
- node.loaded = true;
- // dispose default value on lazy load mode
- if (Array.isArray(_this5.checkedValue)) {
- var nodeValue = _this5.checkedValue[_this5.loadCount++];
- var valueKey = _this5.config.value;
- var leafKey = _this5.config.leaf;
- if (Array.isArray(dataList) && dataList.filter(function (item) {
- return item[valueKey] === nodeValue;
- }).length > 0) {
- var checkedNode = _this5.store.getNodeByValue(nodeValue);
- if (!checkedNode.data[leafKey]) {
- _this5.lazyLoad(checkedNode, function () {
- _this5.handleExpand(checkedNode);
- });
- }
- if (_this5.loadCount === _this5.checkedValue.length) {
- _this5.$parent.computePresentText();
- }
- }
- }
- onFullfiled && onFullfiled(dataList);
- };
- config.lazyLoad(node, resolve);
- },
- /**
- * public methods
- */
- calculateMultiCheckedValue: function calculateMultiCheckedValue() {
- this.checkedValue = this.getCheckedNodes(this.leafOnly).map(function (node) {
- return node.getValueByOption();
- });
- },
- scrollIntoView: function scrollIntoView() {
- if (this.$isServer) return;
- var menus = this.$refs.menu || [];
- menus.forEach(function (menu) {
- var menuElement = menu.$el;
- if (menuElement) {
- var container = menuElement.querySelector('.el-scrollbar__wrap');
- var activeNode = menuElement.querySelector('.el-cascader-node.is-active') || menuElement.querySelector('.el-cascader-node.in-active-path');
- scroll_into_view_default()(container, activeNode);
- }
- });
- },
- getNodeByValue: function getNodeByValue(val) {
- return this.store.getNodeByValue(val);
- },
- getFlattedNodes: function getFlattedNodes(leafOnly) {
- var cached = !this.config.lazy;
- return this.store.getFlattedNodes(leafOnly, cached);
- },
- getCheckedNodes: function getCheckedNodes(leafOnly) {
- var checkedValue = this.checkedValue,
- multiple = this.multiple;
- if (multiple) {
- var nodes = this.getFlattedNodes(leafOnly);
- return nodes.filter(function (node) {
- return node.checked;
- });
- } else {
- return this.isEmptyValue(checkedValue) ? [] : [this.getNodeByValue(checkedValue)];
- }
- },
- clearCheckedNodes: function clearCheckedNodes() {
- var config = this.config,
- leafOnly = this.leafOnly;
- var multiple = config.multiple,
- emitPath = config.emitPath;
- if (multiple) {
- this.getCheckedNodes(leafOnly).filter(function (node) {
- return !node.isDisabled;
- }).forEach(function (node) {
- return node.doCheck(false);
- });
- this.calculateMultiCheckedValue();
- } else {
- this.checkedValue = emitPath ? [] : null;
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_cascader_panelvue_type_script_lang_js_ = (cascader_panelvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue
- /* normalize component */
- var cascader_panel_component = normalizeComponent(
- src_cascader_panelvue_type_script_lang_js_,
- cascader_panelvue_type_template_id_34932346_render,
- cascader_panelvue_type_template_id_34932346_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var cascader_panel_api; }
- cascader_panel_component.options.__file = "packages/cascader-panel/src/cascader-panel.vue"
- /* harmony default export */ var cascader_panel = (cascader_panel_component.exports);
- // CONCATENATED MODULE: ./packages/cascader-panel/index.js
- /* istanbul ignore next */
- cascader_panel.install = function (Vue) {
- Vue.component(cascader_panel.name, cascader_panel);
- };
- /* harmony default export */ var packages_cascader_panel = (cascader_panel);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/avatar/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var avatar_src_mainvue_type_script_lang_js_ = ({
- name: 'ElAvatar',
- props: {
- size: {
- type: [Number, String],
- validator: function validator(val) {
- if (typeof val === 'string') {
- return ['large', 'medium', 'small'].includes(val);
- }
- return typeof val === 'number';
- }
- },
- shape: {
- type: String,
- default: 'circle',
- validator: function validator(val) {
- return ['circle', 'square'].includes(val);
- }
- },
- icon: String,
- src: String,
- alt: String,
- srcSet: String,
- error: Function,
- fit: {
- type: String,
- default: 'cover'
- }
- },
- data: function data() {
- return {
- isImageExist: true
- };
- },
- computed: {
- avatarClass: function avatarClass() {
- var size = this.size,
- icon = this.icon,
- shape = this.shape;
- var classList = ['el-avatar'];
- if (size && typeof size === 'string') {
- classList.push('el-avatar--' + size);
- }
- if (icon) {
- classList.push('el-avatar--icon');
- }
- if (shape) {
- classList.push('el-avatar--' + shape);
- }
- return classList.join(' ');
- }
- },
- methods: {
- handleError: function handleError() {
- var error = this.error;
- var errorFlag = error ? error() : undefined;
- if (errorFlag !== false) {
- this.isImageExist = false;
- }
- },
- renderAvatar: function renderAvatar() {
- var h = this.$createElement;
- var icon = this.icon,
- src = this.src,
- alt = this.alt,
- isImageExist = this.isImageExist,
- srcSet = this.srcSet,
- fit = this.fit;
- if (isImageExist && src) {
- return h('img', {
- attrs: {
- src: src,
- alt: alt,
- srcSet: srcSet
- },
- on: {
- 'error': this.handleError
- },
- style: { 'object-fit': fit } });
- }
- if (icon) {
- return h('i', { 'class': icon });
- }
- return this.$slots.default;
- }
- },
- render: function render() {
- var h = arguments[0];
- var avatarClass = this.avatarClass,
- size = this.size;
- var sizeStyle = typeof size === 'number' ? {
- height: size + 'px',
- width: size + 'px',
- lineHeight: size + 'px'
- } : {};
- return h(
- 'span',
- { 'class': avatarClass, style: sizeStyle },
- [this.renderAvatar()]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/avatar/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_avatar_src_mainvue_type_script_lang_js_ = (avatar_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/avatar/src/main.vue
- var src_main_render, src_main_staticRenderFns
- /* normalize component */
- var avatar_src_main_component = normalizeComponent(
- packages_avatar_src_mainvue_type_script_lang_js_,
- src_main_render,
- src_main_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var avatar_src_main_api; }
- avatar_src_main_component.options.__file = "packages/avatar/src/main.vue"
- /* harmony default export */ var avatar_src_main = (avatar_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/avatar/index.js
- /* istanbul ignore next */
- avatar_src_main.install = function (Vue) {
- Vue.component(avatar_src_main.name, avatar_src_main);
- };
- /* harmony default export */ var avatar = (avatar_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/drawer/src/main.vue?vue&type=template&id=a4885264&
- var mainvue_type_template_id_a4885264_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "transition",
- {
- attrs: { name: "el-drawer-fade" },
- on: { "after-enter": _vm.afterEnter, "after-leave": _vm.afterLeave }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-drawer__wrapper",
- attrs: { tabindex: "-1" }
- },
- [
- _c(
- "div",
- {
- staticClass: "el-drawer__container",
- class: _vm.visible && "el-drawer__open",
- attrs: { role: "document", tabindex: "-1" },
- on: {
- click: function($event) {
- if ($event.target !== $event.currentTarget) {
- return null
- }
- return _vm.handleWrapperClick($event)
- }
- }
- },
- [
- _c(
- "div",
- {
- ref: "drawer",
- staticClass: "el-drawer",
- class: [_vm.direction, _vm.customClass],
- style: _vm.isHorizontal
- ? "width: " + _vm.drawerSize
- : "height: " + _vm.drawerSize,
- attrs: {
- "aria-modal": "true",
- "aria-labelledby": "el-drawer__title",
- "aria-label": _vm.title,
- role: "dialog",
- tabindex: "-1"
- }
- },
- [
- _vm.withHeader
- ? _c(
- "header",
- {
- staticClass: "el-drawer__header",
- attrs: { id: "el-drawer__title" }
- },
- [
- _vm._t("title", [
- _c(
- "span",
- { attrs: { role: "heading", title: _vm.title } },
- [_vm._v(_vm._s(_vm.title))]
- )
- ]),
- _vm.showClose
- ? _c(
- "button",
- {
- staticClass: "el-drawer__close-btn",
- attrs: {
- "aria-label":
- "close " + (_vm.title || "drawer"),
- type: "button"
- },
- on: { click: _vm.closeDrawer }
- },
- [
- _c("i", {
- staticClass:
- "el-dialog__close el-icon el-icon-close"
- })
- ]
- )
- : _vm._e()
- ],
- 2
- )
- : _vm._e(),
- _vm.rendered
- ? _c(
- "section",
- { staticClass: "el-drawer__body" },
- [_vm._t("default")],
- 2
- )
- : _vm._e()
- ]
- )
- ]
- )
- ]
- )
- ]
- )
- }
- var mainvue_type_template_id_a4885264_staticRenderFns = []
- mainvue_type_template_id_a4885264_render._withStripped = true
- // CONCATENATED MODULE: ./packages/drawer/src/main.vue?vue&type=template&id=a4885264&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/drawer/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var drawer_src_mainvue_type_script_lang_js_ = ({
- name: 'ElDrawer',
- mixins: [popup_default.a, emitter_default.a],
- props: {
- appendToBody: {
- type: Boolean,
- default: false
- },
- beforeClose: {
- type: Function
- },
- customClass: {
- type: String,
- default: ''
- },
- closeOnPressEscape: {
- type: Boolean,
- default: true
- },
- destroyOnClose: {
- type: Boolean,
- default: false
- },
- modal: {
- type: Boolean,
- default: true
- },
- direction: {
- type: String,
- default: 'rtl',
- validator: function validator(val) {
- return ['ltr', 'rtl', 'ttb', 'btt'].indexOf(val) !== -1;
- }
- },
- modalAppendToBody: {
- type: Boolean,
- default: true
- },
- showClose: {
- type: Boolean,
- default: true
- },
- size: {
- type: [Number, String],
- default: '30%'
- },
- title: {
- type: String,
- default: ''
- },
- visible: {
- type: Boolean
- },
- wrapperClosable: {
- type: Boolean,
- default: true
- },
- withHeader: {
- type: Boolean,
- default: true
- }
- },
- computed: {
- isHorizontal: function isHorizontal() {
- return this.direction === 'rtl' || this.direction === 'ltr';
- },
- drawerSize: function drawerSize() {
- return typeof this.size === 'number' ? this.size + 'px' : this.size;
- }
- },
- data: function data() {
- return {
- closed: false,
- prevActiveElement: null
- };
- },
- watch: {
- visible: function visible(val) {
- var _this = this;
- if (val) {
- this.closed = false;
- this.$emit('open');
- if (this.appendToBody) {
- document.body.appendChild(this.$el);
- }
- this.prevActiveElement = document.activeElement;
- } else {
- if (!this.closed) {
- this.$emit('close');
- if (this.destroyOnClose === true) {
- this.rendered = false;
- }
- }
- this.$nextTick(function () {
- if (_this.prevActiveElement) {
- _this.prevActiveElement.focus();
- }
- });
- }
- }
- },
- methods: {
- afterEnter: function afterEnter() {
- this.$emit('opened');
- },
- afterLeave: function afterLeave() {
- this.$emit('closed');
- },
- hide: function hide(cancel) {
- if (cancel !== false) {
- this.$emit('update:visible', false);
- this.$emit('close');
- if (this.destroyOnClose === true) {
- this.rendered = false;
- }
- this.closed = true;
- }
- },
- handleWrapperClick: function handleWrapperClick() {
- if (this.wrapperClosable) {
- this.closeDrawer();
- }
- },
- closeDrawer: function closeDrawer() {
- if (typeof this.beforeClose === 'function') {
- this.beforeClose(this.hide);
- } else {
- this.hide();
- }
- },
- handleClose: function handleClose() {
- // This method here will be called by PopupManger, when the `closeOnPressEscape` was set to true
- // pressing `ESC` will call this method, and also close the drawer.
- // This method also calls `beforeClose` if there was one.
- this.closeDrawer();
- }
- },
- mounted: function mounted() {
- if (this.visible) {
- this.rendered = true;
- this.open();
- if (this.appendToBody) {
- document.body.appendChild(this.$el);
- }
- }
- },
- destroyed: function destroyed() {
- // if appendToBody is true, remove DOM node after destroy
- if (this.appendToBody && this.$el && this.$el.parentNode) {
- this.$el.parentNode.removeChild(this.$el);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/drawer/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_drawer_src_mainvue_type_script_lang_js_ = (drawer_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/drawer/src/main.vue
- /* normalize component */
- var drawer_src_main_component = normalizeComponent(
- packages_drawer_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_a4885264_render,
- mainvue_type_template_id_a4885264_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var drawer_src_main_api; }
- drawer_src_main_component.options.__file = "packages/drawer/src/main.vue"
- /* harmony default export */ var drawer_src_main = (drawer_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/drawer/index.js
- /* istanbul ignore next */
- drawer_src_main.install = function (Vue) {
- Vue.component(drawer_src_main.name, drawer_src_main);
- };
- /* harmony default export */ var drawer = (drawer_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/statistic/src/main.vue?vue&type=template&id=76339aa7&
- var mainvue_type_template_id_76339aa7_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("div", { staticClass: "el-statistic" }, [
- _vm.title || _vm.$slots.title
- ? _c(
- "div",
- { staticClass: "head" },
- [
- _vm._t("title", [
- _c("span", { staticClass: "title" }, [
- _vm._v("\n " + _vm._s(_vm.title) + "\n ")
- ])
- ])
- ],
- 2
- )
- : _vm._e(),
- _c("div", { staticClass: "con" }, [
- _vm.prefix || _vm.$slots.prefix
- ? _c(
- "span",
- { staticClass: "prefix" },
- [
- _vm._t("prefix", [
- _vm._v("\n " + _vm._s(_vm.prefix) + "\n ")
- ])
- ],
- 2
- )
- : _vm._e(),
- _c(
- "span",
- { staticClass: "number", style: _vm.valueStyle },
- [_vm._t("formatter", [_vm._v(" " + _vm._s(_vm.disposeValue))])],
- 2
- ),
- _vm.suffix || _vm.$slots.suffix
- ? _c(
- "span",
- { staticClass: "suffix" },
- [
- _vm._t("suffix", [
- _vm._v("\n " + _vm._s(_vm.suffix) + "\n ")
- ])
- ],
- 2
- )
- : _vm._e()
- ])
- ])
- }
- var mainvue_type_template_id_76339aa7_staticRenderFns = []
- mainvue_type_template_id_76339aa7_render._withStripped = true
- // CONCATENATED MODULE: ./packages/statistic/src/main.vue?vue&type=template&id=76339aa7&
- // EXTERNAL MODULE: external "element-ui/lib/utils/lodash"
- var lodash_ = __webpack_require__(28);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/statistic/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var statistic_src_mainvue_type_script_lang_js_ = ({
- name: 'ElStatistic',
- data: function data() {
- return {
- disposeValue: '',
- timeTask: null,
- REFRESH_INTERVAL: 1000 / 30
- };
- },
- props: {
- decimalSeparator: {
- type: String,
- default: '.'
- },
- groupSeparator: {
- type: String,
- default: ''
- },
- precision: {
- type: Number,
- default: null
- },
- value: {
- type: [String, Number, Date],
- default: ''
- },
- prefix: {
- type: String,
- default: ''
- },
- suffix: {
- type: String,
- default: ''
- },
- title: {
- type: [String, Number],
- default: ''
- },
- timeIndices: {
- type: Boolean,
- default: false
- },
- valueStyle: {
- type: Object,
- default: function _default() {
- return {};
- }
- },
- format: {
- type: String,
- default: 'HH:mm:ss:SSS'
- },
- rate: {
- type: Number,
- default: 1000
- }
- },
- created: function created() {
- this.branch();
- },
- watch: {
- value: function value() {
- this.branch();
- },
- groupSeparator: function groupSeparator() {
- this.dispose();
- },
- mulriple: function mulriple() {
- this.dispose();
- }
- },
- methods: {
- branch: function branch() {
- var timeIndices = this.timeIndices,
- countDown = this.countDown,
- dispose = this.dispose;
- if (timeIndices) {
- countDown(this.value.valueOf() || this.value);
- } else {
- dispose();
- }
- },
- magnification: function magnification(num) {
- var mulriple = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1000;
- var groupSeparator = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : ',';
- // magnification factor
- var level = String(mulriple).length;
- return num.replace(new RegExp('(\\d)(?=(\\d{' + (level - 1) + '})+$)', 'g'), '$1' + groupSeparator);
- },
- dispose: function dispose() {
- var value = this.value,
- rate = this.rate,
- groupSeparator = this.groupSeparator;
- if (!Object(lodash_["isNumber"])(value)) return false;
- if (this.precision) {
- value = value.toFixed(this.precision);
- }
- var _String$split = String(value).split('.'),
- integer = _String$split[0],
- decimal = _String$split[1];
- // 1000 multiplying power
- if (groupSeparator) {
- integer = this.magnification(integer, rate, groupSeparator);
- }
- var result = '' + integer + (decimal ? this.decimalSeparator + decimal : '');
- this.disposeValue = result;
- return result;
- },
- diffDate: function diffDate(minuend, subtrahend) {
- return Math.max(minuend - subtrahend, 0);
- },
- suspend: function suspend(isStop) {
- if (isStop) {
- if (this.timeTask) {
- clearInterval(this.timeTask);
- this.timeTask = null;
- }
- } else {
- this.branch();
- }
- return this.disposeValue;
- },
- formatTimeStr: function formatTimeStr(time) {
- var format = this.format;
- var escapeRegex = /\[[^\]]*]/g;
- var keepList = (format.match(escapeRegex) || []).map(function (str) {
- return str.slice(1, -1);
- });
- var timeUnits = [['Y', 1000 * 60 * 60 * 24 * 365], // years
- ['M', 1000 * 60 * 60 * 24 * 30], // months
- ['D', 1000 * 60 * 60 * 24], // days
- ['H', 1000 * 60 * 60], // hours
- ['m', 1000 * 60], // minutes
- ['s', 1000], // seconds
- ['S', 1] // million seconds
- ];
- var formatText = Object(lodash_["reduce"])(timeUnits, function (con, item) {
- var name = item[0];
- return con.replace(new RegExp(name + '+', 'g'), function (match) {
- var sum = Object(lodash_["chain"])(time).divide(item[1]).floor(0).value();
- time -= Object(lodash_["multiply"])(sum, item[1]);
- return Object(lodash_["padStart"])(String(sum), String(match).length, 0);
- });
- }, format);
- var index = 0;
- return formatText.replace(escapeRegex, function () {
- var match = keepList[index];
- index += 1;
- return match;
- });
- },
- stopTime: function stopTime(time) {
- var result = true; // stop
- if (time) {
- this.$emit('change', time);
- result = false;
- } else {
- result = true;
- this.suspend(true);
- this.$emit('finish', true);
- }
- return result;
- },
- countDown: function countDown(timeVlaue) {
- var REFRESH_INTERVAL = this.REFRESH_INTERVAL,
- timeTask = this.timeTask,
- diffDate = this.diffDate,
- formatTimeStr = this.formatTimeStr,
- stopTime = this.stopTime,
- suspend = this.suspend;
- if (timeTask) return;
- var than = this;
- this.timeTask = setInterval(function () {
- var diffTiem = diffDate(timeVlaue, Date.now());
- than.disposeValue = formatTimeStr(diffTiem);
- stopTime(diffTiem);
- }, REFRESH_INTERVAL);
- this.$once('hook:beforeDestroy', function () {
- suspend(true);
- });
- }
- }
- });
- // CONCATENATED MODULE: ./packages/statistic/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_statistic_src_mainvue_type_script_lang_js_ = (statistic_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/statistic/src/main.vue
- /* normalize component */
- var statistic_src_main_component = normalizeComponent(
- packages_statistic_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_76339aa7_render,
- mainvue_type_template_id_76339aa7_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var statistic_src_main_api; }
- statistic_src_main_component.options.__file = "packages/statistic/src/main.vue"
- /* harmony default export */ var statistic_src_main = (statistic_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/statistic/index.js
- /* istanbul ignore next */
- statistic_src_main.install = function (Vue) {
- Vue.component(statistic_src_main.name, statistic_src_main);
- };
- /* harmony default export */ var statistic = (statistic_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/popconfirm/src/main.vue?vue&type=template&id=048de730&
- var mainvue_type_template_id_048de730_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "el-popover",
- _vm._b(
- {
- attrs: { trigger: "click" },
- model: {
- value: _vm.visible,
- callback: function($$v) {
- _vm.visible = $$v
- },
- expression: "visible"
- }
- },
- "el-popover",
- _vm.$attrs,
- false
- ),
- [
- _c("div", { staticClass: "el-popconfirm" }, [
- _c("p", { staticClass: "el-popconfirm__main" }, [
- !_vm.hideIcon
- ? _c("i", {
- staticClass: "el-popconfirm__icon",
- class: _vm.icon,
- style: { color: _vm.iconColor }
- })
- : _vm._e(),
- _vm._v("\n " + _vm._s(_vm.title) + "\n ")
- ]),
- _c(
- "div",
- { staticClass: "el-popconfirm__action" },
- [
- _c(
- "el-button",
- {
- attrs: { size: "mini", type: _vm.cancelButtonType },
- on: { click: _vm.cancel }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.displayCancelButtonText) +
- "\n "
- )
- ]
- ),
- _c(
- "el-button",
- {
- attrs: { size: "mini", type: _vm.confirmButtonType },
- on: { click: _vm.confirm }
- },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.displayConfirmButtonText) +
- "\n "
- )
- ]
- )
- ],
- 1
- )
- ]),
- _vm._t("reference", null, { slot: "reference" })
- ],
- 2
- )
- }
- var mainvue_type_template_id_048de730_staticRenderFns = []
- mainvue_type_template_id_048de730_render._withStripped = true
- // CONCATENATED MODULE: ./packages/popconfirm/src/main.vue?vue&type=template&id=048de730&
- // EXTERNAL MODULE: external "element-ui/lib/popover"
- var popover_ = __webpack_require__(45);
- var popover_default = /*#__PURE__*/__webpack_require__.n(popover_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/popconfirm/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var popconfirm_src_mainvue_type_script_lang_js_ = ({
- name: 'ElPopconfirm',
- props: {
- title: {
- type: String
- },
- confirmButtonText: {
- type: String
- },
- cancelButtonText: {
- type: String
- },
- confirmButtonType: {
- type: String,
- default: 'primary'
- },
- cancelButtonType: {
- type: String,
- default: 'text'
- },
- icon: {
- type: String,
- default: 'el-icon-question'
- },
- iconColor: {
- type: String,
- default: '#f90'
- },
- hideIcon: {
- type: Boolean,
- default: false
- }
- },
- components: {
- ElPopover: popover_default.a,
- ElButton: button_default.a
- },
- data: function data() {
- return {
- visible: false
- };
- },
- computed: {
- displayConfirmButtonText: function displayConfirmButtonText() {
- return this.confirmButtonText || Object(lib_locale_["t"])('el.popconfirm.confirmButtonText');
- },
- displayCancelButtonText: function displayCancelButtonText() {
- return this.cancelButtonText || Object(lib_locale_["t"])('el.popconfirm.cancelButtonText');
- }
- },
- methods: {
- confirm: function confirm() {
- this.visible = false;
- this.$emit('confirm');
- },
- cancel: function cancel() {
- this.visible = false;
- this.$emit('cancel');
- }
- }
- });
- // CONCATENATED MODULE: ./packages/popconfirm/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_popconfirm_src_mainvue_type_script_lang_js_ = (popconfirm_src_mainvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/popconfirm/src/main.vue
- /* normalize component */
- var popconfirm_src_main_component = normalizeComponent(
- packages_popconfirm_src_mainvue_type_script_lang_js_,
- mainvue_type_template_id_048de730_render,
- mainvue_type_template_id_048de730_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var popconfirm_src_main_api; }
- popconfirm_src_main_component.options.__file = "packages/popconfirm/src/main.vue"
- /* harmony default export */ var popconfirm_src_main = (popconfirm_src_main_component.exports);
- // CONCATENATED MODULE: ./packages/popconfirm/index.js
- /* istanbul ignore next */
- popconfirm_src_main.install = function (Vue) {
- Vue.component(popconfirm_src_main.name, popconfirm_src_main);
- };
- /* harmony default export */ var popconfirm = (popconfirm_src_main);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/skeleton/src/index.vue?vue&type=template&id=7f659269&
- var srcvue_type_template_id_7f659269_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- [
- _vm.uiLoading
- ? [
- _c(
- "div",
- _vm._b(
- { class: ["el-skeleton", _vm.animated ? "is-animated" : ""] },
- "div",
- _vm.$attrs,
- false
- ),
- [
- _vm._l(_vm.count, function(i) {
- return [
- _vm.loading
- ? _vm._t(
- "template",
- _vm._l(_vm.rows, function(item) {
- return _c("el-skeleton-item", {
- key: i + "-" + item,
- class: {
- "el-skeleton__paragraph": item !== 1,
- "is-first": item === 1,
- "is-last": item === _vm.rows && _vm.rows > 1
- },
- attrs: { variant: "p" }
- })
- })
- )
- : _vm._e()
- ]
- })
- ],
- 2
- )
- ]
- : [_vm._t("default", null, null, _vm.$attrs)]
- ],
- 2
- )
- }
- var srcvue_type_template_id_7f659269_staticRenderFns = []
- srcvue_type_template_id_7f659269_render._withStripped = true
- // CONCATENATED MODULE: ./packages/skeleton/src/index.vue?vue&type=template&id=7f659269&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/skeleton/src/index.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var skeleton_srcvue_type_script_lang_js_ = ({
- name: 'ElSkeleton',
- props: {
- animated: {
- type: Boolean,
- default: false
- },
- count: {
- type: Number,
- default: 1
- },
- rows: {
- type: Number,
- default: 4
- },
- loading: {
- type: Boolean,
- default: true
- },
- throttle: {
- type: Number,
- default: 0
- }
- },
- watch: {
- loading: {
- handler: function handler(loading) {
- var _this = this;
- if (this.throttle <= 0) {
- this.uiLoading = loading;
- return;
- }
- if (loading) {
- clearTimeout(this.timeoutHandle);
- this.timeoutHandle = setTimeout(function () {
- _this.uiLoading = _this.loading;
- }, this.throttle);
- } else {
- this.uiLoading = loading;
- }
- },
- immediate: true
- }
- },
- data: function data() {
- return {
- uiLoading: this.throttle <= 0 ? this.loading : false
- };
- }
- });
- // CONCATENATED MODULE: ./packages/skeleton/src/index.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_skeleton_srcvue_type_script_lang_js_ = (skeleton_srcvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/skeleton/src/index.vue
- /* normalize component */
- var skeleton_src_component = normalizeComponent(
- packages_skeleton_srcvue_type_script_lang_js_,
- srcvue_type_template_id_7f659269_render,
- srcvue_type_template_id_7f659269_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var skeleton_src_api; }
- skeleton_src_component.options.__file = "packages/skeleton/src/index.vue"
- /* harmony default export */ var skeleton_src = (skeleton_src_component.exports);
- // CONCATENATED MODULE: ./packages/skeleton/index.js
- /* istanbul ignore next */
- skeleton_src.install = function (Vue) {
- Vue.component(skeleton_src.name, skeleton_src);
- };
- /* harmony default export */ var skeleton = (skeleton_src);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/skeleton/src/item.vue?vue&type=template&id=4bc8804c&
- var itemvue_type_template_id_4bc8804c_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- { class: ["el-skeleton__item", "el-skeleton__" + _vm.variant] },
- [_vm.variant === "image" ? _c("img-placeholder") : _vm._e()],
- 1
- )
- }
- var itemvue_type_template_id_4bc8804c_staticRenderFns = []
- itemvue_type_template_id_4bc8804c_render._withStripped = true
- // CONCATENATED MODULE: ./packages/skeleton/src/item.vue?vue&type=template&id=4bc8804c&
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/skeleton/src/img-placeholder.vue?vue&type=template&id=1b2cb5c0&
- var img_placeholdervue_type_template_id_1b2cb5c0_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "svg",
- {
- attrs: { viewBox: "0 0 1024 1024", xmlns: "http://www.w3.org/2000/svg" }
- },
- [
- _c("path", {
- attrs: {
- d:
- "M64 896V128h896v768H64z m64-128l192-192 116.352 116.352L640 448l256 307.2V192H128v576z m224-480a96 96 0 1 1-0.064 192.064A96 96 0 0 1 352 288z"
- }
- })
- ]
- )
- }
- var img_placeholdervue_type_template_id_1b2cb5c0_staticRenderFns = []
- img_placeholdervue_type_template_id_1b2cb5c0_render._withStripped = true
- // CONCATENATED MODULE: ./packages/skeleton/src/img-placeholder.vue?vue&type=template&id=1b2cb5c0&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/skeleton/src/img-placeholder.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var img_placeholdervue_type_script_lang_js_ = ({
- name: 'ImgPlaceholder'
- });
- // CONCATENATED MODULE: ./packages/skeleton/src/img-placeholder.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_img_placeholdervue_type_script_lang_js_ = (img_placeholdervue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/skeleton/src/img-placeholder.vue
- /* normalize component */
- var img_placeholder_component = normalizeComponent(
- src_img_placeholdervue_type_script_lang_js_,
- img_placeholdervue_type_template_id_1b2cb5c0_render,
- img_placeholdervue_type_template_id_1b2cb5c0_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var img_placeholder_api; }
- img_placeholder_component.options.__file = "packages/skeleton/src/img-placeholder.vue"
- /* harmony default export */ var img_placeholder = (img_placeholder_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/skeleton/src/item.vue?vue&type=script&lang=js&
- var _components;
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var skeleton_src_itemvue_type_script_lang_js_ = ({
- name: 'ElSkeletonItem',
- props: {
- variant: {
- type: String,
- default: 'text'
- }
- },
- components: (_components = {}, _components[img_placeholder.name] = img_placeholder, _components)
- });
- // CONCATENATED MODULE: ./packages/skeleton/src/item.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_skeleton_src_itemvue_type_script_lang_js_ = (skeleton_src_itemvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/skeleton/src/item.vue
- /* normalize component */
- var skeleton_src_item_component = normalizeComponent(
- packages_skeleton_src_itemvue_type_script_lang_js_,
- itemvue_type_template_id_4bc8804c_render,
- itemvue_type_template_id_4bc8804c_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var skeleton_src_item_api; }
- skeleton_src_item_component.options.__file = "packages/skeleton/src/item.vue"
- /* harmony default export */ var skeleton_src_item = (skeleton_src_item_component.exports);
- // CONCATENATED MODULE: ./packages/skeleton-item/index.js
- /* istanbul ignore next */
- skeleton_src_item.install = function (Vue) {
- Vue.component(skeleton_src_item.name, skeleton_src_item);
- };
- /* harmony default export */ var skeleton_item = (skeleton_src_item);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/empty/src/index.vue?vue&type=template&id=347ced91&
- var srcvue_type_template_id_347ced91_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("div", { staticClass: "el-empty" }, [
- _c(
- "div",
- { staticClass: "el-empty__image", style: _vm.imageStyle },
- [
- _vm.image
- ? _c("img", {
- attrs: { src: _vm.image, ondragstart: "return false" }
- })
- : _vm._t("image", [_c("img-empty")])
- ],
- 2
- ),
- _c(
- "div",
- { staticClass: "el-empty__description" },
- [
- _vm.$slots.description
- ? _vm._t("description")
- : _c("p", [_vm._v(_vm._s(_vm.emptyDescription))])
- ],
- 2
- ),
- _vm.$slots.default
- ? _c("div", { staticClass: "el-empty__bottom" }, [_vm._t("default")], 2)
- : _vm._e()
- ])
- }
- var srcvue_type_template_id_347ced91_staticRenderFns = []
- srcvue_type_template_id_347ced91_render._withStripped = true
- // CONCATENATED MODULE: ./packages/empty/src/index.vue?vue&type=template&id=347ced91&
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/empty/src/img-empty.vue?vue&type=template&id=42918b82&
- var img_emptyvue_type_template_id_42918b82_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "svg",
- {
- attrs: {
- viewBox: "0 0 79 86",
- version: "1.1",
- xmlns: "http://www.w3.org/2000/svg",
- "xmlns:xlink": "http://www.w3.org/1999/xlink"
- }
- },
- [
- _c(
- "defs",
- [
- _c(
- "linearGradient",
- {
- attrs: {
- id: "linearGradient-1-" + _vm.id,
- x1: "38.8503086%",
- y1: "0%",
- x2: "61.1496914%",
- y2: "100%"
- }
- },
- [
- _c("stop", { attrs: { "stop-color": "#FCFCFD", offset: "0%" } }),
- _c("stop", { attrs: { "stop-color": "#EEEFF3", offset: "100%" } })
- ],
- 1
- ),
- _c(
- "linearGradient",
- {
- attrs: {
- id: "linearGradient-2-" + _vm.id,
- x1: "0%",
- y1: "9.5%",
- x2: "100%",
- y2: "90.5%"
- }
- },
- [
- _c("stop", { attrs: { "stop-color": "#FCFCFD", offset: "0%" } }),
- _c("stop", { attrs: { "stop-color": "#E9EBEF", offset: "100%" } })
- ],
- 1
- ),
- _c("rect", {
- attrs: {
- id: "path-3-" + _vm.id,
- x: "0",
- y: "0",
- width: "17",
- height: "36"
- }
- })
- ],
- 1
- ),
- _c(
- "g",
- {
- attrs: {
- id: "Illustrations",
- stroke: "none",
- "stroke-width": "1",
- fill: "none",
- "fill-rule": "evenodd"
- }
- },
- [
- _c(
- "g",
- {
- attrs: {
- id: "B-type",
- transform: "translate(-1268.000000, -535.000000)"
- }
- },
- [
- _c(
- "g",
- {
- attrs: {
- id: "Group-2",
- transform: "translate(1268.000000, 535.000000)"
- }
- },
- [
- _c("path", {
- attrs: {
- id: "Oval-Copy-2",
- d:
- "M39.5,86 C61.3152476,86 79,83.9106622 79,81.3333333 C79,78.7560045 57.3152476,78 35.5,78 C13.6847524,78 0,78.7560045 0,81.3333333 C0,83.9106622 17.6847524,86 39.5,86 Z",
- fill: "#F7F8FC"
- }
- }),
- _c("polygon", {
- attrs: {
- id: "Rectangle-Copy-14",
- fill: "#E5E7E9",
- transform:
- "translate(27.500000, 51.500000) scale(1, -1) translate(-27.500000, -51.500000) ",
- points: "13 58 53 58 42 45 2 45"
- }
- }),
- _c(
- "g",
- {
- attrs: {
- id: "Group-Copy",
- transform:
- "translate(34.500000, 31.500000) scale(-1, 1) rotate(-25.000000) translate(-34.500000, -31.500000) translate(7.000000, 10.000000)"
- }
- },
- [
- _c("polygon", {
- attrs: {
- id: "Rectangle-Copy-10",
- fill: "#E5E7E9",
- transform:
- "translate(11.500000, 5.000000) scale(1, -1) translate(-11.500000, -5.000000) ",
- points: "2.84078316e-14 3 18 3 23 7 5 7"
- }
- }),
- _c("polygon", {
- attrs: {
- id: "Rectangle-Copy-11",
- fill: "#EDEEF2",
- points:
- "-3.69149156e-15 7 38 7 38 43 -3.69149156e-15 43"
- }
- }),
- _c("rect", {
- attrs: {
- id: "Rectangle-Copy-12",
- fill: "url(#linearGradient-1-" + _vm.id + ")",
- transform:
- "translate(46.500000, 25.000000) scale(-1, 1) translate(-46.500000, -25.000000) ",
- x: "38",
- y: "7",
- width: "17",
- height: "36"
- }
- }),
- _c("polygon", {
- attrs: {
- id: "Rectangle-Copy-13",
- fill: "#F8F9FB",
- transform:
- "translate(39.500000, 3.500000) scale(-1, 1) translate(-39.500000, -3.500000) ",
- points:
- "24 7 41 7 55 -3.63806207e-12 38 -3.63806207e-12"
- }
- })
- ]
- ),
- _c("rect", {
- attrs: {
- id: "Rectangle-Copy-15",
- fill: "url(#linearGradient-2-" + _vm.id + ")",
- x: "13",
- y: "45",
- width: "40",
- height: "36"
- }
- }),
- _c(
- "g",
- {
- attrs: {
- id: "Rectangle-Copy-17",
- transform: "translate(53.000000, 45.000000)"
- }
- },
- [
- _c(
- "mask",
- { attrs: { id: "mask-4-" + _vm.id, fill: "white" } },
- [
- _c("use", {
- attrs: { "xlink:href": "#path-3-" + _vm.id }
- })
- ]
- ),
- _c("use", {
- attrs: {
- id: "Mask",
- fill: "#E0E3E9",
- transform:
- "translate(8.500000, 18.000000) scale(-1, 1) translate(-8.500000, -18.000000) ",
- "xlink:href": "#path-3-" + _vm.id
- }
- }),
- _c("polygon", {
- attrs: {
- id: "Rectangle-Copy",
- fill: "#D5D7DE",
- mask: "url(#mask-4-" + _vm.id + ")",
- transform:
- "translate(12.000000, 9.000000) scale(-1, 1) translate(-12.000000, -9.000000) ",
- points: "7 0 24 0 20 18 -1.70530257e-13 16"
- }
- })
- ]
- ),
- _c("polygon", {
- attrs: {
- id: "Rectangle-Copy-18",
- fill: "#F8F9FB",
- transform:
- "translate(66.000000, 51.500000) scale(-1, 1) translate(-66.000000, -51.500000) ",
- points: "62 45 79 45 70 58 53 58"
- }
- })
- ]
- )
- ]
- )
- ]
- )
- ]
- )
- }
- var img_emptyvue_type_template_id_42918b82_staticRenderFns = []
- img_emptyvue_type_template_id_42918b82_render._withStripped = true
- // CONCATENATED MODULE: ./packages/empty/src/img-empty.vue?vue&type=template&id=42918b82&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/empty/src/img-empty.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var img_emptyvue_type_script_lang_js_id = 0;
- /* harmony default export */ var img_emptyvue_type_script_lang_js_ = ({
- name: 'ImgEmpty',
- data: function data() {
- return {
- id: ++img_emptyvue_type_script_lang_js_id
- };
- }
- });
- // CONCATENATED MODULE: ./packages/empty/src/img-empty.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_img_emptyvue_type_script_lang_js_ = (img_emptyvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/empty/src/img-empty.vue
- /* normalize component */
- var img_empty_component = normalizeComponent(
- src_img_emptyvue_type_script_lang_js_,
- img_emptyvue_type_template_id_42918b82_render,
- img_emptyvue_type_template_id_42918b82_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var img_empty_api; }
- img_empty_component.options.__file = "packages/empty/src/img-empty.vue"
- /* harmony default export */ var img_empty = (img_empty_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/empty/src/index.vue?vue&type=script&lang=js&
- var srcvue_type_script_lang_js_components;
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var empty_srcvue_type_script_lang_js_ = ({
- name: 'ElEmpty',
- components: (srcvue_type_script_lang_js_components = {}, srcvue_type_script_lang_js_components[img_empty.name] = img_empty, srcvue_type_script_lang_js_components),
- props: {
- image: {
- type: String,
- default: ''
- },
- imageSize: Number,
- description: {
- type: String,
- default: ''
- }
- },
- computed: {
- emptyDescription: function emptyDescription() {
- return this.description || Object(lib_locale_["t"])('el.empty.description');
- },
- imageStyle: function imageStyle() {
- return {
- width: this.imageSize ? this.imageSize + 'px' : ''
- };
- }
- }
- });
- // CONCATENATED MODULE: ./packages/empty/src/index.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_empty_srcvue_type_script_lang_js_ = (empty_srcvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/empty/src/index.vue
- /* normalize component */
- var empty_src_component = normalizeComponent(
- packages_empty_srcvue_type_script_lang_js_,
- srcvue_type_template_id_347ced91_render,
- srcvue_type_template_id_347ced91_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var empty_src_api; }
- empty_src_component.options.__file = "packages/empty/src/index.vue"
- /* harmony default export */ var empty_src = (empty_src_component.exports);
- // CONCATENATED MODULE: ./packages/empty/index.js
- empty_src.install = function (Vue) {
- Vue.component(empty_src.name, empty_src);
- };
- /* harmony default export */ var empty = (empty_src);
- // CONCATENATED MODULE: ./packages/descriptions/src/descriptions-row.js
- var descriptions_row_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- /* harmony default export */ var descriptions_row = ({
- name: 'ElDescriptionsRow',
- props: {
- row: {
- type: Array
- }
- },
- inject: ['elDescriptions'],
- render: function render(h) {
- var elDescriptions = this.elDescriptions;
- var row = (this.row || []).map(function (item) {
- return descriptions_row_extends({}, item, {
- label: item.slots.label || item.props.label
- }, ['labelClassName', 'contentClassName', 'labelStyle', 'contentStyle'].reduce(function (res, key) {
- res[key] = item.props[key] || elDescriptions[key];
- return res;
- }, {}));
- });
- if (elDescriptions.direction === 'vertical') {
- return h('tbody', [h(
- 'tr',
- { 'class': 'el-descriptions-row' },
- [row.map(function (item) {
- var _ref;
- return h(
- 'th',
- {
- 'class': (_ref = {
- 'el-descriptions-item__cell': true,
- 'el-descriptions-item__label': true,
- 'has-colon': elDescriptions.border ? false : elDescriptions.colon,
- 'is-bordered-label': elDescriptions.border
- }, _ref[item.labelClassName] = true, _ref),
- style: item.labelStyle,
- attrs: { colSpan: item.props.span
- }
- },
- [item.label]
- );
- })]
- ), h(
- 'tr',
- { 'class': 'el-descriptions-row' },
- [row.map(function (item) {
- return h(
- 'td',
- {
- 'class': ['el-descriptions-item__cell', 'el-descriptions-item__content', item.contentClassName],
- style: item.contentStyle,
- attrs: { colSpan: item.props.span
- }
- },
- [item.slots.default]
- );
- })]
- )]);
- }
- if (elDescriptions.border) {
- return h('tbody', [h(
- 'tr',
- { 'class': 'el-descriptions-row' },
- [row.map(function (item) {
- var _ref2;
- return [h(
- 'th',
- {
- 'class': (_ref2 = {
- 'el-descriptions-item__cell': true,
- 'el-descriptions-item__label': true,
- 'is-bordered-label': elDescriptions.border
- }, _ref2[item.labelClassName] = true, _ref2),
- style: item.labelStyle,
- attrs: { colSpan: '1'
- }
- },
- [item.label]
- ), h(
- 'td',
- {
- 'class': ['el-descriptions-item__cell', 'el-descriptions-item__content', item.contentClassName],
- style: item.contentStyle,
- attrs: { colSpan: item.props.span * 2 - 1
- }
- },
- [item.slots.default]
- )];
- })]
- )]);
- }
- return h('tbody', [h(
- 'tr',
- { 'class': 'el-descriptions-row' },
- [row.map(function (item) {
- var _ref3;
- return h(
- 'td',
- { 'class': 'el-descriptions-item el-descriptions-item__cell', attrs: { colSpan: item.props.span }
- },
- [h(
- 'div',
- { 'class': 'el-descriptions-item__container' },
- [h(
- 'span',
- {
- 'class': (_ref3 = {
- 'el-descriptions-item__label': true,
- 'has-colon': elDescriptions.colon
- }, _ref3[item.labelClassName] = true, _ref3),
- style: item.labelStyle
- },
- [item.label]
- ), h(
- 'span',
- {
- 'class': ['el-descriptions-item__content', item.contentClassName],
- style: item.contentStyle
- },
- [item.slots.default]
- )]
- )]
- );
- })]
- )]);
- }
- });
- // CONCATENATED MODULE: ./packages/descriptions/src/index.js
- var src_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- var src_components;
- /* harmony default export */ var descriptions_src = ({
- name: 'ElDescriptions',
- components: (src_components = {}, src_components[descriptions_row.name] = descriptions_row, src_components),
- props: {
- border: {
- type: Boolean,
- default: false
- },
- column: {
- type: Number,
- default: 3
- },
- direction: {
- type: String,
- default: 'horizontal'
- },
- size: {
- type: String
- // validator: isValidComponentSize,
- },
- title: {
- type: String,
- default: ''
- },
- extra: {
- type: String,
- default: ''
- },
- labelStyle: {
- type: Object
- },
- contentStyle: {
- type: Object
- },
- labelClassName: {
- type: String,
- default: ''
- },
- contentClassName: {
- type: String,
- default: ''
- },
- colon: {
- type: Boolean,
- default: true
- }
- },
- computed: {
- descriptionsSize: function descriptionsSize() {
- return this.size || (this.$ELEMENT || {}).size;
- }
- },
- provide: function provide() {
- return {
- elDescriptions: this
- };
- },
- methods: {
- getOptionProps: function getOptionProps(vnode) {
- if (vnode.componentOptions) {
- var componentOptions = vnode.componentOptions;
- var _componentOptions$pro = componentOptions.propsData,
- propsData = _componentOptions$pro === undefined ? {} : _componentOptions$pro,
- _componentOptions$Cto = componentOptions.Ctor,
- Ctor = _componentOptions$Cto === undefined ? {} : _componentOptions$Cto;
- var props = (Ctor.options || {}).props || {};
- var res = {};
- for (var k in props) {
- var v = props[k];
- var defaultValue = v.default;
- if (defaultValue !== undefined) {
- res[k] = Object(types_["isFunction"])(defaultValue) ? defaultValue.call(vnode) : defaultValue;
- }
- }
- return src_extends({}, res, propsData);
- }
- return {};
- },
- getSlots: function getSlots(vnode) {
- var _this = this;
- var componentOptions = vnode.componentOptions || {};
- var children = vnode.children || componentOptions.children || [];
- var slots = {};
- children.forEach(function (child) {
- if (!_this.isEmptyElement(child)) {
- var name = child.data && child.data.slot || 'default';
- slots[name] = slots[name] || [];
- if (child.tag === 'template') {
- slots[name].push(child.children);
- } else {
- slots[name].push(child);
- }
- }
- });
- return src_extends({}, slots);
- },
- isEmptyElement: function isEmptyElement(c) {
- return !(c.tag || c.text && c.text.trim() !== '');
- },
- filledNode: function filledNode(node, span, count) {
- var isLast = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
- if (!node.props) {
- node.props = {};
- }
- if (span > count) {
- node.props.span = count;
- }
- if (isLast) {
- // set the max span, cause of the last td
- node.props.span = count;
- }
- return node;
- },
- getRows: function getRows() {
- var _this2 = this;
- var children = (this.$slots.default || []).filter(function (vnode) {
- return vnode.tag && vnode.componentOptions && vnode.componentOptions.Ctor.options.name === 'ElDescriptionsItem';
- });
- var nodes = children.map(function (vnode) {
- return {
- props: _this2.getOptionProps(vnode),
- slots: _this2.getSlots(vnode),
- vnode: vnode
- };
- });
- var rows = [];
- var temp = [];
- var count = this.column;
- nodes.forEach(function (node, index) {
- var span = node.props.span || 1;
- if (index === children.length - 1) {
- temp.push(_this2.filledNode(node, span, count, true));
- rows.push(temp);
- return;
- }
- if (span < count) {
- count -= span;
- temp.push(node);
- } else {
- temp.push(_this2.filledNode(node, span, count));
- rows.push(temp);
- count = _this2.column;
- temp = [];
- }
- });
- return rows;
- }
- },
- render: function render() {
- var h = arguments[0];
- var title = this.title,
- extra = this.extra,
- border = this.border,
- descriptionsSize = this.descriptionsSize,
- $slots = this.$slots;
- var rows = this.getRows();
- return h(
- 'div',
- { 'class': 'el-descriptions' },
- [title || extra || $slots.title || $slots.extra ? h(
- 'div',
- { 'class': 'el-descriptions__header' },
- [h(
- 'div',
- { 'class': 'el-descriptions__title' },
- [$slots.title ? $slots.title : title]
- ), h(
- 'div',
- { 'class': 'el-descriptions__extra' },
- [$slots.extra ? $slots.extra : extra]
- )]
- ) : null, h(
- 'div',
- { 'class': 'el-descriptions__body' },
- [h(
- 'table',
- { 'class': ['el-descriptions__table', { 'is-bordered': border }, descriptionsSize ? 'el-descriptions--' + descriptionsSize : ''] },
- [rows.map(function (row) {
- return h(descriptions_row, {
- attrs: { row: row }
- });
- })]
- )]
- )]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/descriptions/index.js
- /* istanbul ignore next */
- descriptions_src.install = function install(Vue) {
- Vue.component(descriptions_src.name, descriptions_src);
- };
- /* harmony default export */ var descriptions = (descriptions_src);
- // CONCATENATED MODULE: ./packages/descriptions/src/descriptions-item.js
- /* harmony default export */ var descriptions_item = ({
- name: 'ElDescriptionsItem',
- props: {
- label: {
- type: String,
- default: ''
- },
- span: {
- type: Number,
- default: 1
- },
- contentClassName: {
- type: String,
- default: ''
- },
- contentStyle: {
- type: Object
- },
- labelClassName: {
- type: String,
- default: ''
- },
- labelStyle: {
- type: Object
- }
- },
- render: function render() {
- return null;
- }
- });
- // CONCATENATED MODULE: ./packages/descriptions-item/index.js
- /* istanbul ignore next */
- descriptions_item.install = function install(Vue) {
- Vue.component(descriptions_item.name, descriptions_item);
- };
- /* harmony default export */ var packages_descriptions_item = (descriptions_item);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/result/src/index.vue?vue&type=template&id=3408b139&
- var srcvue_type_template_id_3408b139_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("div", { staticClass: "el-result" }, [
- _c(
- "div",
- { staticClass: "el-result__icon" },
- [
- _vm._t("icon", [
- _c(_vm.iconElement, { tag: "component", class: _vm.iconElement })
- ])
- ],
- 2
- ),
- _vm.title || _vm.$slots.title
- ? _c(
- "div",
- { staticClass: "el-result__title" },
- [_vm._t("title", [_c("p", [_vm._v(_vm._s(_vm.title))])])],
- 2
- )
- : _vm._e(),
- _vm.subTitle || _vm.$slots.subTitle
- ? _c(
- "div",
- { staticClass: "el-result__subtitle" },
- [_vm._t("subTitle", [_c("p", [_vm._v(_vm._s(_vm.subTitle))])])],
- 2
- )
- : _vm._e(),
- _vm.$slots.extra
- ? _c("div", { staticClass: "el-result__extra" }, [_vm._t("extra")], 2)
- : _vm._e()
- ])
- }
- var srcvue_type_template_id_3408b139_staticRenderFns = []
- srcvue_type_template_id_3408b139_render._withStripped = true
- // CONCATENATED MODULE: ./packages/result/src/index.vue?vue&type=template&id=3408b139&
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/result/src/icon-success.vue?vue&type=template&id=18119418&
- var icon_successvue_type_template_id_18119418_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "svg",
- { attrs: { viewBox: "0 0 48 48", xmlns: "http://www.w3.org/2000/svg" } },
- [
- _c("path", {
- attrs: {
- d:
- "M24,4 C35.045695,4 44,12.954305 44,24 C44,35.045695 35.045695,44 24,44 C12.954305,44 4,35.045695 4,24 C4,12.954305 12.954305,4 24,4 Z M34.5548098,16.4485711 C33.9612228,15.8504763 32.9988282,15.8504763 32.4052412,16.4485711 L32.4052412,16.4485711 L21.413757,27.5805811 L21.413757,27.5805811 L21.4034642,27.590855 C21.0097542,27.9781674 20.3766105,27.9729811 19.9892981,27.5792711 L19.9892981,27.5792711 L15.5947588,23.1121428 C15.0011718,22.514048 14.0387772,22.514048 13.4451902,23.1121428 C12.8516033,23.7102376 12.8516033,24.6799409 13.4451902,25.2780357 L13.4451902,25.2780357 L19.6260786,31.5514289 C20.2196656,32.1495237 21.1820602,32.1495237 21.7756472,31.5514289 L21.7756472,31.5514289 L34.5548098,18.614464 C35.1483967,18.0163692 35.1483967,17.0466659 34.5548098,16.4485711 Z"
- }
- })
- ]
- )
- }
- var icon_successvue_type_template_id_18119418_staticRenderFns = []
- icon_successvue_type_template_id_18119418_render._withStripped = true
- // CONCATENATED MODULE: ./packages/result/src/icon-success.vue?vue&type=template&id=18119418&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/result/src/icon-success.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var icon_successvue_type_script_lang_js_ = ({
- name: 'IconSuccess'
- });
- // CONCATENATED MODULE: ./packages/result/src/icon-success.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_icon_successvue_type_script_lang_js_ = (icon_successvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/result/src/icon-success.vue
- /* normalize component */
- var icon_success_component = normalizeComponent(
- src_icon_successvue_type_script_lang_js_,
- icon_successvue_type_template_id_18119418_render,
- icon_successvue_type_template_id_18119418_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var icon_success_api; }
- icon_success_component.options.__file = "packages/result/src/icon-success.vue"
- /* harmony default export */ var icon_success = (icon_success_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/result/src/icon-error.vue?vue&type=template&id=21199246&
- var icon_errorvue_type_template_id_21199246_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "svg",
- { attrs: { viewBox: "0 0 48 48", xmlns: "http://www.w3.org/2000/svg" } },
- [
- _c("path", {
- attrs: {
- d:
- "M24,4 C35.045695,4 44,12.954305 44,24 C44,35.045695 35.045695,44 24,44 C12.954305,44 4,35.045695 4,24 C4,12.954305 12.954305,4 24,4 Z M32.57818,15.42182 C32.0157534,14.8593933 31.1038797,14.8593933 30.541453,15.42182 L30.541453,15.42182 L24.0006789,21.9625941 L17.458547,15.42182 C16.8961203,14.8593933 15.9842466,14.8593933 15.42182,15.42182 C14.8593933,15.9842466 14.8593933,16.8961203 15.42182,17.458547 L15.42182,17.458547 L21.9639519,23.9993211 L15.42182,30.541453 C14.8593933,31.1038797 14.8593933,32.0157534 15.42182,32.57818 C15.9842466,33.1406067 16.8961203,33.1406067 17.458547,32.57818 L17.458547,32.57818 L24.0006789,26.0360481 L30.541453,32.57818 C31.1038797,33.1406067 32.0157534,33.1406067 32.57818,32.57818 C33.1406067,32.0157534 33.1406067,31.1038797 32.57818,30.541453 L32.57818,30.541453 L26.0374059,23.9993211 L32.57818,17.458547 C33.1406067,16.8961203 33.1406067,15.9842466 32.57818,15.42182 Z"
- }
- })
- ]
- )
- }
- var icon_errorvue_type_template_id_21199246_staticRenderFns = []
- icon_errorvue_type_template_id_21199246_render._withStripped = true
- // CONCATENATED MODULE: ./packages/result/src/icon-error.vue?vue&type=template&id=21199246&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/result/src/icon-error.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var icon_errorvue_type_script_lang_js_ = ({
- name: 'IconError'
- });
- // CONCATENATED MODULE: ./packages/result/src/icon-error.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_icon_errorvue_type_script_lang_js_ = (icon_errorvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/result/src/icon-error.vue
- /* normalize component */
- var icon_error_component = normalizeComponent(
- src_icon_errorvue_type_script_lang_js_,
- icon_errorvue_type_template_id_21199246_render,
- icon_errorvue_type_template_id_21199246_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var icon_error_api; }
- icon_error_component.options.__file = "packages/result/src/icon-error.vue"
- /* harmony default export */ var icon_error = (icon_error_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/result/src/icon-warning.vue?vue&type=template&id=46fe8f31&
- var icon_warningvue_type_template_id_46fe8f31_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "svg",
- { attrs: { viewBox: "0 0 48 48", xmlns: "http://www.w3.org/2000/svg" } },
- [
- _c("path", {
- attrs: {
- d:
- "M24,4 C35.045695,4 44,12.954305 44,24 C44,35.045695 35.045695,44 24,44 C12.954305,44 4,35.045695 4,24 C4,12.954305 12.954305,4 24,4 Z M24,31 C22.8954305,31 22,31.8954305 22,33 C22,34.1045695 22.8954305,35 24,35 C25.1045695,35 26,34.1045695 26,33 C26,31.8954305 25.1045695,31 24,31 Z M24,14 C23.1715729,14 22.5,14.6715729 22.5,15.5 L22.5,15.5 L22.5,27.5 C22.5,28.3284271 23.1715729,29 24,29 C24.8284271,29 25.5,28.3284271 25.5,27.5 L25.5,27.5 L25.5,15.5 C25.5,14.6715729 24.8284271,14 24,14 Z"
- }
- })
- ]
- )
- }
- var icon_warningvue_type_template_id_46fe8f31_staticRenderFns = []
- icon_warningvue_type_template_id_46fe8f31_render._withStripped = true
- // CONCATENATED MODULE: ./packages/result/src/icon-warning.vue?vue&type=template&id=46fe8f31&
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib??vue-loader-options!./packages/result/src/icon-warning.vue?vue&type=script&lang=ts&
- /* harmony default export */ var icon_warningvue_type_script_lang_ts_ = ({
- name: 'IconWarning'
- });
- // CONCATENATED MODULE: ./packages/result/src/icon-warning.vue?vue&type=script&lang=ts&
- /* harmony default export */ var src_icon_warningvue_type_script_lang_ts_ = (icon_warningvue_type_script_lang_ts_);
- // CONCATENATED MODULE: ./packages/result/src/icon-warning.vue
- /* normalize component */
- var icon_warning_component = normalizeComponent(
- src_icon_warningvue_type_script_lang_ts_,
- icon_warningvue_type_template_id_46fe8f31_render,
- icon_warningvue_type_template_id_46fe8f31_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var icon_warning_api; }
- icon_warning_component.options.__file = "packages/result/src/icon-warning.vue"
- /* harmony default export */ var icon_warning = (icon_warning_component.exports);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/result/src/icon-info.vue?vue&type=template&id=19e3de69&
- var icon_infovue_type_template_id_19e3de69_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "svg",
- { attrs: { viewBox: "0 0 48 48", xmlns: "http://www.w3.org/2000/svg" } },
- [
- _c("path", {
- attrs: {
- d:
- "M24,4 C35.045695,4 44,12.954305 44,24 C44,35.045695 35.045695,44 24,44 C12.954305,44 4,35.045695 4,24 C4,12.954305 12.954305,4 24,4 Z M24,19 L21,19 C20.1715729,19 19.5,19.6715729 19.5,20.5 C19.5,21.3284271 20.1715729,22 21,22 L21,22 L22.5,22 L22.5,31 L21,31 C20.1715729,31 19.5,31.6715729 19.5,32.5 C19.5,33.3284271 20.1715729,34 21,34 L21,34 L27,34 C27.8284271,34 28.5,33.3284271 28.5,32.5 C28.5,31.6715729 27.8284271,31 27,31 L27,31 L25.5,31 L25.5,20.5 C25.5,19.6715729 24.8284271,19 24,19 L24,19 Z M24,13 C22.8954305,13 22,13.8954305 22,15 C22,16.1045695 22.8954305,17 24,17 C25.1045695,17 26,16.1045695 26,15 C26,13.8954305 25.1045695,13 24,13 Z"
- }
- })
- ]
- )
- }
- var icon_infovue_type_template_id_19e3de69_staticRenderFns = []
- icon_infovue_type_template_id_19e3de69_render._withStripped = true
- // CONCATENATED MODULE: ./packages/result/src/icon-info.vue?vue&type=template&id=19e3de69&
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib??vue-loader-options!./packages/result/src/icon-info.vue?vue&type=script&lang=ts&
- /* harmony default export */ var icon_infovue_type_script_lang_ts_ = ({
- name: 'IconInfo'
- });
- // CONCATENATED MODULE: ./packages/result/src/icon-info.vue?vue&type=script&lang=ts&
- /* harmony default export */ var src_icon_infovue_type_script_lang_ts_ = (icon_infovue_type_script_lang_ts_);
- // CONCATENATED MODULE: ./packages/result/src/icon-info.vue
- /* normalize component */
- var icon_info_component = normalizeComponent(
- src_icon_infovue_type_script_lang_ts_,
- icon_infovue_type_template_id_19e3de69_render,
- icon_infovue_type_template_id_19e3de69_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var icon_info_api; }
- icon_info_component.options.__file = "packages/result/src/icon-info.vue"
- /* harmony default export */ var icon_info = (icon_info_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/result/src/index.vue?vue&type=script&lang=js&
- var result_srcvue_type_script_lang_js_components;
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var IconMap = {
- success: 'icon-success',
- warning: 'icon-warning',
- error: 'icon-error',
- info: 'icon-info'
- };
- /* harmony default export */ var result_srcvue_type_script_lang_js_ = ({
- name: 'ElResult',
- components: (result_srcvue_type_script_lang_js_components = {}, result_srcvue_type_script_lang_js_components[icon_success.name] = icon_success, result_srcvue_type_script_lang_js_components[icon_error.name] = icon_error, result_srcvue_type_script_lang_js_components[icon_warning.name] = icon_warning, result_srcvue_type_script_lang_js_components[icon_info.name] = icon_info, result_srcvue_type_script_lang_js_components),
- props: {
- title: {
- type: String,
- default: ''
- },
- subTitle: {
- type: String,
- default: ''
- },
- icon: {
- type: String,
- default: 'info'
- }
- },
- computed: {
- iconElement: function iconElement() {
- var icon = this.icon;
- return icon && IconMap[icon] ? IconMap[icon] : 'icon-info';
- }
- }
- });
- // CONCATENATED MODULE: ./packages/result/src/index.vue?vue&type=script&lang=js&
- /* harmony default export */ var packages_result_srcvue_type_script_lang_js_ = (result_srcvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/result/src/index.vue
- /* normalize component */
- var result_src_component = normalizeComponent(
- packages_result_srcvue_type_script_lang_js_,
- srcvue_type_template_id_3408b139_render,
- srcvue_type_template_id_3408b139_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var result_src_api; }
- result_src_component.options.__file = "packages/result/src/index.vue"
- /* harmony default export */ var result_src = (result_src_component.exports);
- // CONCATENATED MODULE: ./packages/result/index.js
- /* istanbul ignore next */
- result_src.install = function (Vue) {
- Vue.component(result_src.name, result_src);
- };
- /* harmony default export */ var packages_result = (result_src);
- // CONCATENATED MODULE: ./src/index.js
- /* Automatically generated by './build/bin/build-entry.js' */
- var components = [packages_pagination, dialog, packages_autocomplete, packages_dropdown, packages_dropdown_menu, packages_dropdown_item, packages_menu, packages_submenu, packages_menu_item, packages_menu_item_group, packages_input, packages_input_number, packages_radio, packages_radio_group, packages_radio_button, packages_checkbox, packages_checkbox_button, packages_checkbox_group, packages_switch, packages_select, packages_option, packages_option_group, packages_button, packages_button_group, packages_table, packages_table_column, packages_date_picker, packages_time_select, packages_time_picker, popover, packages_tooltip, packages_breadcrumb, packages_breadcrumb_item, packages_form, packages_form_item, packages_tabs, packages_tab_pane, packages_tag, packages_tree, packages_alert, slider, packages_icon, packages_row, packages_col, packages_upload, packages_progress, packages_spinner, badge, card, packages_rate, packages_steps, packages_step, carousel, scrollbar, carousel_item, packages_collapse, packages_collapse_item, packages_cascader, color_picker, transfer, packages_container, header, aside, packages_main, footer, timeline, timeline_item, packages_link, divider, packages_image, calendar, backtop, page_header, packages_cascader_panel, avatar, drawer, statistic, popconfirm, skeleton, skeleton_item, empty, descriptions, packages_descriptions_item, packages_result, collapse_transition_default.a];
- var src_install = function install(Vue) {
- var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
- lib_locale_default.a.use(opts.locale);
- lib_locale_default.a.i18n(opts.i18n);
- components.forEach(function (component) {
- Vue.component(component.name, component);
- });
- Vue.use(infinite_scroll);
- Vue.use(packages_loading.directive);
- Vue.prototype.$ELEMENT = {
- size: opts.size || '',
- zIndex: opts.zIndex || 2000
- };
- Vue.prototype.$loading = packages_loading.service;
- Vue.prototype.$msgbox = message_box;
- Vue.prototype.$alert = message_box.alert;
- Vue.prototype.$confirm = message_box.confirm;
- Vue.prototype.$prompt = message_box.prompt;
- Vue.prototype.$notify = notification;
- Vue.prototype.$message = packages_message;
- };
- /* istanbul ignore if */
- if (typeof window !== 'undefined' && window.Vue) {
- src_install(window.Vue);
- }
- /* harmony default export */ var src_0 = __webpack_exports__["default"] = ({
- version: '2.15.14',
- locale: lib_locale_default.a.use,
- i18n: lib_locale_default.a.i18n,
- install: src_install,
- CollapseTransition: collapse_transition_default.a,
- Loading: packages_loading,
- Pagination: packages_pagination,
- Dialog: dialog,
- Autocomplete: packages_autocomplete,
- Dropdown: packages_dropdown,
- DropdownMenu: packages_dropdown_menu,
- DropdownItem: packages_dropdown_item,
- Menu: packages_menu,
- Submenu: packages_submenu,
- MenuItem: packages_menu_item,
- MenuItemGroup: packages_menu_item_group,
- Input: packages_input,
- InputNumber: packages_input_number,
- Radio: packages_radio,
- RadioGroup: packages_radio_group,
- RadioButton: packages_radio_button,
- Checkbox: packages_checkbox,
- CheckboxButton: packages_checkbox_button,
- CheckboxGroup: packages_checkbox_group,
- Switch: packages_switch,
- Select: packages_select,
- Option: packages_option,
- OptionGroup: packages_option_group,
- Button: packages_button,
- ButtonGroup: packages_button_group,
- Table: packages_table,
- TableColumn: packages_table_column,
- DatePicker: packages_date_picker,
- TimeSelect: packages_time_select,
- TimePicker: packages_time_picker,
- Popover: popover,
- Tooltip: packages_tooltip,
- MessageBox: message_box,
- Breadcrumb: packages_breadcrumb,
- BreadcrumbItem: packages_breadcrumb_item,
- Form: packages_form,
- FormItem: packages_form_item,
- Tabs: packages_tabs,
- TabPane: packages_tab_pane,
- Tag: packages_tag,
- Tree: packages_tree,
- Alert: packages_alert,
- Notification: notification,
- Slider: slider,
- Icon: packages_icon,
- Row: packages_row,
- Col: packages_col,
- Upload: packages_upload,
- Progress: packages_progress,
- Spinner: packages_spinner,
- Message: packages_message,
- Badge: badge,
- Card: card,
- Rate: packages_rate,
- Steps: packages_steps,
- Step: packages_step,
- Carousel: carousel,
- Scrollbar: scrollbar,
- CarouselItem: carousel_item,
- Collapse: packages_collapse,
- CollapseItem: packages_collapse_item,
- Cascader: packages_cascader,
- ColorPicker: color_picker,
- Transfer: transfer,
- Container: packages_container,
- Header: header,
- Aside: aside,
- Main: packages_main,
- Footer: footer,
- Timeline: timeline,
- TimelineItem: timeline_item,
- Link: packages_link,
- Divider: divider,
- Image: packages_image,
- Calendar: calendar,
- Backtop: backtop,
- InfiniteScroll: infinite_scroll,
- PageHeader: page_header,
- CascaderPanel: packages_cascader_panel,
- Avatar: avatar,
- Drawer: drawer,
- Statistic: statistic,
- Popconfirm: popconfirm,
- Skeleton: skeleton,
- SkeletonItem: skeleton_item,
- Empty: empty,
- Descriptions: descriptions,
- DescriptionsItem: packages_descriptions_item,
- Result: packages_result
- });
- /***/ })
- /******/ ])["default"];
- /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(59)["URL"]))
- /***/ }),
- /* 8 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- function _broadcast(componentName, eventName, params) {
- this.$children.forEach(function (child) {
- var name = child.$options.componentName;
- if (name === componentName) {
- child.$emit.apply(child, [eventName].concat(params));
- } else {
- _broadcast.apply(child, [componentName, eventName].concat([params]));
- }
- });
- }
- exports.default = {
- methods: {
- dispatch: function dispatch(componentName, eventName, params) {
- var parent = this.$parent || this.$root;
- var name = parent.$options.componentName;
- while (parent && (!name || name !== componentName)) {
- parent = parent.$parent;
- if (parent) {
- name = parent.$options.componentName;
- }
- }
- if (parent) {
- parent.$emit.apply(parent, [eventName].concat(params));
- }
- },
- broadcast: function broadcast(componentName, eventName, params) {
- _broadcast.call(this, componentName, eventName, params);
- }
- }
- };
- /***/ }),
- /* 9 */
- /***/ (function(module, exports, __webpack_require__) {
- /* WEBPACK VAR INJECTION */(function(module) {/**
- * lodash (Custom Build) <https://lodash.com/>
- * Build: `lodash modularize exports="npm" -o ./`
- * Copyright jQuery Foundation and other contributors <https://jquery.org/>
- * Released under MIT license <https://lodash.com/license>
- * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>
- * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
- */
- /** Used as the size to enable large array optimizations. */
- var LARGE_ARRAY_SIZE = 200;
- /** Used to stand-in for `undefined` hash values. */
- var HASH_UNDEFINED = '__lodash_hash_undefined__';
- /** Used as references for various `Number` constants. */
- var MAX_SAFE_INTEGER = 9007199254740991;
- /** `Object#toString` result references. */
- var argsTag = '[object Arguments]',
- arrayTag = '[object Array]',
- boolTag = '[object Boolean]',
- dateTag = '[object Date]',
- errorTag = '[object Error]',
- funcTag = '[object Function]',
- genTag = '[object GeneratorFunction]',
- mapTag = '[object Map]',
- numberTag = '[object Number]',
- objectTag = '[object Object]',
- promiseTag = '[object Promise]',
- regexpTag = '[object RegExp]',
- setTag = '[object Set]',
- stringTag = '[object String]',
- symbolTag = '[object Symbol]',
- weakMapTag = '[object WeakMap]';
- var arrayBufferTag = '[object ArrayBuffer]',
- dataViewTag = '[object DataView]',
- float32Tag = '[object Float32Array]',
- float64Tag = '[object Float64Array]',
- int8Tag = '[object Int8Array]',
- int16Tag = '[object Int16Array]',
- int32Tag = '[object Int32Array]',
- uint8Tag = '[object Uint8Array]',
- uint8ClampedTag = '[object Uint8ClampedArray]',
- uint16Tag = '[object Uint16Array]',
- uint32Tag = '[object Uint32Array]';
- /**
- * Used to match `RegExp`
- * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).
- */
- var reRegExpChar = /[\\^$.*+?()[\]{}|]/g;
- /** Used to match `RegExp` flags from their coerced string values. */
- var reFlags = /\w*$/;
- /** Used to detect host constructors (Safari). */
- var reIsHostCtor = /^\[object .+?Constructor\]$/;
- /** Used to detect unsigned integer values. */
- var reIsUint = /^(?:0|[1-9]\d*)$/;
- /** Used to identify `toStringTag` values supported by `_.clone`. */
- var cloneableTags = {};
- cloneableTags[argsTag] = cloneableTags[arrayTag] =
- cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =
- cloneableTags[boolTag] = cloneableTags[dateTag] =
- cloneableTags[float32Tag] = cloneableTags[float64Tag] =
- cloneableTags[int8Tag] = cloneableTags[int16Tag] =
- cloneableTags[int32Tag] = cloneableTags[mapTag] =
- cloneableTags[numberTag] = cloneableTags[objectTag] =
- cloneableTags[regexpTag] = cloneableTags[setTag] =
- cloneableTags[stringTag] = cloneableTags[symbolTag] =
- cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =
- cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;
- cloneableTags[errorTag] = cloneableTags[funcTag] =
- cloneableTags[weakMapTag] = false;
- /** Detect free variable `global` from Node.js. */
- var freeGlobal = typeof global == 'object' && global && global.Object === Object && global;
- /** Detect free variable `self`. */
- var freeSelf = typeof self == 'object' && self && self.Object === Object && self;
- /** Used as a reference to the global object. */
- var root = freeGlobal || freeSelf || Function('return this')();
- /** Detect free variable `exports`. */
- var freeExports = true && exports && !exports.nodeType && exports;
- /** Detect free variable `module`. */
- var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;
- /** Detect the popular CommonJS extension `module.exports`. */
- var moduleExports = freeModule && freeModule.exports === freeExports;
- /**
- * Adds the key-value `pair` to `map`.
- *
- * @private
- * @param {Object} map The map to modify.
- * @param {Array} pair The key-value pair to add.
- * @returns {Object} Returns `map`.
- */
- function addMapEntry(map, pair) {
- // Don't return `map.set` because it's not chainable in IE 11.
- map.set(pair[0], pair[1]);
- return map;
- }
- /**
- * Adds `value` to `set`.
- *
- * @private
- * @param {Object} set The set to modify.
- * @param {*} value The value to add.
- * @returns {Object} Returns `set`.
- */
- function addSetEntry(set, value) {
- // Don't return `set.add` because it's not chainable in IE 11.
- set.add(value);
- return set;
- }
- /**
- * A specialized version of `_.forEach` for arrays without support for
- * iteratee shorthands.
- *
- * @private
- * @param {Array} [array] The array to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {Array} Returns `array`.
- */
- function arrayEach(array, iteratee) {
- var index = -1,
- length = array ? array.length : 0;
- while (++index < length) {
- if (iteratee(array[index], index, array) === false) {
- break;
- }
- }
- return array;
- }
- /**
- * Appends the elements of `values` to `array`.
- *
- * @private
- * @param {Array} array The array to modify.
- * @param {Array} values The values to append.
- * @returns {Array} Returns `array`.
- */
- function arrayPush(array, values) {
- var index = -1,
- length = values.length,
- offset = array.length;
- while (++index < length) {
- array[offset + index] = values[index];
- }
- return array;
- }
- /**
- * A specialized version of `_.reduce` for arrays without support for
- * iteratee shorthands.
- *
- * @private
- * @param {Array} [array] The array to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @param {*} [accumulator] The initial value.
- * @param {boolean} [initAccum] Specify using the first element of `array` as
- * the initial value.
- * @returns {*} Returns the accumulated value.
- */
- function arrayReduce(array, iteratee, accumulator, initAccum) {
- var index = -1,
- length = array ? array.length : 0;
- if (initAccum && length) {
- accumulator = array[++index];
- }
- while (++index < length) {
- accumulator = iteratee(accumulator, array[index], index, array);
- }
- return accumulator;
- }
- /**
- * The base implementation of `_.times` without support for iteratee shorthands
- * or max array length checks.
- *
- * @private
- * @param {number} n The number of times to invoke `iteratee`.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {Array} Returns the array of results.
- */
- function baseTimes(n, iteratee) {
- var index = -1,
- result = Array(n);
- while (++index < n) {
- result[index] = iteratee(index);
- }
- return result;
- }
- /**
- * Gets the value at `key` of `object`.
- *
- * @private
- * @param {Object} [object] The object to query.
- * @param {string} key The key of the property to get.
- * @returns {*} Returns the property value.
- */
- function getValue(object, key) {
- return object == null ? undefined : object[key];
- }
- /**
- * Checks if `value` is a host object in IE < 9.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a host object, else `false`.
- */
- function isHostObject(value) {
- // Many host objects are `Object` objects that can coerce to strings
- // despite having improperly defined `toString` methods.
- var result = false;
- if (value != null && typeof value.toString != 'function') {
- try {
- result = !!(value + '');
- } catch (e) {}
- }
- return result;
- }
- /**
- * Converts `map` to its key-value pairs.
- *
- * @private
- * @param {Object} map The map to convert.
- * @returns {Array} Returns the key-value pairs.
- */
- function mapToArray(map) {
- var index = -1,
- result = Array(map.size);
- map.forEach(function(value, key) {
- result[++index] = [key, value];
- });
- return result;
- }
- /**
- * Creates a unary function that invokes `func` with its argument transformed.
- *
- * @private
- * @param {Function} func The function to wrap.
- * @param {Function} transform The argument transform.
- * @returns {Function} Returns the new function.
- */
- function overArg(func, transform) {
- return function(arg) {
- return func(transform(arg));
- };
- }
- /**
- * Converts `set` to an array of its values.
- *
- * @private
- * @param {Object} set The set to convert.
- * @returns {Array} Returns the values.
- */
- function setToArray(set) {
- var index = -1,
- result = Array(set.size);
- set.forEach(function(value) {
- result[++index] = value;
- });
- return result;
- }
- /** Used for built-in method references. */
- var arrayProto = Array.prototype,
- funcProto = Function.prototype,
- objectProto = Object.prototype;
- /** Used to detect overreaching core-js shims. */
- var coreJsData = root['__core-js_shared__'];
- /** Used to detect methods masquerading as native. */
- var maskSrcKey = (function() {
- var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');
- return uid ? ('Symbol(src)_1.' + uid) : '';
- }());
- /** Used to resolve the decompiled source of functions. */
- var funcToString = funcProto.toString;
- /** Used to check objects for own properties. */
- var hasOwnProperty = objectProto.hasOwnProperty;
- /**
- * Used to resolve the
- * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
- * of values.
- */
- var objectToString = objectProto.toString;
- /** Used to detect if a method is native. */
- var reIsNative = RegExp('^' +
- funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\$&')
- .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$'
- );
- /** Built-in value references. */
- var Buffer = moduleExports ? root.Buffer : undefined,
- Symbol = root.Symbol,
- Uint8Array = root.Uint8Array,
- getPrototype = overArg(Object.getPrototypeOf, Object),
- objectCreate = Object.create,
- propertyIsEnumerable = objectProto.propertyIsEnumerable,
- splice = arrayProto.splice;
- /* Built-in method references for those with the same name as other `lodash` methods. */
- var nativeGetSymbols = Object.getOwnPropertySymbols,
- nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,
- nativeKeys = overArg(Object.keys, Object);
- /* Built-in method references that are verified to be native. */
- var DataView = getNative(root, 'DataView'),
- Map = getNative(root, 'Map'),
- Promise = getNative(root, 'Promise'),
- Set = getNative(root, 'Set'),
- WeakMap = getNative(root, 'WeakMap'),
- nativeCreate = getNative(Object, 'create');
- /** Used to detect maps, sets, and weakmaps. */
- var dataViewCtorString = toSource(DataView),
- mapCtorString = toSource(Map),
- promiseCtorString = toSource(Promise),
- setCtorString = toSource(Set),
- weakMapCtorString = toSource(WeakMap);
- /** Used to convert symbols to primitives and strings. */
- var symbolProto = Symbol ? Symbol.prototype : undefined,
- symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;
- /**
- * Creates a hash object.
- *
- * @private
- * @constructor
- * @param {Array} [entries] The key-value pairs to cache.
- */
- function Hash(entries) {
- var index = -1,
- length = entries ? entries.length : 0;
- this.clear();
- while (++index < length) {
- var entry = entries[index];
- this.set(entry[0], entry[1]);
- }
- }
- /**
- * Removes all key-value entries from the hash.
- *
- * @private
- * @name clear
- * @memberOf Hash
- */
- function hashClear() {
- this.__data__ = nativeCreate ? nativeCreate(null) : {};
- }
- /**
- * Removes `key` and its value from the hash.
- *
- * @private
- * @name delete
- * @memberOf Hash
- * @param {Object} hash The hash to modify.
- * @param {string} key The key of the value to remove.
- * @returns {boolean} Returns `true` if the entry was removed, else `false`.
- */
- function hashDelete(key) {
- return this.has(key) && delete this.__data__[key];
- }
- /**
- * Gets the hash value for `key`.
- *
- * @private
- * @name get
- * @memberOf Hash
- * @param {string} key The key of the value to get.
- * @returns {*} Returns the entry value.
- */
- function hashGet(key) {
- var data = this.__data__;
- if (nativeCreate) {
- var result = data[key];
- return result === HASH_UNDEFINED ? undefined : result;
- }
- return hasOwnProperty.call(data, key) ? data[key] : undefined;
- }
- /**
- * Checks if a hash value for `key` exists.
- *
- * @private
- * @name has
- * @memberOf Hash
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */
- function hashHas(key) {
- var data = this.__data__;
- return nativeCreate ? data[key] !== undefined : hasOwnProperty.call(data, key);
- }
- /**
- * Sets the hash `key` to `value`.
- *
- * @private
- * @name set
- * @memberOf Hash
- * @param {string} key The key of the value to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns the hash instance.
- */
- function hashSet(key, value) {
- var data = this.__data__;
- data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;
- return this;
- }
- // Add methods to `Hash`.
- Hash.prototype.clear = hashClear;
- Hash.prototype['delete'] = hashDelete;
- Hash.prototype.get = hashGet;
- Hash.prototype.has = hashHas;
- Hash.prototype.set = hashSet;
- /**
- * Creates an list cache object.
- *
- * @private
- * @constructor
- * @param {Array} [entries] The key-value pairs to cache.
- */
- function ListCache(entries) {
- var index = -1,
- length = entries ? entries.length : 0;
- this.clear();
- while (++index < length) {
- var entry = entries[index];
- this.set(entry[0], entry[1]);
- }
- }
- /**
- * Removes all key-value entries from the list cache.
- *
- * @private
- * @name clear
- * @memberOf ListCache
- */
- function listCacheClear() {
- this.__data__ = [];
- }
- /**
- * Removes `key` and its value from the list cache.
- *
- * @private
- * @name delete
- * @memberOf ListCache
- * @param {string} key The key of the value to remove.
- * @returns {boolean} Returns `true` if the entry was removed, else `false`.
- */
- function listCacheDelete(key) {
- var data = this.__data__,
- index = assocIndexOf(data, key);
- if (index < 0) {
- return false;
- }
- var lastIndex = data.length - 1;
- if (index == lastIndex) {
- data.pop();
- } else {
- splice.call(data, index, 1);
- }
- return true;
- }
- /**
- * Gets the list cache value for `key`.
- *
- * @private
- * @name get
- * @memberOf ListCache
- * @param {string} key The key of the value to get.
- * @returns {*} Returns the entry value.
- */
- function listCacheGet(key) {
- var data = this.__data__,
- index = assocIndexOf(data, key);
- return index < 0 ? undefined : data[index][1];
- }
- /**
- * Checks if a list cache value for `key` exists.
- *
- * @private
- * @name has
- * @memberOf ListCache
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */
- function listCacheHas(key) {
- return assocIndexOf(this.__data__, key) > -1;
- }
- /**
- * Sets the list cache `key` to `value`.
- *
- * @private
- * @name set
- * @memberOf ListCache
- * @param {string} key The key of the value to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns the list cache instance.
- */
- function listCacheSet(key, value) {
- var data = this.__data__,
- index = assocIndexOf(data, key);
- if (index < 0) {
- data.push([key, value]);
- } else {
- data[index][1] = value;
- }
- return this;
- }
- // Add methods to `ListCache`.
- ListCache.prototype.clear = listCacheClear;
- ListCache.prototype['delete'] = listCacheDelete;
- ListCache.prototype.get = listCacheGet;
- ListCache.prototype.has = listCacheHas;
- ListCache.prototype.set = listCacheSet;
- /**
- * Creates a map cache object to store key-value pairs.
- *
- * @private
- * @constructor
- * @param {Array} [entries] The key-value pairs to cache.
- */
- function MapCache(entries) {
- var index = -1,
- length = entries ? entries.length : 0;
- this.clear();
- while (++index < length) {
- var entry = entries[index];
- this.set(entry[0], entry[1]);
- }
- }
- /**
- * Removes all key-value entries from the map.
- *
- * @private
- * @name clear
- * @memberOf MapCache
- */
- function mapCacheClear() {
- this.__data__ = {
- 'hash': new Hash,
- 'map': new (Map || ListCache),
- 'string': new Hash
- };
- }
- /**
- * Removes `key` and its value from the map.
- *
- * @private
- * @name delete
- * @memberOf MapCache
- * @param {string} key The key of the value to remove.
- * @returns {boolean} Returns `true` if the entry was removed, else `false`.
- */
- function mapCacheDelete(key) {
- return getMapData(this, key)['delete'](key);
- }
- /**
- * Gets the map value for `key`.
- *
- * @private
- * @name get
- * @memberOf MapCache
- * @param {string} key The key of the value to get.
- * @returns {*} Returns the entry value.
- */
- function mapCacheGet(key) {
- return getMapData(this, key).get(key);
- }
- /**
- * Checks if a map value for `key` exists.
- *
- * @private
- * @name has
- * @memberOf MapCache
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */
- function mapCacheHas(key) {
- return getMapData(this, key).has(key);
- }
- /**
- * Sets the map `key` to `value`.
- *
- * @private
- * @name set
- * @memberOf MapCache
- * @param {string} key The key of the value to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns the map cache instance.
- */
- function mapCacheSet(key, value) {
- getMapData(this, key).set(key, value);
- return this;
- }
- // Add methods to `MapCache`.
- MapCache.prototype.clear = mapCacheClear;
- MapCache.prototype['delete'] = mapCacheDelete;
- MapCache.prototype.get = mapCacheGet;
- MapCache.prototype.has = mapCacheHas;
- MapCache.prototype.set = mapCacheSet;
- /**
- * Creates a stack cache object to store key-value pairs.
- *
- * @private
- * @constructor
- * @param {Array} [entries] The key-value pairs to cache.
- */
- function Stack(entries) {
- this.__data__ = new ListCache(entries);
- }
- /**
- * Removes all key-value entries from the stack.
- *
- * @private
- * @name clear
- * @memberOf Stack
- */
- function stackClear() {
- this.__data__ = new ListCache;
- }
- /**
- * Removes `key` and its value from the stack.
- *
- * @private
- * @name delete
- * @memberOf Stack
- * @param {string} key The key of the value to remove.
- * @returns {boolean} Returns `true` if the entry was removed, else `false`.
- */
- function stackDelete(key) {
- return this.__data__['delete'](key);
- }
- /**
- * Gets the stack value for `key`.
- *
- * @private
- * @name get
- * @memberOf Stack
- * @param {string} key The key of the value to get.
- * @returns {*} Returns the entry value.
- */
- function stackGet(key) {
- return this.__data__.get(key);
- }
- /**
- * Checks if a stack value for `key` exists.
- *
- * @private
- * @name has
- * @memberOf Stack
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */
- function stackHas(key) {
- return this.__data__.has(key);
- }
- /**
- * Sets the stack `key` to `value`.
- *
- * @private
- * @name set
- * @memberOf Stack
- * @param {string} key The key of the value to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns the stack cache instance.
- */
- function stackSet(key, value) {
- var cache = this.__data__;
- if (cache instanceof ListCache) {
- var pairs = cache.__data__;
- if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {
- pairs.push([key, value]);
- return this;
- }
- cache = this.__data__ = new MapCache(pairs);
- }
- cache.set(key, value);
- return this;
- }
- // Add methods to `Stack`.
- Stack.prototype.clear = stackClear;
- Stack.prototype['delete'] = stackDelete;
- Stack.prototype.get = stackGet;
- Stack.prototype.has = stackHas;
- Stack.prototype.set = stackSet;
- /**
- * Creates an array of the enumerable property names of the array-like `value`.
- *
- * @private
- * @param {*} value The value to query.
- * @param {boolean} inherited Specify returning inherited property names.
- * @returns {Array} Returns the array of property names.
- */
- function arrayLikeKeys(value, inherited) {
- // Safari 8.1 makes `arguments.callee` enumerable in strict mode.
- // Safari 9 makes `arguments.length` enumerable in strict mode.
- var result = (isArray(value) || isArguments(value))
- ? baseTimes(value.length, String)
- : [];
- var length = result.length,
- skipIndexes = !!length;
- for (var key in value) {
- if ((inherited || hasOwnProperty.call(value, key)) &&
- !(skipIndexes && (key == 'length' || isIndex(key, length)))) {
- result.push(key);
- }
- }
- return result;
- }
- /**
- * Assigns `value` to `key` of `object` if the existing value is not equivalent
- * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * for equality comparisons.
- *
- * @private
- * @param {Object} object The object to modify.
- * @param {string} key The key of the property to assign.
- * @param {*} value The value to assign.
- */
- function assignValue(object, key, value) {
- var objValue = object[key];
- if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||
- (value === undefined && !(key in object))) {
- object[key] = value;
- }
- }
- /**
- * Gets the index at which the `key` is found in `array` of key-value pairs.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {*} key The key to search for.
- * @returns {number} Returns the index of the matched value, else `-1`.
- */
- function assocIndexOf(array, key) {
- var length = array.length;
- while (length--) {
- if (eq(array[length][0], key)) {
- return length;
- }
- }
- return -1;
- }
- /**
- * The base implementation of `_.assign` without support for multiple sources
- * or `customizer` functions.
- *
- * @private
- * @param {Object} object The destination object.
- * @param {Object} source The source object.
- * @returns {Object} Returns `object`.
- */
- function baseAssign(object, source) {
- return object && copyObject(source, keys(source), object);
- }
- /**
- * The base implementation of `_.clone` and `_.cloneDeep` which tracks
- * traversed objects.
- *
- * @private
- * @param {*} value The value to clone.
- * @param {boolean} [isDeep] Specify a deep clone.
- * @param {boolean} [isFull] Specify a clone including symbols.
- * @param {Function} [customizer] The function to customize cloning.
- * @param {string} [key] The key of `value`.
- * @param {Object} [object] The parent object of `value`.
- * @param {Object} [stack] Tracks traversed objects and their clone counterparts.
- * @returns {*} Returns the cloned value.
- */
- function baseClone(value, isDeep, isFull, customizer, key, object, stack) {
- var result;
- if (customizer) {
- result = object ? customizer(value, key, object, stack) : customizer(value);
- }
- if (result !== undefined) {
- return result;
- }
- if (!isObject(value)) {
- return value;
- }
- var isArr = isArray(value);
- if (isArr) {
- result = initCloneArray(value);
- if (!isDeep) {
- return copyArray(value, result);
- }
- } else {
- var tag = getTag(value),
- isFunc = tag == funcTag || tag == genTag;
- if (isBuffer(value)) {
- return cloneBuffer(value, isDeep);
- }
- if (tag == objectTag || tag == argsTag || (isFunc && !object)) {
- if (isHostObject(value)) {
- return object ? value : {};
- }
- result = initCloneObject(isFunc ? {} : value);
- if (!isDeep) {
- return copySymbols(value, baseAssign(result, value));
- }
- } else {
- if (!cloneableTags[tag]) {
- return object ? value : {};
- }
- result = initCloneByTag(value, tag, baseClone, isDeep);
- }
- }
- // Check for circular references and return its corresponding clone.
- stack || (stack = new Stack);
- var stacked = stack.get(value);
- if (stacked) {
- return stacked;
- }
- stack.set(value, result);
- if (!isArr) {
- var props = isFull ? getAllKeys(value) : keys(value);
- }
- arrayEach(props || value, function(subValue, key) {
- if (props) {
- key = subValue;
- subValue = value[key];
- }
- // Recursively populate clone (susceptible to call stack limits).
- assignValue(result, key, baseClone(subValue, isDeep, isFull, customizer, key, value, stack));
- });
- return result;
- }
- /**
- * The base implementation of `_.create` without support for assigning
- * properties to the created object.
- *
- * @private
- * @param {Object} prototype The object to inherit from.
- * @returns {Object} Returns the new object.
- */
- function baseCreate(proto) {
- return isObject(proto) ? objectCreate(proto) : {};
- }
- /**
- * The base implementation of `getAllKeys` and `getAllKeysIn` which uses
- * `keysFunc` and `symbolsFunc` to get the enumerable property names and
- * symbols of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @param {Function} keysFunc The function to get the keys of `object`.
- * @param {Function} symbolsFunc The function to get the symbols of `object`.
- * @returns {Array} Returns the array of property names and symbols.
- */
- function baseGetAllKeys(object, keysFunc, symbolsFunc) {
- var result = keysFunc(object);
- return isArray(object) ? result : arrayPush(result, symbolsFunc(object));
- }
- /**
- * The base implementation of `getTag`.
- *
- * @private
- * @param {*} value The value to query.
- * @returns {string} Returns the `toStringTag`.
- */
- function baseGetTag(value) {
- return objectToString.call(value);
- }
- /**
- * The base implementation of `_.isNative` without bad shim checks.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a native function,
- * else `false`.
- */
- function baseIsNative(value) {
- if (!isObject(value) || isMasked(value)) {
- return false;
- }
- var pattern = (isFunction(value) || isHostObject(value)) ? reIsNative : reIsHostCtor;
- return pattern.test(toSource(value));
- }
- /**
- * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property names.
- */
- function baseKeys(object) {
- if (!isPrototype(object)) {
- return nativeKeys(object);
- }
- var result = [];
- for (var key in Object(object)) {
- if (hasOwnProperty.call(object, key) && key != 'constructor') {
- result.push(key);
- }
- }
- return result;
- }
- /**
- * Creates a clone of `buffer`.
- *
- * @private
- * @param {Buffer} buffer The buffer to clone.
- * @param {boolean} [isDeep] Specify a deep clone.
- * @returns {Buffer} Returns the cloned buffer.
- */
- function cloneBuffer(buffer, isDeep) {
- if (isDeep) {
- return buffer.slice();
- }
- var result = new buffer.constructor(buffer.length);
- buffer.copy(result);
- return result;
- }
- /**
- * Creates a clone of `arrayBuffer`.
- *
- * @private
- * @param {ArrayBuffer} arrayBuffer The array buffer to clone.
- * @returns {ArrayBuffer} Returns the cloned array buffer.
- */
- function cloneArrayBuffer(arrayBuffer) {
- var result = new arrayBuffer.constructor(arrayBuffer.byteLength);
- new Uint8Array(result).set(new Uint8Array(arrayBuffer));
- return result;
- }
- /**
- * Creates a clone of `dataView`.
- *
- * @private
- * @param {Object} dataView The data view to clone.
- * @param {boolean} [isDeep] Specify a deep clone.
- * @returns {Object} Returns the cloned data view.
- */
- function cloneDataView(dataView, isDeep) {
- var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;
- return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);
- }
- /**
- * Creates a clone of `map`.
- *
- * @private
- * @param {Object} map The map to clone.
- * @param {Function} cloneFunc The function to clone values.
- * @param {boolean} [isDeep] Specify a deep clone.
- * @returns {Object} Returns the cloned map.
- */
- function cloneMap(map, isDeep, cloneFunc) {
- var array = isDeep ? cloneFunc(mapToArray(map), true) : mapToArray(map);
- return arrayReduce(array, addMapEntry, new map.constructor);
- }
- /**
- * Creates a clone of `regexp`.
- *
- * @private
- * @param {Object} regexp The regexp to clone.
- * @returns {Object} Returns the cloned regexp.
- */
- function cloneRegExp(regexp) {
- var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));
- result.lastIndex = regexp.lastIndex;
- return result;
- }
- /**
- * Creates a clone of `set`.
- *
- * @private
- * @param {Object} set The set to clone.
- * @param {Function} cloneFunc The function to clone values.
- * @param {boolean} [isDeep] Specify a deep clone.
- * @returns {Object} Returns the cloned set.
- */
- function cloneSet(set, isDeep, cloneFunc) {
- var array = isDeep ? cloneFunc(setToArray(set), true) : setToArray(set);
- return arrayReduce(array, addSetEntry, new set.constructor);
- }
- /**
- * Creates a clone of the `symbol` object.
- *
- * @private
- * @param {Object} symbol The symbol object to clone.
- * @returns {Object} Returns the cloned symbol object.
- */
- function cloneSymbol(symbol) {
- return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};
- }
- /**
- * Creates a clone of `typedArray`.
- *
- * @private
- * @param {Object} typedArray The typed array to clone.
- * @param {boolean} [isDeep] Specify a deep clone.
- * @returns {Object} Returns the cloned typed array.
- */
- function cloneTypedArray(typedArray, isDeep) {
- var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;
- return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);
- }
- /**
- * Copies the values of `source` to `array`.
- *
- * @private
- * @param {Array} source The array to copy values from.
- * @param {Array} [array=[]] The array to copy values to.
- * @returns {Array} Returns `array`.
- */
- function copyArray(source, array) {
- var index = -1,
- length = source.length;
- array || (array = Array(length));
- while (++index < length) {
- array[index] = source[index];
- }
- return array;
- }
- /**
- * Copies properties of `source` to `object`.
- *
- * @private
- * @param {Object} source The object to copy properties from.
- * @param {Array} props The property identifiers to copy.
- * @param {Object} [object={}] The object to copy properties to.
- * @param {Function} [customizer] The function to customize copied values.
- * @returns {Object} Returns `object`.
- */
- function copyObject(source, props, object, customizer) {
- object || (object = {});
- var index = -1,
- length = props.length;
- while (++index < length) {
- var key = props[index];
- var newValue = customizer
- ? customizer(object[key], source[key], key, object, source)
- : undefined;
- assignValue(object, key, newValue === undefined ? source[key] : newValue);
- }
- return object;
- }
- /**
- * Copies own symbol properties of `source` to `object`.
- *
- * @private
- * @param {Object} source The object to copy symbols from.
- * @param {Object} [object={}] The object to copy symbols to.
- * @returns {Object} Returns `object`.
- */
- function copySymbols(source, object) {
- return copyObject(source, getSymbols(source), object);
- }
- /**
- * Creates an array of own enumerable property names and symbols of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property names and symbols.
- */
- function getAllKeys(object) {
- return baseGetAllKeys(object, keys, getSymbols);
- }
- /**
- * Gets the data for `map`.
- *
- * @private
- * @param {Object} map The map to query.
- * @param {string} key The reference key.
- * @returns {*} Returns the map data.
- */
- function getMapData(map, key) {
- var data = map.__data__;
- return isKeyable(key)
- ? data[typeof key == 'string' ? 'string' : 'hash']
- : data.map;
- }
- /**
- * Gets the native function at `key` of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @param {string} key The key of the method to get.
- * @returns {*} Returns the function if it's native, else `undefined`.
- */
- function getNative(object, key) {
- var value = getValue(object, key);
- return baseIsNative(value) ? value : undefined;
- }
- /**
- * Creates an array of the own enumerable symbol properties of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of symbols.
- */
- var getSymbols = nativeGetSymbols ? overArg(nativeGetSymbols, Object) : stubArray;
- /**
- * Gets the `toStringTag` of `value`.
- *
- * @private
- * @param {*} value The value to query.
- * @returns {string} Returns the `toStringTag`.
- */
- var getTag = baseGetTag;
- // Fallback for data views, maps, sets, and weak maps in IE 11,
- // for data views in Edge < 14, and promises in Node.js.
- if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||
- (Map && getTag(new Map) != mapTag) ||
- (Promise && getTag(Promise.resolve()) != promiseTag) ||
- (Set && getTag(new Set) != setTag) ||
- (WeakMap && getTag(new WeakMap) != weakMapTag)) {
- getTag = function(value) {
- var result = objectToString.call(value),
- Ctor = result == objectTag ? value.constructor : undefined,
- ctorString = Ctor ? toSource(Ctor) : undefined;
- if (ctorString) {
- switch (ctorString) {
- case dataViewCtorString: return dataViewTag;
- case mapCtorString: return mapTag;
- case promiseCtorString: return promiseTag;
- case setCtorString: return setTag;
- case weakMapCtorString: return weakMapTag;
- }
- }
- return result;
- };
- }
- /**
- * Initializes an array clone.
- *
- * @private
- * @param {Array} array The array to clone.
- * @returns {Array} Returns the initialized clone.
- */
- function initCloneArray(array) {
- var length = array.length,
- result = array.constructor(length);
- // Add properties assigned by `RegExp#exec`.
- if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {
- result.index = array.index;
- result.input = array.input;
- }
- return result;
- }
- /**
- * Initializes an object clone.
- *
- * @private
- * @param {Object} object The object to clone.
- * @returns {Object} Returns the initialized clone.
- */
- function initCloneObject(object) {
- return (typeof object.constructor == 'function' && !isPrototype(object))
- ? baseCreate(getPrototype(object))
- : {};
- }
- /**
- * Initializes an object clone based on its `toStringTag`.
- *
- * **Note:** This function only supports cloning values with tags of
- * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.
- *
- * @private
- * @param {Object} object The object to clone.
- * @param {string} tag The `toStringTag` of the object to clone.
- * @param {Function} cloneFunc The function to clone values.
- * @param {boolean} [isDeep] Specify a deep clone.
- * @returns {Object} Returns the initialized clone.
- */
- function initCloneByTag(object, tag, cloneFunc, isDeep) {
- var Ctor = object.constructor;
- switch (tag) {
- case arrayBufferTag:
- return cloneArrayBuffer(object);
- case boolTag:
- case dateTag:
- return new Ctor(+object);
- case dataViewTag:
- return cloneDataView(object, isDeep);
- case float32Tag: case float64Tag:
- case int8Tag: case int16Tag: case int32Tag:
- case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:
- return cloneTypedArray(object, isDeep);
- case mapTag:
- return cloneMap(object, isDeep, cloneFunc);
- case numberTag:
- case stringTag:
- return new Ctor(object);
- case regexpTag:
- return cloneRegExp(object);
- case setTag:
- return cloneSet(object, isDeep, cloneFunc);
- case symbolTag:
- return cloneSymbol(object);
- }
- }
- /**
- * Checks if `value` is a valid array-like index.
- *
- * @private
- * @param {*} value The value to check.
- * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.
- * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.
- */
- function isIndex(value, length) {
- length = length == null ? MAX_SAFE_INTEGER : length;
- return !!length &&
- (typeof value == 'number' || reIsUint.test(value)) &&
- (value > -1 && value % 1 == 0 && value < length);
- }
- /**
- * Checks if `value` is suitable for use as unique object key.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is suitable, else `false`.
- */
- function isKeyable(value) {
- var type = typeof value;
- return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')
- ? (value !== '__proto__')
- : (value === null);
- }
- /**
- * Checks if `func` has its source masked.
- *
- * @private
- * @param {Function} func The function to check.
- * @returns {boolean} Returns `true` if `func` is masked, else `false`.
- */
- function isMasked(func) {
- return !!maskSrcKey && (maskSrcKey in func);
- }
- /**
- * Checks if `value` is likely a prototype object.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.
- */
- function isPrototype(value) {
- var Ctor = value && value.constructor,
- proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;
- return value === proto;
- }
- /**
- * Converts `func` to its source code.
- *
- * @private
- * @param {Function} func The function to process.
- * @returns {string} Returns the source code.
- */
- function toSource(func) {
- if (func != null) {
- try {
- return funcToString.call(func);
- } catch (e) {}
- try {
- return (func + '');
- } catch (e) {}
- }
- return '';
- }
- /**
- * This method is like `_.clone` except that it recursively clones `value`.
- *
- * @static
- * @memberOf _
- * @since 1.0.0
- * @category Lang
- * @param {*} value The value to recursively clone.
- * @returns {*} Returns the deep cloned value.
- * @see _.clone
- * @example
- *
- * var objects = [{ 'a': 1 }, { 'b': 2 }];
- *
- * var deep = _.cloneDeep(objects);
- * console.log(deep[0] === objects[0]);
- * // => false
- */
- function cloneDeep(value) {
- return baseClone(value, true, true);
- }
- /**
- * Performs a
- * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * comparison between two values to determine if they are equivalent.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @returns {boolean} Returns `true` if the values are equivalent, else `false`.
- * @example
- *
- * var object = { 'a': 1 };
- * var other = { 'a': 1 };
- *
- * _.eq(object, object);
- * // => true
- *
- * _.eq(object, other);
- * // => false
- *
- * _.eq('a', 'a');
- * // => true
- *
- * _.eq('a', Object('a'));
- * // => false
- *
- * _.eq(NaN, NaN);
- * // => true
- */
- function eq(value, other) {
- return value === other || (value !== value && other !== other);
- }
- /**
- * Checks if `value` is likely an `arguments` object.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an `arguments` object,
- * else `false`.
- * @example
- *
- * _.isArguments(function() { return arguments; }());
- * // => true
- *
- * _.isArguments([1, 2, 3]);
- * // => false
- */
- function isArguments(value) {
- // Safari 8.1 makes `arguments.callee` enumerable in strict mode.
- return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') &&
- (!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag);
- }
- /**
- * Checks if `value` is classified as an `Array` object.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an array, else `false`.
- * @example
- *
- * _.isArray([1, 2, 3]);
- * // => true
- *
- * _.isArray(document.body.children);
- * // => false
- *
- * _.isArray('abc');
- * // => false
- *
- * _.isArray(_.noop);
- * // => false
- */
- var isArray = Array.isArray;
- /**
- * Checks if `value` is array-like. A value is considered array-like if it's
- * not a function and has a `value.length` that's an integer greater than or
- * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is array-like, else `false`.
- * @example
- *
- * _.isArrayLike([1, 2, 3]);
- * // => true
- *
- * _.isArrayLike(document.body.children);
- * // => true
- *
- * _.isArrayLike('abc');
- * // => true
- *
- * _.isArrayLike(_.noop);
- * // => false
- */
- function isArrayLike(value) {
- return value != null && isLength(value.length) && !isFunction(value);
- }
- /**
- * This method is like `_.isArrayLike` except that it also checks if `value`
- * is an object.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an array-like object,
- * else `false`.
- * @example
- *
- * _.isArrayLikeObject([1, 2, 3]);
- * // => true
- *
- * _.isArrayLikeObject(document.body.children);
- * // => true
- *
- * _.isArrayLikeObject('abc');
- * // => false
- *
- * _.isArrayLikeObject(_.noop);
- * // => false
- */
- function isArrayLikeObject(value) {
- return isObjectLike(value) && isArrayLike(value);
- }
- /**
- * Checks if `value` is a buffer.
- *
- * @static
- * @memberOf _
- * @since 4.3.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.
- * @example
- *
- * _.isBuffer(new Buffer(2));
- * // => true
- *
- * _.isBuffer(new Uint8Array(2));
- * // => false
- */
- var isBuffer = nativeIsBuffer || stubFalse;
- /**
- * Checks if `value` is classified as a `Function` object.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a function, else `false`.
- * @example
- *
- * _.isFunction(_);
- * // => true
- *
- * _.isFunction(/abc/);
- * // => false
- */
- function isFunction(value) {
- // The use of `Object#toString` avoids issues with the `typeof` operator
- // in Safari 8-9 which returns 'object' for typed array and other constructors.
- var tag = isObject(value) ? objectToString.call(value) : '';
- return tag == funcTag || tag == genTag;
- }
- /**
- * Checks if `value` is a valid array-like length.
- *
- * **Note:** This method is loosely based on
- * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.
- * @example
- *
- * _.isLength(3);
- * // => true
- *
- * _.isLength(Number.MIN_VALUE);
- * // => false
- *
- * _.isLength(Infinity);
- * // => false
- *
- * _.isLength('3');
- * // => false
- */
- function isLength(value) {
- return typeof value == 'number' &&
- value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;
- }
- /**
- * Checks if `value` is the
- * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
- * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an object, else `false`.
- * @example
- *
- * _.isObject({});
- * // => true
- *
- * _.isObject([1, 2, 3]);
- * // => true
- *
- * _.isObject(_.noop);
- * // => true
- *
- * _.isObject(null);
- * // => false
- */
- function isObject(value) {
- var type = typeof value;
- return !!value && (type == 'object' || type == 'function');
- }
- /**
- * Checks if `value` is object-like. A value is object-like if it's not `null`
- * and has a `typeof` result of "object".
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is object-like, else `false`.
- * @example
- *
- * _.isObjectLike({});
- * // => true
- *
- * _.isObjectLike([1, 2, 3]);
- * // => true
- *
- * _.isObjectLike(_.noop);
- * // => false
- *
- * _.isObjectLike(null);
- * // => false
- */
- function isObjectLike(value) {
- return !!value && typeof value == 'object';
- }
- /**
- * Creates an array of the own enumerable property names of `object`.
- *
- * **Note:** Non-object values are coerced to objects. See the
- * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)
- * for more details.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Object
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property names.
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.keys(new Foo);
- * // => ['a', 'b'] (iteration order is not guaranteed)
- *
- * _.keys('hi');
- * // => ['0', '1']
- */
- function keys(object) {
- return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);
- }
- /**
- * This method returns a new empty array.
- *
- * @static
- * @memberOf _
- * @since 4.13.0
- * @category Util
- * @returns {Array} Returns the new empty array.
- * @example
- *
- * var arrays = _.times(2, _.stubArray);
- *
- * console.log(arrays);
- * // => [[], []]
- *
- * console.log(arrays[0] === arrays[1]);
- * // => false
- */
- function stubArray() {
- return [];
- }
- /**
- * This method returns `false`.
- *
- * @static
- * @memberOf _
- * @since 4.13.0
- * @category Util
- * @returns {boolean} Returns `false`.
- * @example
- *
- * _.times(2, _.stubFalse);
- * // => [false, false]
- */
- function stubFalse() {
- return false;
- }
- module.exports = cloneDeep;
- /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(41)(module)))
- /***/ }),
- /* 10 */
- /***/ (function(module, exports) {
- module.exports = require("axios");
- /***/ }),
- /* 11 */
- /***/ (function(module, exports) {
- // This file is intentionally left empty for noop aliases
- /***/ }),
- /* 12 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- var _vue = __webpack_require__(0);
- var _vue2 = _interopRequireDefault(_vue);
- var _popup = __webpack_require__(35);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var PopperJS = _vue2.default.prototype.$isServer ? function () {} : __webpack_require__(65);
- var stop = function stop(e) {
- return e.stopPropagation();
- };
- /**
- * @param {HTMLElement} [reference=$refs.reference] - The reference element used to position the popper.
- * @param {HTMLElement} [popper=$refs.popper] - The HTML element used as popper, or a configuration used to generate the popper.
- * @param {String} [placement=button] - Placement of the popper accepted values: top(-start, -end), right(-start, -end), bottom(-start, -end), left(-start, -end)
- * @param {Number} [offset=0] - Amount of pixels the popper will be shifted (can be negative).
- * @param {Boolean} [visible=false] Visibility of the popup element.
- * @param {Boolean} [visible-arrow=false] Visibility of the arrow, no style.
- */
- exports.default = {
- props: {
- transformOrigin: {
- type: [Boolean, String],
- default: true
- },
- placement: {
- type: String,
- default: 'bottom'
- },
- boundariesPadding: {
- type: Number,
- default: 5
- },
- reference: {},
- popper: {},
- offset: {
- default: 0
- },
- value: Boolean,
- visibleArrow: Boolean,
- arrowOffset: {
- type: Number,
- default: 35
- },
- appendToBody: {
- type: Boolean,
- default: true
- },
- popperOptions: {
- type: Object,
- default: function _default() {
- return {
- gpuAcceleration: false
- };
- }
- }
- },
- data: function data() {
- return {
- showPopper: false,
- currentPlacement: ''
- };
- },
- watch: {
- value: {
- immediate: true,
- handler: function handler(val) {
- this.showPopper = val;
- this.$emit('input', val);
- }
- },
- showPopper: function showPopper(val) {
- if (this.disabled) return;
- val ? this.updatePopper() : this.destroyPopper();
- this.$emit('input', val);
- }
- },
- methods: {
- createPopper: function createPopper() {
- var _this = this;
- if (this.$isServer) return;
- this.currentPlacement = this.currentPlacement || this.placement;
- if (!/^(top|bottom|left|right)(-start|-end)?$/g.test(this.currentPlacement)) {
- return;
- }
- var options = this.popperOptions;
- var popper = this.popperElm = this.popperElm || this.popper || this.$refs.popper;
- var reference = this.referenceElm = this.referenceElm || this.reference || this.$refs.reference;
- if (!reference && this.$slots.reference && this.$slots.reference[0]) {
- reference = this.referenceElm = this.$slots.reference[0].elm;
- }
- if (!popper || !reference) return;
- if (this.visibleArrow) this.appendArrow(popper);
- if (this.appendToBody) document.body.appendChild(this.popperElm);
- if (this.popperJS && this.popperJS.destroy) {
- this.popperJS.destroy();
- }
- options.placement = this.currentPlacement;
- options.offset = this.offset;
- options.arrowOffset = this.arrowOffset;
- this.popperJS = new PopperJS(reference, popper, options);
- this.popperJS.onCreate(function (_) {
- _this.$emit('created', _this);
- _this.resetTransformOrigin();
- _this.$nextTick(_this.updatePopper);
- });
- if (typeof options.onUpdate === 'function') {
- this.popperJS.onUpdate(options.onUpdate);
- }
- this.popperJS._popper.style.zIndex = _popup.PopupManager.nextZIndex();
- this.popperElm.addEventListener('click', stop);
- },
- updatePopper: function updatePopper() {
- var popperJS = this.popperJS;
- if (popperJS) {
- popperJS.update();
- if (popperJS._popper) {
- popperJS._popper.style.zIndex = _popup.PopupManager.nextZIndex();
- }
- } else {
- this.createPopper();
- }
- },
- doDestroy: function doDestroy(forceDestroy) {
- /* istanbul ignore if */
- if (!this.popperJS || this.showPopper && !forceDestroy) return;
- this.popperJS.destroy();
- this.popperJS = null;
- },
- destroyPopper: function destroyPopper() {
- if (this.popperJS) {
- this.resetTransformOrigin();
- }
- },
- resetTransformOrigin: function resetTransformOrigin() {
- if (!this.transformOrigin) return;
- var placementMap = {
- top: 'bottom',
- bottom: 'top',
- left: 'right',
- right: 'left'
- };
- var placement = this.popperJS._popper.getAttribute('x-placement').split('-')[0];
- var origin = placementMap[placement];
- this.popperJS._popper.style.transformOrigin = typeof this.transformOrigin === 'string' ? this.transformOrigin : ['top', 'bottom'].indexOf(placement) > -1 ? 'center ' + origin : origin + ' center';
- },
- appendArrow: function appendArrow(element) {
- var hash = void 0;
- if (this.appended) {
- return;
- }
- this.appended = true;
- for (var item in element.attributes) {
- if (/^_v-/.test(element.attributes[item].name)) {
- hash = element.attributes[item].name;
- break;
- }
- }
- var arrow = document.createElement('div');
- if (hash) {
- arrow.setAttribute(hash, '');
- }
- arrow.setAttribute('x-arrow', '');
- arrow.className = 'popper__arrow';
- element.appendChild(arrow);
- }
- },
- beforeDestroy: function beforeDestroy() {
- this.doDestroy(true);
- if (this.popperElm && this.popperElm.parentNode === document.body) {
- this.popperElm.removeEventListener('click', stop);
- document.body.removeChild(this.popperElm);
- }
- },
- // call destroy in keep-alive mode
- deactivated: function deactivated() {
- this.$options.beforeDestroy[0].call(this);
- }
- };
- /***/ }),
- /* 13 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.default = function (target) {
- for (var i = 1, j = arguments.length; i < j; i++) {
- var source = arguments[i] || {};
- for (var prop in source) {
- if (source.hasOwnProperty(prop)) {
- var value = source[prop];
- if (value !== undefined) {
- target[prop] = value;
- }
- }
- }
- }
- return target;
- };
- ;
- /***/ }),
- /* 14 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.isDef = isDef;
- exports.isKorean = isKorean;
- function isDef(val) {
- return val !== undefined && val !== null;
- }
- function isKorean(text) {
- var reg = /([(\uAC00-\uD7AF)|(\u3130-\u318F)])+/gi;
- return reg.test(text);
- }
- /***/ }),
- /* 15 */
- /***/ (function(module, exports) {
- module.exports = require("vue-no-ssr");
- /***/ }),
- /* 16 */
- /***/ (function(module, exports) {
- module.exports = require("dayjs");
- /***/ }),
- /* 17 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.i18n = exports.use = exports.t = undefined;
- var _zhCN = __webpack_require__(61);
- var _zhCN2 = _interopRequireDefault(_zhCN);
- var _vue = __webpack_require__(0);
- var _vue2 = _interopRequireDefault(_vue);
- var _deepmerge = __webpack_require__(62);
- var _deepmerge2 = _interopRequireDefault(_deepmerge);
- var _format = __webpack_require__(63);
- var _format2 = _interopRequireDefault(_format);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var format = (0, _format2.default)(_vue2.default);
- var lang = _zhCN2.default;
- var merged = false;
- var i18nHandler = function i18nHandler() {
- var vuei18n = Object.getPrototypeOf(this || _vue2.default).$t;
- if (typeof vuei18n === 'function' && !!_vue2.default.locale) {
- if (!merged) {
- merged = true;
- _vue2.default.locale(_vue2.default.config.lang, (0, _deepmerge2.default)(lang, _vue2.default.locale(_vue2.default.config.lang) || {}, { clone: true }));
- }
- return vuei18n.apply(this, arguments);
- }
- };
- var t = exports.t = function t(path, options) {
- var value = i18nHandler.apply(this, arguments);
- if (value !== null && value !== undefined) return value;
- var array = path.split('.');
- var current = lang;
- for (var i = 0, j = array.length; i < j; i++) {
- var property = array[i];
- value = current[property];
- if (i === j - 1) return format(value, options);
- if (!value) return '';
- current = value;
- }
- return '';
- };
- var use = exports.use = function use(l) {
- lang = l || lang;
- };
- var i18n = exports.i18n = function i18n(fn) {
- i18nHandler = fn || i18nHandler;
- };
- exports.default = { use: use, t: t, i18n: i18n };
- /***/ }),
- /* 18 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- var _locale = __webpack_require__(17);
- exports.default = {
- methods: {
- t: function t() {
- for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
- return _locale.t.apply(this, args);
- }
- }
- };
- /***/ }),
- /* 19 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.default = function () {
- if (_vue2.default.prototype.$isServer) return 0;
- if (scrollBarWidth !== undefined) return scrollBarWidth;
- var outer = document.createElement('div');
- outer.className = 'el-scrollbar__wrap';
- outer.style.visibility = 'hidden';
- outer.style.width = '100px';
- outer.style.position = 'absolute';
- outer.style.top = '-9999px';
- document.body.appendChild(outer);
- var widthNoScroll = outer.offsetWidth;
- outer.style.overflow = 'scroll';
- var inner = document.createElement('div');
- inner.style.width = '100%';
- outer.appendChild(inner);
- var widthWithScroll = inner.offsetWidth;
- outer.parentNode.removeChild(outer);
- scrollBarWidth = widthNoScroll - widthWithScroll;
- return scrollBarWidth;
- };
- var _vue = __webpack_require__(0);
- var _vue2 = _interopRequireDefault(_vue);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var scrollBarWidth = void 0;
- ;
- /***/ }),
- /* 20 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 75);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 11:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(36);
- /***/ }),
- /***/ 21:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(14);
- /***/ }),
- /***/ 4:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(8);
- /***/ }),
- /***/ 75:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/input/src/input.vue?vue&type=template&id=343dd774&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- class: [
- _vm.type === "textarea" ? "el-textarea" : "el-input",
- _vm.inputSize ? "el-input--" + _vm.inputSize : "",
- {
- "is-disabled": _vm.inputDisabled,
- "is-exceed": _vm.inputExceed,
- "el-input-group": _vm.$slots.prepend || _vm.$slots.append,
- "el-input-group--append": _vm.$slots.append,
- "el-input-group--prepend": _vm.$slots.prepend,
- "el-input--prefix": _vm.$slots.prefix || _vm.prefixIcon,
- "el-input--suffix":
- _vm.$slots.suffix ||
- _vm.suffixIcon ||
- _vm.clearable ||
- _vm.showPassword
- }
- ],
- on: {
- mouseenter: function($event) {
- _vm.hovering = true
- },
- mouseleave: function($event) {
- _vm.hovering = false
- }
- }
- },
- [
- _vm.type !== "textarea"
- ? [
- _vm.$slots.prepend
- ? _c(
- "div",
- { staticClass: "el-input-group__prepend" },
- [_vm._t("prepend")],
- 2
- )
- : _vm._e(),
- _vm.type !== "textarea"
- ? _c(
- "input",
- _vm._b(
- {
- ref: "input",
- staticClass: "el-input__inner",
- attrs: {
- tabindex: _vm.tabindex,
- type: _vm.showPassword
- ? _vm.passwordVisible
- ? "text"
- : "password"
- : _vm.type,
- disabled: _vm.inputDisabled,
- readonly: _vm.readonly,
- autocomplete: _vm.autoComplete || _vm.autocomplete,
- "aria-label": _vm.label
- },
- on: {
- compositionstart: _vm.handleCompositionStart,
- compositionupdate: _vm.handleCompositionUpdate,
- compositionend: _vm.handleCompositionEnd,
- input: _vm.handleInput,
- focus: _vm.handleFocus,
- blur: _vm.handleBlur,
- change: _vm.handleChange
- }
- },
- "input",
- _vm.$attrs,
- false
- )
- )
- : _vm._e(),
- _vm.$slots.prefix || _vm.prefixIcon
- ? _c(
- "span",
- { staticClass: "el-input__prefix" },
- [
- _vm._t("prefix"),
- _vm.prefixIcon
- ? _c("i", {
- staticClass: "el-input__icon",
- class: _vm.prefixIcon
- })
- : _vm._e()
- ],
- 2
- )
- : _vm._e(),
- _vm.getSuffixVisible()
- ? _c("span", { staticClass: "el-input__suffix" }, [
- _c(
- "span",
- { staticClass: "el-input__suffix-inner" },
- [
- !_vm.showClear ||
- !_vm.showPwdVisible ||
- !_vm.isWordLimitVisible
- ? [
- _vm._t("suffix"),
- _vm.suffixIcon
- ? _c("i", {
- staticClass: "el-input__icon",
- class: _vm.suffixIcon
- })
- : _vm._e()
- ]
- : _vm._e(),
- _vm.showClear
- ? _c("i", {
- staticClass:
- "el-input__icon el-icon-circle-close el-input__clear",
- on: {
- mousedown: function($event) {
- $event.preventDefault()
- },
- click: _vm.clear
- }
- })
- : _vm._e(),
- _vm.showPwdVisible
- ? _c("i", {
- staticClass:
- "el-input__icon el-icon-view el-input__clear",
- on: { click: _vm.handlePasswordVisible }
- })
- : _vm._e(),
- _vm.isWordLimitVisible
- ? _c("span", { staticClass: "el-input__count" }, [
- _c(
- "span",
- { staticClass: "el-input__count-inner" },
- [
- _vm._v(
- "\n " +
- _vm._s(_vm.textLength) +
- "/" +
- _vm._s(_vm.upperLimit) +
- "\n "
- )
- ]
- )
- ])
- : _vm._e()
- ],
- 2
- ),
- _vm.validateState
- ? _c("i", {
- staticClass: "el-input__icon",
- class: ["el-input__validateIcon", _vm.validateIcon]
- })
- : _vm._e()
- ])
- : _vm._e(),
- _vm.$slots.append
- ? _c(
- "div",
- { staticClass: "el-input-group__append" },
- [_vm._t("append")],
- 2
- )
- : _vm._e()
- ]
- : _c(
- "textarea",
- _vm._b(
- {
- ref: "textarea",
- staticClass: "el-textarea__inner",
- style: _vm.textareaStyle,
- attrs: {
- tabindex: _vm.tabindex,
- disabled: _vm.inputDisabled,
- readonly: _vm.readonly,
- autocomplete: _vm.autoComplete || _vm.autocomplete,
- "aria-label": _vm.label
- },
- on: {
- compositionstart: _vm.handleCompositionStart,
- compositionupdate: _vm.handleCompositionUpdate,
- compositionend: _vm.handleCompositionEnd,
- input: _vm.handleInput,
- focus: _vm.handleFocus,
- blur: _vm.handleBlur,
- change: _vm.handleChange
- }
- },
- "textarea",
- _vm.$attrs,
- false
- )
- ),
- _vm.isWordLimitVisible && _vm.type === "textarea"
- ? _c("span", { staticClass: "el-input__count" }, [
- _vm._v(_vm._s(_vm.textLength) + "/" + _vm._s(_vm.upperLimit))
- ])
- : _vm._e()
- ],
- 2
- )
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/input/src/input.vue?vue&type=template&id=343dd774&
- // EXTERNAL MODULE: external "element-ui/lib/mixins/emitter"
- var emitter_ = __webpack_require__(4);
- var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_);
- // EXTERNAL MODULE: external "element-ui/lib/mixins/migrating"
- var migrating_ = __webpack_require__(11);
- var migrating_default = /*#__PURE__*/__webpack_require__.n(migrating_);
- // CONCATENATED MODULE: ./packages/input/src/calcTextareaHeight.js
- var hiddenTextarea = void 0;
- var HIDDEN_STYLE = '\n height:0 !important;\n visibility:hidden !important;\n overflow:hidden !important;\n position:absolute !important;\n z-index:-1000 !important;\n top:0 !important;\n right:0 !important\n';
- var CONTEXT_STYLE = ['letter-spacing', 'line-height', 'padding-top', 'padding-bottom', 'font-family', 'font-weight', 'font-size', 'text-rendering', 'text-transform', 'width', 'text-indent', 'padding-left', 'padding-right', 'border-width', 'box-sizing'];
- function calculateNodeStyling(targetElement) {
- var style = window.getComputedStyle(targetElement);
- var boxSizing = style.getPropertyValue('box-sizing');
- var paddingSize = parseFloat(style.getPropertyValue('padding-bottom')) + parseFloat(style.getPropertyValue('padding-top'));
- var borderSize = parseFloat(style.getPropertyValue('border-bottom-width')) + parseFloat(style.getPropertyValue('border-top-width'));
- var contextStyle = CONTEXT_STYLE.map(function (name) {
- return name + ':' + style.getPropertyValue(name);
- }).join(';');
- return { contextStyle: contextStyle, paddingSize: paddingSize, borderSize: borderSize, boxSizing: boxSizing };
- }
- function calcTextareaHeight(targetElement) {
- var minRows = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
- var maxRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;
- if (!hiddenTextarea) {
- hiddenTextarea = document.createElement('textarea');
- document.body.appendChild(hiddenTextarea);
- }
- var _calculateNodeStyling = calculateNodeStyling(targetElement),
- paddingSize = _calculateNodeStyling.paddingSize,
- borderSize = _calculateNodeStyling.borderSize,
- boxSizing = _calculateNodeStyling.boxSizing,
- contextStyle = _calculateNodeStyling.contextStyle;
- hiddenTextarea.setAttribute('style', contextStyle + ';' + HIDDEN_STYLE);
- hiddenTextarea.value = targetElement.value || targetElement.placeholder || '';
- var height = hiddenTextarea.scrollHeight;
- var result = {};
- if (boxSizing === 'border-box') {
- height = height + borderSize;
- } else if (boxSizing === 'content-box') {
- height = height - paddingSize;
- }
- hiddenTextarea.value = '';
- var singleRowHeight = hiddenTextarea.scrollHeight - paddingSize;
- if (minRows !== null) {
- var minHeight = singleRowHeight * minRows;
- if (boxSizing === 'border-box') {
- minHeight = minHeight + paddingSize + borderSize;
- }
- height = Math.max(minHeight, height);
- result.minHeight = minHeight + 'px';
- }
- if (maxRows !== null) {
- var maxHeight = singleRowHeight * maxRows;
- if (boxSizing === 'border-box') {
- maxHeight = maxHeight + paddingSize + borderSize;
- }
- height = Math.min(maxHeight, height);
- }
- result.height = height + 'px';
- hiddenTextarea.parentNode && hiddenTextarea.parentNode.removeChild(hiddenTextarea);
- hiddenTextarea = null;
- return result;
- };
- // EXTERNAL MODULE: external "element-ui/lib/utils/merge"
- var merge_ = __webpack_require__(9);
- var merge_default = /*#__PURE__*/__webpack_require__.n(merge_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/shared"
- var shared_ = __webpack_require__(21);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/input/src/input.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var inputvue_type_script_lang_js_ = ({
- name: 'ElInput',
- componentName: 'ElInput',
- mixins: [emitter_default.a, migrating_default.a],
- inheritAttrs: false,
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- data: function data() {
- return {
- textareaCalcStyle: {},
- hovering: false,
- focused: false,
- isComposing: false,
- passwordVisible: false
- };
- },
- props: {
- value: [String, Number],
- size: String,
- resize: String,
- form: String,
- disabled: Boolean,
- readonly: Boolean,
- type: {
- type: String,
- default: 'text'
- },
- autosize: {
- type: [Boolean, Object],
- default: false
- },
- autocomplete: {
- type: String,
- default: 'off'
- },
- /** @Deprecated in next major version */
- autoComplete: {
- type: String,
- validator: function validator(val) {
- false && false;
- return true;
- }
- },
- validateEvent: {
- type: Boolean,
- default: true
- },
- suffixIcon: String,
- prefixIcon: String,
- label: String,
- clearable: {
- type: Boolean,
- default: false
- },
- showPassword: {
- type: Boolean,
- default: false
- },
- showWordLimit: {
- type: Boolean,
- default: false
- },
- tabindex: String
- },
- computed: {
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- validateState: function validateState() {
- return this.elFormItem ? this.elFormItem.validateState : '';
- },
- needStatusIcon: function needStatusIcon() {
- return this.elForm ? this.elForm.statusIcon : false;
- },
- validateIcon: function validateIcon() {
- return {
- validating: 'el-icon-loading',
- success: 'el-icon-circle-check',
- error: 'el-icon-circle-close'
- }[this.validateState];
- },
- textareaStyle: function textareaStyle() {
- return merge_default()({}, this.textareaCalcStyle, { resize: this.resize });
- },
- inputSize: function inputSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- inputDisabled: function inputDisabled() {
- return this.disabled || (this.elForm || {}).disabled;
- },
- nativeInputValue: function nativeInputValue() {
- return this.value === null || this.value === undefined ? '' : String(this.value);
- },
- showClear: function showClear() {
- return this.clearable && !this.inputDisabled && !this.readonly && this.nativeInputValue && (this.focused || this.hovering);
- },
- showPwdVisible: function showPwdVisible() {
- return this.showPassword && !this.inputDisabled && !this.readonly && (!!this.nativeInputValue || this.focused);
- },
- isWordLimitVisible: function isWordLimitVisible() {
- return this.showWordLimit && this.$attrs.maxlength && (this.type === 'text' || this.type === 'textarea') && !this.inputDisabled && !this.readonly && !this.showPassword;
- },
- upperLimit: function upperLimit() {
- return this.$attrs.maxlength;
- },
- textLength: function textLength() {
- if (typeof this.value === 'number') {
- return String(this.value).length;
- }
- return (this.value || '').length;
- },
- inputExceed: function inputExceed() {
- // show exceed style if length of initial value greater then maxlength
- return this.isWordLimitVisible && this.textLength > this.upperLimit;
- }
- },
- watch: {
- value: function value(val) {
- this.$nextTick(this.resizeTextarea);
- if (this.validateEvent) {
- this.dispatch('ElFormItem', 'el.form.change', [val]);
- }
- },
- // native input value is set explicitly
- // do not use v-model / :value in template
- // see: https://github.com/ElemeFE/element/issues/14521
- nativeInputValue: function nativeInputValue() {
- this.setNativeInputValue();
- },
- // when change between <input> and <textarea>,
- // update DOM dependent value and styles
- // https://github.com/ElemeFE/element/issues/14857
- type: function type() {
- var _this = this;
- this.$nextTick(function () {
- _this.setNativeInputValue();
- _this.resizeTextarea();
- _this.updateIconOffset();
- });
- }
- },
- methods: {
- focus: function focus() {
- this.getInput().focus();
- },
- blur: function blur() {
- this.getInput().blur();
- },
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {
- 'icon': 'icon is removed, use suffix-icon / prefix-icon instead.',
- 'on-icon-click': 'on-icon-click is removed.'
- },
- events: {
- 'click': 'click is removed.'
- }
- };
- },
- handleBlur: function handleBlur(event) {
- this.focused = false;
- this.$emit('blur', event);
- if (this.validateEvent) {
- this.dispatch('ElFormItem', 'el.form.blur', [this.value]);
- }
- },
- select: function select() {
- this.getInput().select();
- },
- resizeTextarea: function resizeTextarea() {
- if (this.$isServer) return;
- var autosize = this.autosize,
- type = this.type;
- if (type !== 'textarea') return;
- if (!autosize) {
- this.textareaCalcStyle = {
- minHeight: calcTextareaHeight(this.$refs.textarea).minHeight
- };
- return;
- }
- var minRows = autosize.minRows;
- var maxRows = autosize.maxRows;
- this.textareaCalcStyle = calcTextareaHeight(this.$refs.textarea, minRows, maxRows);
- },
- setNativeInputValue: function setNativeInputValue() {
- var input = this.getInput();
- if (!input) return;
- if (input.value === this.nativeInputValue) return;
- input.value = this.nativeInputValue;
- },
- handleFocus: function handleFocus(event) {
- this.focused = true;
- this.$emit('focus', event);
- },
- handleCompositionStart: function handleCompositionStart(event) {
- this.$emit('compositionstart', event);
- this.isComposing = true;
- },
- handleCompositionUpdate: function handleCompositionUpdate(event) {
- this.$emit('compositionupdate', event);
- var text = event.target.value;
- var lastCharacter = text[text.length - 1] || '';
- this.isComposing = !Object(shared_["isKorean"])(lastCharacter);
- },
- handleCompositionEnd: function handleCompositionEnd(event) {
- this.$emit('compositionend', event);
- if (this.isComposing) {
- this.isComposing = false;
- this.handleInput(event);
- }
- },
- handleInput: function handleInput(event) {
- // should not emit input during composition
- // see: https://github.com/ElemeFE/element/issues/10516
- if (this.isComposing) return;
- // hack for https://github.com/ElemeFE/element/issues/8548
- // should remove the following line when we don't support IE
- if (event.target.value === this.nativeInputValue) return;
- this.$emit('input', event.target.value);
- // ensure native input value is controlled
- // see: https://github.com/ElemeFE/element/issues/12850
- this.$nextTick(this.setNativeInputValue);
- },
- handleChange: function handleChange(event) {
- this.$emit('change', event.target.value);
- },
- calcIconOffset: function calcIconOffset(place) {
- var elList = [].slice.call(this.$el.querySelectorAll('.el-input__' + place) || []);
- if (!elList.length) return;
- var el = null;
- for (var i = 0; i < elList.length; i++) {
- if (elList[i].parentNode === this.$el) {
- el = elList[i];
- break;
- }
- }
- if (!el) return;
- var pendantMap = {
- suffix: 'append',
- prefix: 'prepend'
- };
- var pendant = pendantMap[place];
- if (this.$slots[pendant]) {
- el.style.transform = 'translateX(' + (place === 'suffix' ? '-' : '') + this.$el.querySelector('.el-input-group__' + pendant).offsetWidth + 'px)';
- } else {
- el.removeAttribute('style');
- }
- },
- updateIconOffset: function updateIconOffset() {
- this.calcIconOffset('prefix');
- this.calcIconOffset('suffix');
- },
- clear: function clear() {
- this.$emit('input', '');
- this.$emit('change', '');
- this.$emit('clear');
- },
- handlePasswordVisible: function handlePasswordVisible() {
- var _this2 = this;
- this.passwordVisible = !this.passwordVisible;
- this.$nextTick(function () {
- _this2.focus();
- });
- },
- getInput: function getInput() {
- return this.$refs.input || this.$refs.textarea;
- },
- getSuffixVisible: function getSuffixVisible() {
- return this.$slots.suffix || this.suffixIcon || this.showClear || this.showPassword || this.isWordLimitVisible || this.validateState && this.needStatusIcon;
- }
- },
- created: function created() {
- this.$on('inputSelect', this.select);
- },
- mounted: function mounted() {
- this.setNativeInputValue();
- this.resizeTextarea();
- this.updateIconOffset();
- },
- updated: function updated() {
- this.$nextTick(this.updateIconOffset);
- }
- });
- // CONCATENATED MODULE: ./packages/input/src/input.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_inputvue_type_script_lang_js_ = (inputvue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/input/src/input.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_inputvue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/input/src/input.vue"
- /* harmony default export */ var input = (component.exports);
- // CONCATENATED MODULE: ./packages/input/index.js
- /* istanbul ignore next */
- input.install = function (Vue) {
- Vue.component(input.name, input);
- };
- /* harmony default export */ var packages_input = __webpack_exports__["default"] = (input);
- /***/ }),
- /***/ 9:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(13);
- /***/ })
- /******/ });
- /***/ }),
- /* 21 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.removeResizeListener = exports.addResizeListener = undefined;
- var _resizeObserverPolyfill = __webpack_require__(67);
- var _resizeObserverPolyfill2 = _interopRequireDefault(_resizeObserverPolyfill);
- var _throttleDebounce = __webpack_require__(39);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var isServer = typeof window === 'undefined';
- /* istanbul ignore next */
- var resizeHandler = function resizeHandler(entries) {
- for (var _iterator = entries, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
- var _ref;
- if (_isArray) {
- if (_i >= _iterator.length) break;
- _ref = _iterator[_i++];
- } else {
- _i = _iterator.next();
- if (_i.done) break;
- _ref = _i.value;
- }
- var entry = _ref;
- var listeners = entry.target.__resizeListeners__ || [];
- if (listeners.length) {
- listeners.forEach(function (fn) {
- fn();
- });
- }
- }
- };
- /* istanbul ignore next */
- var addResizeListener = exports.addResizeListener = function addResizeListener(element, fn) {
- if (isServer) return;
- if (!element.__resizeListeners__) {
- element.__resizeListeners__ = [];
- element.__ro__ = new _resizeObserverPolyfill2.default((0, _throttleDebounce.debounce)(16, resizeHandler));
- element.__ro__.observe(element);
- }
- element.__resizeListeners__.push(fn);
- };
- /* istanbul ignore next */
- var removeResizeListener = exports.removeResizeListener = function removeResizeListener(element, fn) {
- if (!element || !element.__resizeListeners__) return;
- element.__resizeListeners__.splice(element.__resizeListeners__.indexOf(fn), 1);
- if (!element.__resizeListeners__.length) {
- element.__ro__.disconnect();
- }
- };
- /***/ }),
- /* 22 */
- /***/ (function(module, exports) {
- module.exports = require("throttle-debounce/debounce");
- /***/ }),
- /* 23 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 133);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 133:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // EXTERNAL MODULE: external "element-ui/lib/utils/resize-event"
- var resize_event_ = __webpack_require__(16);
- // EXTERNAL MODULE: external "element-ui/lib/utils/scrollbar-width"
- var scrollbar_width_ = __webpack_require__(39);
- var scrollbar_width_default = /*#__PURE__*/__webpack_require__.n(scrollbar_width_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/util"
- var util_ = __webpack_require__(3);
- // EXTERNAL MODULE: external "element-ui/lib/utils/dom"
- var dom_ = __webpack_require__(2);
- // CONCATENATED MODULE: ./packages/scrollbar/src/util.js
- var BAR_MAP = {
- vertical: {
- offset: 'offsetHeight',
- scroll: 'scrollTop',
- scrollSize: 'scrollHeight',
- size: 'height',
- key: 'vertical',
- axis: 'Y',
- client: 'clientY',
- direction: 'top'
- },
- horizontal: {
- offset: 'offsetWidth',
- scroll: 'scrollLeft',
- scrollSize: 'scrollWidth',
- size: 'width',
- key: 'horizontal',
- axis: 'X',
- client: 'clientX',
- direction: 'left'
- }
- };
- function renderThumbStyle(_ref) {
- var move = _ref.move,
- size = _ref.size,
- bar = _ref.bar;
- var style = {};
- var translate = 'translate' + bar.axis + '(' + move + '%)';
- style[bar.size] = size;
- style.transform = translate;
- style.msTransform = translate;
- style.webkitTransform = translate;
- return style;
- };
- // CONCATENATED MODULE: ./packages/scrollbar/src/bar.js
- /* istanbul ignore next */
- /* harmony default export */ var src_bar = ({
- name: 'Bar',
- props: {
- vertical: Boolean,
- size: String,
- move: Number
- },
- computed: {
- bar: function bar() {
- return BAR_MAP[this.vertical ? 'vertical' : 'horizontal'];
- },
- wrap: function wrap() {
- return this.$parent.wrap;
- }
- },
- render: function render(h) {
- var size = this.size,
- move = this.move,
- bar = this.bar;
- return h(
- 'div',
- {
- 'class': ['el-scrollbar__bar', 'is-' + bar.key],
- on: {
- 'mousedown': this.clickTrackHandler
- }
- },
- [h('div', {
- ref: 'thumb',
- 'class': 'el-scrollbar__thumb',
- on: {
- 'mousedown': this.clickThumbHandler
- },
- style: renderThumbStyle({ size: size, move: move, bar: bar }) })]
- );
- },
- methods: {
- clickThumbHandler: function clickThumbHandler(e) {
- // prevent click event of right button
- if (e.ctrlKey || e.button === 2) {
- return;
- }
- this.startDrag(e);
- this[this.bar.axis] = e.currentTarget[this.bar.offset] - (e[this.bar.client] - e.currentTarget.getBoundingClientRect()[this.bar.direction]);
- },
- clickTrackHandler: function clickTrackHandler(e) {
- var offset = Math.abs(e.target.getBoundingClientRect()[this.bar.direction] - e[this.bar.client]);
- var thumbHalf = this.$refs.thumb[this.bar.offset] / 2;
- var thumbPositionPercentage = (offset - thumbHalf) * 100 / this.$el[this.bar.offset];
- this.wrap[this.bar.scroll] = thumbPositionPercentage * this.wrap[this.bar.scrollSize] / 100;
- },
- startDrag: function startDrag(e) {
- e.stopImmediatePropagation();
- this.cursorDown = true;
- Object(dom_["on"])(document, 'mousemove', this.mouseMoveDocumentHandler);
- Object(dom_["on"])(document, 'mouseup', this.mouseUpDocumentHandler);
- document.onselectstart = function () {
- return false;
- };
- },
- mouseMoveDocumentHandler: function mouseMoveDocumentHandler(e) {
- if (this.cursorDown === false) return;
- var prevPage = this[this.bar.axis];
- if (!prevPage) return;
- var offset = (this.$el.getBoundingClientRect()[this.bar.direction] - e[this.bar.client]) * -1;
- var thumbClickPosition = this.$refs.thumb[this.bar.offset] - prevPage;
- var thumbPositionPercentage = (offset - thumbClickPosition) * 100 / this.$el[this.bar.offset];
- this.wrap[this.bar.scroll] = thumbPositionPercentage * this.wrap[this.bar.scrollSize] / 100;
- },
- mouseUpDocumentHandler: function mouseUpDocumentHandler(e) {
- this.cursorDown = false;
- this[this.bar.axis] = 0;
- Object(dom_["off"])(document, 'mousemove', this.mouseMoveDocumentHandler);
- document.onselectstart = null;
- }
- },
- destroyed: function destroyed() {
- Object(dom_["off"])(document, 'mouseup', this.mouseUpDocumentHandler);
- }
- });
- // CONCATENATED MODULE: ./packages/scrollbar/src/main.js
- // reference https://github.com/noeldelgado/gemini-scrollbar/blob/master/index.js
- /* istanbul ignore next */
- /* harmony default export */ var main = ({
- name: 'ElScrollbar',
- components: { Bar: src_bar },
- props: {
- native: Boolean,
- wrapStyle: {},
- wrapClass: {},
- viewClass: {},
- viewStyle: {},
- noresize: Boolean, // 如果 container 尺寸不会发生变化,最好设置它可以优化性能
- tag: {
- type: String,
- default: 'div'
- }
- },
- data: function data() {
- return {
- sizeWidth: '0',
- sizeHeight: '0',
- moveX: 0,
- moveY: 0
- };
- },
- computed: {
- wrap: function wrap() {
- return this.$refs.wrap;
- }
- },
- render: function render(h) {
- var gutter = scrollbar_width_default()();
- var style = this.wrapStyle;
- if (gutter) {
- var gutterWith = '-' + gutter + 'px';
- var gutterStyle = 'margin-bottom: ' + gutterWith + '; margin-right: ' + gutterWith + ';';
- if (Array.isArray(this.wrapStyle)) {
- style = Object(util_["toObject"])(this.wrapStyle);
- style.marginRight = style.marginBottom = gutterWith;
- } else if (typeof this.wrapStyle === 'string') {
- style += gutterStyle;
- } else {
- style = gutterStyle;
- }
- }
- var view = h(this.tag, {
- class: ['el-scrollbar__view', this.viewClass],
- style: this.viewStyle,
- ref: 'resize'
- }, this.$slots.default);
- var wrap = h(
- 'div',
- {
- ref: 'wrap',
- style: style,
- on: {
- 'scroll': this.handleScroll
- },
- 'class': [this.wrapClass, 'el-scrollbar__wrap', gutter ? '' : 'el-scrollbar__wrap--hidden-default'] },
- [[view]]
- );
- var nodes = void 0;
- if (!this.native) {
- nodes = [wrap, h(src_bar, {
- attrs: {
- move: this.moveX,
- size: this.sizeWidth }
- }), h(src_bar, {
- attrs: {
- vertical: true,
- move: this.moveY,
- size: this.sizeHeight }
- })];
- } else {
- nodes = [h(
- 'div',
- {
- ref: 'wrap',
- 'class': [this.wrapClass, 'el-scrollbar__wrap'],
- style: style },
- [[view]]
- )];
- }
- return h('div', { class: 'el-scrollbar' }, nodes);
- },
- methods: {
- handleScroll: function handleScroll() {
- var wrap = this.wrap;
- this.moveY = wrap.scrollTop * 100 / wrap.clientHeight;
- this.moveX = wrap.scrollLeft * 100 / wrap.clientWidth;
- },
- update: function update() {
- var heightPercentage = void 0,
- widthPercentage = void 0;
- var wrap = this.wrap;
- if (!wrap) return;
- heightPercentage = wrap.clientHeight * 100 / wrap.scrollHeight;
- widthPercentage = wrap.clientWidth * 100 / wrap.scrollWidth;
- this.sizeHeight = heightPercentage < 100 ? heightPercentage + '%' : '';
- this.sizeWidth = widthPercentage < 100 ? widthPercentage + '%' : '';
- }
- },
- mounted: function mounted() {
- if (this.native) return;
- this.$nextTick(this.update);
- !this.noresize && Object(resize_event_["addResizeListener"])(this.$refs.resize, this.update);
- },
- beforeDestroy: function beforeDestroy() {
- if (this.native) return;
- !this.noresize && Object(resize_event_["removeResizeListener"])(this.$refs.resize, this.update);
- }
- });
- // CONCATENATED MODULE: ./packages/scrollbar/index.js
- /* istanbul ignore next */
- main.install = function (Vue) {
- Vue.component(main.name, main);
- };
- /* harmony default export */ var scrollbar = __webpack_exports__["default"] = (main);
- /***/ }),
- /***/ 16:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(21);
- /***/ }),
- /***/ 2:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(6);
- /***/ }),
- /***/ 3:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(4);
- /***/ }),
- /***/ 39:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(19);
- /***/ })
- /******/ });
- /***/ }),
- /* 24 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.default = function (ref) {
- return {
- methods: {
- focus: function focus() {
- this.$refs[ref].focus();
- }
- }
- };
- };
- ;
- /***/ }),
- /* 25 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.default = scrollIntoView;
- var _vue = __webpack_require__(0);
- var _vue2 = _interopRequireDefault(_vue);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- function scrollIntoView(container, selected) {
- if (_vue2.default.prototype.$isServer) return;
- if (!selected) {
- container.scrollTop = 0;
- return;
- }
- var offsetParents = [];
- var pointer = selected.offsetParent;
- while (pointer && container !== pointer && container.contains(pointer)) {
- offsetParents.push(pointer);
- pointer = pointer.offsetParent;
- }
- var top = selected.offsetTop + offsetParents.reduce(function (prev, curr) {
- return prev + curr.offsetTop;
- }, 0);
- var bottom = top + selected.offsetHeight;
- var viewRectTop = container.scrollTop;
- var viewRectBottom = viewRectTop + container.clientHeight;
- if (top < viewRectTop) {
- container.scrollTop = top;
- } else if (bottom > viewRectBottom) {
- container.scrollTop = bottom - container.clientHeight;
- }
- }
- /***/ }),
- /* 26 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- var aria = aria || {};
- aria.Utils = aria.Utils || {};
- /**
- * @desc Set focus on descendant nodes until the first focusable element is
- * found.
- * @param element
- * DOM node for which to find the first focusable descendant.
- * @returns
- * true if a focusable element is found and focus is set.
- */
- aria.Utils.focusFirstDescendant = function (element) {
- for (var i = 0; i < element.childNodes.length; i++) {
- var child = element.childNodes[i];
- if (aria.Utils.attemptFocus(child) || aria.Utils.focusFirstDescendant(child)) {
- return true;
- }
- }
- return false;
- };
- /**
- * @desc Find the last descendant node that is focusable.
- * @param element
- * DOM node for which to find the last focusable descendant.
- * @returns
- * true if a focusable element is found and focus is set.
- */
- aria.Utils.focusLastDescendant = function (element) {
- for (var i = element.childNodes.length - 1; i >= 0; i--) {
- var child = element.childNodes[i];
- if (aria.Utils.attemptFocus(child) || aria.Utils.focusLastDescendant(child)) {
- return true;
- }
- }
- return false;
- };
- /**
- * @desc Set Attempt to set focus on the current node.
- * @param element
- * The node to attempt to focus on.
- * @returns
- * true if element is focused.
- */
- aria.Utils.attemptFocus = function (element) {
- if (!aria.Utils.isFocusable(element)) {
- return false;
- }
- aria.Utils.IgnoreUtilFocusChanges = true;
- try {
- element.focus();
- } catch (e) {}
- aria.Utils.IgnoreUtilFocusChanges = false;
- return document.activeElement === element;
- };
- aria.Utils.isFocusable = function (element) {
- if (element.tabIndex > 0 || element.tabIndex === 0 && element.getAttribute('tabIndex') !== null) {
- return true;
- }
- if (element.disabled) {
- return false;
- }
- switch (element.nodeName) {
- case 'A':
- return !!element.href && element.rel !== 'ignore';
- case 'INPUT':
- return element.type !== 'hidden' && element.type !== 'file';
- case 'BUTTON':
- case 'SELECT':
- case 'TEXTAREA':
- return true;
- default:
- return false;
- }
- };
- /**
- * 触发一个事件
- * mouseenter, mouseleave, mouseover, keyup, change, click 等
- * @param {Element} elm
- * @param {String} name
- * @param {*} opts
- */
- aria.Utils.triggerEvent = function (elm, name) {
- var eventName = void 0;
- if (/^mouse|click/.test(name)) {
- eventName = 'MouseEvents';
- } else if (/^key/.test(name)) {
- eventName = 'KeyboardEvent';
- } else {
- eventName = 'HTMLEvents';
- }
- var evt = document.createEvent(eventName);
- for (var _len = arguments.length, opts = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {
- opts[_key - 2] = arguments[_key];
- }
- evt.initEvent.apply(evt, [name].concat(opts));
- elm.dispatchEvent ? elm.dispatchEvent(evt) : elm.fireEvent('on' + name, evt);
- return elm;
- };
- aria.Utils.keys = {
- tab: 9,
- enter: 13,
- space: 32,
- left: 37,
- up: 38,
- right: 39,
- down: 40,
- esc: 27
- };
- exports.default = aria.Utils;
- /***/ }),
- /* 27 */
- /***/ (function(module, exports) {
- module.exports = require("js-cookie");
- /***/ }),
- /* 28 */
- /***/ (function(module, exports) {
- module.exports = require("vue-client-only");
- /***/ }),
- /* 29 */
- /***/ (function(module, exports) {
- module.exports = require("vue-router");
- /***/ }),
- /* 30 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- // ESM COMPAT FLAG
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/DIalogXXSuccess.vue?vue&type=template&id=5bfd8b9e
- var render = function render() {
- var _vm = this,
- _c = _vm._self._c;
- return _c('div', {
- staticClass: "dialog-xx-success"
- }, [_c('el-dialog', {
- attrs: {
- "visible": _vm.modelVisible,
- "lock-scroll": false,
- "width": "600px"
- },
- on: {
- "update:visible": function ($event) {
- _vm.modelVisible = $event;
- }
- }
- }, [_c('div', {
- staticClass: "flex column center stretch"
- }, [_vm.imgShow ? _c('div', {
- staticClass: "flex center img-wrap"
- }, [_vm.imgType ? _c('img', {
- attrs: {
- "src": __webpack_require__(98)
- }
- }) : _c('img', {
- attrs: {
- "src": __webpack_require__(99)
- }
- })]) : _vm._e(), _vm._v(" "), _c('div', {
- staticClass: "content-area"
- }, [_vm.content ? _c('div', {
- staticClass: "content"
- }, [_vm._v(_vm._s(_vm.content))]) : _vm._e(), _vm._v(" "), _vm.desc && _vm.desc.length ? _c('div', {
- staticClass: "desc"
- }, [_vm._v("\n " + _vm._s(_vm.desc) + "\n ")]) : _vm._e()]), _vm._v(" "), _c('div', {
- staticClass: "flex center"
- }, [_c('div', {
- staticClass: "btn-ok flex center",
- on: {
- "click": _vm.notifyParent
- }
- }, [_vm._v("\n OK\n ")])])])])], 1);
- };
- var staticRenderFns = [];
- // CONCATENATED MODULE: ./components/DIalogXXSuccess.vue?vue&type=template&id=5bfd8b9e
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/DIalogXXSuccess.vue?vue&type=script&lang=js
- /* harmony default export */ var DIalogXXSuccessvue_type_script_lang_js = ({
- props: {
- visible: {
- type: Boolean,
- default: false
- },
- imgShow: {
- type: Boolean,
- default: true
- },
- imgType: {
- type: Boolean,
- default: true
- },
- content: {
- type: String,
- default: ''
- },
- desc: {
- type: String,
- default: ''
- }
- },
- data() {
- return {
- modelVisible: false
- };
- },
- watch: {
- modelVisible(value) {
- this.$emit('update:visible', value);
- if (value) {
- document.addEventListener('keydown', this.close);
- } else {
- document.removeEventListener('keydown', this.close);
- }
- },
- visible() {
- this.modelVisible = this.visible;
- }
- },
- methods: {
- notifyParent() {
- this.modelVisible = false;
- this.$emit('notify-parent');
- },
- close(e) {
- if (e.keyCode === 13) {
- this.modelVisible = false;
- }
- }
- }
- });
- // CONCATENATED MODULE: ./components/DIalogXXSuccess.vue?vue&type=script&lang=js
- /* harmony default export */ var components_DIalogXXSuccessvue_type_script_lang_js = (DIalogXXSuccessvue_type_script_lang_js);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(2);
- // CONCATENATED MODULE: ./components/DIalogXXSuccess.vue
- function injectStyles (context) {
-
- var style0 = __webpack_require__(100)
- if (style0.__inject__) style0.__inject__(context)
- }
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- components_DIalogXXSuccessvue_type_script_lang_js,
- render,
- staticRenderFns,
- false,
- injectStyles,
- null,
- "3f2470c6"
-
- )
- /* harmony default export */ var DIalogXXSuccess = __webpack_exports__["default"] = (component.exports);
- /***/ }),
- /* 31 */
- /***/ (function(module, exports) {
- module.exports = require("algoliasearch");
- /***/ }),
- /* 32 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1);
- /* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(crypto_js__WEBPACK_IMPORTED_MODULE_0__);
- const key = crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.enc.Utf8.parse("1234567890000000"); //16位
- const iv = crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.enc.Utf8.parse("1234567890000000");
- /* harmony default export */ __webpack_exports__["a"] = ({
- //aes加密
- encrypt(word) {
- let encrypted = "";
- if (typeof word == "string") {
- const srcs = crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.enc.Utf8.parse(word);
- encrypted = crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.AES.encrypt(srcs, key, {
- iv: iv,
- mode: crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.mode.CBC,
- padding: crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.pad.Pkcs7
- });
- } else if (typeof word == "object") {
- //对象格式的转成json字符串
- const data = JSON.stringify(word);
- const srcs = crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.enc.Utf8.parse(data);
- encrypted = crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.AES.encrypt(srcs, key, {
- iv: iv,
- mode: crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.mode.CBC,
- padding: crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.pad.Pkcs7
- });
- }
- return encrypted.ciphertext.toString();
- },
- // aes解密
- decrypt(word) {
- const encryptedHexStr = crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.enc.Hex.parse(word);
- const srcs = crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.enc.Base64.stringify(encryptedHexStr);
- const decrypt = crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.AES.decrypt(srcs, key, {
- iv: iv,
- mode: crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.mode.CBC,
- padding: crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.pad.Pkcs7
- });
- const decryptedStr = decrypt.toString(crypto_js__WEBPACK_IMPORTED_MODULE_0___default.a.enc.Utf8);
- return decryptedStr.toString();
- }
- });
- /***/ }),
- /* 33 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var __WEBPACK_AMD_DEFINE_RESULT__;
- /* Modified from https://github.com/taylorhakes/fecha
- *
- * The MIT License (MIT)
- *
- * Copyright (c) 2015 Taylor Hakes
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- */
- /*eslint-disable*/
- // 把 YYYY-MM-DD 改成了 yyyy-MM-dd
- (function (main) {
- 'use strict';
- /**
- * Parse or format dates
- * @class fecha
- */
- var fecha = {};
- var token = /d{1,4}|M{1,4}|yy(?:yy)?|S{1,3}|Do|ZZ|([HhMsDm])\1?|[aA]|"[^"]*"|'[^']*'/g;
- var twoDigits = '\\d\\d?';
- var threeDigits = '\\d{3}';
- var fourDigits = '\\d{4}';
- var word = '[^\\s]+';
- var literal = /\[([^]*?)\]/gm;
- var noop = function noop() {};
- function regexEscape(str) {
- return str.replace(/[|\\{()[^$+*?.-]/g, '\\$&');
- }
- function shorten(arr, sLen) {
- var newArr = [];
- for (var i = 0, len = arr.length; i < len; i++) {
- newArr.push(arr[i].substr(0, sLen));
- }
- return newArr;
- }
- function monthUpdate(arrName) {
- return function (d, v, i18n) {
- var index = i18n[arrName].indexOf(v.charAt(0).toUpperCase() + v.substr(1).toLowerCase());
- if (~index) {
- d.month = index;
- }
- };
- }
- function pad(val, len) {
- val = String(val);
- len = len || 2;
- while (val.length < len) {
- val = '0' + val;
- }
- return val;
- }
- var dayNames = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];
- var monthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];
- var monthNamesShort = shorten(monthNames, 3);
- var dayNamesShort = shorten(dayNames, 3);
- fecha.i18n = {
- dayNamesShort: dayNamesShort,
- dayNames: dayNames,
- monthNamesShort: monthNamesShort,
- monthNames: monthNames,
- amPm: ['am', 'pm'],
- DoFn: function DoFn(D) {
- return D + ['th', 'st', 'nd', 'rd'][D % 10 > 3 ? 0 : (D - D % 10 !== 10) * D % 10];
- }
- };
- var formatFlags = {
- D: function D(dateObj) {
- return dateObj.getDay();
- },
- DD: function DD(dateObj) {
- return pad(dateObj.getDay());
- },
- Do: function Do(dateObj, i18n) {
- return i18n.DoFn(dateObj.getDate());
- },
- d: function d(dateObj) {
- return dateObj.getDate();
- },
- dd: function dd(dateObj) {
- return pad(dateObj.getDate());
- },
- ddd: function ddd(dateObj, i18n) {
- return i18n.dayNamesShort[dateObj.getDay()];
- },
- dddd: function dddd(dateObj, i18n) {
- return i18n.dayNames[dateObj.getDay()];
- },
- M: function M(dateObj) {
- return dateObj.getMonth() + 1;
- },
- MM: function MM(dateObj) {
- return pad(dateObj.getMonth() + 1);
- },
- MMM: function MMM(dateObj, i18n) {
- return i18n.monthNamesShort[dateObj.getMonth()];
- },
- MMMM: function MMMM(dateObj, i18n) {
- return i18n.monthNames[dateObj.getMonth()];
- },
- yy: function yy(dateObj) {
- return pad(String(dateObj.getFullYear()), 4).substr(2);
- },
- yyyy: function yyyy(dateObj) {
- return pad(dateObj.getFullYear(), 4);
- },
- h: function h(dateObj) {
- return dateObj.getHours() % 12 || 12;
- },
- hh: function hh(dateObj) {
- return pad(dateObj.getHours() % 12 || 12);
- },
- H: function H(dateObj) {
- return dateObj.getHours();
- },
- HH: function HH(dateObj) {
- return pad(dateObj.getHours());
- },
- m: function m(dateObj) {
- return dateObj.getMinutes();
- },
- mm: function mm(dateObj) {
- return pad(dateObj.getMinutes());
- },
- s: function s(dateObj) {
- return dateObj.getSeconds();
- },
- ss: function ss(dateObj) {
- return pad(dateObj.getSeconds());
- },
- S: function S(dateObj) {
- return Math.round(dateObj.getMilliseconds() / 100);
- },
- SS: function SS(dateObj) {
- return pad(Math.round(dateObj.getMilliseconds() / 10), 2);
- },
- SSS: function SSS(dateObj) {
- return pad(dateObj.getMilliseconds(), 3);
- },
- a: function a(dateObj, i18n) {
- return dateObj.getHours() < 12 ? i18n.amPm[0] : i18n.amPm[1];
- },
- A: function A(dateObj, i18n) {
- return dateObj.getHours() < 12 ? i18n.amPm[0].toUpperCase() : i18n.amPm[1].toUpperCase();
- },
- ZZ: function ZZ(dateObj) {
- var o = dateObj.getTimezoneOffset();
- return (o > 0 ? '-' : '+') + pad(Math.floor(Math.abs(o) / 60) * 100 + Math.abs(o) % 60, 4);
- }
- };
- var parseFlags = {
- d: [twoDigits, function (d, v) {
- d.day = v;
- }],
- Do: [twoDigits + word, function (d, v) {
- d.day = parseInt(v, 10);
- }],
- M: [twoDigits, function (d, v) {
- d.month = v - 1;
- }],
- yy: [twoDigits, function (d, v) {
- var da = new Date(),
- cent = +('' + da.getFullYear()).substr(0, 2);
- d.year = '' + (v > 68 ? cent - 1 : cent) + v;
- }],
- h: [twoDigits, function (d, v) {
- d.hour = v;
- }],
- m: [twoDigits, function (d, v) {
- d.minute = v;
- }],
- s: [twoDigits, function (d, v) {
- d.second = v;
- }],
- yyyy: [fourDigits, function (d, v) {
- d.year = v;
- }],
- S: ['\\d', function (d, v) {
- d.millisecond = v * 100;
- }],
- SS: ['\\d{2}', function (d, v) {
- d.millisecond = v * 10;
- }],
- SSS: [threeDigits, function (d, v) {
- d.millisecond = v;
- }],
- D: [twoDigits, noop],
- ddd: [word, noop],
- MMM: [word, monthUpdate('monthNamesShort')],
- MMMM: [word, monthUpdate('monthNames')],
- a: [word, function (d, v, i18n) {
- var val = v.toLowerCase();
- if (val === i18n.amPm[0]) {
- d.isPm = false;
- } else if (val === i18n.amPm[1]) {
- d.isPm = true;
- }
- }],
- ZZ: ['[^\\s]*?[\\+\\-]\\d\\d:?\\d\\d|[^\\s]*?Z', function (d, v) {
- var parts = (v + '').match(/([+-]|\d\d)/gi),
- minutes;
- if (parts) {
- minutes = +(parts[1] * 60) + parseInt(parts[2], 10);
- d.timezoneOffset = parts[0] === '+' ? minutes : -minutes;
- }
- }]
- };
- parseFlags.dd = parseFlags.d;
- parseFlags.dddd = parseFlags.ddd;
- parseFlags.DD = parseFlags.D;
- parseFlags.mm = parseFlags.m;
- parseFlags.hh = parseFlags.H = parseFlags.HH = parseFlags.h;
- parseFlags.MM = parseFlags.M;
- parseFlags.ss = parseFlags.s;
- parseFlags.A = parseFlags.a;
- // Some common format strings
- fecha.masks = {
- default: 'ddd MMM dd yyyy HH:mm:ss',
- shortDate: 'M/D/yy',
- mediumDate: 'MMM d, yyyy',
- longDate: 'MMMM d, yyyy',
- fullDate: 'dddd, MMMM d, yyyy',
- shortTime: 'HH:mm',
- mediumTime: 'HH:mm:ss',
- longTime: 'HH:mm:ss.SSS'
- };
- /***
- * Format a date
- * @method format
- * @param {Date|number} dateObj
- * @param {string} mask Format of the date, i.e. 'mm-dd-yy' or 'shortDate'
- */
- fecha.format = function (dateObj, mask, i18nSettings) {
- var i18n = i18nSettings || fecha.i18n;
- if (typeof dateObj === 'number') {
- dateObj = new Date(dateObj);
- }
- if (Object.prototype.toString.call(dateObj) !== '[object Date]' || isNaN(dateObj.getTime())) {
- throw new Error('Invalid Date in fecha.format');
- }
- mask = fecha.masks[mask] || mask || fecha.masks['default'];
- var literals = [];
- // Make literals inactive by replacing them with ??
- mask = mask.replace(literal, function ($0, $1) {
- literals.push($1);
- return '@@@';
- });
- // Apply formatting rules
- mask = mask.replace(token, function ($0) {
- return $0 in formatFlags ? formatFlags[$0](dateObj, i18n) : $0.slice(1, $0.length - 1);
- });
- // Inline literal values back into the formatted value
- return mask.replace(/@@@/g, function () {
- return literals.shift();
- });
- };
- /**
- * Parse a date string into an object, changes - into /
- * @method parse
- * @param {string} dateStr Date string
- * @param {string} format Date parse format
- * @returns {Date|boolean}
- */
- fecha.parse = function (dateStr, format, i18nSettings) {
- var i18n = i18nSettings || fecha.i18n;
- if (typeof format !== 'string') {
- throw new Error('Invalid format in fecha.parse');
- }
- format = fecha.masks[format] || format;
- // Avoid regular expression denial of service, fail early for really long strings
- // https://www.owasp.org/index.php/Regular_expression_Denial_of_Service_-_ReDoS
- if (dateStr.length > 1000) {
- return null;
- }
- var dateInfo = {};
- var parseInfo = [];
- var literals = [];
- format = format.replace(literal, function ($0, $1) {
- literals.push($1);
- return '@@@';
- });
- var newFormat = regexEscape(format).replace(token, function ($0) {
- if (parseFlags[$0]) {
- var info = parseFlags[$0];
- parseInfo.push(info[1]);
- return '(' + info[0] + ')';
- }
- return $0;
- });
- newFormat = newFormat.replace(/@@@/g, function () {
- return literals.shift();
- });
- var matches = dateStr.match(new RegExp(newFormat, 'i'));
- if (!matches) {
- return null;
- }
- for (var i = 1; i < matches.length; i++) {
- parseInfo[i - 1](dateInfo, matches[i], i18n);
- }
- var today = new Date();
- if (dateInfo.isPm === true && dateInfo.hour != null && +dateInfo.hour !== 12) {
- dateInfo.hour = +dateInfo.hour + 12;
- } else if (dateInfo.isPm === false && +dateInfo.hour === 12) {
- dateInfo.hour = 0;
- }
- var date;
- if (dateInfo.timezoneOffset != null) {
- dateInfo.minute = +(dateInfo.minute || 0) - +dateInfo.timezoneOffset;
- date = new Date(Date.UTC(dateInfo.year || today.getFullYear(), dateInfo.month || 0, dateInfo.day || 1, dateInfo.hour || 0, dateInfo.minute || 0, dateInfo.second || 0, dateInfo.millisecond || 0));
- } else {
- date = new Date(dateInfo.year || today.getFullYear(), dateInfo.month || 0, dateInfo.day || 1, dateInfo.hour || 0, dateInfo.minute || 0, dateInfo.second || 0, dateInfo.millisecond || 0);
- }
- return date;
- };
- /* istanbul ignore next */
- if ( true && module.exports) {
- module.exports = fecha;
- } else if (true) {
- !(__WEBPACK_AMD_DEFINE_RESULT__ = (function () {
- return fecha;
- }).call(exports, __webpack_require__, exports, module),
- __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
- } else {}
- })(undefined);
- /***/ }),
- /* 34 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.isDefined = exports.isUndefined = exports.isFunction = undefined;
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- exports.isString = isString;
- exports.isObject = isObject;
- exports.isHtmlElement = isHtmlElement;
- var _vue = __webpack_require__(0);
- var _vue2 = _interopRequireDefault(_vue);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- function isString(obj) {
- return Object.prototype.toString.call(obj) === '[object String]';
- }
- function isObject(obj) {
- return Object.prototype.toString.call(obj) === '[object Object]';
- }
- function isHtmlElement(node) {
- return node && node.nodeType === Node.ELEMENT_NODE;
- }
- /**
- * - Inspired:
- * https://github.com/jashkenas/underscore/blob/master/modules/isFunction.js
- */
- var isFunction = function isFunction(functionToCheck) {
- var getType = {};
- return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
- };
- if ( true && (typeof Int8Array === 'undefined' ? 'undefined' : _typeof(Int8Array)) !== 'object' && (_vue2.default.prototype.$isServer || typeof document.childNodes !== 'function')) {
- exports.isFunction = isFunction = function isFunction(obj) {
- return typeof obj === 'function' || false;
- };
- }
- exports.isFunction = isFunction;
- var isUndefined = exports.isUndefined = function isUndefined(val) {
- return val === void 0;
- };
- var isDefined = exports.isDefined = function isDefined(val) {
- return val !== undefined && val !== null;
- };
- /***/ }),
- /* 35 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.PopupManager = undefined;
- var _vue = __webpack_require__(0);
- var _vue2 = _interopRequireDefault(_vue);
- var _merge = __webpack_require__(13);
- var _merge2 = _interopRequireDefault(_merge);
- var _popupManager = __webpack_require__(64);
- var _popupManager2 = _interopRequireDefault(_popupManager);
- var _scrollbarWidth = __webpack_require__(19);
- var _scrollbarWidth2 = _interopRequireDefault(_scrollbarWidth);
- var _dom = __webpack_require__(6);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var idSeed = 1;
- var scrollBarWidth = void 0;
- exports.default = {
- props: {
- visible: {
- type: Boolean,
- default: false
- },
- openDelay: {},
- closeDelay: {},
- zIndex: {},
- modal: {
- type: Boolean,
- default: false
- },
- modalFade: {
- type: Boolean,
- default: true
- },
- modalClass: {},
- modalAppendToBody: {
- type: Boolean,
- default: false
- },
- lockScroll: {
- type: Boolean,
- default: true
- },
- closeOnPressEscape: {
- type: Boolean,
- default: false
- },
- closeOnClickModal: {
- type: Boolean,
- default: false
- }
- },
- beforeMount: function beforeMount() {
- this._popupId = 'popup-' + idSeed++;
- _popupManager2.default.register(this._popupId, this);
- },
- beforeDestroy: function beforeDestroy() {
- _popupManager2.default.deregister(this._popupId);
- _popupManager2.default.closeModal(this._popupId);
- this.restoreBodyStyle();
- },
- data: function data() {
- return {
- opened: false,
- bodyPaddingRight: null,
- computedBodyPaddingRight: 0,
- withoutHiddenClass: true,
- rendered: false
- };
- },
- watch: {
- visible: function visible(val) {
- var _this = this;
- if (val) {
- if (this._opening) return;
- if (!this.rendered) {
- this.rendered = true;
- _vue2.default.nextTick(function () {
- _this.open();
- });
- } else {
- this.open();
- }
- } else {
- this.close();
- }
- }
- },
- methods: {
- open: function open(options) {
- var _this2 = this;
- if (!this.rendered) {
- this.rendered = true;
- }
- var props = (0, _merge2.default)({}, this.$props || this, options);
- if (this._closeTimer) {
- clearTimeout(this._closeTimer);
- this._closeTimer = null;
- }
- clearTimeout(this._openTimer);
- var openDelay = Number(props.openDelay);
- if (openDelay > 0) {
- this._openTimer = setTimeout(function () {
- _this2._openTimer = null;
- _this2.doOpen(props);
- }, openDelay);
- } else {
- this.doOpen(props);
- }
- },
- doOpen: function doOpen(props) {
- if (this.$isServer) return;
- if (this.willOpen && !this.willOpen()) return;
- if (this.opened) return;
- this._opening = true;
- var dom = this.$el;
- var modal = props.modal;
- var zIndex = props.zIndex;
- if (zIndex) {
- _popupManager2.default.zIndex = zIndex;
- }
- if (modal) {
- if (this._closing) {
- _popupManager2.default.closeModal(this._popupId);
- this._closing = false;
- }
- _popupManager2.default.openModal(this._popupId, _popupManager2.default.nextZIndex(), this.modalAppendToBody ? undefined : dom, props.modalClass, props.modalFade);
- if (props.lockScroll) {
- this.withoutHiddenClass = !(0, _dom.hasClass)(document.body, 'el-popup-parent--hidden');
- if (this.withoutHiddenClass) {
- this.bodyPaddingRight = document.body.style.paddingRight;
- this.computedBodyPaddingRight = parseInt((0, _dom.getStyle)(document.body, 'paddingRight'), 10);
- }
- scrollBarWidth = (0, _scrollbarWidth2.default)();
- var bodyHasOverflow = document.documentElement.clientHeight < document.body.scrollHeight;
- var bodyOverflowY = (0, _dom.getStyle)(document.body, 'overflowY');
- if (scrollBarWidth > 0 && (bodyHasOverflow || bodyOverflowY === 'scroll') && this.withoutHiddenClass) {
- document.body.style.paddingRight = this.computedBodyPaddingRight + scrollBarWidth + 'px';
- }
- (0, _dom.addClass)(document.body, 'el-popup-parent--hidden');
- }
- }
- if (getComputedStyle(dom).position === 'static') {
- dom.style.position = 'absolute';
- }
- dom.style.zIndex = _popupManager2.default.nextZIndex();
- this.opened = true;
- this.onOpen && this.onOpen();
- this.doAfterOpen();
- },
- doAfterOpen: function doAfterOpen() {
- this._opening = false;
- },
- close: function close() {
- var _this3 = this;
- if (this.willClose && !this.willClose()) return;
- if (this._openTimer !== null) {
- clearTimeout(this._openTimer);
- this._openTimer = null;
- }
- clearTimeout(this._closeTimer);
- var closeDelay = Number(this.closeDelay);
- if (closeDelay > 0) {
- this._closeTimer = setTimeout(function () {
- _this3._closeTimer = null;
- _this3.doClose();
- }, closeDelay);
- } else {
- this.doClose();
- }
- },
- doClose: function doClose() {
- this._closing = true;
- this.onClose && this.onClose();
- if (this.lockScroll) {
- setTimeout(this.restoreBodyStyle, 200);
- }
- this.opened = false;
- this.doAfterClose();
- },
- doAfterClose: function doAfterClose() {
- _popupManager2.default.closeModal(this._popupId);
- this._closing = false;
- },
- restoreBodyStyle: function restoreBodyStyle() {
- if (this.modal && this.withoutHiddenClass) {
- document.body.style.paddingRight = this.bodyPaddingRight;
- (0, _dom.removeClass)(document.body, 'el-popup-parent--hidden');
- }
- this.withoutHiddenClass = true;
- }
- }
- };
- exports.PopupManager = _popupManager2.default;
- /***/ }),
- /* 36 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- var _util = __webpack_require__(4);
- /**
- * Show migrating guide in browser console.
- *
- * Usage:
- * import Migrating from 'element-ui/src/mixins/migrating';
- *
- * mixins: [Migrating]
- *
- * add getMigratingConfig method for your component.
- * getMigratingConfig() {
- * return {
- * props: {
- * 'allow-no-selection': 'allow-no-selection is removed.',
- * 'selection-mode': 'selection-mode is removed.'
- * },
- * events: {
- * selectionchange: 'selectionchange is renamed to selection-change.'
- * }
- * };
- * },
- */
- exports.default = {
- mounted: function mounted() {
- if (true) return;
- if (!this.$vnode) return;
- var _getMigratingConfig = this.getMigratingConfig(),
- _getMigratingConfig$p = _getMigratingConfig.props,
- props = _getMigratingConfig$p === undefined ? {} : _getMigratingConfig$p,
- _getMigratingConfig$e = _getMigratingConfig.events,
- events = _getMigratingConfig$e === undefined ? {} : _getMigratingConfig$e;
- var _$vnode = this.$vnode,
- data = _$vnode.data,
- componentOptions = _$vnode.componentOptions;
- var definedProps = data.attrs || {};
- var definedEvents = componentOptions.listeners || {};
- for (var propName in definedProps) {
- propName = (0, _util.kebabCase)(propName); // compatible with camel case
- if (props[propName]) {
- console.warn('[Element Migrating][' + this.$options.name + '][Attribute]: ' + props[propName]);
- }
- }
- for (var eventName in definedEvents) {
- eventName = (0, _util.kebabCase)(eventName); // compatible with camel case
- if (events[eventName]) {
- console.warn('[Element Migrating][' + this.$options.name + '][Event]: ' + events[eventName]);
- }
- }
- },
- methods: {
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {},
- events: {}
- };
- }
- }
- };
- /***/ }),
- /* 37 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- var _vue = __webpack_require__(0);
- var _vue2 = _interopRequireDefault(_vue);
- var _dom = __webpack_require__(6);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var nodeList = [];
- var ctx = '@@clickoutsideContext';
- var startClick = void 0;
- var seed = 0;
- !_vue2.default.prototype.$isServer && (0, _dom.on)(document, 'mousedown', function (e) {
- return startClick = e;
- });
- !_vue2.default.prototype.$isServer && (0, _dom.on)(document, 'mouseup', function (e) {
- nodeList.forEach(function (node) {
- return node[ctx].documentHandler(e, startClick);
- });
- });
- function createDocumentHandler(el, binding, vnode) {
- return function () {
- var mouseup = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
- var mousedown = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
- if (!vnode || !vnode.context || !mouseup.target || !mousedown.target || el.contains(mouseup.target) || el.contains(mousedown.target) || el === mouseup.target || vnode.context.popperElm && (vnode.context.popperElm.contains(mouseup.target) || vnode.context.popperElm.contains(mousedown.target))) return;
- if (binding.expression && el[ctx].methodName && vnode.context[el[ctx].methodName]) {
- vnode.context[el[ctx].methodName]();
- } else {
- el[ctx].bindingFn && el[ctx].bindingFn();
- }
- };
- }
- /**
- * v-clickoutside
- * @desc 点击元素外面才会触发的事件
- * @example
- * ```vue
- * <div v-element-clickoutside="handleClose">
- * ```
- */
- exports.default = {
- bind: function bind(el, binding, vnode) {
- nodeList.push(el);
- var id = seed++;
- el[ctx] = {
- id: id,
- documentHandler: createDocumentHandler(el, binding, vnode),
- methodName: binding.expression,
- bindingFn: binding.value
- };
- },
- update: function update(el, binding, vnode) {
- el[ctx].documentHandler = createDocumentHandler(el, binding, vnode);
- el[ctx].methodName = binding.expression;
- el[ctx].bindingFn = binding.value;
- },
- unbind: function unbind(el) {
- var len = nodeList.length;
- for (var i = 0; i < len; i++) {
- if (nodeList[i][ctx].id === el[ctx].id) {
- nodeList.splice(i, 1);
- break;
- }
- }
- delete el[ctx];
- }
- };
- /***/ }),
- /* 38 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 91);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 4:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(8);
- /***/ }),
- /***/ 91:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox.vue?vue&type=template&id=d0387074&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "label",
- {
- staticClass: "el-checkbox",
- class: [
- _vm.border && _vm.checkboxSize
- ? "el-checkbox--" + _vm.checkboxSize
- : "",
- { "is-disabled": _vm.isDisabled },
- { "is-bordered": _vm.border },
- { "is-checked": _vm.isChecked }
- ],
- attrs: { id: _vm.id }
- },
- [
- _c(
- "span",
- {
- staticClass: "el-checkbox__input",
- class: {
- "is-disabled": _vm.isDisabled,
- "is-checked": _vm.isChecked,
- "is-indeterminate": _vm.indeterminate,
- "is-focus": _vm.focus
- },
- attrs: {
- tabindex: _vm.indeterminate ? 0 : false,
- role: _vm.indeterminate ? "checkbox" : false,
- "aria-checked": _vm.indeterminate ? "mixed" : false
- }
- },
- [
- _c("span", { staticClass: "el-checkbox__inner" }),
- _vm.trueLabel || _vm.falseLabel
- ? _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model",
- value: _vm.model,
- expression: "model"
- }
- ],
- staticClass: "el-checkbox__original",
- attrs: {
- type: "checkbox",
- "aria-hidden": _vm.indeterminate ? "true" : "false",
- name: _vm.name,
- disabled: _vm.isDisabled,
- "true-value": _vm.trueLabel,
- "false-value": _vm.falseLabel
- },
- domProps: {
- checked: Array.isArray(_vm.model)
- ? _vm._i(_vm.model, null) > -1
- : _vm._q(_vm.model, _vm.trueLabel)
- },
- on: {
- change: [
- function($event) {
- var $$a = _vm.model,
- $$el = $event.target,
- $$c = $$el.checked ? _vm.trueLabel : _vm.falseLabel
- if (Array.isArray($$a)) {
- var $$v = null,
- $$i = _vm._i($$a, $$v)
- if ($$el.checked) {
- $$i < 0 && (_vm.model = $$a.concat([$$v]))
- } else {
- $$i > -1 &&
- (_vm.model = $$a
- .slice(0, $$i)
- .concat($$a.slice($$i + 1)))
- }
- } else {
- _vm.model = $$c
- }
- },
- _vm.handleChange
- ],
- focus: function($event) {
- _vm.focus = true
- },
- blur: function($event) {
- _vm.focus = false
- }
- }
- })
- : _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model",
- value: _vm.model,
- expression: "model"
- }
- ],
- staticClass: "el-checkbox__original",
- attrs: {
- type: "checkbox",
- "aria-hidden": _vm.indeterminate ? "true" : "false",
- disabled: _vm.isDisabled,
- name: _vm.name
- },
- domProps: {
- value: _vm.label,
- checked: Array.isArray(_vm.model)
- ? _vm._i(_vm.model, _vm.label) > -1
- : _vm.model
- },
- on: {
- change: [
- function($event) {
- var $$a = _vm.model,
- $$el = $event.target,
- $$c = $$el.checked ? true : false
- if (Array.isArray($$a)) {
- var $$v = _vm.label,
- $$i = _vm._i($$a, $$v)
- if ($$el.checked) {
- $$i < 0 && (_vm.model = $$a.concat([$$v]))
- } else {
- $$i > -1 &&
- (_vm.model = $$a
- .slice(0, $$i)
- .concat($$a.slice($$i + 1)))
- }
- } else {
- _vm.model = $$c
- }
- },
- _vm.handleChange
- ],
- focus: function($event) {
- _vm.focus = true
- },
- blur: function($event) {
- _vm.focus = false
- }
- }
- })
- ]
- ),
- _vm.$slots.default || _vm.label
- ? _c(
- "span",
- { staticClass: "el-checkbox__label" },
- [
- _vm._t("default"),
- !_vm.$slots.default ? [_vm._v(_vm._s(_vm.label))] : _vm._e()
- ],
- 2
- )
- : _vm._e()
- ]
- )
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue?vue&type=template&id=d0387074&
- // EXTERNAL MODULE: external "element-ui/lib/mixins/emitter"
- var emitter_ = __webpack_require__(4);
- var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var checkboxvue_type_script_lang_js_ = ({
- name: 'ElCheckbox',
- mixins: [emitter_default.a],
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- componentName: 'ElCheckbox',
- data: function data() {
- return {
- selfModel: false,
- focus: false,
- isLimitExceeded: false
- };
- },
- computed: {
- model: {
- get: function get() {
- return this.isGroup ? this.store : this.value !== undefined ? this.value : this.selfModel;
- },
- set: function set(val) {
- if (this.isGroup) {
- this.isLimitExceeded = false;
- this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (this.isLimitExceeded = true);
- this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (this.isLimitExceeded = true);
- this.isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]);
- } else {
- this.$emit('input', val);
- this.selfModel = val;
- }
- }
- },
- isChecked: function isChecked() {
- if ({}.toString.call(this.model) === '[object Boolean]') {
- return this.model;
- } else if (Array.isArray(this.model)) {
- return this.model.indexOf(this.label) > -1;
- } else if (this.model !== null && this.model !== undefined) {
- return this.model === this.trueLabel;
- }
- },
- isGroup: function isGroup() {
- var parent = this.$parent;
- while (parent) {
- if (parent.$options.componentName !== 'ElCheckboxGroup') {
- parent = parent.$parent;
- } else {
- this._checkboxGroup = parent;
- return true;
- }
- }
- return false;
- },
- store: function store() {
- return this._checkboxGroup ? this._checkboxGroup.value : this.value;
- },
- /* used to make the isDisabled judgment under max/min props */
- isLimitDisabled: function isLimitDisabled() {
- var _checkboxGroup = this._checkboxGroup,
- max = _checkboxGroup.max,
- min = _checkboxGroup.min;
- return !!(max || min) && this.model.length >= max && !this.isChecked || this.model.length <= min && this.isChecked;
- },
- isDisabled: function isDisabled() {
- return this.isGroup ? this._checkboxGroup.disabled || this.disabled || (this.elForm || {}).disabled || this.isLimitDisabled : this.disabled || (this.elForm || {}).disabled;
- },
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- checkboxSize: function checkboxSize() {
- var temCheckboxSize = this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- return this.isGroup ? this._checkboxGroup.checkboxGroupSize || temCheckboxSize : temCheckboxSize;
- }
- },
- props: {
- value: {},
- label: {},
- indeterminate: Boolean,
- disabled: Boolean,
- checked: Boolean,
- name: String,
- trueLabel: [String, Number],
- falseLabel: [String, Number],
- id: String, /* 当indeterminate为真时,为controls提供相关连的checkbox的id,表明元素间的控制关系*/
- controls: String, /* 当indeterminate为真时,为controls提供相关连的checkbox的id,表明元素间的控制关系*/
- border: Boolean,
- size: String
- },
- methods: {
- addToStore: function addToStore() {
- if (Array.isArray(this.model) && this.model.indexOf(this.label) === -1) {
- this.model.push(this.label);
- } else {
- this.model = this.trueLabel || true;
- }
- },
- handleChange: function handleChange(ev) {
- var _this = this;
- if (this.isLimitExceeded) return;
- var value = void 0;
- if (ev.target.checked) {
- value = this.trueLabel === undefined ? true : this.trueLabel;
- } else {
- value = this.falseLabel === undefined ? false : this.falseLabel;
- }
- this.$emit('change', value, ev);
- this.$nextTick(function () {
- if (_this.isGroup) {
- _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]);
- }
- });
- }
- },
- created: function created() {
- this.checked && this.addToStore();
- },
- mounted: function mounted() {
- // 为indeterminate元素 添加aria-controls 属性
- if (this.indeterminate) {
- this.$el.setAttribute('aria-controls', this.controls);
- }
- },
- watch: {
- value: function value(_value) {
- this.dispatch('ElFormItem', 'el.form.change', _value);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_checkboxvue_type_script_lang_js_ = (checkboxvue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_checkboxvue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/checkbox/src/checkbox.vue"
- /* harmony default export */ var src_checkbox = (component.exports);
- // CONCATENATED MODULE: ./packages/checkbox/index.js
- /* istanbul ignore next */
- src_checkbox.install = function (Vue) {
- Vue.component(src_checkbox.name, src_checkbox);
- };
- /* harmony default export */ var packages_checkbox = __webpack_exports__["default"] = (src_checkbox);
- /***/ })
- /******/ });
- /***/ }),
- /* 39 */
- /***/ (function(module, exports) {
- module.exports = require("throttle-debounce");
- /***/ }),
- /* 40 */
- /***/ (function(module, exports) {
- module.exports = require("babel-helper-vue-jsx-merge-props");
- /***/ }),
- /* 41 */
- /***/ (function(module, exports) {
- module.exports = function(module) {
- if (!module.webpackPolyfill) {
- module.deprecate = function() {};
- module.paths = [];
- // module.parent = undefined by default
- if (!module.children) module.children = [];
- Object.defineProperty(module, "loaded", {
- enumerable: true,
- get: function() {
- return module.l;
- }
- });
- Object.defineProperty(module, "id", {
- enumerable: true,
- get: function() {
- return module.i;
- }
- });
- module.webpackPolyfill = 1;
- }
- return module;
- };
- /***/ }),
- /* 42 */
- /***/ (function(module, exports) {
- /* WEBPACK VAR INJECTION */(function(__webpack_amd_options__) {/* globals __webpack_amd_options__ */
- module.exports = __webpack_amd_options__;
- /* WEBPACK VAR INJECTION */}.call(this, {}))
- /***/ }),
- /* 43 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 132);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 132:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tag/src/tag.vue?vue&type=script&lang=js&
- /* harmony default export */ var tagvue_type_script_lang_js_ = ({
- name: 'ElTag',
- props: {
- text: String,
- closable: Boolean,
- type: String,
- hit: Boolean,
- disableTransitions: Boolean,
- color: String,
- size: String,
- effect: {
- type: String,
- default: 'light',
- validator: function validator(val) {
- return ['dark', 'light', 'plain'].indexOf(val) !== -1;
- }
- }
- },
- methods: {
- handleClose: function handleClose(event) {
- event.stopPropagation();
- this.$emit('close', event);
- },
- handleClick: function handleClick(event) {
- this.$emit('click', event);
- }
- },
- computed: {
- tagSize: function tagSize() {
- return this.size || (this.$ELEMENT || {}).size;
- }
- },
- render: function render(h) {
- var type = this.type,
- tagSize = this.tagSize,
- hit = this.hit,
- effect = this.effect;
- var classes = ['el-tag', type ? 'el-tag--' + type : '', tagSize ? 'el-tag--' + tagSize : '', effect ? 'el-tag--' + effect : '', hit && 'is-hit'];
- var tagEl = h(
- 'span',
- {
- 'class': classes,
- style: { backgroundColor: this.color },
- on: {
- 'click': this.handleClick
- }
- },
- [this.$slots.default, this.closable && h('i', { 'class': 'el-tag__close el-icon-close', on: {
- 'click': this.handleClose
- }
- })]
- );
- return this.disableTransitions ? tagEl : h(
- 'transition',
- {
- attrs: { name: 'el-zoom-in-center' }
- },
- [tagEl]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/tag/src/tag.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_tagvue_type_script_lang_js_ = (tagvue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/tag/src/tag.vue
- var render, staticRenderFns
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_tagvue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/tag/src/tag.vue"
- /* harmony default export */ var tag = (component.exports);
- // CONCATENATED MODULE: ./packages/tag/index.js
- /* istanbul ignore next */
- tag.install = function (Vue) {
- Vue.component(tag.name, tag);
- };
- /* harmony default export */ var packages_tag = __webpack_exports__["default"] = (tag);
- /***/ })
- /******/ });
- /***/ }),
- /* 44 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 88);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 4:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(8);
- /***/ }),
- /***/ 88:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio.vue?vue&type=template&id=69cd6268&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "label",
- {
- staticClass: "el-radio",
- class: [
- _vm.border && _vm.radioSize ? "el-radio--" + _vm.radioSize : "",
- { "is-disabled": _vm.isDisabled },
- { "is-focus": _vm.focus },
- { "is-bordered": _vm.border },
- { "is-checked": _vm.model === _vm.label }
- ],
- attrs: {
- role: "radio",
- "aria-checked": _vm.model === _vm.label,
- "aria-disabled": _vm.isDisabled,
- tabindex: _vm.tabIndex
- },
- on: {
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "space", 32, $event.key, [" ", "Spacebar"])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.model = _vm.isDisabled ? _vm.model : _vm.label
- }
- }
- },
- [
- _c(
- "span",
- {
- staticClass: "el-radio__input",
- class: {
- "is-disabled": _vm.isDisabled,
- "is-checked": _vm.model === _vm.label
- }
- },
- [
- _c("span", { staticClass: "el-radio__inner" }),
- _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model",
- value: _vm.model,
- expression: "model"
- }
- ],
- ref: "radio",
- staticClass: "el-radio__original",
- attrs: {
- type: "radio",
- "aria-hidden": "true",
- name: _vm.name,
- disabled: _vm.isDisabled,
- tabindex: "-1",
- autocomplete: "off"
- },
- domProps: {
- value: _vm.label,
- checked: _vm._q(_vm.model, _vm.label)
- },
- on: {
- focus: function($event) {
- _vm.focus = true
- },
- blur: function($event) {
- _vm.focus = false
- },
- change: [
- function($event) {
- _vm.model = _vm.label
- },
- _vm.handleChange
- ]
- }
- })
- ]
- ),
- _c(
- "span",
- {
- staticClass: "el-radio__label",
- on: {
- keydown: function($event) {
- $event.stopPropagation()
- }
- }
- },
- [
- _vm._t("default"),
- !_vm.$slots.default ? [_vm._v(_vm._s(_vm.label))] : _vm._e()
- ],
- 2
- )
- ]
- )
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/radio/src/radio.vue?vue&type=template&id=69cd6268&
- // EXTERNAL MODULE: external "element-ui/lib/mixins/emitter"
- var emitter_ = __webpack_require__(4);
- var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var radiovue_type_script_lang_js_ = ({
- name: 'ElRadio',
- mixins: [emitter_default.a],
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- componentName: 'ElRadio',
- props: {
- value: {},
- label: {},
- disabled: Boolean,
- name: String,
- border: Boolean,
- size: String
- },
- data: function data() {
- return {
- focus: false
- };
- },
- computed: {
- isGroup: function isGroup() {
- var parent = this.$parent;
- while (parent) {
- if (parent.$options.componentName !== 'ElRadioGroup') {
- parent = parent.$parent;
- } else {
- this._radioGroup = parent;
- return true;
- }
- }
- return false;
- },
- model: {
- get: function get() {
- return this.isGroup ? this._radioGroup.value : this.value;
- },
- set: function set(val) {
- if (this.isGroup) {
- this.dispatch('ElRadioGroup', 'input', [val]);
- } else {
- this.$emit('input', val);
- }
- this.$refs.radio && (this.$refs.radio.checked = this.model === this.label);
- }
- },
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- radioSize: function radioSize() {
- var temRadioSize = this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- return this.isGroup ? this._radioGroup.radioGroupSize || temRadioSize : temRadioSize;
- },
- isDisabled: function isDisabled() {
- return this.isGroup ? this._radioGroup.disabled || this.disabled || (this.elForm || {}).disabled : this.disabled || (this.elForm || {}).disabled;
- },
- tabIndex: function tabIndex() {
- return this.isDisabled || this.isGroup && this.model !== this.label ? -1 : 0;
- }
- },
- methods: {
- handleChange: function handleChange() {
- var _this = this;
- this.$nextTick(function () {
- _this.$emit('change', _this.model);
- _this.isGroup && _this.dispatch('ElRadioGroup', 'handleChange', _this.model);
- });
- }
- }
- });
- // CONCATENATED MODULE: ./packages/radio/src/radio.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_radiovue_type_script_lang_js_ = (radiovue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/radio/src/radio.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_radiovue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/radio/src/radio.vue"
- /* harmony default export */ var src_radio = (component.exports);
- // CONCATENATED MODULE: ./packages/radio/index.js
- /* istanbul ignore next */
- src_radio.install = function (Vue) {
- Vue.component(src_radio.name, src_radio);
- };
- /* harmony default export */ var packages_radio = __webpack_exports__["default"] = (src_radio);
- /***/ })
- /******/ });
- /***/ }),
- /* 45 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 46 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 47 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 48 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 49 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 50 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 51 */
- /***/ (function(module, exports) {
- module.exports = require("node-fetch-native");
- /***/ }),
- /* 52 */
- /***/ (function(module, exports) {
- module.exports = require("vue-meta");
- /***/ }),
- /* 53 */
- /***/ (function(module, exports) {
- module.exports = require("cookie-universal");
- /***/ }),
- /* 54 */
- /***/ (function(module, exports) {
- module.exports = require("defu");
- /***/ }),
- /* 55 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.default = {
- el: {
- colorpicker: {
- confirm: 'OK',
- clear: 'Clear'
- },
- datepicker: {
- now: 'Now',
- today: 'Today',
- cancel: 'Cancel',
- clear: 'Clear',
- confirm: 'OK',
- selectDate: 'Select date',
- selectTime: 'Select time',
- startDate: 'Start Date',
- startTime: 'Start Time',
- endDate: 'End Date',
- endTime: 'End Time',
- prevYear: 'Previous Year',
- nextYear: 'Next Year',
- prevMonth: 'Previous Month',
- nextMonth: 'Next Month',
- year: '',
- month1: 'January',
- month2: 'February',
- month3: 'March',
- month4: 'April',
- month5: 'May',
- month6: 'June',
- month7: 'July',
- month8: 'August',
- month9: 'September',
- month10: 'October',
- month11: 'November',
- month12: 'December',
- week: 'week',
- weeks: {
- sun: 'Sun',
- mon: 'Mon',
- tue: 'Tue',
- wed: 'Wed',
- thu: 'Thu',
- fri: 'Fri',
- sat: 'Sat'
- },
- months: {
- jan: 'Jan',
- feb: 'Feb',
- mar: 'Mar',
- apr: 'Apr',
- may: 'May',
- jun: 'Jun',
- jul: 'Jul',
- aug: 'Aug',
- sep: 'Sep',
- oct: 'Oct',
- nov: 'Nov',
- dec: 'Dec'
- }
- },
- select: {
- loading: 'Loading',
- noMatch: 'No matching data',
- noData: 'No data',
- placeholder: 'Select'
- },
- cascader: {
- noMatch: 'No matching data',
- loading: 'Loading',
- placeholder: 'Select',
- noData: 'No data'
- },
- pagination: {
- goto: 'Go to',
- pagesize: '/page',
- total: 'Total {total}',
- pageClassifier: ''
- },
- messagebox: {
- title: 'Message',
- confirm: 'OK',
- cancel: 'Cancel',
- error: 'Illegal input'
- },
- upload: {
- deleteTip: 'press delete to remove',
- delete: 'Delete',
- preview: 'Preview',
- continue: 'Continue'
- },
- table: {
- emptyText: 'No Data',
- confirmFilter: 'Confirm',
- resetFilter: 'Reset',
- clearFilter: 'All',
- sumText: 'Sum'
- },
- tree: {
- emptyText: 'No Data'
- },
- transfer: {
- noMatch: 'No matching data',
- noData: 'No data',
- titles: ['List 1', 'List 2'], // to be translated
- filterPlaceholder: 'Enter keyword', // to be translated
- noCheckedFormat: '{total} items', // to be translated
- hasCheckedFormat: '{checked}/{total} checked' // to be translated
- },
- image: {
- error: 'FAILED'
- },
- pageHeader: {
- title: 'Back' // to be translated
- },
- popconfirm: {
- confirmButtonText: 'Yes',
- cancelButtonText: 'No'
- },
- empty: {
- description: 'No Data'
- }
- }
- };
- /***/ }),
- /* 56 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__.p + "img/logo.ebcafaa.png";
- /***/ }),
- /* 57 */
- /***/ (function(module, exports, __webpack_require__) {
- __webpack_require__(58);
- module.exports = __webpack_require__(107);
- /***/ }),
- /* 58 */
- /***/ (function(module, exports) {
- global.installComponents = function (component, components) {
- var options = typeof component.exports === 'function'
- ? component.exports.extendOptions
- : component.options
- if (typeof component.exports === 'function') {
- options.components = component.exports.options.components
- }
- options.components = options.components || {}
- for (var i in components) {
- options.components[i] = options.components[i] || components[i]
- }
- if (options.functional) {
- provideFunctionalComponents(component, options.components)
- }
- }
- var functionalPatchKey = '_functionalComponents'
- function provideFunctionalComponents(component, components) {
- if (component.exports[functionalPatchKey]) {
- return
- }
- component.exports[functionalPatchKey] = true
- var render = component.exports.render
- component.exports.render = function (h, vm) {
- return render(h, Object.assign({}, vm, {
- _c: function (n, a, b) {
- return vm._c(components[n] || n, a, b)
- }
- }))
- }
- }
- /***/ }),
- /* 59 */
- /***/ (function(module, exports) {
- module.exports = require("url");
- /***/ }),
- /* 60 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.validateRangeInOneMonth = exports.extractTimeFormat = exports.extractDateFormat = exports.nextYear = exports.prevYear = exports.nextMonth = exports.prevMonth = exports.changeYearMonthAndClampDate = exports.timeWithinRange = exports.limitTimeRange = exports.clearMilliseconds = exports.clearTime = exports.modifyWithTimeString = exports.modifyTime = exports.modifyDate = exports.range = exports.getRangeMinutes = exports.getMonthDays = exports.getPrevMonthLastDays = exports.getRangeHours = exports.getWeekNumber = exports.getStartDateOfMonth = exports.nextDate = exports.prevDate = exports.getFirstDayOfMonth = exports.getDayCountOfYear = exports.getDayCountOfMonth = exports.parseDate = exports.formatDate = exports.isDateObject = exports.isDate = exports.toDate = exports.getI18nSettings = undefined;
- var _date = __webpack_require__(33);
- var _date2 = _interopRequireDefault(_date);
- var _locale = __webpack_require__(17);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var weeks = ['sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat'];
- var months = ['jan', 'feb', 'mar', 'apr', 'may', 'jun', 'jul', 'aug', 'sep', 'oct', 'nov', 'dec'];
- var newArray = function newArray(start, end) {
- var result = [];
- for (var i = start; i <= end; i++) {
- result.push(i);
- }
- return result;
- };
- var getI18nSettings = exports.getI18nSettings = function getI18nSettings() {
- return {
- dayNamesShort: weeks.map(function (week) {
- return (0, _locale.t)('el.datepicker.weeks.' + week);
- }),
- dayNames: weeks.map(function (week) {
- return (0, _locale.t)('el.datepicker.weeks.' + week);
- }),
- monthNamesShort: months.map(function (month) {
- return (0, _locale.t)('el.datepicker.months.' + month);
- }),
- monthNames: months.map(function (month, index) {
- return (0, _locale.t)('el.datepicker.month' + (index + 1));
- }),
- amPm: ['am', 'pm']
- };
- };
- var toDate = exports.toDate = function toDate(date) {
- return isDate(date) ? new Date(date) : null;
- };
- var isDate = exports.isDate = function isDate(date) {
- if (date === null || date === undefined) return false;
- if (isNaN(new Date(date).getTime())) return false;
- if (Array.isArray(date)) return false; // deal with `new Date([ new Date() ]) -> new Date()`
- return true;
- };
- var isDateObject = exports.isDateObject = function isDateObject(val) {
- return val instanceof Date;
- };
- var formatDate = exports.formatDate = function formatDate(date, format) {
- date = toDate(date);
- if (!date) return '';
- return _date2.default.format(date, format || 'yyyy-MM-dd', getI18nSettings());
- };
- var parseDate = exports.parseDate = function parseDate(string, format) {
- return _date2.default.parse(string, format || 'yyyy-MM-dd', getI18nSettings());
- };
- var getDayCountOfMonth = exports.getDayCountOfMonth = function getDayCountOfMonth(year, month) {
- if (isNaN(+month)) return 31;
- return new Date(year, +month + 1, 0).getDate();
- };
- var getDayCountOfYear = exports.getDayCountOfYear = function getDayCountOfYear(year) {
- var isLeapYear = year % 400 === 0 || year % 100 !== 0 && year % 4 === 0;
- return isLeapYear ? 366 : 365;
- };
- var getFirstDayOfMonth = exports.getFirstDayOfMonth = function getFirstDayOfMonth(date) {
- var temp = new Date(date.getTime());
- temp.setDate(1);
- return temp.getDay();
- };
- // see: https://stackoverflow.com/questions/3674539/incrementing-a-date-in-javascript
- // {prev, next} Date should work for Daylight Saving Time
- // Adding 24 * 60 * 60 * 1000 does not work in the above scenario
- var prevDate = exports.prevDate = function prevDate(date) {
- var amount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
- return new Date(date.getFullYear(), date.getMonth(), date.getDate() - amount);
- };
- var nextDate = exports.nextDate = function nextDate(date) {
- var amount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
- return new Date(date.getFullYear(), date.getMonth(), date.getDate() + amount);
- };
- var getStartDateOfMonth = exports.getStartDateOfMonth = function getStartDateOfMonth(year, month) {
- var result = new Date(year, month, 1);
- var day = result.getDay();
- if (day === 0) {
- return prevDate(result, 7);
- } else {
- return prevDate(result, day);
- }
- };
- var getWeekNumber = exports.getWeekNumber = function getWeekNumber(src) {
- if (!isDate(src)) return null;
- var date = new Date(src.getTime());
- date.setHours(0, 0, 0, 0);
- // Thursday in current week decides the year.
- date.setDate(date.getDate() + 3 - (date.getDay() + 6) % 7);
- // January 4 is always in week 1.
- var week1 = new Date(date.getFullYear(), 0, 4);
- // Adjust to Thursday in week 1 and count number of weeks from date to week 1.
- // Rounding should be fine for Daylight Saving Time. Its shift should never be more than 12 hours.
- return 1 + Math.round(((date.getTime() - week1.getTime()) / 86400000 - 3 + (week1.getDay() + 6) % 7) / 7);
- };
- var getRangeHours = exports.getRangeHours = function getRangeHours(ranges) {
- var hours = [];
- var disabledHours = [];
- (ranges || []).forEach(function (range) {
- var value = range.map(function (date) {
- return date.getHours();
- });
- disabledHours = disabledHours.concat(newArray(value[0], value[1]));
- });
- if (disabledHours.length) {
- for (var i = 0; i < 24; i++) {
- hours[i] = disabledHours.indexOf(i) === -1;
- }
- } else {
- for (var _i = 0; _i < 24; _i++) {
- hours[_i] = false;
- }
- }
- return hours;
- };
- var getPrevMonthLastDays = exports.getPrevMonthLastDays = function getPrevMonthLastDays(date, amount) {
- if (amount <= 0) return [];
- var temp = new Date(date.getTime());
- temp.setDate(0);
- var lastDay = temp.getDate();
- return range(amount).map(function (_, index) {
- return lastDay - (amount - index - 1);
- });
- };
- var getMonthDays = exports.getMonthDays = function getMonthDays(date) {
- var temp = new Date(date.getFullYear(), date.getMonth() + 1, 0);
- var days = temp.getDate();
- return range(days).map(function (_, index) {
- return index + 1;
- });
- };
- function setRangeData(arr, start, end, value) {
- for (var i = start; i < end; i++) {
- arr[i] = value;
- }
- }
- var getRangeMinutes = exports.getRangeMinutes = function getRangeMinutes(ranges, hour) {
- var minutes = new Array(60);
- if (ranges.length > 0) {
- ranges.forEach(function (range) {
- var start = range[0];
- var end = range[1];
- var startHour = start.getHours();
- var startMinute = start.getMinutes();
- var endHour = end.getHours();
- var endMinute = end.getMinutes();
- if (startHour === hour && endHour !== hour) {
- setRangeData(minutes, startMinute, 60, true);
- } else if (startHour === hour && endHour === hour) {
- setRangeData(minutes, startMinute, endMinute + 1, true);
- } else if (startHour !== hour && endHour === hour) {
- setRangeData(minutes, 0, endMinute + 1, true);
- } else if (startHour < hour && endHour > hour) {
- setRangeData(minutes, 0, 60, true);
- }
- });
- } else {
- setRangeData(minutes, 0, 60, true);
- }
- return minutes;
- };
- var range = exports.range = function range(n) {
- // see https://stackoverflow.com/questions/3746725/create-a-javascript-array-containing-1-n
- return Array.apply(null, { length: n }).map(function (_, n) {
- return n;
- });
- };
- var modifyDate = exports.modifyDate = function modifyDate(date, y, m, d) {
- return new Date(y, m, d, date.getHours(), date.getMinutes(), date.getSeconds(), date.getMilliseconds());
- };
- var modifyTime = exports.modifyTime = function modifyTime(date, h, m, s) {
- return new Date(date.getFullYear(), date.getMonth(), date.getDate(), h, m, s, date.getMilliseconds());
- };
- var modifyWithTimeString = exports.modifyWithTimeString = function modifyWithTimeString(date, time) {
- if (date == null || !time) {
- return date;
- }
- time = parseDate(time, 'HH:mm:ss');
- return modifyTime(date, time.getHours(), time.getMinutes(), time.getSeconds());
- };
- var clearTime = exports.clearTime = function clearTime(date) {
- return new Date(date.getFullYear(), date.getMonth(), date.getDate());
- };
- var clearMilliseconds = exports.clearMilliseconds = function clearMilliseconds(date) {
- return new Date(date.getFullYear(), date.getMonth(), date.getDate(), date.getHours(), date.getMinutes(), date.getSeconds(), 0);
- };
- var limitTimeRange = exports.limitTimeRange = function limitTimeRange(date, ranges) {
- var format = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'HH:mm:ss';
- // TODO: refactory a more elegant solution
- if (ranges.length === 0) return date;
- var normalizeDate = function normalizeDate(date) {
- return _date2.default.parse(_date2.default.format(date, format), format);
- };
- var ndate = normalizeDate(date);
- var nranges = ranges.map(function (range) {
- return range.map(normalizeDate);
- });
- if (nranges.some(function (nrange) {
- return ndate >= nrange[0] && ndate <= nrange[1];
- })) return date;
- var minDate = nranges[0][0];
- var maxDate = nranges[0][0];
- nranges.forEach(function (nrange) {
- minDate = new Date(Math.min(nrange[0], minDate));
- maxDate = new Date(Math.max(nrange[1], minDate));
- });
- var ret = ndate < minDate ? minDate : maxDate;
- // preserve Year/Month/Date
- return modifyDate(ret, date.getFullYear(), date.getMonth(), date.getDate());
- };
- var timeWithinRange = exports.timeWithinRange = function timeWithinRange(date, selectableRange, format) {
- var limitedDate = limitTimeRange(date, selectableRange, format);
- return limitedDate.getTime() === date.getTime();
- };
- var changeYearMonthAndClampDate = exports.changeYearMonthAndClampDate = function changeYearMonthAndClampDate(date, year, month) {
- // clamp date to the number of days in `year`, `month`
- // eg: (2010-1-31, 2010, 2) => 2010-2-28
- var monthDate = Math.min(date.getDate(), getDayCountOfMonth(year, month));
- return modifyDate(date, year, month, monthDate);
- };
- var prevMonth = exports.prevMonth = function prevMonth(date) {
- var year = date.getFullYear();
- var month = date.getMonth();
- return month === 0 ? changeYearMonthAndClampDate(date, year - 1, 11) : changeYearMonthAndClampDate(date, year, month - 1);
- };
- var nextMonth = exports.nextMonth = function nextMonth(date) {
- var year = date.getFullYear();
- var month = date.getMonth();
- return month === 11 ? changeYearMonthAndClampDate(date, year + 1, 0) : changeYearMonthAndClampDate(date, year, month + 1);
- };
- var prevYear = exports.prevYear = function prevYear(date) {
- var amount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
- var year = date.getFullYear();
- var month = date.getMonth();
- return changeYearMonthAndClampDate(date, year - amount, month);
- };
- var nextYear = exports.nextYear = function nextYear(date) {
- var amount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
- var year = date.getFullYear();
- var month = date.getMonth();
- return changeYearMonthAndClampDate(date, year + amount, month);
- };
- var extractDateFormat = exports.extractDateFormat = function extractDateFormat(format) {
- return format.replace(/\W?m{1,2}|\W?ZZ/g, '').replace(/\W?h{1,2}|\W?s{1,3}|\W?a/gi, '').trim();
- };
- var extractTimeFormat = exports.extractTimeFormat = function extractTimeFormat(format) {
- return format.replace(/\W?D{1,2}|\W?Do|\W?d{1,4}|\W?M{1,4}|\W?y{2,4}/g, '').trim();
- };
- var validateRangeInOneMonth = exports.validateRangeInOneMonth = function validateRangeInOneMonth(start, end) {
- return start.getMonth() === end.getMonth() && start.getFullYear() === end.getFullYear();
- };
- /***/ }),
- /* 61 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.default = {
- el: {
- colorpicker: {
- confirm: '确定',
- clear: '清空'
- },
- datepicker: {
- now: '此刻',
- today: '今天',
- cancel: '取消',
- clear: '清空',
- confirm: '确定',
- selectDate: '选择日期',
- selectTime: '选择时间',
- startDate: '开始日期',
- startTime: '开始时间',
- endDate: '结束日期',
- endTime: '结束时间',
- prevYear: '前一年',
- nextYear: '后一年',
- prevMonth: '上个月',
- nextMonth: '下个月',
- year: '年',
- month1: '1 月',
- month2: '2 月',
- month3: '3 月',
- month4: '4 月',
- month5: '5 月',
- month6: '6 月',
- month7: '7 月',
- month8: '8 月',
- month9: '9 月',
- month10: '10 月',
- month11: '11 月',
- month12: '12 月',
- // week: '周次',
- weeks: {
- sun: '日',
- mon: '一',
- tue: '二',
- wed: '三',
- thu: '四',
- fri: '五',
- sat: '六'
- },
- months: {
- jan: '一月',
- feb: '二月',
- mar: '三月',
- apr: '四月',
- may: '五月',
- jun: '六月',
- jul: '七月',
- aug: '八月',
- sep: '九月',
- oct: '十月',
- nov: '十一月',
- dec: '十二月'
- }
- },
- select: {
- loading: '加载中',
- noMatch: '无匹配数据',
- noData: '无数据',
- placeholder: '请选择'
- },
- cascader: {
- noMatch: '无匹配数据',
- loading: '加载中',
- placeholder: '请选择',
- noData: '暂无数据'
- },
- pagination: {
- goto: '前往',
- pagesize: '条/页',
- total: '共 {total} 条',
- pageClassifier: '页'
- },
- messagebox: {
- title: '提示',
- confirm: '确定',
- cancel: '取消',
- error: '输入的数据不合法!'
- },
- upload: {
- deleteTip: '按 delete 键可删除',
- delete: '删除',
- preview: '查看图片',
- continue: '继续上传'
- },
- table: {
- emptyText: '暂无数据',
- confirmFilter: '筛选',
- resetFilter: '重置',
- clearFilter: '全部',
- sumText: '合计'
- },
- tree: {
- emptyText: '暂无数据'
- },
- transfer: {
- noMatch: '无匹配数据',
- noData: '无数据',
- titles: ['列表 1', '列表 2'],
- filterPlaceholder: '请输入搜索内容',
- noCheckedFormat: '共 {total} 项',
- hasCheckedFormat: '已选 {checked}/{total} 项'
- },
- image: {
- error: '加载失败'
- },
- pageHeader: {
- title: '返回'
- },
- popconfirm: {
- confirmButtonText: '确定',
- cancelButtonText: '取消'
- },
- empty: {
- description: '暂无数据'
- }
- }
- };
- /***/ }),
- /* 62 */
- /***/ (function(module, exports) {
- module.exports = require("deepmerge");
- /***/ }),
- /* 63 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- exports.default = function (Vue) {
- /**
- * template
- *
- * @param {String} string
- * @param {Array} ...args
- * @return {String}
- */
- function template(string) {
- for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
- args[_key - 1] = arguments[_key];
- }
- if (args.length === 1 && _typeof(args[0]) === 'object') {
- args = args[0];
- }
- if (!args || !args.hasOwnProperty) {
- args = {};
- }
- return string.replace(RE_NARGS, function (match, prefix, i, index) {
- var result = void 0;
- if (string[index - 1] === '{' && string[index + match.length] === '}') {
- return i;
- } else {
- result = (0, _util.hasOwn)(args, i) ? args[i] : null;
- if (result === null || result === undefined) {
- return '';
- }
- return result;
- }
- });
- }
- return template;
- };
- var _util = __webpack_require__(4);
- var RE_NARGS = /(%|)\{([0-9a-zA-Z_]+)\}/g;
- /**
- * String format template
- * - Inspired:
- * https://github.com/Matt-Esch/string-template/index.js
- */
- /***/ }),
- /* 64 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- var _vue = __webpack_require__(0);
- var _vue2 = _interopRequireDefault(_vue);
- var _dom = __webpack_require__(6);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var hasModal = false;
- var hasInitZIndex = false;
- var zIndex = void 0;
- var getModal = function getModal() {
- if (_vue2.default.prototype.$isServer) return;
- var modalDom = PopupManager.modalDom;
- if (modalDom) {
- hasModal = true;
- } else {
- hasModal = false;
- modalDom = document.createElement('div');
- PopupManager.modalDom = modalDom;
- modalDom.addEventListener('touchmove', function (event) {
- event.preventDefault();
- event.stopPropagation();
- });
- modalDom.addEventListener('click', function () {
- PopupManager.doOnModalClick && PopupManager.doOnModalClick();
- });
- }
- return modalDom;
- };
- var instances = {};
- var PopupManager = {
- modalFade: true,
- getInstance: function getInstance(id) {
- return instances[id];
- },
- register: function register(id, instance) {
- if (id && instance) {
- instances[id] = instance;
- }
- },
- deregister: function deregister(id) {
- if (id) {
- instances[id] = null;
- delete instances[id];
- }
- },
- nextZIndex: function nextZIndex() {
- return PopupManager.zIndex++;
- },
- modalStack: [],
- doOnModalClick: function doOnModalClick() {
- var topItem = PopupManager.modalStack[PopupManager.modalStack.length - 1];
- if (!topItem) return;
- var instance = PopupManager.getInstance(topItem.id);
- if (instance && instance.closeOnClickModal) {
- instance.close();
- }
- },
- openModal: function openModal(id, zIndex, dom, modalClass, modalFade) {
- if (_vue2.default.prototype.$isServer) return;
- if (!id || zIndex === undefined) return;
- this.modalFade = modalFade;
- var modalStack = this.modalStack;
- for (var i = 0, j = modalStack.length; i < j; i++) {
- var item = modalStack[i];
- if (item.id === id) {
- return;
- }
- }
- var modalDom = getModal();
- (0, _dom.addClass)(modalDom, 'v-modal');
- if (this.modalFade && !hasModal) {
- (0, _dom.addClass)(modalDom, 'v-modal-enter');
- }
- if (modalClass) {
- var classArr = modalClass.trim().split(/\s+/);
- classArr.forEach(function (item) {
- return (0, _dom.addClass)(modalDom, item);
- });
- }
- setTimeout(function () {
- (0, _dom.removeClass)(modalDom, 'v-modal-enter');
- }, 200);
- if (dom && dom.parentNode && dom.parentNode.nodeType !== 11) {
- dom.parentNode.appendChild(modalDom);
- } else {
- document.body.appendChild(modalDom);
- }
- if (zIndex) {
- modalDom.style.zIndex = zIndex;
- }
- modalDom.tabIndex = 0;
- modalDom.style.display = '';
- this.modalStack.push({ id: id, zIndex: zIndex, modalClass: modalClass });
- },
- closeModal: function closeModal(id) {
- var modalStack = this.modalStack;
- var modalDom = getModal();
- if (modalStack.length > 0) {
- var topItem = modalStack[modalStack.length - 1];
- if (topItem.id === id) {
- if (topItem.modalClass) {
- var classArr = topItem.modalClass.trim().split(/\s+/);
- classArr.forEach(function (item) {
- return (0, _dom.removeClass)(modalDom, item);
- });
- }
- modalStack.pop();
- if (modalStack.length > 0) {
- modalDom.style.zIndex = modalStack[modalStack.length - 1].zIndex;
- }
- } else {
- for (var i = modalStack.length - 1; i >= 0; i--) {
- if (modalStack[i].id === id) {
- modalStack.splice(i, 1);
- break;
- }
- }
- }
- }
- if (modalStack.length === 0) {
- if (this.modalFade) {
- (0, _dom.addClass)(modalDom, 'v-modal-leave');
- }
- setTimeout(function () {
- if (modalStack.length === 0) {
- if (modalDom.parentNode) modalDom.parentNode.removeChild(modalDom);
- modalDom.style.display = 'none';
- PopupManager.modalDom = undefined;
- }
- (0, _dom.removeClass)(modalDom, 'v-modal-leave');
- }, 200);
- }
- }
- };
- Object.defineProperty(PopupManager, 'zIndex', {
- configurable: true,
- get: function get() {
- if (!hasInitZIndex) {
- zIndex = zIndex || (_vue2.default.prototype.$ELEMENT || {}).zIndex || 2000;
- hasInitZIndex = true;
- }
- return zIndex;
- },
- set: function set(value) {
- zIndex = value;
- }
- });
- var getTopPopup = function getTopPopup() {
- if (_vue2.default.prototype.$isServer) return;
- if (PopupManager.modalStack.length > 0) {
- var topPopup = PopupManager.modalStack[PopupManager.modalStack.length - 1];
- if (!topPopup) return;
- var instance = PopupManager.getInstance(topPopup.id);
- return instance;
- }
- };
- if (!_vue2.default.prototype.$isServer) {
- // handle `esc` key when the popup is shown
- window.addEventListener('keydown', function (event) {
- if (event.keyCode === 27) {
- var topPopup = getTopPopup();
- if (topPopup && topPopup.closeOnPressEscape) {
- topPopup.handleClose ? topPopup.handleClose() : topPopup.handleAction ? topPopup.handleAction('cancel') : topPopup.close();
- }
- }
- });
- }
- exports.default = PopupManager;
- /***/ }),
- /* 65 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- /**
- * @fileOverview Kickass library to create and place poppers near their reference elements.
- * @version {{version}}
- * @license
- * Copyright (c) 2016 Federico Zivolo and contributors
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- */
- //
- // Cross module loader
- // Supported: Node, AMD, Browser globals
- //
- ;(function (root, factory) {
- if (true) {
- // AMD. Register as an anonymous module.
- !(__WEBPACK_AMD_DEFINE_FACTORY__ = (factory),
- __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?
- (__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :
- __WEBPACK_AMD_DEFINE_FACTORY__),
- __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
- } else {}
- })(undefined, function () {
- 'use strict';
- var root = window;
- // default options
- var DEFAULTS = {
- // placement of the popper
- placement: 'bottom',
- gpuAcceleration: true,
- // shift popper from its origin by the given amount of pixels (can be negative)
- offset: 0,
- // the element which will act as boundary of the popper
- boundariesElement: 'viewport',
- // amount of pixel used to define a minimum distance between the boundaries and the popper
- boundariesPadding: 5,
- // popper will try to prevent overflow following this order,
- // by default, then, it could overflow on the left and on top of the boundariesElement
- preventOverflowOrder: ['left', 'right', 'top', 'bottom'],
- // the behavior used by flip to change the placement of the popper
- flipBehavior: 'flip',
- arrowElement: '[x-arrow]',
- arrowOffset: 0,
- // list of functions used to modify the offsets before they are applied to the popper
- modifiers: ['shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle'],
- modifiersIgnored: [],
- forceAbsolute: false
- };
- /**
- * Create a new Popper.js instance
- * @constructor Popper
- * @param {HTMLElement} reference - The reference element used to position the popper
- * @param {HTMLElement|Object} popper
- * The HTML element used as popper, or a configuration used to generate the popper.
- * @param {String} [popper.tagName='div'] The tag name of the generated popper.
- * @param {Array} [popper.classNames=['popper']] Array of classes to apply to the generated popper.
- * @param {Array} [popper.attributes] Array of attributes to apply, specify `attr:value` to assign a value to it.
- * @param {HTMLElement|String} [popper.parent=window.document.body] The parent element, given as HTMLElement or as query string.
- * @param {String} [popper.content=''] The content of the popper, it can be text, html, or node; if it is not text, set `contentType` to `html` or `node`.
- * @param {String} [popper.contentType='text'] If `html`, the `content` will be parsed as HTML. If `node`, it will be appended as-is.
- * @param {String} [popper.arrowTagName='div'] Same as `popper.tagName` but for the arrow element.
- * @param {Array} [popper.arrowClassNames='popper__arrow'] Same as `popper.classNames` but for the arrow element.
- * @param {String} [popper.arrowAttributes=['x-arrow']] Same as `popper.attributes` but for the arrow element.
- * @param {Object} options
- * @param {String} [options.placement=bottom]
- * Placement of the popper accepted values: `top(-start, -end), right(-start, -end), bottom(-start, -right),
- * left(-start, -end)`
- *
- * @param {HTMLElement|String} [options.arrowElement='[x-arrow]']
- * The DOM Node used as arrow for the popper, or a CSS selector used to get the DOM node. It must be child of
- * its parent Popper. Popper.js will apply to the given element the style required to align the arrow with its
- * reference element.
- * By default, it will look for a child node of the popper with the `x-arrow` attribute.
- *
- * @param {Boolean} [options.gpuAcceleration=true]
- * When this property is set to true, the popper position will be applied using CSS3 translate3d, allowing the
- * browser to use the GPU to accelerate the rendering.
- * If set to false, the popper will be placed using `top` and `left` properties, not using the GPU.
- *
- * @param {Number} [options.offset=0]
- * Amount of pixels the popper will be shifted (can be negative).
- *
- * @param {String|Element} [options.boundariesElement='viewport']
- * The element which will define the boundaries of the popper position, the popper will never be placed outside
- * of the defined boundaries (except if `keepTogether` is enabled)
- *
- * @param {Number} [options.boundariesPadding=5]
- * Additional padding for the boundaries
- *
- * @param {Array} [options.preventOverflowOrder=['left', 'right', 'top', 'bottom']]
- * Order used when Popper.js tries to avoid overflows from the boundaries, they will be checked in order,
- * this means that the last ones will never overflow
- *
- * @param {String|Array} [options.flipBehavior='flip']
- * The behavior used by the `flip` modifier to change the placement of the popper when the latter is trying to
- * overlap its reference element. Defining `flip` as value, the placement will be flipped on
- * its axis (`right - left`, `top - bottom`).
- * You can even pass an array of placements (eg: `['right', 'left', 'top']` ) to manually specify
- * how alter the placement when a flip is needed. (eg. in the above example, it would first flip from right to left,
- * then, if even in its new placement, the popper is overlapping its reference element, it will be moved to top)
- *
- * @param {Array} [options.modifiers=[ 'shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle']]
- * List of functions used to modify the data before they are applied to the popper, add your custom functions
- * to this array to edit the offsets and placement.
- * The function should reflect the @params and @returns of preventOverflow
- *
- * @param {Array} [options.modifiersIgnored=[]]
- * Put here any built-in modifier name you want to exclude from the modifiers list
- * The function should reflect the @params and @returns of preventOverflow
- *
- * @param {Boolean} [options.removeOnDestroy=false]
- * Set to true if you want to automatically remove the popper when you call the `destroy` method.
- */
- function Popper(reference, popper, options) {
- this._reference = reference.jquery ? reference[0] : reference;
- this.state = {};
- // if the popper variable is a configuration object, parse it to generate an HTMLElement
- // generate a default popper if is not defined
- var isNotDefined = typeof popper === 'undefined' || popper === null;
- var isConfig = popper && Object.prototype.toString.call(popper) === '[object Object]';
- if (isNotDefined || isConfig) {
- this._popper = this.parse(isConfig ? popper : {});
- }
- // otherwise, use the given HTMLElement as popper
- else {
- this._popper = popper.jquery ? popper[0] : popper;
- }
- // with {} we create a new object with the options inside it
- this._options = Object.assign({}, DEFAULTS, options);
- // refactoring modifiers' list
- this._options.modifiers = this._options.modifiers.map(function (modifier) {
- // remove ignored modifiers
- if (this._options.modifiersIgnored.indexOf(modifier) !== -1) return;
- // set the x-placement attribute before everything else because it could be used to add margins to the popper
- // margins needs to be calculated to get the correct popper offsets
- if (modifier === 'applyStyle') {
- this._popper.setAttribute('x-placement', this._options.placement);
- }
- // return predefined modifier identified by string or keep the custom one
- return this.modifiers[modifier] || modifier;
- }.bind(this));
- // make sure to apply the popper position before any computation
- this.state.position = this._getPosition(this._popper, this._reference);
- setStyle(this._popper, { position: this.state.position, top: 0 });
- // fire the first update to position the popper in the right place
- this.update();
- // setup event listeners, they will take care of update the position in specific situations
- this._setupEventListeners();
- return this;
- }
- //
- // Methods
- //
- /**
- * Destroy the popper
- * @method
- * @memberof Popper
- */
- Popper.prototype.destroy = function () {
- this._popper.removeAttribute('x-placement');
- this._popper.style.left = '';
- this._popper.style.position = '';
- this._popper.style.top = '';
- this._popper.style[getSupportedPropertyName('transform')] = '';
- this._removeEventListeners();
- // remove the popper if user explicity asked for the deletion on destroy
- if (this._options.removeOnDestroy) {
- this._popper.remove();
- }
- return this;
- };
- /**
- * Updates the position of the popper, computing the new offsets and applying the new style
- * @method
- * @memberof Popper
- */
- Popper.prototype.update = function () {
- var data = { instance: this, styles: {} };
- // store placement inside the data object, modifiers will be able to edit `placement` if needed
- // and refer to _originalPlacement to know the original value
- data.placement = this._options.placement;
- data._originalPlacement = this._options.placement;
- // compute the popper and reference offsets and put them inside data.offsets
- data.offsets = this._getOffsets(this._popper, this._reference, data.placement);
- // get boundaries
- data.boundaries = this._getBoundaries(data, this._options.boundariesPadding, this._options.boundariesElement);
- data = this.runModifiers(data, this._options.modifiers);
- if (typeof this.state.updateCallback === 'function') {
- this.state.updateCallback(data);
- }
- };
- /**
- * If a function is passed, it will be executed after the initialization of popper with as first argument the Popper instance.
- * @method
- * @memberof Popper
- * @param {Function} callback
- */
- Popper.prototype.onCreate = function (callback) {
- // the createCallbacks return as first argument the popper instance
- callback(this);
- return this;
- };
- /**
- * If a function is passed, it will be executed after each update of popper with as first argument the set of coordinates and informations
- * used to style popper and its arrow.
- * NOTE: it doesn't get fired on the first call of the `Popper.update()` method inside the `Popper` constructor!
- * @method
- * @memberof Popper
- * @param {Function} callback
- */
- Popper.prototype.onUpdate = function (callback) {
- this.state.updateCallback = callback;
- return this;
- };
- /**
- * Helper used to generate poppers from a configuration file
- * @method
- * @memberof Popper
- * @param config {Object} configuration
- * @returns {HTMLElement} popper
- */
- Popper.prototype.parse = function (config) {
- var defaultConfig = {
- tagName: 'div',
- classNames: ['popper'],
- attributes: [],
- parent: root.document.body,
- content: '',
- contentType: 'text',
- arrowTagName: 'div',
- arrowClassNames: ['popper__arrow'],
- arrowAttributes: ['x-arrow']
- };
- config = Object.assign({}, defaultConfig, config);
- var d = root.document;
- var popper = d.createElement(config.tagName);
- addClassNames(popper, config.classNames);
- addAttributes(popper, config.attributes);
- if (config.contentType === 'node') {
- popper.appendChild(config.content.jquery ? config.content[0] : config.content);
- } else if (config.contentType === 'html') {
- popper.innerHTML = config.content;
- } else {
- popper.textContent = config.content;
- }
- if (config.arrowTagName) {
- var arrow = d.createElement(config.arrowTagName);
- addClassNames(arrow, config.arrowClassNames);
- addAttributes(arrow, config.arrowAttributes);
- popper.appendChild(arrow);
- }
- var parent = config.parent.jquery ? config.parent[0] : config.parent;
- // if the given parent is a string, use it to match an element
- // if more than one element is matched, the first one will be used as parent
- // if no elements are matched, the script will throw an error
- if (typeof parent === 'string') {
- parent = d.querySelectorAll(config.parent);
- if (parent.length > 1) {
- console.warn('WARNING: the given `parent` query(' + config.parent + ') matched more than one element, the first one will be used');
- }
- if (parent.length === 0) {
- throw 'ERROR: the given `parent` doesn\'t exists!';
- }
- parent = parent[0];
- }
- // if the given parent is a DOM nodes list or an array of nodes with more than one element,
- // the first one will be used as parent
- if (parent.length > 1 && parent instanceof Element === false) {
- console.warn('WARNING: you have passed as parent a list of elements, the first one will be used');
- parent = parent[0];
- }
- // append the generated popper to its parent
- parent.appendChild(popper);
- return popper;
- /**
- * Adds class names to the given element
- * @function
- * @ignore
- * @param {HTMLElement} target
- * @param {Array} classes
- */
- function addClassNames(element, classNames) {
- classNames.forEach(function (className) {
- element.classList.add(className);
- });
- }
- /**
- * Adds attributes to the given element
- * @function
- * @ignore
- * @param {HTMLElement} target
- * @param {Array} attributes
- * @example
- * addAttributes(element, [ 'data-info:foobar' ]);
- */
- function addAttributes(element, attributes) {
- attributes.forEach(function (attribute) {
- element.setAttribute(attribute.split(':')[0], attribute.split(':')[1] || '');
- });
- }
- };
- /**
- * Helper used to get the position which will be applied to the popper
- * @method
- * @memberof Popper
- * @param config {HTMLElement} popper element
- * @param reference {HTMLElement} reference element
- * @returns {String} position
- */
- Popper.prototype._getPosition = function (popper, reference) {
- var container = getOffsetParent(reference);
- if (this._options.forceAbsolute) {
- return 'absolute';
- }
- // Decide if the popper will be fixed
- // If the reference element is inside a fixed context, the popper will be fixed as well to allow them to scroll together
- var isParentFixed = isFixed(reference, container);
- return isParentFixed ? 'fixed' : 'absolute';
- };
- /**
- * Get offsets to the popper
- * @method
- * @memberof Popper
- * @access private
- * @param {Element} popper - the popper element
- * @param {Element} reference - the reference element (the popper will be relative to this)
- * @returns {Object} An object containing the offsets which will be applied to the popper
- */
- Popper.prototype._getOffsets = function (popper, reference, placement) {
- placement = placement.split('-')[0];
- var popperOffsets = {};
- popperOffsets.position = this.state.position;
- var isParentFixed = popperOffsets.position === 'fixed';
- //
- // Get reference element position
- //
- var referenceOffsets = getOffsetRectRelativeToCustomParent(reference, getOffsetParent(popper), isParentFixed);
- //
- // Get popper sizes
- //
- var popperRect = getOuterSizes(popper);
- //
- // Compute offsets of popper
- //
- // depending by the popper placement we have to compute its offsets slightly differently
- if (['right', 'left'].indexOf(placement) !== -1) {
- popperOffsets.top = referenceOffsets.top + referenceOffsets.height / 2 - popperRect.height / 2;
- if (placement === 'left') {
- popperOffsets.left = referenceOffsets.left - popperRect.width;
- } else {
- popperOffsets.left = referenceOffsets.right;
- }
- } else {
- popperOffsets.left = referenceOffsets.left + referenceOffsets.width / 2 - popperRect.width / 2;
- if (placement === 'top') {
- popperOffsets.top = referenceOffsets.top - popperRect.height;
- } else {
- popperOffsets.top = referenceOffsets.bottom;
- }
- }
- // Add width and height to our offsets object
- popperOffsets.width = popperRect.width;
- popperOffsets.height = popperRect.height;
- return {
- popper: popperOffsets,
- reference: referenceOffsets
- };
- };
- /**
- * Setup needed event listeners used to update the popper position
- * @method
- * @memberof Popper
- * @access private
- */
- Popper.prototype._setupEventListeners = function () {
- // NOTE: 1 DOM access here
- this.state.updateBound = this.update.bind(this);
- root.addEventListener('resize', this.state.updateBound);
- // if the boundariesElement is window we don't need to listen for the scroll event
- if (this._options.boundariesElement !== 'window') {
- var target = getScrollParent(this._reference);
- // here it could be both `body` or `documentElement` thanks to Firefox, we then check both
- if (target === root.document.body || target === root.document.documentElement) {
- target = root;
- }
- target.addEventListener('scroll', this.state.updateBound);
- this.state.scrollTarget = target;
- }
- };
- /**
- * Remove event listeners used to update the popper position
- * @method
- * @memberof Popper
- * @access private
- */
- Popper.prototype._removeEventListeners = function () {
- // NOTE: 1 DOM access here
- root.removeEventListener('resize', this.state.updateBound);
- if (this._options.boundariesElement !== 'window' && this.state.scrollTarget) {
- this.state.scrollTarget.removeEventListener('scroll', this.state.updateBound);
- this.state.scrollTarget = null;
- }
- this.state.updateBound = null;
- };
- /**
- * Computed the boundaries limits and return them
- * @method
- * @memberof Popper
- * @access private
- * @param {Object} data - Object containing the property "offsets" generated by `_getOffsets`
- * @param {Number} padding - Boundaries padding
- * @param {Element} boundariesElement - Element used to define the boundaries
- * @returns {Object} Coordinates of the boundaries
- */
- Popper.prototype._getBoundaries = function (data, padding, boundariesElement) {
- // NOTE: 1 DOM access here
- var boundaries = {};
- var width, height;
- if (boundariesElement === 'window') {
- var body = root.document.body,
- html = root.document.documentElement;
- height = Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight);
- width = Math.max(body.scrollWidth, body.offsetWidth, html.clientWidth, html.scrollWidth, html.offsetWidth);
- boundaries = {
- top: 0,
- right: width,
- bottom: height,
- left: 0
- };
- } else if (boundariesElement === 'viewport') {
- var offsetParent = getOffsetParent(this._popper);
- var scrollParent = getScrollParent(this._popper);
- var offsetParentRect = getOffsetRect(offsetParent);
- // Thanks the fucking native API, `document.body.scrollTop` & `document.documentElement.scrollTop`
- var getScrollTopValue = function getScrollTopValue(element) {
- return element == document.body ? Math.max(document.documentElement.scrollTop, document.body.scrollTop) : element.scrollTop;
- };
- var getScrollLeftValue = function getScrollLeftValue(element) {
- return element == document.body ? Math.max(document.documentElement.scrollLeft, document.body.scrollLeft) : element.scrollLeft;
- };
- // if the popper is fixed we don't have to substract scrolling from the boundaries
- var scrollTop = data.offsets.popper.position === 'fixed' ? 0 : getScrollTopValue(scrollParent);
- var scrollLeft = data.offsets.popper.position === 'fixed' ? 0 : getScrollLeftValue(scrollParent);
- boundaries = {
- top: 0 - (offsetParentRect.top - scrollTop),
- right: root.document.documentElement.clientWidth - (offsetParentRect.left - scrollLeft),
- bottom: root.document.documentElement.clientHeight - (offsetParentRect.top - scrollTop),
- left: 0 - (offsetParentRect.left - scrollLeft)
- };
- } else {
- if (getOffsetParent(this._popper) === boundariesElement) {
- boundaries = {
- top: 0,
- left: 0,
- right: boundariesElement.clientWidth,
- bottom: boundariesElement.clientHeight
- };
- } else {
- boundaries = getOffsetRect(boundariesElement);
- }
- }
- boundaries.left += padding;
- boundaries.right -= padding;
- boundaries.top = boundaries.top + padding;
- boundaries.bottom = boundaries.bottom - padding;
- return boundaries;
- };
- /**
- * Loop trough the list of modifiers and run them in order, each of them will then edit the data object
- * @method
- * @memberof Popper
- * @access public
- * @param {Object} data
- * @param {Array} modifiers
- * @param {Function} ends
- */
- Popper.prototype.runModifiers = function (data, modifiers, ends) {
- var modifiersToRun = modifiers.slice();
- if (ends !== undefined) {
- modifiersToRun = this._options.modifiers.slice(0, getArrayKeyIndex(this._options.modifiers, ends));
- }
- modifiersToRun.forEach(function (modifier) {
- if (isFunction(modifier)) {
- data = modifier.call(this, data);
- }
- }.bind(this));
- return data;
- };
- /**
- * Helper used to know if the given modifier depends from another one.
- * @method
- * @memberof Popper
- * @param {String} requesting - name of requesting modifier
- * @param {String} requested - name of requested modifier
- * @returns {Boolean}
- */
- Popper.prototype.isModifierRequired = function (requesting, requested) {
- var index = getArrayKeyIndex(this._options.modifiers, requesting);
- return !!this._options.modifiers.slice(0, index).filter(function (modifier) {
- return modifier === requested;
- }).length;
- };
- //
- // Modifiers
- //
- /**
- * Modifiers list
- * @namespace Popper.modifiers
- * @memberof Popper
- * @type {Object}
- */
- Popper.prototype.modifiers = {};
- /**
- * Apply the computed styles to the popper element
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by `update` method
- * @returns {Object} The same data object
- */
- Popper.prototype.modifiers.applyStyle = function (data) {
- // apply the final offsets to the popper
- // NOTE: 1 DOM access here
- var styles = {
- position: data.offsets.popper.position
- };
- // round top and left to avoid blurry text
- var left = Math.round(data.offsets.popper.left);
- var top = Math.round(data.offsets.popper.top);
- // if gpuAcceleration is set to true and transform is supported, we use `translate3d` to apply the position to the popper
- // we automatically use the supported prefixed version if needed
- var prefixedProperty;
- if (this._options.gpuAcceleration && (prefixedProperty = getSupportedPropertyName('transform'))) {
- styles[prefixedProperty] = 'translate3d(' + left + 'px, ' + top + 'px, 0)';
- styles.top = 0;
- styles.left = 0;
- }
- // othwerise, we use the standard `left` and `top` properties
- else {
- styles.left = left;
- styles.top = top;
- }
- // any property present in `data.styles` will be applied to the popper,
- // in this way we can make the 3rd party modifiers add custom styles to it
- // Be aware, modifiers could override the properties defined in the previous
- // lines of this modifier!
- Object.assign(styles, data.styles);
- setStyle(this._popper, styles);
- // set an attribute which will be useful to style the tooltip (use it to properly position its arrow)
- // NOTE: 1 DOM access here
- this._popper.setAttribute('x-placement', data.placement);
- // if the arrow modifier is required and the arrow style has been computed, apply the arrow style
- if (this.isModifierRequired(this.modifiers.applyStyle, this.modifiers.arrow) && data.offsets.arrow) {
- setStyle(data.arrowElement, data.offsets.arrow);
- }
- return data;
- };
- /**
- * Modifier used to shift the popper on the start or end of its reference element side
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by `update` method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.shift = function (data) {
- var placement = data.placement;
- var basePlacement = placement.split('-')[0];
- var shiftVariation = placement.split('-')[1];
- // if shift shiftVariation is specified, run the modifier
- if (shiftVariation) {
- var reference = data.offsets.reference;
- var popper = getPopperClientRect(data.offsets.popper);
- var shiftOffsets = {
- y: {
- start: { top: reference.top },
- end: { top: reference.top + reference.height - popper.height }
- },
- x: {
- start: { left: reference.left },
- end: { left: reference.left + reference.width - popper.width }
- }
- };
- var axis = ['bottom', 'top'].indexOf(basePlacement) !== -1 ? 'x' : 'y';
- data.offsets.popper = Object.assign(popper, shiftOffsets[axis][shiftVariation]);
- }
- return data;
- };
- /**
- * Modifier used to make sure the popper does not overflows from it's boundaries
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by `update` method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.preventOverflow = function (data) {
- var order = this._options.preventOverflowOrder;
- var popper = getPopperClientRect(data.offsets.popper);
- var check = {
- left: function left() {
- var left = popper.left;
- if (popper.left < data.boundaries.left) {
- left = Math.max(popper.left, data.boundaries.left);
- }
- return { left: left };
- },
- right: function right() {
- var left = popper.left;
- if (popper.right > data.boundaries.right) {
- left = Math.min(popper.left, data.boundaries.right - popper.width);
- }
- return { left: left };
- },
- top: function top() {
- var top = popper.top;
- if (popper.top < data.boundaries.top) {
- top = Math.max(popper.top, data.boundaries.top);
- }
- return { top: top };
- },
- bottom: function bottom() {
- var top = popper.top;
- if (popper.bottom > data.boundaries.bottom) {
- top = Math.min(popper.top, data.boundaries.bottom - popper.height);
- }
- return { top: top };
- }
- };
- order.forEach(function (direction) {
- data.offsets.popper = Object.assign(popper, check[direction]());
- });
- return data;
- };
- /**
- * Modifier used to make sure the popper is always near its reference
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by _update method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.keepTogether = function (data) {
- var popper = getPopperClientRect(data.offsets.popper);
- var reference = data.offsets.reference;
- var f = Math.floor;
- if (popper.right < f(reference.left)) {
- data.offsets.popper.left = f(reference.left) - popper.width;
- }
- if (popper.left > f(reference.right)) {
- data.offsets.popper.left = f(reference.right);
- }
- if (popper.bottom < f(reference.top)) {
- data.offsets.popper.top = f(reference.top) - popper.height;
- }
- if (popper.top > f(reference.bottom)) {
- data.offsets.popper.top = f(reference.bottom);
- }
- return data;
- };
- /**
- * Modifier used to flip the placement of the popper when the latter is starting overlapping its reference element.
- * Requires the `preventOverflow` modifier before it in order to work.
- * **NOTE:** This modifier will run all its previous modifiers everytime it tries to flip the popper!
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by _update method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.flip = function (data) {
- // check if preventOverflow is in the list of modifiers before the flip modifier.
- // otherwise flip would not work as expected.
- if (!this.isModifierRequired(this.modifiers.flip, this.modifiers.preventOverflow)) {
- console.warn('WARNING: preventOverflow modifier is required by flip modifier in order to work, be sure to include it before flip!');
- return data;
- }
- if (data.flipped && data.placement === data._originalPlacement) {
- // seems like flip is trying to loop, probably there's not enough space on any of the flippable sides
- return data;
- }
- var placement = data.placement.split('-')[0];
- var placementOpposite = getOppositePlacement(placement);
- var variation = data.placement.split('-')[1] || '';
- var flipOrder = [];
- if (this._options.flipBehavior === 'flip') {
- flipOrder = [placement, placementOpposite];
- } else {
- flipOrder = this._options.flipBehavior;
- }
- flipOrder.forEach(function (step, index) {
- if (placement !== step || flipOrder.length === index + 1) {
- return;
- }
- placement = data.placement.split('-')[0];
- placementOpposite = getOppositePlacement(placement);
- var popperOffsets = getPopperClientRect(data.offsets.popper);
- // this boolean is used to distinguish right and bottom from top and left
- // they need different computations to get flipped
- var a = ['right', 'bottom'].indexOf(placement) !== -1;
- // using Math.floor because the reference offsets may contain decimals we are not going to consider here
- if (a && Math.floor(data.offsets.reference[placement]) > Math.floor(popperOffsets[placementOpposite]) || !a && Math.floor(data.offsets.reference[placement]) < Math.floor(popperOffsets[placementOpposite])) {
- // we'll use this boolean to detect any flip loop
- data.flipped = true;
- data.placement = flipOrder[index + 1];
- if (variation) {
- data.placement += '-' + variation;
- }
- data.offsets.popper = this._getOffsets(this._popper, this._reference, data.placement).popper;
- data = this.runModifiers(data, this._options.modifiers, this._flip);
- }
- }.bind(this));
- return data;
- };
- /**
- * Modifier used to add an offset to the popper, useful if you more granularity positioning your popper.
- * The offsets will shift the popper on the side of its reference element.
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by _update method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.offset = function (data) {
- var offset = this._options.offset;
- var popper = data.offsets.popper;
- if (data.placement.indexOf('left') !== -1) {
- popper.top -= offset;
- } else if (data.placement.indexOf('right') !== -1) {
- popper.top += offset;
- } else if (data.placement.indexOf('top') !== -1) {
- popper.left -= offset;
- } else if (data.placement.indexOf('bottom') !== -1) {
- popper.left += offset;
- }
- return data;
- };
- /**
- * Modifier used to move the arrows on the edge of the popper to make sure them are always between the popper and the reference element
- * It will use the CSS outer size of the arrow element to know how many pixels of conjuction are needed
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by _update method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.arrow = function (data) {
- var arrow = this._options.arrowElement;
- var arrowOffset = this._options.arrowOffset;
- // if the arrowElement is a string, suppose it's a CSS selector
- if (typeof arrow === 'string') {
- arrow = this._popper.querySelector(arrow);
- }
- // if arrow element is not found, don't run the modifier
- if (!arrow) {
- return data;
- }
- // the arrow element must be child of its popper
- if (!this._popper.contains(arrow)) {
- console.warn('WARNING: `arrowElement` must be child of its popper element!');
- return data;
- }
- // arrow depends on keepTogether in order to work
- if (!this.isModifierRequired(this.modifiers.arrow, this.modifiers.keepTogether)) {
- console.warn('WARNING: keepTogether modifier is required by arrow modifier in order to work, be sure to include it before arrow!');
- return data;
- }
- var arrowStyle = {};
- var placement = data.placement.split('-')[0];
- var popper = getPopperClientRect(data.offsets.popper);
- var reference = data.offsets.reference;
- var isVertical = ['left', 'right'].indexOf(placement) !== -1;
- var len = isVertical ? 'height' : 'width';
- var side = isVertical ? 'top' : 'left';
- var translate = isVertical ? 'translateY' : 'translateX';
- var altSide = isVertical ? 'left' : 'top';
- var opSide = isVertical ? 'bottom' : 'right';
- var arrowSize = getOuterSizes(arrow)[len];
- //
- // extends keepTogether behavior making sure the popper and its reference have enough pixels in conjuction
- //
- // top/left side
- if (reference[opSide] - arrowSize < popper[side]) {
- data.offsets.popper[side] -= popper[side] - (reference[opSide] - arrowSize);
- }
- // bottom/right side
- if (reference[side] + arrowSize > popper[opSide]) {
- data.offsets.popper[side] += reference[side] + arrowSize - popper[opSide];
- }
- // compute center of the popper
- var center = reference[side] + (arrowOffset || reference[len] / 2 - arrowSize / 2);
- var sideValue = center - popper[side];
- // prevent arrow from being placed not contiguously to its popper
- sideValue = Math.max(Math.min(popper[len] - arrowSize - 8, sideValue), 8);
- arrowStyle[side] = sideValue;
- arrowStyle[altSide] = ''; // make sure to remove any old style from the arrow
- data.offsets.arrow = arrowStyle;
- data.arrowElement = arrow;
- return data;
- };
- //
- // Helpers
- //
- /**
- * Get the outer sizes of the given element (offset size + margins)
- * @function
- * @ignore
- * @argument {Element} element
- * @returns {Object} object containing width and height properties
- */
- function getOuterSizes(element) {
- // NOTE: 1 DOM access here
- var _display = element.style.display,
- _visibility = element.style.visibility;
- element.style.display = 'block';element.style.visibility = 'hidden';
- var calcWidthToForceRepaint = element.offsetWidth;
- // original method
- var styles = root.getComputedStyle(element);
- var x = parseFloat(styles.marginTop) + parseFloat(styles.marginBottom);
- var y = parseFloat(styles.marginLeft) + parseFloat(styles.marginRight);
- var result = { width: element.offsetWidth + y, height: element.offsetHeight + x };
- // reset element styles
- element.style.display = _display;element.style.visibility = _visibility;
- return result;
- }
- /**
- * Get the opposite placement of the given one/
- * @function
- * @ignore
- * @argument {String} placement
- * @returns {String} flipped placement
- */
- function getOppositePlacement(placement) {
- var hash = { left: 'right', right: 'left', bottom: 'top', top: 'bottom' };
- return placement.replace(/left|right|bottom|top/g, function (matched) {
- return hash[matched];
- });
- }
- /**
- * Given the popper offsets, generate an output similar to getBoundingClientRect
- * @function
- * @ignore
- * @argument {Object} popperOffsets
- * @returns {Object} ClientRect like output
- */
- function getPopperClientRect(popperOffsets) {
- var offsets = Object.assign({}, popperOffsets);
- offsets.right = offsets.left + offsets.width;
- offsets.bottom = offsets.top + offsets.height;
- return offsets;
- }
- /**
- * Given an array and the key to find, returns its index
- * @function
- * @ignore
- * @argument {Array} arr
- * @argument keyToFind
- * @returns index or null
- */
- function getArrayKeyIndex(arr, keyToFind) {
- var i = 0,
- key;
- for (key in arr) {
- if (arr[key] === keyToFind) {
- return i;
- }
- i++;
- }
- return null;
- }
- /**
- * Get CSS computed property of the given element
- * @function
- * @ignore
- * @argument {Eement} element
- * @argument {String} property
- */
- function getStyleComputedProperty(element, property) {
- // NOTE: 1 DOM access here
- var css = root.getComputedStyle(element, null);
- return css[property];
- }
- /**
- * Returns the offset parent of the given element
- * @function
- * @ignore
- * @argument {Element} element
- * @returns {Element} offset parent
- */
- function getOffsetParent(element) {
- // NOTE: 1 DOM access here
- var offsetParent = element.offsetParent;
- return offsetParent === root.document.body || !offsetParent ? root.document.documentElement : offsetParent;
- }
- /**
- * Returns the scrolling parent of the given element
- * @function
- * @ignore
- * @argument {Element} element
- * @returns {Element} offset parent
- */
- function getScrollParent(element) {
- var parent = element.parentNode;
- if (!parent) {
- return element;
- }
- if (parent === root.document) {
- // Firefox puts the scrollTOp value on `documentElement` instead of `body`, we then check which of them is
- // greater than 0 and return the proper element
- if (root.document.body.scrollTop || root.document.body.scrollLeft) {
- return root.document.body;
- } else {
- return root.document.documentElement;
- }
- }
- // Firefox want us to check `-x` and `-y` variations as well
- if (['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow')) !== -1 || ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-x')) !== -1 || ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-y')) !== -1) {
- // If the detected scrollParent is body, we perform an additional check on its parentNode
- // in this way we'll get body if the browser is Chrome-ish, or documentElement otherwise
- // fixes issue #65
- return parent;
- }
- return getScrollParent(element.parentNode);
- }
- /**
- * Check if the given element is fixed or is inside a fixed parent
- * @function
- * @ignore
- * @argument {Element} element
- * @argument {Element} customContainer
- * @returns {Boolean} answer to "isFixed?"
- */
- function isFixed(element) {
- if (element === root.document.body) {
- return false;
- }
- if (getStyleComputedProperty(element, 'position') === 'fixed') {
- return true;
- }
- return element.parentNode ? isFixed(element.parentNode) : element;
- }
- /**
- * Set the style to the given popper
- * @function
- * @ignore
- * @argument {Element} element - Element to apply the style to
- * @argument {Object} styles - Object with a list of properties and values which will be applied to the element
- */
- function setStyle(element, styles) {
- function is_numeric(n) {
- return n !== '' && !isNaN(parseFloat(n)) && isFinite(n);
- }
- Object.keys(styles).forEach(function (prop) {
- var unit = '';
- // add unit if the value is numeric and is one of the following
- if (['width', 'height', 'top', 'right', 'bottom', 'left'].indexOf(prop) !== -1 && is_numeric(styles[prop])) {
- unit = 'px';
- }
- element.style[prop] = styles[prop] + unit;
- });
- }
- /**
- * Check if the given variable is a function
- * @function
- * @ignore
- * @argument {*} functionToCheck - variable to check
- * @returns {Boolean} answer to: is a function?
- */
- function isFunction(functionToCheck) {
- var getType = {};
- return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
- }
- /**
- * Get the position of the given element, relative to its offset parent
- * @function
- * @ignore
- * @param {Element} element
- * @return {Object} position - Coordinates of the element and its `scrollTop`
- */
- function getOffsetRect(element) {
- var elementRect = {
- width: element.offsetWidth,
- height: element.offsetHeight,
- left: element.offsetLeft,
- top: element.offsetTop
- };
- elementRect.right = elementRect.left + elementRect.width;
- elementRect.bottom = elementRect.top + elementRect.height;
- // position
- return elementRect;
- }
- /**
- * Get bounding client rect of given element
- * @function
- * @ignore
- * @param {HTMLElement} element
- * @return {Object} client rect
- */
- function getBoundingClientRect(element) {
- var rect = element.getBoundingClientRect();
- // whether the IE version is lower than 11
- var isIE = navigator.userAgent.indexOf("MSIE") != -1;
- // fix ie document bounding top always 0 bug
- var rectTop = isIE && element.tagName === 'HTML' ? -element.scrollTop : rect.top;
- return {
- left: rect.left,
- top: rectTop,
- right: rect.right,
- bottom: rect.bottom,
- width: rect.right - rect.left,
- height: rect.bottom - rectTop
- };
- }
- /**
- * Given an element and one of its parents, return the offset
- * @function
- * @ignore
- * @param {HTMLElement} element
- * @param {HTMLElement} parent
- * @return {Object} rect
- */
- function getOffsetRectRelativeToCustomParent(element, parent, fixed) {
- var elementRect = getBoundingClientRect(element);
- var parentRect = getBoundingClientRect(parent);
- if (fixed) {
- var scrollParent = getScrollParent(parent);
- parentRect.top += scrollParent.scrollTop;
- parentRect.bottom += scrollParent.scrollTop;
- parentRect.left += scrollParent.scrollLeft;
- parentRect.right += scrollParent.scrollLeft;
- }
- var rect = {
- top: elementRect.top - parentRect.top,
- left: elementRect.left - parentRect.left,
- bottom: elementRect.top - parentRect.top + elementRect.height,
- right: elementRect.left - parentRect.left + elementRect.width,
- width: elementRect.width,
- height: elementRect.height
- };
- return rect;
- }
- /**
- * Get the prefixed supported property name
- * @function
- * @ignore
- * @argument {String} property (camelCase)
- * @returns {String} prefixed property (camelCase)
- */
- function getSupportedPropertyName(property) {
- var prefixes = ['', 'ms', 'webkit', 'moz', 'o'];
- for (var i = 0; i < prefixes.length; i++) {
- var toCheck = prefixes[i] ? prefixes[i] + property.charAt(0).toUpperCase() + property.slice(1) : property;
- if (typeof root.document.body.style[toCheck] !== 'undefined') {
- return toCheck;
- }
- }
- return null;
- }
- /**
- * The Object.assign() method is used to copy the values of all enumerable own properties from one or more source
- * objects to a target object. It will return the target object.
- * This polyfill doesn't support symbol properties, since ES5 doesn't have symbols anyway
- * Source: https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign
- * @function
- * @ignore
- */
- if (!Object.assign) {
- Object.defineProperty(Object, 'assign', {
- enumerable: false,
- configurable: true,
- writable: true,
- value: function value(target) {
- if (target === undefined || target === null) {
- throw new TypeError('Cannot convert first argument to object');
- }
- var to = Object(target);
- for (var i = 1; i < arguments.length; i++) {
- var nextSource = arguments[i];
- if (nextSource === undefined || nextSource === null) {
- continue;
- }
- nextSource = Object(nextSource);
- var keysArray = Object.keys(nextSource);
- for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex++) {
- var nextKey = keysArray[nextIndex];
- var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);
- if (desc !== undefined && desc.enumerable) {
- to[nextKey] = nextSource[nextKey];
- }
- }
- }
- return to;
- }
- });
- }
- return Popper;
- });
- /***/ }),
- /* 66 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 96);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 96:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button.vue?vue&type=template&id=ca859fb4&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "button",
- {
- staticClass: "el-button",
- class: [
- _vm.type ? "el-button--" + _vm.type : "",
- _vm.buttonSize ? "el-button--" + _vm.buttonSize : "",
- {
- "is-disabled": _vm.buttonDisabled,
- "is-loading": _vm.loading,
- "is-plain": _vm.plain,
- "is-round": _vm.round,
- "is-circle": _vm.circle
- }
- ],
- attrs: {
- disabled: _vm.buttonDisabled || _vm.loading,
- autofocus: _vm.autofocus,
- type: _vm.nativeType
- },
- on: { click: _vm.handleClick }
- },
- [
- _vm.loading ? _c("i", { staticClass: "el-icon-loading" }) : _vm._e(),
- _vm.icon && !_vm.loading ? _c("i", { class: _vm.icon }) : _vm._e(),
- _vm.$slots.default ? _c("span", [_vm._t("default")], 2) : _vm._e()
- ]
- )
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/button/src/button.vue?vue&type=template&id=ca859fb4&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var buttonvue_type_script_lang_js_ = ({
- name: 'ElButton',
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- props: {
- type: {
- type: String,
- default: 'default'
- },
- size: String,
- icon: {
- type: String,
- default: ''
- },
- nativeType: {
- type: String,
- default: 'button'
- },
- loading: Boolean,
- disabled: Boolean,
- plain: Boolean,
- autofocus: Boolean,
- round: Boolean,
- circle: Boolean
- },
- computed: {
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- buttonSize: function buttonSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- buttonDisabled: function buttonDisabled() {
- return this.$options.propsData.hasOwnProperty('disabled') ? this.disabled : (this.elForm || {}).disabled;
- }
- },
- methods: {
- handleClick: function handleClick(evt) {
- this.$emit('click', evt);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/button/src/button.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_buttonvue_type_script_lang_js_ = (buttonvue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/button/src/button.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_buttonvue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/button/src/button.vue"
- /* harmony default export */ var src_button = (component.exports);
- // CONCATENATED MODULE: ./packages/button/index.js
- /* istanbul ignore next */
- src_button.install = function (Vue) {
- Vue.component(src_button.name, src_button);
- };
- /* harmony default export */ var packages_button = __webpack_exports__["default"] = (src_button);
- /***/ })
- /******/ });
- /***/ }),
- /* 67 */
- /***/ (function(module, exports) {
- module.exports = require("resize-observer-polyfill");
- /***/ }),
- /* 68 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- var _dom = __webpack_require__(6);
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- var Transition = function () {
- function Transition() {
- _classCallCheck(this, Transition);
- }
- Transition.prototype.beforeEnter = function beforeEnter(el) {
- (0, _dom.addClass)(el, 'collapse-transition');
- if (!el.dataset) el.dataset = {};
- el.dataset.oldPaddingTop = el.style.paddingTop;
- el.dataset.oldPaddingBottom = el.style.paddingBottom;
- el.style.height = '0';
- el.style.paddingTop = 0;
- el.style.paddingBottom = 0;
- };
- Transition.prototype.enter = function enter(el) {
- el.dataset.oldOverflow = el.style.overflow;
- if (el.scrollHeight !== 0) {
- el.style.height = el.scrollHeight + 'px';
- el.style.paddingTop = el.dataset.oldPaddingTop;
- el.style.paddingBottom = el.dataset.oldPaddingBottom;
- } else {
- el.style.height = '';
- el.style.paddingTop = el.dataset.oldPaddingTop;
- el.style.paddingBottom = el.dataset.oldPaddingBottom;
- }
- el.style.overflow = 'hidden';
- };
- Transition.prototype.afterEnter = function afterEnter(el) {
- // for safari: remove class then reset height is necessary
- (0, _dom.removeClass)(el, 'collapse-transition');
- el.style.height = '';
- el.style.overflow = el.dataset.oldOverflow;
- };
- Transition.prototype.beforeLeave = function beforeLeave(el) {
- if (!el.dataset) el.dataset = {};
- el.dataset.oldPaddingTop = el.style.paddingTop;
- el.dataset.oldPaddingBottom = el.style.paddingBottom;
- el.dataset.oldOverflow = el.style.overflow;
- el.style.height = el.scrollHeight + 'px';
- el.style.overflow = 'hidden';
- };
- Transition.prototype.leave = function leave(el) {
- if (el.scrollHeight !== 0) {
- // for safari: add class after set height, or it will jump to zero height suddenly, weired
- (0, _dom.addClass)(el, 'collapse-transition');
- el.style.height = 0;
- el.style.paddingTop = 0;
- el.style.paddingBottom = 0;
- }
- };
- Transition.prototype.afterLeave = function afterLeave(el) {
- (0, _dom.removeClass)(el, 'collapse-transition');
- el.style.height = '';
- el.style.overflow = el.dataset.oldOverflow;
- el.style.paddingTop = el.dataset.oldPaddingTop;
- el.style.paddingBottom = el.dataset.oldPaddingBottom;
- };
- return Transition;
- }();
- exports.default = {
- name: 'ElCollapseTransition',
- functional: true,
- render: function render(h, _ref) {
- var children = _ref.children;
- var data = {
- on: new Transition()
- };
- return h('transition', data, children);
- }
- };
- /***/ }),
- /* 69 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- exports.isVNode = isVNode;
- var _util = __webpack_require__(4);
- function isVNode(node) {
- return node !== null && (typeof node === 'undefined' ? 'undefined' : _typeof(node)) === 'object' && (0, _util.hasOwn)(node, 'componentOptions');
- };
- /***/ }),
- /* 70 */
- /***/ (function(module, exports) {
- module.exports = require("throttle-debounce/throttle");
- /***/ }),
- /* 71 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 138);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 138:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper"
- var vue_popper_ = __webpack_require__(5);
- var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_);
- // EXTERNAL MODULE: external "throttle-debounce/debounce"
- var debounce_ = __webpack_require__(19);
- var debounce_default = /*#__PURE__*/__webpack_require__.n(debounce_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/dom"
- var dom_ = __webpack_require__(2);
- // EXTERNAL MODULE: external "element-ui/lib/utils/util"
- var util_ = __webpack_require__(3);
- // EXTERNAL MODULE: external "vue"
- var external_vue_ = __webpack_require__(7);
- var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_);
- // CONCATENATED MODULE: ./packages/tooltip/src/main.js
- /* harmony default export */ var main = ({
- name: 'ElTooltip',
- mixins: [vue_popper_default.a],
- props: {
- openDelay: {
- type: Number,
- default: 0
- },
- disabled: Boolean,
- manual: Boolean,
- effect: {
- type: String,
- default: 'dark'
- },
- arrowOffset: {
- type: Number,
- default: 0
- },
- popperClass: String,
- content: String,
- visibleArrow: {
- default: true
- },
- transition: {
- type: String,
- default: 'el-fade-in-linear'
- },
- popperOptions: {
- default: function _default() {
- return {
- boundariesPadding: 10,
- gpuAcceleration: false
- };
- }
- },
- enterable: {
- type: Boolean,
- default: true
- },
- hideAfter: {
- type: Number,
- default: 0
- },
- tabindex: {
- type: Number,
- default: 0
- }
- },
- data: function data() {
- return {
- tooltipId: 'el-tooltip-' + Object(util_["generateId"])(),
- timeoutPending: null,
- focusing: false
- };
- },
- beforeCreate: function beforeCreate() {
- var _this = this;
- if (this.$isServer) return;
- this.popperVM = new external_vue_default.a({
- data: { node: '' },
- render: function render(h) {
- return this.node;
- }
- }).$mount();
- this.debounceClose = debounce_default()(200, function () {
- return _this.handleClosePopper();
- });
- },
- render: function render(h) {
- var _this2 = this;
- if (this.popperVM) {
- this.popperVM.node = h(
- 'transition',
- {
- attrs: {
- name: this.transition
- },
- on: {
- 'afterLeave': this.doDestroy
- }
- },
- [h(
- 'div',
- {
- on: {
- 'mouseleave': function mouseleave() {
- _this2.setExpectedState(false);_this2.debounceClose();
- },
- 'mouseenter': function mouseenter() {
- _this2.setExpectedState(true);
- }
- },
- ref: 'popper',
- attrs: { role: 'tooltip',
- id: this.tooltipId,
- 'aria-hidden': this.disabled || !this.showPopper ? 'true' : 'false'
- },
- directives: [{
- name: 'show',
- value: !this.disabled && this.showPopper
- }],
- 'class': ['el-tooltip__popper', 'is-' + this.effect, this.popperClass] },
- [this.$slots.content || this.content]
- )]
- );
- }
- var firstElement = this.getFirstElement();
- if (!firstElement) return null;
- var data = firstElement.data = firstElement.data || {};
- data.staticClass = this.addTooltipClass(data.staticClass);
- return firstElement;
- },
- mounted: function mounted() {
- var _this3 = this;
- this.referenceElm = this.$el;
- if (this.$el.nodeType === 1) {
- this.$el.setAttribute('aria-describedby', this.tooltipId);
- this.$el.setAttribute('tabindex', this.tabindex);
- Object(dom_["on"])(this.referenceElm, 'mouseenter', this.show);
- Object(dom_["on"])(this.referenceElm, 'mouseleave', this.hide);
- Object(dom_["on"])(this.referenceElm, 'focus', function () {
- if (!_this3.$slots.default || !_this3.$slots.default.length) {
- _this3.handleFocus();
- return;
- }
- var instance = _this3.$slots.default[0].componentInstance;
- if (instance && instance.focus) {
- instance.focus();
- } else {
- _this3.handleFocus();
- }
- });
- Object(dom_["on"])(this.referenceElm, 'blur', this.handleBlur);
- Object(dom_["on"])(this.referenceElm, 'click', this.removeFocusing);
- }
- // fix issue https://github.com/ElemeFE/element/issues/14424
- if (this.value && this.popperVM) {
- this.popperVM.$nextTick(function () {
- if (_this3.value) {
- _this3.updatePopper();
- }
- });
- }
- },
- watch: {
- focusing: function focusing(val) {
- if (val) {
- Object(dom_["addClass"])(this.referenceElm, 'focusing');
- } else {
- Object(dom_["removeClass"])(this.referenceElm, 'focusing');
- }
- }
- },
- methods: {
- show: function show() {
- this.setExpectedState(true);
- this.handleShowPopper();
- },
- hide: function hide() {
- this.setExpectedState(false);
- this.debounceClose();
- },
- handleFocus: function handleFocus() {
- this.focusing = true;
- this.show();
- },
- handleBlur: function handleBlur() {
- this.focusing = false;
- this.hide();
- },
- removeFocusing: function removeFocusing() {
- this.focusing = false;
- },
- addTooltipClass: function addTooltipClass(prev) {
- if (!prev) {
- return 'el-tooltip';
- } else {
- return 'el-tooltip ' + prev.replace('el-tooltip', '');
- }
- },
- handleShowPopper: function handleShowPopper() {
- var _this4 = this;
- if (!this.expectedState || this.manual) return;
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- _this4.showPopper = true;
- }, this.openDelay);
- if (this.hideAfter > 0) {
- this.timeoutPending = setTimeout(function () {
- _this4.showPopper = false;
- }, this.hideAfter);
- }
- },
- handleClosePopper: function handleClosePopper() {
- if (this.enterable && this.expectedState || this.manual) return;
- clearTimeout(this.timeout);
- if (this.timeoutPending) {
- clearTimeout(this.timeoutPending);
- }
- this.showPopper = false;
- if (this.disabled) {
- this.doDestroy();
- }
- },
- setExpectedState: function setExpectedState(expectedState) {
- if (expectedState === false) {
- clearTimeout(this.timeoutPending);
- }
- this.expectedState = expectedState;
- },
- getFirstElement: function getFirstElement() {
- var slots = this.$slots.default;
- if (!Array.isArray(slots)) return null;
- var element = null;
- for (var index = 0; index < slots.length; index++) {
- if (slots[index] && slots[index].tag) {
- element = slots[index];
- break;
- };
- }
- return element;
- }
- },
- beforeDestroy: function beforeDestroy() {
- this.popperVM && this.popperVM.$destroy();
- },
- destroyed: function destroyed() {
- var reference = this.referenceElm;
- if (reference.nodeType === 1) {
- Object(dom_["off"])(reference, 'mouseenter', this.show);
- Object(dom_["off"])(reference, 'mouseleave', this.hide);
- Object(dom_["off"])(reference, 'focus', this.handleFocus);
- Object(dom_["off"])(reference, 'blur', this.handleBlur);
- Object(dom_["off"])(reference, 'click', this.removeFocusing);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/tooltip/index.js
- /* istanbul ignore next */
- main.install = function (Vue) {
- Vue.component(main.name, main);
- };
- /* harmony default export */ var tooltip = __webpack_exports__["default"] = (main);
- /***/ }),
- /***/ 19:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(22);
- /***/ }),
- /***/ 2:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(6);
- /***/ }),
- /***/ 3:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(4);
- /***/ }),
- /***/ 5:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(12);
- /***/ }),
- /***/ 7:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(0);
- /***/ })
- /******/ });
- /***/ }),
- /* 72 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- /* WEBPACK VAR INJECTION */(function(module) {var __WEBPACK_AMD_DEFINE_RESULT__;var _typeof=typeof Symbol==="function"&&typeof Symbol.iterator==="symbol"?function(obj){return typeof obj;}:function(obj){return obj&&typeof Symbol==="function"&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj;};/**
- * @license
- * Lodash <https://lodash.com/>
- * Copyright JS Foundation and other contributors <https://js.foundation/>
- * Released under MIT license <https://lodash.com/license>
- * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>
- * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
- *//*eslint-disable*/(function(){/** Used as a safe reference for `undefined` in pre-ES5 environments. */var undefined;/** Used as the semantic version number. */var VERSION='4.17.10';/** Used as the size to enable large array optimizations. */var LARGE_ARRAY_SIZE=200;/** Error message constants. */var CORE_ERROR_TEXT='Unsupported core-js use. Try https://npms.io/search?q=ponyfill.',FUNC_ERROR_TEXT='Expected a function';/** Used to stand-in for `undefined` hash values. */var HASH_UNDEFINED='__lodash_hash_undefined__';/** Used as the maximum memoize cache size. */var MAX_MEMOIZE_SIZE=500;/** Used as the internal argument placeholder. */var PLACEHOLDER='__lodash_placeholder__';/** Used to compose bitmasks for cloning. */var CLONE_DEEP_FLAG=1,CLONE_FLAT_FLAG=2,CLONE_SYMBOLS_FLAG=4;/** Used to compose bitmasks for value comparisons. */var COMPARE_PARTIAL_FLAG=1,COMPARE_UNORDERED_FLAG=2;/** Used to compose bitmasks for function metadata. */var WRAP_BIND_FLAG=1,WRAP_BIND_KEY_FLAG=2,WRAP_CURRY_BOUND_FLAG=4,WRAP_CURRY_FLAG=8,WRAP_CURRY_RIGHT_FLAG=16,WRAP_PARTIAL_FLAG=32,WRAP_PARTIAL_RIGHT_FLAG=64,WRAP_ARY_FLAG=128,WRAP_REARG_FLAG=256,WRAP_FLIP_FLAG=512;/** Used as default options for `_.truncate`. */var DEFAULT_TRUNC_LENGTH=30,DEFAULT_TRUNC_OMISSION='...';/** Used to detect hot functions by number of calls within a span of milliseconds. */var HOT_COUNT=800,HOT_SPAN=16;/** Used to indicate the type of lazy iteratees. */var LAZY_FILTER_FLAG=1,LAZY_MAP_FLAG=2,LAZY_WHILE_FLAG=3;/** Used as references for various `Number` constants. */var INFINITY=1/0,MAX_SAFE_INTEGER=9007199254740991,MAX_INTEGER=1.7976931348623157e308,NAN=0/0;/** Used as references for the maximum length and index of an array. */var MAX_ARRAY_LENGTH=4294967295,MAX_ARRAY_INDEX=MAX_ARRAY_LENGTH-1,HALF_MAX_ARRAY_LENGTH=MAX_ARRAY_LENGTH>>>1;/** Used to associate wrap methods with their bit flags. */var wrapFlags=[['ary',WRAP_ARY_FLAG],['bind',WRAP_BIND_FLAG],['bindKey',WRAP_BIND_KEY_FLAG],['curry',WRAP_CURRY_FLAG],['curryRight',WRAP_CURRY_RIGHT_FLAG],['flip',WRAP_FLIP_FLAG],['partial',WRAP_PARTIAL_FLAG],['partialRight',WRAP_PARTIAL_RIGHT_FLAG],['rearg',WRAP_REARG_FLAG]];/** `Object#toString` result references. */var argsTag='[object Arguments]',arrayTag='[object Array]',asyncTag='[object AsyncFunction]',boolTag='[object Boolean]',dateTag='[object Date]',domExcTag='[object DOMException]',errorTag='[object Error]',funcTag='[object Function]',genTag='[object GeneratorFunction]',mapTag='[object Map]',numberTag='[object Number]',nullTag='[object Null]',objectTag='[object Object]',promiseTag='[object Promise]',proxyTag='[object Proxy]',regexpTag='[object RegExp]',setTag='[object Set]',stringTag='[object String]',symbolTag='[object Symbol]',undefinedTag='[object Undefined]',weakMapTag='[object WeakMap]',weakSetTag='[object WeakSet]';var arrayBufferTag='[object ArrayBuffer]',dataViewTag='[object DataView]',float32Tag='[object Float32Array]',float64Tag='[object Float64Array]',int8Tag='[object Int8Array]',int16Tag='[object Int16Array]',int32Tag='[object Int32Array]',uint8Tag='[object Uint8Array]',uint8ClampedTag='[object Uint8ClampedArray]',uint16Tag='[object Uint16Array]',uint32Tag='[object Uint32Array]';/** Used to match empty string literals in compiled template source. */var reEmptyStringLeading=/\b__p \+= '';/g,reEmptyStringMiddle=/\b(__p \+=) '' \+/g,reEmptyStringTrailing=/(__e\(.*?\)|\b__t\)) \+\n'';/g;/** Used to match HTML entities and HTML characters. */var reEscapedHtml=/&(?:amp|lt|gt|quot|#39);/g,reUnescapedHtml=/[&<>"']/g,reHasEscapedHtml=RegExp(reEscapedHtml.source),reHasUnescapedHtml=RegExp(reUnescapedHtml.source);/** Used to match template delimiters. */var reEscape=/<%-([\s\S]+?)%>/g,reEvaluate=/<%([\s\S]+?)%>/g,reInterpolate=/<%=([\s\S]+?)%>/g;/** Used to match property names within property paths. */var reIsDeepProp=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,reIsPlainProp=/^\w*$/,rePropName=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g;/**
- * Used to match `RegExp`
- * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).
- */var reRegExpChar=/[\\^$.*+?()[\]{}|]/g,reHasRegExpChar=RegExp(reRegExpChar.source);/** Used to match leading and trailing whitespace. */var reTrim=/^\s+|\s+$/g,reTrimStart=/^\s+/,reTrimEnd=/\s+$/;/** Used to match wrap detail comments. */var reWrapComment=/\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/,reWrapDetails=/\{\n\/\* \[wrapped with (.+)\] \*/,reSplitDetails=/,? & /;/** Used to match words composed of alphanumeric characters. */var reAsciiWord=/[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g;/** Used to match backslashes in property paths. */var reEscapeChar=/\\(\\)?/g;/**
- * Used to match
- * [ES template delimiters](http://ecma-international.org/ecma-262/7.0/#sec-template-literal-lexical-components).
- */var reEsTemplate=/\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g;/** Used to match `RegExp` flags from their coerced string values. */var reFlags=/\w*$/;/** Used to detect bad signed hexadecimal string values. */var reIsBadHex=/^[-+]0x[0-9a-f]+$/i;/** Used to detect binary string values. */var reIsBinary=/^0b[01]+$/i;/** Used to detect host constructors (Safari). */var reIsHostCtor=/^\[object .+?Constructor\]$/;/** Used to detect octal string values. */var reIsOctal=/^0o[0-7]+$/i;/** Used to detect unsigned integer values. */var reIsUint=/^(?:0|[1-9]\d*)$/;/** Used to match Latin Unicode letters (excluding mathematical operators). */var reLatin=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g;/** Used to ensure capturing order of template delimiters. */var reNoMatch=/($^)/;/** Used to match unescaped characters in compiled string literals. */var reUnescapedString=/['\n\r\u2028\u2029\\]/g;/** Used to compose unicode character classes. */var rsAstralRange='\\ud800-\\udfff',rsComboMarksRange='\\u0300-\\u036f',reComboHalfMarksRange='\\ufe20-\\ufe2f',rsComboSymbolsRange='\\u20d0-\\u20ff',rsComboRange=rsComboMarksRange+reComboHalfMarksRange+rsComboSymbolsRange,rsDingbatRange='\\u2700-\\u27bf',rsLowerRange='a-z\\xdf-\\xf6\\xf8-\\xff',rsMathOpRange='\\xac\\xb1\\xd7\\xf7',rsNonCharRange='\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf',rsPunctuationRange='\\u2000-\\u206f',rsSpaceRange=' \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000',rsUpperRange='A-Z\\xc0-\\xd6\\xd8-\\xde',rsVarRange='\\ufe0e\\ufe0f',rsBreakRange=rsMathOpRange+rsNonCharRange+rsPunctuationRange+rsSpaceRange;/** Used to compose unicode capture groups. */var rsApos='[\'\u2019]',rsAstral='['+rsAstralRange+']',rsBreak='['+rsBreakRange+']',rsCombo='['+rsComboRange+']',rsDigits='\\d+',rsDingbat='['+rsDingbatRange+']',rsLower='['+rsLowerRange+']',rsMisc='[^'+rsAstralRange+rsBreakRange+rsDigits+rsDingbatRange+rsLowerRange+rsUpperRange+']',rsFitz='\\ud83c[\\udffb-\\udfff]',rsModifier='(?:'+rsCombo+'|'+rsFitz+')',rsNonAstral='[^'+rsAstralRange+']',rsRegional='(?:\\ud83c[\\udde6-\\uddff]){2}',rsSurrPair='[\\ud800-\\udbff][\\udc00-\\udfff]',rsUpper='['+rsUpperRange+']',rsZWJ='\\u200d';/** Used to compose unicode regexes. */var rsMiscLower='(?:'+rsLower+'|'+rsMisc+')',rsMiscUpper='(?:'+rsUpper+'|'+rsMisc+')',rsOptContrLower='(?:'+rsApos+'(?:d|ll|m|re|s|t|ve))?',rsOptContrUpper='(?:'+rsApos+'(?:D|LL|M|RE|S|T|VE))?',reOptMod=rsModifier+'?',rsOptVar='['+rsVarRange+']?',rsOptJoin='(?:'+rsZWJ+'(?:'+[rsNonAstral,rsRegional,rsSurrPair].join('|')+')'+rsOptVar+reOptMod+')*',rsOrdLower='\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?=\\b|[A-Z_])',rsOrdUpper='\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?=\\b|[a-z_])',rsSeq=rsOptVar+reOptMod+rsOptJoin,rsEmoji='(?:'+[rsDingbat,rsRegional,rsSurrPair].join('|')+')'+rsSeq,rsSymbol='(?:'+[rsNonAstral+rsCombo+'?',rsCombo,rsRegional,rsSurrPair,rsAstral].join('|')+')';/** Used to match apostrophes. */var reApos=RegExp(rsApos,'g');/**
- * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and
- * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols).
- */var reComboMark=RegExp(rsCombo,'g');/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */var reUnicode=RegExp(rsFitz+'(?='+rsFitz+')|'+rsSymbol+rsSeq,'g');/** Used to match complex or compound words. */var reUnicodeWord=RegExp([rsUpper+'?'+rsLower+'+'+rsOptContrLower+'(?='+[rsBreak,rsUpper,'$'].join('|')+')',rsMiscUpper+'+'+rsOptContrUpper+'(?='+[rsBreak,rsUpper+rsMiscLower,'$'].join('|')+')',rsUpper+'?'+rsMiscLower+'+'+rsOptContrLower,rsUpper+'+'+rsOptContrUpper,rsOrdUpper,rsOrdLower,rsDigits,rsEmoji].join('|'),'g');/** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */var reHasUnicode=RegExp('['+rsZWJ+rsAstralRange+rsComboRange+rsVarRange+']');/** Used to detect strings that need a more robust regexp to match words. */var reHasUnicodeWord=/[a-z][A-Z]|[A-Z]{2,}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;/** Used to assign default `context` object properties. */var contextProps=['Array','Buffer','DataView','Date','Error','Float32Array','Float64Array','Function','Int8Array','Int16Array','Int32Array','Map','Math','Object','Promise','RegExp','Set','String','Symbol','TypeError','Uint8Array','Uint8ClampedArray','Uint16Array','Uint32Array','WeakMap','_','clearTimeout','isFinite','parseInt','setTimeout'];/** Used to make template sourceURLs easier to identify. */var templateCounter=-1;/** Used to identify `toStringTag` values of typed arrays. */var typedArrayTags={};typedArrayTags[float32Tag]=typedArrayTags[float64Tag]=typedArrayTags[int8Tag]=typedArrayTags[int16Tag]=typedArrayTags[int32Tag]=typedArrayTags[uint8Tag]=typedArrayTags[uint8ClampedTag]=typedArrayTags[uint16Tag]=typedArrayTags[uint32Tag]=true;typedArrayTags[argsTag]=typedArrayTags[arrayTag]=typedArrayTags[arrayBufferTag]=typedArrayTags[boolTag]=typedArrayTags[dataViewTag]=typedArrayTags[dateTag]=typedArrayTags[errorTag]=typedArrayTags[funcTag]=typedArrayTags[mapTag]=typedArrayTags[numberTag]=typedArrayTags[objectTag]=typedArrayTags[regexpTag]=typedArrayTags[setTag]=typedArrayTags[stringTag]=typedArrayTags[weakMapTag]=false;/** Used to identify `toStringTag` values supported by `_.clone`. */var cloneableTags={};cloneableTags[argsTag]=cloneableTags[arrayTag]=cloneableTags[arrayBufferTag]=cloneableTags[dataViewTag]=cloneableTags[boolTag]=cloneableTags[dateTag]=cloneableTags[float32Tag]=cloneableTags[float64Tag]=cloneableTags[int8Tag]=cloneableTags[int16Tag]=cloneableTags[int32Tag]=cloneableTags[mapTag]=cloneableTags[numberTag]=cloneableTags[objectTag]=cloneableTags[regexpTag]=cloneableTags[setTag]=cloneableTags[stringTag]=cloneableTags[symbolTag]=cloneableTags[uint8Tag]=cloneableTags[uint8ClampedTag]=cloneableTags[uint16Tag]=cloneableTags[uint32Tag]=true;cloneableTags[errorTag]=cloneableTags[funcTag]=cloneableTags[weakMapTag]=false;/** Used to map Latin Unicode letters to basic Latin letters. */var deburredLetters={// Latin-1 Supplement block.
- À:'A',Á:'A',Â:'A',Ã:'A',Ä:'A',Å:'A',à:'a',á:'a',â:'a',ã:'a',ä:'a',å:'a',Ç:'C',ç:'c',Ð:'D',ð:'d',È:'E',É:'E',Ê:'E',Ë:'E',è:'e',é:'e',ê:'e',ë:'e',Ì:'I',Í:'I',Î:'I',Ï:'I',ì:'i',í:'i',î:'i',ï:'i',Ñ:'N',ñ:'n',Ò:'O',Ó:'O',Ô:'O',Õ:'O',Ö:'O',Ø:'O',ò:'o',ó:'o',ô:'o',õ:'o',ö:'o',ø:'o',Ù:'U',Ú:'U',Û:'U',Ü:'U',ù:'u',ú:'u',û:'u',ü:'u',Ý:'Y',ý:'y',ÿ:'y',Æ:'Ae',æ:'ae',Þ:'Th',þ:'th',ß:'ss',// Latin Extended-A block.
- Ā:'A',Ă:'A',Ą:'A',ā:'a',ă:'a',ą:'a',Ć:'C',Ĉ:'C',Ċ:'C',Č:'C',ć:'c',ĉ:'c',ċ:'c',č:'c',Ď:'D',Đ:'D',ď:'d',đ:'d',Ē:'E',Ĕ:'E',Ė:'E',Ę:'E',Ě:'E',ē:'e',ĕ:'e',ė:'e',ę:'e',ě:'e',Ĝ:'G',Ğ:'G',Ġ:'G',Ģ:'G',ĝ:'g',ğ:'g',ġ:'g',ģ:'g',Ĥ:'H',Ħ:'H',ĥ:'h',ħ:'h',Ĩ:'I',Ī:'I',Ĭ:'I',Į:'I',İ:'I',ĩ:'i',ī:'i',ĭ:'i',į:'i',ı:'i',Ĵ:'J',ĵ:'j',Ķ:'K',ķ:'k',ĸ:'k',Ĺ:'L',Ļ:'L',Ľ:'L',Ŀ:'L',Ł:'L',ĺ:'l',ļ:'l',ľ:'l',ŀ:'l',ł:'l',Ń:'N',Ņ:'N',Ň:'N',Ŋ:'N',ń:'n',ņ:'n',ň:'n',ŋ:'n',Ō:'O',Ŏ:'O',Ő:'O',ō:'o',ŏ:'o',ő:'o',Ŕ:'R',Ŗ:'R',Ř:'R',ŕ:'r',ŗ:'r',ř:'r',Ś:'S',Ŝ:'S',Ş:'S',Š:'S',ś:'s',ŝ:'s',ş:'s',š:'s',Ţ:'T',Ť:'T',Ŧ:'T',ţ:'t',ť:'t',ŧ:'t',Ũ:'U',Ū:'U',Ŭ:'U',Ů:'U',Ű:'U',Ų:'U',ũ:'u',ū:'u',ŭ:'u',ů:'u',ű:'u',ų:'u',Ŵ:'W',ŵ:'w',Ŷ:'Y',ŷ:'y',Ÿ:'Y',Ź:'Z',Ż:'Z',Ž:'Z',ź:'z',ż:'z',ž:'z',IJ:'IJ',ij:'ij',Œ:'Oe',œ:'oe',ʼn:"'n",ſ:'s'};/** Used to map characters to HTML entities. */var htmlEscapes={'&':'&','<':'<','>':'>','"':'"',"'":'''};/** Used to map HTML entities to characters. */var htmlUnescapes={'&':'&','<':'<','>':'>','"':'"',''':"'"};/** Used to escape characters for inclusion in compiled string literals. */var stringEscapes={'\\':'\\',"'":"'",'\n':'n','\r':'r','\u2028':'u2028','\u2029':'u2029'};/** Built-in method references without a dependency on `root`. */var freeParseFloat=parseFloat,freeParseInt=parseInt;/** Detect free variable `global` from Node.js. */var freeGlobal=(typeof global==='undefined'?'undefined':_typeof(global))==='object'&&global&&global.Object===Object&&global;/** Detect free variable `self`. */var freeSelf=(typeof self==='undefined'?'undefined':_typeof(self))==='object'&&self&&self.Object===Object&&self;/** Used as a reference to the global object. */var root=freeGlobal||freeSelf||Function('return this')();/** Detect free variable `exports`. */var freeExports=( false?undefined:_typeof(exports))==='object'&&exports&&!exports.nodeType&&exports;/** Detect free variable `module`. */var freeModule=freeExports&&( false?undefined:_typeof(module))==='object'&&module&&!module.nodeType&&module;/** Detect the popular CommonJS extension `module.exports`. */var moduleExports=freeModule&&freeModule.exports===freeExports;/** Detect free variable `process` from Node.js. */var freeProcess=moduleExports&&freeGlobal.process;/** Used to access faster Node.js helpers. */var nodeUtil=function(){try{// Use `util.types` for Node.js 10+.
- var types=freeModule&&freeModule.require&&freeModule.require('util').types;if(types){return types;}// Legacy `process.binding('util')` for Node.js < 10.
- return freeProcess&&freeProcess.binding&&freeProcess.binding('util');}catch(e){}}();/* Node.js helper references. */var nodeIsArrayBuffer=nodeUtil&&nodeUtil.isArrayBuffer,nodeIsDate=nodeUtil&&nodeUtil.isDate,nodeIsMap=nodeUtil&&nodeUtil.isMap,nodeIsRegExp=nodeUtil&&nodeUtil.isRegExp,nodeIsSet=nodeUtil&&nodeUtil.isSet,nodeIsTypedArray=nodeUtil&&nodeUtil.isTypedArray;/* --------------------------------------------------------------------------*//**
- * A faster alternative to `Function#apply`, this function invokes `func`
- * with the `this` binding of `thisArg` and the arguments of `args`.
- *
- * @private
- * @param {Function} func The function to invoke.
- * @param {*} thisArg The `this` binding of `func`.
- * @param {Array} args The arguments to invoke `func` with.
- * @returns {*} Returns the result of `func`.
- */function apply(func,thisArg,args){switch(args.length){case 0:return func.call(thisArg);case 1:return func.call(thisArg,args[0]);case 2:return func.call(thisArg,args[0],args[1]);case 3:return func.call(thisArg,args[0],args[1],args[2]);}return func.apply(thisArg,args);}/**
- * A specialized version of `baseAggregator` for arrays.
- *
- * @private
- * @param {Array} [array] The array to iterate over.
- * @param {Function} setter The function to set `accumulator` values.
- * @param {Function} iteratee The iteratee to transform keys.
- * @param {Object} accumulator The initial aggregated object.
- * @returns {Function} Returns `accumulator`.
- */function arrayAggregator(array,setter,iteratee,accumulator){var index=-1,length=array==null?0:array.length;while(++index<length){var value=array[index];setter(accumulator,value,iteratee(value),array);}return accumulator;}/**
- * A specialized version of `_.forEach` for arrays without support for
- * iteratee shorthands.
- *
- * @private
- * @param {Array} [array] The array to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {Array} Returns `array`.
- */function arrayEach(array,iteratee){var index=-1,length=array==null?0:array.length;while(++index<length){if(iteratee(array[index],index,array)===false){break;}}return array;}/**
- * A specialized version of `_.forEachRight` for arrays without support for
- * iteratee shorthands.
- *
- * @private
- * @param {Array} [array] The array to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {Array} Returns `array`.
- */function arrayEachRight(array,iteratee){var length=array==null?0:array.length;while(length--){if(iteratee(array[length],length,array)===false){break;}}return array;}/**
- * A specialized version of `_.every` for arrays without support for
- * iteratee shorthands.
- *
- * @private
- * @param {Array} [array] The array to iterate over.
- * @param {Function} predicate The function invoked per iteration.
- * @returns {boolean} Returns `true` if all elements pass the predicate check,
- * else `false`.
- */function arrayEvery(array,predicate){var index=-1,length=array==null?0:array.length;while(++index<length){if(!predicate(array[index],index,array)){return false;}}return true;}/**
- * A specialized version of `_.filter` for arrays without support for
- * iteratee shorthands.
- *
- * @private
- * @param {Array} [array] The array to iterate over.
- * @param {Function} predicate The function invoked per iteration.
- * @returns {Array} Returns the new filtered array.
- */function arrayFilter(array,predicate){var index=-1,length=array==null?0:array.length,resIndex=0,result=[];while(++index<length){var value=array[index];if(predicate(value,index,array)){result[resIndex++]=value;}}return result;}/**
- * A specialized version of `_.includes` for arrays without support for
- * specifying an index to search from.
- *
- * @private
- * @param {Array} [array] The array to inspect.
- * @param {*} target The value to search for.
- * @returns {boolean} Returns `true` if `target` is found, else `false`.
- */function arrayIncludes(array,value){var length=array==null?0:array.length;return!!length&&baseIndexOf(array,value,0)>-1;}/**
- * This function is like `arrayIncludes` except that it accepts a comparator.
- *
- * @private
- * @param {Array} [array] The array to inspect.
- * @param {*} target The value to search for.
- * @param {Function} comparator The comparator invoked per element.
- * @returns {boolean} Returns `true` if `target` is found, else `false`.
- */function arrayIncludesWith(array,value,comparator){var index=-1,length=array==null?0:array.length;while(++index<length){if(comparator(value,array[index])){return true;}}return false;}/**
- * A specialized version of `_.map` for arrays without support for iteratee
- * shorthands.
- *
- * @private
- * @param {Array} [array] The array to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {Array} Returns the new mapped array.
- */function arrayMap(array,iteratee){var index=-1,length=array==null?0:array.length,result=Array(length);while(++index<length){result[index]=iteratee(array[index],index,array);}return result;}/**
- * Appends the elements of `values` to `array`.
- *
- * @private
- * @param {Array} array The array to modify.
- * @param {Array} values The values to append.
- * @returns {Array} Returns `array`.
- */function arrayPush(array,values){var index=-1,length=values.length,offset=array.length;while(++index<length){array[offset+index]=values[index];}return array;}/**
- * A specialized version of `_.reduce` for arrays without support for
- * iteratee shorthands.
- *
- * @private
- * @param {Array} [array] The array to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @param {*} [accumulator] The initial value.
- * @param {boolean} [initAccum] Specify using the first element of `array` as
- * the initial value.
- * @returns {*} Returns the accumulated value.
- */function arrayReduce(array,iteratee,accumulator,initAccum){var index=-1,length=array==null?0:array.length;if(initAccum&&length){accumulator=array[++index];}while(++index<length){accumulator=iteratee(accumulator,array[index],index,array);}return accumulator;}/**
- * A specialized version of `_.reduceRight` for arrays without support for
- * iteratee shorthands.
- *
- * @private
- * @param {Array} [array] The array to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @param {*} [accumulator] The initial value.
- * @param {boolean} [initAccum] Specify using the last element of `array` as
- * the initial value.
- * @returns {*} Returns the accumulated value.
- */function arrayReduceRight(array,iteratee,accumulator,initAccum){var length=array==null?0:array.length;if(initAccum&&length){accumulator=array[--length];}while(length--){accumulator=iteratee(accumulator,array[length],length,array);}return accumulator;}/**
- * A specialized version of `_.some` for arrays without support for iteratee
- * shorthands.
- *
- * @private
- * @param {Array} [array] The array to iterate over.
- * @param {Function} predicate The function invoked per iteration.
- * @returns {boolean} Returns `true` if any element passes the predicate check,
- * else `false`.
- */function arraySome(array,predicate){var index=-1,length=array==null?0:array.length;while(++index<length){if(predicate(array[index],index,array)){return true;}}return false;}/**
- * Gets the size of an ASCII `string`.
- *
- * @private
- * @param {string} string The string inspect.
- * @returns {number} Returns the string size.
- */var asciiSize=baseProperty('length');/**
- * Converts an ASCII `string` to an array.
- *
- * @private
- * @param {string} string The string to convert.
- * @returns {Array} Returns the converted array.
- */function asciiToArray(string){return string.split('');}/**
- * Splits an ASCII `string` into an array of its words.
- *
- * @private
- * @param {string} The string to inspect.
- * @returns {Array} Returns the words of `string`.
- */function asciiWords(string){return string.match(reAsciiWord)||[];}/**
- * The base implementation of methods like `_.findKey` and `_.findLastKey`,
- * without support for iteratee shorthands, which iterates over `collection`
- * using `eachFunc`.
- *
- * @private
- * @param {Array|Object} collection The collection to inspect.
- * @param {Function} predicate The function invoked per iteration.
- * @param {Function} eachFunc The function to iterate over `collection`.
- * @returns {*} Returns the found element or its key, else `undefined`.
- */function baseFindKey(collection,predicate,eachFunc){var result;eachFunc(collection,function(value,key,collection){if(predicate(value,key,collection)){result=key;return false;}});return result;}/**
- * The base implementation of `_.findIndex` and `_.findLastIndex` without
- * support for iteratee shorthands.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {Function} predicate The function invoked per iteration.
- * @param {number} fromIndex The index to search from.
- * @param {boolean} [fromRight] Specify iterating from right to left.
- * @returns {number} Returns the index of the matched value, else `-1`.
- */function baseFindIndex(array,predicate,fromIndex,fromRight){var length=array.length,index=fromIndex+(fromRight?1:-1);while(fromRight?index--:++index<length){if(predicate(array[index],index,array)){return index;}}return-1;}/**
- * The base implementation of `_.indexOf` without `fromIndex` bounds checks.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {*} value The value to search for.
- * @param {number} fromIndex The index to search from.
- * @returns {number} Returns the index of the matched value, else `-1`.
- */function baseIndexOf(array,value,fromIndex){return value===value?strictIndexOf(array,value,fromIndex):baseFindIndex(array,baseIsNaN,fromIndex);}/**
- * This function is like `baseIndexOf` except that it accepts a comparator.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {*} value The value to search for.
- * @param {number} fromIndex The index to search from.
- * @param {Function} comparator The comparator invoked per element.
- * @returns {number} Returns the index of the matched value, else `-1`.
- */function baseIndexOfWith(array,value,fromIndex,comparator){var index=fromIndex-1,length=array.length;while(++index<length){if(comparator(array[index],value)){return index;}}return-1;}/**
- * The base implementation of `_.isNaN` without support for number objects.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.
- */function baseIsNaN(value){return value!==value;}/**
- * The base implementation of `_.mean` and `_.meanBy` without support for
- * iteratee shorthands.
- *
- * @private
- * @param {Array} array The array to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {number} Returns the mean.
- */function baseMean(array,iteratee){var length=array==null?0:array.length;return length?baseSum(array,iteratee)/length:NAN;}/**
- * The base implementation of `_.property` without support for deep paths.
- *
- * @private
- * @param {string} key The key of the property to get.
- * @returns {Function} Returns the new accessor function.
- */function baseProperty(key){return function(object){return object==null?undefined:object[key];};}/**
- * The base implementation of `_.propertyOf` without support for deep paths.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Function} Returns the new accessor function.
- */function basePropertyOf(object){return function(key){return object==null?undefined:object[key];};}/**
- * The base implementation of `_.reduce` and `_.reduceRight`, without support
- * for iteratee shorthands, which iterates over `collection` using `eachFunc`.
- *
- * @private
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @param {*} accumulator The initial value.
- * @param {boolean} initAccum Specify using the first or last element of
- * `collection` as the initial value.
- * @param {Function} eachFunc The function to iterate over `collection`.
- * @returns {*} Returns the accumulated value.
- */function baseReduce(collection,iteratee,accumulator,initAccum,eachFunc){eachFunc(collection,function(value,index,collection){accumulator=initAccum?(initAccum=false,value):iteratee(accumulator,value,index,collection);});return accumulator;}/**
- * The base implementation of `_.sortBy` which uses `comparer` to define the
- * sort order of `array` and replaces criteria objects with their corresponding
- * values.
- *
- * @private
- * @param {Array} array The array to sort.
- * @param {Function} comparer The function to define sort order.
- * @returns {Array} Returns `array`.
- */function baseSortBy(array,comparer){var length=array.length;array.sort(comparer);while(length--){array[length]=array[length].value;}return array;}/**
- * The base implementation of `_.sum` and `_.sumBy` without support for
- * iteratee shorthands.
- *
- * @private
- * @param {Array} array The array to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {number} Returns the sum.
- */function baseSum(array,iteratee){var result,index=-1,length=array.length;while(++index<length){var current=iteratee(array[index]);if(current!==undefined){result=result===undefined?current:result+current;}}return result;}/**
- * The base implementation of `_.times` without support for iteratee shorthands
- * or max array length checks.
- *
- * @private
- * @param {number} n The number of times to invoke `iteratee`.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {Array} Returns the array of results.
- */function baseTimes(n,iteratee){var index=-1,result=Array(n);while(++index<n){result[index]=iteratee(index);}return result;}/**
- * The base implementation of `_.toPairs` and `_.toPairsIn` which creates an array
- * of key-value pairs for `object` corresponding to the property names of `props`.
- *
- * @private
- * @param {Object} object The object to query.
- * @param {Array} props The property names to get values for.
- * @returns {Object} Returns the key-value pairs.
- */function baseToPairs(object,props){return arrayMap(props,function(key){return[key,object[key]];});}/**
- * The base implementation of `_.unary` without support for storing metadata.
- *
- * @private
- * @param {Function} func The function to cap arguments for.
- * @returns {Function} Returns the new capped function.
- */function baseUnary(func){return function(value){return func(value);};}/**
- * The base implementation of `_.values` and `_.valuesIn` which creates an
- * array of `object` property values corresponding to the property names
- * of `props`.
- *
- * @private
- * @param {Object} object The object to query.
- * @param {Array} props The property names to get values for.
- * @returns {Object} Returns the array of property values.
- */function baseValues(object,props){return arrayMap(props,function(key){return object[key];});}/**
- * Checks if a `cache` value for `key` exists.
- *
- * @private
- * @param {Object} cache The cache to query.
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */function cacheHas(cache,key){return cache.has(key);}/**
- * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol
- * that is not found in the character symbols.
- *
- * @private
- * @param {Array} strSymbols The string symbols to inspect.
- * @param {Array} chrSymbols The character symbols to find.
- * @returns {number} Returns the index of the first unmatched string symbol.
- */function charsStartIndex(strSymbols,chrSymbols){var index=-1,length=strSymbols.length;while(++index<length&&baseIndexOf(chrSymbols,strSymbols[index],0)>-1){}return index;}/**
- * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol
- * that is not found in the character symbols.
- *
- * @private
- * @param {Array} strSymbols The string symbols to inspect.
- * @param {Array} chrSymbols The character symbols to find.
- * @returns {number} Returns the index of the last unmatched string symbol.
- */function charsEndIndex(strSymbols,chrSymbols){var index=strSymbols.length;while(index--&&baseIndexOf(chrSymbols,strSymbols[index],0)>-1){}return index;}/**
- * Gets the number of `placeholder` occurrences in `array`.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {*} placeholder The placeholder to search for.
- * @returns {number} Returns the placeholder count.
- */function countHolders(array,placeholder){var length=array.length,result=0;while(length--){if(array[length]===placeholder){++result;}}return result;}/**
- * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A
- * letters to basic Latin letters.
- *
- * @private
- * @param {string} letter The matched letter to deburr.
- * @returns {string} Returns the deburred letter.
- */var deburrLetter=basePropertyOf(deburredLetters);/**
- * Used by `_.escape` to convert characters to HTML entities.
- *
- * @private
- * @param {string} chr The matched character to escape.
- * @returns {string} Returns the escaped character.
- */var escapeHtmlChar=basePropertyOf(htmlEscapes);/**
- * Used by `_.template` to escape characters for inclusion in compiled string literals.
- *
- * @private
- * @param {string} chr The matched character to escape.
- * @returns {string} Returns the escaped character.
- */function escapeStringChar(chr){return'\\'+stringEscapes[chr];}/**
- * Gets the value at `key` of `object`.
- *
- * @private
- * @param {Object} [object] The object to query.
- * @param {string} key The key of the property to get.
- * @returns {*} Returns the property value.
- */function getValue(object,key){return object==null?undefined:object[key];}/**
- * Checks if `string` contains Unicode symbols.
- *
- * @private
- * @param {string} string The string to inspect.
- * @returns {boolean} Returns `true` if a symbol is found, else `false`.
- */function hasUnicode(string){return reHasUnicode.test(string);}/**
- * Checks if `string` contains a word composed of Unicode symbols.
- *
- * @private
- * @param {string} string The string to inspect.
- * @returns {boolean} Returns `true` if a word is found, else `false`.
- */function hasUnicodeWord(string){return reHasUnicodeWord.test(string);}/**
- * Converts `iterator` to an array.
- *
- * @private
- * @param {Object} iterator The iterator to convert.
- * @returns {Array} Returns the converted array.
- */function iteratorToArray(iterator){var data,result=[];while(!(data=iterator.next()).done){result.push(data.value);}return result;}/**
- * Converts `map` to its key-value pairs.
- *
- * @private
- * @param {Object} map The map to convert.
- * @returns {Array} Returns the key-value pairs.
- */function mapToArray(map){var index=-1,result=Array(map.size);map.forEach(function(value,key){result[++index]=[key,value];});return result;}/**
- * Creates a unary function that invokes `func` with its argument transformed.
- *
- * @private
- * @param {Function} func The function to wrap.
- * @param {Function} transform The argument transform.
- * @returns {Function} Returns the new function.
- */function overArg(func,transform){return function(arg){return func(transform(arg));};}/**
- * Replaces all `placeholder` elements in `array` with an internal placeholder
- * and returns an array of their indexes.
- *
- * @private
- * @param {Array} array The array to modify.
- * @param {*} placeholder The placeholder to replace.
- * @returns {Array} Returns the new array of placeholder indexes.
- */function replaceHolders(array,placeholder){var index=-1,length=array.length,resIndex=0,result=[];while(++index<length){var value=array[index];if(value===placeholder||value===PLACEHOLDER){array[index]=PLACEHOLDER;result[resIndex++]=index;}}return result;}/**
- * Gets the value at `key`, unless `key` is "__proto__".
- *
- * @private
- * @param {Object} object The object to query.
- * @param {string} key The key of the property to get.
- * @returns {*} Returns the property value.
- */function safeGet(object,key){return key=='__proto__'?undefined:object[key];}/**
- * Converts `set` to an array of its values.
- *
- * @private
- * @param {Object} set The set to convert.
- * @returns {Array} Returns the values.
- */function setToArray(set){var index=-1,result=Array(set.size);set.forEach(function(value){result[++index]=value;});return result;}/**
- * Converts `set` to its value-value pairs.
- *
- * @private
- * @param {Object} set The set to convert.
- * @returns {Array} Returns the value-value pairs.
- */function setToPairs(set){var index=-1,result=Array(set.size);set.forEach(function(value){result[++index]=[value,value];});return result;}/**
- * A specialized version of `_.indexOf` which performs strict equality
- * comparisons of values, i.e. `===`.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {*} value The value to search for.
- * @param {number} fromIndex The index to search from.
- * @returns {number} Returns the index of the matched value, else `-1`.
- */function strictIndexOf(array,value,fromIndex){var index=fromIndex-1,length=array.length;while(++index<length){if(array[index]===value){return index;}}return-1;}/**
- * A specialized version of `_.lastIndexOf` which performs strict equality
- * comparisons of values, i.e. `===`.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {*} value The value to search for.
- * @param {number} fromIndex The index to search from.
- * @returns {number} Returns the index of the matched value, else `-1`.
- */function strictLastIndexOf(array,value,fromIndex){var index=fromIndex+1;while(index--){if(array[index]===value){return index;}}return index;}/**
- * Gets the number of symbols in `string`.
- *
- * @private
- * @param {string} string The string to inspect.
- * @returns {number} Returns the string size.
- */function stringSize(string){return hasUnicode(string)?unicodeSize(string):asciiSize(string);}/**
- * Converts `string` to an array.
- *
- * @private
- * @param {string} string The string to convert.
- * @returns {Array} Returns the converted array.
- */function stringToArray(string){return hasUnicode(string)?unicodeToArray(string):asciiToArray(string);}/**
- * Used by `_.unescape` to convert HTML entities to characters.
- *
- * @private
- * @param {string} chr The matched character to unescape.
- * @returns {string} Returns the unescaped character.
- */var unescapeHtmlChar=basePropertyOf(htmlUnescapes);/**
- * Gets the size of a Unicode `string`.
- *
- * @private
- * @param {string} string The string inspect.
- * @returns {number} Returns the string size.
- */function unicodeSize(string){var result=reUnicode.lastIndex=0;while(reUnicode.test(string)){++result;}return result;}/**
- * Converts a Unicode `string` to an array.
- *
- * @private
- * @param {string} string The string to convert.
- * @returns {Array} Returns the converted array.
- */function unicodeToArray(string){return string.match(reUnicode)||[];}/**
- * Splits a Unicode `string` into an array of its words.
- *
- * @private
- * @param {string} The string to inspect.
- * @returns {Array} Returns the words of `string`.
- */function unicodeWords(string){return string.match(reUnicodeWord)||[];}/* --------------------------------------------------------------------------*//**
- * Create a new pristine `lodash` function using the `context` object.
- *
- * @static
- * @memberOf _
- * @since 1.1.0
- * @category Util
- * @param {Object} [context=root] The context object.
- * @returns {Function} Returns a new `lodash` function.
- * @example
- *
- * _.mixin({ 'foo': _.constant('foo') });
- *
- * var lodash = _.runInContext();
- * lodash.mixin({ 'bar': lodash.constant('bar') });
- *
- * _.isFunction(_.foo);
- * // => true
- * _.isFunction(_.bar);
- * // => false
- *
- * lodash.isFunction(lodash.foo);
- * // => false
- * lodash.isFunction(lodash.bar);
- * // => true
- *
- * // Create a suped-up `defer` in Node.js.
- * var defer = _.runInContext({ 'setTimeout': setImmediate }).defer;
- */var runInContext=function runInContext(context){context=context==null?root:_.defaults(root.Object(),context,_.pick(root,contextProps));/** Built-in constructor references. */var Array=context.Array,Date=context.Date,Error=context.Error,Function=context.Function,Math=context.Math,Object=context.Object,RegExp=context.RegExp,String=context.String,TypeError=context.TypeError;/** Used for built-in method references. */var arrayProto=Array.prototype,funcProto=Function.prototype,objectProto=Object.prototype;/** Used to detect overreaching core-js shims. */var coreJsData=context['__core-js_shared__'];/** Used to resolve the decompiled source of functions. */var funcToString=funcProto.toString;/** Used to check objects for own properties. */var hasOwnProperty=objectProto.hasOwnProperty;/** Used to generate unique IDs. */var idCounter=0;/** Used to detect methods masquerading as native. */var maskSrcKey=function(){var uid=/[^.]+$/.exec(coreJsData&&coreJsData.keys&&coreJsData.keys.IE_PROTO||'');return uid?'Symbol(src)_1.'+uid:'';}();/**
- * Used to resolve the
- * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
- * of values.
- */var nativeObjectToString=objectProto.toString;/** Used to infer the `Object` constructor. */var objectCtorString=funcToString.call(Object);/** Used to restore the original `_` reference in `_.noConflict`. */var oldDash=root._;/** Used to detect if a method is native. */var reIsNative=RegExp('^'+funcToString.call(hasOwnProperty).replace(reRegExpChar,'\\$&').replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,'$1.*?')+'$');/** Built-in value references. */var Buffer=moduleExports?context.Buffer:undefined,_Symbol=context.Symbol,Uint8Array=context.Uint8Array,allocUnsafe=Buffer?Buffer.allocUnsafe:undefined,getPrototype=overArg(Object.getPrototypeOf,Object),objectCreate=Object.create,propertyIsEnumerable=objectProto.propertyIsEnumerable,splice=arrayProto.splice,spreadableSymbol=_Symbol?_Symbol.isConcatSpreadable:undefined,symIterator=_Symbol?_Symbol.iterator:undefined,symToStringTag=_Symbol?_Symbol.toStringTag:undefined;var defineProperty=function(){try{var func=getNative(Object,'defineProperty');func({},'',{});return func;}catch(e){}}();/** Mocked built-ins. */var ctxClearTimeout=context.clearTimeout!==root.clearTimeout&&context.clearTimeout,ctxNow=Date&&Date.now!==root.Date.now&&Date.now,ctxSetTimeout=context.setTimeout!==root.setTimeout&&context.setTimeout;/* Built-in method references for those with the same name as other `lodash` methods. */var nativeCeil=Math.ceil,nativeFloor=Math.floor,nativeGetSymbols=Object.getOwnPropertySymbols,nativeIsBuffer=Buffer?Buffer.isBuffer:undefined,nativeIsFinite=context.isFinite,nativeJoin=arrayProto.join,nativeKeys=overArg(Object.keys,Object),nativeMax=Math.max,nativeMin=Math.min,nativeNow=Date.now,nativeParseInt=context.parseInt,nativeRandom=Math.random,nativeReverse=arrayProto.reverse;/* Built-in method references that are verified to be native. */var DataView=getNative(context,'DataView'),Map=getNative(context,'Map'),Promise=getNative(context,'Promise'),Set=getNative(context,'Set'),WeakMap=getNative(context,'WeakMap'),nativeCreate=getNative(Object,'create');/** Used to store function metadata. */var metaMap=WeakMap&&new WeakMap();/** Used to lookup unminified function names. */var realNames={};/** Used to detect maps, sets, and weakmaps. */var dataViewCtorString=toSource(DataView),mapCtorString=toSource(Map),promiseCtorString=toSource(Promise),setCtorString=toSource(Set),weakMapCtorString=toSource(WeakMap);/** Used to convert symbols to primitives and strings. */var symbolProto=_Symbol?_Symbol.prototype:undefined,symbolValueOf=symbolProto?symbolProto.valueOf:undefined,symbolToString=symbolProto?symbolProto.toString:undefined;/* ------------------------------------------------------------------------*//**
- * Creates a `lodash` object which wraps `value` to enable implicit method
- * chain sequences. Methods that operate on and return arrays, collections,
- * and functions can be chained together. Methods that retrieve a single value
- * or may return a primitive value will automatically end the chain sequence
- * and return the unwrapped value. Otherwise, the value must be unwrapped
- * with `_#value`.
- *
- * Explicit chain sequences, which must be unwrapped with `_#value`, may be
- * enabled using `_.chain`.
- *
- * The execution of chained methods is lazy, that is, it's deferred until
- * `_#value` is implicitly or explicitly called.
- *
- * Lazy evaluation allows several methods to support shortcut fusion.
- * Shortcut fusion is an optimization to merge iteratee calls; this avoids
- * the creation of intermediate arrays and can greatly reduce the number of
- * iteratee executions. Sections of a chain sequence qualify for shortcut
- * fusion if the section is applied to an array and iteratees accept only
- * one argument. The heuristic for whether a section qualifies for shortcut
- * fusion is subject to change.
- *
- * Chaining is supported in custom builds as long as the `_#value` method is
- * directly or indirectly included in the build.
- *
- * In addition to lodash methods, wrappers have `Array` and `String` methods.
- *
- * The wrapper `Array` methods are:
- * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift`
- *
- * The wrapper `String` methods are:
- * `replace` and `split`
- *
- * The wrapper methods that support shortcut fusion are:
- * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`,
- * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`,
- * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray`
- *
- * The chainable wrapper methods are:
- * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`,
- * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`,
- * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`,
- * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`,
- * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`,
- * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`,
- * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`,
- * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`,
- * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`,
- * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`,
- * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`,
- * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`,
- * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`,
- * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`,
- * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`,
- * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`,
- * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`,
- * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`,
- * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`,
- * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`,
- * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`,
- * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`,
- * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`,
- * `zipObject`, `zipObjectDeep`, and `zipWith`
- *
- * The wrapper methods that are **not** chainable by default are:
- * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`,
- * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`,
- * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`,
- * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`,
- * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`,
- * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`,
- * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`,
- * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`,
- * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`,
- * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`,
- * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`,
- * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`,
- * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`,
- * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`,
- * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`,
- * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`,
- * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`,
- * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`,
- * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`,
- * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`,
- * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`,
- * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`,
- * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`,
- * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`,
- * `upperFirst`, `value`, and `words`
- *
- * @name _
- * @constructor
- * @category Seq
- * @param {*} value The value to wrap in a `lodash` instance.
- * @returns {Object} Returns the new `lodash` wrapper instance.
- * @example
- *
- * function square(n) {
- * return n * n;
- * }
- *
- * var wrapped = _([1, 2, 3]);
- *
- * // Returns an unwrapped value.
- * wrapped.reduce(_.add);
- * // => 6
- *
- * // Returns a wrapped value.
- * var squares = wrapped.map(square);
- *
- * _.isArray(squares);
- * // => false
- *
- * _.isArray(squares.value());
- * // => true
- */function lodash(value){if(isObjectLike(value)&&!isArray(value)&&!(value instanceof LazyWrapper)){if(value instanceof LodashWrapper){return value;}if(hasOwnProperty.call(value,'__wrapped__')){return wrapperClone(value);}}return new LodashWrapper(value);}/**
- * The base implementation of `_.create` without support for assigning
- * properties to the created object.
- *
- * @private
- * @param {Object} proto The object to inherit from.
- * @returns {Object} Returns the new object.
- */var baseCreate=function(){function object(){}return function(proto){if(!isObject(proto)){return{};}if(objectCreate){return objectCreate(proto);}object.prototype=proto;var result=new object();object.prototype=undefined;return result;};}();/**
- * The function whose prototype chain sequence wrappers inherit from.
- *
- * @private
- */function baseLodash(){}// No operation performed.
- /**
- * The base constructor for creating `lodash` wrapper objects.
- *
- * @private
- * @param {*} value The value to wrap.
- * @param {boolean} [chainAll] Enable explicit method chain sequences.
- */function LodashWrapper(value,chainAll){this.__wrapped__=value;this.__actions__=[];this.__chain__=!!chainAll;this.__index__=0;this.__values__=undefined;}/**
- * By default, the template delimiters used by lodash are like those in
- * embedded Ruby (ERB) as well as ES2015 template strings. Change the
- * following template settings to use alternative delimiters.
- *
- * @static
- * @memberOf _
- * @type {Object}
- */lodash.templateSettings={/**
- * Used to detect `data` property values to be HTML-escaped.
- *
- * @memberOf _.templateSettings
- * @type {RegExp}
- */escape:reEscape,/**
- * Used to detect code to be evaluated.
- *
- * @memberOf _.templateSettings
- * @type {RegExp}
- */evaluate:reEvaluate,/**
- * Used to detect `data` property values to inject.
- *
- * @memberOf _.templateSettings
- * @type {RegExp}
- */interpolate:reInterpolate,/**
- * Used to reference the data object in the template text.
- *
- * @memberOf _.templateSettings
- * @type {string}
- */variable:'',/**
- * Used to import variables into the compiled template.
- *
- * @memberOf _.templateSettings
- * @type {Object}
- */imports:{/**
- * A reference to the `lodash` function.
- *
- * @memberOf _.templateSettings.imports
- * @type {Function}
- */_:lodash}};// Ensure wrappers are instances of `baseLodash`.
- lodash.prototype=baseLodash.prototype;lodash.prototype.constructor=lodash;LodashWrapper.prototype=baseCreate(baseLodash.prototype);LodashWrapper.prototype.constructor=LodashWrapper;/* ------------------------------------------------------------------------*//**
- * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation.
- *
- * @private
- * @constructor
- * @param {*} value The value to wrap.
- */function LazyWrapper(value){this.__wrapped__=value;this.__actions__=[];this.__dir__=1;this.__filtered__=false;this.__iteratees__=[];this.__takeCount__=MAX_ARRAY_LENGTH;this.__views__=[];}/**
- * Creates a clone of the lazy wrapper object.
- *
- * @private
- * @name clone
- * @memberOf LazyWrapper
- * @returns {Object} Returns the cloned `LazyWrapper` object.
- */function lazyClone(){var result=new LazyWrapper(this.__wrapped__);result.__actions__=copyArray(this.__actions__);result.__dir__=this.__dir__;result.__filtered__=this.__filtered__;result.__iteratees__=copyArray(this.__iteratees__);result.__takeCount__=this.__takeCount__;result.__views__=copyArray(this.__views__);return result;}/**
- * Reverses the direction of lazy iteration.
- *
- * @private
- * @name reverse
- * @memberOf LazyWrapper
- * @returns {Object} Returns the new reversed `LazyWrapper` object.
- */function lazyReverse(){if(this.__filtered__){var result=new LazyWrapper(this);result.__dir__=-1;result.__filtered__=true;}else{result=this.clone();result.__dir__*=-1;}return result;}/**
- * Extracts the unwrapped value from its lazy wrapper.
- *
- * @private
- * @name value
- * @memberOf LazyWrapper
- * @returns {*} Returns the unwrapped value.
- */function lazyValue(){var array=this.__wrapped__.value(),dir=this.__dir__,isArr=isArray(array),isRight=dir<0,arrLength=isArr?array.length:0,view=getView(0,arrLength,this.__views__),start=view.start,end=view.end,length=end-start,index=isRight?end:start-1,iteratees=this.__iteratees__,iterLength=iteratees.length,resIndex=0,takeCount=nativeMin(length,this.__takeCount__);if(!isArr||!isRight&&arrLength==length&&takeCount==length){return baseWrapperValue(array,this.__actions__);}var result=[];outer:while(length--&&resIndex<takeCount){index+=dir;var iterIndex=-1,value=array[index];while(++iterIndex<iterLength){var data=iteratees[iterIndex],iteratee=data.iteratee,type=data.type,computed=iteratee(value);if(type==LAZY_MAP_FLAG){value=computed;}else if(!computed){if(type==LAZY_FILTER_FLAG){continue outer;}else{break outer;}}}result[resIndex++]=value;}return result;}// Ensure `LazyWrapper` is an instance of `baseLodash`.
- LazyWrapper.prototype=baseCreate(baseLodash.prototype);LazyWrapper.prototype.constructor=LazyWrapper;/* ------------------------------------------------------------------------*//**
- * Creates a hash object.
- *
- * @private
- * @constructor
- * @param {Array} [entries] The key-value pairs to cache.
- */function Hash(entries){var index=-1,length=entries==null?0:entries.length;this.clear();while(++index<length){var entry=entries[index];this.set(entry[0],entry[1]);}}/**
- * Removes all key-value entries from the hash.
- *
- * @private
- * @name clear
- * @memberOf Hash
- */function hashClear(){this.__data__=nativeCreate?nativeCreate(null):{};this.size=0;}/**
- * Removes `key` and its value from the hash.
- *
- * @private
- * @name delete
- * @memberOf Hash
- * @param {Object} hash The hash to modify.
- * @param {string} key The key of the value to remove.
- * @returns {boolean} Returns `true` if the entry was removed, else `false`.
- */function hashDelete(key){var result=this.has(key)&&delete this.__data__[key];this.size-=result?1:0;return result;}/**
- * Gets the hash value for `key`.
- *
- * @private
- * @name get
- * @memberOf Hash
- * @param {string} key The key of the value to get.
- * @returns {*} Returns the entry value.
- */function hashGet(key){var data=this.__data__;if(nativeCreate){var result=data[key];return result===HASH_UNDEFINED?undefined:result;}return hasOwnProperty.call(data,key)?data[key]:undefined;}/**
- * Checks if a hash value for `key` exists.
- *
- * @private
- * @name has
- * @memberOf Hash
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */function hashHas(key){var data=this.__data__;return nativeCreate?data[key]!==undefined:hasOwnProperty.call(data,key);}/**
- * Sets the hash `key` to `value`.
- *
- * @private
- * @name set
- * @memberOf Hash
- * @param {string} key The key of the value to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns the hash instance.
- */function hashSet(key,value){var data=this.__data__;this.size+=this.has(key)?0:1;data[key]=nativeCreate&&value===undefined?HASH_UNDEFINED:value;return this;}// Add methods to `Hash`.
- Hash.prototype.clear=hashClear;Hash.prototype['delete']=hashDelete;Hash.prototype.get=hashGet;Hash.prototype.has=hashHas;Hash.prototype.set=hashSet;/* ------------------------------------------------------------------------*//**
- * Creates an list cache object.
- *
- * @private
- * @constructor
- * @param {Array} [entries] The key-value pairs to cache.
- */function ListCache(entries){var index=-1,length=entries==null?0:entries.length;this.clear();while(++index<length){var entry=entries[index];this.set(entry[0],entry[1]);}}/**
- * Removes all key-value entries from the list cache.
- *
- * @private
- * @name clear
- * @memberOf ListCache
- */function listCacheClear(){this.__data__=[];this.size=0;}/**
- * Removes `key` and its value from the list cache.
- *
- * @private
- * @name delete
- * @memberOf ListCache
- * @param {string} key The key of the value to remove.
- * @returns {boolean} Returns `true` if the entry was removed, else `false`.
- */function listCacheDelete(key){var data=this.__data__,index=assocIndexOf(data,key);if(index<0){return false;}var lastIndex=data.length-1;if(index==lastIndex){data.pop();}else{splice.call(data,index,1);}--this.size;return true;}/**
- * Gets the list cache value for `key`.
- *
- * @private
- * @name get
- * @memberOf ListCache
- * @param {string} key The key of the value to get.
- * @returns {*} Returns the entry value.
- */function listCacheGet(key){var data=this.__data__,index=assocIndexOf(data,key);return index<0?undefined:data[index][1];}/**
- * Checks if a list cache value for `key` exists.
- *
- * @private
- * @name has
- * @memberOf ListCache
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */function listCacheHas(key){return assocIndexOf(this.__data__,key)>-1;}/**
- * Sets the list cache `key` to `value`.
- *
- * @private
- * @name set
- * @memberOf ListCache
- * @param {string} key The key of the value to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns the list cache instance.
- */function listCacheSet(key,value){var data=this.__data__,index=assocIndexOf(data,key);if(index<0){++this.size;data.push([key,value]);}else{data[index][1]=value;}return this;}// Add methods to `ListCache`.
- ListCache.prototype.clear=listCacheClear;ListCache.prototype['delete']=listCacheDelete;ListCache.prototype.get=listCacheGet;ListCache.prototype.has=listCacheHas;ListCache.prototype.set=listCacheSet;/* ------------------------------------------------------------------------*//**
- * Creates a map cache object to store key-value pairs.
- *
- * @private
- * @constructor
- * @param {Array} [entries] The key-value pairs to cache.
- */function MapCache(entries){var index=-1,length=entries==null?0:entries.length;this.clear();while(++index<length){var entry=entries[index];this.set(entry[0],entry[1]);}}/**
- * Removes all key-value entries from the map.
- *
- * @private
- * @name clear
- * @memberOf MapCache
- */function mapCacheClear(){this.size=0;this.__data__={hash:new Hash(),map:new(Map||ListCache)(),string:new Hash()};}/**
- * Removes `key` and its value from the map.
- *
- * @private
- * @name delete
- * @memberOf MapCache
- * @param {string} key The key of the value to remove.
- * @returns {boolean} Returns `true` if the entry was removed, else `false`.
- */function mapCacheDelete(key){var result=getMapData(this,key)['delete'](key);this.size-=result?1:0;return result;}/**
- * Gets the map value for `key`.
- *
- * @private
- * @name get
- * @memberOf MapCache
- * @param {string} key The key of the value to get.
- * @returns {*} Returns the entry value.
- */function mapCacheGet(key){return getMapData(this,key).get(key);}/**
- * Checks if a map value for `key` exists.
- *
- * @private
- * @name has
- * @memberOf MapCache
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */function mapCacheHas(key){return getMapData(this,key).has(key);}/**
- * Sets the map `key` to `value`.
- *
- * @private
- * @name set
- * @memberOf MapCache
- * @param {string} key The key of the value to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns the map cache instance.
- */function mapCacheSet(key,value){var data=getMapData(this,key),size=data.size;data.set(key,value);this.size+=data.size==size?0:1;return this;}// Add methods to `MapCache`.
- MapCache.prototype.clear=mapCacheClear;MapCache.prototype['delete']=mapCacheDelete;MapCache.prototype.get=mapCacheGet;MapCache.prototype.has=mapCacheHas;MapCache.prototype.set=mapCacheSet;/* ------------------------------------------------------------------------*//**
- *
- * Creates an array cache object to store unique values.
- *
- * @private
- * @constructor
- * @param {Array} [values] The values to cache.
- */function SetCache(values){var index=-1,length=values==null?0:values.length;this.__data__=new MapCache();while(++index<length){this.add(values[index]);}}/**
- * Adds `value` to the array cache.
- *
- * @private
- * @name add
- * @memberOf SetCache
- * @alias push
- * @param {*} value The value to cache.
- * @returns {Object} Returns the cache instance.
- */function setCacheAdd(value){this.__data__.set(value,HASH_UNDEFINED);return this;}/**
- * Checks if `value` is in the array cache.
- *
- * @private
- * @name has
- * @memberOf SetCache
- * @param {*} value The value to search for.
- * @returns {number} Returns `true` if `value` is found, else `false`.
- */function setCacheHas(value){return this.__data__.has(value);}// Add methods to `SetCache`.
- SetCache.prototype.add=SetCache.prototype.push=setCacheAdd;SetCache.prototype.has=setCacheHas;/* ------------------------------------------------------------------------*//**
- * Creates a stack cache object to store key-value pairs.
- *
- * @private
- * @constructor
- * @param {Array} [entries] The key-value pairs to cache.
- */function Stack(entries){var data=this.__data__=new ListCache(entries);this.size=data.size;}/**
- * Removes all key-value entries from the stack.
- *
- * @private
- * @name clear
- * @memberOf Stack
- */function stackClear(){this.__data__=new ListCache();this.size=0;}/**
- * Removes `key` and its value from the stack.
- *
- * @private
- * @name delete
- * @memberOf Stack
- * @param {string} key The key of the value to remove.
- * @returns {boolean} Returns `true` if the entry was removed, else `false`.
- */function stackDelete(key){var data=this.__data__,result=data['delete'](key);this.size=data.size;return result;}/**
- * Gets the stack value for `key`.
- *
- * @private
- * @name get
- * @memberOf Stack
- * @param {string} key The key of the value to get.
- * @returns {*} Returns the entry value.
- */function stackGet(key){return this.__data__.get(key);}/**
- * Checks if a stack value for `key` exists.
- *
- * @private
- * @name has
- * @memberOf Stack
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */function stackHas(key){return this.__data__.has(key);}/**
- * Sets the stack `key` to `value`.
- *
- * @private
- * @name set
- * @memberOf Stack
- * @param {string} key The key of the value to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns the stack cache instance.
- */function stackSet(key,value){var data=this.__data__;if(data instanceof ListCache){var pairs=data.__data__;if(!Map||pairs.length<LARGE_ARRAY_SIZE-1){pairs.push([key,value]);this.size=++data.size;return this;}data=this.__data__=new MapCache(pairs);}data.set(key,value);this.size=data.size;return this;}// Add methods to `Stack`.
- Stack.prototype.clear=stackClear;Stack.prototype['delete']=stackDelete;Stack.prototype.get=stackGet;Stack.prototype.has=stackHas;Stack.prototype.set=stackSet;/* ------------------------------------------------------------------------*//**
- * Creates an array of the enumerable property names of the array-like `value`.
- *
- * @private
- * @param {*} value The value to query.
- * @param {boolean} inherited Specify returning inherited property names.
- * @returns {Array} Returns the array of property names.
- */function arrayLikeKeys(value,inherited){var isArr=isArray(value),isArg=!isArr&&isArguments(value),isBuff=!isArr&&!isArg&&isBuffer(value),isType=!isArr&&!isArg&&!isBuff&&isTypedArray(value),skipIndexes=isArr||isArg||isBuff||isType,result=skipIndexes?baseTimes(value.length,String):[],length=result.length;for(var key in value){if((inherited||hasOwnProperty.call(value,key))&&!(skipIndexes&&(// Safari 9 has enumerable `arguments.length` in strict mode.
- key=='length'||// Node.js 0.10 has enumerable non-index properties on buffers.
- isBuff&&(key=='offset'||key=='parent')||// PhantomJS 2 has enumerable non-index properties on typed arrays.
- isType&&(key=='buffer'||key=='byteLength'||key=='byteOffset')||// Skip index properties.
- isIndex(key,length)))){result.push(key);}}return result;}/**
- * A specialized version of `_.sample` for arrays.
- *
- * @private
- * @param {Array} array The array to sample.
- * @returns {*} Returns the random element.
- */function arraySample(array){var length=array.length;return length?array[baseRandom(0,length-1)]:undefined;}/**
- * A specialized version of `_.sampleSize` for arrays.
- *
- * @private
- * @param {Array} array The array to sample.
- * @param {number} n The number of elements to sample.
- * @returns {Array} Returns the random elements.
- */function arraySampleSize(array,n){return shuffleSelf(copyArray(array),baseClamp(n,0,array.length));}/**
- * A specialized version of `_.shuffle` for arrays.
- *
- * @private
- * @param {Array} array The array to shuffle.
- * @returns {Array} Returns the new shuffled array.
- */function arrayShuffle(array){return shuffleSelf(copyArray(array));}/**
- * This function is like `assignValue` except that it doesn't assign
- * `undefined` values.
- *
- * @private
- * @param {Object} object The object to modify.
- * @param {string} key The key of the property to assign.
- * @param {*} value The value to assign.
- */function assignMergeValue(object,key,value){if(value!==undefined&&!eq(object[key],value)||value===undefined&&!(key in object)){baseAssignValue(object,key,value);}}/**
- * Assigns `value` to `key` of `object` if the existing value is not equivalent
- * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * for equality comparisons.
- *
- * @private
- * @param {Object} object The object to modify.
- * @param {string} key The key of the property to assign.
- * @param {*} value The value to assign.
- */function assignValue(object,key,value){var objValue=object[key];if(!(hasOwnProperty.call(object,key)&&eq(objValue,value))||value===undefined&&!(key in object)){baseAssignValue(object,key,value);}}/**
- * Gets the index at which the `key` is found in `array` of key-value pairs.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {*} key The key to search for.
- * @returns {number} Returns the index of the matched value, else `-1`.
- */function assocIndexOf(array,key){var length=array.length;while(length--){if(eq(array[length][0],key)){return length;}}return-1;}/**
- * Aggregates elements of `collection` on `accumulator` with keys transformed
- * by `iteratee` and values set by `setter`.
- *
- * @private
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} setter The function to set `accumulator` values.
- * @param {Function} iteratee The iteratee to transform keys.
- * @param {Object} accumulator The initial aggregated object.
- * @returns {Function} Returns `accumulator`.
- */function baseAggregator(collection,setter,iteratee,accumulator){baseEach(collection,function(value,key,collection){setter(accumulator,value,iteratee(value),collection);});return accumulator;}/**
- * The base implementation of `_.assign` without support for multiple sources
- * or `customizer` functions.
- *
- * @private
- * @param {Object} object The destination object.
- * @param {Object} source The source object.
- * @returns {Object} Returns `object`.
- */function baseAssign(object,source){return object&©Object(source,keys(source),object);}/**
- * The base implementation of `_.assignIn` without support for multiple sources
- * or `customizer` functions.
- *
- * @private
- * @param {Object} object The destination object.
- * @param {Object} source The source object.
- * @returns {Object} Returns `object`.
- */function baseAssignIn(object,source){return object&©Object(source,keysIn(source),object);}/**
- * The base implementation of `assignValue` and `assignMergeValue` without
- * value checks.
- *
- * @private
- * @param {Object} object The object to modify.
- * @param {string} key The key of the property to assign.
- * @param {*} value The value to assign.
- */function baseAssignValue(object,key,value){if(key=='__proto__'&&defineProperty){defineProperty(object,key,{configurable:true,enumerable:true,value:value,writable:true});}else{object[key]=value;}}/**
- * The base implementation of `_.at` without support for individual paths.
- *
- * @private
- * @param {Object} object The object to iterate over.
- * @param {string[]} paths The property paths to pick.
- * @returns {Array} Returns the picked elements.
- */function baseAt(object,paths){var index=-1,length=paths.length,result=Array(length),skip=object==null;while(++index<length){result[index]=skip?undefined:get(object,paths[index]);}return result;}/**
- * The base implementation of `_.clamp` which doesn't coerce arguments.
- *
- * @private
- * @param {number} number The number to clamp.
- * @param {number} [lower] The lower bound.
- * @param {number} upper The upper bound.
- * @returns {number} Returns the clamped number.
- */function baseClamp(number,lower,upper){if(number===number){if(upper!==undefined){number=number<=upper?number:upper;}if(lower!==undefined){number=number>=lower?number:lower;}}return number;}/**
- * The base implementation of `_.clone` and `_.cloneDeep` which tracks
- * traversed objects.
- *
- * @private
- * @param {*} value The value to clone.
- * @param {boolean} bitmask The bitmask flags.
- * 1 - Deep clone
- * 2 - Flatten inherited properties
- * 4 - Clone symbols
- * @param {Function} [customizer] The function to customize cloning.
- * @param {string} [key] The key of `value`.
- * @param {Object} [object] The parent object of `value`.
- * @param {Object} [stack] Tracks traversed objects and their clone counterparts.
- * @returns {*} Returns the cloned value.
- */function baseClone(value,bitmask,customizer,key,object,stack){var result,isDeep=bitmask&CLONE_DEEP_FLAG,isFlat=bitmask&CLONE_FLAT_FLAG,isFull=bitmask&CLONE_SYMBOLS_FLAG;if(customizer){result=object?customizer(value,key,object,stack):customizer(value);}if(result!==undefined){return result;}if(!isObject(value)){return value;}var isArr=isArray(value);if(isArr){result=initCloneArray(value);if(!isDeep){return copyArray(value,result);}}else{var tag=getTag(value),isFunc=tag==funcTag||tag==genTag;if(isBuffer(value)){return cloneBuffer(value,isDeep);}if(tag==objectTag||tag==argsTag||isFunc&&!object){result=isFlat||isFunc?{}:initCloneObject(value);if(!isDeep){return isFlat?copySymbolsIn(value,baseAssignIn(result,value)):copySymbols(value,baseAssign(result,value));}}else{if(!cloneableTags[tag]){return object?value:{};}result=initCloneByTag(value,tag,isDeep);}}// Check for circular references and return its corresponding clone.
- stack||(stack=new Stack());var stacked=stack.get(value);if(stacked){return stacked;}stack.set(value,result);if(isSet(value)){value.forEach(function(subValue){result.add(baseClone(subValue,bitmask,customizer,subValue,value,stack));});return result;}if(isMap(value)){value.forEach(function(subValue,key){result.set(key,baseClone(subValue,bitmask,customizer,key,value,stack));});return result;}var keysFunc=isFull?isFlat?getAllKeysIn:getAllKeys:isFlat?keysIn:keys;var props=isArr?undefined:keysFunc(value);arrayEach(props||value,function(subValue,key){if(props){key=subValue;subValue=value[key];}// Recursively populate clone (susceptible to call stack limits).
- assignValue(result,key,baseClone(subValue,bitmask,customizer,key,value,stack));});return result;}/**
- * The base implementation of `_.conforms` which doesn't clone `source`.
- *
- * @private
- * @param {Object} source The object of property predicates to conform to.
- * @returns {Function} Returns the new spec function.
- */function baseConforms(source){var props=keys(source);return function(object){return baseConformsTo(object,source,props);};}/**
- * The base implementation of `_.conformsTo` which accepts `props` to check.
- *
- * @private
- * @param {Object} object The object to inspect.
- * @param {Object} source The object of property predicates to conform to.
- * @returns {boolean} Returns `true` if `object` conforms, else `false`.
- */function baseConformsTo(object,source,props){var length=props.length;if(object==null){return!length;}object=Object(object);while(length--){var key=props[length],predicate=source[key],value=object[key];if(value===undefined&&!(key in object)||!predicate(value)){return false;}}return true;}/**
- * The base implementation of `_.delay` and `_.defer` which accepts `args`
- * to provide to `func`.
- *
- * @private
- * @param {Function} func The function to delay.
- * @param {number} wait The number of milliseconds to delay invocation.
- * @param {Array} args The arguments to provide to `func`.
- * @returns {number|Object} Returns the timer id or timeout object.
- */function baseDelay(func,wait,args){if(typeof func!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}return setTimeout(function(){func.apply(undefined,args);},wait);}/**
- * The base implementation of methods like `_.difference` without support
- * for excluding multiple arrays or iteratee shorthands.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {Array} values The values to exclude.
- * @param {Function} [iteratee] The iteratee invoked per element.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns the new array of filtered values.
- */function baseDifference(array,values,iteratee,comparator){var index=-1,includes=arrayIncludes,isCommon=true,length=array.length,result=[],valuesLength=values.length;if(!length){return result;}if(iteratee){values=arrayMap(values,baseUnary(iteratee));}if(comparator){includes=arrayIncludesWith;isCommon=false;}else if(values.length>=LARGE_ARRAY_SIZE){includes=cacheHas;isCommon=false;values=new SetCache(values);}outer:while(++index<length){var value=array[index],computed=iteratee==null?value:iteratee(value);value=comparator||value!==0?value:0;if(isCommon&&computed===computed){var valuesIndex=valuesLength;while(valuesIndex--){if(values[valuesIndex]===computed){continue outer;}}result.push(value);}else if(!includes(values,computed,comparator)){result.push(value);}}return result;}/**
- * The base implementation of `_.forEach` without support for iteratee shorthands.
- *
- * @private
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {Array|Object} Returns `collection`.
- */var baseEach=createBaseEach(baseForOwn);/**
- * The base implementation of `_.forEachRight` without support for iteratee shorthands.
- *
- * @private
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {Array|Object} Returns `collection`.
- */var baseEachRight=createBaseEach(baseForOwnRight,true);/**
- * The base implementation of `_.every` without support for iteratee shorthands.
- *
- * @private
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} predicate The function invoked per iteration.
- * @returns {boolean} Returns `true` if all elements pass the predicate check,
- * else `false`
- */function baseEvery(collection,predicate){var result=true;baseEach(collection,function(value,index,collection){result=!!predicate(value,index,collection);return result;});return result;}/**
- * The base implementation of methods like `_.max` and `_.min` which accepts a
- * `comparator` to determine the extremum value.
- *
- * @private
- * @param {Array} array The array to iterate over.
- * @param {Function} iteratee The iteratee invoked per iteration.
- * @param {Function} comparator The comparator used to compare values.
- * @returns {*} Returns the extremum value.
- */function baseExtremum(array,iteratee,comparator){var index=-1,length=array.length;while(++index<length){var value=array[index],current=iteratee(value);if(current!=null&&(computed===undefined?current===current&&!isSymbol(current):comparator(current,computed))){var computed=current,result=value;}}return result;}/**
- * The base implementation of `_.fill` without an iteratee call guard.
- *
- * @private
- * @param {Array} array The array to fill.
- * @param {*} value The value to fill `array` with.
- * @param {number} [start=0] The start position.
- * @param {number} [end=array.length] The end position.
- * @returns {Array} Returns `array`.
- */function baseFill(array,value,start,end){var length=array.length;start=toInteger(start);if(start<0){start=-start>length?0:length+start;}end=end===undefined||end>length?length:toInteger(end);if(end<0){end+=length;}end=start>end?0:toLength(end);while(start<end){array[start++]=value;}return array;}/**
- * The base implementation of `_.filter` without support for iteratee shorthands.
- *
- * @private
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} predicate The function invoked per iteration.
- * @returns {Array} Returns the new filtered array.
- */function baseFilter(collection,predicate){var result=[];baseEach(collection,function(value,index,collection){if(predicate(value,index,collection)){result.push(value);}});return result;}/**
- * The base implementation of `_.flatten` with support for restricting flattening.
- *
- * @private
- * @param {Array} array The array to flatten.
- * @param {number} depth The maximum recursion depth.
- * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.
- * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.
- * @param {Array} [result=[]] The initial result value.
- * @returns {Array} Returns the new flattened array.
- */function baseFlatten(array,depth,predicate,isStrict,result){var index=-1,length=array.length;predicate||(predicate=isFlattenable);result||(result=[]);while(++index<length){var value=array[index];if(depth>0&&predicate(value)){if(depth>1){// Recursively flatten arrays (susceptible to call stack limits).
- baseFlatten(value,depth-1,predicate,isStrict,result);}else{arrayPush(result,value);}}else if(!isStrict){result[result.length]=value;}}return result;}/**
- * The base implementation of `baseForOwn` which iterates over `object`
- * properties returned by `keysFunc` and invokes `iteratee` for each property.
- * Iteratee functions may exit iteration early by explicitly returning `false`.
- *
- * @private
- * @param {Object} object The object to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @param {Function} keysFunc The function to get the keys of `object`.
- * @returns {Object} Returns `object`.
- */var baseFor=createBaseFor();/**
- * This function is like `baseFor` except that it iterates over properties
- * in the opposite order.
- *
- * @private
- * @param {Object} object The object to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @param {Function} keysFunc The function to get the keys of `object`.
- * @returns {Object} Returns `object`.
- */var baseForRight=createBaseFor(true);/**
- * The base implementation of `_.forOwn` without support for iteratee shorthands.
- *
- * @private
- * @param {Object} object The object to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {Object} Returns `object`.
- */function baseForOwn(object,iteratee){return object&&baseFor(object,iteratee,keys);}/**
- * The base implementation of `_.forOwnRight` without support for iteratee shorthands.
- *
- * @private
- * @param {Object} object The object to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {Object} Returns `object`.
- */function baseForOwnRight(object,iteratee){return object&&baseForRight(object,iteratee,keys);}/**
- * The base implementation of `_.functions` which creates an array of
- * `object` function property names filtered from `props`.
- *
- * @private
- * @param {Object} object The object to inspect.
- * @param {Array} props The property names to filter.
- * @returns {Array} Returns the function names.
- */function baseFunctions(object,props){return arrayFilter(props,function(key){return isFunction(object[key]);});}/**
- * The base implementation of `_.get` without support for default values.
- *
- * @private
- * @param {Object} object The object to query.
- * @param {Array|string} path The path of the property to get.
- * @returns {*} Returns the resolved value.
- */function baseGet(object,path){path=castPath(path,object);var index=0,length=path.length;while(object!=null&&index<length){object=object[toKey(path[index++])];}return index&&index==length?object:undefined;}/**
- * The base implementation of `getAllKeys` and `getAllKeysIn` which uses
- * `keysFunc` and `symbolsFunc` to get the enumerable property names and
- * symbols of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @param {Function} keysFunc The function to get the keys of `object`.
- * @param {Function} symbolsFunc The function to get the symbols of `object`.
- * @returns {Array} Returns the array of property names and symbols.
- */function baseGetAllKeys(object,keysFunc,symbolsFunc){var result=keysFunc(object);return isArray(object)?result:arrayPush(result,symbolsFunc(object));}/**
- * The base implementation of `getTag` without fallbacks for buggy environments.
- *
- * @private
- * @param {*} value The value to query.
- * @returns {string} Returns the `toStringTag`.
- */function baseGetTag(value){if(value==null){return value===undefined?undefinedTag:nullTag;}return symToStringTag&&symToStringTag in Object(value)?getRawTag(value):objectToString(value);}/**
- * The base implementation of `_.gt` which doesn't coerce arguments.
- *
- * @private
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @returns {boolean} Returns `true` if `value` is greater than `other`,
- * else `false`.
- */function baseGt(value,other){return value>other;}/**
- * The base implementation of `_.has` without support for deep paths.
- *
- * @private
- * @param {Object} [object] The object to query.
- * @param {Array|string} key The key to check.
- * @returns {boolean} Returns `true` if `key` exists, else `false`.
- */function baseHas(object,key){return object!=null&&hasOwnProperty.call(object,key);}/**
- * The base implementation of `_.hasIn` without support for deep paths.
- *
- * @private
- * @param {Object} [object] The object to query.
- * @param {Array|string} key The key to check.
- * @returns {boolean} Returns `true` if `key` exists, else `false`.
- */function baseHasIn(object,key){return object!=null&&key in Object(object);}/**
- * The base implementation of `_.inRange` which doesn't coerce arguments.
- *
- * @private
- * @param {number} number The number to check.
- * @param {number} start The start of the range.
- * @param {number} end The end of the range.
- * @returns {boolean} Returns `true` if `number` is in the range, else `false`.
- */function baseInRange(number,start,end){return number>=nativeMin(start,end)&&number<nativeMax(start,end);}/**
- * The base implementation of methods like `_.intersection`, without support
- * for iteratee shorthands, that accepts an array of arrays to inspect.
- *
- * @private
- * @param {Array} arrays The arrays to inspect.
- * @param {Function} [iteratee] The iteratee invoked per element.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns the new array of shared values.
- */function baseIntersection(arrays,iteratee,comparator){var includes=comparator?arrayIncludesWith:arrayIncludes,length=arrays[0].length,othLength=arrays.length,othIndex=othLength,caches=Array(othLength),maxLength=Infinity,result=[];while(othIndex--){var array=arrays[othIndex];if(othIndex&&iteratee){array=arrayMap(array,baseUnary(iteratee));}maxLength=nativeMin(array.length,maxLength);caches[othIndex]=!comparator&&(iteratee||length>=120&&array.length>=120)?new SetCache(othIndex&&array):undefined;}array=arrays[0];var index=-1,seen=caches[0];outer:while(++index<length&&result.length<maxLength){var value=array[index],computed=iteratee?iteratee(value):value;value=comparator||value!==0?value:0;if(!(seen?cacheHas(seen,computed):includes(result,computed,comparator))){othIndex=othLength;while(--othIndex){var cache=caches[othIndex];if(!(cache?cacheHas(cache,computed):includes(arrays[othIndex],computed,comparator))){continue outer;}}if(seen){seen.push(computed);}result.push(value);}}return result;}/**
- * The base implementation of `_.invert` and `_.invertBy` which inverts
- * `object` with values transformed by `iteratee` and set by `setter`.
- *
- * @private
- * @param {Object} object The object to iterate over.
- * @param {Function} setter The function to set `accumulator` values.
- * @param {Function} iteratee The iteratee to transform values.
- * @param {Object} accumulator The initial inverted object.
- * @returns {Function} Returns `accumulator`.
- */function baseInverter(object,setter,iteratee,accumulator){baseForOwn(object,function(value,key,object){setter(accumulator,iteratee(value),key,object);});return accumulator;}/**
- * The base implementation of `_.invoke` without support for individual
- * method arguments.
- *
- * @private
- * @param {Object} object The object to query.
- * @param {Array|string} path The path of the method to invoke.
- * @param {Array} args The arguments to invoke the method with.
- * @returns {*} Returns the result of the invoked method.
- */function baseInvoke(object,path,args){path=castPath(path,object);object=parent(object,path);var func=object==null?object:object[toKey(last(path))];return func==null?undefined:apply(func,object,args);}/**
- * The base implementation of `_.isArguments`.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an `arguments` object,
- */function baseIsArguments(value){return isObjectLike(value)&&baseGetTag(value)==argsTag;}/**
- * The base implementation of `_.isArrayBuffer` without Node.js optimizations.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.
- */function baseIsArrayBuffer(value){return isObjectLike(value)&&baseGetTag(value)==arrayBufferTag;}/**
- * The base implementation of `_.isDate` without Node.js optimizations.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a date object, else `false`.
- */function baseIsDate(value){return isObjectLike(value)&&baseGetTag(value)==dateTag;}/**
- * The base implementation of `_.isEqual` which supports partial comparisons
- * and tracks traversed objects.
- *
- * @private
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @param {boolean} bitmask The bitmask flags.
- * 1 - Unordered comparison
- * 2 - Partial comparison
- * @param {Function} [customizer] The function to customize comparisons.
- * @param {Object} [stack] Tracks traversed `value` and `other` objects.
- * @returns {boolean} Returns `true` if the values are equivalent, else `false`.
- */function baseIsEqual(value,other,bitmask,customizer,stack){if(value===other){return true;}if(value==null||other==null||!isObjectLike(value)&&!isObjectLike(other)){return value!==value&&other!==other;}return baseIsEqualDeep(value,other,bitmask,customizer,baseIsEqual,stack);}/**
- * A specialized version of `baseIsEqual` for arrays and objects which performs
- * deep comparisons and tracks traversed objects enabling objects with circular
- * references to be compared.
- *
- * @private
- * @param {Object} object The object to compare.
- * @param {Object} other The other object to compare.
- * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.
- * @param {Function} customizer The function to customize comparisons.
- * @param {Function} equalFunc The function to determine equivalents of values.
- * @param {Object} [stack] Tracks traversed `object` and `other` objects.
- * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.
- */function baseIsEqualDeep(object,other,bitmask,customizer,equalFunc,stack){var objIsArr=isArray(object),othIsArr=isArray(other),objTag=objIsArr?arrayTag:getTag(object),othTag=othIsArr?arrayTag:getTag(other);objTag=objTag==argsTag?objectTag:objTag;othTag=othTag==argsTag?objectTag:othTag;var objIsObj=objTag==objectTag,othIsObj=othTag==objectTag,isSameTag=objTag==othTag;if(isSameTag&&isBuffer(object)){if(!isBuffer(other)){return false;}objIsArr=true;objIsObj=false;}if(isSameTag&&!objIsObj){stack||(stack=new Stack());return objIsArr||isTypedArray(object)?equalArrays(object,other,bitmask,customizer,equalFunc,stack):equalByTag(object,other,objTag,bitmask,customizer,equalFunc,stack);}if(!(bitmask&COMPARE_PARTIAL_FLAG)){var objIsWrapped=objIsObj&&hasOwnProperty.call(object,'__wrapped__'),othIsWrapped=othIsObj&&hasOwnProperty.call(other,'__wrapped__');if(objIsWrapped||othIsWrapped){var objUnwrapped=objIsWrapped?object.value():object,othUnwrapped=othIsWrapped?other.value():other;stack||(stack=new Stack());return equalFunc(objUnwrapped,othUnwrapped,bitmask,customizer,stack);}}if(!isSameTag){return false;}stack||(stack=new Stack());return equalObjects(object,other,bitmask,customizer,equalFunc,stack);}/**
- * The base implementation of `_.isMap` without Node.js optimizations.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a map, else `false`.
- */function baseIsMap(value){return isObjectLike(value)&&getTag(value)==mapTag;}/**
- * The base implementation of `_.isMatch` without support for iteratee shorthands.
- *
- * @private
- * @param {Object} object The object to inspect.
- * @param {Object} source The object of property values to match.
- * @param {Array} matchData The property names, values, and compare flags to match.
- * @param {Function} [customizer] The function to customize comparisons.
- * @returns {boolean} Returns `true` if `object` is a match, else `false`.
- */function baseIsMatch(object,source,matchData,customizer){var index=matchData.length,length=index,noCustomizer=!customizer;if(object==null){return!length;}object=Object(object);while(index--){var data=matchData[index];if(noCustomizer&&data[2]?data[1]!==object[data[0]]:!(data[0]in object)){return false;}}while(++index<length){data=matchData[index];var key=data[0],objValue=object[key],srcValue=data[1];if(noCustomizer&&data[2]){if(objValue===undefined&&!(key in object)){return false;}}else{var stack=new Stack();if(customizer){var result=customizer(objValue,srcValue,key,object,source,stack);}if(!(result===undefined?baseIsEqual(srcValue,objValue,COMPARE_PARTIAL_FLAG|COMPARE_UNORDERED_FLAG,customizer,stack):result)){return false;}}}return true;}/**
- * The base implementation of `_.isNative` without bad shim checks.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a native function,
- * else `false`.
- */function baseIsNative(value){if(!isObject(value)||isMasked(value)){return false;}var pattern=isFunction(value)?reIsNative:reIsHostCtor;return pattern.test(toSource(value));}/**
- * The base implementation of `_.isRegExp` without Node.js optimizations.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.
- */function baseIsRegExp(value){return isObjectLike(value)&&baseGetTag(value)==regexpTag;}/**
- * The base implementation of `_.isSet` without Node.js optimizations.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a set, else `false`.
- */function baseIsSet(value){return isObjectLike(value)&&getTag(value)==setTag;}/**
- * The base implementation of `_.isTypedArray` without Node.js optimizations.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.
- */function baseIsTypedArray(value){return isObjectLike(value)&&isLength(value.length)&&!!typedArrayTags[baseGetTag(value)];}/**
- * The base implementation of `_.iteratee`.
- *
- * @private
- * @param {*} [value=_.identity] The value to convert to an iteratee.
- * @returns {Function} Returns the iteratee.
- */function baseIteratee(value){// Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.
- // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.
- if(typeof value==='function'){return value;}if(value==null){return identity;}if((typeof value==='undefined'?'undefined':_typeof(value))==='object'){return isArray(value)?baseMatchesProperty(value[0],value[1]):baseMatches(value);}return property(value);}/**
- * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property names.
- */function baseKeys(object){if(!isPrototype(object)){return nativeKeys(object);}var result=[];for(var key in Object(object)){if(hasOwnProperty.call(object,key)&&key!='constructor'){result.push(key);}}return result;}/**
- * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property names.
- */function baseKeysIn(object){if(!isObject(object)){return nativeKeysIn(object);}var isProto=isPrototype(object),result=[];for(var key in object){if(!(key=='constructor'&&(isProto||!hasOwnProperty.call(object,key)))){result.push(key);}}return result;}/**
- * The base implementation of `_.lt` which doesn't coerce arguments.
- *
- * @private
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @returns {boolean} Returns `true` if `value` is less than `other`,
- * else `false`.
- */function baseLt(value,other){return value<other;}/**
- * The base implementation of `_.map` without support for iteratee shorthands.
- *
- * @private
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} iteratee The function invoked per iteration.
- * @returns {Array} Returns the new mapped array.
- */function baseMap(collection,iteratee){var index=-1,result=isArrayLike(collection)?Array(collection.length):[];baseEach(collection,function(value,key,collection){result[++index]=iteratee(value,key,collection);});return result;}/**
- * The base implementation of `_.matches` which doesn't clone `source`.
- *
- * @private
- * @param {Object} source The object of property values to match.
- * @returns {Function} Returns the new spec function.
- */function baseMatches(source){var matchData=getMatchData(source);if(matchData.length==1&&matchData[0][2]){return matchesStrictComparable(matchData[0][0],matchData[0][1]);}return function(object){return object===source||baseIsMatch(object,source,matchData);};}/**
- * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.
- *
- * @private
- * @param {string} path The path of the property to get.
- * @param {*} srcValue The value to match.
- * @returns {Function} Returns the new spec function.
- */function baseMatchesProperty(path,srcValue){if(isKey(path)&&isStrictComparable(srcValue)){return matchesStrictComparable(toKey(path),srcValue);}return function(object){var objValue=get(object,path);return objValue===undefined&&objValue===srcValue?hasIn(object,path):baseIsEqual(srcValue,objValue,COMPARE_PARTIAL_FLAG|COMPARE_UNORDERED_FLAG);};}/**
- * The base implementation of `_.merge` without support for multiple sources.
- *
- * @private
- * @param {Object} object The destination object.
- * @param {Object} source The source object.
- * @param {number} srcIndex The index of `source`.
- * @param {Function} [customizer] The function to customize merged values.
- * @param {Object} [stack] Tracks traversed source values and their merged
- * counterparts.
- */function baseMerge(object,source,srcIndex,customizer,stack){if(object===source){return;}baseFor(source,function(srcValue,key){if(isObject(srcValue)){stack||(stack=new Stack());baseMergeDeep(object,source,key,srcIndex,baseMerge,customizer,stack);}else{var newValue=customizer?customizer(safeGet(object,key),srcValue,key+'',object,source,stack):undefined;if(newValue===undefined){newValue=srcValue;}assignMergeValue(object,key,newValue);}},keysIn);}/**
- * A specialized version of `baseMerge` for arrays and objects which performs
- * deep merges and tracks traversed objects enabling objects with circular
- * references to be merged.
- *
- * @private
- * @param {Object} object The destination object.
- * @param {Object} source The source object.
- * @param {string} key The key of the value to merge.
- * @param {number} srcIndex The index of `source`.
- * @param {Function} mergeFunc The function to merge values.
- * @param {Function} [customizer] The function to customize assigned values.
- * @param {Object} [stack] Tracks traversed source values and their merged
- * counterparts.
- */function baseMergeDeep(object,source,key,srcIndex,mergeFunc,customizer,stack){var objValue=safeGet(object,key),srcValue=safeGet(source,key),stacked=stack.get(srcValue);if(stacked){assignMergeValue(object,key,stacked);return;}var newValue=customizer?customizer(objValue,srcValue,key+'',object,source,stack):undefined;var isCommon=newValue===undefined;if(isCommon){var isArr=isArray(srcValue),isBuff=!isArr&&isBuffer(srcValue),isTyped=!isArr&&!isBuff&&isTypedArray(srcValue);newValue=srcValue;if(isArr||isBuff||isTyped){if(isArray(objValue)){newValue=objValue;}else if(isArrayLikeObject(objValue)){newValue=copyArray(objValue);}else if(isBuff){isCommon=false;newValue=cloneBuffer(srcValue,true);}else if(isTyped){isCommon=false;newValue=cloneTypedArray(srcValue,true);}else{newValue=[];}}else if(isPlainObject(srcValue)||isArguments(srcValue)){newValue=objValue;if(isArguments(objValue)){newValue=toPlainObject(objValue);}else if(!isObject(objValue)||srcIndex&&isFunction(objValue)){newValue=initCloneObject(srcValue);}}else{isCommon=false;}}if(isCommon){// Recursively merge objects and arrays (susceptible to call stack limits).
- stack.set(srcValue,newValue);mergeFunc(newValue,srcValue,srcIndex,customizer,stack);stack['delete'](srcValue);}assignMergeValue(object,key,newValue);}/**
- * The base implementation of `_.nth` which doesn't coerce arguments.
- *
- * @private
- * @param {Array} array The array to query.
- * @param {number} n The index of the element to return.
- * @returns {*} Returns the nth element of `array`.
- */function baseNth(array,n){var length=array.length;if(!length){return;}n+=n<0?length:0;return isIndex(n,length)?array[n]:undefined;}/**
- * The base implementation of `_.orderBy` without param guards.
- *
- * @private
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by.
- * @param {string[]} orders The sort orders of `iteratees`.
- * @returns {Array} Returns the new sorted array.
- */function baseOrderBy(collection,iteratees,orders){var index=-1;iteratees=arrayMap(iteratees.length?iteratees:[identity],baseUnary(getIteratee()));var result=baseMap(collection,function(value,key,collection){var criteria=arrayMap(iteratees,function(iteratee){return iteratee(value);});return{criteria:criteria,index:++index,value:value};});return baseSortBy(result,function(object,other){return compareMultiple(object,other,orders);});}/**
- * The base implementation of `_.pick` without support for individual
- * property identifiers.
- *
- * @private
- * @param {Object} object The source object.
- * @param {string[]} paths The property paths to pick.
- * @returns {Object} Returns the new object.
- */function basePick(object,paths){return basePickBy(object,paths,function(value,path){return hasIn(object,path);});}/**
- * The base implementation of `_.pickBy` without support for iteratee shorthands.
- *
- * @private
- * @param {Object} object The source object.
- * @param {string[]} paths The property paths to pick.
- * @param {Function} predicate The function invoked per property.
- * @returns {Object} Returns the new object.
- */function basePickBy(object,paths,predicate){var index=-1,length=paths.length,result={};while(++index<length){var path=paths[index],value=baseGet(object,path);if(predicate(value,path)){baseSet(result,castPath(path,object),value);}}return result;}/**
- * A specialized version of `baseProperty` which supports deep paths.
- *
- * @private
- * @param {Array|string} path The path of the property to get.
- * @returns {Function} Returns the new accessor function.
- */function basePropertyDeep(path){return function(object){return baseGet(object,path);};}/**
- * The base implementation of `_.pullAllBy` without support for iteratee
- * shorthands.
- *
- * @private
- * @param {Array} array The array to modify.
- * @param {Array} values The values to remove.
- * @param {Function} [iteratee] The iteratee invoked per element.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns `array`.
- */function basePullAll(array,values,iteratee,comparator){var indexOf=comparator?baseIndexOfWith:baseIndexOf,index=-1,length=values.length,seen=array;if(array===values){values=copyArray(values);}if(iteratee){seen=arrayMap(array,baseUnary(iteratee));}while(++index<length){var fromIndex=0,value=values[index],computed=iteratee?iteratee(value):value;while((fromIndex=indexOf(seen,computed,fromIndex,comparator))>-1){if(seen!==array){splice.call(seen,fromIndex,1);}splice.call(array,fromIndex,1);}}return array;}/**
- * The base implementation of `_.pullAt` without support for individual
- * indexes or capturing the removed elements.
- *
- * @private
- * @param {Array} array The array to modify.
- * @param {number[]} indexes The indexes of elements to remove.
- * @returns {Array} Returns `array`.
- */function basePullAt(array,indexes){var length=array?indexes.length:0,lastIndex=length-1;while(length--){var index=indexes[length];if(length==lastIndex||index!==previous){var previous=index;if(isIndex(index)){splice.call(array,index,1);}else{baseUnset(array,index);}}}return array;}/**
- * The base implementation of `_.random` without support for returning
- * floating-point numbers.
- *
- * @private
- * @param {number} lower The lower bound.
- * @param {number} upper The upper bound.
- * @returns {number} Returns the random number.
- */function baseRandom(lower,upper){return lower+nativeFloor(nativeRandom()*(upper-lower+1));}/**
- * The base implementation of `_.range` and `_.rangeRight` which doesn't
- * coerce arguments.
- *
- * @private
- * @param {number} start The start of the range.
- * @param {number} end The end of the range.
- * @param {number} step The value to increment or decrement by.
- * @param {boolean} [fromRight] Specify iterating from right to left.
- * @returns {Array} Returns the range of numbers.
- */function baseRange(start,end,step,fromRight){var index=-1,length=nativeMax(nativeCeil((end-start)/(step||1)),0),result=Array(length);while(length--){result[fromRight?length:++index]=start;start+=step;}return result;}/**
- * The base implementation of `_.repeat` which doesn't coerce arguments.
- *
- * @private
- * @param {string} string The string to repeat.
- * @param {number} n The number of times to repeat the string.
- * @returns {string} Returns the repeated string.
- */function baseRepeat(string,n){var result='';if(!string||n<1||n>MAX_SAFE_INTEGER){return result;}// Leverage the exponentiation by squaring algorithm for a faster repeat.
- // See https://en.wikipedia.org/wiki/Exponentiation_by_squaring for more details.
- do{if(n%2){result+=string;}n=nativeFloor(n/2);if(n){string+=string;}}while(n);return result;}/**
- * The base implementation of `_.rest` which doesn't validate or coerce arguments.
- *
- * @private
- * @param {Function} func The function to apply a rest parameter to.
- * @param {number} [start=func.length-1] The start position of the rest parameter.
- * @returns {Function} Returns the new function.
- */function baseRest(func,start){return setToString(overRest(func,start,identity),func+'');}/**
- * The base implementation of `_.sample`.
- *
- * @private
- * @param {Array|Object} collection The collection to sample.
- * @returns {*} Returns the random element.
- */function baseSample(collection){return arraySample(values(collection));}/**
- * The base implementation of `_.sampleSize` without param guards.
- *
- * @private
- * @param {Array|Object} collection The collection to sample.
- * @param {number} n The number of elements to sample.
- * @returns {Array} Returns the random elements.
- */function baseSampleSize(collection,n){var array=values(collection);return shuffleSelf(array,baseClamp(n,0,array.length));}/**
- * The base implementation of `_.set`.
- *
- * @private
- * @param {Object} object The object to modify.
- * @param {Array|string} path The path of the property to set.
- * @param {*} value The value to set.
- * @param {Function} [customizer] The function to customize path creation.
- * @returns {Object} Returns `object`.
- */function baseSet(object,path,value,customizer){if(!isObject(object)){return object;}path=castPath(path,object);var index=-1,length=path.length,lastIndex=length-1,nested=object;while(nested!=null&&++index<length){var key=toKey(path[index]),newValue=value;if(index!=lastIndex){var objValue=nested[key];newValue=customizer?customizer(objValue,key,nested):undefined;if(newValue===undefined){newValue=isObject(objValue)?objValue:isIndex(path[index+1])?[]:{};}}assignValue(nested,key,newValue);nested=nested[key];}return object;}/**
- * The base implementation of `setData` without support for hot loop shorting.
- *
- * @private
- * @param {Function} func The function to associate metadata with.
- * @param {*} data The metadata.
- * @returns {Function} Returns `func`.
- */var baseSetData=!metaMap?identity:function(func,data){metaMap.set(func,data);return func;};/**
- * The base implementation of `setToString` without support for hot loop shorting.
- *
- * @private
- * @param {Function} func The function to modify.
- * @param {Function} string The `toString` result.
- * @returns {Function} Returns `func`.
- */var baseSetToString=!defineProperty?identity:function(func,string){return defineProperty(func,'toString',{configurable:true,enumerable:false,value:constant(string),writable:true});};/**
- * The base implementation of `_.shuffle`.
- *
- * @private
- * @param {Array|Object} collection The collection to shuffle.
- * @returns {Array} Returns the new shuffled array.
- */function baseShuffle(collection){return shuffleSelf(values(collection));}/**
- * The base implementation of `_.slice` without an iteratee call guard.
- *
- * @private
- * @param {Array} array The array to slice.
- * @param {number} [start=0] The start position.
- * @param {number} [end=array.length] The end position.
- * @returns {Array} Returns the slice of `array`.
- */function baseSlice(array,start,end){var index=-1,length=array.length;if(start<0){start=-start>length?0:length+start;}end=end>length?length:end;if(end<0){end+=length;}length=start>end?0:end-start>>>0;start>>>=0;var result=Array(length);while(++index<length){result[index]=array[index+start];}return result;}/**
- * The base implementation of `_.some` without support for iteratee shorthands.
- *
- * @private
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} predicate The function invoked per iteration.
- * @returns {boolean} Returns `true` if any element passes the predicate check,
- * else `false`.
- */function baseSome(collection,predicate){var result;baseEach(collection,function(value,index,collection){result=predicate(value,index,collection);return!result;});return!!result;}/**
- * The base implementation of `_.sortedIndex` and `_.sortedLastIndex` which
- * performs a binary search of `array` to determine the index at which `value`
- * should be inserted into `array` in order to maintain its sort order.
- *
- * @private
- * @param {Array} array The sorted array to inspect.
- * @param {*} value The value to evaluate.
- * @param {boolean} [retHighest] Specify returning the highest qualified index.
- * @returns {number} Returns the index at which `value` should be inserted
- * into `array`.
- */function baseSortedIndex(array,value,retHighest){var low=0,high=array==null?low:array.length;if(typeof value==='number'&&value===value&&high<=HALF_MAX_ARRAY_LENGTH){while(low<high){var mid=low+high>>>1,computed=array[mid];if(computed!==null&&!isSymbol(computed)&&(retHighest?computed<=value:computed<value)){low=mid+1;}else{high=mid;}}return high;}return baseSortedIndexBy(array,value,identity,retHighest);}/**
- * The base implementation of `_.sortedIndexBy` and `_.sortedLastIndexBy`
- * which invokes `iteratee` for `value` and each element of `array` to compute
- * their sort ranking. The iteratee is invoked with one argument; (value).
- *
- * @private
- * @param {Array} array The sorted array to inspect.
- * @param {*} value The value to evaluate.
- * @param {Function} iteratee The iteratee invoked per element.
- * @param {boolean} [retHighest] Specify returning the highest qualified index.
- * @returns {number} Returns the index at which `value` should be inserted
- * into `array`.
- */function baseSortedIndexBy(array,value,iteratee,retHighest){value=iteratee(value);var low=0,high=array==null?0:array.length,valIsNaN=value!==value,valIsNull=value===null,valIsSymbol=isSymbol(value),valIsUndefined=value===undefined;while(low<high){var mid=nativeFloor((low+high)/2),computed=iteratee(array[mid]),othIsDefined=computed!==undefined,othIsNull=computed===null,othIsReflexive=computed===computed,othIsSymbol=isSymbol(computed);if(valIsNaN){var setLow=retHighest||othIsReflexive;}else if(valIsUndefined){setLow=othIsReflexive&&(retHighest||othIsDefined);}else if(valIsNull){setLow=othIsReflexive&&othIsDefined&&(retHighest||!othIsNull);}else if(valIsSymbol){setLow=othIsReflexive&&othIsDefined&&!othIsNull&&(retHighest||!othIsSymbol);}else if(othIsNull||othIsSymbol){setLow=false;}else{setLow=retHighest?computed<=value:computed<value;}if(setLow){low=mid+1;}else{high=mid;}}return nativeMin(high,MAX_ARRAY_INDEX);}/**
- * The base implementation of `_.sortedUniq` and `_.sortedUniqBy` without
- * support for iteratee shorthands.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {Function} [iteratee] The iteratee invoked per element.
- * @returns {Array} Returns the new duplicate free array.
- */function baseSortedUniq(array,iteratee){var index=-1,length=array.length,resIndex=0,result=[];while(++index<length){var value=array[index],computed=iteratee?iteratee(value):value;if(!index||!eq(computed,seen)){var seen=computed;result[resIndex++]=value===0?0:value;}}return result;}/**
- * The base implementation of `_.toNumber` which doesn't ensure correct
- * conversions of binary, hexadecimal, or octal string values.
- *
- * @private
- * @param {*} value The value to process.
- * @returns {number} Returns the number.
- */function baseToNumber(value){if(typeof value==='number'){return value;}if(isSymbol(value)){return NAN;}return+value;}/**
- * The base implementation of `_.toString` which doesn't convert nullish
- * values to empty strings.
- *
- * @private
- * @param {*} value The value to process.
- * @returns {string} Returns the string.
- */function baseToString(value){// Exit early for strings to avoid a performance hit in some environments.
- if(typeof value==='string'){return value;}if(isArray(value)){// Recursively convert values (susceptible to call stack limits).
- return arrayMap(value,baseToString)+'';}if(isSymbol(value)){return symbolToString?symbolToString.call(value):'';}var result=value+'';return result=='0'&&1/value==-INFINITY?'-0':result;}/**
- * The base implementation of `_.uniqBy` without support for iteratee shorthands.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {Function} [iteratee] The iteratee invoked per element.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns the new duplicate free array.
- */function baseUniq(array,iteratee,comparator){var index=-1,includes=arrayIncludes,length=array.length,isCommon=true,result=[],seen=result;if(comparator){isCommon=false;includes=arrayIncludesWith;}else if(length>=LARGE_ARRAY_SIZE){var set=iteratee?null:createSet(array);if(set){return setToArray(set);}isCommon=false;includes=cacheHas;seen=new SetCache();}else{seen=iteratee?[]:result;}outer:while(++index<length){var value=array[index],computed=iteratee?iteratee(value):value;value=comparator||value!==0?value:0;if(isCommon&&computed===computed){var seenIndex=seen.length;while(seenIndex--){if(seen[seenIndex]===computed){continue outer;}}if(iteratee){seen.push(computed);}result.push(value);}else if(!includes(seen,computed,comparator)){if(seen!==result){seen.push(computed);}result.push(value);}}return result;}/**
- * The base implementation of `_.unset`.
- *
- * @private
- * @param {Object} object The object to modify.
- * @param {Array|string} path The property path to unset.
- * @returns {boolean} Returns `true` if the property is deleted, else `false`.
- */function baseUnset(object,path){path=castPath(path,object);object=parent(object,path);return object==null||delete object[toKey(last(path))];}/**
- * The base implementation of `_.update`.
- *
- * @private
- * @param {Object} object The object to modify.
- * @param {Array|string} path The path of the property to update.
- * @param {Function} updater The function to produce the updated value.
- * @param {Function} [customizer] The function to customize path creation.
- * @returns {Object} Returns `object`.
- */function baseUpdate(object,path,updater,customizer){return baseSet(object,path,updater(baseGet(object,path)),customizer);}/**
- * The base implementation of methods like `_.dropWhile` and `_.takeWhile`
- * without support for iteratee shorthands.
- *
- * @private
- * @param {Array} array The array to query.
- * @param {Function} predicate The function invoked per iteration.
- * @param {boolean} [isDrop] Specify dropping elements instead of taking them.
- * @param {boolean} [fromRight] Specify iterating from right to left.
- * @returns {Array} Returns the slice of `array`.
- */function baseWhile(array,predicate,isDrop,fromRight){var length=array.length,index=fromRight?length:-1;while((fromRight?index--:++index<length)&&predicate(array[index],index,array)){}return isDrop?baseSlice(array,fromRight?0:index,fromRight?index+1:length):baseSlice(array,fromRight?index+1:0,fromRight?length:index);}/**
- * The base implementation of `wrapperValue` which returns the result of
- * performing a sequence of actions on the unwrapped `value`, where each
- * successive action is supplied the return value of the previous.
- *
- * @private
- * @param {*} value The unwrapped value.
- * @param {Array} actions Actions to perform to resolve the unwrapped value.
- * @returns {*} Returns the resolved value.
- */function baseWrapperValue(value,actions){var result=value;if(result instanceof LazyWrapper){result=result.value();}return arrayReduce(actions,function(result,action){return action.func.apply(action.thisArg,arrayPush([result],action.args));},result);}/**
- * The base implementation of methods like `_.xor`, without support for
- * iteratee shorthands, that accepts an array of arrays to inspect.
- *
- * @private
- * @param {Array} arrays The arrays to inspect.
- * @param {Function} [iteratee] The iteratee invoked per element.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns the new array of values.
- */function baseXor(arrays,iteratee,comparator){var length=arrays.length;if(length<2){return length?baseUniq(arrays[0]):[];}var index=-1,result=Array(length);while(++index<length){var array=arrays[index],othIndex=-1;while(++othIndex<length){if(othIndex!=index){result[index]=baseDifference(result[index]||array,arrays[othIndex],iteratee,comparator);}}}return baseUniq(baseFlatten(result,1),iteratee,comparator);}/**
- * This base implementation of `_.zipObject` which assigns values using `assignFunc`.
- *
- * @private
- * @param {Array} props The property identifiers.
- * @param {Array} values The property values.
- * @param {Function} assignFunc The function to assign values.
- * @returns {Object} Returns the new object.
- */function baseZipObject(props,values,assignFunc){var index=-1,length=props.length,valsLength=values.length,result={};while(++index<length){var value=index<valsLength?values[index]:undefined;assignFunc(result,props[index],value);}return result;}/**
- * Casts `value` to an empty array if it's not an array like object.
- *
- * @private
- * @param {*} value The value to inspect.
- * @returns {Array|Object} Returns the cast array-like object.
- */function castArrayLikeObject(value){return isArrayLikeObject(value)?value:[];}/**
- * Casts `value` to `identity` if it's not a function.
- *
- * @private
- * @param {*} value The value to inspect.
- * @returns {Function} Returns cast function.
- */function castFunction(value){return typeof value==='function'?value:identity;}/**
- * Casts `value` to a path array if it's not one.
- *
- * @private
- * @param {*} value The value to inspect.
- * @param {Object} [object] The object to query keys on.
- * @returns {Array} Returns the cast property path array.
- */function castPath(value,object){if(isArray(value)){return value;}return isKey(value,object)?[value]:stringToPath(toString(value));}/**
- * A `baseRest` alias which can be replaced with `identity` by module
- * replacement plugins.
- *
- * @private
- * @type {Function}
- * @param {Function} func The function to apply a rest parameter to.
- * @returns {Function} Returns the new function.
- */var castRest=baseRest;/**
- * Casts `array` to a slice if it's needed.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {number} start The start position.
- * @param {number} [end=array.length] The end position.
- * @returns {Array} Returns the cast slice.
- */function castSlice(array,start,end){var length=array.length;end=end===undefined?length:end;return!start&&end>=length?array:baseSlice(array,start,end);}/**
- * A simple wrapper around the global [`clearTimeout`](https://mdn.io/clearTimeout).
- *
- * @private
- * @param {number|Object} id The timer id or timeout object of the timer to clear.
- */var clearTimeout=ctxClearTimeout||function(id){return root.clearTimeout(id);};/**
- * Creates a clone of `buffer`.
- *
- * @private
- * @param {Buffer} buffer The buffer to clone.
- * @param {boolean} [isDeep] Specify a deep clone.
- * @returns {Buffer} Returns the cloned buffer.
- */function cloneBuffer(buffer,isDeep){if(isDeep){return buffer.slice();}var length=buffer.length,result=allocUnsafe?allocUnsafe(length):new buffer.constructor(length);buffer.copy(result);return result;}/**
- * Creates a clone of `arrayBuffer`.
- *
- * @private
- * @param {ArrayBuffer} arrayBuffer The array buffer to clone.
- * @returns {ArrayBuffer} Returns the cloned array buffer.
- */function cloneArrayBuffer(arrayBuffer){var result=new arrayBuffer.constructor(arrayBuffer.byteLength);new Uint8Array(result).set(new Uint8Array(arrayBuffer));return result;}/**
- * Creates a clone of `dataView`.
- *
- * @private
- * @param {Object} dataView The data view to clone.
- * @param {boolean} [isDeep] Specify a deep clone.
- * @returns {Object} Returns the cloned data view.
- */function cloneDataView(dataView,isDeep){var buffer=isDeep?cloneArrayBuffer(dataView.buffer):dataView.buffer;return new dataView.constructor(buffer,dataView.byteOffset,dataView.byteLength);}/**
- * Creates a clone of `regexp`.
- *
- * @private
- * @param {Object} regexp The regexp to clone.
- * @returns {Object} Returns the cloned regexp.
- */function cloneRegExp(regexp){var result=new regexp.constructor(regexp.source,reFlags.exec(regexp));result.lastIndex=regexp.lastIndex;return result;}/**
- * Creates a clone of the `symbol` object.
- *
- * @private
- * @param {Object} symbol The symbol object to clone.
- * @returns {Object} Returns the cloned symbol object.
- */function cloneSymbol(symbol){return symbolValueOf?Object(symbolValueOf.call(symbol)):{};}/**
- * Creates a clone of `typedArray`.
- *
- * @private
- * @param {Object} typedArray The typed array to clone.
- * @param {boolean} [isDeep] Specify a deep clone.
- * @returns {Object} Returns the cloned typed array.
- */function cloneTypedArray(typedArray,isDeep){var buffer=isDeep?cloneArrayBuffer(typedArray.buffer):typedArray.buffer;return new typedArray.constructor(buffer,typedArray.byteOffset,typedArray.length);}/**
- * Compares values to sort them in ascending order.
- *
- * @private
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @returns {number} Returns the sort order indicator for `value`.
- */function compareAscending(value,other){if(value!==other){var valIsDefined=value!==undefined,valIsNull=value===null,valIsReflexive=value===value,valIsSymbol=isSymbol(value);var othIsDefined=other!==undefined,othIsNull=other===null,othIsReflexive=other===other,othIsSymbol=isSymbol(other);if(!othIsNull&&!othIsSymbol&&!valIsSymbol&&value>other||valIsSymbol&&othIsDefined&&othIsReflexive&&!othIsNull&&!othIsSymbol||valIsNull&&othIsDefined&&othIsReflexive||!valIsDefined&&othIsReflexive||!valIsReflexive){return 1;}if(!valIsNull&&!valIsSymbol&&!othIsSymbol&&value<other||othIsSymbol&&valIsDefined&&valIsReflexive&&!valIsNull&&!valIsSymbol||othIsNull&&valIsDefined&&valIsReflexive||!othIsDefined&&valIsReflexive||!othIsReflexive){return-1;}}return 0;}/**
- * Used by `_.orderBy` to compare multiple properties of a value to another
- * and stable sort them.
- *
- * If `orders` is unspecified, all values are sorted in ascending order. Otherwise,
- * specify an order of "desc" for descending or "asc" for ascending sort order
- * of corresponding values.
- *
- * @private
- * @param {Object} object The object to compare.
- * @param {Object} other The other object to compare.
- * @param {boolean[]|string[]} orders The order to sort by for each property.
- * @returns {number} Returns the sort order indicator for `object`.
- */function compareMultiple(object,other,orders){var index=-1,objCriteria=object.criteria,othCriteria=other.criteria,length=objCriteria.length,ordersLength=orders.length;while(++index<length){var result=compareAscending(objCriteria[index],othCriteria[index]);if(result){if(index>=ordersLength){return result;}var order=orders[index];return result*(order=='desc'?-1:1);}}// Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications
- // that causes it, under certain circumstances, to provide the same value for
- // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247
- // for more details.
- //
- // This also ensures a stable sort in V8 and other engines.
- // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.
- return object.index-other.index;}/**
- * Creates an array that is the composition of partially applied arguments,
- * placeholders, and provided arguments into a single array of arguments.
- *
- * @private
- * @param {Array} args The provided arguments.
- * @param {Array} partials The arguments to prepend to those provided.
- * @param {Array} holders The `partials` placeholder indexes.
- * @params {boolean} [isCurried] Specify composing for a curried function.
- * @returns {Array} Returns the new array of composed arguments.
- */function composeArgs(args,partials,holders,isCurried){var argsIndex=-1,argsLength=args.length,holdersLength=holders.length,leftIndex=-1,leftLength=partials.length,rangeLength=nativeMax(argsLength-holdersLength,0),result=Array(leftLength+rangeLength),isUncurried=!isCurried;while(++leftIndex<leftLength){result[leftIndex]=partials[leftIndex];}while(++argsIndex<holdersLength){if(isUncurried||argsIndex<argsLength){result[holders[argsIndex]]=args[argsIndex];}}while(rangeLength--){result[leftIndex++]=args[argsIndex++];}return result;}/**
- * This function is like `composeArgs` except that the arguments composition
- * is tailored for `_.partialRight`.
- *
- * @private
- * @param {Array} args The provided arguments.
- * @param {Array} partials The arguments to append to those provided.
- * @param {Array} holders The `partials` placeholder indexes.
- * @params {boolean} [isCurried] Specify composing for a curried function.
- * @returns {Array} Returns the new array of composed arguments.
- */function composeArgsRight(args,partials,holders,isCurried){var argsIndex=-1,argsLength=args.length,holdersIndex=-1,holdersLength=holders.length,rightIndex=-1,rightLength=partials.length,rangeLength=nativeMax(argsLength-holdersLength,0),result=Array(rangeLength+rightLength),isUncurried=!isCurried;while(++argsIndex<rangeLength){result[argsIndex]=args[argsIndex];}var offset=argsIndex;while(++rightIndex<rightLength){result[offset+rightIndex]=partials[rightIndex];}while(++holdersIndex<holdersLength){if(isUncurried||argsIndex<argsLength){result[offset+holders[holdersIndex]]=args[argsIndex++];}}return result;}/**
- * Copies the values of `source` to `array`.
- *
- * @private
- * @param {Array} source The array to copy values from.
- * @param {Array} [array=[]] The array to copy values to.
- * @returns {Array} Returns `array`.
- */function copyArray(source,array){var index=-1,length=source.length;array||(array=Array(length));while(++index<length){array[index]=source[index];}return array;}/**
- * Copies properties of `source` to `object`.
- *
- * @private
- * @param {Object} source The object to copy properties from.
- * @param {Array} props The property identifiers to copy.
- * @param {Object} [object={}] The object to copy properties to.
- * @param {Function} [customizer] The function to customize copied values.
- * @returns {Object} Returns `object`.
- */function copyObject(source,props,object,customizer){var isNew=!object;object||(object={});var index=-1,length=props.length;while(++index<length){var key=props[index];var newValue=customizer?customizer(object[key],source[key],key,object,source):undefined;if(newValue===undefined){newValue=source[key];}if(isNew){baseAssignValue(object,key,newValue);}else{assignValue(object,key,newValue);}}return object;}/**
- * Copies own symbols of `source` to `object`.
- *
- * @private
- * @param {Object} source The object to copy symbols from.
- * @param {Object} [object={}] The object to copy symbols to.
- * @returns {Object} Returns `object`.
- */function copySymbols(source,object){return copyObject(source,getSymbols(source),object);}/**
- * Copies own and inherited symbols of `source` to `object`.
- *
- * @private
- * @param {Object} source The object to copy symbols from.
- * @param {Object} [object={}] The object to copy symbols to.
- * @returns {Object} Returns `object`.
- */function copySymbolsIn(source,object){return copyObject(source,getSymbolsIn(source),object);}/**
- * Creates a function like `_.groupBy`.
- *
- * @private
- * @param {Function} setter The function to set accumulator values.
- * @param {Function} [initializer] The accumulator object initializer.
- * @returns {Function} Returns the new aggregator function.
- */function createAggregator(setter,initializer){return function(collection,iteratee){var func=isArray(collection)?arrayAggregator:baseAggregator,accumulator=initializer?initializer():{};return func(collection,setter,getIteratee(iteratee,2),accumulator);};}/**
- * Creates a function like `_.assign`.
- *
- * @private
- * @param {Function} assigner The function to assign values.
- * @returns {Function} Returns the new assigner function.
- */function createAssigner(assigner){return baseRest(function(object,sources){var index=-1,length=sources.length,customizer=length>1?sources[length-1]:undefined,guard=length>2?sources[2]:undefined;customizer=assigner.length>3&&typeof customizer==='function'?(length--,customizer):undefined;if(guard&&isIterateeCall(sources[0],sources[1],guard)){customizer=length<3?undefined:customizer;length=1;}object=Object(object);while(++index<length){var source=sources[index];if(source){assigner(object,source,index,customizer);}}return object;});}/**
- * Creates a `baseEach` or `baseEachRight` function.
- *
- * @private
- * @param {Function} eachFunc The function to iterate over a collection.
- * @param {boolean} [fromRight] Specify iterating from right to left.
- * @returns {Function} Returns the new base function.
- */function createBaseEach(eachFunc,fromRight){return function(collection,iteratee){if(collection==null){return collection;}if(!isArrayLike(collection)){return eachFunc(collection,iteratee);}var length=collection.length,index=fromRight?length:-1,iterable=Object(collection);while(fromRight?index--:++index<length){if(iteratee(iterable[index],index,iterable)===false){break;}}return collection;};}/**
- * Creates a base function for methods like `_.forIn` and `_.forOwn`.
- *
- * @private
- * @param {boolean} [fromRight] Specify iterating from right to left.
- * @returns {Function} Returns the new base function.
- */function createBaseFor(fromRight){return function(object,iteratee,keysFunc){var index=-1,iterable=Object(object),props=keysFunc(object),length=props.length;while(length--){var key=props[fromRight?length:++index];if(iteratee(iterable[key],key,iterable)===false){break;}}return object;};}/**
- * Creates a function that wraps `func` to invoke it with the optional `this`
- * binding of `thisArg`.
- *
- * @private
- * @param {Function} func The function to wrap.
- * @param {number} bitmask The bitmask flags. See `createWrap` for more details.
- * @param {*} [thisArg] The `this` binding of `func`.
- * @returns {Function} Returns the new wrapped function.
- */function createBind(func,bitmask,thisArg){var isBind=bitmask&WRAP_BIND_FLAG,Ctor=createCtor(func);function wrapper(){var fn=this&&this!==root&&this instanceof wrapper?Ctor:func;return fn.apply(isBind?thisArg:this,arguments);}return wrapper;}/**
- * Creates a function like `_.lowerFirst`.
- *
- * @private
- * @param {string} methodName The name of the `String` case method to use.
- * @returns {Function} Returns the new case function.
- */function createCaseFirst(methodName){return function(string){string=toString(string);var strSymbols=hasUnicode(string)?stringToArray(string):undefined;var chr=strSymbols?strSymbols[0]:string.charAt(0);var trailing=strSymbols?castSlice(strSymbols,1).join(''):string.slice(1);return chr[methodName]()+trailing;};}/**
- * Creates a function like `_.camelCase`.
- *
- * @private
- * @param {Function} callback The function to combine each word.
- * @returns {Function} Returns the new compounder function.
- */function createCompounder(callback){return function(string){return arrayReduce(words(deburr(string).replace(reApos,'')),callback,'');};}/**
- * Creates a function that produces an instance of `Ctor` regardless of
- * whether it was invoked as part of a `new` expression or by `call` or `apply`.
- *
- * @private
- * @param {Function} Ctor The constructor to wrap.
- * @returns {Function} Returns the new wrapped function.
- */function createCtor(Ctor){return function(){// Use a `switch` statement to work with class constructors. See
- // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist
- // for more details.
- var args=arguments;switch(args.length){case 0:return new Ctor();case 1:return new Ctor(args[0]);case 2:return new Ctor(args[0],args[1]);case 3:return new Ctor(args[0],args[1],args[2]);case 4:return new Ctor(args[0],args[1],args[2],args[3]);case 5:return new Ctor(args[0],args[1],args[2],args[3],args[4]);case 6:return new Ctor(args[0],args[1],args[2],args[3],args[4],args[5]);case 7:return new Ctor(args[0],args[1],args[2],args[3],args[4],args[5],args[6]);}var thisBinding=baseCreate(Ctor.prototype),result=Ctor.apply(thisBinding,args);// Mimic the constructor's `return` behavior.
- // See https://es5.github.io/#x13.2.2 for more details.
- return isObject(result)?result:thisBinding;};}/**
- * Creates a function that wraps `func` to enable currying.
- *
- * @private
- * @param {Function} func The function to wrap.
- * @param {number} bitmask The bitmask flags. See `createWrap` for more details.
- * @param {number} arity The arity of `func`.
- * @returns {Function} Returns the new wrapped function.
- */function createCurry(func,bitmask,arity){var Ctor=createCtor(func);function wrapper(){var length=arguments.length,args=Array(length),index=length,placeholder=getHolder(wrapper);while(index--){args[index]=arguments[index];}var holders=length<3&&args[0]!==placeholder&&args[length-1]!==placeholder?[]:replaceHolders(args,placeholder);length-=holders.length;if(length<arity){return createRecurry(func,bitmask,createHybrid,wrapper.placeholder,undefined,args,holders,undefined,undefined,arity-length);}var fn=this&&this!==root&&this instanceof wrapper?Ctor:func;return apply(fn,this,args);}return wrapper;}/**
- * Creates a `_.find` or `_.findLast` function.
- *
- * @private
- * @param {Function} findIndexFunc The function to find the collection index.
- * @returns {Function} Returns the new find function.
- */function createFind(findIndexFunc){return function(collection,predicate,fromIndex){var iterable=Object(collection);if(!isArrayLike(collection)){var iteratee=getIteratee(predicate,3);collection=keys(collection);predicate=function predicate(key){return iteratee(iterable[key],key,iterable);};}var index=findIndexFunc(collection,predicate,fromIndex);return index>-1?iterable[iteratee?collection[index]:index]:undefined;};}/**
- * Creates a `_.flow` or `_.flowRight` function.
- *
- * @private
- * @param {boolean} [fromRight] Specify iterating from right to left.
- * @returns {Function} Returns the new flow function.
- */function createFlow(fromRight){return flatRest(function(funcs){var length=funcs.length,index=length,prereq=LodashWrapper.prototype.thru;if(fromRight){funcs.reverse();}while(index--){var func=funcs[index];if(typeof func!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}if(prereq&&!wrapper&&getFuncName(func)=='wrapper'){var wrapper=new LodashWrapper([],true);}}index=wrapper?index:length;while(++index<length){func=funcs[index];var funcName=getFuncName(func),data=funcName=='wrapper'?getData(func):undefined;if(data&&isLaziable(data[0])&&data[1]==(WRAP_ARY_FLAG|WRAP_CURRY_FLAG|WRAP_PARTIAL_FLAG|WRAP_REARG_FLAG)&&!data[4].length&&data[9]==1){wrapper=wrapper[getFuncName(data[0])].apply(wrapper,data[3]);}else{wrapper=func.length==1&&isLaziable(func)?wrapper[funcName]():wrapper.thru(func);}}return function(){var args=arguments,value=args[0];if(wrapper&&args.length==1&&isArray(value)){return wrapper.plant(value).value();}var index=0,result=length?funcs[index].apply(this,args):value;while(++index<length){result=funcs[index].call(this,result);}return result;};});}/**
- * Creates a function that wraps `func` to invoke it with optional `this`
- * binding of `thisArg`, partial application, and currying.
- *
- * @private
- * @param {Function|string} func The function or method name to wrap.
- * @param {number} bitmask The bitmask flags. See `createWrap` for more details.
- * @param {*} [thisArg] The `this` binding of `func`.
- * @param {Array} [partials] The arguments to prepend to those provided to
- * the new function.
- * @param {Array} [holders] The `partials` placeholder indexes.
- * @param {Array} [partialsRight] The arguments to append to those provided
- * to the new function.
- * @param {Array} [holdersRight] The `partialsRight` placeholder indexes.
- * @param {Array} [argPos] The argument positions of the new function.
- * @param {number} [ary] The arity cap of `func`.
- * @param {number} [arity] The arity of `func`.
- * @returns {Function} Returns the new wrapped function.
- */function createHybrid(func,bitmask,thisArg,partials,holders,partialsRight,holdersRight,argPos,ary,arity){var isAry=bitmask&WRAP_ARY_FLAG,isBind=bitmask&WRAP_BIND_FLAG,isBindKey=bitmask&WRAP_BIND_KEY_FLAG,isCurried=bitmask&(WRAP_CURRY_FLAG|WRAP_CURRY_RIGHT_FLAG),isFlip=bitmask&WRAP_FLIP_FLAG,Ctor=isBindKey?undefined:createCtor(func);function wrapper(){var length=arguments.length,args=Array(length),index=length;while(index--){args[index]=arguments[index];}if(isCurried){var placeholder=getHolder(wrapper),holdersCount=countHolders(args,placeholder);}if(partials){args=composeArgs(args,partials,holders,isCurried);}if(partialsRight){args=composeArgsRight(args,partialsRight,holdersRight,isCurried);}length-=holdersCount;if(isCurried&&length<arity){var newHolders=replaceHolders(args,placeholder);return createRecurry(func,bitmask,createHybrid,wrapper.placeholder,thisArg,args,newHolders,argPos,ary,arity-length);}var thisBinding=isBind?thisArg:this,fn=isBindKey?thisBinding[func]:func;length=args.length;if(argPos){args=reorder(args,argPos);}else if(isFlip&&length>1){args.reverse();}if(isAry&&ary<length){args.length=ary;}if(this&&this!==root&&this instanceof wrapper){fn=Ctor||createCtor(fn);}return fn.apply(thisBinding,args);}return wrapper;}/**
- * Creates a function like `_.invertBy`.
- *
- * @private
- * @param {Function} setter The function to set accumulator values.
- * @param {Function} toIteratee The function to resolve iteratees.
- * @returns {Function} Returns the new inverter function.
- */function createInverter(setter,toIteratee){return function(object,iteratee){return baseInverter(object,setter,toIteratee(iteratee),{});};}/**
- * Creates a function that performs a mathematical operation on two values.
- *
- * @private
- * @param {Function} operator The function to perform the operation.
- * @param {number} [defaultValue] The value used for `undefined` arguments.
- * @returns {Function} Returns the new mathematical operation function.
- */function createMathOperation(operator,defaultValue){return function(value,other){var result;if(value===undefined&&other===undefined){return defaultValue;}if(value!==undefined){result=value;}if(other!==undefined){if(result===undefined){return other;}if(typeof value==='string'||typeof other==='string'){value=baseToString(value);other=baseToString(other);}else{value=baseToNumber(value);other=baseToNumber(other);}result=operator(value,other);}return result;};}/**
- * Creates a function like `_.over`.
- *
- * @private
- * @param {Function} arrayFunc The function to iterate over iteratees.
- * @returns {Function} Returns the new over function.
- */function createOver(arrayFunc){return flatRest(function(iteratees){iteratees=arrayMap(iteratees,baseUnary(getIteratee()));return baseRest(function(args){var thisArg=this;return arrayFunc(iteratees,function(iteratee){return apply(iteratee,thisArg,args);});});});}/**
- * Creates the padding for `string` based on `length`. The `chars` string
- * is truncated if the number of characters exceeds `length`.
- *
- * @private
- * @param {number} length The padding length.
- * @param {string} [chars=' '] The string used as padding.
- * @returns {string} Returns the padding for `string`.
- */function createPadding(length,chars){chars=chars===undefined?' ':baseToString(chars);var charsLength=chars.length;if(charsLength<2){return charsLength?baseRepeat(chars,length):chars;}var result=baseRepeat(chars,nativeCeil(length/stringSize(chars)));return hasUnicode(chars)?castSlice(stringToArray(result),0,length).join(''):result.slice(0,length);}/**
- * Creates a function that wraps `func` to invoke it with the `this` binding
- * of `thisArg` and `partials` prepended to the arguments it receives.
- *
- * @private
- * @param {Function} func The function to wrap.
- * @param {number} bitmask The bitmask flags. See `createWrap` for more details.
- * @param {*} thisArg The `this` binding of `func`.
- * @param {Array} partials The arguments to prepend to those provided to
- * the new function.
- * @returns {Function} Returns the new wrapped function.
- */function createPartial(func,bitmask,thisArg,partials){var isBind=bitmask&WRAP_BIND_FLAG,Ctor=createCtor(func);function wrapper(){var argsIndex=-1,argsLength=arguments.length,leftIndex=-1,leftLength=partials.length,args=Array(leftLength+argsLength),fn=this&&this!==root&&this instanceof wrapper?Ctor:func;while(++leftIndex<leftLength){args[leftIndex]=partials[leftIndex];}while(argsLength--){args[leftIndex++]=arguments[++argsIndex];}return apply(fn,isBind?thisArg:this,args);}return wrapper;}/**
- * Creates a `_.range` or `_.rangeRight` function.
- *
- * @private
- * @param {boolean} [fromRight] Specify iterating from right to left.
- * @returns {Function} Returns the new range function.
- */function createRange(fromRight){return function(start,end,step){if(step&&typeof step!=='number'&&isIterateeCall(start,end,step)){end=step=undefined;}// Ensure the sign of `-0` is preserved.
- start=toFinite(start);if(end===undefined){end=start;start=0;}else{end=toFinite(end);}step=step===undefined?start<end?1:-1:toFinite(step);return baseRange(start,end,step,fromRight);};}/**
- * Creates a function that performs a relational operation on two values.
- *
- * @private
- * @param {Function} operator The function to perform the operation.
- * @returns {Function} Returns the new relational operation function.
- */function createRelationalOperation(operator){return function(value,other){if(!(typeof value==='string'&&typeof other==='string')){value=toNumber(value);other=toNumber(other);}return operator(value,other);};}/**
- * Creates a function that wraps `func` to continue currying.
- *
- * @private
- * @param {Function} func The function to wrap.
- * @param {number} bitmask The bitmask flags. See `createWrap` for more details.
- * @param {Function} wrapFunc The function to create the `func` wrapper.
- * @param {*} placeholder The placeholder value.
- * @param {*} [thisArg] The `this` binding of `func`.
- * @param {Array} [partials] The arguments to prepend to those provided to
- * the new function.
- * @param {Array} [holders] The `partials` placeholder indexes.
- * @param {Array} [argPos] The argument positions of the new function.
- * @param {number} [ary] The arity cap of `func`.
- * @param {number} [arity] The arity of `func`.
- * @returns {Function} Returns the new wrapped function.
- */function createRecurry(func,bitmask,wrapFunc,placeholder,thisArg,partials,holders,argPos,ary,arity){var isCurry=bitmask&WRAP_CURRY_FLAG,newHolders=isCurry?holders:undefined,newHoldersRight=isCurry?undefined:holders,newPartials=isCurry?partials:undefined,newPartialsRight=isCurry?undefined:partials;bitmask|=isCurry?WRAP_PARTIAL_FLAG:WRAP_PARTIAL_RIGHT_FLAG;bitmask&=~(isCurry?WRAP_PARTIAL_RIGHT_FLAG:WRAP_PARTIAL_FLAG);if(!(bitmask&WRAP_CURRY_BOUND_FLAG)){bitmask&=~(WRAP_BIND_FLAG|WRAP_BIND_KEY_FLAG);}var newData=[func,bitmask,thisArg,newPartials,newHolders,newPartialsRight,newHoldersRight,argPos,ary,arity];var result=wrapFunc.apply(undefined,newData);if(isLaziable(func)){setData(result,newData);}result.placeholder=placeholder;return setWrapToString(result,func,bitmask);}/**
- * Creates a function like `_.round`.
- *
- * @private
- * @param {string} methodName The name of the `Math` method to use when rounding.
- * @returns {Function} Returns the new round function.
- */function createRound(methodName){var func=Math[methodName];return function(number,precision){number=toNumber(number);precision=precision==null?0:nativeMin(toInteger(precision),292);if(precision){// Shift with exponential notation to avoid floating-point issues.
- // See [MDN](https://mdn.io/round#Examples) for more details.
- var pair=(toString(number)+'e').split('e'),value=func(pair[0]+'e'+(+pair[1]+precision));pair=(toString(value)+'e').split('e');return+(pair[0]+'e'+(+pair[1]-precision));}return func(number);};}/**
- * Creates a set object of `values`.
- *
- * @private
- * @param {Array} values The values to add to the set.
- * @returns {Object} Returns the new set.
- */var createSet=!(Set&&1/setToArray(new Set([,-0]))[1]==INFINITY)?noop:function(values){return new Set(values);};/**
- * Creates a `_.toPairs` or `_.toPairsIn` function.
- *
- * @private
- * @param {Function} keysFunc The function to get the keys of a given object.
- * @returns {Function} Returns the new pairs function.
- */function createToPairs(keysFunc){return function(object){var tag=getTag(object);if(tag==mapTag){return mapToArray(object);}if(tag==setTag){return setToPairs(object);}return baseToPairs(object,keysFunc(object));};}/**
- * Creates a function that either curries or invokes `func` with optional
- * `this` binding and partially applied arguments.
- *
- * @private
- * @param {Function|string} func The function or method name to wrap.
- * @param {number} bitmask The bitmask flags.
- * 1 - `_.bind`
- * 2 - `_.bindKey`
- * 4 - `_.curry` or `_.curryRight` of a bound function
- * 8 - `_.curry`
- * 16 - `_.curryRight`
- * 32 - `_.partial`
- * 64 - `_.partialRight`
- * 128 - `_.rearg`
- * 256 - `_.ary`
- * 512 - `_.flip`
- * @param {*} [thisArg] The `this` binding of `func`.
- * @param {Array} [partials] The arguments to be partially applied.
- * @param {Array} [holders] The `partials` placeholder indexes.
- * @param {Array} [argPos] The argument positions of the new function.
- * @param {number} [ary] The arity cap of `func`.
- * @param {number} [arity] The arity of `func`.
- * @returns {Function} Returns the new wrapped function.
- */function createWrap(func,bitmask,thisArg,partials,holders,argPos,ary,arity){var isBindKey=bitmask&WRAP_BIND_KEY_FLAG;if(!isBindKey&&typeof func!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}var length=partials?partials.length:0;if(!length){bitmask&=~(WRAP_PARTIAL_FLAG|WRAP_PARTIAL_RIGHT_FLAG);partials=holders=undefined;}ary=ary===undefined?ary:nativeMax(toInteger(ary),0);arity=arity===undefined?arity:toInteger(arity);length-=holders?holders.length:0;if(bitmask&WRAP_PARTIAL_RIGHT_FLAG){var partialsRight=partials,holdersRight=holders;partials=holders=undefined;}var data=isBindKey?undefined:getData(func);var newData=[func,bitmask,thisArg,partials,holders,partialsRight,holdersRight,argPos,ary,arity];if(data){mergeData(newData,data);}func=newData[0];bitmask=newData[1];thisArg=newData[2];partials=newData[3];holders=newData[4];arity=newData[9]=newData[9]===undefined?isBindKey?0:func.length:nativeMax(newData[9]-length,0);if(!arity&&bitmask&(WRAP_CURRY_FLAG|WRAP_CURRY_RIGHT_FLAG)){bitmask&=~(WRAP_CURRY_FLAG|WRAP_CURRY_RIGHT_FLAG);}if(!bitmask||bitmask==WRAP_BIND_FLAG){var result=createBind(func,bitmask,thisArg);}else if(bitmask==WRAP_CURRY_FLAG||bitmask==WRAP_CURRY_RIGHT_FLAG){result=createCurry(func,bitmask,arity);}else if((bitmask==WRAP_PARTIAL_FLAG||bitmask==(WRAP_BIND_FLAG|WRAP_PARTIAL_FLAG))&&!holders.length){result=createPartial(func,bitmask,thisArg,partials);}else{result=createHybrid.apply(undefined,newData);}var setter=data?baseSetData:setData;return setWrapToString(setter(result,newData),func,bitmask);}/**
- * Used by `_.defaults` to customize its `_.assignIn` use to assign properties
- * of source objects to the destination object for all destination properties
- * that resolve to `undefined`.
- *
- * @private
- * @param {*} objValue The destination value.
- * @param {*} srcValue The source value.
- * @param {string} key The key of the property to assign.
- * @param {Object} object The parent object of `objValue`.
- * @returns {*} Returns the value to assign.
- */function customDefaultsAssignIn(objValue,srcValue,key,object){if(objValue===undefined||eq(objValue,objectProto[key])&&!hasOwnProperty.call(object,key)){return srcValue;}return objValue;}/**
- * Used by `_.defaultsDeep` to customize its `_.merge` use to merge source
- * objects into destination objects that are passed thru.
- *
- * @private
- * @param {*} objValue The destination value.
- * @param {*} srcValue The source value.
- * @param {string} key The key of the property to merge.
- * @param {Object} object The parent object of `objValue`.
- * @param {Object} source The parent object of `srcValue`.
- * @param {Object} [stack] Tracks traversed source values and their merged
- * counterparts.
- * @returns {*} Returns the value to assign.
- */function customDefaultsMerge(objValue,srcValue,key,object,source,stack){if(isObject(objValue)&&isObject(srcValue)){// Recursively merge objects and arrays (susceptible to call stack limits).
- stack.set(srcValue,objValue);baseMerge(objValue,srcValue,undefined,customDefaultsMerge,stack);stack['delete'](srcValue);}return objValue;}/**
- * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain
- * objects.
- *
- * @private
- * @param {*} value The value to inspect.
- * @param {string} key The key of the property to inspect.
- * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`.
- */function customOmitClone(value){return isPlainObject(value)?undefined:value;}/**
- * A specialized version of `baseIsEqualDeep` for arrays with support for
- * partial deep comparisons.
- *
- * @private
- * @param {Array} array The array to compare.
- * @param {Array} other The other array to compare.
- * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.
- * @param {Function} customizer The function to customize comparisons.
- * @param {Function} equalFunc The function to determine equivalents of values.
- * @param {Object} stack Tracks traversed `array` and `other` objects.
- * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.
- */function equalArrays(array,other,bitmask,customizer,equalFunc,stack){var isPartial=bitmask&COMPARE_PARTIAL_FLAG,arrLength=array.length,othLength=other.length;if(arrLength!=othLength&&!(isPartial&&othLength>arrLength)){return false;}// Assume cyclic values are equal.
- var stacked=stack.get(array);if(stacked&&stack.get(other)){return stacked==other;}var index=-1,result=true,seen=bitmask&COMPARE_UNORDERED_FLAG?new SetCache():undefined;stack.set(array,other);stack.set(other,array);// Ignore non-index properties.
- while(++index<arrLength){var arrValue=array[index],othValue=other[index];if(customizer){var compared=isPartial?customizer(othValue,arrValue,index,other,array,stack):customizer(arrValue,othValue,index,array,other,stack);}if(compared!==undefined){if(compared){continue;}result=false;break;}// Recursively compare arrays (susceptible to call stack limits).
- if(seen){if(!arraySome(other,function(othValue,othIndex){if(!cacheHas(seen,othIndex)&&(arrValue===othValue||equalFunc(arrValue,othValue,bitmask,customizer,stack))){return seen.push(othIndex);}})){result=false;break;}}else if(!(arrValue===othValue||equalFunc(arrValue,othValue,bitmask,customizer,stack))){result=false;break;}}stack['delete'](array);stack['delete'](other);return result;}/**
- * A specialized version of `baseIsEqualDeep` for comparing objects of
- * the same `toStringTag`.
- *
- * **Note:** This function only supports comparing values with tags of
- * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.
- *
- * @private
- * @param {Object} object The object to compare.
- * @param {Object} other The other object to compare.
- * @param {string} tag The `toStringTag` of the objects to compare.
- * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.
- * @param {Function} customizer The function to customize comparisons.
- * @param {Function} equalFunc The function to determine equivalents of values.
- * @param {Object} stack Tracks traversed `object` and `other` objects.
- * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.
- */function equalByTag(object,other,tag,bitmask,customizer,equalFunc,stack){switch(tag){case dataViewTag:if(object.byteLength!=other.byteLength||object.byteOffset!=other.byteOffset){return false;}object=object.buffer;other=other.buffer;case arrayBufferTag:if(object.byteLength!=other.byteLength||!equalFunc(new Uint8Array(object),new Uint8Array(other))){return false;}return true;case boolTag:case dateTag:case numberTag:// Coerce booleans to `1` or `0` and dates to milliseconds.
- // Invalid dates are coerced to `NaN`.
- return eq(+object,+other);case errorTag:return object.name==other.name&&object.message==other.message;case regexpTag:case stringTag:// Coerce regexes to strings and treat strings, primitives and objects,
- // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring
- // for more details.
- return object==other+'';case mapTag:var convert=mapToArray;case setTag:var isPartial=bitmask&COMPARE_PARTIAL_FLAG;convert||(convert=setToArray);if(object.size!=other.size&&!isPartial){return false;}// Assume cyclic values are equal.
- var stacked=stack.get(object);if(stacked){return stacked==other;}bitmask|=COMPARE_UNORDERED_FLAG;// Recursively compare objects (susceptible to call stack limits).
- stack.set(object,other);var result=equalArrays(convert(object),convert(other),bitmask,customizer,equalFunc,stack);stack['delete'](object);return result;case symbolTag:if(symbolValueOf){return symbolValueOf.call(object)==symbolValueOf.call(other);}}return false;}/**
- * A specialized version of `baseIsEqualDeep` for objects with support for
- * partial deep comparisons.
- *
- * @private
- * @param {Object} object The object to compare.
- * @param {Object} other The other object to compare.
- * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.
- * @param {Function} customizer The function to customize comparisons.
- * @param {Function} equalFunc The function to determine equivalents of values.
- * @param {Object} stack Tracks traversed `object` and `other` objects.
- * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.
- */function equalObjects(object,other,bitmask,customizer,equalFunc,stack){var isPartial=bitmask&COMPARE_PARTIAL_FLAG,objProps=getAllKeys(object),objLength=objProps.length,othProps=getAllKeys(other),othLength=othProps.length;if(objLength!=othLength&&!isPartial){return false;}var index=objLength;while(index--){var key=objProps[index];if(!(isPartial?key in other:hasOwnProperty.call(other,key))){return false;}}// Assume cyclic values are equal.
- var stacked=stack.get(object);if(stacked&&stack.get(other)){return stacked==other;}var result=true;stack.set(object,other);stack.set(other,object);var skipCtor=isPartial;while(++index<objLength){key=objProps[index];var objValue=object[key],othValue=other[key];if(customizer){var compared=isPartial?customizer(othValue,objValue,key,other,object,stack):customizer(objValue,othValue,key,object,other,stack);}// Recursively compare objects (susceptible to call stack limits).
- if(!(compared===undefined?objValue===othValue||equalFunc(objValue,othValue,bitmask,customizer,stack):compared)){result=false;break;}skipCtor||(skipCtor=key=='constructor');}if(result&&!skipCtor){var objCtor=object.constructor,othCtor=other.constructor;// Non `Object` object instances with different constructors are not equal.
- if(objCtor!=othCtor&&'constructor'in object&&'constructor'in other&&!(typeof objCtor==='function'&&objCtor instanceof objCtor&&typeof othCtor==='function'&&othCtor instanceof othCtor)){result=false;}}stack['delete'](object);stack['delete'](other);return result;}/**
- * A specialized version of `baseRest` which flattens the rest array.
- *
- * @private
- * @param {Function} func The function to apply a rest parameter to.
- * @returns {Function} Returns the new function.
- */function flatRest(func){return setToString(overRest(func,undefined,flatten),func+'');}/**
- * Creates an array of own enumerable property names and symbols of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property names and symbols.
- */function getAllKeys(object){return baseGetAllKeys(object,keys,getSymbols);}/**
- * Creates an array of own and inherited enumerable property names and
- * symbols of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property names and symbols.
- */function getAllKeysIn(object){return baseGetAllKeys(object,keysIn,getSymbolsIn);}/**
- * Gets metadata for `func`.
- *
- * @private
- * @param {Function} func The function to query.
- * @returns {*} Returns the metadata for `func`.
- */var getData=!metaMap?noop:function(func){return metaMap.get(func);};/**
- * Gets the name of `func`.
- *
- * @private
- * @param {Function} func The function to query.
- * @returns {string} Returns the function name.
- */function getFuncName(func){var result=func.name+'',array=realNames[result],length=hasOwnProperty.call(realNames,result)?array.length:0;while(length--){var data=array[length],otherFunc=data.func;if(otherFunc==null||otherFunc==func){return data.name;}}return result;}/**
- * Gets the argument placeholder value for `func`.
- *
- * @private
- * @param {Function} func The function to inspect.
- * @returns {*} Returns the placeholder value.
- */function getHolder(func){var object=hasOwnProperty.call(lodash,'placeholder')?lodash:func;return object.placeholder;}/**
- * Gets the appropriate "iteratee" function. If `_.iteratee` is customized,
- * this function returns the custom method, otherwise it returns `baseIteratee`.
- * If arguments are provided, the chosen function is invoked with them and
- * its result is returned.
- *
- * @private
- * @param {*} [value] The value to convert to an iteratee.
- * @param {number} [arity] The arity of the created iteratee.
- * @returns {Function} Returns the chosen function or its result.
- */function getIteratee(){var result=lodash.iteratee||iteratee;result=result===iteratee?baseIteratee:result;return arguments.length?result(arguments[0],arguments[1]):result;}/**
- * Gets the data for `map`.
- *
- * @private
- * @param {Object} map The map to query.
- * @param {string} key The reference key.
- * @returns {*} Returns the map data.
- */function getMapData(map,key){var data=map.__data__;return isKeyable(key)?data[typeof key==='string'?'string':'hash']:data.map;}/**
- * Gets the property names, values, and compare flags of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Array} Returns the match data of `object`.
- */function getMatchData(object){var result=keys(object),length=result.length;while(length--){var key=result[length],value=object[key];result[length]=[key,value,isStrictComparable(value)];}return result;}/**
- * Gets the native function at `key` of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @param {string} key The key of the method to get.
- * @returns {*} Returns the function if it's native, else `undefined`.
- */function getNative(object,key){var value=getValue(object,key);return baseIsNative(value)?value:undefined;}/**
- * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.
- *
- * @private
- * @param {*} value The value to query.
- * @returns {string} Returns the raw `toStringTag`.
- */function getRawTag(value){var isOwn=hasOwnProperty.call(value,symToStringTag),tag=value[symToStringTag];try{value[symToStringTag]=undefined;var unmasked=true;}catch(e){}var result=nativeObjectToString.call(value);if(unmasked){if(isOwn){value[symToStringTag]=tag;}else{delete value[symToStringTag];}}return result;}/**
- * Creates an array of the own enumerable symbols of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of symbols.
- */var getSymbols=!nativeGetSymbols?stubArray:function(object){if(object==null){return[];}object=Object(object);return arrayFilter(nativeGetSymbols(object),function(symbol){return propertyIsEnumerable.call(object,symbol);});};/**
- * Creates an array of the own and inherited enumerable symbols of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of symbols.
- */var getSymbolsIn=!nativeGetSymbols?stubArray:function(object){var result=[];while(object){arrayPush(result,getSymbols(object));object=getPrototype(object);}return result;};/**
- * Gets the `toStringTag` of `value`.
- *
- * @private
- * @param {*} value The value to query.
- * @returns {string} Returns the `toStringTag`.
- */var getTag=baseGetTag;// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.
- if(DataView&&getTag(new DataView(new ArrayBuffer(1)))!=dataViewTag||Map&&getTag(new Map())!=mapTag||Promise&&getTag(Promise.resolve())!=promiseTag||Set&&getTag(new Set())!=setTag||WeakMap&&getTag(new WeakMap())!=weakMapTag){getTag=function getTag(value){var result=baseGetTag(value),Ctor=result==objectTag?value.constructor:undefined,ctorString=Ctor?toSource(Ctor):'';if(ctorString){switch(ctorString){case dataViewCtorString:return dataViewTag;case mapCtorString:return mapTag;case promiseCtorString:return promiseTag;case setCtorString:return setTag;case weakMapCtorString:return weakMapTag;}}return result;};}/**
- * Gets the view, applying any `transforms` to the `start` and `end` positions.
- *
- * @private
- * @param {number} start The start of the view.
- * @param {number} end The end of the view.
- * @param {Array} transforms The transformations to apply to the view.
- * @returns {Object} Returns an object containing the `start` and `end`
- * positions of the view.
- */function getView(start,end,transforms){var index=-1,length=transforms.length;while(++index<length){var data=transforms[index],size=data.size;switch(data.type){case'drop':start+=size;break;case'dropRight':end-=size;break;case'take':end=nativeMin(end,start+size);break;case'takeRight':start=nativeMax(start,end-size);break;}}return{start:start,end:end};}/**
- * Extracts wrapper details from the `source` body comment.
- *
- * @private
- * @param {string} source The source to inspect.
- * @returns {Array} Returns the wrapper details.
- */function getWrapDetails(source){var match=source.match(reWrapDetails);return match?match[1].split(reSplitDetails):[];}/**
- * Checks if `path` exists on `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @param {Array|string} path The path to check.
- * @param {Function} hasFunc The function to check properties.
- * @returns {boolean} Returns `true` if `path` exists, else `false`.
- */function hasPath(object,path,hasFunc){path=castPath(path,object);var index=-1,length=path.length,result=false;while(++index<length){var key=toKey(path[index]);if(!(result=object!=null&&hasFunc(object,key))){break;}object=object[key];}if(result||++index!=length){return result;}length=object==null?0:object.length;return!!length&&isLength(length)&&isIndex(key,length)&&(isArray(object)||isArguments(object));}/**
- * Initializes an array clone.
- *
- * @private
- * @param {Array} array The array to clone.
- * @returns {Array} Returns the initialized clone.
- */function initCloneArray(array){var length=array.length,result=new array.constructor(length);// Add properties assigned by `RegExp#exec`.
- if(length&&typeof array[0]==='string'&&hasOwnProperty.call(array,'index')){result.index=array.index;result.input=array.input;}return result;}/**
- * Initializes an object clone.
- *
- * @private
- * @param {Object} object The object to clone.
- * @returns {Object} Returns the initialized clone.
- */function initCloneObject(object){return typeof object.constructor==='function'&&!isPrototype(object)?baseCreate(getPrototype(object)):{};}/**
- * Initializes an object clone based on its `toStringTag`.
- *
- * **Note:** This function only supports cloning values with tags of
- * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.
- *
- * @private
- * @param {Object} object The object to clone.
- * @param {string} tag The `toStringTag` of the object to clone.
- * @param {boolean} [isDeep] Specify a deep clone.
- * @returns {Object} Returns the initialized clone.
- */function initCloneByTag(object,tag,isDeep){var Ctor=object.constructor;switch(tag){case arrayBufferTag:return cloneArrayBuffer(object);case boolTag:case dateTag:return new Ctor(+object);case dataViewTag:return cloneDataView(object,isDeep);case float32Tag:case float64Tag:case int8Tag:case int16Tag:case int32Tag:case uint8Tag:case uint8ClampedTag:case uint16Tag:case uint32Tag:return cloneTypedArray(object,isDeep);case mapTag:return new Ctor();case numberTag:case stringTag:return new Ctor(object);case regexpTag:return cloneRegExp(object);case setTag:return new Ctor();case symbolTag:return cloneSymbol(object);}}/**
- * Inserts wrapper `details` in a comment at the top of the `source` body.
- *
- * @private
- * @param {string} source The source to modify.
- * @returns {Array} details The details to insert.
- * @returns {string} Returns the modified source.
- */function insertWrapDetails(source,details){var length=details.length;if(!length){return source;}var lastIndex=length-1;details[lastIndex]=(length>1?'& ':'')+details[lastIndex];details=details.join(length>2?', ':' ');return source.replace(reWrapComment,'{\n/* [wrapped with '+details+'] */\n');}/**
- * Checks if `value` is a flattenable `arguments` object or array.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.
- */function isFlattenable(value){return isArray(value)||isArguments(value)||!!(spreadableSymbol&&value&&value[spreadableSymbol]);}/**
- * Checks if `value` is a valid array-like index.
- *
- * @private
- * @param {*} value The value to check.
- * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.
- * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.
- */function isIndex(value,length){var type=typeof value==='undefined'?'undefined':_typeof(value);length=length==null?MAX_SAFE_INTEGER:length;return!!length&&(type=='number'||type!='symbol'&&reIsUint.test(value))&&value>-1&&value%1==0&&value<length;}/**
- * Checks if the given arguments are from an iteratee call.
- *
- * @private
- * @param {*} value The potential iteratee value argument.
- * @param {*} index The potential iteratee index or key argument.
- * @param {*} object The potential iteratee object argument.
- * @returns {boolean} Returns `true` if the arguments are from an iteratee call,
- * else `false`.
- */function isIterateeCall(value,index,object){if(!isObject(object)){return false;}var type=typeof index==='undefined'?'undefined':_typeof(index);if(type=='number'?isArrayLike(object)&&isIndex(index,object.length):type=='string'&&index in object){return eq(object[index],value);}return false;}/**
- * Checks if `value` is a property name and not a property path.
- *
- * @private
- * @param {*} value The value to check.
- * @param {Object} [object] The object to query keys on.
- * @returns {boolean} Returns `true` if `value` is a property name, else `false`.
- */function isKey(value,object){if(isArray(value)){return false;}var type=typeof value==='undefined'?'undefined':_typeof(value);if(type=='number'||type=='symbol'||type=='boolean'||value==null||isSymbol(value)){return true;}return reIsPlainProp.test(value)||!reIsDeepProp.test(value)||object!=null&&value in Object(object);}/**
- * Checks if `value` is suitable for use as unique object key.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is suitable, else `false`.
- */function isKeyable(value){var type=typeof value==='undefined'?'undefined':_typeof(value);return type=='string'||type=='number'||type=='symbol'||type=='boolean'?value!=='__proto__':value===null;}/**
- * Checks if `func` has a lazy counterpart.
- *
- * @private
- * @param {Function} func The function to check.
- * @returns {boolean} Returns `true` if `func` has a lazy counterpart,
- * else `false`.
- */function isLaziable(func){var funcName=getFuncName(func),other=lodash[funcName];if(typeof other!=='function'||!(funcName in LazyWrapper.prototype)){return false;}if(func===other){return true;}var data=getData(other);return!!data&&func===data[0];}/**
- * Checks if `func` has its source masked.
- *
- * @private
- * @param {Function} func The function to check.
- * @returns {boolean} Returns `true` if `func` is masked, else `false`.
- */function isMasked(func){return!!maskSrcKey&&maskSrcKey in func;}/**
- * Checks if `func` is capable of being masked.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `func` is maskable, else `false`.
- */var isMaskable=coreJsData?isFunction:stubFalse;/**
- * Checks if `value` is likely a prototype object.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.
- */function isPrototype(value){var Ctor=value&&value.constructor,proto=typeof Ctor==='function'&&Ctor.prototype||objectProto;return value===proto;}/**
- * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` if suitable for strict
- * equality comparisons, else `false`.
- */function isStrictComparable(value){return value===value&&!isObject(value);}/**
- * A specialized version of `matchesProperty` for source values suitable
- * for strict equality comparisons, i.e. `===`.
- *
- * @private
- * @param {string} key The key of the property to get.
- * @param {*} srcValue The value to match.
- * @returns {Function} Returns the new spec function.
- */function matchesStrictComparable(key,srcValue){return function(object){if(object==null){return false;}return object[key]===srcValue&&(srcValue!==undefined||key in Object(object));};}/**
- * A specialized version of `_.memoize` which clears the memoized function's
- * cache when it exceeds `MAX_MEMOIZE_SIZE`.
- *
- * @private
- * @param {Function} func The function to have its output memoized.
- * @returns {Function} Returns the new memoized function.
- */function memoizeCapped(func){var result=memoize(func,function(key){if(cache.size===MAX_MEMOIZE_SIZE){cache.clear();}return key;});var cache=result.cache;return result;}/**
- * Merges the function metadata of `source` into `data`.
- *
- * Merging metadata reduces the number of wrappers used to invoke a function.
- * This is possible because methods like `_.bind`, `_.curry`, and `_.partial`
- * may be applied regardless of execution order. Methods like `_.ary` and
- * `_.rearg` modify function arguments, making the order in which they are
- * executed important, preventing the merging of metadata. However, we make
- * an exception for a safe combined case where curried functions have `_.ary`
- * and or `_.rearg` applied.
- *
- * @private
- * @param {Array} data The destination metadata.
- * @param {Array} source The source metadata.
- * @returns {Array} Returns `data`.
- */function mergeData(data,source){var bitmask=data[1],srcBitmask=source[1],newBitmask=bitmask|srcBitmask,isCommon=newBitmask<(WRAP_BIND_FLAG|WRAP_BIND_KEY_FLAG|WRAP_ARY_FLAG);var isCombo=srcBitmask==WRAP_ARY_FLAG&&bitmask==WRAP_CURRY_FLAG||srcBitmask==WRAP_ARY_FLAG&&bitmask==WRAP_REARG_FLAG&&data[7].length<=source[8]||srcBitmask==(WRAP_ARY_FLAG|WRAP_REARG_FLAG)&&source[7].length<=source[8]&&bitmask==WRAP_CURRY_FLAG;// Exit early if metadata can't be merged.
- if(!(isCommon||isCombo)){return data;}// Use source `thisArg` if available.
- if(srcBitmask&WRAP_BIND_FLAG){data[2]=source[2];// Set when currying a bound function.
- newBitmask|=bitmask&WRAP_BIND_FLAG?0:WRAP_CURRY_BOUND_FLAG;}// Compose partial arguments.
- var value=source[3];if(value){var partials=data[3];data[3]=partials?composeArgs(partials,value,source[4]):value;data[4]=partials?replaceHolders(data[3],PLACEHOLDER):source[4];}// Compose partial right arguments.
- value=source[5];if(value){partials=data[5];data[5]=partials?composeArgsRight(partials,value,source[6]):value;data[6]=partials?replaceHolders(data[5],PLACEHOLDER):source[6];}// Use source `argPos` if available.
- value=source[7];if(value){data[7]=value;}// Use source `ary` if it's smaller.
- if(srcBitmask&WRAP_ARY_FLAG){data[8]=data[8]==null?source[8]:nativeMin(data[8],source[8]);}// Use source `arity` if one is not provided.
- if(data[9]==null){data[9]=source[9];}// Use source `func` and merge bitmasks.
- data[0]=source[0];data[1]=newBitmask;return data;}/**
- * This function is like
- * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)
- * except that it includes inherited enumerable properties.
- *
- * @private
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property names.
- */function nativeKeysIn(object){var result=[];if(object!=null){for(var key in Object(object)){result.push(key);}}return result;}/**
- * Converts `value` to a string using `Object.prototype.toString`.
- *
- * @private
- * @param {*} value The value to convert.
- * @returns {string} Returns the converted string.
- */function objectToString(value){return nativeObjectToString.call(value);}/**
- * A specialized version of `baseRest` which transforms the rest array.
- *
- * @private
- * @param {Function} func The function to apply a rest parameter to.
- * @param {number} [start=func.length-1] The start position of the rest parameter.
- * @param {Function} transform The rest array transform.
- * @returns {Function} Returns the new function.
- */function overRest(func,start,transform){start=nativeMax(start===undefined?func.length-1:start,0);return function(){var args=arguments,index=-1,length=nativeMax(args.length-start,0),array=Array(length);while(++index<length){array[index]=args[start+index];}index=-1;var otherArgs=Array(start+1);while(++index<start){otherArgs[index]=args[index];}otherArgs[start]=transform(array);return apply(func,this,otherArgs);};}/**
- * Gets the parent value at `path` of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @param {Array} path The path to get the parent value of.
- * @returns {*} Returns the parent value.
- */function parent(object,path){return path.length<2?object:baseGet(object,baseSlice(path,0,-1));}/**
- * Reorder `array` according to the specified indexes where the element at
- * the first index is assigned as the first element, the element at
- * the second index is assigned as the second element, and so on.
- *
- * @private
- * @param {Array} array The array to reorder.
- * @param {Array} indexes The arranged array indexes.
- * @returns {Array} Returns `array`.
- */function reorder(array,indexes){var arrLength=array.length,length=nativeMin(indexes.length,arrLength),oldArray=copyArray(array);while(length--){var index=indexes[length];array[length]=isIndex(index,arrLength)?oldArray[index]:undefined;}return array;}/**
- * Sets metadata for `func`.
- *
- * **Note:** If this function becomes hot, i.e. is invoked a lot in a short
- * period of time, it will trip its breaker and transition to an identity
- * function to avoid garbage collection pauses in V8. See
- * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070)
- * for more details.
- *
- * @private
- * @param {Function} func The function to associate metadata with.
- * @param {*} data The metadata.
- * @returns {Function} Returns `func`.
- */var setData=shortOut(baseSetData);/**
- * A simple wrapper around the global [`setTimeout`](https://mdn.io/setTimeout).
- *
- * @private
- * @param {Function} func The function to delay.
- * @param {number} wait The number of milliseconds to delay invocation.
- * @returns {number|Object} Returns the timer id or timeout object.
- */var setTimeout=ctxSetTimeout||function(func,wait){return root.setTimeout(func,wait);};/**
- * Sets the `toString` method of `func` to return `string`.
- *
- * @private
- * @param {Function} func The function to modify.
- * @param {Function} string The `toString` result.
- * @returns {Function} Returns `func`.
- */var setToString=shortOut(baseSetToString);/**
- * Sets the `toString` method of `wrapper` to mimic the source of `reference`
- * with wrapper details in a comment at the top of the source body.
- *
- * @private
- * @param {Function} wrapper The function to modify.
- * @param {Function} reference The reference function.
- * @param {number} bitmask The bitmask flags. See `createWrap` for more details.
- * @returns {Function} Returns `wrapper`.
- */function setWrapToString(wrapper,reference,bitmask){var source=reference+'';return setToString(wrapper,insertWrapDetails(source,updateWrapDetails(getWrapDetails(source),bitmask)));}/**
- * Creates a function that'll short out and invoke `identity` instead
- * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`
- * milliseconds.
- *
- * @private
- * @param {Function} func The function to restrict.
- * @returns {Function} Returns the new shortable function.
- */function shortOut(func){var count=0,lastCalled=0;return function(){var stamp=nativeNow(),remaining=HOT_SPAN-(stamp-lastCalled);lastCalled=stamp;if(remaining>0){if(++count>=HOT_COUNT){return arguments[0];}}else{count=0;}return func.apply(undefined,arguments);};}/**
- * A specialized version of `_.shuffle` which mutates and sets the size of `array`.
- *
- * @private
- * @param {Array} array The array to shuffle.
- * @param {number} [size=array.length] The size of `array`.
- * @returns {Array} Returns `array`.
- */function shuffleSelf(array,size){var index=-1,length=array.length,lastIndex=length-1;size=size===undefined?length:size;while(++index<size){var rand=baseRandom(index,lastIndex),value=array[rand];array[rand]=array[index];array[index]=value;}array.length=size;return array;}/**
- * Converts `string` to a property path array.
- *
- * @private
- * @param {string} string The string to convert.
- * @returns {Array} Returns the property path array.
- */var stringToPath=memoizeCapped(function(string){var result=[];if(string.charCodeAt(0)===46/* . */){result.push('');}string.replace(rePropName,function(match,number,quote,subString){result.push(quote?subString.replace(reEscapeChar,'$1'):number||match);});return result;});/**
- * Converts `value` to a string key if it's not a string or symbol.
- *
- * @private
- * @param {*} value The value to inspect.
- * @returns {string|symbol} Returns the key.
- */function toKey(value){if(typeof value==='string'||isSymbol(value)){return value;}var result=value+'';return result=='0'&&1/value==-INFINITY?'-0':result;}/**
- * Converts `func` to its source code.
- *
- * @private
- * @param {Function} func The function to convert.
- * @returns {string} Returns the source code.
- */function toSource(func){if(func!=null){try{return funcToString.call(func);}catch(e){}try{return func+'';}catch(e){}}return'';}/**
- * Updates wrapper `details` based on `bitmask` flags.
- *
- * @private
- * @returns {Array} details The details to modify.
- * @param {number} bitmask The bitmask flags. See `createWrap` for more details.
- * @returns {Array} Returns `details`.
- */function updateWrapDetails(details,bitmask){arrayEach(wrapFlags,function(pair){var value='_.'+pair[0];if(bitmask&pair[1]&&!arrayIncludes(details,value)){details.push(value);}});return details.sort();}/**
- * Creates a clone of `wrapper`.
- *
- * @private
- * @param {Object} wrapper The wrapper to clone.
- * @returns {Object} Returns the cloned wrapper.
- */function wrapperClone(wrapper){if(wrapper instanceof LazyWrapper){return wrapper.clone();}var result=new LodashWrapper(wrapper.__wrapped__,wrapper.__chain__);result.__actions__=copyArray(wrapper.__actions__);result.__index__=wrapper.__index__;result.__values__=wrapper.__values__;return result;}/* ------------------------------------------------------------------------*//**
- * Creates an array of elements split into groups the length of `size`.
- * If `array` can't be split evenly, the final chunk will be the remaining
- * elements.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Array
- * @param {Array} array The array to process.
- * @param {number} [size=1] The length of each chunk
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {Array} Returns the new array of chunks.
- * @example
- *
- * _.chunk(['a', 'b', 'c', 'd'], 2);
- * // => [['a', 'b'], ['c', 'd']]
- *
- * _.chunk(['a', 'b', 'c', 'd'], 3);
- * // => [['a', 'b', 'c'], ['d']]
- */function chunk(array,size,guard){if(guard?isIterateeCall(array,size,guard):size===undefined){size=1;}else{size=nativeMax(toInteger(size),0);}var length=array==null?0:array.length;if(!length||size<1){return[];}var index=0,resIndex=0,result=Array(nativeCeil(length/size));while(index<length){result[resIndex++]=baseSlice(array,index,index+=size);}return result;}/**
- * Creates an array with all falsey values removed. The values `false`, `null`,
- * `0`, `""`, `undefined`, and `NaN` are falsey.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The array to compact.
- * @returns {Array} Returns the new array of filtered values.
- * @example
- *
- * _.compact([0, 1, false, 2, '', 3]);
- * // => [1, 2, 3]
- */function compact(array){var index=-1,length=array==null?0:array.length,resIndex=0,result=[];while(++index<length){var value=array[index];if(value){result[resIndex++]=value;}}return result;}/**
- * Creates a new array concatenating `array` with any additional arrays
- * and/or values.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to concatenate.
- * @param {...*} [values] The values to concatenate.
- * @returns {Array} Returns the new concatenated array.
- * @example
- *
- * var array = [1];
- * var other = _.concat(array, 2, [3], [[4]]);
- *
- * console.log(other);
- * // => [1, 2, 3, [4]]
- *
- * console.log(array);
- * // => [1]
- */function concat(){var length=arguments.length;if(!length){return[];}var args=Array(length-1),array=arguments[0],index=length;while(index--){args[index-1]=arguments[index];}return arrayPush(isArray(array)?copyArray(array):[array],baseFlatten(args,1));}/**
- * Creates an array of `array` values not included in the other given arrays
- * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * for equality comparisons. The order and references of result values are
- * determined by the first array.
- *
- * **Note:** Unlike `_.pullAll`, this method returns a new array.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {...Array} [values] The values to exclude.
- * @returns {Array} Returns the new array of filtered values.
- * @see _.without, _.xor
- * @example
- *
- * _.difference([2, 1], [2, 3]);
- * // => [1]
- */var difference=baseRest(function(array,values){return isArrayLikeObject(array)?baseDifference(array,baseFlatten(values,1,isArrayLikeObject,true)):[];});/**
- * This method is like `_.difference` except that it accepts `iteratee` which
- * is invoked for each element of `array` and `values` to generate the criterion
- * by which they're compared. The order and references of result values are
- * determined by the first array. The iteratee is invoked with one argument:
- * (value).
- *
- * **Note:** Unlike `_.pullAllBy`, this method returns a new array.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {...Array} [values] The values to exclude.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {Array} Returns the new array of filtered values.
- * @example
- *
- * _.differenceBy([2.1, 1.2], [2.3, 3.4], Math.floor);
- * // => [1.2]
- *
- * // The `_.property` iteratee shorthand.
- * _.differenceBy([{ 'x': 2 }, { 'x': 1 }], [{ 'x': 1 }], 'x');
- * // => [{ 'x': 2 }]
- */var differenceBy=baseRest(function(array,values){var iteratee=last(values);if(isArrayLikeObject(iteratee)){iteratee=undefined;}return isArrayLikeObject(array)?baseDifference(array,baseFlatten(values,1,isArrayLikeObject,true),getIteratee(iteratee,2)):[];});/**
- * This method is like `_.difference` except that it accepts `comparator`
- * which is invoked to compare elements of `array` to `values`. The order and
- * references of result values are determined by the first array. The comparator
- * is invoked with two arguments: (arrVal, othVal).
- *
- * **Note:** Unlike `_.pullAllWith`, this method returns a new array.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {...Array} [values] The values to exclude.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns the new array of filtered values.
- * @example
- *
- * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];
- *
- * _.differenceWith(objects, [{ 'x': 1, 'y': 2 }], _.isEqual);
- * // => [{ 'x': 2, 'y': 1 }]
- */var differenceWith=baseRest(function(array,values){var comparator=last(values);if(isArrayLikeObject(comparator)){comparator=undefined;}return isArrayLikeObject(array)?baseDifference(array,baseFlatten(values,1,isArrayLikeObject,true),undefined,comparator):[];});/**
- * Creates a slice of `array` with `n` elements dropped from the beginning.
- *
- * @static
- * @memberOf _
- * @since 0.5.0
- * @category Array
- * @param {Array} array The array to query.
- * @param {number} [n=1] The number of elements to drop.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {Array} Returns the slice of `array`.
- * @example
- *
- * _.drop([1, 2, 3]);
- * // => [2, 3]
- *
- * _.drop([1, 2, 3], 2);
- * // => [3]
- *
- * _.drop([1, 2, 3], 5);
- * // => []
- *
- * _.drop([1, 2, 3], 0);
- * // => [1, 2, 3]
- */function drop(array,n,guard){var length=array==null?0:array.length;if(!length){return[];}n=guard||n===undefined?1:toInteger(n);return baseSlice(array,n<0?0:n,length);}/**
- * Creates a slice of `array` with `n` elements dropped from the end.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Array
- * @param {Array} array The array to query.
- * @param {number} [n=1] The number of elements to drop.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {Array} Returns the slice of `array`.
- * @example
- *
- * _.dropRight([1, 2, 3]);
- * // => [1, 2]
- *
- * _.dropRight([1, 2, 3], 2);
- * // => [1]
- *
- * _.dropRight([1, 2, 3], 5);
- * // => []
- *
- * _.dropRight([1, 2, 3], 0);
- * // => [1, 2, 3]
- */function dropRight(array,n,guard){var length=array==null?0:array.length;if(!length){return[];}n=guard||n===undefined?1:toInteger(n);n=length-n;return baseSlice(array,0,n<0?0:n);}/**
- * Creates a slice of `array` excluding elements dropped from the end.
- * Elements are dropped until `predicate` returns falsey. The predicate is
- * invoked with three arguments: (value, index, array).
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Array
- * @param {Array} array The array to query.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the slice of `array`.
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'active': true },
- * { 'user': 'fred', 'active': false },
- * { 'user': 'pebbles', 'active': false }
- * ];
- *
- * _.dropRightWhile(users, function(o) { return !o.active; });
- * // => objects for ['barney']
- *
- * // The `_.matches` iteratee shorthand.
- * _.dropRightWhile(users, { 'user': 'pebbles', 'active': false });
- * // => objects for ['barney', 'fred']
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.dropRightWhile(users, ['active', false]);
- * // => objects for ['barney']
- *
- * // The `_.property` iteratee shorthand.
- * _.dropRightWhile(users, 'active');
- * // => objects for ['barney', 'fred', 'pebbles']
- */function dropRightWhile(array,predicate){return array&&array.length?baseWhile(array,getIteratee(predicate,3),true,true):[];}/**
- * Creates a slice of `array` excluding elements dropped from the beginning.
- * Elements are dropped until `predicate` returns falsey. The predicate is
- * invoked with three arguments: (value, index, array).
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Array
- * @param {Array} array The array to query.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the slice of `array`.
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'active': false },
- * { 'user': 'fred', 'active': false },
- * { 'user': 'pebbles', 'active': true }
- * ];
- *
- * _.dropWhile(users, function(o) { return !o.active; });
- * // => objects for ['pebbles']
- *
- * // The `_.matches` iteratee shorthand.
- * _.dropWhile(users, { 'user': 'barney', 'active': false });
- * // => objects for ['fred', 'pebbles']
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.dropWhile(users, ['active', false]);
- * // => objects for ['pebbles']
- *
- * // The `_.property` iteratee shorthand.
- * _.dropWhile(users, 'active');
- * // => objects for ['barney', 'fred', 'pebbles']
- */function dropWhile(array,predicate){return array&&array.length?baseWhile(array,getIteratee(predicate,3),true):[];}/**
- * Fills elements of `array` with `value` from `start` up to, but not
- * including, `end`.
- *
- * **Note:** This method mutates `array`.
- *
- * @static
- * @memberOf _
- * @since 3.2.0
- * @category Array
- * @param {Array} array The array to fill.
- * @param {*} value The value to fill `array` with.
- * @param {number} [start=0] The start position.
- * @param {number} [end=array.length] The end position.
- * @returns {Array} Returns `array`.
- * @example
- *
- * var array = [1, 2, 3];
- *
- * _.fill(array, 'a');
- * console.log(array);
- * // => ['a', 'a', 'a']
- *
- * _.fill(Array(3), 2);
- * // => [2, 2, 2]
- *
- * _.fill([4, 6, 8, 10], '*', 1, 3);
- * // => [4, '*', '*', 10]
- */function fill(array,value,start,end){var length=array==null?0:array.length;if(!length){return[];}if(start&&typeof start!=='number'&&isIterateeCall(array,value,start)){start=0;end=length;}return baseFill(array,value,start,end);}/**
- * This method is like `_.find` except that it returns the index of the first
- * element `predicate` returns truthy for instead of the element itself.
- *
- * @static
- * @memberOf _
- * @since 1.1.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @param {number} [fromIndex=0] The index to search from.
- * @returns {number} Returns the index of the found element, else `-1`.
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'active': false },
- * { 'user': 'fred', 'active': false },
- * { 'user': 'pebbles', 'active': true }
- * ];
- *
- * _.findIndex(users, function(o) { return o.user == 'barney'; });
- * // => 0
- *
- * // The `_.matches` iteratee shorthand.
- * _.findIndex(users, { 'user': 'fred', 'active': false });
- * // => 1
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.findIndex(users, ['active', false]);
- * // => 0
- *
- * // The `_.property` iteratee shorthand.
- * _.findIndex(users, 'active');
- * // => 2
- */function findIndex(array,predicate,fromIndex){var length=array==null?0:array.length;if(!length){return-1;}var index=fromIndex==null?0:toInteger(fromIndex);if(index<0){index=nativeMax(length+index,0);}return baseFindIndex(array,getIteratee(predicate,3),index);}/**
- * This method is like `_.findIndex` except that it iterates over elements
- * of `collection` from right to left.
- *
- * @static
- * @memberOf _
- * @since 2.0.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @param {number} [fromIndex=array.length-1] The index to search from.
- * @returns {number} Returns the index of the found element, else `-1`.
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'active': true },
- * { 'user': 'fred', 'active': false },
- * { 'user': 'pebbles', 'active': false }
- * ];
- *
- * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; });
- * // => 2
- *
- * // The `_.matches` iteratee shorthand.
- * _.findLastIndex(users, { 'user': 'barney', 'active': true });
- * // => 0
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.findLastIndex(users, ['active', false]);
- * // => 2
- *
- * // The `_.property` iteratee shorthand.
- * _.findLastIndex(users, 'active');
- * // => 0
- */function findLastIndex(array,predicate,fromIndex){var length=array==null?0:array.length;if(!length){return-1;}var index=length-1;if(fromIndex!==undefined){index=toInteger(fromIndex);index=fromIndex<0?nativeMax(length+index,0):nativeMin(index,length-1);}return baseFindIndex(array,getIteratee(predicate,3),index,true);}/**
- * Flattens `array` a single level deep.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The array to flatten.
- * @returns {Array} Returns the new flattened array.
- * @example
- *
- * _.flatten([1, [2, [3, [4]], 5]]);
- * // => [1, 2, [3, [4]], 5]
- */function flatten(array){var length=array==null?0:array.length;return length?baseFlatten(array,1):[];}/**
- * Recursively flattens `array`.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Array
- * @param {Array} array The array to flatten.
- * @returns {Array} Returns the new flattened array.
- * @example
- *
- * _.flattenDeep([1, [2, [3, [4]], 5]]);
- * // => [1, 2, 3, 4, 5]
- */function flattenDeep(array){var length=array==null?0:array.length;return length?baseFlatten(array,INFINITY):[];}/**
- * Recursively flatten `array` up to `depth` times.
- *
- * @static
- * @memberOf _
- * @since 4.4.0
- * @category Array
- * @param {Array} array The array to flatten.
- * @param {number} [depth=1] The maximum recursion depth.
- * @returns {Array} Returns the new flattened array.
- * @example
- *
- * var array = [1, [2, [3, [4]], 5]];
- *
- * _.flattenDepth(array, 1);
- * // => [1, 2, [3, [4]], 5]
- *
- * _.flattenDepth(array, 2);
- * // => [1, 2, 3, [4], 5]
- */function flattenDepth(array,depth){var length=array==null?0:array.length;if(!length){return[];}depth=depth===undefined?1:toInteger(depth);return baseFlatten(array,depth);}/**
- * The inverse of `_.toPairs`; this method returns an object composed
- * from key-value `pairs`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} pairs The key-value pairs.
- * @returns {Object} Returns the new object.
- * @example
- *
- * _.fromPairs([['a', 1], ['b', 2]]);
- * // => { 'a': 1, 'b': 2 }
- */function fromPairs(pairs){var index=-1,length=pairs==null?0:pairs.length,result={};while(++index<length){var pair=pairs[index];result[pair[0]]=pair[1];}return result;}/**
- * Gets the first element of `array`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @alias first
- * @category Array
- * @param {Array} array The array to query.
- * @returns {*} Returns the first element of `array`.
- * @example
- *
- * _.head([1, 2, 3]);
- * // => 1
- *
- * _.head([]);
- * // => undefined
- */function head(array){return array&&array.length?array[0]:undefined;}/**
- * Gets the index at which the first occurrence of `value` is found in `array`
- * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * for equality comparisons. If `fromIndex` is negative, it's used as the
- * offset from the end of `array`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {*} value The value to search for.
- * @param {number} [fromIndex=0] The index to search from.
- * @returns {number} Returns the index of the matched value, else `-1`.
- * @example
- *
- * _.indexOf([1, 2, 1, 2], 2);
- * // => 1
- *
- * // Search from the `fromIndex`.
- * _.indexOf([1, 2, 1, 2], 2, 2);
- * // => 3
- */function indexOf(array,value,fromIndex){var length=array==null?0:array.length;if(!length){return-1;}var index=fromIndex==null?0:toInteger(fromIndex);if(index<0){index=nativeMax(length+index,0);}return baseIndexOf(array,value,index);}/**
- * Gets all but the last element of `array`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The array to query.
- * @returns {Array} Returns the slice of `array`.
- * @example
- *
- * _.initial([1, 2, 3]);
- * // => [1, 2]
- */function initial(array){var length=array==null?0:array.length;return length?baseSlice(array,0,-1):[];}/**
- * Creates an array of unique values that are included in all given arrays
- * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * for equality comparisons. The order and references of result values are
- * determined by the first array.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {...Array} [arrays] The arrays to inspect.
- * @returns {Array} Returns the new array of intersecting values.
- * @example
- *
- * _.intersection([2, 1], [2, 3]);
- * // => [2]
- */var intersection=baseRest(function(arrays){var mapped=arrayMap(arrays,castArrayLikeObject);return mapped.length&&mapped[0]===arrays[0]?baseIntersection(mapped):[];});/**
- * This method is like `_.intersection` except that it accepts `iteratee`
- * which is invoked for each element of each `arrays` to generate the criterion
- * by which they're compared. The order and references of result values are
- * determined by the first array. The iteratee is invoked with one argument:
- * (value).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {...Array} [arrays] The arrays to inspect.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {Array} Returns the new array of intersecting values.
- * @example
- *
- * _.intersectionBy([2.1, 1.2], [2.3, 3.4], Math.floor);
- * // => [2.1]
- *
- * // The `_.property` iteratee shorthand.
- * _.intersectionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');
- * // => [{ 'x': 1 }]
- */var intersectionBy=baseRest(function(arrays){var iteratee=last(arrays),mapped=arrayMap(arrays,castArrayLikeObject);if(iteratee===last(mapped)){iteratee=undefined;}else{mapped.pop();}return mapped.length&&mapped[0]===arrays[0]?baseIntersection(mapped,getIteratee(iteratee,2)):[];});/**
- * This method is like `_.intersection` except that it accepts `comparator`
- * which is invoked to compare elements of `arrays`. The order and references
- * of result values are determined by the first array. The comparator is
- * invoked with two arguments: (arrVal, othVal).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {...Array} [arrays] The arrays to inspect.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns the new array of intersecting values.
- * @example
- *
- * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];
- * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];
- *
- * _.intersectionWith(objects, others, _.isEqual);
- * // => [{ 'x': 1, 'y': 2 }]
- */var intersectionWith=baseRest(function(arrays){var comparator=last(arrays),mapped=arrayMap(arrays,castArrayLikeObject);comparator=typeof comparator==='function'?comparator:undefined;if(comparator){mapped.pop();}return mapped.length&&mapped[0]===arrays[0]?baseIntersection(mapped,undefined,comparator):[];});/**
- * Converts all elements in `array` into a string separated by `separator`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to convert.
- * @param {string} [separator=','] The element separator.
- * @returns {string} Returns the joined string.
- * @example
- *
- * _.join(['a', 'b', 'c'], '~');
- * // => 'a~b~c'
- */function join(array,separator){return array==null?'':nativeJoin.call(array,separator);}/**
- * Gets the last element of `array`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The array to query.
- * @returns {*} Returns the last element of `array`.
- * @example
- *
- * _.last([1, 2, 3]);
- * // => 3
- */function last(array){var length=array==null?0:array.length;return length?array[length-1]:undefined;}/**
- * This method is like `_.indexOf` except that it iterates over elements of
- * `array` from right to left.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {*} value The value to search for.
- * @param {number} [fromIndex=array.length-1] The index to search from.
- * @returns {number} Returns the index of the matched value, else `-1`.
- * @example
- *
- * _.lastIndexOf([1, 2, 1, 2], 2);
- * // => 3
- *
- * // Search from the `fromIndex`.
- * _.lastIndexOf([1, 2, 1, 2], 2, 2);
- * // => 1
- */function lastIndexOf(array,value,fromIndex){var length=array==null?0:array.length;if(!length){return-1;}var index=length;if(fromIndex!==undefined){index=toInteger(fromIndex);index=index<0?nativeMax(length+index,0):nativeMin(index,length-1);}return value===value?strictLastIndexOf(array,value,index):baseFindIndex(array,baseIsNaN,index,true);}/**
- * Gets the element at index `n` of `array`. If `n` is negative, the nth
- * element from the end is returned.
- *
- * @static
- * @memberOf _
- * @since 4.11.0
- * @category Array
- * @param {Array} array The array to query.
- * @param {number} [n=0] The index of the element to return.
- * @returns {*} Returns the nth element of `array`.
- * @example
- *
- * var array = ['a', 'b', 'c', 'd'];
- *
- * _.nth(array, 1);
- * // => 'b'
- *
- * _.nth(array, -2);
- * // => 'c';
- */function nth(array,n){return array&&array.length?baseNth(array,toInteger(n)):undefined;}/**
- * Removes all given values from `array` using
- * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * for equality comparisons.
- *
- * **Note:** Unlike `_.without`, this method mutates `array`. Use `_.remove`
- * to remove elements from an array by predicate.
- *
- * @static
- * @memberOf _
- * @since 2.0.0
- * @category Array
- * @param {Array} array The array to modify.
- * @param {...*} [values] The values to remove.
- * @returns {Array} Returns `array`.
- * @example
- *
- * var array = ['a', 'b', 'c', 'a', 'b', 'c'];
- *
- * _.pull(array, 'a', 'c');
- * console.log(array);
- * // => ['b', 'b']
- */var pull=baseRest(pullAll);/**
- * This method is like `_.pull` except that it accepts an array of values to remove.
- *
- * **Note:** Unlike `_.difference`, this method mutates `array`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to modify.
- * @param {Array} values The values to remove.
- * @returns {Array} Returns `array`.
- * @example
- *
- * var array = ['a', 'b', 'c', 'a', 'b', 'c'];
- *
- * _.pullAll(array, ['a', 'c']);
- * console.log(array);
- * // => ['b', 'b']
- */function pullAll(array,values){return array&&array.length&&values&&values.length?basePullAll(array,values):array;}/**
- * This method is like `_.pullAll` except that it accepts `iteratee` which is
- * invoked for each element of `array` and `values` to generate the criterion
- * by which they're compared. The iteratee is invoked with one argument: (value).
- *
- * **Note:** Unlike `_.differenceBy`, this method mutates `array`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to modify.
- * @param {Array} values The values to remove.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {Array} Returns `array`.
- * @example
- *
- * var array = [{ 'x': 1 }, { 'x': 2 }, { 'x': 3 }, { 'x': 1 }];
- *
- * _.pullAllBy(array, [{ 'x': 1 }, { 'x': 3 }], 'x');
- * console.log(array);
- * // => [{ 'x': 2 }]
- */function pullAllBy(array,values,iteratee){return array&&array.length&&values&&values.length?basePullAll(array,values,getIteratee(iteratee,2)):array;}/**
- * This method is like `_.pullAll` except that it accepts `comparator` which
- * is invoked to compare elements of `array` to `values`. The comparator is
- * invoked with two arguments: (arrVal, othVal).
- *
- * **Note:** Unlike `_.differenceWith`, this method mutates `array`.
- *
- * @static
- * @memberOf _
- * @since 4.6.0
- * @category Array
- * @param {Array} array The array to modify.
- * @param {Array} values The values to remove.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns `array`.
- * @example
- *
- * var array = [{ 'x': 1, 'y': 2 }, { 'x': 3, 'y': 4 }, { 'x': 5, 'y': 6 }];
- *
- * _.pullAllWith(array, [{ 'x': 3, 'y': 4 }], _.isEqual);
- * console.log(array);
- * // => [{ 'x': 1, 'y': 2 }, { 'x': 5, 'y': 6 }]
- */function pullAllWith(array,values,comparator){return array&&array.length&&values&&values.length?basePullAll(array,values,undefined,comparator):array;}/**
- * Removes elements from `array` corresponding to `indexes` and returns an
- * array of removed elements.
- *
- * **Note:** Unlike `_.at`, this method mutates `array`.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Array
- * @param {Array} array The array to modify.
- * @param {...(number|number[])} [indexes] The indexes of elements to remove.
- * @returns {Array} Returns the new array of removed elements.
- * @example
- *
- * var array = ['a', 'b', 'c', 'd'];
- * var pulled = _.pullAt(array, [1, 3]);
- *
- * console.log(array);
- * // => ['a', 'c']
- *
- * console.log(pulled);
- * // => ['b', 'd']
- */var pullAt=flatRest(function(array,indexes){var length=array==null?0:array.length,result=baseAt(array,indexes);basePullAt(array,arrayMap(indexes,function(index){return isIndex(index,length)?+index:index;}).sort(compareAscending));return result;});/**
- * Removes all elements from `array` that `predicate` returns truthy for
- * and returns an array of the removed elements. The predicate is invoked
- * with three arguments: (value, index, array).
- *
- * **Note:** Unlike `_.filter`, this method mutates `array`. Use `_.pull`
- * to pull elements from an array by value.
- *
- * @static
- * @memberOf _
- * @since 2.0.0
- * @category Array
- * @param {Array} array The array to modify.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the new array of removed elements.
- * @example
- *
- * var array = [1, 2, 3, 4];
- * var evens = _.remove(array, function(n) {
- * return n % 2 == 0;
- * });
- *
- * console.log(array);
- * // => [1, 3]
- *
- * console.log(evens);
- * // => [2, 4]
- */function remove(array,predicate){var result=[];if(!(array&&array.length)){return result;}var index=-1,indexes=[],length=array.length;predicate=getIteratee(predicate,3);while(++index<length){var value=array[index];if(predicate(value,index,array)){result.push(value);indexes.push(index);}}basePullAt(array,indexes);return result;}/**
- * Reverses `array` so that the first element becomes the last, the second
- * element becomes the second to last, and so on.
- *
- * **Note:** This method mutates `array` and is based on
- * [`Array#reverse`](https://mdn.io/Array/reverse).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to modify.
- * @returns {Array} Returns `array`.
- * @example
- *
- * var array = [1, 2, 3];
- *
- * _.reverse(array);
- * // => [3, 2, 1]
- *
- * console.log(array);
- * // => [3, 2, 1]
- */function reverse(array){return array==null?array:nativeReverse.call(array);}/**
- * Creates a slice of `array` from `start` up to, but not including, `end`.
- *
- * **Note:** This method is used instead of
- * [`Array#slice`](https://mdn.io/Array/slice) to ensure dense arrays are
- * returned.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Array
- * @param {Array} array The array to slice.
- * @param {number} [start=0] The start position.
- * @param {number} [end=array.length] The end position.
- * @returns {Array} Returns the slice of `array`.
- */function slice(array,start,end){var length=array==null?0:array.length;if(!length){return[];}if(end&&typeof end!=='number'&&isIterateeCall(array,start,end)){start=0;end=length;}else{start=start==null?0:toInteger(start);end=end===undefined?length:toInteger(end);}return baseSlice(array,start,end);}/**
- * Uses a binary search to determine the lowest index at which `value`
- * should be inserted into `array` in order to maintain its sort order.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The sorted array to inspect.
- * @param {*} value The value to evaluate.
- * @returns {number} Returns the index at which `value` should be inserted
- * into `array`.
- * @example
- *
- * _.sortedIndex([30, 50], 40);
- * // => 1
- */function sortedIndex(array,value){return baseSortedIndex(array,value);}/**
- * This method is like `_.sortedIndex` except that it accepts `iteratee`
- * which is invoked for `value` and each element of `array` to compute their
- * sort ranking. The iteratee is invoked with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The sorted array to inspect.
- * @param {*} value The value to evaluate.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {number} Returns the index at which `value` should be inserted
- * into `array`.
- * @example
- *
- * var objects = [{ 'x': 4 }, { 'x': 5 }];
- *
- * _.sortedIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });
- * // => 0
- *
- * // The `_.property` iteratee shorthand.
- * _.sortedIndexBy(objects, { 'x': 4 }, 'x');
- * // => 0
- */function sortedIndexBy(array,value,iteratee){return baseSortedIndexBy(array,value,getIteratee(iteratee,2));}/**
- * This method is like `_.indexOf` except that it performs a binary
- * search on a sorted `array`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {*} value The value to search for.
- * @returns {number} Returns the index of the matched value, else `-1`.
- * @example
- *
- * _.sortedIndexOf([4, 5, 5, 5, 6], 5);
- * // => 1
- */function sortedIndexOf(array,value){var length=array==null?0:array.length;if(length){var index=baseSortedIndex(array,value);if(index<length&&eq(array[index],value)){return index;}}return-1;}/**
- * This method is like `_.sortedIndex` except that it returns the highest
- * index at which `value` should be inserted into `array` in order to
- * maintain its sort order.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Array
- * @param {Array} array The sorted array to inspect.
- * @param {*} value The value to evaluate.
- * @returns {number} Returns the index at which `value` should be inserted
- * into `array`.
- * @example
- *
- * _.sortedLastIndex([4, 5, 5, 5, 6], 5);
- * // => 4
- */function sortedLastIndex(array,value){return baseSortedIndex(array,value,true);}/**
- * This method is like `_.sortedLastIndex` except that it accepts `iteratee`
- * which is invoked for `value` and each element of `array` to compute their
- * sort ranking. The iteratee is invoked with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The sorted array to inspect.
- * @param {*} value The value to evaluate.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {number} Returns the index at which `value` should be inserted
- * into `array`.
- * @example
- *
- * var objects = [{ 'x': 4 }, { 'x': 5 }];
- *
- * _.sortedLastIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });
- * // => 1
- *
- * // The `_.property` iteratee shorthand.
- * _.sortedLastIndexBy(objects, { 'x': 4 }, 'x');
- * // => 1
- */function sortedLastIndexBy(array,value,iteratee){return baseSortedIndexBy(array,value,getIteratee(iteratee,2),true);}/**
- * This method is like `_.lastIndexOf` except that it performs a binary
- * search on a sorted `array`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {*} value The value to search for.
- * @returns {number} Returns the index of the matched value, else `-1`.
- * @example
- *
- * _.sortedLastIndexOf([4, 5, 5, 5, 6], 5);
- * // => 3
- */function sortedLastIndexOf(array,value){var length=array==null?0:array.length;if(length){var index=baseSortedIndex(array,value,true)-1;if(eq(array[index],value)){return index;}}return-1;}/**
- * This method is like `_.uniq` except that it's designed and optimized
- * for sorted arrays.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @returns {Array} Returns the new duplicate free array.
- * @example
- *
- * _.sortedUniq([1, 1, 2]);
- * // => [1, 2]
- */function sortedUniq(array){return array&&array.length?baseSortedUniq(array):[];}/**
- * This method is like `_.uniqBy` except that it's designed and optimized
- * for sorted arrays.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {Function} [iteratee] The iteratee invoked per element.
- * @returns {Array} Returns the new duplicate free array.
- * @example
- *
- * _.sortedUniqBy([1.1, 1.2, 2.3, 2.4], Math.floor);
- * // => [1.1, 2.3]
- */function sortedUniqBy(array,iteratee){return array&&array.length?baseSortedUniq(array,getIteratee(iteratee,2)):[];}/**
- * Gets all but the first element of `array`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to query.
- * @returns {Array} Returns the slice of `array`.
- * @example
- *
- * _.tail([1, 2, 3]);
- * // => [2, 3]
- */function tail(array){var length=array==null?0:array.length;return length?baseSlice(array,1,length):[];}/**
- * Creates a slice of `array` with `n` elements taken from the beginning.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The array to query.
- * @param {number} [n=1] The number of elements to take.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {Array} Returns the slice of `array`.
- * @example
- *
- * _.take([1, 2, 3]);
- * // => [1]
- *
- * _.take([1, 2, 3], 2);
- * // => [1, 2]
- *
- * _.take([1, 2, 3], 5);
- * // => [1, 2, 3]
- *
- * _.take([1, 2, 3], 0);
- * // => []
- */function take(array,n,guard){if(!(array&&array.length)){return[];}n=guard||n===undefined?1:toInteger(n);return baseSlice(array,0,n<0?0:n);}/**
- * Creates a slice of `array` with `n` elements taken from the end.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Array
- * @param {Array} array The array to query.
- * @param {number} [n=1] The number of elements to take.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {Array} Returns the slice of `array`.
- * @example
- *
- * _.takeRight([1, 2, 3]);
- * // => [3]
- *
- * _.takeRight([1, 2, 3], 2);
- * // => [2, 3]
- *
- * _.takeRight([1, 2, 3], 5);
- * // => [1, 2, 3]
- *
- * _.takeRight([1, 2, 3], 0);
- * // => []
- */function takeRight(array,n,guard){var length=array==null?0:array.length;if(!length){return[];}n=guard||n===undefined?1:toInteger(n);n=length-n;return baseSlice(array,n<0?0:n,length);}/**
- * Creates a slice of `array` with elements taken from the end. Elements are
- * taken until `predicate` returns falsey. The predicate is invoked with
- * three arguments: (value, index, array).
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Array
- * @param {Array} array The array to query.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the slice of `array`.
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'active': true },
- * { 'user': 'fred', 'active': false },
- * { 'user': 'pebbles', 'active': false }
- * ];
- *
- * _.takeRightWhile(users, function(o) { return !o.active; });
- * // => objects for ['fred', 'pebbles']
- *
- * // The `_.matches` iteratee shorthand.
- * _.takeRightWhile(users, { 'user': 'pebbles', 'active': false });
- * // => objects for ['pebbles']
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.takeRightWhile(users, ['active', false]);
- * // => objects for ['fred', 'pebbles']
- *
- * // The `_.property` iteratee shorthand.
- * _.takeRightWhile(users, 'active');
- * // => []
- */function takeRightWhile(array,predicate){return array&&array.length?baseWhile(array,getIteratee(predicate,3),false,true):[];}/**
- * Creates a slice of `array` with elements taken from the beginning. Elements
- * are taken until `predicate` returns falsey. The predicate is invoked with
- * three arguments: (value, index, array).
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Array
- * @param {Array} array The array to query.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the slice of `array`.
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'active': false },
- * { 'user': 'fred', 'active': false },
- * { 'user': 'pebbles', 'active': true }
- * ];
- *
- * _.takeWhile(users, function(o) { return !o.active; });
- * // => objects for ['barney', 'fred']
- *
- * // The `_.matches` iteratee shorthand.
- * _.takeWhile(users, { 'user': 'barney', 'active': false });
- * // => objects for ['barney']
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.takeWhile(users, ['active', false]);
- * // => objects for ['barney', 'fred']
- *
- * // The `_.property` iteratee shorthand.
- * _.takeWhile(users, 'active');
- * // => []
- */function takeWhile(array,predicate){return array&&array.length?baseWhile(array,getIteratee(predicate,3)):[];}/**
- * Creates an array of unique values, in order, from all given arrays using
- * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * for equality comparisons.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {...Array} [arrays] The arrays to inspect.
- * @returns {Array} Returns the new array of combined values.
- * @example
- *
- * _.union([2], [1, 2]);
- * // => [2, 1]
- */var union=baseRest(function(arrays){return baseUniq(baseFlatten(arrays,1,isArrayLikeObject,true));});/**
- * This method is like `_.union` except that it accepts `iteratee` which is
- * invoked for each element of each `arrays` to generate the criterion by
- * which uniqueness is computed. Result values are chosen from the first
- * array in which the value occurs. The iteratee is invoked with one argument:
- * (value).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {...Array} [arrays] The arrays to inspect.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {Array} Returns the new array of combined values.
- * @example
- *
- * _.unionBy([2.1], [1.2, 2.3], Math.floor);
- * // => [2.1, 1.2]
- *
- * // The `_.property` iteratee shorthand.
- * _.unionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');
- * // => [{ 'x': 1 }, { 'x': 2 }]
- */var unionBy=baseRest(function(arrays){var iteratee=last(arrays);if(isArrayLikeObject(iteratee)){iteratee=undefined;}return baseUniq(baseFlatten(arrays,1,isArrayLikeObject,true),getIteratee(iteratee,2));});/**
- * This method is like `_.union` except that it accepts `comparator` which
- * is invoked to compare elements of `arrays`. Result values are chosen from
- * the first array in which the value occurs. The comparator is invoked
- * with two arguments: (arrVal, othVal).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {...Array} [arrays] The arrays to inspect.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns the new array of combined values.
- * @example
- *
- * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];
- * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];
- *
- * _.unionWith(objects, others, _.isEqual);
- * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]
- */var unionWith=baseRest(function(arrays){var comparator=last(arrays);comparator=typeof comparator==='function'?comparator:undefined;return baseUniq(baseFlatten(arrays,1,isArrayLikeObject,true),undefined,comparator);});/**
- * Creates a duplicate-free version of an array, using
- * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * for equality comparisons, in which only the first occurrence of each element
- * is kept. The order of result values is determined by the order they occur
- * in the array.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @returns {Array} Returns the new duplicate free array.
- * @example
- *
- * _.uniq([2, 1, 2]);
- * // => [2, 1]
- */function uniq(array){return array&&array.length?baseUniq(array):[];}/**
- * This method is like `_.uniq` except that it accepts `iteratee` which is
- * invoked for each element in `array` to generate the criterion by which
- * uniqueness is computed. The order of result values is determined by the
- * order they occur in the array. The iteratee is invoked with one argument:
- * (value).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {Array} Returns the new duplicate free array.
- * @example
- *
- * _.uniqBy([2.1, 1.2, 2.3], Math.floor);
- * // => [2.1, 1.2]
- *
- * // The `_.property` iteratee shorthand.
- * _.uniqBy([{ 'x': 1 }, { 'x': 2 }, { 'x': 1 }], 'x');
- * // => [{ 'x': 1 }, { 'x': 2 }]
- */function uniqBy(array,iteratee){return array&&array.length?baseUniq(array,getIteratee(iteratee,2)):[];}/**
- * This method is like `_.uniq` except that it accepts `comparator` which
- * is invoked to compare elements of `array`. The order of result values is
- * determined by the order they occur in the array.The comparator is invoked
- * with two arguments: (arrVal, othVal).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns the new duplicate free array.
- * @example
- *
- * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 2 }];
- *
- * _.uniqWith(objects, _.isEqual);
- * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]
- */function uniqWith(array,comparator){comparator=typeof comparator==='function'?comparator:undefined;return array&&array.length?baseUniq(array,undefined,comparator):[];}/**
- * This method is like `_.zip` except that it accepts an array of grouped
- * elements and creates an array regrouping the elements to their pre-zip
- * configuration.
- *
- * @static
- * @memberOf _
- * @since 1.2.0
- * @category Array
- * @param {Array} array The array of grouped elements to process.
- * @returns {Array} Returns the new array of regrouped elements.
- * @example
- *
- * var zipped = _.zip(['a', 'b'], [1, 2], [true, false]);
- * // => [['a', 1, true], ['b', 2, false]]
- *
- * _.unzip(zipped);
- * // => [['a', 'b'], [1, 2], [true, false]]
- */function unzip(array){if(!(array&&array.length)){return[];}var length=0;array=arrayFilter(array,function(group){if(isArrayLikeObject(group)){length=nativeMax(group.length,length);return true;}});return baseTimes(length,function(index){return arrayMap(array,baseProperty(index));});}/**
- * This method is like `_.unzip` except that it accepts `iteratee` to specify
- * how regrouped values should be combined. The iteratee is invoked with the
- * elements of each group: (...group).
- *
- * @static
- * @memberOf _
- * @since 3.8.0
- * @category Array
- * @param {Array} array The array of grouped elements to process.
- * @param {Function} [iteratee=_.identity] The function to combine
- * regrouped values.
- * @returns {Array} Returns the new array of regrouped elements.
- * @example
- *
- * var zipped = _.zip([1, 2], [10, 20], [100, 200]);
- * // => [[1, 10, 100], [2, 20, 200]]
- *
- * _.unzipWith(zipped, _.add);
- * // => [3, 30, 300]
- */function unzipWith(array,iteratee){if(!(array&&array.length)){return[];}var result=unzip(array);if(iteratee==null){return result;}return arrayMap(result,function(group){return apply(iteratee,undefined,group);});}/**
- * Creates an array excluding all given values using
- * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * for equality comparisons.
- *
- * **Note:** Unlike `_.pull`, this method returns a new array.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @param {...*} [values] The values to exclude.
- * @returns {Array} Returns the new array of filtered values.
- * @see _.difference, _.xor
- * @example
- *
- * _.without([2, 1, 2, 3], 1, 2);
- * // => [3]
- */var without=baseRest(function(array,values){return isArrayLikeObject(array)?baseDifference(array,values):[];});/**
- * Creates an array of unique values that is the
- * [symmetric difference](https://en.wikipedia.org/wiki/Symmetric_difference)
- * of the given arrays. The order of result values is determined by the order
- * they occur in the arrays.
- *
- * @static
- * @memberOf _
- * @since 2.4.0
- * @category Array
- * @param {...Array} [arrays] The arrays to inspect.
- * @returns {Array} Returns the new array of filtered values.
- * @see _.difference, _.without
- * @example
- *
- * _.xor([2, 1], [2, 3]);
- * // => [1, 3]
- */var xor=baseRest(function(arrays){return baseXor(arrayFilter(arrays,isArrayLikeObject));});/**
- * This method is like `_.xor` except that it accepts `iteratee` which is
- * invoked for each element of each `arrays` to generate the criterion by
- * which by which they're compared. The order of result values is determined
- * by the order they occur in the arrays. The iteratee is invoked with one
- * argument: (value).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {...Array} [arrays] The arrays to inspect.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {Array} Returns the new array of filtered values.
- * @example
- *
- * _.xorBy([2.1, 1.2], [2.3, 3.4], Math.floor);
- * // => [1.2, 3.4]
- *
- * // The `_.property` iteratee shorthand.
- * _.xorBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');
- * // => [{ 'x': 2 }]
- */var xorBy=baseRest(function(arrays){var iteratee=last(arrays);if(isArrayLikeObject(iteratee)){iteratee=undefined;}return baseXor(arrayFilter(arrays,isArrayLikeObject),getIteratee(iteratee,2));});/**
- * This method is like `_.xor` except that it accepts `comparator` which is
- * invoked to compare elements of `arrays`. The order of result values is
- * determined by the order they occur in the arrays. The comparator is invoked
- * with two arguments: (arrVal, othVal).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Array
- * @param {...Array} [arrays] The arrays to inspect.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns the new array of filtered values.
- * @example
- *
- * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];
- * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];
- *
- * _.xorWith(objects, others, _.isEqual);
- * // => [{ 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]
- */var xorWith=baseRest(function(arrays){var comparator=last(arrays);comparator=typeof comparator==='function'?comparator:undefined;return baseXor(arrayFilter(arrays,isArrayLikeObject),undefined,comparator);});/**
- * Creates an array of grouped elements, the first of which contains the
- * first elements of the given arrays, the second of which contains the
- * second elements of the given arrays, and so on.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {...Array} [arrays] The arrays to process.
- * @returns {Array} Returns the new array of grouped elements.
- * @example
- *
- * _.zip(['a', 'b'], [1, 2], [true, false]);
- * // => [['a', 1, true], ['b', 2, false]]
- */var zip=baseRest(unzip);/**
- * This method is like `_.fromPairs` except that it accepts two arrays,
- * one of property identifiers and one of corresponding values.
- *
- * @static
- * @memberOf _
- * @since 0.4.0
- * @category Array
- * @param {Array} [props=[]] The property identifiers.
- * @param {Array} [values=[]] The property values.
- * @returns {Object} Returns the new object.
- * @example
- *
- * _.zipObject(['a', 'b'], [1, 2]);
- * // => { 'a': 1, 'b': 2 }
- */function zipObject(props,values){return baseZipObject(props||[],values||[],assignValue);}/**
- * This method is like `_.zipObject` except that it supports property paths.
- *
- * @static
- * @memberOf _
- * @since 4.1.0
- * @category Array
- * @param {Array} [props=[]] The property identifiers.
- * @param {Array} [values=[]] The property values.
- * @returns {Object} Returns the new object.
- * @example
- *
- * _.zipObjectDeep(['a.b[0].c', 'a.b[1].d'], [1, 2]);
- * // => { 'a': { 'b': [{ 'c': 1 }, { 'd': 2 }] } }
- */function zipObjectDeep(props,values){return baseZipObject(props||[],values||[],baseSet);}/**
- * This method is like `_.zip` except that it accepts `iteratee` to specify
- * how grouped values should be combined. The iteratee is invoked with the
- * elements of each group: (...group).
- *
- * @static
- * @memberOf _
- * @since 3.8.0
- * @category Array
- * @param {...Array} [arrays] The arrays to process.
- * @param {Function} [iteratee=_.identity] The function to combine
- * grouped values.
- * @returns {Array} Returns the new array of grouped elements.
- * @example
- *
- * _.zipWith([1, 2], [10, 20], [100, 200], function(a, b, c) {
- * return a + b + c;
- * });
- * // => [111, 222]
- */var zipWith=baseRest(function(arrays){var length=arrays.length,iteratee=length>1?arrays[length-1]:undefined;iteratee=typeof iteratee==='function'?(arrays.pop(),iteratee):undefined;return unzipWith(arrays,iteratee);});/* ------------------------------------------------------------------------*//**
- * Creates a `lodash` wrapper instance that wraps `value` with explicit method
- * chain sequences enabled. The result of such sequences must be unwrapped
- * with `_#value`.
- *
- * @static
- * @memberOf _
- * @since 1.3.0
- * @category Seq
- * @param {*} value The value to wrap.
- * @returns {Object} Returns the new `lodash` wrapper instance.
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'age': 36 },
- * { 'user': 'fred', 'age': 40 },
- * { 'user': 'pebbles', 'age': 1 }
- * ];
- *
- * var youngest = _
- * .chain(users)
- * .sortBy('age')
- * .map(function(o) {
- * return o.user + ' is ' + o.age;
- * })
- * .head()
- * .value();
- * // => 'pebbles is 1'
- */function chain(value){var result=lodash(value);result.__chain__=true;return result;}/**
- * This method invokes `interceptor` and returns `value`. The interceptor
- * is invoked with one argument; (value). The purpose of this method is to
- * "tap into" a method chain sequence in order to modify intermediate results.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Seq
- * @param {*} value The value to provide to `interceptor`.
- * @param {Function} interceptor The function to invoke.
- * @returns {*} Returns `value`.
- * @example
- *
- * _([1, 2, 3])
- * .tap(function(array) {
- * // Mutate input array.
- * array.pop();
- * })
- * .reverse()
- * .value();
- * // => [2, 1]
- */function tap(value,interceptor){interceptor(value);return value;}/**
- * This method is like `_.tap` except that it returns the result of `interceptor`.
- * The purpose of this method is to "pass thru" values replacing intermediate
- * results in a method chain sequence.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Seq
- * @param {*} value The value to provide to `interceptor`.
- * @param {Function} interceptor The function to invoke.
- * @returns {*} Returns the result of `interceptor`.
- * @example
- *
- * _(' abc ')
- * .chain()
- * .trim()
- * .thru(function(value) {
- * return [value];
- * })
- * .value();
- * // => ['abc']
- */function thru(value,interceptor){return interceptor(value);}/**
- * This method is the wrapper version of `_.at`.
- *
- * @name at
- * @memberOf _
- * @since 1.0.0
- * @category Seq
- * @param {...(string|string[])} [paths] The property paths to pick.
- * @returns {Object} Returns the new `lodash` wrapper instance.
- * @example
- *
- * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };
- *
- * _(object).at(['a[0].b.c', 'a[1]']).value();
- * // => [3, 4]
- */var wrapperAt=flatRest(function(paths){var length=paths.length,start=length?paths[0]:0,value=this.__wrapped__,interceptor=function interceptor(object){return baseAt(object,paths);};if(length>1||this.__actions__.length||!(value instanceof LazyWrapper)||!isIndex(start)){return this.thru(interceptor);}value=value.slice(start,+start+(length?1:0));value.__actions__.push({func:thru,args:[interceptor],thisArg:undefined});return new LodashWrapper(value,this.__chain__).thru(function(array){if(length&&!array.length){array.push(undefined);}return array;});});/**
- * Creates a `lodash` wrapper instance with explicit method chain sequences enabled.
- *
- * @name chain
- * @memberOf _
- * @since 0.1.0
- * @category Seq
- * @returns {Object} Returns the new `lodash` wrapper instance.
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'age': 36 },
- * { 'user': 'fred', 'age': 40 }
- * ];
- *
- * // A sequence without explicit chaining.
- * _(users).head();
- * // => { 'user': 'barney', 'age': 36 }
- *
- * // A sequence with explicit chaining.
- * _(users)
- * .chain()
- * .head()
- * .pick('user')
- * .value();
- * // => { 'user': 'barney' }
- */function wrapperChain(){return chain(this);}/**
- * Executes the chain sequence and returns the wrapped result.
- *
- * @name commit
- * @memberOf _
- * @since 3.2.0
- * @category Seq
- * @returns {Object} Returns the new `lodash` wrapper instance.
- * @example
- *
- * var array = [1, 2];
- * var wrapped = _(array).push(3);
- *
- * console.log(array);
- * // => [1, 2]
- *
- * wrapped = wrapped.commit();
- * console.log(array);
- * // => [1, 2, 3]
- *
- * wrapped.last();
- * // => 3
- *
- * console.log(array);
- * // => [1, 2, 3]
- */function wrapperCommit(){return new LodashWrapper(this.value(),this.__chain__);}/**
- * Gets the next value on a wrapped object following the
- * [iterator protocol](https://mdn.io/iteration_protocols#iterator).
- *
- * @name next
- * @memberOf _
- * @since 4.0.0
- * @category Seq
- * @returns {Object} Returns the next iterator value.
- * @example
- *
- * var wrapped = _([1, 2]);
- *
- * wrapped.next();
- * // => { 'done': false, 'value': 1 }
- *
- * wrapped.next();
- * // => { 'done': false, 'value': 2 }
- *
- * wrapped.next();
- * // => { 'done': true, 'value': undefined }
- */function wrapperNext(){if(this.__values__===undefined){this.__values__=toArray(this.value());}var done=this.__index__>=this.__values__.length,value=done?undefined:this.__values__[this.__index__++];return{done:done,value:value};}/**
- * Enables the wrapper to be iterable.
- *
- * @name Symbol.iterator
- * @memberOf _
- * @since 4.0.0
- * @category Seq
- * @returns {Object} Returns the wrapper object.
- * @example
- *
- * var wrapped = _([1, 2]);
- *
- * wrapped[Symbol.iterator]() === wrapped;
- * // => true
- *
- * Array.from(wrapped);
- * // => [1, 2]
- */function wrapperToIterator(){return this;}/**
- * Creates a clone of the chain sequence planting `value` as the wrapped value.
- *
- * @name plant
- * @memberOf _
- * @since 3.2.0
- * @category Seq
- * @param {*} value The value to plant.
- * @returns {Object} Returns the new `lodash` wrapper instance.
- * @example
- *
- * function square(n) {
- * return n * n;
- * }
- *
- * var wrapped = _([1, 2]).map(square);
- * var other = wrapped.plant([3, 4]);
- *
- * other.value();
- * // => [9, 16]
- *
- * wrapped.value();
- * // => [1, 4]
- */function wrapperPlant(value){var result,parent=this;while(parent instanceof baseLodash){var clone=wrapperClone(parent);clone.__index__=0;clone.__values__=undefined;if(result){previous.__wrapped__=clone;}else{result=clone;}var previous=clone;parent=parent.__wrapped__;}previous.__wrapped__=value;return result;}/**
- * This method is the wrapper version of `_.reverse`.
- *
- * **Note:** This method mutates the wrapped array.
- *
- * @name reverse
- * @memberOf _
- * @since 0.1.0
- * @category Seq
- * @returns {Object} Returns the new `lodash` wrapper instance.
- * @example
- *
- * var array = [1, 2, 3];
- *
- * _(array).reverse().value()
- * // => [3, 2, 1]
- *
- * console.log(array);
- * // => [3, 2, 1]
- */function wrapperReverse(){var value=this.__wrapped__;if(value instanceof LazyWrapper){var wrapped=value;if(this.__actions__.length){wrapped=new LazyWrapper(this);}wrapped=wrapped.reverse();wrapped.__actions__.push({func:thru,args:[reverse],thisArg:undefined});return new LodashWrapper(wrapped,this.__chain__);}return this.thru(reverse);}/**
- * Executes the chain sequence to resolve the unwrapped value.
- *
- * @name value
- * @memberOf _
- * @since 0.1.0
- * @alias toJSON, valueOf
- * @category Seq
- * @returns {*} Returns the resolved unwrapped value.
- * @example
- *
- * _([1, 2, 3]).value();
- * // => [1, 2, 3]
- */function wrapperValue(){return baseWrapperValue(this.__wrapped__,this.__actions__);}/* ------------------------------------------------------------------------*//**
- * Creates an object composed of keys generated from the results of running
- * each element of `collection` thru `iteratee`. The corresponding value of
- * each key is the number of times the key was returned by `iteratee`. The
- * iteratee is invoked with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 0.5.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [iteratee=_.identity] The iteratee to transform keys.
- * @returns {Object} Returns the composed aggregate object.
- * @example
- *
- * _.countBy([6.1, 4.2, 6.3], Math.floor);
- * // => { '4': 1, '6': 2 }
- *
- * // The `_.property` iteratee shorthand.
- * _.countBy(['one', 'two', 'three'], 'length');
- * // => { '3': 2, '5': 1 }
- */var countBy=createAggregator(function(result,value,key){if(hasOwnProperty.call(result,key)){++result[key];}else{baseAssignValue(result,key,1);}});/**
- * Checks if `predicate` returns truthy for **all** elements of `collection`.
- * Iteration is stopped once `predicate` returns falsey. The predicate is
- * invoked with three arguments: (value, index|key, collection).
- *
- * **Note:** This method returns `true` for
- * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because
- * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of
- * elements of empty collections.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {boolean} Returns `true` if all elements pass the predicate check,
- * else `false`.
- * @example
- *
- * _.every([true, 1, null, 'yes'], Boolean);
- * // => false
- *
- * var users = [
- * { 'user': 'barney', 'age': 36, 'active': false },
- * { 'user': 'fred', 'age': 40, 'active': false }
- * ];
- *
- * // The `_.matches` iteratee shorthand.
- * _.every(users, { 'user': 'barney', 'active': false });
- * // => false
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.every(users, ['active', false]);
- * // => true
- *
- * // The `_.property` iteratee shorthand.
- * _.every(users, 'active');
- * // => false
- */function every(collection,predicate,guard){var func=isArray(collection)?arrayEvery:baseEvery;if(guard&&isIterateeCall(collection,predicate,guard)){predicate=undefined;}return func(collection,getIteratee(predicate,3));}/**
- * Iterates over elements of `collection`, returning an array of all elements
- * `predicate` returns truthy for. The predicate is invoked with three
- * arguments: (value, index|key, collection).
- *
- * **Note:** Unlike `_.remove`, this method returns a new array.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the new filtered array.
- * @see _.reject
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'age': 36, 'active': true },
- * { 'user': 'fred', 'age': 40, 'active': false }
- * ];
- *
- * _.filter(users, function(o) { return !o.active; });
- * // => objects for ['fred']
- *
- * // The `_.matches` iteratee shorthand.
- * _.filter(users, { 'age': 36, 'active': true });
- * // => objects for ['barney']
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.filter(users, ['active', false]);
- * // => objects for ['fred']
- *
- * // The `_.property` iteratee shorthand.
- * _.filter(users, 'active');
- * // => objects for ['barney']
- */function filter(collection,predicate){var func=isArray(collection)?arrayFilter:baseFilter;return func(collection,getIteratee(predicate,3));}/**
- * Iterates over elements of `collection`, returning the first element
- * `predicate` returns truthy for. The predicate is invoked with three
- * arguments: (value, index|key, collection).
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object} collection The collection to inspect.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @param {number} [fromIndex=0] The index to search from.
- * @returns {*} Returns the matched element, else `undefined`.
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'age': 36, 'active': true },
- * { 'user': 'fred', 'age': 40, 'active': false },
- * { 'user': 'pebbles', 'age': 1, 'active': true }
- * ];
- *
- * _.find(users, function(o) { return o.age < 40; });
- * // => object for 'barney'
- *
- * // The `_.matches` iteratee shorthand.
- * _.find(users, { 'age': 1, 'active': true });
- * // => object for 'pebbles'
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.find(users, ['active', false]);
- * // => object for 'fred'
- *
- * // The `_.property` iteratee shorthand.
- * _.find(users, 'active');
- * // => object for 'barney'
- */var find=createFind(findIndex);/**
- * This method is like `_.find` except that it iterates over elements of
- * `collection` from right to left.
- *
- * @static
- * @memberOf _
- * @since 2.0.0
- * @category Collection
- * @param {Array|Object} collection The collection to inspect.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @param {number} [fromIndex=collection.length-1] The index to search from.
- * @returns {*} Returns the matched element, else `undefined`.
- * @example
- *
- * _.findLast([1, 2, 3, 4], function(n) {
- * return n % 2 == 1;
- * });
- * // => 3
- */var findLast=createFind(findLastIndex);/**
- * Creates a flattened array of values by running each element in `collection`
- * thru `iteratee` and flattening the mapped results. The iteratee is invoked
- * with three arguments: (value, index|key, collection).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the new flattened array.
- * @example
- *
- * function duplicate(n) {
- * return [n, n];
- * }
- *
- * _.flatMap([1, 2], duplicate);
- * // => [1, 1, 2, 2]
- */function flatMap(collection,iteratee){return baseFlatten(map(collection,iteratee),1);}/**
- * This method is like `_.flatMap` except that it recursively flattens the
- * mapped results.
- *
- * @static
- * @memberOf _
- * @since 4.7.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the new flattened array.
- * @example
- *
- * function duplicate(n) {
- * return [[[n, n]]];
- * }
- *
- * _.flatMapDeep([1, 2], duplicate);
- * // => [1, 1, 2, 2]
- */function flatMapDeep(collection,iteratee){return baseFlatten(map(collection,iteratee),INFINITY);}/**
- * This method is like `_.flatMap` except that it recursively flattens the
- * mapped results up to `depth` times.
- *
- * @static
- * @memberOf _
- * @since 4.7.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @param {number} [depth=1] The maximum recursion depth.
- * @returns {Array} Returns the new flattened array.
- * @example
- *
- * function duplicate(n) {
- * return [[[n, n]]];
- * }
- *
- * _.flatMapDepth([1, 2], duplicate, 2);
- * // => [[1, 1], [2, 2]]
- */function flatMapDepth(collection,iteratee,depth){depth=depth===undefined?1:toInteger(depth);return baseFlatten(map(collection,iteratee),depth);}/**
- * Iterates over elements of `collection` and invokes `iteratee` for each element.
- * The iteratee is invoked with three arguments: (value, index|key, collection).
- * Iteratee functions may exit iteration early by explicitly returning `false`.
- *
- * **Note:** As with other "Collections" methods, objects with a "length"
- * property are iterated like arrays. To avoid this behavior use `_.forIn`
- * or `_.forOwn` for object iteration.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @alias each
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Array|Object} Returns `collection`.
- * @see _.forEachRight
- * @example
- *
- * _.forEach([1, 2], function(value) {
- * console.log(value);
- * });
- * // => Logs `1` then `2`.
- *
- * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) {
- * console.log(key);
- * });
- * // => Logs 'a' then 'b' (iteration order is not guaranteed).
- */function forEach(collection,iteratee){var func=isArray(collection)?arrayEach:baseEach;return func(collection,getIteratee(iteratee,3));}/**
- * This method is like `_.forEach` except that it iterates over elements of
- * `collection` from right to left.
- *
- * @static
- * @memberOf _
- * @since 2.0.0
- * @alias eachRight
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Array|Object} Returns `collection`.
- * @see _.forEach
- * @example
- *
- * _.forEachRight([1, 2], function(value) {
- * console.log(value);
- * });
- * // => Logs `2` then `1`.
- */function forEachRight(collection,iteratee){var func=isArray(collection)?arrayEachRight:baseEachRight;return func(collection,getIteratee(iteratee,3));}/**
- * Creates an object composed of keys generated from the results of running
- * each element of `collection` thru `iteratee`. The order of grouped values
- * is determined by the order they occur in `collection`. The corresponding
- * value of each key is an array of elements responsible for generating the
- * key. The iteratee is invoked with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [iteratee=_.identity] The iteratee to transform keys.
- * @returns {Object} Returns the composed aggregate object.
- * @example
- *
- * _.groupBy([6.1, 4.2, 6.3], Math.floor);
- * // => { '4': [4.2], '6': [6.1, 6.3] }
- *
- * // The `_.property` iteratee shorthand.
- * _.groupBy(['one', 'two', 'three'], 'length');
- * // => { '3': ['one', 'two'], '5': ['three'] }
- */var groupBy=createAggregator(function(result,value,key){if(hasOwnProperty.call(result,key)){result[key].push(value);}else{baseAssignValue(result,key,[value]);}});/**
- * Checks if `value` is in `collection`. If `collection` is a string, it's
- * checked for a substring of `value`, otherwise
- * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * is used for equality comparisons. If `fromIndex` is negative, it's used as
- * the offset from the end of `collection`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object|string} collection The collection to inspect.
- * @param {*} value The value to search for.
- * @param {number} [fromIndex=0] The index to search from.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.
- * @returns {boolean} Returns `true` if `value` is found, else `false`.
- * @example
- *
- * _.includes([1, 2, 3], 1);
- * // => true
- *
- * _.includes([1, 2, 3], 1, 2);
- * // => false
- *
- * _.includes({ 'a': 1, 'b': 2 }, 1);
- * // => true
- *
- * _.includes('abcd', 'bc');
- * // => true
- */function includes(collection,value,fromIndex,guard){collection=isArrayLike(collection)?collection:values(collection);fromIndex=fromIndex&&!guard?toInteger(fromIndex):0;var length=collection.length;if(fromIndex<0){fromIndex=nativeMax(length+fromIndex,0);}return isString(collection)?fromIndex<=length&&collection.indexOf(value,fromIndex)>-1:!!length&&baseIndexOf(collection,value,fromIndex)>-1;}/**
- * Invokes the method at `path` of each element in `collection`, returning
- * an array of the results of each invoked method. Any additional arguments
- * are provided to each invoked method. If `path` is a function, it's invoked
- * for, and `this` bound to, each element in `collection`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Array|Function|string} path The path of the method to invoke or
- * the function invoked per iteration.
- * @param {...*} [args] The arguments to invoke each method with.
- * @returns {Array} Returns the array of results.
- * @example
- *
- * _.invokeMap([[5, 1, 7], [3, 2, 1]], 'sort');
- * // => [[1, 5, 7], [1, 2, 3]]
- *
- * _.invokeMap([123, 456], String.prototype.split, '');
- * // => [['1', '2', '3'], ['4', '5', '6']]
- */var invokeMap=baseRest(function(collection,path,args){var index=-1,isFunc=typeof path==='function',result=isArrayLike(collection)?Array(collection.length):[];baseEach(collection,function(value){result[++index]=isFunc?apply(path,value,args):baseInvoke(value,path,args);});return result;});/**
- * Creates an object composed of keys generated from the results of running
- * each element of `collection` thru `iteratee`. The corresponding value of
- * each key is the last element responsible for generating the key. The
- * iteratee is invoked with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [iteratee=_.identity] The iteratee to transform keys.
- * @returns {Object} Returns the composed aggregate object.
- * @example
- *
- * var array = [
- * { 'dir': 'left', 'code': 97 },
- * { 'dir': 'right', 'code': 100 }
- * ];
- *
- * _.keyBy(array, function(o) {
- * return String.fromCharCode(o.code);
- * });
- * // => { 'a': { 'dir': 'left', 'code': 97 }, 'd': { 'dir': 'right', 'code': 100 } }
- *
- * _.keyBy(array, 'dir');
- * // => { 'left': { 'dir': 'left', 'code': 97 }, 'right': { 'dir': 'right', 'code': 100 } }
- */var keyBy=createAggregator(function(result,value,key){baseAssignValue(result,key,value);});/**
- * Creates an array of values by running each element in `collection` thru
- * `iteratee`. The iteratee is invoked with three arguments:
- * (value, index|key, collection).
- *
- * Many lodash methods are guarded to work as iteratees for methods like
- * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.
- *
- * The guarded methods are:
- * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,
- * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,
- * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,
- * `template`, `trim`, `trimEnd`, `trimStart`, and `words`
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the new mapped array.
- * @example
- *
- * function square(n) {
- * return n * n;
- * }
- *
- * _.map([4, 8], square);
- * // => [16, 64]
- *
- * _.map({ 'a': 4, 'b': 8 }, square);
- * // => [16, 64] (iteration order is not guaranteed)
- *
- * var users = [
- * { 'user': 'barney' },
- * { 'user': 'fred' }
- * ];
- *
- * // The `_.property` iteratee shorthand.
- * _.map(users, 'user');
- * // => ['barney', 'fred']
- */function map(collection,iteratee){var func=isArray(collection)?arrayMap:baseMap;return func(collection,getIteratee(iteratee,3));}/**
- * This method is like `_.sortBy` except that it allows specifying the sort
- * orders of the iteratees to sort by. If `orders` is unspecified, all values
- * are sorted in ascending order. Otherwise, specify an order of "desc" for
- * descending or "asc" for ascending sort order of corresponding values.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Array[]|Function[]|Object[]|string[]} [iteratees=[_.identity]]
- * The iteratees to sort by.
- * @param {string[]} [orders] The sort orders of `iteratees`.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.
- * @returns {Array} Returns the new sorted array.
- * @example
- *
- * var users = [
- * { 'user': 'fred', 'age': 48 },
- * { 'user': 'barney', 'age': 34 },
- * { 'user': 'fred', 'age': 40 },
- * { 'user': 'barney', 'age': 36 }
- * ];
- *
- * // Sort by `user` in ascending order and by `age` in descending order.
- * _.orderBy(users, ['user', 'age'], ['asc', 'desc']);
- * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]]
- */function orderBy(collection,iteratees,orders,guard){if(collection==null){return[];}if(!isArray(iteratees)){iteratees=iteratees==null?[]:[iteratees];}orders=guard?undefined:orders;if(!isArray(orders)){orders=orders==null?[]:[orders];}return baseOrderBy(collection,iteratees,orders);}/**
- * Creates an array of elements split into two groups, the first of which
- * contains elements `predicate` returns truthy for, the second of which
- * contains elements `predicate` returns falsey for. The predicate is
- * invoked with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the array of grouped elements.
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'age': 36, 'active': false },
- * { 'user': 'fred', 'age': 40, 'active': true },
- * { 'user': 'pebbles', 'age': 1, 'active': false }
- * ];
- *
- * _.partition(users, function(o) { return o.active; });
- * // => objects for [['fred'], ['barney', 'pebbles']]
- *
- * // The `_.matches` iteratee shorthand.
- * _.partition(users, { 'age': 1, 'active': false });
- * // => objects for [['pebbles'], ['barney', 'fred']]
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.partition(users, ['active', false]);
- * // => objects for [['barney', 'pebbles'], ['fred']]
- *
- * // The `_.property` iteratee shorthand.
- * _.partition(users, 'active');
- * // => objects for [['fred'], ['barney', 'pebbles']]
- */var partition=createAggregator(function(result,value,key){result[key?0:1].push(value);},function(){return[[],[]];});/**
- * Reduces `collection` to a value which is the accumulated result of running
- * each element in `collection` thru `iteratee`, where each successive
- * invocation is supplied the return value of the previous. If `accumulator`
- * is not given, the first element of `collection` is used as the initial
- * value. The iteratee is invoked with four arguments:
- * (accumulator, value, index|key, collection).
- *
- * Many lodash methods are guarded to work as iteratees for methods like
- * `_.reduce`, `_.reduceRight`, and `_.transform`.
- *
- * The guarded methods are:
- * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`,
- * and `sortBy`
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @param {*} [accumulator] The initial value.
- * @returns {*} Returns the accumulated value.
- * @see _.reduceRight
- * @example
- *
- * _.reduce([1, 2], function(sum, n) {
- * return sum + n;
- * }, 0);
- * // => 3
- *
- * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {
- * (result[value] || (result[value] = [])).push(key);
- * return result;
- * }, {});
- * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed)
- */function reduce(collection,iteratee,accumulator){var func=isArray(collection)?arrayReduce:baseReduce,initAccum=arguments.length<3;return func(collection,getIteratee(iteratee,4),accumulator,initAccum,baseEach);}/**
- * This method is like `_.reduce` except that it iterates over elements of
- * `collection` from right to left.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @param {*} [accumulator] The initial value.
- * @returns {*} Returns the accumulated value.
- * @see _.reduce
- * @example
- *
- * var array = [[0, 1], [2, 3], [4, 5]];
- *
- * _.reduceRight(array, function(flattened, other) {
- * return flattened.concat(other);
- * }, []);
- * // => [4, 5, 2, 3, 0, 1]
- */function reduceRight(collection,iteratee,accumulator){var func=isArray(collection)?arrayReduceRight:baseReduce,initAccum=arguments.length<3;return func(collection,getIteratee(iteratee,4),accumulator,initAccum,baseEachRight);}/**
- * The opposite of `_.filter`; this method returns the elements of `collection`
- * that `predicate` does **not** return truthy for.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the new filtered array.
- * @see _.filter
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'age': 36, 'active': false },
- * { 'user': 'fred', 'age': 40, 'active': true }
- * ];
- *
- * _.reject(users, function(o) { return !o.active; });
- * // => objects for ['fred']
- *
- * // The `_.matches` iteratee shorthand.
- * _.reject(users, { 'age': 40, 'active': true });
- * // => objects for ['barney']
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.reject(users, ['active', false]);
- * // => objects for ['fred']
- *
- * // The `_.property` iteratee shorthand.
- * _.reject(users, 'active');
- * // => objects for ['barney']
- */function reject(collection,predicate){var func=isArray(collection)?arrayFilter:baseFilter;return func(collection,negate(getIteratee(predicate,3)));}/**
- * Gets a random element from `collection`.
- *
- * @static
- * @memberOf _
- * @since 2.0.0
- * @category Collection
- * @param {Array|Object} collection The collection to sample.
- * @returns {*} Returns the random element.
- * @example
- *
- * _.sample([1, 2, 3, 4]);
- * // => 2
- */function sample(collection){var func=isArray(collection)?arraySample:baseSample;return func(collection);}/**
- * Gets `n` random elements at unique keys from `collection` up to the
- * size of `collection`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Collection
- * @param {Array|Object} collection The collection to sample.
- * @param {number} [n=1] The number of elements to sample.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {Array} Returns the random elements.
- * @example
- *
- * _.sampleSize([1, 2, 3], 2);
- * // => [3, 1]
- *
- * _.sampleSize([1, 2, 3], 4);
- * // => [2, 3, 1]
- */function sampleSize(collection,n,guard){if(guard?isIterateeCall(collection,n,guard):n===undefined){n=1;}else{n=toInteger(n);}var func=isArray(collection)?arraySampleSize:baseSampleSize;return func(collection,n);}/**
- * Creates an array of shuffled values, using a version of the
- * [Fisher-Yates shuffle](https://en.wikipedia.org/wiki/Fisher-Yates_shuffle).
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object} collection The collection to shuffle.
- * @returns {Array} Returns the new shuffled array.
- * @example
- *
- * _.shuffle([1, 2, 3, 4]);
- * // => [4, 1, 3, 2]
- */function shuffle(collection){var func=isArray(collection)?arrayShuffle:baseShuffle;return func(collection);}/**
- * Gets the size of `collection` by returning its length for array-like
- * values or the number of own enumerable string keyed properties for objects.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object|string} collection The collection to inspect.
- * @returns {number} Returns the collection size.
- * @example
- *
- * _.size([1, 2, 3]);
- * // => 3
- *
- * _.size({ 'a': 1, 'b': 2 });
- * // => 2
- *
- * _.size('pebbles');
- * // => 7
- */function size(collection){if(collection==null){return 0;}if(isArrayLike(collection)){return isString(collection)?stringSize(collection):collection.length;}var tag=getTag(collection);if(tag==mapTag||tag==setTag){return collection.size;}return baseKeys(collection).length;}/**
- * Checks if `predicate` returns truthy for **any** element of `collection`.
- * Iteration is stopped once `predicate` returns truthy. The predicate is
- * invoked with three arguments: (value, index|key, collection).
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {boolean} Returns `true` if any element passes the predicate check,
- * else `false`.
- * @example
- *
- * _.some([null, 0, 'yes', false], Boolean);
- * // => true
- *
- * var users = [
- * { 'user': 'barney', 'active': true },
- * { 'user': 'fred', 'active': false }
- * ];
- *
- * // The `_.matches` iteratee shorthand.
- * _.some(users, { 'user': 'barney', 'active': false });
- * // => false
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.some(users, ['active', false]);
- * // => true
- *
- * // The `_.property` iteratee shorthand.
- * _.some(users, 'active');
- * // => true
- */function some(collection,predicate,guard){var func=isArray(collection)?arraySome:baseSome;if(guard&&isIterateeCall(collection,predicate,guard)){predicate=undefined;}return func(collection,getIteratee(predicate,3));}/**
- * Creates an array of elements, sorted in ascending order by the results of
- * running each element in a collection thru each iteratee. This method
- * performs a stable sort, that is, it preserves the original sort order of
- * equal elements. The iteratees are invoked with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Collection
- * @param {Array|Object} collection The collection to iterate over.
- * @param {...(Function|Function[])} [iteratees=[_.identity]]
- * The iteratees to sort by.
- * @returns {Array} Returns the new sorted array.
- * @example
- *
- * var users = [
- * { 'user': 'fred', 'age': 48 },
- * { 'user': 'barney', 'age': 36 },
- * { 'user': 'fred', 'age': 40 },
- * { 'user': 'barney', 'age': 34 }
- * ];
- *
- * _.sortBy(users, [function(o) { return o.user; }]);
- * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]]
- *
- * _.sortBy(users, ['user', 'age']);
- * // => objects for [['barney', 34], ['barney', 36], ['fred', 40], ['fred', 48]]
- */var sortBy=baseRest(function(collection,iteratees){if(collection==null){return[];}var length=iteratees.length;if(length>1&&isIterateeCall(collection,iteratees[0],iteratees[1])){iteratees=[];}else if(length>2&&isIterateeCall(iteratees[0],iteratees[1],iteratees[2])){iteratees=[iteratees[0]];}return baseOrderBy(collection,baseFlatten(iteratees,1),[]);});/* ------------------------------------------------------------------------*//**
- * Gets the timestamp of the number of milliseconds that have elapsed since
- * the Unix epoch (1 January 1970 00:00:00 UTC).
- *
- * @static
- * @memberOf _
- * @since 2.4.0
- * @category Date
- * @returns {number} Returns the timestamp.
- * @example
- *
- * _.defer(function(stamp) {
- * console.log(_.now() - stamp);
- * }, _.now());
- * // => Logs the number of milliseconds it took for the deferred invocation.
- */var now=ctxNow||function(){return root.Date.now();};/* ------------------------------------------------------------------------*//**
- * The opposite of `_.before`; this method creates a function that invokes
- * `func` once it's called `n` or more times.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Function
- * @param {number} n The number of calls before `func` is invoked.
- * @param {Function} func The function to restrict.
- * @returns {Function} Returns the new restricted function.
- * @example
- *
- * var saves = ['profile', 'settings'];
- *
- * var done = _.after(saves.length, function() {
- * console.log('done saving!');
- * });
- *
- * _.forEach(saves, function(type) {
- * asyncSave({ 'type': type, 'complete': done });
- * });
- * // => Logs 'done saving!' after the two async saves have completed.
- */function after(n,func){if(typeof func!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}n=toInteger(n);return function(){if(--n<1){return func.apply(this,arguments);}};}/**
- * Creates a function that invokes `func`, with up to `n` arguments,
- * ignoring any additional arguments.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Function
- * @param {Function} func The function to cap arguments for.
- * @param {number} [n=func.length] The arity cap.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {Function} Returns the new capped function.
- * @example
- *
- * _.map(['6', '8', '10'], _.ary(parseInt, 1));
- * // => [6, 8, 10]
- */function ary(func,n,guard){n=guard?undefined:n;n=func&&n==null?func.length:n;return createWrap(func,WRAP_ARY_FLAG,undefined,undefined,undefined,undefined,n);}/**
- * Creates a function that invokes `func`, with the `this` binding and arguments
- * of the created function, while it's called less than `n` times. Subsequent
- * calls to the created function return the result of the last `func` invocation.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Function
- * @param {number} n The number of calls at which `func` is no longer invoked.
- * @param {Function} func The function to restrict.
- * @returns {Function} Returns the new restricted function.
- * @example
- *
- * jQuery(element).on('click', _.before(5, addContactToList));
- * // => Allows adding up to 4 contacts to the list.
- */function before(n,func){var result;if(typeof func!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}n=toInteger(n);return function(){if(--n>0){result=func.apply(this,arguments);}if(n<=1){func=undefined;}return result;};}/**
- * Creates a function that invokes `func` with the `this` binding of `thisArg`
- * and `partials` prepended to the arguments it receives.
- *
- * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds,
- * may be used as a placeholder for partially applied arguments.
- *
- * **Note:** Unlike native `Function#bind`, this method doesn't set the "length"
- * property of bound functions.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Function
- * @param {Function} func The function to bind.
- * @param {*} thisArg The `this` binding of `func`.
- * @param {...*} [partials] The arguments to be partially applied.
- * @returns {Function} Returns the new bound function.
- * @example
- *
- * function greet(greeting, punctuation) {
- * return greeting + ' ' + this.user + punctuation;
- * }
- *
- * var object = { 'user': 'fred' };
- *
- * var bound = _.bind(greet, object, 'hi');
- * bound('!');
- * // => 'hi fred!'
- *
- * // Bound with placeholders.
- * var bound = _.bind(greet, object, _, '!');
- * bound('hi');
- * // => 'hi fred!'
- */var bind=baseRest(function(func,thisArg,partials){var bitmask=WRAP_BIND_FLAG;if(partials.length){var holders=replaceHolders(partials,getHolder(bind));bitmask|=WRAP_PARTIAL_FLAG;}return createWrap(func,bitmask,thisArg,partials,holders);});/**
- * Creates a function that invokes the method at `object[key]` with `partials`
- * prepended to the arguments it receives.
- *
- * This method differs from `_.bind` by allowing bound functions to reference
- * methods that may be redefined or don't yet exist. See
- * [Peter Michaux's article](http://peter.michaux.ca/articles/lazy-function-definition-pattern)
- * for more details.
- *
- * The `_.bindKey.placeholder` value, which defaults to `_` in monolithic
- * builds, may be used as a placeholder for partially applied arguments.
- *
- * @static
- * @memberOf _
- * @since 0.10.0
- * @category Function
- * @param {Object} object The object to invoke the method on.
- * @param {string} key The key of the method.
- * @param {...*} [partials] The arguments to be partially applied.
- * @returns {Function} Returns the new bound function.
- * @example
- *
- * var object = {
- * 'user': 'fred',
- * 'greet': function(greeting, punctuation) {
- * return greeting + ' ' + this.user + punctuation;
- * }
- * };
- *
- * var bound = _.bindKey(object, 'greet', 'hi');
- * bound('!');
- * // => 'hi fred!'
- *
- * object.greet = function(greeting, punctuation) {
- * return greeting + 'ya ' + this.user + punctuation;
- * };
- *
- * bound('!');
- * // => 'hiya fred!'
- *
- * // Bound with placeholders.
- * var bound = _.bindKey(object, 'greet', _, '!');
- * bound('hi');
- * // => 'hiya fred!'
- */var bindKey=baseRest(function(object,key,partials){var bitmask=WRAP_BIND_FLAG|WRAP_BIND_KEY_FLAG;if(partials.length){var holders=replaceHolders(partials,getHolder(bindKey));bitmask|=WRAP_PARTIAL_FLAG;}return createWrap(key,bitmask,object,partials,holders);});/**
- * Creates a function that accepts arguments of `func` and either invokes
- * `func` returning its result, if at least `arity` number of arguments have
- * been provided, or returns a function that accepts the remaining `func`
- * arguments, and so on. The arity of `func` may be specified if `func.length`
- * is not sufficient.
- *
- * The `_.curry.placeholder` value, which defaults to `_` in monolithic builds,
- * may be used as a placeholder for provided arguments.
- *
- * **Note:** This method doesn't set the "length" property of curried functions.
- *
- * @static
- * @memberOf _
- * @since 2.0.0
- * @category Function
- * @param {Function} func The function to curry.
- * @param {number} [arity=func.length] The arity of `func`.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {Function} Returns the new curried function.
- * @example
- *
- * var abc = function(a, b, c) {
- * return [a, b, c];
- * };
- *
- * var curried = _.curry(abc);
- *
- * curried(1)(2)(3);
- * // => [1, 2, 3]
- *
- * curried(1, 2)(3);
- * // => [1, 2, 3]
- *
- * curried(1, 2, 3);
- * // => [1, 2, 3]
- *
- * // Curried with placeholders.
- * curried(1)(_, 3)(2);
- * // => [1, 2, 3]
- */function curry(func,arity,guard){arity=guard?undefined:arity;var result=createWrap(func,WRAP_CURRY_FLAG,undefined,undefined,undefined,undefined,undefined,arity);result.placeholder=curry.placeholder;return result;}/**
- * This method is like `_.curry` except that arguments are applied to `func`
- * in the manner of `_.partialRight` instead of `_.partial`.
- *
- * The `_.curryRight.placeholder` value, which defaults to `_` in monolithic
- * builds, may be used as a placeholder for provided arguments.
- *
- * **Note:** This method doesn't set the "length" property of curried functions.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Function
- * @param {Function} func The function to curry.
- * @param {number} [arity=func.length] The arity of `func`.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {Function} Returns the new curried function.
- * @example
- *
- * var abc = function(a, b, c) {
- * return [a, b, c];
- * };
- *
- * var curried = _.curryRight(abc);
- *
- * curried(3)(2)(1);
- * // => [1, 2, 3]
- *
- * curried(2, 3)(1);
- * // => [1, 2, 3]
- *
- * curried(1, 2, 3);
- * // => [1, 2, 3]
- *
- * // Curried with placeholders.
- * curried(3)(1, _)(2);
- * // => [1, 2, 3]
- */function curryRight(func,arity,guard){arity=guard?undefined:arity;var result=createWrap(func,WRAP_CURRY_RIGHT_FLAG,undefined,undefined,undefined,undefined,undefined,arity);result.placeholder=curryRight.placeholder;return result;}/**
- * Creates a debounced function that delays invoking `func` until after `wait`
- * milliseconds have elapsed since the last time the debounced function was
- * invoked. The debounced function comes with a `cancel` method to cancel
- * delayed `func` invocations and a `flush` method to immediately invoke them.
- * Provide `options` to indicate whether `func` should be invoked on the
- * leading and/or trailing edge of the `wait` timeout. The `func` is invoked
- * with the last arguments provided to the debounced function. Subsequent
- * calls to the debounced function return the result of the last `func`
- * invocation.
- *
- * **Note:** If `leading` and `trailing` options are `true`, `func` is
- * invoked on the trailing edge of the timeout only if the debounced function
- * is invoked more than once during the `wait` timeout.
- *
- * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred
- * until to the next tick, similar to `setTimeout` with a timeout of `0`.
- *
- * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)
- * for details over the differences between `_.debounce` and `_.throttle`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Function
- * @param {Function} func The function to debounce.
- * @param {number} [wait=0] The number of milliseconds to delay.
- * @param {Object} [options={}] The options object.
- * @param {boolean} [options.leading=false]
- * Specify invoking on the leading edge of the timeout.
- * @param {number} [options.maxWait]
- * The maximum time `func` is allowed to be delayed before it's invoked.
- * @param {boolean} [options.trailing=true]
- * Specify invoking on the trailing edge of the timeout.
- * @returns {Function} Returns the new debounced function.
- * @example
- *
- * // Avoid costly calculations while the window size is in flux.
- * jQuery(window).on('resize', _.debounce(calculateLayout, 150));
- *
- * // Invoke `sendMail` when clicked, debouncing subsequent calls.
- * jQuery(element).on('click', _.debounce(sendMail, 300, {
- * 'leading': true,
- * 'trailing': false
- * }));
- *
- * // Ensure `batchLog` is invoked once after 1 second of debounced calls.
- * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });
- * var source = new EventSource('/stream');
- * jQuery(source).on('message', debounced);
- *
- * // Cancel the trailing debounced invocation.
- * jQuery(window).on('popstate', debounced.cancel);
- */function debounce(func,wait,options){var lastArgs,lastThis,maxWait,result,timerId,lastCallTime,lastInvokeTime=0,leading=false,maxing=false,trailing=true;if(typeof func!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}wait=toNumber(wait)||0;if(isObject(options)){leading=!!options.leading;maxing='maxWait'in options;maxWait=maxing?nativeMax(toNumber(options.maxWait)||0,wait):maxWait;trailing='trailing'in options?!!options.trailing:trailing;}function invokeFunc(time){var args=lastArgs,thisArg=lastThis;lastArgs=lastThis=undefined;lastInvokeTime=time;result=func.apply(thisArg,args);return result;}function leadingEdge(time){// Reset any `maxWait` timer.
- lastInvokeTime=time;// Start the timer for the trailing edge.
- timerId=setTimeout(timerExpired,wait);// Invoke the leading edge.
- return leading?invokeFunc(time):result;}function remainingWait(time){var timeSinceLastCall=time-lastCallTime,timeSinceLastInvoke=time-lastInvokeTime,timeWaiting=wait-timeSinceLastCall;return maxing?nativeMin(timeWaiting,maxWait-timeSinceLastInvoke):timeWaiting;}function shouldInvoke(time){var timeSinceLastCall=time-lastCallTime,timeSinceLastInvoke=time-lastInvokeTime;// Either this is the first call, activity has stopped and we're at the
- // trailing edge, the system time has gone backwards and we're treating
- // it as the trailing edge, or we've hit the `maxWait` limit.
- return lastCallTime===undefined||timeSinceLastCall>=wait||timeSinceLastCall<0||maxing&&timeSinceLastInvoke>=maxWait;}function timerExpired(){var time=now();if(shouldInvoke(time)){return trailingEdge(time);}// Restart the timer.
- timerId=setTimeout(timerExpired,remainingWait(time));}function trailingEdge(time){timerId=undefined;// Only invoke if we have `lastArgs` which means `func` has been
- // debounced at least once.
- if(trailing&&lastArgs){return invokeFunc(time);}lastArgs=lastThis=undefined;return result;}function cancel(){if(timerId!==undefined){clearTimeout(timerId);}lastInvokeTime=0;lastArgs=lastCallTime=lastThis=timerId=undefined;}function flush(){return timerId===undefined?result:trailingEdge(now());}function debounced(){var time=now(),isInvoking=shouldInvoke(time);lastArgs=arguments;lastThis=this;lastCallTime=time;if(isInvoking){if(timerId===undefined){return leadingEdge(lastCallTime);}if(maxing){// Handle invocations in a tight loop.
- timerId=setTimeout(timerExpired,wait);return invokeFunc(lastCallTime);}}if(timerId===undefined){timerId=setTimeout(timerExpired,wait);}return result;}debounced.cancel=cancel;debounced.flush=flush;return debounced;}/**
- * Defers invoking the `func` until the current call stack has cleared. Any
- * additional arguments are provided to `func` when it's invoked.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Function
- * @param {Function} func The function to defer.
- * @param {...*} [args] The arguments to invoke `func` with.
- * @returns {number} Returns the timer id.
- * @example
- *
- * _.defer(function(text) {
- * console.log(text);
- * }, 'deferred');
- * // => Logs 'deferred' after one millisecond.
- */var defer=baseRest(function(func,args){return baseDelay(func,1,args);});/**
- * Invokes `func` after `wait` milliseconds. Any additional arguments are
- * provided to `func` when it's invoked.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Function
- * @param {Function} func The function to delay.
- * @param {number} wait The number of milliseconds to delay invocation.
- * @param {...*} [args] The arguments to invoke `func` with.
- * @returns {number} Returns the timer id.
- * @example
- *
- * _.delay(function(text) {
- * console.log(text);
- * }, 1000, 'later');
- * // => Logs 'later' after one second.
- */var delay=baseRest(function(func,wait,args){return baseDelay(func,toNumber(wait)||0,args);});/**
- * Creates a function that invokes `func` with arguments reversed.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Function
- * @param {Function} func The function to flip arguments for.
- * @returns {Function} Returns the new flipped function.
- * @example
- *
- * var flipped = _.flip(function() {
- * return _.toArray(arguments);
- * });
- *
- * flipped('a', 'b', 'c', 'd');
- * // => ['d', 'c', 'b', 'a']
- */function flip(func){return createWrap(func,WRAP_FLIP_FLAG);}/**
- * Creates a function that memoizes the result of `func`. If `resolver` is
- * provided, it determines the cache key for storing the result based on the
- * arguments provided to the memoized function. By default, the first argument
- * provided to the memoized function is used as the map cache key. The `func`
- * is invoked with the `this` binding of the memoized function.
- *
- * **Note:** The cache is exposed as the `cache` property on the memoized
- * function. Its creation may be customized by replacing the `_.memoize.Cache`
- * constructor with one whose instances implement the
- * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)
- * method interface of `clear`, `delete`, `get`, `has`, and `set`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Function
- * @param {Function} func The function to have its output memoized.
- * @param {Function} [resolver] The function to resolve the cache key.
- * @returns {Function} Returns the new memoized function.
- * @example
- *
- * var object = { 'a': 1, 'b': 2 };
- * var other = { 'c': 3, 'd': 4 };
- *
- * var values = _.memoize(_.values);
- * values(object);
- * // => [1, 2]
- *
- * values(other);
- * // => [3, 4]
- *
- * object.a = 2;
- * values(object);
- * // => [1, 2]
- *
- * // Modify the result cache.
- * values.cache.set(object, ['a', 'b']);
- * values(object);
- * // => ['a', 'b']
- *
- * // Replace `_.memoize.Cache`.
- * _.memoize.Cache = WeakMap;
- */function memoize(func,resolver){if(typeof func!=='function'||resolver!=null&&typeof resolver!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}var memoized=function memoized(){var args=arguments,key=resolver?resolver.apply(this,args):args[0],cache=memoized.cache;if(cache.has(key)){return cache.get(key);}var result=func.apply(this,args);memoized.cache=cache.set(key,result)||cache;return result;};memoized.cache=new(memoize.Cache||MapCache)();return memoized;}// Expose `MapCache`.
- memoize.Cache=MapCache;/**
- * Creates a function that negates the result of the predicate `func`. The
- * `func` predicate is invoked with the `this` binding and arguments of the
- * created function.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Function
- * @param {Function} predicate The predicate to negate.
- * @returns {Function} Returns the new negated function.
- * @example
- *
- * function isEven(n) {
- * return n % 2 == 0;
- * }
- *
- * _.filter([1, 2, 3, 4, 5, 6], _.negate(isEven));
- * // => [1, 3, 5]
- */function negate(predicate){if(typeof predicate!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}return function(){var args=arguments;switch(args.length){case 0:return!predicate.call(this);case 1:return!predicate.call(this,args[0]);case 2:return!predicate.call(this,args[0],args[1]);case 3:return!predicate.call(this,args[0],args[1],args[2]);}return!predicate.apply(this,args);};}/**
- * Creates a function that is restricted to invoking `func` once. Repeat calls
- * to the function return the value of the first invocation. The `func` is
- * invoked with the `this` binding and arguments of the created function.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Function
- * @param {Function} func The function to restrict.
- * @returns {Function} Returns the new restricted function.
- * @example
- *
- * var initialize = _.once(createApplication);
- * initialize();
- * initialize();
- * // => `createApplication` is invoked once
- */function once(func){return before(2,func);}/**
- * Creates a function that invokes `func` with its arguments transformed.
- *
- * @static
- * @since 4.0.0
- * @memberOf _
- * @category Function
- * @param {Function} func The function to wrap.
- * @param {...(Function|Function[])} [transforms=[_.identity]]
- * The argument transforms.
- * @returns {Function} Returns the new function.
- * @example
- *
- * function doubled(n) {
- * return n * 2;
- * }
- *
- * function square(n) {
- * return n * n;
- * }
- *
- * var func = _.overArgs(function(x, y) {
- * return [x, y];
- * }, [square, doubled]);
- *
- * func(9, 3);
- * // => [81, 6]
- *
- * func(10, 5);
- * // => [100, 10]
- */var overArgs=castRest(function(func,transforms){transforms=transforms.length==1&&isArray(transforms[0])?arrayMap(transforms[0],baseUnary(getIteratee())):arrayMap(baseFlatten(transforms,1),baseUnary(getIteratee()));var funcsLength=transforms.length;return baseRest(function(args){var index=-1,length=nativeMin(args.length,funcsLength);while(++index<length){args[index]=transforms[index].call(this,args[index]);}return apply(func,this,args);});});/**
- * Creates a function that invokes `func` with `partials` prepended to the
- * arguments it receives. This method is like `_.bind` except it does **not**
- * alter the `this` binding.
- *
- * The `_.partial.placeholder` value, which defaults to `_` in monolithic
- * builds, may be used as a placeholder for partially applied arguments.
- *
- * **Note:** This method doesn't set the "length" property of partially
- * applied functions.
- *
- * @static
- * @memberOf _
- * @since 0.2.0
- * @category Function
- * @param {Function} func The function to partially apply arguments to.
- * @param {...*} [partials] The arguments to be partially applied.
- * @returns {Function} Returns the new partially applied function.
- * @example
- *
- * function greet(greeting, name) {
- * return greeting + ' ' + name;
- * }
- *
- * var sayHelloTo = _.partial(greet, 'hello');
- * sayHelloTo('fred');
- * // => 'hello fred'
- *
- * // Partially applied with placeholders.
- * var greetFred = _.partial(greet, _, 'fred');
- * greetFred('hi');
- * // => 'hi fred'
- */var partial=baseRest(function(func,partials){var holders=replaceHolders(partials,getHolder(partial));return createWrap(func,WRAP_PARTIAL_FLAG,undefined,partials,holders);});/**
- * This method is like `_.partial` except that partially applied arguments
- * are appended to the arguments it receives.
- *
- * The `_.partialRight.placeholder` value, which defaults to `_` in monolithic
- * builds, may be used as a placeholder for partially applied arguments.
- *
- * **Note:** This method doesn't set the "length" property of partially
- * applied functions.
- *
- * @static
- * @memberOf _
- * @since 1.0.0
- * @category Function
- * @param {Function} func The function to partially apply arguments to.
- * @param {...*} [partials] The arguments to be partially applied.
- * @returns {Function} Returns the new partially applied function.
- * @example
- *
- * function greet(greeting, name) {
- * return greeting + ' ' + name;
- * }
- *
- * var greetFred = _.partialRight(greet, 'fred');
- * greetFred('hi');
- * // => 'hi fred'
- *
- * // Partially applied with placeholders.
- * var sayHelloTo = _.partialRight(greet, 'hello', _);
- * sayHelloTo('fred');
- * // => 'hello fred'
- */var partialRight=baseRest(function(func,partials){var holders=replaceHolders(partials,getHolder(partialRight));return createWrap(func,WRAP_PARTIAL_RIGHT_FLAG,undefined,partials,holders);});/**
- * Creates a function that invokes `func` with arguments arranged according
- * to the specified `indexes` where the argument value at the first index is
- * provided as the first argument, the argument value at the second index is
- * provided as the second argument, and so on.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Function
- * @param {Function} func The function to rearrange arguments for.
- * @param {...(number|number[])} indexes The arranged argument indexes.
- * @returns {Function} Returns the new function.
- * @example
- *
- * var rearged = _.rearg(function(a, b, c) {
- * return [a, b, c];
- * }, [2, 0, 1]);
- *
- * rearged('b', 'c', 'a')
- * // => ['a', 'b', 'c']
- */var rearg=flatRest(function(func,indexes){return createWrap(func,WRAP_REARG_FLAG,undefined,undefined,undefined,indexes);});/**
- * Creates a function that invokes `func` with the `this` binding of the
- * created function and arguments from `start` and beyond provided as
- * an array.
- *
- * **Note:** This method is based on the
- * [rest parameter](https://mdn.io/rest_parameters).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Function
- * @param {Function} func The function to apply a rest parameter to.
- * @param {number} [start=func.length-1] The start position of the rest parameter.
- * @returns {Function} Returns the new function.
- * @example
- *
- * var say = _.rest(function(what, names) {
- * return what + ' ' + _.initial(names).join(', ') +
- * (_.size(names) > 1 ? ', & ' : '') + _.last(names);
- * });
- *
- * say('hello', 'fred', 'barney', 'pebbles');
- * // => 'hello fred, barney, & pebbles'
- */function rest(func,start){if(typeof func!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}start=start===undefined?start:toInteger(start);return baseRest(func,start);}/**
- * Creates a function that invokes `func` with the `this` binding of the
- * create function and an array of arguments much like
- * [`Function#apply`](http://www.ecma-international.org/ecma-262/7.0/#sec-function.prototype.apply).
- *
- * **Note:** This method is based on the
- * [spread operator](https://mdn.io/spread_operator).
- *
- * @static
- * @memberOf _
- * @since 3.2.0
- * @category Function
- * @param {Function} func The function to spread arguments over.
- * @param {number} [start=0] The start position of the spread.
- * @returns {Function} Returns the new function.
- * @example
- *
- * var say = _.spread(function(who, what) {
- * return who + ' says ' + what;
- * });
- *
- * say(['fred', 'hello']);
- * // => 'fred says hello'
- *
- * var numbers = Promise.all([
- * Promise.resolve(40),
- * Promise.resolve(36)
- * ]);
- *
- * numbers.then(_.spread(function(x, y) {
- * return x + y;
- * }));
- * // => a Promise of 76
- */function spread(func,start){if(typeof func!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}start=start==null?0:nativeMax(toInteger(start),0);return baseRest(function(args){var array=args[start],otherArgs=castSlice(args,0,start);if(array){arrayPush(otherArgs,array);}return apply(func,this,otherArgs);});}/**
- * Creates a throttled function that only invokes `func` at most once per
- * every `wait` milliseconds. The throttled function comes with a `cancel`
- * method to cancel delayed `func` invocations and a `flush` method to
- * immediately invoke them. Provide `options` to indicate whether `func`
- * should be invoked on the leading and/or trailing edge of the `wait`
- * timeout. The `func` is invoked with the last arguments provided to the
- * throttled function. Subsequent calls to the throttled function return the
- * result of the last `func` invocation.
- *
- * **Note:** If `leading` and `trailing` options are `true`, `func` is
- * invoked on the trailing edge of the timeout only if the throttled function
- * is invoked more than once during the `wait` timeout.
- *
- * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred
- * until to the next tick, similar to `setTimeout` with a timeout of `0`.
- *
- * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)
- * for details over the differences between `_.throttle` and `_.debounce`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Function
- * @param {Function} func The function to throttle.
- * @param {number} [wait=0] The number of milliseconds to throttle invocations to.
- * @param {Object} [options={}] The options object.
- * @param {boolean} [options.leading=true]
- * Specify invoking on the leading edge of the timeout.
- * @param {boolean} [options.trailing=true]
- * Specify invoking on the trailing edge of the timeout.
- * @returns {Function} Returns the new throttled function.
- * @example
- *
- * // Avoid excessively updating the position while scrolling.
- * jQuery(window).on('scroll', _.throttle(updatePosition, 100));
- *
- * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.
- * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });
- * jQuery(element).on('click', throttled);
- *
- * // Cancel the trailing throttled invocation.
- * jQuery(window).on('popstate', throttled.cancel);
- */function throttle(func,wait,options){var leading=true,trailing=true;if(typeof func!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}if(isObject(options)){leading='leading'in options?!!options.leading:leading;trailing='trailing'in options?!!options.trailing:trailing;}return debounce(func,wait,{leading:leading,maxWait:wait,trailing:trailing});}/**
- * Creates a function that accepts up to one argument, ignoring any
- * additional arguments.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Function
- * @param {Function} func The function to cap arguments for.
- * @returns {Function} Returns the new capped function.
- * @example
- *
- * _.map(['6', '8', '10'], _.unary(parseInt));
- * // => [6, 8, 10]
- */function unary(func){return ary(func,1);}/**
- * Creates a function that provides `value` to `wrapper` as its first
- * argument. Any additional arguments provided to the function are appended
- * to those provided to the `wrapper`. The wrapper is invoked with the `this`
- * binding of the created function.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Function
- * @param {*} value The value to wrap.
- * @param {Function} [wrapper=identity] The wrapper function.
- * @returns {Function} Returns the new function.
- * @example
- *
- * var p = _.wrap(_.escape, function(func, text) {
- * return '<p>' + func(text) + '</p>';
- * });
- *
- * p('fred, barney, & pebbles');
- * // => '<p>fred, barney, & pebbles</p>'
- */function wrap(value,wrapper){return partial(castFunction(wrapper),value);}/* ------------------------------------------------------------------------*//**
- * Casts `value` as an array if it's not one.
- *
- * @static
- * @memberOf _
- * @since 4.4.0
- * @category Lang
- * @param {*} value The value to inspect.
- * @returns {Array} Returns the cast array.
- * @example
- *
- * _.castArray(1);
- * // => [1]
- *
- * _.castArray({ 'a': 1 });
- * // => [{ 'a': 1 }]
- *
- * _.castArray('abc');
- * // => ['abc']
- *
- * _.castArray(null);
- * // => [null]
- *
- * _.castArray(undefined);
- * // => [undefined]
- *
- * _.castArray();
- * // => []
- *
- * var array = [1, 2, 3];
- * console.log(_.castArray(array) === array);
- * // => true
- */function castArray(){if(!arguments.length){return[];}var value=arguments[0];return isArray(value)?value:[value];}/**
- * Creates a shallow clone of `value`.
- *
- * **Note:** This method is loosely based on the
- * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)
- * and supports cloning arrays, array buffers, booleans, date objects, maps,
- * numbers, `Object` objects, regexes, sets, strings, symbols, and typed
- * arrays. The own enumerable properties of `arguments` objects are cloned
- * as plain objects. An empty object is returned for uncloneable values such
- * as error objects, functions, DOM nodes, and WeakMaps.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to clone.
- * @returns {*} Returns the cloned value.
- * @see _.cloneDeep
- * @example
- *
- * var objects = [{ 'a': 1 }, { 'b': 2 }];
- *
- * var shallow = _.clone(objects);
- * console.log(shallow[0] === objects[0]);
- * // => true
- */function clone(value){return baseClone(value,CLONE_SYMBOLS_FLAG);}/**
- * This method is like `_.clone` except that it accepts `customizer` which
- * is invoked to produce the cloned value. If `customizer` returns `undefined`,
- * cloning is handled by the method instead. The `customizer` is invoked with
- * up to four arguments; (value [, index|key, object, stack]).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to clone.
- * @param {Function} [customizer] The function to customize cloning.
- * @returns {*} Returns the cloned value.
- * @see _.cloneDeepWith
- * @example
- *
- * function customizer(value) {
- * if (_.isElement(value)) {
- * return value.cloneNode(false);
- * }
- * }
- *
- * var el = _.cloneWith(document.body, customizer);
- *
- * console.log(el === document.body);
- * // => false
- * console.log(el.nodeName);
- * // => 'BODY'
- * console.log(el.childNodes.length);
- * // => 0
- */function cloneWith(value,customizer){customizer=typeof customizer==='function'?customizer:undefined;return baseClone(value,CLONE_SYMBOLS_FLAG,customizer);}/**
- * This method is like `_.clone` except that it recursively clones `value`.
- *
- * @static
- * @memberOf _
- * @since 1.0.0
- * @category Lang
- * @param {*} value The value to recursively clone.
- * @returns {*} Returns the deep cloned value.
- * @see _.clone
- * @example
- *
- * var objects = [{ 'a': 1 }, { 'b': 2 }];
- *
- * var deep = _.cloneDeep(objects);
- * console.log(deep[0] === objects[0]);
- * // => false
- */function cloneDeep(value){return baseClone(value,CLONE_DEEP_FLAG|CLONE_SYMBOLS_FLAG);}/**
- * This method is like `_.cloneWith` except that it recursively clones `value`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to recursively clone.
- * @param {Function} [customizer] The function to customize cloning.
- * @returns {*} Returns the deep cloned value.
- * @see _.cloneWith
- * @example
- *
- * function customizer(value) {
- * if (_.isElement(value)) {
- * return value.cloneNode(true);
- * }
- * }
- *
- * var el = _.cloneDeepWith(document.body, customizer);
- *
- * console.log(el === document.body);
- * // => false
- * console.log(el.nodeName);
- * // => 'BODY'
- * console.log(el.childNodes.length);
- * // => 20
- */function cloneDeepWith(value,customizer){customizer=typeof customizer==='function'?customizer:undefined;return baseClone(value,CLONE_DEEP_FLAG|CLONE_SYMBOLS_FLAG,customizer);}/**
- * Checks if `object` conforms to `source` by invoking the predicate
- * properties of `source` with the corresponding property values of `object`.
- *
- * **Note:** This method is equivalent to `_.conforms` when `source` is
- * partially applied.
- *
- * @static
- * @memberOf _
- * @since 4.14.0
- * @category Lang
- * @param {Object} object The object to inspect.
- * @param {Object} source The object of property predicates to conform to.
- * @returns {boolean} Returns `true` if `object` conforms, else `false`.
- * @example
- *
- * var object = { 'a': 1, 'b': 2 };
- *
- * _.conformsTo(object, { 'b': function(n) { return n > 1; } });
- * // => true
- *
- * _.conformsTo(object, { 'b': function(n) { return n > 2; } });
- * // => false
- */function conformsTo(object,source){return source==null||baseConformsTo(object,source,keys(source));}/**
- * Performs a
- * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * comparison between two values to determine if they are equivalent.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @returns {boolean} Returns `true` if the values are equivalent, else `false`.
- * @example
- *
- * var object = { 'a': 1 };
- * var other = { 'a': 1 };
- *
- * _.eq(object, object);
- * // => true
- *
- * _.eq(object, other);
- * // => false
- *
- * _.eq('a', 'a');
- * // => true
- *
- * _.eq('a', Object('a'));
- * // => false
- *
- * _.eq(NaN, NaN);
- * // => true
- */function eq(value,other){return value===other||value!==value&&other!==other;}/**
- * Checks if `value` is greater than `other`.
- *
- * @static
- * @memberOf _
- * @since 3.9.0
- * @category Lang
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @returns {boolean} Returns `true` if `value` is greater than `other`,
- * else `false`.
- * @see _.lt
- * @example
- *
- * _.gt(3, 1);
- * // => true
- *
- * _.gt(3, 3);
- * // => false
- *
- * _.gt(1, 3);
- * // => false
- */var gt=createRelationalOperation(baseGt);/**
- * Checks if `value` is greater than or equal to `other`.
- *
- * @static
- * @memberOf _
- * @since 3.9.0
- * @category Lang
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @returns {boolean} Returns `true` if `value` is greater than or equal to
- * `other`, else `false`.
- * @see _.lte
- * @example
- *
- * _.gte(3, 1);
- * // => true
- *
- * _.gte(3, 3);
- * // => true
- *
- * _.gte(1, 3);
- * // => false
- */var gte=createRelationalOperation(function(value,other){return value>=other;});/**
- * Checks if `value` is likely an `arguments` object.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an `arguments` object,
- * else `false`.
- * @example
- *
- * _.isArguments(function() { return arguments; }());
- * // => true
- *
- * _.isArguments([1, 2, 3]);
- * // => false
- */var isArguments=baseIsArguments(function(){return arguments;}())?baseIsArguments:function(value){return isObjectLike(value)&&hasOwnProperty.call(value,'callee')&&!propertyIsEnumerable.call(value,'callee');};/**
- * Checks if `value` is classified as an `Array` object.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an array, else `false`.
- * @example
- *
- * _.isArray([1, 2, 3]);
- * // => true
- *
- * _.isArray(document.body.children);
- * // => false
- *
- * _.isArray('abc');
- * // => false
- *
- * _.isArray(_.noop);
- * // => false
- */var isArray=Array.isArray;/**
- * Checks if `value` is classified as an `ArrayBuffer` object.
- *
- * @static
- * @memberOf _
- * @since 4.3.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.
- * @example
- *
- * _.isArrayBuffer(new ArrayBuffer(2));
- * // => true
- *
- * _.isArrayBuffer(new Array(2));
- * // => false
- */var isArrayBuffer=nodeIsArrayBuffer?baseUnary(nodeIsArrayBuffer):baseIsArrayBuffer;/**
- * Checks if `value` is array-like. A value is considered array-like if it's
- * not a function and has a `value.length` that's an integer greater than or
- * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is array-like, else `false`.
- * @example
- *
- * _.isArrayLike([1, 2, 3]);
- * // => true
- *
- * _.isArrayLike(document.body.children);
- * // => true
- *
- * _.isArrayLike('abc');
- * // => true
- *
- * _.isArrayLike(_.noop);
- * // => false
- */function isArrayLike(value){return value!=null&&isLength(value.length)&&!isFunction(value);}/**
- * This method is like `_.isArrayLike` except that it also checks if `value`
- * is an object.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an array-like object,
- * else `false`.
- * @example
- *
- * _.isArrayLikeObject([1, 2, 3]);
- * // => true
- *
- * _.isArrayLikeObject(document.body.children);
- * // => true
- *
- * _.isArrayLikeObject('abc');
- * // => false
- *
- * _.isArrayLikeObject(_.noop);
- * // => false
- */function isArrayLikeObject(value){return isObjectLike(value)&&isArrayLike(value);}/**
- * Checks if `value` is classified as a boolean primitive or object.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a boolean, else `false`.
- * @example
- *
- * _.isBoolean(false);
- * // => true
- *
- * _.isBoolean(null);
- * // => false
- */function isBoolean(value){return value===true||value===false||isObjectLike(value)&&baseGetTag(value)==boolTag;}/**
- * Checks if `value` is a buffer.
- *
- * @static
- * @memberOf _
- * @since 4.3.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.
- * @example
- *
- * _.isBuffer(new Buffer(2));
- * // => true
- *
- * _.isBuffer(new Uint8Array(2));
- * // => false
- */var isBuffer=nativeIsBuffer||stubFalse;/**
- * Checks if `value` is classified as a `Date` object.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a date object, else `false`.
- * @example
- *
- * _.isDate(new Date);
- * // => true
- *
- * _.isDate('Mon April 23 2012');
- * // => false
- */var isDate=nodeIsDate?baseUnary(nodeIsDate):baseIsDate;/**
- * Checks if `value` is likely a DOM element.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a DOM element, else `false`.
- * @example
- *
- * _.isElement(document.body);
- * // => true
- *
- * _.isElement('<body>');
- * // => false
- */function isElement(value){return isObjectLike(value)&&value.nodeType===1&&!isPlainObject(value);}/**
- * Checks if `value` is an empty object, collection, map, or set.
- *
- * Objects are considered empty if they have no own enumerable string keyed
- * properties.
- *
- * Array-like values such as `arguments` objects, arrays, buffers, strings, or
- * jQuery-like collections are considered empty if they have a `length` of `0`.
- * Similarly, maps and sets are considered empty if they have a `size` of `0`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is empty, else `false`.
- * @example
- *
- * _.isEmpty(null);
- * // => true
- *
- * _.isEmpty(true);
- * // => true
- *
- * _.isEmpty(1);
- * // => true
- *
- * _.isEmpty([1, 2, 3]);
- * // => false
- *
- * _.isEmpty({ 'a': 1 });
- * // => false
- */function isEmpty(value){if(value==null){return true;}if(isArrayLike(value)&&(isArray(value)||typeof value==='string'||typeof value.splice==='function'||isBuffer(value)||isTypedArray(value)||isArguments(value))){return!value.length;}var tag=getTag(value);if(tag==mapTag||tag==setTag){return!value.size;}if(isPrototype(value)){return!baseKeys(value).length;}for(var key in value){if(hasOwnProperty.call(value,key)){return false;}}return true;}/**
- * Performs a deep comparison between two values to determine if they are
- * equivalent.
- *
- * **Note:** This method supports comparing arrays, array buffers, booleans,
- * date objects, error objects, maps, numbers, `Object` objects, regexes,
- * sets, strings, symbols, and typed arrays. `Object` objects are compared
- * by their own, not inherited, enumerable properties. Functions and DOM
- * nodes are compared by strict equality, i.e. `===`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @returns {boolean} Returns `true` if the values are equivalent, else `false`.
- * @example
- *
- * var object = { 'a': 1 };
- * var other = { 'a': 1 };
- *
- * _.isEqual(object, other);
- * // => true
- *
- * object === other;
- * // => false
- */function isEqual(value,other){return baseIsEqual(value,other);}/**
- * This method is like `_.isEqual` except that it accepts `customizer` which
- * is invoked to compare values. If `customizer` returns `undefined`, comparisons
- * are handled by the method instead. The `customizer` is invoked with up to
- * six arguments: (objValue, othValue [, index|key, object, other, stack]).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @param {Function} [customizer] The function to customize comparisons.
- * @returns {boolean} Returns `true` if the values are equivalent, else `false`.
- * @example
- *
- * function isGreeting(value) {
- * return /^h(?:i|ello)$/.test(value);
- * }
- *
- * function customizer(objValue, othValue) {
- * if (isGreeting(objValue) && isGreeting(othValue)) {
- * return true;
- * }
- * }
- *
- * var array = ['hello', 'goodbye'];
- * var other = ['hi', 'goodbye'];
- *
- * _.isEqualWith(array, other, customizer);
- * // => true
- */function isEqualWith(value,other,customizer){customizer=typeof customizer==='function'?customizer:undefined;var result=customizer?customizer(value,other):undefined;return result===undefined?baseIsEqual(value,other,undefined,customizer):!!result;}/**
- * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`,
- * `SyntaxError`, `TypeError`, or `URIError` object.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an error object, else `false`.
- * @example
- *
- * _.isError(new Error);
- * // => true
- *
- * _.isError(Error);
- * // => false
- */function isError(value){if(!isObjectLike(value)){return false;}var tag=baseGetTag(value);return tag==errorTag||tag==domExcTag||typeof value.message==='string'&&typeof value.name==='string'&&!isPlainObject(value);}/**
- * Checks if `value` is a finite primitive number.
- *
- * **Note:** This method is based on
- * [`Number.isFinite`](https://mdn.io/Number/isFinite).
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a finite number, else `false`.
- * @example
- *
- * _.isFinite(3);
- * // => true
- *
- * _.isFinite(Number.MIN_VALUE);
- * // => true
- *
- * _.isFinite(Infinity);
- * // => false
- *
- * _.isFinite('3');
- * // => false
- */function isFinite(value){return typeof value==='number'&&nativeIsFinite(value);}/**
- * Checks if `value` is classified as a `Function` object.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a function, else `false`.
- * @example
- *
- * _.isFunction(_);
- * // => true
- *
- * _.isFunction(/abc/);
- * // => false
- */function isFunction(value){if(!isObject(value)){return false;}// The use of `Object#toString` avoids issues with the `typeof` operator
- // in Safari 9 which returns 'object' for typed arrays and other constructors.
- var tag=baseGetTag(value);return tag==funcTag||tag==genTag||tag==asyncTag||tag==proxyTag;}/**
- * Checks if `value` is an integer.
- *
- * **Note:** This method is based on
- * [`Number.isInteger`](https://mdn.io/Number/isInteger).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an integer, else `false`.
- * @example
- *
- * _.isInteger(3);
- * // => true
- *
- * _.isInteger(Number.MIN_VALUE);
- * // => false
- *
- * _.isInteger(Infinity);
- * // => false
- *
- * _.isInteger('3');
- * // => false
- */function isInteger(value){return typeof value==='number'&&value==toInteger(value);}/**
- * Checks if `value` is a valid array-like length.
- *
- * **Note:** This method is loosely based on
- * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.
- * @example
- *
- * _.isLength(3);
- * // => true
- *
- * _.isLength(Number.MIN_VALUE);
- * // => false
- *
- * _.isLength(Infinity);
- * // => false
- *
- * _.isLength('3');
- * // => false
- */function isLength(value){return typeof value==='number'&&value>-1&&value%1==0&&value<=MAX_SAFE_INTEGER;}/**
- * Checks if `value` is the
- * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
- * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an object, else `false`.
- * @example
- *
- * _.isObject({});
- * // => true
- *
- * _.isObject([1, 2, 3]);
- * // => true
- *
- * _.isObject(_.noop);
- * // => true
- *
- * _.isObject(null);
- * // => false
- */function isObject(value){var type=typeof value==='undefined'?'undefined':_typeof(value);return value!=null&&(type=='object'||type=='function');}/**
- * Checks if `value` is object-like. A value is object-like if it's not `null`
- * and has a `typeof` result of "object".
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is object-like, else `false`.
- * @example
- *
- * _.isObjectLike({});
- * // => true
- *
- * _.isObjectLike([1, 2, 3]);
- * // => true
- *
- * _.isObjectLike(_.noop);
- * // => false
- *
- * _.isObjectLike(null);
- * // => false
- */function isObjectLike(value){return value!=null&&(typeof value==='undefined'?'undefined':_typeof(value))==='object';}/**
- * Checks if `value` is classified as a `Map` object.
- *
- * @static
- * @memberOf _
- * @since 4.3.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a map, else `false`.
- * @example
- *
- * _.isMap(new Map);
- * // => true
- *
- * _.isMap(new WeakMap);
- * // => false
- */var isMap=nodeIsMap?baseUnary(nodeIsMap):baseIsMap;/**
- * Performs a partial deep comparison between `object` and `source` to
- * determine if `object` contains equivalent property values.
- *
- * **Note:** This method is equivalent to `_.matches` when `source` is
- * partially applied.
- *
- * Partial comparisons will match empty array and empty object `source`
- * values against any array or object value, respectively. See `_.isEqual`
- * for a list of supported value comparisons.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Lang
- * @param {Object} object The object to inspect.
- * @param {Object} source The object of property values to match.
- * @returns {boolean} Returns `true` if `object` is a match, else `false`.
- * @example
- *
- * var object = { 'a': 1, 'b': 2 };
- *
- * _.isMatch(object, { 'b': 2 });
- * // => true
- *
- * _.isMatch(object, { 'b': 1 });
- * // => false
- */function isMatch(object,source){return object===source||baseIsMatch(object,source,getMatchData(source));}/**
- * This method is like `_.isMatch` except that it accepts `customizer` which
- * is invoked to compare values. If `customizer` returns `undefined`, comparisons
- * are handled by the method instead. The `customizer` is invoked with five
- * arguments: (objValue, srcValue, index|key, object, source).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {Object} object The object to inspect.
- * @param {Object} source The object of property values to match.
- * @param {Function} [customizer] The function to customize comparisons.
- * @returns {boolean} Returns `true` if `object` is a match, else `false`.
- * @example
- *
- * function isGreeting(value) {
- * return /^h(?:i|ello)$/.test(value);
- * }
- *
- * function customizer(objValue, srcValue) {
- * if (isGreeting(objValue) && isGreeting(srcValue)) {
- * return true;
- * }
- * }
- *
- * var object = { 'greeting': 'hello' };
- * var source = { 'greeting': 'hi' };
- *
- * _.isMatchWith(object, source, customizer);
- * // => true
- */function isMatchWith(object,source,customizer){customizer=typeof customizer==='function'?customizer:undefined;return baseIsMatch(object,source,getMatchData(source),customizer);}/**
- * Checks if `value` is `NaN`.
- *
- * **Note:** This method is based on
- * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as
- * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for
- * `undefined` and other non-number values.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.
- * @example
- *
- * _.isNaN(NaN);
- * // => true
- *
- * _.isNaN(new Number(NaN));
- * // => true
- *
- * isNaN(undefined);
- * // => true
- *
- * _.isNaN(undefined);
- * // => false
- */function isNaN(value){// An `NaN` primitive is the only value that is not equal to itself.
- // Perform the `toStringTag` check first to avoid errors with some
- // ActiveX objects in IE.
- return isNumber(value)&&value!=+value;}/**
- * Checks if `value` is a pristine native function.
- *
- * **Note:** This method can't reliably detect native functions in the presence
- * of the core-js package because core-js circumvents this kind of detection.
- * Despite multiple requests, the core-js maintainer has made it clear: any
- * attempt to fix the detection will be obstructed. As a result, we're left
- * with little choice but to throw an error. Unfortunately, this also affects
- * packages, like [babel-polyfill](https://www.npmjs.com/package/babel-polyfill),
- * which rely on core-js.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a native function,
- * else `false`.
- * @example
- *
- * _.isNative(Array.prototype.push);
- * // => true
- *
- * _.isNative(_);
- * // => false
- */function isNative(value){if(isMaskable(value)){throw new Error(CORE_ERROR_TEXT);}return baseIsNative(value);}/**
- * Checks if `value` is `null`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is `null`, else `false`.
- * @example
- *
- * _.isNull(null);
- * // => true
- *
- * _.isNull(void 0);
- * // => false
- */function isNull(value){return value===null;}/**
- * Checks if `value` is `null` or `undefined`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is nullish, else `false`.
- * @example
- *
- * _.isNil(null);
- * // => true
- *
- * _.isNil(void 0);
- * // => true
- *
- * _.isNil(NaN);
- * // => false
- */function isNil(value){return value==null;}/**
- * Checks if `value` is classified as a `Number` primitive or object.
- *
- * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are
- * classified as numbers, use the `_.isFinite` method.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a number, else `false`.
- * @example
- *
- * _.isNumber(3);
- * // => true
- *
- * _.isNumber(Number.MIN_VALUE);
- * // => true
- *
- * _.isNumber(Infinity);
- * // => true
- *
- * _.isNumber('3');
- * // => false
- */function isNumber(value){return typeof value==='number'||isObjectLike(value)&&baseGetTag(value)==numberTag;}/**
- * Checks if `value` is a plain object, that is, an object created by the
- * `Object` constructor or one with a `[[Prototype]]` of `null`.
- *
- * @static
- * @memberOf _
- * @since 0.8.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * }
- *
- * _.isPlainObject(new Foo);
- * // => false
- *
- * _.isPlainObject([1, 2, 3]);
- * // => false
- *
- * _.isPlainObject({ 'x': 0, 'y': 0 });
- * // => true
- *
- * _.isPlainObject(Object.create(null));
- * // => true
- */function isPlainObject(value){if(!isObjectLike(value)||baseGetTag(value)!=objectTag){return false;}var proto=getPrototype(value);if(proto===null){return true;}var Ctor=hasOwnProperty.call(proto,'constructor')&&proto.constructor;return typeof Ctor==='function'&&Ctor instanceof Ctor&&funcToString.call(Ctor)==objectCtorString;}/**
- * Checks if `value` is classified as a `RegExp` object.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.
- * @example
- *
- * _.isRegExp(/abc/);
- * // => true
- *
- * _.isRegExp('/abc/');
- * // => false
- */var isRegExp=nodeIsRegExp?baseUnary(nodeIsRegExp):baseIsRegExp;/**
- * Checks if `value` is a safe integer. An integer is safe if it's an IEEE-754
- * double precision number which isn't the result of a rounded unsafe integer.
- *
- * **Note:** This method is based on
- * [`Number.isSafeInteger`](https://mdn.io/Number/isSafeInteger).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a safe integer, else `false`.
- * @example
- *
- * _.isSafeInteger(3);
- * // => true
- *
- * _.isSafeInteger(Number.MIN_VALUE);
- * // => false
- *
- * _.isSafeInteger(Infinity);
- * // => false
- *
- * _.isSafeInteger('3');
- * // => false
- */function isSafeInteger(value){return isInteger(value)&&value>=-MAX_SAFE_INTEGER&&value<=MAX_SAFE_INTEGER;}/**
- * Checks if `value` is classified as a `Set` object.
- *
- * @static
- * @memberOf _
- * @since 4.3.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a set, else `false`.
- * @example
- *
- * _.isSet(new Set);
- * // => true
- *
- * _.isSet(new WeakSet);
- * // => false
- */var isSet=nodeIsSet?baseUnary(nodeIsSet):baseIsSet;/**
- * Checks if `value` is classified as a `String` primitive or object.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a string, else `false`.
- * @example
- *
- * _.isString('abc');
- * // => true
- *
- * _.isString(1);
- * // => false
- */function isString(value){return typeof value==='string'||!isArray(value)&&isObjectLike(value)&&baseGetTag(value)==stringTag;}/**
- * Checks if `value` is classified as a `Symbol` primitive or object.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.
- * @example
- *
- * _.isSymbol(Symbol.iterator);
- * // => true
- *
- * _.isSymbol('abc');
- * // => false
- */function isSymbol(value){return(typeof value==='undefined'?'undefined':_typeof(value))==='symbol'||isObjectLike(value)&&baseGetTag(value)==symbolTag;}/**
- * Checks if `value` is classified as a typed array.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.
- * @example
- *
- * _.isTypedArray(new Uint8Array);
- * // => true
- *
- * _.isTypedArray([]);
- * // => false
- */var isTypedArray=nodeIsTypedArray?baseUnary(nodeIsTypedArray):baseIsTypedArray;/**
- * Checks if `value` is `undefined`.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`.
- * @example
- *
- * _.isUndefined(void 0);
- * // => true
- *
- * _.isUndefined(null);
- * // => false
- */function isUndefined(value){return value===undefined;}/**
- * Checks if `value` is classified as a `WeakMap` object.
- *
- * @static
- * @memberOf _
- * @since 4.3.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a weak map, else `false`.
- * @example
- *
- * _.isWeakMap(new WeakMap);
- * // => true
- *
- * _.isWeakMap(new Map);
- * // => false
- */function isWeakMap(value){return isObjectLike(value)&&getTag(value)==weakMapTag;}/**
- * Checks if `value` is classified as a `WeakSet` object.
- *
- * @static
- * @memberOf _
- * @since 4.3.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a weak set, else `false`.
- * @example
- *
- * _.isWeakSet(new WeakSet);
- * // => true
- *
- * _.isWeakSet(new Set);
- * // => false
- */function isWeakSet(value){return isObjectLike(value)&&baseGetTag(value)==weakSetTag;}/**
- * Checks if `value` is less than `other`.
- *
- * @static
- * @memberOf _
- * @since 3.9.0
- * @category Lang
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @returns {boolean} Returns `true` if `value` is less than `other`,
- * else `false`.
- * @see _.gt
- * @example
- *
- * _.lt(1, 3);
- * // => true
- *
- * _.lt(3, 3);
- * // => false
- *
- * _.lt(3, 1);
- * // => false
- */var lt=createRelationalOperation(baseLt);/**
- * Checks if `value` is less than or equal to `other`.
- *
- * @static
- * @memberOf _
- * @since 3.9.0
- * @category Lang
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @returns {boolean} Returns `true` if `value` is less than or equal to
- * `other`, else `false`.
- * @see _.gte
- * @example
- *
- * _.lte(1, 3);
- * // => true
- *
- * _.lte(3, 3);
- * // => true
- *
- * _.lte(3, 1);
- * // => false
- */var lte=createRelationalOperation(function(value,other){return value<=other;});/**
- * Converts `value` to an array.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Lang
- * @param {*} value The value to convert.
- * @returns {Array} Returns the converted array.
- * @example
- *
- * _.toArray({ 'a': 1, 'b': 2 });
- * // => [1, 2]
- *
- * _.toArray('abc');
- * // => ['a', 'b', 'c']
- *
- * _.toArray(1);
- * // => []
- *
- * _.toArray(null);
- * // => []
- */function toArray(value){if(!value){return[];}if(isArrayLike(value)){return isString(value)?stringToArray(value):copyArray(value);}if(symIterator&&value[symIterator]){return iteratorToArray(value[symIterator]());}var tag=getTag(value),func=tag==mapTag?mapToArray:tag==setTag?setToArray:values;return func(value);}/**
- * Converts `value` to a finite number.
- *
- * @static
- * @memberOf _
- * @since 4.12.0
- * @category Lang
- * @param {*} value The value to convert.
- * @returns {number} Returns the converted number.
- * @example
- *
- * _.toFinite(3.2);
- * // => 3.2
- *
- * _.toFinite(Number.MIN_VALUE);
- * // => 5e-324
- *
- * _.toFinite(Infinity);
- * // => 1.7976931348623157e+308
- *
- * _.toFinite('3.2');
- * // => 3.2
- */function toFinite(value){if(!value){return value===0?value:0;}value=toNumber(value);if(value===INFINITY||value===-INFINITY){var sign=value<0?-1:1;return sign*MAX_INTEGER;}return value===value?value:0;}/**
- * Converts `value` to an integer.
- *
- * **Note:** This method is loosely based on
- * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to convert.
- * @returns {number} Returns the converted integer.
- * @example
- *
- * _.toInteger(3.2);
- * // => 3
- *
- * _.toInteger(Number.MIN_VALUE);
- * // => 0
- *
- * _.toInteger(Infinity);
- * // => 1.7976931348623157e+308
- *
- * _.toInteger('3.2');
- * // => 3
- */function toInteger(value){var result=toFinite(value),remainder=result%1;return result===result?remainder?result-remainder:result:0;}/**
- * Converts `value` to an integer suitable for use as the length of an
- * array-like object.
- *
- * **Note:** This method is based on
- * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to convert.
- * @returns {number} Returns the converted integer.
- * @example
- *
- * _.toLength(3.2);
- * // => 3
- *
- * _.toLength(Number.MIN_VALUE);
- * // => 0
- *
- * _.toLength(Infinity);
- * // => 4294967295
- *
- * _.toLength('3.2');
- * // => 3
- */function toLength(value){return value?baseClamp(toInteger(value),0,MAX_ARRAY_LENGTH):0;}/**
- * Converts `value` to a number.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to process.
- * @returns {number} Returns the number.
- * @example
- *
- * _.toNumber(3.2);
- * // => 3.2
- *
- * _.toNumber(Number.MIN_VALUE);
- * // => 5e-324
- *
- * _.toNumber(Infinity);
- * // => Infinity
- *
- * _.toNumber('3.2');
- * // => 3.2
- */function toNumber(value){if(typeof value==='number'){return value;}if(isSymbol(value)){return NAN;}if(isObject(value)){var other=typeof value.valueOf==='function'?value.valueOf():value;value=isObject(other)?other+'':other;}if(typeof value!=='string'){return value===0?value:+value;}value=value.replace(reTrim,'');var isBinary=reIsBinary.test(value);return isBinary||reIsOctal.test(value)?freeParseInt(value.slice(2),isBinary?2:8):reIsBadHex.test(value)?NAN:+value;}/**
- * Converts `value` to a plain object flattening inherited enumerable string
- * keyed properties of `value` to own properties of the plain object.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Lang
- * @param {*} value The value to convert.
- * @returns {Object} Returns the converted plain object.
- * @example
- *
- * function Foo() {
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.assign({ 'a': 1 }, new Foo);
- * // => { 'a': 1, 'b': 2 }
- *
- * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));
- * // => { 'a': 1, 'b': 2, 'c': 3 }
- */function toPlainObject(value){return copyObject(value,keysIn(value));}/**
- * Converts `value` to a safe integer. A safe integer can be compared and
- * represented correctly.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to convert.
- * @returns {number} Returns the converted integer.
- * @example
- *
- * _.toSafeInteger(3.2);
- * // => 3
- *
- * _.toSafeInteger(Number.MIN_VALUE);
- * // => 0
- *
- * _.toSafeInteger(Infinity);
- * // => 9007199254740991
- *
- * _.toSafeInteger('3.2');
- * // => 3
- */function toSafeInteger(value){return value?baseClamp(toInteger(value),-MAX_SAFE_INTEGER,MAX_SAFE_INTEGER):value===0?value:0;}/**
- * Converts `value` to a string. An empty string is returned for `null`
- * and `undefined` values. The sign of `-0` is preserved.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to convert.
- * @returns {string} Returns the converted string.
- * @example
- *
- * _.toString(null);
- * // => ''
- *
- * _.toString(-0);
- * // => '-0'
- *
- * _.toString([1, 2, 3]);
- * // => '1,2,3'
- */function toString(value){return value==null?'':baseToString(value);}/* ------------------------------------------------------------------------*//**
- * Assigns own enumerable string keyed properties of source objects to the
- * destination object. Source objects are applied from left to right.
- * Subsequent sources overwrite property assignments of previous sources.
- *
- * **Note:** This method mutates `object` and is loosely based on
- * [`Object.assign`](https://mdn.io/Object/assign).
- *
- * @static
- * @memberOf _
- * @since 0.10.0
- * @category Object
- * @param {Object} object The destination object.
- * @param {...Object} [sources] The source objects.
- * @returns {Object} Returns `object`.
- * @see _.assignIn
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * }
- *
- * function Bar() {
- * this.c = 3;
- * }
- *
- * Foo.prototype.b = 2;
- * Bar.prototype.d = 4;
- *
- * _.assign({ 'a': 0 }, new Foo, new Bar);
- * // => { 'a': 1, 'c': 3 }
- */var assign=createAssigner(function(object,source){if(isPrototype(source)||isArrayLike(source)){copyObject(source,keys(source),object);return;}for(var key in source){if(hasOwnProperty.call(source,key)){assignValue(object,key,source[key]);}}});/**
- * This method is like `_.assign` except that it iterates over own and
- * inherited source properties.
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @alias extend
- * @category Object
- * @param {Object} object The destination object.
- * @param {...Object} [sources] The source objects.
- * @returns {Object} Returns `object`.
- * @see _.assign
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * }
- *
- * function Bar() {
- * this.c = 3;
- * }
- *
- * Foo.prototype.b = 2;
- * Bar.prototype.d = 4;
- *
- * _.assignIn({ 'a': 0 }, new Foo, new Bar);
- * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 }
- */var assignIn=createAssigner(function(object,source){copyObject(source,keysIn(source),object);});/**
- * This method is like `_.assignIn` except that it accepts `customizer`
- * which is invoked to produce the assigned values. If `customizer` returns
- * `undefined`, assignment is handled by the method instead. The `customizer`
- * is invoked with five arguments: (objValue, srcValue, key, object, source).
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @alias extendWith
- * @category Object
- * @param {Object} object The destination object.
- * @param {...Object} sources The source objects.
- * @param {Function} [customizer] The function to customize assigned values.
- * @returns {Object} Returns `object`.
- * @see _.assignWith
- * @example
- *
- * function customizer(objValue, srcValue) {
- * return _.isUndefined(objValue) ? srcValue : objValue;
- * }
- *
- * var defaults = _.partialRight(_.assignInWith, customizer);
- *
- * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });
- * // => { 'a': 1, 'b': 2 }
- */var assignInWith=createAssigner(function(object,source,srcIndex,customizer){copyObject(source,keysIn(source),object,customizer);});/**
- * This method is like `_.assign` except that it accepts `customizer`
- * which is invoked to produce the assigned values. If `customizer` returns
- * `undefined`, assignment is handled by the method instead. The `customizer`
- * is invoked with five arguments: (objValue, srcValue, key, object, source).
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Object
- * @param {Object} object The destination object.
- * @param {...Object} sources The source objects.
- * @param {Function} [customizer] The function to customize assigned values.
- * @returns {Object} Returns `object`.
- * @see _.assignInWith
- * @example
- *
- * function customizer(objValue, srcValue) {
- * return _.isUndefined(objValue) ? srcValue : objValue;
- * }
- *
- * var defaults = _.partialRight(_.assignWith, customizer);
- *
- * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });
- * // => { 'a': 1, 'b': 2 }
- */var assignWith=createAssigner(function(object,source,srcIndex,customizer){copyObject(source,keys(source),object,customizer);});/**
- * Creates an array of values corresponding to `paths` of `object`.
- *
- * @static
- * @memberOf _
- * @since 1.0.0
- * @category Object
- * @param {Object} object The object to iterate over.
- * @param {...(string|string[])} [paths] The property paths to pick.
- * @returns {Array} Returns the picked values.
- * @example
- *
- * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };
- *
- * _.at(object, ['a[0].b.c', 'a[1]']);
- * // => [3, 4]
- */var at=flatRest(baseAt);/**
- * Creates an object that inherits from the `prototype` object. If a
- * `properties` object is given, its own enumerable string keyed properties
- * are assigned to the created object.
- *
- * @static
- * @memberOf _
- * @since 2.3.0
- * @category Object
- * @param {Object} prototype The object to inherit from.
- * @param {Object} [properties] The properties to assign to the object.
- * @returns {Object} Returns the new object.
- * @example
- *
- * function Shape() {
- * this.x = 0;
- * this.y = 0;
- * }
- *
- * function Circle() {
- * Shape.call(this);
- * }
- *
- * Circle.prototype = _.create(Shape.prototype, {
- * 'constructor': Circle
- * });
- *
- * var circle = new Circle;
- * circle instanceof Circle;
- * // => true
- *
- * circle instanceof Shape;
- * // => true
- */function create(prototype,properties){var result=baseCreate(prototype);return properties==null?result:baseAssign(result,properties);}/**
- * Assigns own and inherited enumerable string keyed properties of source
- * objects to the destination object for all destination properties that
- * resolve to `undefined`. Source objects are applied from left to right.
- * Once a property is set, additional values of the same property are ignored.
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Object
- * @param {Object} object The destination object.
- * @param {...Object} [sources] The source objects.
- * @returns {Object} Returns `object`.
- * @see _.defaultsDeep
- * @example
- *
- * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });
- * // => { 'a': 1, 'b': 2 }
- */var defaults=baseRest(function(object,sources){object=Object(object);var index=-1;var length=sources.length;var guard=length>2?sources[2]:undefined;if(guard&&isIterateeCall(sources[0],sources[1],guard)){length=1;}while(++index<length){var source=sources[index];var props=keysIn(source);var propsIndex=-1;var propsLength=props.length;while(++propsIndex<propsLength){var key=props[propsIndex];var value=object[key];if(value===undefined||eq(value,objectProto[key])&&!hasOwnProperty.call(object,key)){object[key]=source[key];}}}return object;});/**
- * This method is like `_.defaults` except that it recursively assigns
- * default properties.
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @memberOf _
- * @since 3.10.0
- * @category Object
- * @param {Object} object The destination object.
- * @param {...Object} [sources] The source objects.
- * @returns {Object} Returns `object`.
- * @see _.defaults
- * @example
- *
- * _.defaultsDeep({ 'a': { 'b': 2 } }, { 'a': { 'b': 1, 'c': 3 } });
- * // => { 'a': { 'b': 2, 'c': 3 } }
- */var defaultsDeep=baseRest(function(args){args.push(undefined,customDefaultsMerge);return apply(mergeWith,undefined,args);});/**
- * This method is like `_.find` except that it returns the key of the first
- * element `predicate` returns truthy for instead of the element itself.
- *
- * @static
- * @memberOf _
- * @since 1.1.0
- * @category Object
- * @param {Object} object The object to inspect.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @returns {string|undefined} Returns the key of the matched element,
- * else `undefined`.
- * @example
- *
- * var users = {
- * 'barney': { 'age': 36, 'active': true },
- * 'fred': { 'age': 40, 'active': false },
- * 'pebbles': { 'age': 1, 'active': true }
- * };
- *
- * _.findKey(users, function(o) { return o.age < 40; });
- * // => 'barney' (iteration order is not guaranteed)
- *
- * // The `_.matches` iteratee shorthand.
- * _.findKey(users, { 'age': 1, 'active': true });
- * // => 'pebbles'
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.findKey(users, ['active', false]);
- * // => 'fred'
- *
- * // The `_.property` iteratee shorthand.
- * _.findKey(users, 'active');
- * // => 'barney'
- */function findKey(object,predicate){return baseFindKey(object,getIteratee(predicate,3),baseForOwn);}/**
- * This method is like `_.findKey` except that it iterates over elements of
- * a collection in the opposite order.
- *
- * @static
- * @memberOf _
- * @since 2.0.0
- * @category Object
- * @param {Object} object The object to inspect.
- * @param {Function} [predicate=_.identity] The function invoked per iteration.
- * @returns {string|undefined} Returns the key of the matched element,
- * else `undefined`.
- * @example
- *
- * var users = {
- * 'barney': { 'age': 36, 'active': true },
- * 'fred': { 'age': 40, 'active': false },
- * 'pebbles': { 'age': 1, 'active': true }
- * };
- *
- * _.findLastKey(users, function(o) { return o.age < 40; });
- * // => returns 'pebbles' assuming `_.findKey` returns 'barney'
- *
- * // The `_.matches` iteratee shorthand.
- * _.findLastKey(users, { 'age': 36, 'active': true });
- * // => 'barney'
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.findLastKey(users, ['active', false]);
- * // => 'fred'
- *
- * // The `_.property` iteratee shorthand.
- * _.findLastKey(users, 'active');
- * // => 'pebbles'
- */function findLastKey(object,predicate){return baseFindKey(object,getIteratee(predicate,3),baseForOwnRight);}/**
- * Iterates over own and inherited enumerable string keyed properties of an
- * object and invokes `iteratee` for each property. The iteratee is invoked
- * with three arguments: (value, key, object). Iteratee functions may exit
- * iteration early by explicitly returning `false`.
- *
- * @static
- * @memberOf _
- * @since 0.3.0
- * @category Object
- * @param {Object} object The object to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Object} Returns `object`.
- * @see _.forInRight
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.forIn(new Foo, function(value, key) {
- * console.log(key);
- * });
- * // => Logs 'a', 'b', then 'c' (iteration order is not guaranteed).
- */function forIn(object,iteratee){return object==null?object:baseFor(object,getIteratee(iteratee,3),keysIn);}/**
- * This method is like `_.forIn` except that it iterates over properties of
- * `object` in the opposite order.
- *
- * @static
- * @memberOf _
- * @since 2.0.0
- * @category Object
- * @param {Object} object The object to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Object} Returns `object`.
- * @see _.forIn
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.forInRight(new Foo, function(value, key) {
- * console.log(key);
- * });
- * // => Logs 'c', 'b', then 'a' assuming `_.forIn` logs 'a', 'b', then 'c'.
- */function forInRight(object,iteratee){return object==null?object:baseForRight(object,getIteratee(iteratee,3),keysIn);}/**
- * Iterates over own enumerable string keyed properties of an object and
- * invokes `iteratee` for each property. The iteratee is invoked with three
- * arguments: (value, key, object). Iteratee functions may exit iteration
- * early by explicitly returning `false`.
- *
- * @static
- * @memberOf _
- * @since 0.3.0
- * @category Object
- * @param {Object} object The object to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Object} Returns `object`.
- * @see _.forOwnRight
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.forOwn(new Foo, function(value, key) {
- * console.log(key);
- * });
- * // => Logs 'a' then 'b' (iteration order is not guaranteed).
- */function forOwn(object,iteratee){return object&&baseForOwn(object,getIteratee(iteratee,3));}/**
- * This method is like `_.forOwn` except that it iterates over properties of
- * `object` in the opposite order.
- *
- * @static
- * @memberOf _
- * @since 2.0.0
- * @category Object
- * @param {Object} object The object to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Object} Returns `object`.
- * @see _.forOwn
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.forOwnRight(new Foo, function(value, key) {
- * console.log(key);
- * });
- * // => Logs 'b' then 'a' assuming `_.forOwn` logs 'a' then 'b'.
- */function forOwnRight(object,iteratee){return object&&baseForOwnRight(object,getIteratee(iteratee,3));}/**
- * Creates an array of function property names from own enumerable properties
- * of `object`.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Object
- * @param {Object} object The object to inspect.
- * @returns {Array} Returns the function names.
- * @see _.functionsIn
- * @example
- *
- * function Foo() {
- * this.a = _.constant('a');
- * this.b = _.constant('b');
- * }
- *
- * Foo.prototype.c = _.constant('c');
- *
- * _.functions(new Foo);
- * // => ['a', 'b']
- */function functions(object){return object==null?[]:baseFunctions(object,keys(object));}/**
- * Creates an array of function property names from own and inherited
- * enumerable properties of `object`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Object
- * @param {Object} object The object to inspect.
- * @returns {Array} Returns the function names.
- * @see _.functions
- * @example
- *
- * function Foo() {
- * this.a = _.constant('a');
- * this.b = _.constant('b');
- * }
- *
- * Foo.prototype.c = _.constant('c');
- *
- * _.functionsIn(new Foo);
- * // => ['a', 'b', 'c']
- */function functionsIn(object){return object==null?[]:baseFunctions(object,keysIn(object));}/**
- * Gets the value at `path` of `object`. If the resolved value is
- * `undefined`, the `defaultValue` is returned in its place.
- *
- * @static
- * @memberOf _
- * @since 3.7.0
- * @category Object
- * @param {Object} object The object to query.
- * @param {Array|string} path The path of the property to get.
- * @param {*} [defaultValue] The value returned for `undefined` resolved values.
- * @returns {*} Returns the resolved value.
- * @example
- *
- * var object = { 'a': [{ 'b': { 'c': 3 } }] };
- *
- * _.get(object, 'a[0].b.c');
- * // => 3
- *
- * _.get(object, ['a', '0', 'b', 'c']);
- * // => 3
- *
- * _.get(object, 'a.b.c', 'default');
- * // => 'default'
- */function get(object,path,defaultValue){var result=object==null?undefined:baseGet(object,path);return result===undefined?defaultValue:result;}/**
- * Checks if `path` is a direct property of `object`.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Object
- * @param {Object} object The object to query.
- * @param {Array|string} path The path to check.
- * @returns {boolean} Returns `true` if `path` exists, else `false`.
- * @example
- *
- * var object = { 'a': { 'b': 2 } };
- * var other = _.create({ 'a': _.create({ 'b': 2 }) });
- *
- * _.has(object, 'a');
- * // => true
- *
- * _.has(object, 'a.b');
- * // => true
- *
- * _.has(object, ['a', 'b']);
- * // => true
- *
- * _.has(other, 'a');
- * // => false
- */function has(object,path){return object!=null&&hasPath(object,path,baseHas);}/**
- * Checks if `path` is a direct or inherited property of `object`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Object
- * @param {Object} object The object to query.
- * @param {Array|string} path The path to check.
- * @returns {boolean} Returns `true` if `path` exists, else `false`.
- * @example
- *
- * var object = _.create({ 'a': _.create({ 'b': 2 }) });
- *
- * _.hasIn(object, 'a');
- * // => true
- *
- * _.hasIn(object, 'a.b');
- * // => true
- *
- * _.hasIn(object, ['a', 'b']);
- * // => true
- *
- * _.hasIn(object, 'b');
- * // => false
- */function hasIn(object,path){return object!=null&&hasPath(object,path,baseHasIn);}/**
- * Creates an object composed of the inverted keys and values of `object`.
- * If `object` contains duplicate values, subsequent values overwrite
- * property assignments of previous values.
- *
- * @static
- * @memberOf _
- * @since 0.7.0
- * @category Object
- * @param {Object} object The object to invert.
- * @returns {Object} Returns the new inverted object.
- * @example
- *
- * var object = { 'a': 1, 'b': 2, 'c': 1 };
- *
- * _.invert(object);
- * // => { '1': 'c', '2': 'b' }
- */var invert=createInverter(function(result,value,key){if(value!=null&&typeof value.toString!=='function'){value=nativeObjectToString.call(value);}result[value]=key;},constant(identity));/**
- * This method is like `_.invert` except that the inverted object is generated
- * from the results of running each element of `object` thru `iteratee`. The
- * corresponding inverted value of each inverted key is an array of keys
- * responsible for generating the inverted value. The iteratee is invoked
- * with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 4.1.0
- * @category Object
- * @param {Object} object The object to invert.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {Object} Returns the new inverted object.
- * @example
- *
- * var object = { 'a': 1, 'b': 2, 'c': 1 };
- *
- * _.invertBy(object);
- * // => { '1': ['a', 'c'], '2': ['b'] }
- *
- * _.invertBy(object, function(value) {
- * return 'group' + value;
- * });
- * // => { 'group1': ['a', 'c'], 'group2': ['b'] }
- */var invertBy=createInverter(function(result,value,key){if(value!=null&&typeof value.toString!=='function'){value=nativeObjectToString.call(value);}if(hasOwnProperty.call(result,value)){result[value].push(key);}else{result[value]=[key];}},getIteratee);/**
- * Invokes the method at `path` of `object`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Object
- * @param {Object} object The object to query.
- * @param {Array|string} path The path of the method to invoke.
- * @param {...*} [args] The arguments to invoke the method with.
- * @returns {*} Returns the result of the invoked method.
- * @example
- *
- * var object = { 'a': [{ 'b': { 'c': [1, 2, 3, 4] } }] };
- *
- * _.invoke(object, 'a[0].b.c.slice', 1, 3);
- * // => [2, 3]
- */var invoke=baseRest(baseInvoke);/**
- * Creates an array of the own enumerable property names of `object`.
- *
- * **Note:** Non-object values are coerced to objects. See the
- * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)
- * for more details.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Object
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property names.
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.keys(new Foo);
- * // => ['a', 'b'] (iteration order is not guaranteed)
- *
- * _.keys('hi');
- * // => ['0', '1']
- */function keys(object){return isArrayLike(object)?arrayLikeKeys(object):baseKeys(object);}/**
- * Creates an array of the own and inherited enumerable property names of `object`.
- *
- * **Note:** Non-object values are coerced to objects.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Object
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property names.
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.keysIn(new Foo);
- * // => ['a', 'b', 'c'] (iteration order is not guaranteed)
- */function keysIn(object){return isArrayLike(object)?arrayLikeKeys(object,true):baseKeysIn(object);}/**
- * The opposite of `_.mapValues`; this method creates an object with the
- * same values as `object` and keys generated by running each own enumerable
- * string keyed property of `object` thru `iteratee`. The iteratee is invoked
- * with three arguments: (value, key, object).
- *
- * @static
- * @memberOf _
- * @since 3.8.0
- * @category Object
- * @param {Object} object The object to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Object} Returns the new mapped object.
- * @see _.mapValues
- * @example
- *
- * _.mapKeys({ 'a': 1, 'b': 2 }, function(value, key) {
- * return key + value;
- * });
- * // => { 'a1': 1, 'b2': 2 }
- */function mapKeys(object,iteratee){var result={};iteratee=getIteratee(iteratee,3);baseForOwn(object,function(value,key,object){baseAssignValue(result,iteratee(value,key,object),value);});return result;}/**
- * Creates an object with the same keys as `object` and values generated
- * by running each own enumerable string keyed property of `object` thru
- * `iteratee`. The iteratee is invoked with three arguments:
- * (value, key, object).
- *
- * @static
- * @memberOf _
- * @since 2.4.0
- * @category Object
- * @param {Object} object The object to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Object} Returns the new mapped object.
- * @see _.mapKeys
- * @example
- *
- * var users = {
- * 'fred': { 'user': 'fred', 'age': 40 },
- * 'pebbles': { 'user': 'pebbles', 'age': 1 }
- * };
- *
- * _.mapValues(users, function(o) { return o.age; });
- * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)
- *
- * // The `_.property` iteratee shorthand.
- * _.mapValues(users, 'age');
- * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)
- */function mapValues(object,iteratee){var result={};iteratee=getIteratee(iteratee,3);baseForOwn(object,function(value,key,object){baseAssignValue(result,key,iteratee(value,key,object));});return result;}/**
- * This method is like `_.assign` except that it recursively merges own and
- * inherited enumerable string keyed properties of source objects into the
- * destination object. Source properties that resolve to `undefined` are
- * skipped if a destination value exists. Array and plain object properties
- * are merged recursively. Other objects and value types are overridden by
- * assignment. Source objects are applied from left to right. Subsequent
- * sources overwrite property assignments of previous sources.
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @memberOf _
- * @since 0.5.0
- * @category Object
- * @param {Object} object The destination object.
- * @param {...Object} [sources] The source objects.
- * @returns {Object} Returns `object`.
- * @example
- *
- * var object = {
- * 'a': [{ 'b': 2 }, { 'd': 4 }]
- * };
- *
- * var other = {
- * 'a': [{ 'c': 3 }, { 'e': 5 }]
- * };
- *
- * _.merge(object, other);
- * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }
- */var merge=createAssigner(function(object,source,srcIndex){baseMerge(object,source,srcIndex);});/**
- * This method is like `_.merge` except that it accepts `customizer` which
- * is invoked to produce the merged values of the destination and source
- * properties. If `customizer` returns `undefined`, merging is handled by the
- * method instead. The `customizer` is invoked with six arguments:
- * (objValue, srcValue, key, object, source, stack).
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Object
- * @param {Object} object The destination object.
- * @param {...Object} sources The source objects.
- * @param {Function} customizer The function to customize assigned values.
- * @returns {Object} Returns `object`.
- * @example
- *
- * function customizer(objValue, srcValue) {
- * if (_.isArray(objValue)) {
- * return objValue.concat(srcValue);
- * }
- * }
- *
- * var object = { 'a': [1], 'b': [2] };
- * var other = { 'a': [3], 'b': [4] };
- *
- * _.mergeWith(object, other, customizer);
- * // => { 'a': [1, 3], 'b': [2, 4] }
- */var mergeWith=createAssigner(function(object,source,srcIndex,customizer){baseMerge(object,source,srcIndex,customizer);});/**
- * The opposite of `_.pick`; this method creates an object composed of the
- * own and inherited enumerable property paths of `object` that are not omitted.
- *
- * **Note:** This method is considerably slower than `_.pick`.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Object
- * @param {Object} object The source object.
- * @param {...(string|string[])} [paths] The property paths to omit.
- * @returns {Object} Returns the new object.
- * @example
- *
- * var object = { 'a': 1, 'b': '2', 'c': 3 };
- *
- * _.omit(object, ['a', 'c']);
- * // => { 'b': '2' }
- */var omit=flatRest(function(object,paths){var result={};if(object==null){return result;}var isDeep=false;paths=arrayMap(paths,function(path){path=castPath(path,object);isDeep||(isDeep=path.length>1);return path;});copyObject(object,getAllKeysIn(object),result);if(isDeep){result=baseClone(result,CLONE_DEEP_FLAG|CLONE_FLAT_FLAG|CLONE_SYMBOLS_FLAG,customOmitClone);}var length=paths.length;while(length--){baseUnset(result,paths[length]);}return result;});/**
- * The opposite of `_.pickBy`; this method creates an object composed of
- * the own and inherited enumerable string keyed properties of `object` that
- * `predicate` doesn't return truthy for. The predicate is invoked with two
- * arguments: (value, key).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Object
- * @param {Object} object The source object.
- * @param {Function} [predicate=_.identity] The function invoked per property.
- * @returns {Object} Returns the new object.
- * @example
- *
- * var object = { 'a': 1, 'b': '2', 'c': 3 };
- *
- * _.omitBy(object, _.isNumber);
- * // => { 'b': '2' }
- */function omitBy(object,predicate){return pickBy(object,negate(getIteratee(predicate)));}/**
- * Creates an object composed of the picked `object` properties.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Object
- * @param {Object} object The source object.
- * @param {...(string|string[])} [paths] The property paths to pick.
- * @returns {Object} Returns the new object.
- * @example
- *
- * var object = { 'a': 1, 'b': '2', 'c': 3 };
- *
- * _.pick(object, ['a', 'c']);
- * // => { 'a': 1, 'c': 3 }
- */var pick=flatRest(function(object,paths){return object==null?{}:basePick(object,paths);});/**
- * Creates an object composed of the `object` properties `predicate` returns
- * truthy for. The predicate is invoked with two arguments: (value, key).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Object
- * @param {Object} object The source object.
- * @param {Function} [predicate=_.identity] The function invoked per property.
- * @returns {Object} Returns the new object.
- * @example
- *
- * var object = { 'a': 1, 'b': '2', 'c': 3 };
- *
- * _.pickBy(object, _.isNumber);
- * // => { 'a': 1, 'c': 3 }
- */function pickBy(object,predicate){if(object==null){return{};}var props=arrayMap(getAllKeysIn(object),function(prop){return[prop];});predicate=getIteratee(predicate);return basePickBy(object,props,function(value,path){return predicate(value,path[0]);});}/**
- * This method is like `_.get` except that if the resolved value is a
- * function it's invoked with the `this` binding of its parent object and
- * its result is returned.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Object
- * @param {Object} object The object to query.
- * @param {Array|string} path The path of the property to resolve.
- * @param {*} [defaultValue] The value returned for `undefined` resolved values.
- * @returns {*} Returns the resolved value.
- * @example
- *
- * var object = { 'a': [{ 'b': { 'c1': 3, 'c2': _.constant(4) } }] };
- *
- * _.result(object, 'a[0].b.c1');
- * // => 3
- *
- * _.result(object, 'a[0].b.c2');
- * // => 4
- *
- * _.result(object, 'a[0].b.c3', 'default');
- * // => 'default'
- *
- * _.result(object, 'a[0].b.c3', _.constant('default'));
- * // => 'default'
- */function result(object,path,defaultValue){path=castPath(path,object);var index=-1,length=path.length;// Ensure the loop is entered when path is empty.
- if(!length){length=1;object=undefined;}while(++index<length){var value=object==null?undefined:object[toKey(path[index])];if(value===undefined){index=length;value=defaultValue;}object=isFunction(value)?value.call(object):value;}return object;}/**
- * Sets the value at `path` of `object`. If a portion of `path` doesn't exist,
- * it's created. Arrays are created for missing index properties while objects
- * are created for all other missing properties. Use `_.setWith` to customize
- * `path` creation.
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @memberOf _
- * @since 3.7.0
- * @category Object
- * @param {Object} object The object to modify.
- * @param {Array|string} path The path of the property to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns `object`.
- * @example
- *
- * var object = { 'a': [{ 'b': { 'c': 3 } }] };
- *
- * _.set(object, 'a[0].b.c', 4);
- * console.log(object.a[0].b.c);
- * // => 4
- *
- * _.set(object, ['x', '0', 'y', 'z'], 5);
- * console.log(object.x[0].y.z);
- * // => 5
- */function set(object,path,value){return object==null?object:baseSet(object,path,value);}/**
- * This method is like `_.set` except that it accepts `customizer` which is
- * invoked to produce the objects of `path`. If `customizer` returns `undefined`
- * path creation is handled by the method instead. The `customizer` is invoked
- * with three arguments: (nsValue, key, nsObject).
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Object
- * @param {Object} object The object to modify.
- * @param {Array|string} path The path of the property to set.
- * @param {*} value The value to set.
- * @param {Function} [customizer] The function to customize assigned values.
- * @returns {Object} Returns `object`.
- * @example
- *
- * var object = {};
- *
- * _.setWith(object, '[0][1]', 'a', Object);
- * // => { '0': { '1': 'a' } }
- */function setWith(object,path,value,customizer){customizer=typeof customizer==='function'?customizer:undefined;return object==null?object:baseSet(object,path,value,customizer);}/**
- * Creates an array of own enumerable string keyed-value pairs for `object`
- * which can be consumed by `_.fromPairs`. If `object` is a map or set, its
- * entries are returned.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @alias entries
- * @category Object
- * @param {Object} object The object to query.
- * @returns {Array} Returns the key-value pairs.
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.toPairs(new Foo);
- * // => [['a', 1], ['b', 2]] (iteration order is not guaranteed)
- */var toPairs=createToPairs(keys);/**
- * Creates an array of own and inherited enumerable string keyed-value pairs
- * for `object` which can be consumed by `_.fromPairs`. If `object` is a map
- * or set, its entries are returned.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @alias entriesIn
- * @category Object
- * @param {Object} object The object to query.
- * @returns {Array} Returns the key-value pairs.
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.toPairsIn(new Foo);
- * // => [['a', 1], ['b', 2], ['c', 3]] (iteration order is not guaranteed)
- */var toPairsIn=createToPairs(keysIn);/**
- * An alternative to `_.reduce`; this method transforms `object` to a new
- * `accumulator` object which is the result of running each of its own
- * enumerable string keyed properties thru `iteratee`, with each invocation
- * potentially mutating the `accumulator` object. If `accumulator` is not
- * provided, a new object with the same `[[Prototype]]` will be used. The
- * iteratee is invoked with four arguments: (accumulator, value, key, object).
- * Iteratee functions may exit iteration early by explicitly returning `false`.
- *
- * @static
- * @memberOf _
- * @since 1.3.0
- * @category Object
- * @param {Object} object The object to iterate over.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @param {*} [accumulator] The custom accumulator value.
- * @returns {*} Returns the accumulated value.
- * @example
- *
- * _.transform([2, 3, 4], function(result, n) {
- * result.push(n *= n);
- * return n % 2 == 0;
- * }, []);
- * // => [4, 9]
- *
- * _.transform({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {
- * (result[value] || (result[value] = [])).push(key);
- * }, {});
- * // => { '1': ['a', 'c'], '2': ['b'] }
- */function transform(object,iteratee,accumulator){var isArr=isArray(object),isArrLike=isArr||isBuffer(object)||isTypedArray(object);iteratee=getIteratee(iteratee,4);if(accumulator==null){var Ctor=object&&object.constructor;if(isArrLike){accumulator=isArr?new Ctor():[];}else if(isObject(object)){accumulator=isFunction(Ctor)?baseCreate(getPrototype(object)):{};}else{accumulator={};}}(isArrLike?arrayEach:baseForOwn)(object,function(value,index,object){return iteratee(accumulator,value,index,object);});return accumulator;}/**
- * Removes the property at `path` of `object`.
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Object
- * @param {Object} object The object to modify.
- * @param {Array|string} path The path of the property to unset.
- * @returns {boolean} Returns `true` if the property is deleted, else `false`.
- * @example
- *
- * var object = { 'a': [{ 'b': { 'c': 7 } }] };
- * _.unset(object, 'a[0].b.c');
- * // => true
- *
- * console.log(object);
- * // => { 'a': [{ 'b': {} }] };
- *
- * _.unset(object, ['a', '0', 'b', 'c']);
- * // => true
- *
- * console.log(object);
- * // => { 'a': [{ 'b': {} }] };
- */function unset(object,path){return object==null?true:baseUnset(object,path);}/**
- * This method is like `_.set` except that accepts `updater` to produce the
- * value to set. Use `_.updateWith` to customize `path` creation. The `updater`
- * is invoked with one argument: (value).
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @memberOf _
- * @since 4.6.0
- * @category Object
- * @param {Object} object The object to modify.
- * @param {Array|string} path The path of the property to set.
- * @param {Function} updater The function to produce the updated value.
- * @returns {Object} Returns `object`.
- * @example
- *
- * var object = { 'a': [{ 'b': { 'c': 3 } }] };
- *
- * _.update(object, 'a[0].b.c', function(n) { return n * n; });
- * console.log(object.a[0].b.c);
- * // => 9
- *
- * _.update(object, 'x[0].y.z', function(n) { return n ? n + 1 : 0; });
- * console.log(object.x[0].y.z);
- * // => 0
- */function update(object,path,updater){return object==null?object:baseUpdate(object,path,castFunction(updater));}/**
- * This method is like `_.update` except that it accepts `customizer` which is
- * invoked to produce the objects of `path`. If `customizer` returns `undefined`
- * path creation is handled by the method instead. The `customizer` is invoked
- * with three arguments: (nsValue, key, nsObject).
- *
- * **Note:** This method mutates `object`.
- *
- * @static
- * @memberOf _
- * @since 4.6.0
- * @category Object
- * @param {Object} object The object to modify.
- * @param {Array|string} path The path of the property to set.
- * @param {Function} updater The function to produce the updated value.
- * @param {Function} [customizer] The function to customize assigned values.
- * @returns {Object} Returns `object`.
- * @example
- *
- * var object = {};
- *
- * _.updateWith(object, '[0][1]', _.constant('a'), Object);
- * // => { '0': { '1': 'a' } }
- */function updateWith(object,path,updater,customizer){customizer=typeof customizer==='function'?customizer:undefined;return object==null?object:baseUpdate(object,path,castFunction(updater),customizer);}/**
- * Creates an array of the own enumerable string keyed property values of `object`.
- *
- * **Note:** Non-object values are coerced to objects.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Object
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property values.
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.values(new Foo);
- * // => [1, 2] (iteration order is not guaranteed)
- *
- * _.values('hi');
- * // => ['h', 'i']
- */function values(object){return object==null?[]:baseValues(object,keys(object));}/**
- * Creates an array of the own and inherited enumerable string keyed property
- * values of `object`.
- *
- * **Note:** Non-object values are coerced to objects.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Object
- * @param {Object} object The object to query.
- * @returns {Array} Returns the array of property values.
- * @example
- *
- * function Foo() {
- * this.a = 1;
- * this.b = 2;
- * }
- *
- * Foo.prototype.c = 3;
- *
- * _.valuesIn(new Foo);
- * // => [1, 2, 3] (iteration order is not guaranteed)
- */function valuesIn(object){return object==null?[]:baseValues(object,keysIn(object));}/* ------------------------------------------------------------------------*//**
- * Clamps `number` within the inclusive `lower` and `upper` bounds.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Number
- * @param {number} number The number to clamp.
- * @param {number} [lower] The lower bound.
- * @param {number} upper The upper bound.
- * @returns {number} Returns the clamped number.
- * @example
- *
- * _.clamp(-10, -5, 5);
- * // => -5
- *
- * _.clamp(10, -5, 5);
- * // => 5
- */function clamp(number,lower,upper){if(upper===undefined){upper=lower;lower=undefined;}if(upper!==undefined){upper=toNumber(upper);upper=upper===upper?upper:0;}if(lower!==undefined){lower=toNumber(lower);lower=lower===lower?lower:0;}return baseClamp(toNumber(number),lower,upper);}/**
- * Checks if `n` is between `start` and up to, but not including, `end`. If
- * `end` is not specified, it's set to `start` with `start` then set to `0`.
- * If `start` is greater than `end` the params are swapped to support
- * negative ranges.
- *
- * @static
- * @memberOf _
- * @since 3.3.0
- * @category Number
- * @param {number} number The number to check.
- * @param {number} [start=0] The start of the range.
- * @param {number} end The end of the range.
- * @returns {boolean} Returns `true` if `number` is in the range, else `false`.
- * @see _.range, _.rangeRight
- * @example
- *
- * _.inRange(3, 2, 4);
- * // => true
- *
- * _.inRange(4, 8);
- * // => true
- *
- * _.inRange(4, 2);
- * // => false
- *
- * _.inRange(2, 2);
- * // => false
- *
- * _.inRange(1.2, 2);
- * // => true
- *
- * _.inRange(5.2, 4);
- * // => false
- *
- * _.inRange(-3, -2, -6);
- * // => true
- */function inRange(number,start,end){start=toFinite(start);if(end===undefined){end=start;start=0;}else{end=toFinite(end);}number=toNumber(number);return baseInRange(number,start,end);}/**
- * Produces a random number between the inclusive `lower` and `upper` bounds.
- * If only one argument is provided a number between `0` and the given number
- * is returned. If `floating` is `true`, or either `lower` or `upper` are
- * floats, a floating-point number is returned instead of an integer.
- *
- * **Note:** JavaScript follows the IEEE-754 standard for resolving
- * floating-point values which can produce unexpected results.
- *
- * @static
- * @memberOf _
- * @since 0.7.0
- * @category Number
- * @param {number} [lower=0] The lower bound.
- * @param {number} [upper=1] The upper bound.
- * @param {boolean} [floating] Specify returning a floating-point number.
- * @returns {number} Returns the random number.
- * @example
- *
- * _.random(0, 5);
- * // => an integer between 0 and 5
- *
- * _.random(5);
- * // => also an integer between 0 and 5
- *
- * _.random(5, true);
- * // => a floating-point number between 0 and 5
- *
- * _.random(1.2, 5.2);
- * // => a floating-point number between 1.2 and 5.2
- */function random(lower,upper,floating){if(floating&&typeof floating!=='boolean'&&isIterateeCall(lower,upper,floating)){upper=floating=undefined;}if(floating===undefined){if(typeof upper==='boolean'){floating=upper;upper=undefined;}else if(typeof lower==='boolean'){floating=lower;lower=undefined;}}if(lower===undefined&&upper===undefined){lower=0;upper=1;}else{lower=toFinite(lower);if(upper===undefined){upper=lower;lower=0;}else{upper=toFinite(upper);}}if(lower>upper){var temp=lower;lower=upper;upper=temp;}if(floating||lower%1||upper%1){var rand=nativeRandom();return nativeMin(lower+rand*(upper-lower+freeParseFloat('1e-'+((rand+'').length-1))),upper);}return baseRandom(lower,upper);}/* ------------------------------------------------------------------------*//**
- * Converts `string` to [camel case](https://en.wikipedia.org/wiki/CamelCase).
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to convert.
- * @returns {string} Returns the camel cased string.
- * @example
- *
- * _.camelCase('Foo Bar');
- * // => 'fooBar'
- *
- * _.camelCase('--foo-bar--');
- * // => 'fooBar'
- *
- * _.camelCase('__FOO_BAR__');
- * // => 'fooBar'
- */var camelCase=createCompounder(function(result,word,index){word=word.toLowerCase();return result+(index?capitalize(word):word);});/**
- * Converts the first character of `string` to upper case and the remaining
- * to lower case.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to capitalize.
- * @returns {string} Returns the capitalized string.
- * @example
- *
- * _.capitalize('FRED');
- * // => 'Fred'
- */function capitalize(string){return upperFirst(toString(string).toLowerCase());}/**
- * Deburrs `string` by converting
- * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table)
- * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A)
- * letters to basic Latin letters and removing
- * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks).
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to deburr.
- * @returns {string} Returns the deburred string.
- * @example
- *
- * _.deburr('déjà vu');
- * // => 'deja vu'
- */function deburr(string){string=toString(string);return string&&string.replace(reLatin,deburrLetter).replace(reComboMark,'');}/**
- * Checks if `string` ends with the given target string.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to inspect.
- * @param {string} [target] The string to search for.
- * @param {number} [position=string.length] The position to search up to.
- * @returns {boolean} Returns `true` if `string` ends with `target`,
- * else `false`.
- * @example
- *
- * _.endsWith('abc', 'c');
- * // => true
- *
- * _.endsWith('abc', 'b');
- * // => false
- *
- * _.endsWith('abc', 'b', 2);
- * // => true
- */function endsWith(string,target,position){string=toString(string);target=baseToString(target);var length=string.length;position=position===undefined?length:baseClamp(toInteger(position),0,length);var end=position;position-=target.length;return position>=0&&string.slice(position,end)==target;}/**
- * Converts the characters "&", "<", ">", '"', and "'" in `string` to their
- * corresponding HTML entities.
- *
- * **Note:** No other characters are escaped. To escape additional
- * characters use a third-party library like [_he_](https://mths.be/he).
- *
- * Though the ">" character is escaped for symmetry, characters like
- * ">" and "/" don't need escaping in HTML and have no special meaning
- * unless they're part of a tag or unquoted attribute value. See
- * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands)
- * (under "semi-related fun fact") for more details.
- *
- * When working with HTML you should always
- * [quote attribute values](http://wonko.com/post/html-escaping) to reduce
- * XSS vectors.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category String
- * @param {string} [string=''] The string to escape.
- * @returns {string} Returns the escaped string.
- * @example
- *
- * _.escape('fred, barney, & pebbles');
- * // => 'fred, barney, & pebbles'
- */function escape(string){string=toString(string);return string&&reHasUnescapedHtml.test(string)?string.replace(reUnescapedHtml,escapeHtmlChar):string;}/**
- * Escapes the `RegExp` special characters "^", "$", "\", ".", "*", "+",
- * "?", "(", ")", "[", "]", "{", "}", and "|" in `string`.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to escape.
- * @returns {string} Returns the escaped string.
- * @example
- *
- * _.escapeRegExp('[lodash](https://lodash.com/)');
- * // => '\[lodash\]\(https://lodash\.com/\)'
- */function escapeRegExp(string){string=toString(string);return string&&reHasRegExpChar.test(string)?string.replace(reRegExpChar,'\\$&'):string;}/**
- * Converts `string` to
- * [kebab case](https://en.wikipedia.org/wiki/Letter_case#Special_case_styles).
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to convert.
- * @returns {string} Returns the kebab cased string.
- * @example
- *
- * _.kebabCase('Foo Bar');
- * // => 'foo-bar'
- *
- * _.kebabCase('fooBar');
- * // => 'foo-bar'
- *
- * _.kebabCase('__FOO_BAR__');
- * // => 'foo-bar'
- */var kebabCase=createCompounder(function(result,word,index){return result+(index?'-':'')+word.toLowerCase();});/**
- * Converts `string`, as space separated words, to lower case.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to convert.
- * @returns {string} Returns the lower cased string.
- * @example
- *
- * _.lowerCase('--Foo-Bar--');
- * // => 'foo bar'
- *
- * _.lowerCase('fooBar');
- * // => 'foo bar'
- *
- * _.lowerCase('__FOO_BAR__');
- * // => 'foo bar'
- */var lowerCase=createCompounder(function(result,word,index){return result+(index?' ':'')+word.toLowerCase();});/**
- * Converts the first character of `string` to lower case.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to convert.
- * @returns {string} Returns the converted string.
- * @example
- *
- * _.lowerFirst('Fred');
- * // => 'fred'
- *
- * _.lowerFirst('FRED');
- * // => 'fRED'
- */var lowerFirst=createCaseFirst('toLowerCase');/**
- * Pads `string` on the left and right sides if it's shorter than `length`.
- * Padding characters are truncated if they can't be evenly divided by `length`.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to pad.
- * @param {number} [length=0] The padding length.
- * @param {string} [chars=' '] The string used as padding.
- * @returns {string} Returns the padded string.
- * @example
- *
- * _.pad('abc', 8);
- * // => ' abc '
- *
- * _.pad('abc', 8, '_-');
- * // => '_-abc_-_'
- *
- * _.pad('abc', 3);
- * // => 'abc'
- */function pad(string,length,chars){string=toString(string);length=toInteger(length);var strLength=length?stringSize(string):0;if(!length||strLength>=length){return string;}var mid=(length-strLength)/2;return createPadding(nativeFloor(mid),chars)+string+createPadding(nativeCeil(mid),chars);}/**
- * Pads `string` on the right side if it's shorter than `length`. Padding
- * characters are truncated if they exceed `length`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to pad.
- * @param {number} [length=0] The padding length.
- * @param {string} [chars=' '] The string used as padding.
- * @returns {string} Returns the padded string.
- * @example
- *
- * _.padEnd('abc', 6);
- * // => 'abc '
- *
- * _.padEnd('abc', 6, '_-');
- * // => 'abc_-_'
- *
- * _.padEnd('abc', 3);
- * // => 'abc'
- */function padEnd(string,length,chars){string=toString(string);length=toInteger(length);var strLength=length?stringSize(string):0;return length&&strLength<length?string+createPadding(length-strLength,chars):string;}/**
- * Pads `string` on the left side if it's shorter than `length`. Padding
- * characters are truncated if they exceed `length`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to pad.
- * @param {number} [length=0] The padding length.
- * @param {string} [chars=' '] The string used as padding.
- * @returns {string} Returns the padded string.
- * @example
- *
- * _.padStart('abc', 6);
- * // => ' abc'
- *
- * _.padStart('abc', 6, '_-');
- * // => '_-_abc'
- *
- * _.padStart('abc', 3);
- * // => 'abc'
- */function padStart(string,length,chars){string=toString(string);length=toInteger(length);var strLength=length?stringSize(string):0;return length&&strLength<length?createPadding(length-strLength,chars)+string:string;}/**
- * Converts `string` to an integer of the specified radix. If `radix` is
- * `undefined` or `0`, a `radix` of `10` is used unless `value` is a
- * hexadecimal, in which case a `radix` of `16` is used.
- *
- * **Note:** This method aligns with the
- * [ES5 implementation](https://es5.github.io/#x15.1.2.2) of `parseInt`.
- *
- * @static
- * @memberOf _
- * @since 1.1.0
- * @category String
- * @param {string} string The string to convert.
- * @param {number} [radix=10] The radix to interpret `value` by.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {number} Returns the converted integer.
- * @example
- *
- * _.parseInt('08');
- * // => 8
- *
- * _.map(['6', '08', '10'], _.parseInt);
- * // => [6, 8, 10]
- */function parseInt(string,radix,guard){if(guard||radix==null){radix=0;}else if(radix){radix=+radix;}return nativeParseInt(toString(string).replace(reTrimStart,''),radix||0);}/**
- * Repeats the given string `n` times.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to repeat.
- * @param {number} [n=1] The number of times to repeat the string.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {string} Returns the repeated string.
- * @example
- *
- * _.repeat('*', 3);
- * // => '***'
- *
- * _.repeat('abc', 2);
- * // => 'abcabc'
- *
- * _.repeat('abc', 0);
- * // => ''
- */function repeat(string,n,guard){if(guard?isIterateeCall(string,n,guard):n===undefined){n=1;}else{n=toInteger(n);}return baseRepeat(toString(string),n);}/**
- * Replaces matches for `pattern` in `string` with `replacement`.
- *
- * **Note:** This method is based on
- * [`String#replace`](https://mdn.io/String/replace).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to modify.
- * @param {RegExp|string} pattern The pattern to replace.
- * @param {Function|string} replacement The match replacement.
- * @returns {string} Returns the modified string.
- * @example
- *
- * _.replace('Hi Fred', 'Fred', 'Barney');
- * // => 'Hi Barney'
- */function replace(){var args=arguments,string=toString(args[0]);return args.length<3?string:string.replace(args[1],args[2]);}/**
- * Converts `string` to
- * [snake case](https://en.wikipedia.org/wiki/Snake_case).
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to convert.
- * @returns {string} Returns the snake cased string.
- * @example
- *
- * _.snakeCase('Foo Bar');
- * // => 'foo_bar'
- *
- * _.snakeCase('fooBar');
- * // => 'foo_bar'
- *
- * _.snakeCase('--FOO-BAR--');
- * // => 'foo_bar'
- */var snakeCase=createCompounder(function(result,word,index){return result+(index?'_':'')+word.toLowerCase();});/**
- * Splits `string` by `separator`.
- *
- * **Note:** This method is based on
- * [`String#split`](https://mdn.io/String/split).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to split.
- * @param {RegExp|string} separator The separator pattern to split by.
- * @param {number} [limit] The length to truncate results to.
- * @returns {Array} Returns the string segments.
- * @example
- *
- * _.split('a-b-c', '-', 2);
- * // => ['a', 'b']
- */function split(string,separator,limit){if(limit&&typeof limit!=='number'&&isIterateeCall(string,separator,limit)){separator=limit=undefined;}limit=limit===undefined?MAX_ARRAY_LENGTH:limit>>>0;if(!limit){return[];}string=toString(string);if(string&&(typeof separator==='string'||separator!=null&&!isRegExp(separator))){separator=baseToString(separator);if(!separator&&hasUnicode(string)){return castSlice(stringToArray(string),0,limit);}}return string.split(separator,limit);}/**
- * Converts `string` to
- * [start case](https://en.wikipedia.org/wiki/Letter_case#Stylistic_or_specialised_usage).
- *
- * @static
- * @memberOf _
- * @since 3.1.0
- * @category String
- * @param {string} [string=''] The string to convert.
- * @returns {string} Returns the start cased string.
- * @example
- *
- * _.startCase('--foo-bar--');
- * // => 'Foo Bar'
- *
- * _.startCase('fooBar');
- * // => 'Foo Bar'
- *
- * _.startCase('__FOO_BAR__');
- * // => 'FOO BAR'
- */var startCase=createCompounder(function(result,word,index){return result+(index?' ':'')+upperFirst(word);});/**
- * Checks if `string` starts with the given target string.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to inspect.
- * @param {string} [target] The string to search for.
- * @param {number} [position=0] The position to search from.
- * @returns {boolean} Returns `true` if `string` starts with `target`,
- * else `false`.
- * @example
- *
- * _.startsWith('abc', 'a');
- * // => true
- *
- * _.startsWith('abc', 'b');
- * // => false
- *
- * _.startsWith('abc', 'b', 1);
- * // => true
- */function startsWith(string,target,position){string=toString(string);position=position==null?0:baseClamp(toInteger(position),0,string.length);target=baseToString(target);return string.slice(position,position+target.length)==target;}/**
- * Creates a compiled template function that can interpolate data properties
- * in "interpolate" delimiters, HTML-escape interpolated data properties in
- * "escape" delimiters, and execute JavaScript in "evaluate" delimiters. Data
- * properties may be accessed as free variables in the template. If a setting
- * object is given, it takes precedence over `_.templateSettings` values.
- *
- * **Note:** In the development build `_.template` utilizes
- * [sourceURLs](http://www.html5rocks.com/en/tutorials/developertools/sourcemaps/#toc-sourceurl)
- * for easier debugging.
- *
- * For more information on precompiling templates see
- * [lodash's custom builds documentation](https://lodash.com/custom-builds).
- *
- * For more information on Chrome extension sandboxes see
- * [Chrome's extensions documentation](https://developer.chrome.com/extensions/sandboxingEval).
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category String
- * @param {string} [string=''] The template string.
- * @param {Object} [options={}] The options object.
- * @param {RegExp} [options.escape=_.templateSettings.escape]
- * The HTML "escape" delimiter.
- * @param {RegExp} [options.evaluate=_.templateSettings.evaluate]
- * The "evaluate" delimiter.
- * @param {Object} [options.imports=_.templateSettings.imports]
- * An object to import into the template as free variables.
- * @param {RegExp} [options.interpolate=_.templateSettings.interpolate]
- * The "interpolate" delimiter.
- * @param {string} [options.sourceURL='lodash.templateSources[n]']
- * The sourceURL of the compiled template.
- * @param {string} [options.variable='obj']
- * The data object variable name.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {Function} Returns the compiled template function.
- * @example
- *
- * // Use the "interpolate" delimiter to create a compiled template.
- * var compiled = _.template('hello <%= user %>!');
- * compiled({ 'user': 'fred' });
- * // => 'hello fred!'
- *
- * // Use the HTML "escape" delimiter to escape data property values.
- * var compiled = _.template('<b><%- value %></b>');
- * compiled({ 'value': '<script>' });
- * // => '<b><script></b>'
- *
- * // Use the "evaluate" delimiter to execute JavaScript and generate HTML.
- * var compiled = _.template('<% _.forEach(users, function(user) { %><li><%- user %></li><% }); %>');
- * compiled({ 'users': ['fred', 'barney'] });
- * // => '<li>fred</li><li>barney</li>'
- *
- * // Use the internal `print` function in "evaluate" delimiters.
- * var compiled = _.template('<% print("hello " + user); %>!');
- * compiled({ 'user': 'barney' });
- * // => 'hello barney!'
- *
- * // Use the ES template literal delimiter as an "interpolate" delimiter.
- * // Disable support by replacing the "interpolate" delimiter.
- * var compiled = _.template('hello ${ user }!');
- * compiled({ 'user': 'pebbles' });
- * // => 'hello pebbles!'
- *
- * // Use backslashes to treat delimiters as plain text.
- * var compiled = _.template('<%= "\\<%- value %\\>" %>');
- * compiled({ 'value': 'ignored' });
- * // => '<%- value %>'
- *
- * // Use the `imports` option to import `jQuery` as `jq`.
- * var text = '<% jq.each(users, function(user) { %><li><%- user %></li><% }); %>';
- * var compiled = _.template(text, { 'imports': { 'jq': jQuery } });
- * compiled({ 'users': ['fred', 'barney'] });
- * // => '<li>fred</li><li>barney</li>'
- *
- * // Use the `sourceURL` option to specify a custom sourceURL for the template.
- * var compiled = _.template('hello <%= user %>!', { 'sourceURL': '/basic/greeting.jst' });
- * compiled(data);
- * // => Find the source of "greeting.jst" under the Sources tab or Resources panel of the web inspector.
- *
- * // Use the `variable` option to ensure a with-statement isn't used in the compiled template.
- * var compiled = _.template('hi <%= data.user %>!', { 'variable': 'data' });
- * compiled.source;
- * // => function(data) {
- * // var __t, __p = '';
- * // __p += 'hi ' + ((__t = ( data.user )) == null ? '' : __t) + '!';
- * // return __p;
- * // }
- *
- * // Use custom template delimiters.
- * _.templateSettings.interpolate = /{{([\s\S]+?)}}/g;
- * var compiled = _.template('hello {{ user }}!');
- * compiled({ 'user': 'mustache' });
- * // => 'hello mustache!'
- *
- * // Use the `source` property to inline compiled templates for meaningful
- * // line numbers in error messages and stack traces.
- * fs.writeFileSync(path.join(process.cwd(), 'jst.js'), '\
- * var JST = {\
- * "main": ' + _.template(mainText).source + '\
- * };\
- * ');
- */function template(string,options,guard){// Based on John Resig's `tmpl` implementation
- // (http://ejohn.org/blog/javascript-micro-templating/)
- // and Laura Doktorova's doT.js (https://github.com/olado/doT).
- var settings=lodash.templateSettings;if(guard&&isIterateeCall(string,options,guard)){options=undefined;}string=toString(string);options=assignInWith({},options,settings,customDefaultsAssignIn);var imports=assignInWith({},options.imports,settings.imports,customDefaultsAssignIn),importsKeys=keys(imports),importsValues=baseValues(imports,importsKeys);var isEscaping,isEvaluating,index=0,interpolate=options.interpolate||reNoMatch,source="__p += '";// Compile the regexp to match each delimiter.
- var reDelimiters=RegExp((options.escape||reNoMatch).source+'|'+interpolate.source+'|'+(interpolate===reInterpolate?reEsTemplate:reNoMatch).source+'|'+(options.evaluate||reNoMatch).source+'|$','g');// Use a sourceURL for easier debugging.
- var sourceURL='//# sourceURL='+('sourceURL'in options?options.sourceURL:'lodash.templateSources['+ ++templateCounter+']')+'\n';string.replace(reDelimiters,function(match,escapeValue,interpolateValue,esTemplateValue,evaluateValue,offset){interpolateValue||(interpolateValue=esTemplateValue);// Escape characters that can't be included in string literals.
- source+=string.slice(index,offset).replace(reUnescapedString,escapeStringChar);// Replace delimiters with snippets.
- if(escapeValue){isEscaping=true;source+="' +\n__e("+escapeValue+") +\n'";}if(evaluateValue){isEvaluating=true;source+="';\n"+evaluateValue+";\n__p += '";}if(interpolateValue){source+="' +\n((__t = ("+interpolateValue+")) == null ? '' : __t) +\n'";}index=offset+match.length;// The JS engine embedded in Adobe products needs `match` returned in
- // order to produce the correct `offset` value.
- return match;});source+="';\n";// If `variable` is not specified wrap a with-statement around the generated
- // code to add the data object to the top of the scope chain.
- var variable=options.variable;if(!variable){source='with (obj) {\n'+source+'\n}\n';}// Cleanup code by stripping empty strings.
- source=(isEvaluating?source.replace(reEmptyStringLeading,''):source).replace(reEmptyStringMiddle,'$1').replace(reEmptyStringTrailing,'$1;');// Frame code as the function body.
- source='function('+(variable||'obj')+') {\n'+(variable?'':'obj || (obj = {});\n')+"var __t, __p = ''"+(isEscaping?', __e = _.escape':'')+(isEvaluating?', __j = Array.prototype.join;\n'+"function print() { __p += __j.call(arguments, '') }\n":';\n')+source+'return __p\n}';var result=attempt(function(){return Function(importsKeys,sourceURL+'return '+source).apply(undefined,importsValues);});// Provide the compiled function's source by its `toString` method or
- // the `source` property as a convenience for inlining compiled templates.
- result.source=source;if(isError(result)){throw result;}return result;}/**
- * Converts `string`, as a whole, to lower case just like
- * [String#toLowerCase](https://mdn.io/toLowerCase).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to convert.
- * @returns {string} Returns the lower cased string.
- * @example
- *
- * _.toLower('--Foo-Bar--');
- * // => '--foo-bar--'
- *
- * _.toLower('fooBar');
- * // => 'foobar'
- *
- * _.toLower('__FOO_BAR__');
- * // => '__foo_bar__'
- */function toLower(value){return toString(value).toLowerCase();}/**
- * Converts `string`, as a whole, to upper case just like
- * [String#toUpperCase](https://mdn.io/toUpperCase).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to convert.
- * @returns {string} Returns the upper cased string.
- * @example
- *
- * _.toUpper('--foo-bar--');
- * // => '--FOO-BAR--'
- *
- * _.toUpper('fooBar');
- * // => 'FOOBAR'
- *
- * _.toUpper('__foo_bar__');
- * // => '__FOO_BAR__'
- */function toUpper(value){return toString(value).toUpperCase();}/**
- * Removes leading and trailing whitespace or specified characters from `string`.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to trim.
- * @param {string} [chars=whitespace] The characters to trim.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {string} Returns the trimmed string.
- * @example
- *
- * _.trim(' abc ');
- * // => 'abc'
- *
- * _.trim('-_-abc-_-', '_-');
- * // => 'abc'
- *
- * _.map([' foo ', ' bar '], _.trim);
- * // => ['foo', 'bar']
- */function trim(string,chars,guard){string=toString(string);if(string&&(guard||chars===undefined)){return string.replace(reTrim,'');}if(!string||!(chars=baseToString(chars))){return string;}var strSymbols=stringToArray(string),chrSymbols=stringToArray(chars),start=charsStartIndex(strSymbols,chrSymbols),end=charsEndIndex(strSymbols,chrSymbols)+1;return castSlice(strSymbols,start,end).join('');}/**
- * Removes trailing whitespace or specified characters from `string`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to trim.
- * @param {string} [chars=whitespace] The characters to trim.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {string} Returns the trimmed string.
- * @example
- *
- * _.trimEnd(' abc ');
- * // => ' abc'
- *
- * _.trimEnd('-_-abc-_-', '_-');
- * // => '-_-abc'
- */function trimEnd(string,chars,guard){string=toString(string);if(string&&(guard||chars===undefined)){return string.replace(reTrimEnd,'');}if(!string||!(chars=baseToString(chars))){return string;}var strSymbols=stringToArray(string),end=charsEndIndex(strSymbols,stringToArray(chars))+1;return castSlice(strSymbols,0,end).join('');}/**
- * Removes leading whitespace or specified characters from `string`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to trim.
- * @param {string} [chars=whitespace] The characters to trim.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {string} Returns the trimmed string.
- * @example
- *
- * _.trimStart(' abc ');
- * // => 'abc '
- *
- * _.trimStart('-_-abc-_-', '_-');
- * // => 'abc-_-'
- */function trimStart(string,chars,guard){string=toString(string);if(string&&(guard||chars===undefined)){return string.replace(reTrimStart,'');}if(!string||!(chars=baseToString(chars))){return string;}var strSymbols=stringToArray(string),start=charsStartIndex(strSymbols,stringToArray(chars));return castSlice(strSymbols,start).join('');}/**
- * Truncates `string` if it's longer than the given maximum string length.
- * The last characters of the truncated string are replaced with the omission
- * string which defaults to "...".
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to truncate.
- * @param {Object} [options={}] The options object.
- * @param {number} [options.length=30] The maximum string length.
- * @param {string} [options.omission='...'] The string to indicate text is omitted.
- * @param {RegExp|string} [options.separator] The separator pattern to truncate to.
- * @returns {string} Returns the truncated string.
- * @example
- *
- * _.truncate('hi-diddly-ho there, neighborino');
- * // => 'hi-diddly-ho there, neighbo...'
- *
- * _.truncate('hi-diddly-ho there, neighborino', {
- * 'length': 24,
- * 'separator': ' '
- * });
- * // => 'hi-diddly-ho there,...'
- *
- * _.truncate('hi-diddly-ho there, neighborino', {
- * 'length': 24,
- * 'separator': /,? +/
- * });
- * // => 'hi-diddly-ho there...'
- *
- * _.truncate('hi-diddly-ho there, neighborino', {
- * 'omission': ' [...]'
- * });
- * // => 'hi-diddly-ho there, neig [...]'
- */function truncate(string,options){var length=DEFAULT_TRUNC_LENGTH,omission=DEFAULT_TRUNC_OMISSION;if(isObject(options)){var separator='separator'in options?options.separator:separator;length='length'in options?toInteger(options.length):length;omission='omission'in options?baseToString(options.omission):omission;}string=toString(string);var strLength=string.length;if(hasUnicode(string)){var strSymbols=stringToArray(string);strLength=strSymbols.length;}if(length>=strLength){return string;}var end=length-stringSize(omission);if(end<1){return omission;}var result=strSymbols?castSlice(strSymbols,0,end).join(''):string.slice(0,end);if(separator===undefined){return result+omission;}if(strSymbols){end+=result.length-end;}if(isRegExp(separator)){if(string.slice(end).search(separator)){var match,substring=result;if(!separator.global){separator=RegExp(separator.source,toString(reFlags.exec(separator))+'g');}separator.lastIndex=0;while(match=separator.exec(substring)){var newEnd=match.index;}result=result.slice(0,newEnd===undefined?end:newEnd);}}else if(string.indexOf(baseToString(separator),end)!=end){var index=result.lastIndexOf(separator);if(index>-1){result=result.slice(0,index);}}return result+omission;}/**
- * The inverse of `_.escape`; this method converts the HTML entities
- * `&`, `<`, `>`, `"`, and `'` in `string` to
- * their corresponding characters.
- *
- * **Note:** No other HTML entities are unescaped. To unescape additional
- * HTML entities use a third-party library like [_he_](https://mths.be/he).
- *
- * @static
- * @memberOf _
- * @since 0.6.0
- * @category String
- * @param {string} [string=''] The string to unescape.
- * @returns {string} Returns the unescaped string.
- * @example
- *
- * _.unescape('fred, barney, & pebbles');
- * // => 'fred, barney, & pebbles'
- */function unescape(string){string=toString(string);return string&&reHasEscapedHtml.test(string)?string.replace(reEscapedHtml,unescapeHtmlChar):string;}/**
- * Converts `string`, as space separated words, to upper case.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to convert.
- * @returns {string} Returns the upper cased string.
- * @example
- *
- * _.upperCase('--foo-bar');
- * // => 'FOO BAR'
- *
- * _.upperCase('fooBar');
- * // => 'FOO BAR'
- *
- * _.upperCase('__foo_bar__');
- * // => 'FOO BAR'
- */var upperCase=createCompounder(function(result,word,index){return result+(index?' ':'')+word.toUpperCase();});/**
- * Converts the first character of `string` to upper case.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category String
- * @param {string} [string=''] The string to convert.
- * @returns {string} Returns the converted string.
- * @example
- *
- * _.upperFirst('fred');
- * // => 'Fred'
- *
- * _.upperFirst('FRED');
- * // => 'FRED'
- */var upperFirst=createCaseFirst('toUpperCase');/**
- * Splits `string` into an array of its words.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category String
- * @param {string} [string=''] The string to inspect.
- * @param {RegExp|string} [pattern] The pattern to match words.
- * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
- * @returns {Array} Returns the words of `string`.
- * @example
- *
- * _.words('fred, barney, & pebbles');
- * // => ['fred', 'barney', 'pebbles']
- *
- * _.words('fred, barney, & pebbles', /[^, ]+/g);
- * // => ['fred', 'barney', '&', 'pebbles']
- */function words(string,pattern,guard){string=toString(string);pattern=guard?undefined:pattern;if(pattern===undefined){return hasUnicodeWord(string)?unicodeWords(string):asciiWords(string);}return string.match(pattern)||[];}/* ------------------------------------------------------------------------*//**
- * Attempts to invoke `func`, returning either the result or the caught error
- * object. Any additional arguments are provided to `func` when it's invoked.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Util
- * @param {Function} func The function to attempt.
- * @param {...*} [args] The arguments to invoke `func` with.
- * @returns {*} Returns the `func` result or error object.
- * @example
- *
- * // Avoid throwing errors for invalid selectors.
- * var elements = _.attempt(function(selector) {
- * return document.querySelectorAll(selector);
- * }, '>_>');
- *
- * if (_.isError(elements)) {
- * elements = [];
- * }
- */var attempt=baseRest(function(func,args){try{return apply(func,undefined,args);}catch(e){return isError(e)?e:new Error(e);}});/**
- * Binds methods of an object to the object itself, overwriting the existing
- * method.
- *
- * **Note:** This method doesn't set the "length" property of bound functions.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Util
- * @param {Object} object The object to bind and assign the bound methods to.
- * @param {...(string|string[])} methodNames The object method names to bind.
- * @returns {Object} Returns `object`.
- * @example
- *
- * var view = {
- * 'label': 'docs',
- * 'click': function() {
- * console.log('clicked ' + this.label);
- * }
- * };
- *
- * _.bindAll(view, ['click']);
- * jQuery(element).on('click', view.click);
- * // => Logs 'clicked docs' when clicked.
- */var bindAll=flatRest(function(object,methodNames){arrayEach(methodNames,function(key){key=toKey(key);baseAssignValue(object,key,bind(object[key],object));});return object;});/**
- * Creates a function that iterates over `pairs` and invokes the corresponding
- * function of the first predicate to return truthy. The predicate-function
- * pairs are invoked with the `this` binding and arguments of the created
- * function.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Util
- * @param {Array} pairs The predicate-function pairs.
- * @returns {Function} Returns the new composite function.
- * @example
- *
- * var func = _.cond([
- * [_.matches({ 'a': 1 }), _.constant('matches A')],
- * [_.conforms({ 'b': _.isNumber }), _.constant('matches B')],
- * [_.stubTrue, _.constant('no match')]
- * ]);
- *
- * func({ 'a': 1, 'b': 2 });
- * // => 'matches A'
- *
- * func({ 'a': 0, 'b': 1 });
- * // => 'matches B'
- *
- * func({ 'a': '1', 'b': '2' });
- * // => 'no match'
- */function cond(pairs){var length=pairs==null?0:pairs.length,toIteratee=getIteratee();pairs=!length?[]:arrayMap(pairs,function(pair){if(typeof pair[1]!=='function'){throw new TypeError(FUNC_ERROR_TEXT);}return[toIteratee(pair[0]),pair[1]];});return baseRest(function(args){var index=-1;while(++index<length){var pair=pairs[index];if(apply(pair[0],this,args)){return apply(pair[1],this,args);}}});}/**
- * Creates a function that invokes the predicate properties of `source` with
- * the corresponding property values of a given object, returning `true` if
- * all predicates return truthy, else `false`.
- *
- * **Note:** The created function is equivalent to `_.conformsTo` with
- * `source` partially applied.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Util
- * @param {Object} source The object of property predicates to conform to.
- * @returns {Function} Returns the new spec function.
- * @example
- *
- * var objects = [
- * { 'a': 2, 'b': 1 },
- * { 'a': 1, 'b': 2 }
- * ];
- *
- * _.filter(objects, _.conforms({ 'b': function(n) { return n > 1; } }));
- * // => [{ 'a': 1, 'b': 2 }]
- */function conforms(source){return baseConforms(baseClone(source,CLONE_DEEP_FLAG));}/**
- * Creates a function that returns `value`.
- *
- * @static
- * @memberOf _
- * @since 2.4.0
- * @category Util
- * @param {*} value The value to return from the new function.
- * @returns {Function} Returns the new constant function.
- * @example
- *
- * var objects = _.times(2, _.constant({ 'a': 1 }));
- *
- * console.log(objects);
- * // => [{ 'a': 1 }, { 'a': 1 }]
- *
- * console.log(objects[0] === objects[1]);
- * // => true
- */function constant(value){return function(){return value;};}/**
- * Checks `value` to determine whether a default value should be returned in
- * its place. The `defaultValue` is returned if `value` is `NaN`, `null`,
- * or `undefined`.
- *
- * @static
- * @memberOf _
- * @since 4.14.0
- * @category Util
- * @param {*} value The value to check.
- * @param {*} defaultValue The default value.
- * @returns {*} Returns the resolved value.
- * @example
- *
- * _.defaultTo(1, 10);
- * // => 1
- *
- * _.defaultTo(undefined, 10);
- * // => 10
- */function defaultTo(value,defaultValue){return value==null||value!==value?defaultValue:value;}/**
- * Creates a function that returns the result of invoking the given functions
- * with the `this` binding of the created function, where each successive
- * invocation is supplied the return value of the previous.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Util
- * @param {...(Function|Function[])} [funcs] The functions to invoke.
- * @returns {Function} Returns the new composite function.
- * @see _.flowRight
- * @example
- *
- * function square(n) {
- * return n * n;
- * }
- *
- * var addSquare = _.flow([_.add, square]);
- * addSquare(1, 2);
- * // => 9
- */var flow=createFlow();/**
- * This method is like `_.flow` except that it creates a function that
- * invokes the given functions from right to left.
- *
- * @static
- * @since 3.0.0
- * @memberOf _
- * @category Util
- * @param {...(Function|Function[])} [funcs] The functions to invoke.
- * @returns {Function} Returns the new composite function.
- * @see _.flow
- * @example
- *
- * function square(n) {
- * return n * n;
- * }
- *
- * var addSquare = _.flowRight([square, _.add]);
- * addSquare(1, 2);
- * // => 9
- */var flowRight=createFlow(true);/**
- * This method returns the first argument it receives.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Util
- * @param {*} value Any value.
- * @returns {*} Returns `value`.
- * @example
- *
- * var object = { 'a': 1 };
- *
- * console.log(_.identity(object) === object);
- * // => true
- */function identity(value){return value;}/**
- * Creates a function that invokes `func` with the arguments of the created
- * function. If `func` is a property name, the created function returns the
- * property value for a given element. If `func` is an array or object, the
- * created function returns `true` for elements that contain the equivalent
- * source properties, otherwise it returns `false`.
- *
- * @static
- * @since 4.0.0
- * @memberOf _
- * @category Util
- * @param {*} [func=_.identity] The value to convert to a callback.
- * @returns {Function} Returns the callback.
- * @example
- *
- * var users = [
- * { 'user': 'barney', 'age': 36, 'active': true },
- * { 'user': 'fred', 'age': 40, 'active': false }
- * ];
- *
- * // The `_.matches` iteratee shorthand.
- * _.filter(users, _.iteratee({ 'user': 'barney', 'active': true }));
- * // => [{ 'user': 'barney', 'age': 36, 'active': true }]
- *
- * // The `_.matchesProperty` iteratee shorthand.
- * _.filter(users, _.iteratee(['user', 'fred']));
- * // => [{ 'user': 'fred', 'age': 40 }]
- *
- * // The `_.property` iteratee shorthand.
- * _.map(users, _.iteratee('user'));
- * // => ['barney', 'fred']
- *
- * // Create custom iteratee shorthands.
- * _.iteratee = _.wrap(_.iteratee, function(iteratee, func) {
- * return !_.isRegExp(func) ? iteratee(func) : function(string) {
- * return func.test(string);
- * };
- * });
- *
- * _.filter(['abc', 'def'], /ef/);
- * // => ['def']
- */function iteratee(func){return baseIteratee(typeof func==='function'?func:baseClone(func,CLONE_DEEP_FLAG));}/**
- * Creates a function that performs a partial deep comparison between a given
- * object and `source`, returning `true` if the given object has equivalent
- * property values, else `false`.
- *
- * **Note:** The created function is equivalent to `_.isMatch` with `source`
- * partially applied.
- *
- * Partial comparisons will match empty array and empty object `source`
- * values against any array or object value, respectively. See `_.isEqual`
- * for a list of supported value comparisons.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Util
- * @param {Object} source The object of property values to match.
- * @returns {Function} Returns the new spec function.
- * @example
- *
- * var objects = [
- * { 'a': 1, 'b': 2, 'c': 3 },
- * { 'a': 4, 'b': 5, 'c': 6 }
- * ];
- *
- * _.filter(objects, _.matches({ 'a': 4, 'c': 6 }));
- * // => [{ 'a': 4, 'b': 5, 'c': 6 }]
- */function matches(source){return baseMatches(baseClone(source,CLONE_DEEP_FLAG));}/**
- * Creates a function that performs a partial deep comparison between the
- * value at `path` of a given object to `srcValue`, returning `true` if the
- * object value is equivalent, else `false`.
- *
- * **Note:** Partial comparisons will match empty array and empty object
- * `srcValue` values against any array or object value, respectively. See
- * `_.isEqual` for a list of supported value comparisons.
- *
- * @static
- * @memberOf _
- * @since 3.2.0
- * @category Util
- * @param {Array|string} path The path of the property to get.
- * @param {*} srcValue The value to match.
- * @returns {Function} Returns the new spec function.
- * @example
- *
- * var objects = [
- * { 'a': 1, 'b': 2, 'c': 3 },
- * { 'a': 4, 'b': 5, 'c': 6 }
- * ];
- *
- * _.find(objects, _.matchesProperty('a', 4));
- * // => { 'a': 4, 'b': 5, 'c': 6 }
- */function matchesProperty(path,srcValue){return baseMatchesProperty(path,baseClone(srcValue,CLONE_DEEP_FLAG));}/**
- * Creates a function that invokes the method at `path` of a given object.
- * Any additional arguments are provided to the invoked method.
- *
- * @static
- * @memberOf _
- * @since 3.7.0
- * @category Util
- * @param {Array|string} path The path of the method to invoke.
- * @param {...*} [args] The arguments to invoke the method with.
- * @returns {Function} Returns the new invoker function.
- * @example
- *
- * var objects = [
- * { 'a': { 'b': _.constant(2) } },
- * { 'a': { 'b': _.constant(1) } }
- * ];
- *
- * _.map(objects, _.method('a.b'));
- * // => [2, 1]
- *
- * _.map(objects, _.method(['a', 'b']));
- * // => [2, 1]
- */var method=baseRest(function(path,args){return function(object){return baseInvoke(object,path,args);};});/**
- * The opposite of `_.method`; this method creates a function that invokes
- * the method at a given path of `object`. Any additional arguments are
- * provided to the invoked method.
- *
- * @static
- * @memberOf _
- * @since 3.7.0
- * @category Util
- * @param {Object} object The object to query.
- * @param {...*} [args] The arguments to invoke the method with.
- * @returns {Function} Returns the new invoker function.
- * @example
- *
- * var array = _.times(3, _.constant),
- * object = { 'a': array, 'b': array, 'c': array };
- *
- * _.map(['a[2]', 'c[0]'], _.methodOf(object));
- * // => [2, 0]
- *
- * _.map([['a', '2'], ['c', '0']], _.methodOf(object));
- * // => [2, 0]
- */var methodOf=baseRest(function(object,args){return function(path){return baseInvoke(object,path,args);};});/**
- * Adds all own enumerable string keyed function properties of a source
- * object to the destination object. If `object` is a function, then methods
- * are added to its prototype as well.
- *
- * **Note:** Use `_.runInContext` to create a pristine `lodash` function to
- * avoid conflicts caused by modifying the original.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Util
- * @param {Function|Object} [object=lodash] The destination object.
- * @param {Object} source The object of functions to add.
- * @param {Object} [options={}] The options object.
- * @param {boolean} [options.chain=true] Specify whether mixins are chainable.
- * @returns {Function|Object} Returns `object`.
- * @example
- *
- * function vowels(string) {
- * return _.filter(string, function(v) {
- * return /[aeiou]/i.test(v);
- * });
- * }
- *
- * _.mixin({ 'vowels': vowels });
- * _.vowels('fred');
- * // => ['e']
- *
- * _('fred').vowels().value();
- * // => ['e']
- *
- * _.mixin({ 'vowels': vowels }, { 'chain': false });
- * _('fred').vowels();
- * // => ['e']
- */function mixin(object,source,options){var props=keys(source),methodNames=baseFunctions(source,props);if(options==null&&!(isObject(source)&&(methodNames.length||!props.length))){options=source;source=object;object=this;methodNames=baseFunctions(source,keys(source));}var chain=!(isObject(options)&&'chain'in options)||!!options.chain,isFunc=isFunction(object);arrayEach(methodNames,function(methodName){var func=source[methodName];object[methodName]=func;if(isFunc){object.prototype[methodName]=function(){var chainAll=this.__chain__;if(chain||chainAll){var result=object(this.__wrapped__),actions=result.__actions__=copyArray(this.__actions__);actions.push({func:func,args:arguments,thisArg:object});result.__chain__=chainAll;return result;}return func.apply(object,arrayPush([this.value()],arguments));};}});return object;}/**
- * Reverts the `_` variable to its previous value and returns a reference to
- * the `lodash` function.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Util
- * @returns {Function} Returns the `lodash` function.
- * @example
- *
- * var lodash = _.noConflict();
- */function noConflict(){if(root._===this){root._=oldDash;}return this;}/**
- * This method returns `undefined`.
- *
- * @static
- * @memberOf _
- * @since 2.3.0
- * @category Util
- * @example
- *
- * _.times(2, _.noop);
- * // => [undefined, undefined]
- */function noop(){}// No operation performed.
- /**
- * Creates a function that gets the argument at index `n`. If `n` is negative,
- * the nth argument from the end is returned.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Util
- * @param {number} [n=0] The index of the argument to return.
- * @returns {Function} Returns the new pass-thru function.
- * @example
- *
- * var func = _.nthArg(1);
- * func('a', 'b', 'c', 'd');
- * // => 'b'
- *
- * var func = _.nthArg(-2);
- * func('a', 'b', 'c', 'd');
- * // => 'c'
- */function nthArg(n){n=toInteger(n);return baseRest(function(args){return baseNth(args,n);});}/**
- * Creates a function that invokes `iteratees` with the arguments it receives
- * and returns their results.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Util
- * @param {...(Function|Function[])} [iteratees=[_.identity]]
- * The iteratees to invoke.
- * @returns {Function} Returns the new function.
- * @example
- *
- * var func = _.over([Math.max, Math.min]);
- *
- * func(1, 2, 3, 4);
- * // => [4, 1]
- */var over=createOver(arrayMap);/**
- * Creates a function that checks if **all** of the `predicates` return
- * truthy when invoked with the arguments it receives.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Util
- * @param {...(Function|Function[])} [predicates=[_.identity]]
- * The predicates to check.
- * @returns {Function} Returns the new function.
- * @example
- *
- * var func = _.overEvery([Boolean, isFinite]);
- *
- * func('1');
- * // => true
- *
- * func(null);
- * // => false
- *
- * func(NaN);
- * // => false
- */var overEvery=createOver(arrayEvery);/**
- * Creates a function that checks if **any** of the `predicates` return
- * truthy when invoked with the arguments it receives.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Util
- * @param {...(Function|Function[])} [predicates=[_.identity]]
- * The predicates to check.
- * @returns {Function} Returns the new function.
- * @example
- *
- * var func = _.overSome([Boolean, isFinite]);
- *
- * func('1');
- * // => true
- *
- * func(null);
- * // => true
- *
- * func(NaN);
- * // => false
- */var overSome=createOver(arraySome);/**
- * Creates a function that returns the value at `path` of a given object.
- *
- * @static
- * @memberOf _
- * @since 2.4.0
- * @category Util
- * @param {Array|string} path The path of the property to get.
- * @returns {Function} Returns the new accessor function.
- * @example
- *
- * var objects = [
- * { 'a': { 'b': 2 } },
- * { 'a': { 'b': 1 } }
- * ];
- *
- * _.map(objects, _.property('a.b'));
- * // => [2, 1]
- *
- * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');
- * // => [1, 2]
- */function property(path){return isKey(path)?baseProperty(toKey(path)):basePropertyDeep(path);}/**
- * The opposite of `_.property`; this method creates a function that returns
- * the value at a given path of `object`.
- *
- * @static
- * @memberOf _
- * @since 3.0.0
- * @category Util
- * @param {Object} object The object to query.
- * @returns {Function} Returns the new accessor function.
- * @example
- *
- * var array = [0, 1, 2],
- * object = { 'a': array, 'b': array, 'c': array };
- *
- * _.map(['a[2]', 'c[0]'], _.propertyOf(object));
- * // => [2, 0]
- *
- * _.map([['a', '2'], ['c', '0']], _.propertyOf(object));
- * // => [2, 0]
- */function propertyOf(object){return function(path){return object==null?undefined:baseGet(object,path);};}/**
- * Creates an array of numbers (positive and/or negative) progressing from
- * `start` up to, but not including, `end`. A step of `-1` is used if a negative
- * `start` is specified without an `end` or `step`. If `end` is not specified,
- * it's set to `start` with `start` then set to `0`.
- *
- * **Note:** JavaScript follows the IEEE-754 standard for resolving
- * floating-point values which can produce unexpected results.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Util
- * @param {number} [start=0] The start of the range.
- * @param {number} end The end of the range.
- * @param {number} [step=1] The value to increment or decrement by.
- * @returns {Array} Returns the range of numbers.
- * @see _.inRange, _.rangeRight
- * @example
- *
- * _.range(4);
- * // => [0, 1, 2, 3]
- *
- * _.range(-4);
- * // => [0, -1, -2, -3]
- *
- * _.range(1, 5);
- * // => [1, 2, 3, 4]
- *
- * _.range(0, 20, 5);
- * // => [0, 5, 10, 15]
- *
- * _.range(0, -4, -1);
- * // => [0, -1, -2, -3]
- *
- * _.range(1, 4, 0);
- * // => [1, 1, 1]
- *
- * _.range(0);
- * // => []
- */var range=createRange();/**
- * This method is like `_.range` except that it populates values in
- * descending order.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Util
- * @param {number} [start=0] The start of the range.
- * @param {number} end The end of the range.
- * @param {number} [step=1] The value to increment or decrement by.
- * @returns {Array} Returns the range of numbers.
- * @see _.inRange, _.range
- * @example
- *
- * _.rangeRight(4);
- * // => [3, 2, 1, 0]
- *
- * _.rangeRight(-4);
- * // => [-3, -2, -1, 0]
- *
- * _.rangeRight(1, 5);
- * // => [4, 3, 2, 1]
- *
- * _.rangeRight(0, 20, 5);
- * // => [15, 10, 5, 0]
- *
- * _.rangeRight(0, -4, -1);
- * // => [-3, -2, -1, 0]
- *
- * _.rangeRight(1, 4, 0);
- * // => [1, 1, 1]
- *
- * _.rangeRight(0);
- * // => []
- */var rangeRight=createRange(true);/**
- * This method returns a new empty array.
- *
- * @static
- * @memberOf _
- * @since 4.13.0
- * @category Util
- * @returns {Array} Returns the new empty array.
- * @example
- *
- * var arrays = _.times(2, _.stubArray);
- *
- * console.log(arrays);
- * // => [[], []]
- *
- * console.log(arrays[0] === arrays[1]);
- * // => false
- */function stubArray(){return[];}/**
- * This method returns `false`.
- *
- * @static
- * @memberOf _
- * @since 4.13.0
- * @category Util
- * @returns {boolean} Returns `false`.
- * @example
- *
- * _.times(2, _.stubFalse);
- * // => [false, false]
- */function stubFalse(){return false;}/**
- * This method returns a new empty object.
- *
- * @static
- * @memberOf _
- * @since 4.13.0
- * @category Util
- * @returns {Object} Returns the new empty object.
- * @example
- *
- * var objects = _.times(2, _.stubObject);
- *
- * console.log(objects);
- * // => [{}, {}]
- *
- * console.log(objects[0] === objects[1]);
- * // => false
- */function stubObject(){return{};}/**
- * This method returns an empty string.
- *
- * @static
- * @memberOf _
- * @since 4.13.0
- * @category Util
- * @returns {string} Returns the empty string.
- * @example
- *
- * _.times(2, _.stubString);
- * // => ['', '']
- */function stubString(){return'';}/**
- * This method returns `true`.
- *
- * @static
- * @memberOf _
- * @since 4.13.0
- * @category Util
- * @returns {boolean} Returns `true`.
- * @example
- *
- * _.times(2, _.stubTrue);
- * // => [true, true]
- */function stubTrue(){return true;}/**
- * Invokes the iteratee `n` times, returning an array of the results of
- * each invocation. The iteratee is invoked with one argument; (index).
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Util
- * @param {number} n The number of times to invoke `iteratee`.
- * @param {Function} [iteratee=_.identity] The function invoked per iteration.
- * @returns {Array} Returns the array of results.
- * @example
- *
- * _.times(3, String);
- * // => ['0', '1', '2']
- *
- * _.times(4, _.constant(0));
- * // => [0, 0, 0, 0]
- */function times(n,iteratee){n=toInteger(n);if(n<1||n>MAX_SAFE_INTEGER){return[];}var index=MAX_ARRAY_LENGTH,length=nativeMin(n,MAX_ARRAY_LENGTH);iteratee=getIteratee(iteratee);n-=MAX_ARRAY_LENGTH;var result=baseTimes(length,iteratee);while(++index<n){iteratee(index);}return result;}/**
- * Converts `value` to a property path array.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Util
- * @param {*} value The value to convert.
- * @returns {Array} Returns the new property path array.
- * @example
- *
- * _.toPath('a.b.c');
- * // => ['a', 'b', 'c']
- *
- * _.toPath('a[0].b.c');
- * // => ['a', '0', 'b', 'c']
- */function toPath(value){if(isArray(value)){return arrayMap(value,toKey);}return isSymbol(value)?[value]:copyArray(stringToPath(toString(value)));}/**
- * Generates a unique ID. If `prefix` is given, the ID is appended to it.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Util
- * @param {string} [prefix=''] The value to prefix the ID with.
- * @returns {string} Returns the unique ID.
- * @example
- *
- * _.uniqueId('contact_');
- * // => 'contact_104'
- *
- * _.uniqueId();
- * // => '105'
- */function uniqueId(prefix){var id=++idCounter;return toString(prefix)+id;}/* ------------------------------------------------------------------------*//**
- * Adds two numbers.
- *
- * @static
- * @memberOf _
- * @since 3.4.0
- * @category Math
- * @param {number} augend The first number in an addition.
- * @param {number} addend The second number in an addition.
- * @returns {number} Returns the total.
- * @example
- *
- * _.add(6, 4);
- * // => 10
- */var add=createMathOperation(function(augend,addend){return augend+addend;},0);/**
- * Computes `number` rounded up to `precision`.
- *
- * @static
- * @memberOf _
- * @since 3.10.0
- * @category Math
- * @param {number} number The number to round up.
- * @param {number} [precision=0] The precision to round up to.
- * @returns {number} Returns the rounded up number.
- * @example
- *
- * _.ceil(4.006);
- * // => 5
- *
- * _.ceil(6.004, 2);
- * // => 6.01
- *
- * _.ceil(6040, -2);
- * // => 6100
- */var ceil=createRound('ceil');/**
- * Divide two numbers.
- *
- * @static
- * @memberOf _
- * @since 4.7.0
- * @category Math
- * @param {number} dividend The first number in a division.
- * @param {number} divisor The second number in a division.
- * @returns {number} Returns the quotient.
- * @example
- *
- * _.divide(6, 4);
- * // => 1.5
- */var divide=createMathOperation(function(dividend,divisor){return dividend/divisor;},1);/**
- * Computes `number` rounded down to `precision`.
- *
- * @static
- * @memberOf _
- * @since 3.10.0
- * @category Math
- * @param {number} number The number to round down.
- * @param {number} [precision=0] The precision to round down to.
- * @returns {number} Returns the rounded down number.
- * @example
- *
- * _.floor(4.006);
- * // => 4
- *
- * _.floor(0.046, 2);
- * // => 0.04
- *
- * _.floor(4060, -2);
- * // => 4000
- */var floor=createRound('floor');/**
- * Computes the maximum value of `array`. If `array` is empty or falsey,
- * `undefined` is returned.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Math
- * @param {Array} array The array to iterate over.
- * @returns {*} Returns the maximum value.
- * @example
- *
- * _.max([4, 2, 8, 6]);
- * // => 8
- *
- * _.max([]);
- * // => undefined
- */function max(array){return array&&array.length?baseExtremum(array,identity,baseGt):undefined;}/**
- * This method is like `_.max` except that it accepts `iteratee` which is
- * invoked for each element in `array` to generate the criterion by which
- * the value is ranked. The iteratee is invoked with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Math
- * @param {Array} array The array to iterate over.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {*} Returns the maximum value.
- * @example
- *
- * var objects = [{ 'n': 1 }, { 'n': 2 }];
- *
- * _.maxBy(objects, function(o) { return o.n; });
- * // => { 'n': 2 }
- *
- * // The `_.property` iteratee shorthand.
- * _.maxBy(objects, 'n');
- * // => { 'n': 2 }
- */function maxBy(array,iteratee){return array&&array.length?baseExtremum(array,getIteratee(iteratee,2),baseGt):undefined;}/**
- * Computes the mean of the values in `array`.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Math
- * @param {Array} array The array to iterate over.
- * @returns {number} Returns the mean.
- * @example
- *
- * _.mean([4, 2, 8, 6]);
- * // => 5
- */function mean(array){return baseMean(array,identity);}/**
- * This method is like `_.mean` except that it accepts `iteratee` which is
- * invoked for each element in `array` to generate the value to be averaged.
- * The iteratee is invoked with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 4.7.0
- * @category Math
- * @param {Array} array The array to iterate over.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {number} Returns the mean.
- * @example
- *
- * var objects = [{ 'n': 4 }, { 'n': 2 }, { 'n': 8 }, { 'n': 6 }];
- *
- * _.meanBy(objects, function(o) { return o.n; });
- * // => 5
- *
- * // The `_.property` iteratee shorthand.
- * _.meanBy(objects, 'n');
- * // => 5
- */function meanBy(array,iteratee){return baseMean(array,getIteratee(iteratee,2));}/**
- * Computes the minimum value of `array`. If `array` is empty or falsey,
- * `undefined` is returned.
- *
- * @static
- * @since 0.1.0
- * @memberOf _
- * @category Math
- * @param {Array} array The array to iterate over.
- * @returns {*} Returns the minimum value.
- * @example
- *
- * _.min([4, 2, 8, 6]);
- * // => 2
- *
- * _.min([]);
- * // => undefined
- */function min(array){return array&&array.length?baseExtremum(array,identity,baseLt):undefined;}/**
- * This method is like `_.min` except that it accepts `iteratee` which is
- * invoked for each element in `array` to generate the criterion by which
- * the value is ranked. The iteratee is invoked with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Math
- * @param {Array} array The array to iterate over.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {*} Returns the minimum value.
- * @example
- *
- * var objects = [{ 'n': 1 }, { 'n': 2 }];
- *
- * _.minBy(objects, function(o) { return o.n; });
- * // => { 'n': 1 }
- *
- * // The `_.property` iteratee shorthand.
- * _.minBy(objects, 'n');
- * // => { 'n': 1 }
- */function minBy(array,iteratee){return array&&array.length?baseExtremum(array,getIteratee(iteratee,2),baseLt):undefined;}/**
- * Multiply two numbers.
- *
- * @static
- * @memberOf _
- * @since 4.7.0
- * @category Math
- * @param {number} multiplier The first number in a multiplication.
- * @param {number} multiplicand The second number in a multiplication.
- * @returns {number} Returns the product.
- * @example
- *
- * _.multiply(6, 4);
- * // => 24
- */var multiply=createMathOperation(function(multiplier,multiplicand){return multiplier*multiplicand;},1);/**
- * Computes `number` rounded to `precision`.
- *
- * @static
- * @memberOf _
- * @since 3.10.0
- * @category Math
- * @param {number} number The number to round.
- * @param {number} [precision=0] The precision to round to.
- * @returns {number} Returns the rounded number.
- * @example
- *
- * _.round(4.006);
- * // => 4
- *
- * _.round(4.006, 2);
- * // => 4.01
- *
- * _.round(4060, -2);
- * // => 4100
- */var round=createRound('round');/**
- * Subtract two numbers.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Math
- * @param {number} minuend The first number in a subtraction.
- * @param {number} subtrahend The second number in a subtraction.
- * @returns {number} Returns the difference.
- * @example
- *
- * _.subtract(6, 4);
- * // => 2
- */var subtract=createMathOperation(function(minuend,subtrahend){return minuend-subtrahend;},0);/**
- * Computes the sum of the values in `array`.
- *
- * @static
- * @memberOf _
- * @since 3.4.0
- * @category Math
- * @param {Array} array The array to iterate over.
- * @returns {number} Returns the sum.
- * @example
- *
- * _.sum([4, 2, 8, 6]);
- * // => 20
- */function sum(array){return array&&array.length?baseSum(array,identity):0;}/**
- * This method is like `_.sum` except that it accepts `iteratee` which is
- * invoked for each element in `array` to generate the value to be summed.
- * The iteratee is invoked with one argument: (value).
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Math
- * @param {Array} array The array to iterate over.
- * @param {Function} [iteratee=_.identity] The iteratee invoked per element.
- * @returns {number} Returns the sum.
- * @example
- *
- * var objects = [{ 'n': 4 }, { 'n': 2 }, { 'n': 8 }, { 'n': 6 }];
- *
- * _.sumBy(objects, function(o) { return o.n; });
- * // => 20
- *
- * // The `_.property` iteratee shorthand.
- * _.sumBy(objects, 'n');
- * // => 20
- */function sumBy(array,iteratee){return array&&array.length?baseSum(array,getIteratee(iteratee,2)):0;}/* ------------------------------------------------------------------------*/// Add methods that return wrapped values in chain sequences.
- lodash.after=after;lodash.ary=ary;lodash.assign=assign;lodash.assignIn=assignIn;lodash.assignInWith=assignInWith;lodash.assignWith=assignWith;lodash.at=at;lodash.before=before;lodash.bind=bind;lodash.bindAll=bindAll;lodash.bindKey=bindKey;lodash.castArray=castArray;lodash.chain=chain;lodash.chunk=chunk;lodash.compact=compact;lodash.concat=concat;lodash.cond=cond;lodash.conforms=conforms;lodash.constant=constant;lodash.countBy=countBy;lodash.create=create;lodash.curry=curry;lodash.curryRight=curryRight;lodash.debounce=debounce;lodash.defaults=defaults;lodash.defaultsDeep=defaultsDeep;lodash.defer=defer;lodash.delay=delay;lodash.difference=difference;lodash.differenceBy=differenceBy;lodash.differenceWith=differenceWith;lodash.drop=drop;lodash.dropRight=dropRight;lodash.dropRightWhile=dropRightWhile;lodash.dropWhile=dropWhile;lodash.fill=fill;lodash.filter=filter;lodash.flatMap=flatMap;lodash.flatMapDeep=flatMapDeep;lodash.flatMapDepth=flatMapDepth;lodash.flatten=flatten;lodash.flattenDeep=flattenDeep;lodash.flattenDepth=flattenDepth;lodash.flip=flip;lodash.flow=flow;lodash.flowRight=flowRight;lodash.fromPairs=fromPairs;lodash.functions=functions;lodash.functionsIn=functionsIn;lodash.groupBy=groupBy;lodash.initial=initial;lodash.intersection=intersection;lodash.intersectionBy=intersectionBy;lodash.intersectionWith=intersectionWith;lodash.invert=invert;lodash.invertBy=invertBy;lodash.invokeMap=invokeMap;lodash.iteratee=iteratee;lodash.keyBy=keyBy;lodash.keys=keys;lodash.keysIn=keysIn;lodash.map=map;lodash.mapKeys=mapKeys;lodash.mapValues=mapValues;lodash.matches=matches;lodash.matchesProperty=matchesProperty;lodash.memoize=memoize;lodash.merge=merge;lodash.mergeWith=mergeWith;lodash.method=method;lodash.methodOf=methodOf;lodash.mixin=mixin;lodash.negate=negate;lodash.nthArg=nthArg;lodash.omit=omit;lodash.omitBy=omitBy;lodash.once=once;lodash.orderBy=orderBy;lodash.over=over;lodash.overArgs=overArgs;lodash.overEvery=overEvery;lodash.overSome=overSome;lodash.partial=partial;lodash.partialRight=partialRight;lodash.partition=partition;lodash.pick=pick;lodash.pickBy=pickBy;lodash.property=property;lodash.propertyOf=propertyOf;lodash.pull=pull;lodash.pullAll=pullAll;lodash.pullAllBy=pullAllBy;lodash.pullAllWith=pullAllWith;lodash.pullAt=pullAt;lodash.range=range;lodash.rangeRight=rangeRight;lodash.rearg=rearg;lodash.reject=reject;lodash.remove=remove;lodash.rest=rest;lodash.reverse=reverse;lodash.sampleSize=sampleSize;lodash.set=set;lodash.setWith=setWith;lodash.shuffle=shuffle;lodash.slice=slice;lodash.sortBy=sortBy;lodash.sortedUniq=sortedUniq;lodash.sortedUniqBy=sortedUniqBy;lodash.split=split;lodash.spread=spread;lodash.tail=tail;lodash.take=take;lodash.takeRight=takeRight;lodash.takeRightWhile=takeRightWhile;lodash.takeWhile=takeWhile;lodash.tap=tap;lodash.throttle=throttle;lodash.thru=thru;lodash.toArray=toArray;lodash.toPairs=toPairs;lodash.toPairsIn=toPairsIn;lodash.toPath=toPath;lodash.toPlainObject=toPlainObject;lodash.transform=transform;lodash.unary=unary;lodash.union=union;lodash.unionBy=unionBy;lodash.unionWith=unionWith;lodash.uniq=uniq;lodash.uniqBy=uniqBy;lodash.uniqWith=uniqWith;lodash.unset=unset;lodash.unzip=unzip;lodash.unzipWith=unzipWith;lodash.update=update;lodash.updateWith=updateWith;lodash.values=values;lodash.valuesIn=valuesIn;lodash.without=without;lodash.words=words;lodash.wrap=wrap;lodash.xor=xor;lodash.xorBy=xorBy;lodash.xorWith=xorWith;lodash.zip=zip;lodash.zipObject=zipObject;lodash.zipObjectDeep=zipObjectDeep;lodash.zipWith=zipWith;// Add aliases.
- lodash.entries=toPairs;lodash.entriesIn=toPairsIn;lodash.extend=assignIn;lodash.extendWith=assignInWith;// Add methods to `lodash.prototype`.
- mixin(lodash,lodash);/* ------------------------------------------------------------------------*/// Add methods that return unwrapped values in chain sequences.
- lodash.add=add;lodash.attempt=attempt;lodash.camelCase=camelCase;lodash.capitalize=capitalize;lodash.ceil=ceil;lodash.clamp=clamp;lodash.clone=clone;lodash.cloneDeep=cloneDeep;lodash.cloneDeepWith=cloneDeepWith;lodash.cloneWith=cloneWith;lodash.conformsTo=conformsTo;lodash.deburr=deburr;lodash.defaultTo=defaultTo;lodash.divide=divide;lodash.endsWith=endsWith;lodash.eq=eq;lodash.escape=escape;lodash.escapeRegExp=escapeRegExp;lodash.every=every;lodash.find=find;lodash.findIndex=findIndex;lodash.findKey=findKey;lodash.findLast=findLast;lodash.findLastIndex=findLastIndex;lodash.findLastKey=findLastKey;lodash.floor=floor;lodash.forEach=forEach;lodash.forEachRight=forEachRight;lodash.forIn=forIn;lodash.forInRight=forInRight;lodash.forOwn=forOwn;lodash.forOwnRight=forOwnRight;lodash.get=get;lodash.gt=gt;lodash.gte=gte;lodash.has=has;lodash.hasIn=hasIn;lodash.head=head;lodash.identity=identity;lodash.includes=includes;lodash.indexOf=indexOf;lodash.inRange=inRange;lodash.invoke=invoke;lodash.isArguments=isArguments;lodash.isArray=isArray;lodash.isArrayBuffer=isArrayBuffer;lodash.isArrayLike=isArrayLike;lodash.isArrayLikeObject=isArrayLikeObject;lodash.isBoolean=isBoolean;lodash.isBuffer=isBuffer;lodash.isDate=isDate;lodash.isElement=isElement;lodash.isEmpty=isEmpty;lodash.isEqual=isEqual;lodash.isEqualWith=isEqualWith;lodash.isError=isError;lodash.isFinite=isFinite;lodash.isFunction=isFunction;lodash.isInteger=isInteger;lodash.isLength=isLength;lodash.isMap=isMap;lodash.isMatch=isMatch;lodash.isMatchWith=isMatchWith;lodash.isNaN=isNaN;lodash.isNative=isNative;lodash.isNil=isNil;lodash.isNull=isNull;lodash.isNumber=isNumber;lodash.isObject=isObject;lodash.isObjectLike=isObjectLike;lodash.isPlainObject=isPlainObject;lodash.isRegExp=isRegExp;lodash.isSafeInteger=isSafeInteger;lodash.isSet=isSet;lodash.isString=isString;lodash.isSymbol=isSymbol;lodash.isTypedArray=isTypedArray;lodash.isUndefined=isUndefined;lodash.isWeakMap=isWeakMap;lodash.isWeakSet=isWeakSet;lodash.join=join;lodash.kebabCase=kebabCase;lodash.last=last;lodash.lastIndexOf=lastIndexOf;lodash.lowerCase=lowerCase;lodash.lowerFirst=lowerFirst;lodash.lt=lt;lodash.lte=lte;lodash.max=max;lodash.maxBy=maxBy;lodash.mean=mean;lodash.meanBy=meanBy;lodash.min=min;lodash.minBy=minBy;lodash.stubArray=stubArray;lodash.stubFalse=stubFalse;lodash.stubObject=stubObject;lodash.stubString=stubString;lodash.stubTrue=stubTrue;lodash.multiply=multiply;lodash.nth=nth;lodash.noConflict=noConflict;lodash.noop=noop;lodash.now=now;lodash.pad=pad;lodash.padEnd=padEnd;lodash.padStart=padStart;lodash.parseInt=parseInt;lodash.random=random;lodash.reduce=reduce;lodash.reduceRight=reduceRight;lodash.repeat=repeat;lodash.replace=replace;lodash.result=result;lodash.round=round;lodash.runInContext=runInContext;lodash.sample=sample;lodash.size=size;lodash.snakeCase=snakeCase;lodash.some=some;lodash.sortedIndex=sortedIndex;lodash.sortedIndexBy=sortedIndexBy;lodash.sortedIndexOf=sortedIndexOf;lodash.sortedLastIndex=sortedLastIndex;lodash.sortedLastIndexBy=sortedLastIndexBy;lodash.sortedLastIndexOf=sortedLastIndexOf;lodash.startCase=startCase;lodash.startsWith=startsWith;lodash.subtract=subtract;lodash.sum=sum;lodash.sumBy=sumBy;lodash.template=template;lodash.times=times;lodash.toFinite=toFinite;lodash.toInteger=toInteger;lodash.toLength=toLength;lodash.toLower=toLower;lodash.toNumber=toNumber;lodash.toSafeInteger=toSafeInteger;lodash.toString=toString;lodash.toUpper=toUpper;lodash.trim=trim;lodash.trimEnd=trimEnd;lodash.trimStart=trimStart;lodash.truncate=truncate;lodash.unescape=unescape;lodash.uniqueId=uniqueId;lodash.upperCase=upperCase;lodash.upperFirst=upperFirst;// Add aliases.
- lodash.each=forEach;lodash.eachRight=forEachRight;lodash.first=head;mixin(lodash,function(){var source={};baseForOwn(lodash,function(func,methodName){if(!hasOwnProperty.call(lodash.prototype,methodName)){source[methodName]=func;}});return source;}(),{chain:false});/* ------------------------------------------------------------------------*//**
- * The semantic version number.
- *
- * @static
- * @memberOf _
- * @type {string}
- */lodash.VERSION=VERSION;// Assign default placeholders.
- arrayEach(['bind','bindKey','curry','curryRight','partial','partialRight'],function(methodName){lodash[methodName].placeholder=lodash;});// Add `LazyWrapper` methods for `_.drop` and `_.take` variants.
- arrayEach(['drop','take'],function(methodName,index){LazyWrapper.prototype[methodName]=function(n){n=n===undefined?1:nativeMax(toInteger(n),0);var result=this.__filtered__&&!index?new LazyWrapper(this):this.clone();if(result.__filtered__){result.__takeCount__=nativeMin(n,result.__takeCount__);}else{result.__views__.push({size:nativeMin(n,MAX_ARRAY_LENGTH),type:methodName+(result.__dir__<0?'Right':'')});}return result;};LazyWrapper.prototype[methodName+'Right']=function(n){return this.reverse()[methodName](n).reverse();};});// Add `LazyWrapper` methods that accept an `iteratee` value.
- arrayEach(['filter','map','takeWhile'],function(methodName,index){var type=index+1,isFilter=type==LAZY_FILTER_FLAG||type==LAZY_WHILE_FLAG;LazyWrapper.prototype[methodName]=function(iteratee){var result=this.clone();result.__iteratees__.push({iteratee:getIteratee(iteratee,3),type:type});result.__filtered__=result.__filtered__||isFilter;return result;};});// Add `LazyWrapper` methods for `_.head` and `_.last`.
- arrayEach(['head','last'],function(methodName,index){var takeName='take'+(index?'Right':'');LazyWrapper.prototype[methodName]=function(){return this[takeName](1).value()[0];};});// Add `LazyWrapper` methods for `_.initial` and `_.tail`.
- arrayEach(['initial','tail'],function(methodName,index){var dropName='drop'+(index?'':'Right');LazyWrapper.prototype[methodName]=function(){return this.__filtered__?new LazyWrapper(this):this[dropName](1);};});LazyWrapper.prototype.compact=function(){return this.filter(identity);};LazyWrapper.prototype.find=function(predicate){return this.filter(predicate).head();};LazyWrapper.prototype.findLast=function(predicate){return this.reverse().find(predicate);};LazyWrapper.prototype.invokeMap=baseRest(function(path,args){if(typeof path==='function'){return new LazyWrapper(this);}return this.map(function(value){return baseInvoke(value,path,args);});});LazyWrapper.prototype.reject=function(predicate){return this.filter(negate(getIteratee(predicate)));};LazyWrapper.prototype.slice=function(start,end){start=toInteger(start);var result=this;if(result.__filtered__&&(start>0||end<0)){return new LazyWrapper(result);}if(start<0){result=result.takeRight(-start);}else if(start){result=result.drop(start);}if(end!==undefined){end=toInteger(end);result=end<0?result.dropRight(-end):result.take(end-start);}return result;};LazyWrapper.prototype.takeRightWhile=function(predicate){return this.reverse().takeWhile(predicate).reverse();};LazyWrapper.prototype.toArray=function(){return this.take(MAX_ARRAY_LENGTH);};// Add `LazyWrapper` methods to `lodash.prototype`.
- baseForOwn(LazyWrapper.prototype,function(func,methodName){var checkIteratee=/^(?:filter|find|map|reject)|While$/.test(methodName),isTaker=/^(?:head|last)$/.test(methodName),lodashFunc=lodash[isTaker?'take'+(methodName=='last'?'Right':''):methodName],retUnwrapped=isTaker||/^find/.test(methodName);if(!lodashFunc){return;}lodash.prototype[methodName]=function(){var value=this.__wrapped__,args=isTaker?[1]:arguments,isLazy=value instanceof LazyWrapper,iteratee=args[0],useLazy=isLazy||isArray(value);var interceptor=function interceptor(value){var result=lodashFunc.apply(lodash,arrayPush([value],args));return isTaker&&chainAll?result[0]:result;};if(useLazy&&checkIteratee&&typeof iteratee==='function'&&iteratee.length!=1){// Avoid lazy use if the iteratee has a "length" value other than `1`.
- isLazy=useLazy=false;}var chainAll=this.__chain__,isHybrid=!!this.__actions__.length,isUnwrapped=retUnwrapped&&!chainAll,onlyLazy=isLazy&&!isHybrid;if(!retUnwrapped&&useLazy){value=onlyLazy?value:new LazyWrapper(this);var result=func.apply(value,args);result.__actions__.push({func:thru,args:[interceptor],thisArg:undefined});return new LodashWrapper(result,chainAll);}if(isUnwrapped&&onlyLazy){return func.apply(this,args);}result=this.thru(interceptor);return isUnwrapped?isTaker?result.value()[0]:result.value():result;};});// Add `Array` methods to `lodash.prototype`.
- arrayEach(['pop','push','shift','sort','splice','unshift'],function(methodName){var func=arrayProto[methodName],chainName=/^(?:push|sort|unshift)$/.test(methodName)?'tap':'thru',retUnwrapped=/^(?:pop|shift)$/.test(methodName);lodash.prototype[methodName]=function(){var args=arguments;if(retUnwrapped&&!this.__chain__){var value=this.value();return func.apply(isArray(value)?value:[],args);}return this[chainName](function(value){return func.apply(isArray(value)?value:[],args);});};});// Map minified method names to their real names.
- baseForOwn(LazyWrapper.prototype,function(func,methodName){var lodashFunc=lodash[methodName];if(lodashFunc){var key=lodashFunc.name+'',names=realNames[key]||(realNames[key]=[]);names.push({name:methodName,func:lodashFunc});}});realNames[createHybrid(undefined,WRAP_BIND_KEY_FLAG).name]=[{name:'wrapper',func:undefined}];// Add methods to `LazyWrapper`.
- LazyWrapper.prototype.clone=lazyClone;LazyWrapper.prototype.reverse=lazyReverse;LazyWrapper.prototype.value=lazyValue;// Add chain sequence methods to the `lodash` wrapper.
- lodash.prototype.at=wrapperAt;lodash.prototype.chain=wrapperChain;lodash.prototype.commit=wrapperCommit;lodash.prototype.next=wrapperNext;lodash.prototype.plant=wrapperPlant;lodash.prototype.reverse=wrapperReverse;lodash.prototype.toJSON=lodash.prototype.valueOf=lodash.prototype.value=wrapperValue;// Add lazy aliases.
- lodash.prototype.first=lodash.prototype.head;if(symIterator){lodash.prototype[symIterator]=wrapperToIterator;}return lodash;};/* --------------------------------------------------------------------------*/// Export lodash.
- var _=runInContext();// Some AMD build optimizers, like r.js, check for condition patterns like:
- if( true&&_typeof(__webpack_require__(42))==='object'&&__webpack_require__(42)){// Expose Lodash on the global object to prevent errors when Lodash is
- // loaded by a script tag in the presence of an AMD loader.
- // See http://requirejs.org/docs/errors.html#mismatch for more details.
- // Use `_.noConflict` to remove Lodash from the global object.
- root._=_;// Define as an anonymous module so, through path mapping, it can be
- // referenced as the "underscore" module.
- !(__WEBPACK_AMD_DEFINE_RESULT__ = (function(){return _;}).call(exports, __webpack_require__, exports, module),
- __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));}// Check for `exports` after `define` in case a build optimizer adds it.
- else if(freeModule){// Export for Node.js.
- (freeModule.exports=_)._=_;// Export for CommonJS support.
- freeExports._=_;}else{// Export to the global object.
- root._=_;}}).call(undefined);
- /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(41)(module)))
- /***/ }),
- /* 73 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 97);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 97:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button-group.vue?vue&type=template&id=3d8661d0&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c("div", { staticClass: "el-button-group" }, [_vm._t("default")], 2)
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/button/src/button-group.vue?vue&type=template&id=3d8661d0&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button-group.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- /* harmony default export */ var button_groupvue_type_script_lang_js_ = ({
- name: 'ElButtonGroup'
- });
- // CONCATENATED MODULE: ./packages/button/src/button-group.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_button_groupvue_type_script_lang_js_ = (button_groupvue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/button/src/button-group.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_button_groupvue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/button/src/button-group.vue"
- /* harmony default export */ var button_group = (component.exports);
- // CONCATENATED MODULE: ./packages/button-group/index.js
- /* istanbul ignore next */
- button_group.install = function (Vue) {
- Vue.component(button_group.name, button_group);
- };
- /* harmony default export */ var packages_button_group = __webpack_exports__["default"] = (button_group);
- /***/ })
- /******/ });
- /***/ }),
- /* 74 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 93);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 4:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(8);
- /***/ }),
- /***/ 93:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-group.vue?vue&type=template&id=7289a290&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-checkbox-group",
- attrs: { role: "group", "aria-label": "checkbox-group" }
- },
- [_vm._t("default")],
- 2
- )
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue?vue&type=template&id=7289a290&
- // EXTERNAL MODULE: external "element-ui/lib/mixins/emitter"
- var emitter_ = __webpack_require__(4);
- var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-group.vue?vue&type=script&lang=js&
- /* harmony default export */ var checkbox_groupvue_type_script_lang_js_ = ({
- name: 'ElCheckboxGroup',
- componentName: 'ElCheckboxGroup',
- mixins: [emitter_default.a],
- inject: {
- elFormItem: {
- default: ''
- }
- },
- props: {
- value: {},
- disabled: Boolean,
- min: Number,
- max: Number,
- size: String,
- fill: String,
- textColor: String
- },
- computed: {
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- checkboxGroupSize: function checkboxGroupSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- }
- },
- watch: {
- value: function value(_value) {
- this.dispatch('ElFormItem', 'el.form.change', [_value]);
- }
- }
- });
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_checkbox_groupvue_type_script_lang_js_ = (checkbox_groupvue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_checkbox_groupvue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/checkbox/src/checkbox-group.vue"
- /* harmony default export */ var checkbox_group = (component.exports);
- // CONCATENATED MODULE: ./packages/checkbox-group/index.js
- /* istanbul ignore next */
- checkbox_group.install = function (Vue) {
- Vue.component(checkbox_group.name, checkbox_group);
- };
- /* harmony default export */ var packages_checkbox_group = __webpack_exports__["default"] = (checkbox_group);
- /***/ })
- /******/ });
- /***/ }),
- /* 75 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- exports.default = function (instance, callback) {
- var speed = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 300;
- var once = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
- if (!instance || !callback) throw new Error('instance & callback is required');
- var called = false;
- var afterLeaveCallback = function afterLeaveCallback() {
- if (called) return;
- called = true;
- if (callback) {
- callback.apply(null, arguments);
- }
- };
- if (once) {
- instance.$once('after-leave', afterLeaveCallback);
- } else {
- instance.$on('after-leave', afterLeaveCallback);
- }
- setTimeout(function () {
- afterLeaveCallback();
- }, speed + 100);
- };
- ; /**
- * Bind after-leave event for vue instance. Make sure after-leave is called in any browsers.
- *
- * @param {Vue} instance Vue instance.
- * @param {Function} callback callback of after-leave event
- * @param {Number} speed the speed of transition, default value is 300ms
- * @param {Boolean} once weather bind after-leave once. default value is false.
- */
- /***/ }),
- /* 76 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 104);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 104:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/progress/src/progress.vue?vue&type=template&id=229ee406&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-progress",
- class: [
- "el-progress--" + _vm.type,
- _vm.status ? "is-" + _vm.status : "",
- {
- "el-progress--without-text": !_vm.showText,
- "el-progress--text-inside": _vm.textInside
- }
- ],
- attrs: {
- role: "progressbar",
- "aria-valuenow": _vm.percentage,
- "aria-valuemin": "0",
- "aria-valuemax": "100"
- }
- },
- [
- _vm.type === "line"
- ? _c("div", { staticClass: "el-progress-bar" }, [
- _c(
- "div",
- {
- staticClass: "el-progress-bar__outer",
- style: {
- height: _vm.strokeWidth + "px",
- backgroundColor: _vm.defineBackColor
- }
- },
- [
- _c(
- "div",
- {
- staticClass: "el-progress-bar__inner",
- style: _vm.barStyle
- },
- [
- _vm.showText && _vm.textInside
- ? _c(
- "div",
- {
- staticClass: "el-progress-bar__innerText",
- style: { color: _vm.textColor }
- },
- [_vm._v(_vm._s(_vm.content))]
- )
- : _vm._e()
- ]
- )
- ]
- )
- ])
- : _c(
- "div",
- {
- staticClass: "el-progress-circle",
- style: { height: _vm.width + "px", width: _vm.width + "px" }
- },
- [
- _c("svg", { attrs: { viewBox: "0 0 100 100" } }, [
- _c("path", {
- staticClass: "el-progress-circle__track",
- style: _vm.trailPathStyle,
- attrs: {
- d: _vm.trackPath,
- stroke: _vm.defineBackColor,
- "stroke-width": _vm.relativeStrokeWidth,
- fill: "none"
- }
- }),
- _c("path", {
- staticClass: "el-progress-circle__path",
- style: _vm.circlePathStyle,
- attrs: {
- d: _vm.trackPath,
- stroke: _vm.stroke,
- fill: "none",
- "stroke-linecap": _vm.strokeLinecap,
- "stroke-width": _vm.percentage ? _vm.relativeStrokeWidth : 0
- }
- })
- ])
- ]
- ),
- _vm.showText && !_vm.textInside
- ? _c(
- "div",
- {
- staticClass: "el-progress__text",
- style: {
- fontSize: _vm.progressTextSize + "px",
- color: _vm.textColor
- }
- },
- [
- !_vm.status
- ? [_vm._v(_vm._s(_vm.content))]
- : _c("i", { class: _vm.iconClass })
- ],
- 2
- )
- : _vm._e()
- ]
- )
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/progress/src/progress.vue?vue&type=template&id=229ee406&
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/progress/src/progress.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var progressvue_type_script_lang_js_ = ({
- name: 'ElProgress',
- props: {
- type: {
- type: String,
- default: 'line',
- validator: function validator(val) {
- return ['line', 'circle', 'dashboard'].indexOf(val) > -1;
- }
- },
- percentage: {
- type: Number,
- default: 0,
- required: true,
- validator: function validator(val) {
- return val >= 0 && val <= 100;
- }
- },
- status: {
- type: String,
- validator: function validator(val) {
- return ['success', 'exception', 'warning'].indexOf(val) > -1;
- }
- },
- strokeWidth: {
- type: Number,
- default: 6
- },
- strokeLinecap: {
- type: String,
- default: 'round'
- },
- textInside: {
- type: Boolean,
- default: false
- },
- width: {
- type: Number,
- default: 126
- },
- showText: {
- type: Boolean,
- default: true
- },
- color: {
- type: [String, Array, Function],
- default: ''
- },
- defineBackColor: {
- type: [String, Array, Function],
- default: '#ebeef5'
- },
- textColor: {
- type: [String, Array, Function],
- default: '#606266'
- },
- format: Function
- },
- computed: {
- barStyle: function barStyle() {
- var style = {};
- style.width = this.percentage + '%';
- style.backgroundColor = this.getCurrentColor(this.percentage);
- return style;
- },
- relativeStrokeWidth: function relativeStrokeWidth() {
- return (this.strokeWidth / this.width * 100).toFixed(1);
- },
- radius: function radius() {
- if (this.type === 'circle' || this.type === 'dashboard') {
- return parseInt(50 - parseFloat(this.relativeStrokeWidth) / 2, 10);
- } else {
- return 0;
- }
- },
- trackPath: function trackPath() {
- var radius = this.radius;
- var isDashboard = this.type === 'dashboard';
- return '\n M 50 50\n m 0 ' + (isDashboard ? '' : '-') + radius + '\n a ' + radius + ' ' + radius + ' 0 1 1 0 ' + (isDashboard ? '-' : '') + radius * 2 + '\n a ' + radius + ' ' + radius + ' 0 1 1 0 ' + (isDashboard ? '' : '-') + radius * 2 + '\n ';
- },
- perimeter: function perimeter() {
- return 2 * Math.PI * this.radius;
- },
- rate: function rate() {
- return this.type === 'dashboard' ? 0.75 : 1;
- },
- strokeDashoffset: function strokeDashoffset() {
- var offset = -1 * this.perimeter * (1 - this.rate) / 2;
- return offset + 'px';
- },
- trailPathStyle: function trailPathStyle() {
- return {
- strokeDasharray: this.perimeter * this.rate + 'px, ' + this.perimeter + 'px',
- strokeDashoffset: this.strokeDashoffset
- };
- },
- circlePathStyle: function circlePathStyle() {
- return {
- strokeDasharray: this.perimeter * this.rate * (this.percentage / 100) + 'px, ' + this.perimeter + 'px',
- strokeDashoffset: this.strokeDashoffset,
- transition: 'stroke-dasharray 0.6s ease 0s, stroke 0.6s ease'
- };
- },
- stroke: function stroke() {
- var ret = void 0;
- if (this.color) {
- ret = this.getCurrentColor(this.percentage);
- } else {
- switch (this.status) {
- case 'success':
- ret = '#13ce66';
- break;
- case 'exception':
- ret = '#ff4949';
- break;
- case 'warning':
- ret = '#e6a23c';
- break;
- default:
- ret = '#20a0ff';
- }
- }
- return ret;
- },
- iconClass: function iconClass() {
- if (this.status === 'warning') {
- return 'el-icon-warning';
- }
- if (this.type === 'line') {
- return this.status === 'success' ? 'el-icon-circle-check' : 'el-icon-circle-close';
- } else {
- return this.status === 'success' ? 'el-icon-check' : 'el-icon-close';
- }
- },
- progressTextSize: function progressTextSize() {
- return this.type === 'line' ? 12 + this.strokeWidth * 0.4 : this.width * 0.111111 + 2;
- },
- content: function content() {
- if (typeof this.format === 'function') {
- return this.format(this.percentage) || '';
- } else {
- return this.percentage + '%';
- }
- }
- },
- methods: {
- getCurrentColor: function getCurrentColor(percentage) {
- if (typeof this.color === 'function') {
- return this.color(percentage);
- } else if (typeof this.color === 'string') {
- return this.color;
- } else {
- return this.getLevelColor(percentage);
- }
- },
- getLevelColor: function getLevelColor(percentage) {
- var colorArray = this.getColorArray().sort(function (a, b) {
- return a.percentage - b.percentage;
- });
- for (var i = 0; i < colorArray.length; i++) {
- if (colorArray[i].percentage > percentage) {
- return colorArray[i].color;
- }
- }
- return colorArray[colorArray.length - 1].color;
- },
- getColorArray: function getColorArray() {
- var color = this.color;
- var span = 100 / color.length;
- return color.map(function (seriesColor, index) {
- if (typeof seriesColor === 'string') {
- return {
- color: seriesColor,
- percentage: (index + 1) * span
- };
- }
- return seriesColor;
- });
- }
- }
- });
- // CONCATENATED MODULE: ./packages/progress/src/progress.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_progressvue_type_script_lang_js_ = (progressvue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/progress/src/progress.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_progressvue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/progress/src/progress.vue"
- /* harmony default export */ var progress = (component.exports);
- // CONCATENATED MODULE: ./packages/progress/index.js
- /* istanbul ignore next */
- progress.install = function (Vue) {
- Vue.component(progress.name, progress);
- };
- /* harmony default export */ var packages_progress = __webpack_exports__["default"] = (progress);
- /***/ })
- /******/ });
- /***/ }),
- /* 77 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 62);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 10:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(20);
- /***/ }),
- /***/ 12:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(37);
- /***/ }),
- /***/ 15:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(23);
- /***/ }),
- /***/ 16:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(21);
- /***/ }),
- /***/ 19:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(22);
- /***/ }),
- /***/ 21:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(14);
- /***/ }),
- /***/ 22:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(24);
- /***/ }),
- /***/ 3:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(4);
- /***/ }),
- /***/ 31:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(25);
- /***/ }),
- /***/ 33:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option.vue?vue&type=template&id=7a44c642&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "li",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-select-dropdown__item",
- class: {
- selected: _vm.itemSelected,
- "is-disabled": _vm.disabled || _vm.groupDisabled || _vm.limitReached,
- hover: _vm.hover
- },
- on: {
- mouseenter: _vm.hoverItem,
- click: function($event) {
- $event.stopPropagation()
- return _vm.selectOptionClick($event)
- }
- }
- },
- [_vm._t("default", [_c("span", [_vm._v(_vm._s(_vm.currentLabel))])])],
- 2
- )
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/select/src/option.vue?vue&type=template&id=7a44c642&
- // EXTERNAL MODULE: external "element-ui/lib/mixins/emitter"
- var emitter_ = __webpack_require__(4);
- var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/util"
- var util_ = __webpack_require__(3);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option.vue?vue&type=script&lang=js&
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var optionvue_type_script_lang_js_ = ({
- mixins: [emitter_default.a],
- name: 'ElOption',
- componentName: 'ElOption',
- inject: ['select'],
- props: {
- value: {
- required: true
- },
- label: [String, Number],
- created: Boolean,
- disabled: {
- type: Boolean,
- default: false
- }
- },
- data: function data() {
- return {
- index: -1,
- groupDisabled: false,
- visible: true,
- hitState: false,
- hover: false
- };
- },
- computed: {
- isObject: function isObject() {
- return Object.prototype.toString.call(this.value).toLowerCase() === '[object object]';
- },
- currentLabel: function currentLabel() {
- return this.label || (this.isObject ? '' : this.value);
- },
- currentValue: function currentValue() {
- return this.value || this.label || '';
- },
- itemSelected: function itemSelected() {
- if (!this.select.multiple) {
- return this.isEqual(this.value, this.select.value);
- } else {
- return this.contains(this.select.value, this.value);
- }
- },
- limitReached: function limitReached() {
- if (this.select.multiple) {
- return !this.itemSelected && (this.select.value || []).length >= this.select.multipleLimit && this.select.multipleLimit > 0;
- } else {
- return false;
- }
- }
- },
- watch: {
- currentLabel: function currentLabel() {
- if (!this.created && !this.select.remote) this.dispatch('ElSelect', 'setSelected');
- },
- value: function value(val, oldVal) {
- var _select = this.select,
- remote = _select.remote,
- valueKey = _select.valueKey;
- if (!this.created && !remote) {
- if (valueKey && (typeof val === 'undefined' ? 'undefined' : _typeof(val)) === 'object' && (typeof oldVal === 'undefined' ? 'undefined' : _typeof(oldVal)) === 'object' && val[valueKey] === oldVal[valueKey]) {
- return;
- }
- this.dispatch('ElSelect', 'setSelected');
- }
- }
- },
- methods: {
- isEqual: function isEqual(a, b) {
- if (!this.isObject) {
- return a === b;
- } else {
- var valueKey = this.select.valueKey;
- return Object(util_["getValueByPath"])(a, valueKey) === Object(util_["getValueByPath"])(b, valueKey);
- }
- },
- contains: function contains() {
- var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- var target = arguments[1];
- if (!this.isObject) {
- return arr && arr.indexOf(target) > -1;
- } else {
- var valueKey = this.select.valueKey;
- return arr && arr.some(function (item) {
- return Object(util_["getValueByPath"])(item, valueKey) === Object(util_["getValueByPath"])(target, valueKey);
- });
- }
- },
- handleGroupDisabled: function handleGroupDisabled(val) {
- this.groupDisabled = val;
- },
- hoverItem: function hoverItem() {
- if (!this.disabled && !this.groupDisabled) {
- this.select.hoverIndex = this.select.options.indexOf(this);
- }
- },
- selectOptionClick: function selectOptionClick() {
- if (this.disabled !== true && this.groupDisabled !== true) {
- this.dispatch('ElSelect', 'handleOptionClick', [this, true]);
- }
- },
- queryChange: function queryChange(query) {
- this.visible = new RegExp(Object(util_["escapeRegexpString"])(query), 'i').test(this.currentLabel) || this.created;
- if (!this.visible) {
- this.select.filteredOptionsCount--;
- }
- }
- },
- created: function created() {
- this.select.options.push(this);
- this.select.cachedOptions.push(this);
- this.select.optionsCount++;
- this.select.filteredOptionsCount++;
- this.$on('queryChange', this.queryChange);
- this.$on('handleGroupDisabled', this.handleGroupDisabled);
- },
- beforeDestroy: function beforeDestroy() {
- var _select2 = this.select,
- selected = _select2.selected,
- multiple = _select2.multiple;
- var selectedOptions = multiple ? selected : [selected];
- var index = this.select.cachedOptions.indexOf(this);
- var selectedIndex = selectedOptions.indexOf(this);
- // if option is not selected, remove it from cache
- if (index > -1 && selectedIndex < 0) {
- this.select.cachedOptions.splice(index, 1);
- }
- this.select.onOptionDestroy(this.select.options.indexOf(this));
- }
- });
- // CONCATENATED MODULE: ./packages/select/src/option.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_optionvue_type_script_lang_js_ = (optionvue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/select/src/option.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_optionvue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/select/src/option.vue"
- /* harmony default export */ var src_option = __webpack_exports__["a"] = (component.exports);
- /***/ }),
- /***/ 38:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(43);
- /***/ }),
- /***/ 4:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(8);
- /***/ }),
- /***/ 5:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(12);
- /***/ }),
- /***/ 6:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(18);
- /***/ }),
- /***/ 62:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select.vue?vue&type=template&id=0e4aade6&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- directives: [
- {
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: _vm.handleClose,
- expression: "handleClose"
- }
- ],
- staticClass: "el-select",
- class: [_vm.selectSize ? "el-select--" + _vm.selectSize : ""],
- on: {
- click: function($event) {
- $event.stopPropagation()
- return _vm.toggleMenu($event)
- }
- }
- },
- [
- _vm.multiple
- ? _c(
- "div",
- {
- ref: "tags",
- staticClass: "el-select__tags",
- style: { "max-width": _vm.inputWidth - 32 + "px", width: "100%" }
- },
- [
- _vm.collapseTags && _vm.selected.length
- ? _c(
- "span",
- [
- _c(
- "el-tag",
- {
- attrs: {
- closable: !_vm.selectDisabled,
- size: _vm.collapseTagSize,
- hit: _vm.selected[0].hitState,
- type: "info",
- "disable-transitions": ""
- },
- on: {
- close: function($event) {
- _vm.deleteTag($event, _vm.selected[0])
- }
- }
- },
- [
- _c("span", { staticClass: "el-select__tags-text" }, [
- _vm._v(_vm._s(_vm.selected[0].currentLabel))
- ])
- ]
- ),
- _vm.selected.length > 1
- ? _c(
- "el-tag",
- {
- attrs: {
- closable: false,
- size: _vm.collapseTagSize,
- type: "info",
- "disable-transitions": ""
- }
- },
- [
- _c(
- "span",
- { staticClass: "el-select__tags-text" },
- [_vm._v("+ " + _vm._s(_vm.selected.length - 1))]
- )
- ]
- )
- : _vm._e()
- ],
- 1
- )
- : _vm._e(),
- !_vm.collapseTags
- ? _c(
- "transition-group",
- { on: { "after-leave": _vm.resetInputHeight } },
- _vm._l(_vm.selected, function(item) {
- return _c(
- "el-tag",
- {
- key: _vm.getValueKey(item),
- attrs: {
- closable: !_vm.selectDisabled,
- size: _vm.collapseTagSize,
- hit: item.hitState,
- type: "info",
- "disable-transitions": ""
- },
- on: {
- close: function($event) {
- _vm.deleteTag($event, item)
- }
- }
- },
- [
- _c("span", { staticClass: "el-select__tags-text" }, [
- _vm._v(_vm._s(item.currentLabel))
- ])
- ]
- )
- }),
- 1
- )
- : _vm._e(),
- _vm.filterable
- ? _c("input", {
- directives: [
- {
- name: "model",
- rawName: "v-model",
- value: _vm.query,
- expression: "query"
- }
- ],
- ref: "input",
- staticClass: "el-select__input",
- class: [_vm.selectSize ? "is-" + _vm.selectSize : ""],
- style: {
- "flex-grow": "1",
- width: _vm.inputLength / (_vm.inputWidth - 32) + "%",
- "max-width": _vm.inputWidth - 42 + "px"
- },
- attrs: {
- type: "text",
- disabled: _vm.selectDisabled,
- autocomplete: _vm.autoComplete || _vm.autocomplete
- },
- domProps: { value: _vm.query },
- on: {
- focus: _vm.handleFocus,
- blur: function($event) {
- _vm.softFocus = false
- },
- keyup: _vm.managePlaceholder,
- keydown: [
- _vm.resetInputState,
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "down", 40, $event.key, [
- "Down",
- "ArrowDown"
- ])
- ) {
- return null
- }
- $event.preventDefault()
- _vm.handleNavigate("next")
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "up", 38, $event.key, [
- "Up",
- "ArrowUp"
- ])
- ) {
- return null
- }
- $event.preventDefault()
- _vm.handleNavigate("prev")
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k(
- $event.keyCode,
- "enter",
- 13,
- $event.key,
- "Enter"
- )
- ) {
- return null
- }
- $event.preventDefault()
- return _vm.selectOption($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "esc", 27, $event.key, [
- "Esc",
- "Escape"
- ])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.visible = false
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k(
- $event.keyCode,
- "delete",
- [8, 46],
- $event.key,
- ["Backspace", "Delete", "Del"]
- )
- ) {
- return null
- }
- return _vm.deletePrevTag($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "tab", 9, $event.key, "Tab")
- ) {
- return null
- }
- _vm.visible = false
- }
- ],
- compositionstart: _vm.handleComposition,
- compositionupdate: _vm.handleComposition,
- compositionend: _vm.handleComposition,
- input: [
- function($event) {
- if ($event.target.composing) {
- return
- }
- _vm.query = $event.target.value
- },
- _vm.debouncedQueryChange
- ]
- }
- })
- : _vm._e()
- ],
- 1
- )
- : _vm._e(),
- _c(
- "el-input",
- {
- ref: "reference",
- class: { "is-focus": _vm.visible },
- attrs: {
- type: "text",
- placeholder: _vm.currentPlaceholder,
- name: _vm.name,
- id: _vm.id,
- autocomplete: _vm.autoComplete || _vm.autocomplete,
- size: _vm.selectSize,
- disabled: _vm.selectDisabled,
- readonly: _vm.readonly,
- "validate-event": false,
- tabindex: _vm.multiple && _vm.filterable ? "-1" : null
- },
- on: {
- focus: _vm.handleFocus,
- blur: _vm.handleBlur,
- input: _vm.debouncedOnInputChange,
- compositionstart: _vm.handleComposition,
- compositionupdate: _vm.handleComposition,
- compositionend: _vm.handleComposition
- },
- nativeOn: {
- keydown: [
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "down", 40, $event.key, [
- "Down",
- "ArrowDown"
- ])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.handleNavigate("next")
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "up", 38, $event.key, [
- "Up",
- "ArrowUp"
- ])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.handleNavigate("prev")
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")
- ) {
- return null
- }
- $event.preventDefault()
- return _vm.selectOption($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "esc", 27, $event.key, [
- "Esc",
- "Escape"
- ])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.visible = false
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "tab", 9, $event.key, "Tab")
- ) {
- return null
- }
- _vm.visible = false
- }
- ],
- mouseenter: function($event) {
- _vm.inputHovering = true
- },
- mouseleave: function($event) {
- _vm.inputHovering = false
- }
- },
- model: {
- value: _vm.selectedLabel,
- callback: function($$v) {
- _vm.selectedLabel = $$v
- },
- expression: "selectedLabel"
- }
- },
- [
- _vm.$slots.prefix
- ? _c("template", { slot: "prefix" }, [_vm._t("prefix")], 2)
- : _vm._e(),
- _c("template", { slot: "suffix" }, [
- _c("i", {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: !_vm.showClose,
- expression: "!showClose"
- }
- ],
- class: [
- "el-select__caret",
- "el-input__icon",
- "el-icon-" + _vm.iconClass
- ]
- }),
- _vm.showClose
- ? _c("i", {
- staticClass:
- "el-select__caret el-input__icon el-icon-circle-close",
- on: { click: _vm.handleClearClick }
- })
- : _vm._e()
- ])
- ],
- 2
- ),
- _c(
- "transition",
- {
- attrs: { name: "el-zoom-in-top" },
- on: {
- "before-enter": _vm.handleMenuEnter,
- "after-leave": _vm.doDestroy
- }
- },
- [
- _c(
- "el-select-menu",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible && _vm.emptyText !== false,
- expression: "visible && emptyText !== false"
- }
- ],
- ref: "popper",
- attrs: { "append-to-body": _vm.popperAppendToBody }
- },
- [
- _c(
- "el-scrollbar",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.options.length > 0 && !_vm.loading,
- expression: "options.length > 0 && !loading"
- }
- ],
- ref: "scrollbar",
- class: {
- "is-empty":
- !_vm.allowCreate &&
- _vm.query &&
- _vm.filteredOptionsCount === 0
- },
- attrs: {
- tag: "ul",
- "wrap-class": "el-select-dropdown__wrap",
- "view-class": "el-select-dropdown__list"
- }
- },
- [
- _vm.showNewOption
- ? _c("el-option", {
- attrs: { value: _vm.query, created: "" }
- })
- : _vm._e(),
- _vm._t("default")
- ],
- 2
- ),
- _vm.emptyText &&
- (!_vm.allowCreate ||
- _vm.loading ||
- (_vm.allowCreate && _vm.options.length === 0))
- ? [
- _vm.$slots.empty
- ? _vm._t("empty")
- : _c("p", { staticClass: "el-select-dropdown__empty" }, [
- _vm._v(
- "\n " +
- _vm._s(_vm.emptyText) +
- "\n "
- )
- ])
- ]
- : _vm._e()
- ],
- 2
- )
- ],
- 1
- )
- ],
- 1
- )
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/select/src/select.vue?vue&type=template&id=0e4aade6&
- // EXTERNAL MODULE: external "element-ui/lib/mixins/emitter"
- var emitter_ = __webpack_require__(4);
- var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_);
- // EXTERNAL MODULE: external "element-ui/lib/mixins/focus"
- var focus_ = __webpack_require__(22);
- var focus_default = /*#__PURE__*/__webpack_require__.n(focus_);
- // EXTERNAL MODULE: external "element-ui/lib/mixins/locale"
- var locale_ = __webpack_require__(6);
- var locale_default = /*#__PURE__*/__webpack_require__.n(locale_);
- // EXTERNAL MODULE: external "element-ui/lib/input"
- var input_ = __webpack_require__(10);
- var input_default = /*#__PURE__*/__webpack_require__.n(input_);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select-dropdown.vue?vue&type=template&id=06828748&
- var select_dropdownvue_type_template_id_06828748_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- staticClass: "el-select-dropdown el-popper",
- class: [{ "is-multiple": _vm.$parent.multiple }, _vm.popperClass],
- style: { minWidth: _vm.minWidth }
- },
- [_vm._t("default")],
- 2
- )
- }
- var select_dropdownvue_type_template_id_06828748_staticRenderFns = []
- select_dropdownvue_type_template_id_06828748_render._withStripped = true
- // CONCATENATED MODULE: ./packages/select/src/select-dropdown.vue?vue&type=template&id=06828748&
- // EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper"
- var vue_popper_ = __webpack_require__(5);
- var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select-dropdown.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var select_dropdownvue_type_script_lang_js_ = ({
- name: 'ElSelectDropdown',
- componentName: 'ElSelectDropdown',
- mixins: [vue_popper_default.a],
- props: {
- placement: {
- default: 'bottom-start'
- },
- boundariesPadding: {
- default: 0
- },
- popperOptions: {
- default: function _default() {
- return {
- gpuAcceleration: false
- };
- }
- },
- visibleArrow: {
- default: true
- },
- appendToBody: {
- type: Boolean,
- default: true
- }
- },
- data: function data() {
- return {
- minWidth: ''
- };
- },
- computed: {
- popperClass: function popperClass() {
- return this.$parent.popperClass;
- }
- },
- watch: {
- '$parent.inputWidth': function $parentInputWidth() {
- this.minWidth = this.$parent.$el.getBoundingClientRect().width + 'px';
- }
- },
- mounted: function mounted() {
- var _this = this;
- this.referenceElm = this.$parent.$refs.reference.$el;
- this.$parent.popperElm = this.popperElm = this.$el;
- this.$on('updatePopper', function () {
- if (_this.$parent.visible) _this.updatePopper();
- });
- this.$on('destroyPopper', this.destroyPopper);
- }
- });
- // CONCATENATED MODULE: ./packages/select/src/select-dropdown.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_select_dropdownvue_type_script_lang_js_ = (select_dropdownvue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/select/src/select-dropdown.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_select_dropdownvue_type_script_lang_js_,
- select_dropdownvue_type_template_id_06828748_render,
- select_dropdownvue_type_template_id_06828748_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/select/src/select-dropdown.vue"
- /* harmony default export */ var select_dropdown = (component.exports);
- // EXTERNAL MODULE: ./packages/select/src/option.vue + 4 modules
- var src_option = __webpack_require__(33);
- // EXTERNAL MODULE: external "element-ui/lib/tag"
- var tag_ = __webpack_require__(38);
- var tag_default = /*#__PURE__*/__webpack_require__.n(tag_);
- // EXTERNAL MODULE: external "element-ui/lib/scrollbar"
- var scrollbar_ = __webpack_require__(15);
- var scrollbar_default = /*#__PURE__*/__webpack_require__.n(scrollbar_);
- // EXTERNAL MODULE: external "throttle-debounce/debounce"
- var debounce_ = __webpack_require__(19);
- var debounce_default = /*#__PURE__*/__webpack_require__.n(debounce_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/clickoutside"
- var clickoutside_ = __webpack_require__(12);
- var clickoutside_default = /*#__PURE__*/__webpack_require__.n(clickoutside_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/resize-event"
- var resize_event_ = __webpack_require__(16);
- // EXTERNAL MODULE: external "element-ui/lib/utils/scroll-into-view"
- var scroll_into_view_ = __webpack_require__(31);
- var scroll_into_view_default = /*#__PURE__*/__webpack_require__.n(scroll_into_view_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/util"
- var util_ = __webpack_require__(3);
- // CONCATENATED MODULE: ./packages/select/src/navigation-mixin.js
- /* harmony default export */ var navigation_mixin = ({
- data: function data() {
- return {
- hoverOption: -1
- };
- },
- computed: {
- optionsAllDisabled: function optionsAllDisabled() {
- return this.options.filter(function (option) {
- return option.visible;
- }).every(function (option) {
- return option.disabled;
- });
- }
- },
- watch: {
- hoverIndex: function hoverIndex(val) {
- var _this = this;
- if (typeof val === 'number' && val > -1) {
- this.hoverOption = this.options[val] || {};
- }
- this.options.forEach(function (option) {
- option.hover = _this.hoverOption === option;
- });
- }
- },
- methods: {
- navigateOptions: function navigateOptions(direction) {
- var _this2 = this;
- if (!this.visible) {
- this.visible = true;
- return;
- }
- if (this.options.length === 0 || this.filteredOptionsCount === 0) return;
- if (!this.optionsAllDisabled) {
- if (direction === 'next') {
- this.hoverIndex++;
- if (this.hoverIndex === this.options.length) {
- this.hoverIndex = 0;
- }
- } else if (direction === 'prev') {
- this.hoverIndex--;
- if (this.hoverIndex < 0) {
- this.hoverIndex = this.options.length - 1;
- }
- }
- var option = this.options[this.hoverIndex];
- if (option.disabled === true || option.groupDisabled === true || !option.visible) {
- this.navigateOptions(direction);
- }
- this.$nextTick(function () {
- return _this2.scrollToOption(_this2.hoverOption);
- });
- }
- }
- }
- });
- // EXTERNAL MODULE: external "element-ui/lib/utils/shared"
- var shared_ = __webpack_require__(21);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var selectvue_type_script_lang_js_ = ({
- mixins: [emitter_default.a, locale_default.a, focus_default()('reference'), navigation_mixin],
- name: 'ElSelect',
- componentName: 'ElSelect',
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- provide: function provide() {
- return {
- 'select': this
- };
- },
- computed: {
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- readonly: function readonly() {
- return !this.filterable || this.multiple || !Object(util_["isIE"])() && !Object(util_["isEdge"])() && !this.visible;
- },
- showClose: function showClose() {
- var hasValue = this.multiple ? Array.isArray(this.value) && this.value.length > 0 : this.value !== undefined && this.value !== null && this.value !== '';
- var criteria = this.clearable && !this.selectDisabled && this.inputHovering && hasValue;
- return criteria;
- },
- iconClass: function iconClass() {
- return this.remote && this.filterable ? '' : this.visible ? 'arrow-up is-reverse' : 'arrow-up';
- },
- debounce: function debounce() {
- return this.remote ? 300 : 0;
- },
- emptyText: function emptyText() {
- if (this.loading) {
- return this.loadingText || this.t('el.select.loading');
- } else {
- if (this.remote && this.query === '' && this.options.length === 0) return false;
- if (this.filterable && this.query && this.options.length > 0 && this.filteredOptionsCount === 0) {
- return this.noMatchText || this.t('el.select.noMatch');
- }
- if (this.options.length === 0) {
- return this.noDataText || this.t('el.select.noData');
- }
- }
- return null;
- },
- showNewOption: function showNewOption() {
- var _this = this;
- var hasExistingOption = this.options.filter(function (option) {
- return !option.created;
- }).some(function (option) {
- return option.currentLabel === _this.query;
- });
- return this.filterable && this.allowCreate && this.query !== '' && !hasExistingOption;
- },
- selectSize: function selectSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- selectDisabled: function selectDisabled() {
- return this.disabled || (this.elForm || {}).disabled;
- },
- collapseTagSize: function collapseTagSize() {
- return ['small', 'mini'].indexOf(this.selectSize) > -1 ? 'mini' : 'small';
- },
- propPlaceholder: function propPlaceholder() {
- return typeof this.placeholder !== 'undefined' ? this.placeholder : this.t('el.select.placeholder');
- }
- },
- components: {
- ElInput: input_default.a,
- ElSelectMenu: select_dropdown,
- ElOption: src_option["a" /* default */],
- ElTag: tag_default.a,
- ElScrollbar: scrollbar_default.a
- },
- directives: { Clickoutside: clickoutside_default.a },
- props: {
- name: String,
- id: String,
- value: {
- required: true
- },
- autocomplete: {
- type: String,
- default: 'off'
- },
- /** @Deprecated in next major version */
- autoComplete: {
- type: String,
- validator: function validator(val) {
- false && false;
- return true;
- }
- },
- automaticDropdown: Boolean,
- size: String,
- disabled: Boolean,
- clearable: Boolean,
- filterable: Boolean,
- allowCreate: Boolean,
- loading: Boolean,
- popperClass: String,
- remote: Boolean,
- loadingText: String,
- noMatchText: String,
- noDataText: String,
- remoteMethod: Function,
- filterMethod: Function,
- multiple: Boolean,
- multipleLimit: {
- type: Number,
- default: 0
- },
- placeholder: {
- type: String,
- required: false
- },
- defaultFirstOption: Boolean,
- reserveKeyword: Boolean,
- valueKey: {
- type: String,
- default: 'value'
- },
- collapseTags: Boolean,
- popperAppendToBody: {
- type: Boolean,
- default: true
- }
- },
- data: function data() {
- return {
- options: [],
- cachedOptions: [],
- createdLabel: null,
- createdSelected: false,
- selected: this.multiple ? [] : {},
- inputLength: 20,
- inputWidth: 0,
- initialInputHeight: 0,
- cachedPlaceHolder: '',
- optionsCount: 0,
- filteredOptionsCount: 0,
- visible: false,
- softFocus: false,
- selectedLabel: '',
- hoverIndex: -1,
- query: '',
- previousQuery: null,
- inputHovering: false,
- currentPlaceholder: '',
- menuVisibleOnFocus: false,
- isOnComposition: false,
- isSilentBlur: false
- };
- },
- watch: {
- selectDisabled: function selectDisabled() {
- var _this2 = this;
- this.$nextTick(function () {
- _this2.resetInputHeight();
- });
- },
- propPlaceholder: function propPlaceholder(val) {
- this.cachedPlaceHolder = this.currentPlaceholder = val;
- },
- value: function value(val, oldVal) {
- if (this.multiple) {
- this.resetInputHeight();
- if (val && val.length > 0 || this.$refs.input && this.query !== '') {
- this.currentPlaceholder = '';
- } else {
- this.currentPlaceholder = this.cachedPlaceHolder;
- }
- if (this.filterable && !this.reserveKeyword) {
- this.query = '';
- this.handleQueryChange(this.query);
- }
- }
- this.setSelected();
- if (this.filterable && !this.multiple) {
- this.inputLength = 20;
- }
- if (!Object(util_["valueEquals"])(val, oldVal)) {
- this.dispatch('ElFormItem', 'el.form.change', val);
- }
- },
- visible: function visible(val) {
- var _this3 = this;
- if (!val) {
- this.broadcast('ElSelectDropdown', 'destroyPopper');
- if (this.$refs.input) {
- this.$refs.input.blur();
- }
- this.query = '';
- this.previousQuery = null;
- this.selectedLabel = '';
- this.inputLength = 20;
- this.menuVisibleOnFocus = false;
- this.resetHoverIndex();
- this.$nextTick(function () {
- if (_this3.$refs.input && _this3.$refs.input.value === '' && _this3.selected.length === 0) {
- _this3.currentPlaceholder = _this3.cachedPlaceHolder;
- }
- });
- if (!this.multiple) {
- if (this.selected) {
- if (this.filterable && this.allowCreate && this.createdSelected && this.createdLabel) {
- this.selectedLabel = this.createdLabel;
- } else {
- this.selectedLabel = this.selected.currentLabel;
- }
- if (this.filterable) this.query = this.selectedLabel;
- }
- if (this.filterable) {
- this.currentPlaceholder = this.cachedPlaceHolder;
- }
- }
- } else {
- this.broadcast('ElSelectDropdown', 'updatePopper');
- if (this.filterable) {
- this.query = this.remote ? '' : this.selectedLabel;
- this.handleQueryChange(this.query);
- if (this.multiple) {
- this.$refs.input.focus();
- } else {
- if (!this.remote) {
- this.broadcast('ElOption', 'queryChange', '');
- this.broadcast('ElOptionGroup', 'queryChange');
- }
- if (this.selectedLabel) {
- this.currentPlaceholder = this.selectedLabel;
- this.selectedLabel = '';
- }
- }
- }
- }
- this.$emit('visible-change', val);
- },
- options: function options() {
- var _this4 = this;
- if (this.$isServer) return;
- this.$nextTick(function () {
- _this4.broadcast('ElSelectDropdown', 'updatePopper');
- });
- if (this.multiple) {
- this.resetInputHeight();
- }
- var inputs = this.$el.querySelectorAll('input');
- if ([].indexOf.call(inputs, document.activeElement) === -1) {
- this.setSelected();
- }
- if (this.defaultFirstOption && (this.filterable || this.remote) && this.filteredOptionsCount) {
- this.checkDefaultFirstOption();
- }
- }
- },
- methods: {
- handleNavigate: function handleNavigate(direction) {
- if (this.isOnComposition) return;
- this.navigateOptions(direction);
- },
- handleComposition: function handleComposition(event) {
- var _this5 = this;
- var text = event.target.value;
- if (event.type === 'compositionend') {
- this.isOnComposition = false;
- this.$nextTick(function (_) {
- return _this5.handleQueryChange(text);
- });
- } else {
- var lastCharacter = text[text.length - 1] || '';
- this.isOnComposition = !Object(shared_["isKorean"])(lastCharacter);
- }
- },
- handleQueryChange: function handleQueryChange(val) {
- var _this6 = this;
- if (this.previousQuery === val || this.isOnComposition) return;
- if (this.previousQuery === null && (typeof this.filterMethod === 'function' || typeof this.remoteMethod === 'function')) {
- this.previousQuery = val;
- return;
- }
- this.previousQuery = val;
- this.$nextTick(function () {
- if (_this6.visible) _this6.broadcast('ElSelectDropdown', 'updatePopper');
- });
- this.hoverIndex = -1;
- if (this.multiple && this.filterable) {
- this.$nextTick(function () {
- var length = _this6.$refs.input.value.length * 15 + 20;
- _this6.inputLength = _this6.collapseTags ? Math.min(50, length) : length;
- _this6.managePlaceholder();
- _this6.resetInputHeight();
- });
- }
- if (this.remote && typeof this.remoteMethod === 'function') {
- this.hoverIndex = -1;
- this.remoteMethod(val);
- } else if (typeof this.filterMethod === 'function') {
- this.filterMethod(val);
- this.broadcast('ElOptionGroup', 'queryChange');
- } else {
- this.filteredOptionsCount = this.optionsCount;
- this.broadcast('ElOption', 'queryChange', val);
- this.broadcast('ElOptionGroup', 'queryChange');
- }
- if (this.defaultFirstOption && (this.filterable || this.remote) && this.filteredOptionsCount) {
- this.checkDefaultFirstOption();
- }
- },
- scrollToOption: function scrollToOption(option) {
- var target = Array.isArray(option) && option[0] ? option[0].$el : option.$el;
- if (this.$refs.popper && target) {
- var menu = this.$refs.popper.$el.querySelector('.el-select-dropdown__wrap');
- scroll_into_view_default()(menu, target);
- }
- this.$refs.scrollbar && this.$refs.scrollbar.handleScroll();
- },
- handleMenuEnter: function handleMenuEnter() {
- var _this7 = this;
- this.$nextTick(function () {
- return _this7.scrollToOption(_this7.selected);
- });
- },
- emitChange: function emitChange(val) {
- if (!Object(util_["valueEquals"])(this.value, val)) {
- this.$emit('change', val);
- }
- },
- getOption: function getOption(value) {
- var option = void 0;
- var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
- var isNull = Object.prototype.toString.call(value).toLowerCase() === '[object null]';
- var isUndefined = Object.prototype.toString.call(value).toLowerCase() === '[object undefined]';
- for (var i = this.cachedOptions.length - 1; i >= 0; i--) {
- var cachedOption = this.cachedOptions[i];
- var isEqual = isObject ? Object(util_["getValueByPath"])(cachedOption.value, this.valueKey) === Object(util_["getValueByPath"])(value, this.valueKey) : cachedOption.value === value;
- if (isEqual) {
- option = cachedOption;
- break;
- }
- }
- if (option) return option;
- var label = !isObject && !isNull && !isUndefined ? String(value) : '';
- var newOption = {
- value: value,
- currentLabel: label
- };
- if (this.multiple) {
- newOption.hitState = false;
- }
- return newOption;
- },
- setSelected: function setSelected() {
- var _this8 = this;
- if (!this.multiple) {
- var option = this.getOption(this.value);
- if (option.created) {
- this.createdLabel = option.currentLabel;
- this.createdSelected = true;
- } else {
- this.createdSelected = false;
- }
- this.selectedLabel = option.currentLabel;
- this.selected = option;
- if (this.filterable) this.query = this.selectedLabel;
- return;
- }
- var result = [];
- if (Array.isArray(this.value)) {
- this.value.forEach(function (value) {
- result.push(_this8.getOption(value));
- });
- }
- this.selected = result;
- this.$nextTick(function () {
- _this8.resetInputHeight();
- });
- },
- handleFocus: function handleFocus(event) {
- if (!this.softFocus) {
- if (this.automaticDropdown || this.filterable) {
- if (this.filterable && !this.visible) {
- this.menuVisibleOnFocus = true;
- }
- this.visible = true;
- }
- this.$emit('focus', event);
- } else {
- this.softFocus = false;
- }
- },
- blur: function blur() {
- this.visible = false;
- this.$refs.reference.blur();
- },
- handleBlur: function handleBlur(event) {
- var _this9 = this;
- setTimeout(function () {
- if (_this9.isSilentBlur) {
- _this9.isSilentBlur = false;
- } else {
- _this9.$emit('blur', event);
- }
- }, 50);
- this.softFocus = false;
- },
- handleClearClick: function handleClearClick(event) {
- this.deleteSelected(event);
- },
- doDestroy: function doDestroy() {
- this.$refs.popper && this.$refs.popper.doDestroy();
- },
- handleClose: function handleClose() {
- this.visible = false;
- },
- toggleLastOptionHitState: function toggleLastOptionHitState(hit) {
- if (!Array.isArray(this.selected)) return;
- var option = this.selected[this.selected.length - 1];
- if (!option) return;
- if (hit === true || hit === false) {
- option.hitState = hit;
- return hit;
- }
- option.hitState = !option.hitState;
- return option.hitState;
- },
- deletePrevTag: function deletePrevTag(e) {
- if (e.target.value.length <= 0 && !this.toggleLastOptionHitState()) {
- var value = this.value.slice();
- value.pop();
- this.$emit('input', value);
- this.emitChange(value);
- }
- },
- managePlaceholder: function managePlaceholder() {
- if (this.currentPlaceholder !== '') {
- this.currentPlaceholder = this.$refs.input.value ? '' : this.cachedPlaceHolder;
- }
- },
- resetInputState: function resetInputState(e) {
- if (e.keyCode !== 8) this.toggleLastOptionHitState(false);
- this.inputLength = this.$refs.input.value.length * 15 + 20;
- this.resetInputHeight();
- },
- resetInputHeight: function resetInputHeight() {
- var _this10 = this;
- if (this.collapseTags && !this.filterable) return;
- this.$nextTick(function () {
- if (!_this10.$refs.reference) return;
- var inputChildNodes = _this10.$refs.reference.$el.childNodes;
- var input = [].filter.call(inputChildNodes, function (item) {
- return item.tagName === 'INPUT';
- })[0];
- var tags = _this10.$refs.tags;
- var tagsHeight = tags ? Math.round(tags.getBoundingClientRect().height) : 0;
- var sizeInMap = _this10.initialInputHeight || 40;
- input.style.height = _this10.selected.length === 0 ? sizeInMap + 'px' : Math.max(tags ? tagsHeight + (tagsHeight > sizeInMap ? 6 : 0) : 0, sizeInMap) + 'px';
- if (_this10.visible && _this10.emptyText !== false) {
- _this10.broadcast('ElSelectDropdown', 'updatePopper');
- }
- });
- },
- resetHoverIndex: function resetHoverIndex() {
- var _this11 = this;
- setTimeout(function () {
- if (!_this11.multiple) {
- _this11.hoverIndex = _this11.options.indexOf(_this11.selected);
- } else {
- if (_this11.selected.length > 0) {
- _this11.hoverIndex = Math.min.apply(null, _this11.selected.map(function (item) {
- return _this11.options.indexOf(item);
- }));
- } else {
- _this11.hoverIndex = -1;
- }
- }
- }, 300);
- },
- handleOptionSelect: function handleOptionSelect(option, byClick) {
- var _this12 = this;
- if (this.multiple) {
- var value = (this.value || []).slice();
- var optionIndex = this.getValueIndex(value, option.value);
- if (optionIndex > -1) {
- value.splice(optionIndex, 1);
- } else if (this.multipleLimit <= 0 || value.length < this.multipleLimit) {
- value.push(option.value);
- }
- this.$emit('input', value);
- this.emitChange(value);
- if (option.created) {
- this.query = '';
- this.handleQueryChange('');
- this.inputLength = 20;
- }
- if (this.filterable) this.$refs.input.focus();
- } else {
- this.$emit('input', option.value);
- this.emitChange(option.value);
- this.visible = false;
- }
- this.isSilentBlur = byClick;
- this.setSoftFocus();
- if (this.visible) return;
- this.$nextTick(function () {
- _this12.scrollToOption(option);
- });
- },
- setSoftFocus: function setSoftFocus() {
- this.softFocus = true;
- var input = this.$refs.input || this.$refs.reference;
- if (input) {
- input.focus();
- }
- },
- getValueIndex: function getValueIndex() {
- var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- var value = arguments[1];
- var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
- if (!isObject) {
- return arr.indexOf(value);
- } else {
- var valueKey = this.valueKey;
- var index = -1;
- arr.some(function (item, i) {
- if (Object(util_["getValueByPath"])(item, valueKey) === Object(util_["getValueByPath"])(value, valueKey)) {
- index = i;
- return true;
- }
- return false;
- });
- return index;
- }
- },
- toggleMenu: function toggleMenu() {
- if (!this.selectDisabled) {
- if (this.menuVisibleOnFocus) {
- this.menuVisibleOnFocus = false;
- } else {
- this.visible = !this.visible;
- }
- if (this.visible) {
- (this.$refs.input || this.$refs.reference).focus();
- }
- }
- },
- selectOption: function selectOption() {
- if (!this.visible) {
- this.toggleMenu();
- } else {
- if (this.options[this.hoverIndex]) {
- this.handleOptionSelect(this.options[this.hoverIndex]);
- }
- }
- },
- deleteSelected: function deleteSelected(event) {
- event.stopPropagation();
- var value = this.multiple ? [] : '';
- this.$emit('input', value);
- this.emitChange(value);
- this.visible = false;
- this.$emit('clear');
- },
- deleteTag: function deleteTag(event, tag) {
- var index = this.selected.indexOf(tag);
- if (index > -1 && !this.selectDisabled) {
- var value = this.value.slice();
- value.splice(index, 1);
- this.$emit('input', value);
- this.emitChange(value);
- this.$emit('remove-tag', tag.value);
- }
- event.stopPropagation();
- },
- onInputChange: function onInputChange() {
- if (this.filterable && this.query !== this.selectedLabel) {
- this.query = this.selectedLabel;
- this.handleQueryChange(this.query);
- }
- },
- onOptionDestroy: function onOptionDestroy(index) {
- if (index > -1) {
- this.optionsCount--;
- this.filteredOptionsCount--;
- this.options.splice(index, 1);
- }
- },
- resetInputWidth: function resetInputWidth() {
- this.inputWidth = this.$refs.reference.$el.getBoundingClientRect().width;
- },
- handleResize: function handleResize() {
- this.resetInputWidth();
- if (this.multiple) this.resetInputHeight();
- },
- checkDefaultFirstOption: function checkDefaultFirstOption() {
- this.hoverIndex = -1;
- // highlight the created option
- var hasCreated = false;
- for (var i = this.options.length - 1; i >= 0; i--) {
- if (this.options[i].created) {
- hasCreated = true;
- this.hoverIndex = i;
- break;
- }
- }
- if (hasCreated) return;
- for (var _i = 0; _i !== this.options.length; ++_i) {
- var option = this.options[_i];
- if (this.query) {
- // highlight first options that passes the filter
- if (!option.disabled && !option.groupDisabled && option.visible) {
- this.hoverIndex = _i;
- break;
- }
- } else {
- // highlight currently selected option
- if (option.itemSelected) {
- this.hoverIndex = _i;
- break;
- }
- }
- }
- },
- getValueKey: function getValueKey(item) {
- if (Object.prototype.toString.call(item.value).toLowerCase() !== '[object object]') {
- return item.value;
- } else {
- return Object(util_["getValueByPath"])(item.value, this.valueKey);
- }
- }
- },
- created: function created() {
- var _this13 = this;
- this.cachedPlaceHolder = this.currentPlaceholder = this.propPlaceholder;
- if (this.multiple && !Array.isArray(this.value)) {
- this.$emit('input', []);
- }
- if (!this.multiple && Array.isArray(this.value)) {
- this.$emit('input', '');
- }
- this.debouncedOnInputChange = debounce_default()(this.debounce, function () {
- _this13.onInputChange();
- });
- this.debouncedQueryChange = debounce_default()(this.debounce, function (e) {
- _this13.handleQueryChange(e.target.value);
- });
- this.$on('handleOptionClick', this.handleOptionSelect);
- this.$on('setSelected', this.setSelected);
- },
- mounted: function mounted() {
- var _this14 = this;
- if (this.multiple && Array.isArray(this.value) && this.value.length > 0) {
- this.currentPlaceholder = '';
- }
- Object(resize_event_["addResizeListener"])(this.$el, this.handleResize);
- var reference = this.$refs.reference;
- if (reference && reference.$el) {
- var sizeMap = {
- medium: 36,
- small: 32,
- mini: 28
- };
- var input = reference.$el.querySelector('input');
- this.initialInputHeight = input.getBoundingClientRect().height || sizeMap[this.selectSize];
- }
- if (this.remote && this.multiple) {
- this.resetInputHeight();
- }
- this.$nextTick(function () {
- if (reference && reference.$el) {
- _this14.inputWidth = reference.$el.getBoundingClientRect().width;
- }
- });
- this.setSelected();
- },
- beforeDestroy: function beforeDestroy() {
- if (this.$el && this.handleResize) Object(resize_event_["removeResizeListener"])(this.$el, this.handleResize);
- }
- });
- // CONCATENATED MODULE: ./packages/select/src/select.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_selectvue_type_script_lang_js_ = (selectvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/select/src/select.vue
- /* normalize component */
- var select_component = Object(componentNormalizer["a" /* default */])(
- src_selectvue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var select_api; }
- select_component.options.__file = "packages/select/src/select.vue"
- /* harmony default export */ var src_select = (select_component.exports);
- // CONCATENATED MODULE: ./packages/select/index.js
- /* istanbul ignore next */
- src_select.install = function (Vue) {
- Vue.component(src_select.name, src_select);
- };
- /* harmony default export */ var packages_select = __webpack_exports__["default"] = (src_select);
- /***/ })
- /******/ });
- /***/ }),
- /* 78 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 54);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 3:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(4);
- /***/ }),
- /***/ 33:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option.vue?vue&type=template&id=7a44c642&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "li",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.visible,
- expression: "visible"
- }
- ],
- staticClass: "el-select-dropdown__item",
- class: {
- selected: _vm.itemSelected,
- "is-disabled": _vm.disabled || _vm.groupDisabled || _vm.limitReached,
- hover: _vm.hover
- },
- on: {
- mouseenter: _vm.hoverItem,
- click: function($event) {
- $event.stopPropagation()
- return _vm.selectOptionClick($event)
- }
- }
- },
- [_vm._t("default", [_c("span", [_vm._v(_vm._s(_vm.currentLabel))])])],
- 2
- )
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/select/src/option.vue?vue&type=template&id=7a44c642&
- // EXTERNAL MODULE: external "element-ui/lib/mixins/emitter"
- var emitter_ = __webpack_require__(4);
- var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/util"
- var util_ = __webpack_require__(3);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option.vue?vue&type=script&lang=js&
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var optionvue_type_script_lang_js_ = ({
- mixins: [emitter_default.a],
- name: 'ElOption',
- componentName: 'ElOption',
- inject: ['select'],
- props: {
- value: {
- required: true
- },
- label: [String, Number],
- created: Boolean,
- disabled: {
- type: Boolean,
- default: false
- }
- },
- data: function data() {
- return {
- index: -1,
- groupDisabled: false,
- visible: true,
- hitState: false,
- hover: false
- };
- },
- computed: {
- isObject: function isObject() {
- return Object.prototype.toString.call(this.value).toLowerCase() === '[object object]';
- },
- currentLabel: function currentLabel() {
- return this.label || (this.isObject ? '' : this.value);
- },
- currentValue: function currentValue() {
- return this.value || this.label || '';
- },
- itemSelected: function itemSelected() {
- if (!this.select.multiple) {
- return this.isEqual(this.value, this.select.value);
- } else {
- return this.contains(this.select.value, this.value);
- }
- },
- limitReached: function limitReached() {
- if (this.select.multiple) {
- return !this.itemSelected && (this.select.value || []).length >= this.select.multipleLimit && this.select.multipleLimit > 0;
- } else {
- return false;
- }
- }
- },
- watch: {
- currentLabel: function currentLabel() {
- if (!this.created && !this.select.remote) this.dispatch('ElSelect', 'setSelected');
- },
- value: function value(val, oldVal) {
- var _select = this.select,
- remote = _select.remote,
- valueKey = _select.valueKey;
- if (!this.created && !remote) {
- if (valueKey && (typeof val === 'undefined' ? 'undefined' : _typeof(val)) === 'object' && (typeof oldVal === 'undefined' ? 'undefined' : _typeof(oldVal)) === 'object' && val[valueKey] === oldVal[valueKey]) {
- return;
- }
- this.dispatch('ElSelect', 'setSelected');
- }
- }
- },
- methods: {
- isEqual: function isEqual(a, b) {
- if (!this.isObject) {
- return a === b;
- } else {
- var valueKey = this.select.valueKey;
- return Object(util_["getValueByPath"])(a, valueKey) === Object(util_["getValueByPath"])(b, valueKey);
- }
- },
- contains: function contains() {
- var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- var target = arguments[1];
- if (!this.isObject) {
- return arr && arr.indexOf(target) > -1;
- } else {
- var valueKey = this.select.valueKey;
- return arr && arr.some(function (item) {
- return Object(util_["getValueByPath"])(item, valueKey) === Object(util_["getValueByPath"])(target, valueKey);
- });
- }
- },
- handleGroupDisabled: function handleGroupDisabled(val) {
- this.groupDisabled = val;
- },
- hoverItem: function hoverItem() {
- if (!this.disabled && !this.groupDisabled) {
- this.select.hoverIndex = this.select.options.indexOf(this);
- }
- },
- selectOptionClick: function selectOptionClick() {
- if (this.disabled !== true && this.groupDisabled !== true) {
- this.dispatch('ElSelect', 'handleOptionClick', [this, true]);
- }
- },
- queryChange: function queryChange(query) {
- this.visible = new RegExp(Object(util_["escapeRegexpString"])(query), 'i').test(this.currentLabel) || this.created;
- if (!this.visible) {
- this.select.filteredOptionsCount--;
- }
- }
- },
- created: function created() {
- this.select.options.push(this);
- this.select.cachedOptions.push(this);
- this.select.optionsCount++;
- this.select.filteredOptionsCount++;
- this.$on('queryChange', this.queryChange);
- this.$on('handleGroupDisabled', this.handleGroupDisabled);
- },
- beforeDestroy: function beforeDestroy() {
- var _select2 = this.select,
- selected = _select2.selected,
- multiple = _select2.multiple;
- var selectedOptions = multiple ? selected : [selected];
- var index = this.select.cachedOptions.indexOf(this);
- var selectedIndex = selectedOptions.indexOf(this);
- // if option is not selected, remove it from cache
- if (index > -1 && selectedIndex < 0) {
- this.select.cachedOptions.splice(index, 1);
- }
- this.select.onOptionDestroy(this.select.options.indexOf(this));
- }
- });
- // CONCATENATED MODULE: ./packages/select/src/option.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_optionvue_type_script_lang_js_ = (optionvue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/select/src/option.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_optionvue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/select/src/option.vue"
- /* harmony default export */ var src_option = __webpack_exports__["a"] = (component.exports);
- /***/ }),
- /***/ 4:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(8);
- /***/ }),
- /***/ 54:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony import */ var _select_src_option__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(33);
- /* istanbul ignore next */
- _select_src_option__WEBPACK_IMPORTED_MODULE_0__[/* default */ "a"].install = function (Vue) {
- Vue.component(_select_src_option__WEBPACK_IMPORTED_MODULE_0__[/* default */ "a"].name, _select_src_option__WEBPACK_IMPORTED_MODULE_0__[/* default */ "a"]);
- };
- /* harmony default export */ __webpack_exports__["default"] = (_select_src_option__WEBPACK_IMPORTED_MODULE_0__[/* default */ "a"]);
- /***/ })
- /******/ });
- /***/ }),
- /* 79 */
- /***/ (function(module, exports) {
- module.exports = require("normalize-wheel");
- /***/ }),
- /* 80 */
- /***/ (function(module, exports, __webpack_require__) {
- "use strict";
- exports.__esModule = true;
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
- var _ariaUtils = __webpack_require__(26);
- var _ariaUtils2 = _interopRequireDefault(_ariaUtils);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- /**
- * @constructor
- * @desc Dialog object providing modal focus management.
- *
- * Assumptions: The element serving as the dialog container is present in the
- * DOM and hidden. The dialog container has role='dialog'.
- *
- * @param dialogId
- * The ID of the element serving as the dialog container.
- * @param focusAfterClosed
- * Either the DOM node or the ID of the DOM node to focus when the
- * dialog closes.
- * @param focusFirst
- * Optional parameter containing either the DOM node or the ID of the
- * DOM node to focus when the dialog opens. If not specified, the
- * first focusable element in the dialog will receive focus.
- */
- var aria = aria || {};
- var tabEvent;
- aria.Dialog = function (dialog, focusAfterClosed, focusFirst) {
- var _this = this;
- this.dialogNode = dialog;
- if (this.dialogNode === null || this.dialogNode.getAttribute('role') !== 'dialog') {
- throw new Error('Dialog() requires a DOM element with ARIA role of dialog.');
- }
- if (typeof focusAfterClosed === 'string') {
- this.focusAfterClosed = document.getElementById(focusAfterClosed);
- } else if ((typeof focusAfterClosed === 'undefined' ? 'undefined' : _typeof(focusAfterClosed)) === 'object') {
- this.focusAfterClosed = focusAfterClosed;
- } else {
- this.focusAfterClosed = null;
- }
- if (typeof focusFirst === 'string') {
- this.focusFirst = document.getElementById(focusFirst);
- } else if ((typeof focusFirst === 'undefined' ? 'undefined' : _typeof(focusFirst)) === 'object') {
- this.focusFirst = focusFirst;
- } else {
- this.focusFirst = null;
- }
- if (this.focusFirst) {
- this.focusFirst.focus();
- } else {
- _ariaUtils2.default.focusFirstDescendant(this.dialogNode);
- }
- this.lastFocus = document.activeElement;
- tabEvent = function tabEvent(e) {
- _this.trapFocus(e);
- };
- this.addListeners();
- };
- aria.Dialog.prototype.addListeners = function () {
- document.addEventListener('focus', tabEvent, true);
- };
- aria.Dialog.prototype.removeListeners = function () {
- document.removeEventListener('focus', tabEvent, true);
- };
- aria.Dialog.prototype.closeDialog = function () {
- var _this2 = this;
- this.removeListeners();
- if (this.focusAfterClosed) {
- setTimeout(function () {
- _this2.focusAfterClosed.focus();
- });
- }
- };
- aria.Dialog.prototype.trapFocus = function (event) {
- if (_ariaUtils2.default.IgnoreUtilFocusChanges) {
- return;
- }
- if (this.dialogNode.contains(event.target)) {
- this.lastFocus = event.target;
- } else {
- _ariaUtils2.default.focusFirstDescendant(this.dialogNode);
- if (this.lastFocus === document.activeElement) {
- _ariaUtils2.default.focusLastDescendant(this.dialogNode);
- }
- this.lastFocus = document.activeElement;
- }
- };
- exports.default = aria.Dialog;
- /***/ }),
- /* 81 */
- /***/ (function(module, exports) {
- module.exports = require("async-validator");
- /***/ }),
- /* 82 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 87);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 10:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(20);
- /***/ }),
- /***/ 2:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(6);
- /***/ }),
- /***/ 22:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(24);
- /***/ }),
- /***/ 3:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(4);
- /***/ }),
- /***/ 30:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony import */ var element_ui_src_utils_dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2);
- /* harmony import */ var element_ui_src_utils_dom__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(element_ui_src_utils_dom__WEBPACK_IMPORTED_MODULE_0__);
- /* harmony import */ var element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3);
- /* harmony import */ var element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_1__);
- /* harmony default export */ __webpack_exports__["a"] = ({
- bind: function bind(el, binding, vnode) {
- var interval = null;
- var startTime = void 0;
- var maxIntervals = Object(element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_1__["isMac"])() ? 100 : 200;
- var handler = function handler() {
- return vnode.context[binding.expression].apply();
- };
- var clear = function clear() {
- if (Date.now() - startTime < maxIntervals) {
- handler();
- }
- clearInterval(interval);
- interval = null;
- };
- Object(element_ui_src_utils_dom__WEBPACK_IMPORTED_MODULE_0__["on"])(el, 'mousedown', function (e) {
- if (e.button !== 0) return;
- startTime = Date.now();
- Object(element_ui_src_utils_dom__WEBPACK_IMPORTED_MODULE_0__["once"])(document, 'mouseup', clear);
- clearInterval(interval);
- interval = setInterval(handler, maxIntervals);
- });
- }
- });
- /***/ }),
- /***/ 87:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/input-number/src/input-number.vue?vue&type=template&id=42f8cf66&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- class: [
- "el-input-number",
- _vm.inputNumberSize ? "el-input-number--" + _vm.inputNumberSize : "",
- { "is-disabled": _vm.inputNumberDisabled },
- { "is-without-controls": !_vm.controls },
- { "is-controls-right": _vm.controlsAtRight }
- ],
- on: {
- dragstart: function($event) {
- $event.preventDefault()
- }
- }
- },
- [
- _vm.controls
- ? _c(
- "span",
- {
- directives: [
- {
- name: "repeat-click",
- rawName: "v-repeat-click",
- value: _vm.decrease,
- expression: "decrease"
- }
- ],
- staticClass: "el-input-number__decrease",
- class: { "is-disabled": _vm.minDisabled },
- attrs: { role: "button" },
- on: {
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")
- ) {
- return null
- }
- return _vm.decrease($event)
- }
- }
- },
- [
- _c("i", {
- class:
- "el-icon-" + (_vm.controlsAtRight ? "arrow-down" : "minus")
- })
- ]
- )
- : _vm._e(),
- _vm.controls
- ? _c(
- "span",
- {
- directives: [
- {
- name: "repeat-click",
- rawName: "v-repeat-click",
- value: _vm.increase,
- expression: "increase"
- }
- ],
- staticClass: "el-input-number__increase",
- class: { "is-disabled": _vm.maxDisabled },
- attrs: { role: "button" },
- on: {
- keydown: function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")
- ) {
- return null
- }
- return _vm.increase($event)
- }
- }
- },
- [
- _c("i", {
- class: "el-icon-" + (_vm.controlsAtRight ? "arrow-up" : "plus")
- })
- ]
- )
- : _vm._e(),
- _c("el-input", {
- ref: "input",
- attrs: {
- value: _vm.displayValue,
- placeholder: _vm.placeholder,
- disabled: _vm.inputNumberDisabled,
- size: _vm.inputNumberSize,
- max: _vm.max,
- min: _vm.min,
- name: _vm.name,
- label: _vm.label
- },
- on: {
- blur: _vm.handleBlur,
- focus: _vm.handleFocus,
- input: _vm.handleInput,
- change: _vm.handleInputChange
- },
- nativeOn: {
- keydown: [
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "up", 38, $event.key, ["Up", "ArrowUp"])
- ) {
- return null
- }
- $event.preventDefault()
- return _vm.increase($event)
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "down", 40, $event.key, [
- "Down",
- "ArrowDown"
- ])
- ) {
- return null
- }
- $event.preventDefault()
- return _vm.decrease($event)
- }
- ]
- }
- })
- ],
- 1
- )
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/input-number/src/input-number.vue?vue&type=template&id=42f8cf66&
- // EXTERNAL MODULE: external "element-ui/lib/input"
- var input_ = __webpack_require__(10);
- var input_default = /*#__PURE__*/__webpack_require__.n(input_);
- // EXTERNAL MODULE: external "element-ui/lib/mixins/focus"
- var focus_ = __webpack_require__(22);
- var focus_default = /*#__PURE__*/__webpack_require__.n(focus_);
- // EXTERNAL MODULE: ./src/directives/repeat-click.js
- var repeat_click = __webpack_require__(30);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/input-number/src/input-number.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var input_numbervue_type_script_lang_js_ = ({
- name: 'ElInputNumber',
- mixins: [focus_default()('input')],
- inject: {
- elForm: {
- default: ''
- },
- elFormItem: {
- default: ''
- }
- },
- directives: {
- repeatClick: repeat_click["a" /* default */]
- },
- components: {
- ElInput: input_default.a
- },
- props: {
- step: {
- type: Number,
- default: 1
- },
- stepStrictly: {
- type: Boolean,
- default: false
- },
- max: {
- type: Number,
- default: Infinity
- },
- min: {
- type: Number,
- default: -Infinity
- },
- value: {},
- disabled: Boolean,
- size: String,
- controls: {
- type: Boolean,
- default: true
- },
- controlsPosition: {
- type: String,
- default: ''
- },
- name: String,
- label: String,
- placeholder: String,
- precision: {
- type: Number,
- validator: function validator(val) {
- return val >= 0 && val === parseInt(val, 10);
- }
- }
- },
- data: function data() {
- return {
- currentValue: 0,
- userInput: null
- };
- },
- watch: {
- value: {
- immediate: true,
- handler: function handler(value) {
- var newVal = value === undefined ? value : Number(value);
- if (newVal !== undefined) {
- if (isNaN(newVal)) {
- return;
- }
- if (this.stepStrictly) {
- var stepPrecision = this.getPrecision(this.step);
- var precisionFactor = Math.pow(10, stepPrecision);
- newVal = Math.round(newVal / this.step) * precisionFactor * this.step / precisionFactor;
- }
- if (this.precision !== undefined) {
- newVal = this.toPrecision(newVal, this.precision);
- }
- }
- if (newVal >= this.max) newVal = this.max;
- if (newVal <= this.min) newVal = this.min;
- this.currentValue = newVal;
- this.userInput = null;
- this.$emit('input', newVal);
- }
- }
- },
- computed: {
- minDisabled: function minDisabled() {
- return this._decrease(this.value, this.step) < this.min;
- },
- maxDisabled: function maxDisabled() {
- return this._increase(this.value, this.step) > this.max;
- },
- numPrecision: function numPrecision() {
- var value = this.value,
- step = this.step,
- getPrecision = this.getPrecision,
- precision = this.precision;
- var stepPrecision = getPrecision(step);
- if (precision !== undefined) {
- if (stepPrecision > precision) {
- console.warn('[Element Warn][InputNumber]precision should not be less than the decimal places of step');
- }
- return precision;
- } else {
- return Math.max(getPrecision(value), stepPrecision);
- }
- },
- controlsAtRight: function controlsAtRight() {
- return this.controls && this.controlsPosition === 'right';
- },
- _elFormItemSize: function _elFormItemSize() {
- return (this.elFormItem || {}).elFormItemSize;
- },
- inputNumberSize: function inputNumberSize() {
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
- },
- inputNumberDisabled: function inputNumberDisabled() {
- return this.disabled || !!(this.elForm || {}).disabled;
- },
- displayValue: function displayValue() {
- if (this.userInput !== null) {
- return this.userInput;
- }
- var currentValue = this.currentValue;
- if (typeof currentValue === 'number') {
- if (this.stepStrictly) {
- var stepPrecision = this.getPrecision(this.step);
- var precisionFactor = Math.pow(10, stepPrecision);
- currentValue = Math.round(currentValue / this.step) * precisionFactor * this.step / precisionFactor;
- }
- if (this.precision !== undefined) {
- currentValue = currentValue.toFixed(this.precision);
- }
- }
- return currentValue;
- }
- },
- methods: {
- toPrecision: function toPrecision(num, precision) {
- if (precision === undefined) precision = this.numPrecision;
- return parseFloat(Math.round(num * Math.pow(10, precision)) / Math.pow(10, precision));
- },
- getPrecision: function getPrecision(value) {
- if (value === undefined) return 0;
- var valueString = value.toString();
- var dotPosition = valueString.indexOf('.');
- var precision = 0;
- if (dotPosition !== -1) {
- precision = valueString.length - dotPosition - 1;
- }
- return precision;
- },
- _increase: function _increase(val, step) {
- if (typeof val !== 'number' && val !== undefined) return this.currentValue;
- var precisionFactor = Math.pow(10, this.numPrecision);
- // Solve the accuracy problem of JS decimal calculation by converting the value to integer.
- return this.toPrecision((precisionFactor * val + precisionFactor * step) / precisionFactor);
- },
- _decrease: function _decrease(val, step) {
- if (typeof val !== 'number' && val !== undefined) return this.currentValue;
- var precisionFactor = Math.pow(10, this.numPrecision);
- return this.toPrecision((precisionFactor * val - precisionFactor * step) / precisionFactor);
- },
- increase: function increase() {
- if (this.inputNumberDisabled || this.maxDisabled) return;
- var value = this.value || 0;
- var newVal = this._increase(value, this.step);
- this.setCurrentValue(newVal);
- },
- decrease: function decrease() {
- if (this.inputNumberDisabled || this.minDisabled) return;
- var value = this.value || 0;
- var newVal = this._decrease(value, this.step);
- this.setCurrentValue(newVal);
- },
- handleBlur: function handleBlur(event) {
- this.$emit('blur', event);
- },
- handleFocus: function handleFocus(event) {
- this.$emit('focus', event);
- },
- setCurrentValue: function setCurrentValue(newVal) {
- var oldVal = this.currentValue;
- if (typeof newVal === 'number' && this.precision !== undefined) {
- newVal = this.toPrecision(newVal, this.precision);
- }
- if (newVal >= this.max) newVal = this.max;
- if (newVal <= this.min) newVal = this.min;
- if (oldVal === newVal) return;
- this.userInput = null;
- this.$emit('input', newVal);
- this.$emit('change', newVal, oldVal);
- this.currentValue = newVal;
- },
- handleInput: function handleInput(value) {
- this.userInput = value;
- },
- handleInputChange: function handleInputChange(value) {
- var newVal = value === '' ? undefined : Number(value);
- if (!isNaN(newVal) || value === '') {
- this.setCurrentValue(newVal);
- }
- this.userInput = null;
- },
- select: function select() {
- this.$refs.input.select();
- }
- },
- mounted: function mounted() {
- var innerInput = this.$refs.input.$refs.input;
- innerInput.setAttribute('role', 'spinbutton');
- innerInput.setAttribute('aria-valuemax', this.max);
- innerInput.setAttribute('aria-valuemin', this.min);
- innerInput.setAttribute('aria-valuenow', this.currentValue);
- innerInput.setAttribute('aria-disabled', this.inputNumberDisabled);
- },
- updated: function updated() {
- if (!this.$refs || !this.$refs.input) return;
- var innerInput = this.$refs.input.$refs.input;
- innerInput.setAttribute('aria-valuenow', this.currentValue);
- }
- });
- // CONCATENATED MODULE: ./packages/input-number/src/input-number.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_input_numbervue_type_script_lang_js_ = (input_numbervue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/input-number/src/input-number.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_input_numbervue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/input-number/src/input-number.vue"
- /* harmony default export */ var input_number = (component.exports);
- // CONCATENATED MODULE: ./packages/input-number/index.js
- /* istanbul ignore next */
- input_number.install = function (Vue) {
- Vue.component(input_number.name, input_number);
- };
- /* harmony default export */ var packages_input_number = __webpack_exports__["default"] = (input_number);
- /***/ })
- /******/ });
- /***/ }),
- /* 83 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 61);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 15:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(23);
- /***/ }),
- /***/ 18:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(38);
- /***/ }),
- /***/ 21:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(14);
- /***/ }),
- /***/ 26:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(40);
- /***/ }),
- /***/ 3:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(4);
- /***/ }),
- /***/ 31:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(25);
- /***/ }),
- /***/ 41:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(26);
- /***/ }),
- /***/ 52:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(44);
- /***/ }),
- /***/ 6:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(18);
- /***/ }),
- /***/ 61:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-panel.vue?vue&type=template&id=34932346&
- var cascader_panelvue_type_template_id_34932346_render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "div",
- {
- class: ["el-cascader-panel", _vm.border && "is-bordered"],
- on: { keydown: _vm.handleKeyDown }
- },
- _vm._l(_vm.menus, function(menu, index) {
- return _c("cascader-menu", {
- key: index,
- ref: "menu",
- refInFor: true,
- attrs: { index: index, nodes: menu }
- })
- }),
- 1
- )
- }
- var staticRenderFns = []
- cascader_panelvue_type_template_id_34932346_render._withStripped = true
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue?vue&type=template&id=34932346&
- // EXTERNAL MODULE: external "babel-helper-vue-jsx-merge-props"
- var external_babel_helper_vue_jsx_merge_props_ = __webpack_require__(26);
- var external_babel_helper_vue_jsx_merge_props_default = /*#__PURE__*/__webpack_require__.n(external_babel_helper_vue_jsx_merge_props_);
- // EXTERNAL MODULE: external "element-ui/lib/scrollbar"
- var scrollbar_ = __webpack_require__(15);
- var scrollbar_default = /*#__PURE__*/__webpack_require__.n(scrollbar_);
- // EXTERNAL MODULE: external "element-ui/lib/checkbox"
- var checkbox_ = __webpack_require__(18);
- var checkbox_default = /*#__PURE__*/__webpack_require__.n(checkbox_);
- // EXTERNAL MODULE: external "element-ui/lib/radio"
- var radio_ = __webpack_require__(52);
- var radio_default = /*#__PURE__*/__webpack_require__.n(radio_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/util"
- var util_ = __webpack_require__(3);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-node.vue?vue&type=script&lang=js&
- var stopPropagation = function stopPropagation(e) {
- return e.stopPropagation();
- };
- /* harmony default export */ var cascader_nodevue_type_script_lang_js_ = ({
- inject: ['panel'],
- components: {
- ElCheckbox: checkbox_default.a,
- ElRadio: radio_default.a
- },
- props: {
- node: {
- required: true
- },
- nodeId: String
- },
- computed: {
- config: function config() {
- return this.panel.config;
- },
- isLeaf: function isLeaf() {
- return this.node.isLeaf;
- },
- isDisabled: function isDisabled() {
- return this.node.isDisabled;
- },
- checkedValue: function checkedValue() {
- return this.panel.checkedValue;
- },
- isChecked: function isChecked() {
- return this.node.isSameNode(this.checkedValue);
- },
- inActivePath: function inActivePath() {
- return this.isInPath(this.panel.activePath);
- },
- inCheckedPath: function inCheckedPath() {
- var _this = this;
- if (!this.config.checkStrictly) return false;
- return this.panel.checkedNodePaths.some(function (checkedPath) {
- return _this.isInPath(checkedPath);
- });
- },
- value: function value() {
- return this.node.getValueByOption();
- }
- },
- methods: {
- handleExpand: function handleExpand() {
- var _this2 = this;
- var panel = this.panel,
- node = this.node,
- isDisabled = this.isDisabled,
- config = this.config;
- var multiple = config.multiple,
- checkStrictly = config.checkStrictly;
- if (!checkStrictly && isDisabled || node.loading) return;
- if (config.lazy && !node.loaded) {
- panel.lazyLoad(node, function () {
- // do not use cached leaf value here, invoke this.isLeaf to get new value.
- var isLeaf = _this2.isLeaf;
- if (!isLeaf) _this2.handleExpand();
- if (multiple) {
- // if leaf sync checked state, else clear checked state
- var checked = isLeaf ? node.checked : false;
- _this2.handleMultiCheckChange(checked);
- }
- });
- } else {
- panel.handleExpand(node);
- }
- },
- handleCheckChange: function handleCheckChange() {
- var panel = this.panel,
- value = this.value,
- node = this.node;
- panel.handleCheckChange(value);
- panel.handleExpand(node);
- },
- handleMultiCheckChange: function handleMultiCheckChange(checked) {
- this.node.doCheck(checked);
- this.panel.calculateMultiCheckedValue();
- },
- isInPath: function isInPath(pathNodes) {
- var node = this.node;
- var selectedPathNode = pathNodes[node.level - 1] || {};
- return selectedPathNode.uid === node.uid;
- },
- renderPrefix: function renderPrefix(h) {
- var isLeaf = this.isLeaf,
- isChecked = this.isChecked,
- config = this.config;
- var checkStrictly = config.checkStrictly,
- multiple = config.multiple;
- if (multiple) {
- return this.renderCheckbox(h);
- } else if (checkStrictly) {
- return this.renderRadio(h);
- } else if (isLeaf && isChecked) {
- return this.renderCheckIcon(h);
- }
- return null;
- },
- renderPostfix: function renderPostfix(h) {
- var node = this.node,
- isLeaf = this.isLeaf;
- if (node.loading) {
- return this.renderLoadingIcon(h);
- } else if (!isLeaf) {
- return this.renderExpandIcon(h);
- }
- return null;
- },
- renderCheckbox: function renderCheckbox(h) {
- var node = this.node,
- config = this.config,
- isDisabled = this.isDisabled;
- var events = {
- on: { change: this.handleMultiCheckChange },
- nativeOn: {}
- };
- if (config.checkStrictly) {
- // when every node is selectable, click event should not trigger expand event.
- events.nativeOn.click = stopPropagation;
- }
- return h('el-checkbox', external_babel_helper_vue_jsx_merge_props_default()([{
- attrs: {
- value: node.checked,
- indeterminate: node.indeterminate,
- disabled: isDisabled
- }
- }, events]));
- },
- renderRadio: function renderRadio(h) {
- var checkedValue = this.checkedValue,
- value = this.value,
- isDisabled = this.isDisabled;
- // to keep same reference if value cause radio's checked state is calculated by reference comparision;
- if (Object(util_["isEqual"])(value, checkedValue)) {
- value = checkedValue;
- }
- return h(
- 'el-radio',
- {
- attrs: {
- value: checkedValue,
- label: value,
- disabled: isDisabled
- },
- on: {
- 'change': this.handleCheckChange
- },
- nativeOn: {
- 'click': stopPropagation
- }
- },
- [h('span')]
- );
- },
- renderCheckIcon: function renderCheckIcon(h) {
- return h('i', { 'class': 'el-icon-check el-cascader-node__prefix' });
- },
- renderLoadingIcon: function renderLoadingIcon(h) {
- return h('i', { 'class': 'el-icon-loading el-cascader-node__postfix' });
- },
- renderExpandIcon: function renderExpandIcon(h) {
- return h('i', { 'class': 'el-icon-arrow-right el-cascader-node__postfix' });
- },
- renderContent: function renderContent(h) {
- var panel = this.panel,
- node = this.node;
- var render = panel.renderLabelFn;
- var vnode = render ? render({ node: node, data: node.data }) : null;
- return h(
- 'span',
- { 'class': 'el-cascader-node__label' },
- [vnode || node.label]
- );
- }
- },
- render: function render(h) {
- var _this3 = this;
- var inActivePath = this.inActivePath,
- inCheckedPath = this.inCheckedPath,
- isChecked = this.isChecked,
- isLeaf = this.isLeaf,
- isDisabled = this.isDisabled,
- config = this.config,
- nodeId = this.nodeId;
- var expandTrigger = config.expandTrigger,
- checkStrictly = config.checkStrictly,
- multiple = config.multiple;
- var disabled = !checkStrictly && isDisabled;
- var events = { on: {} };
- if (expandTrigger === 'click') {
- events.on.click = this.handleExpand;
- } else {
- events.on.mouseenter = function (e) {
- _this3.handleExpand();
- _this3.$emit('expand', e);
- };
- events.on.focus = function (e) {
- _this3.handleExpand();
- _this3.$emit('expand', e);
- };
- }
- if (isLeaf && !isDisabled && !checkStrictly && !multiple) {
- events.on.click = this.handleCheckChange;
- }
- return h(
- 'li',
- external_babel_helper_vue_jsx_merge_props_default()([{
- attrs: {
- role: 'menuitem',
- id: nodeId,
- 'aria-expanded': inActivePath,
- tabindex: disabled ? null : -1
- },
- 'class': {
- 'el-cascader-node': true,
- 'is-selectable': checkStrictly,
- 'in-active-path': inActivePath,
- 'in-checked-path': inCheckedPath,
- 'is-active': isChecked,
- 'is-disabled': disabled
- }
- }, events]),
- [this.renderPrefix(h), this.renderContent(h), this.renderPostfix(h)]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-node.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_cascader_nodevue_type_script_lang_js_ = (cascader_nodevue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-node.vue
- var cascader_node_render, cascader_node_staticRenderFns
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_cascader_nodevue_type_script_lang_js_,
- cascader_node_render,
- cascader_node_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/cascader-panel/src/cascader-node.vue"
- /* harmony default export */ var cascader_node = (component.exports);
- // EXTERNAL MODULE: external "element-ui/lib/mixins/locale"
- var locale_ = __webpack_require__(6);
- var locale_default = /*#__PURE__*/__webpack_require__.n(locale_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-menu.vue?vue&type=script&lang=js&
- /* harmony default export */ var cascader_menuvue_type_script_lang_js_ = ({
- name: 'ElCascaderMenu',
- mixins: [locale_default.a],
- inject: ['panel'],
- components: {
- ElScrollbar: scrollbar_default.a,
- CascaderNode: cascader_node
- },
- props: {
- nodes: {
- type: Array,
- required: true
- },
- index: Number
- },
- data: function data() {
- return {
- activeNode: null,
- hoverTimer: null,
- id: Object(util_["generateId"])()
- };
- },
- computed: {
- isEmpty: function isEmpty() {
- return !this.nodes.length;
- },
- menuId: function menuId() {
- return 'cascader-menu-' + this.id + '-' + this.index;
- }
- },
- methods: {
- handleExpand: function handleExpand(e) {
- this.activeNode = e.target;
- },
- handleMouseMove: function handleMouseMove(e) {
- var activeNode = this.activeNode,
- hoverTimer = this.hoverTimer;
- var hoverZone = this.$refs.hoverZone;
- if (!activeNode || !hoverZone) return;
- if (activeNode.contains(e.target)) {
- clearTimeout(hoverTimer);
- var _$el$getBoundingClien = this.$el.getBoundingClientRect(),
- left = _$el$getBoundingClien.left;
- var startX = e.clientX - left;
- var _$el = this.$el,
- offsetWidth = _$el.offsetWidth,
- offsetHeight = _$el.offsetHeight;
- var top = activeNode.offsetTop;
- var bottom = top + activeNode.offsetHeight;
- hoverZone.innerHTML = '\n <path style="pointer-events: auto;" fill="transparent" d="M' + startX + ' ' + top + ' L' + offsetWidth + ' 0 V' + top + ' Z" />\n <path style="pointer-events: auto;" fill="transparent" d="M' + startX + ' ' + bottom + ' L' + offsetWidth + ' ' + offsetHeight + ' V' + bottom + ' Z" />\n ';
- } else if (!hoverTimer) {
- this.hoverTimer = setTimeout(this.clearHoverZone, this.panel.config.hoverThreshold);
- }
- },
- clearHoverZone: function clearHoverZone() {
- var hoverZone = this.$refs.hoverZone;
- if (!hoverZone) return;
- hoverZone.innerHTML = '';
- },
- renderEmptyText: function renderEmptyText(h) {
- return h(
- 'div',
- { 'class': 'el-cascader-menu__empty-text' },
- [this.t('el.cascader.noData')]
- );
- },
- renderNodeList: function renderNodeList(h) {
- var menuId = this.menuId;
- var isHoverMenu = this.panel.isHoverMenu;
- var events = { on: {} };
- if (isHoverMenu) {
- events.on.expand = this.handleExpand;
- }
- var nodes = this.nodes.map(function (node, index) {
- var hasChildren = node.hasChildren;
- return h('cascader-node', external_babel_helper_vue_jsx_merge_props_default()([{
- key: node.uid,
- attrs: { node: node,
- 'node-id': menuId + '-' + index,
- 'aria-haspopup': hasChildren,
- 'aria-owns': hasChildren ? menuId : null
- }
- }, events]));
- });
- return [].concat(nodes, [isHoverMenu ? h('svg', { ref: 'hoverZone', 'class': 'el-cascader-menu__hover-zone' }) : null]);
- }
- },
- render: function render(h) {
- var isEmpty = this.isEmpty,
- menuId = this.menuId;
- var events = { nativeOn: {} };
- // optimize hover to expand experience (#8010)
- if (this.panel.isHoverMenu) {
- events.nativeOn.mousemove = this.handleMouseMove;
- // events.nativeOn.mouseleave = this.clearHoverZone;
- }
- return h(
- 'el-scrollbar',
- external_babel_helper_vue_jsx_merge_props_default()([{
- attrs: {
- tag: 'ul',
- role: 'menu',
- id: menuId,
- 'wrap-class': 'el-cascader-menu__wrap',
- 'view-class': {
- 'el-cascader-menu__list': true,
- 'is-empty': isEmpty
- }
- },
- 'class': 'el-cascader-menu' }, events]),
- [isEmpty ? this.renderEmptyText(h) : this.renderNodeList(h)]
- );
- }
- });
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-menu.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_cascader_menuvue_type_script_lang_js_ = (cascader_menuvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-menu.vue
- var cascader_menu_render, cascader_menu_staticRenderFns
- /* normalize component */
- var cascader_menu_component = Object(componentNormalizer["a" /* default */])(
- src_cascader_menuvue_type_script_lang_js_,
- cascader_menu_render,
- cascader_menu_staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var cascader_menu_api; }
- cascader_menu_component.options.__file = "packages/cascader-panel/src/cascader-menu.vue"
- /* harmony default export */ var cascader_menu = (cascader_menu_component.exports);
- // EXTERNAL MODULE: external "element-ui/lib/utils/shared"
- var shared_ = __webpack_require__(21);
- // CONCATENATED MODULE: ./packages/cascader-panel/src/node.js
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- var uid = 0;
- var node_Node = function () {
- function Node(data, config, parentNode) {
- _classCallCheck(this, Node);
- this.data = data;
- this.config = config;
- this.parent = parentNode || null;
- this.level = !this.parent ? 1 : this.parent.level + 1;
- this.uid = uid++;
- this.initState();
- this.initChildren();
- }
- Node.prototype.initState = function initState() {
- var _config = this.config,
- valueKey = _config.value,
- labelKey = _config.label;
- this.value = this.data[valueKey];
- this.label = this.data[labelKey];
- this.pathNodes = this.calculatePathNodes();
- this.path = this.pathNodes.map(function (node) {
- return node.value;
- });
- this.pathLabels = this.pathNodes.map(function (node) {
- return node.label;
- });
- // lazy load
- this.loading = false;
- this.loaded = false;
- };
- Node.prototype.initChildren = function initChildren() {
- var _this = this;
- var config = this.config;
- var childrenKey = config.children;
- var childrenData = this.data[childrenKey];
- this.hasChildren = Array.isArray(childrenData);
- this.children = (childrenData || []).map(function (child) {
- return new Node(child, config, _this);
- });
- };
- Node.prototype.calculatePathNodes = function calculatePathNodes() {
- var nodes = [this];
- var parent = this.parent;
- while (parent) {
- nodes.unshift(parent);
- parent = parent.parent;
- }
- return nodes;
- };
- Node.prototype.getPath = function getPath() {
- return this.path;
- };
- Node.prototype.getValue = function getValue() {
- return this.value;
- };
- Node.prototype.getValueByOption = function getValueByOption() {
- return this.config.emitPath ? this.getPath() : this.getValue();
- };
- Node.prototype.getText = function getText(allLevels, separator) {
- return allLevels ? this.pathLabels.join(separator) : this.label;
- };
- Node.prototype.isSameNode = function isSameNode(checkedValue) {
- var value = this.getValueByOption();
- return this.config.multiple && Array.isArray(checkedValue) ? checkedValue.some(function (val) {
- return Object(util_["isEqual"])(val, value);
- }) : Object(util_["isEqual"])(checkedValue, value);
- };
- Node.prototype.broadcast = function broadcast(event) {
- for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
- args[_key - 1] = arguments[_key];
- }
- var handlerName = 'onParent' + Object(util_["capitalize"])(event);
- this.children.forEach(function (child) {
- if (child) {
- // bottom up
- child.broadcast.apply(child, [event].concat(args));
- child[handlerName] && child[handlerName].apply(child, args);
- }
- });
- };
- Node.prototype.emit = function emit(event) {
- var parent = this.parent;
- var handlerName = 'onChild' + Object(util_["capitalize"])(event);
- if (parent) {
- for (var _len2 = arguments.length, args = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
- args[_key2 - 1] = arguments[_key2];
- }
- parent[handlerName] && parent[handlerName].apply(parent, args);
- parent.emit.apply(parent, [event].concat(args));
- }
- };
- Node.prototype.onParentCheck = function onParentCheck(checked) {
- if (!this.isDisabled) {
- this.setCheckState(checked);
- }
- };
- Node.prototype.onChildCheck = function onChildCheck() {
- var children = this.children;
- var validChildren = children.filter(function (child) {
- return !child.isDisabled;
- });
- var checked = validChildren.length ? validChildren.every(function (child) {
- return child.checked;
- }) : false;
- this.setCheckState(checked);
- };
- Node.prototype.setCheckState = function setCheckState(checked) {
- var totalNum = this.children.length;
- var checkedNum = this.children.reduce(function (c, p) {
- var num = p.checked ? 1 : p.indeterminate ? 0.5 : 0;
- return c + num;
- }, 0);
- this.checked = checked;
- this.indeterminate = checkedNum !== totalNum && checkedNum > 0;
- };
- Node.prototype.syncCheckState = function syncCheckState(checkedValue) {
- var value = this.getValueByOption();
- var checked = this.isSameNode(checkedValue, value);
- this.doCheck(checked);
- };
- Node.prototype.doCheck = function doCheck(checked) {
- if (this.checked !== checked) {
- if (this.config.checkStrictly) {
- this.checked = checked;
- } else {
- // bottom up to unify the calculation of the indeterminate state
- this.broadcast('check', checked);
- this.setCheckState(checked);
- this.emit('check');
- }
- }
- };
- _createClass(Node, [{
- key: 'isDisabled',
- get: function get() {
- var data = this.data,
- parent = this.parent,
- config = this.config;
- var disabledKey = config.disabled;
- var checkStrictly = config.checkStrictly;
- return data[disabledKey] || !checkStrictly && parent && parent.isDisabled;
- }
- }, {
- key: 'isLeaf',
- get: function get() {
- var data = this.data,
- loaded = this.loaded,
- hasChildren = this.hasChildren,
- children = this.children;
- var _config2 = this.config,
- lazy = _config2.lazy,
- leafKey = _config2.leaf;
- if (lazy) {
- var isLeaf = Object(shared_["isDef"])(data[leafKey]) ? data[leafKey] : loaded ? !children.length : false;
- this.hasChildren = !isLeaf;
- return isLeaf;
- }
- return !hasChildren;
- }
- }]);
- return Node;
- }();
- /* harmony default export */ var src_node = (node_Node);
- // CONCATENATED MODULE: ./packages/cascader-panel/src/store.js
- function store_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- var flatNodes = function flatNodes(data, leafOnly) {
- return data.reduce(function (res, node) {
- if (node.isLeaf) {
- res.push(node);
- } else {
- !leafOnly && res.push(node);
- res = res.concat(flatNodes(node.children, leafOnly));
- }
- return res;
- }, []);
- };
- var store_Store = function () {
- function Store(data, config) {
- store_classCallCheck(this, Store);
- this.config = config;
- this.initNodes(data);
- }
- Store.prototype.initNodes = function initNodes(data) {
- var _this = this;
- data = Object(util_["coerceTruthyValueToArray"])(data);
- this.nodes = data.map(function (nodeData) {
- return new src_node(nodeData, _this.config);
- });
- this.flattedNodes = this.getFlattedNodes(false, false);
- this.leafNodes = this.getFlattedNodes(true, false);
- };
- Store.prototype.appendNode = function appendNode(nodeData, parentNode) {
- var node = new src_node(nodeData, this.config, parentNode);
- var children = parentNode ? parentNode.children : this.nodes;
- children.push(node);
- };
- Store.prototype.appendNodes = function appendNodes(nodeDataList, parentNode) {
- var _this2 = this;
- nodeDataList = Object(util_["coerceTruthyValueToArray"])(nodeDataList);
- nodeDataList.forEach(function (nodeData) {
- return _this2.appendNode(nodeData, parentNode);
- });
- };
- Store.prototype.getNodes = function getNodes() {
- return this.nodes;
- };
- Store.prototype.getFlattedNodes = function getFlattedNodes(leafOnly) {
- var cached = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
- var cachedNodes = leafOnly ? this.leafNodes : this.flattedNodes;
- return cached ? cachedNodes : flatNodes(this.nodes, leafOnly);
- };
- Store.prototype.getNodeByValue = function getNodeByValue(value) {
- var nodes = this.getFlattedNodes(false, !this.config.lazy).filter(function (node) {
- return Object(util_["valueEquals"])(node.path, value) || node.value === value;
- });
- return nodes && nodes.length ? nodes[0] : null;
- };
- return Store;
- }();
- /* harmony default export */ var src_store = (store_Store);
- // EXTERNAL MODULE: external "element-ui/lib/utils/merge"
- var merge_ = __webpack_require__(9);
- var merge_default = /*#__PURE__*/__webpack_require__.n(merge_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/aria-utils"
- var aria_utils_ = __webpack_require__(41);
- var aria_utils_default = /*#__PURE__*/__webpack_require__.n(aria_utils_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/scroll-into-view"
- var scroll_into_view_ = __webpack_require__(31);
- var scroll_into_view_default = /*#__PURE__*/__webpack_require__.n(scroll_into_view_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-panel.vue?vue&type=script&lang=js&
- var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var KeyCode = aria_utils_default.a.keys;
- var DefaultProps = {
- expandTrigger: 'click', // or hover
- multiple: false,
- checkStrictly: false, // whether all nodes can be selected
- emitPath: true, // wether to emit an array of all levels value in which node is located
- lazy: false,
- lazyLoad: util_["noop"],
- value: 'value',
- label: 'label',
- children: 'children',
- leaf: 'leaf',
- disabled: 'disabled',
- hoverThreshold: 500
- };
- var cascader_panelvue_type_script_lang_js_isLeaf = function isLeaf(el) {
- return !el.getAttribute('aria-owns');
- };
- var getSibling = function getSibling(el, distance) {
- var parentNode = el.parentNode;
- if (parentNode) {
- var siblings = parentNode.querySelectorAll('.el-cascader-node[tabindex="-1"]');
- var index = Array.prototype.indexOf.call(siblings, el);
- return siblings[index + distance] || null;
- }
- return null;
- };
- var getMenuIndex = function getMenuIndex(el, distance) {
- if (!el) return;
- var pieces = el.id.split('-');
- return Number(pieces[pieces.length - 2]);
- };
- var focusNode = function focusNode(el) {
- if (!el) return;
- el.focus();
- !cascader_panelvue_type_script_lang_js_isLeaf(el) && el.click();
- };
- var checkNode = function checkNode(el) {
- if (!el) return;
- var input = el.querySelector('input');
- if (input) {
- input.click();
- } else if (cascader_panelvue_type_script_lang_js_isLeaf(el)) {
- el.click();
- }
- };
- /* harmony default export */ var cascader_panelvue_type_script_lang_js_ = ({
- name: 'ElCascaderPanel',
- components: {
- CascaderMenu: cascader_menu
- },
- props: {
- value: {},
- options: Array,
- props: Object,
- border: {
- type: Boolean,
- default: true
- },
- renderLabel: Function
- },
- provide: function provide() {
- return {
- panel: this
- };
- },
- data: function data() {
- return {
- checkedValue: null,
- checkedNodePaths: [],
- store: [],
- menus: [],
- activePath: [],
- loadCount: 0
- };
- },
- computed: {
- config: function config() {
- return merge_default()(_extends({}, DefaultProps), this.props || {});
- },
- multiple: function multiple() {
- return this.config.multiple;
- },
- checkStrictly: function checkStrictly() {
- return this.config.checkStrictly;
- },
- leafOnly: function leafOnly() {
- return !this.checkStrictly;
- },
- isHoverMenu: function isHoverMenu() {
- return this.config.expandTrigger === 'hover';
- },
- renderLabelFn: function renderLabelFn() {
- return this.renderLabel || this.$scopedSlots.default;
- }
- },
- watch: {
- value: function value() {
- this.syncCheckedValue();
- this.checkStrictly && this.calculateCheckedNodePaths();
- },
- options: {
- handler: function handler() {
- this.initStore();
- },
- immediate: true,
- deep: true
- },
- checkedValue: function checkedValue(val) {
- if (!Object(util_["isEqual"])(val, this.value)) {
- this.checkStrictly && this.calculateCheckedNodePaths();
- this.$emit('input', val);
- this.$emit('change', val);
- }
- }
- },
- mounted: function mounted() {
- if (!this.isEmptyValue(this.value)) {
- this.syncCheckedValue();
- }
- },
- methods: {
- initStore: function initStore() {
- var config = this.config,
- options = this.options;
- if (config.lazy && Object(util_["isEmpty"])(options)) {
- this.lazyLoad();
- } else {
- this.store = new src_store(options, config);
- this.menus = [this.store.getNodes()];
- this.syncMenuState();
- }
- },
- syncCheckedValue: function syncCheckedValue() {
- var value = this.value,
- checkedValue = this.checkedValue;
- if (!Object(util_["isEqual"])(value, checkedValue)) {
- this.activePath = [];
- this.checkedValue = value;
- this.syncMenuState();
- }
- },
- syncMenuState: function syncMenuState() {
- var multiple = this.multiple,
- checkStrictly = this.checkStrictly;
- this.syncActivePath();
- multiple && this.syncMultiCheckState();
- checkStrictly && this.calculateCheckedNodePaths();
- this.$nextTick(this.scrollIntoView);
- },
- syncMultiCheckState: function syncMultiCheckState() {
- var _this = this;
- var nodes = this.getFlattedNodes(this.leafOnly);
- nodes.forEach(function (node) {
- node.syncCheckState(_this.checkedValue);
- });
- },
- isEmptyValue: function isEmptyValue(val) {
- var multiple = this.multiple,
- config = this.config;
- var emitPath = config.emitPath;
- if (multiple || emitPath) {
- return Object(util_["isEmpty"])(val);
- }
- return false;
- },
- syncActivePath: function syncActivePath() {
- var _this2 = this;
- var store = this.store,
- multiple = this.multiple,
- activePath = this.activePath,
- checkedValue = this.checkedValue;
- if (!Object(util_["isEmpty"])(activePath)) {
- var nodes = activePath.map(function (node) {
- return _this2.getNodeByValue(node.getValue());
- });
- this.expandNodes(nodes);
- } else if (!this.isEmptyValue(checkedValue)) {
- var value = multiple ? checkedValue[0] : checkedValue;
- var checkedNode = this.getNodeByValue(value) || {};
- var _nodes = (checkedNode.pathNodes || []).slice(0, -1);
- this.expandNodes(_nodes);
- } else {
- this.activePath = [];
- this.menus = [store.getNodes()];
- }
- },
- expandNodes: function expandNodes(nodes) {
- var _this3 = this;
- nodes.forEach(function (node) {
- return _this3.handleExpand(node, true /* silent */);
- });
- },
- calculateCheckedNodePaths: function calculateCheckedNodePaths() {
- var _this4 = this;
- var checkedValue = this.checkedValue,
- multiple = this.multiple;
- var checkedValues = multiple ? Object(util_["coerceTruthyValueToArray"])(checkedValue) : [checkedValue];
- this.checkedNodePaths = checkedValues.map(function (v) {
- var checkedNode = _this4.getNodeByValue(v);
- return checkedNode ? checkedNode.pathNodes : [];
- });
- },
- handleKeyDown: function handleKeyDown(e) {
- var target = e.target,
- keyCode = e.keyCode;
- switch (keyCode) {
- case KeyCode.up:
- var prev = getSibling(target, -1);
- focusNode(prev);
- break;
- case KeyCode.down:
- var next = getSibling(target, 1);
- focusNode(next);
- break;
- case KeyCode.left:
- var preMenu = this.$refs.menu[getMenuIndex(target) - 1];
- if (preMenu) {
- var expandedNode = preMenu.$el.querySelector('.el-cascader-node[aria-expanded="true"]');
- focusNode(expandedNode);
- }
- break;
- case KeyCode.right:
- var nextMenu = this.$refs.menu[getMenuIndex(target) + 1];
- if (nextMenu) {
- var firstNode = nextMenu.$el.querySelector('.el-cascader-node[tabindex="-1"]');
- focusNode(firstNode);
- }
- break;
- case KeyCode.enter:
- checkNode(target);
- break;
- case KeyCode.esc:
- case KeyCode.tab:
- this.$emit('close');
- break;
- default:
- return;
- }
- },
- handleExpand: function handleExpand(node, silent) {
- var activePath = this.activePath;
- var level = node.level;
- var path = activePath.slice(0, level - 1);
- var menus = this.menus.slice(0, level);
- if (!node.isLeaf) {
- path.push(node);
- menus.push(node.children);
- }
- this.activePath = path;
- this.menus = menus;
- if (!silent) {
- var pathValues = path.map(function (node) {
- return node.getValue();
- });
- var activePathValues = activePath.map(function (node) {
- return node.getValue();
- });
- if (!Object(util_["valueEquals"])(pathValues, activePathValues)) {
- this.$emit('active-item-change', pathValues); // Deprecated
- this.$emit('expand-change', pathValues);
- }
- }
- },
- handleCheckChange: function handleCheckChange(value) {
- this.checkedValue = value;
- },
- lazyLoad: function lazyLoad(node, onFullfiled) {
- var _this5 = this;
- var config = this.config;
- if (!node) {
- node = node || { root: true, level: 0 };
- this.store = new src_store([], config);
- this.menus = [this.store.getNodes()];
- }
- node.loading = true;
- var resolve = function resolve(dataList) {
- var parent = node.root ? null : node;
- dataList && dataList.length && _this5.store.appendNodes(dataList, parent);
- node.loading = false;
- node.loaded = true;
- // dispose default value on lazy load mode
- if (Array.isArray(_this5.checkedValue)) {
- var nodeValue = _this5.checkedValue[_this5.loadCount++];
- var valueKey = _this5.config.value;
- var leafKey = _this5.config.leaf;
- if (Array.isArray(dataList) && dataList.filter(function (item) {
- return item[valueKey] === nodeValue;
- }).length > 0) {
- var checkedNode = _this5.store.getNodeByValue(nodeValue);
- if (!checkedNode.data[leafKey]) {
- _this5.lazyLoad(checkedNode, function () {
- _this5.handleExpand(checkedNode);
- });
- }
- if (_this5.loadCount === _this5.checkedValue.length) {
- _this5.$parent.computePresentText();
- }
- }
- }
- onFullfiled && onFullfiled(dataList);
- };
- config.lazyLoad(node, resolve);
- },
- /**
- * public methods
- */
- calculateMultiCheckedValue: function calculateMultiCheckedValue() {
- this.checkedValue = this.getCheckedNodes(this.leafOnly).map(function (node) {
- return node.getValueByOption();
- });
- },
- scrollIntoView: function scrollIntoView() {
- if (this.$isServer) return;
- var menus = this.$refs.menu || [];
- menus.forEach(function (menu) {
- var menuElement = menu.$el;
- if (menuElement) {
- var container = menuElement.querySelector('.el-scrollbar__wrap');
- var activeNode = menuElement.querySelector('.el-cascader-node.is-active') || menuElement.querySelector('.el-cascader-node.in-active-path');
- scroll_into_view_default()(container, activeNode);
- }
- });
- },
- getNodeByValue: function getNodeByValue(val) {
- return this.store.getNodeByValue(val);
- },
- getFlattedNodes: function getFlattedNodes(leafOnly) {
- var cached = !this.config.lazy;
- return this.store.getFlattedNodes(leafOnly, cached);
- },
- getCheckedNodes: function getCheckedNodes(leafOnly) {
- var checkedValue = this.checkedValue,
- multiple = this.multiple;
- if (multiple) {
- var nodes = this.getFlattedNodes(leafOnly);
- return nodes.filter(function (node) {
- return node.checked;
- });
- } else {
- return this.isEmptyValue(checkedValue) ? [] : [this.getNodeByValue(checkedValue)];
- }
- },
- clearCheckedNodes: function clearCheckedNodes() {
- var config = this.config,
- leafOnly = this.leafOnly;
- var multiple = config.multiple,
- emitPath = config.emitPath;
- if (multiple) {
- this.getCheckedNodes(leafOnly).filter(function (node) {
- return !node.isDisabled;
- }).forEach(function (node) {
- return node.doCheck(false);
- });
- this.calculateMultiCheckedValue();
- } else {
- this.checkedValue = emitPath ? [] : null;
- }
- }
- }
- });
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_cascader_panelvue_type_script_lang_js_ = (cascader_panelvue_type_script_lang_js_);
- // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue
- /* normalize component */
- var cascader_panel_component = Object(componentNormalizer["a" /* default */])(
- src_cascader_panelvue_type_script_lang_js_,
- cascader_panelvue_type_template_id_34932346_render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var cascader_panel_api; }
- cascader_panel_component.options.__file = "packages/cascader-panel/src/cascader-panel.vue"
- /* harmony default export */ var cascader_panel = (cascader_panel_component.exports);
- // CONCATENATED MODULE: ./packages/cascader-panel/index.js
- /* istanbul ignore next */
- cascader_panel.install = function (Vue) {
- Vue.component(cascader_panel.name, cascader_panel);
- };
- /* harmony default export */ var packages_cascader_panel = __webpack_exports__["default"] = (cascader_panel);
- /***/ }),
- /***/ 9:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(13);
- /***/ })
- /******/ });
- /***/ }),
- /* 84 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports =
- /******/ (function(modules) { // webpackBootstrap
- /******/ // The module cache
- /******/ var installedModules = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/
- /******/ // Check if module is in cache
- /******/ if(installedModules[moduleId]) {
- /******/ return installedModules[moduleId].exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = installedModules[moduleId] = {
- /******/ i: moduleId,
- /******/ l: false,
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- /******/
- /******/ // Flag the module as loaded
- /******/ module.l = true;
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /******/
- /******/ // expose the modules object (__webpack_modules__)
- /******/ __webpack_require__.m = modules;
- /******/
- /******/ // expose the module cache
- /******/ __webpack_require__.c = installedModules;
- /******/
- /******/ // define getter function for harmony exports
- /******/ __webpack_require__.d = function(exports, name, getter) {
- /******/ if(!__webpack_require__.o(exports, name)) {
- /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
- /******/ }
- /******/ };
- /******/
- /******/ // define __esModule on exports
- /******/ __webpack_require__.r = function(exports) {
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
- /******/ }
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
- /******/ };
- /******/
- /******/ // create a fake namespace object
- /******/ // mode & 1: value is a module id, require it
- /******/ // mode & 2: merge all properties of value into the ns
- /******/ // mode & 4: return value when already ns object
- /******/ // mode & 8|1: behave like require
- /******/ __webpack_require__.t = function(value, mode) {
- /******/ if(mode & 1) value = __webpack_require__(value);
- /******/ if(mode & 8) return value;
- /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
- /******/ var ns = Object.create(null);
- /******/ __webpack_require__.r(ns);
- /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
- /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
- /******/ return ns;
- /******/ };
- /******/
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = function(module) {
- /******/ var getter = module && module.__esModule ?
- /******/ function getDefault() { return module['default']; } :
- /******/ function getModuleExports() { return module; };
- /******/ __webpack_require__.d(getter, 'a', getter);
- /******/ return getter;
- /******/ };
- /******/
- /******/ // Object.prototype.hasOwnProperty.call
- /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
- /******/
- /******/ // __webpack_public_path__
- /******/ __webpack_require__.p = "/dist/";
- /******/
- /******/
- /******/ // Load entry module and return exports
- /******/ return __webpack_require__(__webpack_require__.s = 78);
- /******/ })
- /************************************************************************/
- /******/ ({
- /***/ 0:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
- /* globals __VUE_SSR_CONTEXT__ */
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
- // This module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle.
- function normalizeComponent (
- scriptExports,
- render,
- staticRenderFns,
- functionalTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier, /* server only */
- shadowMode /* vue-cli only */
- ) {
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
- // render functions
- if (render) {
- options.render = render
- options.staticRenderFns = staticRenderFns
- options._compiled = true
- }
- // functional template
- if (functionalTemplate) {
- options.functional = true
- }
- // scopedId
- if (scopeId) {
- options._scopeId = 'data-v-' + scopeId
- }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context =
- context || // cached call
- (this.$vnode && this.$vnode.ssrContext) || // stateful
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
- }
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
- }
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
- }
- }
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = shadowMode
- ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }
- : injectStyles
- }
- if (hook) {
- if (options.functional) {
- // for template-only hot-reload because in that case the render fn doesn't
- // go through the normalizer
- options._injectStyles = hook
- // register for functioal component in vue file
- var originalRender = options.render
- options.render = function renderWithStyleInjection (h, context) {
- hook.call(context)
- return originalRender(h, context)
- }
- } else {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
- }
- return {
- exports: scriptExports,
- options: options
- }
- }
- /***/ }),
- /***/ 2:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(6);
- /***/ }),
- /***/ 3:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(4);
- /***/ }),
- /***/ 5:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(12);
- /***/ }),
- /***/ 7:
- /***/ (function(module, exports) {
- module.exports = __webpack_require__(0);
- /***/ }),
- /***/ 78:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/popover/src/main.vue?vue&type=template&id=52060272&
- var render = function() {
- var _vm = this
- var _h = _vm.$createElement
- var _c = _vm._self._c || _h
- return _c(
- "span",
- [
- _c(
- "transition",
- {
- attrs: { name: _vm.transition },
- on: {
- "after-enter": _vm.handleAfterEnter,
- "after-leave": _vm.handleAfterLeave
- }
- },
- [
- _c(
- "div",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: !_vm.disabled && _vm.showPopper,
- expression: "!disabled && showPopper"
- }
- ],
- ref: "popper",
- staticClass: "el-popover el-popper",
- class: [_vm.popperClass, _vm.content && "el-popover--plain"],
- style: { width: _vm.width + "px" },
- attrs: {
- role: "tooltip",
- id: _vm.tooltipId,
- "aria-hidden":
- _vm.disabled || !_vm.showPopper ? "true" : "false"
- }
- },
- [
- _vm.title
- ? _c("div", {
- staticClass: "el-popover__title",
- domProps: { textContent: _vm._s(_vm.title) }
- })
- : _vm._e(),
- _vm._t("default", [_vm._v(_vm._s(_vm.content))])
- ],
- 2
- )
- ]
- ),
- _c(
- "span",
- { ref: "wrapper", staticClass: "el-popover__reference-wrapper" },
- [_vm._t("reference")],
- 2
- )
- ],
- 1
- )
- }
- var staticRenderFns = []
- render._withStripped = true
- // CONCATENATED MODULE: ./packages/popover/src/main.vue?vue&type=template&id=52060272&
- // EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper"
- var vue_popper_ = __webpack_require__(5);
- var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/dom"
- var dom_ = __webpack_require__(2);
- // EXTERNAL MODULE: external "element-ui/lib/utils/util"
- var util_ = __webpack_require__(3);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/popover/src/main.vue?vue&type=script&lang=js&
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- /* harmony default export */ var mainvue_type_script_lang_js_ = ({
- name: 'ElPopover',
- mixins: [vue_popper_default.a],
- props: {
- trigger: {
- type: String,
- default: 'click',
- validator: function validator(value) {
- return ['click', 'focus', 'hover', 'manual'].indexOf(value) > -1;
- }
- },
- openDelay: {
- type: Number,
- default: 0
- },
- closeDelay: {
- type: Number,
- default: 200
- },
- title: String,
- disabled: Boolean,
- content: String,
- reference: {},
- popperClass: String,
- width: {},
- visibleArrow: {
- default: true
- },
- arrowOffset: {
- type: Number,
- default: 0
- },
- transition: {
- type: String,
- default: 'fade-in-linear'
- },
- tabindex: {
- type: Number,
- default: 0
- }
- },
- computed: {
- tooltipId: function tooltipId() {
- return 'el-popover-' + Object(util_["generateId"])();
- }
- },
- watch: {
- showPopper: function showPopper(val) {
- if (this.disabled) {
- return;
- }
- val ? this.$emit('show') : this.$emit('hide');
- }
- },
- mounted: function mounted() {
- var _this = this;
- var reference = this.referenceElm = this.reference || this.$refs.reference;
- var popper = this.popper || this.$refs.popper;
- if (!reference && this.$refs.wrapper.children) {
- reference = this.referenceElm = this.$refs.wrapper.children[0];
- }
- // 可访问性
- if (reference) {
- Object(dom_["addClass"])(reference, 'el-popover__reference');
- reference.setAttribute('aria-describedby', this.tooltipId);
- reference.setAttribute('tabindex', this.tabindex); // tab序列
- popper.setAttribute('tabindex', 0);
- if (this.trigger !== 'click') {
- Object(dom_["on"])(reference, 'focusin', function () {
- _this.handleFocus();
- var instance = reference.__vue__;
- if (instance && typeof instance.focus === 'function') {
- instance.focus();
- }
- });
- Object(dom_["on"])(popper, 'focusin', this.handleFocus);
- Object(dom_["on"])(reference, 'focusout', this.handleBlur);
- Object(dom_["on"])(popper, 'focusout', this.handleBlur);
- }
- Object(dom_["on"])(reference, 'keydown', this.handleKeydown);
- Object(dom_["on"])(reference, 'click', this.handleClick);
- }
- if (this.trigger === 'click') {
- Object(dom_["on"])(reference, 'click', this.doToggle);
- Object(dom_["on"])(document, 'click', this.handleDocumentClick);
- } else if (this.trigger === 'hover') {
- Object(dom_["on"])(reference, 'mouseenter', this.handleMouseEnter);
- Object(dom_["on"])(popper, 'mouseenter', this.handleMouseEnter);
- Object(dom_["on"])(reference, 'mouseleave', this.handleMouseLeave);
- Object(dom_["on"])(popper, 'mouseleave', this.handleMouseLeave);
- } else if (this.trigger === 'focus') {
- if (this.tabindex < 0) {
- console.warn('[Element Warn][Popover]a negative taindex means that the element cannot be focused by tab key');
- }
- if (reference.querySelector('input, textarea')) {
- Object(dom_["on"])(reference, 'focusin', this.doShow);
- Object(dom_["on"])(reference, 'focusout', this.doClose);
- } else {
- Object(dom_["on"])(reference, 'mousedown', this.doShow);
- Object(dom_["on"])(reference, 'mouseup', this.doClose);
- }
- }
- },
- beforeDestroy: function beforeDestroy() {
- this.cleanup();
- },
- deactivated: function deactivated() {
- this.cleanup();
- },
- methods: {
- doToggle: function doToggle() {
- this.showPopper = !this.showPopper;
- },
- doShow: function doShow() {
- this.showPopper = true;
- },
- doClose: function doClose() {
- this.showPopper = false;
- },
- handleFocus: function handleFocus() {
- Object(dom_["addClass"])(this.referenceElm, 'focusing');
- if (this.trigger === 'click' || this.trigger === 'focus') this.showPopper = true;
- },
- handleClick: function handleClick() {
- Object(dom_["removeClass"])(this.referenceElm, 'focusing');
- },
- handleBlur: function handleBlur() {
- Object(dom_["removeClass"])(this.referenceElm, 'focusing');
- if (this.trigger === 'click' || this.trigger === 'focus') this.showPopper = false;
- },
- handleMouseEnter: function handleMouseEnter() {
- var _this2 = this;
- clearTimeout(this._timer);
- if (this.openDelay) {
- this._timer = setTimeout(function () {
- _this2.showPopper = true;
- }, this.openDelay);
- } else {
- this.showPopper = true;
- }
- },
- handleKeydown: function handleKeydown(ev) {
- if (ev.keyCode === 27 && this.trigger !== 'manual') {
- // esc
- this.doClose();
- }
- },
- handleMouseLeave: function handleMouseLeave() {
- var _this3 = this;
- clearTimeout(this._timer);
- if (this.closeDelay) {
- this._timer = setTimeout(function () {
- _this3.showPopper = false;
- }, this.closeDelay);
- } else {
- this.showPopper = false;
- }
- },
- handleDocumentClick: function handleDocumentClick(e) {
- var reference = this.reference || this.$refs.reference;
- var popper = this.popper || this.$refs.popper;
- if (!reference && this.$refs.wrapper.children) {
- reference = this.referenceElm = this.$refs.wrapper.children[0];
- }
- if (!this.$el || !reference || this.$el.contains(e.target) || reference.contains(e.target) || !popper || popper.contains(e.target)) return;
- this.showPopper = false;
- },
- handleAfterEnter: function handleAfterEnter() {
- this.$emit('after-enter');
- },
- handleAfterLeave: function handleAfterLeave() {
- this.$emit('after-leave');
- this.doDestroy();
- },
- cleanup: function cleanup() {
- if (this.openDelay || this.closeDelay) {
- clearTimeout(this._timer);
- }
- }
- },
- destroyed: function destroyed() {
- var reference = this.reference;
- Object(dom_["off"])(reference, 'click', this.doToggle);
- Object(dom_["off"])(reference, 'mouseup', this.doClose);
- Object(dom_["off"])(reference, 'mousedown', this.doShow);
- Object(dom_["off"])(reference, 'focusin', this.doShow);
- Object(dom_["off"])(reference, 'focusout', this.doClose);
- Object(dom_["off"])(reference, 'mousedown', this.doShow);
- Object(dom_["off"])(reference, 'mouseup', this.doClose);
- Object(dom_["off"])(reference, 'mouseleave', this.handleMouseLeave);
- Object(dom_["off"])(reference, 'mouseenter', this.handleMouseEnter);
- Object(dom_["off"])(document, 'click', this.handleDocumentClick);
- }
- });
- // CONCATENATED MODULE: ./packages/popover/src/main.vue?vue&type=script&lang=js&
- /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(0);
- // CONCATENATED MODULE: ./packages/popover/src/main.vue
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- src_mainvue_type_script_lang_js_,
- render,
- staticRenderFns,
- false,
- null,
- null,
- null
-
- )
- /* hot reload */
- if (false) { var api; }
- component.options.__file = "packages/popover/src/main.vue"
- /* harmony default export */ var main = (component.exports);
- // CONCATENATED MODULE: ./packages/popover/src/directive.js
- var getReference = function getReference(el, binding, vnode) {
- var _ref = binding.expression ? binding.value : binding.arg;
- var popper = vnode.context.$refs[_ref];
- if (popper) {
- if (Array.isArray(popper)) {
- popper[0].$refs.reference = el;
- } else {
- popper.$refs.reference = el;
- }
- }
- };
- /* harmony default export */ var directive = ({
- bind: function bind(el, binding, vnode) {
- getReference(el, binding, vnode);
- },
- inserted: function inserted(el, binding, vnode) {
- getReference(el, binding, vnode);
- }
- });
- // EXTERNAL MODULE: external "vue"
- var external_vue_ = __webpack_require__(7);
- var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_);
- // CONCATENATED MODULE: ./packages/popover/index.js
- external_vue_default.a.directive('popover', directive);
- /* istanbul ignore next */
- main.install = function (Vue) {
- Vue.directive('popover', directive);
- Vue.component(main.name, main);
- };
- main.directive = directive;
- /* harmony default export */ var popover = __webpack_exports__["default"] = (main);
- /***/ })
- /******/ });
- /***/ }),
- /* 85 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony import */ var _plugins_AES_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(32);
- /* harmony default export */ __webpack_exports__["default"] = (function ({
- route,
- redirect
- }) {
- const {
- query
- } = route;
- const str = _plugins_AES_js__WEBPACK_IMPORTED_MODULE_0__[/* default */ "a"].decrypt(query.email);
- const parts = str.split("&t=");
- if (parts.length === 2) {
- const timestamp = parseInt(parts[1]);
- const currentTime = new Date().getTime();
- const differenceInHours = (currentTime - timestamp) / (1000 * 60 * 60);
- if (differenceInHours > 3) {
- return redirect("/404"); // 跳转到 404 页面
- }
- } else {
- return redirect("/404"); // 跳转到 404 页面
- }
- });
- /***/ }),
- /* 86 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony default export */ __webpack_exports__["default"] = (function ({
- route,
- redirect
- }) {
- const {
- path
- } = route;
- const parts = path.split('/').filter(Boolean);
- // 如果路径以 /index.php/products/ 开头
- if (path.startsWith('/index.php/products/')) {
- // 获取除去 /index.php/products/ 后的部分
- const newPath = path.replace('/index.php/products/', '/category/');
- return redirect(newPath);
- }
- // 如果路径以 /product/ 开头且包含多于两个部分(除了 /product/ 本身外还有分类部分)
- if (path.startsWith('/product/') && parts.length > 2) {
- // 获取最后一个部分,即产品代码
- const code = parts.pop();
- return redirect(`/product/${code}`);
- }
- if (path.startsWith('/products') && route.query.keyword) {
- const keyword = route.query.keyword;
- return redirect(`/category/searchResult?keyword=${keyword}`);
- }
- if (path === '/products' && route.query.feature === '54') {
- return redirect('/category?feature=54');
- }
- });
- /***/ }),
- /* 87 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__.p + "img/404.2021fd6.png";
- /***/ }),
- /* 88 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_error_vue_vue_type_style_index_0_id_27ad4528_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(45);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_error_vue_vue_type_style_index_0_id_27ad4528_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_error_vue_vue_type_style_index_0_id_27ad4528_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__);
- /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_error_vue_vue_type_style_index_0_id_27ad4528_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__) if(["default"].indexOf(__WEBPACK_IMPORT_KEY__) < 0) (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_error_vue_vue_type_style_index_0_id_27ad4528_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__));
- /***/ }),
- /* 89 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 90 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 91 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 92 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 93 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 94 */
- /***/ (function(module, exports) {
- // Exports
- module.exports = {
- };
- /***/ }),
- /* 95 */
- /***/ (function(module, exports) {
- module.exports = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAATCAYAAACQjC21AAAAAXNSR0IArs4c6QAAAstJREFUOE+VlEloFEEUhv+/JmOIBlymO91ZxKR78CIqgnoR1EQQweBBFKO4IAxBDyoevAieBK+KXkQCObgkQfEgLicTF7yoICJeJD0zEo3d0zNBcUMnU09mcGIWJ0vdqt5fX71X9f4i/j+irh3bC6gOAOsAGH9lWQAvAN3r+bkeAPnJ2zl5wak31kJwlQIX4F0AAyL6Y1FHqkYArYC0C+GBOJD8lH05njEB6FixLaC6Q8hzapUYzGS8/xUQr6tzRekuAddD9I5kkHtY1o0Bm+1FzUqqXpHs9/xwD4DRCtdRXq5ybbNPRNo0R9ek/c/pUhXlqGuZtwGs/BmJrh4eHv4xA6wUbmhomF9TyL8G8MYLwp1jwGXWwpYI53kQ2Z8MsjdmAytrHMvYB/JaQX6774MvqVKGrmUeF+Kc8sPYIPBrLsA4UK1tM0fRp70gd/Ev0LgCcIUXhBvmAht3Xc8AeesF2U4uNYyGaBX6CS6HYFAoJ5N+9t5swI5tbKfwPIi4QN7lR9FG1zb6IWzSos8qpdoB7PiV1/EPuVyp9yqNplissTqqBgHc0VrfVVRnQPlAxzIKIBNJP+y2LCyopflNo7A75Y/cmg7YYi/ZpRC5+U3C2iDAd8c2D0Oki65tCkT2ekG2t9hGrm3qcfOKTNcyOkD2eH6oAEh5XgRkIOjzgvBYi2luVBE8LkBa03720XQZNtvG5gg4oAvYlArDJ65lXgLRQdcyOkFeBmQIgnoBB5JBuK146gwPo1zbvA+RNhABwEaIHCm1jWPH1hFo1VDplB8WHTOT7f7ZzzKfCrGKmlu9TObZlN+mUlaOYSwnqb0wLL4smoCaasu4IGQCWg4mM9nrE7w8XXmuHTsEqO6iRms5RUKDOEEwVhAk0kHYN+W3mQ7oWMZ1kvvGNIKvgPQir896IyND4/fOqmS3bvEGsOq2AJqijzKTe1DJ838A3AUiFwr8mOUAAAAASUVORK5CYII="
- /***/ }),
- /* 96 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcHeader_vue_vue_type_style_index_0_id_7da31f58_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(46);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcHeader_vue_vue_type_style_index_0_id_7da31f58_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcHeader_vue_vue_type_style_index_0_id_7da31f58_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__);
- /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcHeader_vue_vue_type_style_index_0_id_7da31f58_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__) if(["default"].indexOf(__WEBPACK_IMPORT_KEY__) < 0) (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcHeader_vue_vue_type_style_index_0_id_7da31f58_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__));
- /***/ }),
- /* 97 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__.p + "img/Floating.4aa4b8e.png";
- /***/ }),
- /* 98 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__.p + "img/msg_right.9e8d2b4.png";
- /***/ }),
- /* 99 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__.p + "img/msg_error.9a98ae7.png";
- /***/ }),
- /* 100 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_DIalogXXSuccess_vue_vue_type_style_index_0_id_5bfd8b9e_prod_lang_scss__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(47);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_DIalogXXSuccess_vue_vue_type_style_index_0_id_5bfd8b9e_prod_lang_scss__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_DIalogXXSuccess_vue_vue_type_style_index_0_id_5bfd8b9e_prod_lang_scss__WEBPACK_IMPORTED_MODULE_0__);
- /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_DIalogXXSuccess_vue_vue_type_style_index_0_id_5bfd8b9e_prod_lang_scss__WEBPACK_IMPORTED_MODULE_0__) if(["default"].indexOf(__WEBPACK_IMPORT_KEY__) < 0) (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_DIalogXXSuccess_vue_vue_type_style_index_0_id_5bfd8b9e_prod_lang_scss__WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__));
- /***/ }),
- /* 101 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcFooter_vue_vue_type_style_index_0_id_657ebcee_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(48);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcFooter_vue_vue_type_style_index_0_id_657ebcee_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcFooter_vue_vue_type_style_index_0_id_657ebcee_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__);
- /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcFooter_vue_vue_type_style_index_0_id_657ebcee_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__) if(["default"].indexOf(__WEBPACK_IMPORT_KEY__) < 0) (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcFooter_vue_vue_type_style_index_0_id_657ebcee_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__));
- /***/ }),
- /* 102 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_product_builder_layout_vue_vue_type_style_index_0_id_6c4e98e6_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(49);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_product_builder_layout_vue_vue_type_style_index_0_id_6c4e98e6_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_product_builder_layout_vue_vue_type_style_index_0_id_6c4e98e6_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__);
- /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_product_builder_layout_vue_vue_type_style_index_0_id_6c4e98e6_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__) if(["default"].indexOf(__WEBPACK_IMPORT_KEY__) < 0) (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_product_builder_layout_vue_vue_type_style_index_0_id_6c4e98e6_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__));
- /***/ }),
- /* 103 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcHeaderLite_vue_vue_type_style_index_0_id_47b2d662_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(50);
- /* harmony import */ var _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcHeaderLite_vue_vue_type_style_index_0_id_47b2d662_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcHeaderLite_vue_vue_type_style_index_0_id_47b2d662_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__);
- /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcHeaderLite_vue_vue_type_style_index_0_id_47b2d662_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__) if(["default"].indexOf(__WEBPACK_IMPORT_KEY__) < 0) (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_css_loader_dist_cjs_js_ref_7_oneOf_1_0_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_dist_cjs_js_ref_7_oneOf_1_1_node_modules_sass_loader_dist_cjs_js_ref_7_oneOf_1_2_node_modules_nuxt_components_dist_loader_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_PcHeaderLite_vue_vue_type_style_index_0_id_47b2d662_prod_lang_scss_scoped_true__WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__));
- /***/ }),
- /* 104 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "state", function() { return state; });
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "mutations", function() { return mutations; });
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "actions", function() { return actions; });
- const state = () => ({
- token: '',
- // email: "",
- userInfo: {},
- dialogVisible: false,
- compareList: [],
- jumpList: 'contact',
- shopInfo: {}
- });
- const mutations = {
- setToken(state, token) {
- state.token = token;
- this.$cookies.set('shop-token', token, {
- maxAge: 2592000,
- path: '/'
- });
- },
- getToken(state) {
- state.token = this.$cookies.get('shop-token');
- },
- setUserInfo(state, data) {
- state.userInfo = data;
- // state.email = data.email;
- this.$cookies.set('shop-user-info', data, {
- maxAge: 2592000,
- path: '/'
- });
- },
- clearUserInfo(state) {
- state.userInfo = {};
- // state.email = "";
- state.token = '';
- this.$cookies.remove('shop-token');
- this.$cookies.remove('shop-user-info');
- },
- openDialog(state) {
- state.dialogVisible = true;
- },
- closeDialog(state) {
- state.dialogVisible = false;
- },
- setCompareList(state, data) {
- state.compareList = data;
- },
- clearCompareList(state) {
- state.compareList = [];
- },
- setShopInfo(state, data) {
- state.shopInfo = data;
- }
- };
- const actions = {
- getShopInfo(ctx, data) {
- return new Promise((resolve, reject) => {
- if (ctx.state.shopInfo && !ctx.state.shopInfo.id) {
- this.$axios.post(`/c-api/logo/info/${encodeURIComponent(location.hostname
- // 'kkburwoodvicg.promocatalogue.com.au'
- )}`).then(res => {
- ctx.commit('setShopInfo', res.result);
- resolve(res.result);
- }).catch(e => {
- console.log(e);
- reject(e);
- });
- } else {
- resolve(ctx.state.shopInfo);
- }
- });
- },
- login({
- commit,
- dispatch
- }, data) {
- return new Promise((resolve, reject) => {
- if (data) {
- this.$axios({
- url: '/au/login',
- method: 'POST',
- data
- }).then(res => {
- commit('setToken', res.result.token);
- dispatch('getUserInfo');
- resolve(res);
- });
- }
- }).catch(() => {
- // reject(error);
- });
- },
- getUserInfo({
- commit,
- dispatch
- }) {
- return new Promise((resolve, reject) => {
- this.$axios({
- url: 'au/member/detail',
- method: 'GET'
- }).then(res => {
- commit('setUserInfo', res.result);
- resolve(res);
- if (location.pathname.includes('contact')) {
- location.href = location.origin;
- }
- });
- }).catch(() => {
- // reject(error);
- });
- },
- getCompareList({
- commit,
- dispatch
- }) {
- return new Promise((resolve, reject) => {
- this.$axios.post('home/compare_list', {
- compare_keys: 'keys'
- }).then(res => {
- commit('setCompareList', res.result);
- resolve(res);
- });
- }).catch(() => {
- // reject(error);
- });
- },
- logout({
- commit,
- dispatch
- }) {
- return new Promise((resolve, reject) => {
- // 未有退出登录接口
- commit('clearUserInfo');
- resolve();
- }).catch(() => {
- // reject(error);
- });
- }
- };
- /***/ }),
- /* 105 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "state", function() { return state; });
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "mutations", function() { return mutations; });
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "actions", function() { return actions; });
- const state = () => ({
- configInfo: {}
- });
- const mutations = {
- setConfigInfo(state, configInfo) {
- state.configInfo = configInfo;
- this.$cookies.set("config-info", configInfo, {
- maxAge: 2592000,
- path: '/'
- });
- },
- getConfigInfo(state) {
- state.configInfo = this.$cookies.get("config-info");
- }
- };
- const actions = {};
- /***/ }),
- /* 106 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- __webpack_require__.r(__webpack_exports__);
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "state", function() { return state; });
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "mutations", function() { return mutations; });
- const state = () => ({
- loading: false,
- smImgUlIdx: 0
- });
- const mutations = {
- setLoading(state, data) {
- state.loading = data;
- },
- setSmImgUlIdx(state, data) {
- state.smImgUlIdx = data;
- }
- };
- /***/ }),
- /* 107 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- // ESM COMPAT FLAG
- __webpack_require__.r(__webpack_exports__);
- // NAMESPACE OBJECT: ./.nuxt/components/index.js
- var components_namespaceObject = {};
- __webpack_require__.r(components_namespaceObject);
- __webpack_require__.d(components_namespaceObject, "Breadcrumb", function() { return Breadcrumb; });
- __webpack_require__.d(components_namespaceObject, "Bxh", function() { return Bxh; });
- __webpack_require__.d(components_namespaceObject, "Card", function() { return Card; });
- __webpack_require__.d(components_namespaceObject, "Carousel", function() { return Carousel; });
- __webpack_require__.d(components_namespaceObject, "CategoryFilter", function() { return CategoryFilter; });
- __webpack_require__.d(components_namespaceObject, "CategoryNoData", function() { return CategoryNoData; });
- __webpack_require__.d(components_namespaceObject, "DIalogXXSuccess", function() { return DIalogXXSuccess; });
- __webpack_require__.d(components_namespaceObject, "DesignFormDialog", function() { return DesignFormDialog; });
- __webpack_require__.d(components_namespaceObject, "DownloadDialog", function() { return DownloadDialog; });
- __webpack_require__.d(components_namespaceObject, "ExportDialog", function() { return ExportDialog; });
- __webpack_require__.d(components_namespaceObject, "FormDialog", function() { return FormDialog; });
- __webpack_require__.d(components_namespaceObject, "ImageUpload", function() { return ImageUpload; });
- __webpack_require__.d(components_namespaceObject, "Pagination", function() { return Pagination; });
- __webpack_require__.d(components_namespaceObject, "PcArticle", function() { return PcArticle; });
- __webpack_require__.d(components_namespaceObject, "PcFooter", function() { return PcFooter; });
- __webpack_require__.d(components_namespaceObject, "PcGlobalForm", function() { return PcGlobalForm; });
- __webpack_require__.d(components_namespaceObject, "PcHeader", function() { return PcHeader; });
- __webpack_require__.d(components_namespaceObject, "PcHeaderLite", function() { return PcHeaderLite; });
- __webpack_require__.d(components_namespaceObject, "PcSwitch", function() { return PcSwitch; });
- __webpack_require__.d(components_namespaceObject, "PcTitle", function() { return PcTitle; });
- __webpack_require__.d(components_namespaceObject, "PdfHtml", function() { return PdfHtml; });
- __webpack_require__.d(components_namespaceObject, "PriceToImg", function() { return PriceToImg; });
- __webpack_require__.d(components_namespaceObject, "Project", function() { return Project; });
- __webpack_require__.d(components_namespaceObject, "ProjectDialog", function() { return ProjectDialog; });
- __webpack_require__.d(components_namespaceObject, "ResetPasswordMail", function() { return ResetPasswordMail; });
- __webpack_require__.d(components_namespaceObject, "RowCard", function() { return RowCard; });
- __webpack_require__.d(components_namespaceObject, "SubNav", function() { return SubNav; });
- __webpack_require__.d(components_namespaceObject, "Subscription", function() { return Subscription; });
- __webpack_require__.d(components_namespaceObject, "TabNav", function() { return TabNav; });
- __webpack_require__.d(components_namespaceObject, "Zoom", function() { return Zoom; });
- __webpack_require__.d(components_namespaceObject, "AddAddressDialog", function() { return AddAddressDialog; });
- __webpack_require__.d(components_namespaceObject, "BookCard", function() { return BookCard; });
- __webpack_require__.d(components_namespaceObject, "ImageList", function() { return ImageList; });
- __webpack_require__.d(components_namespaceObject, "LoginDialog", function() { return LoginDialog; });
- __webpack_require__.d(components_namespaceObject, "ResetPasswordDialog", function() { return ResetPasswordDialog; });
- __webpack_require__.d(components_namespaceObject, "TinymceDynamicLoadScript", function() { return TinymceDynamicLoadScript; });
- __webpack_require__.d(components_namespaceObject, "Tinymce", function() { return Tinymce; });
- __webpack_require__.d(components_namespaceObject, "TinymcePlugins", function() { return TinymcePlugins; });
- __webpack_require__.d(components_namespaceObject, "TinymceToolbar", function() { return TinymceToolbar; });
- __webpack_require__.d(components_namespaceObject, "CustomElSliderButton", function() { return CustomElSliderButton; });
- __webpack_require__.d(components_namespaceObject, "CustomElSlider", function() { return CustomElSlider; });
- __webpack_require__.d(components_namespaceObject, "CustomElSliderMarker", function() { return CustomElSliderMarker; });
- __webpack_require__.d(components_namespaceObject, "ProductLeft", function() { return ProductLeft; });
- __webpack_require__.d(components_namespaceObject, "ProductRight", function() { return ProductRight; });
- __webpack_require__.d(components_namespaceObject, "ProductQuote", function() { return ProductQuote; });
- __webpack_require__.d(components_namespaceObject, "TableChangeTable", function() { return TableChangeTable; });
- __webpack_require__.d(components_namespaceObject, "TableMailTable", function() { return TableMailTable; });
- __webpack_require__.d(components_namespaceObject, "TableNewPriceTable", function() { return TableNewPriceTable; });
- __webpack_require__.d(components_namespaceObject, "TableStockTable", function() { return TableStockTable; });
- __webpack_require__.d(components_namespaceObject, "TableTotalTable", function() { return TableTotalTable; });
- __webpack_require__.d(components_namespaceObject, "TableUnitTable", function() { return TableUnitTable; });
- __webpack_require__.d(components_namespaceObject, "TableParamTable", function() { return TableParamTable; });
- __webpack_require__.d(components_namespaceObject, "ProductBuilderDialogSelectAddr", function() { return ProductBuilderDialogSelectAddr; });
- __webpack_require__.d(components_namespaceObject, "ProductBuilderStep1", function() { return ProductBuilderStep1; });
- __webpack_require__.d(components_namespaceObject, "ProductBuilderStep2", function() { return ProductBuilderStep2; });
- __webpack_require__.d(components_namespaceObject, "ProductBuilderStep3", function() { return ProductBuilderStep3; });
- __webpack_require__.d(components_namespaceObject, "ProductBuilderStepMixin", function() { return ProductBuilderStepMixin; });
- __webpack_require__.d(components_namespaceObject, "TinymceComponentsEditorImage", function() { return TinymceComponentsEditorImage; });
- // EXTERNAL MODULE: external "vue"
- var external_vue_ = __webpack_require__(0);
- var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_);
- // EXTERNAL MODULE: external "ufo"
- var external_ufo_ = __webpack_require__(3);
- // EXTERNAL MODULE: external "node-fetch-native"
- var external_node_fetch_native_ = __webpack_require__(51);
- var external_node_fetch_native_default = /*#__PURE__*/__webpack_require__.n(external_node_fetch_native_);
- // CONCATENATED MODULE: ./.nuxt/middleware.js
- const middleware = {};
- middleware['auth'] = __webpack_require__(111);
- middleware['auth'] = middleware['auth'].default || middleware['auth'];
- middleware['checkTimestamp'] = __webpack_require__(85);
- middleware['checkTimestamp'] = middleware['checkTimestamp'].default || middleware['checkTimestamp'];
- middleware['redirect'] = __webpack_require__(86);
- middleware['redirect'] = middleware['redirect'].default || middleware['redirect'];
- /* harmony default export */ var _nuxt_middleware = (middleware);
- // CONCATENATED MODULE: ./.nuxt/utils.js
- // window.{{globals.loadedCallback}} hook
- // Useful for jsdom testing or plugins (https://github.com/tmpvar/jsdom#dealing-with-asynchronous-script-loading)
- if (false) {}
- function createGetCounter(counterObject, defaultKey = '') {
- return function getCounter(id = defaultKey) {
- if (counterObject[id] === undefined) {
- counterObject[id] = 0;
- }
- return counterObject[id]++;
- };
- }
- function empty() {}
- function globalHandleError(error) {
- if (external_vue_default.a.config.errorHandler) {
- external_vue_default.a.config.errorHandler(error);
- }
- }
- function interopDefault(promise) {
- return promise.then(m => m.default || m);
- }
- function hasFetch(vm) {
- return vm.$options && typeof vm.$options.fetch === 'function' && !vm.$options.fetch.length;
- }
- function purifyData(data) {
- if (true) {
- return data;
- }
- return Object.entries(data).filter(([key, value]) => {
- const valid = !(value instanceof Function) && !(value instanceof Promise);
- if (!valid) {
- console.warn(`${key} is not able to be stringified. This will break in a production environment.`);
- }
- return valid;
- }).reduce((obj, [key, value]) => {
- obj[key] = value;
- return obj;
- }, {});
- }
- function getChildrenComponentInstancesUsingFetch(vm, instances = []) {
- const children = vm.$children || [];
- for (const child of children) {
- if (child.$fetch) {
- instances.push(child);
- }
- if (child.$children) {
- getChildrenComponentInstancesUsingFetch(child, instances);
- }
- }
- return instances;
- }
- function applyAsyncData(Component, asyncData) {
- if (
- // For SSR, we once all this function without second param to just apply asyncData
- // Prevent doing this for each SSR request
- !asyncData && Component.options.__hasNuxtData) {
- return;
- }
- const ComponentData = Component.options._originDataFn || Component.options.data || function () {
- return {};
- };
- Component.options._originDataFn = ComponentData;
- Component.options.data = function () {
- const data = ComponentData.call(this, this);
- if (this.$ssrContext) {
- asyncData = this.$ssrContext.asyncData[Component.cid];
- }
- return {
- ...data,
- ...asyncData
- };
- };
- Component.options.__hasNuxtData = true;
- if (Component._Ctor && Component._Ctor.options) {
- Component._Ctor.options.data = Component.options.data;
- }
- }
- function sanitizeComponent(Component) {
- // If Component already sanitized
- if (Component.options && Component._Ctor === Component) {
- return Component;
- }
- if (!Component.options) {
- Component = external_vue_default.a.extend(Component); // fix issue #6
- Component._Ctor = Component;
- } else {
- Component._Ctor = Component;
- Component.extendOptions = Component.options;
- }
- // If no component name defined, set file path as name, (also fixes #5703)
- if (!Component.options.name && Component.options.__file) {
- Component.options.name = Component.options.__file;
- }
- return Component;
- }
- function getMatchedComponents(route, matches = false, prop = 'components') {
- return Array.prototype.concat.apply([], route.matched.map((m, index) => {
- return Object.keys(m[prop]).map(key => {
- matches && matches.push(index);
- return m[prop][key];
- });
- }));
- }
- function getMatchedComponentsInstances(route, matches = false) {
- return getMatchedComponents(route, matches, 'instances');
- }
- function flatMapComponents(route, fn) {
- return Array.prototype.concat.apply([], route.matched.map((m, index) => {
- return Object.keys(m.components).reduce((promises, key) => {
- if (m.components[key]) {
- promises.push(fn(m.components[key], m.instances[key], m, key, index));
- } else {
- delete m.components[key];
- }
- return promises;
- }, []);
- }));
- }
- function resolveRouteComponents(route, fn) {
- return Promise.all(flatMapComponents(route, async (Component, instance, match, key) => {
- // If component is a function, resolve it
- if (typeof Component === 'function' && !Component.options) {
- try {
- Component = await Component();
- } catch (error) {
- // Handle webpack chunk loading errors
- // This may be due to a new deployment or a network problem
- if (error && error.name === 'ChunkLoadError' && typeof window !== 'undefined' && window.sessionStorage) {
- const timeNow = Date.now();
- try {
- const previousReloadTime = parseInt(window.sessionStorage.getItem('nuxt-reload'));
- // check for previous reload time not to reload infinitely
- if (!previousReloadTime || previousReloadTime + 60000 < timeNow) {
- window.sessionStorage.setItem('nuxt-reload', timeNow);
- window.location.reload(true /* skip cache */);
- }
- } catch {
- // don't throw an error if we have issues reading sessionStorage
- }
- }
- throw error;
- }
- }
- match.components[key] = Component = sanitizeComponent(Component);
- return typeof fn === 'function' ? fn(Component, instance, match, key) : Component;
- }));
- }
- async function getRouteData(route) {
- if (!route) {
- return;
- }
- // Make sure the components are resolved (code-splitting)
- await resolveRouteComponents(route);
- // Send back a copy of route with meta based on Component definition
- return {
- ...route,
- meta: getMatchedComponents(route).map((Component, index) => {
- return {
- ...Component.options.meta,
- ...(route.matched[index] || {}).meta
- };
- })
- };
- }
- async function setContext(app, context) {
- // If context not defined, create it
- if (!app.context) {
- app.context = {
- isStatic: false,
- isDev: false,
- isHMR: false,
- app,
- store: app.store,
- payload: context.payload,
- error: context.error,
- base: app.router.options.base,
- env: {}
- };
- // Only set once
- if (context.req) {
- app.context.req = context.req;
- }
- if (context.res) {
- app.context.res = context.res;
- }
- if (context.ssrContext) {
- app.context.ssrContext = context.ssrContext;
- }
- app.context.redirect = (status, path, query) => {
- if (!status) {
- return;
- }
- app.context._redirected = true;
- // if only 1 or 2 arguments: redirect('/') or redirect('/', { foo: 'bar' })
- let pathType = typeof path;
- if (typeof status !== 'number' && (pathType === 'undefined' || pathType === 'object')) {
- query = path || {};
- path = status;
- pathType = typeof path;
- status = 302;
- }
- if (pathType === 'object') {
- path = app.router.resolve(path).route.fullPath;
- }
- // "/absolute/route", "./relative/route" or "../relative/route"
- if (/(^[.]{1,2}\/)|(^\/(?!\/))/.test(path)) {
- app.context.next({
- path,
- query,
- status
- });
- } else {
- path = Object(external_ufo_["withQuery"])(path, query);
- if (true) {
- app.context.next({
- path,
- status
- });
- }
- if (false) {}
- }
- };
- if (true) {
- app.context.beforeNuxtRender = fn => context.beforeRenderFns.push(fn);
- app.context.beforeSerialize = fn => context.beforeSerializeFns.push(fn);
- }
- if (false) {}
- }
- // Dynamic keys
- const [currentRouteData, fromRouteData] = await Promise.all([getRouteData(context.route), getRouteData(context.from)]);
- if (context.route) {
- app.context.route = currentRouteData;
- }
- if (context.from) {
- app.context.from = fromRouteData;
- }
- if (context.error) {
- app.context.error = context.error;
- }
- app.context.next = context.next;
- app.context._redirected = false;
- app.context._errored = false;
- app.context.isHMR = false;
- app.context.params = app.context.route.params || {};
- app.context.query = app.context.route.query || {};
- }
- function middlewareSeries(promises, appContext, renderState) {
- if (!promises.length || appContext._redirected || appContext._errored || renderState && renderState.aborted) {
- return Promise.resolve();
- }
- return promisify(promises[0], appContext).then(() => {
- return middlewareSeries(promises.slice(1), appContext, renderState);
- });
- }
- function promisify(fn, context) {
- let promise;
- if (fn.length === 2) {
- // fn(context, callback)
- promise = new Promise(resolve => {
- fn(context, function (err, data) {
- if (err) {
- context.error(err);
- }
- data = data || {};
- resolve(data);
- });
- });
- } else {
- promise = fn(context);
- }
- if (promise && promise instanceof Promise && typeof promise.then === 'function') {
- return promise;
- }
- return Promise.resolve(promise);
- }
- // Imported from vue-router
- function getLocation(base, mode) {
- if (mode === 'hash') {
- return window.location.hash.replace(/^#\//, '');
- }
- base = decodeURI(base).slice(0, -1); // consideration is base is normalized with trailing slash
- let path = decodeURI(window.location.pathname);
- if (base && path.startsWith(base)) {
- path = path.slice(base.length);
- }
- const fullPath = (path || '/') + window.location.search + window.location.hash;
- return Object(external_ufo_["normalizeURL"])(fullPath);
- }
- // Imported from path-to-regexp
- /**
- * Compile a string to a template function for the path.
- *
- * @param {string} str
- * @param {Object=} options
- * @return {!function(Object=, Object=)}
- */
- function compile(str, options) {
- return tokensToFunction(parse(str, options), options);
- }
- function getQueryDiff(toQuery, fromQuery) {
- const diff = {};
- const queries = {
- ...toQuery,
- ...fromQuery
- };
- for (const k in queries) {
- if (String(toQuery[k]) !== String(fromQuery[k])) {
- diff[k] = true;
- }
- }
- return diff;
- }
- function normalizeError(err) {
- let message;
- if (!(err.message || typeof err === 'string')) {
- try {
- message = JSON.stringify(err, null, 2);
- } catch (e) {
- message = `[${err.constructor.name}]`;
- }
- } else {
- message = err.message || err;
- }
- return {
- ...err,
- message,
- statusCode: err.statusCode || err.status || err.response && err.response.status || 500
- };
- }
- /**
- * The main path matching regexp utility.
- *
- * @type {RegExp}
- */
- const PATH_REGEXP = new RegExp([
- // Match escaped characters that would otherwise appear in future matches.
- // This allows the user to escape special characters that won't transform.
- '(\\\\.)',
- // Match Express-style parameters and un-named parameters with a prefix
- // and optional suffixes. Matches appear as:
- //
- // "/:test(\\d+)?" => ["/", "test", "\d+", undefined, "?", undefined]
- // "/route(\\d+)" => [undefined, undefined, undefined, "\d+", undefined, undefined]
- // "/*" => ["/", undefined, undefined, undefined, undefined, "*"]
- '([\\/.])?(?:(?:\\:(\\w+)(?:\\(((?:\\\\.|[^\\\\()])+)\\))?|\\(((?:\\\\.|[^\\\\()])+)\\))([+*?])?|(\\*))'].join('|'), 'g');
- /**
- * Parse a string for the raw tokens.
- *
- * @param {string} str
- * @param {Object=} options
- * @return {!Array}
- */
- function parse(str, options) {
- const tokens = [];
- let key = 0;
- let index = 0;
- let path = '';
- const defaultDelimiter = options && options.delimiter || '/';
- let res;
- while ((res = PATH_REGEXP.exec(str)) != null) {
- const m = res[0];
- const escaped = res[1];
- const offset = res.index;
- path += str.slice(index, offset);
- index = offset + m.length;
- // Ignore already escaped sequences.
- if (escaped) {
- path += escaped[1];
- continue;
- }
- const next = str[index];
- const prefix = res[2];
- const name = res[3];
- const capture = res[4];
- const group = res[5];
- const modifier = res[6];
- const asterisk = res[7];
- // Push the current path onto the tokens.
- if (path) {
- tokens.push(path);
- path = '';
- }
- const partial = prefix != null && next != null && next !== prefix;
- const repeat = modifier === '+' || modifier === '*';
- const optional = modifier === '?' || modifier === '*';
- const delimiter = res[2] || defaultDelimiter;
- const pattern = capture || group;
- tokens.push({
- name: name || key++,
- prefix: prefix || '',
- delimiter,
- optional,
- repeat,
- partial,
- asterisk: Boolean(asterisk),
- pattern: pattern ? escapeGroup(pattern) : asterisk ? '.*' : '[^' + escapeString(delimiter) + ']+?'
- });
- }
- // Match any characters still remaining.
- if (index < str.length) {
- path += str.substr(index);
- }
- // If the path exists, push it onto the end.
- if (path) {
- tokens.push(path);
- }
- return tokens;
- }
- /**
- * Prettier encoding of URI path segments.
- *
- * @param {string}
- * @return {string}
- */
- function encodeURIComponentPretty(str, slashAllowed) {
- const re = slashAllowed ? /[?#]/g : /[/?#]/g;
- return encodeURI(str).replace(re, c => {
- return '%' + c.charCodeAt(0).toString(16).toUpperCase();
- });
- }
- /**
- * Encode the asterisk parameter. Similar to `pretty`, but allows slashes.
- *
- * @param {string}
- * @return {string}
- */
- function encodeAsterisk(str) {
- return encodeURIComponentPretty(str, true);
- }
- /**
- * Escape a regular expression string.
- *
- * @param {string} str
- * @return {string}
- */
- function escapeString(str) {
- return str.replace(/([.+*?=^!:${}()[\]|/\\])/g, '\\$1');
- }
- /**
- * Escape the capturing group by escaping special characters and meaning.
- *
- * @param {string} group
- * @return {string}
- */
- function escapeGroup(group) {
- return group.replace(/([=!:$/()])/g, '\\$1');
- }
- /**
- * Expose a method for transforming tokens into the path function.
- */
- function tokensToFunction(tokens, options) {
- // Compile all the tokens into regexps.
- const matches = new Array(tokens.length);
- // Compile all the patterns before compilation.
- for (let i = 0; i < tokens.length; i++) {
- if (typeof tokens[i] === 'object') {
- matches[i] = new RegExp('^(?:' + tokens[i].pattern + ')$', flags(options));
- }
- }
- return function (obj, opts) {
- let path = '';
- const data = obj || {};
- const options = opts || {};
- const encode = options.pretty ? encodeURIComponentPretty : encodeURIComponent;
- for (let i = 0; i < tokens.length; i++) {
- const token = tokens[i];
- if (typeof token === 'string') {
- path += token;
- continue;
- }
- const value = data[token.name || 'pathMatch'];
- let segment;
- if (value == null) {
- if (token.optional) {
- // Prepend partial segment prefixes.
- if (token.partial) {
- path += token.prefix;
- }
- continue;
- } else {
- throw new TypeError('Expected "' + token.name + '" to be defined');
- }
- }
- if (Array.isArray(value)) {
- if (!token.repeat) {
- throw new TypeError('Expected "' + token.name + '" to not repeat, but received `' + JSON.stringify(value) + '`');
- }
- if (value.length === 0) {
- if (token.optional) {
- continue;
- } else {
- throw new TypeError('Expected "' + token.name + '" to not be empty');
- }
- }
- for (let j = 0; j < value.length; j++) {
- segment = encode(value[j]);
- if (!matches[i].test(segment)) {
- throw new TypeError('Expected all "' + token.name + '" to match "' + token.pattern + '", but received `' + JSON.stringify(segment) + '`');
- }
- path += (j === 0 ? token.prefix : token.delimiter) + segment;
- }
- continue;
- }
- segment = token.asterisk ? encodeAsterisk(value) : encode(value);
- if (!matches[i].test(segment)) {
- throw new TypeError('Expected "' + token.name + '" to match "' + token.pattern + '", but received "' + segment + '"');
- }
- path += token.prefix + segment;
- }
- return path;
- };
- }
- /**
- * Get the flags for a regexp from the options.
- *
- * @param {Object} options
- * @return {string}
- */
- function flags(options) {
- return options && options.sensitive ? '' : 'i';
- }
- function addLifecycleHook(vm, hook, fn) {
- if (!vm.$options[hook]) {
- vm.$options[hook] = [];
- }
- if (!vm.$options[hook].includes(fn)) {
- vm.$options[hook].push(fn);
- }
- }
- const urlJoin = external_ufo_["joinURL"];
- const stripTrailingSlash = external_ufo_["withoutTrailingSlash"];
- const isSamePath = external_ufo_["isSamePath"];
- function setScrollRestoration(newVal) {
- try {
- window.history.scrollRestoration = newVal;
- } catch (e) {}
- }
- // CONCATENATED MODULE: ./.nuxt/mixins/fetch.server.js
- async function serverPrefetch() {
- if (!this._fetchOnServer) {
- return;
- }
- // Call and await on $fetch
- try {
- await this.$options.fetch.call(this);
- } catch (err) {
- if (false) {}
- this.$fetchState.error = normalizeError(err);
- }
- this.$fetchState.pending = false;
- // Define an ssrKey for hydration
- this._fetchKey = this._fetchKey || this.$ssrContext.fetchCounters['']++;
- // Add data-fetch-key on parent element of Component
- const attrs = this.$vnode.data.attrs = this.$vnode.data.attrs || {};
- attrs['data-fetch-key'] = this._fetchKey;
- // Add to ssrContext for window.__NUXT__.fetch
- this.$ssrContext.nuxt.fetch[this._fetchKey] = this.$fetchState.error ? {
- _error: this.$fetchState.error
- } : purifyData(this._data);
- }
- /* harmony default export */ var fetch_server = ({
- created() {
- if (!hasFetch(this)) {
- return;
- }
- if (typeof this.$options.fetchOnServer === 'function') {
- this._fetchOnServer = this.$options.fetchOnServer.call(this) !== false;
- } else {
- this._fetchOnServer = this.$options.fetchOnServer !== false;
- }
- const defaultKey = this.$options._scopeId || this.$options.name || '';
- const getCounter = createGetCounter(this.$ssrContext.fetchCounters, defaultKey);
- if (typeof this.$options.fetchKey === 'function') {
- this._fetchKey = this.$options.fetchKey.call(this, getCounter);
- } else {
- const key = 'string' === typeof this.$options.fetchKey ? this.$options.fetchKey : defaultKey;
- this._fetchKey = key ? key + ':' + getCounter(key) : String(getCounter(key));
- }
- // Added for remove vue undefined warning while ssr
- this.$fetch = () => {}; // issue #8043
- external_vue_default.a.util.defineReactive(this, '$fetchState', {
- pending: true,
- error: null,
- timestamp: Date.now()
- });
- addLifecycleHook(this, 'serverPrefetch', serverPrefetch);
- }
- });
- // EXTERNAL MODULE: external "vuex"
- var external_vuex_ = __webpack_require__(5);
- var external_vuex_default = /*#__PURE__*/__webpack_require__.n(external_vuex_);
- // EXTERNAL MODULE: external "vue-meta"
- var external_vue_meta_ = __webpack_require__(52);
- var external_vue_meta_default = /*#__PURE__*/__webpack_require__.n(external_vue_meta_);
- // EXTERNAL MODULE: external "vue-client-only"
- var external_vue_client_only_ = __webpack_require__(28);
- var external_vue_client_only_default = /*#__PURE__*/__webpack_require__.n(external_vue_client_only_);
- // EXTERNAL MODULE: external "vue-no-ssr"
- var external_vue_no_ssr_ = __webpack_require__(15);
- var external_vue_no_ssr_default = /*#__PURE__*/__webpack_require__.n(external_vue_no_ssr_);
- // EXTERNAL MODULE: external "vue-router"
- var external_vue_router_ = __webpack_require__(29);
- var external_vue_router_default = /*#__PURE__*/__webpack_require__.n(external_vue_router_);
- // CONCATENATED MODULE: ./.nuxt/router.scrollBehavior.js
- /* harmony default export */ var router_scrollBehavior = (function (to, from, savedPosition) {
- // if the returned position is falsy or an empty object,
- // will retain current scroll position.
- let position = false;
- // 自定义行为
- const reg = /\/category/;
- if (reg.test(to.path) && reg.test(from.path) || to.path !== from.path) {
- // 在5种分类页间跳转 或者 同组件路由跳转时, 重置滚动距离
- position = {
- x: 0,
- y: 0
- };
- } else if (savedPosition) {
- position = savedPosition;
- }
- if (to.hash) {
- let hash = to.hash;
- // CSS.escape() is not supported with IE and Edge.
- if (typeof window.CSS !== 'undefined' && typeof window.CSS.escape !== 'undefined') {
- hash = '#' + window.CSS.escape(hash.substr(1));
- }
- try {
- if (document.querySelector(hash)) {
- // scroll to anchor by returning the selector
- position = {
- selector: hash
- };
- } else {
- // 部分情况下, 点击带hash的路由链接跳转会没法正确识别到hash, 需要用这种方式处理.
- return new Promise(resolve => {
- window.$nuxt.$once('triggerScroll', () => {
- position = {
- selector: hash
- };
- resolve(position);
- });
- });
- }
- } catch (e) {
- console.warn('Failed to save scroll position. Please add CSS.escape() polyfill (https://github.com/mathiasbynens/CSS.escape).');
- }
- return position;
- } else {
- return position;
- }
- });
- // CONCATENATED MODULE: ./.nuxt/router.js
- const _1cf41b54 = () => interopDefault(__webpack_require__.e(/* import() | pages/aboutus */ 56).then(__webpack_require__.bind(null, 389)));
- const _4ddd03b0 = () => interopDefault(__webpack_require__.e(/* import() | pages/category/index */ 60).then(__webpack_require__.bind(null, 390)));
- const _19cd67db = () => interopDefault(__webpack_require__.e(/* import() | pages/product/index */ 91).then(__webpack_require__.bind(null, 391)));
- const _90f1bf80 = () => interopDefault(__webpack_require__.e(/* import() | pages/setNewPassword */ 93).then(__webpack_require__.bind(null, 392)));
- const _95931c7c = () => interopDefault(__webpack_require__.e(/* import() | pages/category/searchResult/index */ 61).then(__webpack_require__.bind(null, 393)));
- const _12feed5e = () => interopDefault(__webpack_require__.e(/* import() | pages/home/api */ 65).then(__webpack_require__.bind(null, 394)));
- const _ff71ae40 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/catalogue */ 66).then(__webpack_require__.bind(null, 395)));
- const _70c08a4c = () => interopDefault(__webpack_require__.e(/* import() | pages/home/compareList */ 67).then(__webpack_require__.bind(null, 396)));
- const _5341d8d7 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/contact */ 68).then(__webpack_require__.bind(null, 397)));
- const _5b236ce6 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/contactPromoCollection */ 69).then(__webpack_require__.bind(null, 398)));
- const _030cd4b5 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/contactus */ 70).then(__webpack_require__.bind(null, 399)));
- const _474a2543 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/currentFlyer/index */ 71).then(__webpack_require__.bind(null, 400)));
- const _be27f7d4 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/downloadCenter */ 72).then(__webpack_require__.bind(null, 401)));
- const _377e88de = () => interopDefault(__webpack_require__.e(/* import() | pages/home/EDMS */ 63).then(__webpack_require__.bind(null, 402)));
- const _09435696 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/FAQs */ 64).then(__webpack_require__.bind(null, 403)));
- const _13eca7f7 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/loyaltyProgram */ 73).then(__webpack_require__.bind(null, 404)));
- const _6da624f9 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/myDetail/index */ 76).then(__webpack_require__.bind(null, 405)));
- const _47a75472 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/newsLetter */ 78).then(__webpack_require__.bind(null, 406)));
- const _9349395e = () => interopDefault(__webpack_require__.e(/* import() | pages/home/privacyPolicy */ 79).then(__webpack_require__.bind(null, 407)));
- const _047a2fd3 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/projects */ 80).then(__webpack_require__.bind(null, 408)));
- const _23af22bc = () => interopDefault(__webpack_require__.e(/* import() | pages/home/refundReturns */ 81).then(__webpack_require__.bind(null, 409)));
- const _4305add6 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/termsConditions */ 82).then(__webpack_require__.bind(null, 410)));
- const _005dc11c = () => interopDefault(__webpack_require__.e(/* import() | pages/home/video */ 83).then(__webpack_require__.bind(null, 411)));
- const _e47041ca = () => interopDefault(__webpack_require__.e(/* import() | pages/home/myDetail/enquiryDetail */ 75).then(__webpack_require__.bind(null, 412)));
- const _93ac20b4 = () => interopDefault(__webpack_require__.e(/* import() | pages/home/myDetail/orderDetail */ 77).then(__webpack_require__.bind(null, 413)));
- const _06e0307c = () => interopDefault(__webpack_require__.e(/* import() | pages/home/myDetail/components/orderDetailPart */ 74).then(__webpack_require__.bind(null, 238)));
- const _30f015fb = () => interopDefault(__webpack_require__.e(/* import() | pages/index */ 84).then(__webpack_require__.bind(null, 414)));
- const _3c967843 = () => interopDefault(__webpack_require__.e(/* import() | pages/3D/_id */ 55).then(__webpack_require__.bind(null, 415)));
- const _d75f92a8 = () => interopDefault(__webpack_require__.e(/* import() | pages/category/_firstCategory/index */ 59).then(__webpack_require__.bind(null, 416)));
- const _28ca91e0 = () => interopDefault(__webpack_require__.e(/* import() | pages/design/_id */ 62).then(__webpack_require__.bind(null, 417)));
- const _071e3270 = () => interopDefault(__webpack_require__.e(/* import() | pages/news/_newsName */ 85).then(__webpack_require__.bind(null, 418)));
- const _967a32f4 = () => interopDefault(__webpack_require__.e(/* import() | pages/pdf/_id */ 87).then(__webpack_require__.bind(null, 419)));
- const _2124fbba = () => interopDefault(__webpack_require__.e(/* import() | pages/product-builder/_code */ 88).then(__webpack_require__.bind(null, 420)));
- const _4bc8c093 = () => interopDefault(__webpack_require__.e(/* import() | pages/product-record/_code */ 89).then(__webpack_require__.bind(null, 421)));
- const _1b9818d5 = () => interopDefault(__webpack_require__.e(/* import() | pages/product/_code */ 90).then(__webpack_require__.bind(null, 422)));
- const _c16a4230 = () => interopDefault(__webpack_require__.e(/* import() | pages/render/_id */ 92).then(__webpack_require__.bind(null, 423)));
- const _8091a464 = () => interopDefault(__webpack_require__.e(/* import() | pages/category/_firstCategory/_secondCategory/index */ 58).then(__webpack_require__.bind(null, 424)));
- const _3ed4993d = () => interopDefault(__webpack_require__.e(/* import() | pages/category/_firstCategory/_secondCategory/_thirdCategory/index */ 57).then(__webpack_require__.bind(null, 425)));
- const _3a1a2622 = () => interopDefault(__webpack_require__.e(/* import() | pages/orderShare/_uid/_aid/_id */ 86).then(__webpack_require__.bind(null, 426)));
- const emptyFn = () => {};
- external_vue_default.a.use(external_vue_router_default.a);
- const routerOptions = {
- mode: 'history',
- base: '/',
- linkActiveClass: 'nuxt-link-active',
- linkExactActiveClass: 'nuxt-link-exact-active',
- scrollBehavior: router_scrollBehavior,
- routes: [{
- path: "/aboutus",
- component: _1cf41b54,
- name: "aboutus"
- }, {
- path: "/category",
- component: _4ddd03b0,
- name: "category"
- }, {
- path: "/product",
- component: _19cd67db,
- name: "product"
- }, {
- path: "/setNewPassword",
- component: _90f1bf80,
- name: "setNewPassword"
- }, {
- path: "/category/searchResult",
- component: _95931c7c,
- name: "category-searchResult"
- }, {
- path: "/home/api",
- component: _12feed5e,
- name: "home-api"
- }, {
- path: "/home/catalogue",
- component: _ff71ae40,
- name: "home-catalogue"
- }, {
- path: "/home/compareList",
- component: _70c08a4c,
- name: "home-compareList"
- }, {
- path: "/home/contact",
- component: _5341d8d7,
- name: "home-contact"
- }, {
- path: "/home/contactPromoCollection",
- component: _5b236ce6,
- name: "home-contactPromoCollection"
- }, {
- path: "/home/contactus",
- component: _030cd4b5,
- name: "home-contactus"
- }, {
- path: "/home/currentFlyer",
- component: _474a2543,
- name: "home-currentFlyer"
- }, {
- path: "/home/downloadCenter",
- component: _be27f7d4,
- name: "home-downloadCenter"
- }, {
- path: "/home/EDMS",
- component: _377e88de,
- name: "home-EDMS"
- }, {
- path: "/home/FAQs",
- component: _09435696,
- name: "home-FAQs"
- }, {
- path: "/home/loyaltyProgram",
- component: _13eca7f7,
- name: "home-loyaltyProgram"
- }, {
- path: "/home/myDetail",
- component: _6da624f9,
- name: "home-myDetail"
- }, {
- path: "/home/newsLetter",
- component: _47a75472,
- name: "home-newsLetter"
- }, {
- path: "/home/privacyPolicy",
- component: _9349395e,
- name: "home-privacyPolicy"
- }, {
- path: "/home/projects",
- component: _047a2fd3,
- name: "home-projects"
- }, {
- path: "/home/refundReturns",
- component: _23af22bc,
- name: "home-refundReturns"
- }, {
- path: "/home/termsConditions",
- component: _4305add6,
- name: "home-termsConditions"
- }, {
- path: "/home/video",
- component: _005dc11c,
- name: "home-video"
- }, {
- path: "/home/myDetail/enquiryDetail",
- component: _e47041ca,
- name: "home-myDetail-enquiryDetail"
- }, {
- path: "/home/myDetail/orderDetail",
- component: _93ac20b4,
- name: "home-myDetail-orderDetail"
- }, {
- path: "/home/myDetail/components/orderDetailPart",
- component: _06e0307c,
- name: "home-myDetail-components-orderDetailPart"
- }, {
- path: "/",
- component: _30f015fb,
- name: "index"
- }, {
- path: "/3D/:id?",
- component: _3c967843,
- name: "3D-id"
- }, {
- path: "/category/:firstCategory",
- component: _d75f92a8,
- name: "category-firstCategory"
- }, {
- path: "/design/:id?",
- component: _28ca91e0,
- name: "design-id"
- }, {
- path: "/news/:newsName?",
- component: _071e3270,
- name: "news-newsName"
- }, {
- path: "/pdf/:id?",
- component: _967a32f4,
- name: "pdf-id"
- }, {
- path: "/product-builder/:code",
- component: _2124fbba,
- name: "product-builder-code"
- }, {
- path: "/product-record/:code",
- component: _4bc8c093,
- name: "product-record-code"
- }, {
- path: "/product/:code",
- component: _1b9818d5,
- name: "product-code"
- }, {
- path: "/render/:id?",
- component: _c16a4230,
- name: "render-id"
- }, {
- path: "/category/:firstCategory/:secondCategory",
- component: _8091a464,
- name: "category-firstCategory-secondCategory"
- }, {
- path: "/category/:firstCategory/:secondCategory/:thirdCategory",
- component: _3ed4993d,
- name: "category-firstCategory-secondCategory-thirdCategory"
- }, {
- path: "/orderShare/:uid?/:aid?/:id?",
- component: _3a1a2622,
- name: "orderShare-uid-aid-id"
- }],
- fallback: false
- };
- function createRouter(ssrContext, config) {
- const base = config._app && config._app.basePath || routerOptions.base;
- const router = new external_vue_router_default.a({
- ...routerOptions,
- base
- });
- // TODO: remove in Nuxt 3
- const originalPush = router.push;
- router.push = function push(location, onComplete = emptyFn, onAbort) {
- return originalPush.call(this, location, onComplete, onAbort);
- };
- const resolve = router.resolve.bind(router);
- router.resolve = (to, current, append) => {
- if (typeof to === 'string') {
- to = Object(external_ufo_["normalizeURL"])(to);
- }
- return resolve(to, current, append);
- };
- return router;
- }
- // CONCATENATED MODULE: ./.nuxt/components/nuxt-child.js
- /* harmony default export */ var nuxt_child = ({
- name: 'NuxtChild',
- functional: true,
- props: {
- nuxtChildKey: {
- type: String,
- default: ''
- },
- keepAlive: Boolean,
- keepAliveProps: {
- type: Object,
- default: undefined
- }
- },
- render(_, {
- parent,
- data,
- props
- }) {
- const h = parent.$createElement;
- data.nuxtChild = true;
- const _parent = parent;
- const transitions = parent.$nuxt.nuxt.transitions;
- const defaultTransition = parent.$nuxt.nuxt.defaultTransition;
- let depth = 0;
- while (parent) {
- if (parent.$vnode && parent.$vnode.data.nuxtChild) {
- depth++;
- }
- parent = parent.$parent;
- }
- data.nuxtChildDepth = depth;
- const transition = transitions[depth] || defaultTransition;
- const transitionProps = {};
- transitionsKeys.forEach(key => {
- if (typeof transition[key] !== 'undefined') {
- transitionProps[key] = transition[key];
- }
- });
- const listeners = {};
- listenersKeys.forEach(key => {
- if (typeof transition[key] === 'function') {
- listeners[key] = transition[key].bind(_parent);
- }
- });
- if (false) {}
- // make sure that leave is called asynchronous (fix #5703)
- if (transition.css === false) {
- const leave = listeners.leave;
- // only add leave listener when user didnt provide one
- // or when it misses the done argument
- if (!leave || leave.length < 2) {
- listeners.leave = (el, done) => {
- if (leave) {
- leave.call(_parent, el);
- }
- _parent.$nextTick(done);
- };
- }
- }
- let routerView = h('routerView', data);
- if (props.keepAlive) {
- routerView = h('keep-alive', {
- props: props.keepAliveProps
- }, [routerView]);
- }
- return h('transition', {
- props: transitionProps,
- on: listeners
- }, [routerView]);
- }
- });
- const transitionsKeys = ['name', 'mode', 'appear', 'css', 'type', 'duration', 'enterClass', 'leaveClass', 'appearClass', 'enterActiveClass', 'enterActiveClass', 'leaveActiveClass', 'appearActiveClass', 'enterToClass', 'leaveToClass', 'appearToClass'];
- const listenersKeys = ['beforeEnter', 'enter', 'afterEnter', 'enterCancelled', 'beforeLeave', 'leave', 'afterLeave', 'leaveCancelled', 'beforeAppear', 'appear', 'afterAppear', 'appearCancelled'];
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./layouts/error.vue?vue&type=template&id=27ad4528&scoped=true
- var render = function render() {
- var _vm = this,
- _c = _vm._self._c;
- return _c('img', {
- attrs: {
- "src": __webpack_require__(87),
- "alt": "404"
- }
- }, []);
- };
- var staticRenderFns = [];
- // CONCATENATED MODULE: ./layouts/error.vue?vue&type=template&id=27ad4528&scoped=true
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./layouts/error.vue?vue&type=script&lang=js
- /* harmony default export */ var errorvue_type_script_lang_js = ({
- layout: 'default'
- });
- // CONCATENATED MODULE: ./layouts/error.vue?vue&type=script&lang=js
- /* harmony default export */ var layouts_errorvue_type_script_lang_js = (errorvue_type_script_lang_js);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(2);
- // CONCATENATED MODULE: ./layouts/error.vue
- function injectStyles (context) {
-
- var style0 = __webpack_require__(88)
- if (style0.__inject__) style0.__inject__(context)
- }
- /* normalize component */
- var error_component = Object(componentNormalizer["a" /* default */])(
- layouts_errorvue_type_script_lang_js,
- render,
- staticRenderFns,
- false,
- injectStyles,
- "27ad4528",
- "5dccf557"
-
- )
- /* harmony default export */ var layouts_error = (error_component.exports);
- // CONCATENATED MODULE: ./.nuxt/components/nuxt.js
- /* harmony default export */ var components_nuxt = ({
- name: 'Nuxt',
- components: {
- NuxtChild: nuxt_child,
- NuxtError: layouts_error
- },
- props: {
- nuxtChildKey: {
- type: String,
- default: undefined
- },
- keepAlive: Boolean,
- keepAliveProps: {
- type: Object,
- default: undefined
- },
- name: {
- type: String,
- default: 'default'
- }
- },
- errorCaptured(error) {
- // if we receive and error while showing the NuxtError component
- // capture the error and force an immediate update so we re-render
- // without the NuxtError component
- if (this.displayingNuxtError) {
- this.errorFromNuxtError = error;
- this.$forceUpdate();
- }
- },
- computed: {
- routerViewKey() {
- // If nuxtChildKey prop is given or current route has children
- if (typeof this.nuxtChildKey !== 'undefined' || this.$route.matched.length > 1) {
- return this.nuxtChildKey || compile(this.$route.matched[0].path)(this.$route.params);
- }
- const [matchedRoute] = this.$route.matched;
- if (!matchedRoute) {
- return this.$route.path;
- }
- const Component = matchedRoute.components.default;
- if (Component && Component.options) {
- const {
- options
- } = Component;
- if (options.key) {
- return typeof options.key === 'function' ? options.key(this.$route) : options.key;
- }
- }
- const strict = /\/$/.test(matchedRoute.path);
- return strict ? this.$route.path : this.$route.path.replace(/\/$/, '');
- }
- },
- beforeCreate() {
- external_vue_default.a.util.defineReactive(this, 'nuxt', this.$root.$options.nuxt);
- },
- render(h) {
- // if there is no error or
- // error page has not been loaded yet on client
- if (!this.nuxt.err || false && false) {
- // Directly return nuxt child
- return h('NuxtChild', {
- key: this.routerViewKey,
- props: this.$props
- });
- }
- // if an error occurred within NuxtError show a simple
- // error message instead to prevent looping
- if (this.errorFromNuxtError) {
- this.$nextTick(() => this.errorFromNuxtError = false);
- return h('div', {}, [h('h2', 'An error occurred while showing the error page'), h('p', 'Unfortunately an error occurred and while showing the error page another error occurred'), h('p', `Error details: ${this.errorFromNuxtError.toString()}`), h('nuxt-link', {
- props: {
- to: '/'
- }
- }, 'Go back to home')]);
- }
- // track if we are showing the NuxtError component
- this.displayingNuxtError = true;
- this.$nextTick(() => this.displayingNuxtError = false);
- return h(layouts_error, {
- props: {
- error: this.nuxt.err
- }
- });
- }
- });
- // EXTERNAL MODULE: ./node_modules/element-ui/lib/theme-chalk/index.css
- var theme_chalk = __webpack_require__(89);
- // EXTERNAL MODULE: ./assets/iconfont/iconfont.css
- var iconfont = __webpack_require__(90);
- // EXTERNAL MODULE: ./assets/css/reset.scss
- var css_reset = __webpack_require__(91);
- // EXTERNAL MODULE: ./assets/css/common.scss
- var common = __webpack_require__(92);
- // EXTERNAL MODULE: ./assets/css/element.scss
- var css_element = __webpack_require__(93);
- // EXTERNAL MODULE: ./assets/css/flex-custom.scss
- var flex_custom = __webpack_require__(94);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./layouts/blank_layout.vue?vue&type=template&id=7da06d0b
- var blank_layoutvue_type_template_id_7da06d0b_render = function render() {
- var _vm = this,
- _c = _vm._self._c;
- return _c('div', [_c('nuxt')], 1);
- };
- var blank_layoutvue_type_template_id_7da06d0b_staticRenderFns = [];
- // CONCATENATED MODULE: ./layouts/blank_layout.vue?vue&type=template&id=7da06d0b
- // CONCATENATED MODULE: ./layouts/blank_layout.vue
- var script = {}
- /* normalize component */
- var blank_layout_component = Object(componentNormalizer["a" /* default */])(
- script,
- blank_layoutvue_type_template_id_7da06d0b_render,
- blank_layoutvue_type_template_id_7da06d0b_staticRenderFns,
- false,
- null,
- null,
- "2d596014"
-
- )
- /* harmony default export */ var blank_layout = (blank_layout_component.exports);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./layouts/default.vue?vue&type=template&id=4cbc928a&scoped=true
- var defaultvue_type_template_id_4cbc928a_scoped_true_render = function render() {
- var _vm = this,
- _c = _vm._self._c;
- return _c('div', {
- staticClass: "com-body"
- }, [_c('pc-header', {
- staticStyle: {
- "opacity": "0",
- "position": "static !important"
- }
- }), _vm._ssrNode(" "), _c('pc-header'), _vm._ssrNode(" "), _c('nuxt'), _vm._ssrNode(" "), _c('pc-footer'), _vm._ssrNode(" "), _c('loginDialog')], 2);
- };
- var defaultvue_type_template_id_4cbc928a_scoped_true_staticRenderFns = [];
- // CONCATENATED MODULE: ./layouts/default.vue?vue&type=template&id=4cbc928a&scoped=true
- // CONCATENATED MODULE: ./utils/keyboard.js
- const keys = {};
- function addKeyboardKey(e) {
- keys[e.key] = true;
- }
- function removeKeyboardKey(e) {
- delete keys[e.key];
- }
- function isCtrlPress(e) {
- // eslint-disable-next-line
- return keys['Control'];
- }
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./layouts/default.vue?vue&type=script&lang=js
- /* harmony default export */ var defaultvue_type_script_lang_js = ({
- data() {
- return {
- websitelogo: ''
- };
- },
- mounted() {
- // this.openZoho()
- // 添加监听
- window.addEventListener('keydown', addKeyboardKey);
- window.addEventListener('keyup', removeKeyboardKey);
- // 记住添加事件和卸载事件老是成对存在
- this.$once('hook:beforeDestroy', () => {
- window.removeEventListener('keydown', addKeyboardKey);
- window.removeEventListener('keyup', removeKeyboardKey);
- });
- },
- methods: {
- openZoho() {
- window.$zoho = window.$zoho || {};
- // eslint-disable-next-line
- $zoho.salesiq = $zoho.salesiq || {
- widgetcode: 'c5155e8cbfdb63f0a2b6f6f2cd50bdf2d3a9287755a068674324ed7d483e092e1baa6b2e7ee5c67d53c187e030d5c1f5',
- values: {},
- ready: function () {}
- };
- const d = document;
- const s = d.createElement('script');
- s.type = 'text/javascript';
- s.id = 'zsiqscript';
- s.defer = true;
- s.src = 'https://salesiq.zoho.com/widget';
- const t = d.getElementsByTagName('script')[0];
- t.parentNode.insertBefore(s, t);
- d.write("<div id='zsiqwidget'></div>");
- }
- }
- });
- // CONCATENATED MODULE: ./layouts/default.vue?vue&type=script&lang=js
- /* harmony default export */ var layouts_defaultvue_type_script_lang_js = (defaultvue_type_script_lang_js);
- // CONCATENATED MODULE: ./layouts/default.vue
- function default_injectStyles (context) {
-
-
- }
- /* normalize component */
- var default_component = Object(componentNormalizer["a" /* default */])(
- layouts_defaultvue_type_script_lang_js,
- defaultvue_type_template_id_4cbc928a_scoped_true_render,
- defaultvue_type_template_id_4cbc928a_scoped_true_staticRenderFns,
- false,
- default_injectStyles,
- "4cbc928a",
- "eefa3960"
-
- )
- /* harmony default export */ var layouts_default = (default_component.exports);
- /* nuxt-component-imports */
- installComponents(default_component, {PcHeader: __webpack_require__(108).default,PcFooter: __webpack_require__(109).default})
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./layouts/product_builder_layout.vue?vue&type=template&id=6c4e98e6&scoped=true
- var product_builder_layoutvue_type_template_id_6c4e98e6_scoped_true_render = function render() {
- var _vm = this,
- _c = _vm._self._c;
- return _c('div', {
- staticClass: "flex column stretch layout-wrap"
- }, [_c('pc-header-lite'), _vm._ssrNode(" "), _c('nuxt')], 2);
- };
- var product_builder_layoutvue_type_template_id_6c4e98e6_scoped_true_staticRenderFns = [];
- // CONCATENATED MODULE: ./layouts/product_builder_layout.vue?vue&type=template&id=6c4e98e6&scoped=true
- // CONCATENATED MODULE: ./layouts/product_builder_layout.vue
- var product_builder_layout_script = {}
- function product_builder_layout_injectStyles (context) {
-
- var style0 = __webpack_require__(102)
- if (style0.__inject__) style0.__inject__(context)
- }
- /* normalize component */
- var product_builder_layout_component = Object(componentNormalizer["a" /* default */])(
- product_builder_layout_script,
- product_builder_layoutvue_type_template_id_6c4e98e6_scoped_true_render,
- product_builder_layoutvue_type_template_id_6c4e98e6_scoped_true_staticRenderFns,
- false,
- product_builder_layout_injectStyles,
- "6c4e98e6",
- "d3c08542"
-
- )
- /* harmony default export */ var product_builder_layout = (product_builder_layout_component.exports);
- /* nuxt-component-imports */
- installComponents(product_builder_layout_component, {PcHeaderLite: __webpack_require__(110).default})
- // CONCATENATED MODULE: ./.nuxt/App.js
- const layouts = {
- "_blank_layout": sanitizeComponent(blank_layout),
- "_default": sanitizeComponent(layouts_default),
- "_product_builder_layout": sanitizeComponent(product_builder_layout)
- };
- /* harmony default export */ var App = ({
- render(h, props) {
- const layoutEl = h(this.layout || 'nuxt');
- const templateEl = h('div', {
- domProps: {
- id: '__layout'
- },
- key: this.layoutName
- }, [layoutEl]);
- const transitionEl = h('transition', {
- props: {
- name: 'layout',
- mode: 'out-in'
- },
- on: {
- beforeEnter(el) {
- // Ensure to trigger scroll event after calling scrollBehavior
- window.$nuxt.$nextTick(() => {
- window.$nuxt.$emit('triggerScroll');
- });
- }
- }
- }, [templateEl]);
- return h('div', {
- domProps: {
- id: '__nuxt'
- }
- }, [transitionEl]);
- },
- data: () => ({
- isOnline: true,
- layout: null,
- layoutName: '',
- nbFetching: 0
- }),
- beforeCreate() {
- external_vue_default.a.util.defineReactive(this, 'nuxt', this.$options.nuxt);
- },
- created() {
- // Add this.$nuxt in child instances
- this.$root.$options.$nuxt = this;
- if (false) {}
- // Add $nuxt.error()
- this.error = this.nuxt.error;
- // Add $nuxt.context
- this.context = this.$options.context;
- },
- watch: {
- 'nuxt.err': 'errorChanged'
- },
- computed: {
- isOffline() {
- return !this.isOnline;
- },
- isFetching() {
- return this.nbFetching > 0;
- }
- },
- methods: {
- refreshOnlineStatus() {
- if (false) {}
- },
- async refresh() {
- const pages = getMatchedComponentsInstances(this.$route);
- if (!pages.length) {
- return;
- }
- const promises = pages.map(async page => {
- let p = [];
- // Old fetch
- if (page.$options.fetch && page.$options.fetch.length) {
- p.push(promisify(page.$options.fetch, this.context));
- }
- if (page.$options.asyncData) {
- p.push(promisify(page.$options.asyncData, this.context).then(newData => {
- for (const key in newData) {
- external_vue_default.a.set(page.$data, key, newData[key]);
- }
- }));
- }
- // Wait for asyncData & old fetch to finish
- await Promise.all(p);
- // Cleanup refs
- p = [];
- if (page.$fetch) {
- p.push(page.$fetch());
- }
- // Get all component instance to call $fetch
- for (const component of getChildrenComponentInstancesUsingFetch(page.$vnode.componentInstance)) {
- p.push(component.$fetch());
- }
- return Promise.all(p);
- });
- try {
- await Promise.all(promises);
- } catch (error) {
- globalHandleError(error);
- this.error(error);
- }
- },
- errorChanged() {
- if (this.nuxt.err) {
- let errorLayout = (layouts_error.options || layouts_error).layout;
- if (typeof errorLayout === 'function') {
- errorLayout = errorLayout(this.context);
- }
- this.nuxt.errPageReady = true;
- this.setLayout(errorLayout);
- }
- },
- setLayout(layout) {
- if (!layout || !layouts['_' + layout]) {
- layout = 'default';
- }
- this.layoutName = layout;
- this.layout = layouts['_' + layout];
- return this.layout;
- },
- loadLayout(layout) {
- if (!layout || !layouts['_' + layout]) {
- layout = 'default';
- }
- return Promise.resolve(layouts['_' + layout]);
- }
- }
- });
- // CONCATENATED MODULE: ./.nuxt/store.js
- external_vue_default.a.use(external_vuex_default.a);
- const VUEX_PROPERTIES = ['state', 'getters', 'actions', 'mutations'];
- let store_store = {};
- (function updateModules() {
- store_store = normalizeRoot(__webpack_require__(104), 'store/index.js');
- // If store is an exported method = classic mode (deprecated)
- // Enforce store modules
- store_store.modules = store_store.modules || {};
- resolveStoreModules(__webpack_require__(105), 'config.js');
- resolveStoreModules(__webpack_require__(106), 'product.js');
- // If the environment supports hot reloading...
- })();
- // createStore
- const createStore = store_store instanceof Function ? store_store : () => {
- return new external_vuex_default.a.Store(Object.assign({
- strict: "production" !== 'production'
- }, store_store));
- };
- function normalizeRoot(moduleData, filePath) {
- moduleData = moduleData.default || moduleData;
- if (moduleData.commit) {
- throw new Error(`[nuxt] ${filePath} should export a method that returns a Vuex instance.`);
- }
- if (typeof moduleData !== 'function') {
- // Avoid TypeError: setting a property that has only a getter when overwriting top level keys
- moduleData = Object.assign({}, moduleData);
- }
- return normalizeModule(moduleData, filePath);
- }
- function normalizeModule(moduleData, filePath) {
- if (moduleData.state && typeof moduleData.state !== 'function') {
- console.warn(`'state' should be a method that returns an object in ${filePath}`);
- const state = Object.assign({}, moduleData.state);
- // Avoid TypeError: setting a property that has only a getter when overwriting top level keys
- moduleData = Object.assign({}, moduleData, {
- state: () => state
- });
- }
- return moduleData;
- }
- function resolveStoreModules(moduleData, filename) {
- moduleData = moduleData.default || moduleData;
- // Remove store src + extension (./foo/index.js -> foo/index)
- const namespace = filename.replace(/\.(js|mjs)$/, '');
- const namespaces = namespace.split('/');
- let moduleName = namespaces[namespaces.length - 1];
- const filePath = `store/${filename}`;
- moduleData = moduleName === 'state' ? normalizeState(moduleData, filePath) : normalizeModule(moduleData, filePath);
- // If src is a known Vuex property
- if (VUEX_PROPERTIES.includes(moduleName)) {
- const property = moduleName;
- const propertyStoreModule = getStoreModule(store_store, namespaces, {
- isProperty: true
- });
- // Replace state since it's a function
- mergeProperty(propertyStoreModule, moduleData, property);
- return;
- }
- // If file is foo/index.js, it should be saved as foo
- const isIndexModule = moduleName === 'index';
- if (isIndexModule) {
- namespaces.pop();
- moduleName = namespaces[namespaces.length - 1];
- }
- const storeModule = getStoreModule(store_store, namespaces);
- for (const property of VUEX_PROPERTIES) {
- mergeProperty(storeModule, moduleData[property], property);
- }
- if (moduleData.namespaced === false) {
- delete storeModule.namespaced;
- }
- }
- function normalizeState(moduleData, filePath) {
- if (typeof moduleData !== 'function') {
- console.warn(`${filePath} should export a method that returns an object`);
- const state = Object.assign({}, moduleData);
- return () => state;
- }
- return normalizeModule(moduleData, filePath);
- }
- function getStoreModule(storeModule, namespaces, {
- isProperty = false
- } = {}) {
- // If ./mutations.js
- if (!namespaces.length || isProperty && namespaces.length === 1) {
- return storeModule;
- }
- const namespace = namespaces.shift();
- storeModule.modules[namespace] = storeModule.modules[namespace] || {};
- storeModule.modules[namespace].namespaced = true;
- storeModule.modules[namespace].modules = storeModule.modules[namespace].modules || {};
- return getStoreModule(storeModule.modules[namespace], namespaces, {
- isProperty
- });
- }
- function mergeProperty(storeModule, moduleData, property) {
- if (!moduleData) {
- return;
- }
- if (property === 'state') {
- storeModule.state = moduleData || storeModule.state;
- } else {
- storeModule[property] = Object.assign({}, storeModule[property], moduleData);
- }
- }
- // CONCATENATED MODULE: ./.nuxt/components/index.js
- const Breadcrumb = () => __webpack_require__.e(/* import() | components/breadcrumb */ 3).then(__webpack_require__.bind(null, 323)).then(c => wrapFunctional(c.default || c));
- const Bxh = () => __webpack_require__.e(/* import() | components/bxh */ 4).then(__webpack_require__.bind(null, 206)).then(c => wrapFunctional(c.default || c));
- const Card = () => __webpack_require__.e(/* import() | components/card */ 5).then(__webpack_require__.bind(null, 153)).then(c => wrapFunctional(c.default || c));
- const Carousel = () => __webpack_require__.e(/* import() | components/carousel */ 6).then(__webpack_require__.bind(null, 316)).then(c => wrapFunctional(c.default || c));
- const CategoryFilter = () => __webpack_require__.e(/* import() | components/category-filter */ 7).then(__webpack_require__.bind(null, 175)).then(c => wrapFunctional(c.default || c));
- const CategoryNoData = () => __webpack_require__.e(/* import() | components/category-no-data */ 8).then(__webpack_require__.bind(null, 176)).then(c => wrapFunctional(c.default || c));
- const DIalogXXSuccess = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(null, 30)).then(c => wrapFunctional(c.default || c));
- const DesignFormDialog = () => __webpack_require__.e(/* import() | components/design-form-dialog */ 12).then(__webpack_require__.bind(null, 319)).then(c => wrapFunctional(c.default || c));
- const DownloadDialog = () => __webpack_require__.e(/* import() | components/download-dialog */ 13).then(__webpack_require__.bind(null, 427)).then(c => wrapFunctional(c.default || c));
- const ExportDialog = () => __webpack_require__.e(/* import() | components/export-dialog */ 14).then(__webpack_require__.bind(null, 191)).then(c => wrapFunctional(c.default || c));
- const FormDialog = () => __webpack_require__.e(/* import() | components/form-dialog */ 15).then(__webpack_require__.bind(null, 177)).then(c => wrapFunctional(c.default || c));
- const ImageUpload = () => __webpack_require__.e(/* import() | components/image-upload */ 17).then(__webpack_require__.bind(null, 266)).then(c => wrapFunctional(c.default || c));
- const Pagination = () => __webpack_require__.e(/* import() | components/pagination */ 19).then(__webpack_require__.bind(null, 154)).then(c => wrapFunctional(c.default || c));
- const PcArticle = () => __webpack_require__.e(/* import() | components/pc-article */ 20).then(__webpack_require__.bind(null, 315)).then(c => wrapFunctional(c.default || c));
- const PcFooter = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(null, 109)).then(c => wrapFunctional(c.default || c));
- const PcGlobalForm = () => __webpack_require__.e(/* import() | components/pc-global-form */ 21).then(__webpack_require__.bind(null, 326)).then(c => wrapFunctional(c.default || c));
- const PcHeader = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(null, 108)).then(c => wrapFunctional(c.default || c));
- const PcHeaderLite = () => Promise.resolve(/* import() */).then(__webpack_require__.bind(null, 110)).then(c => wrapFunctional(c.default || c));
- const PcSwitch = () => __webpack_require__.e(/* import() | components/pc-switch */ 22).then(__webpack_require__.bind(null, 212)).then(c => wrapFunctional(c.default || c));
- const PcTitle = () => __webpack_require__.e(/* import() | components/pc-title */ 23).then(__webpack_require__.bind(null, 203)).then(c => wrapFunctional(c.default || c));
- const PdfHtml = () => __webpack_require__.e(/* import() | components/pdf-html */ 24).then(__webpack_require__.bind(null, 428)).then(c => wrapFunctional(c.default || c));
- const PriceToImg = () => __webpack_require__.e(/* import() | components/price-to-img */ 25).then(__webpack_require__.bind(null, 213)).then(c => wrapFunctional(c.default || c));
- const Project = () => __webpack_require__.e(/* import() | components/project */ 34).then(__webpack_require__.bind(null, 244)).then(c => wrapFunctional(c.default || c));
- const ProjectDialog = () => __webpack_require__.e(/* import() | components/project-dialog */ 35).then(__webpack_require__.bind(null, 204)).then(c => wrapFunctional(c.default || c));
- const ResetPasswordMail = () => __webpack_require__.e(/* import() | components/reset-password-mail */ 37).then(__webpack_require__.bind(null, 327)).then(c => wrapFunctional(c.default || c));
- const RowCard = () => __webpack_require__.e(/* import() | components/row-card */ 38).then(__webpack_require__.bind(null, 318)).then(c => wrapFunctional(c.default || c));
- const SubNav = () => __webpack_require__.e(/* import() | components/sub-nav */ 39).then(__webpack_require__.bind(null, 317)).then(c => wrapFunctional(c.default || c));
- const Subscription = () => __webpack_require__.e(/* import() | components/subscription */ 40).then(__webpack_require__.bind(null, 429)).then(c => wrapFunctional(c.default || c));
- const TabNav = () => __webpack_require__.e(/* import() | components/tab-nav */ 41).then(__webpack_require__.bind(null, 192)).then(c => wrapFunctional(c.default || c));
- const Zoom = () => __webpack_require__.e(/* import() | components/zoom */ 54).then(__webpack_require__.bind(null, 207)).then(c => wrapFunctional(c.default || c));
- const AddAddressDialog = () => __webpack_require__.e(/* import() | components/add-address-dialog */ 1).then(__webpack_require__.bind(null, 182)).then(c => wrapFunctional(c.default || c));
- const BookCard = () => __webpack_require__.e(/* import() | components/book-card */ 2).then(__webpack_require__.bind(null, 239)).then(c => wrapFunctional(c.default || c));
- const ImageList = () => __webpack_require__.e(/* import() | components/image-list */ 16).then(__webpack_require__.bind(null, 205)).then(c => wrapFunctional(c.default || c));
- const LoginDialog = () => __webpack_require__.e(/* import() | components/login-dialog */ 18).then(__webpack_require__.bind(null, 430)).then(c => wrapFunctional(c.default || c));
- const ResetPasswordDialog = () => __webpack_require__.e(/* import() | components/reset-password-dialog */ 36).then(__webpack_require__.bind(null, 431)).then(c => wrapFunctional(c.default || c));
- const TinymceDynamicLoadScript = () => __webpack_require__.e(/* import() | components/tinymce-dynamic-load-script */ 51).then(__webpack_require__.bind(null, 152)).then(c => wrapFunctional(c.default || c));
- const Tinymce = () => __webpack_require__.e(/* import() | components/tinymce */ 49).then(__webpack_require__.bind(null, 143)).then(c => wrapFunctional(c.default || c));
- const TinymcePlugins = () => __webpack_require__.e(/* import() | components/tinymce-plugins */ 52).then(__webpack_require__.bind(null, 150)).then(c => wrapFunctional(c.default || c));
- const TinymceToolbar = () => __webpack_require__.e(/* import() | components/tinymce-toolbar */ 53).then(__webpack_require__.bind(null, 151)).then(c => wrapFunctional(c.default || c));
- const CustomElSliderButton = () => __webpack_require__.e(/* import() | components/custom-el-slider-button */ 10).then(__webpack_require__.bind(null, 158)).then(c => wrapFunctional(c.default || c));
- const CustomElSlider = () => __webpack_require__.e(/* import() | components/custom-el-slider */ 9).then(__webpack_require__.bind(null, 161)).then(c => wrapFunctional(c.default || c));
- const CustomElSliderMarker = () => __webpack_require__.e(/* import() | components/custom-el-slider-marker */ 11).then(__webpack_require__.bind(null, 159)).then(c => wrapFunctional(c.default || c));
- const ProductLeft = () => __webpack_require__.e(/* import() | components/product-left */ 31).then(__webpack_require__.bind(null, 324)).then(c => wrapFunctional(c.default || c));
- const ProductRight = () => __webpack_require__.e(/* import() | components/product-right */ 33).then(__webpack_require__.bind(null, 325)).then(c => wrapFunctional(c.default || c));
- const ProductQuote = () => __webpack_require__.e(/* import() | components/product-quote */ 32).then(__webpack_require__.bind(null, 241)).then(c => wrapFunctional(c.default || c));
- const TableChangeTable = () => __webpack_require__.e(/* import() | components/table-change-table */ 42).then(__webpack_require__.bind(null, 243)).then(c => wrapFunctional(c.default || c));
- const TableMailTable = () => __webpack_require__.e(/* import() | components/table-mail-table */ 43).then(__webpack_require__.bind(null, 211)).then(c => wrapFunctional(c.default || c));
- const TableNewPriceTable = () => __webpack_require__.e(/* import() | components/table-new-price-table */ 44).then(__webpack_require__.bind(null, 208)).then(c => wrapFunctional(c.default || c));
- const TableStockTable = () => __webpack_require__.e(/* import() | components/table-stock-table */ 46).then(__webpack_require__.bind(null, 242)).then(c => wrapFunctional(c.default || c));
- const TableTotalTable = () => __webpack_require__.e(/* import() | components/table-total-table */ 47).then(__webpack_require__.bind(null, 209)).then(c => wrapFunctional(c.default || c));
- const TableUnitTable = () => __webpack_require__.e(/* import() | components/table-unit-table */ 48).then(__webpack_require__.bind(null, 210)).then(c => wrapFunctional(c.default || c));
- const TableParamTable = () => __webpack_require__.e(/* import() | components/table-param-table */ 45).then(__webpack_require__.bind(null, 314)).then(c => wrapFunctional(c.default || c));
- const ProductBuilderDialogSelectAddr = () => __webpack_require__.e(/* import() | components/product-builder-dialog-select-addr */ 26).then(__webpack_require__.bind(null, 240)).then(c => wrapFunctional(c.default || c));
- const ProductBuilderStep1 = () => __webpack_require__.e(/* import() | components/product-builder-step1 */ 28).then(__webpack_require__.bind(null, 320)).then(c => wrapFunctional(c.default || c));
- const ProductBuilderStep2 = () => __webpack_require__.e(/* import() | components/product-builder-step2 */ 29).then(__webpack_require__.bind(null, 321)).then(c => wrapFunctional(c.default || c));
- const ProductBuilderStep3 = () => __webpack_require__.e(/* import() | components/product-builder-step3 */ 30).then(__webpack_require__.bind(null, 322)).then(c => wrapFunctional(c.default || c));
- const ProductBuilderStepMixin = () => __webpack_require__.e(/* import() | components/product-builder-step-mixin */ 27).then(__webpack_require__.bind(null, 178)).then(c => wrapFunctional(c.default || c));
- const TinymceComponentsEditorImage = () => __webpack_require__.e(/* import() | components/tinymce-components-editor-image */ 50).then(__webpack_require__.bind(null, 432)).then(c => wrapFunctional(c.default || c));
- // nuxt/nuxt.js#8607
- function wrapFunctional(options) {
- if (!options || !options.functional) {
- return options;
- }
- const propKeys = Array.isArray(options.props) ? options.props : Object.keys(options.props || {});
- return {
- render(h) {
- const attrs = {};
- const props = {};
- for (const key in this.$attrs) {
- if (propKeys.includes(key)) {
- props[key] = this.$attrs[key];
- } else {
- attrs[key] = this.$attrs[key];
- }
- }
- return h(options, {
- on: this.$listeners,
- attrs,
- props,
- scopedSlots: this.$scopedSlots
- }, this.$slots.default);
- }
- };
- }
- // CONCATENATED MODULE: ./.nuxt/components/plugin.js
- for (const name in components_namespaceObject) {
- external_vue_default.a.component(name, components_namespaceObject[name]);
- external_vue_default.a.component('Lazy' + name, components_namespaceObject[name]);
- }
- // EXTERNAL MODULE: external "cookie-universal"
- var external_cookie_universal_ = __webpack_require__(53);
- var external_cookie_universal_default = /*#__PURE__*/__webpack_require__.n(external_cookie_universal_);
- // CONCATENATED MODULE: ./.nuxt/cookie-universal-nuxt.js
- /* harmony default export */ var cookie_universal_nuxt = (({
- req,
- res
- }, inject) => {
- const options = {
- "alias": "cookies",
- "parseJSON": true
- };
- inject(options.alias, external_cookie_universal_default()(req, res, options.parseJSON));
- });
- // EXTERNAL MODULE: external "axios"
- var external_axios_ = __webpack_require__(10);
- var external_axios_default = /*#__PURE__*/__webpack_require__.n(external_axios_);
- // EXTERNAL MODULE: external "defu"
- var external_defu_ = __webpack_require__(54);
- var external_defu_default = /*#__PURE__*/__webpack_require__.n(external_defu_);
- // CONCATENATED MODULE: ./.nuxt/axios.js
- // Axios.prototype cannot be modified
- const axiosExtra = {
- setBaseURL(baseURL) {
- this.defaults.baseURL = baseURL;
- },
- setHeader(name, value, scopes = 'common') {
- for (const scope of Array.isArray(scopes) ? scopes : [scopes]) {
- if (!value) {
- delete this.defaults.headers[scope][name];
- continue;
- }
- this.defaults.headers[scope][name] = value;
- }
- },
- setToken(token, type, scopes = 'common') {
- const value = !token ? null : (type ? type + ' ' : '') + token;
- this.setHeader('Authorization', value, scopes);
- },
- onRequest(fn) {
- this.interceptors.request.use(config => fn(config) || config);
- },
- onResponse(fn) {
- this.interceptors.response.use(response => fn(response) || response);
- },
- onRequestError(fn) {
- this.interceptors.request.use(undefined, error => fn(error) || Promise.reject(error));
- },
- onResponseError(fn) {
- this.interceptors.response.use(undefined, error => fn(error) || Promise.reject(error));
- },
- onError(fn) {
- this.onRequestError(fn);
- this.onResponseError(fn);
- },
- create(options) {
- return createAxiosInstance(external_defu_default()(options, this.defaults));
- }
- };
- // Request helpers ($get, $post, ...)
- for (const method of ['request', 'delete', 'get', 'head', 'options', 'post', 'put', 'patch']) {
- axiosExtra['$' + method] = function () {
- return this[method].apply(this, arguments).then(res => res && res.data);
- };
- }
- const extendAxiosInstance = axios => {
- for (const key in axiosExtra) {
- axios[key] = axiosExtra[key].bind(axios);
- }
- };
- const createAxiosInstance = axiosOptions => {
- // Create new axios instance
- const axios = external_axios_default.a.create(axiosOptions);
- axios.CancelToken = external_axios_default.a.CancelToken;
- axios.isCancel = external_axios_default.a.isCancel;
- // Extend axios proto
- extendAxiosInstance(axios);
- // Intercept to apply default headers
- axios.onRequest(config => {
- config.headers = {
- ...axios.defaults.headers.common,
- ...config.headers
- };
- });
- // Setup interceptors
- setupProgress(axios);
- return axios;
- };
- const setupProgress = axios => {
- if (true) {
- return;
- }
- // A noop loading inteterface for when $nuxt is not yet ready
- const noopLoading = {
- finish: () => {},
- start: () => {},
- fail: () => {},
- set: () => {}
- };
- const $loading = () => {
- const $nuxt = typeof window !== 'undefined' && window['$nuxt'];
- return $nuxt && $nuxt.$loading && $nuxt.$loading.set ? $nuxt.$loading : noopLoading;
- };
- let currentRequests = 0;
- axios.onRequest(config => {
- if (config && config.progress === false) {
- return;
- }
- currentRequests++;
- });
- axios.onResponse(response => {
- if (response && response.config && response.config.progress === false) {
- return;
- }
- currentRequests--;
- if (currentRequests <= 0) {
- currentRequests = 0;
- $loading().finish();
- }
- });
- axios.onError(error => {
- if (error && error.config && error.config.progress === false) {
- return;
- }
- currentRequests--;
- if (external_axios_default.a.isCancel(error)) {
- if (currentRequests <= 0) {
- currentRequests = 0;
- $loading().finish();
- }
- return;
- }
- $loading().fail();
- $loading().finish();
- });
- const onProgress = e => {
- if (!currentRequests || !e.total) {
- return;
- }
- const progress = e.loaded * 100 / (e.total * currentRequests);
- $loading().set(Math.min(100, progress));
- };
- axios.defaults.onUploadProgress = onProgress;
- axios.defaults.onDownloadProgress = onProgress;
- };
- /* harmony default export */ var _nuxt_axios = ((ctx, inject) => {
- // runtimeConfig
- const runtimeConfig = ctx.$config && ctx.$config.axios || {};
- // baseURL
- const baseURL = false ? undefined : runtimeConfig.baseURL || runtimeConfig.baseUrl || process.env._AXIOS_BASE_URL_ || 'http://localhost:3000/';
- // Create fresh objects for all default header scopes
- // Axios creates only one which is shared across SSR requests!
- // https://github.com/mzabriskie/axios/blob/master/lib/defaults.js
- const headers = {
- "common": {
- "Accept": "application/json, text/plain, */*"
- },
- "delete": {},
- "get": {},
- "head": {},
- "post": {},
- "put": {},
- "patch": {}
- };
- const axiosOptions = {
- baseURL,
- headers
- };
- // Proxy SSR request headers headers
- if ( true && ctx.req && ctx.req.headers) {
- const reqHeaders = {
- ...ctx.req.headers
- };
- for (const h of ["accept", "cf-connecting-ip", "cf-ray", "content-length", "content-md5", "content-type", "host", "x-forwarded-host", "x-forwarded-port", "x-forwarded-proto"]) {
- delete reqHeaders[h];
- }
- axiosOptions.headers.common = {
- ...reqHeaders,
- ...axiosOptions.headers.common
- };
- }
- if (true) {
- // Don't accept brotli encoding because Node can't parse it
- axiosOptions.headers.common['accept-encoding'] = 'gzip, deflate';
- }
- const axios = createAxiosInstance(axiosOptions);
- // Inject axios to the context as $axios
- ctx.$axios = axios;
- inject('axios', axios);
- });
- // EXTERNAL MODULE: ./node_modules/element-ui/lib/element-ui.common.js
- var element_ui_common = __webpack_require__(7);
- var element_ui_common_default = /*#__PURE__*/__webpack_require__.n(element_ui_common);
- // EXTERNAL MODULE: ./node_modules/element-ui/lib/locale/lang/en.js
- var en = __webpack_require__(55);
- var en_default = /*#__PURE__*/__webpack_require__.n(en);
- // CONCATENATED MODULE: ./plugins/element-ui.js
- external_vue_default.a.use(element_ui_common_default.a, {
- locale: en_default.a
- });
- // CONCATENATED MODULE: ./plugins/axios.js
- /* harmony default export */ var plugins_axios = (({
- $axios,
- store,
- $cookies,
- redirect
- }) => {
- $axios.onRequest(config => {
- if (!/^\/c-api/.test(config.url)) {
- if (!/^\/api/.test(config.url)) {
- config.url = (/^\//.test(config.url) ? '/api' : '/api/') + config.url;
- }
- }
- // const token = $cookies.get('shop-token')
- // if (token) {
- // config.headers.Authorization = 'Bearer ' + token
- // }
- });
- $axios.onResponse(response => {
- const {
- data,
- status
- } = response;
- if (data.code != 1 && data.msg != 'Error' && data.msg) {
- Object(element_ui_common["Message"])({
- message: data.msg,
- type: 'error',
- duration: 3 * 1000
- });
- return Promise.reject(new Error(data.msg || 'Error'));
- } else {
- return response.data;
- }
- }, error => {
- const {
- data,
- status
- } = error.response;
- Object(element_ui_common["Message"])({
- message: 'error:' + data.msg,
- type: 'error',
- duration: 5 * 1000
- });
- return Promise.reject(error);
- });
- $axios.onError(error => {
- const {
- data,
- status
- } = error.response || {
- data: {
- msg: 'unknow'
- },
- status: 444
- };
- if ([303, 304, 305].includes(status)) {
- store.dispatch('logout');
- return;
- } else if (status == 500) {
- redirect('/layouts/error');
- }
- if (data.code != 200) {
- Object(element_ui_common["Message"])({
- message: '' + error.response.data.msg,
- type: 'error',
- duration: 3 * 1000
- });
- return Promise.reject(error);
- }
- });
- });
- // CONCATENATED MODULE: ./plugins/router.js
- /* harmony default export */ var plugins_router = (({
- app,
- store,
- redirect,
- $cookies
- }) => {
- app.router.beforeEach((to, from, next) => {
- // 在每次路由跳转的时候进行判断
- if (isCtrlPress()) {
- // 若是 ctrl 按键被按下,则以新窗口打开目标页面
- window.open(to.fullPath);
- // 并阻止当前页面的跳转
- return next(false);
- }
- const token = $cookies.get('shop-token');
- if (token) {
- store.commit('setUserInfo', $cookies.get('shop-user-info'));
- } else {
- store.commit('clearUserInfo');
- }
- next();
- });
- });
- // EXTERNAL MODULE: external "dayjs"
- var external_dayjs_ = __webpack_require__(16);
- var external_dayjs_default = /*#__PURE__*/__webpack_require__.n(external_dayjs_);
- // CONCATENATED MODULE: ./plugins/utils.js
- const utils = {
- // 检查是否登录
- checkLogin() {
- if (this.getCookie('shop-token')) {
- return true;
- } else {
- return false;
- }
- },
- getCookie(cname) {
- const name = cname + "=";
- const ca = document.cookie.split(';');
- for (let i = 0; i < ca.length; i++) {
- const c = ca[i].trim();
- if (c.indexOf(name) === 0) return c.substring(name.length, c.length);
- }
- return "";
- },
- checkType(val) {
- return Object.prototype.toString.call(val).slice(8, -1);
- },
- // 时间格式化. 格式参考 https://day.js.org/docs/zh-CN/display/format
- formatTime(date, format = 'DD-MM-YYYY HH:mm:ss', isUnix = false) {
- let str = '';
- if (date) {
- str = isUnix ? external_dayjs_default.a.unix(date).format(format) : external_dayjs_default()(date).format(format);
- }
- return str;
- },
- /**
- * @deprecated 处理 pdf url,使其不在浏览器打开
- * @param {string} url
- */
- downloadBlob(url, filename) {
- fetch(url, {
- method: 'get',
- responseType: 'arraybuffer'
- }).then(function (res) {
- if (res.status !== 200) {
- return res.json();
- }
- return res.arrayBuffer();
- }).then(blobRes => {
- // 生成 Blob 对象,设置 type 等信息
- const e = new Blob([blobRes], {
- type: 'application/octet-stream',
- 'Content-Disposition': 'attachment'
- });
- // 将 Blob 对象转为 url
- const link = window.URL.createObjectURL(e);
- this.handleFileDownload(link, filename);
- }).catch(err => {
- console.error(err);
- });
- },
- handleFileDownload(url, filename, download = true) {
- const a = document.createElement('a');
- a.href = url;
- a.download = download && filename;
- a.target = '_blank';
- a.click();
- },
- isEmail(s) {
- return /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((.[a-zA-Z0-9_-]{2,3}){1,2})$/.test(s);
- },
- isMobile(s) {
- return /^1[0-9]{10}$/.test(s);
- },
- // 亚马逊图像尺寸缩略
- generateResizedImageUrl(urlString, width) {
- if (urlString) {
- const extractedString = urlString.replace(/^https?:\/\/[^/]+/, '');
- const resizedImageUrl = `${external_vue_default.a.prototype.$OSS_PREFIX}/fit-in/${width}x0${extractedString}`;
- return resizedImageUrl;
- }
- },
- // 链接替换
- repaceDomain(urlString) {
- if (urlString) {
- const extractedString = urlString.replace(/^https?:\/\/[^/]+/, '');
- const resizedImageUrl = `${external_vue_default.a.prototype.$OSS_S3_PREFIX}${extractedString}`;
- return resizedImageUrl;
- }
- }
- };
- external_vue_default.a.prototype.$utils = utils;
- // CONCATENATED MODULE: ./plugins/oss.js
- // 写到全局常量是因为如果写到env环境, template里面就无法直接写 process.env.***, 这是nuxt的问题
- external_vue_default.a.prototype.$OSS_PREFIX = 'https://mediahub.promocollection.com.au';
- external_vue_default.a.prototype.$OSS_S3_PREFIX = 'https://promocollection.s3.ap-southeast-2.amazonaws.com';
- external_vue_default.a.prototype.$mediaRegExp = /^(https?:)?\/\/.+(.com.au\/|.com\/)/;
- // EXTERNAL MODULE: ./.nuxt/empty.js
- var _nuxt_empty = __webpack_require__(11);
- // CONCATENATED MODULE: ./.nuxt/index.js
- /* Plugins */
- // Source: ./components/plugin.js (mode: 'all')
- // Source: ./cookie-universal-nuxt.js (mode: 'all')
- // Source: ./axios.js (mode: 'all')
- // Source: ../plugins/element-ui (mode: 'all')
- // Source: ../plugins/axios.js (mode: 'all')
- // Source: ../plugins/router.js (mode: 'all')
- // Source: ../plugins/utils.js (mode: 'all')
- // Source: ../plugins/oss.js (mode: 'all')
- // Source: ../assets/iconfont/iconfont.js (mode: 'client')
- // Source: ../assets/googlemap.js (mode: 'client')
- // Source: ../plugins/clarity.js (mode: 'client')
- // Source: ../plugins/baidu-analytics.js (mode: 'client')
- // Source: ../plugins/google-analytics.js (mode: 'client')
- // Component: <ClientOnly>
- external_vue_default.a.component(external_vue_client_only_default.a.name, external_vue_client_only_default.a);
- // TODO: Remove in Nuxt 3: <NoSsr>
- external_vue_default.a.component(external_vue_no_ssr_default.a.name, {
- ...external_vue_no_ssr_default.a,
- render(h, ctx) {
- if (false) {}
- return external_vue_no_ssr_default.a.render(h, ctx);
- }
- });
- // Component: <NuxtChild>
- external_vue_default.a.component(nuxt_child.name, nuxt_child);
- external_vue_default.a.component('NChild', nuxt_child);
- // Component NuxtLink is imported in server.js or client.js
- // Component: <Nuxt>
- external_vue_default.a.component(components_nuxt.name, components_nuxt);
- Object.defineProperty(external_vue_default.a.prototype, '$nuxt', {
- get() {
- const globalNuxt = this.$root ? this.$root.$options.$nuxt : null;
- if (false) {}
- return globalNuxt;
- },
- configurable: true
- });
- external_vue_default.a.use(external_vue_meta_default.a, {
- "keyName": "head",
- "attribute": "data-n-head",
- "ssrAttribute": "data-n-head-ssr",
- "tagIDKeyName": "hid"
- });
- const defaultTransition = {
- "name": "page",
- "mode": "out-in",
- "appear": false,
- "appearClass": "appear",
- "appearActiveClass": "appear-active",
- "appearToClass": "appear-to"
- };
- const originalRegisterModule = external_vuex_default.a.Store.prototype.registerModule;
- function registerModule(path, rawModule, options = {}) {
- const preserveState = false && (false);
- return originalRegisterModule.call(this, path, rawModule, {
- preserveState,
- ...options
- });
- }
- async function createApp(ssrContext, config = {}) {
- const store = createStore(ssrContext);
- const router = await createRouter(ssrContext, config, {
- store
- });
- // Add this.$router into store actions/mutations
- store.$router = router;
- // Fix SSR caveat https://github.com/nuxt/nuxt.js/issues/3757#issuecomment-414689141
- store.registerModule = registerModule;
- // Create Root instance
- // here we inject the router and store to all child components,
- // making them available everywhere as `this.$router` and `this.$store`.
- const app = {
- head: {
- "title": " ",
- "htmlAttrs": {
- "lang": "en"
- },
- "meta": [{
- "charset": "utf-8"
- }, {
- "name": "google-site-verification",
- "content": "fQgAl9rz9JmPUq85LR8zGTHR7KxbCz19V1pBqiQc27Q"
- }, {
- "name": "viewport",
- "content": "width=1400, initial-scale=0.5"
- }, {
- "hid": "description",
- "name": "description",
- "content": "Promotional Products, Lanyards, Flash Drives, Mousemats."
- }, {
- "hid": "keywords",
- "name": "keywords",
- "content": "PromoCollection"
- }, {
- "name": "format-detection",
- "content": "telephone=no"
- }],
- "link": [{
- "rel": "icon",
- "type": "image\u002Fx-icon",
- "href": "",
- "id": "favicon"
- }],
- "script": [{
- "src": "\u002F\u002Fyun.baoxiaohe.com\u002Fopenflatform\u002Fsdk\u002Fv2.2\u002Fstaticwwnf5q1r.js"
- }],
- "style": []
- },
- store,
- router,
- nuxt: {
- defaultTransition,
- transitions: [defaultTransition],
- setTransitions(transitions) {
- if (!Array.isArray(transitions)) {
- transitions = [transitions];
- }
- transitions = transitions.map(transition => {
- if (!transition) {
- transition = defaultTransition;
- } else if (typeof transition === 'string') {
- transition = Object.assign({}, defaultTransition, {
- name: transition
- });
- } else {
- transition = Object.assign({}, defaultTransition, transition);
- }
- return transition;
- });
- this.$options.nuxt.transitions = transitions;
- return transitions;
- },
- err: null,
- errPageReady: false,
- dateErr: null,
- error(err) {
- err = err || null;
- app.context._errored = Boolean(err);
- err = err ? normalizeError(err) : null;
- let nuxt = app.nuxt; // to work with @vue/composition-api, see https://github.com/nuxt/nuxt.js/issues/6517#issuecomment-573280207
- if (this) {
- nuxt = this.nuxt || this.$options.nuxt;
- }
- nuxt.dateErr = Date.now();
- nuxt.err = err;
- nuxt.errPageReady = false;
- // Used in src/server.js
- if (ssrContext) {
- ssrContext.nuxt.error = err;
- }
- return err;
- }
- },
- ...App
- };
- // Make app available into store via this.app
- store.app = app;
- const next = ssrContext ? ssrContext.next : location => app.router.push(location);
- // Resolve route
- let route;
- if (ssrContext) {
- route = router.resolve(ssrContext.url).route;
- } else {
- const path = getLocation(router.options.base, router.options.mode);
- route = router.resolve(path).route;
- }
- // Set context to app.context
- await setContext(app, {
- store,
- route,
- next,
- error: app.nuxt.error.bind(app),
- payload: ssrContext ? ssrContext.payload : undefined,
- req: ssrContext ? ssrContext.req : undefined,
- res: ssrContext ? ssrContext.res : undefined,
- beforeRenderFns: ssrContext ? ssrContext.beforeRenderFns : undefined,
- beforeSerializeFns: ssrContext ? ssrContext.beforeSerializeFns : undefined,
- ssrContext
- });
- function inject(key, value) {
- if (!key) {
- throw new Error('inject(key, value) has no key provided');
- }
- if (value === undefined) {
- throw new Error(`inject('${key}', value) has no value provided`);
- }
- key = '$' + key;
- // Add into app
- app[key] = value;
- // Add into context
- if (!app.context[key]) {
- app.context[key] = value;
- }
- // Add into store
- store[key] = app[key];
- // Check if plugin not already installed
- const installKey = '__nuxt_' + key + '_installed__';
- if (external_vue_default.a[installKey]) {
- return;
- }
- external_vue_default.a[installKey] = true;
- // Call Vue.use() to install the plugin into vm
- external_vue_default.a.use(() => {
- if (!Object.prototype.hasOwnProperty.call(external_vue_default.a.prototype, key)) {
- Object.defineProperty(external_vue_default.a.prototype, key, {
- get() {
- return this.$root.$options[key];
- }
- });
- }
- });
- }
- // Inject runtime config as $config
- inject('config', config);
- if (false) {}
- // Add enablePreview(previewData = {}) in context for plugins
- if (false) {}
- // Plugin execution
- if (typeof /* Cannot get final name for export "default" in "./.nuxt/components/plugin.js" (known exports: , known reexports: ) */ undefined === 'function') {
- await /* Cannot get final name for export "default" in "./.nuxt/components/plugin.js" (known exports: , known reexports: ) */ undefined(app.context, inject);
- }
- if (typeof cookie_universal_nuxt === 'function') {
- await cookie_universal_nuxt(app.context, inject);
- }
- if (typeof _nuxt_axios === 'function') {
- await _nuxt_axios(app.context, inject);
- }
- if (typeof /* Cannot get final name for export "default" in "./plugins/element-ui.js" (known exports: , known reexports: ) */ undefined === 'function') {
- await /* Cannot get final name for export "default" in "./plugins/element-ui.js" (known exports: , known reexports: ) */ undefined(app.context, inject);
- }
- if (typeof plugins_axios === 'function') {
- await plugins_axios(app.context, inject);
- }
- if (typeof plugins_router === 'function') {
- await plugins_router(app.context, inject);
- }
- if (typeof /* Cannot get final name for export "default" in "./plugins/utils.js" (known exports: , known reexports: ) */ undefined === 'function') {
- await /* Cannot get final name for export "default" in "./plugins/utils.js" (known exports: , known reexports: ) */ undefined(app.context, inject);
- }
- if (typeof /* Cannot get final name for export "default" in "./plugins/oss.js" (known exports: , known reexports: ) */ undefined === 'function') {
- await /* Cannot get final name for export "default" in "./plugins/oss.js" (known exports: , known reexports: ) */ undefined(app.context, inject);
- }
- if (false) {}
- if (false) {}
- if (false) {}
- if (false) {}
- if (false) {}
- // Lock enablePreview in context
- if (false) {}
- // Wait for async component to be resolved first
- await new Promise((resolve, reject) => {
- // Ignore 404s rather than blindly replacing URL in browser
- if (false) {}
- router.replace(app.context.route.fullPath, resolve, err => {
- // https://github.com/vuejs/vue-router/blob/v3.4.3/src/util/errors.js
- if (!err._isRouter) return reject(err);
- if (err.type !== 2 /* NavigationFailureType.redirected */) return resolve();
- // navigated to a different route in router guard
- const unregister = router.afterEach(async (to, from) => {
- if ( true && ssrContext && ssrContext.url) {
- ssrContext.url = to.fullPath;
- }
- app.context.route = await getRouteData(to);
- app.context.params = to.params || {};
- app.context.query = to.query || {};
- unregister();
- resolve();
- });
- });
- });
- return {
- store,
- app,
- router
- };
- }
- // CONCATENATED MODULE: ./.nuxt/components/nuxt-link.server.js
- /* harmony default export */ var nuxt_link_server = ({
- name: 'NuxtLink',
- extends: external_vue_default.a.component('RouterLink'),
- props: {
- prefetch: {
- type: Boolean,
- default: true
- },
- noPrefetch: {
- type: Boolean,
- default: false
- }
- }
- });
- // CONCATENATED MODULE: ./.nuxt/server.js
- // should be included after ./index.js
- // Update serverPrefetch strategy
- external_vue_default.a.config.optionMergeStrategies.serverPrefetch = external_vue_default.a.config.optionMergeStrategies.created;
- // Fetch mixin
- if (!external_vue_default.a.__nuxt__fetch__mixin__) {
- external_vue_default.a.mixin(fetch_server);
- external_vue_default.a.__nuxt__fetch__mixin__ = true;
- }
- // Component: <NuxtLink>
- external_vue_default.a.component(nuxt_link_server.name, nuxt_link_server);
- external_vue_default.a.component('NLink', nuxt_link_server);
- if (!global.fetch) {
- global.fetch = external_node_fetch_native_default.a;
- }
- const noopApp = () => new external_vue_default.a({
- render: h => h('div', {
- domProps: {
- id: '__nuxt'
- }
- })
- });
- const createNext = ssrContext => opts => {
- // If static target, render on client-side
- ssrContext.redirected = opts;
- if (ssrContext.target === 'static' || !ssrContext.res) {
- ssrContext.nuxt.serverRendered = false;
- return;
- }
- let fullPath = Object(external_ufo_["withQuery"])(opts.path, opts.query);
- const $config = ssrContext.nuxt.config || {};
- const routerBase = $config._app && $config._app.basePath || '/';
- if (!fullPath.startsWith('http') && routerBase !== '/' && !fullPath.startsWith(routerBase)) {
- fullPath = Object(external_ufo_["joinURL"])(routerBase, fullPath);
- }
- // Avoid loop redirect
- if (decodeURI(fullPath) === decodeURI(ssrContext.url)) {
- ssrContext.redirected = false;
- return;
- }
- ssrContext.res.writeHead(opts.status, {
- Location: Object(external_ufo_["normalizeURL"])(fullPath)
- });
- ssrContext.res.end();
- };
- // This exported function will be called by `bundleRenderer`.
- // This is where we perform data-prefetching to determine the
- // state of our application before actually rendering it.
- // Since data fetching is async, this function is expected to
- // return a Promise that resolves to the app instance.
- /* harmony default export */ var server = __webpack_exports__["default"] = (async ssrContext => {
- // Create ssrContext.next for simulate next() of beforeEach() when wanted to redirect
- ssrContext.redirected = false;
- ssrContext.next = createNext(ssrContext);
- // Used for beforeNuxtRender({ Components, nuxtState })
- ssrContext.beforeRenderFns = [];
- // for beforeSerialize(nuxtState)
- ssrContext.beforeSerializeFns = [];
- // Nuxt object (window.{{globals.context}}, defaults to window.__NUXT__)
- ssrContext.nuxt = {
- layout: 'default',
- data: [],
- fetch: {},
- error: null,
- state: null,
- serverRendered: true,
- routePath: ''
- };
- ssrContext.fetchCounters = {};
- // Remove query from url is static target
- // Public runtime config
- ssrContext.nuxt.config = ssrContext.runtimeConfig.public;
- if (ssrContext.nuxt.config._app) {
- __webpack_require__.p = Object(external_ufo_["joinURL"])(ssrContext.nuxt.config._app.cdnURL, ssrContext.nuxt.config._app.assetsPath);
- }
- // Create the app definition and the instance (created for each request)
- const {
- app,
- router,
- store
- } = await createApp(ssrContext, ssrContext.runtimeConfig.private);
- const _app = new external_vue_default.a(app);
- // Add ssr route path to nuxt context so we can account for page navigation between ssr and csr
- ssrContext.nuxt.routePath = app.context.route.path;
- // Add meta infos (used in renderer.js)
- ssrContext.meta = _app.$meta();
- // Keep asyncData for each matched component in ssrContext (used in app/utils.js via this.$ssrContext)
- ssrContext.asyncData = {};
- const beforeRender = async () => {
- // Call beforeNuxtRender() methods
- await Promise.all(ssrContext.beforeRenderFns.map(fn => promisify(fn, {
- Components,
- nuxtState: ssrContext.nuxt
- })));
- ssrContext.rendered = () => {
- // Call beforeSerialize() hooks
- ssrContext.beforeSerializeFns.forEach(fn => fn(ssrContext.nuxt));
- // Add the state from the vuex store
- ssrContext.nuxt.state = store.state;
- };
- };
- const renderErrorPage = async () => {
- // Don't server-render the page in static target
- if (ssrContext.target === 'static') {
- ssrContext.nuxt.serverRendered = false;
- }
- // Load layout for error page
- const layout = (layouts_error.options || layouts_error).layout;
- const errLayout = typeof layout === 'function' ? layout.call(layouts_error, app.context) : layout;
- ssrContext.nuxt.layout = errLayout || 'default';
- await _app.loadLayout(errLayout);
- _app.setLayout(errLayout);
- await beforeRender();
- return _app;
- };
- const render404Page = () => {
- app.context.error({
- statusCode: 404,
- path: ssrContext.url,
- message: 'This page could not be found'
- });
- return renderErrorPage();
- };
- // Components are already resolved by setContext -> getRouteData (app/utils.js)
- const Components = getMatchedComponents(app.context.route);
- /*
- ** Dispatch store nuxtServerInit
- */
- if (store._actions && store._actions.nuxtServerInit) {
- try {
- await store.dispatch('nuxtServerInit', app.context);
- } catch (err) {
- console.debug('Error occurred when calling nuxtServerInit: ', err.message);
- throw err;
- }
- }
- // ...If there is a redirect or an error, stop the process
- if (ssrContext.redirected) {
- return noopApp();
- }
- if (ssrContext.nuxt.error) {
- return renderErrorPage();
- }
- /*
- ** Call global middleware (nuxt.config.js)
- */
- let midd = ["redirect"];
- midd = midd.map(name => {
- if (typeof name === 'function') {
- return name;
- }
- if (typeof _nuxt_middleware[name] !== 'function') {
- app.context.error({
- statusCode: 500,
- message: 'Unknown middleware ' + name
- });
- }
- return _nuxt_middleware[name];
- });
- await middlewareSeries(midd, app.context);
- // ...If there is a redirect or an error, stop the process
- if (ssrContext.redirected) {
- return noopApp();
- }
- if (ssrContext.nuxt.error) {
- return renderErrorPage();
- }
- /*
- ** Set layout
- */
- let layout = Components.length ? Components[0].options.layout : layouts_error.layout;
- if (typeof layout === 'function') {
- layout = layout(app.context);
- }
- await _app.loadLayout(layout);
- if (ssrContext.nuxt.error) {
- return renderErrorPage();
- }
- layout = _app.setLayout(layout);
- ssrContext.nuxt.layout = _app.layoutName;
- /*
- ** Call middleware (layout + pages)
- */
- midd = [];
- layout = sanitizeComponent(layout);
- if (layout.options.middleware) {
- midd = midd.concat(layout.options.middleware);
- }
- Components.forEach(Component => {
- if (Component.options.middleware) {
- midd = midd.concat(Component.options.middleware);
- }
- });
- midd = midd.map(name => {
- if (typeof name === 'function') {
- return name;
- }
- if (typeof _nuxt_middleware[name] !== 'function') {
- app.context.error({
- statusCode: 500,
- message: 'Unknown middleware ' + name
- });
- }
- return _nuxt_middleware[name];
- });
- await middlewareSeries(midd, app.context);
- // ...If there is a redirect or an error, stop the process
- if (ssrContext.redirected) {
- return noopApp();
- }
- if (ssrContext.nuxt.error) {
- return renderErrorPage();
- }
- /*
- ** Call .validate()
- */
- let isValid = true;
- try {
- for (const Component of Components) {
- if (typeof Component.options.validate !== 'function') {
- continue;
- }
- isValid = await Component.options.validate(app.context);
- if (!isValid) {
- break;
- }
- }
- } catch (validationError) {
- // ...If .validate() threw an error
- app.context.error({
- statusCode: validationError.statusCode || '500',
- message: validationError.message
- });
- return renderErrorPage();
- }
- // ...If .validate() returned false
- if (!isValid) {
- // Render a 404 error page
- return render404Page();
- }
- // If no Components found, returns 404
- if (!Components.length) {
- return render404Page();
- }
- // Call asyncData & fetch hooks on components matched by the route.
- const asyncDatas = await Promise.all(Components.map(Component => {
- const promises = [];
- // Call asyncData(context)
- if (Component.options.asyncData && typeof Component.options.asyncData === 'function') {
- const promise = promisify(Component.options.asyncData, app.context).then(asyncDataResult => {
- ssrContext.asyncData[Component.cid] = asyncDataResult;
- applyAsyncData(Component);
- return asyncDataResult;
- });
- promises.push(promise);
- } else {
- promises.push(null);
- }
- // Call fetch(context)
- if (Component.options.fetch && Component.options.fetch.length) {
- promises.push(Component.options.fetch(app.context));
- } else {
- promises.push(null);
- }
- return Promise.all(promises);
- }));
- // datas are the first row of each
- ssrContext.nuxt.data = asyncDatas.map(r => r[0] || {});
- // ...If there is a redirect or an error, stop the process
- if (ssrContext.redirected) {
- return noopApp();
- }
- if (ssrContext.nuxt.error) {
- return renderErrorPage();
- }
- // Call beforeNuxtRender methods & add store state
- await beforeRender();
- return _app;
- });
- /***/ }),
- /* 108 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- // ESM COMPAT FLAG
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/PcHeader.vue?vue&type=template&id=7da31f58&scoped=true
- var render = function render() {
- var _vm = this,
- _c = _vm._self._c;
- return _c('header', {
- style: {
- backgroundColor: `${_vm.bgColor}`
- }
- }, [_vm._ssrNode("<div class=\"topbar com-margin-auto com-flex com-width-1400\" data-v-7da31f58>", "</div>", [_c('nuxt-link', {
- staticStyle: {
- "max-height": "100px"
- },
- attrs: {
- "to": {
- name: 'index'
- }
- }
- }, [_c('img', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: _vm.websitelogo.length,
- expression: "websitelogo.length"
- }],
- attrs: {
- "src": `${_vm.websitelogo}`,
- "alt": "Logo",
- "id": "logo"
- }
- })]), _vm._ssrNode(" "), _vm._ssrNode("<div class=\"search-input\" data-v-7da31f58>", "</div>", [_c('el-input', {
- attrs: {
- "placeholder": "Search item here"
- },
- on: {
- "focus": _vm.focus,
- "blur": _vm.blur
- },
- nativeOn: {
- "keyup": function ($event) {
- if (!$event.type.indexOf('key') && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")) return null;
- return _vm.goSearchResultPage.apply(null, arguments);
- }
- },
- model: {
- value: _vm.keyword,
- callback: function ($$v) {
- _vm.keyword = $$v;
- },
- expression: "keyword"
- }
- }, [_c('i', {
- staticClass: "el-input__icon el-icon-search",
- attrs: {
- "slot": "suffix"
- },
- on: {
- "click": _vm.goSearchResultPage
- },
- slot: "suffix"
- })]), _vm._ssrNode(" "), _c('div', {
- directives: [{
- name: "loading",
- rawName: "v-loading",
- value: _vm.loading,
- expression: "loading"
- }],
- staticClass: "search-detail flex column stretch",
- style: {
- display: _vm.showType
- }
- }, [!_vm.loading && _vm.result.cate.length < 1 && _vm.productsList.length < 1 ? _vm._ssrNode("<div class=\"flex-auto flex center stretch no-result\" data-v-7da31f58>", "</div>", [_vm._ssrNode(_vm._ssrEscape("\n No results found for “" + _vm._s(_vm.keyword) + "”\n "))], 2) : _vm._ssrNode("<div class=\"flex-auto flex stretch\" style=\"overflow: hidden\" data-v-7da31f58>", "</div>", [_vm._ssrNode("<div class=\"category-list flex column start stretch\" data-v-7da31f58>", "</div>", [_vm._ssrNode("<p class=\"autocomplete-title sub\" data-v-7da31f58>CATEGORIES</p> "), _vm._ssrNode("<ul class=\"stretch\" data-v-7da31f58>", "</ul>", [_vm._l(_vm.result.firstCate, function (item) {
- return _vm._ssrNode("<li class=\"flex column stretch\" data-v-7da31f58>", "</li>", [_c('nuxt-link', {
- attrs: {
- "to": {
- name: 'category-firstCategory',
- params: {
- firstCategory: item.name.replace(/\s+/g, '-').replace('-&', '').toLowerCase()
- }
- }
- }
- }, [_c('p', [_vm._v(_vm._s(item.name))])])], 1);
- }), _vm._ssrNode(" " + (_vm.result.subCate.length ? "<p class=\"autocomplete-title\" data-v-7da31f58>\n SUB CATEGORIES\n </p>" : "<!---->") + " "), _vm._l(_vm.result.subCate, function (item) {
- return _vm._ssrNode("<li class=\"flex column stretch\" data-v-7da31f58>", "</li>", [item.lev === 2 ? _c('nuxt-link', {
- attrs: {
- "to": {
- name: 'category-firstCategory-secondCategory',
- params: {
- firstCategory: item.parentName.replace(/\s+/g, '-').replace('-&', '').toLowerCase(),
- secondCategory: item.name.replace(/\s+/g, '-').replace('-&', '').toLowerCase()
- }
- }
- }
- }, [_c('p', [_vm._v(_vm._s(item.name))])]) : _c('nuxt-link', {
- attrs: {
- "to": {
- name: 'category-firstCategory-secondCategory-thirdCategory',
- params: {
- firstCategory: item.grandName.replace(/\s+/g, '-').replace('-&', '').toLowerCase(),
- secondCategory: item.parentName.replace(/\s+/g, '-').replace('-&', '').toLowerCase(),
- thirdCategory: item.name.replace(/\s+/g, '-').replace('-&', '').toLowerCase()
- }
- }
- }
- }, [_c('p', [_vm._v(_vm._s(item.name))])])], 1);
- })], 2)], 2), _vm._ssrNode(" "), _vm._ssrNode("<div class=\"product-list flex-auto flex column stretch\" data-v-7da31f58>", "</div>", [_vm._ssrNode("<div class=\"flex between start\" data-v-7da31f58>", "</div>", [_vm._ssrNode("<p class=\"autocomplete-title\" data-v-7da31f58>PRODUCTS</p> "), _vm.result.total ? _c('nuxt-link', {
- attrs: {
- "to": {
- name: 'category-searchResult',
- query: {
- keyword: _vm.keyword
- }
- }
- }
- }, [_c('div', {
- staticClass: "seeAllResult"
- }, [_vm._v("\n Show all " + _vm._s(_vm.result.total) + " Results\n ")])]) : _vm._e()], 2), _vm._ssrNode(" "), _vm._ssrNode("<ul class=\"flex-auto flex column stretch\" style=\"overflow-y: auto\" data-v-7da31f58>", "</ul>", [_vm._l(_vm.productsList, function (item) {
- return _vm._ssrNode("<li data-v-7da31f58>", "</li>", [_c('nuxt-link', {
- attrs: {
- "to": {
- name: 'product-code',
- params: {
- code: item.product_code
- }
- }
- }
- }, [_c('img', {
- attrs: {
- "src": item.image && !_vm.$mediaRegExp.test(item.image) ? _vm.$OSS_PREFIX + item.image : _vm.$utils.generateResizedImageUrl(item.image, 100),
- "alt": ""
- }
- }), _vm._v(" "), _c('div', {
- staticClass: "product-info"
- }, [_c('p', [_vm._v(_vm._s(item.product_name))]), _vm._v(" "), _c('p', [_vm._v(_vm._s(item.product_code))])])])], 1);
- }), _vm._ssrNode(" " + (!_vm.loading && _vm.productsList.length < 1 ? "<div class=\"no-result\" data-v-7da31f58>" + _vm._ssrEscape("\n No results found for “" + _vm._s(_vm.keyword) + "”\n ") + "</div>" : "<!---->"))], 2)], 2)], 2)])], 2), _vm._ssrNode(" " + (_vm.email ? "<div class=\"topbar-item com-flex\" style=\"cursor: default\" data-v-7da31f58><img" + _vm._ssrAttr("src", __webpack_require__(95)) + " alt=\"help\" data-v-7da31f58> <div class=\"topbar-item-right com-flex-item\" data-v-7da31f58><p data-v-7da31f58>1300 369 252</p></div></div>" : "<!---->") + " "), _vm._ssrNode("<div class=\"topbar-item com-flex\" data-v-7da31f58>", "</div>", [_vm._ssrNode((false ? undefined : "<!---->") + " "), false ? undefined : _vm._e()], 2)], 2), _vm._ssrNode(" "), _vm._ssrNode("<nav data-v-7da31f58>", "</nav>", [_vm._ssrNode("<ul class=\"com-width-1400 com-minwidth-1024 com-margin-auto\" data-v-7da31f58>", "</ul>", [_vm._ssrNode("<li class=\"nav-list\" data-v-7da31f58>", "</li>", [_vm._ssrNode("<div class=\"nav-list-title\" data-v-7da31f58><span class=\"shopProducts\" data-v-7da31f58>\n Shop Products\n <i" + _vm._ssrClass(null, _vm.isShopBlock ? 'el-icon-arrow-up' : 'el-icon-arrow-down') + " data-v-7da31f58></i></span></div> "), _c('Transition', {
- attrs: {
- "name": "category"
- }
- }, [_c('div', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: _vm.isShopBlock,
- expression: "isShopBlock"
- }],
- staticClass: "nav-menu border-radius",
- on: {
- "click": _vm.closeAllBlock
- }
- }, [_c('div', {
- staticClass: "nav-menu-content"
- }, _vm._l(_vm.categoryList, function (item1) {
- return _c('div', {
- key: item1.id,
- staticClass: "nav-menu-item"
- }, [_c('div', {
- staticClass: "primary-classification"
- }, [_c('nuxt-link', {
- attrs: {
- "to": {
- name: 'category-firstCategory',
- params: {
- firstCategory: item1.name.replace(/\s+/g, '-').replace('-&', '').toLowerCase()
- }
- }
- }
- }, [_c('div', {
- staticClass: "menu-item-icon"
- }, [_c('img', {
- attrs: {
- "src": item1.style && !_vm.$mediaRegExp.test(item1.style) ? _vm.$OSS_PREFIX + item1.style : item1.style,
- "alt": ""
- }
- })]), _vm._v(" "), _c('div', {
- staticClass: "menu-item-title"
- }, [_vm._v("\n " + _vm._s(item1.name) + "\n ")])]), _vm._v(" "), _c('div', {
- staticClass: "menu-separator"
- })], 1), _vm._v(" "), _vm._l(item1.child, function (item2) {
- return _c('div', {
- key: item2.id,
- staticClass: "secondary-classification"
- }, [_c('nuxt-link', {
- attrs: {
- "to": {
- name: 'category-firstCategory-secondCategory',
- params: {
- firstCategory: item1.name.replace(/\s+/g, '-').replace('-&', '').toLowerCase(),
- secondCategory: item2.name.replace(/\s+/g, '-').replace('-&', '').toLowerCase()
- }
- }
- }
- }, [_vm._v("\n " + _vm._s(item2.name) + "\n ")])], 1);
- })], 2);
- }), 0)])])], 2), _vm._ssrNode(" "), _vm._ssrNode("<li class=\"nav-list\" data-v-7da31f58>", "</li>", [_vm._ssrNode("<div class=\"nav-list-title\" data-v-7da31f58>", "</div>", [_c('nuxt-link', {
- attrs: {
- "to": {
- name: 'category',
- query: {
- feature: 54
- }
- },
- "target": "_self"
- }
- }, [_vm._v("\n New Products\n ")])], 1)])], 2)]), _vm._ssrNode(" <div class=\"header-redLine\" data-v-7da31f58></div>")], 2);
- };
- var staticRenderFns = [];
- // CONCATENATED MODULE: ./components/PcHeader.vue?vue&type=template&id=7da31f58&scoped=true
- // EXTERNAL MODULE: external "vuex"
- var external_vuex_ = __webpack_require__(5);
- // EXTERNAL MODULE: ./node_modules/lodash.clonedeep/index.js
- var lodash_clonedeep = __webpack_require__(9);
- var lodash_clonedeep_default = /*#__PURE__*/__webpack_require__.n(lodash_clonedeep);
- // EXTERNAL MODULE: external "algoliasearch"
- var external_algoliasearch_ = __webpack_require__(31);
- var external_algoliasearch_default = /*#__PURE__*/__webpack_require__.n(external_algoliasearch_);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/PcHeader.vue?vue&type=script&lang=js
- /* harmony default export */ var PcHeadervue_type_script_lang_js = ({
- data() {
- return {
- // loaded: false,
- loading: false,
- timer: '',
- keyword: '',
- result: {
- cate: [],
- subCate: [],
- firstCate: []
- },
- showType: 'none',
- matchingList: [],
- categoryList: [],
- leadTime: [],
- budget: [],
- compareList: [],
- indentIdeasArticle: {},
- complianceArticle: {},
- isShopBlock: false,
- isLeadTimeBlock: false,
- isBudgetBlock: false,
- qtyList: [{
- value: 50,
- name: 50
- }, {
- value: 100,
- name: 100
- }, {
- value: 250,
- name: 250
- }, {
- value: 500,
- name: 500
- }, {
- value: 1000,
- name: '1,000'
- }, {
- value: 2500,
- name: '2,500'
- }, {
- value: 5000,
- name: '5,000'
- }, {
- value: 10000,
- name: '10,000'
- }],
- index: null,
- websitelogo: '',
- bgColor: '#fff',
- favicon: ''
- };
- },
- async fetch() {
- const p1 = this.$axios.post('/common/shopProductList').then(res => {
- if (res.code === 1) {
- this.categoryList = res.result;
- }
- });
- const p2 = this.$axios.get('/home/lead_time').then(res => {
- if (res.code === 1) {
- this.leadTime = res.result.sort((a, b) => a.rank - b.rank);
- }
- });
- const p3 = this.$axios.post('/common/goodsFilterList', {
- pid: 2
- }).then(res => {
- if (res.code === 1) {
- this.budget = res.result;
- }
- });
- const p4 = this.$axios.post('/home/articleLists', {
- state: 'au',
- keyword: 'Indent Ideas'
- }).then(res => {
- this.indentIdeasArticle = res.result.data[0] || {};
- });
- const p5 = this.$axios.post('/home/articleLists', {
- state: 'au',
- keyword: 'Compliance'
- }).then(res => {
- this.complianceArticle = res.result.data[0] || {};
- });
- // 并联异步操作,总耗时===耗时最长的单个请求。之前的逻辑是串联,总耗时为所有请求耗时的累加
- await Promise.all([p1, p2, p3, p4, p5]);
- },
- computed: {
- email() {
- var _this$$store$state$us;
- return (_this$$store$state$us = this.$store.state.userInfo) === null || _this$$store$state$us === void 0 ? void 0 : _this$$store$state$us.email;
- },
- compareLists() {
- return this.$store.state.compareList;
- },
- productsList() {
- var _this$result;
- if ((_this$result = this.result) !== null && _this$result !== void 0 && _this$result.goods) {
- return this.result.goods.map(item => {
- const temp = {
- ...item
- };
- if (item.img) {
- temp.image = !this.$mediaRegExp.test(item.img) ? this.$OSS_PREFIX + item.img : item.img;
- }
- return temp;
- });
- } else {
- return [];
- }
- }
- },
- watch: {
- keyword: {
- handler(newValue, oldValue) {
- // if (newValue.length > 2 && this.loaded) {
- if (newValue.length > 2) {
- this.debounce(this.search, 700);
- } else {
- setTimeout(() => {
- this.showType = 'none';
- }, 501);
- }
- },
- deep: true
- },
- compareLists: {
- handler(newValue, oldValue) {
- if (newValue) {
- this.compareList = lodash_clonedeep_default()(newValue);
- }
- },
- deep: true,
- immediate: true
- },
- $route(to, from) {
- var _this$favicon;
- if (to.path == from.path && to.query.keyword != from.query.keyword) {
- location.reload();
- }
- if (!to.query.keyword) {
- this.keyword = '';
- }
- if ((_this$favicon = this.favicon) !== null && _this$favicon !== void 0 && _this$favicon.length) {
- this.setFavicon(this.favicon);
- }
- }
- },
- beforeMount() {
- this.$store.dispatch('getShopInfo').then(res => {
- var _res$logo_icon;
- document.title = (res.title || '').toUpperCase();
- this.websitelogo = !this.$mediaRegExp.test(res.logo) ? this.$OSS_PREFIX + (/^\/.+/.test(res.logo) ? res.logo : `/${res.logo}`) : res.logo;
- this.bgColor = res.theme_color || '#fff';
- // res.logo_icon = 'uploads/catalog/image/20241031/7b2eeca1add8e56a5b831f7ad4ea354af92e9db4.png'
- if ((_res$logo_icon = res.logo_icon) !== null && _res$logo_icon !== void 0 && _res$logo_icon.length) {
- this.favicon = !this.$mediaRegExp.test(res.logo_icon) ? this.$OSS_PREFIX + (/^\/.+/.test(res.logo_icon) ? res.logo_icon : `/${res.logo_icon}`) : res.logo_icon;
- console.log(this.favicon, 'favicon');
- this.setFavicon(this.favicon);
- }
- });
- },
- created() {
- // this.$store.dispatch('getCompareList')
- },
- mounted() {
- // if (this.$route.query.keyword && this.$route.query.keyword.length) {
- // this.keyword = this.$route.query.keyword
- // }
- // setTimeout(() => {
- // this.loaded = true
- // }, 0)
- window.addEventListener('click', this.closeLeadtimeAndBudget);
- const client = external_algoliasearch_default()('OGR0RAPKVN', '19f480c6a3000b14705a78beadf19ab6');
- this.index = client.initIndex('product_ca');
- },
- beforeDestroy() {
- window.removeEventListener('click', this.closeLeadtimeAndBudget);
- },
- methods: {
- ...Object(external_vuex_["mapMutations"])(['openDialog', 'clearUserInfo', 'clearCompareList', 'getCompareList']),
- debounce(fn, wait) {
- if (this.timer !== null) {
- clearTimeout(this.timer);
- }
- this.timer = setTimeout(fn, wait);
- },
- setFavicon(str) {
- const link = document.getElementById('favicon');
- link.href = str;
- },
- search() {
- this.result = {
- cate: [],
- subCate: [],
- firstCate: []
- };
- this.showType = 'flex';
- this.loading = true;
- const key = this.keyword ? this.keyword.trim() : '';
- if (this.index) {
- this.index.search(key, {
- hitsPerPage: 1000
- }).then(({
- nbHits,
- hits
- }) => {
- const temp = {
- goods: [],
- total: nbHits || hits.length || 0,
- cate: [],
- firstCate: [],
- subCate: []
- };
- const t1 = [];
- const t2 = [];
- hits.filter(i => i.status === 1 || i.status === '1' || i.status).forEach(item => {
- let colorImg = '';
- item.colour_imgs = JSON.parse(item.colour_imgs);
- item.colour_imgs.sort((a, b) => a.name.length - b.name.length);
- if (Array.isArray(item.colour_imgs) && item.colour_imgs.length) {
- item.colour_imgs.forEach(colorItem => {
- if (colorItem.name && colorItem.name.length) {
- if (new RegExp(colorItem.name.toLowerCase(), 'i').test(key)) {
- console.log(item.product_code, colorItem.name, 'replace');
- colorImg = colorItem.img;
- } else if (/\s/.test(colorItem.name) && colorItem.name.split(' ').filter(a => a.length > 0).some(b => new RegExp(b.toLowerCase(), 'i').test(key))) {
- console.log(item.product_code, colorItem.name, 'advance replace');
- colorImg = colorItem.img;
- }
- }
- });
- item.colour_imgs.forEach(i => {
- if (i.name && i.name.length) {
- if (key.toLowerCase().includes(i.name.toLowerCase())) {
- console.log(item.product_code, i.name, 'complete replace');
- colorImg = i.img;
- }
- }
- });
- console.log('---');
- }
- temp.goods.push({
- ...item,
- img: colorImg || item.image || item.img,
- product_name: item.product_name || item.name
- });
- if (!item.category_id) return;
- const id = parseInt(item.category_id);
- const categoryResult = this.getCategoryFromTree(id, this.categoryList);
- switch (categoryResult.lev) {
- case 1:
- if (!t1.includes(id)) {
- t1.push(id);
- temp.firstCate.push(categoryResult);
- }
- break;
- case 2:
- case 3:
- if (!t2.includes(id)) {
- t2.push(id);
- temp.subCate.push(categoryResult);
- }
- // 当前商品在2 3 级, 搜索出来的分类里面应同时展示1级.
- if (!t1.includes(categoryResult.root.id)) {
- t1.push(categoryResult.root.id);
- temp.firstCate.push(categoryResult.root);
- }
- // no default
- }
- });
- this.result = temp;
- }).finally(() => {
- this.loading = false;
- });
- }
- },
- focus() {
- clearTimeout(this.timer);
- if (this.keyword) {
- this.showType = 'flex';
- }
- },
- blur() {
- this.timer = setTimeout(() => {
- this.showType = 'none';
- }, 200);
- },
- goSearchResultPage() {
- // 匹配同组件的路由更改query时, 页面不会被刷新
- // this.$router.push({
- // name: 'category-searchResult',
- // query: { keyword: this.keyword },
- // })
- location.href = location.origin + `/category/searchResult?keyword=${encodeURIComponent(this.keyword)}`;
- },
- logout() {
- this.$store.dispatch('logout').then(() => {
- this.$router.push('/');
- });
- },
- compareAll() {
- if (this.compareList.length) {
- this.$router.push('/home/compareList');
- }
- },
- clearCompare(id) {
- this.$axios.post('home/compare_clear', {
- id,
- compare_keys: 'keys'
- }).then(res => {
- if (res.code === 1) {
- this.compareList.splice(this.compareList.findIndex(item => item.id === id), 1);
- }
- });
- },
- clearAll() {
- if (this.compareList.length) {
- this.$axios.post('home/compare_clear', {
- id: 0,
- compare_keys: 'keys'
- }).then(res => {
- if (res.code === 1) {
- this.clearCompareList();
- }
- });
- }
- },
- openShopProduct() {
- this.isShopBlock = !this.isShopBlock;
- this.isLeadTimeBlock = false;
- this.isBudgetBlock = false;
- },
- openLeadTime() {
- this.isLeadTimeBlock = !this.isLeadTimeBlock;
- this.isShopBlock = false;
- this.isBudgetBlock = false;
- },
- openBudget() {
- this.isBudgetBlock = !this.isBudgetBlock;
- this.isLeadTimeBlock = false;
- this.isShopBlock = false;
- },
- closeAllBlock() {
- this.isShopBlock = false;
- this.isLeadTimeBlock = false;
- this.isBudgetBlock = false;
- },
- closeLeadtimeAndBudget(e) {
- var _e$target;
- const className = (_e$target = e.target) === null || _e$target === void 0 ? void 0 : _e$target.className;
- if (!['shopProducts', 'LeadTime', 'Budget'].includes(className)) {
- this.isShopBlock = false;
- this.isLeadTimeBlock = false;
- this.isBudgetBlock = false;
- }
- },
- closePopoverAndNavigate() {
- this.$refs.userPopover.doClose();
- },
- // 从分类树数据里面找到对应分类
- getCategoryFromTree(id, tree) {
- let result = {};
- if (!tree.length) return result;
- tree.forEach(i => {
- if (i.id === id) {
- result = lodash_clonedeep_default()(i);
- result.lev = 1;
- }
- if (!Array.isArray(i.child)) return;
- i.child.forEach(secondCate => {
- if (secondCate.id === id) {
- result = lodash_clonedeep_default()(secondCate);
- result.parentName = i.name;
- result.lev = 2;
- result.root = {
- name: i.name,
- id: i.id,
- pid: 0
- };
- }
- if (!Array.isArray(secondCate.child)) return;
- secondCate.child.forEach(thirdCate => {
- if (thirdCate.id === id) {
- result = lodash_clonedeep_default()(thirdCate);
- result.parentName = secondCate.name;
- result.grandName = i.name;
- result.lev = 3;
- result.root = {
- name: i.name,
- id: i.id,
- pid: 0
- };
- }
- });
- });
- });
- return result;
- }
- }
- });
- // CONCATENATED MODULE: ./components/PcHeader.vue?vue&type=script&lang=js
- /* harmony default export */ var components_PcHeadervue_type_script_lang_js = (PcHeadervue_type_script_lang_js);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(2);
- // CONCATENATED MODULE: ./components/PcHeader.vue
- function injectStyles (context) {
-
- var style0 = __webpack_require__(96)
- if (style0.__inject__) style0.__inject__(context)
- }
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- components_PcHeadervue_type_script_lang_js,
- render,
- staticRenderFns,
- false,
- injectStyles,
- "7da31f58",
- "4aa12e6e"
-
- )
- /* harmony default export */ var PcHeader = __webpack_exports__["default"] = (component.exports);
- /***/ }),
- /* 109 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- // ESM COMPAT FLAG
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/PcFooter.vue?vue&type=template&id=657ebcee&scoped=true
- var render = function render() {
- var _vm = this,
- _c = _vm._self._c;
- return _c('footer', [_vm.footerBannerList.length > 0 ? _vm._ssrNode("<div class=\"footer-top\" data-v-657ebcee>", "</div>", [_c('el-image', {
- staticClass: "footer-banner",
- attrs: {
- "lazy": "",
- "src": _vm.footerBannerList[0].image,
- "alt": "",
- "fit": "cover"
- }
- }), _vm._ssrNode(" "), _vm._ssrNode("<div class=\"top-item\" data-v-657ebcee>", "</div>", [_vm._ssrNode("<p data-v-657ebcee>Need ideas? Samples? Art assistance?</p> <p data-v-657ebcee>Get in touch, we're here to help</p> "), _vm._ssrNode("<div class=\"btn btn-blue\" data-v-657ebcee>", "</div>", [_c('nuxt-link', {
- attrs: {
- "to": "/home/contactus"
- }
- }, [_vm._v(" Contact Us ")])], 1)], 2)], 2) : _vm._e(), _vm._ssrNode(" "), _vm._ssrNode("<div class=\"footer-middle com-margin-auto\" data-v-657ebcee>", "</div>", [_vm._ssrNode("<div class=\"middle com-margin-auto com-flex\" data-v-657ebcee>", "</div>", [_vm._ssrNode("<div class=\"middle-item-left\" data-v-657ebcee><img" + _vm._ssrAttr("src", _vm.websitelogo) + " alt=\"logo\" data-v-657ebcee></div> "), _vm._ssrNode("<div class=\"middle-item-right\" data-v-657ebcee>", "</div>", [_vm._ssrNode("<div class=\"item-menu\" data-v-657ebcee>", "</div>", [_vm._ssrNode("<div class=\"item-title\" data-v-657ebcee>OUR PRODUCTS</div> <div class=\"item-line\" data-v-657ebcee></div> "), _vm._ssrNode("<div class=\"item-content\" data-v-657ebcee>", "</div>", [_vm._ssrNode("<div data-v-657ebcee>", "</div>", [_vm._ssrNode("<ul data-v-657ebcee>", "</ul>", _vm._l(_vm.productList, function (item) {
- return _vm._ssrNode("<li data-v-657ebcee>", "</li>", [_c('nuxt-link', {
- attrs: {
- "to": {
- name: 'category-firstCategory',
- params: {
- firstCategory: item.name.replace(/\s+/g, '-').replace('-&', '').toLowerCase(),
- id: item.id
- }
- }
- }
- }, [_vm._v("\n " + _vm._s(item.name) + "\n ")])], 1);
- }), 0)])])], 2), _vm._ssrNode(" "), _vm._ssrNode("<div class=\"item-menu\" data-v-657ebcee>", "</div>", [_vm._ssrNode("<div class=\"item-title\" data-v-657ebcee>CUSTOMER SUPPORT</div> <div class=\"item-line\" data-v-657ebcee></div> "), _vm._ssrNode("<div class=\"item-content\" data-v-657ebcee>", "</div>", [_vm._ssrNode("<div data-v-657ebcee>", "</div>", [_c('nuxt-link', {
- attrs: {
- "to": "/home/termsConditions"
- }
- }, [_vm._v("\n Terms & Conditions\n ")])], 1)])], 2), _vm._ssrNode(" "), _vm._ssrNode("<div class=\"item-menu\" data-v-657ebcee>", "</div>", [_vm._ssrNode("<div class=\"item-title\" data-v-657ebcee>ADDITIONAL INFO</div> <div class=\"item-line\" data-v-657ebcee></div> "), _vm._ssrNode("<div class=\"item-content\" data-v-657ebcee>", "</div>", [_vm._ssrNode("<div data-v-657ebcee>", "</div>", [_c('nuxt-link', {
- attrs: {
- "to": "/home/contactus"
- }
- }, [_vm._v(" Contact Us ")]), _vm._ssrNode(" "), _c('nuxt-link', {
- attrs: {
- "to": {
- name: 'aboutus'
- }
- }
- }, [_vm._v("About Us\n ")])], 2)])], 2)], 2)], 2), _vm._ssrNode(" <div class=\"goTop\"" + _vm._ssrStyle(null, null, {
- display: _vm.flag_scroll ? '' : 'none'
- }) + " data-v-657ebcee><img" + _vm._ssrAttr("src", __webpack_require__(97)) + " alt data-v-657ebcee></div>")], 2), _vm._ssrNode(" <div class=\"footer-bottom\" data-v-657ebcee><div class=\"footer-bottom-item com-width-1400 com-margin-auto\" data-v-657ebcee><div class=\"footer-bottom-item-left\" data-v-657ebcee>" + _vm._ssrEscape(_vm._s(_vm.footerInfo)) + "</div> <div class=\"footer-bottom-item-right\" data-v-657ebcee>" + _vm._ssrEscape("\n " + _vm._s(_vm.indexConfigWebsite.version_info) + "\n ") + "</div></div></div> "), _c('dialog-XX-success', {
- attrs: {
- "imgShow": false,
- "visible": _vm.xxContentVisible,
- "desc": _vm.xxDesc
- },
- on: {
- "update:visible": function ($event) {
- _vm.xxContentVisible = $event;
- }
- }
- })], 2);
- };
- var staticRenderFns = [];
- // CONCATENATED MODULE: ./components/PcFooter.vue?vue&type=template&id=657ebcee&scoped=true
- // EXTERNAL MODULE: external "vuex"
- var external_vuex_ = __webpack_require__(5);
- // EXTERNAL MODULE: ./components/DIalogXXSuccess.vue + 4 modules
- var DIalogXXSuccess = __webpack_require__(30);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/PcFooter.vue?vue&type=script&lang=js
- /* harmony default export */ var PcFootervue_type_script_lang_js = ({
- components: {
- 'dialog-XX-success': DIalogXXSuccess["default"]
- },
- data() {
- return {
- footerBannerList: [],
- productList: [],
- indexConfigWebsite: [],
- aboutUsArticle: {},
- flag_scroll: false,
- scroll: 0,
- xxContentVisible: false,
- xxDesc: '',
- websitelogo: '',
- footerInfo: ''
- };
- },
- async fetch() {
- await this.$axios.post('home/indexBanner', {
- site: 1,
- type: 6
- }).then(res => {
- this.footerBannerList = res.result.data;
- // this.$store.commit("config/setConfigInfo", res.result);
- });
- await this.$axios.post('home/indexConfigWebsite', {
- site: 1
- }).then(res => {
- this.indexConfigWebsite = res.result;
- this.$store.commit('config/setConfigInfo', res.result);
- });
- await this.$axios.post('common/shopProductList').then(res => {
- this.productList = res.result;
- });
- await this.$axios.post('/home/articleLists', {
- state: 'au',
- keyword: 'About us'
- }).then(res => {
- this.aboutUsArticle = res.result.data[0];
- });
- },
- computed: {
- audit_status() {
- var _this$$store$state$us;
- return ((_this$$store$state$us = this.$store.state.userInfo) === null || _this$$store$state$us === void 0 ? void 0 : _this$$store$state$us.audit_status) === 1;
- },
- isLogin() {
- var _this$$store$state$us2;
- return !!((_this$$store$state$us2 = this.$store.state.userInfo) !== null && _this$$store$state$us2 !== void 0 && _this$$store$state$us2.email);
- }
- },
- beforeMount() {
- this.$store.dispatch('getShopInfo').then(res => {
- this.websitelogo = !this.$mediaRegExp.test(res.logo) ? this.$OSS_PREFIX + (/^\/.+/.test(res.logo) ? res.logo : `/${res.logo}`) : res.logo;
- this.footerInfo = res.footer || '';
- });
- },
- methods: {
- ...Object(external_vuex_["mapMutations"])('config', ['setConfigInfo']),
- ...Object(external_vuex_["mapMutations"])(['openDialog']),
- backTop() {
- var timer = setInterval(function () {
- document.documentElement.scrollTop -= 20;
- if (document.documentElement.scrollTop <= 0) {
- clearInterval(timer);
- }
- }, 10);
- },
- handleScroll() {
- const scrollobj = document.body.scrollTop + document.documentElement.scrollTop;
- if (scrollobj > 500) {
- this.flag_scroll = true;
- } else {
- this.flag_scroll = false;
- }
- },
- openLoginDialog() {
- if (this.$utils.checkLogin()) {
- this.$router.push({
- name: 'news-newsName',
- params: {
- newsName: 'About-Us'
- }
- });
- } else {
- this.openDialog();
- }
- },
- goApiWord() {
- if (this.isLogin) {
- if (this.$store.state.userInfo.open_platform) {
- const {
- href
- } = this.$router.resolve({
- name: 'home-api'
- });
- window.open(href, '_black');
- } else {
- this.submitLoading = false;
- this.xxContentVisible = true;
- this.xxDesc = 'If you encounter difficulties, please contact info@promocollection.com.au';
- // this.$message.error(
- // 'If you encounter difficulties, please contact info@promocollection.com.au'
- // )
- }
- } else {
- this.openDialog();
- }
- }
- },
- mounted() {
- window.addEventListener('scroll', this.handleScroll, true);
- },
- destroyed() {
- window.removeEventListener('scroll', this.scrollToTop);
- }
- });
- // CONCATENATED MODULE: ./components/PcFooter.vue?vue&type=script&lang=js
- /* harmony default export */ var components_PcFootervue_type_script_lang_js = (PcFootervue_type_script_lang_js);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(2);
- // CONCATENATED MODULE: ./components/PcFooter.vue
- function injectStyles (context) {
-
- var style0 = __webpack_require__(101)
- if (style0.__inject__) style0.__inject__(context)
- }
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- components_PcFootervue_type_script_lang_js,
- render,
- staticRenderFns,
- false,
- injectStyles,
- "657ebcee",
- "296eca7c"
-
- )
- /* harmony default export */ var PcFooter = __webpack_exports__["default"] = (component.exports);
- /***/ }),
- /* 110 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- // ESM COMPAT FLAG
- __webpack_require__.r(__webpack_exports__);
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/PcHeaderLite.vue?vue&type=template&id=47b2d662&scoped=true
- var render = function render() {
- var _vm = this,
- _c = _vm._self._c;
- return _c('div', {
- staticClass: "pc-header-lite"
- }, [_vm._ssrNode("<div class=\"home-link\" data-v-47b2d662><img" + _vm._ssrAttr("src", __webpack_require__(56)) + " alt=\"PromoCollection Logo\" id=\"logo\" data-v-47b2d662></div>")]);
- };
- var staticRenderFns = [];
- // CONCATENATED MODULE: ./components/PcHeaderLite.vue?vue&type=template&id=47b2d662&scoped=true
- // CONCATENATED MODULE: ./node_modules/babel-loader/lib??ref--2-0!./node_modules/@nuxt/components/dist/loader.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./components/PcHeaderLite.vue?vue&type=script&lang=js
- // 仅带一个logo的轻量级页首组件
- /* harmony default export */ var PcHeaderLitevue_type_script_lang_js = ({
- name: 'PcHeaderLite',
- methods: {
- toHome() {
- location.href = location.origin;
- }
- }
- });
- // CONCATENATED MODULE: ./components/PcHeaderLite.vue?vue&type=script&lang=js
- /* harmony default export */ var components_PcHeaderLitevue_type_script_lang_js = (PcHeaderLitevue_type_script_lang_js);
- // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
- var componentNormalizer = __webpack_require__(2);
- // CONCATENATED MODULE: ./components/PcHeaderLite.vue
- function injectStyles (context) {
-
- var style0 = __webpack_require__(103)
- if (style0.__inject__) style0.__inject__(context)
- }
- /* normalize component */
- var component = Object(componentNormalizer["a" /* default */])(
- components_PcHeaderLitevue_type_script_lang_js,
- render,
- staticRenderFns,
- false,
- injectStyles,
- "47b2d662",
- "1b7c613c"
-
- )
- /* harmony default export */ var PcHeaderLite = __webpack_exports__["default"] = (component.exports);
- /***/ }),
- /* 111 */
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
- "use strict";
- // ESM COMPAT FLAG
- __webpack_require__.r(__webpack_exports__);
- // EXTERNAL MODULE: external "js-cookie"
- var external_js_cookie_ = __webpack_require__(27);
- var external_js_cookie_default = /*#__PURE__*/__webpack_require__.n(external_js_cookie_);
- // CONCATENATED MODULE: ./utils/getCookie.js
- /* harmony default export */ var getCookie = ({
- //获取服务端cookie
- getcookiesInServer: function (req) {
- let service_cookie = {};
- req && req.headers.cookie && req.headers.cookie.split(';').forEach(function (val) {
- let parts = val.split('=');
- service_cookie[parts[0].trim()] = (parts[1] || '').trim();
- });
- return service_cookie;
- },
- //获取客户端cookie
- getcookiesInClient: function (key) {
- return external_js_cookie_default.a.get(key) ? external_js_cookie_default.a.get(key) : '';
- }
- });
- // EXTERNAL MODULE: ./node_modules/element-ui/lib/element-ui.common.js
- var element_ui_common = __webpack_require__(7);
- // CONCATENATED MODULE: ./middleware/auth.js
- /* harmony default export */ var auth = __webpack_exports__["default"] = (function ({
- store,
- route,
- req,
- res,
- redirect
- }) {
- let isClient = false;
- let isServer = true;
- let redirectURL = '/';
- var token;
- // var open_platform;
- // 在服务端
- if (isServer) {
- // 获取服务端cookie
- let cookies = getCookie.getcookiesInServer(req);
- // 获取当前服务端cookie中是否含有token字段
- token = cookies.token ? cookies.token : '';
- // open_platform = cookies.open_platform ? cookies.open_platform : ''
- }
- // 在客户端
- if (isClient) {
- // 获取客户端(本地)cookie中的token字段
- token = getCookie.getcookiesInClient('shop-token');
- // open_platform = getCookie.getcookiesInClient('open_platform')
- }
- // 判断是否获取到token
- // 未获取到,重定向到home頁
- if (!token) {
- Object(element_ui_common["Message"])({
- message: 'Please login first!',
- type: 'error',
- duration: 3 * 1000
- });
- redirect(redirectURL);
- }
- });
- /***/ }),
- /* 112 */
- /***/ (function(module, exports) {
- module.exports = require("number-precision");
- /***/ }),
- /* 113 */
- /***/ (function(module, exports) {
- module.exports = require("lodash");
- /***/ }),
- /* 114 */
- /***/ (function(module, exports) {
- module.exports = require("vue-infinite-loading");
- /***/ }),
- /* 115 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.add-all.js");
- /***/ }),
- /* 116 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.delete-all.js");
- /***/ }),
- /* 117 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.difference.js");
- /***/ }),
- /* 118 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.every.js");
- /***/ }),
- /* 119 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.filter.js");
- /***/ }),
- /* 120 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.find.js");
- /***/ }),
- /* 121 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.intersection.js");
- /***/ }),
- /* 122 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.is-disjoint-from.js");
- /***/ }),
- /* 123 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.is-subset-of.js");
- /***/ }),
- /* 124 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.is-superset-of.js");
- /***/ }),
- /* 125 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.join.js");
- /***/ }),
- /* 126 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.map.js");
- /***/ }),
- /* 127 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.reduce.js");
- /***/ }),
- /* 128 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.some.js");
- /***/ }),
- /* 129 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.symmetric-difference.js");
- /***/ }),
- /* 130 */
- /***/ (function(module, exports) {
- module.exports = require("core-js/modules/esnext.set.union.js");
- /***/ }),
- /* 131 */
- /***/ (function(module, exports) {
- module.exports = require("clipboard");
- /***/ }),
- /* 132 */
- /***/ (function(module, exports) {
- module.exports = require("html2canvas");
- /***/ }),
- /* 133 */
- /***/ (function(module, exports) {
- module.exports = require("vuedraggable");
- /***/ }),
- /* 134 */
- /***/ (function(module, exports) {
- module.exports = require("prismjs");
- /***/ }),
- /* 135 */
- /***/ (function(module, exports) {
- module.exports = require("prismjs/plugins/line-numbers/prism-line-numbers.min.js");
- /***/ }),
- /* 136 */
- /***/ (function(module, exports) {
- module.exports = require("js-base64");
- /***/ })
- /******/ ]);
- //# sourceMappingURL=server.js.map
|