123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300930193029303930493059306930793089309931093119312931393149315931693179318931993209321932293239324932593269327932893299330933193329333933493359336933793389339934093419342934393449345934693479348934993509351935293539354935593569357935893599360936193629363936493659366936793689369937093719372937393749375937693779378937993809381938293839384938593869387938893899390939193929393939493959396939793989399940094019402940394049405940694079408940994109411941294139414941594169417941894199420942194229423942494259426942794289429943094319432943394349435943694379438943994409441944294439444944594469447944894499450945194529453945494559456945794589459946094619462946394649465946694679468946994709471947294739474947594769477947894799480948194829483948494859486948794889489949094919492949394949495949694979498949995009501950295039504950595069507950895099510951195129513951495159516951795189519952095219522952395249525952695279528952995309531953295339534953595369537953895399540954195429543954495459546954795489549955095519552955395549555955695579558955995609561956295639564956595669567956895699570957195729573957495759576957795789579958095819582958395849585958695879588958995909591959295939594959595969597959895999600960196029603960496059606960796089609961096119612961396149615961696179618961996209621962296239624962596269627962896299630963196329633963496359636963796389639964096419642964396449645964696479648964996509651965296539654965596569657965896599660966196629663966496659666966796689669967096719672967396749675967696779678967996809681968296839684968596869687968896899690969196929693969496959696969796989699970097019702970397049705970697079708970997109711971297139714971597169717971897199720972197229723972497259726972797289729973097319732973397349735973697379738973997409741974297439744974597469747974897499750975197529753975497559756975797589759976097619762976397649765976697679768976997709771977297739774977597769777977897799780978197829783978497859786978797889789979097919792979397949795979697979798979998009801980298039804980598069807980898099810981198129813981498159816981798189819982098219822982398249825982698279828982998309831983298339834983598369837983898399840984198429843984498459846984798489849985098519852985398549855985698579858985998609861986298639864986598669867986898699870987198729873987498759876987798789879988098819882988398849885988698879888988998909891989298939894989598969897989898999900990199029903990499059906990799089909991099119912991399149915991699179918991999209921992299239924992599269927992899299930993199329933993499359936993799389939994099419942994399449945994699479948994999509951995299539954995599569957995899599960996199629963996499659966996799689969997099719972997399749975997699779978997999809981998299839984998599869987998899899990999199929993999499959996999799989999100001000110002100031000410005100061000710008100091001010011100121001310014100151001610017100181001910020100211002210023100241002510026100271002810029100301003110032100331003410035100361003710038100391004010041100421004310044100451004610047100481004910050100511005210053100541005510056100571005810059100601006110062100631006410065100661006710068100691007010071100721007310074100751007610077100781007910080100811008210083100841008510086100871008810089100901009110092100931009410095100961009710098100991010010101101021010310104101051010610107101081010910110101111011210113101141011510116101171011810119101201012110122101231012410125101261012710128101291013010131101321013310134101351013610137101381013910140101411014210143101441014510146101471014810149101501015110152101531015410155101561015710158101591016010161101621016310164101651016610167101681016910170101711017210173101741017510176101771017810179101801018110182101831018410185101861018710188101891019010191101921019310194101951019610197101981019910200102011020210203102041020510206102071020810209102101021110212102131021410215102161021710218102191022010221102221022310224102251022610227102281022910230102311023210233102341023510236102371023810239102401024110242102431024410245102461024710248102491025010251102521025310254102551025610257102581025910260102611026210263102641026510266102671026810269102701027110272102731027410275102761027710278102791028010281102821028310284102851028610287102881028910290102911029210293102941029510296102971029810299103001030110302103031030410305103061030710308103091031010311103121031310314103151031610317103181031910320103211032210323103241032510326103271032810329103301033110332103331033410335103361033710338103391034010341103421034310344103451034610347103481034910350103511035210353103541035510356103571035810359103601036110362103631036410365103661036710368103691037010371103721037310374103751037610377103781037910380103811038210383103841038510386103871038810389103901039110392103931039410395103961039710398103991040010401104021040310404104051040610407104081040910410104111041210413104141041510416104171041810419104201042110422104231042410425104261042710428104291043010431104321043310434104351043610437104381043910440104411044210443104441044510446104471044810449104501045110452104531045410455104561045710458104591046010461104621046310464104651046610467104681046910470104711047210473104741047510476104771047810479104801048110482104831048410485104861048710488104891049010491104921049310494104951049610497104981049910500105011050210503105041050510506105071050810509105101051110512105131051410515105161051710518105191052010521105221052310524105251052610527105281052910530105311053210533105341053510536105371053810539105401054110542105431054410545105461054710548105491055010551105521055310554105551055610557105581055910560105611056210563105641056510566105671056810569105701057110572105731057410575105761057710578105791058010581105821058310584105851058610587105881058910590105911059210593105941059510596105971059810599106001060110602106031060410605106061060710608106091061010611106121061310614106151061610617106181061910620106211062210623106241062510626106271062810629106301063110632106331063410635106361063710638106391064010641106421064310644106451064610647106481064910650106511065210653106541065510656106571065810659106601066110662106631066410665106661066710668106691067010671106721067310674106751067610677106781067910680106811068210683106841068510686106871068810689106901069110692106931069410695106961069710698106991070010701107021070310704107051070610707107081070910710107111071210713107141071510716107171071810719107201072110722107231072410725107261072710728107291073010731107321073310734107351073610737107381073910740107411074210743107441074510746107471074810749107501075110752107531075410755107561075710758107591076010761107621076310764107651076610767107681076910770107711077210773107741077510776107771077810779107801078110782107831078410785107861078710788107891079010791107921079310794107951079610797107981079910800108011080210803108041080510806108071080810809108101081110812108131081410815108161081710818108191082010821108221082310824108251082610827108281082910830108311083210833108341083510836108371083810839108401084110842108431084410845108461084710848108491085010851108521085310854108551085610857108581085910860108611086210863108641086510866108671086810869108701087110872108731087410875108761087710878108791088010881108821088310884108851088610887108881088910890108911089210893108941089510896108971089810899109001090110902109031090410905109061090710908109091091010911109121091310914109151091610917109181091910920109211092210923109241092510926109271092810929109301093110932109331093410935109361093710938109391094010941109421094310944109451094610947109481094910950109511095210953109541095510956109571095810959109601096110962109631096410965109661096710968109691097010971109721097310974109751097610977109781097910980109811098210983109841098510986109871098810989109901099110992109931099410995109961099710998109991100011001110021100311004110051100611007110081100911010110111101211013110141101511016110171101811019110201102111022110231102411025110261102711028110291103011031110321103311034110351103611037110381103911040110411104211043110441104511046110471104811049110501105111052110531105411055110561105711058110591106011061110621106311064110651106611067110681106911070110711107211073110741107511076110771107811079110801108111082110831108411085110861108711088110891109011091110921109311094110951109611097110981109911100111011110211103111041110511106111071110811109111101111111112111131111411115111161111711118111191112011121111221112311124111251112611127111281112911130111311113211133111341113511136111371113811139111401114111142111431114411145111461114711148111491115011151111521115311154111551115611157111581115911160111611116211163111641116511166111671116811169111701117111172111731117411175111761117711178111791118011181111821118311184111851118611187111881118911190111911119211193111941119511196111971119811199112001120111202112031120411205112061120711208112091121011211112121121311214112151121611217112181121911220112211122211223112241122511226112271122811229112301123111232112331123411235112361123711238112391124011241112421124311244112451124611247112481124911250112511125211253112541125511256112571125811259112601126111262112631126411265112661126711268112691127011271112721127311274112751127611277112781127911280112811128211283112841128511286112871128811289112901129111292112931129411295112961129711298112991130011301113021130311304113051130611307113081130911310113111131211313113141131511316113171131811319113201132111322113231132411325113261132711328113291133011331113321133311334113351133611337113381133911340113411134211343113441134511346113471134811349113501135111352113531135411355113561135711358113591136011361113621136311364113651136611367113681136911370113711137211373113741137511376113771137811379113801138111382113831138411385113861138711388113891139011391113921139311394113951139611397113981139911400114011140211403114041140511406114071140811409114101141111412114131141411415114161141711418114191142011421114221142311424114251142611427114281142911430114311143211433114341143511436114371143811439114401144111442114431144411445114461144711448114491145011451114521145311454114551145611457114581145911460114611146211463114641146511466114671146811469114701147111472114731147411475114761147711478114791148011481114821148311484114851148611487114881148911490114911149211493114941149511496114971149811499115001150111502115031150411505115061150711508115091151011511115121151311514115151151611517115181151911520115211152211523115241152511526115271152811529115301153111532115331153411535115361153711538115391154011541115421154311544115451154611547115481154911550115511155211553115541155511556115571155811559115601156111562115631156411565115661156711568115691157011571115721157311574115751157611577115781157911580115811158211583115841158511586115871158811589115901159111592115931159411595115961159711598115991160011601116021160311604116051160611607116081160911610116111161211613116141161511616116171161811619116201162111622116231162411625116261162711628116291163011631116321163311634116351163611637116381163911640116411164211643116441164511646116471164811649116501165111652116531165411655116561165711658116591166011661116621166311664116651166611667116681166911670116711167211673116741167511676116771167811679116801168111682116831168411685116861168711688116891169011691116921169311694116951169611697116981169911700117011170211703117041170511706117071170811709117101171111712117131171411715117161171711718117191172011721117221172311724117251172611727117281172911730117311173211733117341173511736117371173811739117401174111742117431174411745117461174711748117491175011751117521175311754117551175611757117581175911760117611176211763117641176511766117671176811769117701177111772117731177411775117761177711778117791178011781117821178311784117851178611787117881178911790117911179211793117941179511796117971179811799118001180111802118031180411805118061180711808118091181011811118121181311814118151181611817118181181911820118211182211823118241182511826118271182811829118301183111832118331183411835118361183711838118391184011841118421184311844118451184611847118481184911850118511185211853118541185511856118571185811859118601186111862118631186411865118661186711868118691187011871118721187311874118751187611877118781187911880118811188211883118841188511886118871188811889118901189111892118931189411895118961189711898118991190011901119021190311904119051190611907119081190911910119111191211913119141191511916119171191811919119201192111922119231192411925119261192711928119291193011931119321193311934119351193611937119381193911940119411194211943119441194511946119471194811949119501195111952119531195411955119561195711958119591196011961119621196311964119651196611967119681196911970119711197211973119741197511976119771197811979119801198111982119831198411985119861198711988119891199011991119921199311994119951199611997119981199912000120011200212003120041200512006120071200812009120101201112012120131201412015120161201712018120191202012021120221202312024120251202612027120281202912030120311203212033120341203512036120371203812039120401204112042120431204412045120461204712048120491205012051120521205312054120551205612057120581205912060120611206212063120641206512066120671206812069120701207112072120731207412075120761207712078120791208012081120821208312084120851208612087120881208912090120911209212093120941209512096120971209812099121001210112102121031210412105121061210712108121091211012111121121211312114121151211612117121181211912120121211212212123121241212512126121271212812129121301213112132121331213412135121361213712138121391214012141121421214312144121451214612147121481214912150121511215212153121541215512156121571215812159121601216112162121631216412165121661216712168121691217012171121721217312174121751217612177121781217912180121811218212183121841218512186121871218812189121901219112192121931219412195121961219712198121991220012201122021220312204122051220612207122081220912210122111221212213122141221512216122171221812219122201222112222122231222412225122261222712228122291223012231122321223312234122351223612237122381223912240122411224212243122441224512246122471224812249122501225112252122531225412255122561225712258122591226012261122621226312264122651226612267122681226912270122711227212273122741227512276122771227812279122801228112282122831228412285122861228712288122891229012291122921229312294122951229612297122981229912300123011230212303123041230512306123071230812309123101231112312123131231412315123161231712318123191232012321123221232312324123251232612327123281232912330123311233212333123341233512336123371233812339123401234112342123431234412345123461234712348123491235012351123521235312354123551235612357123581235912360123611236212363123641236512366123671236812369123701237112372123731237412375123761237712378123791238012381123821238312384123851238612387123881238912390123911239212393123941239512396123971239812399124001240112402124031240412405124061240712408124091241012411124121241312414124151241612417124181241912420124211242212423124241242512426124271242812429124301243112432124331243412435124361243712438124391244012441124421244312444124451244612447124481244912450124511245212453124541245512456124571245812459124601246112462124631246412465124661246712468124691247012471124721247312474124751247612477124781247912480124811248212483124841248512486124871248812489124901249112492124931249412495124961249712498124991250012501125021250312504125051250612507125081250912510125111251212513125141251512516125171251812519125201252112522125231252412525125261252712528125291253012531125321253312534125351253612537125381253912540125411254212543125441254512546125471254812549125501255112552125531255412555125561255712558125591256012561125621256312564125651256612567125681256912570125711257212573125741257512576125771257812579125801258112582125831258412585125861258712588125891259012591125921259312594125951259612597125981259912600126011260212603126041260512606126071260812609126101261112612126131261412615126161261712618126191262012621126221262312624126251262612627126281262912630126311263212633126341263512636126371263812639126401264112642126431264412645126461264712648126491265012651126521265312654126551265612657126581265912660126611266212663126641266512666126671266812669126701267112672126731267412675126761267712678126791268012681126821268312684126851268612687126881268912690126911269212693126941269512696126971269812699127001270112702127031270412705127061270712708127091271012711127121271312714127151271612717127181271912720127211272212723127241272512726127271272812729127301273112732127331273412735127361273712738127391274012741127421274312744127451274612747127481274912750127511275212753127541275512756127571275812759127601276112762127631276412765127661276712768127691277012771127721277312774127751277612777127781277912780127811278212783127841278512786127871278812789127901279112792127931279412795127961279712798127991280012801128021280312804128051280612807128081280912810128111281212813128141281512816128171281812819128201282112822128231282412825128261282712828128291283012831128321283312834128351283612837128381283912840128411284212843128441284512846128471284812849128501285112852128531285412855128561285712858128591286012861128621286312864128651286612867128681286912870128711287212873128741287512876128771287812879128801288112882128831288412885128861288712888128891289012891128921289312894128951289612897128981289912900129011290212903129041290512906129071290812909129101291112912129131291412915129161291712918129191292012921129221292312924129251292612927129281292912930129311293212933129341293512936129371293812939129401294112942129431294412945129461294712948129491295012951129521295312954129551295612957129581295912960129611296212963129641296512966129671296812969129701297112972129731297412975129761297712978129791298012981129821298312984129851298612987129881298912990129911299212993129941299512996129971299812999130001300113002130031300413005130061300713008130091301013011130121301313014130151301613017130181301913020130211302213023130241302513026130271302813029130301303113032130331303413035130361303713038130391304013041130421304313044130451304613047130481304913050130511305213053130541305513056130571305813059130601306113062130631306413065130661306713068130691307013071130721307313074130751307613077130781307913080130811308213083130841308513086130871308813089130901309113092130931309413095130961309713098130991310013101131021310313104131051310613107131081310913110131111311213113131141311513116131171311813119131201312113122131231312413125131261312713128131291313013131131321313313134131351313613137131381313913140131411314213143131441314513146131471314813149131501315113152131531315413155131561315713158131591316013161131621316313164131651316613167131681316913170131711317213173131741317513176131771317813179131801318113182131831318413185131861318713188131891319013191131921319313194131951319613197131981319913200132011320213203132041320513206132071320813209132101321113212132131321413215132161321713218132191322013221132221322313224132251322613227132281322913230132311323213233132341323513236132371323813239132401324113242132431324413245132461324713248132491325013251132521325313254132551325613257132581325913260132611326213263132641326513266132671326813269132701327113272132731327413275132761327713278132791328013281132821328313284132851328613287132881328913290132911329213293132941329513296132971329813299133001330113302133031330413305133061330713308133091331013311133121331313314133151331613317133181331913320133211332213323133241332513326133271332813329133301333113332133331333413335133361333713338133391334013341133421334313344133451334613347133481334913350133511335213353133541335513356133571335813359133601336113362133631336413365133661336713368133691337013371133721337313374133751337613377133781337913380133811338213383133841338513386133871338813389133901339113392133931339413395133961339713398133991340013401134021340313404134051340613407134081340913410134111341213413134141341513416134171341813419134201342113422134231342413425134261342713428134291343013431134321343313434134351343613437134381343913440134411344213443134441344513446134471344813449134501345113452134531345413455134561345713458134591346013461134621346313464134651346613467134681346913470134711347213473134741347513476134771347813479134801348113482134831348413485134861348713488134891349013491134921349313494134951349613497134981349913500135011350213503135041350513506135071350813509135101351113512135131351413515135161351713518135191352013521135221352313524135251352613527135281352913530135311353213533135341353513536135371353813539135401354113542135431354413545135461354713548135491355013551135521355313554135551355613557135581355913560135611356213563135641356513566135671356813569135701357113572135731357413575135761357713578135791358013581135821358313584135851358613587135881358913590135911359213593135941359513596135971359813599136001360113602136031360413605136061360713608136091361013611136121361313614136151361613617136181361913620136211362213623136241362513626136271362813629136301363113632136331363413635136361363713638136391364013641136421364313644136451364613647136481364913650136511365213653136541365513656136571365813659136601366113662136631366413665136661366713668136691367013671136721367313674136751367613677136781367913680136811368213683136841368513686136871368813689136901369113692136931369413695136961369713698136991370013701137021370313704137051370613707137081370913710137111371213713137141371513716137171371813719137201372113722137231372413725137261372713728137291373013731137321373313734137351373613737137381373913740137411374213743137441374513746137471374813749137501375113752137531375413755137561375713758137591376013761137621376313764137651376613767137681376913770137711377213773137741377513776137771377813779137801378113782137831378413785137861378713788137891379013791137921379313794137951379613797137981379913800138011380213803138041380513806138071380813809138101381113812138131381413815138161381713818138191382013821138221382313824138251382613827138281382913830138311383213833138341383513836138371383813839138401384113842138431384413845138461384713848138491385013851138521385313854138551385613857138581385913860138611386213863138641386513866138671386813869138701387113872138731387413875138761387713878138791388013881138821388313884138851388613887138881388913890138911389213893138941389513896138971389813899139001390113902139031390413905139061390713908139091391013911139121391313914139151391613917139181391913920139211392213923139241392513926139271392813929139301393113932139331393413935139361393713938139391394013941139421394313944139451394613947139481394913950139511395213953139541395513956139571395813959139601396113962139631396413965139661396713968139691397013971139721397313974139751397613977139781397913980139811398213983139841398513986139871398813989139901399113992139931399413995139961399713998139991400014001140021400314004140051400614007140081400914010140111401214013140141401514016140171401814019140201402114022140231402414025140261402714028140291403014031140321403314034140351403614037140381403914040140411404214043140441404514046140471404814049140501405114052140531405414055140561405714058140591406014061140621406314064140651406614067140681406914070140711407214073140741407514076140771407814079140801408114082140831408414085140861408714088140891409014091140921409314094140951409614097140981409914100141011410214103141041410514106141071410814109141101411114112141131411414115141161411714118141191412014121141221412314124141251412614127141281412914130141311413214133141341413514136141371413814139141401414114142141431414414145141461414714148141491415014151141521415314154141551415614157141581415914160141611416214163141641416514166141671416814169141701417114172141731417414175141761417714178141791418014181141821418314184141851418614187141881418914190141911419214193141941419514196141971419814199142001420114202142031420414205142061420714208142091421014211142121421314214142151421614217142181421914220142211422214223142241422514226142271422814229142301423114232142331423414235142361423714238142391424014241142421424314244142451424614247142481424914250142511425214253142541425514256142571425814259142601426114262142631426414265142661426714268142691427014271142721427314274142751427614277142781427914280142811428214283142841428514286142871428814289142901429114292142931429414295142961429714298142991430014301143021430314304143051430614307143081430914310143111431214313143141431514316143171431814319143201432114322143231432414325143261432714328143291433014331143321433314334143351433614337143381433914340143411434214343143441434514346143471434814349143501435114352143531435414355143561435714358143591436014361143621436314364143651436614367143681436914370143711437214373143741437514376143771437814379143801438114382143831438414385143861438714388143891439014391143921439314394143951439614397143981439914400144011440214403144041440514406144071440814409144101441114412144131441414415144161441714418144191442014421144221442314424144251442614427144281442914430144311443214433144341443514436144371443814439144401444114442144431444414445144461444714448144491445014451144521445314454144551445614457144581445914460144611446214463144641446514466144671446814469144701447114472144731447414475144761447714478144791448014481144821448314484144851448614487144881448914490144911449214493144941449514496144971449814499145001450114502145031450414505145061450714508145091451014511145121451314514145151451614517145181451914520145211452214523145241452514526145271452814529145301453114532145331453414535145361453714538145391454014541145421454314544145451454614547145481454914550145511455214553145541455514556145571455814559145601456114562145631456414565145661456714568145691457014571145721457314574145751457614577145781457914580145811458214583145841458514586145871458814589145901459114592145931459414595145961459714598145991460014601146021460314604146051460614607146081460914610146111461214613146141461514616146171461814619146201462114622146231462414625146261462714628146291463014631146321463314634146351463614637146381463914640146411464214643146441464514646146471464814649146501465114652146531465414655146561465714658146591466014661146621466314664146651466614667146681466914670146711467214673146741467514676146771467814679146801468114682146831468414685146861468714688146891469014691146921469314694146951469614697146981469914700147011470214703147041470514706147071470814709147101471114712147131471414715147161471714718147191472014721147221472314724147251472614727147281472914730147311473214733147341473514736147371473814739147401474114742147431474414745147461474714748147491475014751147521475314754147551475614757147581475914760147611476214763147641476514766147671476814769147701477114772147731477414775147761477714778147791478014781147821478314784147851478614787147881478914790147911479214793147941479514796147971479814799148001480114802148031480414805148061480714808148091481014811148121481314814148151481614817148181481914820148211482214823148241482514826148271482814829148301483114832148331483414835148361483714838148391484014841148421484314844148451484614847148481484914850148511485214853148541485514856148571485814859148601486114862148631486414865148661486714868148691487014871148721487314874148751487614877148781487914880148811488214883148841488514886148871488814889148901489114892148931489414895148961489714898148991490014901149021490314904149051490614907149081490914910149111491214913149141491514916149171491814919149201492114922149231492414925149261492714928149291493014931149321493314934149351493614937149381493914940149411494214943149441494514946149471494814949149501495114952149531495414955149561495714958149591496014961149621496314964149651496614967149681496914970149711497214973149741497514976149771497814979149801498114982149831498414985149861498714988149891499014991149921499314994149951499614997149981499915000150011500215003150041500515006150071500815009150101501115012150131501415015150161501715018150191502015021150221502315024150251502615027150281502915030150311503215033150341503515036150371503815039150401504115042150431504415045150461504715048150491505015051150521505315054150551505615057150581505915060150611506215063150641506515066150671506815069150701507115072150731507415075150761507715078150791508015081150821508315084150851508615087150881508915090150911509215093150941509515096150971509815099151001510115102151031510415105151061510715108151091511015111151121511315114151151511615117151181511915120151211512215123151241512515126151271512815129151301513115132151331513415135151361513715138151391514015141151421514315144151451514615147151481514915150151511515215153151541515515156151571515815159151601516115162151631516415165151661516715168151691517015171151721517315174151751517615177151781517915180151811518215183151841518515186151871518815189151901519115192151931519415195151961519715198151991520015201152021520315204152051520615207152081520915210152111521215213152141521515216152171521815219152201522115222152231522415225152261522715228152291523015231152321523315234152351523615237152381523915240152411524215243152441524515246152471524815249152501525115252152531525415255152561525715258152591526015261152621526315264152651526615267152681526915270152711527215273152741527515276152771527815279152801528115282152831528415285152861528715288152891529015291152921529315294152951529615297152981529915300153011530215303153041530515306153071530815309153101531115312153131531415315153161531715318153191532015321153221532315324153251532615327153281532915330153311533215333153341533515336153371533815339153401534115342153431534415345153461534715348153491535015351153521535315354153551535615357153581535915360153611536215363153641536515366153671536815369153701537115372153731537415375153761537715378153791538015381153821538315384153851538615387153881538915390153911539215393153941539515396153971539815399154001540115402154031540415405154061540715408154091541015411154121541315414154151541615417154181541915420154211542215423154241542515426154271542815429154301543115432154331543415435154361543715438154391544015441154421544315444154451544615447154481544915450154511545215453154541545515456154571545815459154601546115462154631546415465154661546715468154691547015471154721547315474154751547615477154781547915480154811548215483154841548515486154871548815489154901549115492154931549415495154961549715498154991550015501155021550315504155051550615507155081550915510155111551215513155141551515516155171551815519155201552115522155231552415525155261552715528155291553015531155321553315534155351553615537155381553915540155411554215543155441554515546155471554815549155501555115552155531555415555155561555715558155591556015561155621556315564155651556615567155681556915570155711557215573155741557515576155771557815579155801558115582155831558415585155861558715588155891559015591155921559315594155951559615597155981559915600156011560215603156041560515606156071560815609156101561115612156131561415615156161561715618156191562015621156221562315624156251562615627156281562915630156311563215633156341563515636156371563815639156401564115642156431564415645156461564715648156491565015651156521565315654156551565615657156581565915660156611566215663156641566515666156671566815669156701567115672156731567415675156761567715678156791568015681156821568315684156851568615687156881568915690156911569215693156941569515696156971569815699157001570115702157031570415705157061570715708157091571015711157121571315714157151571615717157181571915720157211572215723157241572515726157271572815729157301573115732157331573415735157361573715738157391574015741157421574315744157451574615747157481574915750157511575215753157541575515756157571575815759157601576115762157631576415765157661576715768157691577015771157721577315774157751577615777157781577915780157811578215783157841578515786157871578815789157901579115792157931579415795157961579715798157991580015801158021580315804158051580615807158081580915810158111581215813158141581515816158171581815819158201582115822158231582415825158261582715828158291583015831158321583315834158351583615837158381583915840158411584215843158441584515846158471584815849158501585115852158531585415855158561585715858158591586015861158621586315864158651586615867158681586915870158711587215873158741587515876158771587815879158801588115882158831588415885158861588715888158891589015891158921589315894158951589615897158981589915900159011590215903159041590515906159071590815909159101591115912159131591415915159161591715918159191592015921159221592315924159251592615927159281592915930159311593215933159341593515936159371593815939159401594115942159431594415945159461594715948159491595015951159521595315954159551595615957159581595915960159611596215963159641596515966159671596815969159701597115972159731597415975159761597715978159791598015981159821598315984159851598615987159881598915990159911599215993159941599515996159971599815999160001600116002160031600416005160061600716008160091601016011160121601316014160151601616017160181601916020160211602216023160241602516026160271602816029160301603116032160331603416035160361603716038160391604016041160421604316044160451604616047160481604916050160511605216053160541605516056160571605816059160601606116062160631606416065160661606716068160691607016071160721607316074160751607616077160781607916080160811608216083160841608516086160871608816089160901609116092160931609416095160961609716098160991610016101161021610316104161051610616107161081610916110161111611216113161141611516116161171611816119161201612116122161231612416125161261612716128161291613016131161321613316134161351613616137161381613916140161411614216143161441614516146161471614816149161501615116152161531615416155161561615716158161591616016161161621616316164161651616616167161681616916170161711617216173161741617516176161771617816179161801618116182161831618416185161861618716188161891619016191161921619316194161951619616197161981619916200162011620216203162041620516206162071620816209162101621116212162131621416215162161621716218162191622016221162221622316224162251622616227162281622916230162311623216233162341623516236162371623816239162401624116242162431624416245162461624716248162491625016251162521625316254162551625616257162581625916260162611626216263162641626516266162671626816269162701627116272162731627416275162761627716278162791628016281162821628316284162851628616287162881628916290162911629216293162941629516296162971629816299163001630116302163031630416305163061630716308163091631016311163121631316314163151631616317163181631916320163211632216323163241632516326163271632816329163301633116332163331633416335163361633716338163391634016341163421634316344163451634616347163481634916350163511635216353163541635516356163571635816359163601636116362163631636416365163661636716368163691637016371163721637316374163751637616377163781637916380163811638216383163841638516386163871638816389163901639116392163931639416395163961639716398163991640016401164021640316404164051640616407164081640916410164111641216413164141641516416164171641816419164201642116422164231642416425164261642716428164291643016431164321643316434164351643616437164381643916440164411644216443164441644516446164471644816449164501645116452164531645416455164561645716458164591646016461164621646316464164651646616467164681646916470164711647216473164741647516476164771647816479164801648116482164831648416485164861648716488164891649016491164921649316494164951649616497164981649916500165011650216503165041650516506165071650816509165101651116512165131651416515165161651716518165191652016521165221652316524165251652616527165281652916530165311653216533165341653516536165371653816539165401654116542165431654416545165461654716548165491655016551165521655316554165551655616557165581655916560165611656216563165641656516566165671656816569165701657116572165731657416575165761657716578165791658016581165821658316584165851658616587165881658916590165911659216593165941659516596165971659816599166001660116602166031660416605166061660716608166091661016611166121661316614166151661616617166181661916620166211662216623166241662516626166271662816629166301663116632166331663416635166361663716638166391664016641166421664316644166451664616647166481664916650166511665216653166541665516656166571665816659166601666116662166631666416665166661666716668166691667016671166721667316674166751667616677166781667916680166811668216683166841668516686166871668816689166901669116692166931669416695166961669716698166991670016701167021670316704167051670616707167081670916710167111671216713167141671516716167171671816719167201672116722167231672416725167261672716728167291673016731167321673316734167351673616737167381673916740167411674216743167441674516746167471674816749167501675116752167531675416755167561675716758167591676016761167621676316764167651676616767167681676916770167711677216773167741677516776167771677816779167801678116782167831678416785167861678716788167891679016791167921679316794167951679616797167981679916800168011680216803168041680516806168071680816809168101681116812168131681416815168161681716818168191682016821168221682316824168251682616827168281682916830168311683216833168341683516836168371683816839168401684116842168431684416845168461684716848168491685016851168521685316854168551685616857168581685916860168611686216863168641686516866168671686816869168701687116872168731687416875168761687716878168791688016881168821688316884168851688616887168881688916890168911689216893168941689516896168971689816899169001690116902169031690416905169061690716908169091691016911169121691316914169151691616917169181691916920169211692216923169241692516926169271692816929169301693116932169331693416935169361693716938169391694016941169421694316944169451694616947169481694916950169511695216953169541695516956169571695816959169601696116962169631696416965169661696716968169691697016971169721697316974169751697616977169781697916980169811698216983169841698516986169871698816989169901699116992169931699416995169961699716998169991700017001170021700317004170051700617007170081700917010170111701217013170141701517016170171701817019170201702117022170231702417025170261702717028170291703017031170321703317034170351703617037170381703917040170411704217043170441704517046170471704817049170501705117052170531705417055170561705717058170591706017061170621706317064170651706617067170681706917070170711707217073170741707517076170771707817079170801708117082170831708417085170861708717088170891709017091170921709317094170951709617097170981709917100171011710217103171041710517106171071710817109171101711117112171131711417115171161711717118171191712017121171221712317124171251712617127171281712917130171311713217133171341713517136171371713817139171401714117142171431714417145171461714717148171491715017151171521715317154171551715617157171581715917160171611716217163171641716517166171671716817169171701717117172171731717417175171761717717178171791718017181171821718317184171851718617187171881718917190171911719217193171941719517196171971719817199172001720117202172031720417205172061720717208172091721017211172121721317214172151721617217172181721917220172211722217223172241722517226172271722817229172301723117232172331723417235172361723717238172391724017241172421724317244172451724617247172481724917250172511725217253172541725517256172571725817259172601726117262172631726417265172661726717268172691727017271172721727317274172751727617277172781727917280172811728217283172841728517286172871728817289172901729117292172931729417295172961729717298172991730017301173021730317304173051730617307173081730917310173111731217313173141731517316173171731817319173201732117322173231732417325173261732717328173291733017331173321733317334173351733617337173381733917340173411734217343173441734517346173471734817349173501735117352173531735417355173561735717358173591736017361173621736317364173651736617367173681736917370173711737217373173741737517376173771737817379173801738117382173831738417385173861738717388173891739017391173921739317394173951739617397173981739917400174011740217403174041740517406174071740817409174101741117412174131741417415174161741717418174191742017421174221742317424174251742617427174281742917430174311743217433174341743517436174371743817439174401744117442174431744417445174461744717448174491745017451174521745317454174551745617457174581745917460174611746217463174641746517466174671746817469174701747117472174731747417475174761747717478174791748017481174821748317484174851748617487174881748917490174911749217493174941749517496174971749817499175001750117502175031750417505175061750717508175091751017511175121751317514175151751617517175181751917520175211752217523175241752517526175271752817529175301753117532175331753417535175361753717538175391754017541175421754317544175451754617547175481754917550175511755217553175541755517556175571755817559175601756117562175631756417565175661756717568175691757017571175721757317574175751757617577175781757917580175811758217583175841758517586175871758817589175901759117592175931759417595175961759717598175991760017601176021760317604176051760617607176081760917610176111761217613176141761517616176171761817619176201762117622176231762417625176261762717628176291763017631176321763317634176351763617637176381763917640176411764217643176441764517646176471764817649176501765117652176531765417655176561765717658176591766017661176621766317664176651766617667176681766917670176711767217673176741767517676176771767817679176801768117682176831768417685176861768717688176891769017691176921769317694176951769617697176981769917700177011770217703177041770517706177071770817709177101771117712177131771417715177161771717718177191772017721177221772317724177251772617727177281772917730177311773217733177341773517736177371773817739177401774117742177431774417745177461774717748177491775017751177521775317754177551775617757177581775917760177611776217763177641776517766177671776817769177701777117772177731777417775177761777717778177791778017781177821778317784177851778617787177881778917790177911779217793177941779517796177971779817799178001780117802178031780417805178061780717808178091781017811178121781317814178151781617817178181781917820178211782217823178241782517826178271782817829178301783117832178331783417835178361783717838178391784017841178421784317844178451784617847178481784917850178511785217853178541785517856178571785817859178601786117862178631786417865178661786717868178691787017871178721787317874178751787617877178781787917880178811788217883178841788517886178871788817889178901789117892178931789417895178961789717898178991790017901179021790317904179051790617907179081790917910179111791217913179141791517916179171791817919179201792117922179231792417925179261792717928179291793017931179321793317934179351793617937179381793917940179411794217943179441794517946179471794817949179501795117952179531795417955179561795717958179591796017961179621796317964179651796617967179681796917970179711797217973179741797517976179771797817979179801798117982179831798417985179861798717988179891799017991179921799317994179951799617997179981799918000180011800218003180041800518006180071800818009180101801118012180131801418015180161801718018180191802018021180221802318024180251802618027180281802918030180311803218033180341803518036180371803818039180401804118042180431804418045180461804718048180491805018051180521805318054180551805618057180581805918060180611806218063180641806518066180671806818069180701807118072180731807418075180761807718078180791808018081180821808318084180851808618087180881808918090180911809218093180941809518096180971809818099181001810118102181031810418105181061810718108181091811018111181121811318114181151811618117181181811918120181211812218123181241812518126181271812818129181301813118132181331813418135181361813718138181391814018141181421814318144181451814618147181481814918150181511815218153181541815518156181571815818159181601816118162181631816418165181661816718168181691817018171181721817318174181751817618177181781817918180181811818218183181841818518186181871818818189181901819118192181931819418195181961819718198181991820018201182021820318204182051820618207182081820918210182111821218213182141821518216182171821818219182201822118222182231822418225182261822718228182291823018231182321823318234182351823618237182381823918240182411824218243182441824518246182471824818249182501825118252182531825418255182561825718258182591826018261182621826318264182651826618267182681826918270182711827218273182741827518276182771827818279182801828118282182831828418285182861828718288182891829018291182921829318294182951829618297182981829918300183011830218303183041830518306183071830818309183101831118312183131831418315183161831718318183191832018321183221832318324183251832618327183281832918330183311833218333183341833518336183371833818339183401834118342183431834418345183461834718348183491835018351183521835318354183551835618357183581835918360183611836218363183641836518366183671836818369183701837118372183731837418375183761837718378183791838018381183821838318384183851838618387183881838918390183911839218393183941839518396183971839818399184001840118402184031840418405184061840718408184091841018411184121841318414184151841618417184181841918420184211842218423184241842518426184271842818429184301843118432184331843418435184361843718438184391844018441184421844318444184451844618447184481844918450184511845218453184541845518456184571845818459184601846118462184631846418465184661846718468184691847018471184721847318474184751847618477184781847918480184811848218483184841848518486184871848818489184901849118492184931849418495184961849718498184991850018501185021850318504185051850618507185081850918510185111851218513185141851518516185171851818519185201852118522185231852418525185261852718528185291853018531185321853318534185351853618537185381853918540185411854218543185441854518546185471854818549185501855118552185531855418555185561855718558185591856018561185621856318564185651856618567185681856918570185711857218573185741857518576185771857818579185801858118582185831858418585185861858718588185891859018591185921859318594185951859618597185981859918600186011860218603186041860518606186071860818609186101861118612186131861418615186161861718618186191862018621186221862318624186251862618627186281862918630186311863218633186341863518636186371863818639186401864118642186431864418645186461864718648186491865018651186521865318654186551865618657186581865918660186611866218663186641866518666186671866818669186701867118672186731867418675186761867718678186791868018681186821868318684186851868618687186881868918690186911869218693186941869518696186971869818699187001870118702187031870418705187061870718708187091871018711187121871318714187151871618717187181871918720187211872218723187241872518726187271872818729187301873118732187331873418735187361873718738187391874018741187421874318744187451874618747187481874918750187511875218753187541875518756187571875818759187601876118762187631876418765187661876718768187691877018771187721877318774187751877618777187781877918780187811878218783187841878518786187871878818789187901879118792187931879418795187961879718798187991880018801188021880318804188051880618807188081880918810188111881218813188141881518816188171881818819188201882118822188231882418825188261882718828188291883018831188321883318834188351883618837188381883918840188411884218843188441884518846188471884818849188501885118852188531885418855188561885718858188591886018861188621886318864188651886618867188681886918870188711887218873188741887518876188771887818879188801888118882188831888418885188861888718888188891889018891188921889318894188951889618897188981889918900189011890218903189041890518906189071890818909189101891118912189131891418915189161891718918189191892018921189221892318924189251892618927189281892918930189311893218933189341893518936189371893818939189401894118942189431894418945189461894718948189491895018951189521895318954189551895618957189581895918960189611896218963189641896518966189671896818969189701897118972189731897418975189761897718978189791898018981189821898318984189851898618987189881898918990189911899218993189941899518996189971899818999190001900119002190031900419005190061900719008190091901019011190121901319014190151901619017190181901919020190211902219023190241902519026190271902819029190301903119032190331903419035190361903719038190391904019041190421904319044190451904619047190481904919050190511905219053190541905519056190571905819059190601906119062190631906419065190661906719068190691907019071190721907319074190751907619077190781907919080190811908219083190841908519086190871908819089190901909119092190931909419095190961909719098190991910019101191021910319104191051910619107191081910919110191111911219113191141911519116191171911819119191201912119122191231912419125191261912719128191291913019131191321913319134191351913619137191381913919140191411914219143191441914519146191471914819149191501915119152191531915419155191561915719158191591916019161191621916319164191651916619167191681916919170191711917219173191741917519176191771917819179191801918119182191831918419185191861918719188191891919019191191921919319194191951919619197191981919919200192011920219203192041920519206192071920819209192101921119212192131921419215192161921719218192191922019221192221922319224192251922619227192281922919230192311923219233192341923519236192371923819239192401924119242192431924419245192461924719248192491925019251192521925319254192551925619257192581925919260192611926219263192641926519266192671926819269192701927119272192731927419275192761927719278192791928019281192821928319284192851928619287192881928919290192911929219293192941929519296192971929819299193001930119302193031930419305193061930719308193091931019311193121931319314193151931619317193181931919320193211932219323193241932519326193271932819329193301933119332193331933419335193361933719338193391934019341193421934319344193451934619347193481934919350193511935219353193541935519356193571935819359193601936119362193631936419365193661936719368193691937019371193721937319374193751937619377193781937919380193811938219383193841938519386193871938819389193901939119392193931939419395193961939719398193991940019401194021940319404194051940619407194081940919410194111941219413194141941519416194171941819419194201942119422194231942419425194261942719428194291943019431194321943319434194351943619437194381943919440194411944219443194441944519446194471944819449194501945119452194531945419455194561945719458194591946019461194621946319464194651946619467194681946919470194711947219473194741947519476194771947819479194801948119482194831948419485194861948719488194891949019491194921949319494194951949619497194981949919500195011950219503195041950519506195071950819509195101951119512195131951419515195161951719518195191952019521195221952319524195251952619527195281952919530195311953219533195341953519536195371953819539195401954119542195431954419545195461954719548195491955019551195521955319554195551955619557195581955919560195611956219563195641956519566195671956819569195701957119572195731957419575195761957719578195791958019581195821958319584195851958619587195881958919590195911959219593195941959519596195971959819599196001960119602196031960419605196061960719608196091961019611196121961319614196151961619617196181961919620196211962219623196241962519626196271962819629196301963119632196331963419635196361963719638196391964019641196421964319644196451964619647196481964919650196511965219653196541965519656196571965819659196601966119662196631966419665196661966719668196691967019671196721967319674196751967619677196781967919680196811968219683196841968519686196871968819689196901969119692196931969419695196961969719698196991970019701197021970319704197051970619707197081970919710197111971219713197141971519716197171971819719197201972119722197231972419725197261972719728197291973019731197321973319734197351973619737197381973919740197411974219743197441974519746197471974819749197501975119752197531975419755197561975719758197591976019761197621976319764197651976619767197681976919770197711977219773197741977519776197771977819779197801978119782197831978419785197861978719788197891979019791197921979319794197951979619797197981979919800198011980219803198041980519806198071980819809198101981119812198131981419815198161981719818198191982019821198221982319824198251982619827198281982919830198311983219833198341983519836198371983819839198401984119842198431984419845198461984719848198491985019851198521985319854198551985619857198581985919860198611986219863198641986519866198671986819869198701987119872198731987419875198761987719878198791988019881198821988319884198851988619887198881988919890198911989219893198941989519896198971989819899199001990119902199031990419905199061990719908199091991019911199121991319914199151991619917199181991919920199211992219923199241992519926199271992819929199301993119932199331993419935199361993719938199391994019941199421994319944199451994619947199481994919950199511995219953199541995519956199571995819959199601996119962199631996419965199661996719968199691997019971199721997319974199751997619977199781997919980199811998219983199841998519986199871998819989199901999119992199931999419995199961999719998199992000020001200022000320004200052000620007200082000920010200112001220013200142001520016200172001820019200202002120022200232002420025200262002720028200292003020031200322003320034200352003620037200382003920040200412004220043200442004520046200472004820049200502005120052200532005420055200562005720058200592006020061200622006320064200652006620067200682006920070200712007220073200742007520076200772007820079200802008120082200832008420085200862008720088200892009020091200922009320094200952009620097200982009920100201012010220103201042010520106201072010820109201102011120112201132011420115201162011720118201192012020121201222012320124201252012620127201282012920130201312013220133201342013520136201372013820139201402014120142201432014420145201462014720148201492015020151201522015320154201552015620157201582015920160201612016220163201642016520166201672016820169201702017120172201732017420175201762017720178201792018020181201822018320184201852018620187201882018920190201912019220193201942019520196201972019820199202002020120202202032020420205202062020720208202092021020211202122021320214202152021620217202182021920220202212022220223202242022520226202272022820229202302023120232202332023420235202362023720238202392024020241202422024320244202452024620247202482024920250202512025220253202542025520256202572025820259202602026120262202632026420265202662026720268202692027020271202722027320274202752027620277202782027920280202812028220283202842028520286202872028820289202902029120292202932029420295202962029720298202992030020301203022030320304203052030620307203082030920310203112031220313203142031520316203172031820319203202032120322203232032420325203262032720328203292033020331203322033320334203352033620337203382033920340203412034220343203442034520346203472034820349203502035120352203532035420355203562035720358203592036020361203622036320364203652036620367203682036920370203712037220373203742037520376203772037820379203802038120382203832038420385203862038720388203892039020391203922039320394203952039620397203982039920400204012040220403204042040520406204072040820409204102041120412204132041420415204162041720418204192042020421204222042320424204252042620427204282042920430204312043220433204342043520436204372043820439204402044120442204432044420445204462044720448204492045020451204522045320454204552045620457204582045920460204612046220463204642046520466204672046820469204702047120472204732047420475204762047720478204792048020481204822048320484204852048620487204882048920490204912049220493204942049520496204972049820499205002050120502205032050420505205062050720508205092051020511205122051320514205152051620517205182051920520205212052220523205242052520526205272052820529205302053120532205332053420535205362053720538205392054020541205422054320544205452054620547205482054920550205512055220553205542055520556205572055820559205602056120562205632056420565205662056720568205692057020571205722057320574205752057620577205782057920580205812058220583205842058520586205872058820589205902059120592205932059420595205962059720598205992060020601206022060320604206052060620607206082060920610206112061220613206142061520616206172061820619206202062120622206232062420625206262062720628206292063020631206322063320634206352063620637206382063920640206412064220643206442064520646206472064820649206502065120652206532065420655206562065720658206592066020661206622066320664206652066620667206682066920670206712067220673206742067520676206772067820679206802068120682206832068420685206862068720688206892069020691206922069320694206952069620697206982069920700207012070220703207042070520706207072070820709207102071120712207132071420715207162071720718207192072020721207222072320724207252072620727207282072920730207312073220733207342073520736207372073820739207402074120742207432074420745207462074720748207492075020751207522075320754207552075620757207582075920760207612076220763207642076520766207672076820769207702077120772207732077420775207762077720778207792078020781207822078320784207852078620787207882078920790207912079220793207942079520796207972079820799208002080120802208032080420805208062080720808208092081020811208122081320814208152081620817208182081920820208212082220823208242082520826208272082820829208302083120832208332083420835208362083720838208392084020841208422084320844208452084620847208482084920850208512085220853208542085520856208572085820859208602086120862208632086420865208662086720868208692087020871208722087320874208752087620877208782087920880208812088220883208842088520886208872088820889208902089120892208932089420895208962089720898208992090020901209022090320904209052090620907209082090920910209112091220913209142091520916209172091820919209202092120922209232092420925209262092720928209292093020931209322093320934209352093620937209382093920940209412094220943209442094520946209472094820949209502095120952209532095420955209562095720958209592096020961209622096320964209652096620967209682096920970209712097220973209742097520976209772097820979209802098120982209832098420985209862098720988209892099020991209922099320994209952099620997209982099921000210012100221003210042100521006210072100821009210102101121012210132101421015210162101721018210192102021021210222102321024210252102621027210282102921030210312103221033210342103521036210372103821039210402104121042210432104421045210462104721048210492105021051210522105321054210552105621057210582105921060210612106221063210642106521066210672106821069210702107121072210732107421075210762107721078210792108021081210822108321084210852108621087210882108921090210912109221093210942109521096210972109821099211002110121102211032110421105211062110721108211092111021111211122111321114211152111621117211182111921120211212112221123211242112521126211272112821129211302113121132211332113421135211362113721138211392114021141211422114321144211452114621147211482114921150211512115221153211542115521156211572115821159211602116121162211632116421165211662116721168211692117021171211722117321174211752117621177211782117921180211812118221183211842118521186211872118821189211902119121192211932119421195211962119721198211992120021201212022120321204212052120621207212082120921210212112121221213212142121521216212172121821219212202122121222212232122421225212262122721228212292123021231212322123321234212352123621237212382123921240212412124221243212442124521246212472124821249212502125121252212532125421255212562125721258212592126021261212622126321264212652126621267212682126921270212712127221273212742127521276212772127821279212802128121282212832128421285212862128721288212892129021291212922129321294212952129621297212982129921300213012130221303213042130521306213072130821309213102131121312213132131421315213162131721318213192132021321213222132321324213252132621327213282132921330213312133221333213342133521336213372133821339213402134121342213432134421345213462134721348213492135021351213522135321354213552135621357213582135921360213612136221363213642136521366213672136821369213702137121372213732137421375213762137721378213792138021381213822138321384213852138621387213882138921390213912139221393213942139521396213972139821399214002140121402214032140421405214062140721408214092141021411214122141321414214152141621417214182141921420214212142221423214242142521426214272142821429214302143121432214332143421435214362143721438214392144021441214422144321444214452144621447214482144921450214512145221453214542145521456214572145821459214602146121462214632146421465214662146721468214692147021471214722147321474214752147621477214782147921480214812148221483214842148521486214872148821489214902149121492214932149421495214962149721498214992150021501215022150321504215052150621507215082150921510215112151221513215142151521516215172151821519215202152121522215232152421525215262152721528215292153021531215322153321534215352153621537215382153921540215412154221543215442154521546215472154821549215502155121552215532155421555215562155721558215592156021561215622156321564215652156621567215682156921570215712157221573215742157521576215772157821579215802158121582215832158421585215862158721588215892159021591215922159321594215952159621597215982159921600216012160221603216042160521606216072160821609216102161121612216132161421615216162161721618216192162021621216222162321624216252162621627216282162921630216312163221633216342163521636216372163821639216402164121642216432164421645216462164721648216492165021651216522165321654216552165621657216582165921660216612166221663216642166521666216672166821669216702167121672216732167421675216762167721678216792168021681216822168321684216852168621687216882168921690216912169221693216942169521696216972169821699217002170121702217032170421705217062170721708217092171021711217122171321714217152171621717217182171921720217212172221723217242172521726217272172821729217302173121732217332173421735217362173721738217392174021741217422174321744217452174621747217482174921750217512175221753217542175521756217572175821759217602176121762217632176421765217662176721768217692177021771217722177321774217752177621777217782177921780217812178221783217842178521786217872178821789217902179121792217932179421795217962179721798217992180021801218022180321804218052180621807218082180921810218112181221813218142181521816218172181821819218202182121822218232182421825218262182721828218292183021831218322183321834218352183621837218382183921840218412184221843218442184521846218472184821849218502185121852218532185421855218562185721858218592186021861218622186321864218652186621867218682186921870218712187221873218742187521876218772187821879218802188121882218832188421885218862188721888218892189021891218922189321894218952189621897218982189921900219012190221903219042190521906219072190821909219102191121912219132191421915219162191721918219192192021921219222192321924219252192621927219282192921930219312193221933219342193521936219372193821939219402194121942219432194421945219462194721948219492195021951219522195321954219552195621957219582195921960219612196221963219642196521966219672196821969219702197121972219732197421975219762197721978219792198021981219822198321984219852198621987219882198921990219912199221993219942199521996219972199821999220002200122002220032200422005220062200722008220092201022011220122201322014220152201622017220182201922020220212202222023220242202522026220272202822029220302203122032220332203422035220362203722038220392204022041220422204322044220452204622047220482204922050220512205222053220542205522056220572205822059220602206122062220632206422065220662206722068220692207022071220722207322074220752207622077220782207922080220812208222083220842208522086220872208822089220902209122092220932209422095220962209722098220992210022101221022210322104221052210622107221082210922110221112211222113221142211522116221172211822119221202212122122221232212422125221262212722128221292213022131221322213322134221352213622137221382213922140221412214222143221442214522146221472214822149221502215122152221532215422155221562215722158221592216022161221622216322164221652216622167221682216922170221712217222173221742217522176221772217822179221802218122182221832218422185221862218722188221892219022191221922219322194221952219622197221982219922200222012220222203222042220522206222072220822209222102221122212222132221422215222162221722218222192222022221222222222322224222252222622227222282222922230222312223222233222342223522236222372223822239222402224122242222432224422245222462224722248222492225022251222522225322254222552225622257222582225922260222612226222263222642226522266222672226822269222702227122272222732227422275222762227722278222792228022281222822228322284222852228622287222882228922290222912229222293222942229522296222972229822299223002230122302223032230422305223062230722308223092231022311223122231322314223152231622317223182231922320223212232222323223242232522326223272232822329223302233122332223332233422335223362233722338223392234022341223422234322344223452234622347223482234922350223512235222353223542235522356223572235822359223602236122362223632236422365223662236722368223692237022371223722237322374223752237622377223782237922380223812238222383223842238522386223872238822389223902239122392223932239422395223962239722398223992240022401224022240322404224052240622407224082240922410224112241222413224142241522416224172241822419224202242122422224232242422425224262242722428224292243022431224322243322434224352243622437224382243922440224412244222443224442244522446224472244822449224502245122452224532245422455224562245722458224592246022461224622246322464224652246622467224682246922470224712247222473224742247522476224772247822479224802248122482224832248422485224862248722488224892249022491224922249322494224952249622497224982249922500225012250222503225042250522506225072250822509225102251122512225132251422515225162251722518225192252022521225222252322524225252252622527225282252922530225312253222533225342253522536225372253822539225402254122542225432254422545225462254722548225492255022551225522255322554225552255622557225582255922560225612256222563225642256522566225672256822569225702257122572225732257422575225762257722578225792258022581225822258322584225852258622587225882258922590225912259222593225942259522596225972259822599226002260122602226032260422605226062260722608226092261022611226122261322614226152261622617226182261922620226212262222623226242262522626226272262822629226302263122632226332263422635226362263722638226392264022641226422264322644226452264622647226482264922650226512265222653226542265522656226572265822659226602266122662226632266422665226662266722668226692267022671226722267322674226752267622677226782267922680226812268222683226842268522686226872268822689226902269122692226932269422695226962269722698226992270022701227022270322704227052270622707227082270922710227112271222713227142271522716227172271822719227202272122722227232272422725227262272722728227292273022731227322273322734227352273622737227382273922740227412274222743227442274522746227472274822749227502275122752227532275422755227562275722758227592276022761227622276322764227652276622767227682276922770227712277222773227742277522776227772277822779227802278122782227832278422785227862278722788227892279022791227922279322794227952279622797227982279922800228012280222803228042280522806228072280822809228102281122812228132281422815228162281722818228192282022821228222282322824228252282622827228282282922830228312283222833228342283522836228372283822839228402284122842228432284422845228462284722848228492285022851228522285322854228552285622857228582285922860228612286222863228642286522866228672286822869228702287122872228732287422875228762287722878228792288022881228822288322884228852288622887228882288922890228912289222893228942289522896228972289822899229002290122902229032290422905229062290722908229092291022911229122291322914229152291622917229182291922920229212292222923229242292522926229272292822929229302293122932229332293422935229362293722938229392294022941229422294322944229452294622947229482294922950229512295222953229542295522956229572295822959229602296122962229632296422965229662296722968229692297022971229722297322974229752297622977229782297922980229812298222983229842298522986229872298822989229902299122992229932299422995229962299722998229992300023001230022300323004230052300623007230082300923010230112301223013230142301523016230172301823019230202302123022230232302423025230262302723028230292303023031230322303323034230352303623037230382303923040230412304223043230442304523046230472304823049230502305123052230532305423055230562305723058230592306023061230622306323064230652306623067230682306923070230712307223073230742307523076230772307823079230802308123082230832308423085230862308723088230892309023091230922309323094230952309623097230982309923100231012310223103231042310523106231072310823109231102311123112231132311423115231162311723118231192312023121231222312323124231252312623127231282312923130231312313223133231342313523136231372313823139231402314123142231432314423145231462314723148231492315023151231522315323154231552315623157231582315923160231612316223163231642316523166231672316823169231702317123172231732317423175231762317723178231792318023181231822318323184231852318623187231882318923190231912319223193231942319523196231972319823199232002320123202232032320423205232062320723208232092321023211232122321323214232152321623217232182321923220232212322223223232242322523226232272322823229232302323123232232332323423235232362323723238232392324023241232422324323244232452324623247232482324923250232512325223253232542325523256232572325823259232602326123262232632326423265232662326723268232692327023271232722327323274232752327623277232782327923280232812328223283232842328523286232872328823289232902329123292232932329423295232962329723298232992330023301233022330323304233052330623307233082330923310233112331223313233142331523316233172331823319233202332123322233232332423325233262332723328233292333023331233322333323334233352333623337233382333923340233412334223343233442334523346233472334823349233502335123352233532335423355233562335723358233592336023361233622336323364233652336623367233682336923370233712337223373233742337523376233772337823379233802338123382233832338423385233862338723388233892339023391233922339323394233952339623397233982339923400234012340223403234042340523406234072340823409234102341123412234132341423415234162341723418234192342023421234222342323424234252342623427234282342923430234312343223433234342343523436234372343823439234402344123442234432344423445234462344723448234492345023451234522345323454234552345623457234582345923460234612346223463234642346523466234672346823469234702347123472234732347423475234762347723478234792348023481234822348323484234852348623487234882348923490234912349223493234942349523496234972349823499235002350123502235032350423505235062350723508235092351023511235122351323514235152351623517235182351923520235212352223523235242352523526235272352823529235302353123532235332353423535235362353723538235392354023541235422354323544235452354623547235482354923550235512355223553235542355523556235572355823559235602356123562235632356423565235662356723568235692357023571235722357323574235752357623577235782357923580235812358223583235842358523586235872358823589235902359123592235932359423595235962359723598235992360023601236022360323604236052360623607236082360923610236112361223613236142361523616236172361823619236202362123622236232362423625236262362723628236292363023631236322363323634236352363623637236382363923640236412364223643236442364523646236472364823649236502365123652236532365423655236562365723658236592366023661236622366323664236652366623667236682366923670236712367223673236742367523676236772367823679236802368123682236832368423685236862368723688236892369023691236922369323694236952369623697236982369923700237012370223703237042370523706237072370823709237102371123712237132371423715237162371723718237192372023721237222372323724237252372623727237282372923730237312373223733237342373523736237372373823739237402374123742237432374423745237462374723748237492375023751237522375323754237552375623757237582375923760237612376223763237642376523766237672376823769237702377123772237732377423775237762377723778237792378023781237822378323784237852378623787237882378923790237912379223793237942379523796237972379823799238002380123802238032380423805238062380723808238092381023811238122381323814238152381623817238182381923820238212382223823238242382523826238272382823829238302383123832238332383423835238362383723838238392384023841238422384323844238452384623847238482384923850238512385223853238542385523856238572385823859238602386123862238632386423865238662386723868238692387023871238722387323874238752387623877238782387923880238812388223883238842388523886238872388823889238902389123892238932389423895238962389723898238992390023901239022390323904239052390623907239082390923910239112391223913239142391523916239172391823919239202392123922239232392423925239262392723928239292393023931239322393323934239352393623937239382393923940239412394223943239442394523946239472394823949239502395123952239532395423955239562395723958239592396023961239622396323964239652396623967239682396923970239712397223973239742397523976239772397823979239802398123982239832398423985239862398723988239892399023991239922399323994239952399623997239982399924000240012400224003240042400524006240072400824009240102401124012240132401424015240162401724018240192402024021240222402324024240252402624027240282402924030240312403224033240342403524036240372403824039240402404124042240432404424045240462404724048240492405024051240522405324054240552405624057240582405924060240612406224063240642406524066240672406824069240702407124072240732407424075240762407724078240792408024081240822408324084240852408624087240882408924090240912409224093240942409524096240972409824099241002410124102241032410424105241062410724108241092411024111241122411324114241152411624117241182411924120241212412224123241242412524126241272412824129241302413124132241332413424135241362413724138241392414024141241422414324144241452414624147241482414924150241512415224153241542415524156241572415824159241602416124162241632416424165241662416724168241692417024171241722417324174241752417624177241782417924180241812418224183241842418524186241872418824189241902419124192241932419424195241962419724198241992420024201242022420324204242052420624207242082420924210242112421224213242142421524216242172421824219242202422124222242232422424225242262422724228242292423024231242322423324234242352423624237242382423924240242412424224243242442424524246242472424824249242502425124252242532425424255242562425724258242592426024261242622426324264242652426624267242682426924270242712427224273242742427524276242772427824279242802428124282242832428424285242862428724288242892429024291242922429324294242952429624297242982429924300243012430224303243042430524306243072430824309243102431124312243132431424315243162431724318243192432024321243222432324324243252432624327243282432924330243312433224333243342433524336243372433824339243402434124342243432434424345243462434724348243492435024351243522435324354243552435624357243582435924360243612436224363243642436524366243672436824369243702437124372243732437424375243762437724378243792438024381243822438324384243852438624387243882438924390243912439224393243942439524396243972439824399244002440124402244032440424405244062440724408244092441024411244122441324414244152441624417244182441924420244212442224423244242442524426244272442824429244302443124432244332443424435244362443724438244392444024441244422444324444244452444624447244482444924450244512445224453244542445524456244572445824459244602446124462244632446424465244662446724468244692447024471244722447324474244752447624477244782447924480244812448224483244842448524486244872448824489244902449124492244932449424495244962449724498244992450024501245022450324504245052450624507245082450924510245112451224513245142451524516245172451824519245202452124522245232452424525245262452724528245292453024531245322453324534245352453624537245382453924540245412454224543245442454524546245472454824549245502455124552245532455424555245562455724558245592456024561245622456324564245652456624567245682456924570245712457224573245742457524576245772457824579245802458124582245832458424585245862458724588245892459024591245922459324594245952459624597245982459924600246012460224603246042460524606246072460824609246102461124612246132461424615246162461724618246192462024621246222462324624246252462624627246282462924630246312463224633246342463524636246372463824639246402464124642246432464424645246462464724648246492465024651246522465324654246552465624657246582465924660246612466224663246642466524666246672466824669246702467124672246732467424675246762467724678246792468024681246822468324684246852468624687246882468924690246912469224693246942469524696246972469824699247002470124702247032470424705247062470724708247092471024711247122471324714247152471624717247182471924720247212472224723247242472524726247272472824729247302473124732247332473424735247362473724738247392474024741247422474324744247452474624747247482474924750247512475224753247542475524756247572475824759247602476124762247632476424765247662476724768247692477024771247722477324774247752477624777247782477924780247812478224783247842478524786247872478824789247902479124792247932479424795247962479724798247992480024801248022480324804248052480624807248082480924810248112481224813248142481524816248172481824819248202482124822248232482424825248262482724828248292483024831248322483324834248352483624837248382483924840248412484224843248442484524846248472484824849248502485124852248532485424855248562485724858248592486024861248622486324864248652486624867248682486924870248712487224873248742487524876248772487824879248802488124882248832488424885248862488724888248892489024891248922489324894248952489624897248982489924900249012490224903249042490524906249072490824909249102491124912249132491424915249162491724918249192492024921249222492324924249252492624927249282492924930249312493224933249342493524936249372493824939249402494124942249432494424945249462494724948249492495024951249522495324954249552495624957249582495924960249612496224963249642496524966249672496824969249702497124972249732497424975249762497724978249792498024981249822498324984249852498624987249882498924990249912499224993249942499524996249972499824999250002500125002250032500425005250062500725008250092501025011250122501325014250152501625017250182501925020250212502225023250242502525026250272502825029250302503125032250332503425035250362503725038250392504025041250422504325044250452504625047250482504925050250512505225053250542505525056250572505825059250602506125062250632506425065250662506725068250692507025071250722507325074250752507625077250782507925080250812508225083250842508525086250872508825089250902509125092250932509425095250962509725098250992510025101251022510325104251052510625107251082510925110251112511225113251142511525116251172511825119251202512125122251232512425125251262512725128251292513025131251322513325134251352513625137251382513925140251412514225143251442514525146251472514825149251502515125152251532515425155251562515725158251592516025161251622516325164251652516625167251682516925170251712517225173251742517525176251772517825179251802518125182251832518425185251862518725188251892519025191251922519325194251952519625197251982519925200252012520225203252042520525206252072520825209252102521125212252132521425215252162521725218252192522025221252222522325224252252522625227252282522925230252312523225233252342523525236252372523825239252402524125242252432524425245252462524725248252492525025251252522525325254252552525625257252582525925260252612526225263252642526525266252672526825269252702527125272252732527425275252762527725278252792528025281252822528325284252852528625287252882528925290252912529225293252942529525296252972529825299253002530125302253032530425305253062530725308253092531025311253122531325314253152531625317253182531925320253212532225323253242532525326253272532825329253302533125332253332533425335253362533725338253392534025341253422534325344253452534625347253482534925350253512535225353253542535525356253572535825359253602536125362253632536425365253662536725368253692537025371253722537325374253752537625377253782537925380253812538225383253842538525386253872538825389253902539125392253932539425395253962539725398253992540025401254022540325404254052540625407254082540925410254112541225413254142541525416254172541825419254202542125422254232542425425254262542725428254292543025431254322543325434254352543625437254382543925440254412544225443254442544525446254472544825449254502545125452254532545425455254562545725458254592546025461254622546325464254652546625467254682546925470254712547225473254742547525476254772547825479254802548125482254832548425485254862548725488254892549025491254922549325494254952549625497254982549925500255012550225503255042550525506255072550825509255102551125512255132551425515255162551725518255192552025521255222552325524255252552625527255282552925530255312553225533255342553525536255372553825539255402554125542255432554425545255462554725548255492555025551255522555325554255552555625557255582555925560255612556225563255642556525566255672556825569255702557125572255732557425575255762557725578255792558025581255822558325584255852558625587255882558925590255912559225593255942559525596255972559825599256002560125602256032560425605256062560725608256092561025611256122561325614256152561625617256182561925620256212562225623256242562525626256272562825629256302563125632256332563425635256362563725638256392564025641256422564325644256452564625647256482564925650256512565225653256542565525656256572565825659256602566125662256632566425665256662566725668256692567025671256722567325674256752567625677256782567925680256812568225683256842568525686256872568825689256902569125692256932569425695256962569725698256992570025701257022570325704257052570625707257082570925710257112571225713257142571525716257172571825719257202572125722257232572425725257262572725728257292573025731257322573325734257352573625737257382573925740257412574225743257442574525746257472574825749257502575125752257532575425755257562575725758257592576025761257622576325764257652576625767257682576925770257712577225773257742577525776257772577825779257802578125782257832578425785257862578725788257892579025791257922579325794257952579625797257982579925800258012580225803258042580525806258072580825809258102581125812258132581425815258162581725818258192582025821258222582325824258252582625827258282582925830258312583225833258342583525836258372583825839258402584125842258432584425845258462584725848258492585025851258522585325854258552585625857258582585925860258612586225863258642586525866258672586825869258702587125872258732587425875258762587725878258792588025881258822588325884258852588625887258882588925890258912589225893258942589525896258972589825899259002590125902259032590425905259062590725908259092591025911259122591325914259152591625917259182591925920259212592225923259242592525926259272592825929259302593125932259332593425935259362593725938259392594025941259422594325944259452594625947259482594925950259512595225953259542595525956259572595825959259602596125962259632596425965259662596725968259692597025971259722597325974259752597625977259782597925980259812598225983259842598525986259872598825989259902599125992259932599425995259962599725998259992600026001260022600326004260052600626007260082600926010260112601226013260142601526016260172601826019260202602126022260232602426025260262602726028260292603026031260322603326034260352603626037260382603926040260412604226043260442604526046260472604826049260502605126052260532605426055260562605726058260592606026061260622606326064260652606626067260682606926070260712607226073260742607526076260772607826079260802608126082260832608426085260862608726088260892609026091260922609326094260952609626097260982609926100261012610226103261042610526106261072610826109261102611126112261132611426115261162611726118261192612026121261222612326124261252612626127261282612926130261312613226133261342613526136261372613826139261402614126142261432614426145261462614726148261492615026151261522615326154261552615626157261582615926160261612616226163261642616526166261672616826169261702617126172261732617426175261762617726178261792618026181261822618326184261852618626187261882618926190261912619226193261942619526196261972619826199262002620126202262032620426205262062620726208262092621026211262122621326214262152621626217262182621926220262212622226223262242622526226262272622826229262302623126232262332623426235262362623726238262392624026241262422624326244262452624626247262482624926250262512625226253262542625526256262572625826259262602626126262262632626426265262662626726268262692627026271262722627326274262752627626277262782627926280262812628226283262842628526286262872628826289262902629126292262932629426295262962629726298262992630026301263022630326304263052630626307263082630926310263112631226313263142631526316263172631826319263202632126322263232632426325263262632726328263292633026331263322633326334263352633626337263382633926340263412634226343263442634526346263472634826349263502635126352263532635426355263562635726358263592636026361263622636326364263652636626367263682636926370263712637226373263742637526376263772637826379263802638126382263832638426385263862638726388263892639026391263922639326394263952639626397263982639926400264012640226403264042640526406264072640826409264102641126412264132641426415264162641726418264192642026421264222642326424264252642626427264282642926430264312643226433264342643526436264372643826439264402644126442264432644426445264462644726448264492645026451264522645326454264552645626457264582645926460264612646226463264642646526466264672646826469264702647126472264732647426475264762647726478264792648026481264822648326484264852648626487264882648926490264912649226493264942649526496264972649826499265002650126502265032650426505265062650726508265092651026511265122651326514265152651626517265182651926520265212652226523265242652526526265272652826529265302653126532265332653426535265362653726538265392654026541265422654326544265452654626547265482654926550265512655226553265542655526556265572655826559265602656126562265632656426565265662656726568265692657026571265722657326574265752657626577265782657926580265812658226583265842658526586265872658826589265902659126592265932659426595265962659726598265992660026601266022660326604266052660626607266082660926610266112661226613266142661526616266172661826619266202662126622266232662426625266262662726628266292663026631266322663326634266352663626637266382663926640266412664226643266442664526646266472664826649266502665126652266532665426655266562665726658266592666026661266622666326664266652666626667266682666926670266712667226673266742667526676266772667826679266802668126682266832668426685266862668726688266892669026691266922669326694266952669626697266982669926700267012670226703267042670526706267072670826709267102671126712267132671426715267162671726718267192672026721267222672326724267252672626727267282672926730267312673226733267342673526736267372673826739267402674126742267432674426745267462674726748267492675026751267522675326754267552675626757267582675926760267612676226763267642676526766267672676826769267702677126772267732677426775267762677726778267792678026781267822678326784267852678626787267882678926790267912679226793267942679526796267972679826799268002680126802268032680426805268062680726808268092681026811268122681326814268152681626817268182681926820268212682226823268242682526826268272682826829268302683126832268332683426835268362683726838268392684026841268422684326844268452684626847268482684926850268512685226853268542685526856268572685826859268602686126862268632686426865268662686726868268692687026871268722687326874268752687626877268782687926880268812688226883268842688526886268872688826889268902689126892268932689426895268962689726898268992690026901269022690326904269052690626907269082690926910269112691226913269142691526916269172691826919269202692126922269232692426925269262692726928269292693026931269322693326934269352693626937269382693926940269412694226943269442694526946269472694826949269502695126952269532695426955269562695726958269592696026961269622696326964269652696626967269682696926970269712697226973269742697526976269772697826979269802698126982269832698426985269862698726988269892699026991269922699326994269952699626997269982699927000270012700227003270042700527006270072700827009270102701127012270132701427015270162701727018270192702027021270222702327024270252702627027270282702927030270312703227033270342703527036270372703827039270402704127042270432704427045270462704727048270492705027051270522705327054270552705627057270582705927060270612706227063270642706527066270672706827069270702707127072270732707427075270762707727078270792708027081270822708327084270852708627087270882708927090270912709227093270942709527096270972709827099271002710127102271032710427105271062710727108271092711027111271122711327114271152711627117271182711927120271212712227123271242712527126271272712827129271302713127132271332713427135271362713727138271392714027141271422714327144271452714627147271482714927150271512715227153271542715527156271572715827159271602716127162271632716427165271662716727168271692717027171271722717327174271752717627177271782717927180271812718227183271842718527186271872718827189271902719127192271932719427195271962719727198271992720027201272022720327204272052720627207272082720927210272112721227213272142721527216272172721827219272202722127222272232722427225272262722727228272292723027231272322723327234272352723627237272382723927240272412724227243272442724527246272472724827249272502725127252272532725427255272562725727258272592726027261272622726327264272652726627267272682726927270272712727227273272742727527276272772727827279272802728127282272832728427285272862728727288272892729027291272922729327294272952729627297272982729927300273012730227303273042730527306273072730827309273102731127312273132731427315273162731727318273192732027321273222732327324273252732627327273282732927330273312733227333273342733527336273372733827339273402734127342273432734427345273462734727348273492735027351273522735327354273552735627357273582735927360273612736227363273642736527366273672736827369273702737127372273732737427375273762737727378273792738027381273822738327384273852738627387273882738927390273912739227393273942739527396273972739827399274002740127402274032740427405274062740727408274092741027411274122741327414274152741627417274182741927420274212742227423274242742527426274272742827429274302743127432274332743427435274362743727438274392744027441274422744327444274452744627447274482744927450274512745227453274542745527456274572745827459274602746127462274632746427465274662746727468274692747027471274722747327474274752747627477274782747927480274812748227483274842748527486274872748827489274902749127492274932749427495274962749727498274992750027501275022750327504275052750627507275082750927510275112751227513275142751527516275172751827519275202752127522275232752427525275262752727528275292753027531275322753327534275352753627537275382753927540275412754227543275442754527546275472754827549275502755127552275532755427555275562755727558275592756027561275622756327564275652756627567275682756927570275712757227573275742757527576275772757827579275802758127582275832758427585275862758727588275892759027591275922759327594275952759627597275982759927600276012760227603276042760527606276072760827609276102761127612276132761427615276162761727618276192762027621276222762327624276252762627627276282762927630276312763227633276342763527636276372763827639276402764127642276432764427645276462764727648276492765027651276522765327654276552765627657276582765927660276612766227663276642766527666276672766827669276702767127672276732767427675276762767727678276792768027681276822768327684276852768627687276882768927690276912769227693276942769527696276972769827699277002770127702277032770427705277062770727708277092771027711277122771327714277152771627717277182771927720277212772227723277242772527726277272772827729277302773127732277332773427735277362773727738277392774027741277422774327744277452774627747277482774927750277512775227753277542775527756277572775827759277602776127762277632776427765277662776727768277692777027771277722777327774277752777627777277782777927780277812778227783277842778527786277872778827789277902779127792277932779427795277962779727798277992780027801278022780327804278052780627807278082780927810278112781227813278142781527816278172781827819278202782127822278232782427825278262782727828278292783027831278322783327834278352783627837278382783927840278412784227843278442784527846278472784827849278502785127852278532785427855278562785727858278592786027861278622786327864278652786627867278682786927870278712787227873278742787527876278772787827879278802788127882278832788427885278862788727888278892789027891278922789327894278952789627897278982789927900279012790227903279042790527906279072790827909279102791127912279132791427915279162791727918279192792027921279222792327924279252792627927279282792927930279312793227933279342793527936279372793827939279402794127942279432794427945279462794727948279492795027951279522795327954279552795627957279582795927960279612796227963279642796527966279672796827969279702797127972279732797427975279762797727978279792798027981279822798327984279852798627987279882798927990279912799227993279942799527996279972799827999280002800128002280032800428005280062800728008280092801028011280122801328014280152801628017280182801928020280212802228023280242802528026280272802828029280302803128032280332803428035280362803728038280392804028041280422804328044280452804628047280482804928050280512805228053280542805528056280572805828059280602806128062280632806428065280662806728068280692807028071280722807328074280752807628077280782807928080280812808228083280842808528086280872808828089280902809128092280932809428095280962809728098280992810028101281022810328104281052810628107281082810928110281112811228113281142811528116281172811828119281202812128122281232812428125281262812728128281292813028131281322813328134281352813628137281382813928140281412814228143281442814528146281472814828149281502815128152281532815428155281562815728158281592816028161281622816328164281652816628167281682816928170281712817228173281742817528176281772817828179281802818128182281832818428185281862818728188281892819028191281922819328194281952819628197281982819928200282012820228203282042820528206282072820828209282102821128212282132821428215282162821728218282192822028221282222822328224282252822628227282282822928230282312823228233282342823528236282372823828239282402824128242282432824428245282462824728248282492825028251282522825328254282552825628257282582825928260282612826228263282642826528266282672826828269282702827128272282732827428275282762827728278282792828028281282822828328284282852828628287282882828928290282912829228293282942829528296282972829828299283002830128302283032830428305283062830728308283092831028311283122831328314283152831628317283182831928320283212832228323283242832528326283272832828329283302833128332283332833428335283362833728338283392834028341283422834328344283452834628347283482834928350283512835228353283542835528356283572835828359283602836128362283632836428365283662836728368283692837028371283722837328374283752837628377283782837928380283812838228383283842838528386283872838828389283902839128392283932839428395283962839728398283992840028401284022840328404284052840628407284082840928410284112841228413284142841528416284172841828419284202842128422284232842428425284262842728428284292843028431284322843328434284352843628437284382843928440284412844228443284442844528446284472844828449284502845128452284532845428455284562845728458284592846028461284622846328464284652846628467284682846928470284712847228473284742847528476284772847828479284802848128482284832848428485284862848728488284892849028491284922849328494284952849628497284982849928500285012850228503285042850528506285072850828509285102851128512285132851428515285162851728518285192852028521285222852328524285252852628527285282852928530285312853228533285342853528536285372853828539285402854128542285432854428545285462854728548285492855028551285522855328554285552855628557285582855928560285612856228563285642856528566285672856828569285702857128572285732857428575285762857728578285792858028581285822858328584285852858628587285882858928590285912859228593285942859528596285972859828599286002860128602286032860428605286062860728608286092861028611286122861328614286152861628617286182861928620286212862228623286242862528626286272862828629286302863128632286332863428635286362863728638286392864028641286422864328644286452864628647286482864928650286512865228653286542865528656286572865828659286602866128662286632866428665286662866728668286692867028671286722867328674286752867628677286782867928680286812868228683286842868528686286872868828689286902869128692286932869428695286962869728698286992870028701287022870328704287052870628707287082870928710287112871228713287142871528716287172871828719287202872128722287232872428725287262872728728287292873028731287322873328734287352873628737287382873928740287412874228743287442874528746287472874828749287502875128752287532875428755287562875728758287592876028761287622876328764287652876628767287682876928770287712877228773287742877528776287772877828779287802878128782287832878428785287862878728788287892879028791287922879328794287952879628797287982879928800288012880228803288042880528806288072880828809288102881128812288132881428815288162881728818288192882028821288222882328824288252882628827288282882928830288312883228833288342883528836288372883828839288402884128842288432884428845288462884728848288492885028851288522885328854288552885628857288582885928860288612886228863288642886528866288672886828869288702887128872288732887428875288762887728878288792888028881288822888328884288852888628887288882888928890288912889228893288942889528896288972889828899289002890128902289032890428905289062890728908289092891028911289122891328914289152891628917289182891928920289212892228923289242892528926289272892828929289302893128932289332893428935289362893728938289392894028941289422894328944289452894628947289482894928950289512895228953289542895528956289572895828959289602896128962289632896428965289662896728968289692897028971289722897328974289752897628977289782897928980289812898228983289842898528986289872898828989289902899128992289932899428995289962899728998289992900029001290022900329004290052900629007290082900929010290112901229013290142901529016290172901829019290202902129022290232902429025290262902729028290292903029031290322903329034290352903629037290382903929040290412904229043290442904529046290472904829049290502905129052290532905429055290562905729058290592906029061290622906329064290652906629067290682906929070290712907229073290742907529076290772907829079290802908129082290832908429085290862908729088290892909029091290922909329094290952909629097290982909929100291012910229103291042910529106291072910829109291102911129112291132911429115291162911729118291192912029121291222912329124291252912629127291282912929130291312913229133291342913529136291372913829139291402914129142291432914429145291462914729148291492915029151291522915329154291552915629157291582915929160291612916229163291642916529166291672916829169291702917129172291732917429175291762917729178291792918029181291822918329184291852918629187291882918929190291912919229193291942919529196291972919829199292002920129202292032920429205292062920729208292092921029211292122921329214292152921629217292182921929220292212922229223292242922529226292272922829229292302923129232292332923429235292362923729238292392924029241292422924329244292452924629247292482924929250292512925229253292542925529256292572925829259292602926129262292632926429265292662926729268292692927029271292722927329274292752927629277292782927929280292812928229283292842928529286292872928829289292902929129292292932929429295292962929729298292992930029301293022930329304293052930629307293082930929310293112931229313293142931529316293172931829319293202932129322293232932429325293262932729328293292933029331293322933329334293352933629337293382933929340293412934229343293442934529346293472934829349293502935129352293532935429355293562935729358293592936029361293622936329364293652936629367293682936929370293712937229373293742937529376293772937829379293802938129382293832938429385293862938729388293892939029391293922939329394293952939629397293982939929400294012940229403294042940529406294072940829409294102941129412294132941429415294162941729418294192942029421294222942329424294252942629427294282942929430294312943229433294342943529436294372943829439294402944129442294432944429445294462944729448294492945029451294522945329454294552945629457294582945929460294612946229463294642946529466294672946829469294702947129472294732947429475294762947729478294792948029481294822948329484294852948629487294882948929490294912949229493294942949529496294972949829499295002950129502295032950429505295062950729508295092951029511295122951329514295152951629517295182951929520295212952229523295242952529526295272952829529295302953129532295332953429535295362953729538295392954029541295422954329544295452954629547295482954929550295512955229553295542955529556295572955829559295602956129562295632956429565295662956729568295692957029571295722957329574295752957629577295782957929580295812958229583295842958529586295872958829589295902959129592295932959429595295962959729598295992960029601296022960329604296052960629607296082960929610296112961229613296142961529616296172961829619296202962129622296232962429625296262962729628296292963029631296322963329634296352963629637296382963929640296412964229643296442964529646296472964829649296502965129652296532965429655296562965729658296592966029661296622966329664296652966629667296682966929670296712967229673296742967529676296772967829679296802968129682296832968429685296862968729688296892969029691296922969329694296952969629697296982969929700297012970229703297042970529706297072970829709297102971129712297132971429715297162971729718297192972029721297222972329724297252972629727297282972929730297312973229733297342973529736297372973829739297402974129742297432974429745297462974729748297492975029751297522975329754297552975629757297582975929760297612976229763297642976529766297672976829769297702977129772297732977429775297762977729778297792978029781297822978329784297852978629787297882978929790297912979229793297942979529796297972979829799298002980129802298032980429805298062980729808298092981029811298122981329814298152981629817298182981929820298212982229823298242982529826298272982829829298302983129832298332983429835298362983729838298392984029841298422984329844298452984629847298482984929850298512985229853298542985529856298572985829859298602986129862298632986429865298662986729868298692987029871298722987329874298752987629877298782987929880298812988229883298842988529886298872988829889298902989129892298932989429895298962989729898298992990029901299022990329904299052990629907299082990929910299112991229913299142991529916299172991829919299202992129922299232992429925299262992729928299292993029931299322993329934299352993629937299382993929940299412994229943299442994529946299472994829949299502995129952299532995429955299562995729958299592996029961299622996329964299652996629967299682996929970299712997229973299742997529976299772997829979299802998129982299832998429985299862998729988299892999029991299922999329994299952999629997299982999930000300013000230003300043000530006300073000830009300103001130012300133001430015300163001730018300193002030021300223002330024300253002630027300283002930030300313003230033300343003530036300373003830039300403004130042300433004430045300463004730048300493005030051300523005330054300553005630057300583005930060300613006230063300643006530066300673006830069300703007130072300733007430075300763007730078300793008030081300823008330084300853008630087300883008930090300913009230093300943009530096300973009830099301003010130102301033010430105301063010730108301093011030111301123011330114301153011630117301183011930120301213012230123301243012530126301273012830129301303013130132301333013430135301363013730138301393014030141301423014330144301453014630147301483014930150301513015230153301543015530156301573015830159301603016130162301633016430165301663016730168301693017030171301723017330174301753017630177301783017930180301813018230183301843018530186301873018830189301903019130192301933019430195301963019730198301993020030201302023020330204302053020630207302083020930210302113021230213302143021530216302173021830219302203022130222302233022430225302263022730228302293023030231302323023330234302353023630237302383023930240302413024230243302443024530246302473024830249302503025130252302533025430255302563025730258302593026030261302623026330264302653026630267302683026930270302713027230273302743027530276302773027830279302803028130282302833028430285302863028730288302893029030291302923029330294302953029630297302983029930300303013030230303303043030530306303073030830309303103031130312303133031430315303163031730318303193032030321303223032330324303253032630327303283032930330303313033230333303343033530336303373033830339303403034130342303433034430345303463034730348303493035030351303523035330354303553035630357303583035930360303613036230363303643036530366303673036830369303703037130372303733037430375303763037730378303793038030381303823038330384303853038630387303883038930390303913039230393303943039530396303973039830399304003040130402304033040430405304063040730408304093041030411304123041330414304153041630417304183041930420304213042230423304243042530426304273042830429304303043130432304333043430435304363043730438304393044030441304423044330444304453044630447304483044930450304513045230453304543045530456304573045830459304603046130462304633046430465304663046730468304693047030471304723047330474304753047630477304783047930480304813048230483304843048530486304873048830489304903049130492304933049430495304963049730498304993050030501305023050330504305053050630507305083050930510305113051230513305143051530516305173051830519305203052130522305233052430525305263052730528305293053030531305323053330534305353053630537305383053930540305413054230543305443054530546305473054830549305503055130552305533055430555305563055730558305593056030561305623056330564305653056630567305683056930570305713057230573305743057530576305773057830579305803058130582305833058430585305863058730588305893059030591305923059330594305953059630597305983059930600306013060230603306043060530606306073060830609306103061130612306133061430615306163061730618306193062030621306223062330624306253062630627306283062930630306313063230633306343063530636306373063830639306403064130642306433064430645306463064730648306493065030651306523065330654306553065630657306583065930660306613066230663306643066530666306673066830669306703067130672306733067430675306763067730678306793068030681306823068330684306853068630687306883068930690306913069230693306943069530696306973069830699307003070130702307033070430705307063070730708307093071030711307123071330714307153071630717307183071930720307213072230723307243072530726307273072830729307303073130732307333073430735307363073730738307393074030741307423074330744307453074630747307483074930750307513075230753307543075530756307573075830759307603076130762307633076430765307663076730768307693077030771307723077330774307753077630777307783077930780307813078230783307843078530786307873078830789307903079130792307933079430795307963079730798307993080030801308023080330804308053080630807308083080930810308113081230813308143081530816308173081830819308203082130822308233082430825308263082730828308293083030831308323083330834308353083630837308383083930840308413084230843308443084530846308473084830849308503085130852308533085430855308563085730858308593086030861308623086330864308653086630867308683086930870308713087230873308743087530876308773087830879308803088130882308833088430885308863088730888308893089030891308923089330894308953089630897308983089930900309013090230903309043090530906309073090830909309103091130912309133091430915309163091730918309193092030921309223092330924309253092630927309283092930930309313093230933309343093530936309373093830939309403094130942309433094430945309463094730948309493095030951309523095330954309553095630957309583095930960309613096230963309643096530966309673096830969309703097130972309733097430975309763097730978309793098030981309823098330984309853098630987309883098930990309913099230993309943099530996309973099830999310003100131002310033100431005310063100731008310093101031011310123101331014310153101631017310183101931020310213102231023310243102531026310273102831029310303103131032310333103431035310363103731038310393104031041310423104331044310453104631047310483104931050310513105231053310543105531056310573105831059310603106131062310633106431065310663106731068310693107031071310723107331074310753107631077310783107931080310813108231083310843108531086310873108831089310903109131092310933109431095310963109731098310993110031101311023110331104311053110631107311083110931110311113111231113311143111531116311173111831119311203112131122311233112431125311263112731128311293113031131311323113331134311353113631137311383113931140311413114231143311443114531146311473114831149311503115131152311533115431155311563115731158311593116031161311623116331164311653116631167311683116931170311713117231173311743117531176311773117831179311803118131182311833118431185311863118731188311893119031191311923119331194311953119631197311983119931200312013120231203312043120531206312073120831209312103121131212312133121431215312163121731218312193122031221312223122331224312253122631227312283122931230312313123231233312343123531236312373123831239312403124131242312433124431245312463124731248312493125031251312523125331254312553125631257312583125931260312613126231263312643126531266312673126831269312703127131272312733127431275312763127731278312793128031281312823128331284312853128631287312883128931290312913129231293312943129531296312973129831299313003130131302313033130431305313063130731308313093131031311313123131331314313153131631317313183131931320313213132231323313243132531326313273132831329313303133131332313333133431335313363133731338313393134031341313423134331344313453134631347313483134931350313513135231353313543135531356313573135831359313603136131362313633136431365313663136731368313693137031371313723137331374313753137631377313783137931380313813138231383313843138531386313873138831389313903139131392313933139431395313963139731398313993140031401314023140331404314053140631407314083140931410314113141231413314143141531416314173141831419314203142131422314233142431425314263142731428314293143031431314323143331434314353143631437314383143931440314413144231443314443144531446314473144831449314503145131452314533145431455314563145731458314593146031461314623146331464314653146631467314683146931470314713147231473314743147531476314773147831479314803148131482314833148431485314863148731488314893149031491314923149331494314953149631497314983149931500315013150231503315043150531506315073150831509315103151131512315133151431515315163151731518315193152031521315223152331524315253152631527315283152931530315313153231533315343153531536315373153831539315403154131542315433154431545315463154731548315493155031551315523155331554315553155631557315583155931560315613156231563315643156531566315673156831569315703157131572315733157431575315763157731578315793158031581315823158331584315853158631587315883158931590315913159231593315943159531596315973159831599316003160131602316033160431605316063160731608316093161031611316123161331614316153161631617316183161931620316213162231623316243162531626316273162831629316303163131632316333163431635316363163731638316393164031641316423164331644316453164631647316483164931650316513165231653316543165531656316573165831659316603166131662316633166431665316663166731668316693167031671316723167331674316753167631677316783167931680316813168231683316843168531686316873168831689316903169131692316933169431695316963169731698316993170031701317023170331704317053170631707317083170931710317113171231713317143171531716317173171831719317203172131722317233172431725317263172731728317293173031731317323173331734317353173631737317383173931740317413174231743317443174531746317473174831749317503175131752317533175431755317563175731758317593176031761317623176331764317653176631767317683176931770317713177231773317743177531776317773177831779317803178131782317833178431785317863178731788317893179031791317923179331794317953179631797317983179931800318013180231803318043180531806318073180831809318103181131812318133181431815318163181731818318193182031821318223182331824318253182631827318283182931830318313183231833318343183531836318373183831839318403184131842318433184431845318463184731848318493185031851318523185331854318553185631857318583185931860318613186231863318643186531866318673186831869318703187131872318733187431875318763187731878318793188031881318823188331884318853188631887318883188931890318913189231893318943189531896318973189831899319003190131902319033190431905319063190731908319093191031911319123191331914319153191631917319183191931920319213192231923319243192531926319273192831929319303193131932319333193431935319363193731938319393194031941319423194331944319453194631947319483194931950319513195231953319543195531956319573195831959319603196131962319633196431965319663196731968319693197031971319723197331974319753197631977319783197931980319813198231983319843198531986319873198831989319903199131992319933199431995319963199731998319993200032001320023200332004320053200632007320083200932010320113201232013320143201532016320173201832019320203202132022320233202432025320263202732028320293203032031320323203332034320353203632037320383203932040320413204232043320443204532046320473204832049320503205132052320533205432055320563205732058320593206032061320623206332064320653206632067320683206932070320713207232073320743207532076320773207832079320803208132082320833208432085320863208732088320893209032091320923209332094320953209632097320983209932100321013210232103321043210532106321073210832109321103211132112321133211432115321163211732118321193212032121321223212332124321253212632127321283212932130321313213232133321343213532136321373213832139321403214132142321433214432145321463214732148321493215032151321523215332154321553215632157321583215932160321613216232163321643216532166321673216832169321703217132172321733217432175321763217732178321793218032181321823218332184321853218632187321883218932190321913219232193321943219532196321973219832199322003220132202322033220432205322063220732208322093221032211322123221332214322153221632217322183221932220322213222232223322243222532226322273222832229322303223132232322333223432235322363223732238322393224032241322423224332244322453224632247322483224932250322513225232253322543225532256322573225832259322603226132262322633226432265322663226732268322693227032271322723227332274322753227632277322783227932280322813228232283322843228532286322873228832289322903229132292322933229432295322963229732298322993230032301323023230332304323053230632307323083230932310323113231232313323143231532316323173231832319323203232132322323233232432325323263232732328323293233032331323323233332334323353233632337323383233932340323413234232343323443234532346323473234832349323503235132352323533235432355323563235732358323593236032361323623236332364323653236632367323683236932370323713237232373323743237532376323773237832379323803238132382323833238432385323863238732388323893239032391323923239332394323953239632397323983239932400324013240232403324043240532406324073240832409324103241132412324133241432415324163241732418324193242032421324223242332424324253242632427324283242932430324313243232433324343243532436324373243832439324403244132442324433244432445324463244732448324493245032451324523245332454324553245632457324583245932460324613246232463324643246532466324673246832469324703247132472324733247432475324763247732478324793248032481324823248332484324853248632487324883248932490324913249232493324943249532496324973249832499325003250132502325033250432505325063250732508325093251032511325123251332514325153251632517325183251932520325213252232523325243252532526325273252832529325303253132532325333253432535325363253732538325393254032541325423254332544325453254632547325483254932550325513255232553325543255532556325573255832559325603256132562325633256432565325663256732568325693257032571325723257332574325753257632577325783257932580325813258232583325843258532586325873258832589325903259132592325933259432595325963259732598325993260032601326023260332604326053260632607326083260932610326113261232613326143261532616326173261832619326203262132622326233262432625326263262732628326293263032631326323263332634326353263632637326383263932640326413264232643326443264532646326473264832649326503265132652326533265432655326563265732658326593266032661326623266332664326653266632667326683266932670326713267232673326743267532676326773267832679326803268132682326833268432685326863268732688326893269032691326923269332694326953269632697326983269932700327013270232703327043270532706327073270832709327103271132712327133271432715327163271732718327193272032721327223272332724327253272632727327283272932730327313273232733327343273532736327373273832739327403274132742327433274432745327463274732748327493275032751327523275332754327553275632757327583275932760327613276232763327643276532766327673276832769327703277132772327733277432775327763277732778327793278032781327823278332784327853278632787327883278932790327913279232793327943279532796327973279832799328003280132802328033280432805328063280732808328093281032811328123281332814328153281632817328183281932820328213282232823328243282532826328273282832829328303283132832328333283432835328363283732838328393284032841328423284332844328453284632847328483284932850328513285232853328543285532856328573285832859328603286132862328633286432865328663286732868328693287032871328723287332874328753287632877328783287932880328813288232883328843288532886328873288832889328903289132892328933289432895328963289732898328993290032901329023290332904329053290632907329083290932910329113291232913329143291532916329173291832919329203292132922329233292432925329263292732928329293293032931329323293332934329353293632937329383293932940329413294232943329443294532946329473294832949329503295132952329533295432955329563295732958329593296032961329623296332964329653296632967329683296932970329713297232973329743297532976329773297832979329803298132982329833298432985329863298732988329893299032991329923299332994329953299632997329983299933000330013300233003330043300533006330073300833009330103301133012330133301433015330163301733018330193302033021330223302333024330253302633027330283302933030330313303233033330343303533036330373303833039330403304133042330433304433045330463304733048330493305033051330523305333054330553305633057330583305933060330613306233063330643306533066330673306833069330703307133072330733307433075330763307733078330793308033081330823308333084330853308633087330883308933090330913309233093330943309533096330973309833099331003310133102331033310433105331063310733108331093311033111331123311333114331153311633117331183311933120331213312233123331243312533126331273312833129331303313133132331333313433135331363313733138331393314033141331423314333144331453314633147331483314933150331513315233153331543315533156331573315833159331603316133162331633316433165331663316733168331693317033171331723317333174331753317633177331783317933180331813318233183331843318533186331873318833189331903319133192331933319433195331963319733198331993320033201332023320333204332053320633207332083320933210332113321233213332143321533216332173321833219332203322133222332233322433225332263322733228332293323033231332323323333234332353323633237332383323933240332413324233243332443324533246332473324833249332503325133252332533325433255332563325733258332593326033261332623326333264332653326633267332683326933270332713327233273332743327533276332773327833279332803328133282332833328433285332863328733288332893329033291332923329333294332953329633297332983329933300333013330233303333043330533306333073330833309333103331133312333133331433315333163331733318333193332033321333223332333324333253332633327333283332933330333313333233333333343333533336333373333833339333403334133342333433334433345333463334733348333493335033351333523335333354333553335633357333583335933360333613336233363333643336533366333673336833369333703337133372333733337433375333763337733378333793338033381333823338333384333853338633387333883338933390333913339233393333943339533396333973339833399334003340133402334033340433405334063340733408334093341033411334123341333414334153341633417334183341933420334213342233423334243342533426334273342833429334303343133432334333343433435334363343733438334393344033441334423344333444334453344633447334483344933450334513345233453334543345533456334573345833459334603346133462334633346433465334663346733468334693347033471334723347333474334753347633477334783347933480334813348233483334843348533486334873348833489334903349133492334933349433495334963349733498334993350033501335023350333504335053350633507335083350933510335113351233513335143351533516335173351833519335203352133522335233352433525335263352733528335293353033531335323353333534335353353633537335383353933540335413354233543335443354533546335473354833549335503355133552335533355433555335563355733558335593356033561335623356333564335653356633567335683356933570335713357233573335743357533576335773357833579335803358133582335833358433585335863358733588335893359033591335923359333594335953359633597335983359933600336013360233603336043360533606336073360833609336103361133612336133361433615336163361733618336193362033621336223362333624336253362633627336283362933630336313363233633336343363533636336373363833639336403364133642336433364433645336463364733648336493365033651336523365333654336553365633657336583365933660336613366233663336643366533666336673366833669336703367133672336733367433675336763367733678336793368033681336823368333684336853368633687336883368933690336913369233693336943369533696336973369833699337003370133702337033370433705337063370733708337093371033711337123371333714337153371633717337183371933720337213372233723337243372533726337273372833729337303373133732337333373433735337363373733738337393374033741337423374333744337453374633747337483374933750337513375233753337543375533756337573375833759337603376133762337633376433765337663376733768337693377033771337723377333774337753377633777337783377933780337813378233783337843378533786337873378833789337903379133792337933379433795337963379733798337993380033801338023380333804338053380633807338083380933810338113381233813338143381533816338173381833819338203382133822338233382433825338263382733828338293383033831338323383333834338353383633837338383383933840338413384233843338443384533846338473384833849338503385133852338533385433855338563385733858338593386033861338623386333864338653386633867338683386933870338713387233873338743387533876338773387833879338803388133882338833388433885338863388733888338893389033891338923389333894338953389633897338983389933900339013390233903339043390533906339073390833909339103391133912339133391433915339163391733918339193392033921339223392333924339253392633927339283392933930339313393233933339343393533936339373393833939339403394133942339433394433945339463394733948339493395033951339523395333954339553395633957339583395933960339613396233963339643396533966339673396833969339703397133972339733397433975339763397733978339793398033981339823398333984339853398633987339883398933990339913399233993339943399533996339973399833999340003400134002340033400434005340063400734008340093401034011340123401334014340153401634017340183401934020340213402234023340243402534026340273402834029340303403134032340333403434035340363403734038340393404034041340423404334044340453404634047340483404934050340513405234053340543405534056340573405834059340603406134062340633406434065340663406734068340693407034071340723407334074340753407634077340783407934080340813408234083340843408534086340873408834089340903409134092340933409434095340963409734098340993410034101341023410334104341053410634107341083410934110341113411234113341143411534116341173411834119341203412134122341233412434125341263412734128341293413034131341323413334134341353413634137341383413934140341413414234143341443414534146341473414834149341503415134152341533415434155341563415734158341593416034161341623416334164341653416634167341683416934170341713417234173341743417534176341773417834179341803418134182341833418434185341863418734188341893419034191341923419334194341953419634197341983419934200342013420234203342043420534206342073420834209342103421134212342133421434215342163421734218342193422034221342223422334224342253422634227342283422934230342313423234233342343423534236342373423834239342403424134242342433424434245342463424734248342493425034251342523425334254342553425634257342583425934260342613426234263342643426534266342673426834269342703427134272342733427434275342763427734278342793428034281342823428334284342853428634287342883428934290342913429234293342943429534296342973429834299343003430134302343033430434305343063430734308343093431034311343123431334314343153431634317343183431934320343213432234323343243432534326343273432834329343303433134332343333433434335343363433734338343393434034341343423434334344343453434634347343483434934350343513435234353343543435534356343573435834359343603436134362343633436434365343663436734368343693437034371343723437334374343753437634377343783437934380343813438234383343843438534386343873438834389343903439134392343933439434395343963439734398343993440034401344023440334404344053440634407344083440934410344113441234413344143441534416344173441834419344203442134422344233442434425344263442734428344293443034431344323443334434344353443634437344383443934440344413444234443344443444534446344473444834449344503445134452344533445434455344563445734458344593446034461344623446334464344653446634467344683446934470344713447234473344743447534476344773447834479344803448134482344833448434485344863448734488344893449034491344923449334494344953449634497344983449934500345013450234503345043450534506345073450834509345103451134512345133451434515345163451734518345193452034521345223452334524345253452634527345283452934530345313453234533345343453534536345373453834539345403454134542345433454434545345463454734548345493455034551345523455334554345553455634557345583455934560345613456234563345643456534566345673456834569345703457134572345733457434575345763457734578345793458034581345823458334584345853458634587345883458934590345913459234593345943459534596345973459834599346003460134602346033460434605346063460734608346093461034611346123461334614346153461634617346183461934620346213462234623346243462534626346273462834629346303463134632346333463434635346363463734638346393464034641346423464334644346453464634647346483464934650346513465234653346543465534656346573465834659346603466134662346633466434665346663466734668346693467034671346723467334674346753467634677346783467934680346813468234683346843468534686346873468834689346903469134692346933469434695346963469734698346993470034701347023470334704347053470634707347083470934710347113471234713347143471534716347173471834719347203472134722347233472434725347263472734728347293473034731347323473334734347353473634737347383473934740347413474234743347443474534746347473474834749347503475134752347533475434755347563475734758347593476034761347623476334764347653476634767347683476934770347713477234773347743477534776347773477834779347803478134782347833478434785347863478734788347893479034791347923479334794347953479634797347983479934800348013480234803348043480534806348073480834809348103481134812348133481434815348163481734818348193482034821348223482334824348253482634827348283482934830348313483234833348343483534836348373483834839348403484134842348433484434845348463484734848348493485034851348523485334854348553485634857348583485934860348613486234863348643486534866348673486834869348703487134872348733487434875348763487734878348793488034881348823488334884348853488634887348883488934890348913489234893348943489534896348973489834899349003490134902349033490434905349063490734908349093491034911349123491334914349153491634917349183491934920349213492234923349243492534926349273492834929349303493134932349333493434935349363493734938349393494034941349423494334944349453494634947349483494934950349513495234953349543495534956349573495834959349603496134962349633496434965349663496734968349693497034971349723497334974349753497634977349783497934980349813498234983349843498534986349873498834989349903499134992349933499434995349963499734998349993500035001350023500335004350053500635007350083500935010350113501235013350143501535016350173501835019350203502135022350233502435025350263502735028350293503035031350323503335034350353503635037350383503935040350413504235043350443504535046350473504835049350503505135052350533505435055350563505735058350593506035061350623506335064350653506635067350683506935070350713507235073350743507535076350773507835079350803508135082350833508435085350863508735088350893509035091350923509335094350953509635097350983509935100351013510235103351043510535106351073510835109351103511135112351133511435115351163511735118351193512035121351223512335124351253512635127351283512935130351313513235133351343513535136351373513835139351403514135142351433514435145351463514735148351493515035151351523515335154351553515635157351583515935160351613516235163351643516535166351673516835169351703517135172351733517435175351763517735178351793518035181351823518335184351853518635187351883518935190351913519235193351943519535196351973519835199352003520135202352033520435205352063520735208352093521035211352123521335214352153521635217352183521935220352213522235223352243522535226352273522835229352303523135232352333523435235352363523735238352393524035241352423524335244352453524635247352483524935250352513525235253352543525535256352573525835259352603526135262352633526435265352663526735268352693527035271352723527335274352753527635277352783527935280352813528235283352843528535286352873528835289352903529135292352933529435295352963529735298352993530035301353023530335304353053530635307353083530935310353113531235313353143531535316353173531835319353203532135322353233532435325353263532735328353293533035331353323533335334353353533635337353383533935340353413534235343353443534535346353473534835349353503535135352353533535435355353563535735358353593536035361353623536335364353653536635367353683536935370353713537235373353743537535376353773537835379353803538135382353833538435385353863538735388353893539035391353923539335394353953539635397353983539935400354013540235403354043540535406354073540835409354103541135412354133541435415354163541735418354193542035421354223542335424354253542635427354283542935430354313543235433354343543535436354373543835439354403544135442354433544435445354463544735448354493545035451354523545335454354553545635457354583545935460354613546235463354643546535466354673546835469354703547135472354733547435475354763547735478354793548035481354823548335484354853548635487354883548935490354913549235493354943549535496354973549835499355003550135502355033550435505355063550735508355093551035511355123551335514355153551635517355183551935520355213552235523355243552535526355273552835529355303553135532355333553435535355363553735538355393554035541355423554335544355453554635547355483554935550355513555235553355543555535556355573555835559355603556135562355633556435565355663556735568355693557035571355723557335574355753557635577355783557935580355813558235583355843558535586355873558835589355903559135592355933559435595355963559735598355993560035601356023560335604356053560635607356083560935610356113561235613356143561535616356173561835619356203562135622356233562435625356263562735628356293563035631356323563335634356353563635637356383563935640356413564235643356443564535646356473564835649356503565135652356533565435655356563565735658356593566035661356623566335664356653566635667356683566935670356713567235673356743567535676356773567835679356803568135682356833568435685356863568735688356893569035691356923569335694356953569635697356983569935700357013570235703357043570535706357073570835709357103571135712357133571435715357163571735718357193572035721357223572335724357253572635727357283572935730357313573235733357343573535736357373573835739357403574135742357433574435745357463574735748357493575035751357523575335754357553575635757357583575935760357613576235763357643576535766357673576835769357703577135772357733577435775357763577735778357793578035781357823578335784357853578635787357883578935790357913579235793357943579535796357973579835799358003580135802358033580435805358063580735808358093581035811358123581335814358153581635817358183581935820358213582235823358243582535826358273582835829358303583135832358333583435835358363583735838358393584035841358423584335844358453584635847358483584935850358513585235853358543585535856358573585835859358603586135862358633586435865358663586735868358693587035871358723587335874358753587635877358783587935880358813588235883358843588535886358873588835889358903589135892358933589435895358963589735898358993590035901359023590335904359053590635907359083590935910359113591235913359143591535916359173591835919359203592135922359233592435925359263592735928359293593035931359323593335934359353593635937359383593935940359413594235943359443594535946359473594835949359503595135952359533595435955359563595735958359593596035961359623596335964359653596635967359683596935970359713597235973359743597535976359773597835979359803598135982359833598435985359863598735988359893599035991359923599335994359953599635997359983599936000360013600236003360043600536006360073600836009360103601136012360133601436015360163601736018360193602036021360223602336024360253602636027360283602936030360313603236033360343603536036360373603836039360403604136042360433604436045360463604736048360493605036051360523605336054360553605636057360583605936060360613606236063360643606536066360673606836069360703607136072360733607436075360763607736078360793608036081360823608336084360853608636087360883608936090360913609236093360943609536096360973609836099361003610136102361033610436105361063610736108361093611036111361123611336114361153611636117361183611936120361213612236123361243612536126361273612836129361303613136132361333613436135361363613736138361393614036141361423614336144361453614636147361483614936150361513615236153361543615536156361573615836159361603616136162361633616436165361663616736168361693617036171361723617336174361753617636177361783617936180361813618236183361843618536186361873618836189361903619136192361933619436195361963619736198361993620036201362023620336204362053620636207362083620936210362113621236213362143621536216362173621836219362203622136222362233622436225362263622736228362293623036231362323623336234362353623636237362383623936240362413624236243362443624536246362473624836249362503625136252362533625436255362563625736258362593626036261362623626336264362653626636267362683626936270362713627236273362743627536276362773627836279362803628136282362833628436285362863628736288362893629036291362923629336294362953629636297362983629936300363013630236303363043630536306363073630836309363103631136312363133631436315363163631736318363193632036321363223632336324363253632636327363283632936330363313633236333363343633536336363373633836339363403634136342363433634436345363463634736348363493635036351363523635336354363553635636357363583635936360363613636236363363643636536366363673636836369363703637136372363733637436375363763637736378363793638036381363823638336384363853638636387363883638936390363913639236393363943639536396363973639836399364003640136402364033640436405364063640736408364093641036411364123641336414364153641636417364183641936420364213642236423364243642536426364273642836429364303643136432364333643436435364363643736438364393644036441364423644336444364453644636447364483644936450364513645236453364543645536456364573645836459364603646136462364633646436465364663646736468364693647036471364723647336474364753647636477364783647936480364813648236483364843648536486364873648836489364903649136492364933649436495364963649736498364993650036501365023650336504365053650636507365083650936510365113651236513365143651536516365173651836519365203652136522365233652436525365263652736528365293653036531365323653336534365353653636537365383653936540365413654236543365443654536546365473654836549365503655136552365533655436555365563655736558365593656036561365623656336564365653656636567365683656936570365713657236573365743657536576365773657836579365803658136582365833658436585365863658736588365893659036591365923659336594365953659636597365983659936600366013660236603366043660536606366073660836609366103661136612366133661436615366163661736618366193662036621366223662336624366253662636627366283662936630366313663236633366343663536636366373663836639366403664136642366433664436645366463664736648366493665036651366523665336654366553665636657366583665936660366613666236663366643666536666366673666836669366703667136672366733667436675366763667736678366793668036681366823668336684366853668636687366883668936690366913669236693366943669536696366973669836699367003670136702367033670436705367063670736708367093671036711367123671336714367153671636717367183671936720367213672236723367243672536726367273672836729367303673136732367333673436735367363673736738367393674036741367423674336744367453674636747367483674936750367513675236753367543675536756367573675836759367603676136762367633676436765367663676736768367693677036771367723677336774367753677636777367783677936780367813678236783367843678536786367873678836789367903679136792367933679436795367963679736798367993680036801368023680336804368053680636807368083680936810368113681236813368143681536816368173681836819368203682136822368233682436825368263682736828368293683036831368323683336834368353683636837368383683936840368413684236843368443684536846368473684836849368503685136852368533685436855368563685736858368593686036861368623686336864368653686636867368683686936870368713687236873368743687536876368773687836879368803688136882368833688436885368863688736888368893689036891368923689336894368953689636897368983689936900369013690236903369043690536906369073690836909369103691136912369133691436915369163691736918369193692036921369223692336924369253692636927369283692936930369313693236933369343693536936369373693836939369403694136942369433694436945369463694736948369493695036951369523695336954369553695636957369583695936960369613696236963369643696536966369673696836969369703697136972369733697436975369763697736978369793698036981369823698336984369853698636987369883698936990369913699236993369943699536996369973699836999370003700137002370033700437005370063700737008370093701037011370123701337014370153701637017370183701937020370213702237023370243702537026370273702837029370303703137032370333703437035370363703737038370393704037041370423704337044370453704637047370483704937050370513705237053370543705537056370573705837059370603706137062370633706437065370663706737068370693707037071370723707337074370753707637077370783707937080370813708237083370843708537086370873708837089370903709137092370933709437095370963709737098370993710037101371023710337104371053710637107371083710937110371113711237113371143711537116371173711837119371203712137122371233712437125371263712737128371293713037131371323713337134371353713637137371383713937140371413714237143371443714537146371473714837149371503715137152371533715437155371563715737158371593716037161371623716337164371653716637167371683716937170371713717237173371743717537176371773717837179371803718137182371833718437185371863718737188371893719037191371923719337194371953719637197371983719937200372013720237203372043720537206372073720837209372103721137212372133721437215372163721737218372193722037221372223722337224372253722637227372283722937230372313723237233372343723537236372373723837239372403724137242372433724437245372463724737248372493725037251372523725337254372553725637257372583725937260372613726237263372643726537266372673726837269372703727137272372733727437275372763727737278372793728037281372823728337284372853728637287372883728937290372913729237293372943729537296372973729837299373003730137302373033730437305373063730737308373093731037311373123731337314373153731637317373183731937320373213732237323373243732537326373273732837329373303733137332373333733437335373363733737338373393734037341373423734337344373453734637347373483734937350373513735237353373543735537356373573735837359373603736137362373633736437365373663736737368373693737037371373723737337374373753737637377373783737937380373813738237383373843738537386373873738837389373903739137392373933739437395373963739737398373993740037401374023740337404374053740637407374083740937410374113741237413374143741537416374173741837419374203742137422374233742437425374263742737428374293743037431374323743337434374353743637437374383743937440374413744237443374443744537446374473744837449374503745137452374533745437455374563745737458374593746037461374623746337464374653746637467374683746937470374713747237473374743747537476374773747837479374803748137482374833748437485374863748737488374893749037491374923749337494374953749637497374983749937500375013750237503375043750537506375073750837509375103751137512375133751437515375163751737518375193752037521375223752337524375253752637527375283752937530375313753237533375343753537536375373753837539375403754137542375433754437545375463754737548375493755037551375523755337554375553755637557375583755937560375613756237563375643756537566375673756837569375703757137572375733757437575375763757737578375793758037581375823758337584375853758637587375883758937590375913759237593375943759537596375973759837599376003760137602376033760437605376063760737608376093761037611376123761337614376153761637617376183761937620376213762237623376243762537626376273762837629376303763137632376333763437635376363763737638376393764037641376423764337644376453764637647376483764937650376513765237653376543765537656376573765837659376603766137662376633766437665376663766737668376693767037671376723767337674376753767637677376783767937680376813768237683376843768537686376873768837689376903769137692376933769437695376963769737698376993770037701377023770337704377053770637707377083770937710377113771237713377143771537716377173771837719377203772137722377233772437725377263772737728377293773037731377323773337734377353773637737377383773937740377413774237743377443774537746377473774837749377503775137752377533775437755377563775737758377593776037761377623776337764377653776637767377683776937770377713777237773377743777537776377773777837779377803778137782377833778437785377863778737788377893779037791377923779337794377953779637797377983779937800378013780237803378043780537806378073780837809378103781137812378133781437815378163781737818378193782037821378223782337824378253782637827378283782937830378313783237833378343783537836378373783837839378403784137842378433784437845378463784737848378493785037851378523785337854378553785637857378583785937860378613786237863378643786537866378673786837869378703787137872378733787437875378763787737878378793788037881378823788337884378853788637887378883788937890378913789237893378943789537896378973789837899379003790137902379033790437905379063790737908379093791037911379123791337914379153791637917379183791937920379213792237923379243792537926379273792837929379303793137932379333793437935379363793737938379393794037941379423794337944379453794637947379483794937950379513795237953379543795537956379573795837959379603796137962379633796437965379663796737968379693797037971379723797337974379753797637977379783797937980379813798237983379843798537986379873798837989379903799137992379933799437995379963799737998379993800038001380023800338004380053800638007380083800938010380113801238013380143801538016380173801838019380203802138022380233802438025380263802738028380293803038031380323803338034380353803638037380383803938040380413804238043380443804538046380473804838049380503805138052380533805438055380563805738058380593806038061380623806338064380653806638067380683806938070380713807238073380743807538076380773807838079380803808138082380833808438085380863808738088380893809038091380923809338094380953809638097380983809938100381013810238103381043810538106381073810838109381103811138112381133811438115381163811738118381193812038121381223812338124381253812638127381283812938130381313813238133381343813538136381373813838139381403814138142381433814438145381463814738148381493815038151381523815338154381553815638157381583815938160381613816238163381643816538166381673816838169381703817138172381733817438175381763817738178381793818038181381823818338184381853818638187381883818938190381913819238193381943819538196381973819838199382003820138202382033820438205382063820738208382093821038211382123821338214382153821638217382183821938220382213822238223382243822538226382273822838229382303823138232382333823438235382363823738238382393824038241382423824338244382453824638247382483824938250382513825238253382543825538256382573825838259382603826138262382633826438265382663826738268382693827038271382723827338274382753827638277382783827938280382813828238283382843828538286382873828838289382903829138292382933829438295382963829738298382993830038301383023830338304383053830638307383083830938310383113831238313383143831538316383173831838319383203832138322383233832438325383263832738328383293833038331383323833338334383353833638337383383833938340383413834238343383443834538346383473834838349383503835138352383533835438355383563835738358383593836038361383623836338364383653836638367383683836938370383713837238373383743837538376383773837838379383803838138382383833838438385383863838738388383893839038391383923839338394383953839638397383983839938400384013840238403384043840538406384073840838409384103841138412384133841438415384163841738418384193842038421384223842338424384253842638427384283842938430384313843238433384343843538436384373843838439384403844138442384433844438445384463844738448384493845038451384523845338454384553845638457384583845938460384613846238463384643846538466384673846838469384703847138472384733847438475384763847738478384793848038481384823848338484384853848638487384883848938490384913849238493384943849538496384973849838499385003850138502385033850438505385063850738508385093851038511385123851338514385153851638517385183851938520385213852238523385243852538526385273852838529385303853138532385333853438535385363853738538385393854038541385423854338544385453854638547385483854938550385513855238553385543855538556385573855838559385603856138562385633856438565385663856738568385693857038571385723857338574385753857638577385783857938580385813858238583385843858538586385873858838589385903859138592385933859438595385963859738598385993860038601386023860338604386053860638607386083860938610386113861238613386143861538616386173861838619386203862138622386233862438625386263862738628386293863038631386323863338634386353863638637386383863938640386413864238643386443864538646386473864838649386503865138652386533865438655386563865738658386593866038661386623866338664386653866638667386683866938670386713867238673386743867538676386773867838679386803868138682386833868438685386863868738688386893869038691386923869338694386953869638697386983869938700387013870238703387043870538706387073870838709387103871138712387133871438715387163871738718387193872038721387223872338724387253872638727387283872938730387313873238733387343873538736387373873838739387403874138742387433874438745387463874738748387493875038751387523875338754387553875638757387583875938760387613876238763387643876538766387673876838769387703877138772387733877438775387763877738778387793878038781387823878338784387853878638787387883878938790387913879238793387943879538796387973879838799388003880138802388033880438805388063880738808388093881038811388123881338814388153881638817388183881938820388213882238823388243882538826388273882838829388303883138832388333883438835388363883738838388393884038841388423884338844388453884638847388483884938850388513885238853388543885538856388573885838859388603886138862388633886438865388663886738868388693887038871388723887338874388753887638877388783887938880388813888238883388843888538886388873888838889388903889138892388933889438895388963889738898388993890038901389023890338904389053890638907389083890938910389113891238913389143891538916389173891838919389203892138922389233892438925389263892738928389293893038931389323893338934389353893638937389383893938940389413894238943389443894538946389473894838949389503895138952389533895438955389563895738958389593896038961389623896338964389653896638967389683896938970389713897238973389743897538976389773897838979389803898138982389833898438985389863898738988389893899038991389923899338994389953899638997389983899939000390013900239003390043900539006390073900839009390103901139012390133901439015390163901739018390193902039021390223902339024390253902639027390283902939030390313903239033390343903539036390373903839039390403904139042390433904439045390463904739048390493905039051390523905339054390553905639057390583905939060390613906239063390643906539066390673906839069390703907139072390733907439075390763907739078390793908039081390823908339084390853908639087390883908939090390913909239093390943909539096390973909839099391003910139102391033910439105391063910739108391093911039111391123911339114391153911639117391183911939120391213912239123391243912539126391273912839129391303913139132391333913439135391363913739138391393914039141391423914339144391453914639147391483914939150391513915239153391543915539156391573915839159391603916139162391633916439165391663916739168391693917039171391723917339174391753917639177391783917939180391813918239183391843918539186391873918839189391903919139192391933919439195391963919739198391993920039201392023920339204392053920639207392083920939210392113921239213392143921539216392173921839219392203922139222392233922439225392263922739228392293923039231392323923339234392353923639237392383923939240392413924239243392443924539246392473924839249392503925139252392533925439255392563925739258392593926039261392623926339264392653926639267392683926939270392713927239273392743927539276392773927839279392803928139282392833928439285392863928739288392893929039291392923929339294392953929639297392983929939300393013930239303393043930539306393073930839309393103931139312393133931439315393163931739318393193932039321393223932339324393253932639327393283932939330393313933239333393343933539336393373933839339393403934139342393433934439345393463934739348393493935039351393523935339354393553935639357393583935939360393613936239363393643936539366393673936839369393703937139372393733937439375393763937739378393793938039381393823938339384393853938639387393883938939390393913939239393393943939539396393973939839399394003940139402394033940439405394063940739408394093941039411394123941339414394153941639417394183941939420394213942239423394243942539426394273942839429394303943139432394333943439435394363943739438394393944039441394423944339444394453944639447394483944939450394513945239453394543945539456394573945839459394603946139462394633946439465394663946739468394693947039471394723947339474394753947639477394783947939480394813948239483394843948539486394873948839489394903949139492394933949439495394963949739498394993950039501395023950339504395053950639507395083950939510395113951239513395143951539516395173951839519395203952139522395233952439525395263952739528395293953039531395323953339534395353953639537395383953939540395413954239543395443954539546395473954839549395503955139552395533955439555395563955739558395593956039561395623956339564395653956639567395683956939570395713957239573395743957539576395773957839579395803958139582395833958439585395863958739588395893959039591395923959339594395953959639597395983959939600396013960239603396043960539606396073960839609396103961139612396133961439615396163961739618396193962039621396223962339624396253962639627396283962939630396313963239633396343963539636396373963839639396403964139642396433964439645396463964739648396493965039651396523965339654396553965639657396583965939660396613966239663396643966539666396673966839669396703967139672396733967439675396763967739678396793968039681396823968339684396853968639687396883968939690396913969239693396943969539696396973969839699397003970139702397033970439705397063970739708397093971039711397123971339714397153971639717397183971939720397213972239723397243972539726397273972839729397303973139732397333973439735397363973739738397393974039741397423974339744397453974639747397483974939750397513975239753397543975539756397573975839759397603976139762397633976439765397663976739768397693977039771397723977339774397753977639777397783977939780397813978239783397843978539786397873978839789397903979139792397933979439795397963979739798397993980039801398023980339804398053980639807398083980939810398113981239813398143981539816398173981839819398203982139822398233982439825398263982739828398293983039831398323983339834398353983639837398383983939840398413984239843398443984539846398473984839849398503985139852398533985439855398563985739858398593986039861398623986339864398653986639867398683986939870398713987239873398743987539876398773987839879398803988139882398833988439885398863988739888398893989039891398923989339894398953989639897398983989939900399013990239903399043990539906399073990839909399103991139912399133991439915399163991739918399193992039921399223992339924399253992639927399283992939930399313993239933399343993539936399373993839939399403994139942399433994439945399463994739948399493995039951399523995339954399553995639957399583995939960399613996239963399643996539966399673996839969399703997139972399733997439975399763997739978399793998039981399823998339984399853998639987399883998939990399913999239993399943999539996399973999839999400004000140002400034000440005400064000740008400094001040011400124001340014400154001640017400184001940020400214002240023400244002540026400274002840029400304003140032400334003440035400364003740038400394004040041400424004340044400454004640047400484004940050400514005240053400544005540056400574005840059400604006140062400634006440065400664006740068400694007040071400724007340074400754007640077400784007940080400814008240083400844008540086400874008840089400904009140092400934009440095400964009740098400994010040101401024010340104401054010640107401084010940110401114011240113401144011540116401174011840119401204012140122401234012440125401264012740128401294013040131401324013340134401354013640137401384013940140401414014240143401444014540146401474014840149401504015140152401534015440155401564015740158401594016040161401624016340164401654016640167401684016940170401714017240173401744017540176401774017840179401804018140182401834018440185401864018740188401894019040191401924019340194401954019640197401984019940200402014020240203402044020540206402074020840209402104021140212402134021440215402164021740218402194022040221402224022340224402254022640227402284022940230402314023240233402344023540236402374023840239402404024140242402434024440245402464024740248402494025040251402524025340254402554025640257402584025940260402614026240263402644026540266402674026840269402704027140272402734027440275402764027740278402794028040281402824028340284402854028640287402884028940290402914029240293402944029540296402974029840299403004030140302403034030440305403064030740308403094031040311403124031340314403154031640317403184031940320403214032240323403244032540326403274032840329403304033140332403334033440335403364033740338403394034040341403424034340344403454034640347403484034940350403514035240353403544035540356403574035840359403604036140362403634036440365403664036740368403694037040371403724037340374403754037640377403784037940380403814038240383403844038540386403874038840389403904039140392403934039440395403964039740398403994040040401404024040340404404054040640407404084040940410404114041240413404144041540416404174041840419404204042140422404234042440425404264042740428404294043040431404324043340434404354043640437404384043940440404414044240443404444044540446404474044840449404504045140452404534045440455404564045740458404594046040461404624046340464404654046640467404684046940470404714047240473404744047540476404774047840479404804048140482404834048440485404864048740488404894049040491404924049340494404954049640497404984049940500405014050240503405044050540506405074050840509405104051140512405134051440515405164051740518405194052040521405224052340524405254052640527405284052940530405314053240533405344053540536405374053840539405404054140542405434054440545405464054740548405494055040551405524055340554405554055640557405584055940560405614056240563405644056540566405674056840569405704057140572405734057440575405764057740578405794058040581405824058340584405854058640587405884058940590405914059240593405944059540596405974059840599406004060140602406034060440605406064060740608406094061040611406124061340614406154061640617406184061940620406214062240623406244062540626406274062840629406304063140632406334063440635406364063740638406394064040641406424064340644406454064640647406484064940650406514065240653406544065540656406574065840659406604066140662406634066440665406664066740668406694067040671406724067340674406754067640677406784067940680406814068240683406844068540686406874068840689406904069140692406934069440695406964069740698406994070040701407024070340704407054070640707407084070940710407114071240713407144071540716407174071840719407204072140722407234072440725407264072740728407294073040731407324073340734407354073640737407384073940740407414074240743407444074540746407474074840749407504075140752407534075440755407564075740758407594076040761407624076340764407654076640767407684076940770407714077240773407744077540776407774077840779407804078140782407834078440785407864078740788407894079040791407924079340794407954079640797407984079940800408014080240803408044080540806408074080840809408104081140812408134081440815408164081740818408194082040821408224082340824408254082640827408284082940830408314083240833408344083540836408374083840839408404084140842408434084440845408464084740848408494085040851408524085340854408554085640857408584085940860408614086240863408644086540866408674086840869408704087140872408734087440875408764087740878408794088040881408824088340884408854088640887408884088940890408914089240893408944089540896408974089840899409004090140902409034090440905409064090740908409094091040911409124091340914409154091640917409184091940920409214092240923409244092540926409274092840929409304093140932409334093440935409364093740938409394094040941409424094340944409454094640947409484094940950409514095240953409544095540956409574095840959409604096140962409634096440965409664096740968409694097040971409724097340974409754097640977409784097940980409814098240983409844098540986409874098840989409904099140992409934099440995409964099740998409994100041001410024100341004410054100641007410084100941010410114101241013410144101541016410174101841019410204102141022410234102441025410264102741028410294103041031410324103341034410354103641037410384103941040410414104241043410444104541046410474104841049410504105141052410534105441055410564105741058410594106041061410624106341064410654106641067410684106941070410714107241073410744107541076410774107841079410804108141082410834108441085410864108741088410894109041091410924109341094410954109641097410984109941100411014110241103411044110541106411074110841109411104111141112411134111441115411164111741118411194112041121411224112341124411254112641127411284112941130411314113241133411344113541136411374113841139411404114141142411434114441145411464114741148411494115041151411524115341154411554115641157411584115941160411614116241163411644116541166411674116841169411704117141172411734117441175411764117741178411794118041181411824118341184411854118641187411884118941190411914119241193411944119541196411974119841199412004120141202412034120441205412064120741208412094121041211412124121341214412154121641217412184121941220412214122241223412244122541226412274122841229412304123141232412334123441235412364123741238412394124041241412424124341244412454124641247412484124941250412514125241253412544125541256412574125841259412604126141262412634126441265412664126741268412694127041271412724127341274412754127641277412784127941280412814128241283412844128541286412874128841289412904129141292412934129441295412964129741298412994130041301413024130341304413054130641307413084130941310413114131241313413144131541316413174131841319413204132141322413234132441325413264132741328413294133041331413324133341334413354133641337413384133941340413414134241343413444134541346413474134841349413504135141352413534135441355413564135741358413594136041361413624136341364413654136641367413684136941370413714137241373413744137541376413774137841379413804138141382413834138441385413864138741388413894139041391413924139341394413954139641397413984139941400414014140241403414044140541406414074140841409414104141141412414134141441415414164141741418414194142041421414224142341424414254142641427414284142941430414314143241433414344143541436414374143841439414404144141442414434144441445414464144741448414494145041451414524145341454414554145641457414584145941460414614146241463414644146541466414674146841469414704147141472414734147441475414764147741478414794148041481414824148341484414854148641487414884148941490414914149241493414944149541496414974149841499415004150141502415034150441505415064150741508415094151041511415124151341514415154151641517415184151941520415214152241523415244152541526415274152841529415304153141532415334153441535415364153741538415394154041541415424154341544415454154641547415484154941550415514155241553415544155541556415574155841559415604156141562415634156441565415664156741568415694157041571415724157341574415754157641577415784157941580415814158241583415844158541586415874158841589415904159141592415934159441595415964159741598415994160041601416024160341604416054160641607416084160941610416114161241613416144161541616416174161841619416204162141622416234162441625416264162741628416294163041631416324163341634416354163641637416384163941640416414164241643416444164541646416474164841649416504165141652 |
- 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 = 45);
- /******/ })
- /************************************************************************/
- /******/ ([
- /* 0 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/date-util");
- /***/ }),
- /* 1 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/dom");
- /***/ }),
- /* 2 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/util");
- /***/ }),
- /* 3 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/mixins/emitter");
- /***/ }),
- /* 4 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/mixins/locale");
- /***/ }),
- /* 5 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/vue-popper");
- /***/ }),
- /* 6 */
- /***/ (function(module, exports) {
- module.exports = require("vue");
- /***/ }),
- /* 7 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/merge");
- /***/ }),
- /* 8 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/input");
- /***/ }),
- /* 9 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/mixins/migrating");
- /***/ }),
- /* 10 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/clickoutside");
- /***/ }),
- /* 11 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/button");
- /***/ }),
- /* 12 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/resize-event");
- /***/ }),
- /* 13 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/popup");
- /***/ }),
- /* 14 */
- /***/ (function(module, exports) {
- module.exports = require("throttle-debounce/debounce");
- /***/ }),
- /* 15 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/locale");
- /***/ }),
- /* 16 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/checkbox");
- /***/ }),
- /* 17 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/scrollbar");
- /***/ }),
- /* 18 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/types");
- /***/ }),
- /* 19 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/shared");
- /***/ }),
- /* 20 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/date");
- /***/ }),
- /* 21 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/transitions/collapse-transition");
- /***/ }),
- /* 22 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/mixins/focus");
- /***/ }),
- /* 23 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/vdom");
- /***/ }),
- /* 24 */
- /***/ (function(module, exports) {
- module.exports = require("babel-helper-vue-jsx-merge-props");
- /***/ }),
- /* 25 */
- /***/ (function(module, exports) {
- module.exports = require("throttle-debounce/throttle");
- /***/ }),
- /* 26 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/tooltip");
- /***/ }),
- /* 27 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/scroll-into-view");
- /***/ }),
- /* 28 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/button-group");
- /***/ }),
- /* 29 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/tag");
- /***/ }),
- /* 30 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/scrollbar-width");
- /***/ }),
- /* 31 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/checkbox-group");
- /***/ }),
- /* 32 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/after-leave");
- /***/ }),
- /* 33 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/progress");
- /***/ }),
- /* 34 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/aria-utils");
- /***/ }),
- /* 35 */
- /***/ (function(module, exports) {
- module.exports = require("throttle-debounce");
- /***/ }),
- /* 36 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/select");
- /***/ }),
- /* 37 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/option");
- /***/ }),
- /* 38 */
- /***/ (function(module, exports) {
- module.exports = require("normalize-wheel");
- /***/ }),
- /* 39 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/utils/aria-dialog");
- /***/ }),
- /* 40 */
- /***/ (function(module, exports) {
- module.exports = require("async-validator");
- /***/ }),
- /* 41 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/input-number");
- /***/ }),
- /* 42 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/cascader-panel");
- /***/ }),
- /* 43 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/radio");
- /***/ }),
- /* 44 */
- /***/ (function(module, exports) {
- module.exports = require("element-ui/lib/popover");
- /***/ }),
- /* 45 */
- /***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(46);
- /***/ }),
- /* 46 */
- /***/ (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__(36);
- var select_default = /*#__PURE__*/__webpack_require__.n(select_);
- // EXTERNAL MODULE: external "element-ui/lib/option"
- var option_ = __webpack_require__(37);
- 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__(13);
- 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__(14);
- 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__(17);
- 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__(22);
- 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__(11);
- var button_default = /*#__PURE__*/__webpack_require__.n(button_);
- // EXTERNAL MODULE: external "element-ui/lib/button-group"
- var button_group_ = __webpack_require__(28);
- 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
- }
- },
- 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.triggerElm.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.triggerElm.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.triggerElm.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;
- var handleMainButtonClick = function handleMainButtonClick(event) {
- _this4.$emit('click', event);
- hide();
- };
- var triggerElm = !splitButton ? this.$slots.default : h('el-button-group', [h(
- 'el-button',
- {
- attrs: { type: type, size: dropdownSize },
- nativeOn: {
- 'click': handleMainButtonClick
- }
- },
- [this.$slots.default]
- ), h(
- 'el-button',
- { ref: 'trigger', attrs: { type: type, size: dropdownSize },
- 'class': 'el-dropdown__caret-button' },
- [h('i', { 'class': 'el-dropdown__icon el-icon-arrow-down' })]
- )]);
- return h(
- 'div',
- { 'class': 'el-dropdown', directives: [{
- name: 'clickoutside',
- value: hide
- }]
- },
- [triggerElm, this.$slots.dropdown]
- );
- }
- });
- // 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() {
- this.isComposing = true;
- },
- handleCompositionUpdate: function handleCompositionUpdate(event) {
- var text = event.target.value;
- var lastCharacter = text[text.length - 1] || '';
- this.isComposing = !Object(shared_["isKorean"])(lastCharacter);
- },
- handleCompositionEnd: function handleCompositionEnd(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() {
- this.passwordVisible = !this.passwordVisible;
- this.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 handler = function handler() {
- return vnode.context[binding.expression].apply();
- };
- var clear = function clear() {
- if (Date.now() - startTime < 100) {
- 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, 100);
- });
- }
- });
- // 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"
- },
- 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() {
- return (this.$vnode.data || {}).tag || 'div';
- },
- 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"
- },
- 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
- _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.navigateOptions("next")
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "up", 38, $event.key, [
- "Up",
- "ArrowUp"
- ])
- ) {
- return null
- }
- $event.preventDefault()
- _vm.navigateOptions("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 },
- nativeOn: {
- keyup: function($event) {
- return _vm.debouncedOnInputChange($event)
- },
- keydown: [
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "down", 40, $event.key, [
- "Down",
- "ArrowDown"
- ])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.navigateOptions("next")
- },
- function($event) {
- if (
- !("button" in $event) &&
- _vm._k($event.keyCode, "up", 38, $event.key, [
- "Up",
- "ArrowUp"
- ])
- ) {
- return null
- }
- $event.stopPropagation()
- $event.preventDefault()
- _vm.navigateOptions("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
- }
- ],
- paste: function($event) {
- return _vm.debouncedOnInputChange($event)
- },
- 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__(29);
- var tag_default = /*#__PURE__*/__webpack_require__.n(tag_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/resize-event"
- var resize_event_ = __webpack_require__(12);
- // 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: {
- 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 ? 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) {
- this.visible = true;
- if (this.filterable) {
- this.menuVisibleOnFocus = 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 sizeInMap = _this10.initialInputHeight || 40;
- input.style.height = _this10.selected.length === 0 ? sizeInMap + 'px' : Math.max(tags ? tags.clientHeight + (tags.clientHeight > 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.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__(16);
- var checkbox_default = /*#__PURE__*/__webpack_require__.n(checkbox_);
- // EXTERNAL MODULE: external "throttle-debounce"
- var external_throttle_debounce_ = __webpack_require__(35);
- // EXTERNAL MODULE: external "normalize-wheel"
- var external_normalize_wheel_ = __webpack_require__(38);
- 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);
- }
- });
- }
- // 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 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 _states6 = this.states,
- lazyTreeNodeMap = _states6.lazyTreeNodeMap,
- treeData = _states6.treeData;
- if (load && !treeData[key].loaded) {
- treeData[key].loading = true;
- load(row, treeNode, function (data) {
- if (!Array.isArray(data)) {
- throw new Error('[ElTable] data must be an array');
- }
- 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, 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__(30);
- 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-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
- },
- 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';
- });
- }
- }), {
- 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 _this2 = 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 = _this2.$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 classes = ['el-table__row'];
- if (this.table.highlightCurrentRow && row === this.store.states.currentRow) {
- classes.push('current-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
- }));
- }
- 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 _this3 = this;
- var h = this.$createElement;
- var treeIndent = this.treeIndent,
- columns = this.columns,
- firstDefaultColumnIndex = this.firstDefaultColumnIndex;
- var columnsHidden = columns.map(function (column, index) {
- return _this3.isColumnHidden(index);
- });
- 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(
- 'tr',
- {
- style: [displayStyle, this.getRowStyle(row, $index)],
- 'class': rowClasses,
- key: this.getKeyOfRow(row, $index),
- on: {
- 'dblclick': function dblclick($event) {
- return _this3.handleDoubleClick($event, row);
- },
- 'click': function click($event) {
- return _this3.handleClick($event, row);
- },
- 'contextmenu': function contextmenu($event) {
- return _this3.handleContextMenu($event, row);
- },
- 'mouseenter': function mouseenter(_) {
- return _this3.handleMouseEnter($index);
- },
- 'mouseleave': this.handleMouseLeave
- }
- },
- [columns.map(function (column, cellIndex) {
- var _getSpan = _this3.getSpan(row, column, $index, cellIndex),
- rowspan = _getSpan.rowspan,
- colspan = _getSpan.colspan;
- if (!rowspan || !colspan) {
- return null;
- }
- var columnData = table_body_extends({}, column);
- columnData.realWidth = _this3.getColspanRealWidth(columns, colspan, cellIndex);
- var data = {
- store: _this3.store,
- _self: _this3.context || _this3.table.$vnode.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: _this3.getCellStyle($index, cellIndex, row, column),
- 'class': _this3.getCellClass($index, cellIndex, row, column),
- attrs: { rowspan: rowspan,
- colspan: colspan
- },
- on: {
- 'mouseenter': function mouseenter($event) {
- return _this3.handleCellMouseEnter($event, row);
- },
- 'mouseleave': _this3.handleCellMouseLeave
- }
- },
- [column.renderCell.call(_this3._renderProxy, _this3.$createElement, data, columnsHidden[cellIndex])]
- );
- })]
- );
- },
- wrappedRowRender: function wrappedRowRender(row, $index) {
- var _this4 = 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__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(_this4.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__(31);
- 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': '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
- }));
- }
- return classes.join(' ');
- },
- toggleAllSelection: function toggleAllSelection(event) {
- event.stopPropagation();
- 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': _this.getRowClasses(column, cellIndex) },
- [h(
- 'div',
- { 'class': ['cell', column.labelClassName] },
- [sums[cellIndex]]
- )]
- );
- }), this.hasGutter ? h('th', { 'class': '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,
- 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: Object(external_throttle_debounce_["throttle"])(20, function () {
- 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';
- }
- }),
- bindEvents: function bindEvents() {
- this.bodyWrapper.addEventListener('scroll', this.syncPostion, { passive: true });
- if (this.fit) {
- Object(resize_event_["addResizeListener"])(this.$el, this.resizeListener);
- }
- },
- unbindEvents: function unbindEvents() {
- this.bodyWrapper.removeEventListener('scroll', this.syncPostion, { 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 },
- nativeOn: {
- 'click': this.toggleAllSelection
- }
- });
- },
- renderCell: function renderCell(h, _ref2) {
- var row = _ref2.row,
- column = _ref2.column,
- store = _ref2.store,
- $index = _ref2.$index;
- return h('el-checkbox', {
- nativeOn: {
- 'click': function click(event) {
- return event.stopPropagation();
- }
- },
- attrs: {
- value: store.isSelected(row),
- 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;
- var classes = ['el-table__expand-icon'];
- if (store.states.expandRows.indexOf(row) > -1) {
- 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",
- 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
- },
- 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',
- 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'
- };
- var HAVE_TRIGGER_TYPES = ['date', 'datetime', 'time', 'time-select', 'week', 'month', 'year', 'daterange', 'monthrange', 'timerange', 'datetimerange', 'dates'];
- 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);
- });
- }
- }
- };
- 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';
- }
- 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' ? 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') {
- // 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: {
- 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: {
- 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",
- expression: "footerVisible && currentView === 'date'"
- }
- ],
- staticClass: "el-picker-panel__footer"
- },
- [
- _c(
- "el-button",
- {
- directives: [
- {
- name: "show",
- rawName: "v-show",
- value: _vm.selectionMode !== "dates",
- expression: "selectionMode !== 'dates'"
- }
- ],
- 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 bindFuntion = function bindFuntion(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);
- };
- };
- bindFuntion('hours');
- bindFuntion('minutes');
- bindFuntion('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: {}
- },
- 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;
- 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;
- }
- };
- /* 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 {
- 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 (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';
- }
- }
- },
- 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 {
- 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 {
- 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.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.currentView = 'month';
- } else if (this.selectionMode === 'year') {
- 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';
- },
- 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];
- };
- }
- 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__(15);
- var lib_locale_default = /*#__PURE__*/__webpack_require__.n(lib_locale_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/aria-dialog"
- var aria_dialog_ = __webpack_require__(39);
- 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__(23);
- // 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) {
- valid ? resolve(valid) : reject(valid);
- };
- });
- }
- 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__(40);
- 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;
- }
- },
- 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 tag = (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 = (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) 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.loaded = true;
- _this5.loading = false;
- _this5.childNodes = [];
- _this5.doCreateChildren(children, defaultProps);
- _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__(41);
- 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__(32);
- 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') {
- 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') {
- 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: {
- type: String,
- default: 'top'
- }
- },
- 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 !== 'top' ? '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__(33);
- 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" }
- },
- [
- _c(
- "div",
- {
- staticClass: "el-progress-bar__inner",
- style: _vm.barStyle
- },
- [
- _vm.showText && _vm.textInside
- ? _c(
- "div",
- { staticClass: "el-progress-bar__innerText" },
- [_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: "#e5e9f2",
- "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" }
- },
- [
- !_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: ''
- },
- 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);
- // CONCATENATED MODULE: ./packages/message/src/main.js
- 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 (typeof options === 'string') {
- options = {
- message: options
- };
- }
- options.type = type;
- return main_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: [
- "el-badge__content--" + _vm.type,
- {
- "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&
- // EXTERNAL MODULE: external "element-ui/lib/utils/types"
- var types_ = __webpack_require__(18);
- // 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 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);
- }
- },
- 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);
- },
- 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);
- }
- },
- 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.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, index) {
- 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(index)
- }
- }
- },
- [_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__(42);
- var cascader_panel_default = /*#__PURE__*/__webpack_require__.n(cascader_panel_);
- // EXTERNAL MODULE: external "element-ui/lib/utils/aria-utils"
- var aria_utils_ = __webpack_require__(34);
- 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
- },
- 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 || null,
- 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 (!Object(util_["isEmpty"])(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;
- },
- 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();
- }
- });
- },
- computePresentText: function computePresentText() {
- var checkedValue = this.checkedValue,
- config = this.config;
- if (!Object(util_["isEmpty"])(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(lastIndex);
- } 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(index) {
- var checkedValue = this.checkedValue;
- var val = checkedValue[index];
- this.checkedValue = checkedValue.filter(function (n, i) {
- return i !== index;
- });
- 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 = tags.offsetHeight;
- var height = Math.max(offsetHeight + 6, inputInitialHeight) + 'px';
- inputInner.style.height = height;
- 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}$/.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.zIndex },
- 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;
- }
- },
- 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 = Object(util_["rafThrottle"])(function (e) {
- 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
- }
- },
- 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 srcIndex = this.previewSrcList.indexOf(this.src);
- if (srcIndex >= 0) {
- previewIndex = srcIndex;
- }
- 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 vertical = imageWidth / imageHeight < 1;
- 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 vertical ? { width: 'auto' } : { height: 'auto' };
- case ObjectFit.COVER:
- return vertical ? { 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'],
- data: function data() {
- return {
- WEEK_DAYS: Object(date_util_["getI18nSettings"])().dayNames
- };
- },
- 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: {
- 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 prevMonthDays = Object(date_util_["getPrevMonthLastDays"])(date, firstDay - firstDayOfWeek).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__(43);
- 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) {
- if (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 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: {
- options: {
- handler: function handler() {
- this.initStore();
- },
- immediate: true,
- deep: true
- },
- value: function value() {
- this.syncCheckedValue();
- this.checkStrictly && this.calculateCheckedNodePaths();
- },
- 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 (!Object(util_["isEmpty"])(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.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);
- });
- },
- 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 (!Object(util_["isEmpty"])(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 Object(util_["isEmpty"])(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.size
- : "height: " + _vm.size,
- 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: 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';
- }
- },
- 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');
- 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();
- }
- },
- 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/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__(44);
- 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: ./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, 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, popconfirm, 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.0',
- 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: 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,
- Popconfirm: popconfirm
- });
- /***/ })
- /******/ ])["default"];
|